hablas-ai 1.1.0 → 1.1.2
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 +151 -155
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -1,46 +1,46 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var oy=Object.create;var
|
|
2
|
+
"use strict";var oy=Object.create;var Ss=Object.defineProperty;var ay=Object.getOwnPropertyDescriptor;var ly=Object.getOwnPropertyNames;var cy=Object.getPrototypeOf,uy=Object.prototype.hasOwnProperty;var N=(n,e)=>()=>(n&&(e=n(n=0)),e);var j=(n,e)=>()=>(e||n((e={exports:{}}).exports,e),e.exports),Ne=(n,e)=>{for(var t in e)Ss(n,t,{get:e[t],enumerable:!0})},sc=(n,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of ly(e))!uy.call(n,r)&&r!==t&&Ss(n,r,{get:()=>e[r],enumerable:!(s=ay(e,r))||s.enumerable});return n};var O=(n,e,t)=>(t=n!=null?oy(cy(n)):{},sc(e||!n||!n.__esModule?Ss(t,"default",{value:n,enumerable:!0}):t,n)),dy=n=>sc(Ss({},"__esModule",{value:!0}),n);var Ln=j(ei=>{var _s=class extends Error{constructor(e,t,s){super(s),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name,this.code=t,this.exitCode=e,this.nestedError=void 0}},Zr=class extends _s{constructor(e){super(1,"commander.invalidArgument",e),Error.captureStackTrace(this,this.constructor),this.name=this.constructor.name}};ei.CommanderError=_s;ei.InvalidArgumentError=Zr});var As=j(ni=>{var{InvalidArgumentError:fy}=Ln(),ti=class{constructor(e,t){switch(this.description=t||"",this.variadic=!1,this.parseArg=void 0,this.defaultValue=void 0,this.defaultValueDescription=void 0,this.argChoices=void 0,e[0]){case"<":this.required=!0,this._name=e.slice(1,-1);break;case"[":this.required=!1,this._name=e.slice(1,-1);break;default:this.required=!0,this._name=e;break}this._name.length>3&&this._name.slice(-3)==="..."&&(this.variadic=!0,this._name=this._name.slice(0,-3))}name(){return this._name}_concatValue(e,t){return t===this.defaultValue||!Array.isArray(t)?[e]:t.concat(e)}default(e,t){return this.defaultValue=e,this.defaultValueDescription=t,this}argParser(e){return this.parseArg=e,this}choices(e){return this.argChoices=e.slice(),this.parseArg=(t,s)=>{if(!this.argChoices.includes(t))throw new fy(`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 py(n){let e=n.name()+(n.variadic===!0?"...":"");return n.required?"<"+e+">":"["+e+"]"}ni.Argument=ti;ni.humanReadableArgName=py});var ri=j(rc=>{var{humanReadableArgName:hy}=As(),si=class{constructor(){this.helpWidth=void 0,this.sortSubcommands=!1,this.sortOptions=!1,this.showGlobalOptions=!1}visibleCommands(e){let t=e.commands.filter(r=>!r._hidden),s=e._getHelpCommand();return s&&!s._hidden&&t.push(s),this.sortSubcommands&&t.sort((r,i)=>r.name().localeCompare(i.name())),t}compareOptions(e,t){let s=r=>r.short?r.short.replace(/^-/,""):r.long.replace(/^--/,"");return s(e).localeCompare(s(t))}visibleOptions(e){let t=e.options.filter(r=>!r.hidden),s=e._getHelpOption();if(s&&!s.hidden){let r=s.short&&e._findOption(s.short),i=s.long&&e._findOption(s.long);!r&&!i?t.push(s):s.long&&!i?t.push(e.createOption(s.long,s.description)):s.short&&!r&&t.push(e.createOption(s.short,s.description))}return this.sortOptions&&t.sort(this.compareOptions),t}visibleGlobalOptions(e){if(!this.showGlobalOptions)return[];let t=[];for(let s=e.parent;s;s=s.parent){let r=s.options.filter(i=>!i.hidden);t.push(...r)}return this.sortOptions&&t.sort(this.compareOptions),t}visibleArguments(e){return e._argsDescription&&e.registeredArguments.forEach(t=>{t.description=t.description||e._argsDescription[t.name()]||""}),e.registeredArguments.find(t=>t.description)?e.registeredArguments:[]}subcommandTerm(e){let t=e.registeredArguments.map(s=>hy(s)).join(" ");return e._name+(e._aliases[0]?"|"+e._aliases[0]:"")+(e.options.length?" [options]":"")+(t?" "+t:"")}optionTerm(e){return e.flags}argumentTerm(e){return e.name()}longestSubcommandTermLength(e,t){return t.visibleCommands(e).reduce((s,r)=>Math.max(s,t.subcommandTerm(r).length),0)}longestOptionTermLength(e,t){return t.visibleOptions(e).reduce((s,r)=>Math.max(s,t.optionTerm(r).length),0)}longestGlobalOptionTermLength(e,t){return t.visibleGlobalOptions(e).reduce((s,r)=>Math.max(s,t.optionTerm(r).length),0)}longestArgumentTermLength(e,t){return t.visibleArguments(e).reduce((s,r)=>Math.max(s,t.argumentTerm(r).length),0)}commandUsage(e){let t=e._name;e._aliases[0]&&(t=t+"|"+e._aliases[0]);let s="";for(let r=e.parent;r;r=r.parent)s=r.name()+" "+s;return s+t+" "+e.usage()}commandDescription(e){return e.description()}subcommandDescription(e){return e.summary()||e.description()}optionDescription(e){let t=[];return e.argChoices&&t.push(`choices: ${e.argChoices.map(s=>JSON.stringify(s)).join(", ")}`),e.defaultValue!==void 0&&(e.required||e.optional||e.isBoolean()&&typeof e.defaultValue=="boolean")&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),e.presetArg!==void 0&&e.optional&&t.push(`preset: ${JSON.stringify(e.presetArg)}`),e.envVar!==void 0&&t.push(`env: ${e.envVar}`),t.length>0?`${e.description} (${t.join(", ")})`:e.description}argumentDescription(e){let t=[];if(e.argChoices&&t.push(`choices: ${e.argChoices.map(s=>JSON.stringify(s)).join(", ")}`),e.defaultValue!==void 0&&t.push(`default: ${e.defaultValueDescription||JSON.stringify(e.defaultValue)}`),t.length>0){let s=`(${t.join(", ")})`;return e.description?`${e.description} ${s}`:s}return e.description}formatHelp(e,t){let s=t.padWidth(e,t),r=t.helpWidth||80,i=2,o=2;function a(p,g){if(g){let x=`${p.padEnd(s+o)}${g}`;return t.wrap(x,r-i,s+o)}return p}function l(p){return p.join(`
|
|
3
3
|
`).replace(/^/gm," ".repeat(i))}let u=[`Usage: ${t.commandUsage(e)}`,""],d=t.commandDescription(e);d.length>0&&(u=u.concat([t.wrap(d,r,0),""]));let f=t.visibleArguments(e).map(p=>a(t.argumentTerm(p),t.argumentDescription(p)));f.length>0&&(u=u.concat(["Arguments:",l(f),""]));let h=t.visibleOptions(e).map(p=>a(t.optionTerm(p),t.optionDescription(p)));if(h.length>0&&(u=u.concat(["Options:",l(h),""])),this.showGlobalOptions){let p=t.visibleGlobalOptions(e).map(g=>a(t.optionTerm(g),t.optionDescription(g)));p.length>0&&(u=u.concat(["Global Options:",l(p),""]))}let m=t.visibleCommands(e).map(p=>a(t.subcommandTerm(p),t.subcommandDescription(p)));return m.length>0&&(u=u.concat(["Commands:",l(m),""])),u.join(`
|
|
4
4
|
`)}padWidth(e,t){return Math.max(t.longestOptionTermLength(e,t),t.longestGlobalOptionTermLength(e,t),t.longestSubcommandTermLength(e,t),t.longestArgumentTermLength(e,t))}wrap(e,t,s,r=40){let i=" \\f\\t\\v\xA0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF",o=new RegExp(`[\\n][${i}]+`);if(e.match(o))return e;let a=t-s;if(a<r)return e;let l=e.slice(0,s),u=e.slice(s).replace(`\r
|
|
5
5
|
`,`
|
|
6
6
|
`),d=" ".repeat(s),h="\\s\u200B",m=new RegExp(`
|
|
7
7
|
|.{1,${a-1}}([${h}]|$)|[^${h}]+?([${h}]|$)`,"g"),p=u.match(m)||[];return l+p.map((g,x)=>g===`
|
|
8
8
|
`?"":(x>0?d:"")+g.trimEnd()).join(`
|
|
9
|
-
`)}};rc.Help=si});var li=j(ai=>{var{InvalidArgumentError:my}=
|
|
9
|
+
`)}};rc.Help=si});var li=j(ai=>{var{InvalidArgumentError:my}=Ln(),ii=class{constructor(e,t){this.flags=e,this.description=t||"",this.required=e.includes("<"),this.optional=e.includes("["),this.variadic=/\w\.\.\.[>\]]$/.test(e),this.mandatory=!1;let s=yy(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 my(`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 gy(this.name().replace(/^no-/,""))}is(e){return this.short===e||this.long===e}isBoolean(){return!this.required&&!this.optional&&!this.negate}},oi=class{constructor(e){this.positiveOptions=new Map,this.negativeOptions=new Map,this.dualOptions=new Set,e.forEach(t=>{t.negate?this.negativeOptions.set(t.attributeName(),t):this.positiveOptions.set(t.attributeName(),t)}),this.negativeOptions.forEach((t,s)=>{this.positiveOptions.has(s)&&this.dualOptions.add(s)})}valueFromOption(e,t){let s=t.attributeName();if(!this.dualOptions.has(s))return!0;let r=this.negativeOptions.get(s).presetArg,i=r!==void 0?r:!1;return t.negate===(i===e)}};function gy(n){return n.split("-").reduce((e,t)=>e+t[0].toUpperCase()+t.slice(1))}function yy(n){let e,t,s=n.split(/[ |,]+/);return s.length>1&&!/^[[<]/.test(s[1])&&(e=s.shift()),t=s.shift(),!e&&/^-[^-]$/.test(t)&&(e=t,t=void 0),{shortFlag:e,longFlag:t}}ai.Option=ii;ai.DualOptions=oi});var oc=j(ic=>{function by(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 vy(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=by(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]}?)`:""}ic.suggestSimilar=vy});var dc=j(uc=>{var wy=require("node:events").EventEmitter,ci=require("node:child_process"),
|
|
11
|
+
(Did you mean ${s[0]}?)`:""}ic.suggestSimilar=vy});var dc=j(uc=>{var wy=require("node:events").EventEmitter,ci=require("node:child_process"),St=require("node:path"),ui=require("node:fs"),pe=require("node:process"),{Argument:xy,humanReadableArgName:Sy}=As(),{CommanderError:di}=Ln(),{Help:_y}=ri(),{Option:ac,DualOptions:Ay}=li(),{suggestSimilar:lc}=oc(),fi=class n extends wy{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=>pe.stdout.write(t),writeErr:t=>pe.stderr.write(t),getOutHelpWidth:()=>pe.stdout.isTTY?pe.stdout.columns:void 0,getErrHelpWidth:()=>pe.stderr.isTTY?pe.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 _y,this.configureHelp())}configureHelp(e){return e===void 0?this._helpConfiguration:(this._helpConfiguration=e,this)}configureOutput(e){return e===void 0?this._outputConfiguration:(Object.assign(this._outputConfiguration,e),this)}showHelpAfterError(e=!0){return typeof e!="string"&&(e=!!e),this._showHelpAfterError=e,this}showSuggestionAfterError(e=!0){return this._showSuggestionAfterError=!!e,this}addCommand(e,t){if(!e._name)throw new Error(`Command passed to .addCommand() must have a name
|
|
12
12
|
- specify the name in Command constructor or using .name()`);return t=t||{},t.isDefault&&(this._defaultCommandName=e._name),(t.noHelp||t.hidden)&&(e._hidden=!0),this._registerCommand(e),e.parent=this,e._checkForBrokenPassThrough(),this}createArgument(e,t){return new xy(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
13
|
Expecting one of '${s.join("', '")}'`);return this._lifeCycleHooks[e]?this._lifeCycleHooks[e].push(t):this._lifeCycleHooks[e]=[t],this}exitOverride(e){return e?this._exitCallback=e:this._exitCallback=t=>{if(t.code!=="commander.executeSubCommandAsync")throw t},this}_exit(e,t,s){this._exitCallback&&this._exitCallback(new di(e,t,s)),pe.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 ac(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 ac)throw new Error("To add an Option object use addOption() instead of option() or requiredOption()");let o=this.createOption(t,s);if(o.makeOptionMandatory(!!e.mandatory),typeof r=="function")o.default(i).argParser(r);else if(r instanceof RegExp){let a=r;r=(l,u)=>{let d=a.exec(l);return d?d[0]:u},o.default(i).argParser(r)}else o.default(r);return this.addOption(o)}option(e,t,s,r){return this._optionEx({},e,t,s,r)}requiredOption(e,t,s,r){return this._optionEx({mandatory:!0},e,t,s,r)}combineFlagAndOptionalValue(e=!0){return this._combineFlagAndOptionalValue=!!e,this}allowUnknownOption(e=!0){return this._allowUnknownOption=!!e,this}allowExcessArguments(e=!0){return this._allowExcessArguments=!!e,this}enablePositionalOptions(e=!0){return this._enablePositionalOptions=!!e,this}passThroughOptions(e=!0){return this._passThroughOptions=!!e,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw new Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties(e=!0){if(this.options.length)throw new Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw new Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!e,this}getOptionValue(e){return this._storeOptionsAsProperties?this[e]:this._optionValues[e]}setOptionValue(e,t){return this.setOptionValueWithSource(e,t,void 0)}setOptionValueWithSource(e,t,s){return this._storeOptionsAsProperties?this[e]=t:this._optionValues[e]=t,this._optionValueSources[e]=s,this}getOptionValueSource(e){return this._optionValueSources[e]}getOptionValueSourceWithGlobals(e){let t;return this._getCommandAndAncestors().forEach(s=>{s.getOptionValueSource(e)!==void 0&&(t=s.getOptionValueSource(e))}),t}_prepareUserArgs(e,t){if(e!==void 0&&!Array.isArray(e))throw new Error("first parameter to parse must be array or undefined");if(t=t||{},e===void 0&&t.from===void 0){pe.versions?.electron&&(t.from="electron");let r=pe.execArgv??[];(r.includes("-e")||r.includes("--eval")||r.includes("-p")||r.includes("--print"))&&(t.from="eval")}e===void 0&&(e=pe.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":pe.defaultApp?(this._scriptPath=e[1],s=e.slice(2)):s=e.slice(1);break;case"user":s=e.slice(0);break;case"eval":s=e.slice(1);break;default:throw new Error(`unexpected parse option { from: '${t.from}' }`)}return!this._name&&this._scriptPath&&this.nameFromFilename(this._scriptPath),this._name=this._name||"program",s}parse(e,t){let s=this._prepareUserArgs(e,t);return this._parseCommand([],s),this}async parseAsync(e,t){let s=this._prepareUserArgs(e,t);return await this._parseCommand([],s),this}_executeSubCommand(e,t){t=t.slice();let s=!1,r=[".js",".ts",".tsx",".mjs",".cjs"];function i(d,f){let h=
|
|
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 ac)throw new Error("To add an Option object use addOption() instead of option() or requiredOption()");let o=this.createOption(t,s);if(o.makeOptionMandatory(!!e.mandatory),typeof r=="function")o.default(i).argParser(r);else if(r instanceof RegExp){let a=r;r=(l,u)=>{let d=a.exec(l);return d?d[0]:u},o.default(i).argParser(r)}else o.default(r);return this.addOption(o)}option(e,t,s,r){return this._optionEx({},e,t,s,r)}requiredOption(e,t,s,r){return this._optionEx({mandatory:!0},e,t,s,r)}combineFlagAndOptionalValue(e=!0){return this._combineFlagAndOptionalValue=!!e,this}allowUnknownOption(e=!0){return this._allowUnknownOption=!!e,this}allowExcessArguments(e=!0){return this._allowExcessArguments=!!e,this}enablePositionalOptions(e=!0){return this._enablePositionalOptions=!!e,this}passThroughOptions(e=!0){return this._passThroughOptions=!!e,this._checkForBrokenPassThrough(),this}_checkForBrokenPassThrough(){if(this.parent&&this._passThroughOptions&&!this.parent._enablePositionalOptions)throw new Error(`passThroughOptions cannot be used for '${this._name}' without turning on enablePositionalOptions for parent command(s)`)}storeOptionsAsProperties(e=!0){if(this.options.length)throw new Error("call .storeOptionsAsProperties() before adding options");if(Object.keys(this._optionValues).length)throw new Error("call .storeOptionsAsProperties() before setting option values");return this._storeOptionsAsProperties=!!e,this}getOptionValue(e){return this._storeOptionsAsProperties?this[e]:this._optionValues[e]}setOptionValue(e,t){return this.setOptionValueWithSource(e,t,void 0)}setOptionValueWithSource(e,t,s){return this._storeOptionsAsProperties?this[e]=t:this._optionValues[e]=t,this._optionValueSources[e]=s,this}getOptionValueSource(e){return this._optionValueSources[e]}getOptionValueSourceWithGlobals(e){let t;return this._getCommandAndAncestors().forEach(s=>{s.getOptionValueSource(e)!==void 0&&(t=s.getOptionValueSource(e))}),t}_prepareUserArgs(e,t){if(e!==void 0&&!Array.isArray(e))throw new Error("first parameter to parse must be array or undefined");if(t=t||{},e===void 0&&t.from===void 0){pe.versions?.electron&&(t.from="electron");let r=pe.execArgv??[];(r.includes("-e")||r.includes("--eval")||r.includes("-p")||r.includes("--print"))&&(t.from="eval")}e===void 0&&(e=pe.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":pe.defaultApp?(this._scriptPath=e[1],s=e.slice(2)):s=e.slice(1);break;case"user":s=e.slice(0);break;case"eval":s=e.slice(1);break;default:throw new Error(`unexpected parse option { from: '${t.from}' }`)}return!this._name&&this._scriptPath&&this.nameFromFilename(this._scriptPath),this._name=this._name||"program",s}parse(e,t){let s=this._prepareUserArgs(e,t);return this._parseCommand([],s),this}async parseAsync(e,t){let s=this._prepareUserArgs(e,t);return await this._parseCommand([],s),this}_executeSubCommand(e,t){t=t.slice();let s=!1,r=[".js",".ts",".tsx",".mjs",".cjs"];function i(d,f){let h=St.resolve(d,f);if(ui.existsSync(h))return h;if(r.includes(St.extname(f)))return;let m=r.find(p=>ui.existsSync(`${h}${p}`));if(m)return`${h}${m}`}this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let o=e._executableFile||`${this._name}-${e._name}`,a=this._executableDir||"";if(this._scriptPath){let d;try{d=ui.realpathSync(this._scriptPath)}catch{d=this._scriptPath}a=St.resolve(St.dirname(d),a)}if(a){let d=i(a,o);if(!d&&!e._executableFile&&this._scriptPath){let f=St.basename(this._scriptPath,St.extname(this._scriptPath));f!==this._name&&(d=i(a,`${f}-${e._name}`))}o=d||o}s=r.includes(St.extname(o));let l;pe.platform!=="win32"?s?(t.unshift(o),t=cc(pe.execArgv).concat(t),l=ci.spawn(pe.argv[0],t,{stdio:"inherit"})):l=ci.spawn(o,t,{stdio:"inherit"}):(t.unshift(o),t=cc(pe.execArgv).concat(t),l=ci.spawn(pe.execPath,t,{stdio:"inherit"})),l.killed||["SIGUSR1","SIGUSR2","SIGTERM","SIGINT","SIGHUP"].forEach(f=>{pe.on(f,()=>{l.killed===!1&&l.exitCode===null&&l.kill(f)})});let u=this._exitCallback;l.on("close",d=>{d=d??1,u?u(new di(d,"commander.executeSubCommandAsync","(close)")):pe.exit(d)}),l.on("error",d=>{if(d.code==="ENOENT"){let f=a?`searched for local subcommand relative to directory '${a}'`:"no directory for search for local subcommand, use .executableDir() to supply a custom directory",h=`'${o}' does not exist
|
|
15
15
|
- if '${e._name}' is not meant to be an executable command, remove description parameter from '.command()' and use '.description()' instead
|
|
16
16
|
- if the default executable name is not suitable, use the executableFile option to supply a custom name or path
|
|
17
17
|
- ${f}`;throw new Error(h)}else if(d.code==="EACCES")throw new Error(`'${o}' not executable`);if(!u)pe.exit(1);else{let f=new di(1,"commander.executeSubCommandAsync","(error)");f.nestedError=d,u(f)}}),this.runningCommand=l}_dispatchSubcommand(e,t,s){let r=this._findCommand(e);r||this.help({error:!0});let i;return i=this._chainOrCallSubCommandHook(i,r,"preSubcommand"),i=this._chainOrCall(i,()=>{if(r._executableHandler)this._executeSubCommand(r,t.concat(s));else return r._parseCommand(t,s)}),i}_dispatchHelpCommand(e){e||this.help();let t=this._findCommand(e);return t&&!t._executableHandler&&t.help(),this._dispatchSubcommand(e,[],[this._getHelpOption()?.long??this._getHelpOption()?.short??"--help"])}_checkNumberOfArguments(){this.registeredArguments.forEach((e,t)=>{e.required&&this.args[t]==null&&this.missingArgument(e.name())}),!(this.registeredArguments.length>0&&this.registeredArguments[this.registeredArguments.length-1].variadic)&&this.args.length>this.registeredArguments.length&&this._excessArguments(this.args)}_processArguments(){let e=(s,r,i)=>{let o=r;if(r!==null&&s.parseArg){let a=`error: command-argument value '${r}' is invalid for argument '${s.name()}'.`;o=this._callParseArg(s,r,i,a)}return o};this._checkNumberOfArguments();let t=[];this.registeredArguments.forEach((s,r)=>{let i=s.defaultValue;s.variadic?r<this.args.length?(i=this.args.slice(r),s.parseArg&&(i=i.reduce((o,a)=>e(s,a,o),s.defaultValue))):i===void 0&&(i=[]):r<this.args.length&&(i=this.args[r],s.parseArg&&(i=e(s,i,s.defaultValue))),t[r]=i}),this.processedArgs=t}_chainOrCall(e,t){return e&&e.then&&typeof e.then=="function"?e.then(()=>t()):t()}_chainOrCallHooks(e,t){let s=e,r=[];return this._getCommandAndAncestors().reverse().filter(i=>i._lifeCycleHooks[t]!==void 0).forEach(i=>{i._lifeCycleHooks[t].forEach(o=>{r.push({hookedCommand:i,callback:o})})}),t==="postAction"&&r.reverse(),r.forEach(i=>{s=this._chainOrCall(s,()=>i.callback(i.hookedCommand,this))}),s}_chainOrCallSubCommandHook(e,t,s){let r=e;return this._lifeCycleHooks[s]!==void 0&&this._lifeCycleHooks[s].forEach(i=>{r=this._chainOrCall(r,()=>i(this,t))}),r}_parseCommand(e,t){let s=this.parseOptions(t);if(this._parseOptionsEnv(),this._parseOptionsImplied(),e=e.concat(s.operands),t=s.unknown,this.args=e.concat(t),e&&this._findCommand(e[0]))return this._dispatchSubcommand(e[0],e.slice(1),t);if(this._getHelpCommand()&&e[0]===this._getHelpCommand().name())return this._dispatchHelpCommand(e[1]);if(this._defaultCommandName)return this._outputHelpIfRequested(t),this._dispatchSubcommand(this._defaultCommandName,e,t);this.commands.length&&this.args.length===0&&!this._actionHandler&&!this._defaultCommandName&&this.help({error:!0}),this._outputHelpIfRequested(s.unknown),this._checkForMissingMandatoryOptions(),this._checkForConflictingOptions();let r=()=>{s.unknown.length>0&&this.unknownOption(s.unknown[0])},i=`command:${this.name()}`;if(this._actionHandler){r(),this._processArguments();let o;return o=this._chainOrCallHooks(o,"preAction"),o=this._chainOrCall(o,()=>this._actionHandler(this.processedArgs)),this.parent&&(o=this._chainOrCall(o,()=>{this.parent.emit(i,e,t)})),o=this._chainOrCallHooks(o,"postAction"),o}if(this.parent&&this.parent.listenerCount(i))r(),this._processArguments(),this.parent.emit(i,e,t);else if(e.length){if(this._findCommand("*"))return this._dispatchSubcommand("*",e,t);this.listenerCount("command:*")?this.emit("command:*",e,t):this.commands.length?this.unknownCommand():(r(),this._processArguments())}else this.commands.length?(r(),this.help({error:!0})):(r(),this._processArguments())}_findCommand(e){if(e)return this.commands.find(t=>t._name===e||t._aliases.includes(e))}_findOption(e){return this.options.find(t=>t.is(e))}_checkForMissingMandatoryOptions(){this._getCommandAndAncestors().forEach(e=>{e.options.forEach(t=>{t.mandatory&&e.getOptionValue(t.attributeName())===void 0&&e.missingMandatoryOptionValue(t)})})}_checkForConflictingLocalOptions(){let e=this.options.filter(s=>{let r=s.attributeName();return this.getOptionValue(r)===void 0?!1:this.getOptionValueSource(r)!=="default"});e.filter(s=>s.conflictsWith.length>0).forEach(s=>{let r=e.find(i=>s.conflictsWith.includes(i.attributeName()));r&&this._conflictingOption(s,r)})}_checkForConflictingOptions(){this._getCommandAndAncestors().forEach(e=>{e._checkForConflictingLocalOptions()})}parseOptions(e){let t=[],s=[],r=t,i=e.slice();function o(l){return l.length>1&&l[0]==="-"}let a=null;for(;i.length;){let l=i.shift();if(l==="--"){r===s&&r.push(l),r.push(...i);break}if(a&&!o(l)){this.emit(`option:${a.name()}`,l);continue}if(a=null,o(l)){let u=this._findOption(l);if(u){if(u.required){let d=i.shift();d===void 0&&this.optionMissingArgument(u),this.emit(`option:${u.name()}`,d)}else if(u.optional){let d=null;i.length>0&&!o(i[0])&&(d=i.shift()),this.emit(`option:${u.name()}`,d)}else this.emit(`option:${u.name()}`);a=u.variadic?u:null;continue}}if(l.length>2&&l[0]==="-"&&l[1]!=="-"){let u=this._findOption(`-${l[1]}`);if(u){u.required||u.optional&&this._combineFlagAndOptionalValue?this.emit(`option:${u.name()}`,l.slice(2)):(this.emit(`option:${u.name()}`),i.unshift(`-${l.slice(2)}`));continue}}if(/^--[^=]+=/.test(l)){let u=l.indexOf("="),d=this._findOption(l.slice(0,u));if(d&&(d.required||d.optional)){this.emit(`option:${d.name()}`,l.slice(u+1));continue}}if(o(l)&&(r=s),(this._enablePositionalOptions||this._passThroughOptions)&&t.length===0&&s.length===0){if(this._findCommand(l)){t.push(l),i.length>0&&s.push(...i);break}else if(this._getHelpCommand()&&l===this._getHelpCommand().name()){t.push(l),i.length>0&&t.push(...i);break}else if(this._defaultCommandName){s.push(l),i.length>0&&s.push(...i);break}}if(this._passThroughOptions){r.push(l),i.length>0&&r.push(...i);break}r.push(l)}return{operands:t,unknown:s}}opts(){if(this._storeOptionsAsProperties){let e={},t=this.options.length;for(let s=0;s<t;s++){let r=this.options[s].attributeName();e[r]=r===this._versionOptionName?this._version:this[r]}return e}return this._optionValues}optsWithGlobals(){return this._getCommandAndAncestors().reduce((e,t)=>Object.assign(e,t.opts()),{})}error(e,t){this._outputConfiguration.outputError(`${e}
|
|
18
18
|
`,this._outputConfiguration.writeErr),typeof this._showHelpAfterError=="string"?this._outputConfiguration.writeErr(`${this._showHelpAfterError}
|
|
19
19
|
`):this._showHelpAfterError&&(this._outputConfiguration.writeErr(`
|
|
20
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 pe.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()}`,pe.env[e.envVar]):this.emit(`optionEnv:${e.name()}`))}})}_parseOptionsImplied(){let e=new Ay(this.options),t=s=>this.getOptionValue(s)!==void 0&&!["default","implied"].includes(this.getOptionValueSource(s));this.options.filter(s=>s.implied!==void 0&&t(s.attributeName())&&e.valueFromOption(this.getOptionValue(s.attributeName()),s)).forEach(s=>{Object.keys(s.implied).filter(r=>!t(r)).forEach(r=>{this.setOptionValueWithSource(r,s.implied[r],"implied")})})}missingArgument(e){let t=`error: missing required argument '${e}'`;this.error(t,{code:"commander.missingArgument"})}optionMissingArgument(e){let t=`error: option '${e.flags}' argument missing`;this.error(t,{code:"commander.optionMissingArgument"})}missingMandatoryOptionValue(e){let t=`error: required option '${e.flags}' not specified`;this.error(t,{code:"commander.missingMandatoryOptionValue"})}_conflictingOption(e,t){let s=o=>{let a=o.attributeName(),l=this.getOptionValue(a),u=this.options.find(f=>f.negate&&a===f.attributeName()),d=this.options.find(f=>!f.negate&&a===f.attributeName());return u&&(u.presetArg===void 0&&l===!1||u.presetArg!==void 0&&l===u.presetArg)?u:d||o},r=o=>{let a=s(o),l=a.attributeName();return this.getOptionValueSource(l)==="env"?`environment variable '${a.envVar}'`:`option '${a.flags}'`},i=`error: ${r(e)} cannot be used with ${r(t)}`;this.error(i,{code:"commander.conflictingOption"})}unknownOption(e){if(this._allowUnknownOption)return;let t="";if(e.startsWith("--")&&this._showSuggestionAfterError){let r=[],i=this;do{let o=i.createHelp().visibleOptions(i).filter(a=>a.long).map(a=>a.long);r=r.concat(o),i=i.parent}while(i&&!i._enablePositionalOptions);t=lc(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=lc(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=>Sy(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=
|
|
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=>Sy(s));return[].concat(this.options.length||this._helpOption!==null?"[options]":[],this.commands.length?"[command]":[],this.registeredArguments.length?t:[]).join(" ")}return this._usage=e,this}name(e){return e===void 0?this._name:(this._name=e,this)}nameFromFilename(e){return this._name=St.basename(e,St.extname(e)),this}executableDir(e){return e===void 0?this._executableDir:(this._executableDir=e,this)}helpInformation(e){let t=this.createHelp();return t.helpWidth===void 0&&(t.helpWidth=e&&e.error?this._outputConfiguration.getErrHelpWidth():this._outputConfiguration.getOutHelpWidth()),t.formatHelp(this,t)}_getHelpContext(e){e=e||{};let t={error:!!e.error},s;return t.error?s=r=>this._outputConfiguration.writeErr(r):s=r=>this._outputConfiguration.writeOut(r),t.write=e.write||s,t.command=this,t}outputHelp(e){let t;typeof e=="function"&&(t=e,e=void 0);let s=this._getHelpContext(e);this._getCommandAndAncestors().reverse().forEach(i=>i.emit("beforeAllHelp",s)),this.emit("beforeHelp",s);let r=this.helpInformation(s);if(t&&(r=t(r),typeof r!="string"&&!Buffer.isBuffer(r)))throw new Error("outputHelp callback must return a string or a Buffer");s.write(r),this._getHelpOption()?.long&&this.emit(this._getHelpOption().long),this.emit("afterHelp",s),this._getCommandAndAncestors().forEach(i=>i.emit("afterAllHelp",s))}helpOption(e,t){return typeof e=="boolean"?(e?this._helpOption=this._helpOption??void 0:this._helpOption=null,this):(e=e??"-h, --help",t=t??"display help for command",this._helpOption=this.createOption(e,t),this)}_getHelpOption(){return this._helpOption===void 0&&this.helpOption(void 0,void 0),this._helpOption}addHelpOption(e){return this._helpOption=e,this}help(e){this.outputHelp(e);let t=pe.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 cc(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})}uc.Command=fi});var mc=j(Ve=>{var{Argument:fc}=
|
|
24
|
-
`);o=u.pop()||"";for(let d of u)if(d.trim())try{let f=JSON.parse(d);f.message?.content&&(yield f.message.content)}catch{}}}}});function Sc(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 Ty(n){return n.map(e=>({type:"function",function:e.function}))}function Ry(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 _c(n){return new Promise(e=>setTimeout(e,n))}function Ac(n,e){return!(n.name==="AbortError"||e&&e>=400&&e<500&&e!==429)}var wc,
|
|
25
|
-
`);a=d.pop()||"";for(let f of d){let h=f.trim();if(!(!h||h==="data: [DONE]")&&h.startsWith("data: "))try{let p=JSON.parse(h.slice(6)).choices?.[0]?.delta?.content;p&&(yield p)}catch{}}}}getHeaders(){let e={};return this.apiKey&&(e.Authorization=`Bearer ${this.apiKey}`),e}}});function Fe(n){if(n.provider==="nvidia"){let e={...n,provider:"custom",apiUrl:Dt.apiUrl};return new
|
|
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 cc(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})}uc.Command=fi});var mc=j(Ve=>{var{Argument:fc}=As(),{Command:pi}=dc(),{CommanderError:ky,InvalidArgumentError:pc}=Ln(),{Help:$y}=ri(),{Option:hc}=li();Ve.program=new pi;Ve.createCommand=n=>new pi(n);Ve.createOption=(n,e)=>new hc(n,e);Ve.createArgument=(n,e)=>new fc(n,e);Ve.Command=pi;Ve.Option=hc;Ve.Argument=fc;Ve.Help=$y;Ve.CommanderError=ky;Ve.InvalidArgumentError=pc;Ve.InvalidOptionArgumentError=pc});var bc={};Ne(bc,{DEFAULT_CONFIG:()=>Dn,NVIDIA_PROVIDER:()=>Dt});var Dn,Dt,Nn=N(()=>{"use strict";Dn={model:"stepfun-ai/step-3.7-flash",ollamaHost:"http://localhost:11434",provider:"ollama",apiUrl:"",apiKey:"",contextBudget:32e3,streamingEnabled:!0,autoConfirmSafe:!0,autoMode:!1,workingDirectory:".",historySize:800,timeout:12e4,maxRetries:3,tools:{runCommand:{allowedCommands:[],blocklist:[],timeout:12e4}},ui:{theme:"dark",showTokenCount:!0,diffPreview:!0,compactMode:!1,dashboard:!1},cache:{enabled:!0,maxEntries:100,ttlMs:3e5},logging:{level:"info",file:!0},plugins:{enabled:!0,directory:"~/.hablas/plugins",marketplace:"https://registry.hablas.dev/plugins"},agents:{enabled:!0,orchestration:"auto",maxConcurrent:3},context:{astParsing:!0,projectGraph:!0,longTermMemory:!0,fileWatcher:!0},workspace:{frameworkDetection:!0,gitAwareness:!0,envParsing:!0,autoPush:!1},security:{scanOnCommit:!1,secretDetection:!0,dependencyAudit:!0},analytics:{enabled:!0,trackUsage:!0,weeklyReports:!1},collaboration:{enabled:!1,teamConfigPath:".hablas/team.json",sharedMemory:!1},team:{enabled:!1,user:"",key:""},api:{enabled:!1,port:8080,host:"0.0.0.0",apiKey:""},license:{tier:"free",key:""}},Dt={name:"NVIDIA",apiUrl:"https://integrate.api.nvidia.com/v1",defaultModel:"stepfun-ai/step-3.7-flash",models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.1-nemotron-70b-instruct","nvidia/nemotron-4-340b-instruct","meta/llama-3.1-405b-instruct","meta/llama-3.1-70b-instruct","meta/llama-3.1-8b-instruct","mistralai/mixtral-8x22b-instruct-v0.1","mistralai/mistral-large-latest","google/gemma-2-27b-it","microsoft/phi-3-medium-128k-instruct","deepseek-ai/deepseek-coder-33b-instruct","nvidia/llama-3.1-nemotron-51b-instruct","qwen/qwen2.5-coder-32b-instruct"]}});var ks,vc=N(()=>{"use strict";ks=class{baseUrl;model;constructor(e){this.baseUrl=e.ollamaHost,this.model=e.model}setModel(e){this.model=e}getModel(){return this.model}async checkConnection(){try{return(await fetch(`${this.baseUrl}/api/tags`,{signal:AbortSignal.timeout(5e3)})).ok}catch{return!1}}async listModels(){try{let e=await fetch(`${this.baseUrl}/api/tags`,{signal:AbortSignal.timeout(5e3)});return e.ok?((await e.json()).models||[]).map(s=>s.name):[]}catch{return[]}}async chatWithTools(e,t,s){let r={model:this.model,messages:e,stream:!1};t.length>0&&(r.tools=t);let i={method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)};s&&(i.signal=s);let o=await fetch(`${this.baseUrl}/api/chat`,i);if(!o.ok){let l=await o.text().catch(()=>"");throw new Error(`Ollama error: ${o.status} ${o.statusText} \u2014 ${l}`)}return await o.json()}async*streamChat(e,t){let s=await fetch(`${this.baseUrl}/api/chat`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:this.model,messages:e,stream:!0}),signal:t});if(!s.ok)throw new Error(`Ollama error: ${s.status} ${s.statusText}`);let r=s.body?.getReader();if(!r)throw new Error("No response body");let i=new TextDecoder,o="";for(;;){let{done:a,value:l}=await r.read();if(a)break;o+=i.decode(l,{stream:!0});let u=o.split(`
|
|
24
|
+
`);o=u.pop()||"";for(let d of u)if(d.trim())try{let f=JSON.parse(d);f.message?.content&&(yield f.message.content)}catch{}}}}});function Sc(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 Ty(n){return n.map(e=>({type:"function",function:e.function}))}function Ry(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 _c(n){return new Promise(e=>setTimeout(e,n))}function Ac(n,e){return!(n.name==="AbortError"||e&&e>=400&&e<500&&e!==429)}var wc,Cy,$s,xc,Ey,Gt,hi=N(()=>{"use strict";wc=12e4,Cy=6e4,$s=3,xc=1e3,Ey=20;Gt=class{apiUrl;apiKey;model;constructor(e){this.apiUrl=e.apiUrl||"https://api.openai.com/v1",this.apiKey=e.apiKey,this.model=e.model}setModel(e){this.model=e}getModel(){return this.model}setApiUrl(e){this.apiUrl=e}getApiUrl(){return this.apiUrl}setApiKey(e){this.apiKey=e}async checkConnection(){try{let e=this.apiUrl.replace(/\/+$/,"")+"/models";return(await fetch(e,{headers:this.getHeaders(),signal:AbortSignal.timeout(15e3)})).ok}catch{return!1}}async listModels(){try{let e=[],t=!0,s,r=0;for(;t&&r<Ey;){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(Cy)});if(!l.ok)break;let u=await l.json();if(Array.isArray(u))e.push(...u.map(d=>d.id||d.name||d).filter(Boolean)),t=!1;else if(u.data&&Array.isArray(u.data)){let d=u.data.map(f=>f.id||f.name).filter(Boolean);e.push(...d),u.has_more&&d.length>0?(s=d[d.length-1],r++):t=!1}else u.models&&Array.isArray(u.models)&&e.push(...u.models.map(d=>d.name||d.id).filter(Boolean)),t=!1}return e.sort((i,o)=>i.localeCompare(o))}catch{return[]}}async chatWithTools(e,t,s){let r=this.apiUrl.replace(/\/+$/,"")+"/chat/completions",i={model:this.model,messages:Sc(e)};t.length>0&&(i.tools=Ty(t),i.tool_choice="auto");let o=null;for(let a=0;a<=$s;a++)try{let l=new AbortController,u=setTimeout(()=>l.abort(),wc),d={method:"POST",headers:{"Content-Type":"application/json",...this.getHeaders()},body:JSON.stringify(i),signal:s||l.signal};try{let f=await fetch(r,d);if(clearTimeout(u),!f.ok){let g=await f.text().catch(()=>"");if(!Ac(null,f.status))throw new Error(`API error: ${f.status} ${f.statusText} \u2014 ${g}`);if(o=new Error(`API error: ${f.status} ${f.statusText} \u2014 ${g}`),a<$s){let x=xc*Math.pow(2,a);await _c(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?Ry(m.message.tool_calls):void 0;return{message:{role:m.message.role||"assistant",content:m.message.content||"",tool_calls:p},done:!0,done_reason:m.finish_reason}}catch(f){if(clearTimeout(u),f.name==="AbortError"&&s?.aborted)throw f;if(Ac(f)&&(o=f,a<$s)){let h=xc*Math.pow(2,a);await _c(h);continue}throw f}}catch(l){if(l.name==="AbortError")throw l;if(o=l,a>=$s)throw o}throw o||new Error("Request failed after retries")}async*streamChat(e,t){let s=this.apiUrl.replace(/\/+$/,"")+"/chat/completions",r=await fetch(s,{method:"POST",headers:{"Content-Type":"application/json",...this.getHeaders()},body:JSON.stringify({model:this.model,messages:Sc(e),stream:!0}),signal:t||AbortSignal.timeout(wc)});if(!r.ok)throw new Error(`API error: ${r.status} ${r.statusText}`);let i=r.body?.getReader();if(!i)throw new Error("No response body");let o=new TextDecoder,a="";for(;;){let{done:l,value:u}=await i.read();if(l)break;a+=o.decode(u,{stream:!0});let d=a.split(`
|
|
25
|
+
`);a=d.pop()||"";for(let f of d){let h=f.trim();if(!(!h||h==="data: [DONE]")&&h.startsWith("data: "))try{let p=JSON.parse(h.slice(6)).choices?.[0]?.delta?.content;p&&(yield p)}catch{}}}}getHeaders(){let e={};return this.apiKey&&(e.Authorization=`Bearer ${this.apiKey}`),e}}});function Fe(n){if(n.provider==="nvidia"){let e={...n,provider:"custom",apiUrl:Dt.apiUrl};return new Gt(e)}return n.provider==="custom"&&n.apiUrl?new Gt(n):new ks(n)}function Cs(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 Fn=N(()=>{"use strict";Nn();vc();hi()});var kc=N(()=>{"use strict"});function Vt(){let n={providers:[],activeProvider:null,activeModel:null};try{if(_t.existsSync(gi)){let e=_t.readFileSync(gi,"utf-8"),t=JSON.parse(e);return{...n,...t}}}catch{}return n}function bi(n){_t.existsSync(mi)||_t.mkdirSync(mi,{recursive:!0}),_t.writeFileSync(gi,JSON.stringify(n,null,2),"utf-8")}function nt(n){let e=Vt();e.providers=e.providers.filter(t=>t.name!==n.name),e.providers.push(n),bi(e)}function Cc(n){let e=Vt(),t=e.providers.length;return e.providers=e.providers.filter(s=>s.name!==n),e.providers.length<t?(e.activeProvider===n&&(e.activeProvider=null,e.activeModel=null),bi(e),!0):!1}function Ec(n){return Vt().providers.find(t=>t.name.toLowerCase()===n.toLowerCase())}function Es(){return Vt().providers}function Tc(n,e){let t=Vt(),s=t.providers.find(r=>r.name===n);s&&(t.activeProvider=n,t.activeModel=e||s.defaultModel,bi(t))}function Rc(n,e){if(n.length===0)return" No saved providers. Use /addmodel to add one.";let t=[];t.push(" Saved Providers:"),t.push("");for(let s of n){let r=s.name===e,i=r?" \u25CF active":"",o=s.apiKey?"***"+s.apiKey.slice(-4):"no key";t.push(` ${r?"\u25B8":"\xB7"} ${s.name}${i}`),t.push(` URL: ${s.apiUrl}`),t.push(` Key: ${o}`),t.push(` Model: ${s.defaultModel}`),t.push(` Added: ${new Date(s.addedAt).toLocaleDateString()}`),t.push("")}return t.join(`
|
|
26
|
+
`)}var _t,yi,$c,mi,gi,vi=N(()=>{"use strict";_t=O(require("fs")),yi=O(require("path")),$c=O(require("os"));kc();mi=yi.join($c.homedir(),".hablas"),gi=yi.join(mi,"models.json")});function Ps(){try{if(At.existsSync(Ts))return JSON.parse(At.readFileSync(Ts,"utf-8"))}catch{}return{}}function Oc(n){let e=Rs.dirname(Ts);At.existsSync(e)||At.mkdirSync(e,{recursive:!0}),At.writeFileSync(Ts,JSON.stringify(n,null,2),"utf-8")}function Ic(n,e){let t=Ps();t[n]=e,Oc(t)}function Mc(n){let e=Ps();return e[n]?(delete e[n],Oc(e),!0):!1}function Lc(n){let e=Ps(),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 Dc(){let n=Ps(),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 At,Rs,Pc,Ts,wi=N(()=>{"use strict";At=O(require("fs")),Rs=O(require("path")),Pc=O(require("os")),Ts=Rs.join(Pc.homedir(),".hablas","aliases.json")});var jc={};Ne(jc,{disablePlugin:()=>Ai,enablePlugin:()=>_i,ensurePluginsDir:()=>Ms,listPlugins:()=>Fc,renderPlugins:()=>ki});function Si(){try{if(je.existsSync(Is))return JSON.parse(je.readFileSync(Is,"utf-8"))}catch{}return{disabled:[]}}function Nc(n){let e=dn.dirname(Is);je.existsSync(e)||je.mkdirSync(e,{recursive:!0}),je.writeFileSync(Is,JSON.stringify(n,null,2),"utf-8")}function Ms(){je.existsSync(Os)||je.mkdirSync(Os,{recursive:!0})}function Fc(){Ms();let n=Si(),e=[];try{let t=je.readdirSync(Os).filter(s=>s.endsWith(".js"));for(let s of t){let r=dn.join(Os,s);try{let i=require(r);e.push({name:i.name||s.replace(".js",""),description:i.description||"No description",version:i.version||"0.0.0",enabled:!n.disabled.includes(i.name||s.replace(".js","")),path:r,commands:i.commands})}catch{e.push({name:s.replace(".js",""),description:"Failed to load",version:"?",enabled:!1,path:r})}}}catch{}return e}function _i(n){let e=Si(),t=e.disabled.indexOf(n);return t!==-1?(e.disabled.splice(t,1),Nc(e),!0):!1}function Ai(n){let e=Si();return e.disabled.includes(n)?!1:(e.disabled.push(n),Nc(e),!0)}function ki(){let n=Fc();return n.length===0?` No plugins installed.
|
|
29
29
|
Add .js files to ~/.hablas/plugins/`:n.map(e=>{let t=e.enabled?"\u25CF enabled":"\u25CB disabled";return` ${e.name} v${e.version} [${t}]
|
|
30
30
|
${e.description}`}).join(`
|
|
31
31
|
|
|
32
|
-
`)}var je,
|
|
33
|
-
`)}var
|
|
34
|
-
`)}var xe,Py,Oy,Iy,My,qc,
|
|
32
|
+
`)}var je,dn,xi,Os,Is,$i=N(()=>{"use strict";je=O(require("fs")),dn=O(require("path")),xi=O(require("os")),Os=dn.join(xi.homedir(),".hablas","plugins"),Is=dn.join(xi.homedir(),".hablas","plugins.json")});var Uc={};Ne(Uc,{renderDiagnostics:()=>Ti,runDiagnostics:()=>Ei});async function Ei(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=Hc.join(st.homedir(),".hablas");if(e.push({name:"Config directory",status:Ci.existsSync(r)?"ok":"warn",message:Ci.existsSync(r)?r:"Not created yet (will be created on first use)"}),n.provider==="ollama")try{let i=await fetch(`${n.ollamaHost}/api/tags`,{signal:AbortSignal.timeout(5e3)});if(i.ok){let o=await i.json(),a=Array.isArray(o.models)?o.models.length:0;e.push({name:"Ollama",status:"ok",message:`Connected \u2014 ${a} models available`})}else e.push({name:"Ollama",status:"error",message:`HTTP ${i.status}`})}catch(i){let o=i instanceof Error?i.message:String(i);e.push({name:"Ollama",status:"error",message:o.includes("ECONNREFUSED")?"Not running \u2014 start with: ollama serve":`Connection failed: ${o}`})}else{let i=n.apiUrl||"unknown";try{let o=await fetch(`${i}/models`,{signal:AbortSignal.timeout(5e3),headers:{Authorization:"Bearer test"}});e.push({name:"API Provider",status:o.ok||o.status===401?"ok":"warn",message:`${i} \u2014 reachable`})}catch{e.push({name:"API Provider",status:"warn",message:`${i} \u2014 could not verify`})}}try{let i=st.homedir();if(process.platform!=="win32"){let a=(0,Bc.execSync)(`df -h "${i}" | tail -1`,{encoding:"utf-8"}).trim().split(/\s+/),l=a[3]||"unknown",u=a[4]||"?";e.push({name:"Disk space",status:parseInt(u)>90?"warn":"ok",message:`${l} available (${u} used)`})}else e.push({name:"Disk space",status:"ok",message:"Check skipped on Windows"})}catch{e.push({name:"Disk space",status:"ok",message:"Could not determine"})}return e.push({name:"Active model",status:n.model?"ok":"warn",message:n.model||"No model configured"}),e.push({name:"Platform",status:"ok",message:`${st.platform()} ${st.arch()} \u2014 ${st.cpus().length} cores, ${Math.round(st.totalmem()/1024/1024/1024)}GB RAM`}),e}function Ti(n){let e={ok:"\u2713",warn:"\u26A0",error:"\u2717"},t={ok:"\x1B[32m",warn:"\x1B[33m",error:"\x1B[31m"},s="\x1B[0m",r="\x1B[2m",i=[""," \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501"," hablas doctor \u2014 System Diagnostics"," \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501",""];for(let l of n){let u=`${t[l.status]}${e[l.status]}${s}`,d=l.name.padEnd(18);i.push(` ${u} ${d}${r}${l.message}${s}`)}let o=n.filter(l=>l.status==="error").length,a=n.filter(l=>l.status==="warn").length;return i.push(""),o>0?i.push(` ${t.error}${o} error(s) found \u2014 fix these for hablas to work properly${s}`):a>0?i.push(` ${t.warn}${a} warning(s) \u2014 hablas should work but check the items above${s}`):i.push(` ${t.ok}All checks passed \u2014 hablas is ready!${s}`),i.push(""),i.join(`
|
|
33
|
+
`)}var Ci,Hc,st,Bc,Ri=N(()=>{"use strict";Ci=O(require("fs")),Hc=O(require("path")),st=O(require("os")),Bc=require("child_process")});function Pi(n){let e=n.trim();return!!(e.length<15&&!qc.test(e)||Py.test(e)||Oy.test(e)||Iy.test(e)||My.test(e))}function Oi(n){let e=n.toLowerCase(),t=["hablas"];return Pi(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&&qc.test(n)&&t.push("alex")),t}function Ii(n,e){let t=[],s=1,r=e.includes("emma"),i=e.includes("bob"),o=e.includes("alex"),a=e.includes("david");if(r&&t.push({id:`task-${s++}`,role:"emma",agentName:"Emma",description:"Analyze requirements, create PRD, and define user stories",input:n,dependencies:[],status:"pending"}),a&&t.push({id:`task-${s++}`,role:"david",agentName:"David",description:"Research requirements, best practices, and relevant documentation",input:n,dependencies:r?[t.find(u=>u.role==="emma").id]:[],status:"pending"}),i){let u=[];a?u.push(t.find(d=>d.role==="david").id):r&&u.push(t.find(d=>d.role==="emma").id),t.push({id:`task-${s++}`,role:"bob",agentName:"Bob",description:"Design system architecture and structure",input:n,dependencies:u,status:"pending"})}if(o){let u=[];i?u.push(t.find(d=>d.role==="bob").id):a?u.push(t.find(d=>d.role==="david").id):r&&u.push(t.find(d=>d.role==="emma").id),t.push({id:`task-${s++}`,role:"alex",agentName:"Alex",description:"Implement the code based on architecture/requirements",input:n,dependencies:u,status:"pending"})}let l="sequential";return t.length>2&&t.some(u=>u.dependencies.length===0)&&(l="mixed"),{id:`plan-${Date.now()}`,description:`Orchestration plan for: ${n.substring(0,100)}`,tasks:t,strategy:l,createdAt:new Date,approved:!1}}function Mi(){let n=[];for(let e of xe){let s=e.role==="hablas"?" \u2605":"";n.push(` @${e.name}${s} \u2014 ${e.title}`),n.push(` ${e.description}`)}return n.join(`
|
|
34
|
+
`)}var xe,Py,Oy,Iy,My,qc,fn=N(()=>{"use strict";xe=[{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"]}],Py=/^(hi|hello|hey|howdy|yo|sup|hiya|good\s*(morning|afternoon|evening|night)|what'?s\s*up|greetings)\b/i,Oy=/^(مرحبا|أهلا|أهلاً|هلا|السلام\s*عليكم|وعليكم\s*السلام|كيف\s*حالك|كيفك|شلونك|صباح\s*الخير|مساء\s*الخير|شكرا|شكراً|يعطيك\s*العافية|تمام|اهلين|هلو|مرحبتين|الله\s*يسلمك|حياك|حياك\s*الله|يا\s*هلا|كيف\s*الحال|اخبارك|شخبارك)/i,Iy=/^(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,My=/^(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,qc=/\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 jn(){try{if(pn.existsSync(Li)){let n=pn.readFileSync(Li,"utf-8"),e=JSON.parse(n);return{...Kc,...e}}}catch{}return{...Kc}}function Gc(){return Li}var pn,Di,Wc,Li,Kc,Ni=N(()=>{"use strict";pn=O(require("fs")),Di=O(require("path")),Wc=O(require("os")),Li=Di.join(Wc.homedir(),".hablas","agents.json"),Kc={hablas:{model:"stepfun-ai/step-3.7-flash",temperature:.7},bob:{model:"stepfun-ai/step-3.7-flash",temperature:.4},alex:{model:"stepfun-ai/step-3.7-flash",temperature:.2},david:{model:"stepfun-ai/step-3.7-flash",temperature:.5},emma:{model:"stepfun-ai/step-3.7-flash",temperature:.6}}});var Ki={};Ne(Ki,{formatStats:()=>Fy,loadStats:()=>Hn,saveStats:()=>Nt,trackAgentUsage:()=>Bn,trackFileModified:()=>Dy,trackMessage:()=>Ui,trackSession:()=>Bi,trackToolCall:()=>qi});function Hn(){try{if(kt.existsSync(ji))return JSON.parse(kt.readFileSync(ji,"utf-8"))}catch{}return Ly()}function Nt(n){try{kt.existsSync(Fi)||kt.mkdirSync(Fi,{recursive:!0}),kt.writeFileSync(ji,JSON.stringify(n,null,2))}catch{}}function Ly(){return{totalSessions:0,totalMessages:0,totalTokensUsed:0,totalToolCalls:0,totalFilesModified:0,totalLinesWritten:0,totalBugsFixed:0,totalCommits:0,agentUsage:{},commandUsage:{},dailyActivity:{},streak:0,longestStreak:0,firstUsed:new Date().toISOString(),lastUsed:new Date().toISOString()}}function Bi(n){return n.totalSessions++,n.lastUsed=new Date().toISOString(),Ny(n),n}function Ui(n,e=0){n.totalMessages++,n.totalTokensUsed+=e;let t=Ls();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].messages++,n.dailyActivity[t].tokens+=e,n}function qi(n,e){n.totalToolCalls++,n.commandUsage[e]=(n.commandUsage[e]||0)+1;let t=Ls();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].toolCalls++,n}function Bn(n,e){return n.agentUsage[e]=(n.agentUsage[e]||0)+1,n}function Dy(n,e=0){n.totalFilesModified++,n.totalLinesWritten+=e;let t=Ls();return n.dailyActivity[t]||(n.dailyActivity[t]={messages:0,tokens:0,toolCalls:0,filesModified:0,linesWritten:0}),n.dailyActivity[t].filesModified++,n.dailyActivity[t].linesWritten+=e,n}function Ny(n){let e=Ls(),t=zc(new Date(Date.now()-864e5));n.dailyActivity[t]||n.dailyActivity[e]?n.streak++:n.streak=1,n.streak>n.longestStreak&&(n.longestStreak=n.streak)}function Ls(){return zc(new Date)}function zc(n){return n.toISOString().split("T")[0]}function Fy(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
|
|
36
|
+
`)}var kt,Hi,Vc,Fi,ji,Un=N(()=>{"use strict";kt=O(require("fs")),Hi=O(require("path")),Vc=O(require("os")),Fi=Hi.join(Vc.homedir(),".hablas"),ji=Hi.join(Fi,"analytics.json")});var Jc={};Ne(Jc,{formatScanResults:()=>Gi,runSecurityScan:()=>Wi});function Uy(n,e){let t=[],s=e.split(`
|
|
37
37
|
`);for(let{pattern:r,name:i,severity:o}of jy){r.lastIndex=0;let a;for(;(a=r.exec(e))!==null;){let u=e.substring(0,a.index).split(`
|
|
38
38
|
`).length,d=s[u-1]||"";d.trim().startsWith("#")||d.trim().startsWith("//")||n.includes(".example")||n.includes(".sample")||t.push({severity:o,type:"secret",file:n,line:u,message:`Potential ${i} detected`,suggestion:"Move to environment variable or use a secrets manager. Add to .gitignore if needed."})}}return t}function qy(n,e){let t=[],s=e.split(`
|
|
39
|
-
`),r=
|
|
39
|
+
`),r=zt.extname(n);return[".ts",".js",".tsx",".jsx"].includes(r)&&s.forEach((i,o)=>{/\beval\s*\(/.test(i)&&!i.trim().startsWith("//")&&t.push({severity:"high",type:"code",file:n,line:o+1,message:"Usage of eval() detected \u2014 potential code injection risk",suggestion:"Replace eval() with safer alternatives like JSON.parse() or Function constructor."}),/\.innerHTML\s*=/.test(i)&&t.push({severity:"medium",type:"code",file:n,line:o+1,message:"Direct innerHTML assignment \u2014 potential XSS vulnerability",suggestion:"Use textContent, or sanitize HTML with DOMPurify before assignment."}),/`.*\$\{.*\}.*(?:SELECT|INSERT|UPDATE|DELETE|DROP)/i.test(i)&&t.push({severity:"high",type:"code",file:n,line:o+1,message:"Potential SQL injection \u2014 string interpolation in SQL query",suggestion:"Use parameterized queries or an ORM instead of string interpolation."})}),t}function Yc(n,e=[]){try{let t=Ds.readdirSync(n,{withFileTypes:!0});for(let s of t){if(Hy.has(s.name))continue;let r=zt.join(n,s.name);if(s.isDirectory())Yc(r,e);else if(s.isFile()){let i=zt.extname(s.name);By.has(i)||e.push(r)}}}catch{}return e}function Wi(n){let e=Date.now(),t=Yc(n),s=[];for(let o of t)try{let a=Ds.readFileSync(o,"utf-8"),l=zt.relative(n,o),u=Uy(l,a);s.push(...u);let d=qy(l,a);s.push(...d)}catch{}let r=Date.now()-e,i={critical:s.filter(o=>o.severity==="critical").length,high:s.filter(o=>o.severity==="high").length,medium:s.filter(o=>o.severity==="medium").length,low:s.filter(o=>o.severity==="low").length,info:s.filter(o=>o.severity==="info").length};return{issues:s,scannedFiles:t.length,duration:r,summary:i}}function Gi(n){let e=[];if(e.push(`
|
|
40
40
|
Security Scan Complete`),e.push(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),e.push(` Files scanned: ${n.scannedFiles}`),e.push(` Duration: ${n.duration}ms`),e.push(""),n.issues.length===0)e.push(" \u2713 No security issues found!");else{e.push(` Issues found: ${n.issues.length}`),e.push(` Critical: ${n.summary.critical}`),e.push(` High: ${n.summary.high}`),e.push(` Medium: ${n.summary.medium}`),e.push(` Low: ${n.summary.low}`),e.push("");let t=n.issues.sort((s,r)=>{let i={critical:0,high:1,medium:2,low:3,info:4};return i[s.severity]-i[r.severity]}).slice(0,10);for(let s of t){let r=s.severity==="critical"?"\u{1F534}":s.severity==="high"?"\u{1F7E0}":s.severity==="medium"?"\u{1F7E1}":"\u{1F535}";e.push(` ${r} [${s.severity.toUpperCase()}] ${s.message}`),e.push(` File: ${s.file}${s.line?`:${s.line}`:""}`),e.push(` Fix: ${s.suggestion}`),e.push("")}}return e.join(`
|
|
41
|
-
`)}var
|
|
42
|
-
`).filter(Boolean)){let d=u.substring(0,2),f=u.substring(3);(d.startsWith("A")||d.startsWith("M")||d.startsWith("R"))&&d[0]!==" "&&r.push(f),(d[1]==="M"||d[1]==="D")&&i.push(f),d==="??"&&o.push(f)}let a=0,l=0;try{let{stdout:u}=await
|
|
43
|
-
... (truncated)`:e.trim()}catch{return""}}async function Gy(n,e=20){try{let{stdout:t}=await
|
|
41
|
+
`)}var Ds,zt,jy,Hy,By,Vi=N(()=>{"use strict";Ds=O(require("fs")),zt=O(require("path")),jy=[{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"}],Hy=new Set(["node_modules",".git","dist","build",".next","__pycache__","venv",".venv","target","vendor",".cache"]),By=new Set([".png",".jpg",".jpeg",".gif",".svg",".ico",".woff",".woff2",".ttf",".eot",".mp4",".mp3",".zip",".tar",".gz",".lock"])});var qn={};Ne(qn,{formatGitStatus:()=>Jy,generateChangelogPrompt:()=>Yy,generateCommitPrompt:()=>Vy,generatePRPrompt:()=>zy,getDetailedDiff:()=>Wy,getGitStatus:()=>zi,getRecentCommits:()=>Gy,getStagedDiff:()=>Ky});async function zi(n){try{let{stdout:e}=await hn("git branch --show-current",{cwd:n}),{stdout:t}=await hn("git status --porcelain",{cwd:n}),s=e.trim(),r=[],i=[],o=[];for(let u of t.split(`
|
|
42
|
+
`).filter(Boolean)){let d=u.substring(0,2),f=u.substring(3);(d.startsWith("A")||d.startsWith("M")||d.startsWith("R"))&&d[0]!==" "&&r.push(f),(d[1]==="M"||d[1]==="D")&&i.push(f),d==="??"&&o.push(f)}let a=0,l=0;try{let{stdout:u}=await hn("git rev-list --left-right --count HEAD...@{upstream}",{cwd:n}),d=u.trim().split(" ");a=parseInt(d[0])||0,l=parseInt(d[1])||0}catch{}return{branch:s,staged:r,modified:i,untracked:o,ahead:a,behind:l}}catch{return null}}async function Ky(n){try{let{stdout:e}=await hn("git diff --cached --stat",{cwd:n});return e.trim()}catch{return""}}async function Wy(n){try{let{stdout:e}=await hn("git diff --cached",{cwd:n,maxBuffer:1048576});return e.length>1e4?e.substring(0,1e4)+`
|
|
43
|
+
... (truncated)`:e.trim()}catch{return""}}async function Gy(n,e=20){try{let{stdout:t}=await hn(`git log --oneline --format="%H|%s|%an|%ai" -n ${e}`,{cwd:n});return t.trim().split(`
|
|
44
44
|
`).filter(Boolean).map(s=>{let[r,i,o,a]=s.split("|");return{hash:r,message:i,author:o,date:a,files:[]}})}catch{return[]}}function Vy(n,e){return`Based on the following git diff, generate a concise, conventional commit message.
|
|
45
45
|
|
|
46
46
|
Rules:
|
|
@@ -99,7 +99,7 @@ Format:
|
|
|
99
99
|
- (removed features)
|
|
100
100
|
|
|
101
101
|
Only include sections that have entries. Generate ONLY the changelog markdown.`}function Jy(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 Qc,Xc,mn
|
|
102
|
+
`)}var Qc,Xc,hn,mn=N(()=>{"use strict";Qc=require("child_process"),Xc=require("util"),hn=(0,Xc.promisify)(Qc.exec)});var su={};Ne(su,{detectFramework:()=>Zc,detectLanguage:()=>tu,detectPackageManager:()=>eu,formatWorkspaceInfo:()=>Yi,getGitBranch:()=>nu,scanWorkspace:()=>Ns});function Zc(n){let e=Y.join(n,"package.json");if(V.existsSync(e))try{let t=JSON.parse(V.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(V.existsSync(Y.join(n,"requirements.txt"))||V.existsSync(Y.join(n,"pyproject.toml")))try{let t=V.existsSync(Y.join(n,"requirements.txt"))?V.readFileSync(Y.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(V.existsSync(Y.join(n,"Cargo.toml")))try{if(V.readFileSync(Y.join(n,"Cargo.toml"),"utf-8").includes("actix"))return"rust-actix"}catch{}if(V.existsSync(Y.join(n,"go.mod")))try{if(V.readFileSync(Y.join(n,"go.mod"),"utf-8").includes("fiber"))return"go-fiber"}catch{}return"unknown"}function eu(n){return V.existsSync(Y.join(n,"pnpm-lock.yaml"))?"pnpm":V.existsSync(Y.join(n,"yarn.lock"))?"yarn":V.existsSync(Y.join(n,"bun.lockb"))?"bun":V.existsSync(Y.join(n,"package-lock.json"))?"npm":V.existsSync(Y.join(n,"Cargo.toml"))?"cargo":V.existsSync(Y.join(n,"go.mod"))?"go":V.existsSync(Y.join(n,"requirements.txt"))||V.existsSync(Y.join(n,"pyproject.toml"))?"pip":"unknown"}function tu(n){return V.existsSync(Y.join(n,"tsconfig.json"))?"TypeScript":V.existsSync(Y.join(n,"package.json"))?"JavaScript":V.existsSync(Y.join(n,"Cargo.toml"))?"Rust":V.existsSync(Y.join(n,"go.mod"))?"Go":V.existsSync(Y.join(n,"pyproject.toml"))||V.existsSync(Y.join(n,"requirements.txt"))?"Python":"Unknown"}function nu(n){let e=Y.join(n,".git","HEAD");if(!V.existsSync(e))return null;try{let t=V.readFileSync(e,"utf-8").trim();return t.startsWith("ref: refs/heads/")?t.replace("ref: refs/heads/",""):t.substring(0,8)}catch{return null}}function Ns(n){let e=Zc(n),t=eu(n),s=tu(n),r=nu(n),i=V.existsSync(Y.join(n,"Dockerfile"))||V.existsSync(Y.join(n,"docker-compose.yml"))||V.existsSync(Y.join(n,"docker-compose.yaml")),o=V.existsSync(Y.join(n,".github","workflows"))||V.existsSync(Y.join(n,".gitlab-ci.yml"))||V.existsSync(Y.join(n,"Jenkinsfile")),a=V.existsSync(Y.join(n,"__tests__"))||V.existsSync(Y.join(n,"tests"))||V.existsSync(Y.join(n,"test"))||V.existsSync(Y.join(n,"spec")),l=V.existsSync(Y.join(n,".git")),u=[],d=[".env",".env.local",".env.development",".env.production",".env.example"];for(let g of d)V.existsSync(Y.join(n,g))&&u.push(g);let f=[],h=["package.json","tsconfig.json","vite.config.ts","next.config.js","next.config.mjs","webpack.config.js","tailwind.config.ts","tailwind.config.js","eslint.config.js",".eslintrc.js",".prettierrc","Dockerfile","docker-compose.yml","Makefile"];for(let g of h)V.existsSync(Y.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)V.existsSync(Y.join(n,g))&&m.push(g);return{rootPath:n,framework:e,packageManager:t,language:s,hasDocker:i,hasCICD:o,hasTests:a,hasGit:l,gitBranch:r,envFiles:u,configFiles:f,entryPoints:m}}function Yi(n){let e=[` Project: ${Y.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
103
|
`)}var V,Y,Ji=N(()=>{"use strict";V=O(require("fs")),Y=O(require("path"))});function ru(){return`
|
|
104
104
|
## Available Tools (HEP-1 Protocol)
|
|
105
105
|
|
|
@@ -181,16 +181,16 @@ 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 iu=N(()=>{"use strict"});function Qy(){try{let n=lu.resolve(__dirname,"..","..","package.json");return JSON.parse(au.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function he(n,e){return uu||!
|
|
184
|
+
`.trim()}var iu=N(()=>{"use strict"});function Qy(){try{let n=lu.resolve(__dirname,"..","..","package.json");return JSON.parse(au.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function he(n,e){return uu||!gn?n:`${e}${n}\x1B[0m`}function Xy(n){let e=Oe();if(!n)return c.border("\u2500".repeat(e));let t=n.replace(/\x1b\[[0-9;]*m/g,""),s=Math.max(0,e-t.length-2),r=Math.floor(s/2),i=s-r;return c.border("\u2500".repeat(r))+" "+n+" "+c.border("\u2500".repeat(i))}function Zy(n,e=2){let t=Oe()-e;if(t<=0)return" ".repeat(e)+n;let s=n.split(" "),r=[],i="";for(let o of s)(i+" "+o).trim().length>t&&i?(r.push(i.trim()),i=o):i+=(i?" ":"")+o;return i&&r.push(i.trim()),r.map(o=>" ".repeat(e)+o).join(`
|
|
185
185
|
`)}function eb(n){let e=Math.max(...n.map(([t])=>t.length));return n.map(([t,s])=>` ${c.muted(t.padEnd(e))} ${s}`).join(`
|
|
186
|
-
`)}function tb(n){if(uu||!
|
|
186
|
+
`)}function tb(n){if(uu||!gn)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 fu(n,e){let t=Oe(),s=e?e.replace(Zi.homedir(),"~"):"",r=c.border("\u2554"+"\u2550".repeat(t-2)+"\u2557"),i=c.border("\u2560"+"\u2550".repeat(t-2)+"\u2563"),o=c.border("\u255A"+"\u2550".repeat(t-2)+"\u255D"),a="H A B L A S A I",l="EXECUTIVE SYSTEM COORDINATOR",u="developed by abdulmoin hablas",d=Math.max(0,Math.floor((t-2-a.length)/2)),f=c.border("\u2551")+" ".repeat(d)+c.strong(a)+" ".repeat(t-2-a.length-d)+c.border("\u2551"),h=Math.max(0,Math.floor((t-2-l.length)/2)),m=c.border("\u2551")+" ".repeat(h)+c.secondary(l)+" ".repeat(t-2-l.length-h)+c.border("\u2551"),p=Math.max(0,Math.floor((t-2-u.length)/2)),g=c.border("\u2551")+" ".repeat(p)+c.muted(u)+" ".repeat(t-2-u.length-p)+c.border("\u2551"),x=c.muted(`SYSTEM VERSION: v${cu}`),S=c.warning(`CORE MODEL: ${n}`);return["",r,f,m,u?g:"",i,` ${c.muted("\u25B8")} ${x}`,` ${c.muted("\u25B8")} ${S}`,s?` ${c.muted("\u25B8")} ${c.muted(`WORKSPACE: ${s}`)}`:"",` ${c.chrome("\u251C"+"\u2500".repeat(t-2)+"\u2524")}`,` ${c.muted(" \u203A")} ${c.secondary("Type naturally to get started")}`,` ${c.muted(" \u203A")} ${c.secondary("/help for commands \xB7 Ctrl+C to cancel \xB7 Ctrl+C\xD72 to exit")}`,o,""].filter(Boolean).join(`
|
|
187
187
|
`)}function pu(){let n=Oe();return[` ${c.border("\u2554"+"\u2550".repeat(n-4)+"\u2557")}`,` ${c.border("\u2551")} ${c.leader("\u2605 Hablas")} ${c.muted("Leader")} ${c.border("\u2551")} ${c.product("\u25C6 Emma")} ${c.muted("Product")} ${c.border("\u2551")} ${c.architect("\u25C6 Bob")} ${c.muted("Architect")} ${c.border("\u2551")} ${c.engineer("\u25C6 Alex")} ${c.muted("Engineer")} ${c.border("\u2551")} ${c.analyst("\u25C6 David")} ${c.muted("Analyst")} ${c.border("\u2551")}`,` ${c.border("\u255A"+"\u2550".repeat(n-4)+"\u255D")}`].join(`
|
|
188
|
-
`)}function
|
|
188
|
+
`)}function yn(n,e){return`
|
|
189
189
|
${(n==="Hablas"?c.leader:n==="Bob"?c.architect:n==="Alex"?c.engineer:n==="David"?c.analyst:n==="Emma"?c.product:c.primary)("\u25C6")} ${c.strong(n)} ${c.muted(`[${e.toUpperCase()}]`)}`}function hu(n,e,t,s){let r=n==="Hablas"?c.leader:n==="Bob"?c.architect:n==="Alex"?c.engineer:n==="David"?c.analyst:n==="Emma"?c.product:c.primary,i=e==="Hablas"?c.leader:e==="Bob"?c.architect:e==="Alex"?c.engineer:e==="David"?c.analyst:e==="Emma"?c.product:c.primary,o=[];if(o.push(""),o.push(` ${r("\u2605")} ${r(n)} ${c.muted("\u2192")} ${c.strong("Delegating to")} ${i(`@${e}`)} ${c.muted(`(${t})`)}`),s){let a=s.length>80?s.slice(0,80)+"...":s;o.push(` ${c.muted(" \u2517")} ${c.secondary(a)}`)}return o.push(""),o.join(`
|
|
190
190
|
`)}function mu(){let n=Oe(),t=[` ${c.accent("\u2726")} ${c.strong("Welcome to hablas")}`,"",` ${c.muted("Try:")} ${c.highlight('"read package.json and list deps"')}`,` ${c.muted("Or:")} ${c.highlight('"create a new component for user auth"')}`,"",` ${c.primary("/tree")} ${c.muted("\u2014 see project structure")}`,` ${c.primary("/model")} ${c.muted("\u2014 switch AI model")}`,` ${c.primary("/models")} ${c.muted("\u2014 browse all available models")}`,` ${c.primary("/team")} ${c.muted("\u2014 see your agent team")}`,` ${c.primary("/about")} ${c.muted("\u2014 developer info")}`,"",` ${c.muted("All file changes are backed up automatically.")}`].map(s=>{let r=s.replace(/\x1b\[[0-9;]*m/g,""),i=Math.max(0,n-8-r.length);return` ${c.border("\u2502")} ${s}${" ".repeat(i)} ${c.border("\u2502")}`});return["",` ${c.border("\u250C"+"\u2500".repeat(n-6)+"\u2510")}`,...t,` ${c.border("\u2514"+"\u2500".repeat(n-6)+"\u2518")}`,""].join(`
|
|
191
191
|
`)}function gu(){let n=Oe();return["",c.chrome("\u256D"+"\u2500".repeat(n-2)+"\u256E"),` ${c.strong("Abdulmoin Hablas")} ${c.muted("\u2014 Full-Stack Developer")}`,c.chrome("\u251C"+"\u2500".repeat(n-2)+"\u2524"),"",` ${c.accent("\u25C6")} ${c.primary("Portfolio")} ${c.muted("https://portfolio-monopoly63s-projects.vercel.app/")}`,` ${c.accent("\u25C6")} ${c.primary("GitHub")} ${c.muted("https://github.com/Monopoly63?tab=repositories")}`,` ${c.accent("\u25C6")} ${c.primary("Telegram")} ${c.muted("https://t.me/Hablas_Trade")}`,` ${c.accent("\u25C6")} ${c.primary("WhatsApp")} ${c.muted("https://wa.me/13232128875")}`,` ${c.accent("\u25C6")} ${c.primary("Instagram")} ${c.muted("https://www.instagram.com/li0vy_")}`,"",c.chrome("\u251C"+"\u2500".repeat(n-2)+"\u2524"),` ${c.strong("Projects")}`,"",` ${c.muted("\u25B8")} AI Search Engine ${c.muted("\u2192")} ${c.highlight("https://ai-search-engine-ashy.vercel.app/")}`,` ${c.muted("\u25B8")} Trade Tracker ${c.muted("\u2192")} ${c.highlight("https://trade-tracker-monopoly63s-projects.vercel.app/")}`,` ${c.muted("\u25B8")} Tree Algo Lab ${c.muted("\u2192")} ${c.highlight("https://tree-algorithms-lab.vercel.app/")}`,"",c.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F"),""].join(`
|
|
192
192
|
`)}function yu(){return["",` ${tb("\u25C6 hablas")} ${c.success(`v${cu}`)}`,"",` ${c.muted("Runtime")} ${c.secondary(`Node.js ${process.version}`)}`,` ${c.muted("Platform")} ${c.secondary(`${process.platform} ${process.arch}`)}`,` ${c.muted("Author")} ${c.secondary("Abdulmoin Hablas")}`,` ${c.muted("License")} ${c.secondary("MIT")}`,""].join(`
|
|
193
|
-
`)}function ou(n,e){let t=Math.min(Oe()-8,60),s=e?` ${c.accent(e)} `:"",r=`${c.error("\u25CF")} ${c.warning("\u25CF")} ${c.success("\u25CF")}`,i=` ${c.chrome("\u250C"+"\u2500".repeat(4))} ${r} ${c.chrome("\u2500".repeat(Math.max(0,t-10-(e?e.length+2:0))))}${s}`,o=String(n.length).length,a=n.map((u,d)=>{let f=c.lineNum(String(d+1).padStart(o)+" \u2502 "),h=c.codeBlock(u);return` ${c.chrome("\u2502")} ${f}${h}`}),l=` ${c.chrome("\u2514"+"\u2500".repeat(t))}`;return[i,...a,l]}function
|
|
193
|
+
`)}function ou(n,e){let t=Math.min(Oe()-8,60),s=e?` ${c.accent(e)} `:"",r=`${c.error("\u25CF")} ${c.warning("\u25CF")} ${c.success("\u25CF")}`,i=` ${c.chrome("\u250C"+"\u2500".repeat(4))} ${r} ${c.chrome("\u2500".repeat(Math.max(0,t-10-(e?e.length+2:0))))}${s}`,o=String(n.length).length,a=n.map((u,d)=>{let f=c.lineNum(String(d+1).padStart(o)+" \u2502 "),h=c.codeBlock(u);return` ${c.chrome("\u2502")} ${f}${h}`}),l=` ${c.chrome("\u2514"+"\u2500".repeat(t))}`;return[i,...a,l]}function bn(n){let e=n.split(`
|
|
194
194
|
`),t=[],s=!1,r="",i=[];for(let o of e){if(o.trimStart().startsWith("```")){s?(t.push(...ou(i,r)),s=!1,i=[]):(s=!0,r=o.trimStart().slice(3).trim(),i=[]);continue}if(s){i.push(o);continue}if(/^#{1,3}\s/.test(o)){let l=o.replace(/^#+\s/,"");t.push(""),t.push(` ${c.strong(c.primary(l))}`);continue}if(/^[-*]\s/.test(o.trim())){let l=o.trim().slice(2),u=Qi(l);t.push(` ${c.accent("\u25B8")} ${u}`);continue}if(/^\d+\.\s/.test(o.trim())){let l=o.trim().match(/^(\d+)\.\s(.+)/);if(l){t.push(` ${c.muted(l[1]+".")} ${Qi(l[2])}`);continue}}if(!o.trim()){t.push("");continue}let a=Zy(Qi(o),2);t.push(...a.split(`
|
|
195
195
|
`))}return s&&i.length>0&&t.push(...ou(i,r)),`
|
|
196
196
|
`+t.join(`
|
|
@@ -205,7 +205,7 @@ ${l}
|
|
|
205
205
|
`),t=[];for(let s of e)s.startsWith("+++")||s.startsWith("---")?t.push(` ${c.muted(s)}`):s.startsWith("+")?t.push(` ${c.added(s)}`):s.startsWith("-")?t.push(` ${c.removed(s)}`):s.startsWith("@@")?t.push(` ${c.hunk(s)}`):s.trim()&&t.push(` ${c.muted(s)}`);return t.join(`
|
|
206
206
|
`)}function wu(n){let e=new Date().toLocaleTimeString("en",{hour:"2-digit",minute:"2-digit"}),t=`${c.accent("\u25C6")} ${c.strong(c.primary(`Turn #${n}`))} ${c.muted(`\xB7 ${e} \xB7`)}`;return`
|
|
207
207
|
`+Xy(t)+`
|
|
208
|
-
`}function
|
|
208
|
+
`}function Ce(n){return` ${c.error("\u2717")} ${n}`}function He(n,e){return` ${c.error("\u2717")} ${n}
|
|
209
209
|
${c.warning("\u2192")} ${c.muted(e)}`}function J(n){return` ${c.success("\u2713")} ${n}`}function fe(n){return` ${c.muted(n)}`}function U(n){return` ${c.warning("\u26A0")} ${n}`}function nb(n,e){let s=Math.round(Math.min(n,e)/Math.max(e,1)*16),r=e>0?n/e:0;return(r>.85?c.error:r>.6?c.warning:c.success)("\u2588".repeat(s))+c.muted("\u2591".repeat(16-s))}function xu(n){let e=Oe(),t=n.connected?c.success("\u25CF connected"):c.error("\u25CB offline"),s=nb(n.cacheTokens,n.budgetTokens),r=[["model",c.highlight(n.model)],["mindset",c.accent(n.mindset||"coder")],["host",c.muted(n.host)],["directory",c.muted(n.directory.replace(Zi.homedir(),"~"))],["context",`${s} ${c.muted(`${n.cacheFiles} files \xB7 ${n.cacheTokens}/${n.budgetTokens} tokens`)}`],["turns",c.muted(String(n.turnCount))],["status",t]];return`
|
|
210
210
|
`+c.chrome("\u256D"+"\u2500".repeat(e-2)+"\u256E")+`
|
|
211
211
|
${c.accent("\u2726")} ${c.strong("Status")}
|
|
@@ -224,13 +224,13 @@ ${l}
|
|
|
224
224
|
|
|
225
225
|
`+c.chrome("\u2570"+"\u2500".repeat(n-2)+"\u256F")+`
|
|
226
226
|
`}function to(n){let e=Math.floor(n.duration/6e4),t=Math.floor(n.duration%6e4/1e3),s=e>0?`${e}m ${t}s`:`${t}s`;return["",c.chrome("\u256D"+"\u2500".repeat(40)+"\u256E"),` ${c.accent("\u2726")} ${c.strong("Session Summary")}`,"",` ${c.muted("Turns")} ${c.secondary(String(n.turns))}`,` ${c.muted("Duration")} ${c.secondary(s)}`,` ${c.muted("Tool calls")} ${c.secondary(String(n.toolCalls))}`,"",c.chrome("\u2570"+"\u2500".repeat(40)+"\u256F"),"",` ${c.muted("Goodbye \u2014 hablas by Abdulmoin Hablas")}`,""].join(`
|
|
227
|
-
`)}function
|
|
227
|
+
`)}function Fs(n,e){let t=Oe(),s=[];s.push(""),s.push(` ${c.chrome("\u256D"+"\u2500".repeat(t-4)+"\u256E")}`),s.push(` ${c.chrome("\u2502")} ${c.leader("\u2605")} ${c.strong("Hablas")} ${c.muted("\u2014 Execution Plan")}${" ".repeat(Math.max(0,t-35))}${c.chrome("\u2502")}`);let r=20,i=Math.round(e.percent/100*r),o=r-i,a=c.success("\u2588".repeat(i))+c.muted("\u2591".repeat(o));s.push(` ${c.chrome("\u2502")} ${a} ${c.muted(`${e.percent}%`)} ${c.muted(`(${e.done}/${e.total} tasks)`)}`),s.push(` ${c.chrome("\u251C"+"\u2500".repeat(t-4)+"\u2524")}`);for(let l=0;l<n.tasks.length;l++){let u=n.tasks[l],d=rb[u.status](sb[u.status]),h=(u.assignee==="hablas"?c.leader:u.assignee==="bob"?c.architect:u.assignee==="alex"?c.engineer:u.assignee==="david"?c.analyst:u.assignee==="emma"?c.product:c.muted)(`@${u.assigneeName}`),m="";u.dependent_task_ids.length>0&&(m=c.muted(` \u2190 [${u.dependent_task_ids.join(", ")}]`));let p=c.secondary(u.description);s.push(` ${c.chrome("\u2502")} ${d} ${c.muted(`${u.task_id}.`)} ${h} ${c.muted("\u2192")} ${p}${m}`)}return s.push(` ${c.chrome("\u251C"+"\u2500".repeat(t-4)+"\u2524")}`),s.push(` ${c.chrome("\u2502")} ${c.muted("Strategy:")} ${c.highlight(n.strategy)} ${c.muted("\xB7")} ${c.muted(`${n.tasks.length} tasks`)}`),s.push(` ${c.chrome("\u2570"+"\u2500".repeat(t-4)+"\u256F")}`),s.push(""),s.join(`
|
|
228
228
|
`)}function _u(n){let e=Oe(),t=[];t.push(""),t.push(` ${c.chrome("\u256D"+"\u2500".repeat(e-4)+"\u256E")}`),t.push(` ${c.chrome("\u2502")} ${c.warning("?")} ${c.strong("Clarification Needed")}`),t.push(` ${c.chrome("\u251C"+"\u2500".repeat(e-4)+"\u2524")}`),t.push(` ${c.chrome("\u2502")} ${c.secondary(n.question)}`),t.push(` ${c.chrome("\u2502")}`);for(let s of n.choices)t.push(` ${c.chrome("\u2502")} ${c.accent(s.label+")")} ${c.secondary(s.value)}`);return n.context&&(t.push(` ${c.chrome("\u2502")}`),t.push(` ${c.chrome("\u2502")} ${c.muted(`Context: "${n.context.slice(0,60)}${n.context.length>60?"...":""}"`)}`)),t.push(` ${c.chrome("\u2570"+"\u2500".repeat(e-4)+"\u256F")}`),t.push(""),t.join(`
|
|
229
|
-
`)}function
|
|
230
|
-
`)}var Zi,au,lu,cu,
|
|
231
|
-
`);return}this.interval=setInterval(()=>{let e=((Date.now()-this.startTime)/1e3).toFixed(1),t=c.accent(this.frames[this.frameIndex]);process.stdout.write(`\r ${t} ${c.muted(this.message)} ${c.muted(e+"s")}`),this.frameIndex=(this.frameIndex+1)%this.frames.length},80)}setPhase(e){this.message=e}updateMessage(e){this.message=e}stop(e){this.interval&&(clearInterval(this.interval),this.interval=null);let t=Date.now()-this.startTime;if(
|
|
229
|
+
`)}function Au(n){let e=Math.min(Oe(),80),t=[],s=`\u250C${"\u2500".repeat(e-2)}\u2510`,r=`\u251C${"\u2500".repeat(e-2)}\u2524`,i=`\u2514${"\u2500".repeat(e-2)}\u2518`;t.push(` ${c.border(s)}`);let a=`\u2605 MISSION STATUS: ${n.taskTitle}`.slice(0,e-4).padEnd(e-4);t.push(` ${c.border("\u2502")} ${c.strong(a)} ${c.border("\u2502")}`),t.push(` ${c.border(r)}`);let u=`Phase: ${n.currentPhase}`.slice(0,e-4).padEnd(e-4);t.push(` ${c.border("\u2502")} ${c.primary(u)} ${c.border("\u2502")}`);let d=[];for(let[y,b]of Object.entries(n.roster)){let v=y==="Hablas"?c.leader:y==="Bob"?c.architect:y==="Alex"?c.engineer:y==="David"?c.analyst:c.product,w="";b==="done"?w=c.success("\u2713"):b==="active"?w=c.highlight("\u25CF"):w=c.muted("\u25CB"),d.push(`@${v(y)} ${w}`)}let f=`Roster: ${d.join(" ")}`,h=f.replace(/\x1b\[[0-9;]*m/g,""),m=Math.max(0,e-4-h.length);t.push(` ${c.border("\u2502")} ${f}${" ".repeat(m)} ${c.border("\u2502")}`);let p=`Active: @${n.activeAgent} (${n.activeAgentTitle})`,g=p.replace(/\x1b\[[0-9;]*m/g,""),x=Math.max(0,e-4-g.length);t.push(` ${c.border("\u2502")} ${p}${" ".repeat(x)} ${c.border("\u2502")}`);let S=`Action: ${n.currentActivity}`,A=S.replace(/\x1b\[[0-9;]*m/g,""),k=Math.max(0,e-4-A.length);return t.push(` ${c.border("\u2502")} ${c.secondary(S)}${" ".repeat(k)} ${c.border("\u2502")}`),t.push(` ${c.border(i)}`),t.join(`
|
|
230
|
+
`)}var Zi,au,lu,cu,gn,uu,du,Oe,c,ze,Xi,sb,rb,no,vn=N(()=>{"use strict";Zi=O(require("os")),au=O(require("fs")),lu=O(require("path"));cu=Qy(),gn=process.stdout.isTTY===!0,uu=process.env.NO_COLOR!==void 0||process.env.TERM==="dumb",du=process.stdout.columns||80;gn&&process.stdout.on("resize",()=>{du=process.stdout.columns||80});Oe=()=>Math.min(du-4,100);c={primary:n=>he(n,"\x1B[38;5;253m"),secondary:n=>he(n,"\x1B[38;5;247m"),muted:n=>he(n,"\x1B[38;5;242m"),strong:n=>he(n,"\x1B[1;38;5;255m"),accent:n=>he(n,"\x1B[38;5;145m"),highlight:n=>he(n,"\x1B[38;5;231m"),success:n=>he(n,"\x1B[38;5;108m"),error:n=>he(n,"\x1B[38;5;167m"),warning:n=>he(n,"\x1B[38;5;179m"),info:n=>he(n,"\x1B[38;5;110m"),codeBlock:n=>he(n,"\x1B[38;5;188m"),lineNum:n=>he(n,"\x1B[38;5;239m"),border:n=>he(n,"\x1B[38;5;237m"),chrome:n=>he(n,"\x1B[38;5;235m"),added:n=>he(n,"\x1B[38;5;108m"),removed:n=>he(n,"\x1B[38;5;167m"),hunk:n=>he(n,"\x1B[38;5;145m"),leader:n=>he(n,"\x1B[38;5;179m"),architect:n=>he(n,"\x1B[38;5;250m"),engineer:n=>he(n,"\x1B[38;5;145m"),analyst:n=>he(n,"\x1B[38;5;108m"),product:n=>he(n,"\x1B[38;5;180m")};ze=class{frames=["\u280B","\u2819","\u2839","\u2838","\u283C","\u2834","\u2826","\u2827","\u2807","\u280F"];interval=null;frameIndex=0;message;startTime=0;constructor(e="Thinking"){this.message=e}start(){if(this.startTime=Date.now(),!gn){process.stderr.write(` ${this.message}...
|
|
231
|
+
`);return}this.interval=setInterval(()=>{let e=((Date.now()-this.startTime)/1e3).toFixed(1),t=c.accent(this.frames[this.frameIndex]);process.stdout.write(`\r ${t} ${c.muted(this.message)} ${c.muted(e+"s")}`),this.frameIndex=(this.frameIndex+1)%this.frames.length},80)}setPhase(e){this.message=e}updateMessage(e){this.message=e}stop(e){this.interval&&(clearInterval(this.interval),this.interval=null);let t=Date.now()-this.startTime;if(gn&&process.stdout.write("\r"+" ".repeat(80)+"\r"),e&&gn){let s=c.muted(`${t}ms`);console.log(` ${c.muted("\xB7")} ${c.secondary(e)} ${s}`)}}};Xi=[{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"}];sb={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},rb={pending:c.muted,running:c.accent,done:c.success,failed:c.error,skipped:c.muted};no=Xi.map(n=>n.cmd).concat(["/exit","/addmodel","/listmodels","/removemodel","/usemodel","/provider","/task","/memory","/mindset","/mindsets","/alias","/doctor","/plugins","/team","/agents","/delegate"])});function so(n){let e=rt.join(n,"package.json");if(Be.existsSync(e))try{let t=JSON.parse(Be.readFileSync(e,"utf-8")),s={...t.dependencies,...t.devDependencies};if(s.vitest)return"vitest";if(s.jest||s["@jest/core"])return"jest";if(s.mocha)return"mocha"}catch{}if(Be.existsSync(rt.join(n,"pytest.ini"))||Be.existsSync(rt.join(n,"pyproject.toml"))||Be.existsSync(rt.join(n,"setup.py")))try{let t=Be.existsSync(rt.join(n,"requirements.txt"))?Be.readFileSync(rt.join(n,"requirements.txt"),"utf-8"):"",s=Be.existsSync(rt.join(n,"pyproject.toml"))?Be.readFileSync(rt.join(n,"pyproject.toml"),"utf-8"):"";if(t.includes("pytest")||s.includes("pytest"))return"pytest"}catch{}return Be.existsSync(rt.join(n,"go.mod"))?"go":Be.existsSync(rt.join(n,"Cargo.toml"))?"cargo":"unknown"}function ib(n,e){switch(n){case"vitest":return e?`npx vitest run ${e}`:"npx vitest run";case"jest":return e?`npx jest ${e} --no-coverage`:"npx jest --no-coverage";case"mocha":return e?`npx mocha ${e}`:"npx mocha";case"pytest":return e?`python -m pytest ${e} -v`:"python -m pytest -v";case"go":return e?`go test ./${e}`:"go test ./...";case"cargo":return"cargo test";default:return"npm test"}}function $u(n,e){let t=so(n),s=ib(t,e),r=Date.now(),i="",o="",a=!1;try{i=(0,ku.execSync)(s,{cwd:n,encoding:"utf-8",timeout:12e4,maxBuffer:5*1024*1024,stdio:["pipe","pipe","pipe"]}),a=!0}catch(m){i=m.stdout||"",o=m.stderr||m.message||"",a=!1}let l=Date.now()-r,{totalTests:u,passedTests:d,failedTests:f,failedTestNames:h}=ob(i+`
|
|
232
232
|
`+o,t);return{framework:t,command:s,passed:a,output:i.slice(0,5e3),errorOutput:o.slice(0,3e3),totalTests:u,passedTests:d,failedTests:f,duration:l,failedTestNames:h}}function ob(n,e){let t=0,s=0,r=0,i=[],o=n.split(`
|
|
233
|
-
`);switch(e){case"jest":case"vitest":{for(let a of o){let l=a.match(/Tests:\s+(\d+)\s+passed.*?(\d+)\s+total/);if(l&&(s=parseInt(l[1]),t=parseInt(l[2]),r=t-s),a.match(/✕|FAIL|✗|×/)){let d=a.replace(/.*(?:✕|FAIL|✗|×)\s*/,"").trim();d&&i.push(d)}}break}case"pytest":{for(let a of o){let l=a.match(/(\d+)\s+passed.*?(\d+)\s+failed/);l&&(s=parseInt(l[1]),r=parseInt(l[2]),t=s+r);let u=a.match(/(\d+)\s+passed/);u&&t===0&&(s=parseInt(u[1]),t=s),a.includes("FAILED")&&i.push(a.trim())}break}case"go":{for(let a of o)a.includes("--- PASS")&&s++,a.includes("--- FAIL")&&(r++,i.push(a.replace("--- FAIL:","").trim()));t=s+r;break}default:{for(let a of o)/\bpass(ed|ing)?\b/i.test(a)&&/\d/.test(a)&&s++,/\bfail(ed|ing|ure)?\b/i.test(a)&&/\d/.test(a)&&r++;t=s+r}}return{totalTests:t,passedTests:s,failedTests:r,failedTestNames:i}}function
|
|
233
|
+
`);switch(e){case"jest":case"vitest":{for(let a of o){let l=a.match(/Tests:\s+(\d+)\s+passed.*?(\d+)\s+total/);if(l&&(s=parseInt(l[1]),t=parseInt(l[2]),r=t-s),a.match(/✕|FAIL|✗|×/)){let d=a.replace(/.*(?:✕|FAIL|✗|×)\s*/,"").trim();d&&i.push(d)}}break}case"pytest":{for(let a of o){let l=a.match(/(\d+)\s+passed.*?(\d+)\s+failed/);l&&(s=parseInt(l[1]),r=parseInt(l[2]),t=s+r);let u=a.match(/(\d+)\s+passed/);u&&t===0&&(s=parseInt(u[1]),t=s),a.includes("FAILED")&&i.push(a.trim())}break}case"go":{for(let a of o)a.includes("--- PASS")&&s++,a.includes("--- FAIL")&&(r++,i.push(a.replace("--- FAIL:","").trim()));t=s+r;break}default:{for(let a of o)/\bpass(ed|ing)?\b/i.test(a)&&/\d/.test(a)&&s++,/\bfail(ed|ing|ure)?\b/i.test(a)&&/\d/.test(a)&&r++;t=s+r}}return{totalTests:t,passedTests:s,failedTests:r,failedTestNames:i}}function Cu(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(`
|
|
234
234
|
`)}function Eu(n){return`The following tests are failing. Analyze the error output and fix the code.
|
|
235
235
|
|
|
236
236
|
Test framework: ${n.framework}
|
|
@@ -251,21 +251,21 @@ Instructions:
|
|
|
251
251
|
1. Read the failing test files to understand what's expected
|
|
252
252
|
2. Read the source files being tested
|
|
253
253
|
3. Fix the source code (not the tests) to make them pass
|
|
254
|
-
4. After fixing, explain what was wrong and what you changed`}var
|
|
255
|
-
`).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await
|
|
256
|
-
`)}var
|
|
257
|
-
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function oo(n,e,t,s,r){e=e||[],t=t||[],s&&(n=s(r,n));var i;for(i=0;i<e.length;i+=1)if(e[i]===n)return t[i];var o;if(gb.call(n)==="[object Array]"){for(e.push(n),o=new Array(n.length),t.push(o),i=0;i<n.length;i+=1)o[i]=oo(n[i],e,t,s,r);return e.pop(),t.pop(),o}if(n&&n.toJSON&&(n=n.toJSON()),
|
|
258
|
-
`),g==="+"?m++:g==="-"?p++:g===" "&&(m++,p++);else break}if(!m&&h.newLines===1&&(h.newLines=0),!p&&h.oldLines===1&&(h.oldLines=0),e.strict){if(m!==h.newLines)throw new Error("Added line count did not match for hunk at line "+(u+1));if(p!==h.oldLines)throw new Error("Removed line count did not match for hunk at line "+(u+1))}return h}for(;i<t.length;)o();return r}function bb(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
|
|
259
|
-
`;if(I===" ")w++;else if(I==="-")s.splice(w,1),r.splice(w,1);else if(I==="+")s.splice(w,0,$),r.splice(w,0,F),w++;else if(I==="\\"){var B=v.lines[
|
|
260
|
-
`));for(var z=0;z<s.length-1;z++)s[z]=s[z]+r[z];return s.join("")}function vb(n,e,t,s,r,i,o){o||(o={}),typeof o.context>"u"&&(o.context=4);var a=cb(t,s,o);if(!a)return;a.push({value:"",lines:[]});function l(
|
|
261
|
-
`);if(k.lines=y,k.added||k.removed){var b;if(!d){var v=a[A-1];d=m,f=p,v&&(h=o.context>0?l(v.lines.slice(-o.context)):[],d-=h.length,f-=h.length)}(b=h).push.apply(b,ro(y.map(function(z){return(k.added?"+":"-")+z}))),k.added?p+=y.length:m+=y.length}else{if(d)if(y.length<=o.context*2&&A<a.length-2){var w;(w=h).push.apply(w,ro(l(y)))}else{var
|
|
254
|
+
4. After fixing, explain what was wrong and what you changed`}var ku,Be,rt,Tu=N(()=>{"use strict";ku=require("child_process"),Be=O(require("fs")),rt=O(require("path"))});function Hs(n){let e=Buffer.from(n).toString("base64url").slice(0,16);return Ie.join(ab,e)}async function Pu(n,e,t){let s=Hs(n);Ee.existsSync(s)||Ee.mkdirSync(s,{recursive:!0});let r=`cp_${Date.now()}`,i=[];for(let f of t){let h=Ie.resolve(n,f);if(Ee.existsSync(h))try{let m=await $t.readFile(h,"utf-8");i.push({path:f,content:m})}catch{}}try{let f=(0,js.execSync)("git ls-files -m",{cwd:n,encoding:"utf-8",timeout:5e3}).split(`
|
|
255
|
+
`).filter(Boolean);for(let h of f)if(!i.find(m=>m.path===h))try{let m=await $t.readFile(Ie.resolve(n,h),"utf-8");i.push({path:h,content:m})}catch{}}catch{}let o,a;try{o=(0,js.execSync)("git branch --show-current",{cwd:n,encoding:"utf-8",timeout:5e3}).trim(),a=(0,js.execSync)("git rev-parse --short HEAD",{cwd:n,encoding:"utf-8",timeout:5e3}).trim()}catch{}let l={id:r,label:e,timestamp:Date.now(),files:i,gitBranch:o,gitHash:a,projectPath:n},u=Ie.join(s,`${r}.json`);await $t.writeFile(u,JSON.stringify(l,null,2),"utf-8");let d=Ee.readdirSync(s).filter(f=>f.endsWith(".json")).sort();if(d.length>20)for(let f of d.slice(0,d.length-20))try{Ee.unlinkSync(Ie.join(s,f))}catch{}return{id:r,label:e,timestamp:l.timestamp,fileCount:i.length,projectPath:n}}function Ou(n){let e=Hs(n);if(!Ee.existsSync(e))return[];let t=Ee.readdirSync(e).filter(r=>r.endsWith(".json")).sort().reverse(),s=[];for(let r of t)try{let i=JSON.parse(Ee.readFileSync(Ie.join(e,r),"utf-8"));s.push({id:i.id,label:i.label,timestamp:i.timestamp,fileCount:i.files.length,projectPath:i.projectPath})}catch{}return s}async function Iu(n,e){let t=Hs(n),s=Ie.join(t,`${e}.json`);if(!Ee.existsSync(s))return{success:!1,filesRestored:0,error:`Checkpoint ${e} not found`};try{let r=JSON.parse(await $t.readFile(s,"utf-8")),i=0;for(let o of r.files)try{let a=Ie.resolve(n,o.path);await $t.mkdir(Ie.dirname(a),{recursive:!0}),await $t.writeFile(a,o.content,"utf-8"),i++}catch{}return{success:!0,filesRestored:i}}catch(r){return{success:!1,filesRestored:0,error:r.message}}}function Mu(n,e){let t=Hs(n),s=Ie.join(t,`${e}.json`);try{if(Ee.existsSync(s))return Ee.unlinkSync(s),!0}catch{}return!1}function Lu(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(`
|
|
256
|
+
`)}var Ee,$t,Ie,Ru,js,ab,Du=N(()=>{"use strict";Ee=O(require("fs")),$t=O(require("fs/promises")),Ie=O(require("path")),Ru=O(require("os")),js=require("child_process"),ab=Ie.join(Ru.homedir(),".hablas","checkpoints")});function Ct(){}function lb(n,e,t,s,r){for(var i=[],o;e;)i.push(e),o=e.previousComponent,delete e.previousComponent,e=o;i.reverse();for(var a=0,l=i.length,u=0,d=0;a<l;a++){var f=i[a];if(f.removed){if(f.value=n.join(s.slice(d,d+f.count)),d+=f.count,a&&i[a-1].added){var m=i[a-1];i[a-1]=i[a],i[a]=m}}else{if(!f.added&&r){var h=t.slice(u,u+f.count);h=h.map(function(g,x){var S=s[d+x];return S.length>g.length?S:g}),f.value=n.join(h)}else f.value=n.join(t.slice(u,u+f.count));u+=f.count,f.added||(d+=f.count)}}var p=i[l-1];return l>1&&typeof p.value=="string"&&(p.added||p.removed)&&n.equals("",p.value)&&(i[l-2].value+=p.value,i.pop()),i}function cb(n,e,t){return lo.diff(n,e,t)}function Bs(n){"@babel/helpers - typeof";return typeof Symbol=="function"&&typeof Symbol.iterator=="symbol"?Bs=function(e){return typeof e}:Bs=function(e){return e&&typeof Symbol=="function"&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Bs(n)}function ro(n){return fb(n)||pb(n)||hb(n)||mb()}function fb(n){if(Array.isArray(n))return io(n)}function pb(n){if(typeof Symbol<"u"&&Symbol.iterator in Object(n))return Array.from(n)}function hb(n,e){if(n){if(typeof n=="string")return io(n,e);var t=Object.prototype.toString.call(n).slice(8,-1);if(t==="Object"&&n.constructor&&(t=n.constructor.name),t==="Map"||t==="Set")return Array.from(n);if(t==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t))return io(n,e)}}function io(n,e){(e==null||e>n.length)&&(e=n.length);for(var t=0,s=new Array(e);t<e;t++)s[t]=n[t];return s}function mb(){throw new TypeError(`Invalid attempt to spread non-iterable instance.
|
|
257
|
+
In order to be iterable, non-array objects must have a [Symbol.iterator]() method.`)}function oo(n,e,t,s,r){e=e||[],t=t||[],s&&(n=s(r,n));var i;for(i=0;i<e.length;i+=1)if(e[i]===n)return t[i];var o;if(gb.call(n)==="[object Array]"){for(e.push(n),o=new Array(n.length),t.push(o),i=0;i<n.length;i+=1)o[i]=oo(n[i],e,t,s,r);return e.pop(),t.pop(),o}if(n&&n.toJSON&&(n=n.toJSON()),Bs(n)==="object"&&n!==null){e.push(n),o={},t.push(o);var a=[],l;for(l in n)n.hasOwnProperty(l)&&a.push(l);for(a.sort(),i=0;i<a.length;i+=1)l=a[i],o[l]=oo(n[l],e,t,s,l);e.pop(),t.pop()}else o=n;return o}function yb(n){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:{},t=n.split(/\r\n|[\n\v\f\r\x85]/),s=n.match(/\r\n|[\n\v\f\r\x85]/g)||[],r=[],i=0;function o(){var u={};for(r.push(u);i<t.length;){var d=t[i];if(/^(\-\-\-|\+\+\+|@@)\s/.test(d))break;var f=/^(?:Index:|diff(?: -r \w+)+)\s+/.exec(d);f&&(u.index=d.substring(f[0].length).trim()),i++}for(a(u),a(u),u.hunks=[];i<t.length;){var h=t[i];if(/^(Index:|diff|\-\-\-|\+\+\+)\s/.test(h))break;if(/^@@/.test(h))u.hunks.push(l());else{if(h&&e.strict)throw new Error("Unknown line "+(i+1)+" "+JSON.stringify(h));i++}}}function a(u){var d=/^(---|\+\+\+)\s+/.exec(t[i]);if(d){var f=d[1]==="---"?"old":"new",h=t[i].substring(3).trim().split(" ",2),m=h[0].replace(/\\\\/g,"\\");m.startsWith('"')&&m.endsWith('"')&&(m=m.substr(1,m.length-2)),u[f+"FileName"]=m,u[f+"Header"]=(h[1]||"").trim(),i++}}function l(){var u=i,d=t[i++],f=d.split(/@@ -(\d+)(?:,(\d+))? \+(\d+)(?:,(\d+))? @@/),h={oldStart:+f[1],oldLines:typeof f[2]>"u"?1:+f[2],newStart:+f[3],newLines:typeof f[4]>"u"?1:+f[4],lines:[],linedelimiters:[]};h.oldLines===0&&(h.oldStart+=1),h.newLines===0&&(h.newStart+=1);for(var m=0,p=0;i<t.length&&!(t[i].indexOf("--- ")===0&&i+2<t.length&&t[i+1].indexOf("+++ ")===0&&t[i+2].indexOf("@@")===0);i++){var g=t[i].length==0&&i!=t.length-1?" ":t[i][0];if(g==="+"||g==="-"||g===" "||g==="\\")h.lines.push(t[i]),h.linedelimiters.push(s[i]||`
|
|
258
|
+
`),g==="+"?m++:g==="-"?p++:g===" "&&(m++,p++);else break}if(!m&&h.newLines===1&&(h.newLines=0),!p&&h.oldLines===1&&(h.oldLines=0),e.strict){if(m!==h.newLines)throw new Error("Added line count did not match for hunk at line "+(u+1));if(p!==h.oldLines)throw new Error("Removed line count did not match for hunk at line "+(u+1))}return h}for(;i<t.length;)o();return r}function bb(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 Hu(n,e){var t=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{};if(typeof e=="string"&&(e=yb(e)),Array.isArray(e)){if(e.length>1)throw new Error("applyPatch only works with a single input.");e=e[0]}var s=n.split(/\r\n|[\n\v\f\r\x85]/),r=n.match(/\r\n|[\n\v\f\r\x85]/g)||[],i=e.hunks,o=t.compareLine||function(T,C,Z,D){return C===D},a=0,l=t.fuzzFactor||0,u=0,d=0,f,h;function m(T,C){for(var Z=0;Z<T.lines.length;Z++){var D=T.lines[Z],K=D.length>0?D[0]:" ",ee=D.length>0?D.substr(1):D;if(K===" "||K==="-"){if(!o(C+1,s[C],K,ee)&&(a++,a>l))return!1;C++}}return!0}for(var p=0;p<i.length;p++){for(var g=i[p],x=s.length-g.oldLines,S=0,A=d+g.oldStart-1,k=bb(A,u,x);S!==void 0;S=k())if(m(g,A+S)){g.offset=d+=S;break}if(S===void 0)return!1;u=g.offset+g.oldStart+g.oldLines}for(var y=0,b=0;b<i.length;b++){var v=i[b],w=v.oldStart+v.offset+y-1;y+=v.newLines-v.oldLines;for(var _=0;_<v.lines.length;_++){var E=v.lines[_],I=E.length>0?E[0]:" ",$=E.length>0?E.substr(1):E,F=v.linedelimiters&&v.linedelimiters[_]||`
|
|
259
|
+
`;if(I===" ")w++;else if(I==="-")s.splice(w,1),r.splice(w,1);else if(I==="+")s.splice(w,0,$),r.splice(w,0,F),w++;else if(I==="\\"){var B=v.lines[_-1]?v.lines[_-1][0]:null;B==="+"?f=!0:B==="-"&&(h=!0)}}}if(f)for(;!s[s.length-1];)s.pop(),r.pop();else h&&(s.push(""),r.push(`
|
|
260
|
+
`));for(var z=0;z<s.length-1;z++)s[z]=s[z]+r[z];return s.join("")}function vb(n,e,t,s,r,i,o){o||(o={}),typeof o.context>"u"&&(o.context=4);var a=cb(t,s,o);if(!a)return;a.push({value:"",lines:[]});function l(S){return S.map(function(A){return" "+A})}for(var u=[],d=0,f=0,h=[],m=1,p=1,g=function(A){var k=a[A],y=k.lines||k.value.replace(/\n$/,"").split(`
|
|
261
|
+
`);if(k.lines=y,k.added||k.removed){var b;if(!d){var v=a[A-1];d=m,f=p,v&&(h=o.context>0?l(v.lines.slice(-o.context)):[],d-=h.length,f-=h.length)}(b=h).push.apply(b,ro(y.map(function(z){return(k.added?"+":"-")+z}))),k.added?p+=y.length:m+=y.length}else{if(d)if(y.length<=o.context*2&&A<a.length-2){var w;(w=h).push.apply(w,ro(l(y)))}else{var _,E=Math.min(y.length,o.context);(_=h).push.apply(_,ro(l(y.slice(0,E))));var I={oldStart:d,oldLines:m-d+E,newStart:f,newLines:p-f+E,lines:h};if(A>=a.length-2&&y.length<=o.context){var $=/\n$/.test(t),F=/\n$/.test(s),B=y.length==0&&h.length>I.oldLines;!$&&B&&t.length>0&&h.splice(I.oldLines,0,"\"),(!$&&!B||!F)&&h.push("\")}u.push(I),d=0,f=0,h=[]}m+=y.length,p+=y.length}},x=0;x<a.length;x++)g(x);return{oldFileName:n,newFileName:e,oldHeader:r,newHeader:i,hunks:u}}function Bu(n){if(Array.isArray(n))return n.map(Bu).join(`
|
|
262
262
|
`);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(`
|
|
263
263
|
`)+`
|
|
264
|
-
`}function wb(n,e,t,s,r,i,o){return
|
|
265
|
-
`));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};ub=new
|
|
264
|
+
`}function wb(n,e,t,s,r,i,o){return Bu(vb(n,e,t,s,r,i,o))}function Uu(n,e,t,s,r,i){return wb(n,n,e,t,s,r,i)}var UC,Nu,Fu,ju,lo,ub,db,gb,Kn,ao,qu=N(()=>{Ct.prototype={diff:function(e,t){var s,r=arguments.length>2&&arguments[2]!==void 0?arguments[2]:{},i=r.callback;typeof r=="function"&&(i=r,r={}),this.options=r;var o=this;function a(y){return i?(setTimeout(function(){i(void 0,y)},0),!0):y}e=this.castInput(e),t=this.castInput(t),e=this.removeEmpty(this.tokenize(e)),t=this.removeEmpty(this.tokenize(t));var l=t.length,u=e.length,d=1,f=l+u;r.maxEditLength&&(f=Math.min(f,r.maxEditLength));var h=(s=r.timeout)!==null&&s!==void 0?s:1/0,m=Date.now()+h,p=[{oldPos:-1,lastComponent:void 0}],g=this.extractCommon(p[0],t,e,0);if(p[0].oldPos+1>=u&&g+1>=l)return a([{value:this.join(t),count:t.length}]);var x=-1/0,S=1/0;function A(){for(var y=Math.max(x,-d);y<=Math.min(S,d);y+=2){var b=void 0,v=p[y-1],w=p[y+1];v&&(p[y-1]=void 0);var _=!1;if(w){var E=w.oldPos-y;_=w&&0<=E&&E<l}var I=v&&v.oldPos+1<u;if(!_&&!I){p[y]=void 0;continue}if(!I||_&&v.oldPos+1<w.oldPos?b=o.addToPath(w,!0,void 0,0):b=o.addToPath(v,void 0,!0,1),g=o.extractCommon(b,t,e,y),b.oldPos+1>=u&&g+1>=l)return a(lb(o,b.lastComponent,t,e,o.useLongestToken));p[y]=b,b.oldPos+1>=u&&(S=Math.min(S,y-1)),g+1>=l&&(x=Math.max(x,y+1))}d++}if(i)(function y(){setTimeout(function(){if(d>f||Date.now()>m)return i();A()||y()},0)})();else for(;d<=f&&Date.now()<=m;){var k=A();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,u=0;l+1<i&&a+1<o&&this.equals(t[l+1],s[a+1]);)l++,a++,u++;return u&&(e.lastComponent={count:u,previousComponent:e.lastComponent}),e.oldPos=a,l},equals:function(e,t){return this.options.comparator?this.options.comparator(e,t):e===t||this.options.ignoreCase&&e.toLowerCase()===t.toLowerCase()},removeEmpty:function(e){for(var t=[],s=0;s<e.length;s++)e[s]&&t.push(e[s]);return t},castInput:function(e){return e},tokenize:function(e){return e.split("")},join:function(e){return e.join("")}};UC=new Ct,Nu=/^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/,Fu=/\S/,ju=new Ct;ju.equals=function(n,e){return this.options.ignoreCase&&(n=n.toLowerCase(),e=e.toLowerCase()),n===e||this.options.ignoreWhitespace&&!Fu.test(n)&&!Fu.test(e)};ju.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};lo=new Ct;lo.tokenize=function(n){this.options.stripTrailingCr&&(n=n.replace(/\r\n/g,`
|
|
265
|
+
`));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};ub=new Ct;ub.tokenize=function(n){return n.split(/(\S.+?[.!?])(?=\s+|$)/)};db=new Ct;db.tokenize=function(n){return n.split(/([{}:;,]|\s+)/)};gb=Object.prototype.toString,Kn=new Ct;Kn.useLongestToken=!0;Kn.tokenize=lo.tokenize;Kn.castInput=function(n){var e=this.options,t=e.undefinedReplacement,s=e.stringifyReplacer,r=s===void 0?function(i,o){return typeof o>"u"?t:o}:s;return typeof n=="string"?n:JSON.stringify(oo(n,null,null,r),r," ")};Kn.equals=function(n,e){return Ct.prototype.equals.call(Kn,n.replace(/,([\r\n])/g,"$1"),e.replace(/,([\r\n])/g,"$1"))};ao=new Ct;ao.tokenize=function(n){return n.slice()};ao.join=ao.removeEmpty=function(n){return n}});var Ku={};Ne(Ku,{applyDiff:()=>xb,formatDiffForDisplay:()=>Sb,generateDiff:()=>Us});function Us(n,e,t){return Uu(n,e,t,"original","modified")}function xb(n,e){return Hu(n,e)}function Sb(n){return n.split(`
|
|
266
266
|
`).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(`
|
|
267
|
-
`)}var co=N(()=>{"use strict";
|
|
268
|
-
`)}function
|
|
267
|
+
`)}var co=N(()=>{"use strict";qu()});async function Yt(n,e){let t=[],s=$e.join(n,"package.json");if(ge.existsSync(s))try{let o=JSON.parse(ge.readFileSync(s,"utf-8"));t.push(`Project: ${o.name||"unknown"}${o.version?` v${o.version}`:""}`),o.description&&t.push(`Description: ${o.description}`);let a=Object.keys(o.dependencies||{}).concat(Object.keys(o.devDependencies||{}));a.length>0&&t.push(`Key deps: ${a.slice(0,15).join(", ")}${a.length>15?"...":""}`)}catch{}if(e?.workspace?.frameworkDetection){let o=Ns(n);t.push(`Framework: ${o.framework}`),t.push(`Language: ${o.language}`),t.push(`Package Manager: ${o.packageManager}`),o.hasDocker&&t.push("Docker: detected"),o.hasCICD&&t.push("CI/CD: detected"),o.hasTests&&t.push("Tests: detected")}if(e?.workspace?.gitAwareness)try{let o=await zi(n);o&&(t.push(`Git branch: ${o.branch}`),o.modified.length>0&&t.push(`Modified files: ${o.modified.length}`),o.staged.length>0&&t.push(`Staged files: ${o.staged.length}`))}catch{}if(e?.workspace?.envParsing){let a=[".env",".env.local",".env.development",".env.production"].filter(l=>ge.existsSync($e.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=>ge.existsSync($e.join(n,o)));if(i.length>0&&t.push(`Config: ${i.join(", ")}`),e?.context?.projectGraph)try{let o=ge.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=ge.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(`
|
|
268
|
+
`)}function Jt(n,e,t,s){let r=n+`
|
|
269
269
|
|
|
270
270
|
## Current Project
|
|
271
271
|
`+e;if(t){let i=t.getSummary();i&&(r+=`
|
|
@@ -275,14 +275,14 @@ In order to be iterable, non-array objects must have a [Symbol.iterator]() metho
|
|
|
275
275
|
## Shared Context
|
|
276
276
|
`+i)}return r+=`
|
|
277
277
|
|
|
278
|
-
`+ru(),r}async function _b(n){try{if(!ge.existsSync(uo))return null;let t=(await
|
|
278
|
+
`+ru(),r}async function _b(n){try{if(!ge.existsSync(uo))return null;let t=(await Ft.readdir(uo)).filter(f=>f.endsWith(".bak"));if(n){let f=$e.basename(n);t=t.filter(h=>h.startsWith(`${f}.`))}if(t.length===0)return null;t.sort().reverse();let s=t[0],r=$e.join(uo,s),i=s.replace(".bak","").split("."),o=parseInt(i[i.length-1],10),a=i.slice(0,-1).join("."),l=Date.now()-o,u=Math.floor(l/6e4),d=u<1?"just now":u<60?`${u} minutes ago`:`${Math.floor(u/60)} hours ago`;return{backupPath:r,originalName:a,age:d}}catch{return null}}async function Wu(n,e,t,s,r,i,o,a,l,u,d,f,h,m,p,g,x){let S=n.split(/\s+/),A=S[0],k=S.slice(1).join(" ");switch(A){case"/quit":case"/exit":return"quit";case"/help":console.log(Su()),console.log(c.muted(" Model & Provider:")),console.log(c.muted(" /addmodel Interactive wizard to add a custom API")),console.log(c.muted(" /listmodels Show saved providers")),console.log(c.muted(" /removemodel <name> Remove a saved provider")),console.log(c.muted(" /usemodel <name> Switch to a saved provider")),console.log(c.muted(" /models [page|search] Browse all available models")),console.log(c.muted(" /provider Show/switch API provider")),console.log(),console.log(c.muted(" Aliases & Plugins:")),console.log(c.muted(" /alias Show all aliases")),console.log(c.muted(" /alias set <n> <cmd> Create an alias")),console.log(c.muted(" /alias del <name> Remove an alias")),console.log(c.muted(" /plugins List installed plugins")),console.log(c.muted(" /doctor Run system diagnostics")),console.log(),console.log(c.muted(" Task & Memory:")),console.log(c.muted(" /task add <desc> Add a task to the queue")),console.log(c.muted(" /task list Show all tasks")),console.log(c.muted(" /task clear Clear task queue")),console.log(c.muted(" /memory Show project memory")),console.log(c.muted(" /memory set <k> <v> Store a memory")),console.log(c.muted(" /memory del <key> Delete a memory")),console.log(c.muted(" /memory clear Clear all memory")),console.log(),console.log(c.muted(" Multi-Agent & Tools:")),console.log(c.muted(" /team Show team roster")),console.log(c.muted(" /delegate <agent> <t> Manually assign task to agent")),console.log(c.muted(" /agents Multi-agent system control")),console.log(c.muted(" /agents on|off Enable/disable multi-agent")),console.log(c.muted(" /agents status Show agent details")),console.log(c.muted(" /security Run security scan")),console.log(c.muted(" /git status Show git status")),console.log(c.muted(" /workspace Show workspace info")),console.log(c.muted(" /stats Show usage analytics")),console.log();break;case"/about":console.log(gu());break;case"/version":console.log(yu());break;case"/team":{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Team Roster")}`),console.log(),console.log(Mi()),console.log();break}case"/model":if(k){let y=await t.listModels();t.setModel(k),y.includes(k)?console.log(J(`Model: ${k}`)):console.log(U(`Model set to "${k}" (not found locally)`))}else console.log(fe(`Current model: ${t.getModel()}`)),console.log(c.muted(" Usage: /model <name>"));break;case"/models":{let y=k.trim(),b=1,v="";if(y){let C=parseInt(y);!isNaN(C)&&C>0?b=C:v=y.toLowerCase()}let w=new ze("Fetching models");w.start();let _=await t.listModels();if(w.stop(_.length>0?`${_.length} found`:void 0),_.length===0){console.log(U("No models found \u2014 check your connection")),console.log(c.muted(" Use /provider test to verify"));break}let E=_;if(v&&(E=_.filter(C=>C.toLowerCase().includes(v)),E.length===0)){console.log(U(`No models matching: "${v}"`)),console.log(c.muted(` ${_.length} models available. Try a different search.`));break}let I=20,$=Math.ceil(E.length/I),F=Math.max(1,Math.min(b,$)),B=(F-1)*I,z=B+I,T=E.slice(B,z);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Available Models")} ${c.muted(`(${E.length} total \xB7 page ${F}/${$})`)}`),console.log();for(let C=0;C<T.length;C++){let Z=B+C+1,K=T[C]===t.getModel()?` ${c.success("\u25CF active")}`:"";console.log(` ${c.muted(String(Z).padStart(3," "))}. ${c.secondary(T[C])}${K}`)}console.log(),$>1&&console.log(c.muted(` /models ${F<$?F+1:1} \u2014 next page`)),v&&console.log(c.muted(` Filtered: ${E.length} of ${_.length} (query: "${v}")`)),console.log(c.muted(" /models <query> \u2014 search \xB7 /model <id> \u2014 switch")),console.log();break}case"/tree":{let y=s.get("list_dir");if(y){let b=await y.execute({path:".",depth:3});console.log(`
|
|
279
279
|
${b.output}
|
|
280
|
-
`)}break}case"/status":{let y=await t.checkConnection(),b=u?u.getActiveName():"planner",v=f?f.size():0,w=d?d.getProgress():void 0;console.log(xu({model:t.getModel(),host:e.ollamaHost,directory:o,cacheFiles:r.getCacheSize(),cacheTokens:r.getTotalTokens(),budgetTokens:e.contextBudget,connected:y,turnCount:l,mindset:b})),v>0&&console.log(c.muted(` Memory entries: ${v}`)),w&&w.total>0&&console.log(c.muted(` Tasks: ${w.done}/${w.total} done`)),console.log();break}case"/clear":r.clear(),i.clear(),console.log(J("History cleared"));break;case"/history":{let y=parseInt(k)||10,b=i.getHistory().slice(-y);if(b.length===0){console.log(fe("No history yet"));break}console.log(),b.forEach(v=>{let w=v.role==="user"?c.primary("You"):v.role==="assistant"?c.success("Hablas"):c.muted("tool"),
|
|
280
|
+
`)}break}case"/status":{let y=await t.checkConnection(),b=u?u.getActiveName():"planner",v=f?f.size():0,w=d?d.getProgress():void 0;console.log(xu({model:t.getModel(),host:e.ollamaHost,directory:o,cacheFiles:r.getCacheSize(),cacheTokens:r.getTotalTokens(),budgetTokens:e.contextBudget,connected:y,turnCount:l,mindset:b})),v>0&&console.log(c.muted(` Memory entries: ${v}`)),w&&w.total>0&&console.log(c.muted(` Tasks: ${w.done}/${w.total} done`)),console.log();break}case"/clear":r.clear(),i.clear(),console.log(J("History cleared"));break;case"/history":{let y=parseInt(k)||10,b=i.getHistory().slice(-y);if(b.length===0){console.log(fe("No history yet"));break}console.log(),b.forEach(v=>{let w=v.role==="user"?c.primary("You"):v.role==="assistant"?c.success("Hablas"):c.muted("tool"),_=v.content.slice(0,120).replace(/\n/g," ");console.log(` ${w}: ${c.muted(_)}`)}),console.log();break}case"/undo":{if(!g){let y=await _b(k||void 0);if(!y){console.log(U("No backups found"));break}let b=k?$e.resolve(o,k):$e.resolve(o,y.originalName);if(await a.confirm(`Restore ${y.originalName} from backup (${y.age})?`))try{let w=await Ft.readFile(y.backupPath,"utf-8");await Ft.writeFile(b,w,"utf-8"),console.log(J(`Restored ${y.originalName} from backup (${y.age})`))}catch(w){console.log(Ce(`Failed: ${w.message}`))}break}if(k==="list")console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Undo History")} (${g.getUndoableCount()} changes)`),console.log(),console.log(g.formatList(20)),console.log();else if(k==="all"){let y=g.getUndoableCount();if(y===0){console.log(fe("Nothing to undo"));break}if(await a.confirm(`Undo ALL ${y} changes?`)){let v=await g.undoAll(),w=v.filter(_=>_.success).length;console.log(J(`Reverted ${w}/${v.length} changes`))}}else{let y=k&&parseInt(k)||1;if(g.getUndoableCount()===0){console.log(fe("Nothing to undo"));break}let b=await g.undo(y);for(let v of b)v.success?console.log(J(`Reverted: ${v.file}`)):console.log(Ce(`Failed to revert ${v.file}: ${v.error}`))}break}case"/config":console.log(`
|
|
281
281
|
${c.muted(JSON.stringify(e,null,2))}
|
|
282
|
-
`),console.log(c.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!u){console.log(U("Mindset system not available"));break}if(k)if(u.setActive(k)){let b=u.getActive(),v=await Jt(o,e),w=Qt(b.systemPrompt,v,f,m);i.updateSystemPrompt(w),console.log(J(`Mindset: ${b.name} \u2014 ${b.description}`))}else{let b=u.listNames().join(", ");console.log(He(`Unknown mindset: "${k}"`,`Available: ${b}`))}else{let y=u.getActive();y&&console.log(fe(`Current mindset: ${y.name} \u2014 ${y.description}`)),console.log(c.muted(" Usage: /mindset <name>")),console.log(c.muted(" See /mindsets for available options"))}break}case"/mindsets":{if(!u){console.log(U("Mindset system not available"));break}let y=u.list(),b=u.getActiveName();console.log();for(let v of y){let S=v.name===b?c.success(" \u25CF active"):"";console.log(` ${c.accent("\u25C6")} ${c.primary(v.name)}${S}`),console.log(` ${c.muted(v.description)}`)}console.log(),console.log(c.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(U("Task queue not available"));break}let y=_[1],b=_.slice(2).join(" ");switch(y){case"add":if(b){let v=d.add(b);console.log(J(`Task #${v.id} added: ${b}`))}else console.log(U("Usage: /task add <description>"));break;case"list":console.log(),console.log(d.render()),console.log();break;case"done":{let v=parseInt(b);v?(d.complete(v),console.log(J(`Task #${v} marked as done`))):console.log(U("Usage: /task done <id>"));break}case"fail":{let v=parseInt(b);v?(d.fail(v,"Manually marked as failed"),console.log(U(`Task #${v} marked as failed`))):console.log(U("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(J("Task queue cleared"));break;default:console.log(),console.log(d.render()),console.log(),console.log(c.muted(" /task add <desc> \u2014 Add a task")),console.log(c.muted(" /task list \u2014 Show all tasks")),console.log(c.muted(" /task done <id> \u2014 Mark task as done")),console.log(c.muted(" /task fail <id> \u2014 Mark task as failed")),console.log(c.muted(" /task clear \u2014 Clear all tasks")),console.log()}break}case"/addmodel":{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Add Custom API Provider")}`),console.log();let b=(await a.prompt(` ${c.muted("Provider name (e.g. OpenAI, Groq):")} `)).trim();if(!b){console.log(U("Cancelled \u2014 name is required"));break}let w=(await a.prompt(` ${c.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!w){console.log(U("Cancelled \u2014 URL is required"));break}let C=(await a.prompt(` ${c.muted("API Key (leave empty if none):")} `)).trim(),$=(await a.prompt(` ${c.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:b,apiUrl:w,apiKey:C,models:[$],defaultModel:$,addedAt:new Date().toISOString()};nt(F),console.log(),console.log(J(`Provider "${b}" saved!`)),console.log(c.muted(` Use: /usemodel ${b}`)),console.log();break}case"/listmodels":{let y=zt();console.log(),console.log(Rc(y.providers,y.activeProvider));break}case"/removemodel":{let y=k.trim();if(!y){console.log(U("Usage: /removemodel <provider-name>"));break}if(Ec(y))console.log(J(`Provider "${y}" removed`));else{console.log(U(`Provider "${y}" not found`));let v=Ts();v.length>0&&console.log(c.muted(` Available: ${v.map(w=>w.name).join(", ")}`))}break}case"/usemodel":{let y=k.trim();if(!y){console.log(U("Usage: /usemodel <provider-name> [model-id]"));let F=Ts();F.length>0&&console.log(c.muted(` Available: ${F.map(B=>B.name).join(", ")}`));break}let b=y.split(/\s+/),v=b[0],w=b[1],S=Cc(v);if(!S){console.log(U(`Provider "${v}" not found`));let F=Ts();F.length>0&&console.log(c.muted(` Available: ${F.map(B=>B.name).join(", ")}`));break}e.provider="custom",e.apiUrl=S.apiUrl,e.apiKey=S.apiKey,e.model=w||S.defaultModel;let C=Fe(e);h&&h(C),Tc(S.name,e.model),console.log(J(`Switched to ${S.name} \xB7 Model: ${e.model}`));let I=new ze("Testing");I.start();let $=await C.checkConnection();I.stop($?"connected":void 0),$||console.log(U("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=_[1],b=_.slice(2).join(" ");if(!y){let v=Cs(e);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Provider")}: ${v}`),console.log(` ${c.muted("Model")}: ${c.highlight(t.getModel())}`),e.provider==="custom"?(console.log(` ${c.muted("API URL")}: ${e.apiUrl}`),console.log(` ${c.muted("API Key")}: ${e.apiKey?"***"+e.apiKey.slice(-4):"not set"}`)):console.log(` ${c.muted("Host")}: ${e.ollamaHost}`),console.log(),console.log(c.muted(" /provider ollama \u2014 Switch to local Ollama")),console.log(c.muted(" /provider nvidia <key> \u2014 Switch to NVIDIA NIM")),console.log(c.muted(" /provider custom <url> [key] \u2014 Switch to custom API")),console.log(c.muted(" /provider test \u2014 Test current connection")),console.log();break}switch(y){case"ollama":{e.provider="ollama",e.apiUrl="",e.apiKey="";let v=Fe(e);h&&h(v),console.log(J("Switched to Ollama (local)"));break}case"nvidia":{let v=_[2];if(!v&&!e.apiKey){console.log(U("Usage: /provider nvidia <api-key>")),console.log(c.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=Dt.apiUrl,v&&(e.apiKey=v),(!e.model||!Dt.models.includes(e.model))&&(e.model=Dt.defaultModel);let w=Fe(e);h&&h(w),console.log(J(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(c.muted(` Available models: ${Dt.models.length}`));let S=new ze("Testing NVIDIA connection");S.start();let C=await w.checkConnection();S.stop(C?"connected":void 0),C||(console.log(U("Connection test failed \u2014 check your API key")),console.log(c.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let v=_[2],w=_[3];if(!v){console.log(U("Usage: /provider custom <api-url> [api-key]")),console.log(c.muted(" Example: /provider custom https://api.openai.com/v1 sk-..."));break}e.provider="custom",e.apiUrl=v,w&&(e.apiKey=w);let S=Fe(e);h&&h(S),console.log(J(`Switched to Custom API: ${v}`)),!w&&!e.apiKey&&console.log(U("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let v=new ze("Testing connection");v.start();let w=await t.checkConnection();if(v.stop(w?"connected":void 0),w){let S=await t.listModels();console.log(J(`Connected! ${S.length} models available.`)),S.length>0&&console.log(c.muted(` Models: ${S.slice(0,5).join(", ")}${S.length>5?"...":""}`))}else console.log(Ee("Connection failed"));break}case"key":{b?(e.apiKey=_[2],t instanceof Vt&&t.setApiKey(e.apiKey),console.log(J("API key updated"))):console.log(U("Usage: /provider key <api-key>"));break}default:console.log(He(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(U("Project memory not available"));break}let y=_[1],b=_.slice(2);switch(y){case"set":{if(b.length>=2){let v=b[0],w=b.slice(1).join(" ");f.set(v,w),console.log(J(`Memory stored: ${v}`));let S=u?.getActive(),C=S?S.systemPrompt:Gn,I=await Jt(o,e);i.updateSystemPrompt(Qt(C,I,f,m))}else console.log(U("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(b[0]){let v=f.delete(b[0]);console.log(v?J(`Memory deleted: ${b[0]}`):U(`Memory key not found: ${b[0]}`))}else console.log(U("Usage: /memory del <key>"));break}case"search":{if(b[0]){let v=f.search(b.join(" "));v.length>0?(console.log(),v.forEach(w=>console.log(` \xB7 ${w.entry.key}: ${w.entry.value}`)),console.log()):console.log(fe("No matching memories found"))}else console.log(U("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(J("Project memory cleared"));break;default:console.log(),console.log(f.render()),console.log(),console.log(c.muted(" /memory set <k> <v> \u2014 Store a memory")),console.log(c.muted(" /memory del <key> \u2014 Delete a memory")),console.log(c.muted(" /memory search <q> \u2014 Search memories")),console.log(c.muted(" /memory clear \u2014 Clear all")),console.log()}break}case"/alias":{let y=_[1],b=_.slice(2);switch(y){case"set":{if(b.length>=2){let v=b[0],w=b.slice(1).join(" ");Ic(v,w),console.log(J(`Alias set: ${v} \u2192 ${w}`))}else console.log(U("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(b[0]){let v=Mc(b[0]);console.log(v?J(`Alias removed: ${b[0]}`):U(`Alias not found: ${b[0]}`))}else console.log(U("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Aliases")}`),console.log(),console.log(Dc()),console.log(),console.log(c.muted(" /alias set <name> <cmd> \u2014 Create alias")),console.log(c.muted(" /alias del <name> \u2014 Remove alias")),console.log()}break}case"/doctor":{let y=new ze("Running diagnostics");y.start();let b=await Ci({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log(Ti(b));break}case"/plugins":{let y=_[1],b=_.slice(2).join(" ");switch(y){case"enable":b?(_i(b),console.log(J(`Plugin "${b}" enabled`))):console.log(U("Usage: /plugins enable <name>"));break;case"disable":b?(Ai(b),console.log(U(`Plugin "${b}" disabled`))):console.log(U("Usage: /plugins disable <name>"));break;default:Ls(),console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plugins")}`),console.log(),console.log(ki()),console.log(),console.log(c.muted(" /plugins enable <name> \u2014 Enable plugin")),console.log(c.muted(" /plugins disable <name> \u2014 Disable plugin")),console.log(c.muted(" Directory: ~/.hablas/plugins/")),console.log()}break}case"/agents":{let y=_[1];if(y==="on")e.agents.enabled=!0,console.log(J("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(J("Multi-agent orchestration disabled"));else if(y==="status")console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}`),console.log(` Status: ${e.agents.enabled?c.success("enabled"):c.muted("disabled")}`),console.log(` Orchestration: ${e.agents.orchestration}`),console.log(` Max concurrent: ${e.agents.maxConcurrent}`),console.log(),console.log(` ${c.strong("Team:")}`),console.log(Mi()),console.log();else if(y==="models"){let b=Hn();console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Agent Models")}`),console.log();for(let v of xe){let w=b[v.role];console.log(w?` ${c.primary(v.name.padEnd(8))} \u2192 ${c.highlight(w.model)}${w.temperature!==void 0?c.muted(` (temp: ${w.temperature})`):""}`:` ${c.primary(v.name.padEnd(8))} \u2192 ${c.muted("(default)")}`)}console.log(),console.log(c.muted(` Config: ${Gc()}`)),console.log(c.muted(" Edit the file to change models per agent.")),console.log()}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}: ${e.agents.enabled?c.success("ON"):c.muted("OFF")}`),console.log(),console.log(c.muted(" /agents on \u2014 Enable multi-agent orchestration")),console.log(c.muted(" /agents off \u2014 Disable multi-agent orchestration")),console.log(c.muted(" /agents status \u2014 Show agent details")),console.log(c.muted(" /agents models \u2014 Show model per agent")),console.log(c.muted(" /team \u2014 Show team roster")),console.log();break}case"/security":{console.log(),console.log(` ${c.accent("\u{1F512}")} Running security scan...`);let y=Wi(o);console.log(Gi(y));break}case"/git":{if(_[1]==="status")try{let{getGitStatus:b,formatGitStatus:v}=await Promise.resolve().then(()=>(gn(),Kn)),w=await b(o);w?(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Status")}`),console.log(v(w)),console.log()):console.log(U("Not a git repository"))}catch{console.log(U("Git not available"))}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Intelligence")}`),console.log(),console.log(c.muted(" /git status \u2014 Show git status")),console.log(c.muted(" hablas commit \u2014 Smart commit message")),console.log(c.muted(" hablas pr \u2014 Generate PR description")),console.log(c.muted(" hablas changelog \u2014 Generate changelog")),console.log();break}case"/workspace":{let y=Fs(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Workspace Information")}`),console.log(),console.log(Yi(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:b}=await Promise.resolve().then(()=>(qn(),Ki)),v=y();console.log(b(v));break}case"/context":{if(!m){console.log(U("Shared context not available"));break}let y=_[1],b=_.slice(2);switch(y){case"set":{if(b.length>=2){let v=b[0],w=b.slice(1).join(" ");m.set(v,w),console.log(J(`Context stored: ${v}`))}else console.log(U("Usage: /context set <key> <value>"));break}case"get":{if(b[0]){let v=m.get(b[0]);v!==void 0?(console.log(),console.log(` ${c.accent("\u25C6")} ${c.strong(b[0])}: ${v}`),console.log()):console.log(U(`Context key not found: ${b[0]}`))}else console.log(U("Usage: /context get <key>"));break}case"del":case"delete":{if(b[0]){let v=m.delete(b[0]);console.log(v?J(`Context deleted: ${b[0]}`):U(`Context key not found: ${b[0]}`))}else console.log(U("Usage: /context del <key>"));break}case"decisions":{let v=m.getDecisions();if(v.length===0)console.log(fe("No decisions logged yet"));else{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Decisions")}`),console.log();for(let w of v)console.log(` ${c.muted(w.timestamp)} ${c.primary(w.by)}: ${w.decision}`),w.rationale&&console.log(` ${c.muted(w.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(J("Shared context cleared"));break;default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Shared Context")}`),console.log(),console.log(m.render()),console.log(),console.log(c.muted(" /context set <k> <v> \u2014 Store a context entry")),console.log(c.muted(" /context get <key> \u2014 Get a context entry")),console.log(c.muted(" /context del <key> \u2014 Delete a context entry")),console.log(c.muted(" /context decisions \u2014 Show logged decisions")),console.log(c.muted(" /context clear \u2014 Clear all context")),console.log()}break}case"/plan":{if(!p){console.log(U("Plan manager not available"));break}let y=_[1],b=_.slice(2).join(" ");switch(y){case"status":{let w=p.getActivePlan();if(!w){console.log(fe("No active plan"));break}let S=p.getProgress();console.log(js(w,{percent:S.percentage,done:S.done,total:S.total}));break}case"finish":{if(b){p.finishTask(b),console.log(J(`Task finished: ${b}`));let w=p.getProgress();console.log(c.muted(` Progress: ${w.done}/${w.total} (${w.percentage}%)`))}else console.log(U("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(J("Plan manager reset"));break}case"next":{let w=p.getNextTask();console.log(w?fe(`Next task: [${w.task_id}] ${w.description} \u2192 @${w.assignee}`):fe("No pending tasks"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plan Manager")}`),console.log();let v=p.getActivePlan();if(v){let w=p.getProgress();console.log(` Active plan: ${v.title} (${w.percentage}% done)`),console.log(` Tasks: ${w.done}/${w.total}`)}else console.log(c.muted(" No active plan"));console.log(),console.log(c.muted(" /plan status \u2014 Show active plan with progress")),console.log(c.muted(" /plan finish <id> \u2014 Mark a task as finished")),console.log(c.muted(" /plan next \u2014 Show next pending task")),console.log(c.muted(" /plan reset \u2014 Reset plan manager")),console.log()}break}case"/learn":{if(!f||!k){console.log(U('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 b=await Jt(o,e),v=u?.getActive(),w=v?v.systemPrompt:Gn,S=Qt(w,b,f,m);i.updateSystemPrompt(S)}console.log(J(`Learned: "${k}"`)),console.log(c.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=so(o);if(y==="unknown"&&!k){console.log(U("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(fe(`Running tests (${y})...`));let b=ku(o,k==="--fix"?void 0:k||void 0);if(console.log(),console.log($u(b)),console.log(),!b.passed&&k==="--fix"){console.log(fe("Tests failed \u2014 adding fix request to conversation..."));let v=Eu(b);i.addUserMessage(v),console.log(fe("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=_[1],b=_.slice(2).join(" ");if(y==="save"){let v=b||`Checkpoint at turn ${l}`,w=g?.getModifiedFiles?.()||[],S=await Ru(o,v,w);console.log(J(`Checkpoint saved: ${S.id} "${v}" (${S.fileCount} files)`))}else if(y==="list"){let v=Pu(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoints")}`),console.log(),console.log(Mu(v)),console.log()}else if(y==="restore"){if(!b){console.log(U("Usage: /checkpoint restore <id>"));break}let v=await Ou(o,b);v.success?console.log(J(`Restored checkpoint: ${b} (${v.filesRestored} files)`)):console.log(Ee(v.error||"Restore failed"))}else y==="delete"?b&&Iu(o,b)?console.log(J(`Deleted checkpoint: ${b}`)):console.log(U("Checkpoint not found")):(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoint System")}`),console.log(),console.log(c.muted(' /checkpoint save "label" \u2014 Save current state')),console.log(c.muted(" /checkpoint list \u2014 List saved checkpoints")),console.log(c.muted(" /checkpoint restore <id> \u2014 Restore a checkpoint")),console.log(c.muted(" /checkpoint delete <id> \u2014 Delete a checkpoint")),console.log());break}case"/compare":{let y=_.slice(1);if(y.length===2)try{let b=await jt.readFile($e.resolve(o,y[0]),"utf-8"),v=await jt.readFile($e.resolve(o,y[1]),"utf-8"),{generateDiff:w}=await Promise.resolve().then(()=>(co(),qu)),S=w(y[0]+" vs "+y[1],b,v);console.log(eo(S))}catch(b){console.log(Ee(`Compare failed: ${b.message}`))}else if(y.length===1&&y[0].startsWith("HEAD"))try{let{execSync:b}=await import("child_process"),v=b(`git diff ${y[0]}`,{cwd:o,encoding:"utf-8",timeout:1e4});console.log(eo(v||"(no changes)"))}catch(b){console.log(Ee(`Git diff failed: ${b.message}`))}else console.log(c.muted(" Usage: /compare file1.ts file2.ts or /compare HEAD~1"));break}case"/cost":{let y=Bn(),b="current";console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Session Cost & Usage")}`),console.log(),console.log(` Session duration: ${b} min`),console.log(` Messages: ${y.totalMessages}`),console.log(` Tool calls: ${y.totalToolCalls}`),console.log(` Tokens used: ${y.totalTokensUsed.toLocaleString()}`),console.log();let v=Object.entries(y.agentUsage);if(v.length>0){console.log(" Agent usage:");for(let[w,S]of v.sort((C,I)=>I[1]-C[1]))console.log(` @${w}: ${S} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(U("Multi-agent system is disabled. Enable with /agents on"));break}let y=_[1]?.toLowerCase(),b=_.slice(2).join(" ");if(!y||!b){console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Delegate Task to Agent")}`),console.log(),console.log(c.muted(" Usage: /delegate <agent> <task description>")),console.log(),console.log(c.muted(" Agents:")),console.log(` ${c.product("emma")} \u2014 Product Manager`),console.log(` ${c.architect("bob")} \u2014 Architect`),console.log(` ${c.engineer("alex")} \u2014 Engineer`),console.log(` ${c.analyst("david")} \u2014 Data Analyst`),console.log(),console.log(c.muted(" Example: /delegate alex create a login component")),console.log();break}let v=["emma","bob","alex","david","hablas"];if(!v.includes(y)){console.log(U(`Unknown agent: "${y}". Valid: ${v.join(", ")}`));break}let w=xe.find(S=>S.role===y);if(w){if(!x){console.log(U("Agent runner not initialized. Cannot delegate."));break}console.log(hu("Hablas",w.name,w.title,b)),console.log(bn(w.name,w.title));let S=s.getOllamaTools(),C=await x.runAgent(y,b,void 0,S);C.success&&C.output?(console.log(vn(C.output)),i.addAssistantMessage(`[@${w.name}]: ${C.output}`)):C.error?console.log(U(`${w.name} failed: ${C.error}`)):console.log(fe(`${w.name} completed without output.`))}break}case"/session":{let y=_[1],b=_.slice(2).join(" "),v=$e.join(fo.homedir(),".hablas","sessions");if(y==="save"){let w=b||`session_${Date.now()}`;try{ge.existsSync(v)||ge.mkdirSync(v,{recursive:!0});let S=i.toJSON(),C=$e.join(v,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);ge.writeFileSync(C,S,"utf-8"),console.log(J(`Session saved: "${w}"`))}catch(S){console.log(Ee(`Save failed: ${S.message}`))}}else if(y==="list")try{if(!ge.existsSync(v)){console.log(fe("No saved sessions"));break}let w=ge.readdirSync(v).filter(S=>S.endsWith(".json"));console.log();for(let S of w){let C=ge.statSync($e.join(v,S));console.log(` ${S.replace(".json","")} (${new Date(C.mtime).toLocaleString()})`)}console.log()}catch{console.log(fe("No saved sessions"))}else if(y==="load"){let w=b;if(!w){console.log(Ee("Please specify the session label to load: /session load <label>"));break}try{let S=$e.join(v,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!ge.existsSync(S)){console.log(Ee(`Session file not found: ${w}`));break}let C=ge.readFileSync(S,"utf-8");i.fromJSON(C),console.log(J(`Session successfully loaded: "${w}"`))}catch(S){console.log(Ee(`Load failed: ${S.message}`))}}else console.log(),console.log(c.muted(' /session save "label" \u2014 Save current conversation')),console.log(c.muted(" /session list \u2014 List saved sessions")),console.log(c.muted(' /session load "label" \u2014 Load saved conversation')),console.log();break}case"/team":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Et(),Ht));if(!y){console.log(U("Team mode is not active. Use hablas --team to start."));break}let b=y.getLocalState(),v=Math.min(process.stdout.columns-4,80);console.log(`
|
|
283
|
-
`+c.border("\u2554"+"\u2550".repeat(v-2)+"\u2557")),console.log(c.border("\u2551")+" ".repeat(Math.floor((v-22)/2))+c.strong("HABLAS COLLABORATION SYNC")+" ".repeat(v-2-25-Math.floor((v-22)/2))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(v-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("My Identity:")} ${c.highlight(`@${b.my_username}`)}`+" ".repeat(Math.max(1,v-21-(b.my_username?.length||0)))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Room Fingerprint:")} ${c.muted(b.project_team_token?.slice(0,12))}...`+" ".repeat(Math.max(1,v-34))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Status:")} ${c.success("\u25CF ACTIVE")}`+" ".repeat(Math.max(1,v-31))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(v-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("Teammates Online:")}`+" ".repeat(Math.max(1,v-21))+c.border("\u2551"));let
|
|
282
|
+
`),console.log(c.muted(" ~/.hablas/config.json")),console.log();break;case"/mindset":{if(!u){console.log(U("Mindset system not available"));break}if(k)if(u.setActive(k)){let b=u.getActive(),v=await Yt(o,e),w=Jt(b.systemPrompt,v,f,m);i.updateSystemPrompt(w),console.log(J(`Mindset: ${b.name} \u2014 ${b.description}`))}else{let b=u.listNames().join(", ");console.log(He(`Unknown mindset: "${k}"`,`Available: ${b}`))}else{let y=u.getActive();y&&console.log(fe(`Current mindset: ${y.name} \u2014 ${y.description}`)),console.log(c.muted(" Usage: /mindset <name>")),console.log(c.muted(" See /mindsets for available options"))}break}case"/mindsets":{if(!u){console.log(U("Mindset system not available"));break}let y=u.list(),b=u.getActiveName();console.log();for(let v of y){let _=v.name===b?c.success(" \u25CF active"):"";console.log(` ${c.accent("\u25C6")} ${c.primary(v.name)}${_}`),console.log(` ${c.muted(v.description)}`)}console.log(),console.log(c.muted(" Switch: /mindset <name>")),console.log();break}case"/task":{if(!d){console.log(U("Task queue not available"));break}let y=S[1],b=S.slice(2).join(" ");switch(y){case"add":if(b){let v=d.add(b);console.log(J(`Task #${v.id} added: ${b}`))}else console.log(U("Usage: /task add <description>"));break;case"list":console.log(),console.log(d.render()),console.log();break;case"done":{let v=parseInt(b);v?(d.complete(v),console.log(J(`Task #${v} marked as done`))):console.log(U("Usage: /task done <id>"));break}case"fail":{let v=parseInt(b);v?(d.fail(v,"Manually marked as failed"),console.log(U(`Task #${v} marked as failed`))):console.log(U("Usage: /task fail <id>"));break}case"clear":d.clear(),console.log(J("Task queue cleared"));break;default:console.log(),console.log(d.render()),console.log(),console.log(c.muted(" /task add <desc> \u2014 Add a task")),console.log(c.muted(" /task list \u2014 Show all tasks")),console.log(c.muted(" /task done <id> \u2014 Mark task as done")),console.log(c.muted(" /task fail <id> \u2014 Mark task as failed")),console.log(c.muted(" /task clear \u2014 Clear all tasks")),console.log()}break}case"/addmodel":{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Add Custom API Provider")}`),console.log();let b=(await a.prompt(` ${c.muted("Provider name (e.g. OpenAI, Groq):")} `)).trim();if(!b){console.log(U("Cancelled \u2014 name is required"));break}let w=(await a.prompt(` ${c.muted("API URL (e.g. https://api.openai.com/v1):")} `)).trim();if(!w){console.log(U("Cancelled \u2014 URL is required"));break}let E=(await a.prompt(` ${c.muted("API Key (leave empty if none):")} `)).trim(),$=(await a.prompt(` ${c.muted("Default model ID (e.g. gpt-4o):")} `)).trim()||"default",F={name:b,apiUrl:w,apiKey:E,models:[$],defaultModel:$,addedAt:new Date().toISOString()};nt(F),console.log(),console.log(J(`Provider "${b}" saved!`)),console.log(c.muted(` Use: /usemodel ${b}`)),console.log();break}case"/listmodels":{let y=Vt();console.log(),console.log(Rc(y.providers,y.activeProvider));break}case"/removemodel":{let y=k.trim();if(!y){console.log(U("Usage: /removemodel <provider-name>"));break}if(Cc(y))console.log(J(`Provider "${y}" removed`));else{console.log(U(`Provider "${y}" not found`));let v=Es();v.length>0&&console.log(c.muted(` Available: ${v.map(w=>w.name).join(", ")}`))}break}case"/usemodel":{let y=k.trim();if(!y){console.log(U("Usage: /usemodel <provider-name> [model-id]"));let F=Es();F.length>0&&console.log(c.muted(` Available: ${F.map(B=>B.name).join(", ")}`));break}let b=y.split(/\s+/),v=b[0],w=b[1],_=Ec(v);if(!_){console.log(U(`Provider "${v}" not found`));let F=Es();F.length>0&&console.log(c.muted(` Available: ${F.map(B=>B.name).join(", ")}`));break}e.provider="custom",e.apiUrl=_.apiUrl,e.apiKey=_.apiKey,e.model=w||_.defaultModel;let E=Fe(e);h&&h(E),Tc(_.name,e.model),console.log(J(`Switched to ${_.name} \xB7 Model: ${e.model}`));let I=new ze("Testing");I.start();let $=await E.checkConnection();I.stop($?"connected":void 0),$||console.log(U("Connection test failed \u2014 check URL and key"));break}case"/provider":{let y=S[1],b=S.slice(2).join(" ");if(!y){let v=Cs(e);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Provider")}: ${v}`),console.log(` ${c.muted("Model")}: ${c.highlight(t.getModel())}`),e.provider==="custom"?(console.log(` ${c.muted("API URL")}: ${e.apiUrl}`),console.log(` ${c.muted("API Key")}: ${e.apiKey?"***"+e.apiKey.slice(-4):"not set"}`)):console.log(` ${c.muted("Host")}: ${e.ollamaHost}`),console.log(),console.log(c.muted(" /provider ollama \u2014 Switch to local Ollama")),console.log(c.muted(" /provider nvidia <key> \u2014 Switch to NVIDIA NIM")),console.log(c.muted(" /provider custom <url> [key] \u2014 Switch to custom API")),console.log(c.muted(" /provider test \u2014 Test current connection")),console.log();break}switch(y){case"ollama":{e.provider="ollama",e.apiUrl="",e.apiKey="";let v=Fe(e);h&&h(v),console.log(J("Switched to Ollama (local)"));break}case"nvidia":{let v=S[2];if(!v&&!e.apiKey){console.log(U("Usage: /provider nvidia <api-key>")),console.log(c.muted(" Get your key at: https://build.nvidia.com/"));break}e.provider="nvidia",e.apiUrl=Dt.apiUrl,v&&(e.apiKey=v),(!e.model||!Dt.models.includes(e.model))&&(e.model=Dt.defaultModel);let w=Fe(e);h&&h(w),console.log(J(`Switched to NVIDIA NIM \xB7 Model: ${e.model}`)),console.log(c.muted(` Available models: ${Dt.models.length}`));let _=new ze("Testing NVIDIA connection");_.start();let E=await w.checkConnection();_.stop(E?"connected":void 0),E||(console.log(U("Connection test failed \u2014 check your API key")),console.log(c.muted(" Get key: https://build.nvidia.com/")));break}case"custom":{let v=S[2],w=S[3];if(!v){console.log(U("Usage: /provider custom <api-url> [api-key]")),console.log(c.muted(" Example: /provider custom https://api.openai.com/v1 sk-..."));break}e.provider="custom",e.apiUrl=v,w&&(e.apiKey=w);let _=Fe(e);h&&h(_),console.log(J(`Switched to Custom API: ${v}`)),!w&&!e.apiKey&&console.log(U("No API key set. Use: /provider custom <url> <key>"));break}case"test":{let v=new ze("Testing connection");v.start();let w=await t.checkConnection();if(v.stop(w?"connected":void 0),w){let _=await t.listModels();console.log(J(`Connected! ${_.length} models available.`)),_.length>0&&console.log(c.muted(` Models: ${_.slice(0,5).join(", ")}${_.length>5?"...":""}`))}else console.log(Ce("Connection failed"));break}case"key":{b?(e.apiKey=S[2],t instanceof Gt&&t.setApiKey(e.apiKey),console.log(J("API key updated"))):console.log(U("Usage: /provider key <api-key>"));break}default:console.log(He(`Unknown: /provider ${y}`,"Type /provider for help"))}break}case"/memory":{if(!f){console.log(U("Project memory not available"));break}let y=S[1],b=S.slice(2);switch(y){case"set":{if(b.length>=2){let v=b[0],w=b.slice(1).join(" ");f.set(v,w),console.log(J(`Memory stored: ${v}`));let _=u?.getActive(),E=_?_.systemPrompt:Wn,I=await Yt(o,e);i.updateSystemPrompt(Jt(E,I,f,m))}else console.log(U("Usage: /memory set <key> <value>"));break}case"del":case"delete":{if(b[0]){let v=f.delete(b[0]);console.log(v?J(`Memory deleted: ${b[0]}`):U(`Memory key not found: ${b[0]}`))}else console.log(U("Usage: /memory del <key>"));break}case"search":{if(b[0]){let v=f.search(b.join(" "));v.length>0?(console.log(),v.forEach(w=>console.log(` \xB7 ${w.entry.key}: ${w.entry.value}`)),console.log()):console.log(fe("No matching memories found"))}else console.log(U("Usage: /memory search <query>"));break}case"clear":f.clear(),console.log(J("Project memory cleared"));break;default:console.log(),console.log(f.render()),console.log(),console.log(c.muted(" /memory set <k> <v> \u2014 Store a memory")),console.log(c.muted(" /memory del <key> \u2014 Delete a memory")),console.log(c.muted(" /memory search <q> \u2014 Search memories")),console.log(c.muted(" /memory clear \u2014 Clear all")),console.log()}break}case"/alias":{let y=S[1],b=S.slice(2);switch(y){case"set":{if(b.length>=2){let v=b[0],w=b.slice(1).join(" ");Ic(v,w),console.log(J(`Alias set: ${v} \u2192 ${w}`))}else console.log(U("Usage: /alias set <name> <expansion>"));break}case"del":case"remove":{if(b[0]){let v=Mc(b[0]);console.log(v?J(`Alias removed: ${b[0]}`):U(`Alias not found: ${b[0]}`))}else console.log(U("Usage: /alias del <name>"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Aliases")}`),console.log(),console.log(Dc()),console.log(),console.log(c.muted(" /alias set <name> <cmd> \u2014 Create alias")),console.log(c.muted(" /alias del <name> \u2014 Remove alias")),console.log()}break}case"/doctor":{let y=new ze("Running diagnostics");y.start();let b=await Ei({ollamaHost:e.ollamaHost,model:t.getModel(),provider:e.provider,apiUrl:e.apiUrl});y.stop(),console.log(Ti(b));break}case"/plugins":{let y=S[1],b=S.slice(2).join(" ");switch(y){case"enable":b?(_i(b),console.log(J(`Plugin "${b}" enabled`))):console.log(U("Usage: /plugins enable <name>"));break;case"disable":b?(Ai(b),console.log(U(`Plugin "${b}" disabled`))):console.log(U("Usage: /plugins disable <name>"));break;default:Ms(),console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plugins")}`),console.log(),console.log(ki()),console.log(),console.log(c.muted(" /plugins enable <name> \u2014 Enable plugin")),console.log(c.muted(" /plugins disable <name> \u2014 Disable plugin")),console.log(c.muted(" Directory: ~/.hablas/plugins/")),console.log()}break}case"/agents":{let y=S[1];if(y==="on")e.agents.enabled=!0,console.log(J("Multi-agent orchestration enabled"));else if(y==="off")e.agents.enabled=!1,console.log(J("Multi-agent orchestration disabled"));else if(y==="status")console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}`),console.log(` Status: ${e.agents.enabled?c.success("enabled"):c.muted("disabled")}`),console.log(` Orchestration: ${e.agents.orchestration}`),console.log(` Max concurrent: ${e.agents.maxConcurrent}`),console.log(),console.log(` ${c.strong("Team:")}`),console.log(Mi()),console.log();else if(y==="models"){let b=jn();console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Agent Models")}`),console.log();for(let v of xe){let w=b[v.role];console.log(w?` ${c.primary(v.name.padEnd(8))} \u2192 ${c.highlight(w.model)}${w.temperature!==void 0?c.muted(` (temp: ${w.temperature})`):""}`:` ${c.primary(v.name.padEnd(8))} \u2192 ${c.muted("(default)")}`)}console.log(),console.log(c.muted(` Config: ${Gc()}`)),console.log(c.muted(" Edit the file to change models per agent.")),console.log()}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Multi-Agent System")}: ${e.agents.enabled?c.success("ON"):c.muted("OFF")}`),console.log(),console.log(c.muted(" /agents on \u2014 Enable multi-agent orchestration")),console.log(c.muted(" /agents off \u2014 Disable multi-agent orchestration")),console.log(c.muted(" /agents status \u2014 Show agent details")),console.log(c.muted(" /agents models \u2014 Show model per agent")),console.log(c.muted(" /team \u2014 Show team roster")),console.log();break}case"/security":{console.log(),console.log(` ${c.accent("\u{1F512}")} Running security scan...`);let y=Wi(o);console.log(Gi(y));break}case"/git":{if(S[1]==="status")try{let{getGitStatus:b,formatGitStatus:v}=await Promise.resolve().then(()=>(mn(),qn)),w=await b(o);w?(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Status")}`),console.log(v(w)),console.log()):console.log(U("Not a git repository"))}catch{console.log(U("Git not available"))}else console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Git Intelligence")}`),console.log(),console.log(c.muted(" /git status \u2014 Show git status")),console.log(c.muted(" hablas commit \u2014 Smart commit message")),console.log(c.muted(" hablas pr \u2014 Generate PR description")),console.log(c.muted(" hablas changelog \u2014 Generate changelog")),console.log();break}case"/workspace":{let y=Ns(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Workspace Information")}`),console.log(),console.log(Yi(y)),console.log();break}case"/stats":{let{loadStats:y,formatStats:b}=await Promise.resolve().then(()=>(Un(),Ki)),v=y();console.log(b(v));break}case"/context":{if(!m){console.log(U("Shared context not available"));break}let y=S[1],b=S.slice(2);switch(y){case"set":{if(b.length>=2){let v=b[0],w=b.slice(1).join(" ");m.set(v,w),console.log(J(`Context stored: ${v}`))}else console.log(U("Usage: /context set <key> <value>"));break}case"get":{if(b[0]){let v=m.get(b[0]);v!==void 0?(console.log(),console.log(` ${c.accent("\u25C6")} ${c.strong(b[0])}: ${v}`),console.log()):console.log(U(`Context key not found: ${b[0]}`))}else console.log(U("Usage: /context get <key>"));break}case"del":case"delete":{if(b[0]){let v=m.delete(b[0]);console.log(v?J(`Context deleted: ${b[0]}`):U(`Context key not found: ${b[0]}`))}else console.log(U("Usage: /context del <key>"));break}case"decisions":{let v=m.getDecisions();if(v.length===0)console.log(fe("No decisions logged yet"));else{console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Decisions")}`),console.log();for(let w of v)console.log(` ${c.muted(w.timestamp)} ${c.primary(w.by)}: ${w.decision}`),w.rationale&&console.log(` ${c.muted(w.rationale)}`);console.log()}break}case"clear":m.clear(),console.log(J("Shared context cleared"));break;default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Shared Context")}`),console.log(),console.log(m.render()),console.log(),console.log(c.muted(" /context set <k> <v> \u2014 Store a context entry")),console.log(c.muted(" /context get <key> \u2014 Get a context entry")),console.log(c.muted(" /context del <key> \u2014 Delete a context entry")),console.log(c.muted(" /context decisions \u2014 Show logged decisions")),console.log(c.muted(" /context clear \u2014 Clear all context")),console.log()}break}case"/plan":{if(!p){console.log(U("Plan manager not available"));break}let y=S[1],b=S.slice(2).join(" ");switch(y){case"status":{let w=p.getActivePlan();if(!w){console.log(fe("No active plan"));break}let _=p.getProgress();console.log(Fs(w,{percent:_.percentage,done:_.done,total:_.total}));break}case"finish":{if(b){p.finishTask(b),console.log(J(`Task finished: ${b}`));let w=p.getProgress();console.log(c.muted(` Progress: ${w.done}/${w.total} (${w.percentage}%)`))}else console.log(U("Usage: /plan finish <task_id>"));break}case"reset":{p.reset(),console.log(J("Plan manager reset"));break}case"next":{let w=p.getNextTask();console.log(w?fe(`Next task: [${w.task_id}] ${w.description} \u2192 @${w.assignee}`):fe("No pending tasks"));break}default:console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Plan Manager")}`),console.log();let v=p.getActivePlan();if(v){let w=p.getProgress();console.log(` Active plan: ${v.title} (${w.percentage}% done)`),console.log(` Tasks: ${w.done}/${w.total}`)}else console.log(c.muted(" No active plan"));console.log(),console.log(c.muted(" /plan status \u2014 Show active plan with progress")),console.log(c.muted(" /plan finish <id> \u2014 Mark a task as finished")),console.log(c.muted(" /plan next \u2014 Show next pending task")),console.log(c.muted(" /plan reset \u2014 Reset plan manager")),console.log()}break}case"/learn":{if(!f||!k){console.log(U('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 b=await Yt(o,e),v=u?.getActive(),w=v?v.systemPrompt:Wn,_=Jt(w,b,f,m);i.updateSystemPrompt(_)}console.log(J(`Learned: "${k}"`)),console.log(c.muted(" This will be remembered across sessions and injected into every prompt."));break}case"/test":{let y=so(o);if(y==="unknown"&&!k){console.log(U("No test framework detected. Install jest, vitest, pytest, etc."));break}console.log(fe(`Running tests (${y})...`));let b=$u(o,k==="--fix"?void 0:k||void 0);if(console.log(),console.log(Cu(b)),console.log(),!b.passed&&k==="--fix"){console.log(fe("Tests failed \u2014 adding fix request to conversation..."));let v=Eu(b);i.addUserMessage(v),console.log(fe("Type your next message or let the agent work on the fix."))}break}case"/checkpoint":{let y=S[1],b=S.slice(2).join(" ");if(y==="save"){let v=b||`Checkpoint at turn ${l}`,w=g?.getModifiedFiles?.()||[],_=await Pu(o,v,w);console.log(J(`Checkpoint saved: ${_.id} "${v}" (${_.fileCount} files)`))}else if(y==="list"){let v=Ou(o);console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoints")}`),console.log(),console.log(Lu(v)),console.log()}else if(y==="restore"){if(!b){console.log(U("Usage: /checkpoint restore <id>"));break}let v=await Iu(o,b);v.success?console.log(J(`Restored checkpoint: ${b} (${v.filesRestored} files)`)):console.log(Ce(v.error||"Restore failed"))}else y==="delete"?b&&Mu(o,b)?console.log(J(`Deleted checkpoint: ${b}`)):console.log(U("Checkpoint not found")):(console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Checkpoint System")}`),console.log(),console.log(c.muted(' /checkpoint save "label" \u2014 Save current state')),console.log(c.muted(" /checkpoint list \u2014 List saved checkpoints")),console.log(c.muted(" /checkpoint restore <id> \u2014 Restore a checkpoint")),console.log(c.muted(" /checkpoint delete <id> \u2014 Delete a checkpoint")),console.log());break}case"/compare":{let y=S.slice(1);if(y.length===2)try{let b=await Ft.readFile($e.resolve(o,y[0]),"utf-8"),v=await Ft.readFile($e.resolve(o,y[1]),"utf-8"),{generateDiff:w}=await Promise.resolve().then(()=>(co(),Ku)),_=w(y[0]+" vs "+y[1],b,v);console.log(eo(_))}catch(b){console.log(Ce(`Compare failed: ${b.message}`))}else if(y.length===1&&y[0].startsWith("HEAD"))try{let{execSync:b}=await import("child_process"),v=b(`git diff ${y[0]}`,{cwd:o,encoding:"utf-8",timeout:1e4});console.log(eo(v||"(no changes)"))}catch(b){console.log(Ce(`Git diff failed: ${b.message}`))}else console.log(c.muted(" Usage: /compare file1.ts file2.ts or /compare HEAD~1"));break}case"/cost":{let y=Hn(),b="current";console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Session Cost & Usage")}`),console.log(),console.log(` Session duration: ${b} min`),console.log(` Messages: ${y.totalMessages}`),console.log(` Tool calls: ${y.totalToolCalls}`),console.log(` Tokens used: ${y.totalTokensUsed.toLocaleString()}`),console.log();let v=Object.entries(y.agentUsage);if(v.length>0){console.log(" Agent usage:");for(let[w,_]of v.sort((E,I)=>I[1]-E[1]))console.log(` @${w}: ${_} invocations`)}console.log();break}case"/delegate":{if(!e.agents.enabled){console.log(U("Multi-agent system is disabled. Enable with /agents on"));break}let y=S[1]?.toLowerCase(),b=S.slice(2).join(" ");if(!y||!b){console.log(),console.log(` ${c.accent("\u2726")} ${c.strong("Delegate Task to Agent")}`),console.log(),console.log(c.muted(" Usage: /delegate <agent> <task description>")),console.log(),console.log(c.muted(" Agents:")),console.log(` ${c.product("emma")} \u2014 Product Manager`),console.log(` ${c.architect("bob")} \u2014 Architect`),console.log(` ${c.engineer("alex")} \u2014 Engineer`),console.log(` ${c.analyst("david")} \u2014 Data Analyst`),console.log(),console.log(c.muted(" Example: /delegate alex create a login component")),console.log();break}let v=["emma","bob","alex","david","hablas"];if(!v.includes(y)){console.log(U(`Unknown agent: "${y}". Valid: ${v.join(", ")}`));break}let w=xe.find(_=>_.role===y);if(w){if(!x){console.log(U("Agent runner not initialized. Cannot delegate."));break}console.log(hu("Hablas",w.name,w.title,b)),console.log(yn(w.name,w.title));let _=s.getOllamaTools(),E=await x.runAgent(y,b,void 0,_);E.success&&E.output?(console.log(bn(E.output)),i.addAssistantMessage(`[@${w.name}]: ${E.output}`)):E.error?console.log(U(`${w.name} failed: ${E.error}`)):console.log(fe(`${w.name} completed without output.`))}break}case"/session":{let y=S[1],b=S.slice(2).join(" "),v=$e.join(fo.homedir(),".hablas","sessions");if(y==="save"){let w=b||`session_${Date.now()}`;try{ge.existsSync(v)||ge.mkdirSync(v,{recursive:!0});let _=i.toJSON(),E=$e.join(v,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);ge.writeFileSync(E,_,"utf-8"),console.log(J(`Session saved: "${w}"`))}catch(_){console.log(Ce(`Save failed: ${_.message}`))}}else if(y==="list")try{if(!ge.existsSync(v)){console.log(fe("No saved sessions"));break}let w=ge.readdirSync(v).filter(_=>_.endsWith(".json"));console.log();for(let _ of w){let E=ge.statSync($e.join(v,_));console.log(` ${_.replace(".json","")} (${new Date(E.mtime).toLocaleString()})`)}console.log()}catch{console.log(fe("No saved sessions"))}else if(y==="load"){let w=b;if(!w){console.log(Ce("Please specify the session label to load: /session load <label>"));break}try{let _=$e.join(v,`${w.replace(/[^a-zA-Z0-9_-]/g,"_")}.json`);if(!ge.existsSync(_)){console.log(Ce(`Session file not found: ${w}`));break}let E=ge.readFileSync(_,"utf-8");i.fromJSON(E),console.log(J(`Session successfully loaded: "${w}"`))}catch(_){console.log(Ce(`Load failed: ${_.message}`))}}else console.log(),console.log(c.muted(' /session save "label" \u2014 Save current conversation')),console.log(c.muted(" /session list \u2014 List saved sessions")),console.log(c.muted(' /session load "label" \u2014 Load saved conversation')),console.log();break}case"/team":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Et(),jt));if(!y){console.log(U("Team mode is not active. Use hablas --team to start."));break}let b=y.getLocalState(),v=Math.min(process.stdout.columns-4,80);console.log(`
|
|
283
|
+
`+c.border("\u2554"+"\u2550".repeat(v-2)+"\u2557")),console.log(c.border("\u2551")+" ".repeat(Math.floor((v-22)/2))+c.strong("HABLAS COLLABORATION SYNC")+" ".repeat(v-2-25-Math.floor((v-22)/2))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(v-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("My Identity:")} ${c.highlight(`@${b.my_username}`)}`+" ".repeat(Math.max(1,v-21-(b.my_username?.length||0)))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Room Fingerprint:")} ${c.muted(b.project_team_token?.slice(0,12))}...`+" ".repeat(Math.max(1,v-34))+c.border("\u2551")),console.log(c.border("\u2551")+` ${c.strong("Status:")} ${c.success("\u25CF ACTIVE")}`+" ".repeat(Math.max(1,v-31))+c.border("\u2551")),console.log(c.border("\u2560"+"\u2550".repeat(v-2)+"\u2563")),console.log(c.border("\u2551")+` ${c.strong("Teammates Online:")}`+" ".repeat(Math.max(1,v-21))+c.border("\u2551"));let _=(b.sessions||[]).filter(E=>E.developer_name!==b.my_username);if(_.length===0)console.log(c.border("\u2551")+" (awaiting colleagues...)"+" ".repeat(Math.max(1,v-31))+c.border("\u2551"));else for(let E of _){let I=` @${E.developer_name} [${E.active_section||"idle"}] - ${E.current_task||"none"}`;console.log(c.border("\u2551")+` ${c.secondary(I.slice(0,v-6))}`+" ".repeat(Math.max(0,v-6-I.length))+c.border("\u2551"))}console.log(c.border("\u255A"+"\u2550".repeat(v-2)+"\u255D")+`
|
|
284
284
|
`),console.log(c.muted(` Verify that "Room Fingerprint" matches on all devices to ensure connectivity.
|
|
285
|
-
`));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Et(),
|
|
285
|
+
`));break}case"/msg":{let{activeCollabManager:y}=await Promise.resolve().then(()=>(Et(),jt));if(!y){console.log(U("Team mode is not active. Use hablas --team to start."));break}let b=k.split(/\s+/),v=b[0],w=b.slice(1).join(" ");if(!v||!w){console.log(U("Usage: /msg <username> <content>"));break}let _=await y.sendMessage(v,w);console.log(_?J(`Message sent to @${v}`):Ce(`Failed to send message to @${v}`));break}default:console.log(He(`Unknown: ${A}`,"Type /help for commands"))}}var ge,Ft,$e,fo,Wn,uo,Gu=N(()=>{"use strict";ge=O(require("fs")),Ft=O(require("fs/promises")),$e=O(require("path")),fo=O(require("os"));Nn();Fn();hi();vi();wi();$i();Ri();fn();Ni();Un();Vi();mn();Ji();iu();vn();Tu();Du();Wn=`You are Hablas, the Team Leader of a multi-agent AI development system created by Abdulmoin Hablas. You are a strategic mastermind with an INTJ personality type, deeply analytical, engineering-focused, and fiercely logical.
|
|
286
286
|
|
|
287
287
|
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.
|
|
288
288
|
|
|
@@ -320,15 +320,15 @@ Your role is to orchestrate, coordinate, and synthesize the work of your special
|
|
|
320
320
|
## Important
|
|
321
321
|
Never output tool calls as text or JSON in your response.
|
|
322
322
|
Always use the tool_calls field provided by the API.
|
|
323
|
-
If you cannot complete a task, explain why with absolute technical objectivity.`;uo=$e.join(fo.homedir(),".hablas","backup")});var Vn=j((pC,Ju)=>{"use strict";var Ab=require("path"),pt="\\\\/",Gu=`[^${pt}]`,kb=0,Ct="\\.",$b="\\+",Eb="\\?",Ks="\\/",Cb="(?=.)",Vu="[^/]",po=`(?:${Ks}|$)`,zu=`(?:^|${Ks})`,ho=`${Ct}{1,2}${po}`,Tb=`(?!${Ct})`,Rb=`(?!${zu}${ho})`,Pb=`(?!${Ct}{0,1}${po})`,Ob=`(?!${ho})`,Ib=`[^.${Ks}]`,Mb=`${Vu}*?`,Yu={DOT_LITERAL:Ct,PLUS_LITERAL:$b,QMARK_LITERAL:Eb,SLASH_LITERAL:Ks,ONE_CHAR:Cb,QMARK:Vu,END_ANCHOR:po,DOTS_SLASH:ho,NO_DOT:Tb,NO_DOTS:Rb,NO_DOT_SLASH:Pb,NO_DOTS_SLASH:Ob,QMARK_NO_DOT:Ib,STAR:Mb,START_ANCHOR:zu},Lb={...Yu,SLASH_LITERAL:`[${pt}]`,QMARK:Gu,STAR:`${Gu}*?`,DOTS_SLASH:`${Ct}{1,2}(?:[${pt}]|$)`,NO_DOT:`(?!${Ct})`,NO_DOTS:`(?!(?:^|[${pt}])${Ct}{1,2}(?:[${pt}]|$))`,NO_DOT_SLASH:`(?!${Ct}{0,1}(?:[${pt}]|$))`,NO_DOTS_SLASH:`(?!${Ct}{1,2}(?:[${pt}]|$))`,QMARK_NO_DOT:`[^.${pt}]`,START_ANCHOR:`(?:^|[${pt}])`,END_ANCHOR:`(?:[${pt}]|$)`},Db={__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"};Ju.exports={DEFAULT_MAX_EXTGLOB_RECURSION:kb,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:Db,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:Ab.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?Lb:Yu}}});var Ws=j(Me=>{"use strict";var Nb=require("path"),Fb=process.platform==="win32",{REGEX_BACKSLASH:jb,REGEX_REMOVE_BACKSLASH:Hb,REGEX_SPECIAL_CHARS:Bb,REGEX_SPECIAL_CHARS_GLOBAL:Ub}=Vn();Me.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Me.hasRegexChars=n=>Bb.test(n);Me.isRegexChar=n=>n.length===1&&Me.hasRegexChars(n);Me.escapeRegex=n=>n.replace(Ub,"\\$1");Me.toPosixSlashes=n=>n.replace(jb,"/");Me.removeBackslashes=n=>n.replace(Hb,e=>e==="\\"?"":e);Me.supportsLookbehinds=()=>{let n=process.version.slice(1).split(".").map(Number);return n.length===3&&n[0]>=9||n[0]===8&&n[1]>=10};Me.isWindows=n=>n&&typeof n.windows=="boolean"?n.windows:Fb===!0||Nb.sep==="\\";Me.escapeLast=(n,e,t)=>{let s=n.lastIndexOf(e,t);return s===-1?n:n[s-1]==="\\"?Me.escapeLast(n,e,s-1):`${n.slice(0,s)}\\${n.slice(s)}`};Me.removePrefix=(n,e={})=>{let t=n;return t.startsWith("./")&&(t=t.slice(2),e.prefix="./"),t};Me.wrapOutput=(n,e={},t={})=>{let s=t.contains?"":"^",r=t.contains?"":"$",i=`${s}(?:${n})${r}`;return e.negated===!0&&(i=`(?:^(?!${i}).*$)`),i}});var rd=j((mC,sd)=>{"use strict";var Qu=Ws(),{CHAR_ASTERISK:mo,CHAR_AT:qb,CHAR_BACKWARD_SLASH:zn,CHAR_COMMA:Kb,CHAR_DOT:go,CHAR_EXCLAMATION_MARK:yo,CHAR_FORWARD_SLASH:nd,CHAR_LEFT_CURLY_BRACE:bo,CHAR_LEFT_PARENTHESES:vo,CHAR_LEFT_SQUARE_BRACKET:Wb,CHAR_PLUS:Gb,CHAR_QUESTION_MARK:Xu,CHAR_RIGHT_CURLY_BRACE:Vb,CHAR_RIGHT_PARENTHESES:Zu,CHAR_RIGHT_SQUARE_BRACKET:zb}=Vn(),ed=n=>n===nd||n===zn,td=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},Yb=(n,e)=>{let t=e||{},s=n.length-1,r=t.parts===!0||t.scanToEnd===!0,i=[],o=[],a=[],l=n,u=-1,d=0,f=0,h=!1,m=!1,p=!1,g=!1,x=!1,_=!1,A=!1,k=!1,y=!1,b=!1,v=0,w,S,C={value:"",depth:0,isGlob:!1},I=()=>u>=s,$=()=>l.charCodeAt(u+1),F=()=>(w=S,l.charCodeAt(++u));for(;u<s;){S=F();let Z;if(S===zn){A=C.backslashes=!0,S=F(),S===bo&&(_=!0);continue}if(_===!0||S===bo){for(v++;I()!==!0&&(S=F());){if(S===zn){A=C.backslashes=!0,F();continue}if(S===bo){v++;continue}if(_!==!0&&S===go&&(S=F())===go){if(h=C.isBrace=!0,p=C.isGlob=!0,b=!0,r===!0)continue;break}if(_!==!0&&S===Kb){if(h=C.isBrace=!0,p=C.isGlob=!0,b=!0,r===!0)continue;break}if(S===Vb&&(v--,v===0)){_=!1,h=C.isBrace=!0,b=!0;break}}if(r===!0)continue;break}if(S===nd){if(i.push(u),o.push(C),C={value:"",depth:0,isGlob:!1},b===!0)continue;if(w===go&&u===d+1){d+=2;continue}f=u+1;continue}if(t.noext!==!0&&(S===Gb||S===qb||S===mo||S===Xu||S===yo)===!0&&$()===vo){if(p=C.isGlob=!0,g=C.isExtglob=!0,b=!0,S===yo&&u===d&&(y=!0),r===!0){for(;I()!==!0&&(S=F());){if(S===zn){A=C.backslashes=!0,S=F();continue}if(S===Zu){p=C.isGlob=!0,b=!0;break}}continue}break}if(S===mo){if(w===mo&&(x=C.isGlobstar=!0),p=C.isGlob=!0,b=!0,r===!0)continue;break}if(S===Xu){if(p=C.isGlob=!0,b=!0,r===!0)continue;break}if(S===Wb){for(;I()!==!0&&(Z=F());){if(Z===zn){A=C.backslashes=!0,F();continue}if(Z===zb){m=C.isBracket=!0,p=C.isGlob=!0,b=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&S===yo&&u===d){k=C.negated=!0,d++;continue}if(t.noparen!==!0&&S===vo){if(p=C.isGlob=!0,r===!0){for(;I()!==!0&&(S=F());){if(S===vo){A=C.backslashes=!0,S=F();continue}if(S===Zu){b=!0;break}}continue}break}if(p===!0){if(b=!0,r===!0)continue;break}}t.noext===!0&&(g=!1,p=!1);let B=l,z="",T="";d>0&&(z=l.slice(0,d),l=l.slice(d),f-=d),B&&p===!0&&f>0?(B=l.slice(0,f),T=l.slice(f)):p===!0?(B="",T=l):B=l,B&&B!==""&&B!=="/"&&B!==l&&ed(B.charCodeAt(B.length-1))&&(B=B.slice(0,-1)),t.unescape===!0&&(T&&(T=Qu.removeBackslashes(T)),B&&A===!0&&(B=Qu.removeBackslashes(B)));let E={prefix:z,input:n,start:d,base:B,glob:T,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:x,negated:k,negatedExtglob:y};if(t.tokens===!0&&(E.maxDepth=0,ed(S)||o.push(C),E.tokens=o),t.parts===!0||t.tokens===!0){let Z;for(let D=0;D<i.length;D++){let K=Z?Z+1:d,ee=i[D],le=n.slice(K,ee);t.tokens&&(D===0&&d!==0?(o[D].isPrefix=!0,o[D].value=z):o[D].value=le,td(o[D]),E.maxDepth+=o[D].depth),(D!==0||le!=="")&&a.push(le),Z=ee}if(Z&&Z+1<n.length){let D=n.slice(Z+1);a.push(D),t.tokens&&(o[o.length-1].value=D,td(o[o.length-1]),E.maxDepth+=o[o.length-1].depth)}E.slashes=i,E.parts=a}return E};sd.exports=Yb});var cd=j((gC,ld)=>{"use strict";var Yn=Vn(),Te=Ws(),{MAX_LENGTH:Gs,POSIX_REGEX_SOURCE:Jb,REGEX_NON_SPECIAL_CHARS:Qb,REGEX_SPECIAL_CHARS_BACKREF:Xb,REPLACEMENTS:id}=Yn,Zb=(n,e)=>{if(typeof e.expandRange=="function")return e.expandRange(...n,e);n.sort();let t=`[${n.join("-")}]`;try{new RegExp(t)}catch{return n.map(r=>Te.escapeRegex(r)).join("..")}return t},xn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,od=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},ev=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},ad=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(ev(e))return e.replace(/\\(.)/g,"$1")},tv=n=>{let e=n.map(ad).filter(Boolean);for(let t=0;t<e.length;t++)for(let s=t+1;s<e.length;s++){let r=e[t],i=e[s],o=r[0];if(!(!o||r!==o.repeat(r.length)||i!==o.repeat(i.length))&&(r===i||r.startsWith(i)||i.startsWith(r)))return!0}return!1},wo=(n,e=!0)=>{if(n[0]!=="+"&&n[0]!=="*"||n[1]!=="(")return;let t=0,s=0,r=0,i=!1;for(let o=1;o<n.length;o++){let a=n[o];if(i===!0){i=!1;continue}if(a==="\\"){i=!0;continue}if(a==='"'){r=r===1?0:1;continue}if(r!==1){if(a==="["){t++;continue}if(a==="]"&&t>0){t--;continue}if(!(t>0)){if(a==="("){s++;continue}if(a===")"&&(s--,s===0))return e===!0&&o!==n.length-1?void 0:{type:n[0],body:n.slice(2,o),end:o}}}}},nv=n=>{let e=0,t=[];for(;e<n.length;){let r=wo(n.slice(e),!1);if(!r||r.type!=="*")return;let i=od(r.body).map(a=>a.trim());if(i.length!==1)return;let o=ad(i[0]);if(!o||o.length!==1)return;t.push(o),e+=r.end+1}return t.length<1?void 0:`${t.length===1?Te.escapeRegex(t[0]):`[${t.map(r=>Te.escapeRegex(r)).join("")}]`}*`},sv=n=>{let e=0,t=n.trim(),s=wo(t);for(;s;)e++,t=s.body.trim(),s=wo(t);return e},rv=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:Yn.DEFAULT_MAX_EXTGLOB_RECURSION,s=od(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||tv(s)))return{risky:!0};for(let r of s){let i=nv(r);if(i)return{risky:!0,safeOutput:i};if(sv(r)>t)return{risky:!0}}return{risky:!1}},xo=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=id[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(Gs,t.maxLength):Gs,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);let i={type:"bos",value:"",output:t.prepend||""},o=[i],a=t.capture?"":"?:",l=Te.isWindows(e),u=Yn.globChars(l),d=Yn.extglobChars(u),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:x,NO_DOT_SLASH:_,NO_DOTS_SLASH:A,QMARK:k,QMARK_NO_DOT:y,STAR:b,START_ANCHOR:v}=u,w=P=>`(${a}(?:(?!${v}${P.dot?g:f}).)*?)`,S=t.dot?"":x,C=t.dot?k:y,I=t.bash===!0?w(t):b;t.capture&&(I=`(${I})`),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=Te.removePrefix(n,$),r=n.length;let F=[],B=[],z=[],T=i,E,Z=()=>$.index===r-1,D=$.peek=(P=1)=>n[$.index+P],K=$.advance=()=>n[++$.index]||"",ee=()=>n.slice($.index+1),le=(P="",X=0)=>{$.consumed+=P,$.index+=X},ne=P=>{$.output+=P.output!=null?P.output:P.value,le(P.value)},me=()=>{let P=1;for(;D()==="!"&&(D(2)!=="("||D(3)==="?");)K(),$.start++,P++;return P%2===0?!1:($.negated=!0,$.start++,!0)},We=P=>{$[P]++,z.push(P)},se=P=>{$[P]--,z.pop()},H=P=>{if(T.type==="globstar"){let X=$.braces>0&&(P.type==="comma"||P.type==="brace"),M=P.extglob===!0||F.length&&(P.type==="pipe"||P.type==="paren");P.type!=="slash"&&P.type!=="paren"&&!X&&!M&&($.output=$.output.slice(0,-T.output.length),T.type="star",T.value="*",T.output=I,$.output+=T.output)}if(F.length&&P.type!=="paren"&&(F[F.length-1].inner+=P.value),(P.value||P.output)&&ne(P),T&&T.type==="text"&&P.type==="text"){T.value+=P.value,T.output=(T.output||"")+P.value;return}P.prev=T,o.push(P),T=P},be=(P,X)=>{let M={...d[X],conditions:1,inner:""};M.prev=T,M.parens=$.parens,M.output=$.output,M.startIndex=$.index,M.tokensIndex=o.length;let W=(t.capture?"(":"")+M.open;We("parens"),H({type:P,value:X,output:$.output?"":p}),H({type:"paren",extglob:!0,value:K(),output:W}),F.push(M)},Ae=P=>{let X=n.slice(P.startIndex,$.index+1),M=n.slice(P.startIndex+2,$.index),W=rv(M,t);if((P.type==="plus"||P.type==="star")&&W.risky){let Q=W.safeOutput?(P.output?"":p)+(t.capture?`(${W.safeOutput})`:W.safeOutput):void 0,ke=o[P.tokensIndex];ke.type="text",ke.value=X,ke.output=Q||Te.escapeRegex(X);for(let Ge=P.tokensIndex+1;Ge<o.length;Ge++)o[Ge].value="",o[Ge].output="",delete o[Ge].suffix;$.output=P.output+ke.output,$.backtrack=!0,H({type:"paren",extglob:!0,value:E,output:""}),se("parens");return}let te=P.close+(t.capture?")":""),oe;if(P.type==="negate"){let Q=I;if(P.inner&&P.inner.length>1&&P.inner.includes("/")&&(Q=w(t)),(Q!==I||Z()||/^\)+$/.test(ee()))&&(te=P.close=`)$))${Q}`),P.inner.includes("*")&&(oe=ee())&&/^\.[^\\/.]+$/.test(oe)){let ke=xo(oe,{...e,fastpaths:!1}).output;te=P.close=`)${ke})${Q})`}P.prev.type==="bos"&&($.negatedExtglob=!0)}H({type:"paren",extglob:!0,value:E,output:te}),se("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let P=!1,X=n.replace(Xb,(M,W,te,oe,Q,ke)=>oe==="\\"?(P=!0,M):oe==="?"?W?W+oe+(Q?k.repeat(Q.length):""):ke===0?C+(Q?k.repeat(Q.length):""):k.repeat(te.length):oe==="."?f.repeat(te.length):oe==="*"?W?W+oe+(Q?I:""):I:W?M:`\\${M}`);return P===!0&&(t.unescape===!0?X=X.replace(/\\/g,""):X=X.replace(/\\+/g,M=>M.length%2===0?"\\\\":M?"\\":"")),X===n&&t.contains===!0?($.output=n,$):($.output=Te.wrapOutput(X,$,e),$)}for(;!Z();){if(E=K(),E==="\0")continue;if(E==="\\"){let M=D();if(M==="/"&&t.bash!==!0||M==="."||M===";")continue;if(!M){E+="\\",H({type:"text",value:E});continue}let W=/^\\+/.exec(ee()),te=0;if(W&&W[0].length>2&&(te=W[0].length,$.index+=te,te%2!==0&&(E+="\\")),t.unescape===!0?E=K():E+=K(),$.brackets===0){H({type:"text",value:E});continue}}if($.brackets>0&&(E!=="]"||T.value==="["||T.value==="[^")){if(t.posix!==!1&&E===":"){let M=T.value.slice(1);if(M.includes("[")&&(T.posix=!0,M.includes(":"))){let W=T.value.lastIndexOf("["),te=T.value.slice(0,W),oe=T.value.slice(W+2),Q=Jb[oe];if(Q){T.value=te+Q,$.backtrack=!0,K(),!i.output&&o.indexOf(T)===1&&(i.output=p);continue}}}(E==="["&&D()!==":"||E==="-"&&D()==="]")&&(E=`\\${E}`),E==="]"&&(T.value==="["||T.value==="[^")&&(E=`\\${E}`),t.posix===!0&&E==="!"&&T.value==="["&&(E="^"),T.value+=E,ne({value:E});continue}if($.quotes===1&&E!=='"'){E=Te.escapeRegex(E),T.value+=E,ne({value:E});continue}if(E==='"'){$.quotes=$.quotes===1?0:1,t.keepQuotes===!0&&H({type:"text",value:E});continue}if(E==="("){We("parens"),H({type:"paren",value:E});continue}if(E===")"){if($.parens===0&&t.strictBrackets===!0)throw new SyntaxError(xn("opening","("));let M=F[F.length-1];if(M&&$.parens===M.parens+1){Ae(F.pop());continue}H({type:"paren",value:E,output:$.parens?")":"\\)"}),se("parens");continue}if(E==="["){if(t.nobracket===!0||!ee().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(xn("closing","]"));E=`\\${E}`}else We("brackets");H({type:"bracket",value:E});continue}if(E==="]"){if(t.nobracket===!0||T&&T.type==="bracket"&&T.value.length===1){H({type:"text",value:E,output:`\\${E}`});continue}if($.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(xn("opening","["));H({type:"text",value:E,output:`\\${E}`});continue}se("brackets");let M=T.value.slice(1);if(T.posix!==!0&&M[0]==="^"&&!M.includes("/")&&(E=`/${E}`),T.value+=E,ne({value:E}),t.literalBrackets===!1||Te.hasRegexChars(M))continue;let W=Te.escapeRegex(T.value);if($.output=$.output.slice(0,-T.value.length),t.literalBrackets===!0){$.output+=W,T.value=W;continue}T.value=`(${a}${W}|${T.value})`,$.output+=T.value;continue}if(E==="{"&&t.nobrace!==!0){We("braces");let M={type:"brace",value:E,output:"(",outputIndex:$.output.length,tokensIndex:$.tokens.length};B.push(M),H(M);continue}if(E==="}"){let M=B[B.length-1];if(t.nobrace===!0||!M){H({type:"text",value:E,output:E});continue}let W=")";if(M.dots===!0){let te=o.slice(),oe=[];for(let Q=te.length-1;Q>=0&&(o.pop(),te[Q].type!=="brace");Q--)te[Q].type!=="dots"&&oe.unshift(te[Q].value);W=Zb(oe,t),$.backtrack=!0}if(M.comma!==!0&&M.dots!==!0){let te=$.output.slice(0,M.outputIndex),oe=$.tokens.slice(M.tokensIndex);M.value=M.output="\\{",E=W="\\}",$.output=te;for(let Q of oe)$.output+=Q.output||Q.value}H({type:"brace",value:E,output:W}),se("braces"),B.pop();continue}if(E==="|"){F.length>0&&F[F.length-1].conditions++,H({type:"text",value:E});continue}if(E===","){let M=E,W=B[B.length-1];W&&z[z.length-1]==="braces"&&(W.comma=!0,M="|"),H({type:"comma",value:E,output:M});continue}if(E==="/"){if(T.type==="dot"&&$.index===$.start+1){$.start=$.index+1,$.consumed="",$.output="",o.pop(),T=i;continue}H({type:"slash",value:E,output:m});continue}if(E==="."){if($.braces>0&&T.type==="dot"){T.value==="."&&(T.output=f);let M=B[B.length-1];T.type="dots",T.output+=E,T.value+=E,M.dots=!0;continue}if($.braces+$.parens===0&&T.type!=="bos"&&T.type!=="slash"){H({type:"text",value:E,output:f});continue}H({type:"dot",value:E,output:f});continue}if(E==="?"){if(!(T&&T.value==="(")&&t.noextglob!==!0&&D()==="("&&D(2)!=="?"){be("qmark",E);continue}if(T&&T.type==="paren"){let W=D(),te=E;if(W==="<"&&!Te.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(T.value==="("&&!/[!=<:]/.test(W)||W==="<"&&!/<([!=]|\w+>)/.test(ee()))&&(te=`\\${E}`),H({type:"text",value:E,output:te});continue}if(t.dot!==!0&&(T.type==="slash"||T.type==="bos")){H({type:"qmark",value:E,output:y});continue}H({type:"qmark",value:E,output:k});continue}if(E==="!"){if(t.noextglob!==!0&&D()==="("&&(D(2)!=="?"||!/[!=<:]/.test(D(3)))){be("negate",E);continue}if(t.nonegate!==!0&&$.index===0){me();continue}}if(E==="+"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){be("plus",E);continue}if(T&&T.value==="("||t.regex===!1){H({type:"plus",value:E,output:h});continue}if(T&&(T.type==="bracket"||T.type==="paren"||T.type==="brace")||$.parens>0){H({type:"plus",value:E});continue}H({type:"plus",value:h});continue}if(E==="@"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){H({type:"at",extglob:!0,value:E,output:""});continue}H({type:"text",value:E});continue}if(E!=="*"){(E==="$"||E==="^")&&(E=`\\${E}`);let M=Qb.exec(ee());M&&(E+=M[0],$.index+=M[0].length),H({type:"text",value:E});continue}if(T&&(T.type==="globstar"||T.star===!0)){T.type="star",T.star=!0,T.value+=E,T.output=I,$.backtrack=!0,$.globstar=!0,le(E);continue}let P=ee();if(t.noextglob!==!0&&/^\([^?]/.test(P)){be("star",E);continue}if(T.type==="star"){if(t.noglobstar===!0){le(E);continue}let M=T.prev,W=M.prev,te=M.type==="slash"||M.type==="bos",oe=W&&(W.type==="star"||W.type==="globstar");if(t.bash===!0&&(!te||P[0]&&P[0]!=="/")){H({type:"star",value:E,output:""});continue}let Q=$.braces>0&&(M.type==="comma"||M.type==="brace"),ke=F.length&&(M.type==="pipe"||M.type==="paren");if(!te&&M.type!=="paren"&&!Q&&!ke){H({type:"star",value:E,output:""});continue}for(;P.slice(0,3)==="/**";){let Ge=n[$.index+4];if(Ge&&Ge!=="/")break;P=P.slice(3),le("/**",3)}if(M.type==="bos"&&Z()){T.type="globstar",T.value+=E,T.output=w(t),$.output=T.output,$.globstar=!0,le(E);continue}if(M.type==="slash"&&M.prev.type!=="bos"&&!oe&&Z()){$.output=$.output.slice(0,-(M.output+T.output).length),M.output=`(?:${M.output}`,T.type="globstar",T.output=w(t)+(t.strictSlashes?")":"|$)"),T.value+=E,$.globstar=!0,$.output+=M.output+T.output,le(E);continue}if(M.type==="slash"&&M.prev.type!=="bos"&&P[0]==="/"){let Ge=P[1]!==void 0?"|$":"";$.output=$.output.slice(0,-(M.output+T.output).length),M.output=`(?:${M.output}`,T.type="globstar",T.output=`${w(t)}${m}|${m}${Ge})`,T.value+=E,$.output+=M.output+T.output,$.globstar=!0,le(E+K()),H({type:"slash",value:"/",output:""});continue}if(M.type==="bos"&&P[0]==="/"){T.type="globstar",T.value+=E,T.output=`(?:^|${m}|${w(t)}${m})`,$.output=T.output,$.globstar=!0,le(E+K()),H({type:"slash",value:"/",output:""});continue}$.output=$.output.slice(0,-T.output.length),T.type="globstar",T.output=w(t),T.value+=E,$.output+=T.output,$.globstar=!0,le(E);continue}let X={type:"star",value:E,output:I};if(t.bash===!0){X.output=".*?",(T.type==="bos"||T.type==="slash")&&(X.output=S+X.output),H(X);continue}if(T&&(T.type==="bracket"||T.type==="paren")&&t.regex===!0){X.output=E,H(X);continue}($.index===$.start||T.type==="slash"||T.type==="dot")&&(T.type==="dot"?($.output+=_,T.output+=_):t.dot===!0?($.output+=A,T.output+=A):($.output+=S,T.output+=S),D()!=="*"&&($.output+=p,T.output+=p)),H(X)}for(;$.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(xn("closing","]"));$.output=Te.escapeLast($.output,"["),se("brackets")}for(;$.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(xn("closing",")"));$.output=Te.escapeLast($.output,"("),se("parens")}for(;$.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(xn("closing","}"));$.output=Te.escapeLast($.output,"{"),se("braces")}if(t.strictSlashes!==!0&&(T.type==="star"||T.type==="bracket")&&H({type:"maybe_slash",value:"",output:`${m}?`}),$.backtrack===!0){$.output="";for(let P of $.tokens)$.output+=P.output!=null?P.output:P.value,P.suffix&&($.output+=P.suffix)}return $};xo.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(Gs,t.maxLength):Gs,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=id[n]||n;let i=Te.isWindows(e),{DOT_LITERAL:o,SLASH_LITERAL:a,ONE_CHAR:l,DOTS_SLASH:u,NO_DOT:d,NO_DOTS:f,NO_DOTS_SLASH:h,STAR:m,START_ANCHOR:p}=Yn.globChars(i),g=t.dot?f:d,x=t.dot?h:d,_=t.capture?"":"?:",A={negated:!1,prefix:""},k=t.bash===!0?".*?":m;t.capture&&(k=`(${k})`);let y=S=>S.noglobstar===!0?k:`(${_}(?:(?!${p}${S.dot?u:o}).)*?)`,b=S=>{switch(S){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 C=/^(.*?)\.(\w+)$/.exec(S);if(!C)return;let I=b(C[1]);return I?I+o+C[2]:void 0}}},v=Te.removePrefix(n,A),w=b(v);return w&&t.strictSlashes!==!0&&(w+=`${a}?`),w};ld.exports=xo});var dd=j((yC,ud)=>{"use strict";var iv=require("path"),ov=rd(),So=cd(),_o=Ws(),av=Vn(),lv=n=>n&&typeof n=="object"&&!Array.isArray(n),ye=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>ye(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=lv(n)&&n.tokens&&n.input;if(n===""||typeof n!="string"&&!s)throw new TypeError("Expected pattern to be a non-empty string");let r=e||{},i=_o.isWindows(e),o=s?ye.compileRe(n,e):ye.makeRe(n,e,!1,!0),a=o.state;delete o.state;let l=()=>!1;if(r.ignore){let d={...e,ignore:null,onMatch:null,onResult:null};l=ye(r.ignore,d,t)}let u=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=ye.test(d,o,e,{glob:n,posix:i}),g={glob:n,state:a,regex:o,posix:i,input:d,output:p,match:m,isMatch:h};return typeof r.onResult=="function"&&r.onResult(g),h===!1?(g.isMatch=!1,f?g:!1):l(d)?(typeof r.onIgnore=="function"&&r.onIgnore(g),g.isMatch=!1,f?g:!1):(typeof r.onMatch=="function"&&r.onMatch(g),f?g:!0)};return t&&(u.state=a),u};ye.test=(n,e,t,{glob:s,posix:r}={})=>{if(typeof n!="string")throw new TypeError("Expected input to be a string");if(n==="")return{isMatch:!1,output:""};let i=t||{},o=i.format||(r?_o.toPosixSlashes:null),a=n===s,l=a&&o?o(n):n;return a===!1&&(l=o?o(n):n,a=l===s),(a===!1||i.capture===!0)&&(i.matchBase===!0||i.basename===!0?a=ye.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ye.matchBase=(n,e,t,s=_o.isWindows(t))=>(e instanceof RegExp?e:ye.makeRe(e,t)).test(iv.basename(n));ye.isMatch=(n,e,t)=>ye(e,t)(n);ye.parse=(n,e)=>Array.isArray(n)?n.map(t=>ye.parse(t,e)):So(n,{...e,fastpaths:!1});ye.scan=(n,e)=>ov(n,e);ye.compileRe=(n,e,t=!1,s=!1)=>{if(t===!0)return n.output;let r=e||{},i=r.contains?"":"^",o=r.contains?"":"$",a=`${i}(?:${n.output})${o}`;n&&n.negated===!0&&(a=`^(?!${a}).*$`);let l=ye.toRegex(a,e);return s===!0&&(l.state=n),l};ye.makeRe=(n,e={},t=!1,s=!1)=>{if(!n||typeof n!="string")throw new TypeError("Expected a non-empty string");let r={negated:!1,fastpaths:!0};return e.fastpaths!==!1&&(n[0]==="."||n[0]==="*")&&(r.output=So.fastpaths(n,e)),r.output||(r=So(n,e)),ye.compileRe(r,e,t,s)};ye.toRegex=(n,e)=>{try{let t=e||{};return new RegExp(n,t.flags||(t.nocase?"i":""))}catch(t){if(e&&e.debug===!0)throw t;return/$^/}};ye.constants=av;ud.exports=ye});var Ao=j((bC,fd)=>{"use strict";fd.exports=dd()});var wd=j((vC,vd)=>{"use strict";var Qn=require("fs"),{Readable:cv}=require("stream"),Jn=require("path"),{promisify:Js}=require("util"),ko=Ao(),uv=Js(Qn.readdir),dv=Js(Qn.stat),pd=Js(Qn.lstat),fv=Js(Qn.realpath),pv="!",yd="READDIRP_RECURSIVE_ERROR",hv=new Set(["ENOENT","EPERM","EACCES","ELOOP",yd]),$o="files",bd="directories",zs="files_directories",Vs="all",hd=[$o,bd,zs,Vs],mv=n=>hv.has(n.code),[md,gv]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),yv=process.platform==="win32"&&(md>10||md===10&&gv>=5),gd=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=ko(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)===pv?t.push(ko(r.slice(1))):e.push(ko(r))}return t.length>0?e.length>0?s=>e.some(r=>r(s.basename))&&!t.some(r=>r(s.basename)):s=>!t.some(r=>r(s.basename)):s=>e.some(r=>r(s.basename))}}},Ys=class n extends cv{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:$o,lstat:!1,depth:2147483648,alwaysStat:!1}}constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark||4096});let t={...n.defaultOptions,...e},{root:s,type:r}=t;this._fileFilter=gd(t.fileFilter),this._directoryFilter=gd(t.directoryFilter);let i=t.lstat?pd:dv;yv?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[bd,zs,Vs].includes(r),this._wantsFile=[$o,zs,Vs].includes(r),this._wantsEverything=r===Vs,this._root=Jn.resolve(s),this._isDirent="Dirent"in Qn&&!t.alwaysStat,this._statsProp=this._isDirent?"dirent":"stats",this._rdOptions={encoding:"utf8",withFileTypes:this._isDirent},this.parents=[this._exploreDir(s,1)],this.reading=!1,this.parent=void 0}async _read(e){if(!this.reading){this.reading=!0;try{for(;!this.destroyed&&e>0;){let{path:t,depth:s,files:r=[]}=this.parent||{};if(r.length>0){let i=r.splice(0,e).map(o=>this._formatEntry(o,t));for(let o of await Promise.all(i)){if(this.destroyed)return;let a=await this._getEntryType(o);a==="directory"&&this._directoryFilter(o)?(s<=this._maxDepth&&this.parents.push(this._exploreDir(o.fullPath,s+1)),this._wantsDir&&(this.push(o),e--)):(a==="file"||this._includeAsFile(o))&&this._fileFilter(o)&&this._wantsFile&&(this.push(o),e--)}}else{let i=this.parents.pop();if(!i){this.push(null);break}if(this.parent=await i,this.destroyed)return}}}catch(t){this.destroy(t)}finally{this.reading=!1}}}async _exploreDir(e,t){let s;try{s=await uv(e,this._rdOptions)}catch(r){this._onError(r)}return{files:s,depth:t,path:e}}async _formatEntry(e,t){let s;try{let r=this._isDirent?e.name:e,i=Jn.resolve(Jn.join(t,r));s={path:Jn.relative(this._root,i),fullPath:i,basename:r},s[this._statsProp]=this._isDirent?e:await this._stat(i)}catch(r){this._onError(r)}return s}_onError(e){mv(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 fv(s),i=await pd(r);if(i.isFile())return"file";if(i.isDirectory()){let o=r.length;if(s.startsWith(r)&&s.substr(o,1)===Jn.sep){let a=new Error(`Circular symlink detected: "${s}" points to "${r}"`);return a.code=yd,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},Sn=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=zs),t&&(e.type=t),n){if(typeof n!="string")throw new TypeError("readdirp: root argument must be a string. Usage: readdirp(root, options)");if(t&&!hd.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${hd.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new Ys(e)},bv=(n,e={})=>new Promise((t,s)=>{let r=[];Sn(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});Sn.promise=bv;Sn.ReaddirpStream=Ys;Sn.default=Sn;vd.exports=Sn});var Eo=j((wC,xd)=>{xd.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 Ed=j((kd,$d)=>{"use strict";Object.defineProperty(kd,"__esModule",{value:!0});var Ad=Ao(),vv=Eo(),Sd="!",wv={returnIndex:!1},xv=n=>Array.isArray(n)?n:[n],Sv=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=Ad(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},_d=(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=vv(i,!1);for(let l=0;l<e.length;l++){let u=e[l];if(u(o))return s?-1:!1}let a=r&&[o].concat(t.slice(1));for(let l=0;l<n.length;l++){let u=n[l];if(r?u(...a):u(o))return s?l:!0}return s?-1:!1},Co=(n,e,t=wv)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=xv(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===Sd).map(l=>l.slice(1)).map(l=>Ad(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==Sd).map(l=>Sv(l,s));return e==null?(l,u=!1)=>_d(a,o,l,typeof u=="boolean"?u:!1):_d(a,o,e,r)};Co.default=Co;$d.exports=Co});var Td=j((xC,Cd)=>{Cd.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 To=j((SC,Pd)=>{var _v=Td(),Rd={"{":"}","(":")","[":"]"},Av=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=Rd[a];if(l){var u=n.indexOf(l,e);u!==-1&&(e=u+1)}if(n[e]==="!")return!0}else e++}return!1},kv=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=Rd[t];if(s){var r=n.indexOf(s,e);r!==-1&&(e=r+1)}if(n[e]==="!")return!0}else e++}return!1};Pd.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(_v(e))return!0;var s=Av;return t&&t.strict===!1&&(s=kv),s(e)}});var Id=j((_C,Od)=>{"use strict";var $v=To(),Ev=require("path").posix.dirname,Cv=require("os").platform()==="win32",Ro="/",Tv=/\\/g,Rv=/[\{\[].*[\}\]]$/,Pv=/(^|[^\\])([\{\[]|\([^\)]+$)/,Ov=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Od.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&Cv&&e.indexOf(Ro)<0&&(e=e.replace(Tv,Ro)),Rv.test(e)&&(e+=Ro),e+="a";do e=Ev(e);while($v(e)||Pv.test(e));return e.replace(Ov,"$1")}});var Qs=j(Ye=>{"use strict";Ye.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;Ye.find=(n,e)=>n.nodes.find(t=>t.type===e);Ye.exceedsLimit=(n,e,t=1,s)=>s===!1||!Ye.isInteger(n)||!Ye.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;Ye.escapeNode=(n,e=0,t)=>{let s=n.nodes[e];s&&(t&&s.type===t||s.type==="open"||s.type==="close")&&s.escaped!==!0&&(s.value="\\"+s.value,s.escaped=!0)};Ye.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;Ye.isInvalidBrace=n=>n.type!=="brace"?!1:n.invalid===!0||n.dollar?!0:n.commas>>0+n.ranges>>0===0||n.open!==!0||n.close!==!0?(n.invalid=!0,!0):!1;Ye.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;Ye.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);Ye.flatten=(...n)=>{let e=[],t=s=>{for(let r=0;r<s.length;r++){let i=s[r];if(Array.isArray(i)){t(i);continue}i!==void 0&&e.push(i)}return e};return t(n),e}});var Xs=j((kC,Ld)=>{"use strict";var Md=Qs();Ld.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Md.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Md.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 Nd=j(($C,Dd)=>{"use strict";Dd.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var Gd=j((EC,Wd)=>{"use strict";var Fd=Nd(),Xt=(n,e,t)=>{if(Fd(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(Fd(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(Xt.cache.hasOwnProperty(l))return Xt.cache[l].result;let u=Math.min(n,e),d=Math.max(n,e);if(Math.abs(u-d)===1){let g=n+"|"+e;return s.capture?`(${g})`:s.wrap===!1?g:`(?:${g})`}let f=Kd(n)||Kd(e),h={min:n,max:e,a:u,b:d},m=[],p=[];if(f&&(h.isPadded=f,h.maxLen=String(h.max).length),u<0){let g=d<0?Math.abs(d):1;p=jd(g,Math.abs(u),h,s),u=h.a=0}return d>=0&&(m=jd(u,d,h,s)),h.negatives=p,h.positives=m,h.result=Iv(p,m,s),s.capture===!0?h.result=`(${h.result})`:s.wrap!==!1&&m.length+p.length>1&&(h.result=`(?:${h.result})`),Xt.cache[l]=h,h.result};function Iv(n,e,t){let s=Po(n,e,"-",!1,t)||[],r=Po(e,n,"",!1,t)||[],i=Po(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function Mv(n,e){let t=1,s=1,r=Bd(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=Bd(n,t);for(r=Ud(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=Ud(e+1,s)-1;return i=[...i],i.sort(Nv),i}function Lv(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=Dv(n,e),r=s.length,i="",o=0;for(let a=0;a<r;a++){let[l,u]=s[a];l===u?i+=l:l!=="0"||u!=="9"?i+=Fv(l,u,t):o++}return o&&(i+=t.shorthand===!0?"\\d":"[0-9]"),{pattern:i,count:[o],digits:r}}function jd(n,e,t,s){let r=Mv(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let u=r[l],d=Lv(String(o),String(u),s),f="";if(!t.isPadded&&a&&a.pattern===d.pattern){a.count.length>1&&a.count.pop(),a.count.push(d.count[0]),a.string=a.pattern+qd(a.count),o=u+1;continue}t.isPadded&&(f=jv(u,t,s)),d.string=f+d.pattern+qd(d.count),i.push(d),o=u+1,a=d}return i}function Po(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!Hd(e,"string",a)&&i.push(t+a),s&&Hd(e,"string",a)&&i.push(t+a)}return i}function Dv(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function Nv(n,e){return n>e?1:e>n?-1:0}function Hd(n,e,t){return n.some(s=>s[e]===t)}function Bd(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function Ud(n,e){return n-n%Math.pow(10,e)}function qd(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function Fv(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function Kd(n){return/^-?(0+)\d/.test(n)}function jv(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}}`}}Xt.cache={};Xt.clearCache=()=>Xt.cache={};Wd.exports=Xt});var Mo=j((CC,Zd)=>{"use strict";var Hv=require("util"),zd=Gd(),Vd=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),Bv=n=>e=>n===!0?Number(e):String(e),Oo=n=>typeof n=="number"||typeof n=="string"&&n!=="",Xn=n=>Number.isInteger(+n),Io=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},Uv=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,qv=(n,e,t)=>{if(e>0){let s=n[0]==="-"?"-":"";s&&(n=n.slice(1)),n=s+n.padStart(s?e-1:e,"0")}return t===!1?String(n):n},er=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},Kv=(n,e,t)=>{n.negatives.sort((a,l)=>a<l?-1:a>l?1:0),n.positives.sort((a,l)=>a<l?-1:a>l?1:0);let s=e.capture?"":"?:",r="",i="",o;return n.positives.length&&(r=n.positives.map(a=>er(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>er(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},Yd=(n,e,t,s)=>{if(t)return zd(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},Jd=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return zd(n,e,t)},Qd=(...n)=>new RangeError("Invalid range arguments: "+Hv.inspect(...n)),Xd=(n,e,t)=>{if(t.strictRanges===!0)throw Qd([n,e]);return[]},Wv=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},Gv=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw Qd([n,e]);return[]}r===0&&(r=0),i===0&&(i=0);let o=r>i,a=String(n),l=String(e),u=String(t);t=Math.max(Math.abs(t),1);let d=Io(a)||Io(l)||Io(u),f=d?Math.max(a.length,l.length,u.length):0,h=d===!1&&Uv(n,e,s)===!1,m=s.transform||Bv(h);if(s.toRegex&&t===1)return Yd(er(n,f),er(e,f),!0,s);let p={negatives:[],positives:[]},g=A=>p[A<0?"negatives":"positives"].push(Math.abs(A)),x=[],_=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):x.push(qv(m(r,_),f,h)),r=o?r-t:r+t,_++;return s.toRegex===!0?t>1?Kv(p,s,f):Jd(x,null,{wrap:!1,...s}):x},Vv=(n,e,t=1,s={})=>{if(!Xn(n)&&n.length>1||!Xn(e)&&e.length>1)return Xd(n,e,s);let r=s.transform||(h=>String.fromCharCode(h)),i=`${n}`.charCodeAt(0),o=`${e}`.charCodeAt(0),a=i>o,l=Math.min(i,o),u=Math.max(i,o);if(s.toRegex&&t===1)return Yd(l,u,!1,s);let d=[],f=0;for(;a?i>=o:i<=o;)d.push(r(i,f)),i=a?i-t:i+t,f++;return s.toRegex===!0?Jd(d,null,{wrap:!1,options:s}):d},Zs=(n,e,t,s={})=>{if(e==null&&Oo(n))return[n];if(!Oo(n)||!Oo(e))return Xd(n,e,s);if(typeof t=="function")return Zs(n,e,1,{transform:t});if(Vd(t))return Zs(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,Xn(t)?Xn(n)&&Xn(e)?Gv(n,e,t,r):Vv(n,e,Math.max(Math.abs(t),1),r):t!=null&&!Vd(t)?Wv(t,r):Zs(n,e,1,t)};Zd.exports=Zs});var nf=j((TC,tf)=>{"use strict";var zv=Mo(),ef=Qs(),Yv=(n,e={})=>{let t=(s,r={})=>{let i=ef.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a=i===!0||o===!0,l=e.escapeInvalid===!0?"\\":"",u="";if(s.isOpen===!0)return l+s.value;if(s.isClose===!0)return console.log("node.isClose",l,s.value),l+s.value;if(s.type==="open")return a?l+s.value:"(";if(s.type==="close")return a?l+s.value:")";if(s.type==="comma")return s.prev.type==="comma"?"":a?s.value:"|";if(s.value)return s.value;if(s.nodes&&s.ranges>0){let d=ef.reduce(s.nodes),f=zv(...d,{...e,wrap:!1,toRegex:!0,strictZeros:!0});if(f.length!==0)return d.length>1&&f.length>1?`(${f})`:f}if(s.nodes)for(let d of s.nodes)u+=t(d,s);return u};return t(n)};tf.exports=Yv});var of=j((RC,rf)=>{"use strict";var Jv=Mo(),sf=Xs(),_n=Qs(),Zt=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?_n.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 _n.flatten(s)},Qv=(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(),sf(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=_n.reduce(r.nodes);if(_n.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=Jv(...f,e);h.length===0&&(h=sf(r,e)),a.push(Zt(a.pop(),h)),r.nodes=[];return}let l=_n.encloseBrace(r),u=r.queue,d=r;for(;d.type!=="brace"&&d.type!=="root"&&d.parent;)d=d.parent,u=d.queue;for(let f=0;f<r.nodes.length;f++){let h=r.nodes[f];if(h.type==="comma"&&r.type==="brace"){f===1&&u.push(""),u.push("");continue}if(h.type==="close"){a.push(Zt(a.pop(),u,l));continue}if(h.value&&h.type!=="open"){u.push(Zt(u.pop(),h.value));continue}h.nodes&&s(h,r)}return u};return _n.flatten(s(n))};rf.exports=Qv});var lf=j((PC,af)=>{"use strict";af.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:`
|
|
324
|
-
`,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 pf=j((OC,ff)=>{"use strict";var Xv=Xs(),{MAX_LENGTH:cf,CHAR_BACKSLASH:Lo,CHAR_BACKTICK:Zv,CHAR_COMMA:ew,CHAR_DOT:tw,CHAR_LEFT_PARENTHESES:nw,CHAR_RIGHT_PARENTHESES:sw,CHAR_LEFT_CURLY_BRACE:rw,CHAR_RIGHT_CURLY_BRACE:iw,CHAR_LEFT_SQUARE_BRACKET:uf,CHAR_RIGHT_SQUARE_BRACKET:df,CHAR_DOUBLE_QUOTE:ow,CHAR_SINGLE_QUOTE:aw,CHAR_NO_BREAK_SPACE:lw,CHAR_ZERO_WIDTH_NOBREAK_SPACE:cw}=lf(),uw=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(cf,t.maxLength):cf;if(n.length>s)throw new SyntaxError(`Input length (${n.length}), exceeds max characters (${s})`);let r={type:"root",input:n,nodes:[]},i=[r],o=r,a=r,l=0,u=n.length,d=0,f=0,h,m=()=>n[d++],p=g=>{if(g.type==="text"&&a.type==="dot"&&(a.type="text"),a&&a.type==="text"&&g.type==="text"){a.value+=g.value;return}return o.nodes.push(g),g.parent=o,g.prev=a,a=g,g};for(p({type:"bos"});d<u;)if(o=i[i.length-1],h=m(),!(h===cw||h===lw)){if(h===Lo){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===df){p({type:"text",value:"\\"+h});continue}if(h===uf){l++;let g;for(;d<u&&(g=m());){if(h+=g,g===uf){l++;continue}if(g===Lo){h+=m();continue}if(g===df&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===nw){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===sw){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===ow||h===aw||h===Zv){let g=h,x;for(e.keepQuotes!==!0&&(h="");d<u&&(x=m());){if(x===Lo){h+=x+m();continue}if(x===g){e.keepQuotes===!0&&(h+=x);break}h+=x}p({type:"text",value:h});continue}if(h===rw){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===iw){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===ew&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:Xv(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===tw&&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(_=>{_.nodes||(_.type==="open"&&(_.isOpen=!0),_.type==="close"&&(_.isClose=!0),_.nodes||(_.type="text"),_.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};ff.exports=uw});var gf=j((IC,mf)=>{"use strict";var hf=Xs(),dw=nf(),fw=of(),pw=pf(),Ue=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=Ue.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(Ue.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.parse=(n,e={})=>pw(n,e);Ue.stringify=(n,e={})=>hf(typeof n=="string"?Ue.parse(n,e):n,e);Ue.compile=(n,e={})=>(typeof n=="string"&&(n=Ue.parse(n,e)),dw(n,e));Ue.expand=(n,e={})=>{typeof n=="string"&&(n=Ue.parse(n,e));let t=fw(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?Ue.compile(n,e):Ue.expand(n,e);mf.exports=Ue});var yf=j((MC,hw)=>{hw.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 vf=j((LC,bf)=>{bf.exports=yf()});var xf=j((DC,wf)=>{"use strict";var mw=require("path"),gw=vf(),yw=new Set(gw);wf.exports=n=>yw.has(mw.extname(n).slice(1).toLowerCase())});var tr=j(q=>{"use strict";var{sep:bw}=require("path"),{platform:Do}=process,vw=require("os");q.EV_ALL="all";q.EV_READY="ready";q.EV_ADD="add";q.EV_CHANGE="change";q.EV_ADD_DIR="addDir";q.EV_UNLINK="unlink";q.EV_UNLINK_DIR="unlinkDir";q.EV_RAW="raw";q.EV_ERROR="error";q.STR_DATA="data";q.STR_END="end";q.STR_CLOSE="close";q.FSEVENT_CREATED="created";q.FSEVENT_MODIFIED="modified";q.FSEVENT_DELETED="deleted";q.FSEVENT_MOVED="moved";q.FSEVENT_CLONED="cloned";q.FSEVENT_UNKNOWN="unknown";q.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;q.FSEVENT_TYPE_FILE="file";q.FSEVENT_TYPE_DIRECTORY="directory";q.FSEVENT_TYPE_SYMLINK="symlink";q.KEY_LISTENERS="listeners";q.KEY_ERR="errHandlers";q.KEY_RAW="rawEmitters";q.HANDLER_KEYS=[q.KEY_LISTENERS,q.KEY_ERR,q.KEY_RAW];q.DOT_SLASH=`.${bw}`;q.BACK_SLASH_RE=/\\/g;q.DOUBLE_SLASH_RE=/\/\//;q.SLASH_OR_BACK_SLASH_RE=/[/\\]/;q.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;q.REPLACER_RE=/^\.[/\\]/;q.SLASH="/";q.SLASH_SLASH="//";q.BRACE_START="{";q.BANG="!";q.ONE_DOT=".";q.TWO_DOTS="..";q.STAR="*";q.GLOBSTAR="**";q.ROOT_GLOBSTAR="/**/*";q.SLASH_GLOBSTAR="/**";q.DIR_SUFFIX="Dir";q.ANYMATCH_OPTS={dot:!0};q.STRING_TYPE="string";q.FUNCTION_TYPE="function";q.EMPTY_STR="";q.EMPTY_FN=()=>{};q.IDENTITY_FN=n=>n;q.isWindows=Do==="win32";q.isMacos=Do==="darwin";q.isLinux=Do==="linux";q.isIBMi=vw.type()==="OS400"});var Ef=j((FC,$f)=>{"use strict";var Tt=require("fs"),Se=require("path"),{promisify:ns}=require("util"),ww=xf(),{isWindows:xw,isLinux:Sw,EMPTY_FN:_w,EMPTY_STR:Aw,KEY_LISTENERS:An,KEY_ERR:No,KEY_RAW:Zn,HANDLER_KEYS:kw,EV_CHANGE:sr,EV_ADD:nr,EV_ADD_DIR:$w,EV_ERROR:_f,STR_DATA:Ew,STR_END:Cw,BRACE_START:Tw,STAR:Rw}=tr(),Pw="watch",Ow=ns(Tt.open),Af=ns(Tt.stat),Iw=ns(Tt.lstat),Mw=ns(Tt.close),Fo=ns(Tt.realpath),Lw={lstat:Iw,stat:Af},Ho=(n,e)=>{n instanceof Set?n.forEach(e):e(n)},es=(n,e,t)=>{let s=n[e];s instanceof Set||(n[e]=s=new Set([s])),s.add(t)},Dw=n=>e=>{let t=n[e];t instanceof Set?t.clear():delete n[e]},ts=(n,e,t)=>{let s=n[e];s instanceof Set?s.delete(t):s===t&&delete n[e]},kf=n=>n instanceof Set?n.size===0:!n,rr=new Map;function Sf(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&ir(Se.resolve(n,a),An,Se.join(n,a))};try{return Tt.watch(n,e,i)}catch(o){s(o)}}var ir=(n,e,t,s,r)=>{let i=rr.get(n);i&&Ho(i[e],o=>{o(t,s,r)})},Nw=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=rr.get(e),l;if(!t.persistent)return l=Sf(n,t,r,i,o),l.close.bind(l);if(a)es(a,An,r),es(a,No,i),es(a,Zn,o);else{if(l=Sf(n,t,ir.bind(null,e,An),i,ir.bind(null,e,Zn)),!l)return;l.on(_f,async u=>{let d=ir.bind(null,e,No);if(a.watcherUnusable=!0,xw&&u.code==="EPERM")try{let f=await Ow(n,"r");await Mw(f),d(u)}catch{}else d(u)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},rr.set(e,a)}return()=>{ts(a,An,r),ts(a,No,i),ts(a,Zn,o),kf(a.listeners)&&(a.watcher.close(),rr.delete(e),kw.forEach(Dw(a)),a.watcher=void 0,Object.freeze(a))}},jo=new Map,Fw=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=jo.get(e),a=new Set,l=new Set,u=o&&o.options;return u&&(u.persistent<t.persistent||u.interval>t.interval)&&(a=o.listeners,l=o.rawEmitters,Tt.unwatchFile(e),o=void 0),o?(es(o,An,r),es(o,Zn,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:Tt.watchFile(e,t,(d,f)=>{Ho(o.rawEmitters,m=>{m(sr,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&Ho(o.listeners,m=>m(n,d))})},jo.set(e,o)),()=>{ts(o,An,r),ts(o,Zn,i),kf(o.listeners)&&(jo.delete(e),Tt.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},Bo=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=Se.dirname(e),i=Se.basename(e);this.fsw._getWatchedDir(r).add(i);let a=Se.resolve(e),l={persistent:s.persistent};t||(t=_w);let u;return s.usePolling?(l.interval=s.enableBinaryInterval&&ww(i)?s.binaryInterval:s.interval,u=Fw(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):u=Nw(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=Se.dirname(e),i=Se.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Pw,e,5)){if(!f||f.mtimeMs===0)try{let h=await Af(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(sr,e,h),Sw&&a.ino!==h.ino?(this.fsw._closeFile(d),a=h,this.fsw._addPathCloser(d,this._watchWithNodeFs(e,l))):a=h}catch{this.fsw._remove(r,i)}else if(o.has(i)){let h=f.atimeMs,m=f.mtimeMs;(!h||h<=m||m!==a.mtimeMs)&&this.fsw._emit(sr,e,f),a=f}}},u=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(nr,e,0))return;this.fsw._emit(nr,e,t)}return u}async _handleSymlink(e,t,s,r){if(this.fsw.closed)return;let i=e.fullPath,o=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let a;try{a=await Fo(s)}catch{return this.fsw._emitReady(),!0}return this.fsw.closed?void 0:(o.has(r)?this.fsw._symlinkPaths.get(i)!==a&&(this.fsw._symlinkPaths.set(i,a),this.fsw._emit(sr,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(nr,s,e.stats)),this.fsw._emitReady(),!0)}if(this.fsw._symlinkPaths.has(i))return!0;this.fsw._symlinkPaths.set(i,!0)}_handleRead(e,t,s,r,i,o,a){if(e=Se.join(e,Aw),!s.hasGlob&&(a=this.fsw._throttle("readdir",e,1e3),!a))return;let l=this.fsw._getWatchedDir(s.path),u=new Set,d=this.fsw._readdirp(e,{fileFilter:f=>s.filterPath(f),directoryFilter:f=>s.filterDir(f),depth:0}).on(Ew,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=Se.join(e,h);if(u.add(h),!(f.stats.isSymbolicLink()&&await this._handleSymlink(f,e,m,h))){if(this.fsw.closed){d=void 0;return}(h===r||!r&&!l.has(h))&&(this.fsw._incrReadyCount(),m=Se.join(i,Se.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(_f,this._boundHandleError);return new Promise(f=>d.once(Cw,()=>{if(this.fsw.closed){d=void 0;return}let h=a?a.clear():!1;f(),l.getChildren().filter(m=>m!==e&&!u.has(m)&&(!s.hasGlob||s.filterPath({fullPath:Se.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(Se.dirname(e)),u=l.has(Se.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit($w,e,t),l.add(Se.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 Lw[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))return o(),!1;let u=this.fsw.options.followSymlinks&&!e.includes(Rw)&&!e.includes(Tw),d;if(l.isDirectory()){let f=Se.resolve(e),h=u?await Fo(e):e;if(this.fsw.closed||(d=await this._handleDir(a.watchPath,l,t,r,i,a,h),this.fsw.closed))return;f!==h&&h!==void 0&&this.fsw._symlinkPaths.set(f,h)}else if(l.isSymbolicLink()){let f=u?await Fo(e):e;if(this.fsw.closed)return;let h=Se.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(nr,a.watchPath,l),d=await this._handleDir(h,l,t,r,e,a,f),this.fsw.closed)return;f!==void 0&&this.fsw._symlinkPaths.set(Se.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}}};$f.exports=Bo});var Mf=j((jC,Yo)=>{"use strict";var Vo=require("fs"),_e=require("path"),{promisify:zo}=require("util"),kn;try{kn=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if(kn){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&&(kn=void 0)}}var{EV_ADD:Uo,EV_CHANGE:jw,EV_ADD_DIR:Cf,EV_UNLINK:or,EV_ERROR:Hw,STR_DATA:Bw,STR_END:Uw,FSEVENT_CREATED:qw,FSEVENT_MODIFIED:Kw,FSEVENT_DELETED:Ww,FSEVENT_MOVED:Gw,FSEVENT_UNKNOWN:Vw,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:zw,FSEVENT_TYPE_FILE:Yw,FSEVENT_TYPE_DIRECTORY:ss,FSEVENT_TYPE_SYMLINK:If,ROOT_GLOBSTAR:Tf,DIR_SUFFIX:Jw,DOT_SLASH:Rf,FUNCTION_TYPE:qo,EMPTY_FN:Qw,IDENTITY_FN:Xw}=tr(),Zw=n=>isNaN(n)?{}:{depth:n},Wo=zo(Vo.stat),ex=zo(Vo.lstat),Pf=zo(Vo.realpath),tx={stat:Wo,lstat:ex},en=new Map,nx=10,sx=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),rx=(n,e)=>({stop:kn.watch(n,e)});function ix(n,e,t,s){let r=_e.extname(e)?_e.dirname(e):e,i=_e.dirname(r),o=en.get(r);ox(i)&&(r=i);let a=_e.resolve(n),l=a!==e,u=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+_e.sep))&&t(f,h,m)},d=!1;for(let f of en.keys())if(e.indexOf(_e.resolve(f)+_e.sep)===0){r=f,o=en.get(r),d=!0;break}return o||d?o.listeners.add(u):(o={listeners:new Set([u]),rawEmitter:s,watcher:rx(r,(f,h)=>{if(!o.listeners.size||h&zw)return;let m=kn.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},en.set(r,o)),()=>{let f=o.listeners;if(f.delete(u),!f.size&&(en.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var ox=n=>{let e=0;for(let t of en.keys())if(t.indexOf(n)===0&&(e++,e>=nx))return!0;return!1},ax=()=>kn&&en.size<128,Ko=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=_e.dirname(n))!==e;)t++;return t},Of=(n,e)=>n.type===ss&&e.isDirectory()||n.type===If&&e.isSymbolicLink()||n.type===Yw&&e.isFile(),Go=class{constructor(e){this.fsw=e}checkIgnored(e,t){let s=this.fsw._ignoredPaths;if(this.fsw._isIgnored(e,t))return s.add(e),t&&t.isDirectory()&&s.add(e+Tf),!0;s.delete(e),s.delete(e+Tf)}addOrChange(e,t,s,r,i,o,a,l){let u=i.has(o)?jw:Uo;this.handleEvent(u,e,t,s,r,i,o,a,l)}async checkExists(e,t,s,r,i,o,a,l){try{let u=await Wo(e);if(this.fsw.closed)return;Of(a,u)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(or,e,t,s,r,i,o,a,l)}catch(u){u.code==="EACCES"?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(or,e,t,s,r,i,o,a,l)}}handleEvent(e,t,s,r,i,o,a,l,u){if(!(this.fsw.closed||this.checkIgnored(t)))if(e===or){let d=l.type===ss;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===Uo){if(l.type===ss&&this.fsw._getWatchedDir(t),l.type===If&&u.followSymlinks){let f=u.depth===void 0?void 0:Ko(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===ss?e+Jw:e;this.fsw._emit(d,t),d===Cf&&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=ix(e,t,async(l,u,d)=>{if(this.fsw.closed||i.depth!==void 0&&Ko(l,t)>i.depth)return;let f=s(_e.join(e,_e.relative(e,l)));if(r&&!r(f))return;let h=_e.dirname(f),m=_e.basename(f),p=this.fsw._getWatchedDir(d.type===ss?f:h);if(sx.has(u)||d.event===Vw)if(typeof i.ignored===qo){let g;try{g=await Wo(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;Of(d,g)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(or,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case qw:case Kw:return this.addOrChange(f,l,t,h,p,m,d,i);case Ww:case Gw: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 Pf(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!==Rf?a=o.replace(i,e):o!==Rf&&(a=_e.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(_e.dirname(o)),u=_e.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(u)&&(l.add(u),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?Cf:Uo,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,_e.resolve(e||s.watchPath),r,s.globFilter);this.fsw._addPathCloser(t,i)}async _addToFsEvents(e,t,s,r){if(this.fsw.closed)return;let i=this.fsw.options,o=typeof t===qo?t:Xw,a=this.fsw._getWatchHelpers(e);try{let l=await tx[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))throw null;if(l.isDirectory()){if(a.globFilter||this.emitAdd(o(e),l,o,i,s),r&&r>i.depth)return;this.fsw._readdirp(a.watchPath,{fileFilter:u=>a.filterPath(u),directoryFilter:u=>a.filterDir(u),...Zw(i.depth-(r||0))}).on(Bw,u=>{if(this.fsw.closed||u.stats.isDirectory()&&!a.filterPath(u))return;let d=_e.join(a.watchPath,u.path),{fullPath:f}=u;if(a.followSymlinks&&u.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:Ko(d,_e.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,u.stats,o,i,s)}).on(Hw,Qw).on(Uw,()=>{this.fsw._emitReady()})}else this.emitAdd(a.watchPath,l,o,i,s),this.fsw._emitReady()}catch(l){(!l||this.fsw._handleError(l))&&(this.fsw._emitReady(),this.fsw._emitReady())}if(i.persistent&&s!==!0)if(typeof t===qo)this.initWatch(void 0,e,a,o);else{let l;try{l=await Pf(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};Yo.exports=Go;Yo.exports.canUse=ax});var Wf=j(ua=>{"use strict";var{EventEmitter:lx}=require("events"),la=require("fs"),re=require("path"),{promisify:Bf}=require("util"),cx=wd(),ta=Ed().default,ux=Id(),Jo=To(),dx=gf(),fx=Eo(),px=Ef(),Lf=Mf(),{EV_ALL:Qo,EV_READY:hx,EV_ADD:ar,EV_CHANGE:rs,EV_UNLINK:Df,EV_ADD_DIR:mx,EV_UNLINK_DIR:gx,EV_RAW:yx,EV_ERROR:Xo,STR_CLOSE:bx,STR_END:vx,BACK_SLASH_RE:wx,DOUBLE_SLASH_RE:Nf,SLASH_OR_BACK_SLASH_RE:xx,DOT_RE:Sx,REPLACER_RE:_x,SLASH:Zo,SLASH_SLASH:Ax,BRACE_START:kx,BANG:na,ONE_DOT:Uf,TWO_DOTS:$x,GLOBSTAR:Ex,SLASH_GLOBSTAR:ea,ANYMATCH_OPTS:sa,STRING_TYPE:ca,FUNCTION_TYPE:Cx,EMPTY_STR:ra,EMPTY_FN:Tx,isWindows:Rx,isMacos:Px,isIBMi:Ox}=tr(),Ix=Bf(la.stat),Mx=Bf(la.readdir),ia=(n=[])=>Array.isArray(n)?n:[n],qf=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?qf(t,e):e.push(t)}),e),Ff=n=>{let e=qf(ia(n));if(!e.every(t=>typeof t===ca))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(Kf)},jf=n=>{let e=n.replace(wx,Zo),t=!1;for(e.startsWith(Ax)&&(t=!0);e.match(Nf);)e=e.replace(Nf,Zo);return t&&(e=Zo+e),e},Kf=n=>jf(re.normalize(jf(n))),Hf=(n=ra)=>e=>typeof e!==ca?e:Kf(re.isAbsolute(e)?e:re.join(n,e)),Lx=(n,e)=>re.isAbsolute(n)?n:n.startsWith(na)?na+re.join(e,n.slice(1)):re.join(e,n),it=(n,e)=>n[e]===void 0,oa=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==Uf&&e!==$x&&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 Mx(s)}catch{this._removeWatcher&&this._removeWatcher(re.dirname(s),re.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)}},Dx="stat",Nx="lstat",aa=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(_x,ra),this.watchPath=t,this.fullWatchPath=re.resolve(t),this.hasGlob=t!==e,e===ra&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?ta(e,void 0,sa):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?Dx:Nx}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 re.join(this.watchPath,re.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===Cx?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(kx)?dx.expand(e):[e]).forEach(r=>{t.push(re.relative(this.watchPath,r).split(xx))}),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===Ex&&(s=!0),s||!t[0][o]||ta(i,t[0][o],sa))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},lr=class extends lx{constructor(e){super();let t={};e&&Object.assign(t,e),this._watched=new Map,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._symlinkPaths=new Map,this._streams=new Set,this.closed=!1,it(t,"persistent")&&(t.persistent=!0),it(t,"ignoreInitial")&&(t.ignoreInitial=!1),it(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),it(t,"interval")&&(t.interval=100),it(t,"binaryInterval")&&(t.binaryInterval=300),it(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,it(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Lf.canUse()||(t.useFsEvents=!1),it(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=Px),Ox&&(t.usePolling=!0);let r=process.env.CHOKIDAR_USEPOLLING;if(r!==void 0){let l=r.toLowerCase();l==="false"||l==="0"?t.usePolling=!1:l==="true"||l==="1"?t.usePolling=!0:t.usePolling=!!l}let i=process.env.CHOKIDAR_INTERVAL;i&&(t.interval=Number.parseInt(i,10)),it(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),it(t,"followSymlinks")&&(t.followSymlinks=!0),it(t,"awaitWriteFinish")&&(t.awaitWriteFinish=!1),t.awaitWriteFinish===!0&&(t.awaitWriteFinish={});let o=t.awaitWriteFinish;o&&(o.stabilityThreshold||(o.stabilityThreshold=2e3),o.pollInterval||(o.pollInterval=100),this._pendingWrites=new Map),t.ignored&&(t.ignored=ia(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=Tx,this._readyEmitted=!0,process.nextTick(()=>this.emit(hx)))},this._emitRaw=(...l)=>this.emit(yx,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Lf(this):this._nodeFsHandler=new px(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=Ff(e);return r&&(o=o.map(a=>{let l=Lx(a,r);return i||!Jo(a)?l:fx(l)})),o=o.filter(a=>a.startsWith(na)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+ea),this._userIgnored=void 0,!0)),this.options.useFsEvents&&this._fsEventsHandler?(this._readyCount||(this._readyCount=o.length),this.options.persistent&&(this._readyCount+=o.length),o.forEach(a=>this._fsEventsHandler._addToFsEvents(a))):(this._readyCount||(this._readyCount=0),this._readyCount+=o.length,Promise.all(o.map(async a=>{let l=await this._nodeFsHandler._addToNodeFs(a,!s,0,0,t);return l&&this._emitReady(),l})).then(a=>{this.closed||a.filter(l=>l).forEach(l=>{this.add(re.dirname(l),re.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=Ff(e),{cwd:s}=this.options;return t.forEach(r=>{!re.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=re.join(s,r)),r=re.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+ea),this._userIgnored=void 0}),this}close(){if(this.closed)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(s=>{let r=s();r instanceof Promise&&e.push(r)})),this._streams.forEach(t=>t.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(t=>t.dispose()),["closers","watched","streams","symlinkPaths","throttled"].forEach(t=>{this[`_${t}`].clear()}),this._closePromise=e.length?Promise.all(e).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,s)=>{let r=this.options.cwd?re.relative(this.options.cwd,s):s;e[r||Uf]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==Xo&&this.emit(Qo,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;Rx&&(t=re.normalize(t)),o.cwd&&(t=re.relative(o.cwd,t));let a=[e,t];i!==void 0?a.push(s,r,i):r!==void 0?a.push(s,r):s!==void 0&&a.push(s);let l=o.awaitWriteFinish,u;if(l&&(u=this._pendingWrites.get(t)))return u.lastChange=new Date,this;if(o.atomic){if(e===Df)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(Qo,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===ar&&this._pendingUnlinks.has(t)&&(e=a[0]=rs,this._pendingUnlinks.delete(t))}if(l&&(e===ar||e===rs)&&this._readyEmitted){let d=(f,h)=>{f?(e=a[0]=Xo,a[1]=f,this.emitWithAll(e,a)):h&&(a.length>2?a[2]=h:a.push(h),this.emitWithAll(e,a))};return this._awaitWriteFinish(t,l.stabilityThreshold,e,d),this}if(e===rs&&!this._throttle(rs,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===ar||e===mx||e===rs)){let d=o.cwd?re.join(o.cwd,t):t,f;try{f=await Ix(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(Xo,e),e||this.closed}_throttle(e,t,s){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e),i=r.get(t);if(i)return i.count++,!1;let o,a=()=>{let u=r.get(t),d=u?u.count:0;return r.delete(t),clearTimeout(o),u&&clearTimeout(u.timeoutObject),d};o=setTimeout(a,s);let l={timeoutObject:o,clear:a,count:0};return r.set(t,l),l}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,s,r){let i,o=e;this.options.cwd&&!re.isAbsolute(e)&&(o=re.join(this.options.cwd,e));let a=new Date,l=u=>{la.stat(o,(d,f)=>{if(d||!this._pendingWrites.has(e)){d&&d.code!=="ENOENT"&&r(d);return}let h=Number(new Date);u&&f.size!==u.size&&(this._pendingWrites.get(e).lastChange=h);let m=this._pendingWrites.get(e);h-m.lastChange>=t?(this._pendingWrites.delete(e),r(void 0,f)):i=setTimeout(l,this.options.awaitWriteFinish.pollInterval,f)})};this._pendingWrites.has(e)||(this._pendingWrites.set(e,{lastChange:a,cancelWait:()=>(this._pendingWrites.delete(e),clearTimeout(i),s)}),i=setTimeout(l,this.options.awaitWriteFinish.pollInterval))}_getGlobIgnored(){return[...this._ignoredPaths.values()]}_isIgnored(e,t){if(this.options.atomic&&Sx.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(Hf(s)),o=ia(i).filter(l=>typeof l===ca&&!Jo(l)).map(l=>l+ea),a=this._getGlobIgnored().map(Hf(s)).concat(i,o);this._userIgnored=ta(a,void 0,sa)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!Jo(e)?e:ux(e),r=this.options.followSymlinks;return new aa(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=re.resolve(e);return this._watched.has(t)||this._watched.set(t,new oa(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){if(this.options.ignorePermissionErrors)return!0;let s=(e&&Number.parseInt(e.mode,10))&511;return!!(4&Number.parseInt(s.toString(8)[0],10))}_remove(e,t,s){let r=re.join(e,t),i=re.resolve(r);if(s=s??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!s&&!this.options.useFsEvents&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(h=>this._remove(r,h));let l=this._getWatchedDir(e),u=l.has(t);l.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let d=r;if(this.options.cwd&&(d=re.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===ar)return;this._watched.delete(r),this._watched.delete(i);let f=s?gx:Df;u&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=re.dirname(e);this._getWatchedDir(t).remove(re.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:Qo,alwaysStat:!0,lstat:!0,...t},r=cx(e,s);return this._streams.add(r),r.once(bx,()=>{r=void 0}),r.once(vx,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};ua.FSWatcher=lr;var Fx=(n,e)=>{let t=new lr(e);return t.add(n),t};ua.watch=Fx});var Yf={};Ne(Yf,{CollaborationManager:()=>is,addTeamMember:()=>Bx,formatTeamConfig:()=>Ux,initTeamConfig:()=>Hx,loadTeamConfig:()=>jx,saveTeamConfig:()=>zf});function jx(n){let e=Je.join(n,".hablas","team.json");if(ve.existsSync(e))try{return JSON.parse(ve.readFileSync(e,"utf-8"))}catch{return null}return null}function Hx(n,e){let t={name:e,members:[]};return zf(n,t),t}function zf(n,e){let t=Je.join(n,".hablas","team.json"),s=Je.dirname(t);ve.existsSync(s)||ve.mkdirSync(s,{recursive:!0}),ve.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function Bx(n,e,t){return n.members.push({name:e,email:t}),n}function Ux(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
|
|
325
|
-
`)}var ve,Je,
|
|
326
|
-
${c.muted("[Debug] Project Context:")} ${c.highlight(i)}`),this.projectTeamToken=
|
|
323
|
+
If you cannot complete a task, explain why with absolute technical objectivity.`;uo=$e.join(fo.homedir(),".hablas","backup")});var Gn=j((pE,Qu)=>{"use strict";var Ab=require("path"),ht="\\\\/",Vu=`[^${ht}]`,kb=0,Tt="\\.",$b="\\+",Cb="\\?",qs="\\/",Eb="(?=.)",zu="[^/]",po=`(?:${qs}|$)`,Yu=`(?:^|${qs})`,ho=`${Tt}{1,2}${po}`,Tb=`(?!${Tt})`,Rb=`(?!${Yu}${ho})`,Pb=`(?!${Tt}{0,1}${po})`,Ob=`(?!${ho})`,Ib=`[^.${qs}]`,Mb=`${zu}*?`,Ju={DOT_LITERAL:Tt,PLUS_LITERAL:$b,QMARK_LITERAL:Cb,SLASH_LITERAL:qs,ONE_CHAR:Eb,QMARK:zu,END_ANCHOR:po,DOTS_SLASH:ho,NO_DOT:Tb,NO_DOTS:Rb,NO_DOT_SLASH:Pb,NO_DOTS_SLASH:Ob,QMARK_NO_DOT:Ib,STAR:Mb,START_ANCHOR:Yu},Lb={...Ju,SLASH_LITERAL:`[${ht}]`,QMARK:Vu,STAR:`${Vu}*?`,DOTS_SLASH:`${Tt}{1,2}(?:[${ht}]|$)`,NO_DOT:`(?!${Tt})`,NO_DOTS:`(?!(?:^|[${ht}])${Tt}{1,2}(?:[${ht}]|$))`,NO_DOT_SLASH:`(?!${Tt}{0,1}(?:[${ht}]|$))`,NO_DOTS_SLASH:`(?!${Tt}{1,2}(?:[${ht}]|$))`,QMARK_NO_DOT:`[^.${ht}]`,START_ANCHOR:`(?:^|[${ht}])`,END_ANCHOR:`(?:[${ht}]|$)`},Db={__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"};Qu.exports={DEFAULT_MAX_EXTGLOB_RECURSION:kb,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:Db,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:Ab.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?Lb:Ju}}});var Ks=j(Me=>{"use strict";var Nb=require("path"),Fb=process.platform==="win32",{REGEX_BACKSLASH:jb,REGEX_REMOVE_BACKSLASH:Hb,REGEX_SPECIAL_CHARS:Bb,REGEX_SPECIAL_CHARS_GLOBAL:Ub}=Gn();Me.isObject=n=>n!==null&&typeof n=="object"&&!Array.isArray(n);Me.hasRegexChars=n=>Bb.test(n);Me.isRegexChar=n=>n.length===1&&Me.hasRegexChars(n);Me.escapeRegex=n=>n.replace(Ub,"\\$1");Me.toPosixSlashes=n=>n.replace(jb,"/");Me.removeBackslashes=n=>n.replace(Hb,e=>e==="\\"?"":e);Me.supportsLookbehinds=()=>{let n=process.version.slice(1).split(".").map(Number);return n.length===3&&n[0]>=9||n[0]===8&&n[1]>=10};Me.isWindows=n=>n&&typeof n.windows=="boolean"?n.windows:Fb===!0||Nb.sep==="\\";Me.escapeLast=(n,e,t)=>{let s=n.lastIndexOf(e,t);return s===-1?n:n[s-1]==="\\"?Me.escapeLast(n,e,s-1):`${n.slice(0,s)}\\${n.slice(s)}`};Me.removePrefix=(n,e={})=>{let t=n;return t.startsWith("./")&&(t=t.slice(2),e.prefix="./"),t};Me.wrapOutput=(n,e={},t={})=>{let s=t.contains?"":"^",r=t.contains?"":"$",i=`${s}(?:${n})${r}`;return e.negated===!0&&(i=`(?:^(?!${i}).*$)`),i}});var id=j((mE,rd)=>{"use strict";var Xu=Ks(),{CHAR_ASTERISK:mo,CHAR_AT:qb,CHAR_BACKWARD_SLASH:Vn,CHAR_COMMA:Kb,CHAR_DOT:go,CHAR_EXCLAMATION_MARK:yo,CHAR_FORWARD_SLASH:sd,CHAR_LEFT_CURLY_BRACE:bo,CHAR_LEFT_PARENTHESES:vo,CHAR_LEFT_SQUARE_BRACKET:Wb,CHAR_PLUS:Gb,CHAR_QUESTION_MARK:Zu,CHAR_RIGHT_CURLY_BRACE:Vb,CHAR_RIGHT_PARENTHESES:ed,CHAR_RIGHT_SQUARE_BRACKET:zb}=Gn(),td=n=>n===sd||n===Vn,nd=n=>{n.isPrefix!==!0&&(n.depth=n.isGlobstar?1/0:1)},Yb=(n,e)=>{let t=e||{},s=n.length-1,r=t.parts===!0||t.scanToEnd===!0,i=[],o=[],a=[],l=n,u=-1,d=0,f=0,h=!1,m=!1,p=!1,g=!1,x=!1,S=!1,A=!1,k=!1,y=!1,b=!1,v=0,w,_,E={value:"",depth:0,isGlob:!1},I=()=>u>=s,$=()=>l.charCodeAt(u+1),F=()=>(w=_,l.charCodeAt(++u));for(;u<s;){_=F();let Z;if(_===Vn){A=E.backslashes=!0,_=F(),_===bo&&(S=!0);continue}if(S===!0||_===bo){for(v++;I()!==!0&&(_=F());){if(_===Vn){A=E.backslashes=!0,F();continue}if(_===bo){v++;continue}if(S!==!0&&_===go&&(_=F())===go){if(h=E.isBrace=!0,p=E.isGlob=!0,b=!0,r===!0)continue;break}if(S!==!0&&_===Kb){if(h=E.isBrace=!0,p=E.isGlob=!0,b=!0,r===!0)continue;break}if(_===Vb&&(v--,v===0)){S=!1,h=E.isBrace=!0,b=!0;break}}if(r===!0)continue;break}if(_===sd){if(i.push(u),o.push(E),E={value:"",depth:0,isGlob:!1},b===!0)continue;if(w===go&&u===d+1){d+=2;continue}f=u+1;continue}if(t.noext!==!0&&(_===Gb||_===qb||_===mo||_===Zu||_===yo)===!0&&$()===vo){if(p=E.isGlob=!0,g=E.isExtglob=!0,b=!0,_===yo&&u===d&&(y=!0),r===!0){for(;I()!==!0&&(_=F());){if(_===Vn){A=E.backslashes=!0,_=F();continue}if(_===ed){p=E.isGlob=!0,b=!0;break}}continue}break}if(_===mo){if(w===mo&&(x=E.isGlobstar=!0),p=E.isGlob=!0,b=!0,r===!0)continue;break}if(_===Zu){if(p=E.isGlob=!0,b=!0,r===!0)continue;break}if(_===Wb){for(;I()!==!0&&(Z=F());){if(Z===Vn){A=E.backslashes=!0,F();continue}if(Z===zb){m=E.isBracket=!0,p=E.isGlob=!0,b=!0;break}}if(r===!0)continue;break}if(t.nonegate!==!0&&_===yo&&u===d){k=E.negated=!0,d++;continue}if(t.noparen!==!0&&_===vo){if(p=E.isGlob=!0,r===!0){for(;I()!==!0&&(_=F());){if(_===vo){A=E.backslashes=!0,_=F();continue}if(_===ed){b=!0;break}}continue}break}if(p===!0){if(b=!0,r===!0)continue;break}}t.noext===!0&&(g=!1,p=!1);let B=l,z="",T="";d>0&&(z=l.slice(0,d),l=l.slice(d),f-=d),B&&p===!0&&f>0?(B=l.slice(0,f),T=l.slice(f)):p===!0?(B="",T=l):B=l,B&&B!==""&&B!=="/"&&B!==l&&td(B.charCodeAt(B.length-1))&&(B=B.slice(0,-1)),t.unescape===!0&&(T&&(T=Xu.removeBackslashes(T)),B&&A===!0&&(B=Xu.removeBackslashes(B)));let C={prefix:z,input:n,start:d,base:B,glob:T,isBrace:h,isBracket:m,isGlob:p,isExtglob:g,isGlobstar:x,negated:k,negatedExtglob:y};if(t.tokens===!0&&(C.maxDepth=0,td(_)||o.push(E),C.tokens=o),t.parts===!0||t.tokens===!0){let Z;for(let D=0;D<i.length;D++){let K=Z?Z+1:d,ee=i[D],le=n.slice(K,ee);t.tokens&&(D===0&&d!==0?(o[D].isPrefix=!0,o[D].value=z):o[D].value=le,nd(o[D]),C.maxDepth+=o[D].depth),(D!==0||le!=="")&&a.push(le),Z=ee}if(Z&&Z+1<n.length){let D=n.slice(Z+1);a.push(D),t.tokens&&(o[o.length-1].value=D,nd(o[o.length-1]),C.maxDepth+=o[o.length-1].depth)}C.slashes=i,C.parts=a}return C};rd.exports=Yb});var ud=j((gE,cd)=>{"use strict";var zn=Gn(),Te=Ks(),{MAX_LENGTH:Ws,POSIX_REGEX_SOURCE:Jb,REGEX_NON_SPECIAL_CHARS:Qb,REGEX_SPECIAL_CHARS_BACKREF:Xb,REPLACEMENTS:od}=zn,Zb=(n,e)=>{if(typeof e.expandRange=="function")return e.expandRange(...n,e);n.sort();let t=`[${n.join("-")}]`;try{new RegExp(t)}catch{return n.map(r=>Te.escapeRegex(r)).join("..")}return t},wn=(n,e)=>`Missing ${n}: "${e}" - use "\\\\${e}" to match literal characters`,ad=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},ev=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},ld=n=>{let e=n.trim(),t=!0;for(;t===!0;)t=!1,/^@\([^\\()[\]{}|]+\)$/.test(e)&&(e=e.slice(2,-1),t=!0);if(ev(e))return e.replace(/\\(.)/g,"$1")},tv=n=>{let e=n.map(ld).filter(Boolean);for(let t=0;t<e.length;t++)for(let s=t+1;s<e.length;s++){let r=e[t],i=e[s],o=r[0];if(!(!o||r!==o.repeat(r.length)||i!==o.repeat(i.length))&&(r===i||r.startsWith(i)||i.startsWith(r)))return!0}return!1},wo=(n,e=!0)=>{if(n[0]!=="+"&&n[0]!=="*"||n[1]!=="(")return;let t=0,s=0,r=0,i=!1;for(let o=1;o<n.length;o++){let a=n[o];if(i===!0){i=!1;continue}if(a==="\\"){i=!0;continue}if(a==='"'){r=r===1?0:1;continue}if(r!==1){if(a==="["){t++;continue}if(a==="]"&&t>0){t--;continue}if(!(t>0)){if(a==="("){s++;continue}if(a===")"&&(s--,s===0))return e===!0&&o!==n.length-1?void 0:{type:n[0],body:n.slice(2,o),end:o}}}}},nv=n=>{let e=0,t=[];for(;e<n.length;){let r=wo(n.slice(e),!1);if(!r||r.type!=="*")return;let i=ad(r.body).map(a=>a.trim());if(i.length!==1)return;let o=ld(i[0]);if(!o||o.length!==1)return;t.push(o),e+=r.end+1}return t.length<1?void 0:`${t.length===1?Te.escapeRegex(t[0]):`[${t.map(r=>Te.escapeRegex(r)).join("")}]`}*`},sv=n=>{let e=0,t=n.trim(),s=wo(t);for(;s;)e++,t=s.body.trim(),s=wo(t);return e},rv=(n,e)=>{if(e.maxExtglobRecursion===!1)return{risky:!1};let t=typeof e.maxExtglobRecursion=="number"?e.maxExtglobRecursion:zn.DEFAULT_MAX_EXTGLOB_RECURSION,s=ad(n).map(r=>r.trim());if(s.length>1&&(s.some(r=>r==="")||s.some(r=>/^[*?]+$/.test(r))||tv(s)))return{risky:!0};for(let r of s){let i=nv(r);if(i)return{risky:!0,safeOutput:i};if(sv(r)>t)return{risky:!0}}return{risky:!1}},xo=(n,e)=>{if(typeof n!="string")throw new TypeError("Expected a string");n=od[n]||n;let t={...e},s=typeof t.maxLength=="number"?Math.min(Ws,t.maxLength):Ws,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);let i={type:"bos",value:"",output:t.prepend||""},o=[i],a=t.capture?"":"?:",l=Te.isWindows(e),u=zn.globChars(l),d=zn.extglobChars(u),{DOT_LITERAL:f,PLUS_LITERAL:h,SLASH_LITERAL:m,ONE_CHAR:p,DOTS_SLASH:g,NO_DOT:x,NO_DOT_SLASH:S,NO_DOTS_SLASH:A,QMARK:k,QMARK_NO_DOT:y,STAR:b,START_ANCHOR:v}=u,w=P=>`(${a}(?:(?!${v}${P.dot?g:f}).)*?)`,_=t.dot?"":x,E=t.dot?k:y,I=t.bash===!0?w(t):b;t.capture&&(I=`(${I})`),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=Te.removePrefix(n,$),r=n.length;let F=[],B=[],z=[],T=i,C,Z=()=>$.index===r-1,D=$.peek=(P=1)=>n[$.index+P],K=$.advance=()=>n[++$.index]||"",ee=()=>n.slice($.index+1),le=(P="",X=0)=>{$.consumed+=P,$.index+=X},ne=P=>{$.output+=P.output!=null?P.output:P.value,le(P.value)},me=()=>{let P=1;for(;D()==="!"&&(D(2)!=="("||D(3)==="?");)K(),$.start++,P++;return P%2===0?!1:($.negated=!0,$.start++,!0)},We=P=>{$[P]++,z.push(P)},se=P=>{$[P]--,z.pop()},H=P=>{if(T.type==="globstar"){let X=$.braces>0&&(P.type==="comma"||P.type==="brace"),M=P.extglob===!0||F.length&&(P.type==="pipe"||P.type==="paren");P.type!=="slash"&&P.type!=="paren"&&!X&&!M&&($.output=$.output.slice(0,-T.output.length),T.type="star",T.value="*",T.output=I,$.output+=T.output)}if(F.length&&P.type!=="paren"&&(F[F.length-1].inner+=P.value),(P.value||P.output)&&ne(P),T&&T.type==="text"&&P.type==="text"){T.value+=P.value,T.output=(T.output||"")+P.value;return}P.prev=T,o.push(P),T=P},be=(P,X)=>{let M={...d[X],conditions:1,inner:""};M.prev=T,M.parens=$.parens,M.output=$.output,M.startIndex=$.index,M.tokensIndex=o.length;let W=(t.capture?"(":"")+M.open;We("parens"),H({type:P,value:X,output:$.output?"":p}),H({type:"paren",extglob:!0,value:K(),output:W}),F.push(M)},Ae=P=>{let X=n.slice(P.startIndex,$.index+1),M=n.slice(P.startIndex+2,$.index),W=rv(M,t);if((P.type==="plus"||P.type==="star")&&W.risky){let Q=W.safeOutput?(P.output?"":p)+(t.capture?`(${W.safeOutput})`:W.safeOutput):void 0,ke=o[P.tokensIndex];ke.type="text",ke.value=X,ke.output=Q||Te.escapeRegex(X);for(let Ge=P.tokensIndex+1;Ge<o.length;Ge++)o[Ge].value="",o[Ge].output="",delete o[Ge].suffix;$.output=P.output+ke.output,$.backtrack=!0,H({type:"paren",extglob:!0,value:C,output:""}),se("parens");return}let te=P.close+(t.capture?")":""),oe;if(P.type==="negate"){let Q=I;if(P.inner&&P.inner.length>1&&P.inner.includes("/")&&(Q=w(t)),(Q!==I||Z()||/^\)+$/.test(ee()))&&(te=P.close=`)$))${Q}`),P.inner.includes("*")&&(oe=ee())&&/^\.[^\\/.]+$/.test(oe)){let ke=xo(oe,{...e,fastpaths:!1}).output;te=P.close=`)${ke})${Q})`}P.prev.type==="bos"&&($.negatedExtglob=!0)}H({type:"paren",extglob:!0,value:C,output:te}),se("parens")};if(t.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(n)){let P=!1,X=n.replace(Xb,(M,W,te,oe,Q,ke)=>oe==="\\"?(P=!0,M):oe==="?"?W?W+oe+(Q?k.repeat(Q.length):""):ke===0?E+(Q?k.repeat(Q.length):""):k.repeat(te.length):oe==="."?f.repeat(te.length):oe==="*"?W?W+oe+(Q?I:""):I:W?M:`\\${M}`);return P===!0&&(t.unescape===!0?X=X.replace(/\\/g,""):X=X.replace(/\\+/g,M=>M.length%2===0?"\\\\":M?"\\":"")),X===n&&t.contains===!0?($.output=n,$):($.output=Te.wrapOutput(X,$,e),$)}for(;!Z();){if(C=K(),C==="\0")continue;if(C==="\\"){let M=D();if(M==="/"&&t.bash!==!0||M==="."||M===";")continue;if(!M){C+="\\",H({type:"text",value:C});continue}let W=/^\\+/.exec(ee()),te=0;if(W&&W[0].length>2&&(te=W[0].length,$.index+=te,te%2!==0&&(C+="\\")),t.unescape===!0?C=K():C+=K(),$.brackets===0){H({type:"text",value:C});continue}}if($.brackets>0&&(C!=="]"||T.value==="["||T.value==="[^")){if(t.posix!==!1&&C===":"){let M=T.value.slice(1);if(M.includes("[")&&(T.posix=!0,M.includes(":"))){let W=T.value.lastIndexOf("["),te=T.value.slice(0,W),oe=T.value.slice(W+2),Q=Jb[oe];if(Q){T.value=te+Q,$.backtrack=!0,K(),!i.output&&o.indexOf(T)===1&&(i.output=p);continue}}}(C==="["&&D()!==":"||C==="-"&&D()==="]")&&(C=`\\${C}`),C==="]"&&(T.value==="["||T.value==="[^")&&(C=`\\${C}`),t.posix===!0&&C==="!"&&T.value==="["&&(C="^"),T.value+=C,ne({value:C});continue}if($.quotes===1&&C!=='"'){C=Te.escapeRegex(C),T.value+=C,ne({value:C});continue}if(C==='"'){$.quotes=$.quotes===1?0:1,t.keepQuotes===!0&&H({type:"text",value:C});continue}if(C==="("){We("parens"),H({type:"paren",value:C});continue}if(C===")"){if($.parens===0&&t.strictBrackets===!0)throw new SyntaxError(wn("opening","("));let M=F[F.length-1];if(M&&$.parens===M.parens+1){Ae(F.pop());continue}H({type:"paren",value:C,output:$.parens?")":"\\)"}),se("parens");continue}if(C==="["){if(t.nobracket===!0||!ee().includes("]")){if(t.nobracket!==!0&&t.strictBrackets===!0)throw new SyntaxError(wn("closing","]"));C=`\\${C}`}else We("brackets");H({type:"bracket",value:C});continue}if(C==="]"){if(t.nobracket===!0||T&&T.type==="bracket"&&T.value.length===1){H({type:"text",value:C,output:`\\${C}`});continue}if($.brackets===0){if(t.strictBrackets===!0)throw new SyntaxError(wn("opening","["));H({type:"text",value:C,output:`\\${C}`});continue}se("brackets");let M=T.value.slice(1);if(T.posix!==!0&&M[0]==="^"&&!M.includes("/")&&(C=`/${C}`),T.value+=C,ne({value:C}),t.literalBrackets===!1||Te.hasRegexChars(M))continue;let W=Te.escapeRegex(T.value);if($.output=$.output.slice(0,-T.value.length),t.literalBrackets===!0){$.output+=W,T.value=W;continue}T.value=`(${a}${W}|${T.value})`,$.output+=T.value;continue}if(C==="{"&&t.nobrace!==!0){We("braces");let M={type:"brace",value:C,output:"(",outputIndex:$.output.length,tokensIndex:$.tokens.length};B.push(M),H(M);continue}if(C==="}"){let M=B[B.length-1];if(t.nobrace===!0||!M){H({type:"text",value:C,output:C});continue}let W=")";if(M.dots===!0){let te=o.slice(),oe=[];for(let Q=te.length-1;Q>=0&&(o.pop(),te[Q].type!=="brace");Q--)te[Q].type!=="dots"&&oe.unshift(te[Q].value);W=Zb(oe,t),$.backtrack=!0}if(M.comma!==!0&&M.dots!==!0){let te=$.output.slice(0,M.outputIndex),oe=$.tokens.slice(M.tokensIndex);M.value=M.output="\\{",C=W="\\}",$.output=te;for(let Q of oe)$.output+=Q.output||Q.value}H({type:"brace",value:C,output:W}),se("braces"),B.pop();continue}if(C==="|"){F.length>0&&F[F.length-1].conditions++,H({type:"text",value:C});continue}if(C===","){let M=C,W=B[B.length-1];W&&z[z.length-1]==="braces"&&(W.comma=!0,M="|"),H({type:"comma",value:C,output:M});continue}if(C==="/"){if(T.type==="dot"&&$.index===$.start+1){$.start=$.index+1,$.consumed="",$.output="",o.pop(),T=i;continue}H({type:"slash",value:C,output:m});continue}if(C==="."){if($.braces>0&&T.type==="dot"){T.value==="."&&(T.output=f);let M=B[B.length-1];T.type="dots",T.output+=C,T.value+=C,M.dots=!0;continue}if($.braces+$.parens===0&&T.type!=="bos"&&T.type!=="slash"){H({type:"text",value:C,output:f});continue}H({type:"dot",value:C,output:f});continue}if(C==="?"){if(!(T&&T.value==="(")&&t.noextglob!==!0&&D()==="("&&D(2)!=="?"){be("qmark",C);continue}if(T&&T.type==="paren"){let W=D(),te=C;if(W==="<"&&!Te.supportsLookbehinds())throw new Error("Node.js v10 or higher is required for regex lookbehinds");(T.value==="("&&!/[!=<:]/.test(W)||W==="<"&&!/<([!=]|\w+>)/.test(ee()))&&(te=`\\${C}`),H({type:"text",value:C,output:te});continue}if(t.dot!==!0&&(T.type==="slash"||T.type==="bos")){H({type:"qmark",value:C,output:y});continue}H({type:"qmark",value:C,output:k});continue}if(C==="!"){if(t.noextglob!==!0&&D()==="("&&(D(2)!=="?"||!/[!=<:]/.test(D(3)))){be("negate",C);continue}if(t.nonegate!==!0&&$.index===0){me();continue}}if(C==="+"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){be("plus",C);continue}if(T&&T.value==="("||t.regex===!1){H({type:"plus",value:C,output:h});continue}if(T&&(T.type==="bracket"||T.type==="paren"||T.type==="brace")||$.parens>0){H({type:"plus",value:C});continue}H({type:"plus",value:h});continue}if(C==="@"){if(t.noextglob!==!0&&D()==="("&&D(2)!=="?"){H({type:"at",extglob:!0,value:C,output:""});continue}H({type:"text",value:C});continue}if(C!=="*"){(C==="$"||C==="^")&&(C=`\\${C}`);let M=Qb.exec(ee());M&&(C+=M[0],$.index+=M[0].length),H({type:"text",value:C});continue}if(T&&(T.type==="globstar"||T.star===!0)){T.type="star",T.star=!0,T.value+=C,T.output=I,$.backtrack=!0,$.globstar=!0,le(C);continue}let P=ee();if(t.noextglob!==!0&&/^\([^?]/.test(P)){be("star",C);continue}if(T.type==="star"){if(t.noglobstar===!0){le(C);continue}let M=T.prev,W=M.prev,te=M.type==="slash"||M.type==="bos",oe=W&&(W.type==="star"||W.type==="globstar");if(t.bash===!0&&(!te||P[0]&&P[0]!=="/")){H({type:"star",value:C,output:""});continue}let Q=$.braces>0&&(M.type==="comma"||M.type==="brace"),ke=F.length&&(M.type==="pipe"||M.type==="paren");if(!te&&M.type!=="paren"&&!Q&&!ke){H({type:"star",value:C,output:""});continue}for(;P.slice(0,3)==="/**";){let Ge=n[$.index+4];if(Ge&&Ge!=="/")break;P=P.slice(3),le("/**",3)}if(M.type==="bos"&&Z()){T.type="globstar",T.value+=C,T.output=w(t),$.output=T.output,$.globstar=!0,le(C);continue}if(M.type==="slash"&&M.prev.type!=="bos"&&!oe&&Z()){$.output=$.output.slice(0,-(M.output+T.output).length),M.output=`(?:${M.output}`,T.type="globstar",T.output=w(t)+(t.strictSlashes?")":"|$)"),T.value+=C,$.globstar=!0,$.output+=M.output+T.output,le(C);continue}if(M.type==="slash"&&M.prev.type!=="bos"&&P[0]==="/"){let Ge=P[1]!==void 0?"|$":"";$.output=$.output.slice(0,-(M.output+T.output).length),M.output=`(?:${M.output}`,T.type="globstar",T.output=`${w(t)}${m}|${m}${Ge})`,T.value+=C,$.output+=M.output+T.output,$.globstar=!0,le(C+K()),H({type:"slash",value:"/",output:""});continue}if(M.type==="bos"&&P[0]==="/"){T.type="globstar",T.value+=C,T.output=`(?:^|${m}|${w(t)}${m})`,$.output=T.output,$.globstar=!0,le(C+K()),H({type:"slash",value:"/",output:""});continue}$.output=$.output.slice(0,-T.output.length),T.type="globstar",T.output=w(t),T.value+=C,$.output+=T.output,$.globstar=!0,le(C);continue}let X={type:"star",value:C,output:I};if(t.bash===!0){X.output=".*?",(T.type==="bos"||T.type==="slash")&&(X.output=_+X.output),H(X);continue}if(T&&(T.type==="bracket"||T.type==="paren")&&t.regex===!0){X.output=C,H(X);continue}($.index===$.start||T.type==="slash"||T.type==="dot")&&(T.type==="dot"?($.output+=S,T.output+=S):t.dot===!0?($.output+=A,T.output+=A):($.output+=_,T.output+=_),D()!=="*"&&($.output+=p,T.output+=p)),H(X)}for(;$.brackets>0;){if(t.strictBrackets===!0)throw new SyntaxError(wn("closing","]"));$.output=Te.escapeLast($.output,"["),se("brackets")}for(;$.parens>0;){if(t.strictBrackets===!0)throw new SyntaxError(wn("closing",")"));$.output=Te.escapeLast($.output,"("),se("parens")}for(;$.braces>0;){if(t.strictBrackets===!0)throw new SyntaxError(wn("closing","}"));$.output=Te.escapeLast($.output,"{"),se("braces")}if(t.strictSlashes!==!0&&(T.type==="star"||T.type==="bracket")&&H({type:"maybe_slash",value:"",output:`${m}?`}),$.backtrack===!0){$.output="";for(let P of $.tokens)$.output+=P.output!=null?P.output:P.value,P.suffix&&($.output+=P.suffix)}return $};xo.fastpaths=(n,e)=>{let t={...e},s=typeof t.maxLength=="number"?Math.min(Ws,t.maxLength):Ws,r=n.length;if(r>s)throw new SyntaxError(`Input length: ${r}, exceeds maximum allowed length: ${s}`);n=od[n]||n;let i=Te.isWindows(e),{DOT_LITERAL:o,SLASH_LITERAL:a,ONE_CHAR:l,DOTS_SLASH:u,NO_DOT:d,NO_DOTS:f,NO_DOTS_SLASH:h,STAR:m,START_ANCHOR:p}=zn.globChars(i),g=t.dot?f:d,x=t.dot?h:d,S=t.capture?"":"?:",A={negated:!1,prefix:""},k=t.bash===!0?".*?":m;t.capture&&(k=`(${k})`);let y=_=>_.noglobstar===!0?k:`(${S}(?:(?!${p}${_.dot?u:o}).)*?)`,b=_=>{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 E=/^(.*?)\.(\w+)$/.exec(_);if(!E)return;let I=b(E[1]);return I?I+o+E[2]:void 0}}},v=Te.removePrefix(n,A),w=b(v);return w&&t.strictSlashes!==!0&&(w+=`${a}?`),w};cd.exports=xo});var fd=j((yE,dd)=>{"use strict";var iv=require("path"),ov=id(),So=ud(),_o=Ks(),av=Gn(),lv=n=>n&&typeof n=="object"&&!Array.isArray(n),ye=(n,e,t=!1)=>{if(Array.isArray(n)){let d=n.map(h=>ye(h,e,t));return h=>{for(let m of d){let p=m(h);if(p)return p}return!1}}let s=lv(n)&&n.tokens&&n.input;if(n===""||typeof n!="string"&&!s)throw new TypeError("Expected pattern to be a non-empty string");let r=e||{},i=_o.isWindows(e),o=s?ye.compileRe(n,e):ye.makeRe(n,e,!1,!0),a=o.state;delete o.state;let l=()=>!1;if(r.ignore){let d={...e,ignore:null,onMatch:null,onResult:null};l=ye(r.ignore,d,t)}let u=(d,f=!1)=>{let{isMatch:h,match:m,output:p}=ye.test(d,o,e,{glob:n,posix:i}),g={glob:n,state:a,regex:o,posix:i,input:d,output:p,match:m,isMatch:h};return typeof r.onResult=="function"&&r.onResult(g),h===!1?(g.isMatch=!1,f?g:!1):l(d)?(typeof r.onIgnore=="function"&&r.onIgnore(g),g.isMatch=!1,f?g:!1):(typeof r.onMatch=="function"&&r.onMatch(g),f?g:!0)};return t&&(u.state=a),u};ye.test=(n,e,t,{glob:s,posix:r}={})=>{if(typeof n!="string")throw new TypeError("Expected input to be a string");if(n==="")return{isMatch:!1,output:""};let i=t||{},o=i.format||(r?_o.toPosixSlashes:null),a=n===s,l=a&&o?o(n):n;return a===!1&&(l=o?o(n):n,a=l===s),(a===!1||i.capture===!0)&&(i.matchBase===!0||i.basename===!0?a=ye.matchBase(n,e,t,r):a=e.exec(l)),{isMatch:!!a,match:a,output:l}};ye.matchBase=(n,e,t,s=_o.isWindows(t))=>(e instanceof RegExp?e:ye.makeRe(e,t)).test(iv.basename(n));ye.isMatch=(n,e,t)=>ye(e,t)(n);ye.parse=(n,e)=>Array.isArray(n)?n.map(t=>ye.parse(t,e)):So(n,{...e,fastpaths:!1});ye.scan=(n,e)=>ov(n,e);ye.compileRe=(n,e,t=!1,s=!1)=>{if(t===!0)return n.output;let r=e||{},i=r.contains?"":"^",o=r.contains?"":"$",a=`${i}(?:${n.output})${o}`;n&&n.negated===!0&&(a=`^(?!${a}).*$`);let l=ye.toRegex(a,e);return s===!0&&(l.state=n),l};ye.makeRe=(n,e={},t=!1,s=!1)=>{if(!n||typeof n!="string")throw new TypeError("Expected a non-empty string");let r={negated:!1,fastpaths:!0};return e.fastpaths!==!1&&(n[0]==="."||n[0]==="*")&&(r.output=So.fastpaths(n,e)),r.output||(r=So(n,e)),ye.compileRe(r,e,t,s)};ye.toRegex=(n,e)=>{try{let t=e||{};return new RegExp(n,t.flags||(t.nocase?"i":""))}catch(t){if(e&&e.debug===!0)throw t;return/$^/}};ye.constants=av;dd.exports=ye});var Ao=j((bE,pd)=>{"use strict";pd.exports=fd()});var xd=j((vE,wd)=>{"use strict";var Jn=require("fs"),{Readable:cv}=require("stream"),Yn=require("path"),{promisify:Ys}=require("util"),ko=Ao(),uv=Ys(Jn.readdir),dv=Ys(Jn.stat),hd=Ys(Jn.lstat),fv=Ys(Jn.realpath),pv="!",bd="READDIRP_RECURSIVE_ERROR",hv=new Set(["ENOENT","EPERM","EACCES","ELOOP",bd]),$o="files",vd="directories",Vs="files_directories",Gs="all",md=[$o,vd,Vs,Gs],mv=n=>hv.has(n.code),[gd,gv]=process.versions.node.split(".").slice(0,2).map(n=>Number.parseInt(n,10)),yv=process.platform==="win32"&&(gd>10||gd===10&&gv>=5),yd=n=>{if(n!==void 0){if(typeof n=="function")return n;if(typeof n=="string"){let e=ko(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)===pv?t.push(ko(r.slice(1))):e.push(ko(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))}}},zs=class n extends cv{static get defaultOptions(){return{root:".",fileFilter:e=>!0,directoryFilter:e=>!0,type:$o,lstat:!1,depth:2147483648,alwaysStat:!1}}constructor(e={}){super({objectMode:!0,autoDestroy:!0,highWaterMark:e.highWaterMark||4096});let t={...n.defaultOptions,...e},{root:s,type:r}=t;this._fileFilter=yd(t.fileFilter),this._directoryFilter=yd(t.directoryFilter);let i=t.lstat?hd:dv;yv?this._stat=o=>i(o,{bigint:!0}):this._stat=i,this._maxDepth=t.depth,this._wantsDir=[vd,Vs,Gs].includes(r),this._wantsFile=[$o,Vs,Gs].includes(r),this._wantsEverything=r===Gs,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 uv(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){mv(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 fv(s),i=await hd(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=bd,this._onError(a)}return"directory"}}catch(r){this._onError(r)}}}}_includeAsFile(e){let t=e&&e[this._statsProp];return t&&this._wantsEverything&&!t.isDirectory()}},xn=(n,e={})=>{let t=e.entryType||e.type;if(t==="both"&&(t=Vs),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&&!md.includes(t))throw new Error(`readdirp: Invalid type passed. Use one of ${md.join(", ")}`)}else throw new Error("readdirp: root argument is required. Usage: readdirp(root, options)");return e.root=n,new zs(e)},bv=(n,e={})=>new Promise((t,s)=>{let r=[];xn(n,e).on("data",i=>r.push(i)).on("end",()=>t(r)).on("error",i=>s(i))});xn.promise=bv;xn.ReaddirpStream=zs;xn.default=xn;wd.exports=xn});var Co=j((wE,Sd)=>{Sd.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 Ed=j(($d,Cd)=>{"use strict";Object.defineProperty($d,"__esModule",{value:!0});var kd=Ao(),vv=Co(),_d="!",wv={returnIndex:!1},xv=n=>Array.isArray(n)?n:[n],Sv=(n,e)=>{if(typeof n=="function")return n;if(typeof n=="string"){let t=kd(n,e);return s=>n===s||t(s)}return n instanceof RegExp?t=>n.test(t):t=>!1},Ad=(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=vv(i,!1);for(let l=0;l<e.length;l++){let u=e[l];if(u(o))return s?-1:!1}let a=r&&[o].concat(t.slice(1));for(let l=0;l<n.length;l++){let u=n[l];if(r?u(...a):u(o))return s?l:!0}return s?-1:!1},Eo=(n,e,t=wv)=>{if(n==null)throw new TypeError("anymatch: specify first argument");let s=typeof t=="boolean"?{returnIndex:t}:t,r=s.returnIndex||!1,i=xv(n),o=i.filter(l=>typeof l=="string"&&l.charAt(0)===_d).map(l=>l.slice(1)).map(l=>kd(l,s)),a=i.filter(l=>typeof l!="string"||typeof l=="string"&&l.charAt(0)!==_d).map(l=>Sv(l,s));return e==null?(l,u=!1)=>Ad(a,o,l,typeof u=="boolean"?u:!1):Ad(a,o,e,r)};Eo.default=Eo;Cd.exports=Eo});var Rd=j((xE,Td)=>{Td.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 To=j((SE,Od)=>{var _v=Rd(),Pd={"{":"}","(":")","[":"]"},Av=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=Pd[a];if(l){var u=n.indexOf(l,e);u!==-1&&(e=u+1)}if(n[e]==="!")return!0}else e++}return!1},kv=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=Pd[t];if(s){var r=n.indexOf(s,e);r!==-1&&(e=r+1)}if(n[e]==="!")return!0}else e++}return!1};Od.exports=function(e,t){if(typeof e!="string"||e==="")return!1;if(_v(e))return!0;var s=Av;return t&&t.strict===!1&&(s=kv),s(e)}});var Md=j((_E,Id)=>{"use strict";var $v=To(),Cv=require("path").posix.dirname,Ev=require("os").platform()==="win32",Ro="/",Tv=/\\/g,Rv=/[\{\[].*[\}\]]$/,Pv=/(^|[^\\])([\{\[]|\([^\)]+$)/,Ov=/\\([\!\*\?\|\[\]\(\)\{\}])/g;Id.exports=function(e,t){var s=Object.assign({flipBackslashes:!0},t);s.flipBackslashes&&Ev&&e.indexOf(Ro)<0&&(e=e.replace(Tv,Ro)),Rv.test(e)&&(e+=Ro),e+="a";do e=Cv(e);while($v(e)||Pv.test(e));return e.replace(Ov,"$1")}});var Js=j(Ye=>{"use strict";Ye.isInteger=n=>typeof n=="number"?Number.isInteger(n):typeof n=="string"&&n.trim()!==""?Number.isInteger(Number(n)):!1;Ye.find=(n,e)=>n.nodes.find(t=>t.type===e);Ye.exceedsLimit=(n,e,t=1,s)=>s===!1||!Ye.isInteger(n)||!Ye.isInteger(e)?!1:(Number(e)-Number(n))/Number(t)>=s;Ye.escapeNode=(n,e=0,t)=>{let s=n.nodes[e];s&&(t&&s.type===t||s.type==="open"||s.type==="close")&&s.escaped!==!0&&(s.value="\\"+s.value,s.escaped=!0)};Ye.encloseBrace=n=>n.type!=="brace"?!1:n.commas>>0+n.ranges>>0===0?(n.invalid=!0,!0):!1;Ye.isInvalidBrace=n=>n.type!=="brace"?!1:n.invalid===!0||n.dollar?!0:n.commas>>0+n.ranges>>0===0||n.open!==!0||n.close!==!0?(n.invalid=!0,!0):!1;Ye.isOpenOrClose=n=>n.type==="open"||n.type==="close"?!0:n.open===!0||n.close===!0;Ye.reduce=n=>n.reduce((e,t)=>(t.type==="text"&&e.push(t.value),t.type==="range"&&(t.type="text"),e),[]);Ye.flatten=(...n)=>{let e=[],t=s=>{for(let r=0;r<s.length;r++){let i=s[r];if(Array.isArray(i)){t(i);continue}i!==void 0&&e.push(i)}return e};return t(n),e}});var Qs=j((kE,Dd)=>{"use strict";var Ld=Js();Dd.exports=(n,e={})=>{let t=(s,r={})=>{let i=e.escapeInvalid&&Ld.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a="";if(s.value)return(i||o)&&Ld.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 Fd=j(($E,Nd)=>{"use strict";Nd.exports=function(n){return typeof n=="number"?n-n===0:typeof n=="string"&&n.trim()!==""?Number.isFinite?Number.isFinite(+n):isFinite(+n):!1}});var Vd=j((CE,Gd)=>{"use strict";var jd=Fd(),Qt=(n,e,t)=>{if(jd(n)===!1)throw new TypeError("toRegexRange: expected the first argument to be a number");if(e===void 0||n===e)return String(n);if(jd(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 u=Math.min(n,e),d=Math.max(n,e);if(Math.abs(u-d)===1){let g=n+"|"+e;return s.capture?`(${g})`:s.wrap===!1?g:`(?:${g})`}let f=Wd(n)||Wd(e),h={min:n,max:e,a:u,b:d},m=[],p=[];if(f&&(h.isPadded=f,h.maxLen=String(h.max).length),u<0){let g=d<0?Math.abs(d):1;p=Hd(g,Math.abs(u),h,s),u=h.a=0}return d>=0&&(m=Hd(u,d,h,s)),h.negatives=p,h.positives=m,h.result=Iv(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 Iv(n,e,t){let s=Po(n,e,"-",!1,t)||[],r=Po(e,n,"",!1,t)||[],i=Po(n,e,"-?",!0,t)||[];return s.concat(i).concat(r).join("|")}function Mv(n,e){let t=1,s=1,r=Ud(n,t),i=new Set([e]);for(;n<=r&&r<=e;)i.add(r),t+=1,r=Ud(n,t);for(r=qd(e+1,s)-1;n<r&&r<=e;)i.add(r),s+=1,r=qd(e+1,s)-1;return i=[...i],i.sort(Nv),i}function Lv(n,e,t){if(n===e)return{pattern:n,count:[],digits:0};let s=Dv(n,e),r=s.length,i="",o=0;for(let a=0;a<r;a++){let[l,u]=s[a];l===u?i+=l:l!=="0"||u!=="9"?i+=Fv(l,u,t):o++}return o&&(i+=t.shorthand===!0?"\\d":"[0-9]"),{pattern:i,count:[o],digits:r}}function Hd(n,e,t,s){let r=Mv(n,e),i=[],o=n,a;for(let l=0;l<r.length;l++){let u=r[l],d=Lv(String(o),String(u),s),f="";if(!t.isPadded&&a&&a.pattern===d.pattern){a.count.length>1&&a.count.pop(),a.count.push(d.count[0]),a.string=a.pattern+Kd(a.count),o=u+1;continue}t.isPadded&&(f=jv(u,t,s)),d.string=f+d.pattern+Kd(d.count),i.push(d),o=u+1,a=d}return i}function Po(n,e,t,s,r){let i=[];for(let o of n){let{string:a}=o;!s&&!Bd(e,"string",a)&&i.push(t+a),s&&Bd(e,"string",a)&&i.push(t+a)}return i}function Dv(n,e){let t=[];for(let s=0;s<n.length;s++)t.push([n[s],e[s]]);return t}function Nv(n,e){return n>e?1:e>n?-1:0}function Bd(n,e,t){return n.some(s=>s[e]===t)}function Ud(n,e){return Number(String(n).slice(0,-e)+"9".repeat(e))}function qd(n,e){return n-n%Math.pow(10,e)}function Kd(n){let[e=0,t=""]=n;return t||e>1?`{${e+(t?","+t:"")}}`:""}function Fv(n,e,t){return`[${n}${e-n===1?"":"-"}${e}]`}function Wd(n){return/^-?(0+)\d/.test(n)}function jv(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={};Gd.exports=Qt});var Mo=j((EE,ef)=>{"use strict";var Hv=require("util"),Yd=Vd(),zd=n=>n!==null&&typeof n=="object"&&!Array.isArray(n),Bv=n=>e=>n===!0?Number(e):String(e),Oo=n=>typeof n=="number"||typeof n=="string"&&n!=="",Qn=n=>Number.isInteger(+n),Io=n=>{let e=`${n}`,t=-1;if(e[0]==="-"&&(e=e.slice(1)),e==="0")return!1;for(;e[++t]==="0";);return t>0},Uv=(n,e,t)=>typeof n=="string"||typeof e=="string"?!0:t.stringify===!0,qv=(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},Zs=(n,e)=>{let t=n[0]==="-"?"-":"";for(t&&(n=n.slice(1),e--);n.length<e;)n="0"+n;return t?"-"+n:n},Kv=(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=>Zs(String(a),t)).join("|")),n.negatives.length&&(i=`-(${s}${n.negatives.map(a=>Zs(String(a),t)).join("|")})`),r&&i?o=`${r}|${i}`:o=r||i,e.wrap?`(${s}${o})`:o},Jd=(n,e,t,s)=>{if(t)return Yd(n,e,{wrap:!1,...s});let r=String.fromCharCode(n);if(n===e)return r;let i=String.fromCharCode(e);return`[${r}-${i}]`},Qd=(n,e,t)=>{if(Array.isArray(n)){let s=t.wrap===!0,r=t.capture?"":"?:";return s?`(${r}${n.join("|")})`:n.join("|")}return Yd(n,e,t)},Xd=(...n)=>new RangeError("Invalid range arguments: "+Hv.inspect(...n)),Zd=(n,e,t)=>{if(t.strictRanges===!0)throw Xd([n,e]);return[]},Wv=(n,e)=>{if(e.strictRanges===!0)throw new TypeError(`Expected step "${n}" to be a number`);return[]},Gv=(n,e,t=1,s={})=>{let r=Number(n),i=Number(e);if(!Number.isInteger(r)||!Number.isInteger(i)){if(s.strictRanges===!0)throw Xd([n,e]);return[]}r===0&&(r=0),i===0&&(i=0);let o=r>i,a=String(n),l=String(e),u=String(t);t=Math.max(Math.abs(t),1);let d=Io(a)||Io(l)||Io(u),f=d?Math.max(a.length,l.length,u.length):0,h=d===!1&&Uv(n,e,s)===!1,m=s.transform||Bv(h);if(s.toRegex&&t===1)return Jd(Zs(n,f),Zs(e,f),!0,s);let p={negatives:[],positives:[]},g=A=>p[A<0?"negatives":"positives"].push(Math.abs(A)),x=[],S=0;for(;o?r>=i:r<=i;)s.toRegex===!0&&t>1?g(r):x.push(qv(m(r,S),f,h)),r=o?r-t:r+t,S++;return s.toRegex===!0?t>1?Kv(p,s,f):Qd(x,null,{wrap:!1,...s}):x},Vv=(n,e,t=1,s={})=>{if(!Qn(n)&&n.length>1||!Qn(e)&&e.length>1)return Zd(n,e,s);let r=s.transform||(h=>String.fromCharCode(h)),i=`${n}`.charCodeAt(0),o=`${e}`.charCodeAt(0),a=i>o,l=Math.min(i,o),u=Math.max(i,o);if(s.toRegex&&t===1)return Jd(l,u,!1,s);let d=[],f=0;for(;a?i>=o:i<=o;)d.push(r(i,f)),i=a?i-t:i+t,f++;return s.toRegex===!0?Qd(d,null,{wrap:!1,options:s}):d},Xs=(n,e,t,s={})=>{if(e==null&&Oo(n))return[n];if(!Oo(n)||!Oo(e))return Zd(n,e,s);if(typeof t=="function")return Xs(n,e,1,{transform:t});if(zd(t))return Xs(n,e,0,t);let r={...s};return r.capture===!0&&(r.wrap=!0),t=t||r.step||1,Qn(t)?Qn(n)&&Qn(e)?Gv(n,e,t,r):Vv(n,e,Math.max(Math.abs(t),1),r):t!=null&&!zd(t)?Wv(t,r):Xs(n,e,1,t)};ef.exports=Xs});var sf=j((TE,nf)=>{"use strict";var zv=Mo(),tf=Js(),Yv=(n,e={})=>{let t=(s,r={})=>{let i=tf.isInvalidBrace(r),o=s.invalid===!0&&e.escapeInvalid===!0,a=i===!0||o===!0,l=e.escapeInvalid===!0?"\\":"",u="";if(s.isOpen===!0)return l+s.value;if(s.isClose===!0)return console.log("node.isClose",l,s.value),l+s.value;if(s.type==="open")return a?l+s.value:"(";if(s.type==="close")return a?l+s.value:")";if(s.type==="comma")return s.prev.type==="comma"?"":a?s.value:"|";if(s.value)return s.value;if(s.nodes&&s.ranges>0){let d=tf.reduce(s.nodes),f=zv(...d,{...e,wrap:!1,toRegex:!0,strictZeros:!0});if(f.length!==0)return d.length>1&&f.length>1?`(${f})`:f}if(s.nodes)for(let d of s.nodes)u+=t(d,s);return u};return t(n)};nf.exports=Yv});var af=j((RE,of)=>{"use strict";var Jv=Mo(),rf=Qs(),Sn=Js(),Xt=(n="",e="",t=!1)=>{let s=[];if(n=[].concat(n),e=[].concat(e),!e.length)return n;if(!n.length)return t?Sn.flatten(e).map(r=>`{${r}}`):e;for(let r of n)if(Array.isArray(r))for(let i of r)s.push(Xt(i,e,t));else for(let i of e)t===!0&&typeof i=="string"&&(i=`{${i}}`),s.push(Array.isArray(i)?Xt(r,i,t):r+i);return Sn.flatten(s)},Qv=(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(Xt(a.pop(),rf(r,e)));return}if(r.type==="brace"&&r.invalid!==!0&&r.nodes.length===2){a.push(Xt(a.pop(),["{}"]));return}if(r.nodes&&r.ranges>0){let f=Sn.reduce(r.nodes);if(Sn.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=Jv(...f,e);h.length===0&&(h=rf(r,e)),a.push(Xt(a.pop(),h)),r.nodes=[];return}let l=Sn.encloseBrace(r),u=r.queue,d=r;for(;d.type!=="brace"&&d.type!=="root"&&d.parent;)d=d.parent,u=d.queue;for(let f=0;f<r.nodes.length;f++){let h=r.nodes[f];if(h.type==="comma"&&r.type==="brace"){f===1&&u.push(""),u.push("");continue}if(h.type==="close"){a.push(Xt(a.pop(),u,l));continue}if(h.value&&h.type!=="open"){u.push(Xt(u.pop(),h.value));continue}h.nodes&&s(h,r)}return u};return Sn.flatten(s(n))};of.exports=Qv});var cf=j((PE,lf)=>{"use strict";lf.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:`
|
|
324
|
+
`,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 hf=j((OE,pf)=>{"use strict";var Xv=Qs(),{MAX_LENGTH:uf,CHAR_BACKSLASH:Lo,CHAR_BACKTICK:Zv,CHAR_COMMA:ew,CHAR_DOT:tw,CHAR_LEFT_PARENTHESES:nw,CHAR_RIGHT_PARENTHESES:sw,CHAR_LEFT_CURLY_BRACE:rw,CHAR_RIGHT_CURLY_BRACE:iw,CHAR_LEFT_SQUARE_BRACKET:df,CHAR_RIGHT_SQUARE_BRACKET:ff,CHAR_DOUBLE_QUOTE:ow,CHAR_SINGLE_QUOTE:aw,CHAR_NO_BREAK_SPACE:lw,CHAR_ZERO_WIDTH_NOBREAK_SPACE:cw}=cf(),uw=(n,e={})=>{if(typeof n!="string")throw new TypeError("Expected a string");let t=e||{},s=typeof t.maxLength=="number"?Math.min(uf,t.maxLength):uf;if(n.length>s)throw new SyntaxError(`Input length (${n.length}), exceeds max characters (${s})`);let r={type:"root",input:n,nodes:[]},i=[r],o=r,a=r,l=0,u=n.length,d=0,f=0,h,m=()=>n[d++],p=g=>{if(g.type==="text"&&a.type==="dot"&&(a.type="text"),a&&a.type==="text"&&g.type==="text"){a.value+=g.value;return}return o.nodes.push(g),g.parent=o,g.prev=a,a=g,g};for(p({type:"bos"});d<u;)if(o=i[i.length-1],h=m(),!(h===cw||h===lw)){if(h===Lo){p({type:"text",value:(e.keepEscaping?h:"")+m()});continue}if(h===ff){p({type:"text",value:"\\"+h});continue}if(h===df){l++;let g;for(;d<u&&(g=m());){if(h+=g,g===df){l++;continue}if(g===Lo){h+=m();continue}if(g===ff&&(l--,l===0))break}p({type:"text",value:h});continue}if(h===nw){o=p({type:"paren",nodes:[]}),i.push(o),p({type:"text",value:h});continue}if(h===sw){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===ow||h===aw||h===Zv){let g=h,x;for(e.keepQuotes!==!0&&(h="");d<u&&(x=m());){if(x===Lo){h+=x+m();continue}if(x===g){e.keepQuotes===!0&&(h+=x);break}h+=x}p({type:"text",value:h});continue}if(h===rw){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===iw){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===ew&&f>0){if(o.ranges>0){o.ranges=0;let g=o.nodes.shift();o.nodes=[g,{type:"text",value:Xv(o)}]}p({type:"comma",value:h}),o.commas++;continue}if(h===tw&&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};pf.exports=uw});var yf=j((IE,gf)=>{"use strict";var mf=Qs(),dw=sf(),fw=af(),pw=hf(),Ue=(n,e={})=>{let t=[];if(Array.isArray(n))for(let s of n){let r=Ue.create(s,e);Array.isArray(r)?t.push(...r):t.push(r)}else t=[].concat(Ue.create(n,e));return e&&e.expand===!0&&e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.parse=(n,e={})=>pw(n,e);Ue.stringify=(n,e={})=>mf(typeof n=="string"?Ue.parse(n,e):n,e);Ue.compile=(n,e={})=>(typeof n=="string"&&(n=Ue.parse(n,e)),dw(n,e));Ue.expand=(n,e={})=>{typeof n=="string"&&(n=Ue.parse(n,e));let t=fw(n,e);return e.noempty===!0&&(t=t.filter(Boolean)),e.nodupes===!0&&(t=[...new Set(t)]),t};Ue.create=(n,e={})=>n===""||n.length<3?[n]:e.expand!==!0?Ue.compile(n,e):Ue.expand(n,e);gf.exports=Ue});var bf=j((ME,hw)=>{hw.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 wf=j((LE,vf)=>{vf.exports=bf()});var Sf=j((DE,xf)=>{"use strict";var mw=require("path"),gw=wf(),yw=new Set(gw);xf.exports=n=>yw.has(mw.extname(n).slice(1).toLowerCase())});var er=j(q=>{"use strict";var{sep:bw}=require("path"),{platform:Do}=process,vw=require("os");q.EV_ALL="all";q.EV_READY="ready";q.EV_ADD="add";q.EV_CHANGE="change";q.EV_ADD_DIR="addDir";q.EV_UNLINK="unlink";q.EV_UNLINK_DIR="unlinkDir";q.EV_RAW="raw";q.EV_ERROR="error";q.STR_DATA="data";q.STR_END="end";q.STR_CLOSE="close";q.FSEVENT_CREATED="created";q.FSEVENT_MODIFIED="modified";q.FSEVENT_DELETED="deleted";q.FSEVENT_MOVED="moved";q.FSEVENT_CLONED="cloned";q.FSEVENT_UNKNOWN="unknown";q.FSEVENT_FLAG_MUST_SCAN_SUBDIRS=1;q.FSEVENT_TYPE_FILE="file";q.FSEVENT_TYPE_DIRECTORY="directory";q.FSEVENT_TYPE_SYMLINK="symlink";q.KEY_LISTENERS="listeners";q.KEY_ERR="errHandlers";q.KEY_RAW="rawEmitters";q.HANDLER_KEYS=[q.KEY_LISTENERS,q.KEY_ERR,q.KEY_RAW];q.DOT_SLASH=`.${bw}`;q.BACK_SLASH_RE=/\\/g;q.DOUBLE_SLASH_RE=/\/\//;q.SLASH_OR_BACK_SLASH_RE=/[/\\]/;q.DOT_RE=/\..*\.(sw[px])$|~$|\.subl.*\.tmp/;q.REPLACER_RE=/^\.[/\\]/;q.SLASH="/";q.SLASH_SLASH="//";q.BRACE_START="{";q.BANG="!";q.ONE_DOT=".";q.TWO_DOTS="..";q.STAR="*";q.GLOBSTAR="**";q.ROOT_GLOBSTAR="/**/*";q.SLASH_GLOBSTAR="/**";q.DIR_SUFFIX="Dir";q.ANYMATCH_OPTS={dot:!0};q.STRING_TYPE="string";q.FUNCTION_TYPE="function";q.EMPTY_STR="";q.EMPTY_FN=()=>{};q.IDENTITY_FN=n=>n;q.isWindows=Do==="win32";q.isMacos=Do==="darwin";q.isLinux=Do==="linux";q.isIBMi=vw.type()==="OS400"});var Ef=j((FE,Cf)=>{"use strict";var Rt=require("fs"),Se=require("path"),{promisify:ts}=require("util"),ww=Sf(),{isWindows:xw,isLinux:Sw,EMPTY_FN:_w,EMPTY_STR:Aw,KEY_LISTENERS:_n,KEY_ERR:No,KEY_RAW:Xn,HANDLER_KEYS:kw,EV_CHANGE:nr,EV_ADD:tr,EV_ADD_DIR:$w,EV_ERROR:Af,STR_DATA:Cw,STR_END:Ew,BRACE_START:Tw,STAR:Rw}=er(),Pw="watch",Ow=ts(Rt.open),kf=ts(Rt.stat),Iw=ts(Rt.lstat),Mw=ts(Rt.close),Fo=ts(Rt.realpath),Lw={lstat:Iw,stat:kf},Ho=(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)},Dw=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]},$f=n=>n instanceof Set?n.size===0:!n,sr=new Map;function _f(n,e,t,s,r){let i=(o,a)=>{t(n),r(o,a,{watchedPath:n}),a&&n!==a&&rr(Se.resolve(n,a),_n,Se.join(n,a))};try{return Rt.watch(n,e,i)}catch(o){s(o)}}var rr=(n,e,t,s,r)=>{let i=sr.get(n);i&&Ho(i[e],o=>{o(t,s,r)})},Nw=(n,e,t,s)=>{let{listener:r,errHandler:i,rawEmitter:o}=s,a=sr.get(e),l;if(!t.persistent)return l=_f(n,t,r,i,o),l.close.bind(l);if(a)Zn(a,_n,r),Zn(a,No,i),Zn(a,Xn,o);else{if(l=_f(n,t,rr.bind(null,e,_n),i,rr.bind(null,e,Xn)),!l)return;l.on(Af,async u=>{let d=rr.bind(null,e,No);if(a.watcherUnusable=!0,xw&&u.code==="EPERM")try{let f=await Ow(n,"r");await Mw(f),d(u)}catch{}else d(u)}),a={listeners:r,errHandlers:i,rawEmitters:o,watcher:l},sr.set(e,a)}return()=>{es(a,_n,r),es(a,No,i),es(a,Xn,o),$f(a.listeners)&&(a.watcher.close(),sr.delete(e),kw.forEach(Dw(a)),a.watcher=void 0,Object.freeze(a))}},jo=new Map,Fw=(n,e,t,s)=>{let{listener:r,rawEmitter:i}=s,o=jo.get(e),a=new Set,l=new Set,u=o&&o.options;return u&&(u.persistent<t.persistent||u.interval>t.interval)&&(a=o.listeners,l=o.rawEmitters,Rt.unwatchFile(e),o=void 0),o?(Zn(o,_n,r),Zn(o,Xn,i)):(o={listeners:r,rawEmitters:i,options:t,watcher:Rt.watchFile(e,t,(d,f)=>{Ho(o.rawEmitters,m=>{m(nr,e,{curr:d,prev:f})});let h=d.mtimeMs;(d.size!==f.size||h>f.mtimeMs||h===0)&&Ho(o.listeners,m=>m(n,d))})},jo.set(e,o)),()=>{es(o,_n,r),es(o,Xn,i),$f(o.listeners)&&(jo.delete(e),Rt.unwatchFile(e),o.options=o.watcher=void 0,Object.freeze(o))}},Bo=class{constructor(e){this.fsw=e,this._boundHandleError=t=>e._handleError(t)}_watchWithNodeFs(e,t){let s=this.fsw.options,r=Se.dirname(e),i=Se.basename(e);this.fsw._getWatchedDir(r).add(i);let a=Se.resolve(e),l={persistent:s.persistent};t||(t=_w);let u;return s.usePolling?(l.interval=s.enableBinaryInterval&&ww(i)?s.binaryInterval:s.interval,u=Fw(e,a,l,{listener:t,rawEmitter:this.fsw._emitRaw})):u=Nw(e,a,l,{listener:t,errHandler:this._boundHandleError,rawEmitter:this.fsw._emitRaw}),u}_handleFile(e,t,s){if(this.fsw.closed)return;let r=Se.dirname(e),i=Se.basename(e),o=this.fsw._getWatchedDir(r),a=t;if(o.has(i))return;let l=async(d,f)=>{if(this.fsw._throttle(Pw,e,5)){if(!f||f.mtimeMs===0)try{let h=await kf(e);if(this.fsw.closed)return;let m=h.atimeMs,p=h.mtimeMs;(!m||m<=p||p!==a.mtimeMs)&&this.fsw._emit(nr,e,h),Sw&&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(nr,e,f),a=f}}},u=this._watchWithNodeFs(e,l);if(!(s&&this.fsw.options.ignoreInitial)&&this.fsw._isntIgnored(e)){if(!this.fsw._throttle(tr,e,0))return;this.fsw._emit(tr,e,t)}return u}async _handleSymlink(e,t,s,r){if(this.fsw.closed)return;let i=e.fullPath,o=this.fsw._getWatchedDir(t);if(!this.fsw.options.followSymlinks){this.fsw._incrReadyCount();let a;try{a=await Fo(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(nr,s,e.stats)):(o.add(r),this.fsw._symlinkPaths.set(i,a),this.fsw._emit(tr,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=Se.join(e,Aw),!s.hasGlob&&(a=this.fsw._throttle("readdir",e,1e3),!a))return;let l=this.fsw._getWatchedDir(s.path),u=new Set,d=this.fsw._readdirp(e,{fileFilter:f=>s.filterPath(f),directoryFilter:f=>s.filterDir(f),depth:0}).on(Cw,async f=>{if(this.fsw.closed){d=void 0;return}let h=f.path,m=Se.join(e,h);if(u.add(h),!(f.stats.isSymbolicLink()&&await this._handleSymlink(f,e,m,h))){if(this.fsw.closed){d=void 0;return}(h===r||!r&&!l.has(h))&&(this.fsw._incrReadyCount(),m=Se.join(i,Se.relative(i,m)),this._addToNodeFs(m,t,s,o+1))}}).on(Af,this._boundHandleError);return new Promise(f=>d.once(Ew,()=>{if(this.fsw.closed){d=void 0;return}let h=a?a.clear():!1;f(),l.getChildren().filter(m=>m!==e&&!u.has(m)&&(!s.hasGlob||s.filterPath({fullPath:Se.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(Se.dirname(e)),u=l.has(Se.basename(e));!(s&&this.fsw.options.ignoreInitial)&&!i&&!u&&(!o.hasGlob||o.globFilter(e))&&this.fsw._emit($w,e,t),l.add(Se.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 Lw[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))return o(),!1;let u=this.fsw.options.followSymlinks&&!e.includes(Rw)&&!e.includes(Tw),d;if(l.isDirectory()){let f=Se.resolve(e),h=u?await Fo(e):e;if(this.fsw.closed||(d=await this._handleDir(a.watchPath,l,t,r,i,a,h),this.fsw.closed))return;f!==h&&h!==void 0&&this.fsw._symlinkPaths.set(f,h)}else if(l.isSymbolicLink()){let f=u?await Fo(e):e;if(this.fsw.closed)return;let h=Se.dirname(a.watchPath);if(this.fsw._getWatchedDir(h).add(a.watchPath),this.fsw._emit(tr,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(Se.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}}};Cf.exports=Bo});var Lf=j((jE,Yo)=>{"use strict";var Vo=require("fs"),_e=require("path"),{promisify:zo}=require("util"),An;try{An=require("fsevents")}catch(n){process.env.CHOKIDAR_PRINT_FSEVENTS_REQUIRE_ERROR&&console.error(n)}if(An){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&&(An=void 0)}}var{EV_ADD:Uo,EV_CHANGE:jw,EV_ADD_DIR:Tf,EV_UNLINK:ir,EV_ERROR:Hw,STR_DATA:Bw,STR_END:Uw,FSEVENT_CREATED:qw,FSEVENT_MODIFIED:Kw,FSEVENT_DELETED:Ww,FSEVENT_MOVED:Gw,FSEVENT_UNKNOWN:Vw,FSEVENT_FLAG_MUST_SCAN_SUBDIRS:zw,FSEVENT_TYPE_FILE:Yw,FSEVENT_TYPE_DIRECTORY:ns,FSEVENT_TYPE_SYMLINK:Mf,ROOT_GLOBSTAR:Rf,DIR_SUFFIX:Jw,DOT_SLASH:Pf,FUNCTION_TYPE:qo,EMPTY_FN:Qw,IDENTITY_FN:Xw}=er(),Zw=n=>isNaN(n)?{}:{depth:n},Wo=zo(Vo.stat),ex=zo(Vo.lstat),Of=zo(Vo.realpath),tx={stat:Wo,lstat:ex},Zt=new Map,nx=10,sx=new Set([69888,70400,71424,72704,73472,131328,131840,262912]),rx=(n,e)=>({stop:An.watch(n,e)});function ix(n,e,t,s){let r=_e.extname(e)?_e.dirname(e):e,i=_e.dirname(r),o=Zt.get(r);ox(i)&&(r=i);let a=_e.resolve(n),l=a!==e,u=(f,h,m)=>{l&&(f=f.replace(e,a)),(f===a||!f.indexOf(a+_e.sep))&&t(f,h,m)},d=!1;for(let f of Zt.keys())if(e.indexOf(_e.resolve(f)+_e.sep)===0){r=f,o=Zt.get(r),d=!0;break}return o||d?o.listeners.add(u):(o={listeners:new Set([u]),rawEmitter:s,watcher:rx(r,(f,h)=>{if(!o.listeners.size||h&zw)return;let m=An.getInfo(f,h);o.listeners.forEach(p=>{p(f,h,m)}),o.rawEmitter(m.event,f,m)})},Zt.set(r,o)),()=>{let f=o.listeners;if(f.delete(u),!f.size&&(Zt.delete(r),o.watcher))return o.watcher.stop().then(()=>{o.rawEmitter=o.watcher=void 0,Object.freeze(o)})}}var ox=n=>{let e=0;for(let t of Zt.keys())if(t.indexOf(n)===0&&(e++,e>=nx))return!0;return!1},ax=()=>An&&Zt.size<128,Ko=(n,e)=>{let t=0;for(;!n.indexOf(e)&&(n=_e.dirname(n))!==e;)t++;return t},If=(n,e)=>n.type===ns&&e.isDirectory()||n.type===Mf&&e.isSymbolicLink()||n.type===Yw&&e.isFile(),Go=class{constructor(e){this.fsw=e}checkIgnored(e,t){let s=this.fsw._ignoredPaths;if(this.fsw._isIgnored(e,t))return s.add(e),t&&t.isDirectory()&&s.add(e+Rf),!0;s.delete(e),s.delete(e+Rf)}addOrChange(e,t,s,r,i,o,a,l){let u=i.has(o)?jw:Uo;this.handleEvent(u,e,t,s,r,i,o,a,l)}async checkExists(e,t,s,r,i,o,a,l){try{let u=await Wo(e);if(this.fsw.closed)return;If(a,u)?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(ir,e,t,s,r,i,o,a,l)}catch(u){u.code==="EACCES"?this.addOrChange(e,t,s,r,i,o,a,l):this.handleEvent(ir,e,t,s,r,i,o,a,l)}}handleEvent(e,t,s,r,i,o,a,l,u){if(!(this.fsw.closed||this.checkIgnored(t)))if(e===ir){let d=l.type===ns;(d||o.has(a))&&this.fsw._remove(i,a,d)}else{if(e===Uo){if(l.type===ns&&this.fsw._getWatchedDir(t),l.type===Mf&&u.followSymlinks){let f=u.depth===void 0?void 0:Ko(s,r)+1;return this._addToFsEvents(t,!1,!0,f)}this.fsw._getWatchedDir(i).add(a)}let d=l.type===ns?e+Jw:e;this.fsw._emit(d,t),d===Tf&&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=ix(e,t,async(l,u,d)=>{if(this.fsw.closed||i.depth!==void 0&&Ko(l,t)>i.depth)return;let f=s(_e.join(e,_e.relative(e,l)));if(r&&!r(f))return;let h=_e.dirname(f),m=_e.basename(f),p=this.fsw._getWatchedDir(d.type===ns?f:h);if(sx.has(u)||d.event===Vw)if(typeof i.ignored===qo){let g;try{g=await Wo(f)}catch{}if(this.fsw.closed||this.checkIgnored(f,g))return;If(d,g)?this.addOrChange(f,l,t,h,p,m,d,i):this.handleEvent(ir,f,l,t,h,p,m,d,i)}else this.checkExists(f,l,t,h,p,m,d,i);else switch(d.event){case qw:case Kw:return this.addOrChange(f,l,t,h,p,m,d,i);case Ww:case Gw: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 Of(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!==Pf?a=o.replace(i,e):o!==Pf&&(a=_e.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(_e.dirname(o)),u=_e.basename(o);a&&this.fsw._getWatchedDir(o),!l.has(u)&&(l.add(u),(!r.ignoreInitial||i===!0)&&this.fsw._emit(a?Tf:Uo,o,t))}initWatch(e,t,s,r){if(this.fsw.closed)return;let i=this._watchWithFsEvents(s.watchPath,_e.resolve(e||s.watchPath),r,s.globFilter);this.fsw._addPathCloser(t,i)}async _addToFsEvents(e,t,s,r){if(this.fsw.closed)return;let i=this.fsw.options,o=typeof t===qo?t:Xw,a=this.fsw._getWatchHelpers(e);try{let l=await tx[a.statMethod](a.watchPath);if(this.fsw.closed)return;if(this.fsw._isIgnored(a.watchPath,l))throw null;if(l.isDirectory()){if(a.globFilter||this.emitAdd(o(e),l,o,i,s),r&&r>i.depth)return;this.fsw._readdirp(a.watchPath,{fileFilter:u=>a.filterPath(u),directoryFilter:u=>a.filterDir(u),...Zw(i.depth-(r||0))}).on(Bw,u=>{if(this.fsw.closed||u.stats.isDirectory()&&!a.filterPath(u))return;let d=_e.join(a.watchPath,u.path),{fullPath:f}=u;if(a.followSymlinks&&u.stats.isSymbolicLink()){let h=i.depth===void 0?void 0:Ko(d,_e.resolve(a.watchPath))+1;this._handleFsEventsSymlink(d,f,o,h)}else this.emitAdd(d,u.stats,o,i,s)}).on(Hw,Qw).on(Uw,()=>{this.fsw._emitReady()})}else this.emitAdd(a.watchPath,l,o,i,s),this.fsw._emitReady()}catch(l){(!l||this.fsw._handleError(l))&&(this.fsw._emitReady(),this.fsw._emitReady())}if(i.persistent&&s!==!0)if(typeof t===qo)this.initWatch(void 0,e,a,o);else{let l;try{l=await Of(a.watchPath)}catch{}this.initWatch(l,e,a,o)}}};Yo.exports=Go;Yo.exports.canUse=ax});var Gf=j(ua=>{"use strict";var{EventEmitter:lx}=require("events"),la=require("fs"),re=require("path"),{promisify:Uf}=require("util"),cx=xd(),ta=Ed().default,ux=Md(),Jo=To(),dx=yf(),fx=Co(),px=Ef(),Df=Lf(),{EV_ALL:Qo,EV_READY:hx,EV_ADD:or,EV_CHANGE:ss,EV_UNLINK:Nf,EV_ADD_DIR:mx,EV_UNLINK_DIR:gx,EV_RAW:yx,EV_ERROR:Xo,STR_CLOSE:bx,STR_END:vx,BACK_SLASH_RE:wx,DOUBLE_SLASH_RE:Ff,SLASH_OR_BACK_SLASH_RE:xx,DOT_RE:Sx,REPLACER_RE:_x,SLASH:Zo,SLASH_SLASH:Ax,BRACE_START:kx,BANG:na,ONE_DOT:qf,TWO_DOTS:$x,GLOBSTAR:Cx,SLASH_GLOBSTAR:ea,ANYMATCH_OPTS:sa,STRING_TYPE:ca,FUNCTION_TYPE:Ex,EMPTY_STR:ra,EMPTY_FN:Tx,isWindows:Rx,isMacos:Px,isIBMi:Ox}=er(),Ix=Uf(la.stat),Mx=Uf(la.readdir),ia=(n=[])=>Array.isArray(n)?n:[n],Kf=(n,e=[])=>(n.forEach(t=>{Array.isArray(t)?Kf(t,e):e.push(t)}),e),jf=n=>{let e=Kf(ia(n));if(!e.every(t=>typeof t===ca))throw new TypeError(`Non-string provided as watch path: ${e}`);return e.map(Wf)},Hf=n=>{let e=n.replace(wx,Zo),t=!1;for(e.startsWith(Ax)&&(t=!0);e.match(Ff);)e=e.replace(Ff,Zo);return t&&(e=Zo+e),e},Wf=n=>Hf(re.normalize(Hf(n))),Bf=(n=ra)=>e=>typeof e!==ca?e:Wf(re.isAbsolute(e)?e:re.join(n,e)),Lx=(n,e)=>re.isAbsolute(n)?n:n.startsWith(na)?na+re.join(e,n.slice(1)):re.join(e,n),it=(n,e)=>n[e]===void 0,oa=class{constructor(e,t){this.path=e,this._removeWatcher=t,this.items=new Set}add(e){let{items:t}=this;t&&e!==qf&&e!==$x&&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 Mx(s)}catch{this._removeWatcher&&this._removeWatcher(re.dirname(s),re.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)}},Dx="stat",Nx="lstat",aa=class{constructor(e,t,s,r){this.fsw=r,this.path=e=e.replace(_x,ra),this.watchPath=t,this.fullWatchPath=re.resolve(t),this.hasGlob=t!==e,e===ra&&(this.hasGlob=!1),this.globSymlink=this.hasGlob&&s?void 0:!1,this.globFilter=this.hasGlob?ta(e,void 0,sa):!1,this.dirParts=this.getDirParts(e),this.dirParts.forEach(i=>{i.length>1&&i.pop()}),this.followSymlinks=s,this.statMethod=s?Dx:Nx}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 re.join(this.watchPath,re.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===Ex?this.globFilter(s):!0)&&this.fsw._isntIgnored(s,t)&&this.fsw._hasReadPermissions(t)}getDirParts(e){if(!this.hasGlob)return[];let t=[];return(e.includes(kx)?dx.expand(e):[e]).forEach(r=>{t.push(re.relative(this.watchPath,r).split(xx))}),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===Cx&&(s=!0),s||!t[0][o]||ta(i,t[0][o],sa))))}return!this.unmatchedGlob&&this.fsw._isntIgnored(this.entryPath(e),e.stats)}},ar=class extends lx{constructor(e){super();let t={};e&&Object.assign(t,e),this._watched=new Map,this._closers=new Map,this._ignoredPaths=new Set,this._throttled=new Map,this._symlinkPaths=new Map,this._streams=new Set,this.closed=!1,it(t,"persistent")&&(t.persistent=!0),it(t,"ignoreInitial")&&(t.ignoreInitial=!1),it(t,"ignorePermissionErrors")&&(t.ignorePermissionErrors=!1),it(t,"interval")&&(t.interval=100),it(t,"binaryInterval")&&(t.binaryInterval=300),it(t,"disableGlobbing")&&(t.disableGlobbing=!1),t.enableBinaryInterval=t.binaryInterval!==t.interval,it(t,"useFsEvents")&&(t.useFsEvents=!t.usePolling),Df.canUse()||(t.useFsEvents=!1),it(t,"usePolling")&&!t.useFsEvents&&(t.usePolling=Px),Ox&&(t.usePolling=!0);let r=process.env.CHOKIDAR_USEPOLLING;if(r!==void 0){let l=r.toLowerCase();l==="false"||l==="0"?t.usePolling=!1:l==="true"||l==="1"?t.usePolling=!0:t.usePolling=!!l}let i=process.env.CHOKIDAR_INTERVAL;i&&(t.interval=Number.parseInt(i,10)),it(t,"atomic")&&(t.atomic=!t.usePolling&&!t.useFsEvents),t.atomic&&(this._pendingUnlinks=new Map),it(t,"followSymlinks")&&(t.followSymlinks=!0),it(t,"awaitWriteFinish")&&(t.awaitWriteFinish=!1),t.awaitWriteFinish===!0&&(t.awaitWriteFinish={});let o=t.awaitWriteFinish;o&&(o.stabilityThreshold||(o.stabilityThreshold=2e3),o.pollInterval||(o.pollInterval=100),this._pendingWrites=new Map),t.ignored&&(t.ignored=ia(t.ignored));let a=0;this._emitReady=()=>{a++,a>=this._readyCount&&(this._emitReady=Tx,this._readyEmitted=!0,process.nextTick(()=>this.emit(hx)))},this._emitRaw=(...l)=>this.emit(yx,...l),this._readyEmitted=!1,this.options=t,t.useFsEvents?this._fsEventsHandler=new Df(this):this._nodeFsHandler=new px(this),Object.freeze(t)}add(e,t,s){let{cwd:r,disableGlobbing:i}=this.options;this.closed=!1;let o=jf(e);return r&&(o=o.map(a=>{let l=Lx(a,r);return i||!Jo(a)?l:fx(l)})),o=o.filter(a=>a.startsWith(na)?(this._ignoredPaths.add(a.slice(1)),!1):(this._ignoredPaths.delete(a),this._ignoredPaths.delete(a+ea),this._userIgnored=void 0,!0)),this.options.useFsEvents&&this._fsEventsHandler?(this._readyCount||(this._readyCount=o.length),this.options.persistent&&(this._readyCount+=o.length),o.forEach(a=>this._fsEventsHandler._addToFsEvents(a))):(this._readyCount||(this._readyCount=0),this._readyCount+=o.length,Promise.all(o.map(async a=>{let l=await this._nodeFsHandler._addToNodeFs(a,!s,0,0,t);return l&&this._emitReady(),l})).then(a=>{this.closed||a.filter(l=>l).forEach(l=>{this.add(re.dirname(l),re.basename(t||l))})})),this}unwatch(e){if(this.closed)return this;let t=jf(e),{cwd:s}=this.options;return t.forEach(r=>{!re.isAbsolute(r)&&!this._closers.has(r)&&(s&&(r=re.join(s,r)),r=re.resolve(r)),this._closePath(r),this._ignoredPaths.add(r),this._watched.has(r)&&this._ignoredPaths.add(r+ea),this._userIgnored=void 0}),this}close(){if(this.closed)return this._closePromise;this.closed=!0,this.removeAllListeners();let e=[];return this._closers.forEach(t=>t.forEach(s=>{let r=s();r instanceof Promise&&e.push(r)})),this._streams.forEach(t=>t.destroy()),this._userIgnored=void 0,this._readyCount=0,this._readyEmitted=!1,this._watched.forEach(t=>t.dispose()),["closers","watched","streams","symlinkPaths","throttled"].forEach(t=>{this[`_${t}`].clear()}),this._closePromise=e.length?Promise.all(e).then(()=>{}):Promise.resolve(),this._closePromise}getWatched(){let e={};return this._watched.forEach((t,s)=>{let r=this.options.cwd?re.relative(this.options.cwd,s):s;e[r||qf]=t.getChildren().sort()}),e}emitWithAll(e,t){this.emit(...t),e!==Xo&&this.emit(Qo,...t)}async _emit(e,t,s,r,i){if(this.closed)return;let o=this.options;Rx&&(t=re.normalize(t)),o.cwd&&(t=re.relative(o.cwd,t));let a=[e,t];i!==void 0?a.push(s,r,i):r!==void 0?a.push(s,r):s!==void 0&&a.push(s);let l=o.awaitWriteFinish,u;if(l&&(u=this._pendingWrites.get(t)))return u.lastChange=new Date,this;if(o.atomic){if(e===Nf)return this._pendingUnlinks.set(t,a),setTimeout(()=>{this._pendingUnlinks.forEach((d,f)=>{this.emit(...d),this.emit(Qo,...d),this._pendingUnlinks.delete(f)})},typeof o.atomic=="number"?o.atomic:100),this;e===or&&this._pendingUnlinks.has(t)&&(e=a[0]=ss,this._pendingUnlinks.delete(t))}if(l&&(e===or||e===ss)&&this._readyEmitted){let d=(f,h)=>{f?(e=a[0]=Xo,a[1]=f,this.emitWithAll(e,a)):h&&(a.length>2?a[2]=h:a.push(h),this.emitWithAll(e,a))};return this._awaitWriteFinish(t,l.stabilityThreshold,e,d),this}if(e===ss&&!this._throttle(ss,t,50))return this;if(o.alwaysStat&&s===void 0&&(e===or||e===mx||e===ss)){let d=o.cwd?re.join(o.cwd,t):t,f;try{f=await Ix(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(Xo,e),e||this.closed}_throttle(e,t,s){this._throttled.has(e)||this._throttled.set(e,new Map);let r=this._throttled.get(e),i=r.get(t);if(i)return i.count++,!1;let o,a=()=>{let u=r.get(t),d=u?u.count:0;return r.delete(t),clearTimeout(o),u&&clearTimeout(u.timeoutObject),d};o=setTimeout(a,s);let l={timeoutObject:o,clear:a,count:0};return r.set(t,l),l}_incrReadyCount(){return this._readyCount++}_awaitWriteFinish(e,t,s,r){let i,o=e;this.options.cwd&&!re.isAbsolute(e)&&(o=re.join(this.options.cwd,e));let a=new Date,l=u=>{la.stat(o,(d,f)=>{if(d||!this._pendingWrites.has(e)){d&&d.code!=="ENOENT"&&r(d);return}let h=Number(new Date);u&&f.size!==u.size&&(this._pendingWrites.get(e).lastChange=h);let m=this._pendingWrites.get(e);h-m.lastChange>=t?(this._pendingWrites.delete(e),r(void 0,f)):i=setTimeout(l,this.options.awaitWriteFinish.pollInterval,f)})};this._pendingWrites.has(e)||(this._pendingWrites.set(e,{lastChange:a,cancelWait:()=>(this._pendingWrites.delete(e),clearTimeout(i),s)}),i=setTimeout(l,this.options.awaitWriteFinish.pollInterval))}_getGlobIgnored(){return[...this._ignoredPaths.values()]}_isIgnored(e,t){if(this.options.atomic&&Sx.test(e))return!0;if(!this._userIgnored){let{cwd:s}=this.options,r=this.options.ignored,i=r&&r.map(Bf(s)),o=ia(i).filter(l=>typeof l===ca&&!Jo(l)).map(l=>l+ea),a=this._getGlobIgnored().map(Bf(s)).concat(i,o);this._userIgnored=ta(a,void 0,sa)}return this._userIgnored([e,t])}_isntIgnored(e,t){return!this._isIgnored(e,t)}_getWatchHelpers(e,t){let s=t||this.options.disableGlobbing||!Jo(e)?e:ux(e),r=this.options.followSymlinks;return new aa(e,s,r,this)}_getWatchedDir(e){this._boundRemove||(this._boundRemove=this._remove.bind(this));let t=re.resolve(e);return this._watched.has(t)||this._watched.set(t,new oa(t,this._boundRemove)),this._watched.get(t)}_hasReadPermissions(e){if(this.options.ignorePermissionErrors)return!0;let s=(e&&Number.parseInt(e.mode,10))&511;return!!(4&Number.parseInt(s.toString(8)[0],10))}_remove(e,t,s){let r=re.join(e,t),i=re.resolve(r);if(s=s??(this._watched.has(r)||this._watched.has(i)),!this._throttle("remove",r,100))return;!s&&!this.options.useFsEvents&&this._watched.size===1&&this.add(e,t,!0),this._getWatchedDir(r).getChildren().forEach(h=>this._remove(r,h));let l=this._getWatchedDir(e),u=l.has(t);l.remove(t),this._symlinkPaths.has(i)&&this._symlinkPaths.delete(i);let d=r;if(this.options.cwd&&(d=re.relative(this.options.cwd,r)),this.options.awaitWriteFinish&&this._pendingWrites.has(d)&&this._pendingWrites.get(d).cancelWait()===or)return;this._watched.delete(r),this._watched.delete(i);let f=s?gx:Nf;u&&!this._isIgnored(r)&&this._emit(f,r),this.options.useFsEvents||this._closePath(r)}_closePath(e){this._closeFile(e);let t=re.dirname(e);this._getWatchedDir(t).remove(re.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:Qo,alwaysStat:!0,lstat:!0,...t},r=cx(e,s);return this._streams.add(r),r.once(bx,()=>{r=void 0}),r.once(vx,()=>{r&&(this._streams.delete(r),r=void 0)}),r}};ua.FSWatcher=ar;var Fx=(n,e)=>{let t=new ar(e);return t.add(n),t};ua.watch=Fx});var Jf={};Ne(Jf,{CollaborationManager:()=>rs,addTeamMember:()=>Bx,formatTeamConfig:()=>Ux,initTeamConfig:()=>Hx,loadTeamConfig:()=>jx,saveTeamConfig:()=>Yf});function jx(n){let e=Je.join(n,".hablas","team.json");if(ve.existsSync(e))try{return JSON.parse(ve.readFileSync(e,"utf-8"))}catch{return null}return null}function Hx(n,e){let t={name:e,members:[]};return Yf(n,t),t}function Yf(n,e){let t=Je.join(n,".hablas","team.json"),s=Je.dirname(t);ve.existsSync(s)||ve.mkdirSync(s,{recursive:!0}),ve.writeFileSync(t,JSON.stringify(e,null,2),"utf-8")}function Bx(n,e,t){return n.members.push({name:e,email:t}),n}function Ux(n){return[`Team: ${n.name}`,"Members:",...n.members.map(t=>` - ${t.name} (${t.email})`)].join(`
|
|
325
|
+
`)}var ve,Je,lr,Vf,zf,rs,da=N(()=>{"use strict";ve=O(require("fs")),Je=O(require("path")),lr=O(require("os")),Vf=O(require("crypto")),zf=O(Gf());vn();rs=class n{workingDir;config;username;teamKey;projectTeamToken;supabaseUrl="";supabaseKey="";isConfigured=!1;watcher=null;localStatePath;heartbeatInterval=null;syncInterval=null;static HEARTBEAT_MS=12e3;static POLL_ACTIVE_MS=3e3;static POLL_IDLE_MS=2e4;static STALE_MS=75e3;consecutiveHeartbeatFailures=0;announcedOffline=!1;idlePollTicks=0;signalHandler=null;shuttingDown=!1;currentActivity={section:"idle",task:"standby"};knownSessions=new Map;knownLocks=new Map;constructor(e,t,s,r){this.workingDir=e,this.config=t,this.username=s||lr.userInfo().username||"developer",this.teamKey=r||"default-team",this.localStatePath=Je.join(this.workingDir,".hablas","collaboration.json");let i=this.getProjectIdentifier();console.log(`
|
|
326
|
+
${c.muted("[Debug] Project Context:")} ${c.highlight(i)}`),this.projectTeamToken=Vf.createHash("sha256").update(`${i}:${this.teamKey}`).digest("hex"),console.log(` ${c.muted("[Debug] Session Fingerprint:")} ${c.muted(this.projectTeamToken.slice(0,16))}...
|
|
327
327
|
`),this.loadSupabaseConfig()}async init(){if(!this.isConfigured)return console.log(` ${c.warning("\u26A0")} ${c.secondary("Supabase is not configured in .env. Collaboration mode operates locally.")}`),!1;let e=Je.dirname(this.localStatePath);return ve.existsSync(e)||ve.mkdirSync(e,{recursive:!0}),this.saveLocalState([],[]),this.startLoops(),this.startWatcher(),this.registerCleanups(),!0}async shutdown(){this.shuttingDown||(this.shuttingDown=!0,this.heartbeatInterval&&(clearInterval(this.heartbeatInterval),this.heartbeatInterval=null),this.syncInterval&&(clearTimeout(this.syncInterval),this.syncInterval=null),this.watcher&&(await this.watcher.close(),this.watcher=null),this.signalHandler&&(process.off("SIGINT",this.signalHandler),process.off("SIGTERM",this.signalHandler),this.signalHandler=null),await this.releaseAllMyLocks(),await this.deleteSession())}async apiRequest(e,t,s,r){if(!this.isConfigured)return{ok:!1,data:null};let i=`${this.supabaseUrl}/rest/v1/${e}`,o={apikey:this.supabaseKey,Authorization:`Bearer ${this.supabaseKey}`,"Content-Type":"application/json"};r?.prefer?o.Prefer=r.prefer:(t==="POST"||t==="PATCH")&&(o.Prefer="return=representation");let a=(r?.retries??0)+1,l=null;for(let u=0;u<a;u++)try{let d=await fetch(i,{method:t,headers:o,body:s?JSON.stringify(s):void 0,signal:AbortSignal.timeout(1e4)});if(!d.ok){let h=await d.text().catch(()=>"");if(l=new Error(`[Supabase ${d.status}] ${h}`),(d.status>=500||d.status===429)&&u<a-1){await this.delay(400*(u+1));continue}return{ok:!1,data:null}}let f=await d.text();return{ok:!0,data:f?JSON.parse(f):null}}catch(d){if(l=d,u<a-1){await this.delay(400*(u+1));continue}}return{ok:!1,data:null}}delay(e){return new Promise(t=>setTimeout(t,e))}async sendHeartbeat(e,t){let s={project_team_token:this.projectTeamToken,developer_name:this.username,last_heartbeat:new Date().toISOString(),active_section:e||"idle",current_task:t||"none"},r="hablas_team_sessions?on_conflict=project_team_token,developer_name",{ok:i}=await this.apiRequest(r,"POST",s,{prefer:"resolution=merge-duplicates,return=minimal",retries:2});return i}async fetchSessions(){let e=`hablas_team_sessions?project_team_token=eq.${this.projectTeamToken}`,{data:t}=await this.apiRequest(e,"GET");return t||[]}async deleteSession(){let e=`hablas_team_sessions?project_team_token=eq.${this.projectTeamToken}&developer_name=eq.${encodeURIComponent(this.username)}`;await this.apiRequest(e,"DELETE")}async fetchLocks(){let e=`hablas_team_locks?project_team_token=eq.${this.projectTeamToken}`,{data:t}=await this.apiRequest(e,"GET");return t||[]}async acquireLock(e,t){let s={project_team_token:this.projectTeamToken,file_path:e,locked_by:this.username,lock_context:t||"editing file",created_at:new Date().toISOString()};return await this.apiRequest("hablas_team_locks?on_conflict=project_team_token,file_path","POST",s,{prefer:"resolution=ignore-duplicates,return=minimal",retries:1}),!!(await this.fetchLocks()).find(a=>a.file_path===e&&a.locked_by===this.username)}async releaseLock(e){let t=`hablas_team_locks?project_team_token=eq.${this.projectTeamToken}&file_path=eq.${encodeURIComponent(e)}&locked_by=eq.${encodeURIComponent(this.username)}`;return await this.apiRequest(t,"DELETE"),!0}async releaseAllMyLocks(){let e=`hablas_team_locks?project_team_token=eq.${this.projectTeamToken}&locked_by=eq.${encodeURIComponent(this.username)}`;await this.apiRequest(e,"DELETE")}async sendMessage(e,t){let s={project_team_token:this.projectTeamToken,sender_name:this.username,receiver_name:e,message_content:t,is_read:!1,created_at:new Date().toISOString()},{ok:r}=await this.apiRequest("hablas_team_messages","POST",s,{retries:1});return r}async fetchUnreadMessages(){let e=`hablas_team_messages?project_team_token=eq.${this.projectTeamToken}&receiver_name=eq.${encodeURIComponent(this.username)}&is_read=eq.false`,t=(await this.apiRequest(e,"GET")).data||[];if(t.length>0)for(let s of t){let r=`hablas_team_messages?id=eq.${s.id}`;await this.apiRequest(r,"PATCH",{is_read:!0})}return t}saveLocalState(e,t){let s={project_team_token:this.projectTeamToken,last_sync:new Date().toISOString(),my_username:this.username,sessions:e,locks:t};ve.writeFileSync(this.localStatePath,JSON.stringify(s,null,2),"utf-8")}getLocalState(){if(ve.existsSync(this.localStatePath))try{return JSON.parse(ve.readFileSync(this.localStatePath,"utf-8"))}catch{}return{sessions:[],locks:[],my_username:this.username}}startLoops(){this.beat("idle","standby"),this.heartbeatInterval=setInterval(()=>{this.beat()},n.HEARTBEAT_MS);let e=t=>{this.syncInterval=setTimeout(async()=>{if(this.shuttingDown)return;await this.syncWithCloud()?this.idlePollTicks=0:this.idlePollTicks++;let r=this.idlePollTicks>=3?n.POLL_IDLE_MS:n.POLL_ACTIVE_MS;e(r)},t)};e(n.POLL_ACTIVE_MS)}setActivity(e,t="working"){this.currentActivity={section:t,task:e.slice(0,120)},this.beat(t,this.currentActivity.task)}async beat(e,t){await this.sendHeartbeat(e??this.currentActivity.section,t??this.currentActivity.task)?(this.announcedOffline&&(console.log(`
|
|
328
328
|
${c.success("\u2713")} ${c.muted("[Team]")} Cloud sync reconnected \u2014 session restored.
|
|
329
329
|
`),this.announcedOffline=!1),this.consecutiveHeartbeatFailures=0):(this.consecutiveHeartbeatFailures++,this.consecutiveHeartbeatFailures>=4&&!this.announcedOffline&&(console.log(`
|
|
330
330
|
${c.warning("\u26A0")} ${c.muted("[Team]")} Cloud sync is unreachable \u2014 retrying in the background. Your session is preserved.
|
|
331
|
-
`),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 u of r)this.renderMessageBox(u.sender_name,u.message_content);let i=Date.now(),o=t.filter(u=>{if(u.developer_name===this.username)return!0;let d=new Date(u.last_heartbeat).getTime();return i-d<=n.STALE_MS}),a=this.getLocalState(),l=r.length>0||JSON.stringify(a.sessions?.map(u=>u.developer_name).sort())!==JSON.stringify(o.map(u=>u.developer_name).sort())||JSON.stringify(a.locks?.map(u=>`${u.file_path}:${u.locked_by}`).sort())!==JSON.stringify(s.map(u=>`${u.file_path}:${u.locked_by}`).sort());return this.saveLocalState(o,s),l}startWatcher(){this.watcher=
|
|
331
|
+
`),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 u of r)this.renderMessageBox(u.sender_name,u.message_content);let i=Date.now(),o=t.filter(u=>{if(u.developer_name===this.username)return!0;let d=new Date(u.last_heartbeat).getTime();return i-d<=n.STALE_MS}),a=this.getLocalState(),l=r.length>0||JSON.stringify(a.sessions?.map(u=>u.developer_name).sort())!==JSON.stringify(o.map(u=>u.developer_name).sort())||JSON.stringify(a.locks?.map(u=>`${u.file_path}:${u.locked_by}`).sort())!==JSON.stringify(s.map(u=>`${u.file_path}:${u.locked_by}`).sort());return this.saveLocalState(o,s),l}startWatcher(){this.watcher=zf.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(`
|
|
332
332
|
${c.success("\u{1F514}")} ${c.muted("[Live Sync]")} ${c.strong(`@${i.developer_name}`)} has joined the session.
|
|
333
333
|
`);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(` ${c.accent("\u27F3")} ${c.muted("[Activity]")} ${c.strong(`@${i.developer_name}`)} is now: "${c.secondary(i.current_task)}"
|
|
334
334
|
`))}for(let i of this.knownSessions.keys())s.has(i)||(this.knownSessions.delete(i),console.log(`
|
|
@@ -336,83 +336,83 @@ If you cannot complete a task, explain why with absolute technical objectivity.`
|
|
|
336
336
|
`));let r=new Set;for(let i of t)r.add(i.file_path),this.knownLocks.has(i.file_path)||(this.knownLocks.set(i.file_path,i.locked_by),i.locked_by!==this.username&&console.log(` ${c.error("\u{1F512}")} ${c.muted("[File Locked]")} ${c.strong(`@${i.locked_by}`)} locked ${c.highlight(i.file_path)}`));for(let i of this.knownLocks.keys())if(!r.has(i)){let o=this.knownLocks.get(i);this.knownLocks.delete(i),o!==this.username&&console.log(` ${c.success("\u{1F513}")} ${c.muted("[File Unlocked]")} ${c.strong(`@${o}`)} released lock on ${c.highlight(i)}`)}}renderMessageBox(e,t){let s=Math.min(process.stdout.columns-4,80),r=c.border("\u250C"+"\u2500".repeat(s-2)+"\u2510"),i=c.border("\u2514"+"\u2500".repeat(s-2)+"\u2518"),o=` MESSAGE FROM @${e.toUpperCase()} `,a=Math.max(0,Math.floor((s-2-o.length)/2)),l=c.border("\u2502")+" ".repeat(a)+c.strong(o)+" ".repeat(s-2-o.length-a)+c.border("\u2502"),u=t.replace(/\n/g," "),d=Math.max(0,s-8-u.length),f=c.border("\u2502")+` "${c.secondary(u)}"`+" ".repeat(d)+c.border("\u2502");console.log(`
|
|
337
337
|
`+r),console.log(l),console.log(f),console.log(i+`
|
|
338
338
|
`)}registerCleanups(){this.signalHandler||(this.signalHandler=()=>{this.shutdown()},process.on("SIGTERM",this.signalHandler),process.once("beforeExit",this.signalHandler))}loadSupabaseConfig(){let e=Je.join(this.workingDir,".env");if(ve.existsSync(e))try{let s=ve.readFileSync(e,"utf-8").split(`
|
|
339
|
-
`);for(let r of s){let i=r.split("=");if(i.length>=2){let o=i[0].trim(),a=i.slice(1).join("=").trim().replace(/^['"]|['"]$/g,"");o==="SUPABASE_URL"||o==="VITE_SUPABASE_URL"?this.supabaseUrl=a:(o==="SUPABASE_KEY"||o==="SUPABASE_ANON_KEY"||o==="VITE_SUPABASE_ANON_KEY")&&(this.supabaseKey=a)}}}catch{}if(!this.supabaseUrl||!this.supabaseKey){let t="aHR0cHM6Ly93dXVtYXptcGp6dHZ4a3l3Y3Rvci5zdXBhYmFzZS5jbw==",s="c2JfcHVibGlzaGFibGVfVmxmNEtCUzdsaTRjaGFWNE04d19xQV9fbnJuczh1WQ==";this.supabaseUrl=Buffer.from(t,"base64").toString("utf-8"),this.supabaseKey=Buffer.from(s,"base64").toString("utf-8")}this.isConfigured=!!(this.supabaseUrl&&this.supabaseKey),this.isConfigured&&this.syncLlmConfig()}syncLlmConfig(){let e=Je.join(
|
|
340
|
-
`),
|
|
341
|
-
... [File has ${
|
|
339
|
+
`);for(let r of s){let i=r.split("=");if(i.length>=2){let o=i[0].trim(),a=i.slice(1).join("=").trim().replace(/^['"]|['"]$/g,"");o==="SUPABASE_URL"||o==="VITE_SUPABASE_URL"?this.supabaseUrl=a:(o==="SUPABASE_KEY"||o==="SUPABASE_ANON_KEY"||o==="VITE_SUPABASE_ANON_KEY")&&(this.supabaseKey=a)}}}catch{}if(!this.supabaseUrl||!this.supabaseKey){let t="aHR0cHM6Ly93dXVtYXptcGp6dHZ4a3l3Y3Rvci5zdXBhYmFzZS5jbw==",s="c2JfcHVibGlzaGFibGVfVmxmNEtCUzdsaTRjaGFWNE04d19xQV9fbnJuczh1WQ==";this.supabaseUrl=Buffer.from(t,"base64").toString("utf-8"),this.supabaseKey=Buffer.from(s,"base64").toString("utf-8")}this.isConfigured=!!(this.supabaseUrl&&this.supabaseKey),this.isConfigured&&this.syncLlmConfig()}syncLlmConfig(){let e=Je.join(lr.homedir(),".hablas","config.json");if(ve.existsSync(e))try{let t=JSON.parse(ve.readFileSync(e,"utf-8"));!this.config.apiUrl&&t.apiUrl&&(this.config.apiUrl=t.apiUrl,this.config.apiKey=t.apiKey,this.config.provider=t.provider)}catch{}}getProjectIdentifier(){let e="";try{let{execSync:t}=require("child_process"),s=t("git config --get remote.origin.url",{cwd:this.workingDir,encoding:"utf-8",stdio:["ignore","pipe","ignore"]}).trim();if(s){let r=s.match(/[:/]([^/]+\/[^/.]+)(\.git)?$/);r&&r[1]&&(e=r[1].toLowerCase())}}catch{}if(!e)try{let t=Je.join(this.workingDir,"package.json");if(ve.existsSync(t)){let s=JSON.parse(ve.readFileSync(t,"utf-8"));s.name&&(e=s.name.toLowerCase())}}catch{}return e||(e=Je.basename(this.workingDir).toLowerCase()),e.replace(/\s+/g,"")}}});async function en(n){try{if(!fa.existsSync(n))return;fa.existsSync(is)||await mt.mkdir(is,{recursive:!0});let e=await mt.readFile(n,"utf-8"),t=kn.basename(n),s=Date.now(),r=`${t}.${s}.bak`,i=kn.join(is,r);await mt.writeFile(i,e,"utf-8");let a=(await mt.readdir(is)).filter(l=>l.startsWith(`${t}.`)&&l.endsWith(".bak")).sort().reverse();if(a.length>Qf)for(let l of a.slice(Qf))await mt.unlink(kn.join(is,l))}catch{}}var mt,fa,kn,Xf,is,Qf,Zf=N(()=>{"use strict";mt=O(require("fs/promises")),fa=O(require("fs")),kn=O(require("path")),Xf=O(require("os")),is=kn.join(Xf.homedir(),".hablas","backup"),Qf=10});function np(n){let e=m=>Ht.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 ce.readFile(p,"utf-8")).split(`
|
|
340
|
+
`),S=x.length,A=m.start_line?Math.max(1,m.start_line):1,k=m.end_line?Math.min(S,m.end_line):Math.min(S,A+ep-1),y=Math.min(k,A+ep-1),b=x.slice(A-1,y),v=String(y).length,w=b.map((I,$)=>`${String(A+$).padStart(v," ")} | ${I}`),_=`[${m.path} \u2014 lines ${A}-${y} of ${S}]`,E=y<S?`
|
|
341
|
+
... [File has ${S} total lines. Use start_line/end_line to read more.]`:"";return{success:!0,output:`${_}
|
|
342
342
|
${w.join(`
|
|
343
|
-
`)}${
|
|
343
|
+
`)}${E}`}}catch(p){return{success:!1,output:"",error:`[read_file]: ${p.message}`}}}},{name:"write_file",description:"Create or overwrite a file with content",safety:"confirm",parameters:{path:{type:"string",description:"File path to write",required:!0},content:{type:"string",description:"Content to write",required:!0}},execute:async m=>{try{if(!m.path)return{success:!1,output:"",error:"[write_file]: path is required"};if(m.content===void 0)return{success:!1,output:"",error:"[write_file]: content is required"};let p=e(m.path);return pa.existsSync(p)&&await en(p),await ce.mkdir(Ht.dirname(p),{recursive:!0}),await ce.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 ce.readFile(p,"utf-8"),x=m.old_content,S=m.new_content,A=tp(g,x);if(A===0)return{success:!1,output:"",error:"[edit_file]: Old content not found in file"};if(A>1)return{success:!1,output:"",error:`[edit_file]: old_content matches ${A} locations in the file. Provide more surrounding context to be specific.`};await en(p);let k=g.replace(x,S);await ce.writeFile(p,k,"utf-8");let y=Us(m.path,g,k);return{success:!0,output:`Edited: ${m.path}
|
|
344
344
|
${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 ce.readFile(p,"utf-8"),x=g.split(`
|
|
345
|
-
`),
|
|
345
|
+
`),S=x.length,A=m.start_line,k=m.end_line;if(A<1||A>S)return{success:!1,output:"",error:`[patch_file]: start_line ${A} is out of range (file has ${S} lines)`};if(k<A||k>S)return{success:!1,output:"",error:`[patch_file]: end_line ${k} is out of range (start_line=${A}, total=${S})`};await en(p);let y=x.slice(0,A-1),b=x.slice(k),v=m.new_content.split(`
|
|
346
346
|
`),w=[...y,...v,...b].join(`
|
|
347
|
-
`);await ce.writeFile(p,w,"utf-8");let
|
|
348
|
-
${
|
|
349
|
-
`)}}catch(p){return{success:!1,output:"",error:`[get_file_info]: ${p.message}`}}}}]}function
|
|
350
|
-
`,l.isDirectory()){let h=e+(u?" ":"\u2502 ");o+=await
|
|
347
|
+
`);await ce.writeFile(p,w,"utf-8");let _=Us(m.path,g,w),E=k-A+1,I=v.length;return{success:!0,output:`Patched: ${m.path} (replaced ${E} lines with ${I})
|
|
348
|
+
${_}`}}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 ce.readFile(p,"utf-8"),x=m.search,S=m.replace,A=m.is_regex;await en(p);let k,y;if(A){let b=new RegExp(x,"g");y=(g.match(b)||[]).length,k=g.replace(b,S)}else y=tp(g,x),k=g.split(x).join(S);return y===0?{success:!1,output:"",error:"[search_and_replace]: Pattern not found in file"}:(await ce.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 ce.mkdir(Ht.dirname(p),{recursive:!0}),pa.existsSync(p)&&await en(p),await ce.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 en(p),await ce.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 ce.mkdir(Ht.dirname(g),{recursive:!0}),await ce.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 ce.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 sp(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 ce.stat(p);return{success:!0,output:[`Path: ${m.path}`,`Size: ${Kx(g.size)}`,`Type: ${g.isDirectory()?"directory":"file"}`,`Modified: ${g.mtime.toISOString()}`,`Created: ${g.birthtime.toISOString()}`].join(`
|
|
349
|
+
`)}}catch(p){return{success:!1,output:"",error:`[get_file_info]: ${p.message}`}}}}]}function tp(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 sp(n,e,t,s){if(s>=t)return"";let i=(await ce.readdir(n,{withFileTypes:!0})).filter(a=>!qx.has(a.name)&&!a.name.startsWith(".")).sort((a,l)=>a.isDirectory()&&!l.isDirectory()?-1:!a.isDirectory()&&l.isDirectory()?1:a.name.localeCompare(l.name)),o="";for(let a=0;a<i.length;a++){let l=i[a],u=a===i.length-1,d=u?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",f=l.isDirectory()?"\u{1F4C1}":"\u{1F4C4}";if(o+=`${e}${d}${f} ${l.name}
|
|
350
|
+
`,l.isDirectory()){let h=e+(u?" ":"\u2502 ");o+=await sp(Ht.join(n,l.name),h,t,s+1)}}return o}function Kx(n){return n<1024?`${n} B`:n<1024*1024?`${(n/1024).toFixed(1)} KB`:`${(n/(1024*1024)).toFixed(1)} MB`}var ce,pa,Ht,ep,qx,rp=N(()=>{"use strict";ce=O(require("fs/promises")),pa=O(require("fs")),Ht=O(require("path"));co();Zf();ep=300;qx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next"])});var ip,cr,op=N(()=>{"use strict";ip=require("child_process"),cr=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,ip.spawn)(e,{shell:!0,cwd:this.config.workingDir,env:{...process.env,...t?.env}}),o={id:s,command:e,process:i,stdout:"",stderr:"",startTime:Date.now(),pid:i.pid,status:"running"};return i.stdout?.on("data",a=>{o.stdout+=a.toString(),o.stdout.length>this.config.maxOutputSize&&(o.stdout=o.stdout.slice(-this.config.maxOutputSize))}),i.stderr?.on("data",a=>{o.stderr+=a.toString(),o.stderr.length>this.config.maxOutputSize&&(o.stderr=o.stderr.slice(-this.config.maxOutputSize))}),i.on("exit",a=>{o.status="finished",o.exitCode=a??void 0}),i.on("error",a=>{o.status="finished",o.stderr+=`
|
|
351
351
|
Error: ${a.message}`}),r>0&&setTimeout(()=>{o.status==="running"&&(this.kill(s),o.status="timeout",o.stderr+=`
|
|
352
352
|
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+=`
|
|
353
353
|
`),i+=s.stderr),t?.lastLines&&(i=i.split(`
|
|
354
354
|
`).slice(-t.lastLines).join(`
|
|
355
|
-
`)),{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
|
|
356
|
-
PID: ${
|
|
357
|
-
Use bash_output to read output: bash_output(process_id="${l}")`}}return new Promise(l=>{let u=(0,
|
|
355
|
+
`)),{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 ap(n){return ha||(ha=new cr({workingDir:n})),ha}function cp(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=[...Wx,...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=ap(n).start(s,{timeout:i});return{success:!0,output:`Background process started: ${l}
|
|
356
|
+
PID: ${ap(n).getProcess(l)?.pid}
|
|
357
|
+
Use bash_output to read output: bash_output(process_id="${l}")`}}return new Promise(l=>{let u=(0,lp.exec)(s,{cwd:n,timeout:i,maxBuffer:10485760,env:{...process.env,FORCE_COLOR:"0"}}),d="",f="";u.stdout?.on("data",h=>{d+=h}),u.stderr?.on("data",h=>{f+=h}),u.on("close",h=>{l(h===0?{success:!0,output:d||"(no output)"}:{success:!1,output:d,error:f||`Exit code: ${h}`})}),u.on("error",h=>{l({success:!1,output:"",error:h.message})})})}}}var lp,Wx,ha,up=N(()=>{"use strict";lp=require("child_process");op();Wx=["rm -rf /","rm -rf /*","rm -rf ~","rm -rf $HOME","rm -rf /home","mkfs",":(){ :|:& };:"],ha=null});function dp(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=Bt.resolve(n,e.path||"."),r=new RegExp(t,"gi"),i=[];if(await fp(s,r,i,n),i.length===0)return{success:!0,output:`No matches found for: "${t}"`};let o=i.slice(0,50).join(`
|
|
358
358
|
`),a=i.length>50?`
|
|
359
|
-
... 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
|
|
360
|
-
`),u=
|
|
361
|
-
`);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 Yx(n){let e=[];if(![".eslintrc.json",".eslintrc.js",".eslintrc.yml","eslint.config.js","eslint.config.mjs"].some(s=>Qe.existsSync(
|
|
362
|
-
`);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 Jx(n,e,t){let s;try{s=Qe.readFileSync(n,"utf-8")}catch{return}let r=
|
|
363
|
-
`);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 Qx(n){let e=[],t=[".ts",".tsx",".js",".jsx"];function s(r,i=0){if(i>5)return;let o=["node_modules",".git","dist","build",".next","coverage"],a;try{a=Qe.readdirSync(r)}catch{return}for(let l of a){if(o.includes(l))continue;let u=
|
|
364
|
-
`)}function Zx(n,e){let t=[];for(let s of n)if(s.source==="pattern"&&s.message.includes("console.log")){let r=
|
|
359
|
+
... 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 fp(n,e,t,s){let r=await ur.readdir(n,{withFileTypes:!0});for(let i of r){if(Gx.has(i.name)||i.name.startsWith("."))continue;let o=Bt.join(n,i.name);if(i.isDirectory())await fp(o,e,t,s);else if(Vx.has(Bt.extname(i.name)))try{let l=(await ur.readFile(o,"utf-8")).split(`
|
|
360
|
+
`),u=Bt.relative(s,o);for(let d=0;d<l.length;d++)e.test(l[d])&&(t.push(`${u}:${d+1}: ${l[d].trim()}`),e.lastIndex=0)}catch{}}}var ur,Bt,Gx,Vx,pp=N(()=>{"use strict";ur=O(require("fs/promises")),Bt=O(require("path")),Gx=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),Vx=new Set([".ts",".js",".tsx",".jsx",".py",".go",".rs",".java",".c",".cpp",".h",".css",".html",".json",".md",".yaml",".yml",".toml"])});function zx(n){let e=[],t=Ut.join(n,"tsconfig.json");if(!Qe.existsSync(t))return e;try{(0,ma.execSync)("npx tsc --noEmit 2>&1",{cwd:n,encoding:"utf-8",timeout:3e4})}catch(s){let r=s,o=(r.stdout||r.message||"").split(`
|
|
361
|
+
`);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 Yx(n){let e=[];if(![".eslintrc.json",".eslintrc.js",".eslintrc.yml","eslint.config.js","eslint.config.mjs"].some(s=>Qe.existsSync(Ut.join(n,s))))return e;try{(0,ma.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:Ut.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(`
|
|
362
|
+
`);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 Jx(n,e,t){let s;try{s=Qe.readFileSync(n,"utf-8")}catch{return}let r=Ut.relative(e,n),i=s.split(`
|
|
363
|
+
`);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 Qx(n){let e=[],t=[".ts",".tsx",".js",".jsx"];function s(r,i=0){if(i>5)return;let o=["node_modules",".git","dist","build",".next","coverage"],a;try{a=Qe.readdirSync(r)}catch{return}for(let l of a){if(o.includes(l))continue;let u=Ut.join(r,l),d;try{d=Qe.statSync(u)}catch{continue}d.isDirectory()?s(u,i+1):t.some(f=>l.endsWith(f))&&Jx(u,n,e)}}return s(n),e.slice(0,20)}function Xx(n){let e=[];e.push(...zx(n)),e.push(...Yx(n)),e.push(...Qx(n));let t={error:0,warning:1,info:2};return e.sort((s,r)=>t[s.severity]-t[r.severity]),e}function hp(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(`
|
|
364
|
+
`)}function Zx(n,e){let t=[];for(let s of n)if(s.source==="pattern"&&s.message.includes("console.log")){let r=Ut.join(e,s.file);try{let o=Qe.readFileSync(r,"utf-8").split(`
|
|
365
365
|
`);s.line>0&&s.line<=o.length&&(o[s.line-1]="// "+o[s.line-1],Qe.writeFileSync(r,o.join(`
|
|
366
|
-
`),"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
|
|
366
|
+
`),"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 mp(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=Xx(t);if(s&&r.length>0){let o=Zx(r,t).filter(l=>l.fixed).length;return{success:!0,output:`${hp(r)}
|
|
367
367
|
|
|
368
|
-
Auto-fixed: ${o}/${r.length} issues`}}return{success:!0,output:
|
|
368
|
+
Auto-fixed: ${o}/${r.length} issues`}}return{success:!0,output:hp(r)}}catch(r){return{success:!1,output:"",error:`Bug detection failed: ${r instanceof Error?r.message:String(r)}`}}}}}var ma,Qe,Ut,gp=N(()=>{"use strict";ma=require("child_process"),Qe=O(require("fs")),Ut=O(require("path"))});function tS(n){let e=n;return e=e.replace(/<(script|style|nav|footer|header|aside|iframe|noscript)[^>]*>[\s\S]*?<\/\1>/gi,""),e=e.replace(/<!--[\s\S]*?-->/g,""),e=e.replace(/<\/(p|div|section|article|li|tr|h[1-6])>/gi,`
|
|
369
369
|
`),e=e.replace(/<(br|hr)\s*\/?>/gi,`
|
|
370
370
|
`),e=e.replace(/<\/?(ul|ol)>/gi,`
|
|
371
371
|
`),e=e.replace(/<h([1-6])[^>]*>([\s\S]*?)<\/h\1>/gi,(t,s,r)=>`
|
|
372
372
|
${"#".repeat(parseInt(s))} ${r.replace(/<[^>]+>/g,"").trim()}
|
|
373
373
|
`),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,`
|
|
374
374
|
|
|
375
|
-
`),e=e.replace(/^\s+|\s+$/gm,""),e.trim()}function nS(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 sS(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
|
|
375
|
+
`),e=e.replace(/^\s+|\s+$/gm,""),e.trim()}function nS(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 sS(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 wp(n){let e=new AbortController,t=setTimeout(()=>e.abort(),bp);try{let s=await fetch(n,{signal:e.signal,headers:{"User-Agent":eS,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<yp;){let{done:d,value:f}=await i.read();if(d)break;o.push(f),a+=f.length}if(a>=yp)try{i.cancel()}catch{}let l=new TextDecoder("utf-8",{fatal:!1});return{html:o.map(d=>l.decode(d,{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 ${bp/1e3}s`):r}}function xp(){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 wp(e);if(!t||r>=400)return{success:!1,output:"",error:`HTTP ${r} \u2014 could not fetch ${e}`};let i=nS(t),o=tS(t);return o.length>vp&&(o=o.slice(0,vp)+`
|
|
376
376
|
|
|
377
377
|
[... content truncated ...]`),{success:!0,output:[`# ${i}`,`URL: ${s}`,`Fetched: ${new Date().toISOString()}`,"",o].join(`
|
|
378
|
-
`)}}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
|
|
378
|
+
`)}}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 wp(e);if(!s||i>=400)return{success:!1,output:"",error:`HTTP ${i} \u2014 could not fetch ${e}`};let o=sS(s,r);if(t&&(o=o.filter(l=>l.url.toLowerCase().includes(t)||l.text.toLowerCase().includes(t))),o.length===0)return{success:!0,output:"No links found"+(t?` matching "${t}"`:"")};let a=o.slice(0,100).map((l,u)=>`${u+1}. [${l.text}](${l.url})`).join(`
|
|
379
379
|
`);return{success:!0,output:`Found ${o.length} links:
|
|
380
380
|
|
|
381
|
-
${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
|
|
382
|
-
`)}}catch(s){return{success:!1,output:"",error:`Search failed: ${s instanceof Error?s.message:String(s)}`}}}}}var rS,
|
|
381
|
+
${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 yp,bp,vp,eS,Sp=N(()=>{"use strict";yp=2*1024*1024,bp=15e3,vp=32e3,eS="HablasBot/2.0 (+https://hablas.dev)"});function iS(n){let e=$n.get(n.toLowerCase().trim());return e?Date.now()-e.timestamp>rS?($n.delete(n.toLowerCase().trim()),null):e.results:null}function oS(n,e){if($n.size>200){let t=$n.keys().next().value;t!==void 0&&$n.delete(t)}$n.set(n.toLowerCase().trim(),{results:e,timestamp:Date.now()})}async function aS(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 lS(n,e){try{let t=new URLSearchParams({q:n}),s=await fetch(`https://html.duckduckgo.com/html/?${t}`,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"},signal:AbortSignal.timeout(1e4)});if(!s.ok)return null;let r=await s.text(),i=[],o=/<a[^>]+class="result__a"[^>]+href="([^"]+)"[^>]*>([\s\S]*?)<\/a>[\s\S]*?<a[^>]+class="result__snippet"[^>]*>([\s\S]*?)<\/a>/gi,a;for(;(a=o.exec(r))!==null&&i.length<e;){let l=a[1],u=a[2].replace(/<[^>]+>/g,"").trim(),d=a[3].replace(/<[^>]+>/g,"").trim(),f=l.match(/uddg=([^&]+)/);if(f)try{l=decodeURIComponent(f[1])}catch{}u&&l&&!l.startsWith("/")&&i.push({title:u,url:l,snippet:d,source:"duckduckgo"})}if(i.length===0){let l=/<a[^>]+href="(https?:\/\/[^"]+)"[^>]*>([\s\S]*?)<\/a>/gi,u=new Set;for(;(a=l.exec(r))!==null&&i.length<e;){let d=a[1],f=a[2].replace(/<[^>]+>/g,"").trim();f&&f.length>5&&!u.has(d)&&!d.includes("duckduckgo.com")&&(u.add(d),i.push({title:f,url:d,snippet:"",source:"duckduckgo"}))}}return i.length>0?i:null}catch{return null}}async function cS(n,e=5){let t=iS(n);if(t)return t.slice(0,e);let s=[{name:"brave",fn:()=>aS(n,e)},{name:"duckduckgo",fn:()=>lS(n,e)}];for(let r of s)try{let i=await r.fn();if(i&&i.length>0)return oS(n,i),i}catch{}return[]}function _p(){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 cS(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(`
|
|
382
|
+
`)}}catch(s){return{success:!1,output:"",error:`Search failed: ${s instanceof Error?s.message:String(s)}`}}}}}var rS,$n,Ap=N(()=>{"use strict";rS=3600*1e3,$n=new Map});function Cp(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=tn(o[1]));let a=e.match(/\/Author\s*\(([^)]*)\)/);a&&(t.author=tn(a[1]));let l=e.match(/\/Subject\s*\(([^)]*)\)/);l&&(t.subject=tn(l[1]));let u=e.match(/\/Creator\s*\(([^)]*)\)/);u&&(t.creator=tn(u[1]));let d=/stream\r?\n([\s\S]*?)\r?\nendstream/g,f;for(;(f=d.exec(e))!==null;){let m=f[1],p=Ep(m);p.trim()&&s.push(p);try{let g=require("zlib"),x=Buffer.from(m,"latin1"),S=g.inflateSync(x).toString("latin1"),A=Ep(S);A.trim()&&!s.includes(A)&&s.push(A)}catch{}}return{text:s.join(`
|
|
383
383
|
`).replace(/\r\n/g,`
|
|
384
384
|
`).replace(/\n{3,}/g,`
|
|
385
385
|
|
|
386
|
-
`).trim(),pages:r,metadata:t}}function Ep(n){let e=[],t=/\(([^)]*)\)\s*Tj/g,s;for(;(s=t.exec(n))!==null;)e.push(
|
|
387
|
-
`).replace(/\\r/g,"").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\"),o}function
|
|
388
|
-
`).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
|
|
386
|
+
`).trim(),pages:r,metadata:t}}function Ep(n){let e=[],t=/\(([^)]*)\)\s*Tj/g,s;for(;(s=t.exec(n))!==null;)e.push(tn(s[1]));let r=/\[((?:\([^)]*\)|[^])*?)\]\s*TJ/g;for(;(s=r.exec(n))!==null;){let l=s[1].match(/\(([^)]*)\)/g);if(l){let u=l.map(d=>tn(d.slice(1,-1))).join("");e.push(u)}}let i=/\(([^)]*)\)\s*'/g;for(;(s=i.exec(n))!==null;)e.push(tn(s[1]));let o=e.join(" ");return o=o.replace(/\\n/g,`
|
|
387
|
+
`).replace(/\\r/g,"").replace(/\\t/g," ").replace(/\\\(/g,"(").replace(/\\\)/g,")").replace(/\\\\/g,"\\"),o}function tn(n){return n.replace(/\\n/g,`
|
|
388
|
+
`).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 Rp(n){let e=t=>Tp.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(!Pt.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=Pt.statSync(s);if(r.size>kp)return{success:!1,output:"",error:`File too large: ${(r.size/1024/1024).toFixed(1)}MB (max: ${kp/1024/1024}MB)`};try{let i=Pt.readFileSync(s),{text:o,pages:a,metadata:l}=Cp(i);if(!o||o.length<10)return{success:!0,output:`PDF: ${t.path} (${a} pages)
|
|
389
389
|
|
|
390
|
-
[No extractable text found \u2014 this may be a scanned/image-only PDF. Use OCR tools for scanned documents.]`};let u=o;return u.length
|
|
390
|
+
[No extractable text found \u2014 this may be a scanned/image-only PDF. Use OCR tools for scanned documents.]`};let u=o;return u.length>$p&&(u=u.slice(0,$p)+`
|
|
391
391
|
|
|
392
392
|
[... 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(`
|
|
393
393
|
`)}
|
|
394
|
-
${u}`}}catch(i){return{success:!1,output:"",error:`Failed to read PDF: ${i instanceof Error?i.message:String(i)}`}}}},{name:"pdf_metadata",description:"Get metadata from a PDF file: page count, title, author, file size. Quick way to inspect a PDF without reading its full content.",safety:"safe",parameters:{path:{type:"string",description:"Path to the PDF file",required:!0}},execute:async t=>{let s=e(t.path);if(!
|
|
395
|
-
`)}}catch(r){return{success:!1,output:"",error:`Failed to read PDF metadata: ${r instanceof Error?r.message:String(r)}`}}}}]}var
|
|
394
|
+
${u}`}}catch(i){return{success:!1,output:"",error:`Failed to read PDF: ${i instanceof Error?i.message:String(i)}`}}}},{name:"pdf_metadata",description:"Get metadata from a PDF file: page count, title, author, file size. Quick way to inspect a PDF without reading its full content.",safety:"safe",parameters:{path:{type:"string",description:"Path to the PDF file",required:!0}},execute:async t=>{let s=e(t.path);if(!Pt.existsSync(s))return{success:!1,output:"",error:`File not found: ${t.path}`};try{let r=Pt.statSync(s),i=Pt.readFileSync(s),{pages:o,metadata:a}=Cp(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(`
|
|
395
|
+
`)}}catch(r){return{success:!1,output:"",error:`Failed to read PDF metadata: ${r instanceof Error?r.message:String(r)}`}}}}]}var Pt,Tp,kp,$p,Pp=N(()=>{"use strict";Pt=O(require("fs")),Tp=O(require("path")),kp=50*1024*1024,$p=4e4});function Cn(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 uS(n,e,t=Np){let s=Ip[e];if(!s)return{success:!1,stdout:"",stderr:`Unsupported language: "${e}". Supported: ${Object.keys(Ip).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=Lp.tmpdir(),i=Dp.join(r,`hablas_exec_${Date.now()}${s.extension}`);try{dr.writeFileSync(i,n,"utf-8");let o=s.command(i),a=Date.now();return await new Promise(l=>{let u=(0,Mp.exec)(o,{timeout:t,maxBuffer:5242880,cwd:r,env:{...process.env,NODE_ENV:"production",FORCE_COLOR:"0"}}),d="",f="";u.stdout?.on("data",h=>{d+=h}),u.stderr?.on("data",h=>{f+=h}),u.on("close",h=>{let m=Date.now()-a;l({success:h===0,stdout:d.slice(0,Op),stderr:f.slice(0,Op/2),exitCode:h??1,duration:m,language:e})}),u.on("error",h=>{let m=Date.now()-a;l({success:!1,stdout:"",stderr:h.message,exitCode:1,duration:m,language:e})})})}finally{try{dr.unlinkSync(i)}catch{}}}function dS(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 Fp(){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()||dS(e),s=Math.min(Math.max(1e3,n.timeout||Np),3e4),r=await uS(e,t,s),i=[];return i.push(`Language: ${r.language} | Exit: ${r.exitCode} | Duration: ${r.duration}ms`),i.push(""),r.stdout&&(i.push("Output:"),i.push(r.stdout)),r.stderr&&(i.push(r.stdout?`
|
|
396
396
|
Errors/Warnings:`:"Errors:"),i.push(r.stderr)),!r.stdout&&!r.stderr&&i.push("(no output)"),{success:r.success,output:i.join(`
|
|
397
|
-
`),error:r.success?void 0:r.stderr||`Exit code: ${r.exitCode}`}}}]}var
|
|
397
|
+
`),error:r.success?void 0:r.stderr||`Exit code: ${r.exitCode}`}}}]}var Mp,dr,Lp,Dp,Np,Op,Ip,jp=N(()=>{"use strict";Mp=require("child_process"),dr=O(require("fs")),Lp=O(require("os")),Dp=O(require("path")),Np=1e4,Op=16e3;Ip={javascript:{extension:".js",command:n=>`node --no-warnings "${n}"`,available:()=>!0},typescript:{extension:".ts",command:n=>Cn("tsx")?`tsx "${n}"`:Cn("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=>Cn("python3")?`python3 "${n}"`:`python "${n}"`,available:()=>Cn("python3")||Cn("python")},bash:{extension:".sh",command:n=>`bash "${n}"`,available:()=>Cn("bash")}}});var os,Hp=N(()=>{"use strict";rp();up();pp();gp();Sp();Ap();Pp();jp();os=class{tools=new Map;constructor(e,t){let s=np(e);for(let r of s)this.tools.set(r.name,r);this.tools.set("run_command",cp(e,t)),this.tools.set("search_codebase",dp(e)),this.tools.set("detect_bugs",mp(e)),this.tools.set("web_search",_p());for(let r of xp())this.tools.set(r.name,r);for(let r of Rp(e))this.tools.set(r.name,r);for(let r of Fp())this.tools.set(r.name,r)}get(e){return this.tools.get(e)}getAll(){return Array.from(this.tools.values())}getSafetyLevel(e){return this.tools.get(e)?.safety}async execute(e){let t=this.tools.get(e.name);return t?t.execute(e.arguments):{success:!1,output:"",error:`Unknown tool: ${e.name}`}}getOllamaTools(){return this.getAll().map(e=>{let t={},s=[];for(let[r,i]of Object.entries(e.parameters))t[r]={type:i.type==="number"?"number":"string",description:i.description},i.required&&s.push(r);return{type:"function",function:{name:e.name,description:e.description,parameters:{type:"object",properties:t,required:s}}}})}getToolDescriptions(){return this.getAll().map(t=>{let s=Object.entries(t.parameters).map(([r,i])=>` ${r}: ${i.type} \u2014 ${i.description}`).join(`
|
|
398
398
|
`);return`- ${t.name} [${t.safety}]: ${t.description}
|
|
399
399
|
${s}`}).join(`
|
|
400
400
|
|
|
401
|
-
`)}}});function ga(n){return Math.ceil(n.length/3.5)}function
|
|
402
|
-
... [truncated to fit context budget]`}var ya=N(()=>{"use strict"});var
|
|
401
|
+
`)}}});function ga(n){return Math.ceil(n.length/3.5)}function as(n,e){let t=Math.floor(e*3.5);return n.length<=t?n:n.slice(0,t)+`
|
|
402
|
+
... [truncated to fit context budget]`}var ya=N(()=>{"use strict"});var Bp,nn,ba=N(()=>{"use strict";Bp=O(require("crypto"));ya();nn=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=ga(t),a=s?.importance??this.autoImportance(e,t);this.usedTokens+o>this.budget&&this.evictToFit(o);let l={path:e,content:t,hash:r,lastUsed:Date.now(),tokenCount:o,importance:a,accessCount:i?i.accessCount+1:1,relatedFiles:i?.relatedFiles||[],summarized:!1,tags:s?.tags||this.autoTag(e)};i&&(this.usedTokens-=i.tokenCount),this.cache.set(e,l),this.usedTokens+=o,this.recordAccess(e)}hasChanged(e,t){let s=this.cache.get(e);return s?s.hash!==this.computeHash(t):!0}buildContext(e){let t=e||this.budget,s=Array.from(this.cache.values()).map(o=>({...o,score:this.computeScore(o)})).sort((o,a)=>a.score-o.score),r=0,i=[];for(let o of s){if(r+o.tokenCount>t){if(o.importance>=7){let a=t-r;if(a>200){let l=as(o.content,a);i.push(`--- ${o.path} (truncated, importance: ${o.importance}) ---
|
|
403
403
|
${l}`),r+=a}}continue}i.push(`--- ${o.path} ---
|
|
404
404
|
${o.content}`),r+=o.tokenCount}return i.join(`
|
|
405
405
|
|
|
406
406
|
`)}buildAgentContext(e,t){let s=t||Math.floor(this.budget*.5),i={alex:[".ts",".js",".tsx",".jsx",".py",".go",".rs",".css",".html"],bob:[".md",".json",".yaml",".yml",".toml",".xml","schema","config"],david:[".md",".csv",".json",".txt",".sql"],emma:[".md",".txt",".json"],hablas:[]}[e]||[],o=Array.from(this.cache.values()).filter(u=>i.length===0?!0:i.some(d=>u.path.includes(d))).sort((u,d)=>this.computeScore(d)-this.computeScore(u)),a=0,l=[];for(let u of o){if(a+u.tokenCount>s)break;l.push(`--- ${u.path} ---
|
|
407
407
|
${u.content}`),a+=u.tokenCount}return l.join(`
|
|
408
408
|
|
|
409
|
-
`)}getTotalTokens(){return this.usedTokens}getCacheSize(){return this.cache.size}getCacheInfo(){return Array.from(this.cache.values()).map(e=>({path:e.path,tokens:e.tokenCount,importance:e.importance,accesses:e.accessCount})).sort((e,t)=>t.importance-e.importance)}evictToFit(e){let t=Array.from(this.cache.entries()).map(([r,i])=>({key:r,...i,score:this.computeScore(i)})).sort((r,i)=>r.score-i.score),s=0;for(let r of t){if(s>=e)break;r.importance>=9||(s+=r.tokenCount,this.usedTokens-=r.tokenCount,this.cache.delete(r.key))}}evict(e){this.evictToFit(e)}clear(){this.cache.clear(),this.usedTokens=0,this.accessHistory=[]}computeScore(e){let r=(Date.now()-e.lastUsed)/6e4,i=Math.exp(-r/30),o=Math.log1p(e.accessCount);return e.importance*(i+o)}autoImportance(e,t){let s=5;/\b(config|tsconfig|package\.json|\.env|Dockerfile|docker-compose)\b/i.test(e)&&(s=8),/\b(index|main|app|server)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=7),/\.(test|spec)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=3);let r=ga(t);return r>2e3&&(s=Math.max(1,s-1)),r>5e3&&(s=Math.max(1,s-2)),s}autoTag(e){let t=[];return/\.(ts|tsx)$/.test(e)&&t.push("typescript"),/\.(js|jsx)$/.test(e)&&t.push("javascript"),/\.json$/.test(e)&&t.push("config"),/\.md$/.test(e)&&t.push("documentation"),/\.(css|scss|sass)$/.test(e)&&t.push("style"),/\.(test|spec)\./i.test(e)&&t.push("test"),/src\//.test(e)&&t.push("source"),t}recordAccess(e){this.accessHistory.length>50&&(this.accessHistory=this.accessHistory.slice(-50));let t=this.accessHistory[this.accessHistory.length-1];if(t&&Date.now()-this.getGroupTime(t)<3e4){if(!t.includes(e)){t.push(e);for(let s of t)if(s!==e){let r=this.cache.get(s);r&&!r.relatedFiles.includes(e)&&r.relatedFiles.push(e)}}}else this.accessHistory.push([e])}getGroupTime(e){return Date.now()}computeHash(e){return
|
|
409
|
+
`)}getTotalTokens(){return this.usedTokens}getCacheSize(){return this.cache.size}getCacheInfo(){return Array.from(this.cache.values()).map(e=>({path:e.path,tokens:e.tokenCount,importance:e.importance,accesses:e.accessCount})).sort((e,t)=>t.importance-e.importance)}evictToFit(e){let t=Array.from(this.cache.entries()).map(([r,i])=>({key:r,...i,score:this.computeScore(i)})).sort((r,i)=>r.score-i.score),s=0;for(let r of t){if(s>=e)break;r.importance>=9||(s+=r.tokenCount,this.usedTokens-=r.tokenCount,this.cache.delete(r.key))}}evict(e){this.evictToFit(e)}clear(){this.cache.clear(),this.usedTokens=0,this.accessHistory=[]}computeScore(e){let r=(Date.now()-e.lastUsed)/6e4,i=Math.exp(-r/30),o=Math.log1p(e.accessCount);return e.importance*(i+o)}autoImportance(e,t){let s=5;/\b(config|tsconfig|package\.json|\.env|Dockerfile|docker-compose)\b/i.test(e)&&(s=8),/\b(index|main|app|server)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=7),/\.(test|spec)\.(ts|js|tsx|jsx)$/i.test(e)&&(s=3);let r=ga(t);return r>2e3&&(s=Math.max(1,s-1)),r>5e3&&(s=Math.max(1,s-2)),s}autoTag(e){let t=[];return/\.(ts|tsx)$/.test(e)&&t.push("typescript"),/\.(js|jsx)$/.test(e)&&t.push("javascript"),/\.json$/.test(e)&&t.push("config"),/\.md$/.test(e)&&t.push("documentation"),/\.(css|scss|sass)$/.test(e)&&t.push("style"),/\.(test|spec)\./i.test(e)&&t.push("test"),/src\//.test(e)&&t.push("source"),t}recordAccess(e){this.accessHistory.length>50&&(this.accessHistory=this.accessHistory.slice(-50));let t=this.accessHistory[this.accessHistory.length-1];if(t&&Date.now()-this.getGroupTime(t)<3e4){if(!t.includes(e)){t.push(e);for(let s of t)if(s!==e){let r=this.cache.get(s);r&&!r.relatedFiles.includes(e)&&r.relatedFiles.push(e)}}}else this.accessHistory.push([e])}getGroupTime(e){return Date.now()}computeHash(e){return Bp.createHash("md5").update(e).digest("hex")}}});function ls(){return`msg_${Date.now()}_${++fS}`}function En(n){return Math.ceil(n.length/4)}var fS,sn,va=N(()=>{"use strict";fS=0;sn=class n{messages=[];maxMessages;maxTokens;sessionId;snapshots=[];forks=new Map;agentMessageCounts=new Map;totalTokens=0;constructor(e,t=50,s=32e3){this.maxMessages=t,this.maxTokens=s,this.sessionId=`session_${Date.now()}`;let r=En(e);this.messages.push({id:ls(),role:"system",content:e,timestamp:Date.now(),priority:"critical",tokenEstimate:r,compressed:!1,tags:["system"]}),this.totalTokens=r}getSessionId(){return this.sessionId}addUserMessage(e,t){let s=ls(),r=En(e);return this.messages.push({id:s,role:"user",content:e,timestamp:Date.now(),priority:t?.priority||"high",tokenEstimate:r,compressed:!1,tags:t?.tags||["user-input"]}),this.totalTokens+=r,this.trimIfNeeded(),s}addAssistantMessage(e,t,s){let r=ls(),i=En(e),o={id:r,role:"assistant",content:e,timestamp:Date.now(),priority:"normal",agent:s||"hablas",tokenEstimate:i,compressed:!1,tags:s?[`agent:${s}`]:["assistant"]};return t&&t.length>0&&(o.tool_calls=t,o.tags.push("has-tools")),this.messages.push(o),this.totalTokens+=i,s&&this.agentMessageCounts.set(s,(this.agentMessageCounts.get(s)||0)+1),this.trimIfNeeded(),r}addToolMessage(e,t){let s=ls(),r=En(e);return this.messages.push({id:s,role:"tool",content:e,timestamp:Date.now(),priority:e.startsWith("Error")?"high":"low",tokenEstimate:r,compressed:!1,tags:t?[`tool:${t}`]:["tool-result"]}),this.totalTokens+=r,this.trimIfNeeded(),s}getMessages(){return this.messages.map(e=>{let t={role:e.role,content:e.content};return e.tool_calls&&e.tool_calls.length>0&&(t.tool_calls=e.tool_calls),t})}getEnhancedMessages(){return[...this.messages]}getHistory(){return this.messages.slice(1).map(e=>({role:e.role,content:e.content,tool_calls:e.tool_calls}))}getAgentMessages(e){return this.messages.filter(t=>t.agent===e)}getAgentStats(){return new Map(this.agentMessageCounts)}getTotalTokens(){return this.totalTokens}getMessageCount(){return this.messages.length}clear(){let e=this.messages[0];this.messages=[e],this.totalTokens=e.tokenEstimate,this.agentMessageCounts.clear()}updateSystemPrompt(e){let t=En(e),s=this.messages.filter(r=>r.priority==="critical"&&r.role!=="system");this.messages=[{id:ls(),role:"system",content:e,timestamp:Date.now(),priority:"critical",tokenEstimate:t,compressed:!1,tags:["system"]},...s],this.recalculateTokens()}takeSnapshot(e){let t={id:`snap_${Date.now()}`,timestamp:Date.now(),messages:this.messages.map(s=>({...s})),systemPrompt:this.messages[0]?.content||"",label:e};return this.snapshots.push(t),this.snapshots.length>10&&(this.snapshots=this.snapshots.slice(-10)),t.id}rollback(e){let t=this.snapshots.find(s=>s.id===e);return t?(this.messages=t.messages.map(s=>({...s})),this.recalculateTokens(),!0):!1}getSnapshots(){return[...this.snapshots]}fork(e,t){let s=this.messages.length,r=new n(t,this.maxMessages,this.maxTokens),i=this.messages.filter(o=>o.priority==="critical"||o.priority==="high").filter(o=>o.role!=="system").slice(-5);for(let o of i)o.role==="user"?r.addUserMessage(o.content,{priority:o.priority,tags:[...o.tags,"inherited"]}):o.role==="assistant"&&r.addAssistantMessage(o.content,o.tool_calls,o.agent);return this.forks.set(e,{parentSessionId:this.sessionId,forkPoint:s,session:r}),r}mergeFork(e,t){let s=this.forks.get(e);if(!s)return!1;let r=s.session.getEnhancedMessages().filter(i=>i.role!=="system").filter(i=>!i.tags.includes("inherited"));if(t)this.addAssistantMessage(`[Agent @${e} result]: ${t}`,void 0,e);else if(r.length>0){let i=r.filter(o=>o.role==="assistant").pop();i&&this.addAssistantMessage(i.content,i.tool_calls,e)}return this.forks.delete(e),!0}getActiveForks(){return Array.from(this.forks.keys())}searchMessages(e){let t=e.toLowerCase();return this.messages.filter(s=>s.content.toLowerCase().includes(t))}getMessagesByTag(e){return this.messages.filter(t=>t.tags.includes(e))}getLastByRole(e,t=1){return this.messages.filter(s=>s.role===e).slice(-t)}trimIfNeeded(){if(this.messages.length<=this.maxMessages&&this.totalTokens<=this.maxTokens)return;let e=this.messages.filter(t=>t.role==="tool"&&!t.compressed&&t.tokenEstimate>200);for(let t of e.slice(0,-3)){if(this.totalTokens<=this.maxTokens&&this.messages.length<=this.maxMessages)break;this.compressMessage(t)}if(this.totalTokens>this.maxTokens||this.messages.length>this.maxMessages){let t=this.messages.filter(s=>s.role==="assistant"&&!s.compressed&&s.priority!=="critical"&&s.tokenEstimate>300);for(let s of t.slice(0,-2)){if(this.totalTokens<=this.maxTokens&&this.messages.length<=this.maxMessages)break;this.compressMessage(s)}}if(this.messages.length>this.maxMessages){let t=this.messages[0],s=this.messages.slice(1),r={critical:3,high:2,normal:1,low:0},i=s.sort((o,a)=>{let l=r[a.priority]-r[o.priority];return l!==0?l:a.timestamp-o.timestamp}).slice(0,this.maxMessages-1);i.sort((o,a)=>o.timestamp-a.timestamp),this.messages=[t,...i],this.recalculateTokens()}}compressMessage(e){let t=e.content.length,s=e.tokenEstimate;e.role==="tool"?e.content=e.content.slice(0,200)+`
|
|
410
410
|
...(compressed from `+t+" chars)":e.content=e.content.slice(0,400)+`
|
|
411
|
-
...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=
|
|
411
|
+
...(compressed from `+t+" chars)",e.compressed=!0,e.originalLength=t,e.tokenEstimate=En(e.content),this.totalTokens-=s-e.tokenEstimate}recalculateTokens(){this.totalTokens=this.messages.reduce((e,t)=>e+t.tokenEstimate,0)}toJSON(){return JSON.stringify({sessionId:this.sessionId,messageCount:this.messages.length,totalTokens:this.totalTokens,messages:this.messages,agentStats:Object.fromEntries(this.agentMessageCounts)},null,2)}fromJSON(e){let t=JSON.parse(e);if(!t.messages||!Array.isArray(t.messages))throw new Error("Invalid session JSON data structure.");this.sessionId=t.sessionId||`session_${Date.now()}`,this.messages=t.messages,this.totalTokens=t.totalTokens||0,this.agentMessageCounts=new Map(Object.entries(t.agentStats||{})),this.recalculateTokens()}getSessionInfo(){return{id:this.sessionId,messages:this.messages.length,tokens:this.totalTokens,agents:Object.fromEntries(this.agentMessageCounts),forks:Array.from(this.forks.keys()),snapshots:this.snapshots.length}}}});var Up,Xe,qe,qp,fr,wa,pS,hS,mS,cs,Kp=N(()=>{"use strict";Up=O(require("readline")),Xe=O(require("fs")),qe=O(require("path")),qp=O(require("os"));vn();fr=qe.join(qp.homedir(),".hablas","history"),wa=500,pS=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"]),hS=new Set(["node_modules",".git","__pycache__",".venv","dist","build",".next",".cache"]),mS=["read ","edit ","write ","delete ","open ","patch "],cs=class{rl;history=[];workingDir;fileCache=[];fileCacheTime=0;constructor(e){this.workingDir=e||process.cwd(),this.loadHistory(),this.rl=this.createReadline()}createReadline(){return Up.createInterface({input:process.stdin,output:process.stdout,terminal:!0,history:this.history,historySize:wa,completer:e=>this.autocomplete(e)})}reinitialize(){this.loadHistory(),this.rl=this.createReadline()}async prompt(e){return new Promise(t=>{process.stdin.isTTY&&process.stdout.write("\r\x1B[K"),this.rl.question(e,s=>{s.trim()&&(this.history.push(s.trim()),this.saveHistory()),t(s)})})}async confirm(e){let t=` ${c.warning("?")} ${e} ${c.muted("[Y/n]")} `;return(await this.prompt(t)).toLowerCase()!=="n"}async confirmDangerous(e){console.log(`
|
|
412
412
|
${c.error("\u26A0")} ${c.error(c.strong(e))}`),console.log(` ${c.muted('This action cannot be undone. Type "yes" to confirm.')}
|
|
413
|
-
`);let t=` ${c.error("\u2192")} `;return(await this.prompt(t)).trim().toLowerCase()==="yes"}close(){this.saveHistory(),this.rl.close()}autocomplete(e){if(e.startsWith("/")){if(e.startsWith("/model ")||e.startsWith("/usemodel "))return[[],e];if(e.startsWith("/mindset ")){let r=["coder","planner","debugger","reviewer"],i=e.slice(9),o=r.filter(a=>a.startsWith(i)).map(a=>"/mindset "+a);return[o.length?o:r.map(a=>"/mindset "+a),e]}if(e.startsWith("/alias ")){let r=["/alias set","/alias del"],i=r.filter(o=>o.startsWith(e));return[i.length?i:r,e]}if(e.startsWith("/plugins ")){let r=["/plugins enable","/plugins disable"],i=r.filter(o=>o.startsWith(e));return[i.length?i:r,e]}let s=no.filter(r=>r.startsWith(e));return[s.length?s:no,e]}for(let s of mS)if(e.toLowerCase().includes(s)){let r=e.split(s).pop()??"";if(r&&!r.includes(" "))try{let i=qe.dirname(r)||".",o=qe.basename(r),a=qe.resolve(this.workingDir,i),l=Xe.readdirSync(a).filter(u=>u.startsWith(o)).slice(0,8).map(u=>e.slice(0,e.lastIndexOf(r))+qe.join(i,u));if(l.length)return[l,e]}catch{}}let t=e.match(/#([\w./-]*)$/);if(t){let s=t[1],r=this.getProjectFiles(),i=r.filter(a=>a.toLowerCase().startsWith(s.toLowerCase())).map(a=>e.slice(0,e.length-t[0].length)+"#"+a);return i.length>0?[i,e]:[r.slice(0,20).map(a=>e.slice(0,e.length-t[0].length)+"#"+a),e]}return[[],e]}getProjectFiles(){let e=Date.now();if(this.fileCache.length>0&&e-this.fileCacheTime<1e4)return this.fileCache;let t=[];return this.scanDir(this.workingDir,"",t,3),this.fileCache=t,this.fileCacheTime=e,t}scanDir(e,t,s,r,i=0){if(!(i>=r))try{let o=Xe.readdirSync(e,{withFileTypes:!0});for(let a of o){if(a.name.startsWith(".")||hS.has(a.name))continue;let l=t?`${t}/${a.name}`:a.name;if(a.isDirectory())this.scanDir(qe.join(e,a.name),l,s,r,i+1);else{let u=qe.extname(a.name).toLowerCase();(pS.has(u)||a.name==="Dockerfile"||a.name==="Makefile")&&s.push(l)}}}catch{}}loadHistory(){try{if(Xe.existsSync(
|
|
414
|
-
`).filter(Boolean).slice(-wa)}}catch{}}saveHistory(){try{let e=qe.dirname(
|
|
415
|
-
`),"utf-8")}catch{}}}});function Ze(n={}){let e={};if(ot.existsSync(xa))try{let s=ot.readFileSync(xa,"utf-8");e=JSON.parse(s)}catch{}let t={...
|
|
413
|
+
`);let t=` ${c.error("\u2192")} `;return(await this.prompt(t)).trim().toLowerCase()==="yes"}close(){this.saveHistory(),this.rl.close()}autocomplete(e){if(e.startsWith("/")){if(e.startsWith("/model ")||e.startsWith("/usemodel "))return[[],e];if(e.startsWith("/mindset ")){let r=["coder","planner","debugger","reviewer"],i=e.slice(9),o=r.filter(a=>a.startsWith(i)).map(a=>"/mindset "+a);return[o.length?o:r.map(a=>"/mindset "+a),e]}if(e.startsWith("/alias ")){let r=["/alias set","/alias del"],i=r.filter(o=>o.startsWith(e));return[i.length?i:r,e]}if(e.startsWith("/plugins ")){let r=["/plugins enable","/plugins disable"],i=r.filter(o=>o.startsWith(e));return[i.length?i:r,e]}let s=no.filter(r=>r.startsWith(e));return[s.length?s:no,e]}for(let s of mS)if(e.toLowerCase().includes(s)){let r=e.split(s).pop()??"";if(r&&!r.includes(" "))try{let i=qe.dirname(r)||".",o=qe.basename(r),a=qe.resolve(this.workingDir,i),l=Xe.readdirSync(a).filter(u=>u.startsWith(o)).slice(0,8).map(u=>e.slice(0,e.lastIndexOf(r))+qe.join(i,u));if(l.length)return[l,e]}catch{}}let t=e.match(/#([\w./-]*)$/);if(t){let s=t[1],r=this.getProjectFiles(),i=r.filter(a=>a.toLowerCase().startsWith(s.toLowerCase())).map(a=>e.slice(0,e.length-t[0].length)+"#"+a);return i.length>0?[i,e]:[r.slice(0,20).map(a=>e.slice(0,e.length-t[0].length)+"#"+a),e]}return[[],e]}getProjectFiles(){let e=Date.now();if(this.fileCache.length>0&&e-this.fileCacheTime<1e4)return this.fileCache;let t=[];return this.scanDir(this.workingDir,"",t,3),this.fileCache=t,this.fileCacheTime=e,t}scanDir(e,t,s,r,i=0){if(!(i>=r))try{let o=Xe.readdirSync(e,{withFileTypes:!0});for(let a of o){if(a.name.startsWith(".")||hS.has(a.name))continue;let l=t?`${t}/${a.name}`:a.name;if(a.isDirectory())this.scanDir(qe.join(e,a.name),l,s,r,i+1);else{let u=qe.extname(a.name).toLowerCase();(pS.has(u)||a.name==="Dockerfile"||a.name==="Makefile")&&s.push(l)}}}catch{}}loadHistory(){try{if(Xe.existsSync(fr)){let e=Xe.readFileSync(fr,"utf-8");this.history=e.split(`
|
|
414
|
+
`).filter(Boolean).slice(-wa)}}catch{}}saveHistory(){try{let e=qe.dirname(fr);Xe.existsSync(e)||Xe.mkdirSync(e,{recursive:!0});let t=this.history.slice(-wa);Xe.writeFileSync(fr,t.join(`
|
|
415
|
+
`),"utf-8")}catch{}}}});function Ze(n={}){let e={};if(ot.existsSync(xa))try{let s=ot.readFileSync(xa,"utf-8");e=JSON.parse(s)}catch{}let t={...Dn,...e,tools:{...Dn.tools,...e.tools||{}},ui:{...Dn.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=rn.resolve(n.project)),n.provider){let s=n.provider;(s==="ollama"||s==="custom")&&(t.provider=s)}return n.apiUrl&&(t.apiUrl=n.apiUrl),n.apiKey&&(t.apiKey=n.apiKey),n.team&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.enabled=!0),n.user&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.user=n.user),n.teamKey&&(t.team||(t.team={enabled:!1,user:"",key:""}),t.team.key=n.teamKey),t.apiUrl&&t.provider==="ollama"&&(t.provider="custom"),t}function gt(n){ot.existsSync(Tn)||ot.mkdirSync(Tn,{recursive:!0}),ot.writeFileSync(xa,JSON.stringify(n,null,2),"utf-8")}function Gp(){let n=[Tn,rn.join(Tn,"logs"),rn.join(Tn,"backup")];for(let e of n)ot.existsSync(e)||ot.mkdirSync(e,{recursive:!0})}var ot,rn,Wp,Tn,xa,pr=N(()=>{"use strict";ot=O(require("fs")),rn=O(require("path")),Wp=O(require("os"));Nn();Tn=rn.join(Wp.homedir(),".hablas"),xa=rn.join(Tn,"config.json")});var us,Sa=N(()=>{"use strict";us=class{mindsets=new Map;activeMindset="planner";history=[];lastActivatedAt=Date.now();listeners=[];register(e){this.mindsets.set(e.name,e)}get(e){return this.mindsets.get(e)}list(){return Array.from(this.mindsets.values())}listNames(){return Array.from(this.mindsets.keys())}getActive(){return this.mindsets.get(this.activeMindset)}getActiveName(){return this.activeMindset}setActive(e){if(!this.mindsets.has(e))return!1;if(this.activeMindset===e)return!0;let t=this.activeMindset;if(this.history.length>0){let s=this.history[this.history.length-1];s.duration=Date.now()-this.lastActivatedAt}this.activeMindset=e,this.lastActivatedAt=Date.now(),this.history.push({name:e,timestamp:Date.now()}),this.history.length>50&&(this.history=this.history.slice(-50));for(let s of this.listeners)try{s(t,e)}catch{}return!0}has(e){return this.mindsets.has(e)}getHistory(){return[...this.history]}getMostUsed(){let e={};for(let s of this.history)e[s.name]=(e[s.name]||0)+1;let t=Object.entries(e).sort((s,r)=>r[1]-s[1]);return t.length>0?t[0][0]:null}onChange(e){this.listeners.push(e)}createComposite(e,t,s){let r=this.mindsets.get(t),i=this.mindsets.get(s);if(!r||!i)return null;let o={name:e,description:`${r.description} + ${i.description}`,systemPrompt:r.systemPrompt+`
|
|
416
416
|
|
|
417
417
|
`+i.systemPrompt,toolPreferences:[...new Set([...i.toolPreferences,...r.toolPreferences])],behaviorModifiers:{...r.behaviorModifiers,...i.behaviorModifiers}};return this.register(o),o}}});var _a,Aa=N(()=>{"use strict";_a={name:"coder",description:"Expert coding assistant \u2014 direct file operations, precise edits, production-quality code",systemPrompt:`You are Alex, the Engineer on the Hablas multi-agent team. You are an expert full-stack developer.
|
|
418
418
|
|
|
@@ -488,7 +488,7 @@ Then execute step by step.
|
|
|
488
488
|
|
|
489
489
|
## Important
|
|
490
490
|
Never output tool calls as text or JSON in your response.
|
|
491
|
-
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 Ea
|
|
491
|
+
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 Ca,Ea=N(()=>{"use strict";Ca={name:"reviewer",description:"Code reviewer \u2014 quality audit, anti-patterns, security issues, performance bottlenecks",systemPrompt:`You are an expert code reviewer. You audit code quality and provide actionable feedback.
|
|
492
492
|
|
|
493
493
|
## Review Checklist
|
|
494
494
|
- Security vulnerabilities (injection, XSS, CSRF, auth bypass)
|
|
@@ -705,34 +705,34 @@ Your absolute priority is to ensure smooth, conflict-free collaboration between
|
|
|
705
705
|
|
|
706
706
|
## Important
|
|
707
707
|
Never output tool calls as text or JSON in your response.
|
|
708
|
-
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
|
|
709
|
-
`)}}});var Le,
|
|
708
|
+
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 hr(){let n=new us;return n.register(_a),n.register(ka),n.register(Ca),n.register(Ta),n.register(Pa),n.register(Ia),n.register(La),n.register(Na),n.register(ja),n}var Ba=N(()=>{"use strict";Sa();Aa();$a();Ea();Ra();Oa();Ma();Da();Fa();Ha();Sa();Aa();$a();Ea();Ra();Oa();Ma();Da();Fa();Ha()});var mr,Vp=N(()=>{"use strict";mr=class{tasks=[];nextId=1;add(e){let t={id:this.nextId++,description:e,status:"pending",createdAt:Date.now()};return this.tasks.push(t),t}addBatch(e){return e.map(t=>this.add(t))}next(){return this.tasks.find(e=>e.status==="pending")}start(e){let t=this.tasks.find(s=>s.id===e);t&&(t.status="running")}complete(e,t){let s=this.tasks.find(r=>r.id===e);s&&(s.status="done",s.result=t,s.completedAt=Date.now())}fail(e,t){let s=this.tasks.find(r=>r.id===e);s&&(s.status="failed",s.error=t,s.completedAt=Date.now())}skip(e){let t=this.tasks.find(s=>s.id===e);t&&(t.status="skipped",t.completedAt=Date.now())}getAll(){return[...this.tasks]}getProgress(){let e=this.tasks.length,t=this.tasks.filter(o=>o.status==="done").length,s=this.tasks.filter(o=>o.status==="failed").length,r=this.tasks.filter(o=>o.status==="pending").length,i=this.tasks.filter(o=>o.status==="running").length;return{total:e,done:t,failed:s,pending:r,running:i}}isComplete(){return this.tasks.every(e=>e.status==="done"||e.status==="failed"||e.status==="skipped")}clear(){this.tasks=[],this.nextId=1}render(){if(this.tasks.length===0)return" No tasks in queue";let e={pending:"\u25CB",running:"\u25C9",done:"\u2713",failed:"\u2717",skipped:"\u2013"},t=this.tasks.map(r=>{let i=e[r.status],o=r.completedAt?` (${Math.round((r.completedAt-r.createdAt)/1e3)}s)`:"";return` ${i} ${r.id}. ${r.description}${o}`}),s=this.getProgress();return t.push(""),t.push(` Progress: ${s.done}/${s.total} done`+(s.failed>0?`, ${s.failed} failed`:"")),t.join(`
|
|
709
|
+
`)}}});var Le,gr,zp,Yp,Rn,ds,Jp=N(()=>{"use strict";Le=O(require("fs")),gr=O(require("path")),zp=O(require("os")),Yp=O(require("crypto")),Rn=gr.join(zp.homedir(),".hablas","memory"),ds=class{entries=new Map;agentLanes=new Map;projectHash;filePath;agentLanesPath;constructor(e){this.projectHash=Yp.createHash("md5").update(e).digest("hex").slice(0,12),this.filePath=gr.join(Rn,`${this.projectHash}.json`),this.agentLanesPath=gr.join(Rn,`${this.projectHash}_agents.json`),this.load()}set(e,t,s){let r=this.entries.get(e),i=Date.now(),o=s?.category||"note";this.entries.set(e,{key:e,value:t,category:o,importance:s?.importance??this.autoImportance(o,t),createdBy:s?.createdBy||"hablas",accessCount:r?.accessCount??0,useCount:r?.useCount??0,tags:s?.tags||this.autoTag(t,o),relatedFiles:s?.relatedFiles||this.extractFileRefs(t),createdAt:r?.createdAt??i,updatedAt:i,lastAccessedAt:i,consolidatedFrom:r?.consolidatedFrom}),this.save()}get(e){let t=this.entries.get(e);return t&&(t.accessCount++,t.lastAccessedAt=Date.now()),t?.value}getEntry(e){return this.entries.get(e)}markUsed(e){let t=this.entries.get(e);t&&(t.useCount++,t.importance=Math.min(10,t.importance+.5))}delete(e){let t=this.entries.delete(e);return t&&this.save(),t}setAgentMemory(e,t,s,r="agent-learning"){let i=this.agentLanes.get(e);i||(i=new Map,this.agentLanes.set(e,i));let o=Date.now(),a=i.get(t);i.set(t,{key:t,value:s,category:r,importance:this.autoImportance(r,s),createdBy:e,accessCount:a?.accessCount??0,useCount:a?.useCount??0,tags:this.autoTag(s,r),relatedFiles:this.extractFileRefs(s),createdAt:a?.createdAt??o,updatedAt:o,lastAccessedAt:o}),this.saveAgentLanes()}getAgentMemories(e){let t=this.agentLanes.get(e);return t?Array.from(t.values()):[]}getAgentMemorySummary(e,t=10){let s=this.getAgentMemories(e),r=this.getAll().filter(a=>a.importance>=5||a.useCount>=2),i=[...s,...r].sort((a,l)=>{let u=a.importance*(1+a.useCount*.3);return l.importance*(1+l.useCount*.3)-u}).slice(0,t);return i.length===0?"":`## Agent Memory
|
|
710
710
|
`+i.map(a=>`- [${a.category}${a.importance>=7?" \u2605":""}] ${a.key}: ${a.value}`).join(`
|
|
711
711
|
`)}search(e,t){let s=e.toLowerCase(),r=s.split(/\s+/).filter(l=>l.length>2),i=t?.maxResults||20,o=[],a=t?.agent?this.getAgentMemories(t.agent):this.getAll();for(let l of a){if(t?.category&&l.category!==t.category||t?.minImportance&&l.importance<t.minImportance)continue;let u=0,d="partial";l.key.toLowerCase()===s&&(u+=10,d="exact"),l.key.toLowerCase().includes(s)&&(u+=5),l.value.toLowerCase().includes(s)&&(u+=3);for(let h of r)l.key.toLowerCase().includes(h)&&(u+=2),l.value.toLowerCase().includes(h)&&(u+=1),l.tags.some(m=>m.toLowerCase().includes(h))&&(u+=2,d=d==="exact"?"exact":"tag");u*=1+l.importance*.1,u*=1+l.useCount*.2;let f=(Date.now()-l.updatedAt)/(10080*60*1e3);u*=Math.max(.3,1-f*.1),u>.5&&o.push({entry:l,relevanceScore:u,matchType:d})}return o.sort((l,u)=>u.relevanceScore-l.relevanceScore).slice(0,i)}getAll(e){let t=Array.from(this.entries.values());return e?t.filter(s=>s.category===e):t}getByFile(e){return Array.from(this.entries.values()).filter(t=>t.relatedFiles.some(s=>s.includes(e)||e.includes(s)))}getTopMemories(e=15){return Array.from(this.entries.values()).sort((t,s)=>{let r=t.importance*(1+t.useCount*.3)*(1+Math.log1p(t.accessCount)*.1);return s.importance*(1+s.useCount*.3)*(1+Math.log1p(s.accessCount)*.1)-r}).slice(0,e)}getSummary(){let e=this.getTopMemories(15);if(e.length===0)return"";let t={};for(let r of e){let i=r.category;t[i]||(t[i]=[]),t[i].push(`${r.key}: ${r.value}`)}let s=["## Project Memory"];for(let[r,i]of Object.entries(t)){s.push(`### ${r}`);for(let o of i)s.push(`- ${o}`)}return s.join(`
|
|
712
712
|
`)}getStats(){let e=this.getAll(),t={},s={};for(let r of e)t[r.category]=(t[r.category]||0)+1,s[r.createdBy]=(s[r.createdBy]||0)+1;return{totalEntries:e.length,byCategory:t,byAgent:s,topAccessed:e.sort((r,i)=>i.accessCount-r.accessCount).slice(0,5),recentlyAdded:e.sort((r,i)=>i.createdAt-r.createdAt).slice(0,5),totalAccessCount:e.reduce((r,i)=>r+i.accessCount,0)}}consolidate(e=200){if(this.entries.size<=e)return 0;let t=Array.from(this.entries.values()).filter(o=>o.importance<4&&o.accessCount<3).sort((o,a)=>o.updatedAt-a.updatedAt),s=t.slice(0,Math.max(10,t.length-e)),r={};for(let o of s){let a=o.category;r[a]||(r[a]=[]),r[a].push(o)}let i=0;for(let[o,a]of Object.entries(r)){if(a.length<2)continue;let l=`[consolidated] ${o} (${a.length} items)`,u=a.map(h=>`${h.key}: ${h.value}`).join("; "),d=a.map(h=>h.key);this.set(l,u.slice(0,500),{category:o,importance:3,tags:["consolidated"]});let f=this.entries.get(l);f&&(f.consolidatedFrom=d);for(let h of a)this.entries.delete(h.key),i++}return i>0&&this.save(),i}learnFromToolResult(e,t,s,r,i="hablas"){if(!(s.length<20)){if(!r){let o=`error:${e}:${JSON.stringify(t).slice(0,50)}`,a=this.entries.get(o);a?(a.useCount++,a.importance=Math.min(10,a.importance+1)):this.set(o,`${e} failed with: ${s.slice(0,200)}`,{category:"error",importance:6,createdBy:i,tags:["auto-learned","error",e]})}if(e==="list_dir"&&r){let o=t.path||".";this.set(`structure:${o}`,s.slice(0,300),{category:"pattern",importance:3,createdBy:i,tags:["auto-learned","structure"],relatedFiles:[o]})}}}size(){return this.entries.size}clear(){this.entries.clear(),this.agentLanes.clear(),this.save(),this.saveAgentLanes()}render(){if(this.getAll().length===0)return" No project memories stored";let t={convention:"\u{1F4CF}",decision:"\u{1F3AF}",pattern:"\u{1F504}",note:"\u{1F4DD}",error:"\u26A0\uFE0F","tool-result":"\u{1F527}","user-pref":"\u{1F464}",dependency:"\u{1F4E6}",performance:"\u26A1",security:"\u{1F512}",api:"\u{1F310}","agent-learning":"\u{1F916}"};return this.getTopMemories(20).map(i=>{let o=t[i.category]||"\xB7",a=i.importance>=7?" \u2605":"",l=i.useCount>0?` (used ${i.useCount}\xD7)`:"";return` ${o}${a} ${i.key}: ${i.value}${l}`}).join(`
|
|
713
|
-
`)}autoImportance(e,t){let r={convention:6,decision:8,pattern:5,note:3,error:7,"tool-result":2,"user-pref":7,dependency:4,performance:5,security:9,api:6,"agent-learning":4}[e]||3;return/\b(important|critical|must|always|never|danger|warning|breaking)\b/i.test(t)&&(r=Math.min(10,r+2)),r}autoTag(e,t){let s=[t];return/\b(react|vue|angular|svelte|next|nuxt)\b/i.test(e)&&s.push("frontend"),/\b(express|fastify|nest|koa|hapi)\b/i.test(e)&&s.push("backend"),/\b(postgres|mysql|mongo|redis|sqlite)\b/i.test(e)&&s.push("database"),/\b(docker|kubernetes|k8s|ci\/cd|deploy)\b/i.test(e)&&s.push("devops"),/\b(test|jest|vitest|cypress|playwright)\b/i.test(e)&&s.push("testing"),/\b(auth|jwt|oauth|session|token)\b/i.test(e)&&s.push("auth"),/\b(api|endpoint|route|rest|graphql)\b/i.test(e)&&s.push("api"),s}extractFileRefs(e){let t=/[\w\-./]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|sql|sh|toml|xml|env)/gi,s=e.match(t);return s?[...new Set(s)]:[]}load(){try{if(Le.existsSync(this.filePath)){let e=JSON.parse(Le.readFileSync(this.filePath,"utf-8"));if(Array.isArray(e))for(let t of e)t.importance||(t.importance=3),t.createdBy||(t.createdBy="hablas"),t.accessCount||(t.accessCount=0),t.useCount||(t.useCount=0),t.tags||(t.tags=[t.category||"note"]),t.relatedFiles||(t.relatedFiles=[]),t.lastAccessedAt||(t.lastAccessedAt=t.updatedAt||Date.now()),this.entries.set(t.key,t)}}catch{}this.loadAgentLanes()}save(){try{Le.existsSync(
|
|
713
|
+
`)}autoImportance(e,t){let r={convention:6,decision:8,pattern:5,note:3,error:7,"tool-result":2,"user-pref":7,dependency:4,performance:5,security:9,api:6,"agent-learning":4}[e]||3;return/\b(important|critical|must|always|never|danger|warning|breaking)\b/i.test(t)&&(r=Math.min(10,r+2)),r}autoTag(e,t){let s=[t];return/\b(react|vue|angular|svelte|next|nuxt)\b/i.test(e)&&s.push("frontend"),/\b(express|fastify|nest|koa|hapi)\b/i.test(e)&&s.push("backend"),/\b(postgres|mysql|mongo|redis|sqlite)\b/i.test(e)&&s.push("database"),/\b(docker|kubernetes|k8s|ci\/cd|deploy)\b/i.test(e)&&s.push("devops"),/\b(test|jest|vitest|cypress|playwright)\b/i.test(e)&&s.push("testing"),/\b(auth|jwt|oauth|session|token)\b/i.test(e)&&s.push("auth"),/\b(api|endpoint|route|rest|graphql)\b/i.test(e)&&s.push("api"),s}extractFileRefs(e){let t=/[\w\-./]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|sql|sh|toml|xml|env)/gi,s=e.match(t);return s?[...new Set(s)]:[]}load(){try{if(Le.existsSync(this.filePath)){let e=JSON.parse(Le.readFileSync(this.filePath,"utf-8"));if(Array.isArray(e))for(let t of e)t.importance||(t.importance=3),t.createdBy||(t.createdBy="hablas"),t.accessCount||(t.accessCount=0),t.useCount||(t.useCount=0),t.tags||(t.tags=[t.category||"note"]),t.relatedFiles||(t.relatedFiles=[]),t.lastAccessedAt||(t.lastAccessedAt=t.updatedAt||Date.now()),this.entries.set(t.key,t)}}catch{}this.loadAgentLanes()}save(){try{Le.existsSync(Rn)||Le.mkdirSync(Rn,{recursive:!0});let e=Array.from(this.entries.values());Le.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf-8")}catch{}}loadAgentLanes(){try{if(Le.existsSync(this.agentLanesPath)){let e=JSON.parse(Le.readFileSync(this.agentLanesPath,"utf-8"));for(let[t,s]of Object.entries(e)){let r=new Map;for(let i of s)r.set(i.key,i);this.agentLanes.set(t,r)}}}catch{}}saveAgentLanes(){try{Le.existsSync(Rn)||Le.mkdirSync(Rn,{recursive:!0});let e={};for(let[t,s]of this.agentLanes)e[t]=Array.from(s.values());Le.writeFileSync(this.agentLanesPath,JSON.stringify(e,null,2),"utf-8")}catch{}}}});var qa=j((eR,Zp)=>{"use strict";var fs=n=>n&&typeof n.message=="string",Ua=n=>{if(!n)return;let e=n.cause;if(typeof e=="function"){let t=n.cause();return fs(t)?t:void 0}else return fs(e)?e:void 0},Qp=(n,e)=>{if(!fs(n))return"";let t=n.stack||"";if(e.has(n))return t+`
|
|
714
714
|
causes have become circular...`;let s=Ua(n);return s?(e.add(n),t+`
|
|
715
|
-
caused by: `+Jp(s,e)):t},gS=n=>Jp(n,new Set),Qp=(n,e,t)=>{if(!ps(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=Ua(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+Qp(r,e,i)}else return s},yS=n=>Qp(n,new Set);Xp.exports={isErrorLike:ps,getErrorCause:Ua,stackWithCauses:gS,messageWithCauses:yS}});var Ka=j((tR,eh)=>{"use strict";var bS=Symbol("circular-ref-tag"),br=Symbol("pino-raw-err-ref"),Zp=Object.create({},{type:{enumerable:!0,writable:!0,value:void 0},message:{enumerable:!0,writable:!0,value:void 0},stack:{enumerable:!0,writable:!0,value:void 0},aggregateErrors:{enumerable:!0,writable:!0,value:void 0},raw:{enumerable:!1,get:function(){return this[br]},set:function(n){this[br]=n}}});Object.defineProperty(Zp,br,{writable:!0,value:{}});eh.exports={pinoErrProto:Zp,pinoErrorSymbols:{seen:bS,rawSymbol:br}}});var sh=j((nR,nh)=>{"use strict";nh.exports=Ga;var{messageWithCauses:vS,stackWithCauses:wS,isErrorLike:th}=qa(),{pinoErrProto:xS,pinoErrorSymbols:SS}=Ka(),{seen:Wa}=SS,{toString:_S}=Object.prototype;function Ga(n){if(!th(n))return n;n[Wa]=void 0;let e=Object.create(xS);e.type=_S.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=vS(n),e.stack=wS(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>Ga(t)));for(let t in n)if(e[t]===void 0){let s=n[t];th(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,Wa)&&(e[t]=Ga(s)):e[t]=s}return delete n[Wa],e.raw=n,e}});var ih=j((sR,rh)=>{"use strict";rh.exports=wr;var{isErrorLike:Va}=qa(),{pinoErrProto:AS,pinoErrorSymbols:kS}=Ka(),{seen:vr}=kS,{toString:$S}=Object.prototype;function wr(n){if(!Va(n))return n;n[vr]=void 0;let e=Object.create(AS);e.type=$S.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=n.message,e.stack=n.stack,Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>wr(t))),Va(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,vr)&&(e.cause=wr(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];Va(s)?Object.prototype.hasOwnProperty.call(s,vr)||(e[t]=wr(s)):e[t]=s}return delete n[vr],e.raw=n,e}});var ch=j((rR,lh)=>{"use strict";lh.exports={mapHttpRequest:ES,reqSerializer:ah};var za=Symbol("pino-raw-req-ref"),oh=Object.create({},{id:{enumerable:!0,writable:!0,value:""},method:{enumerable:!0,writable:!0,value:""},url:{enumerable:!0,writable:!0,value:""},query:{enumerable:!0,writable:!0,value:""},params:{enumerable:!0,writable:!0,value:""},headers:{enumerable:!0,writable:!0,value:{}},remoteAddress:{enumerable:!0,writable:!0,value:""},remotePort:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[za]},set:function(n){this[za]=n}}});Object.defineProperty(oh,za,{writable:!0,value:{}});function ah(n){let e=n.info||n.socket,t=Object.create(oh);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 ES(n){return{req:ah(n)}}});var ph=j((iR,fh)=>{"use strict";fh.exports={mapHttpResponse:CS,resSerializer:dh};var Ya=Symbol("pino-raw-res-ref"),uh=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[Ya]},set:function(n){this[Ya]=n}}});Object.defineProperty(uh,Ya,{writable:!0,value:{}});function dh(n){let e=Object.create(uh);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function CS(n){return{res:dh(n)}}});var Qa=j((oR,hh)=>{"use strict";var Ja=sh(),TS=ih(),xr=ch(),Sr=ph();hh.exports={err:Ja,errWithCause:TS,mapHttpRequest:xr.mapHttpRequest,mapHttpResponse:Sr.mapHttpResponse,req:xr.reqSerializer,res:Sr.resSerializer,wrapErrorSerializer:function(e){return e===Ja?e:function(s){return e(Ja(s))}},wrapRequestSerializer:function(e){return e===xr.reqSerializer?e:function(s){return e(xr.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===Sr.resSerializer?e:function(s){return e(Sr.resSerializer(s))}}}});var Xa=j((aR,mh)=>{"use strict";function RS(n,e){return e}mh.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=RS;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 xh=j((lR,wh)=>{"use strict";function Za(n){if(n===null||typeof n!="object")return n;if(n instanceof Date)return new Date(n.getTime());if(n instanceof Array){let e=[];for(let t=0;t<n.length;t++)e[t]=Za(n[t]);return e}if(typeof n=="object"){let e=Object.create(Object.getPrototypeOf(n));for(let t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=Za(n[t]));return e}return n}function gh(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 yh(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 bh(n,e){let t=n;for(let r=0;r<e.length-1;r++){let i=e[r];if(typeof t!="object"||t===null||!(i in t)||typeof t[i]!="object"||t[i]===null)return!1;t=t[i]}let s=e[e.length-1];if(s==="*"){if(Array.isArray(t))for(let r=0;r<t.length;r++)t[r]=void 0;else if(typeof t=="object"&&t!==null)for(let r in t)Object.prototype.hasOwnProperty.call(t,r)&&delete t[r]}else typeof t=="object"&&t!==null&&s in t&&Object.prototype.hasOwnProperty.call(t,s)&&delete t[s];return!0}var _r=Symbol("PATH_NOT_FOUND");function PS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return _r;t=t[s]}return t}function OS(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 IS(n,e,t,s=!1){for(let r of e){let i=gh(r);if(i.includes("*"))vh(n,i,t,r,s);else if(s)bh(n,i);else{let o=PS(n,i);if(o===_r)continue;let a=typeof t=="function"?t(o,i):t;yh(n,i,a)}}}function vh(n,e,t,s,r=!1){let i=e.indexOf("*");if(i===e.length-1){let o=e.slice(0,-1),a=n;for(let l of o){if(a==null||typeof a!="object"||a===null)return;a=a[l]}if(Array.isArray(a))if(r)for(let l=0;l<a.length;l++)a[l]=void 0;else for(let l=0;l<a.length;l++){let u=[...o,l.toString()],d=typeof t=="function"?t(a[l],u):t;a[l]=d}else if(typeof a=="object"&&a!==null)if(r){let l=[];for(let u in a)Object.prototype.hasOwnProperty.call(a,u)&&l.push(u);for(let u of l)delete a[u]}else for(let l in a){let u=[...o,l],d=typeof t=="function"?t(a[l],u):t;a[l]=d}}else MS(n,e,t,i,s,r)}function MS(n,e,t,s,r,i=!1){let o=e.slice(0,s),a=e.slice(s+1),l=[];function u(d,f){if(f===o.length){if(Array.isArray(d))for(let h=0;h<d.length;h++)l[f]=h.toString(),u(d[h],f+1);else if(typeof d=="object"&&d!==null)for(let h in d)l[f]=h,u(d[h],f+1)}else if(f<o.length){let h=o[f];d&&typeof d=="object"&&d!==null&&h in d&&(l[f]=h,u(d[h],f+1))}else if(a.includes("*"))vh(d,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)bh(d,a);else{let h=typeof t=="function"?t(OS(d,a),[...l.slice(0,f),...a]):t;yh(d,a,h)}}if(o.length===0)u(n,0);else{let d=n;for(let f=0;f<o.length;f++){let h=o[f];if(d==null||typeof d!="object"||d===null)return;d=d[h],l[f]=h}d!=null&&u(d,o.length)}}function LS(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=gh(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 DS(n,e){if(!e)return n;function t(s,r,i=0){if(!r||r.size===0||s===null||typeof s!="object")return s;if(s instanceof Date)return new Date(s.getTime());if(Array.isArray(s)){let a=[];for(let l=0;l<s.length;l++){let u=l.toString();r.has(u)||r.has("*")?a[l]=t(s[l],r.get(u)||r.get("*")):a[l]=s[l]}return a}let o=Object.create(Object.getPrototypeOf(s));for(let a in s)Object.prototype.hasOwnProperty.call(s,a)&&(r.has(a)||r.has("*")?o[a]=t(s[a],r.get(a)||r.get("*")):o[a]=s[a]);return o}return t(n,e)}function NS(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 FS(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)NS(e)}function jS(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;FS(e);let o=LS(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let u=DS(l,o),d=l,f=t;return typeof t=="function"&&(f=t),IS(u,e,f,i),s===!1?(u.restore=function(){return Za(d)},u):typeof s=="function"?s(u):JSON.stringify(u)}}wh.exports=jS});var On=j((cR,Sh)=>{"use strict";var HS=Symbol("pino.setLevel"),BS=Symbol("pino.getLevel"),US=Symbol("pino.levelVal"),qS=Symbol("pino.levelComp"),KS=Symbol("pino.useLevelLabels"),WS=Symbol("pino.useOnlyCustomLevels"),GS=Symbol("pino.mixin"),VS=Symbol("pino.lsCache"),zS=Symbol("pino.chindings"),YS=Symbol("pino.asJson"),JS=Symbol("pino.write"),QS=Symbol("pino.redactFmt"),XS=Symbol("pino.time"),ZS=Symbol("pino.timeSliceIndex"),e_=Symbol("pino.stream"),t_=Symbol("pino.stringify"),n_=Symbol("pino.stringifySafe"),s_=Symbol("pino.stringifiers"),r_=Symbol("pino.end"),i_=Symbol("pino.formatOpts"),o_=Symbol("pino.messageKey"),a_=Symbol("pino.errorKey"),l_=Symbol("pino.nestedKey"),c_=Symbol("pino.nestedKeyStr"),u_=Symbol("pino.mixinMergeStrategy"),d_=Symbol("pino.msgPrefix"),f_=Symbol("pino.wildcardFirst"),p_=Symbol.for("pino.serializers"),h_=Symbol.for("pino.formatters"),m_=Symbol.for("pino.hooks"),g_=Symbol.for("pino.metadata");Sh.exports={setLevelSym:HS,getLevelSym:BS,levelValSym:US,levelCompSym:qS,useLevelLabelsSym:KS,mixinSym:GS,lsCacheSym:VS,chindingsSym:zS,asJsonSym:YS,writeSym:JS,serializersSym:p_,redactFmtSym:QS,timeSym:XS,timeSliceIndexSym:ZS,streamSym:e_,stringifySym:t_,stringifySafeSym:n_,stringifiersSym:s_,endSym:r_,formatOptsSym:i_,messageKeySym:o_,errorKeySym:a_,nestedKeySym:l_,wildcardFirstSym:f_,needsMetadataGsym:g_,useOnlyCustomLevelsSym:WS,formattersSym:h_,hooksSym:m_,nestedKeyStrSym:c_,mixinMergeStrategySym:u_,msgPrefixSym:d_}});var tl=j((uR,$h)=>{"use strict";var _h=xh(),{redactFmtSym:y_,wildcardFirstSym:Ar}=On(),el=/[^.[\]]+|\[([^[\]]*?)\]/g,Ah="[Redacted]",kh=!1;function b_(n,e){let{paths:t,censor:s,remove:r}=v_(n),i=t.reduce((l,u)=>{el.lastIndex=0;let d=el.exec(u),f=el.exec(u),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=Ar),f===null)return l[h]=null,l;if(l[h]===null)return l;let{index:m}=f,p=`${u.substr(m,u.length-1)}`;return l[h]=l[h]||[],h!==Ar&&l[h].length===0&&l[h].push(...l[Ar]||[]),h===Ar&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[y_]:_h({paths:t,censor:s,serialize:e,strict:kh,remove:r})},a=(...l)=>e(typeof s=="function"?s(...l):s);return[...Object.keys(i),...Object.getOwnPropertySymbols(i)].reduce((l,u)=>{if(i[u]===null)l[u]=d=>a(d,[u]);else{let d=typeof s=="function"?(f,h)=>s(f,[u,...h]):s;l[u]=_h({paths:i[u],censor:d,serialize:e,strict:kh,remove:r})}return l},o)}function v_(n){if(Array.isArray(n))return n={paths:n,censor:Ah},n;let{paths:e,censor:t=Ah,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}}$h.exports=b_});var Th=j((dR,Ch)=>{"use strict";var w_=()=>"",x_=()=>`,"time":${Date.now()}`,S_=()=>`,"time":${Math.round(Date.now()/1e3)}`,__=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,A_=1000000n,Eh=1000000000n,k_=BigInt(Date.now())*A_,$_=process.hrtime.bigint(),E_=()=>{let n=process.hrtime.bigint()-$_,e=k_+n,t=e/Eh,s=e%Eh,r=Number(t*1000n+s/1000000n),i=new Date(r),o=i.getUTCFullYear(),a=(i.getUTCMonth()+1).toString().padStart(2,"0"),l=i.getUTCDate().toString().padStart(2,"0"),u=i.getUTCHours().toString().padStart(2,"0"),d=i.getUTCMinutes().toString().padStart(2,"0"),f=i.getUTCSeconds().toString().padStart(2,"0");return`,"time":"${o}-${a}-${l}T${u}:${d}:${f}.${s.toString().padStart(9,"0")}Z"`};Ch.exports={nullTime:w_,epochTime:x_,unixTime:S_,isoTime:__,isoTimeNano:E_}});var Ph=j((fR,Rh)=>{"use strict";function C_(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}Rh.exports=T_;function T_(n,e,t){var s=t&&t.stringify||C_,r=1;if(typeof n=="object"&&n!==null){var i=e.length+r;if(i===1)return n;var o=new Array(i);o[0]=s(n);for(var a=1;a<i;a++)o[a]=s(e[a]);return o.join(" ")}if(typeof n!="string")return n;var l=e.length;if(l===0)return n;for(var u="",d=1-r,f=-1,h=n&&n.length||0,m=0;m<h;){if(n.charCodeAt(m)===37&&m+1<h){switch(f=f>-1?f:0,n.charCodeAt(m+1)){case 100:case 102:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Number(e[d]),f=m+2,m++;break;case 105:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Math.floor(Number(e[d])),f=m+2,m++;break;case 79:case 111:case 106:if(d>=l||e[d]===void 0)break;f<m&&(u+=n.slice(f,m));var p=typeof e[d];if(p==="string"){u+="'"+e[d]+"'",f=m+2,m++;break}if(p==="function"){u+=e[d].name||"<anonymous>",f=m+2,m++;break}u+=s(e[d]),f=m+2,m++;break;case 115:if(d>=l)break;f<m&&(u+=n.slice(f,m)),u+=String(e[d]),f=m+2,m++;break;case 37:f<m&&(u+=n.slice(f,m)),u+="%",f=m+2,m++,d--;break}++d}++m}return f===-1?n:(f<h&&(u+=n.slice(f)),u)}});var sl=j((pR,nl)=>{"use strict";if(typeof SharedArrayBuffer<"u"&&typeof Atomics<"u"){let e=function(t){if((t>0&&t<1/0)===!1)throw typeof t!="number"&&typeof t!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");Atomics.wait(n,0,0,Number(t))},n=new Int32Array(new SharedArrayBuffer(4));nl.exports=e}else{let n=function(e){if((e>0&&e<1/0)===!1)throw typeof e!="number"&&typeof e!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");let s=Date.now()+Number(e);for(;s>Date.now(););};nl.exports=n}});var jh=j((hR,Fh)=>{"use strict";var ue=require("fs"),R_=require("events"),P_=require("util").inherits,Oh=require("path"),il=sl(),O_=require("assert"),kr=100,$r=Buffer.allocUnsafe(0),I_=16*1024,Ih="buffer",Mh="utf8",[M_,L_]=(process.versions.node||"0.0").split(".").map(Number),D_=M_>=22&&L_>=7;function Lh(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&&ue.mkdirSync(Oh.dirname(n),{recursive:!0});let i=ue.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?ue.mkdir(Oh.dirname(n),{recursive:!0},i=>{if(i)return t(i);ue.open(n,s,r,t)}):ue.open(n,s,r,t)}function at(n){if(!(this instanceof at))return new at(n);let{fd:e,dest:t,minLength:s,maxLength:r,maxWrite:i,periodicFlush:o,sync:a,append:l=!0,mkdir:u,retryEAGAIN:d,fsync:f,contentMode:h,mode:m}=n||{};e=e||t,this._len=0,this.fd=-1,this._bufs=[],this._lens=[],this._writing=!1,this._ending=!1,this._reopening=!1,this._asyncDrainScheduled=!1,this._flushPending=!1,this._hwm=Math.max(s||0,16387),this.file=null,this.destroyed=!1,this.minLength=s||0,this.maxLength=r||0,this.maxWrite=i||I_,this._periodicFlush=o||0,this._periodicFlushTimer=void 0,this.sync=a||!1,this.writable=!0,this._fsync=f||!1,this.append=l||!1,this.mode=m,this.retryEAGAIN=d||(()=>!0),this.mkdir=u||!1;let p,g;if(h===Ih)this._writingBuf=$r,this.write=j_,this.flush=B_,this.flushSync=q_,this._actualWrite=W_,p=()=>ue.writeSync(this.fd,this._writingBuf),g=()=>ue.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Mh)this._writingBuf="",this.write=F_,this.flush=H_,this.flushSync=U_,this._actualWrite=K_,p=()=>Buffer.isBuffer(this._writingBuf)?ue.writeSync(this.fd,this._writingBuf):ue.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?ue.write(this.fd,this._writingBuf,this.release):ue.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Mh}" and "${Ih}", but passed ${h}`);if(typeof e=="number")this.fd=e,process.nextTick(()=>this.emit("ready"));else if(typeof e=="string")Lh(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,_)=>{if(x){if((x.code==="EAGAIN"||x.code==="EBUSY")&&this.retryEAGAIN(x,this._writingBuf.length,this._len-this._writingBuf.length))if(this.sync)try{il(kr),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,kr);else this._writing=!1,this.emit("error",x);return}this.emit("write",_);let A=rl(this._writingBuf,this._len,_);if(this._len=A.len,this._writingBuf=A.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),b=rl(this._writingBuf,this._len,y);this._len=b.len,this._writingBuf=b.writingBuf}while(this._writingBuf.length)}catch(y){this.release(y);return}}this._fsync&&ue.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,Er(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(N_,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 rl(n,e,t){return typeof n=="string"&&(n=Buffer.from(n)),e=Math.max(e-t,0),n=n.subarray(t),{writingBuf:n,len:e}}function N_(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}P_(at,R_);function Dh(n,e){return n.length===0?$r:n.length===1?n[0]:Buffer.concat(n,e)}function F_(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 j_(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 Nh(n){this._flushPending=!0;let e=()=>{if(this._fsync)this._flushPending=!1,n();else try{ue.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 H_(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&&Nh.call(this,n),!this._writing&&(this._bufs.length===0&&this._bufs.push(""),this._actualWrite())}function B_(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&&Nh.call(this,n),!this._writing&&(this._bufs.length===0&&(this._bufs.push([]),this._lens.push(0)),this._actualWrite())}at.prototype.reopen=function(n){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.reopen(n)});return}if(this._ending)return;if(!this.file)throw new Error("Unable to reopen a file descriptor, you must pass a file to SonicBoom");if(n&&(this.file=n),this._reopening=!0,this._writing)return;let e=this.fd;this.once("ready",()=>{e!==this.fd&&ue.close(e,t=>{if(t)return this.emit("error",t)})}),Lh(this.file,this)};at.prototype.end=function(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.end()});return}this._ending||(this._ending=!0,!this._writing&&(this._len>0&&this.fd>=0?this._actualWrite():Er(this)))};function U_(){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)?ue.writeSync(this.fd,n):ue.writeSync(this.fd,n,"utf8"),t=rl(n,this._len,e);n=t.writingBuf,this._len=t.len,n.length<=0&&this._bufs.shift()}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(kr)}}try{ue.fsyncSync(this.fd)}catch{}}function q_(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this.fd<0)throw new Error("sonic boom is not ready yet");!this._writing&&this._writingBuf.length>0&&(this._bufs.unshift([this._writingBuf]),this._writingBuf=$r);let n=$r;for(;this._bufs.length||n.length;){n.length<=0&&(n=Dh(this._bufs[0],this._lens[0]));try{let e=ue.writeSync(this.fd,n);n=n.subarray(e),this._len=Math.max(this._len-e,0),n.length<=0&&(this._bufs.shift(),this._lens.shift())}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(kr)}}}at.prototype.destroy=function(){this.destroyed||Er(this)};function K_(){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)?ue.writeSync(this.fd,this._writingBuf):ue.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else ue.write(this.fd,this._writingBuf,n)}function W_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Dh(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=ue.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else D_&&(this._writingBuf=Buffer.from(this._writingBuf)),ue.write(this.fd,this._writingBuf,n)}function Er(n){if(n.fd===-1){n.once("ready",Er.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],O_(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{ue.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?ue.close(n.fd,t):t()}function t(s){if(s){n.emit("error",s);return}n._ending&&!n._writing&&n.emit("finish"),n.emit("close")}}at.SonicBoom=at;at.default=at;Fh.exports=at});var ol=j((mR,Kh)=>{"use strict";var lt={exit:[],beforeExit:[]},Hh={exit:z_,beforeExit:Y_},In;function G_(){In===void 0&&(In=new FinalizationRegistry(J_))}function V_(n){lt[n].length>0||process.on(n,Hh[n])}function Bh(n){lt[n].length>0||(process.removeListener(n,Hh[n]),lt.exit.length===0&<.beforeExit.length===0&&(In=void 0))}function z_(){Uh("exit")}function Y_(){Uh("beforeExit")}function Uh(n){for(let e of lt[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}lt[n]=[]}function J_(n){for(let e of["exit","beforeExit"]){let t=lt[e].indexOf(n);lt[e].splice(t,t+1),Bh(e)}}function qh(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");V_(n);let s=new WeakRef(e);s.fn=t,G_(),In.register(e,s),lt[n].push(s)}function Q_(n,e){qh("exit",n,e)}function X_(n,e){qh("beforeExit",n,e)}function Z_(n){if(In!==void 0){In.unregister(n);for(let e of["exit","beforeExit"])lt[e]=lt[e].filter(t=>{let s=t.deref();return s&&s!==n}),Bh(e)}}Kh.exports={register:Q_,registerBeforeExit:X_,unregister:Z_}});var Wh=j((gR,eA)=>{eA.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 Vh=j((yR,Gh)=>{"use strict";function tA(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{let a=Atomics.load(n,e);if(a===t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,a,l);u.async?u.value.then(o):setImmediate(o)};o()}function nA(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{if(Atomics.load(n,e)!==t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,t,l);u.async?u.value.then(d=>{if(d==="ok"){r(null,"ok");return}o()}):setImmediate(o)};o()}Gh.exports={wait:tA,waitDiff:nA}});var Yh=j((bR,zh)=>{"use strict";zh.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var am=j((vR,om)=>{"use strict";var{version:sA}=Wh(),{EventEmitter:rA}=require("events"),{Worker:iA}=require("worker_threads"),{join:oA}=require("path"),{pathToFileURL:aA}=require("url"),{wait:lA}=Vh(),{WRITE_INDEX:Pt,READ_INDEX:an,SEQ_INDEX:al}=Yh(),cA=require("buffer"),uA=require("assert"),R=Symbol("kImpl"),dA=cA.constants.MAX_STRING_LENGTH;function Jh(){}function dl(n,e){Atomics.add(n[R].state,al,1),e(),Atomics.add(n[R].state,al,1),Atomics.notify(n[R].state,al)}function Qh(n){dl(n,()=>{Atomics.store(n[R].state,an,0),Atomics.store(n[R].state,Pt,0)})}var hs=class{constructor(e){this._value=e}deref(){return this._value}},Cr=class{register(){}unregister(){}},fA=process.env.NODE_V8_COVERAGE?Cr:global.FinalizationRegistry||Cr,pA=process.env.NODE_V8_COVERAGE?hs:global.WeakRef||hs,Xh=new fA(n=>{n.exited||n.terminate()});function hA(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||oA(__dirname,"lib","worker.js"),o=new iA(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:aA(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:sA},...s}}});return o.stream=new hs(n),o.on("message",mA),o.on("exit",tm),Xh.register(n,o),o}function Zh(n){uA(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function em(n){for(;;){let e=Atomics.load(n[R].state,Pt),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?fl(n):n[R].needDrain&&process.nextTick(Zh,n);return}rm(n,t,Jh);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;Tr(n,()=>{n.destroyed||(Qh(n),em(n))});return}et(n,new Error("overwritten"));return}}function mA(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 pA(e),Tr(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":et(e,n.err);break;case"EVENT":Array.isArray(n.args)?e.emit(n.name,...n.args):e.emit(n.name,n.args);break;case"FLUSHED":{if(n.context!=="thread-stream"){et(e,new Error("this should not happen: "+n.code));break}let t=e[R].flushCallbacks.get(n.id);t&&(e[R].flushCallbacks.delete(n.id),process.nextTick(t));break}case"WARNING":process.emitWarning(n.err);break;default:et(e,new Error("this should not happen: "+n.code))}}function tm(n){let e=this.stream.deref();e!==void 0&&(Xh.unregister(e),e.worker.exited=!0,e.worker.off("exit",tm),et(e,n!==0?new Error("the worker thread exited"):null))}var cl=class extends rA{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=hA(this,e),this.on("message",(t,s)=>{this.worker.postMessage(t,s)})}write(e){let t=Buffer.isBuffer(e)?e:Buffer.from(e);if(this[R].destroyed)return ul(this,new Error("the worker has exited")),!1;if(this[R].ending)return ul(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=dA)try{ll(this),this[R].flushing=!0}catch(s){return et(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return ll(this),!0}catch(s){return et(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(em,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,Pt)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,fl(this))}flush(e){e=typeof e=="function"?e:Jh,nm(this,t=>{if(t){process.nextTick(e,t);return}sm(this,e)})}flushSync(){this[R].destroyed||(ll(this),im(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 nm(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(nm,n,e);return}Tr(n,e)}function Tr(n,e){let t=Atomics.load(n[R].state,Pt);lA(n[R].state,an,t,1/0,(s,r)=>{if(s){et(n,s),e(s);return}if(r!=="ok"){Tr(n,e);return}e()})}function sm(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),sm(n,e)},r=()=>{i(),process.nextTick(e,new Error("the worker has exited"))},i=()=>{n.off("ready",s),n.off("close",r)};n.once("ready",s),n.once("close",r);return}let t=++n[R].nextFlushId;n[R].flushCallbacks.set(t,e);try{n.worker.postMessage({code:"FLUSH",context:"thread-stream",id:t})}catch(s){n[R].flushCallbacks.delete(t),et(n,s),process.nextTick(e,s)}}function gA(n,e){let t=n[R].flushCallbacks;if(t.size===0)return;let s=e||new Error("the worker has exited");for(let r of t.values())process.nextTick(r,s);t.clear()}function ul(n,e){setImmediate(()=>{n.emit("error",e)})}function et(n,e){n[R].destroyed||(n[R].destroyed=!0,gA(n,e),e&&(n[R].errored=e,ul(n,e)),n.worker.exited?setImmediate(()=>{n[R].closed=!0,n.emit("close")}):n.worker.terminate().catch(()=>{}).then(()=>{n[R].closed=!0,n.emit("close")}))}function rm(n,e,t){let r=Atomics.load(n[R].state,Pt),i=e;for(;i>0&&n[R].bufLen!==0;){let o=n[R].bufHead,a=n[R].buf[o];if(a.length<=i){a.copy(n[R].data,r),r+=a.length,i-=a.length,n[R].bufLen-=a.length,n[R].bufHead=o+1,n[R].bufHead===n[R].buf.length?(n[R].buf.length=0,n[R].bufHead=0):n[R].bufHead>=1024&&n[R].bufHead*2>=n[R].buf.length&&(n[R].buf.splice(0,n[R].bufHead),n[R].bufHead=0);continue}a.copy(n[R].data,r,0,i),n[R].buf[o]=a.subarray(i),n[R].bufLen-=i,r+=i,i=0}return dl(n,()=>{Atomics.store(n[R].state,Pt,r)}),t(),!0}function fl(n){if(!(n[R].ended||!n[R].ending||n[R].flushing)){n[R].ended=!0;try{n.flushSync();let e=Atomics.load(n[R].state,an);dl(n,()=>{Atomics.store(n[R].state,Pt,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,an,e,1e3),e=Atomics.load(n[R].state,an),e===-2){et(n,new Error("end() failed"));return}if(++t===10){et(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){et(n,e)}}}function ll(n){let e=()=>{n[R].ending?fl(n):n[R].needDrain&&process.nextTick(Zh,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,Pt),s=n[R].data.length-t;if(s===0){im(n),Qh(n);continue}else if(s<0)throw new Error("overwritten");rm(n,s,e)}}function im(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,Pt),t=0;for(;;){let s=Atomics.load(n[R].state,an);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,an,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}om.exports=cl});var ml=j((wR,um)=>{"use strict";var{createRequire:yA}=require("module"),{existsSync:bA}=require("node:fs"),vA=Xa(),{join:pl,isAbsolute:cm,sep:wA}=require("node:path"),{fileURLToPath:xA}=require("node:url"),SA=sl(),hl=ol(),_A=am();function AA(n){hl.register(n,TA),hl.registerBeforeExit(n,RA),n.on("close",function(){hl.unregister(n)})}function kA(){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 $A(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&&lm(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(lm(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function lm(n){let e=EA(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=xA(t)}catch{return!1}return cm(t)&&!bA(t)}function EA(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function CA(n,e,t,s,r){if(!t.execArgv&&kA()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=$A(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new _A({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&&AA(i)}function a(){i.closed||(i.flushSync(),SA(100),i.end())}return i}function TA(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function RA(n){n.flushSync()}function PA(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=vA(),sync:a=!1}=n,l={...n.options},u=typeof o=="string"?[o]:o,d=typeof globalThis=="object"&&Object.prototype.hasOwnProperty.call(globalThis,"__bundlerPathsOverrides")&&globalThis.__bundlerPathsOverrides&&typeof globalThis.__bundlerPathsOverrides=="object"?globalThis.__bundlerPathsOverrides:Object.create(null),f=n.target;if(f&&t)throw new Error("only one of target or targets can be specified");t?(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.targets=t.filter(p=>p.target).map(p=>({...p,target:m(p.target)})),l.pipelines=t.filter(p=>p.pipeline).map(p=>p.pipeline.map(g=>({...g,level:p.level,target:m(g.target)})))):e&&(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.pipelines=[e.map(p=>({...p,target:m(p.target)}))]),s&&(l.levels=s),r&&(l.dedupe=r),l.pinoWillSendConfig=!0;let h=t||e?"pino.transport":f;return CA(m(f),l,i,a,h);function m(p){if(p=d[p]||p,cm(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return pl(__dirname,"..","file.js");let g;for(let x of u)try{let _=x==="node:repl"?process.cwd()+wA:x;g=yA(_).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}um.exports=PA});var Or=j((xR,_m)=>{"use strict";var OA=require("node:diagnostics_channel"),dm=Ph(),{mapHttpRequest:IA,mapHttpResponse:MA}=Qa(),yl=jh(),fm=ol(),{lsCacheSym:LA,chindingsSym:ym,writeSym:pm,serializersSym:bm,formatOptsSym:hm,endSym:DA,stringifiersSym:vm,stringifySym:wm,stringifySafeSym:bl,wildcardFirstSym:xm,nestedKeySym:NA,formattersSym:Sm,messageKeySym:FA,errorKeySym:jA,nestedKeyStrSym:HA,msgPrefixSym:Rr}=On(),{isMainThread:BA}=require("worker_threads"),UA=ml(),[qA]=process.versions.node.split(".").map(n=>Number(n)),mm=OA.tracingChannel("pino_asJson"),gl=qA>=25?n=>JSON.stringify(n):WA;function Mn(){}function KA(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=IA(s):typeof s.setHeader=="function"&&(s=MA(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Rr]=="string"&&i!==void 0&&i!==null&&(i=this[Rr]+i),this[pm](s,dm(i,o,this[hm]),n)}else{let i=s===void 0?r.shift():s;typeof this[Rr]=="string"&&i!==void 0&&i!==null&&(i=this[Rr]+i),this[pm](null,dm(i,r,this[hm]),n)}}}function WA(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 GA(n,e,t,s){if(mm.hasSubscribers===!1)return gm.call(this,n,e,t,s);let r={instance:this,arguments};return mm.traceSync(gm,r,this,n,e,t,s)}function gm(n,e,t,s){let r=this[wm],i=this[bl],o=this[vm],a=this[DA],l=this[ym],u=this[bm],d=this[Sm],f=this[FA],h=this[jA],m=this[LA][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let g=o[xm],x="";for(let A in n)if(p=n[A],Object.prototype.hasOwnProperty.call(n,A)&&p!==void 0){u[A]?p=u[A](p):A===h&&u.err&&(p=u.err(p));let k=o[A]||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||gl)(p);break;default:p=(k||r)(p,i)}if(p===void 0)continue;let y=gl(A);x+=","+y+":"+p}let _="";if(e!==void 0){p=u[f]?u[f](e):e;let A=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":A&&(p=A(p)),_=',"'+f+'":'+p;break;case"string":p=(A||gl)(p),_=',"'+f+'":'+p;break;default:p=(A||r)(p,i),_=',"'+f+'":'+p}}return this[NA]&&x?m+this[HA]+x.slice(1)+"}"+_+a:m+x+_+a}function VA(n,e){let t,s=n[ym],r=n[wm],i=n[bl],o=n[vm],a=o[xm],l=n[bm],u=n[Sm].bindings;e=u(e);for(let d in e)if(t=e[d],((d.length<5||d!=="level"&&d!=="serializers"&&d!=="formatters"&&d!=="customLevels")&&e.hasOwnProperty(d)&&t!==void 0)===!0){if(t=l[d]?l[d](t):t,t=(o[d]||a||r)(t,i),t===void 0)continue;s+=',"'+d+'":'+t}return s}function zA(n){return n.write!==n.constructor.prototype.write}function Pr(n){let e=new yl(n);return e.on("error",t),!n.sync&&BA&&(fm.register(e,YA),e.on("close",function(){fm.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=Mn,e.end=Mn,e.flushSync=Mn,e.destroy=Mn;return}e.removeListener("error",t),e.emit("error",s)}}function YA(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function JA(n){return function(t,s,r={},i){if(typeof r=="string")i=Pr({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=Pr({dest:i})}else if(r instanceof yl||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof yl||r.transport.writable||r.transport._writableState)throw Error("option.transport do not allow stream, please pass to option directly. e.g. pino(transport)");if(r.transport.targets&&r.transport.targets.length&&r.formatters&&typeof r.formatters.level=="function")throw Error("option.transport.targets do not allow custom level formatters");let l;r.customLevels&&(l=r.useOnlyCustomLevels?r.customLevels:Object.assign({},r.levels,r.customLevels)),i=UA({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=Mn),i||(zA(process.stdout)?i=process.stdout:i=Pr({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function QA(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[bl])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function XA(n,e,t){return{level:n,bindings:e,log:t}}function ZA(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}_m.exports={noop:Mn,buildSafeSonicBoom:Pr,asChindings:VA,asJson:GA,genLog:KA,createArgsNormalizer:JA,stringify:QA,buildFormatters:XA,normalizeDestFileDescriptor:ZA}});var Ir=j((SR,Am)=>{var ek={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},tk={ASC:"ASC",DESC:"DESC"};Am.exports={DEFAULT_LEVELS:ek,SORTING_ORDER:tk}});var xl=j((_R,Cm)=>{"use strict";var{lsCacheSym:nk,levelValSym:vl,useOnlyCustomLevelsSym:sk,streamSym:rk,formattersSym:ik,hooksSym:ok,levelCompSym:km}=On(),{noop:ak,genLog:ln}=Or(),{DEFAULT_LEVELS:gt,SORTING_ORDER:$m}=Ir(),Em={fatal:n=>{let e=ln(gt.fatal,n);return function(...t){let s=this[rk];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>ln(gt.error,n),warn:n=>ln(gt.warn,n),info:n=>ln(gt.info,n),debug:n=>ln(gt.debug,n),trace:n=>ln(gt.trace,n)},wl=Object.keys(gt).reduce((n,e)=>(n[gt[e]]=e,n),{}),lk=Object.keys(wl).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function ck(n){let e=n[ik].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[nk]=s,n}function uk(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 dk(n){let{labels:e,values:t}=this.levels;if(typeof n=="number"){if(e[n]===void 0)throw Error("unknown level value"+n);n=e[n]}if(t[n]===void 0)throw Error("unknown level "+n);let s=this[vl],r=this[vl]=t[n],i=this[sk],o=this[km],a=this[ok].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=ak;continue}this[l]=uk(l,i)?Em[l](a):ln(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function fk(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function pk(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[km](t,this[vl])}function hk(n,e,t){return n===$m.DESC?e<=t:e>=t}function mk(n){return typeof n=="string"?hk.bind(null,n):n}function gk(n=null,e=!1){let t=n?Object.keys(n).reduce((i,o)=>(i[n[o]]=o,i),{}):null,s=Object.assign(Object.create(Object.prototype,{Infinity:{value:"silent"}}),e?null:wl,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:gt,n);return{labels:s,values:r}}function yk(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(wl).map(i=>+i),1/0).includes(n))throw Error(`default level:${n} must be included in custom levels`);return}let s=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),t?null:gt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function bk(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 vk(n){if(typeof n!="function"&&!(typeof n=="string"&&Object.values($m).includes(n)))throw new Error('Levels comparison should be one of "ASC", "DESC" or "function" type')}Cm.exports={initialLsCache:lk,genLsCache:ck,levelMethods:Em,getLevel:fk,setLevel:dk,isLevelEnabled:pk,mappings:gk,assertNoLevelCollisions:bk,assertDefaultLevelFound:yk,genLevelComparison:mk,assertLevelComparison:vk}});var Sl=j((AR,Tm)=>{"use strict";Tm.exports={version:"10.3.1"}});var Nm=j(($R,Dm)=>{"use strict";var{EventEmitter:wk}=require("node:events"),{lsCacheSym:xk,levelValSym:Sk,setLevelSym:Al,getLevelSym:Rm,chindingsSym:Lr,mixinSym:_k,asJsonSym:Om,writeSym:Ak,mixinMergeStrategySym:kk,timeSym:$k,timeSliceIndexSym:Ek,streamSym:Im,serializersSym:cn,formattersSym:ms,errorKeySym:Ck,messageKeySym:Tk,useOnlyCustomLevelsSym:Rk,needsMetadataGsym:Pk,redactFmtSym:Ok,stringifySym:Ik,formatOptsSym:Mk,stringifiersSym:Lk,msgPrefixSym:kl,hooksSym:Dk}=On(),{getLevel:Nk,setLevel:Fk,isLevelEnabled:jk,mappings:Hk,initialLsCache:Bk,genLsCache:Uk,assertNoLevelCollisions:qk}=xl(),{asChindings:$l,asJson:Kk,buildFormatters:_l,stringify:Pm,noop:Mm}=Or(),{version:Wk}=Sl(),Gk=tl(),Vk=class{},Lm={constructor:Vk,child:zk,bindings:Yk,setBindings:Jk,flush:Zk,isLevelEnabled:jk,version:Wk,get level(){return this[Rm]()},set level(n){this[Al](n)},get levelVal(){return this[Sk]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[kl]},get[Symbol.toStringTag](){return"Pino"},[xk]:Bk,[Ak]:Xk,[Om]:Kk,[Rm]:Nk,[Al]:Fk};Object.setPrototypeOf(Lm,wk.prototype);Dm.exports=function(){return Object.create(Lm)};var Mr=n=>n;function zk(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[cn],s=this[ms],r=Object.create(this);if(e==null)return r[ms].bindings!==Mr&&(r[ms]=_l(s.level,Mr,s.log)),r[Lr]=$l(r,n),this.onChild!==Mm&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[cn]=Object.create(null);for(let u in t)r[cn][u]=t[u];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let u=a[i];r[cn][u]=t[u]}for(let u in e.serializers)r[cn][u]=e.serializers[u];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let u=l[o];r[cn][u]=e.serializers[u]}}else r[cn]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:u}=e.formatters;r[ms]=_l(a||s.level,l||Mr,u||s.log)}else r[ms]=_l(s.level,Mr,s.log);if(e.hasOwnProperty("customLevels")===!0&&(qk(this.levels,e.customLevels),r.levels=Hk(e.customLevels,r[Rk]),Uk(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=Gk(r.redact,Pm),l={stringify:a[Ok]};r[Ik]=Pm,r[Lk]=a,r[Mk]=l}if(typeof e.msgPrefix=="string"&&(r[kl]=(this[kl]||"")+e.msgPrefix),r[Lr]=$l(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[Al](a)}return this.onChild(r),r}function Yk(){let e=`{${this[Lr].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function Jk(n){let e=$l(this,n);this[Lr]=e}function Qk(n,e){return Object.assign(e,n)}function Xk(n,e,t){let s=this[$k](),r=this[_k],i=this[Ck],o=this[Tk],a=this[kk]||Qk,l,u=this[Dk].streamWrite;n==null?l={}:n instanceof Error?(l={[i]:n},e===void 0&&(e=n.message)):(l=n,e===void 0&&n[o]===void 0&&n[i]&&(e=n[i].message)),r&&(l=a(l,r(l,t,this)));let d=this[Om](l,e,t,s),f=this[Im];f[Pk]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[Ek]),f.lastLogger=this),f.write(u?u(d):d)}function Zk(n){if(n!=null&&typeof n!="function")throw Error("callback must be a function");let e=this[Im];typeof e.flush=="function"?e.flush(n||Mm):n&&n()}});var Bm=j((Rl,Hm)=>{"use strict";var{hasOwnProperty:gs}=Object.prototype,dn=Tl();dn.configure=Tl;dn.stringify=dn;dn.default=dn;Rl.stringify=dn;Rl.configure=Tl;Hm.exports=dn;var e$=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function Kt(n){return n.length<5e3&&!e$.test(n)?`"${n}"`:JSON.stringify(n)}function El(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 t$=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function Cl(n){return t$.call(n)!==void 0&&n.length!==0}function Fm(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 n$(n){if(gs.call(n,"circularValue")){let e=n.circularValue;if(typeof e=="string")return`"${e}"`;if(e==null)return e;if(e===Error||e===TypeError)return{toString(){throw new TypeError("Converting circular structure to JSON")}};throw new TypeError('The "circularValue" argument must be of type string or the value null or undefined')}return'"[Circular]"'}function s$(n){let e;if(gs.call(n,"deterministic")&&(e=n.deterministic,typeof e!="boolean"&&typeof e!="function"))throw new TypeError('The "deterministic" argument must be of type boolean or comparator function');return e===void 0?!0:e}function r$(n,e){let t;if(gs.call(n,e)&&(t=n[e],typeof t!="boolean"))throw new TypeError(`The "${e}" argument must be of type boolean`);return t===void 0?!0:t}function jm(n,e){let t;if(gs.call(n,e)){if(t=n[e],typeof t!="number")throw new TypeError(`The "${e}" argument must be of type number`);if(!Number.isInteger(t))throw new TypeError(`The "${e}" argument must be an integer`);if(t<1)throw new RangeError(`The "${e}" argument must be >= 1`)}return t===void 0?1/0:t}function un(n){return n===1?"1 item":`${n} items`}function i$(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function o$(n){if(gs.call(n,"strict")){let e=n.strict;if(typeof e!="boolean")throw new TypeError('The "strict" argument must be of type boolean');if(e)return t=>{let s=`Object can not safely be stringified. Received type ${typeof t}`;throw typeof t!="function"&&(s+=` (${t.toString()})`),new Error(s)}}}function Tl(n){n={...n};let e=o$(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=n$(n),s=r$(n,"bigint"),r=s$(n),i=typeof r=="function"?r:void 0,o=jm(n,"maximumDepth"),a=jm(n,"maximumBreadth");function l(m,p,g,x,_,A){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 Kt(k);case"object":{if(k===null)return"null";if(g.indexOf(k)!==-1)return t;let y="",b=",",v=A;if(Array.isArray(k)){if(k.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(k),_!==""&&(A+=_,y+=`
|
|
715
|
+
caused by: `+Qp(s,e)):t},gS=n=>Qp(n,new Set),Xp=(n,e,t)=>{if(!fs(n))return"";let s=t?"":n.message||"";if(e.has(n))return s+": ...";let r=Ua(n);if(r){e.add(n);let i=typeof n.cause=="function";return s+(i?"":": ")+Xp(r,e,i)}else return s},yS=n=>Xp(n,new Set);Zp.exports={isErrorLike:fs,getErrorCause:Ua,stackWithCauses:gS,messageWithCauses:yS}});var Ka=j((tR,th)=>{"use strict";var bS=Symbol("circular-ref-tag"),yr=Symbol("pino-raw-err-ref"),eh=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[yr]},set:function(n){this[yr]=n}}});Object.defineProperty(eh,yr,{writable:!0,value:{}});th.exports={pinoErrProto:eh,pinoErrorSymbols:{seen:bS,rawSymbol:yr}}});var rh=j((nR,sh)=>{"use strict";sh.exports=Ga;var{messageWithCauses:vS,stackWithCauses:wS,isErrorLike:nh}=qa(),{pinoErrProto:xS,pinoErrorSymbols:SS}=Ka(),{seen:Wa}=SS,{toString:_S}=Object.prototype;function Ga(n){if(!nh(n))return n;n[Wa]=void 0;let e=Object.create(xS);e.type=_S.call(n.constructor)==="[object Function]"?n.constructor.name:n.name,e.message=vS(n),e.stack=wS(n),Array.isArray(n.errors)&&(e.aggregateErrors=n.errors.map(t=>Ga(t)));for(let t in n)if(e[t]===void 0){let s=n[t];nh(s)?t!=="cause"&&!Object.prototype.hasOwnProperty.call(s,Wa)&&(e[t]=Ga(s)):e[t]=s}return delete n[Wa],e.raw=n,e}});var oh=j((sR,ih)=>{"use strict";ih.exports=vr;var{isErrorLike:Va}=qa(),{pinoErrProto:AS,pinoErrorSymbols:kS}=Ka(),{seen:br}=kS,{toString:$S}=Object.prototype;function vr(n){if(!Va(n))return n;n[br]=void 0;let e=Object.create(AS);e.type=$S.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=>vr(t))),Va(n.cause)&&!Object.prototype.hasOwnProperty.call(n.cause,br)&&(e.cause=vr(n.cause));for(let t in n)if(e[t]===void 0){let s=n[t];Va(s)?Object.prototype.hasOwnProperty.call(s,br)||(e[t]=vr(s)):e[t]=s}return delete n[br],e.raw=n,e}});var uh=j((rR,ch)=>{"use strict";ch.exports={mapHttpRequest:CS,reqSerializer:lh};var za=Symbol("pino-raw-req-ref"),ah=Object.create({},{id:{enumerable:!0,writable:!0,value:""},method:{enumerable:!0,writable:!0,value:""},url:{enumerable:!0,writable:!0,value:""},query:{enumerable:!0,writable:!0,value:""},params:{enumerable:!0,writable:!0,value:""},headers:{enumerable:!0,writable:!0,value:{}},remoteAddress:{enumerable:!0,writable:!0,value:""},remotePort:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[za]},set:function(n){this[za]=n}}});Object.defineProperty(ah,za,{writable:!0,value:{}});function lh(n){let e=n.info||n.socket,t=Object.create(ah);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 CS(n){return{req:lh(n)}}});var hh=j((iR,ph)=>{"use strict";ph.exports={mapHttpResponse:ES,resSerializer:fh};var Ya=Symbol("pino-raw-res-ref"),dh=Object.create({},{statusCode:{enumerable:!0,writable:!0,value:0},headers:{enumerable:!0,writable:!0,value:""},raw:{enumerable:!1,get:function(){return this[Ya]},set:function(n){this[Ya]=n}}});Object.defineProperty(dh,Ya,{writable:!0,value:{}});function fh(n){let e=Object.create(dh);return e.statusCode=n.headersSent?n.statusCode:null,e.headers=n.getHeaders?n.getHeaders():n._headers,e.raw=n,e}function ES(n){return{res:fh(n)}}});var Qa=j((oR,mh)=>{"use strict";var Ja=rh(),TS=oh(),wr=uh(),xr=hh();mh.exports={err:Ja,errWithCause:TS,mapHttpRequest:wr.mapHttpRequest,mapHttpResponse:xr.mapHttpResponse,req:wr.reqSerializer,res:xr.resSerializer,wrapErrorSerializer:function(e){return e===Ja?e:function(s){return e(Ja(s))}},wrapRequestSerializer:function(e){return e===wr.reqSerializer?e:function(s){return e(wr.reqSerializer(s))}},wrapResponseSerializer:function(e){return e===xr.resSerializer?e:function(s){return e(xr.resSerializer(s))}}}});var Xa=j((aR,gh)=>{"use strict";function RS(n,e){return e}gh.exports=function(){let e=Error.prepareStackTrace;Error.prepareStackTrace=RS;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 Sh=j((lR,xh)=>{"use strict";function Za(n){if(n===null||typeof n!="object")return n;if(n instanceof Date)return new Date(n.getTime());if(n instanceof Array){let e=[];for(let t=0;t<n.length;t++)e[t]=Za(n[t]);return e}if(typeof n=="object"){let e=Object.create(Object.getPrototypeOf(n));for(let t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=Za(n[t]));return e}return n}function yh(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 bh(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 vh(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 Sr=Symbol("PATH_NOT_FOUND");function PS(n,e){let t=n;for(let s of e){if(t==null||typeof t!="object"||t===null||!(s in t))return Sr;t=t[s]}return t}function OS(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 IS(n,e,t,s=!1){for(let r of e){let i=yh(r);if(i.includes("*"))wh(n,i,t,r,s);else if(s)vh(n,i);else{let o=PS(n,i);if(o===Sr)continue;let a=typeof t=="function"?t(o,i):t;bh(n,i,a)}}}function wh(n,e,t,s,r=!1){let i=e.indexOf("*");if(i===e.length-1){let o=e.slice(0,-1),a=n;for(let l of o){if(a==null||typeof a!="object"||a===null)return;a=a[l]}if(Array.isArray(a))if(r)for(let l=0;l<a.length;l++)a[l]=void 0;else for(let l=0;l<a.length;l++){let u=[...o,l.toString()],d=typeof t=="function"?t(a[l],u):t;a[l]=d}else if(typeof a=="object"&&a!==null)if(r){let l=[];for(let u in a)Object.prototype.hasOwnProperty.call(a,u)&&l.push(u);for(let u of l)delete a[u]}else for(let l in a){let u=[...o,l],d=typeof t=="function"?t(a[l],u):t;a[l]=d}}else MS(n,e,t,i,s,r)}function MS(n,e,t,s,r,i=!1){let o=e.slice(0,s),a=e.slice(s+1),l=[];function u(d,f){if(f===o.length){if(Array.isArray(d))for(let h=0;h<d.length;h++)l[f]=h.toString(),u(d[h],f+1);else if(typeof d=="object"&&d!==null)for(let h in d)l[f]=h,u(d[h],f+1)}else if(f<o.length){let h=o[f];d&&typeof d=="object"&&d!==null&&h in d&&(l[f]=h,u(d[h],f+1))}else if(a.includes("*"))wh(d,a,typeof t=="function"?(m,p)=>{let g=[...l.slice(0,f),...p];return t(m,g)}:t,r,i);else if(i)vh(d,a);else{let h=typeof t=="function"?t(OS(d,a),[...l.slice(0,f),...a]):t;bh(d,a,h)}}if(o.length===0)u(n,0);else{let d=n;for(let f=0;f<o.length;f++){let h=o[f];if(d==null||typeof d!="object"||d===null)return;d=d[h],l[f]=h}d!=null&&u(d,o.length)}}function LS(n){if(n.length===0)return null;let e=new Map;for(let t of n){let s=yh(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 DS(n,e){if(!e)return n;function t(s,r,i=0){if(!r||r.size===0||s===null||typeof s!="object")return s;if(s instanceof Date)return new Date(s.getTime());if(Array.isArray(s)){let a=[];for(let l=0;l<s.length;l++){let u=l.toString();r.has(u)||r.has("*")?a[l]=t(s[l],r.get(u)||r.get("*")):a[l]=s[l]}return a}let o=Object.create(Object.getPrototypeOf(s));for(let a in s)Object.prototype.hasOwnProperty.call(s,a)&&(r.has(a)||r.has("*")?o[a]=t(s[a],r.get(a)||r.get("*")):o[a]=s[a]);return o}return t(n,e)}function NS(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 FS(n){if(!Array.isArray(n))throw new TypeError("paths must be an array");for(let e of n)NS(e)}function jS(n={}){let{paths:e=[],censor:t="[REDACTED]",serialize:s=JSON.stringify,strict:r=!0,remove:i=!1}=n;FS(e);let o=LS(e);return function(l){if(r&&(l===null||typeof l!="object")&&(l==null||typeof l!="object"))return s?s(l):l;let u=DS(l,o),d=l,f=t;return typeof t=="function"&&(f=t),IS(u,e,f,i),s===!1?(u.restore=function(){return Za(d)},u):typeof s=="function"?s(u):JSON.stringify(u)}}xh.exports=jS});var Pn=j((cR,_h)=>{"use strict";var HS=Symbol("pino.setLevel"),BS=Symbol("pino.getLevel"),US=Symbol("pino.levelVal"),qS=Symbol("pino.levelComp"),KS=Symbol("pino.useLevelLabels"),WS=Symbol("pino.useOnlyCustomLevels"),GS=Symbol("pino.mixin"),VS=Symbol("pino.lsCache"),zS=Symbol("pino.chindings"),YS=Symbol("pino.asJson"),JS=Symbol("pino.write"),QS=Symbol("pino.redactFmt"),XS=Symbol("pino.time"),ZS=Symbol("pino.timeSliceIndex"),e_=Symbol("pino.stream"),t_=Symbol("pino.stringify"),n_=Symbol("pino.stringifySafe"),s_=Symbol("pino.stringifiers"),r_=Symbol("pino.end"),i_=Symbol("pino.formatOpts"),o_=Symbol("pino.messageKey"),a_=Symbol("pino.errorKey"),l_=Symbol("pino.nestedKey"),c_=Symbol("pino.nestedKeyStr"),u_=Symbol("pino.mixinMergeStrategy"),d_=Symbol("pino.msgPrefix"),f_=Symbol("pino.wildcardFirst"),p_=Symbol.for("pino.serializers"),h_=Symbol.for("pino.formatters"),m_=Symbol.for("pino.hooks"),g_=Symbol.for("pino.metadata");_h.exports={setLevelSym:HS,getLevelSym:BS,levelValSym:US,levelCompSym:qS,useLevelLabelsSym:KS,mixinSym:GS,lsCacheSym:VS,chindingsSym:zS,asJsonSym:YS,writeSym:JS,serializersSym:p_,redactFmtSym:QS,timeSym:XS,timeSliceIndexSym:ZS,streamSym:e_,stringifySym:t_,stringifySafeSym:n_,stringifiersSym:s_,endSym:r_,formatOptsSym:i_,messageKeySym:o_,errorKeySym:a_,nestedKeySym:l_,wildcardFirstSym:f_,needsMetadataGsym:g_,useOnlyCustomLevelsSym:WS,formattersSym:h_,hooksSym:m_,nestedKeyStrSym:c_,mixinMergeStrategySym:u_,msgPrefixSym:d_}});var tl=j((uR,Ch)=>{"use strict";var Ah=Sh(),{redactFmtSym:y_,wildcardFirstSym:_r}=Pn(),el=/[^.[\]]+|\[([^[\]]*?)\]/g,kh="[Redacted]",$h=!1;function b_(n,e){let{paths:t,censor:s,remove:r}=v_(n),i=t.reduce((l,u)=>{el.lastIndex=0;let d=el.exec(u),f=el.exec(u),h=d[1]!==void 0?d[1].replace(/^(?:"|'|`)(.*)(?:"|'|`)$/,"$1"):d[0];if(h==="*"&&(h=_r),f===null)return l[h]=null,l;if(l[h]===null)return l;let{index:m}=f,p=`${u.substr(m,u.length-1)}`;return l[h]=l[h]||[],h!==_r&&l[h].length===0&&l[h].push(...l[_r]||[]),h===_r&&Object.keys(l).forEach(function(g){l[g]&&l[g].push(p)}),l[h].push(p),l},{}),o={[y_]:Ah({paths:t,censor:s,serialize:e,strict:$h,remove:r})},a=(...l)=>e(typeof s=="function"?s(...l):s);return[...Object.keys(i),...Object.getOwnPropertySymbols(i)].reduce((l,u)=>{if(i[u]===null)l[u]=d=>a(d,[u]);else{let d=typeof s=="function"?(f,h)=>s(f,[u,...h]):s;l[u]=Ah({paths:i[u],censor:d,serialize:e,strict:$h,remove:r})}return l},o)}function v_(n){if(Array.isArray(n))return n={paths:n,censor:kh},n;let{paths:e,censor:t=kh,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}}Ch.exports=b_});var Rh=j((dR,Th)=>{"use strict";var w_=()=>"",x_=()=>`,"time":${Date.now()}`,S_=()=>`,"time":${Math.round(Date.now()/1e3)}`,__=()=>`,"time":"${new Date(Date.now()).toISOString()}"`,A_=1000000n,Eh=1000000000n,k_=BigInt(Date.now())*A_,$_=process.hrtime.bigint(),C_=()=>{let n=process.hrtime.bigint()-$_,e=k_+n,t=e/Eh,s=e%Eh,r=Number(t*1000n+s/1000000n),i=new Date(r),o=i.getUTCFullYear(),a=(i.getUTCMonth()+1).toString().padStart(2,"0"),l=i.getUTCDate().toString().padStart(2,"0"),u=i.getUTCHours().toString().padStart(2,"0"),d=i.getUTCMinutes().toString().padStart(2,"0"),f=i.getUTCSeconds().toString().padStart(2,"0");return`,"time":"${o}-${a}-${l}T${u}:${d}:${f}.${s.toString().padStart(9,"0")}Z"`};Th.exports={nullTime:w_,epochTime:x_,unixTime:S_,isoTime:__,isoTimeNano:C_}});var Oh=j((fR,Ph)=>{"use strict";function E_(n){try{return JSON.stringify(n)}catch{return'"[Circular]"'}}Ph.exports=T_;function T_(n,e,t){var s=t&&t.stringify||E_,r=1;if(typeof n=="object"&&n!==null){var i=e.length+r;if(i===1)return n;var o=new Array(i);o[0]=s(n);for(var a=1;a<i;a++)o[a]=s(e[a]);return o.join(" ")}if(typeof n!="string")return n;var l=e.length;if(l===0)return n;for(var u="",d=1-r,f=-1,h=n&&n.length||0,m=0;m<h;){if(n.charCodeAt(m)===37&&m+1<h){switch(f=f>-1?f:0,n.charCodeAt(m+1)){case 100:case 102:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Number(e[d]),f=m+2,m++;break;case 105:if(d>=l||e[d]==null)break;f<m&&(u+=n.slice(f,m)),u+=Math.floor(Number(e[d])),f=m+2,m++;break;case 79:case 111:case 106:if(d>=l||e[d]===void 0)break;f<m&&(u+=n.slice(f,m));var p=typeof e[d];if(p==="string"){u+="'"+e[d]+"'",f=m+2,m++;break}if(p==="function"){u+=e[d].name||"<anonymous>",f=m+2,m++;break}u+=s(e[d]),f=m+2,m++;break;case 115:if(d>=l)break;f<m&&(u+=n.slice(f,m)),u+=String(e[d]),f=m+2,m++;break;case 37:f<m&&(u+=n.slice(f,m)),u+="%",f=m+2,m++,d--;break}++d}++m}return f===-1?n:(f<h&&(u+=n.slice(f)),u)}});var sl=j((pR,nl)=>{"use strict";if(typeof SharedArrayBuffer<"u"&&typeof Atomics<"u"){let e=function(t){if((t>0&&t<1/0)===!1)throw typeof t!="number"&&typeof t!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");Atomics.wait(n,0,0,Number(t))},n=new Int32Array(new SharedArrayBuffer(4));nl.exports=e}else{let n=function(e){if((e>0&&e<1/0)===!1)throw typeof e!="number"&&typeof e!="bigint"?TypeError("sleep: ms must be a number"):RangeError("sleep: ms must be a number that is greater than 0 but less than Infinity");let s=Date.now()+Number(e);for(;s>Date.now(););};nl.exports=n}});var Hh=j((hR,jh)=>{"use strict";var ue=require("fs"),R_=require("events"),P_=require("util").inherits,Ih=require("path"),il=sl(),O_=require("assert"),Ar=100,kr=Buffer.allocUnsafe(0),I_=16*1024,Mh="buffer",Lh="utf8",[M_,L_]=(process.versions.node||"0.0").split(".").map(Number),D_=M_>=22&&L_>=7;function Dh(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&&ue.mkdirSync(Ih.dirname(n),{recursive:!0});let i=ue.openSync(n,s,r);t(null,i)}catch(i){throw t(i),i}else e.mkdir?ue.mkdir(Ih.dirname(n),{recursive:!0},i=>{if(i)return t(i);ue.open(n,s,r,t)}):ue.open(n,s,r,t)}function at(n){if(!(this instanceof at))return new at(n);let{fd:e,dest:t,minLength:s,maxLength:r,maxWrite:i,periodicFlush:o,sync:a,append:l=!0,mkdir:u,retryEAGAIN:d,fsync:f,contentMode:h,mode:m}=n||{};e=e||t,this._len=0,this.fd=-1,this._bufs=[],this._lens=[],this._writing=!1,this._ending=!1,this._reopening=!1,this._asyncDrainScheduled=!1,this._flushPending=!1,this._hwm=Math.max(s||0,16387),this.file=null,this.destroyed=!1,this.minLength=s||0,this.maxLength=r||0,this.maxWrite=i||I_,this._periodicFlush=o||0,this._periodicFlushTimer=void 0,this.sync=a||!1,this.writable=!0,this._fsync=f||!1,this.append=l||!1,this.mode=m,this.retryEAGAIN=d||(()=>!0),this.mkdir=u||!1;let p,g;if(h===Mh)this._writingBuf=kr,this.write=j_,this.flush=B_,this.flushSync=q_,this._actualWrite=W_,p=()=>ue.writeSync(this.fd,this._writingBuf),g=()=>ue.write(this.fd,this._writingBuf,this.release);else if(h===void 0||h===Lh)this._writingBuf="",this.write=F_,this.flush=H_,this.flushSync=U_,this._actualWrite=K_,p=()=>Buffer.isBuffer(this._writingBuf)?ue.writeSync(this.fd,this._writingBuf):ue.writeSync(this.fd,this._writingBuf,"utf8"),g=()=>Buffer.isBuffer(this._writingBuf)?ue.write(this.fd,this._writingBuf,this.release):ue.write(this.fd,this._writingBuf,"utf8",this.release);else throw new Error(`SonicBoom supports "${Lh}" and "${Mh}", but passed ${h}`);if(typeof e=="number")this.fd=e,process.nextTick(()=>this.emit("ready"));else if(typeof e=="string")Dh(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{il(Ar),this.release(void 0,0)}catch(y){this.release(y)}else setTimeout(g,Ar);else this._writing=!1,this.emit("error",x);return}this.emit("write",S);let A=rl(this._writingBuf,this._len,S);if(this._len=A.len,this._writingBuf=A.writingBuf,this._writingBuf.length){if(!this.sync){g();return}try{do{let y=p(),b=rl(this._writingBuf,this._len,y);this._len=b.len,this._writingBuf=b.writingBuf}while(this._writingBuf.length)}catch(y){this.release(y);return}}this._fsync&&ue.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,$r(this)):(this._writing=!1,this.sync?this._asyncDrainScheduled||(this._asyncDrainScheduled=!0,process.nextTick(N_,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 rl(n,e,t){return typeof n=="string"&&(n=Buffer.from(n)),e=Math.max(e-t,0),n=n.subarray(t),{writingBuf:n,len:e}}function N_(n){n.listenerCount("drain")>0&&(n._asyncDrainScheduled=!1,n.emit("drain"))}P_(at,R_);function Nh(n,e){return n.length===0?kr:n.length===1?n[0]:Buffer.concat(n,e)}function F_(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 j_(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 Fh(n){this._flushPending=!0;let e=()=>{if(this._fsync)this._flushPending=!1,n();else try{ue.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 H_(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&&Fh.call(this,n),!this._writing&&(this._bufs.length===0&&this._bufs.push(""),this._actualWrite())}function B_(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&&Fh.call(this,n),!this._writing&&(this._bufs.length===0&&(this._bufs.push([]),this._lens.push(0)),this._actualWrite())}at.prototype.reopen=function(n){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.reopen(n)});return}if(this._ending)return;if(!this.file)throw new Error("Unable to reopen a file descriptor, you must pass a file to SonicBoom");if(n&&(this.file=n),this._reopening=!0,this._writing)return;let e=this.fd;this.once("ready",()=>{e!==this.fd&&ue.close(e,t=>{if(t)return this.emit("error",t)})}),Dh(this.file,this)};at.prototype.end=function(){if(this.destroyed)throw new Error("SonicBoom destroyed");if(this._opening){this.once("ready",()=>{this.end()});return}this._ending||(this._ending=!0,!this._writing&&(this._len>0&&this.fd>=0?this._actualWrite():$r(this)))};function U_(){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)?ue.writeSync(this.fd,n):ue.writeSync(this.fd,n,"utf8"),t=rl(n,this._len,e);n=t.writingBuf,this._len=t.len,n.length<=0&&this._bufs.shift()}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(Ar)}}try{ue.fsyncSync(this.fd)}catch{}}function q_(){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=kr);let n=kr;for(;this._bufs.length||n.length;){n.length<=0&&(n=Nh(this._bufs[0],this._lens[0]));try{let e=ue.writeSync(this.fd,n);n=n.subarray(e),this._len=Math.max(this._len-e,0),n.length<=0&&(this._bufs.shift(),this._lens.shift())}catch(e){if((e.code==="EAGAIN"||e.code==="EBUSY")&&!this.retryEAGAIN(e,n.length,this._len-n.length))throw e;il(Ar)}}}at.prototype.destroy=function(){this.destroyed||$r(this)};function K_(){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)?ue.writeSync(this.fd,this._writingBuf):ue.writeSync(this.fd,this._writingBuf,"utf8");n(null,e)}catch(e){n(e)}else ue.write(this.fd,this._writingBuf,n)}function W_(){let n=this.release;if(this._writing=!0,this._writingBuf=this._writingBuf.length?this._writingBuf:Nh(this._bufs.shift(),this._lens.shift()),this.sync)try{let e=ue.writeSync(this.fd,this._writingBuf);n(null,e)}catch(e){n(e)}else D_&&(this._writingBuf=Buffer.from(this._writingBuf)),ue.write(this.fd,this._writingBuf,n)}function $r(n){if(n.fd===-1){n.once("ready",$r.bind(null,n));return}n._periodicFlushTimer!==void 0&&clearInterval(n._periodicFlushTimer),n.destroyed=!0,n._bufs=[],n._lens=[],O_(typeof n.fd=="number",`sonic.fd must be a number, got ${typeof n.fd}`);try{ue.fsync(n.fd,e)}catch{}function e(){n.fd!==1&&n.fd!==2?ue.close(n.fd,t):t()}function t(s){if(s){n.emit("error",s);return}n._ending&&!n._writing&&n.emit("finish"),n.emit("close")}}at.SonicBoom=at;at.default=at;jh.exports=at});var ol=j((mR,Wh)=>{"use strict";var lt={exit:[],beforeExit:[]},Bh={exit:z_,beforeExit:Y_},On;function G_(){On===void 0&&(On=new FinalizationRegistry(J_))}function V_(n){lt[n].length>0||process.on(n,Bh[n])}function Uh(n){lt[n].length>0||(process.removeListener(n,Bh[n]),lt.exit.length===0&<.beforeExit.length===0&&(On=void 0))}function z_(){qh("exit")}function Y_(){qh("beforeExit")}function qh(n){for(let e of lt[n]){let t=e.deref(),s=e.fn;t!==void 0&&s(t,n)}lt[n]=[]}function J_(n){for(let e of["exit","beforeExit"]){let t=lt[e].indexOf(n);lt[e].splice(t,t+1),Uh(e)}}function Kh(n,e,t){if(e===void 0)throw new Error("the object can't be undefined");V_(n);let s=new WeakRef(e);s.fn=t,G_(),On.register(e,s),lt[n].push(s)}function Q_(n,e){Kh("exit",n,e)}function X_(n,e){Kh("beforeExit",n,e)}function Z_(n){if(On!==void 0){On.unregister(n);for(let e of["exit","beforeExit"])lt[e]=lt[e].filter(t=>{let s=t.deref();return s&&s!==n}),Uh(e)}}Wh.exports={register:Q_,registerBeforeExit:X_,unregister:Z_}});var Gh=j((gR,eA)=>{eA.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 zh=j((yR,Vh)=>{"use strict";function tA(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{let a=Atomics.load(n,e);if(a===t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,a,l);u.async?u.value.then(o):setImmediate(o)};o()}function nA(n,e,t,s,r){let i=s===1/0?1/0:Date.now()+s,o=()=>{if(Atomics.load(n,e)!==t){r(null,"ok");return}if(i!==1/0&&Date.now()>i){r(null,"timed-out");return}let l=i===1/0?1e4:Math.min(1e4,Math.max(1,i-Date.now())),u=Atomics.waitAsync(n,e,t,l);u.async?u.value.then(d=>{if(d==="ok"){r(null,"ok");return}o()}):setImmediate(o)};o()}Vh.exports={wait:tA,waitDiff:nA}});var Jh=j((bR,Yh)=>{"use strict";Yh.exports={WRITE_INDEX:4,READ_INDEX:8,SEQ_INDEX:2}});var lm=j((vR,am)=>{"use strict";var{version:sA}=Gh(),{EventEmitter:rA}=require("events"),{Worker:iA}=require("worker_threads"),{join:oA}=require("path"),{pathToFileURL:aA}=require("url"),{wait:lA}=zh(),{WRITE_INDEX:Ot,READ_INDEX:on,SEQ_INDEX:al}=Jh(),cA=require("buffer"),uA=require("assert"),R=Symbol("kImpl"),dA=cA.constants.MAX_STRING_LENGTH;function Qh(){}function dl(n,e){Atomics.add(n[R].state,al,1),e(),Atomics.add(n[R].state,al,1),Atomics.notify(n[R].state,al)}function Xh(n){dl(n,()=>{Atomics.store(n[R].state,on,0),Atomics.store(n[R].state,Ot,0)})}var ps=class{constructor(e){this._value=e}deref(){return this._value}},Cr=class{register(){}unregister(){}},fA=process.env.NODE_V8_COVERAGE?Cr:global.FinalizationRegistry||Cr,pA=process.env.NODE_V8_COVERAGE?ps:global.WeakRef||ps,Zh=new fA(n=>{n.exited||n.terminate()});function hA(n,e){let{filename:t,workerData:s}=e,i=("__bundlerPathsOverrides"in globalThis?globalThis.__bundlerPathsOverrides:{})["thread-stream-worker"]||oA(__dirname,"lib","worker.js"),o=new iA(i,{...e.workerOpts,name:e.workerOpts?.name||"thread-stream",trackUnmanagedFds:!1,workerData:{filename:t.indexOf("file://")===0?t:aA(t).href,dataBuf:n[R].dataBuf,stateBuf:n[R].stateBuf,workerData:{$context:{threadStreamVersion:sA},...s}}});return o.stream=new ps(n),o.on("message",mA),o.on("exit",nm),Zh.register(n,o),o}function em(n){uA(!n[R].sync),n[R].needDrain&&(n[R].needDrain=!1,n.emit("drain"))}function tm(n){for(;;){let e=Atomics.load(n[R].state,Ot),t=n[R].data.length-e;if(t>0){if(n[R].bufLen===0){n[R].flushing=!1,n[R].ending?fl(n):n[R].needDrain&&process.nextTick(em,n);return}im(n,t,Qh);continue}if(t===0){if(e===0&&n[R].bufLen===0)return;Er(n,()=>{n.destroyed||(Xh(n),tm(n))});return}et(n,new Error("overwritten"));return}}function mA(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 pA(e),Er(e,()=>{e[R].ready=!0,e.emit("ready")});break;case"ERROR":et(e,n.err);break;case"EVENT":Array.isArray(n.args)?e.emit(n.name,...n.args):e.emit(n.name,n.args);break;case"FLUSHED":{if(n.context!=="thread-stream"){et(e,new Error("this should not happen: "+n.code));break}let t=e[R].flushCallbacks.get(n.id);t&&(e[R].flushCallbacks.delete(n.id),process.nextTick(t));break}case"WARNING":process.emitWarning(n.err);break;default:et(e,new Error("this should not happen: "+n.code))}}function nm(n){let e=this.stream.deref();e!==void 0&&(Zh.unregister(e),e.worker.exited=!0,e.worker.off("exit",nm),et(e,n!==0?new Error("the worker thread exited"):null))}var cl=class extends rA{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=hA(this,e),this.on("message",(t,s)=>{this.worker.postMessage(t,s)})}write(e){let t=Buffer.isBuffer(e)?e:Buffer.from(e);if(this[R].destroyed)return ul(this,new Error("the worker has exited")),!1;if(this[R].ending)return ul(this,new Error("the worker is ending")),!1;if(this[R].flushing&&this[R].bufLen+t.length>=dA)try{ll(this),this[R].flushing=!0}catch(s){return et(this,s),!1}if(this[R].buf.push(t),this[R].bufLen+=t.length,this[R].sync)try{return ll(this),!0}catch(s){return et(this,s),!1}return this[R].flushing||(this[R].flushing=!0,setImmediate(tm,this)),this[R].needDrain=this[R].data.length-this[R].bufLen-Atomics.load(this[R].state,Ot)<=0,!this[R].needDrain}end(){this[R].destroyed||(this[R].ending=!0,fl(this))}flush(e){e=typeof e=="function"?e:Qh,sm(this,t=>{if(t){process.nextTick(e,t);return}rm(this,e)})}flushSync(){this[R].destroyed||(ll(this),om(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 sm(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(sm,n,e);return}Er(n,e)}function Er(n,e){let t=Atomics.load(n[R].state,Ot);lA(n[R].state,on,t,1/0,(s,r)=>{if(s){et(n,s),e(s);return}if(r!=="ok"){Er(n,e);return}e()})}function rm(n,e){if(n[R].destroyed){process.nextTick(e,new Error("the worker has exited"));return}if(!n[R].ready){let s=()=>{i(),rm(n,e)},r=()=>{i(),process.nextTick(e,new Error("the worker has exited"))},i=()=>{n.off("ready",s),n.off("close",r)};n.once("ready",s),n.once("close",r);return}let t=++n[R].nextFlushId;n[R].flushCallbacks.set(t,e);try{n.worker.postMessage({code:"FLUSH",context:"thread-stream",id:t})}catch(s){n[R].flushCallbacks.delete(t),et(n,s),process.nextTick(e,s)}}function gA(n,e){let t=n[R].flushCallbacks;if(t.size===0)return;let s=e||new Error("the worker has exited");for(let r of t.values())process.nextTick(r,s);t.clear()}function ul(n,e){setImmediate(()=>{n.emit("error",e)})}function et(n,e){n[R].destroyed||(n[R].destroyed=!0,gA(n,e),e&&(n[R].errored=e,ul(n,e)),n.worker.exited?setImmediate(()=>{n[R].closed=!0,n.emit("close")}):n.worker.terminate().catch(()=>{}).then(()=>{n[R].closed=!0,n.emit("close")}))}function im(n,e,t){let r=Atomics.load(n[R].state,Ot),i=e;for(;i>0&&n[R].bufLen!==0;){let o=n[R].bufHead,a=n[R].buf[o];if(a.length<=i){a.copy(n[R].data,r),r+=a.length,i-=a.length,n[R].bufLen-=a.length,n[R].bufHead=o+1,n[R].bufHead===n[R].buf.length?(n[R].buf.length=0,n[R].bufHead=0):n[R].bufHead>=1024&&n[R].bufHead*2>=n[R].buf.length&&(n[R].buf.splice(0,n[R].bufHead),n[R].bufHead=0);continue}a.copy(n[R].data,r,0,i),n[R].buf[o]=a.subarray(i),n[R].bufLen-=i,r+=i,i=0}return dl(n,()=>{Atomics.store(n[R].state,Ot,r)}),t(),!0}function fl(n){if(!(n[R].ended||!n[R].ending||n[R].flushing)){n[R].ended=!0;try{n.flushSync();let e=Atomics.load(n[R].state,on);dl(n,()=>{Atomics.store(n[R].state,Ot,-1)});let t=0;for(;e!==-1;){if(Atomics.wait(n[R].state,on,e,1e3),e=Atomics.load(n[R].state,on),e===-2){et(n,new Error("end() failed"));return}if(++t===10){et(n,new Error("end() took too long (10s)"));return}}process.nextTick(()=>{n[R].finished=!0,n.emit("finish")})}catch(e){et(n,e)}}}function ll(n){let e=()=>{n[R].ending?fl(n):n[R].needDrain&&process.nextTick(em,n)};for(n[R].flushing=!1;n[R].bufLen!==0;){let t=Atomics.load(n[R].state,Ot),s=n[R].data.length-t;if(s===0){om(n),Xh(n);continue}else if(s<0)throw new Error("overwritten");im(n,s,e)}}function om(n){if(n[R].flushing)throw new Error("unable to flush while flushing");let e=Atomics.load(n[R].state,Ot),t=0;for(;;){let s=Atomics.load(n[R].state,on);if(s===-2)throw Error("_flushSync failed");if(s!==e)Atomics.wait(n[R].state,on,s,1e3);else break;if(++t===10)throw new Error("_flushSync took too long (10s)")}}am.exports=cl});var ml=j((wR,dm)=>{"use strict";var{createRequire:yA}=require("module"),{existsSync:bA}=require("node:fs"),vA=Xa(),{join:pl,isAbsolute:um,sep:wA}=require("node:path"),{fileURLToPath:xA}=require("node:url"),SA=sl(),hl=ol(),_A=lm();function AA(n){hl.register(n,TA),hl.registerBeforeExit(n,RA),n.on("close",function(){hl.unregister(n)})}function kA(){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 $A(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&&cm(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(cm(o)){s=!0;continue}}t.push(i)}return s?t.join(" "):n}function cm(n){let e=CA(n);if(!e)return!1;let t=e;if(t.startsWith("file://"))try{t=xA(t)}catch{return!1}return um(t)&&!bA(t)}function CA(n){let e=n[0],t=n[n.length-1];return e==='"'&&t==='"'||e==="'"&&t==="'"?n.slice(1,-1):n}function EA(n,e,t,s,r){if(!t.execArgv&&kA()&&require.main===void 0&&(t={...t,execArgv:[]}),!t.env&&process.env.NODE_OPTIONS){let l=$A(process.env.NODE_OPTIONS);l!==process.env.NODE_OPTIONS&&(t={...t,env:{...process.env,NODE_OPTIONS:l}})}t={...t,name:r};let i=new _A({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&&AA(i)}function a(){i.closed||(i.flushSync(),SA(100),i.end())}return i}function TA(n){n.ref(),n.flushSync(),n.end(),n.once("close",function(){n.unref()})}function RA(n){n.flushSync()}function PA(n){let{pipeline:e,targets:t,levels:s,dedupe:r,worker:i={},caller:o=vA(),sync:a=!1}=n,l={...n.options},u=typeof o=="string"?[o]:o,d=typeof globalThis=="object"&&Object.prototype.hasOwnProperty.call(globalThis,"__bundlerPathsOverrides")&&globalThis.__bundlerPathsOverrides&&typeof globalThis.__bundlerPathsOverrides=="object"?globalThis.__bundlerPathsOverrides:Object.create(null),f=n.target;if(f&&t)throw new Error("only one of target or targets can be specified");t?(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.targets=t.filter(p=>p.target).map(p=>({...p,target:m(p.target)})),l.pipelines=t.filter(p=>p.pipeline).map(p=>p.pipeline.map(g=>({...g,level:p.level,target:m(g.target)})))):e&&(f=d["pino-worker"]||pl(__dirname,"worker.js"),l.pipelines=[e.map(p=>({...p,target:m(p.target)}))]),s&&(l.levels=s),r&&(l.dedupe=r),l.pinoWillSendConfig=!0;let h=t||e?"pino.transport":f;return EA(m(f),l,i,a,h);function m(p){if(p=d[p]||p,um(p)||p.indexOf("file://")===0)return p;if(p==="pino/file")return pl(__dirname,"..","file.js");let g;for(let x of u)try{let S=x==="node:repl"?process.cwd()+wA:x;g=yA(S).resolve(p);break}catch{continue}if(!g)throw new Error(`unable to determine transport target for "${p}"`);return g}}dm.exports=PA});var Pr=j((xR,Am)=>{"use strict";var OA=require("node:diagnostics_channel"),fm=Oh(),{mapHttpRequest:IA,mapHttpResponse:MA}=Qa(),yl=Hh(),pm=ol(),{lsCacheSym:LA,chindingsSym:bm,writeSym:hm,serializersSym:vm,formatOptsSym:mm,endSym:DA,stringifiersSym:wm,stringifySym:xm,stringifySafeSym:bl,wildcardFirstSym:Sm,nestedKeySym:NA,formattersSym:_m,messageKeySym:FA,errorKeySym:jA,nestedKeyStrSym:HA,msgPrefixSym:Tr}=Pn(),{isMainThread:BA}=require("worker_threads"),UA=ml(),[qA]=process.versions.node.split(".").map(n=>Number(n)),gm=OA.tracingChannel("pino_asJson"),gl=qA>=25?n=>JSON.stringify(n):WA;function In(){}function KA(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=IA(s):typeof s.setHeader=="function"&&(s=MA(s)));let o;i===null&&r.length===0?o=[null]:(i=r.shift(),o=r),typeof this[Tr]=="string"&&i!==void 0&&i!==null&&(i=this[Tr]+i),this[hm](s,fm(i,o,this[mm]),n)}else{let i=s===void 0?r.shift():s;typeof this[Tr]=="string"&&i!==void 0&&i!==null&&(i=this[Tr]+i),this[hm](null,fm(i,r,this[mm]),n)}}}function WA(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 GA(n,e,t,s){if(gm.hasSubscribers===!1)return ym.call(this,n,e,t,s);let r={instance:this,arguments};return gm.traceSync(ym,r,this,n,e,t,s)}function ym(n,e,t,s){let r=this[xm],i=this[bl],o=this[wm],a=this[DA],l=this[bm],u=this[vm],d=this[_m],f=this[FA],h=this[jA],m=this[LA][t]+s;m=m+l;let p;d.log&&(n=d.log(n));let g=o[Sm],x="";for(let A in n)if(p=n[A],Object.prototype.hasOwnProperty.call(n,A)&&p!==void 0){u[A]?p=u[A](p):A===h&&u.err&&(p=u.err(p));let k=o[A]||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||gl)(p);break;default:p=(k||r)(p,i)}if(p===void 0)continue;let y=gl(A);x+=","+y+":"+p}let S="";if(e!==void 0){p=u[f]?u[f](e):e;let A=o[f]||g;switch(typeof p){case"function":break;case"number":Number.isFinite(p)===!1&&(p=null);case"boolean":A&&(p=A(p)),S=',"'+f+'":'+p;break;case"string":p=(A||gl)(p),S=',"'+f+'":'+p;break;default:p=(A||r)(p,i),S=',"'+f+'":'+p}}return this[NA]&&x?m+this[HA]+x.slice(1)+"}"+S+a:m+x+S+a}function VA(n,e){let t,s=n[bm],r=n[xm],i=n[bl],o=n[wm],a=o[Sm],l=n[vm],u=n[_m].bindings;e=u(e);for(let d in e)if(t=e[d],((d.length<5||d!=="level"&&d!=="serializers"&&d!=="formatters"&&d!=="customLevels")&&e.hasOwnProperty(d)&&t!==void 0)===!0){if(t=l[d]?l[d](t):t,t=(o[d]||a||r)(t,i),t===void 0)continue;s+=',"'+d+'":'+t}return s}function zA(n){return n.write!==n.constructor.prototype.write}function Rr(n){let e=new yl(n);return e.on("error",t),!n.sync&&BA&&(pm.register(e,YA),e.on("close",function(){pm.unregister(e)})),e;function t(s){if(s.code==="EPIPE"){e.write=In,e.end=In,e.flushSync=In,e.destroy=In;return}e.removeListener("error",t),e.emit("error",s)}}function YA(n,e){n.destroyed||(e==="beforeExit"?(n.flush(),n.on("drain",function(){n.end()})):n.flushSync())}function JA(n){return function(t,s,r={},i){if(typeof r=="string")i=Rr({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=Rr({dest:i})}else if(r instanceof yl||r.writable||r._writableState)i=r,r={};else if(r.transport){if(r.transport instanceof yl||r.transport.writable||r.transport._writableState)throw Error("option.transport do not allow stream, please pass to option directly. e.g. pino(transport)");if(r.transport.targets&&r.transport.targets.length&&r.formatters&&typeof r.formatters.level=="function")throw Error("option.transport.targets do not allow custom level formatters");let l;r.customLevels&&(l=r.useOnlyCustomLevels?r.customLevels:Object.assign({},r.levels,r.customLevels)),i=UA({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=In),i||(zA(process.stdout)?i=process.stdout:i=Rr({fd:process.stdout.fd||1})),{opts:r,stream:i}}}function QA(n,e){try{return JSON.stringify(n)}catch{try{return(e||this[bl])(n)}catch{return'"[unable to serialize, circular reference is too complex to analyze]"'}}}function XA(n,e,t){return{level:n,bindings:e,log:t}}function ZA(n){let e=Number(n);return typeof n=="string"&&Number.isFinite(e)?e:n===void 0?1:n}Am.exports={noop:In,buildSafeSonicBoom:Rr,asChindings:VA,asJson:GA,genLog:KA,createArgsNormalizer:JA,stringify:QA,buildFormatters:XA,normalizeDestFileDescriptor:ZA}});var Or=j((SR,km)=>{var ek={trace:10,debug:20,info:30,warn:40,error:50,fatal:60},tk={ASC:"ASC",DESC:"DESC"};km.exports={DEFAULT_LEVELS:ek,SORTING_ORDER:tk}});var xl=j((_R,Tm)=>{"use strict";var{lsCacheSym:nk,levelValSym:vl,useOnlyCustomLevelsSym:sk,streamSym:rk,formattersSym:ik,hooksSym:ok,levelCompSym:$m}=Pn(),{noop:ak,genLog:an}=Pr(),{DEFAULT_LEVELS:yt,SORTING_ORDER:Cm}=Or(),Em={fatal:n=>{let e=an(yt.fatal,n);return function(...t){let s=this[rk];if(e.call(this,...t),typeof s.flushSync=="function")try{s.flushSync()}catch{}}},error:n=>an(yt.error,n),warn:n=>an(yt.warn,n),info:n=>an(yt.info,n),debug:n=>an(yt.debug,n),trace:n=>an(yt.trace,n)},wl=Object.keys(yt).reduce((n,e)=>(n[yt[e]]=e,n),{}),lk=Object.keys(wl).reduce((n,e)=>(n[e]='{"level":'+Number(e),n),{});function ck(n){let e=n[ik].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[nk]=s,n}function uk(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 dk(n){let{labels:e,values:t}=this.levels;if(typeof n=="number"){if(e[n]===void 0)throw Error("unknown level value"+n);n=e[n]}if(t[n]===void 0)throw Error("unknown level "+n);let s=this[vl],r=this[vl]=t[n],i=this[sk],o=this[$m],a=this[ok].logMethod;for(let l in t){if(o(t[l],r)===!1){this[l]=ak;continue}this[l]=uk(l,i)?Em[l](a):an(t[l],a)}this.emit("level-change",n,r,e[s],s,this)}function fk(n){let{levels:e,levelVal:t}=this;return e&&e.labels?e.labels[t]:""}function pk(n){let{values:e}=this.levels,t=e[n];return t!==void 0&&this[$m](t,this[vl])}function hk(n,e,t){return n===Cm.DESC?e<=t:e>=t}function mk(n){return typeof n=="string"?hk.bind(null,n):n}function gk(n=null,e=!1){let t=n?Object.keys(n).reduce((i,o)=>(i[n[o]]=o,i),{}):null,s=Object.assign(Object.create(Object.prototype,{Infinity:{value:"silent"}}),e?null:wl,t),r=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),e?null:yt,n);return{labels:s,values:r}}function yk(n,e,t){if(typeof n=="number"){if(![].concat(Object.keys(e||{}).map(i=>e[i]),t?[]:Object.keys(wl).map(i=>+i),1/0).includes(n))throw Error(`default level:${n} must be included in custom levels`);return}let s=Object.assign(Object.create(Object.prototype,{silent:{value:1/0}}),t?null:yt,e);if(!(n in s))throw Error(`default level:${n} must be included in custom levels`)}function bk(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 vk(n){if(typeof n!="function"&&!(typeof n=="string"&&Object.values(Cm).includes(n)))throw new Error('Levels comparison should be one of "ASC", "DESC" or "function" type')}Tm.exports={initialLsCache:lk,genLsCache:ck,levelMethods:Em,getLevel:fk,setLevel:dk,isLevelEnabled:pk,mappings:gk,assertNoLevelCollisions:bk,assertDefaultLevelFound:yk,genLevelComparison:mk,assertLevelComparison:vk}});var Sl=j((AR,Rm)=>{"use strict";Rm.exports={version:"10.3.1"}});var Fm=j(($R,Nm)=>{"use strict";var{EventEmitter:wk}=require("node:events"),{lsCacheSym:xk,levelValSym:Sk,setLevelSym:Al,getLevelSym:Pm,chindingsSym:Mr,mixinSym:_k,asJsonSym:Im,writeSym:Ak,mixinMergeStrategySym:kk,timeSym:$k,timeSliceIndexSym:Ck,streamSym:Mm,serializersSym:ln,formattersSym:hs,errorKeySym:Ek,messageKeySym:Tk,useOnlyCustomLevelsSym:Rk,needsMetadataGsym:Pk,redactFmtSym:Ok,stringifySym:Ik,formatOptsSym:Mk,stringifiersSym:Lk,msgPrefixSym:kl,hooksSym:Dk}=Pn(),{getLevel:Nk,setLevel:Fk,isLevelEnabled:jk,mappings:Hk,initialLsCache:Bk,genLsCache:Uk,assertNoLevelCollisions:qk}=xl(),{asChindings:$l,asJson:Kk,buildFormatters:_l,stringify:Om,noop:Lm}=Pr(),{version:Wk}=Sl(),Gk=tl(),Vk=class{},Dm={constructor:Vk,child:zk,bindings:Yk,setBindings:Jk,flush:Zk,isLevelEnabled:jk,version:Wk,get level(){return this[Pm]()},set level(n){this[Al](n)},get levelVal(){return this[Sk]},set levelVal(n){throw Error("levelVal is read-only")},get msgPrefix(){return this[kl]},get[Symbol.toStringTag](){return"Pino"},[xk]:Bk,[Ak]:Xk,[Im]:Kk,[Pm]:Nk,[Al]:Fk};Object.setPrototypeOf(Dm,wk.prototype);Nm.exports=function(){return Object.create(Dm)};var Ir=n=>n;function zk(n,e){if(!n)throw Error("missing bindings for child Pino");let t=this[ln],s=this[hs],r=Object.create(this);if(e==null)return r[hs].bindings!==Ir&&(r[hs]=_l(s.level,Ir,s.log)),r[Mr]=$l(r,n),this.onChild!==Lm&&this.onChild(r),r;if(e.hasOwnProperty("serializers")===!0){r[ln]=Object.create(null);for(let u in t)r[ln][u]=t[u];let a=Object.getOwnPropertySymbols(t);for(var i=0;i<a.length;i++){let u=a[i];r[ln][u]=t[u]}for(let u in e.serializers)r[ln][u]=e.serializers[u];let l=Object.getOwnPropertySymbols(e.serializers);for(var o=0;o<l.length;o++){let u=l[o];r[ln][u]=e.serializers[u]}}else r[ln]=t;if(e.hasOwnProperty("formatters")){let{level:a,bindings:l,log:u}=e.formatters;r[hs]=_l(a||s.level,l||Ir,u||s.log)}else r[hs]=_l(s.level,Ir,s.log);if(e.hasOwnProperty("customLevels")===!0&&(qk(this.levels,e.customLevels),r.levels=Hk(e.customLevels,r[Rk]),Uk(r)),typeof e.redact=="object"&&e.redact!==null||Array.isArray(e.redact)){r.redact=e.redact;let a=Gk(r.redact,Om),l={stringify:a[Ok]};r[Ik]=Om,r[Lk]=a,r[Mk]=l}if(typeof e.msgPrefix=="string"&&(r[kl]=(this[kl]||"")+e.msgPrefix),r[Mr]=$l(r,n),e.level!==void 0&&e.level!==this.level||e.hasOwnProperty("customLevels")){let a=e.level||this.level;r[Al](a)}return this.onChild(r),r}function Yk(){let e=`{${this[Mr].substr(1)}}`,t=JSON.parse(e);return delete t.pid,delete t.hostname,t}function Jk(n){let e=$l(this,n);this[Mr]=e}function Qk(n,e){return Object.assign(e,n)}function Xk(n,e,t){let s=this[$k](),r=this[_k],i=this[Ek],o=this[Tk],a=this[kk]||Qk,l,u=this[Dk].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[Im](l,e,t,s),f=this[Mm];f[Pk]===!0&&(f.lastLevel=t,f.lastObj=l,f.lastMsg=e,f.lastTime=s.slice(this[Ck]),f.lastLogger=this),f.write(u?u(d):d)}function Zk(n){if(n!=null&&typeof n!="function")throw Error("callback must be a function");let e=this[Mm];typeof e.flush=="function"?e.flush(n||Lm):n&&n()}});var Um=j((Rl,Bm)=>{"use strict";var{hasOwnProperty:ms}=Object.prototype,un=Tl();un.configure=Tl;un.stringify=un;un.default=un;Rl.stringify=un;Rl.configure=Tl;Bm.exports=un;var e$=/[\u0000-\u001f\u0022\u005c\ud800-\udfff]/;function qt(n){return n.length<5e3&&!e$.test(n)?`"${n}"`:JSON.stringify(n)}function Cl(n,e){if(n.length>200||e)return n.sort(e);for(let t=1;t<n.length;t++){let s=n[t],r=t;for(;r!==0&&n[r-1]>s;)n[r]=n[r-1],r--;n[r]=s}return n}var t$=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function El(n){return t$.call(n)!==void 0&&n.length!==0}function jm(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 n$(n){if(ms.call(n,"circularValue")){let e=n.circularValue;if(typeof e=="string")return`"${e}"`;if(e==null)return e;if(e===Error||e===TypeError)return{toString(){throw new TypeError("Converting circular structure to JSON")}};throw new TypeError('The "circularValue" argument must be of type string or the value null or undefined')}return'"[Circular]"'}function s$(n){let e;if(ms.call(n,"deterministic")&&(e=n.deterministic,typeof e!="boolean"&&typeof e!="function"))throw new TypeError('The "deterministic" argument must be of type boolean or comparator function');return e===void 0?!0:e}function r$(n,e){let t;if(ms.call(n,e)&&(t=n[e],typeof t!="boolean"))throw new TypeError(`The "${e}" argument must be of type boolean`);return t===void 0?!0:t}function Hm(n,e){let t;if(ms.call(n,e)){if(t=n[e],typeof t!="number")throw new TypeError(`The "${e}" argument must be of type number`);if(!Number.isInteger(t))throw new TypeError(`The "${e}" argument must be an integer`);if(t<1)throw new RangeError(`The "${e}" argument must be >= 1`)}return t===void 0?1/0:t}function cn(n){return n===1?"1 item":`${n} items`}function i$(n){let e=new Set;for(let t of n)(typeof t=="string"||typeof t=="number")&&e.add(String(t));return e}function o$(n){if(ms.call(n,"strict")){let e=n.strict;if(typeof e!="boolean")throw new TypeError('The "strict" argument must be of type boolean');if(e)return t=>{let s=`Object can not safely be stringified. Received type ${typeof t}`;throw typeof t!="function"&&(s+=` (${t.toString()})`),new Error(s)}}}function Tl(n){n={...n};let e=o$(n);e&&(n.bigint===void 0&&(n.bigint=!1),"circularValue"in n||(n.circularValue=Error));let t=n$(n),s=r$(n,"bigint"),r=s$(n),i=typeof r=="function"?r:void 0,o=Hm(n,"maximumDepth"),a=Hm(n,"maximumBreadth");function l(m,p,g,x,S,A){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 qt(k);case"object":{if(k===null)return"null";if(g.indexOf(k)!==-1)return t;let y="",b=",",v=A;if(Array.isArray(k)){if(k.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(k),S!==""&&(A+=S,y+=`
|
|
716
716
|
${A}`,b=`,
|
|
717
|
-
${A}`);let F=Math.min(k.length,a),B=0;for(;B<F-1;B++){let T=l(String(B),k,g,x,
|
|
718
|
-
${v}`),g.pop(),`[${y}]`}let w=Object.keys(k),
|
|
719
|
-
${A}`,
|
|
717
|
+
${A}`);let F=Math.min(k.length,a),B=0;for(;B<F-1;B++){let T=l(String(B),k,g,x,S,A);y+=T!==void 0?T:"null",y+=b}let z=l(String(B),k,g,x,S,A);if(y+=z!==void 0?z:"null",k.length-1>a){let T=k.length-a-1;y+=`${b}"... ${cn(T)} not stringified"`}return S!==""&&(y+=`
|
|
718
|
+
${v}`),g.pop(),`[${y}]`}let w=Object.keys(k),_=w.length;if(_===0)return"{}";if(o<g.length+1)return'"[Object]"';let E="",I="";S!==""&&(A+=S,b=`,
|
|
719
|
+
${A}`,E=" ");let $=Math.min(_,a);r&&!El(k)&&(w=Cl(w,i)),g.push(k);for(let F=0;F<$;F++){let B=w[F],z=l(B,k,g,x,S,A);z!==void 0&&(y+=`${I}${qt(B)}:${E}${z}`,I=b)}if(_>a){let F=_-a;y+=`${I}"...":${E}"${cn(F)} not stringified"`,I=b}return S!==""&&I.length>1&&(y=`
|
|
720
720
|
${A}${y}
|
|
721
|
-
${v}`),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 u(m,p,g,x,
|
|
721
|
+
${v}`),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 u(m,p,g,x,S,A){switch(typeof p=="object"&&p!==null&&typeof p.toJSON=="function"&&(p=p.toJSON(m)),typeof p){case"string":return qt(p);case"object":{if(p===null)return"null";if(g.indexOf(p)!==-1)return t;let k=A,y="",b=",";if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),S!==""&&(A+=S,y+=`
|
|
722
722
|
${A}`,b=`,
|
|
723
|
-
${A}`);let
|
|
724
|
-
${k}`),g.pop(),`[${y}]`}g.push(p);let v="";
|
|
725
|
-
${A}`,v=" ");let w="";for(let
|
|
723
|
+
${A}`);let _=Math.min(p.length,a),E=0;for(;E<_-1;E++){let $=u(String(E),p[E],g,x,S,A);y+=$!==void 0?$:"null",y+=b}let I=u(String(E),p[E],g,x,S,A);if(y+=I!==void 0?I:"null",p.length-1>a){let $=p.length-a-1;y+=`${b}"... ${cn($)} not stringified"`}return S!==""&&(y+=`
|
|
724
|
+
${k}`),g.pop(),`[${y}]`}g.push(p);let v="";S!==""&&(A+=S,b=`,
|
|
725
|
+
${A}`,v=" ");let w="";for(let _ of x){let E=u(_,p[_],g,x,S,A);E!==void 0&&(y+=`${w}${qt(_)}:${v}${E}`,w=b)}return S!==""&&w.length>1&&(y=`
|
|
726
726
|
${A}${y}
|
|
727
|
-
${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 d(m,p,g,x,
|
|
728
|
-
${
|
|
729
|
-
${
|
|
730
|
-
${A}`,g.pop(),`[${
|
|
731
|
-
${
|
|
732
|
-
${
|
|
733
|
-
${A}`),g.pop(),`{${v}}`}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
|
|
727
|
+
${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 d(m,p,g,x,S){switch(typeof p){case"string":return qt(p);case"object":{if(p===null)return"null";if(typeof p.toJSON=="function"){if(p=p.toJSON(m),typeof p!="object")return d(m,p,g,x,S);if(p===null)return"null"}if(g.indexOf(p)!==-1)return t;let A=S;if(Array.isArray(p)){if(p.length===0)return"[]";if(o<g.length+1)return'"[Array]"';g.push(p),S+=x;let E=`
|
|
728
|
+
${S}`,I=`,
|
|
729
|
+
${S}`,$=Math.min(p.length,a),F=0;for(;F<$-1;F++){let z=d(String(F),p[F],g,x,S);E+=z!==void 0?z:"null",E+=I}let B=d(String(F),p[F],g,x,S);if(E+=B!==void 0?B:"null",p.length-1>a){let z=p.length-a-1;E+=`${I}"... ${cn(z)} not stringified"`}return E+=`
|
|
730
|
+
${A}`,g.pop(),`[${E}]`}let k=Object.keys(p),y=k.length;if(y===0)return"{}";if(o<g.length+1)return'"[Object]"';S+=x;let b=`,
|
|
731
|
+
${S}`,v="",w="",_=Math.min(y,a);El(p)&&(v+=jm(p,b,a),k=k.slice(p.length),_-=p.length,w=b),r&&(k=Cl(k,i)),g.push(p);for(let E=0;E<_;E++){let I=k[E],$=d(I,p[I],g,x,S);$!==void 0&&(v+=`${w}${qt(I)}: ${$}`,w=b)}if(y>a){let E=y-a;v+=`${w}"...": "${cn(E)} not stringified"`,w=b}return w!==""&&(v=`
|
|
732
|
+
${S}${v}
|
|
733
|
+
${A}`),g.pop(),`{${v}}`}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 qt(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 v=Math.min(p.length,a),w=0;for(;w<v-1;w++){let E=f(String(w),p[w],g);x+=E!==void 0?E:"null",x+=","}let _=f(String(w),p[w],g);if(x+=_!==void 0?_:"null",p.length-1>a){let E=p.length-a-1;x+=`,"... ${cn(E)} not stringified"`}return g.pop(),`[${x}]`}let A=Object.keys(p),k=A.length;if(k===0)return"{}";if(o<g.length+1)return'"[Object]"';let y="",b=Math.min(k,a);S&&El(p)&&(x+=jm(p,",",a),A=A.slice(p.length),b-=p.length,y=","),r&&(A=Cl(A,i)),g.push(p);for(let v=0;v<b;v++){let w=A[v],_=f(w,p[w],g);_!==void 0&&(x+=`${y}${qt(w)}:${_}`,y=",")}if(k>a){let v=k-a;x+=`${y}"...":"${cn(v)} not stringified"`}return g.pop(),`{${x}}`}case"number":return isFinite(p)?String(p):e?e(p):"null";case"boolean":return p===!0?"true":"false";case"undefined":return;case"bigint":if(s)return String(p);default:return e?e(p):void 0}}function h(m,p,g){if(arguments.length>1){let x="";if(typeof g=="number"?x=" ".repeat(Math.min(g,10)):typeof g=="string"&&(x=g.slice(0,10)),p!=null){if(typeof p=="function")return l("",{"":m},[],p,x,"");if(Array.isArray(p))return u("",m,[],i$(p),x,"")}if(x.length!==0)return d("",m,[],x,"")}return f("",m,[])}return h}});var Gm=j((CR,Wm)=>{"use strict";var Pl=Symbol.for("pino.metadata"),{DEFAULT_LEVELS:Km}=Or(),a$=Km.info;function l$(n,e){n=n||[],e=e||{dedupe:!1};let t=Object.create(Km);t.silent=1/0,e.levels&&typeof e.levels=="object"&&Object.keys(e.levels).forEach(f=>{t[f]=e.levels[f]});let s={write:r,add:a,remove:l,emit:i,flushSync:o,end:u,minLevel:0,lastId:0,streams:[],clone:d,[Pl]:!0,streamLevels:t};return Array.isArray(n)?n.forEach(a,s):a.call(s,n),n=null,s;function r(f){let h,m=this.lastLevel,{streams:p}=this,g=0,x;for(let S=c$(p.length,e.dedupe);d$(S,p.length,e.dedupe);S=u$(S,e.dedupe))if(h=p[S],h.level<=m){if(g!==0&&g!==h.level)break;if(x=h.stream,x[Pl]){let{lastTime:A,lastMsg:k,lastObj:y,lastLogger:b}=this;x.lastLevel=m,x.lastTime=A,x.lastMsg=k,x.lastObj=y,x.lastLogger=b}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=a$;let S={stream:m,level:x,levelVal:void 0,id:++s.lastId};return p.unshift(S),p.sort(qm),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(qm),this.minLevel=h.length>0?h[0].level:-1),s}function u(){for(let{stream:f}of this.streams)typeof f.flushSync=="function"&&f.flushSync(),f.end()}function d(f){let h=new Array(this.streams.length);for(let m=0;m<h.length;m++)h[m]={level:f,stream:this.streams[m].stream};return{write:r,add:a,remove:l,minLevel:f,streams:h,clone:d,emit:i,flushSync:o,[Pl]:!0}}}function qm(n,e){return n.level-e.level}function c$(n,e){return e?n-1:0}function u$(n,e){return e?n-1:n+1}function d$(n,e,t){return t?n>=0:n<e}Wm.exports=l$});var Ll=j((ER,tt)=>{"use strict";var f$=require("node:os"),eg=Qa(),p$=Xa(),h$=tl(),tg=Rh(),m$=Fm(),ng=Pn(),{configure:g$}=Um(),{assertDefaultLevelFound:y$,mappings:sg,genLsCache:b$,genLevelComparison:v$,assertLevelComparison:w$}=xl(),{DEFAULT_LEVELS:rg,SORTING_ORDER:x$}=Or(),{createArgsNormalizer:S$,asChindings:_$,buildSafeSonicBoom:Vm,buildFormatters:A$,stringify:Ol,normalizeDestFileDescriptor:zm,noop:k$}=Pr(),{version:$$}=Sl(),{chindingsSym:Ym,redactFmtSym:C$,serializersSym:Jm,timeSym:E$,timeSliceIndexSym:T$,streamSym:R$,stringifySym:Qm,stringifySafeSym:Il,stringifiersSym:Xm,setLevelSym:P$,endSym:O$,formatOptsSym:I$,messageKeySym:M$,errorKeySym:L$,nestedKeySym:D$,mixinSym:N$,levelCompSym:F$,useOnlyCustomLevelsSym:j$,formattersSym:Zm,hooksSym:H$,nestedKeyStrSym:B$,mixinMergeStrategySym:U$,msgPrefixSym:q$}=ng,{epochTime:ig,nullTime:K$}=tg,{pid:W$}=process,G$=f$.hostname(),V$=eg.err,z$={level:"info",levelComparison:x$.ASC,levels:rg,messageKey:"msg",errorKey:"err",nestedKey:null,enabled:!0,base:{pid:W$,hostname:G$},serializers:Object.assign(Object.create(null),{err:V$}),formatters:Object.assign(Object.create(null),{bindings(n){return n},level(n,e){return{level:e}}}),hooks:{logMethod:void 0,streamWrite:void 0},timestamp:ig,name:void 0,redact:null,customLevels:null,useOnlyCustomLevels:!1,depthLimit:5,edgeLimit:100},Y$=S$(z$),J$=Object.assign(Object.create(null),eg);function Ml(...n){let e={},{opts:t,stream:s}=Y$(e,p$(),...n);t.level&&typeof t.level=="string"&&rg[t.level.toLowerCase()]!==void 0&&(t.level=t.level.toLowerCase());let{redact:r,crlf:i,serializers:o,timestamp:a,messageKey:l,errorKey:u,nestedKey:d,base:f,name:h,level:m,customLevels:p,levelComparison:g,mixin:x,mixinMergeStrategy:S,useOnlyCustomLevels:A,formatters:k,hooks:y,depthLimit:b,edgeLimit:v,onChild:w,msgPrefix:_}=t,E=g$({maximumDepth:b,maximumBreadth:v}),I=A$(k.level,k.bindings,k.log),$=Ol.bind({[Il]:E}),F=r?h$(r,$):{},B=r?{stringify:F[C$]}:{stringify:$},z="}"+(i?`\r
|
|
734
734
|
`:`
|
|
735
|
-
`),T=_$.bind(null,{[
|
|
735
|
+
`),T=_$.bind(null,{[Ym]:"",[Jm]:o,[Xm]:F,[Qm]:Ol,[Il]:E,[Zm]:I}),C="";f!==null&&(h===void 0?C=T(f):C=T(Object.assign({},f,{name:h})));let Z=a instanceof Function?a:a?ig:K$,D=Z().indexOf(":")+1;if(A&&!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"`);y$(m,p,A);let K=sg(p,A);typeof s.emit=="function"&&s.emit("message",{code:"PINO_CONFIG",config:{levels:K,messageKey:l,errorKey:u}}),w$(g);let ee=v$(g);return Object.assign(e,{levels:K,[F$]:ee,[j$]:A,[R$]:s,[E$]:Z,[T$]:D,[Qm]:Ol,[Il]:E,[Xm]:F,[O$]:z,[I$]:B,[M$]:l,[L$]:u,[D$]:d,[B$]:d?`,${JSON.stringify(d)}:{`:"",[Jm]:o,[N$]:x,[U$]:S,[Ym]:C,[Zm]:I,[H$]:y,silent:k$,onChild:w,[q$]:_}),Object.setPrototypeOf(e,m$()),b$(e),e[P$](m),e}tt.exports=Ml;tt.exports.destination=(n=process.stdout.fd)=>typeof n=="object"?(n.dest=zm(n.dest||process.stdout.fd),Vm(n)):Vm({dest:zm(n),minLength:0});tt.exports.transport=ml();tt.exports.multistream=Gm();tt.exports.levels=sg();tt.exports.stdSerializers=J$;tt.exports.stdTimeFunctions=Object.assign({},tg);tt.exports.symbols=ng;tt.exports.version=$$;tt.exports.default=Ml;tt.exports.pino=Ml});function gs(n){return new Dl(n)}var Q$,X$,Z$,Dl,Nl=N(()=>{"use strict";Q$={maxSteps:150,thinkingEnabled:!0,selfEvalEnabled:!0,minConfidence:.6,showThinking:!1},X$=`
|
|
736
736
|
## Reasoning Protocol
|
|
737
737
|
|
|
738
738
|
Before taking ANY action, you MUST think step-by-step inside <thinking> tags.
|
|
@@ -792,11 +792,11 @@ Rate your work. Reply with ONLY a JSON object \u2014 no other text:
|
|
|
792
792
|
}
|
|
793
793
|
</self_eval>
|
|
794
794
|
`.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(`
|
|
795
|
-
`)}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
|
|
796
|
-
`)}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 t0(){try{if(
|
|
795
|
+
`)}getTurnSummary(){let e=this.turnSteps.length,t=this.turnSteps.filter(r=>r.action).length,s=this.turnSteps.filter(r=>r.reflection).length;return`${e} steps, ${t} actions, ${s} reflections`}}});function ys(n=3){return new Fl(n)}var e0,Fl,jl=N(()=>{"use strict";e0=[{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}],Fl=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 e0)if(a.test(t)){let l=r?.lastStrategy===a.strategy&&i>=2,u=l?"decompose_task":a.strategy;return o.lastStrategy=u,this.failures.set(e,o),{errorClass:a.errorClass,strategy:u,explanation:a.explanation,suggestion:l?`Previous recovery attempt ("${a.strategy}") also failed. Try breaking this into smaller steps or use a completely different approach.`:a.suggestion,alternatives:a.alternatives,autoRetry:!l&&a.autoRetry}}return o.lastStrategy=i===1?"retry_fixed":"graceful_fail",this.failures.set(e,o),{errorClass:"unknown",strategy:o.lastStrategy,explanation:`Unexpected error from "${e}".`,suggestion:i===1?"Review the error message and adjust your approach.":"This error is persistent. Explain to the user what went wrong and suggest manual steps.",alternatives:this.suggestAlternatives(e),autoRetry:!1}}buildRecoveryMessage(e,t){let s=[`ERROR: ${t}`,"","[Recovery Analysis]",` Type: ${e.errorClass}`,` Strategy: ${e.strategy}`,` Explanation: ${e.explanation}`,` Suggestion: ${e.suggestion}`];switch(e.alternatives.length>0&&s.push(` Alternative tools: ${e.alternatives.join(", ")}`),e.strategy){case"read_first":s.push("","\u2192 ACTION: Read the file or directory first, then retry with correct information.");break;case"retry_fixed":s.push("","\u2192 ACTION: Fix the arguments based on the error, then retry.");break;case"alternative_tool":s.push("","\u2192 ACTION: Use a different tool to achieve the same goal.");break;case"decompose_task":s.push("","\u2192 ACTION: Break this into smaller, simpler steps.");break;case"ask_user":s.push("","\u2192 ACTION: Ask the user for clarification. Do NOT retry automatically.");break;case"graceful_fail":s.push("","\u2192 ACTION: Explain what went wrong clearly. Suggest manual steps if possible.");break}return s.join(`
|
|
796
|
+
`)}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 t0(){try{if(It.existsSync(Lr))return JSON.parse(It.readFileSync(Lr,"utf-8"))}catch{}return{}}function n0(n){try{let e=Dr.dirname(Lr);It.existsSync(e)||It.mkdirSync(e,{recursive:!0}),It.writeFileSync(Lr,JSON.stringify(n,null,2),"utf-8")}catch{}}function ql(n,e){let t=0,s=!1,r=!1;for(let i=e;i<n.length;i++){let o=n[i];if(r){r=!1;continue}if(o==="\\"&&s){r=!0;continue}if(o==='"'){s=!s;continue}if(!s&&(o==="{"&&t++,o==="}"&&(t--,t===0)))return n.slice(e,i+1)}return null}function bs(n){if(typeof n.name=="string"&&n.arguments&&typeof n.arguments=="object")return{tool:n.name,args:n.arguments};if(typeof n.tool=="string"&&n.args&&typeof n.args=="object")return{tool:n.tool,args:n.args};if(typeof n.name=="string"&&n.parameters&&typeof n.parameters=="object")return{tool:n.name,args:n.parameters};if(n.function&&typeof n.function=="object"){let e=n.function;if(typeof e.name=="string"){let t={};if(typeof e.arguments=="string")try{t=JSON.parse(e.arguments)}catch{t={}}else e.arguments&&typeof e.arguments=="object"&&(t=e.arguments);return{tool:e.name,args:t}}}return null}function s0(n){return n.replace(/"/g,'"').replace(/'/g,"'").replace(/</g,"<").replace(/>/g,">").replace(/&/g,"&")}function r0(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=ql(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 i0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)<<?\/tool[-_]call\s*>>?/gi,s;for(;(s=t.exec(n))!==null;)try{let r=JSON.parse(s[1].trim()),i=bs(r);i&&e.push({...i,format:"xml_tags",rawMatch:s[0]})}catch{}return e}function o0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)<<?\/tool[-_]call\s*>>?/gi,s;for(;(s=t.exec(n))!==null;)try{let r=JSON.parse(s[1].trim());if(r.parameters||r.name){let i=bs(r);i&&e.push({...i,format:"hermes",rawMatch:s[0]})}}catch{}return e}function a0(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=ag(r);for(let o of i)e.push({...o,format:"xml_tool_call_wrapper",rawMatch:s[0]})}return e}function ag(n){let e=[],t=["read_file","write_file","edit_file","search_and_replace","run_command","search_codebase","list_dir","create_dir","delete_file","append_to_file","patch_file","move_file","get_file_info"];for(let s of t){let r=new RegExp(`<<?${s}(\\s+[\\s\\S]*?)?(?:>>?([\\s\\S]*?)<<?\\/${s}>>?|\\s*\\/?>>?)`,"gi"),i;for(;(i=r.exec(n))!==null;){let o=i[1]||"",a=i[2]||"",l={},u=/(\w+)\s*=\s*(?:"([^"]*)"|'([^']*)'|(\S+))/g,d;for(;(d=u.exec(o))!==null;){let h=d[1].toLowerCase(),m=d[2]??d[3]??d[4];l[h]=s0(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 l0(n){return ag(n)}function c0(n){let e=[],t=/```(?:json|tool_call)?\s*\n([\s\S]*?)\n```/g,s;for(;(s=t.exec(n))!==null;)try{let r=JSON.parse(s[1].trim()),i=bs(r);i&&e.push({...i,format:"markdown_json",rawMatch:s[0]})}catch{}return e}function u0(n){let e=[],t=/\{\s*"function"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=ql(n,s.index);if(r)try{let i=JSON.parse(r),o=bs(i);o&&e.push({...o,format:"function_call",rawMatch:r})}catch{}}return e}function d0(n){let e=[],t=/\{\s*"(?:name|tool)"\s*:/g,s;for(;(s=t.exec(n))!==null;){let r=ql(n,s.index);if(r)try{let i=JSON.parse(r),o=bs(i);o&&e.push({...o,format:"json_object",rawMatch:r})}catch{}}return e}function f0(n){let e=[],t=/<<?tool[-_]call\s*>>?([\s\S]*?)(?:<<?\/tool[-_]call\s*>>?|$)/gi,s,r=!1;for(;(s=t.exec(n))!==null;){let i=s[1],o=/<function=([^>]+)>/i.exec(i);if(o){r=!0;let a=o[1].trim(),l={},u=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,d;for(;(d=u.exec(i))!==null;){let f=d[1].trim(),h=d[2].trim();h==="true"?h=!0:h==="false"?h=!1:!isNaN(Number(h))&&h!==""&&(h=Number(h)),l[f]=h}e.push({tool:a,args:l,format:"xml_parameters",rawMatch:s[0]})}}if(!r&&/<function=([^>]+)>/i.test(n)){let i=/<function=([^>]+)>/i.exec(n);if(i){let o=i[1].trim(),a={},l=/<parameter=([^>]+)>([\s\S]*?)<\/parameter>/gi,u;for(;(u=l.exec(n))!==null;){let d=u[1].trim(),f=u[2].trim();f==="true"?f=!0:f==="false"?f=!1:!isNaN(Number(f))&&f!==""&&(f=Number(f)),a[d]=f}e.push({tool:o,args:a,format:"xml_parameters",rawMatch:n})}}return e}function lg(){return Bl||(Bl=new Ul),Bl}var It,Dr,og,Lr,Hl,Ul,Bl,cg=N(()=>{"use strict";It=O(require("fs")),Dr=O(require("path")),og=O(require("os")),Lr=Dr.join(og.homedir(),".hablas","model-formats.json");Hl=[{format:"action_tag_json",parse:r0},{format:"xml_tool_call_wrapper",parse:a0},{format:"xml_prompt",parse:l0},{format:"xml_tags",parse:i0},{format:"xml_parameters",parse:f0},{format:"hermes",parse:o0},{format:"markdown_json",parse:c0},{format:"function_call",parse:u0},{format:"json_object",parse:d0}],Ul=class{registry;constructor(){this.registry=t0()}parse(e,t,s){if(t&&Array.isArray(t)&&t.length>0){let o=t.filter(a=>a?.function?.name&&typeof a.function.name=="string");if(o.length>0){let a=o.map(l=>({function:{name:l.function.name,arguments:l.function.arguments||{}}}));return s&&this.learnFormat(s,"native"),{toolCalls:a,displayContent:(e||"").trim(),format:"native"}}}let r=e||"";if(!r.trim())return{toolCalls:[],displayContent:"",format:"unknown"};if(s){let o=this.registry[s];if(o&&o.format!=="native"){let a=Hl.find(l=>l.format===o.format);if(a){let l=a.parse(r);if(l.length>0)return this.learnFormat(s,o.format),this.buildResult(l,r)}}}for(let{parse:o}of Hl){let a=o(r);if(a.length>0){let l=a[0].format;return s&&this.learnFormat(s,l),this.buildResult(a,r)}}let i=r.trim();return i=i.replace(/<<?thinking>>?[\s\S]*?<<?\/thinking>>?/gi,""),i=i.replace(/<<?think>>?[\s\S]*?<<?\/think>>?/gi,""),i=i.replace(/<<?action>>?[\s\S]*?<<?\/action>>?/gi,""),i=i.replace(/<<?response>>?/gi,"").replace(/<<?\/response>>?/gi,""),{toolCalls:[],displayContent:i.trim(),format:"unknown"}}mightContainToolCall(e){if(!e)return!1;let t=e.trim();return!!(/<<?action[\s>]/i.test(t)||/<<?tool[-_]call[\s>]/i.test(t)||/<function=/i.test(t)||t.includes("```tool_call")||t.includes("```json")&&t.includes('"name"')||/<<?(?:read_file|write_file|run_command|edit_file|search_codebase|create_dir|delete_file|list_dir|append_to_file|patch_file|move_file|get_file_info)[\s>]/i.test(t)||t.startsWith("{")&&(t.includes('"name"')||t.includes('"tool"'))&&(t.includes('"arguments"')||t.includes('"args"')||t.includes('"parameters"'))||t.includes('"function"')&&t.includes('"name"'))}detectFormat(e){for(let{format:t,parse:s}of Hl)if(s(e).length>0)return t;return"unknown"}learnFormat(e,t){let s=this.registry[e];s&&s.format===t?(s.successCount++,s.lastUsed=new Date().toISOString()):this.registry[e]={format:t,successCount:1,lastUsed:new Date().toISOString()},n0(this.registry)}getLearnedFormat(e){return this.registry[e]?.format??null}getLearnedFormats(){let e={};for(let[t,s]of Object.entries(this.registry))e[t]={format:s.format,successCount:s.successCount};return e}buildResult(e,t){let s=e.map(o=>({function:{name:o.tool,arguments:o.args}})),r=t,i=[...e].sort((o,a)=>a.rawMatch.length-o.rawMatch.length);for(let o of i)r=r.replace(o.rawMatch,"");return r=r.replace(/<<?thinking>>?[\s\S]*?<<?\/thinking>>?/gi,""),r=r.replace(/<<?think>>?[\s\S]*?<<?\/think>>?/gi,""),r=r.replace(/<<?action>>?[\s\S]*?<<?\/action>>?/gi,""),r=r.replace(/<<?response>>?/gi,"").replace(/<<?\/response>>?/gi,""),r=r.replace(/\n{3,}/g,`
|
|
797
797
|
|
|
798
|
-
`),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},Bl=null});function h0(n,e,t){let r=
|
|
799
|
-
Please correct your format and try again. Ensure all JSON keys/values are double-quoted and correctly escaped.`;A("ERROR_HEALING",`Syntax error inside action tags (attempt ${
|
|
798
|
+
`),{toolCalls:s,displayContent:r.trim(),format:e[0]?.format??"unknown"}}},Bl=null});function h0(n,e,t){let r=lg().parse(e,n,t);return{toolCalls:r.toolCalls,displayContent:r.displayContent}}function m0(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 g0(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 fg(n,e,t,s){let r=0,i=Date.now();for(;r<=dg;){let o=await n.execute({name:e,arguments:t});if(o.success||r>=dg)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 Fr(n){let{identity:e,client:t,registry:s,session:r,contextManager:i,logger:o,io:a={},safetyPolicy:l,abortSignal:u,skipTools:d}=n,f=n.reactEngine??gs(),h=n.errorRecovery??ys(),m=d?[]:s.getOllamaTools(),p=t.getModel(),g=n.maxIterations??150,x="IDLE",S=0,A=(E,I)=>{let $=p0[x];if(!$||!$.includes(E))throw new Error(`\u{1F6AB} Illegal State Transition Attempt: ${x} \u2501\u2501\u25B6 ${E} (Reason: ${I??"none"})`);o.info({from:x,to:E,reason:I},"FSM State Transition"),x=E},k=[],y=[],b=[],v="",w=0,_=!1;for(A("THINKING","Starting agentic turn");w<g;){if(w++,u?.aborted)return A("TERMINAL_ABORT","Operation aborted by signal"),{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!1,error:"Aborted",completedNaturally:_};let E=f.buildBudgetWarningPrompt();E&&r.addUserMessage(E,{priority:"critical",tags:["system-budget"]});let I;try{I=await t.chatWithTools(r.getMessages(),m,u)}catch(C){if(C.name==="AbortError"||u?.aborted)return A("TERMINAL_ABORT","Aborted during inference"),{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!1,error:"Aborted",completedNaturally:_};if(w<=1){a.onNotice?.(`Transient model error: ${C.message??"unknown"} \u2014 retrying\u2026`,"retry"),await new Promise(Z=>setTimeout(Z,1e3)),w--;continue}return A("TERMINAL_ABORT","Inference failure"),a.onError?.(C.message??"Model request failed"),{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!1,error:C.message,completedNaturally:_}}let $=I.message?.content||"",F=I.message?.tool_calls,B=f.parseThinking($);B.hasThinking&&(f.recordStep({thought:B.thinking}),o.debug({thinking:B.thinking.slice(0,200)},"ReAct thinking")),A("PARSE_VALIDATING","Received model response, parsing");let{toolCalls:z,displayContent:T}=h0(F,$,p);if(z.length===0&&$.toLowerCase().includes("<action>")){if(S++,S>=Nr){A("STATE_RECONCILIATION",`Self-correction loop exhausted after ${S} attempts`);let Z=`Failed to execute after ${Nr} syntax corrections. Rollback initiated.`;a.onError?.(Z);try{let D=s.get("undo");D&&await D.execute({count:100})}catch{}return A("TERMINAL_ABORT","Fatal syntactic self-correction exhaustion"),{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!1,error:Z,completedNaturally:_}}let C=`[SYSTEM ERROR - RETRY ${S}/${Nr}] Malformed action block detected inside <action> tags. Expected a valid JSON object matching the HEP-1 tool schema.
|
|
799
|
+
Please correct your format and try again. Ensure all JSON keys/values are double-quoted and correctly escaped.`;A("ERROR_HEALING",`Syntax error inside action tags (attempt ${S})`),a.onNotice?.(`Malformed action block detected \u2014 healing attempt ${S}/${Nr}\u2026`,"retry"),r.addToolMessage(C),A("THINKING","Error injected, waiting for next generation");continue}if(T&&T.trim()&&(v=T,await a.onAssistantText?.(T,e)),z.length===0){r.addAssistantMessage($,void 0,e.role),_=!0,A("SYNTHESIZING","Completed execution naturally");break}A("ACTION_READY","Action parsed and verified"),r.addAssistantMessage($,z,e.role);for(let C=0;C<z.length;C++){let Z=z[C];if(!Z?.function?.name)continue;let D=Z.function.name,K=Z.function.arguments||{},ee=s.getSafetyLevel(D)??"confirm";if(!s.get(D)){A("ERROR_HEALING",`Unknown tool execution: ${D}`),a.onNotice?.(`Unknown tool: ${D} \u2014 skipping`,"warn"),r.addToolMessage(`Error: Unknown tool "${D}". Available: ${s.getAll().map(se=>se.name).join(", ")}`),A("THINKING","Returning to thought loop");continue}if(await l(D,ee,K)==="skip"){r.addToolMessage(`Tool ${D} was skipped by policy/user.`);break}k.push(D),typeof K.path=="string"&&b.push(K.path);let ne=m0(D,K);a.onToolStart?.(D,ne,K),a.onToolCall?.(),f.recordStep({thought:B.hasThinking?`Executing: ${D}`:"",action:D,actionInput:K}),A("EXECUTING_TOOL",`Executing tool: ${D}`);let me=await fg(s,D,K,o);a.onToolEnd?.(D,me.success,me.error||me.output,me.duration,K);let We;if(me.success)We=as(me.output,ug),f.recordObservation(We.slice(0,300)),y.push({tool:D,success:!0,summary:me.output.slice(0,150)}),A("THINKING",`Successfully executed tool: ${D}`);else{let se=me.error||"Unknown error";if(g0(se)){A("STATE_RECONCILIATION",`Critical failure in tool ${D}: ${se}`),a.onNotice?.("Critical tool failure \u2014 aborting and rolling back changes.","warn");try{let be=s.get("undo");be&&await be.execute({count:100})}catch{}return A("TERMINAL_ABORT","State reverted due to critical failure"),{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!1,error:se,completedNaturally:_}}let H=h.analyze(D,se,K);if(We=h.buildRecoveryMessage(H,se),f.recordObservation(`FAILED: ${se}`,`Recovery: ${H.strategy} \u2014 ${H.suggestion}`),y.push({tool:D,success:!1,summary:se.slice(0,150)}),H.autoRetry&&!f.isOverBudget()){A("ERROR_HEALING","Attempting auto-recovery for transient error"),a.onNotice?.("Auto-retrying (transient error)\u2026","retry");let be=await fg(s,D,K,o);a.onToolEnd?.(D,be.success,be.output,be.duration,K),be.success?(We=as(be.output,ug),f.recordObservation(We.slice(0,300),"Auto-retry succeeded"),y[y.length-1]={tool:D,success:!0,summary:be.output.slice(0,150)},A("THINKING","Recovery successful")):A("THINKING","Recovery failed, continuing turn")}else A("THINKING","Continuing turn with failed step")}r.addToolMessage(We),me.success&&D==="read_file"&&typeof K.path=="string"&&i?.addFile(K.path,me.output),o.info({tool:D,success:me.success,durationMs:me.duration,retries:me.retries},"Tool executed")}f.isOverBudget()&&a.onNotice?.(`Reached max reasoning steps (${f.getConfig().maxSteps}). Wrapping up.`,"warn")}return w>=g&&!_?(a.onNotice?.(`Reached max iterations (${g}). Stopping.`,"warn"),A("TERMINAL_ABORT","Max iterations boundary exceeded"),{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!1,error:"Max iterations exceeded",completedNaturally:_}):(A("TERMINAL_SUCCESS","Turn finalized successfully"),x="IDLE",{output:v,toolsUsed:De(k),toolResults:y,touchedFiles:De(b),iterations:w,success:!0,completedNaturally:_})}function De(n){return[...new Set(n)]}function pg(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 hg(){return(n,e)=>e==="dangerous"?"skip":"allow"}var ug,dg,Nr,p0,Kl=N(()=>{"use strict";ya();Nl();jl();cg();ug=2e3,dg=2,Nr=3,p0={IDLE:["THINKING"],THINKING:["PARSE_VALIDATING","TERMINAL_ABORT"],PARSE_VALIDATING:["ACTION_READY","ERROR_HEALING","SYNTHESIZING","TERMINAL_ABORT"],ACTION_READY:["EXECUTING_TOOL","STATE_RECONCILIATION","TERMINAL_ABORT"],EXECUTING_TOOL:["THINKING","ERROR_HEALING","STATE_RECONCILIATION","TERMINAL_ABORT"],ERROR_HEALING:["THINKING","STATE_RECONCILIATION","TERMINAL_ABORT"],STATE_RECONCILIATION:["TERMINAL_ABORT"],SYNTHESIZING:["TERMINAL_SUCCESS","TERMINAL_ABORT"],TERMINAL_SUCCESS:["IDLE"],TERMINAL_ABORT:["IDLE"]}});var gg,y0,b0,v0,mg,jr,yg=N(()=>{"use strict";gg=O(Ll());Fn();va();ba();fn();Ni();Ba();Kl();y0={hablas:"planner",bob:"architect",alex:"coder",david:"researcher",emma:"product-manager"},b0=(0,gg.default)({level:"silent"}),v0=40,mg={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}},jr=class{baseConfig;agentModels;toolRegistry=null;onOutput=null;channel=null;mindsetRegistry=hr();sharedContext=null;contextManager;constructor(e){this.baseConfig=e,this.agentModels=jn(),this.contextManager=new nn(e)}setSharedContext(e){this.sharedContext=e}setChannel(e){this.channel=e}setToolRegistry(e){this.toolRegistry=e}setOutputCallback(e){this.onOutput=e}reloadModels(){this.agentModels=jn()}getAgentModel(e){let t=this.agentModels[e];if(t)return{model:t.model,temperature:t.temperature??mg[e]?.temperature??.5};let s=mg[e];return{model:s.model,temperature:s.temperature??.5}}async runAgent(e,t,s,r,i){let o=Date.now(),a=xe.find(A=>A.role===e),l=this.getAgentModel(e),u=i?.maxIterations||v0,d={...this.baseConfig,model:l.model},f=Fe(d),h=this.buildAgentPrompt(a,s),m=new sn(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:A=>{this.emit(a.name,"speaking",A.slice(0,200))},onToolStart:(A,k,y)=>{this.emit(a.name,"tool",k),this.channel&&this.channel.emitEvent({type:"act",agent:a.name,toolName:A,toolArgs:this.safeArgs(y),content:k})},onToolEnd:(A,k,y)=>{this.channel&&this.channel.emitEvent({type:"observe",agent:a.name,toolName:A,success:k,content:k?this.summarizeOk(A,y):`error: ${y.slice(0,120)}`})},onError:A=>this.emit(a.name,"error",A)},x=await Fr({identity:p,client:f,registry:this.toolRegistry,session:m,contextManager:this.contextManager,logger:b0,io:g,safetyPolicy:hg(),abortSignal:i?.abortSignal,skipTools:(!r||r.length===0,!1),maxIterations:u});if(this.sharedContext&&x.touchedFiles.length)try{this.sharedContext.set(`files:@${a.name}`,x.touchedFiles.join(", "))}catch{}let 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:u}=e[a];if(s?.abortSignal?.aborted)break;let d=[];if(i&&(d.push("## Previous Agent Results"),d.push(i)),o.length>0){d.push(`
|
|
800
800
|
## Handoff Chain`);for(let p of o)d.push(`- @${p.from} \u2192 @${p.to}: ${p.context.slice(0,100)}`)}let f=d.join(`
|
|
801
801
|
`),h=xe.find(p=>p.role===l);if(h&&a>0){let p=e[a-1].role,g=xe.find(x=>x.role===p);this.emit(h.name,"thinking",`\u2605 Handoff: @${g?.name||p} \u2192 @${h.name} (${h.title})`)}let m=await this.runAgent(l,u,f,t,s);if(r.push(m),m.success&&m.output){let p=m.output.length>600?m.output.slice(0,600)+"...":m.output;i+=`
|
|
802
802
|
|
|
@@ -868,15 +868,15 @@ Expertise: ${e.expertise.join(", ")}
|
|
|
868
868
|
${t}`),this.sharedContext){let a=this.sharedContext.getSummary();a&&(o+=`
|
|
869
869
|
|
|
870
870
|
## Shared Team Context
|
|
871
|
-
${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
|
|
871
|
+
${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 bg,Hr,vg=N(()=>{"use strict";bg=require("events"),Hr=class extends bg.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 w0,bt,Br,Ur,wg=N(()=>{"use strict";Fn();w0={hablas:"Hablas \u2014 INTJ Team Leader. Authoritative, terse, engineering-precise. Speaks in short systemic statements. No pleasantries.",emma:"Emma \u2014 Product Manager. Calm, user-focused, structured. Clarifies scope and outcomes in plain language.",bob:"Bob \u2014 System Architect. Methodical, principled, slightly formal. Talks in terms of boundaries, trade-offs, contracts.",alex:"Alex \u2014 Senior Engineer. Pragmatic, concise, action-biased. Confirms intent, then ships.",david:"David \u2014 Data & Research Analyst. Factual, evidence-driven, neutral tone. Cites context, not opinions."},bt={hablas:"Hablas",emma:"Emma",bob:"Bob",alex:"Alex",david:"David"},Br={handoff:(n,e,t)=>{let s=bt[e];return{hablas:`Routing this to you, @${s}.`,emma:`@${s}, I need the requirements framed before we move.`,bob:`@${s}, design the structure for this. Keep boundaries clean.`,alex:`@${s}, you have the implementation. Stay surgical.`,david:`@${s}, gather the context we need on this.`}[e]||`@${s}, taking this from here.`},ack:(n,e)=>`Acknowledged, @${bt[e]}. Proceeding.`,review:(n,e)=>`@${bt[e]}, structurally sound. Watch the boundaries on the next pass.`,reviewAck:(n,e)=>`Noted, @${bt[e]}. Integrating.`},Ur=class{client;spent=0;cache=new Map;opts;constructor(e,t={}){this.opts={tokenBudget:t.tokenBudget??500,maxChars:t.maxChars??140,lightModel:t.lightModel,abortSignal:t.abortSignal};let s={...e,model:this.opts.lightModel||e.model};this.client=Fe(s)}resetBudget(){this.spent=0,this.cache.clear()}setAbortSignal(e){this.opts.abortSignal=e}async generateHandoffLine(e,t,s){return this.generate(`handoff:${e}:${t}:${this.hash(s)}`,this.buildPrompt(e,t,"handoff",s),()=>Br.handoff(e,t,s))}async generateAckLine(e,t){return this.generate(`ack:${e}:${t}`,this.buildPrompt(e,t,"ack"),()=>Br.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)),()=>Br.review(e,t))}async generateReviewAck(e,t){return this.generate(`reviewAck:${e}:${t}`,this.buildPrompt(e,t,"reviewAck"),()=>Br.reviewAck(e,t))}async generate(e,t,s){let r=this.cache.get(e);if(r)return r;if(this.spent>=this.opts.tokenBudget||this.opts.abortSignal?.aborted)return s();try{let o=((await this.client.chatWithTools(t,[],this.opts.abortSignal)).message?.content||"").trim(),a=this.cleanLine(o);return a?(this.spent+=Math.ceil(a.length/4)+40,this.cache.set(e,a),a):s()}catch{return s()}}buildPrompt(e,t,s,r){let i=`You are ${bt[e]}, speaking in your own voice.
|
|
872
872
|
${w0[e]}
|
|
873
873
|
|
|
874
874
|
Hard constraints:
|
|
875
875
|
- Output exactly ONE sentence.
|
|
876
876
|
- No prefix, no quotes, no markdown, no emojis, no role labels.
|
|
877
877
|
- Maximum ${this.opts.maxChars} characters.
|
|
878
|
-
- Address @${
|
|
879
|
-
- Stay in character. Be useful, not chatty.`,o;switch(s){case"handoff":o=`You are about to hand the following task to @${
|
|
878
|
+
- Address @${bt[t]} directly.
|
|
879
|
+
- Stay in character. Be useful, not chatty.`,o;switch(s){case"handoff":o=`You are about to hand the following task to @${bt[t]}. Write a single in-character line that briefly frames what you need from them. Task: "${(r||"").slice(0,300)}"`;break;case"ack":o=`@${bt[t]} just handed you a task. Write a single in-character line acknowledging it and stating your immediate next move.`;break;case"review":o=`You just reviewed @${bt[t]}'s output below. Write a single in-character line of feedback \u2014 substantive but extremely brief. Output excerpt: """${(r||"").slice(0,400)}"""`;break;case"reviewAck":o=`@${bt[t]} just reviewed your work and gave you feedback. Write a single in-character line acknowledging it and noting the integration.`;break}return[{role:"system",content:i},{role:"user",content:o}]}cleanLine(e){let t=e.trim();return t=t.replace(/^```[a-z]*\n?|```$/gi,"").trim(),t=t.split(/\r?\n/)[0].trim(),t=t.replace(/^@?[A-Z][a-zA-Z]+\s*:\s*/,"").trim(),t=t.replace(/^["'`«»“”]+|["'`«»“”]+$/g,"").trim(),t.length>this.opts.maxChars&&(t=t.slice(0,this.opts.maxChars-1).trim()+"\u2026"),t}hash(e){let t=2166136261;for(let s=0;s<e.length;s++)t^=e.charCodeAt(s),t=t+((t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24))>>>0;return t.toString(36)}}});var ie,ct,x0,Sg,S0,_g,xg,Mn,Wl=N(()=>{"use strict";ie=O(require("fs")),ct=O(require("path")),x0=".hablas",Sg=`# Project Context
|
|
880
880
|
|
|
881
881
|
## Overview
|
|
882
882
|
<!-- Auto-generated by hablas. Describe your project here. -->
|
|
@@ -893,29 +893,29 @@ Hard constraints:
|
|
|
893
893
|
|
|
894
894
|
| Date | Decision | By | Rationale |
|
|
895
895
|
|------|----------|-----|-----------|
|
|
896
|
-
`,
|
|
896
|
+
`,_g=`# Task Assignments
|
|
897
897
|
|
|
898
898
|
## Active Tasks
|
|
899
899
|
<!-- Format: - [ ] Task description (@agent) -->
|
|
900
900
|
|
|
901
901
|
## Completed
|
|
902
902
|
<!-- Format: - [x] Task description (@agent) \u2014 result -->
|
|
903
|
-
`,
|
|
904
|
-
`+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")||
|
|
903
|
+
`,xg={"CONTEXT.md":Sg,"DECISIONS.md":S0,"TASKS.md":_g},Mn=class{contextDir;constructor(e){this.contextDir=ct.join(e,x0)}init(){let e=ct.join(ct.dirname(this.contextDir),".flowagent");if(ie.existsSync(e)&&!ie.existsSync(this.contextDir))try{ie.renameSync(e,this.contextDir)}catch{}ie.existsSync(this.contextDir)||ie.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(xg)){let r=ct.join(this.contextDir,t);ie.existsSync(r)||ie.writeFileSync(r,s,"utf-8")}}exists(){return ie.existsSync(this.contextDir)}read(e){let t=ct.join(this.contextDir,e);return ie.existsSync(t)?ie.readFileSync(t,"utf-8"):null}write(e,t){this.ensureDir();let s=ct.join(this.contextDir,e);ie.writeFileSync(s,t,"utf-8")}append(e,t){this.ensureDir();let s=ct.join(this.contextDir,e),r=ie.existsSync(s)?ie.readFileSync(s,"utf-8"):"";ie.writeFileSync(s,r+`
|
|
904
|
+
`+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")||_g).replace(`## Active Tasks
|
|
905
905
|
`,`## Active Tasks
|
|
906
906
|
${s}
|
|
907
907
|
`);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 ie.existsSync(this.contextDir)?ie.readdirSync(this.contextDir).filter(t=>t.endsWith(".md")).map(t=>{let s=ct.join(this.contextDir,t),r=ie.statSync(s);return{file:t,content:ie.readFileSync(s,"utf-8"),lastModified:r.mtime}}):[]}getSummary(){let e=this.getAll();return e.length===0?"":e.map(t=>`### ${t.file}
|
|
908
908
|
${t.content}`).join(`
|
|
909
909
|
|
|
910
|
-
`)}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(
|
|
910
|
+
`)}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(xg)){let s=ct.join(this.contextDir,e);ie.existsSync(s)&&ie.writeFileSync(s,t,"utf-8")}}getDecisions(){let e=this.read("DECISIONS.md");if(!e)return[];let t=e.split(`
|
|
911
911
|
`),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(`
|
|
912
912
|
`).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(`
|
|
913
|
-
`)}persistKV(){if(this.kvStore.size===0)return;let e=this.read("CONTEXT.md")||
|
|
913
|
+
`)}persistKV(){if(this.kvStore.size===0)return;let e=this.read("CONTEXT.md")||Sg,t=Array.from(this.kvStore.entries()).map(([i,o])=>`- **${i}**: ${o}`).join(`
|
|
914
914
|
`),s=/## Notes\n[\s\S]*$/,r=e.replace(s,`## Notes
|
|
915
915
|
${t}
|
|
916
|
-
`);this.write("CONTEXT.md",r)}ensureDir(){ie.existsSync(this.contextDir)||ie.mkdirSync(this.contextDir,{recursive:!0})}}});function Gl(n){return xe.find(e=>e.role===n)?.name||n}var
|
|
916
|
+
`);this.write("CONTEXT.md",r)}ensureDir(){ie.existsSync(this.contextDir)||ie.mkdirSync(this.contextDir,{recursive:!0})}}});function Gl(n){return xe.find(e=>e.role===n)?.name||n}var vs,Ag=N(()=>{"use strict";fn();Wl();vs=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 Mn(process.cwd());this.runner.setSharedContext(o),this.channel.emitEvent({type:"phase",agent:"System",content:"Delegating to the team"});let a=t.tasks.filter(h=>h.role!=="hablas").map(h=>({role:h.role,task:`${h.description}
|
|
917
917
|
|
|
918
|
-
Original request: ${e}`})),l=[],u="hablas",d=null;for(let h of a){if(r.abortSignal?.aborted)break;let m=xe.find(A=>A.role===h.role);if(!m)continue;this.channel.emitEvent({type:"handoff",agent:Gl(u),to:m.name});let p=await this.chat.generateHandoffLine(u,h.role,h.task);this.channel.emitEvent({type:"speak",agent:Gl(u),to:m.name,content:p});let g=await this.chat.generateAckLine(h.role,u);this.channel.emitEvent({type:"speak",agent:m.name,to:Gl(u),content:g});let x=Date.now(),
|
|
918
|
+
Original request: ${e}`})),l=[],u="hablas",d=null;for(let h of a){if(r.abortSignal?.aborted)break;let m=xe.find(A=>A.role===h.role);if(!m)continue;this.channel.emitEvent({type:"handoff",agent:Gl(u),to:m.name});let p=await this.chat.generateHandoffLine(u,h.role,h.task);this.channel.emitEvent({type:"speak",agent:Gl(u),to:m.name,content:p});let g=await this.chat.generateAckLine(h.role,u);this.channel.emitEvent({type:"speak",agent:m.name,to:Gl(u),content:g});let x=Date.now(),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"&&(d=S.output),i&&h.role==="alex"&&t.tasks.some(A=>A.role==="bob")&&d&&await this.runPeerReview("bob","alex",d,r.abortSignal)):S.error&&this.channel.emitEvent({type:"error",agent:m.name,content:S.error}),u=h.role}this.channel.emitEvent({type:"phase",agent:"System",content:"Hablas compiling final report"});let f=await this.synthesize(e,l,s,r.abortSignal);return this.channel.emitEvent({type:"done",agent:"Hablas"}),f}async runPeerReview(e,t,s,r){let i=xe.find(u=>u.role===e),o=xe.find(u=>u.role===t);if(!i||!o)return;let a=await this.chat.generateReviewLine(e,t,s);this.channel.emitEvent({type:"review",agent:i.name,to:o.name,content:a});let l=await this.chat.generateReviewAck(t,e);this.channel.emitEvent({type:"speak",agent:o.name,to:i.name,content:l}),r?.aborted}async synthesize(e,t,s,r){let i=t.filter(d=>d.success&&d.output);if(i.length===0)return{results:t,finalSynthesis:"The team encountered errors and could not complete the task. Please review the logs and try again.",synthesisOk:!1};let o=i.map(d=>{let f=xe.find(h=>h.role===d.agent);return`### Report from @${d.agentName} (${f?.title??d.agent}):
|
|
919
919
|
${d.output}`}).join(`
|
|
920
920
|
|
|
921
921
|
`),a=`You are Hablas, the Team Leader. Your team has completed a multi-agent workflow for the user's request: "${e}".
|
|
@@ -928,11 +928,10 @@ ${o}
|
|
|
928
928
|
Please compile, synthesize, and present the final unified response to the user. Describe what was achieved, the files modified/created (if any), and any next steps. Speak in your characteristic Hablas voice \u2014 INTJ, authoritative, terse, engineering-precise. Speak directly to the user.`,l=await this.runner.runAgent("hablas",a,void 0,s,{abortSignal:r});if(l.success&&l.output)return{results:t,finalSynthesis:l.output,synthesisOk:!0};let u=i.map(d=>{let f=xe.find(h=>h.role===d.agent);return`### @${d.agentName} (${f?.title??d.agent}):
|
|
929
929
|
${d.output}`}).join(`
|
|
930
930
|
|
|
931
|
-
`);return{results:t,finalSynthesis:u,synthesisOk:!1}}}});function
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
${
|
|
935
|
-
${c.chrome("\u2500".repeat(56))}`),this.lastThinking=null}renderError(e){let t=It(e.agent),s=xs(e.content||"unknown error",this.opts.maxChars);this.print(` ${t("\u25C6")} ${t(e.agent)} ${c.error("\u2717")} ${c.error(s)}`),this.lastThinking=null}print(e){console.log(e)}}});var Wr,$g=N(()=>{"use strict";Wr=class{plans=new Map;activePlanId=null;nextPlanNum=1;createPlan(e,t,s){let r=`plan_${this.nextPlanNum++}`,i={hablas:"Hablas",bob:"Bob",alex:"Alex",david:"David"},o={id:r,title:e,strategy:t,tasks:s.map((a,l)=>({task_id:`${r}_t${l+1}`,dependent_task_ids:a.dependent_task_ids||[],description:a.description,assignee:a.assignee,assigneeName:a.assigneeName||i[a.assignee]||a.assignee,status:"pending",createdAt:Date.now()})),createdAt:Date.now(),updatedAt:Date.now()};return this.plans.set(r,o),this.activePlanId=r,o}getActivePlan(){return this.activePlanId&&this.plans.get(this.activePlanId)||null}getTask(e){let t=this.getActivePlan();return t&&t.tasks.find(s=>s.task_id===e)||null}startTask(e){let t=this.getTask(e);return!t||!this.areDependenciesMet(e)?!1:(t.status="running",t.startedAt=Date.now(),this.touch(),!0)}finishTask(e,t){let s=this.getTask(e);return s?(s.status="done",s.result=t,s.completedAt=Date.now(),this.touch(),!0):!1}failTask(e,t){let s=this.getTask(e);return s?(s.status="failed",s.error=t,s.completedAt=Date.now(),this.touch(),!0):!1}skipTask(e){let t=this.getTask(e);return t?(t.status="skipped",t.completedAt=Date.now(),this.touch(),!0):!1}resetTask(e){let t=this.getTask(e);return t?(t.status="pending",t.result=void 0,t.error=void 0,t.startedAt=void 0,t.completedAt=void 0,this.touch(),!0):!1}replaceTask(e,t,s){let r=this.getTask(e);return r?(r.description=t,s&&(r.assignee=s),r.status="pending",r.result=void 0,r.error=void 0,this.touch(),!0):!1}areDependenciesMet(e){let t=this.getTask(e);if(!t)return!1;if(t.dependent_task_ids.length===0)return!0;let s=this.getActivePlan();return s?t.dependent_task_ids.every(r=>{let i=s.tasks.find(o=>o.task_id===r);return i&&(i.status==="done"||i.status==="skipped")}):!1}getNextTask(){let e=this.getActivePlan();if(!e)return null;for(let t of e.tasks)if(t.status==="pending"&&this.areDependenciesMet(t.task_id))return t;return null}getDependencyOrder(){let e=this.getActivePlan();if(!e)return[];let t=new Set,s=[],r=new Map(e.tasks.map(o=>[o.task_id,o])),i=o=>{if(t.has(o))return;t.add(o);let a=r.get(o);if(a){for(let l of a.dependent_task_ids)i(l);s.push(a)}};for(let o of e.tasks)i(o.task_id);return s}getProgress(){let e=this.getActivePlan();if(!e)return{total:0,done:0,failed:0,pending:0,running:0,skipped:0,percentage:0};let t=e.tasks.length,s=e.tasks.filter(u=>u.status==="done").length,r=e.tasks.filter(u=>u.status==="failed").length,i=e.tasks.filter(u=>u.status==="pending").length,o=e.tasks.filter(u=>u.status==="running").length,a=e.tasks.filter(u=>u.status==="skipped").length,l=t>0?Math.round((s+a)/t*100):0;return{total:t,done:s,failed:r,pending:i,running:o,skipped:a,percentage:l}}isComplete(){let e=this.getActivePlan();return e?e.tasks.every(t=>t.status==="done"||t.status==="failed"||t.status==="skipped"):!0}serialize(){let e=this.getActivePlan();return e?JSON.stringify(e,null,2):"{}"}deserialize(e){try{let t=JSON.parse(e);return t.id&&t.tasks?(this.plans.set(t.id,t),this.activePlanId=t.id,t):null}catch{return null}}reset(){this.plans.clear(),this.activePlanId=null,this.nextPlanNum=1}clear(){this.plans.clear(),this.activePlanId=null}touch(){let e=this.getActivePlan();e&&(e.updatedAt=Date.now())}}});var de,ut,_0,A0,k0,$0,E0,C0,T0,Gr,Eg=N(()=>{"use strict";de=O(require("fs")),ut=O(require("path")),_0=".hablas",A0=`# Project Context \u2014 Hablas AI
|
|
931
|
+
`);return{results:t,finalSynthesis:u,synthesisOk:!1}}}});function ut(n){switch(n){case"Hablas":return c.leader;case"Bob":return c.architect;case"Alex":return c.engineer;case"David":return c.analyst;case"Emma":return c.product;default:return c.primary}}function qr(n){return n==="Hablas"?"\u2605":"\u25C6"}function ws(n,e=140){let t=(n||"").replace(/\s+/g," ").trim();return t.length>e?t.slice(0,e-1)+"\u2026":t}function Vl(n){return n==="Hablas"?"Team Leader":n==="Bob"?"Architect":n==="Alex"?"Engineer":n==="David"?"Data Analyst":n==="Emma"?"Product Manager":"Specialist"}var Kr,kg=N(()=>{"use strict";vn();Kr=class{channel;opts;attached=!1;listener;lastThinking=null;lastLine="";state={taskTitle:"Autonomous Codebase Engineering",currentPhase:"Initializing",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}};constructor(e,t={}){this.channel=e,this.opts={hideThinking:t.hideThinking??!1,hideActs:t.hideActs??!1,maxChars:t.maxChars??140},this.listener=s=>this.handle(s)}attach(){return this.attached?this:(this.channel.onEvent(this.listener),this.attached=!0,this)}detach(){return this.attached?(this.channel.offEvent(this.listener),this.attached=!1,this):this}handle(e){switch(e.type){case"phase":return this.renderPhase(e);case"handoff":return this.renderHandoff(e);case"thinking":return this.renderThinking(e);case"speak":return this.renderSpeak(e);case"act":return this.renderAct(e);case"observe":return this.renderObserve(e);case"review":return this.renderReview(e);case"summary":return this.renderSummary(e);case"decision":return this.renderDecision(e);case"done":return this.renderDone(e);case"error":return this.renderError(e)}}renderPhase(e){let t=(e.content||"").toString();t&&(this.state.currentPhase=t,(t.includes("compiling")||t.includes("report")||t.includes("synthesizing"))&&(this.state.activeAgent="Hablas",this.state.activeAgentTitle="Team Leader",this.state.roster.Hablas="active",this.state.currentActivity="Compiling individual reports and synthesizing final unified solution"),this.print(`
|
|
932
|
+
${c.accent("\u25B8")} ${c.strong(t.toUpperCase())}`),this.lastThinking=null)}renderHandoff(e){let t=e.agent,s=e.to||"";if(!s)return;let r=ut(t),i=ut(s);this.state.roster[t]&&(this.state.roster[t]="done"),this.state.roster[s]="active",this.state.activeAgent=s,this.state.activeAgentTitle=Vl(s),this.state.currentPhase=`Task Handoff to @${s}`,this.state.currentActivity=`Transitioning task context from @${t} to @${s}`,this.print(` ${r(qr(t))} ${r(t)} ${c.muted("\u2501\u2501\u25B6")} ${i(qr(s))} ${i(s)}`),this.lastThinking=null}renderThinking(e){if(this.opts.hideThinking||this.lastThinking===e.agent)return;this.lastThinking=e.agent;let t=ut(e.agent);this.state.activeAgent=e.agent,this.state.activeAgentTitle=Vl(e.agent),this.state.roster[e.agent]="active",this.state.currentActivity="Analyzing workspace & formulating reasoning steps",this.print(` ${t("\u25C9")} [Active Agent: ${e.agent}] is thinking & formulating response\u2026`)}renderSpeak(e){let t=ws(e.content||"",this.opts.maxChars);if(!t)return;let s=ut(e.agent),r=e.to?` ${c.muted("\u2192")} ${ut(e.to)("@"+e.to)}`:"",i=`speak:${e.agent}:${e.to||""}:${t}`;i!==this.lastLine&&(this.lastLine=i,this.print(` ${s(qr(e.agent))} ${s(e.agent)}${r}${c.muted(":")} ${c.secondary(t)}`),this.lastThinking=null)}renderAct(e){if(this.opts.hideActs)return;let t=ut(e.agent),s=e.toolName||"tool",r=e.toolArgs||{},i="";typeof r.path=="string"?i=` ${c.primary(r.path)}`:typeof r.command=="string"?i=` ${c.primary(r.command)}`:typeof r.query=="string"&&(i=` "${c.primary(r.query)}"`);let o=s==="write_file"||s==="edit_file"||s==="patch_file"?"\u270E":s==="run_command"?"\u2318":s==="read_file"?"\u{1F4D6}":s==="search_codebase"?"\u{1F50E}":"\u{1F527}";this.state.activeAgent=e.agent,this.state.activeAgentTitle=Vl(e.agent),this.state.roster[e.agent]="active",this.state.currentActivity=`Executing ${s}${i}`,this.print(` ${t(o)} [Running Tool]: ${t(e.agent)} is executing ${c.strong(s)}${i}...`),this.lastThinking=null}renderObserve(e){if(this.opts.hideActs)return;let t=e.success!==!1,s=t?c.success("\u2713 COMPLETED"):c.error("\u2717 FAILED"),r=ws(e.content||(t?"Execution succeeded":"Execution failed"),this.opts.maxChars);this.print(` ${c.muted("\u21B3")} ${s}: ${c.muted(r)}`)}renderReview(e){let t=e.agent,s=e.to||"",r=ws(e.content||"",this.opts.maxChars);if(!r)return;let i=ut(t),o=ut(s);this.print(`
|
|
933
|
+
${i("\u270E")} ${c.strong("@"+t)} ${c.muted("reviewing")} ${o("@"+s)}${c.muted(":")} ${c.secondary(r)}`),this.lastThinking=null}renderSummary(e){let t=ut(e.agent),s=e.durationMs?` ${c.muted(`(${(e.durationMs/1e3).toFixed(1)}s)`)}`:"";this.print(` ${t(qr(e.agent))} ${t(e.agent)} ${c.muted("\u2500\u2500\u25BA")} ${c.leader("\u2605 Hablas")} ${c.muted("\xB7 report submitted")}${s}`),this.lastThinking=null}renderDecision(e){let t=ws(e.content||"",this.opts.maxChars);if(!t)return;let s=ut(e.agent);this.print(` ${s("\u25C6")} ${s(e.agent)} ${c.muted("decision:")} ${c.secondary(t)}`)}renderDone(e){this.print(`
|
|
934
|
+
${c.chrome("\u2500".repeat(56))}`),this.lastThinking=null}renderError(e){let t=ut(e.agent),s=ws(e.content||"unknown error",this.opts.maxChars);this.print(` ${t("\u25C6")} ${t(e.agent)} ${c.error("\u2717")} ${c.error(s)}`),this.lastThinking=null}print(e){console.log(e)}}});var Wr,$g=N(()=>{"use strict";Wr=class{plans=new Map;activePlanId=null;nextPlanNum=1;createPlan(e,t,s){let r=`plan_${this.nextPlanNum++}`,i={hablas:"Hablas",bob:"Bob",alex:"Alex",david:"David"},o={id:r,title:e,strategy:t,tasks:s.map((a,l)=>({task_id:`${r}_t${l+1}`,dependent_task_ids:a.dependent_task_ids||[],description:a.description,assignee:a.assignee,assigneeName:a.assigneeName||i[a.assignee]||a.assignee,status:"pending",createdAt:Date.now()})),createdAt:Date.now(),updatedAt:Date.now()};return this.plans.set(r,o),this.activePlanId=r,o}getActivePlan(){return this.activePlanId&&this.plans.get(this.activePlanId)||null}getTask(e){let t=this.getActivePlan();return t&&t.tasks.find(s=>s.task_id===e)||null}startTask(e){let t=this.getTask(e);return!t||!this.areDependenciesMet(e)?!1:(t.status="running",t.startedAt=Date.now(),this.touch(),!0)}finishTask(e,t){let s=this.getTask(e);return s?(s.status="done",s.result=t,s.completedAt=Date.now(),this.touch(),!0):!1}failTask(e,t){let s=this.getTask(e);return s?(s.status="failed",s.error=t,s.completedAt=Date.now(),this.touch(),!0):!1}skipTask(e){let t=this.getTask(e);return t?(t.status="skipped",t.completedAt=Date.now(),this.touch(),!0):!1}resetTask(e){let t=this.getTask(e);return t?(t.status="pending",t.result=void 0,t.error=void 0,t.startedAt=void 0,t.completedAt=void 0,this.touch(),!0):!1}replaceTask(e,t,s){let r=this.getTask(e);return r?(r.description=t,s&&(r.assignee=s),r.status="pending",r.result=void 0,r.error=void 0,this.touch(),!0):!1}areDependenciesMet(e){let t=this.getTask(e);if(!t)return!1;if(t.dependent_task_ids.length===0)return!0;let s=this.getActivePlan();return s?t.dependent_task_ids.every(r=>{let i=s.tasks.find(o=>o.task_id===r);return i&&(i.status==="done"||i.status==="skipped")}):!1}getNextTask(){let e=this.getActivePlan();if(!e)return null;for(let t of e.tasks)if(t.status==="pending"&&this.areDependenciesMet(t.task_id))return t;return null}getDependencyOrder(){let e=this.getActivePlan();if(!e)return[];let t=new Set,s=[],r=new Map(e.tasks.map(o=>[o.task_id,o])),i=o=>{if(t.has(o))return;t.add(o);let a=r.get(o);if(a){for(let l of a.dependent_task_ids)i(l);s.push(a)}};for(let o of e.tasks)i(o.task_id);return s}getProgress(){let e=this.getActivePlan();if(!e)return{total:0,done:0,failed:0,pending:0,running:0,skipped:0,percentage:0};let t=e.tasks.length,s=e.tasks.filter(u=>u.status==="done").length,r=e.tasks.filter(u=>u.status==="failed").length,i=e.tasks.filter(u=>u.status==="pending").length,o=e.tasks.filter(u=>u.status==="running").length,a=e.tasks.filter(u=>u.status==="skipped").length,l=t>0?Math.round((s+a)/t*100):0;return{total:t,done:s,failed:r,pending:i,running:o,skipped:a,percentage:l}}isComplete(){let e=this.getActivePlan();return e?e.tasks.every(t=>t.status==="done"||t.status==="failed"||t.status==="skipped"):!0}serialize(){let e=this.getActivePlan();return e?JSON.stringify(e,null,2):"{}"}deserialize(e){try{let t=JSON.parse(e);return t.id&&t.tasks?(this.plans.set(t.id,t),this.activePlanId=t.id,t):null}catch{return null}}reset(){this.plans.clear(),this.activePlanId=null,this.nextPlanNum=1}clear(){this.plans.clear(),this.activePlanId=null}touch(){let e=this.getActivePlan();e&&(e.updatedAt=Date.now())}}});var de,dt,_0,A0,k0,$0,C0,E0,T0,Gr,Cg=N(()=>{"use strict";de=O(require("fs")),dt=O(require("path")),_0=".hablas",A0=`# Project Context \u2014 Hablas AI
|
|
936
935
|
|
|
937
936
|
## Project Overview
|
|
938
937
|
<!-- Auto-populated by Hablas on first scan -->
|
|
@@ -994,7 +993,7 @@ ${d.output}`}).join(`
|
|
|
994
993
|
|
|
995
994
|
## Implementation Guide
|
|
996
995
|
<!-- Step-by-step implementation order -->
|
|
997
|
-
`,
|
|
996
|
+
`,C0=`# Agent Activity Log
|
|
998
997
|
|
|
999
998
|
## Session History
|
|
1000
999
|
| Session | Date | Duration | Agents Used | Tasks Completed |
|
|
@@ -1010,7 +1009,7 @@ ${d.output}`}).join(`
|
|
|
1010
1009
|
|
|
1011
1010
|
## Inter-Agent Communication
|
|
1012
1011
|
<!-- Messages exchanged between agents during complex tasks -->
|
|
1013
|
-
`,
|
|
1012
|
+
`,E0=`# Learned Knowledge
|
|
1014
1013
|
|
|
1015
1014
|
## Project Conventions
|
|
1016
1015
|
<!-- Coding style, naming conventions, file organization patterns -->
|
|
@@ -1026,7 +1025,7 @@ ${d.output}`}).join(`
|
|
|
1026
1025
|
|
|
1027
1026
|
## Dependency Notes
|
|
1028
1027
|
<!-- Important notes about dependencies and versions -->
|
|
1029
|
-
`,T0={"HABLAS.md":A0,"PROGRESS.md":k0,"ARCHITECTURE.md":$0,"AGENTS.md":
|
|
1028
|
+
`,T0={"HABLAS.md":A0,"PROGRESS.md":k0,"ARCHITECTURE.md":$0,"AGENTS.md":C0,"MEMORY.md":E0},Gr=class{contextDir;sessionDelegations=[];sessionDiscoveries=[];constructor(e){this.contextDir=dt.join(e,_0)}init(){let e=dt.join(dt.dirname(this.contextDir),".hablas-legacy");if(de.existsSync(e)&&!de.existsSync(this.contextDir))try{de.renameSync(e,this.contextDir);let t=dt.join(this.contextDir,"LEGACY.md"),s=dt.join(this.contextDir,"HABLAS.md");de.existsSync(t)&&!de.existsSync(s)&&de.renameSync(t,s)}catch{}de.existsSync(this.contextDir)||de.mkdirSync(this.contextDir,{recursive:!0});for(let[t,s]of Object.entries(T0)){let r=dt.join(this.contextDir,t);de.existsSync(r)||de.writeFileSync(r,s,"utf-8")}}exists(){return de.existsSync(this.contextDir)}readContext(e){let t=dt.join(this.contextDir,e);return de.existsSync(t)?de.readFileSync(t,"utf-8"):null}updateProgress(e){let t=new Date().toISOString().split("T")[0],s=new Date().toISOString().split("T")[1].split(".")[0],r=`- [${t} ${s}] ${e}`;this.appendToSection("PROGRESS.md","## Progress Log",r)}addTask(e,t){let s=new Date().toISOString().split("T")[0],r=`| ${e} | @${t} | \u{1F535} pending | ${s} | \u2014 |`;this.appendToSection("PROGRESS.md","## Task Breakdown",r)}updateSprint(e){this.updateSection("PROGRESS.md","## Current Sprint",e)}recordDecision(e,t,s,r="medium"){let o=`| ${new Date().toISOString().split("T")[0]} | ${e} | ${t} | ${s} | ${r} |`;this.appendToSection("HABLAS.md","## Key Decisions",o)}updateArchitecture(e,t){this.updateSection("ARCHITECTURE.md",e,t)}recordADR(e,t,s="accepted"){let r=new Date().toISOString().split("T")[0],a=`| ${((this.readContext("ARCHITECTURE.md")||"").match(/^\|/gm)||[]).length} | ${e} | ${s} | ${r} | ${t} |`;this.appendToSection("ARCHITECTURE.md","## Architecture Decision Records (ADRs)",a)}logDelegation(e){this.sessionDelegations.push(e);let t=`| ${e.time} | ${e.from} | ${e.to} | ${e.task.slice(0,50)} | ${e.model} | ${e.result} | ${e.durationMs}ms |`;this.appendToSection("AGENTS.md","## Delegation Log",t)}logSession(e){let t=`| ${e.sessionId} | ${e.date} | ${Math.round(e.duration/1e3)}s | ${e.agentsUsed.join(", ")} | ${e.tasksCompleted} |`;this.appendToSection("AGENTS.md","## Session History",t)}updateAgentPerformance(e,t,s,r,i){let o=`| @${e} | ${t} | ${Math.round(s*100)}% | ${Math.round(r)}ms | ${i.join(", ")} |`;this.appendToSection("AGENTS.md","## Agent Performance",o)}logAgentComm(e,t,s){let i=`- [${new Date().toISOString()}] **@${e}** \u2192 **@${t}**: ${s.slice(0,200)}`;this.appendToSection("AGENTS.md","## Inter-Agent Communication",i)}addConvention(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Project Conventions",r),this.sessionDiscoveries.push({type:"convention",description:e,source:t,date:s})}addPattern(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Discovered Patterns",r),this.sessionDiscoveries.push({type:"pattern",description:e,source:t,date:s})}addGotcha(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] \u26A0\uFE0F ${e} *(found by ${t})*`;this.appendToSection("MEMORY.md","## Known Gotchas",r),this.sessionDiscoveries.push({type:"gotcha",description:e,source:t,date:s})}addAutoDiscovery(e,t){let s=new Date().toISOString().split("T")[0],r=`- [${s}] \u{1F50D} ${e} *(by ${t})*`;this.appendToSection("MEMORY.md","## Auto-Discoveries",r),this.sessionDiscoveries.push({type:"pattern",description:e,source:t,date:s})}getSummary(e=8e3){let t=["HABLAS.md","PROGRESS.md","ARCHITECTURE.md","MEMORY.md"],s=[],r=0;for(let i of t){let o=this.readContext(i);if(o&&o.trim().length>0){let a=e-r;if(a<=200)break;let l=o.length>a?o.slice(0,a)+`
|
|
1030
1029
|
...(truncated)`:o;s.push(`### ${i}
|
|
1031
1030
|
${l}`),r+=l.length}}return s.length>0?s.join(`
|
|
1032
1031
|
|
|
@@ -1038,47 +1037,44 @@ ${a}`),r=s.join(`
|
|
|
1038
1037
|
`)}getSessionDelegations(){return[...this.sessionDelegations]}getSessionDiscoveries(){return[...this.sessionDiscoveries]}addContextFromFile(e,t,s,r){let i=this.readContext(t);if(!i)return;let o=0;for(let a of s){if(o>=r)break;let l=this.extractSection(i,a);if(l&&l.trim().length>10){let u=r-o,d=l.length>u?l.slice(0,u)+"...":l;e.push(`${a}
|
|
1039
1038
|
${d}`),o+=d.length}}}extractSection(e,t){let s=e.split(`
|
|
1040
1039
|
`),r=s.findIndex(o=>o.trim()===t);if(r===-1)return null;let i=s.length;for(let o=r+1;o<s.length;o++)if(/^#{1,2}\s/.test(s[o])){i=o;break}return s.slice(r+1,i).join(`
|
|
1041
|
-
`).trim()}updateSection(e,t,s){let r=
|
|
1040
|
+
`).trim()}updateSection(e,t,s){let r=dt.join(this.contextDir,e);if(!de.existsSync(r))return;let o=de.readFileSync(r,"utf-8").split(`
|
|
1042
1041
|
`),a=o.findIndex(h=>h.trim()===t);if(a===-1)return;let l=o.length;for(let h=a+1;h<o.length;h++)if(/^#{1,2}\s/.test(o[h])){l=h;break}let u=o.slice(0,a+1),d=o.slice(l),f=[...u,s,"",...d].join(`
|
|
1043
|
-
`);de.writeFileSync(r,f,"utf-8")}appendToSection(e,t,s){let r=
|
|
1042
|
+
`);de.writeFileSync(r,f,"utf-8")}appendToSection(e,t,s){let r=dt.join(this.contextDir,e);de.existsSync(r)||this.init();let i=de.readFileSync(r,"utf-8"),o=i.split(`
|
|
1044
1043
|
`),a=o.findIndex(u=>u.trim()===t);if(a===-1){de.writeFileSync(r,i+`
|
|
1045
1044
|
`+s+`
|
|
1046
1045
|
`,"utf-8");return}let l=a+1;for(;l<o.length;){let u=o[l].trim();if(/^#{1,2}\s/.test(u))break;l++}o.splice(l,0,s),de.writeFileSync(r,o.join(`
|
|
1047
|
-
`),"utf-8")}}});function
|
|
1048
|
-
`)}formatAge(e){let t=Date.now()-e,s=Math.floor(t/1e3);if(s<60)return`${s}s ago`;let r=Math.floor(s/60);return r<60?`${r}m ago`:`${Math.floor(r/60)}h ago`}size(){return this.stack.length}clear(){this.stack=[]}}});function D0(n,e){let t=[],s;for(Fg.lastIndex=0;(s=Fg.exec(n))!==null;){let r=s[1],i=Re.resolve(e,r);
|
|
1046
|
+
`),"utf-8")}}});function Eg(n){let t=n.trim().toLowerCase(),s=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env|vue|svelte|go|rs|sh|toml)/gi,r=t.match(s)||[];return R0.test(t)?"ECOSYSTEM":P0.test(t)?"APPLICATION":O0.test(t)||r.length>=3?"SERVICE":I0.test(t)||r.length===2?"COMPONENT":"FILE"}function Tg(n,e,t){let s=`sp-${Date.now()}`,r=[],i=1,o=t.includes("emma"),a=t.includes("bob"),l=t.includes("alex"),u=t.includes("david");switch(e){case"FILE":r.push({id:`${s}-t${i++}`,description:`Implement the requested file modification: ${n.substring(0,60)}`,assignee:l?"alex":"hablas",dependencies:[]});break;case"COMPONENT":a&&r.push({id:`${s}-t${i++}`,description:"Review component layout and design clean local interfaces",assignee:"bob",dependencies:[]}),r.push({id:`${s}-t${i++}`,description:`Implement the coupled front-end component files: ${n.substring(0,60)}`,assignee:l?"alex":"hablas",dependencies:r.length>0?[r[r.length-1].id]:[]});break;case"SERVICE":u&&r.push({id:`${s}-t${i++}`,description:"Analyze route endpoints, request schemas, and gather local requirements",assignee:"david",dependencies:[]}),a&&r.push({id:`${s}-t${i++}`,description:"Design solid architectural service contracts and database schemas",assignee:"bob",dependencies:r.length>0?[r[r.length-1].id]:[]}),l&&r.push({id:`${s}-t${i++}`,description:"Write the service logic, router endpoints, and local test suites",assignee:"alex",dependencies:r.length>0?[r[r.length-1].id]:[]});break;case"APPLICATION":o&&r.push({id:`${s}-t${i++}`,description:"Draft comprehensive PRD and feature specification with clean user stories",assignee:"emma",dependencies:[]}),a&&r.push({id:`${s}-t${i++}`,description:"Architect full-stack schema separation, database models, and API boundaries",assignee:"bob",dependencies:r.length>0?[r[r.length-1].id]:[]}),l&&r.push({id:`${s}-t${i++}`,description:"Implement full-stack endpoints, frontend pages, and run end-to-end tests",assignee:"alex",dependencies:r.length>0?[r[r.length-1].id]:[]});break;case"ECOSYSTEM":a&&r.push({id:`${s}-t${i++}`,description:"Design system containerization architecture and deployment charts",assignee:"bob",dependencies:[]}),l&&r.push({id:`${s}-t${i++}`,description:"Set up Dockerfiles, CI/CD pipeline runs, and local validation",assignee:"alex",dependencies:r.length>0?[r[r.length-1].id]:[]});break}let d;return r.length<=1?d="direct":d="sequential",{id:s,title:n.substring(0,100),scope:e,tasks:r,strategy:d,requiresApproval:e==="APPLICATION"||e==="ECOSYSTEM",createdAt:Date.now()}}var R0,P0,O0,I0,Rg=N(()=>{"use strict";R0=/\b(deploy|ci|cd|docker|docker-compose|gvisor|kubernetes|aws|gcp|vercel|heroku|server|cloud)\b/i,P0=/\b(full\s+system|complete\s+project|from\s+scratch|entire\s+application|prd|end-to-end|database.*api.*frontend)\b/i,O0=/\b(service|module|auth|login|session|api|controller|middleware|backend|database|schema)\b/i,I0=/\b(component|widget|screen|page|interface|view|button|sidebar|header|footer|form|ui)\b/i});function Pg(n){let e=n.trim(),t=e.toLowerCase();if(!e)return 0;let r=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|html|env|vue|svelte|go|rs|sh|toml)/i.test(e)?1:0,o=/\b(read_file|write_file|run_command|edit_file|search_codebase|list_dir|create_dir|delete_file|append_to_file|patch_file|move_file|get_file_info|git|npm|tsc|install|test|compile|build|setup)\b/i.test(e)?1:0,a=e.startsWith("/")?1:0,u=/\b(something|fix\s+it|make\s+better|do\s+stuff|change\s+things|some\s+file|مشكلة|شيء)\b/i.test(t)?1:0,d=.4*r+.3*o+.3*a-.5*u;return Math.max(0,Math.min(1,d))}var Og=N(()=>{"use strict"});function Mg(n){let e=n.trim();if(e.length<20||Pi(e)||Ig.test(e)||e.includes("```")||L0.test(e)||/\/[\w-]+\.[\w]+/.test(e)||e.length<60&&Ig.test(e))return null;for(let{pattern:t,question:s,choices:r}of M0)if(t.test(e))return e.length>40&&/\b(called|named|using|with|for)\b/i.test(e)?null:{question:s,choices:r,context:e};return null}function Lg(n,e){let t=n.trim().toLowerCase(),s=t.split(/[,\s]+/).filter(i=>/^[a-z]$/.test(i));if(s.length>0)return s.map(i=>{let o=i.charCodeAt(0)-97;return e.choices[o]?.value}).filter(i=>i!==void 0);let r=t.split(/[,\s]+/).filter(i=>/^\d+$/.test(i));return r.length>0?r.map(i=>{let o=parseInt(i,10)-1;return e.choices[o]?.value}).filter(i=>i!==void 0):[t]}var M0,Ig,L0,Dg=N(()=>{"use strict";fn();M0=[{pattern:/\b(create|make|build)\s+(a|an|the)?\s*(app|application|project)\b/i,question:"What type of application would you like to create?",choices:[{label:"Web application (React/Next.js)",value:"web"},{label:"CLI tool (Node.js)",value:"cli"},{label:"API server (Express/Fastify)",value:"api"},{label:"Something else (please describe)",value:"other"}]},{pattern:/\b(refactor|rewrite|restructure)\s+(the\s+)?(entire|whole|all)\b/i,question:"Large-scale refactoring detected. How would you like to proceed?",choices:[{label:"Incremental \u2014 one module at a time",value:"incremental"},{label:"Full rewrite \u2014 replace everything",value:"full"},{label:"Just the architecture \u2014 keep implementations",value:"architecture"},{label:"Let me specify which parts",value:"specify"}]},{pattern:/\b(delete|remove|drop)\s+(all|every|the\s+entire)\b/i,question:"This is a destructive operation. Please confirm scope:",choices:[{label:"Yes, remove everything matching",value:"all"},{label:"Only unused/dead code",value:"unused"},{label:"Let me be more specific",value:"specify"},{label:"Cancel \u2014 don't delete anything",value:"cancel"}]},{pattern:/\b(setup|configure|install)\s+(the\s+)?(project|environment|dev)\b/i,question:"What environment are you setting up?",choices:[{label:"Development (local)",value:"dev"},{label:"Production deployment",value:"prod"},{label:"CI/CD pipeline",value:"ci"},{label:"Docker/containerized",value:"docker"}]},{pattern:/\b(fix|debug|solve)\s+(the\s+)?(issue|bug|problem|error)\b/i,question:"Can you provide more details about the issue?",choices:[{label:"Runtime error (crashes/exceptions)",value:"runtime"},{label:"Build/compile error",value:"build"},{label:"Logic bug (wrong behavior)",value:"logic"},{label:"Performance issue (slow)",value:"performance"}]}],Ig=/[\w-]+\.(ts|js|tsx|jsx|py|json|yaml|yml|md|css|scss|html|vue|svelte|go|rs|java|c|cpp|h|rb|php|sql|sh|bash|toml|xml|env)/i,L0=/\b(fix|update|change|add|remove|rename|move|edit|read|show|cat|open)\s+(the\s+)?(typo|bug|error|import|line|function|variable|class|method|comment|style)/i});var Vr,vt,Yr,zr,Ng=N(()=>{"use strict";Vr=O(require("fs")),vt=O(require("fs/promises")),Yr=O(require("path")),zr=class{stack=[];workingDir;maxEntries;nextGroupId=1;constructor(e,t=200){this.workingDir=e,this.maxEntries=t}async record(e,t,s,r="hablas",i){let o=Yr.resolve(this.workingDir,e),a=null;try{Vr.existsSync(o)&&(a=await vt.readFile(o,"utf-8"))}catch{}let l={id:`undo_${Date.now()}_${this.stack.length}`,filePath:e,absolutePath:o,originalContent:a,newContent:t,toolName:s,agent:r,timestamp:Date.now(),undone:!1,groupId:i};return this.stack.push(l),this.stack.length>this.maxEntries&&(this.stack=this.stack.slice(-this.maxEntries)),l.id}beginGroup(){return`group_${this.nextGroupId++}`}async undo(e=1){let t=[],r=this.stack.filter(i=>!i.undone).reverse().slice(0,e);for(let i of r)try{i.originalContent===null?(Vr.existsSync(i.absolutePath)&&await vt.unlink(i.absolutePath),t.push({file:i.filePath,success:!0})):(await vt.mkdir(Yr.dirname(i.absolutePath),{recursive:!0}),await vt.writeFile(i.absolutePath,i.originalContent,"utf-8"),t.push({file:i.filePath,success:!0})),i.undone=!0}catch(o){t.push({file:i.filePath,success:!1,error:o.message})}return t}async undoGroup(e){let t=this.stack.filter(r=>r.groupId===e&&!r.undone).reverse(),s=[];for(let r of t)try{r.originalContent===null?Vr.existsSync(r.absolutePath)&&await vt.unlink(r.absolutePath):await vt.writeFile(r.absolutePath,r.originalContent,"utf-8"),r.undone=!0,s.push({file:r.filePath,success:!0})}catch(i){s.push({file:r.filePath,success:!1,error:i.message})}return s}async undoAll(){return this.undo(this.getUndoableCount())}getUndoableCount(){return this.stack.filter(e=>!e.undone).length}getRecent(e=15){return this.stack.filter(t=>!t.undone).slice(-e).reverse()}getModifiedFiles(){let e=new Set;for(let t of this.stack.filter(s=>!s.undone))e.add(t.filePath);return Array.from(e)}formatList(e=15){let t=this.getRecent(e);if(t.length===0)return" No changes to undo";let s=[];for(let i=0;i<t.length;i++){let o=t[i],a=this.formatAge(o.timestamp),l=o.originalContent===null?"created":"modified",u=o.agent!=="hablas"?` [@${o.agent}]`:"";s.push(` ${i+1}. ${o.filePath} \u2014 ${l} by ${o.toolName}${u} (${a})`)}let r=this.getUndoableCount();return r>e&&s.push(` ... and ${r-e} more`),s.join(`
|
|
1047
|
+
`)}formatAge(e){let t=Date.now()-e,s=Math.floor(t/1e3);if(s<60)return`${s}s ago`;let r=Math.floor(s/60);return r<60?`${r}m ago`:`${Math.floor(r/60)}h ago`}size(){return this.stack.length}clear(){this.stack=[]}}});function D0(n,e){let t=[],s;for(Fg.lastIndex=0;(s=Fg.exec(n))!==null;){let r=s[1],i=Re.resolve(e,r);ft.existsSync(i)&&t.push(r)}return[...new Set(t)]}function N0(n,e,t){let s=[],r=Re.extname(e),i=Re.dirname(Re.resolve(t,e));if([".ts",".tsx",".js",".jsx",".mjs",".cjs"].includes(r)){let o;for(jg.lastIndex=0;(o=jg.exec(n))!==null;){let a=o[1]||o[2];if(!a||!a.startsWith(".")&&!a.startsWith("/"))continue;let l=F0(a,i);l&&s.push(Re.relative(t,l))}}else if(r===".py"){let o;for(Hg.lastIndex=0;(o=Hg.exec(n))!==null;){let a=o[1]||o[2];if(!a)continue;let l=a.replace(/\./g,"/")+".py",u=Re.resolve(i,l);ft.existsSync(u)&&s.push(Re.relative(t,u))}}return[...new Set(s)]}function F0(n,e){let t=[".ts",".tsx",".js",".jsx",".mjs",".cjs"],s=Re.resolve(e,n);if(ft.existsSync(s)&&ft.statSync(s).isFile())return s;for(let r of t){let i=s+r;if(ft.existsSync(i))return i}for(let r of t){let i=Re.join(s,`index${r}`);if(ft.existsSync(i))return i}return null}function Bg(n,e,t){let s=t?.maxFiles||10,r=t?.maxTokens||8e3,i=t?.followImports!==!1,o=D0(n,e),a=[],l=new Set,u=0;for(let d of o){if(a.length>=s||u>=r)break;if(!l.has(d)){l.add(d);try{let f=Re.resolve(e,d),h=ft.readFileSync(f,"utf-8"),m=h.split(`
|
|
1049
1048
|
`).length,p=Math.ceil(h.length/4);if(p>4e3){let g=h.split(`
|
|
1050
1049
|
`).slice(0,200).join(`
|
|
1051
1050
|
`)+`
|
|
1052
|
-
...(truncated)`,x=Math.ceil(g.length/4);u+x<=r&&(a.push({path:d,content:g,source:"mentioned",lineCount:200}),u+=x)}else if(u+p<=r&&(a.push({path:d,content:h,source:"mentioned",lineCount:m}),u+=p,i)){let g=N0(h,d,e);for(let x of g.slice(0,5)){if(a.length>=s||u>=r)break;if(!l.has(x)){l.add(x);try{let
|
|
1051
|
+
...(truncated)`,x=Math.ceil(g.length/4);u+x<=r&&(a.push({path:d,content:g,source:"mentioned",lineCount:200}),u+=x)}else if(u+p<=r&&(a.push({path:d,content:h,source:"mentioned",lineCount:m}),u+=p,i)){let g=N0(h,d,e);for(let x of g.slice(0,5)){if(a.length>=s||u>=r)break;if(!l.has(x)){l.add(x);try{let S=Re.resolve(e,x),A=ft.readFileSync(S,"utf-8"),k=Math.ceil(A.length/4),y=A.split(`
|
|
1053
1052
|
`).length;if(k>2e3){let b=A.split(`
|
|
1054
1053
|
`).slice(0,100).join(`
|
|
1055
1054
|
`)+`
|
|
1056
1055
|
...(truncated)`,v=Math.ceil(b.length/4);u+v<=r&&(a.push({path:x,content:b,source:"imported",lineCount:100}),u+=v)}else u+k<=r&&(a.push({path:x,content:A,source:"imported",lineCount:y}),u+=k)}catch{}}}}}catch{}}}return{files:a,totalTokensEstimate:u,mentionedPaths:o}}function Ug(n){if(n.files.length===0)return"";let e=["## Referenced Files"];for(let t of n.files){let s=t.source==="imported"?" (imported)":"";e.push(`### ${t.path}${s} (${t.lineCount} lines)`),e.push("```"),e.push(t.content),e.push("```")}return e.join(`
|
|
1057
|
-
`)}var dt,Re,Fg,jg,Hg,qg=N(()=>{"use strict";dt=O(require("fs")),Re=O(require("path")),Fg=/(?:^|\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,jg=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Hg=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var Wg={};Ne(Wg,{runSetupWizard:()=>zl});function we(n,e){return new Promise(t=>{n.question(e,s=>t(s))})}function H0(){return["nvapi-","qJRIIcL3SbN6s91CK-","gk2DtzlHbUnaYvGJk","AoIohOTcABSY5lll","Kdwfj_fO_b55h"].join("")}async function zl(n){let e=Kg.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${Wt}${Ke} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${L}`),console.log(`${Wt}${Ke} hablas \u2014 Setup Wizard${L}`),console.log(`${G} Configure your AI provider and model${L}`),console.log(`${Wt}${Ke} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${L}`),console.log(),console.log(`${Wt} Choose your setup:${L}`),console.log(),console.log(` ${j0}${Wt}1${L}. ${Wt}Hablas Integrated Engine${L} ${vt}(instant \u2014 no setup needed)${L}`),console.log(` ${G}Pre-configured cloud AI, ready to use immediately${L}`),console.log(),console.log(` ${Ke}${Wt}2${L}. ${Wt}Custom Provider${L} ${G}(bring your own API key)${L}`),console.log(` ${G}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${L}`),console.log(),(await we(e,` ${G}Your choice (1-2):${L} `)).trim()){case"1":{n.provider=Gt.provider,n.apiUrl=Gt.apiUrl,n.apiKey=H0(),n.model=Gt.model,mt(n),nt({name:Gt.name,apiUrl:Gt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Gt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Hablas Integrated Engine activated!${L}`),console.log(`${G} Model: ${Gt.model}${L}`),console.log(`${G} API: ${Gt.apiUrl}${L}`),console.log(`${G} No API key needed \u2014 everything is pre-configured.${L}`);break}case"2":{switch(console.log(),console.log(`${G} Select your provider:${L}`),console.log(` ${Ke}a${L}. Ollama (local, free, private)`),console.log(` ${Ke}b${L}. OpenAI API`),console.log(` ${Ke}c${L}. Groq (fast, free tier)`),console.log(` ${Ke}d${L}. OpenRouter (many models)`),console.log(` ${Ke}e${L}. Together AI`),console.log(` ${Ke}f${L}. DeepSeek`),console.log(` ${Ke}g${L}. Custom OpenAI-compatible API`),console.log(` ${Ke}h${L}. NVIDIA NIM (powerful cloud models)`),console.log(),(await we(e,` ${G}Your choice (a-h):${L} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await we(e,` ${G}Ollama host [http://localhost:11434]:${L} `);r.trim()&&(n.ollamaHost=r.trim());let i=await we(e,` ${G}Model [qwen2.5-coder:7b]:${L} `);i.trim()&&(n.model=i.trim()),mt(n),console.log(),console.log(`${vt} \u2713 Configured for Ollama${L}`),console.log(`${G} Model: ${n.model}${L}`),console.log(`${G} Host: ${n.ollamaHost}${L}`),console.log(`${G} Make sure Ollama is running: ollama serve${L}`);break}case"b":{let r=await we(e,` ${G}OpenAI API Key (sk-...):${L} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [gpt-4o]:${L} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",mt(n),nt({name:"OpenAI",apiUrl:"https://api.openai.com/v1",apiKey:r.trim(),models:["gpt-4o","gpt-4o-mini","gpt-4-turbo","o1","o3-mini"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for OpenAI${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"c":{let r=await we(e,` ${G}Groq API Key (gsk_...):${L} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [llama-3.3-70b-versatile]:${L} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",mt(n),nt({name:"Groq",apiUrl:"https://api.groq.com/openai/v1",apiKey:r.trim(),models:["llama-3.3-70b-versatile","llama-3.1-70b-versatile","mixtral-8x7b-32768","gemma2-9b-it"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for Groq${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"d":{let r=await we(e,` ${G}OpenRouter API Key (sk-or-...):${L} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [anthropic/claude-3.5-sonnet]:${L} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",mt(n),nt({name:"OpenRouter",apiUrl:"https://openrouter.ai/api/v1",apiKey:r.trim(),models:["openai/gpt-4o","anthropic/claude-3.5-sonnet","google/gemini-2.0-flash-001","deepseek/deepseek-r1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for OpenRouter${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"e":{let r=await we(e,` ${G}Together API Key:${L} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${L} `);n.provider="custom",n.apiUrl="https://api.together.xyz/v1",n.apiKey=r.trim(),n.model=i.trim()||"meta-llama/Llama-3.3-70B-Instruct-Turbo",mt(n),nt({name:"Together",apiUrl:"https://api.together.xyz/v1",apiKey:r.trim(),models:["meta-llama/Llama-3.3-70B-Instruct-Turbo","Qwen/Qwen2.5-72B-Instruct-Turbo","deepseek-ai/DeepSeek-R1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for Together AI${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"f":{let r=await we(e,` ${G}DeepSeek API Key:${L} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [deepseek-chat]:${L} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",mt(n),nt({name:"DeepSeek",apiUrl:"https://api.deepseek.com/v1",apiKey:r.trim(),models:["deepseek-chat","deepseek-coder","deepseek-reasoner"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for DeepSeek${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"g":{let r=await we(e,` ${G}Provider name:${L} `);if(!r.trim()){console.log(`${wt} \u26A0 Cancelled${L}`);break}let i=await we(e,` ${G}API base URL:${L} `);if(!i.trim()){console.log(`${wt} \u26A0 URL is required \u2014 cancelled${L}`);break}let o=await we(e,` ${G}API Key (leave empty if none):${L} `),a=await we(e,` ${G}Default model ID:${L} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",mt(n),nt({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for ${r.trim()}${L}`),console.log(`${G} URL: ${i.trim()}${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"h":{let r=await we(e,` ${G}NVIDIA API Key (nvapi-...):${L} `);if(!r.trim()){console.log(`${wt} \u26A0 No key provided \u2014 cancelled${L}`),console.log(`${G} Get your key at: https://build.nvidia.com/${L}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(Fn(),bc));console.log(),console.log(`${G} Available NVIDIA models:${L}`),i.models.forEach((u,d)=>{console.log(` ${Ke}${d+1}${L}. ${u}`)}),console.log();let o=await we(e,` ${G}Model number [1]:${L} `),a=parseInt(o.trim())-1,l=i.models[a]||i.defaultModel;n.provider="nvidia",n.apiUrl=i.apiUrl,n.apiKey=r.trim(),n.model=l,mt(n),nt({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${vt} \u2713 Configured for NVIDIA NIM${L}`),console.log(`${G} Model: ${l}${L}`),console.log(`${G} API: ${i.apiUrl}${L}`);break}default:console.log(`${wt} \u26A0 Invalid choice${L}`)}break}default:console.log(`${wt} \u26A0 Invalid choice \u2014 please select 1 or 2${L}`)}console.log(),console.log(`${G} Run 'hablas' to start chatting!${L}`),console.log(),e.close()}var Kg,Ke,vt,wt,G,Wt,L,j0,Gt,Yl=N(()=>{"use strict";Kg=O(require("readline"));hr();vi();Ke="\x1B[36m",vt="\x1B[32m",wt="\x1B[33m",G="\x1B[2m",Wt="\x1B[1m",L="\x1B[0m",j0="\x1B[35m";Gt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var Ht={};Ne(Ht,{activeCollabManager:()=>Pe,runSingleCommand:()=>V0,startRepl:()=>Zl});function K0(){return!ft.existsSync(Ql)}function Gg(){return ft.existsSync(B0)}function W0(){let n=Mt.dirname(Ql);ft.existsSync(n)||ft.mkdirSync(n,{recursive:!0}),ft.writeFileSync(Ql,new Date().toISOString(),"utf-8")}async function G0(n,e=10){let t=n.split(/(\s+)/);for(let s of t)process.stdout.write(s),await new Promise(r=>setTimeout(r,e))}async function zg(n,e,t,s,r){let{interactive:i,autoMode:o,input:a,logger:l,abortSignal:u,onToolCall:d,skipTools:f}=r,h=r.reactEngine??ys(),m=r.errorRecovery??bs(),p=n.getMessages().filter(b=>b.role==="user").pop()?.content||"Solo Execution",x={taskTitle:p.length>45?p.slice(0,45)+"...":p,currentPhase:"Cognitive Reasoning & Planning",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace & preparing reasoning path",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}};console.log(`
|
|
1058
|
-
`+
|
|
1059
|
-
`+Ft(x)),console.log(bn("Hablas","Team Leader")),await G0(vn(b))},onToolStart:(b,v,w)=>{A();let S="";typeof w?.path=="string"?S=` on ${w.path}`:typeof w?.command=="string"&&(S=` for ${w.command}`),x.currentPhase="Tool Execution",x.currentActivity=`Executing ${b}${S}`,console.log(`
|
|
1060
|
-
`+Ft(x)),console.log(bu(b,v)),_=new ze("Continuing"),_.start()},onToolEnd:(b,v,w,S)=>{A(),console.log(vu(v,w,S)),x.currentPhase="Reflecting on Observation",x.currentActivity=`Analyzing result of ${b}`,console.log(`
|
|
1061
|
-
`+Ft(x))},onNotice:(b,v)=>{A(),console.log(v==="retry"?c.muted(` \u21BB ${b}`):U(b))},onError:b=>{A(),b.includes("ECONNREFUSED")?console.log(He("Connection lost","Check your provider connection or run /provider test")):/timeout/i.test(b)?console.log(He("Request timed out (120s)","The API is slow. Try again or use a faster model.")):b.includes("429")?console.log(He("Rate limited by API","Wait a moment and try again, or switch providers.")):b.includes("model")?console.log(He("Model error","Check model availability: /models")):console.log(He(`Error: ${b}`,"Try again or check /status"))},onToolCall:()=>{d&&d()}},safetyPolicy:k,abortSignal:u,skipTools:f,maxIterations:U0}),A()}async function Zl(n,e){Wp();let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=K=>ft.existsSync(Mt.join(K,".git"));if(!s(t)&&!n.team?.enabled)console.log(` ${c.warning("\u26A0")} ${c.secondary("Not in a Git repository. Versioning and auto-sync features are limited.")}
|
|
1056
|
+
`)}var ft,Re,Fg,jg,Hg,qg=N(()=>{"use strict";ft=O(require("fs")),Re=O(require("path")),Fg=/(?:^|\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,jg=/(?:import\s+.*?\s+from\s+['"]([^'"]+)['"]|require\s*\(\s*['"]([^'"]+)['"]\s*\))/g,Hg=/(?:from\s+(\S+)\s+import|import\s+(\S+))/g});var Wg={};Ne(Wg,{runSetupWizard:()=>zl});function we(n,e){return new Promise(t=>{n.question(e,s=>t(s))})}function H0(){return["nvapi-","qJRIIcL3SbN6s91CK-","gk2DtzlHbUnaYvGJk","AoIohOTcABSY5lll","Kdwfj_fO_b55h"].join("")}async function zl(n){let e=Kg.createInterface({input:process.stdin,output:process.stdout});switch(console.log(),console.log(`${Kt}${Ke} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${L}`),console.log(`${Kt}${Ke} hablas \u2014 Setup Wizard${L}`),console.log(`${G} Configure your AI provider and model${L}`),console.log(`${Kt}${Ke} \u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501${L}`),console.log(),console.log(`${Kt} Choose your setup:${L}`),console.log(),console.log(` ${j0}${Kt}1${L}. ${Kt}Hablas Integrated Engine${L} ${wt}(instant \u2014 no setup needed)${L}`),console.log(` ${G}Pre-configured cloud AI, ready to use immediately${L}`),console.log(),console.log(` ${Ke}${Kt}2${L}. ${Kt}Custom Provider${L} ${G}(bring your own API key)${L}`),console.log(` ${G}Choose from Ollama, OpenAI, Groq, OpenRouter, and more${L}`),console.log(),(await we(e,` ${G}Your choice (1-2):${L} `)).trim()){case"1":{n.provider=Wt.provider,n.apiUrl=Wt.apiUrl,n.apiKey=H0(),n.model=Wt.model,gt(n),nt({name:Wt.name,apiUrl:Wt.apiUrl,apiKey:n.apiKey,models:["stepfun-ai/step-3.7-flash","nvidia/llama-3.3-70b-instruct","deepseek-ai/deepseek-r1"],defaultModel:Wt.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Hablas Integrated Engine activated!${L}`),console.log(`${G} Model: ${Wt.model}${L}`),console.log(`${G} API: ${Wt.apiUrl}${L}`),console.log(`${G} No API key needed \u2014 everything is pre-configured.${L}`);break}case"2":{switch(console.log(),console.log(`${G} Select your provider:${L}`),console.log(` ${Ke}a${L}. Ollama (local, free, private)`),console.log(` ${Ke}b${L}. OpenAI API`),console.log(` ${Ke}c${L}. Groq (fast, free tier)`),console.log(` ${Ke}d${L}. OpenRouter (many models)`),console.log(` ${Ke}e${L}. Together AI`),console.log(` ${Ke}f${L}. DeepSeek`),console.log(` ${Ke}g${L}. Custom OpenAI-compatible API`),console.log(` ${Ke}h${L}. NVIDIA NIM (powerful cloud models)`),console.log(),(await we(e,` ${G}Your choice (a-h):${L} `)).trim().toLowerCase()){case"a":{n.provider="ollama";let r=await we(e,` ${G}Ollama host [http://localhost:11434]:${L} `);r.trim()&&(n.ollamaHost=r.trim());let i=await we(e,` ${G}Model [qwen2.5-coder:7b]:${L} `);i.trim()&&(n.model=i.trim()),gt(n),console.log(),console.log(`${wt} \u2713 Configured for Ollama${L}`),console.log(`${G} Model: ${n.model}${L}`),console.log(`${G} Host: ${n.ollamaHost}${L}`),console.log(`${G} Make sure Ollama is running: ollama serve${L}`);break}case"b":{let r=await we(e,` ${G}OpenAI API Key (sk-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [gpt-4o]:${L} `);n.provider="custom",n.apiUrl="https://api.openai.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"gpt-4o",gt(n),nt({name:"OpenAI",apiUrl:"https://api.openai.com/v1",apiKey:r.trim(),models:["gpt-4o","gpt-4o-mini","gpt-4-turbo","o1","o3-mini"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for OpenAI${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"c":{let r=await we(e,` ${G}Groq API Key (gsk_...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [llama-3.3-70b-versatile]:${L} `);n.provider="custom",n.apiUrl="https://api.groq.com/openai/v1",n.apiKey=r.trim(),n.model=i.trim()||"llama-3.3-70b-versatile",gt(n),nt({name:"Groq",apiUrl:"https://api.groq.com/openai/v1",apiKey:r.trim(),models:["llama-3.3-70b-versatile","llama-3.1-70b-versatile","mixtral-8x7b-32768","gemma2-9b-it"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for Groq${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"d":{let r=await we(e,` ${G}OpenRouter API Key (sk-or-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [anthropic/claude-3.5-sonnet]:${L} `);n.provider="custom",n.apiUrl="https://openrouter.ai/api/v1",n.apiKey=r.trim(),n.model=i.trim()||"anthropic/claude-3.5-sonnet",gt(n),nt({name:"OpenRouter",apiUrl:"https://openrouter.ai/api/v1",apiKey:r.trim(),models:["openai/gpt-4o","anthropic/claude-3.5-sonnet","google/gemini-2.0-flash-001","deepseek/deepseek-r1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for OpenRouter${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"e":{let r=await we(e,` ${G}Together API Key:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [meta-llama/Llama-3.3-70B-Instruct-Turbo]:${L} `);n.provider="custom",n.apiUrl="https://api.together.xyz/v1",n.apiKey=r.trim(),n.model=i.trim()||"meta-llama/Llama-3.3-70B-Instruct-Turbo",gt(n),nt({name:"Together",apiUrl:"https://api.together.xyz/v1",apiKey:r.trim(),models:["meta-llama/Llama-3.3-70B-Instruct-Turbo","Qwen/Qwen2.5-72B-Instruct-Turbo","deepseek-ai/DeepSeek-R1"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for Together AI${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"f":{let r=await we(e,` ${G}DeepSeek API Key:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`);break}let i=await we(e,` ${G}Model [deepseek-chat]:${L} `);n.provider="custom",n.apiUrl="https://api.deepseek.com/v1",n.apiKey=r.trim(),n.model=i.trim()||"deepseek-chat",gt(n),nt({name:"DeepSeek",apiUrl:"https://api.deepseek.com/v1",apiKey:r.trim(),models:["deepseek-chat","deepseek-coder","deepseek-reasoner"],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for DeepSeek${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"g":{let r=await we(e,` ${G}Provider name:${L} `);if(!r.trim()){console.log(`${xt} \u26A0 Cancelled${L}`);break}let i=await we(e,` ${G}API base URL:${L} `);if(!i.trim()){console.log(`${xt} \u26A0 URL is required \u2014 cancelled${L}`);break}let o=await we(e,` ${G}API Key (leave empty if none):${L} `),a=await we(e,` ${G}Default model ID:${L} `);n.provider="custom",n.apiUrl=i.trim(),n.apiKey=o.trim(),n.model=a.trim()||"default",gt(n),nt({name:r.trim(),apiUrl:i.trim(),apiKey:o.trim(),models:[n.model],defaultModel:n.model,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for ${r.trim()}${L}`),console.log(`${G} URL: ${i.trim()}${L}`),console.log(`${G} Model: ${n.model}${L}`);break}case"h":{let r=await we(e,` ${G}NVIDIA API Key (nvapi-...):${L} `);if(!r.trim()){console.log(`${xt} \u26A0 No key provided \u2014 cancelled${L}`),console.log(`${G} Get your key at: https://build.nvidia.com/${L}`);break}let{NVIDIA_PROVIDER:i}=await Promise.resolve().then(()=>(Nn(),bc));console.log(),console.log(`${G} Available NVIDIA models:${L}`),i.models.forEach((u,d)=>{console.log(` ${Ke}${d+1}${L}. ${u}`)}),console.log();let o=await we(e,` ${G}Model number [1]:${L} `),a=parseInt(o.trim())-1,l=i.models[a]||i.defaultModel;n.provider="nvidia",n.apiUrl=i.apiUrl,n.apiKey=r.trim(),n.model=l,gt(n),nt({name:"NVIDIA",apiUrl:i.apiUrl,apiKey:r.trim(),models:i.models,defaultModel:l,addedAt:new Date().toISOString()}),console.log(),console.log(`${wt} \u2713 Configured for NVIDIA NIM${L}`),console.log(`${G} Model: ${l}${L}`),console.log(`${G} API: ${i.apiUrl}${L}`);break}default:console.log(`${xt} \u26A0 Invalid choice${L}`)}break}default:console.log(`${xt} \u26A0 Invalid choice \u2014 please select 1 or 2${L}`)}console.log(),console.log(`${G} Run 'hablas' to start chatting!${L}`),console.log(),e.close()}var Kg,Ke,wt,xt,G,Kt,L,j0,Wt,Yl=N(()=>{"use strict";Kg=O(require("readline"));pr();vi();Ke="\x1B[36m",wt="\x1B[32m",xt="\x1B[33m",G="\x1B[2m",Kt="\x1B[1m",L="\x1B[0m",j0="\x1B[35m";Wt={provider:"nvidia",apiUrl:"https://integrate.api.nvidia.com/v1",model:"stepfun-ai/step-3.7-flash",name:"Hablas Integrated Engine"}});var jt={};Ne(jt,{activeCollabManager:()=>Pe,runSingleCommand:()=>V0,startRepl:()=>Zl});function K0(){return!pt.existsSync(Ql)}function Gg(){return pt.existsSync(B0)}function W0(){let n=Mt.dirname(Ql);pt.existsSync(n)||pt.mkdirSync(n,{recursive:!0}),pt.writeFileSync(Ql,new Date().toISOString(),"utf-8")}async function G0(n,e=10){let t=n.split(/(\s+)/);for(let s of t)process.stdout.write(s),await new Promise(r=>setTimeout(r,e))}async function zg(n,e,t,s,r){let{interactive:i,autoMode:o,input:a,logger:l,abortSignal:u,onToolCall:d,skipTools:f}=r,h=r.reactEngine??gs(),m=r.errorRecovery??ys(),p=n.getMessages().filter(b=>b.role==="user").pop()?.content||"Solo Execution",x={taskTitle:p.length>45?p.slice(0,45)+"...":p,currentPhase:"Cognitive Reasoning & Planning",activeAgent:"Hablas",activeAgentTitle:"Team Leader",currentActivity:"Analyzing workspace & preparing reasoning path",roster:{Hablas:"active",Emma:"pending",Bob:"pending",Alex:"pending",David:"pending"}};console.log(`
|
|
1057
|
+
`+Au(x));let S=new ze("Hablas is thinking");S.start();let A=b=>{S&&(S.stop(b),S=null)},k=pg({autoMode:o,interactive:i,confirm:a?b=>a.confirm(b):void 0,confirmDangerous:a?b=>a.confirmDangerous(b):void 0});await Fr({identity:{name:"Hablas",title:"Team Leader",role:"hablas"},client:e,registry:t,session:n,contextManager:s,reactEngine:h,errorRecovery:m,logger:l,io:{onAssistantText:async b=>{A(),console.log(yn("Hablas","Team Leader")),await G0(bn(b))},onToolStart:(b,v)=>{A(),console.log(bu(b,v)),S=new ze("Continuing"),S.start()},onToolEnd:(b,v,w,_)=>{A(),console.log(vu(v,w,_))},onNotice:(b,v)=>{A(),console.log(v==="retry"?c.muted(` \u21BB ${b}`):U(b))},onError:b=>{A(),b.includes("ECONNREFUSED")?console.log(He("Connection lost","Check your provider connection or run /provider test")):/timeout/i.test(b)?console.log(He("Request timed out (120s)","The API is slow. Try again or use a faster model.")):b.includes("429")?console.log(He("Rate limited by API","Wait a moment and try again, or switch providers.")):b.includes("model")?console.log(He("Model error","Check model availability: /models")):console.log(He(`Error: ${b}`,"Try again or check /status"))},onToolCall:()=>{d&&d()}},safetyPolicy:k,abortSignal:u,skipTools:f,maxIterations:U0}),A()}async function Zl(n,e){Gp();let t=n.workingDirectory==="."?process.cwd():n.workingDirectory,s=K=>pt.existsSync(Mt.join(K,".git"));if(!s(t)&&!n.team?.enabled)console.log(` ${c.warning("\u26A0")} ${c.secondary("Not in a Git repository. Versioning and auto-sync features are limited.")}
|
|
1062
1058
|
`);else if(n.team?.enabled&&!s(t)){console.log(`
|
|
1063
1059
|
${c.accent("\u2726")} ${c.strong("Team Mode Strategy Required")}`),console.log(` ${c.muted("Collaboration requires a stable Git repository root.")}
|
|
1064
|
-
`);let ee=await new
|
|
1065
|
-
`)}catch{console.log(
|
|
1066
|
-
`)):(console.log(
|
|
1067
|
-
`)}let
|
|
1068
|
-
`),console.log(U("Operation cancelled \u2014 press Ctrl+C again to exit"))});let Z=Cs(n);if(console.log(fu(n.model,t)),n.provider==="custom"&&console.log(fe(`Provider: ${Z}`)),z&&console.log(fe("Auto mode enabled \u2014 tool confirmations skipped (plan approval still required)")),(K0()||!Gg())&&(console.log(mu()),console.log(""),console.log(fe("First run detected \u2014 launching setup wizard...")),console.log(""),a.close(),await zl(n),W0(),r=Fe(n),a.reinitialize()),Gg()){let K=new ze("Connecting");K.start();let ee=await r.checkConnection();if(K.stop(ee?"ready":void 0),ee){let le=await r.listModels();console.log(J(`Connected \xB7 ${le.length} models available`)),n.provider==="ollama"&&!le.includes(n.model)&&console.log(U(`Model "${n.model}" not found. Pull: ollama pull ${n.model}`))}else n.provider==="custom"?console.log(He(`Cannot connect to ${n.apiUrl}`,"Check your --api-url and --api-key, or run /provider test")):n.provider==="nvidia"?console.log(He("Cannot connect to NVIDIA NIM","Check your API key or run: hablas --setup")):console.log(He("Cannot connect to Ollama","Start it with: ollama serve \u2014 or switch provider: /provider"))}console.log(pu()),console.log();let D=!0;for(;D;)try{let ee=(await a.prompt(` ${c.primary("\u203A")} `)).trim();if(!ee)continue;if(ee.startsWith("/")){if(await
|
|
1069
|
-
[Clarification: ${be.join(", ")}]`}}let me=Bg(ne,t,{maxFiles:8,maxTokens:6e3});if(me.files.length>0){let se=Ug(me);
|
|
1060
|
+
`);let ee=await new cs(t).prompt(` ${c.primary("\u203A")} Specify repo path OR type 'init' to start here: `);if(ee.trim().toLowerCase()==="init")try{(0,Vg.execSync)("git init",{cwd:t,stdio:"ignore"}),console.log(` ${c.success("\u2713")} Git repository initialized in ${c.highlight(t)}
|
|
1061
|
+
`)}catch{console.log(Ce("Failed to initialize Git. Please run git init manually.")),process.exit(1)}else{let le=Mt.resolve(t,ee.trim());pt.existsSync(le)&&s(le)?(t=le,n.workingDirectory=t,console.log(` ${c.success("\u2713")} Context switched to repository: ${c.highlight(t)}
|
|
1062
|
+
`)):(console.log(Ce(`Path "${le}" is not a valid Git repository.`)),process.exit(1))}}let r=Fe(n),i=new os(t,n),o=new nn(n),a=new cs(t),l=hr(),u=new mr,d=new ds(t),f=new Mn(t),h=new Wr,m=new jr(n);m.setToolRegistry(i);let p=new Hr,g=new Kr(p).attach(),x=new Ur(n,{tokenBudget:500,maxChars:140});if(m.setChannel(p),n.team?.enabled){let K=n.team.user||"developer",ee=n.team.key||"default-key";Pe=new rs(t,n,K,ee),await Pe.init()&&console.log(` ${c.success("\u2713")} ${c.muted("[Team]")} Scoped cooperative sync initialized successfully.
|
|
1063
|
+
`)}let S=new zr(t);f.init();let A=null;n.context?.hablasCoreEnabled&&(A=new Gr(t),A.init());let k=await Yt(t,n),y=l.getActive(),b=y?y.systemPrompt:Wn,v=Jt(b,k,d,f),w=gs({thinkingEnabled:!0,selfEvalEnabled:!0,showThinking:!1,maxSteps:150,minConfidence:.6}),_=ys(3),E=new sn(v,n.historySize),I=Hn();I=Bi(I),Nt(I);let $=0,F=0,B=Date.now(),z=n.autoMode||!1,T=0,C=new AbortController;process.on("SIGINT",()=>{let K=Date.now();if(K-T<q0){console.log(to({turns:$,duration:Date.now()-B,toolCalls:F}));let ee=Pe?Pe.shutdown():Promise.resolve();Promise.resolve(ee).finally(()=>process.exit(0)),setTimeout(()=>process.exit(0),2e3);return}T=K,C.abort(),C=new AbortController,process.stdout.write(`
|
|
1064
|
+
`),console.log(U("Operation cancelled \u2014 press Ctrl+C again to exit"))});let Z=Cs(n);if(console.log(fu(n.model,t)),n.provider==="custom"&&console.log(fe(`Provider: ${Z}`)),z&&console.log(fe("Auto mode enabled \u2014 tool confirmations skipped (plan approval still required)")),(K0()||!Gg())&&(console.log(mu()),console.log(""),console.log(fe("First run detected \u2014 launching setup wizard...")),console.log(""),a.close(),await zl(n),W0(),r=Fe(n),a.reinitialize()),Gg()){let K=new ze("Connecting");K.start();let ee=await r.checkConnection();if(K.stop(ee?"ready":void 0),ee){let le=await r.listModels();console.log(J(`Connected \xB7 ${le.length} models available`)),n.provider==="ollama"&&!le.includes(n.model)&&console.log(U(`Model "${n.model}" not found. Pull: ollama pull ${n.model}`))}else n.provider==="custom"?console.log(He(`Cannot connect to ${n.apiUrl}`,"Check your --api-url and --api-key, or run /provider test")):n.provider==="nvidia"?console.log(He("Cannot connect to NVIDIA NIM","Check your API key or run: hablas --setup")):console.log(He("Cannot connect to Ollama","Start it with: ollama serve \u2014 or switch provider: /provider"))}console.log(pu()),console.log();let D=!0;for(;D;)try{let ee=(await a.prompt(` ${c.primary("\u203A")} `)).trim();if(!ee)continue;if(ee.startsWith("/")){if(await Wu(ee,n,r,i,o,E,t,a,$,l,u,d,H=>{r=H},f,h,S,m)==="quit"){D=!1;break}continue}e.info({input:ee},"Processing user input");let le=Lc(ee),ne=Yg(le,t);if($++,console.log(wu($)),I=Ui(I),Nt(I),!z){let se=Mg(ne);if(se){console.log(_u(se));let H=await a.prompt(` ${c.muted("\u203A")} `),be=Lg(H,se);ne=`${ne}
|
|
1065
|
+
[Clarification: ${be.join(", ")}]`}}let me=Bg(ne,t,{maxFiles:8,maxTokens:6e3});if(me.files.length>0){let se=Ug(me);E.addUserMessage(`[Auto-loaded ${me.files.length} file(s): ${me.mentionedPaths.join(", ")}]
|
|
1070
1066
|
${se}`,{priority:"low",tags:["auto-inject"]})}if(n.team?.enabled&&Pe){let se=n.team?.user||Pe.getLocalState().my_username,H=me.mentionedPaths||[];if(H.length>0){let be=await Pe.fetchLocks(),Ae=H.map(P=>be.find(X=>X.file_path===P&&X.locked_by!==se)).filter(P=>!!P);if(Ae.length>0){let P=Ae[0];console.log(`
|
|
1071
1067
|
${c.architect("\u25C6")} ${c.strong("@Consul")} [Coordinator] detected an active lock held by a teammate.`),console.log(`
|
|
1072
1068
|
${c.error("\u2554\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2557")}`),console.log(` ${c.error("\u2551")} ${c.strong("\u{1F512} FILE LOCKED BY TEAMMATE")} ${c.error("\u2551")}`),console.log(` ${c.error("\u2560\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2563")}`),console.log(` ${c.error("\u2551")} File ${c.highlight(P.file_path.padEnd(44))} held by ${c.strong(`@${(P.locked_by||"").padEnd(12)}`)} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} Context: ${c.muted((P.lock_context||"\u2014").slice(0,61).padEnd(61))} ${c.error("\u2551")}`),console.log(` ${c.error("\u2551")} @Consul halted this turn to prevent a Git conflict on the shared repo. ${c.error("\u2551")}`),console.log(` ${c.error("\u255A\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u255D")}`);for(let X of Ae)await Pe.sendMessage(X.locked_by,`@${se} needs to edit ${X.file_path}. Please release the lock when you can.`);console.log(` ${c.muted("@Consul notified the teammate(s). Try again once the lock is released, or coordinate directly.")}
|
|
1073
1069
|
`);continue}for(let P of H)if(!await Pe.acquireLock(P,ne.slice(0,100))){console.log(`
|
|
1074
1070
|
${c.warning("\u26A0")} ${c.strong("@Consul")}: a teammate locked ${c.highlight(P)} first. Halting to avoid a conflict.
|
|
1075
|
-
`);continue}}Pe.setActivity(ne.slice(0,80))}if(n.agents.enabled&&n.agents.orchestration==="auto"){let se=Pg(ne),H="FILE";se>=.7?H="FILE":H=
|
|
1071
|
+
`);continue}}Pe.setActivity(ne.slice(0,80))}if(n.agents.enabled&&n.agents.orchestration==="auto"){let se=Pg(ne),H="FILE";se>=.7?H="FILE":H=Eg(ne);let be={bob:"architect",alex:"coder",david:"researcher",hablas:"planner",emma:"product-manager"};if(H==="FILE")E.addUserMessage(ne);else if(H==="COMPONENT"||H==="SERVICE"){let Ae=Oi(ne),P=Ae.find(Q=>Q!=="hablas")||"alex";I=Bn(I,P),Nt(I),Tg(ne,H,Ae),A&&A.updateProgress(`Task started [${H}]: ${ne.substring(0,60)}`);let X=Ii(ne,[P]),M=i.getOllamaTools();p.reset(),x.resetBudget();let W=new vs(p,m,x,n),{finalSynthesis:te,synthesisOk:oe}=await W.run(ne,X,M,{abortSignal:C?.signal,peerReview:H==="SERVICE"});console.log(yn("Hablas","Team Leader")),console.log(bn(te)),E.addAssistantMessage(oe?te:`[Team Execution Summary]
|
|
1076
1072
|
|
|
1077
|
-
${te}`),await Jl(n,t);continue}else if(H==="APPLICATION"||H==="ECOSYSTEM"){let Ae=Oi(ne);if(!Ae.includes("emma")&&H==="ECOSYSTEM"&&Ae.push("emma"),Ae.length>1){let P=Ii(ne,Ae),X=P.tasks.map((Q,ke)=>({description:Q.description,assignee:Q.role||"alex",assigneeName:Q.agentName||Q.role,dependent_task_ids:ke>0?[`plan_${h.nextPlanNum}_t${ke}`]:[]})),M=h.createPlan(P.strategy||ne.slice(0,60),P.strategy||"sequential",X),W=h.getProgress();console.log(
|
|
1073
|
+
${te}`),await Jl(n,t);continue}else if(H==="APPLICATION"||H==="ECOSYSTEM"){let Ae=Oi(ne);if(!Ae.includes("emma")&&H==="ECOSYSTEM"&&Ae.push("emma"),Ae.length>1){let P=Ii(ne,Ae),X=P.tasks.map((Q,ke)=>({description:Q.description,assignee:Q.role||"alex",assigneeName:Q.agentName||Q.role,dependent_task_ids:ke>0?[`plan_${h.nextPlanNum}_t${ke}`]:[]})),M=h.createPlan(P.strategy||ne.slice(0,60),P.strategy||"sequential",X),W=h.getProgress();console.log(Fs(M,{percent:W.percentage,done:W.done,total:W.total}));let oe=(await a.prompt(` ${c.accent("?")} ${c.strong("approve")} / ${c.muted("edit")} / ${c.muted("skip")} ${c.muted("\u203A")} `)).trim().toLowerCase();if(oe==="edit"||oe==="e"){console.log(fe("Edit mode: describe your changes and I will re-plan."));let Q=await a.prompt(` ${c.muted("Edit \u203A")} `);if(Q.trim()){let ke=`${ne}
|
|
1078
1074
|
|
|
1079
|
-
User modification: ${Q.trim()}`;
|
|
1075
|
+
User modification: ${Q.trim()}`;E.addUserMessage(ke)}else E.addUserMessage(ne)}else if(oe==="skip"||oe==="s"){console.log(fe("Plan skipped \u2014 executing directly without orchestration."));for(let Q of M.tasks)h.skipTask(Q.task_id);E.addUserMessage(ne)}else{console.log(J("Plan approved \u2014 executing...")),console.log(""),f.logDecision(`Plan approved: ${M.title}`,"Hablas",`${M.tasks.length} tasks for ${Ae.length} agents`),A&&(A.updateProgress(`Plan approved [${H}]: ${M.title}`),A.recordDecision(`Plan: ${M.title}`,"Hablas",`${M.tasks.length} tasks, ${Ae.length} agents`));for(let Xr of Ae)I=Bn(I,Xr);Nt(I),p.reset(),x.resetBudget();let Q=i.getOllamaTools(),ke=new vs(p,m,x,n),{results:Ge,finalSynthesis:Qr,synthesisOk:iy}=await ke.run(ne,P,Q,{abortSignal:C?.signal,peerReview:!0});for(let Xr of M.tasks)h.finishTask(Xr.task_id);console.log(yn("Hablas","Team Leader")),console.log(bn(Qr)),E.addAssistantMessage(iy?Qr:`[Team Execution Summary]
|
|
1080
1076
|
|
|
1081
|
-
${Qr}`),await Jl(n,t);continue}}else{let P=Ae.find(M=>M!=="hablas")||"alex";I=
|
|
1077
|
+
${Qr}`),await Jl(n,t);continue}}else{let P=Ae.find(M=>M!=="hablas")||"alex";I=Bn(I,P),Nt(I);let X=be[P]||"coder";if(l.has(X)&&l.getActiveName()!==X){l.setActive(X);let M=l.getActive(),W=await Yt(t,n),te=Jt(M.systemPrompt,W,d,f);E.updateSystemPrompt(te)}E.addUserMessage(ne)}}}else E.addUserMessage(ne);C=new AbortController,w.startTurn(),_.resetTurn(),await zg(E,r,i,o,{interactive:!0,autoMode:z,input:a,logger:e,config:n,abortSignal:C.signal,reactEngine:w,errorRecovery:_,skipTools:!1,onToolCall:()=>{F++,I=qi(I,"tool_call"),Nt(I)}}),await Jl(n,t)}catch(K){if(K.code==="ERR_USE_AFTER_CLOSE")break;if(K.name==="AbortError")continue;console.log(Ce(K.message)),e.error(K,"REPL error")}a.close(),Pe&&await Pe.shutdown(),console.log(to({turns:$,duration:Date.now()-B,toolCalls:F}))}async function V0(n,e,t){let s=e.workingDirectory==="."?process.cwd():e.workingDirectory,r=Fe(e),i=new os(s,e),o=new nn(e),a=new ds(s),l=await Yt(s,e),u=Jt(Wn,l,a),d=new sn(u,e.historySize),f=Yg(n,s);d.addUserMessage(f),await zg(d,r,i,o,{interactive:!1,autoMode:e.autoMode||!1,logger:t,config:e})}function Yg(n,e){let t=/#([\w./-]+)/g,s=n,r;for(;(r=t.exec(n))!==null;){let i=r[1],o=Mt.resolve(e,i);pt.existsSync(o)&&(s=s.replace(`#${i}`,i))}return s}async function Jl(n,e){if(!(n.team?.enabled&&Pe))return;if(await Pe.releaseAllMyLocks(),!n.workspace?.autoPush){console.log(`
|
|
1082
1078
|
${c.info("\u2139")} ${c.strong("@Consul")}: "Changes tracked. Auto-push is off \u2014 commit & push manually when ready."
|
|
1083
1079
|
`);return}let{execSync:t}=await import("child_process"),s=r=>t(r,{cwd:e,encoding:"utf-8",stdio:["ignore","pipe","pipe"]}).trim();try{if(!s("git status --porcelain")){console.log(`
|
|
1084
1080
|
${c.muted("@Consul: workspace clean \u2014 nothing to push.")}
|
|
@@ -1089,16 +1085,16 @@ ${Qr}`),await Jl(n,t);continue}}else{let P=Ae.find(M=>M!=="hablas")||"alex";I=Un
|
|
|
1089
1085
|
`),s("git add -A"),s('git commit -m "sync(team): automatic updates via @Consul" --no-verify');return}console.log(`
|
|
1090
1086
|
${c.success("\u{1F4C1}")} ${c.muted("[Git]")} ${c.strong("@Consul")} committing & pushing to ${c.highlight(i)} \u2192 ${c.muted(o)} ...`),s("git add -A"),s('git commit -m "sync(team): automatic updates via @Consul" --no-verify');try{s(`git push origin ${i}`)}catch{s(`git push --set-upstream origin ${i}`)}console.log(` ${c.success("\u2713")} ${c.strong("@Consul")}: "Pushed to ${i}. Teammates can pull the latest."
|
|
1091
1087
|
`)}catch(r){let i=r.stderr||r.message||"unknown error",o=/authentication|permission|denied|403|401/i.test(i)?"Check your Git credentials / token for this remote.":/non-fast-forward|rejected|behind/i.test(i)?"Remote has newer commits \u2014 pull/rebase first, then push.":"Resolve the issue and push manually.";console.log(` ${c.warning("\u26A0")} ${c.strong("@Consul")}: auto-push failed. ${c.muted(o)}
|
|
1092
|
-
`)}}var
|
|
1088
|
+
`)}}var pt,Vg,Mt,Xl,Pe,Ql,B0,U0,q0,Et=N(()=>{"use strict";Gu();da();pt=O(require("fs")),Vg=require("child_process"),Mt=O(require("path")),Xl=O(require("os"));Fn();Hp();ba();va();Kp();pr();Ba();Vp();Jp();wi();fn();yg();vg();wg();Ag();kg();Un();Wl();$g();Cg();Rg();Og();Dg();vn();Ng();qg();Yl();Nl();jl();Kl();Pe=null,Ql=Mt.join(Xl.homedir(),".hablas",".first_run_done"),B0=Mt.join(Xl.homedir(),".hablas","config.json"),U0=150,q0=1500});function Lt(n){let e=tc.join(Jg.homedir(),".hablas","logs");Jr.existsSync(e)||Jr.mkdirSync(e,{recursive:!0});let t=tc.join(e,`session-${Date.now()}.log`);return(0,ec.default)({level:"info"},ec.default.destination({dest:t,sync:!1}))}var ec,tc,Jg,Jr,nc=N(()=>{"use strict";ec=O(Ll()),tc=O(require("path")),Jg=O(require("os")),Jr=O(require("fs"))});var ty={};Ne(ty,{createApiServer:()=>ey,startApiServer:()=>Q0});function z0(){try{return JSON.parse(Xg.readFileSync(Zg.resolve(__dirname,"..","..","package.json"),"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}function ey(n){let e=Lt(n),t=J0(n);return Qg.createServer(async(r,i)=>{if(i.setHeader("Access-Control-Allow-Origin","*"),i.setHeader("Access-Control-Allow-Methods","GET, POST, PUT, DELETE, OPTIONS"),i.setHeader("Access-Control-Allow-Headers","Content-Type, Authorization"),i.setHeader("Content-Type","application/json"),r.method==="OPTIONS"){i.writeHead(204),i.end();return}if(n.api.apiKey&&(r.headers.authorization||"").replace("Bearer ","")!==n.api.apiKey){i.writeHead(401),i.end(JSON.stringify({error:"Unauthorized",message:"Invalid API key"}));return}let o={};if(r.method==="POST"||r.method==="PUT")try{let l=[];for await(let d of r)l.push(d);let u=Buffer.concat(l).toString();u&&(o=JSON.parse(u))}catch{i.writeHead(400),i.end(JSON.stringify({error:"Bad Request",message:"Invalid JSON body"}));return}let a=t.find(l=>l.method===r.method&&r.url?.startsWith(l.path));if(!a){i.writeHead(404),i.end(JSON.stringify({error:"Not Found",message:`No route for ${r.method} ${r.url}`}));return}try{let l={method:r.method||"GET",path:r.url||"/",body:o,headers:r.headers},u=await a.handler(l);i.writeHead(u.status),i.end(JSON.stringify(u.body))}catch(l){e.error({err:l},"API error"),i.writeHead(500),i.end(JSON.stringify({error:"Internal Server Error",message:String(l)}))}})}function J0(n){return[{method:"GET",path:"/api/v1/health",handler:async()=>({status:200,body:{status:"ok",version:Y0,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 Q0(n){return new Promise((e,t)=>{let s=ey(n);s.on("error",t),s.listen(n.api.port,n.api.host,()=>{e(s)})})}var Qg,Xg,Zg,Y0,ny=N(()=>{"use strict";Qg=O(require("http")),Xg=O(require("fs")),Zg=O(require("path"));nc();Y0=z0()});var Z0={};Ne(Z0,{CLI_VERSION:()=>xs});module.exports=dy(Z0);var gc=O(mc(),1),{program:lC,createCommand:cC,createArgument:uC,createOption:dC,CommanderError:fC,InvalidArgumentError:pC,InvalidOptionArgumentError:hC,Command:yc,Argument:mC,Option:gC,Help:yC}=gc.default;Et();pr();nc();var sy=O(require("fs")),ry=O(require("path"));function X0(){try{let n=ry.resolve(__dirname,"..","package.json");return JSON.parse(sy.readFileSync(n,"utf-8")).version||"0.0.0"}catch{return"0.0.0"}}var xs=X0(),ae=new yc;ae.name("hablas").description(`hablas CLI v${xs} by Abdulmoin Hablas \u2014 Multi-agent AI development system. Local-first via Ollama, NVIDIA NIM, or any OpenAI-compatible API.`).version(xs).option("-m, --model <model>","Model to use").option("-p, --project <path>","Working directory").option("--host <url>","Ollama host URL").option("--provider <type>","LLM provider: ollama | custom | nvidia").option("--api-url <url>","Custom API base URL (OpenAI-compatible)").option("--api-key <key>","API key for custom/nvidia provider").option("--auto","Auto mode \u2014 skip all tool confirmations").option("--timeout <ms>","Request timeout in milliseconds","120000").option("--theme <name>","UI theme: dark | light | galaxy | ocean | forest").option("--dashboard","Launch TUI dashboard mode").option("--team","Enable hybrid cooperative sync mode with teammates").option("--user <name>","Teammate username for coordination").option("--team-key <password>","Teammate password/key for secure connection encryption").option("--setup","Run first-time setup wizard");ae.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=ae.opts(),s=Ze({model:t.model,host:t.host,project:t.project,provider:t.provider,apiUrl:t.apiUrl,apiKey:t.apiKey});t.auto&&(s.autoMode=!0);let r=Lt(s),{runSingleCommand:i}=await Promise.resolve().then(()=>(Et(),jt)),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)});ae.command("commit").description("Generate a smart commit message from staged changes").action(async()=>{let n=ae.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),t=Lt(e),{getGitStatus:s,getDetailedDiff:r,generateCommitPrompt:i}=await Promise.resolve().then(()=>(mn(),qn)),o=e.workingDirectory||process.cwd(),a=await s(o);if(!a||a.staged.length===0){console.log(" \u26A0 No staged changes. Use `git add` first.");return}let l=await r(o),u=i(l,a.staged),{runSingleCommand:d}=await Promise.resolve().then(()=>(Et(),jt));await d(u,e,t)});ae.command("pr").description("Generate a PR description from branch commits").option("--base <branch>","Base branch","main").action(async n=>{let e=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Lt(t),{getGitStatus:r,getRecentCommits:i,generatePRPrompt:o}=await Promise.resolve().then(()=>(mn(),qn)),a=t.workingDirectory||process.cwd(),l=await r(a),u=await i(a,20),d=o(u,n.base,l?.branch||"feature"),{runSingleCommand:f}=await Promise.resolve().then(()=>(Et(),jt));await f(d,t,s)});ae.command("changelog").description("Generate changelog from recent commits").option("--version <ver>","Version number",xs).option("-n, --count <n>","Number of commits to include","30").action(async n=>{let e=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),s=Lt(t),{getRecentCommits:r,generateChangelogPrompt:i}=await Promise.resolve().then(()=>(mn(),qn)),o=t.workingDirectory||process.cwd(),a=await r(o,parseInt(n.count)),l=i(a,n.version),{runSingleCommand:u}=await Promise.resolve().then(()=>(Et(),jt));await u(l,t,s)});ae.command("security").description("Run security scan on the project").option("--fix","Auto-fix issues where possible").action(async n=>{let e=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),{runSecurityScan:s,formatScanResults:r}=await Promise.resolve().then(()=>(Vi(),Jc)),i=t.workingDirectory||process.cwd();console.log(`
|
|
1093
1089
|
\u{1F512} Running security scan...
|
|
1094
|
-
`);let o=s(i);console.log(r(o))});ae.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(
|
|
1090
|
+
`);let o=s(i);console.log(r(o))});ae.command("stats").description("Show developer analytics and usage statistics").action(async()=>{let{loadStats:n,formatStats:e}=await Promise.resolve().then(()=>(Un(),Ki)),t=n();console.log(e(t))});ae.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=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey}),{loadTeamConfig:s,initTeamConfig:r,addTeamMember:i,saveTeamConfig:o,formatTeamConfig:a}=await Promise.resolve().then(()=>(da(),Jf)),l=t.workingDirectory||process.cwd();if(n.init)r(l,n.init),console.log(`
|
|
1095
1091
|
\u2713 Team "${n.init}" initialized.`),console.log(` Config saved to: .hablas/team.json
|
|
1096
1092
|
`);else if(n.add){let u=s(l);if(!u){console.log(" \u26A0 No team config found. Run `hablas team --init <name>` first.");return}let d=i(u,n.add.split("@")[0],n.add);o(l,d),console.log(` \u2713 Added ${n.add} to team.`)}else{let u=s(l);if(!u){console.log(" No team config found. Run `hablas team --init <name>` to create one.");return}console.log(a(u))}});ae.command("info").description("Show workspace information and detected configuration").action(async()=>{let n=ae.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),{scanWorkspace:t,formatWorkspaceInfo:s}=await Promise.resolve().then(()=>(Ji(),su)),r=e.workingDirectory||process.cwd();console.log(`
|
|
1097
1093
|
\u25C6 Workspace Information
|
|
1098
1094
|
`);let i=t(r);console.log(s(i)),console.log("")});ae.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=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey});t.api.enabled=!0,t.api.port=parseInt(n.port),n.key&&(t.api.apiKey=n.key);let{startApiServer:s}=await Promise.resolve().then(()=>(ny(),ty));console.log(`
|
|
1099
|
-
\u25C6 Hablas API Server v${
|
|
1095
|
+
\u25C6 Hablas API Server v${xs}`),console.log(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"),console.log(` Starting on port ${t.api.port}...`);try{await s(t),console.log(` \u2713 API server running at http://${t.api.host}:${t.api.port}`),console.log(" Endpoints:"),console.log(" GET /api/v1/health \u2014 Health check"),console.log(" GET /api/v1/agents \u2014 List agents"),console.log(" GET /api/v1/models \u2014 List models"),console.log(" POST /api/v1/chat \u2014 Send message"),console.log(" POST /api/v1/plan \u2014 Generate plan"),console.log(" POST /api/v1/execute \u2014 Execute command"),console.log(" GET /api/v1/stats \u2014 Usage stats"),console.log(`
|
|
1100
1096
|
Press Ctrl+C to stop.
|
|
1101
|
-
`)}catch(r){console.error(` \u2717 Failed to start API server: ${r}`)}});ae.command("run <prompt>").description("Run a single command non-interactively").action(async n=>{let e=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey});e.auto&&(t.autoMode=!0),e.timeout&&(t.timeout=parseInt(e.timeout,10));let s=Lt(t),{runSingleCommand:r}=await Promise.resolve().then(()=>(Et(),
|
|
1097
|
+
`)}catch(r){console.error(` \u2717 Failed to start API server: ${r}`)}});ae.command("run <prompt>").description("Run a single command non-interactively").action(async n=>{let e=ae.opts(),t=Ze({model:e.model,host:e.host,project:e.project,provider:e.provider,apiUrl:e.apiUrl,apiKey:e.apiKey});e.auto&&(t.autoMode=!0),e.timeout&&(t.timeout=parseInt(e.timeout,10));let s=Lt(t),{runSingleCommand:r}=await Promise.resolve().then(()=>(Et(),jt));await r(n,t,s)});ae.command("doctor").description("Run system diagnostics").action(async()=>{let n=ae.opts(),e=Ze({model:n.model,host:n.host,project:n.project,provider:n.provider,apiUrl:n.apiUrl,apiKey:n.apiKey}),{runDiagnostics:t,renderDiagnostics:s}=await Promise.resolve().then(()=>(Ri(),Uc)),r=await t({ollamaHost:e.ollamaHost,model:e.model,provider:e.provider,apiUrl:e.apiUrl});console.log(s(r))});ae.command("plugins").description("Manage plugins").option("--enable <name>","Enable a plugin").option("--disable <name>","Disable a plugin").option("--search <query>","Search plugin marketplace").option("--install <name>","Install a plugin from marketplace").action(async n=>{let{enablePlugin:e,disablePlugin:t,renderPlugins:s,ensurePluginsDir:r}=await Promise.resolve().then(()=>($i(),jc));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(`
|
|
1102
1098
|
\u{1F50D} Searching marketplace for "${n.search}"...`),console.log(" (Marketplace: https://registry.hablas.dev/plugins)"),console.log(`
|
|
1103
1099
|
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(`
|
|
1104
1100
|
Install: hablas plugins --install <name>
|