@ebowwa/coder 0.1.12 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,308 @@
1
+ // @bun
2
+ var Q6=Object.create;var{getPrototypeOf:Z6,defineProperty:NQ,getOwnPropertyNames:$6}=Object;var X6=Object.prototype.hasOwnProperty;var V6=(Q,Z,$)=>{$=Q!=null?Q6(Z6(Q)):{};let X=Z||!Q||!Q.__esModule?NQ($,"default",{value:Q,enumerable:!0}):$;for(let V of $6(Q))if(!X6.call(X,V))NQ(X,V,{get:()=>Q[V],enumerable:!0});return X};var b0=import.meta.require;var W0={enabled:!0,ttl:"1h",cacheSystemPrompt:!0,cacheTools:!0,minTokensForCache:1024},z6={low:1024,medium:4096,high:16384,max:1e5},K7={enabled:!1,effort:"medium",interleaved:!0};function SQ(Q,Z){if(Q.budgetTokens)return Q.budgetTokens;let $=Q.effort||"medium",X=z6[$],V=Q.modelMultiplier??(Z.includes("opus")?2:1);return Math.min(X*V,1e5)}function IQ(Q){return Q.includes("claude-opus-4")||Q.includes("claude-sonnet-4")||Q.includes("claude-haiku-4")||Q.includes("claude-4")}var q7={"claude-opus-4-6":{input:15,output:75,cache_write:18.75,cache_read:1.5},"claude-sonnet-4-6":{input:3,output:15,cache_write:3.75,cache_read:0.3},"claude-haiku-4-5":{input:0.8,output:4,cache_write:1,cache_read:0.08}};var J6={maxRetries:3,baseDelayMs:1000,maxDelayMs:30000,jitterFactor:0.2,retryableStatusCodes:[429,500,502,503,504,529],onRetry:void 0};function Y6(Q,Z,$,X){let V=Z*Math.pow(2,Q),z=V*X*(Math.random()*2-1);return Math.min(V+z,$)}function K6(Q,Z){if(Q.message.includes("429")||Q.message.includes("rate limit"))return!0;if(Q.message.includes("500")||Q.message.includes("502")||Q.message.includes("503")||Q.message.includes("504"))return!0;if(Q.message.includes("ECONNREFUSED")||Q.message.includes("ENOTFOUND")||Q.message.includes("ETIMEDOUT")||Q.message.includes("network")||Q.message.includes("fetch failed"))return!0;for(let $ of Z)if(Q.message.includes(String($)))return!0;return!1}function q6(Q){return new Promise((Z)=>setTimeout(Z,Q))}async function xQ(Q,Z={}){let $={...J6,...Z},X=null;for(let V=0;V<=$.maxRetries;V++)try{return await Q()}catch(z){if(X=z instanceof Error?z:Error(String(z)),V<$.maxRetries&&K6(X,$.retryableStatusCodes)){let J=Y6(V,$.baseDelayMs,$.maxDelayMs,$.jitterFactor);if($.onRetry)$.onRetry(V+1,X,J);else console.warn(`\x1B[33mRetry ${V+1}/${$.maxRetries} after ${J}ms: ${X.message}\x1B[0m`);await q6(J)}else throw X}throw X||Error("Max retries exceeded")}var EQ={"claude-opus-4-6":{input:15,output:75,cache_write:18.75,cache_read:1.5},"claude-sonnet-4-6":{input:3,output:15,cache_write:3.75,cache_read:0.3},"claude-haiku-4-5":{input:0.8,output:4,cache_write:1,cache_read:0.08},"claude-3-5-sonnet":{input:3,output:15,cache_write:3.75,cache_read:0.3},"claude-3-5-haiku":{input:0.8,output:4,cache_write:1,cache_read:0.08},"claude-3-opus":{input:15,output:75,cache_write:18.75,cache_read:1.5}};function W6(Q,Z){let $=EQ[Q]??EQ["claude-sonnet-4-6"],X=Z.input_tokens-(Z.cache_read_input_tokens??0),V=Z.cache_read_input_tokens??0,z=Z.cache_creation_input_tokens??0,J=Z.output_tokens,Y=X/1e6*$.input,K=V/1e6*$.cache_read,q=z/1e6*$.cache_write,W=J/1e6*$.output,H=Y+K+q+W,_=(V+z)/1e6*($.input-$.cache_read);return{costUSD:H,estimatedSavingsUSD:_}}function H6(Q,Z){if(!Q||!Z.enabled||!Z.cacheSystemPrompt)return typeof Q==="string"?Q:void 0;if(Array.isArray(Q)){let $=[...Q];if($.length>0){let X=$[$.length-1];if(X&&X.type==="text")$[$.length-1]={type:"text",text:X.text,cache_control:{type:"ephemeral",ttl:Z.ttl}}}return $}return[{type:"text",text:Q,cache_control:{type:"ephemeral",ttl:Z.ttl}}]}function G6(Q,Z){if(!Z.enabled)return Q;let $=[];for(let X=0;X<Q.length;X++){let V=Q[X],z=[];for(let J=0;J<V.content.length;J++){let Y=V.content[J],K=J===V.content.length-1,q=X===Q.length-1;if(Y.type==="text"&&Y.text.length>=Z.minTokensForCache*4&&!Y.cache_control&&(K||q))z.push({...Y,cache_control:{type:"ephemeral",ttl:Z.ttl}});else z.push(Y)}$.push({...V,content:z})}if($.length>0&&Z.enabled){let X=$[$.length-1],V=X.content[X.content.length-1];if(V&&!("cache_control"in V))X.content[X.content.length-1]={...V,cache_control:{type:"ephemeral",ttl:Z.ttl}}}return $}function _6(Q){let Z=Q.cache_read_input_tokens??0,$=Q.cache_creation_input_tokens??0,X=Z+$,V=Z>0?1:0,z=$>0?1:0,J=V+z;return{cacheHits:V,cacheMisses:z,totalCacheReadTokens:Z,totalCacheWriteTokens:$,cacheHitRate:J>0?V/J:0,estimatedSavingsUSD:0}}async function TQ(Q,Z){let{apiKey:$,model:X="claude-sonnet-4-6",maxTokens:V=4096,tools:z,systemPrompt:J,cacheConfig:Y=W0,thinking:K,extendedThinking:q,stopSequences:W,onToken:H,onThinking:G,onRedactedThinking:_,onToolUse:U,signal:j}=Z,A=Date.now(),w=0,B=!0,O=0,v=G6(Q,Y),L=H6(J,Y),S={model:X,max_tokens:V,messages:v.map((R)=>({role:R.role,content:R.content})),stream:!0};if(L)S.system=L;if(z&&z.length>0)S.tools=z;if(W&&W.length>0)S.stop_sequences=W;let e=`${process.env.ANTHROPIC_BASE_URL||"https://api.anthropic.com"}/v1/messages`,P={"Content-Type":"application/json","x-api-key":$,"anthropic-version":"2023-06-01"};if(((q?.enabled??!1)||K&&K.type!=="disabled")&&IQ(X)){let R;if(q?.budgetTokens)R=q.budgetTokens;else if(K?.type==="enabled")R=K.budget_tokens;else{let v9=q?.effort||"medium";R=SQ({enabled:!0,effort:v9,modelMultiplier:X.includes("opus")?2:1},X)}R=Math.max(1024,Math.min(R,1e5)),S.thinking={type:"enabled",budget_tokens:R};let r=["extended-thinking-2025-01-24"];if(q?.interleaved!==!1)r.push("interleaved-thinking-2025-01-24");P["anthropic-beta"]=r.join(",")}else P["anthropic-beta"]="max-tokens-3-5-sonnet-2024-07-15";let f9={maxRetries:3,baseDelayMs:1000,maxDelayMs:30000,retryableStatusCodes:[429,500,502,503,504,529],onRetry:(R,r,v9)=>{console.log(`\x1B[33mAPI retry ${R}/3 after ${v9}ms: ${r.message}\x1B[0m`)}},Q9=await xQ(async()=>{let R=await fetch(e,{method:"POST",headers:P,body:JSON.stringify(S),signal:j});if(!R.ok&&f9.retryableStatusCodes?.includes(R.status)){let r=await R.text();throw Error(`API error: ${R.status} - ${r}`)}return R},f9);if(!Q9.ok){let R=await Q9.text();throw Error(`API error: ${Q9.status} - ${R}`)}if(!Q9.body)throw Error("No response body");let b9=Q9.body.getReader(),u9=new TextDecoder,q9=null,W9=[],H9={input_tokens:0,output_tokens:0},k=null,A9=null,Z9=null,c=null,O9="",h9=new Map,DQ="";try{let R="";while(!0){let{done:r,value:v9}=await b9.read();if(r)break;R+=u9.decode(v9,{stream:!0});let g9=R.split(`
3
+ `);R=g9.pop()||"";for(let d9 of g9){if(!d9.startsWith("data: "))continue;let N9=d9.slice(6);if(!N9)continue;try{let X9=JSON.parse(N9);switch(X9.type){case"message_start":{let F=X9.message;q9=F,H9=F.usage;break}case"content_block_start":{let{index:F,content_block:M}=X9;if(h9.set(F,M.type),M.type==="text")k={type:"text",text:""};else if(M.type==="thinking")A9={type:"thinking",thinking:""};else if(M.type==="redacted_thinking")Z9={type:"redacted_thinking",data:""};else if(M.type==="tool_use")c={type:"tool_use",id:M.id,name:M.name,input:{}},O9="";break}case"content_block_delta":{let F=X9.delta;if(F.type==="text_delta"&&k){let M=F.text;if(k.text+=M,H?.(M),B)w=Date.now()-A,B=!1}else if(F.type==="thinking_delta"&&A9){let M=F.thinking;A9.thinking+=M,G?.(M),O+=Math.ceil(M.length/4)}else if(F.type==="redacted_thinking_delta"&&Z9){let M=F.data;Z9.data+=M,_?.(M),O+=Math.ceil(M.length/4)}else if(F.type==="input_json_delta"&&c)O9+=F.partial_json;break}case"content_block_stop":{let F=X9.index,M=h9.get(F);if(M==="text"&&k)W9.push(k),k=null;else if(M==="thinking"&&A9)W9.push(A9),A9=null;else if(M==="redacted_thinking"){let C={type:"redacted_thinking",data:Z9?.data||""};W9.push(C),_?.(C.data),Z9=null}else if(M==="tool_use"&&c){try{c.input=JSON.parse(O9)}catch{c.input={}}W9.push(c),U?.({id:c.id,name:c.name,input:c.input}),c=null}h9.delete(F);break}case"message_delta":{let F=X9;if(F.usage)H9.output_tokens=F.usage.output_tokens;if(q9&&F.delta?.stop_reason)q9.stop_reason=F.delta.stop_reason;break}case"message_stop":break}}catch{}}}}finally{b9.releaseLock()}if(!q9)throw Error("No message received from API");q9.content=W9;let{costUSD:k0,estimatedSavingsUSD:G9}=W6(X,H9),D9=_6(H9);D9.estimatedSavingsUSD=G9;let $9=Date.now()-A;return{message:q9,usage:H9,cacheMetrics:D9,costUSD:k0,durationMs:$9,ttftMs:w||$9,thinkingTokens:O}}import*as yQ from"readline";var j6={Read:"low",Glob:"low",Grep:"low",Task:"low",Write:"medium",Edit:"medium",NotebookEdit:"medium",Bash:"high"},U6=[/\brm\s+-rf\b/,/\brm\s+-r\b/,/\brm\s+[^-]/,/\bgit\s+push\s+--force\b/,/\bgit\s+reset\s+--hard\b/,/\bgit\s+clean\s+-fd\b/,/\bdrop\b/i,/\bdelete\b/i,/\btruncate\b/i,/\bformat\b/i,/\bdd\s+if=/,/\bshred\b/,/\b:\(\)\{\s*:\|:\s*&\s*\};\s*:\b/];function w6(Q,Z){let $=j6[Q]??"medium";if(Q==="Bash"){let X=String(Z.command??"");for(let V of U6)if(V.test(X))return"critical";if(/\bsudo\b/.test(X)||/\bchmod\b/.test(X))$="high"}if(Q==="Write"||Q==="Edit"){let X=String(Z.file_path??Z.path??"");if(/\.(env|pem|key|secret|credentials)/.test(X))$="high";if(/\/\.ssh\//.test(X)||/\/\.gnupg\//.test(X))$="critical"}return $}function A6(Q,Z){switch(Q){case"Read":return`Read file: ${Z.file_path??"unknown"}`;case"Write":return`Write file: ${Z.file_path??"unknown"} (${String(Z.content??"").length} chars)`;case"Edit":return`Edit file: ${Z.file_path??"unknown"}`;case"Bash":return`Execute: ${String(Z.command??"").slice(0,100)}${String(Z.command??"").length>100?"...":""}`;case"Glob":return`Find files: ${Z.pattern??"*"}`;case"Grep":return`Search: "${Z.pattern??""}" in ${Z.path??"."}`;case"Task":return`Spawn agent: ${Z.subagent_type??"unknown"}`;default:return`Use tool: ${Q}`}}class u0{cache={};cacheTimeout=300000;promptCallback;mode;constructor(Q="default",Z){this.mode=Q,this.promptCallback=Z??this.defaultPrompt.bind(this)}async checkPermission(Q,Z){if(this.mode==="bypassPermissions")return{decision:"allow"};if(this.mode==="dontAsk")return{decision:"deny",reason:"Permission mode is dontAsk"};if(this.mode==="acceptEdits"){if(["Read","Write","Edit","Glob","Grep"].includes(Q))return{decision:"allow"}}if(this.mode==="plan"){if(["Read","Glob","Grep","Task"].includes(Q))return{decision:"allow"};return{decision:"deny",reason:"Plan mode - write operations disabled"}}let $=this.getCacheKey(Q,Z),X=this.cache[$];if(X&&Date.now()-X.timestamp<this.cacheTimeout){if(X.decision==="allowAlways")return{decision:"allow",reason:"Previously approved (always)"};if(X.decision==="denyAlways")return{decision:"deny",reason:"Previously denied (always)"}}let V=w6(Q,Z),z=A6(Q,Z),J={toolName:Q,toolInput:Z,riskLevel:V,description:z,file:Z.file_path??Z.path,command:Q==="Bash"?Z.command:void 0};if(this.mode==="interactive"||this.mode==="default"){let Y=await this.promptCallback(J);if(Y.decision==="allowAlways"||Y.decision==="denyAlways")this.cache[$]={decision:Y.decision,timestamp:Date.now()};return Y}return{decision:"allow"}}getCacheKey(Q,Z){if(["Read","Write","Edit"].includes(Q))return`${Q}:${Z.file_path??Z.path??"unknown"}`;if(Q==="Bash"){let $=String(Z.command??"").slice(0,100);return`${Q}:${$}`}return Q}async defaultPrompt(Q){return new Promise((Z)=>{let $=yQ.createInterface({input:process.stdin,output:process.stdout}),V={low:"\x1B[32m",medium:"\x1B[33m",high:"\x1B[31m",critical:"\x1B[35m"}[Q.riskLevel]??"\x1B[0m",z="\x1B[0m";if(console.log(""),console.log("\x1B[36m\u2501\u2501\u2501 Permission Required \u2501\u2501\u2501\x1B[0m"),console.log(`Tool: \x1B[1m${Q.toolName}\x1B[0m`),console.log(`Risk: ${V}${Q.riskLevel.toUpperCase()}\x1B[0m`),console.log(`Action: ${Q.description}`),Q.file)console.log(`File: ${Q.file}`);if(Q.command)console.log(`Command: ${Q.command.slice(0,200)}${Q.command.length>200?"...":""}`);console.log("");let J="[y]es / [n]o / [a]lways / [d]eny always";$.question(`Allow? ${J}: `,(Y)=>{switch($.close(),Y.trim().toLowerCase()){case"y":case"yes":Z({decision:"allow"});break;case"a":case"always":Z({decision:"allowAlways"});break;case"d":case"deny":case"deny always":Z({decision:"denyAlways"});break;case"n":case"no":default:Z({decision:"deny"});break}})})}clearCache(){this.cache={}}setMode(Q){this.mode=Q,this.clearCache()}}var h0={readOnly:["Read","Glob","Grep","Task"],fileEdit:["Write","Edit","NotebookEdit"],system:["Bash"],network:[]};function A7(Q){return h0.readOnly.includes(Q)}function B7(Q){return h0.fileEdit.includes(Q)}function L7(Q){return h0.system.includes(Q)}import{join as V9,dirname as B6}from"path";import{fileURLToPath as L6}from"url";import{existsSync as F6}from"fs";var c9=null,kQ=!1;function I(){if(c9)return c9;if(kQ)return fQ();kQ=!0;let{platform:Q,arch:Z}=process,$=`${Q}-${Z}`,X;try{X=B6(L6(import.meta.url))}catch{X=process.cwd()}let V=[V9(X,"..","..","native",`claude-code-native.${$}.node`),V9(X,"..","native",`claude-code-native.${$}.node`),V9(X,"native",`claude-code-native.${$}.node`),V9(X,"..","..","native",`claude_code_native.${$}.node`),V9(X,"..","..","native","index.node"),V9(X,"..","native","index.node"),V9(X,"..","..","native","claude-code-native.node"),V9(X,"..","..","node_modules","@ebowwa","coder-native","index.node"),V9(process.cwd(),"native",`claude-code-native.${$}.node`),V9(process.cwd(),"native","index.node")];for(let z of V)if(F6(z))try{let J=b0(z);return console.debug(`[native] Loaded module from: ${z}`),c9=J,c9}catch(J){console.debug(`[native] Failed to load ${z}:`,J);continue}return console.debug("[native] No native module found, using JS fallback"),fQ()}function G0(){try{return I(),c9!==null}catch{return!1}}var O6=4,l9=10,bQ=100;function d(Q){if(!Q||Q.length===0)return 0;return Math.ceil(Q.length/O6)}function m0(Q){switch(Q.type){case"text":return d(Q.text);case"image":return bQ;case"tool_use":{let Z=JSON.stringify(Q.input);return d(Q.name)+d(Z)+l9}case"tool_result":{if(typeof Q.content==="string")return d(Q.content)+l9;return Q.content.reduce((Z,$)=>Z+m0($),0)+l9}case"thinking":return d(Q.thinking);case"redacted_thinking":return d(Q.data);default:return 0}}function H0(Q){let Z=14695981039346656037n,$=1099511628211n,X=Z;for(let V=0;V<Q.length;V++)X^=BigInt(Q.charCodeAt(V)),X*=$,X&=0xFFFFFFFFFFFFFFFFn;return X.toString(16).padStart(16,"0")}function z9(Q){let Z=3735928559,$=1103553917;for(let X=0;X<Q.length;X++){let V=Q.charCodeAt(X);Z=Math.imul(Z^V,2654435761),$=Math.imul($^V,1597334677)}return Z=Math.imul(Z^Z>>>16,2246822507),Z=Math.imul(Z^Z>>>13,3266489909),Z=(Z^Z>>>16)>>>0,$=Math.imul($^$>>>16,2246822507),$=Math.imul($^$>>>13,3266489909),$=($^$>>>16)>>>0,(Z>>>0).toString(16).padStart(8,"0")+($>>>0).toString(16).padStart(8,"0")}function g0(Q){if(typeof Bun<"u"&&Bun.hash)try{return Bun.hash(Q).toString(16).padStart(16,"0")}catch{}if(typeof crypto<"u"&&crypto.subtle);let Z=z9(Q);for(let $=0;$<3;$++)Z=z9(Z+Q+$);return(Z+H0(Q)+z9(Q+Z)).slice(0,64)}function d0(Q){let Z;try{Z=JSON.parse(Q)}catch{return{pairs:[],totalToolUses:0,totalToolResults:0,matchedPairs:0,orphanUses:0,orphanResults:0}}let $=new Map,X=0,V=0,z=0;Z.forEach((W,H)=>{if(!Array.isArray(W.content))return;W.content.forEach((G)=>{if(G.type==="tool_use"&&G.id&&G.name)X++,$.set(G.id,{toolUse:{blockType:"tool_use",id:G.id,name:G.name,input:JSON.stringify(G.input||{})},toolResult:void 0,useMessageIndex:H,resultMessageIndex:void 0})})}),Z.forEach((W,H)=>{if(!Array.isArray(W.content))return;W.content.forEach((G)=>{if(G.type==="tool_result"&&G.tool_use_id){V++;let _=$.get(G.tool_use_id);if(_)z++,_.toolResult={blockType:"tool_result",toolUseId:G.tool_use_id,content:typeof G.content==="string"?G.content:JSON.stringify(G.content),isError:G.is_error||!1},_.resultMessageIndex=H}})});let J=Array.from($.values()),Y=J.filter((W)=>!W.toolResult).length,K=new Set(J.filter((W)=>W.toolResult).map((W)=>W.toolResult.toolUseId)),q=0;return Z.forEach((W)=>{if(!Array.isArray(W.content))return;W.content.forEach((H)=>{if(H.type==="tool_result"&&H.tool_use_id){if(!K.has(H.tool_use_id))q++}})}),{pairs:J,totalToolUses:X,totalToolResults:V,matchedPairs:z,orphanUses:Y,orphanResults:q}}function v6(Q){let Z;try{Z=JSON.parse(Q)}catch{return{toolCounts:"{}",totalInvocations:0,successRate:1,mostUsedTool:void 0,mostUsedCount:0}}let $=new Map,X=0,V=0,z=0;Z.forEach((W)=>{if(!Array.isArray(W.content))return;W.content.forEach((H)=>{if(H.type==="tool_use"&&H.name)$.set(H.name,($.get(H.name)||0)+1),X++;if(H.type==="tool_result")if(H.is_error)z++;else V++})});let J,Y=0;$.forEach((W,H)=>{if(W>Y)Y=W,J=H});let K=V+z,q=K>0?V/K:1;return{toolCounts:JSON.stringify(Object.fromEntries($)),totalInvocations:X,successRate:q,mostUsedTool:J,mostUsedCount:Y}}async function m9(Q,Z){let $=[],X=new Set,V=0,z=!1;try{let J=["--json"];if(Z.caseInsensitive)J.push("-i");if(Z.contextLines)J.push("-C",String(Z.contextLines));if(Z.glob)J.push("--glob",Z.glob);if(Z.hidden)J.push("--hidden");J.push(Z.pattern,Q);let K=Bun.spawnSync(["rg",...J],{maxBuffer:10485760}).stdout?.toString()||"";if(!K.trim())return{matches:[],totalCount:0,filesSearched:0,filesWithMatches:[],truncated:!1};let q=K.trim().split(`
4
+ `),W=Z.headLimit||100;for(let H of q){if($.length>=W){z=!0;break}try{let G=JSON.parse(H);if(G.type==="match"){let _=G.data?.path?.text||"",U=G.data?.line_number||0,j=G.data?.lines?.text||"";X.add(_),$.push({filePath:_,lineNumber:U,column:1,line:j.trim(),matchText:Z.pattern,beforeContext:[],afterContext:[]})}else if(G.type==="begin")V++}catch{}}}catch(J){}return{matches:$,totalCount:$.length,filesSearched:V,filesWithMatches:Array.from(X),truncated:z}}function fQ(){return{searchFiles:(Q,Z,$)=>{return{matches:[],total_count:0,files_searched:0}},grepSearch:m9,grepQuick:async(Q,Z,$,X)=>{return m9(Z,{pattern:Q,case_insensitive:$,head_limit:X||100})},grepFiles:async(Q,Z,$,X)=>{return(await m9(Z,{pattern:Q,glob:$,case_insensitive:X,output_mode:"files_with_matches"})).files_with_matches},grepCount:async(Q,Z,$,X)=>{return(await m9(Z,{pattern:Q,glob:$,case_insensitive:X,output_mode:"count"})).total_count},grepFile:async(Q,Z,$,X)=>{return(await m9(Q,{pattern:Z,case_insensitive:$,head_limit:X||1000})).matches},extractToolPairs:(Q)=>{return d0(Q)},getSuccessfulToolPairIndices:(Q)=>{return d0(Q).pairs.map(($,X)=>({pair:$,index:X})).filter(({pair:$})=>$.toolResult&&!$.toolResult.isError).map(({index:$})=>$)},getRecentToolPairIndices:(Q,Z)=>{return d0(Q).pairs.map((V,z)=>({pair:V,index:z})).sort((V,z)=>z.pair.useMessageIndex-V.pair.useMessageIndex).slice(0,Z).map(({index:V})=>V)},calculateToolStats:(Q)=>{return v6(Q)},countTokens:(Q)=>{return Math.ceil(Q.length/4)},estimateTokens:d,estimateTextBlockTokens:(Q)=>d(Q),estimateImageBlockTokens:()=>bQ,estimateToolUseBlockTokens:(Q,Z)=>{return d(Q)+d(Z)+l9},estimateToolResultBlockTokens:(Q)=>{return d(Q)+l9},estimateThinkingBlockTokens:(Q)=>d(Q),estimateRedactedThinkingBlockTokens:(Q)=>d(Q),estimateBlocksFromJson:(Q)=>{try{return JSON.parse(Q).reduce(($,X)=>$+m0(X),0)}catch{return 0}},estimateMessageTokensJson:(Q,Z)=>{try{return 4+JSON.parse(Z).reduce((z,J)=>z+m0(J),0)}catch{return 4}},calculateDiff:(Q,Z)=>{let $=Q.split(`
5
+ `),X=Z.split(`
6
+ `),V=[];if(Q!==Z)V.push({old_start:1,old_lines:$.length,new_start:1,new_lines:X.length,content:`- ${$.join(`
7
+ - `)}
8
+ + ${X.join(`
9
+ + `)}`});return V},compactContent:(Q,Z,$="truncate")=>{let V=Z*4;if(Q.length<=V)return Q;switch($){case"truncate":return Q.slice(0,V/2)+`
10
+
11
+ ... [truncated] ...
12
+
13
+ `+Q.slice(-V/2);case"summarize":let z=Math.floor(V/4);return`=== BEGINNING ===
14
+ `+Q.slice(0,z)+`
15
+
16
+ === END ===
17
+ `+Q.slice(-z);case"extract":return Q.split(`
18
+ `).filter((K)=>K.trim().startsWith("#")||K.trim().startsWith("function")||K.trim().startsWith("const")||K.trim().startsWith("class")||K.trim().startsWith("export")||K.trim().startsWith("import")).slice(0,V/50).join(`
19
+ `);default:return Q.slice(0,V)}},hashContentXxhash3:z9,hashContentXxhash64:H0,hashContentSha256:g0,hashContent:(Q,Z="xxhash3")=>{let $=performance.now(),X;switch(Z){case"xxhash64":X=H0(Q);break;case"sha256":X=g0(Q);break;default:X=z9(Q)}return{hash:X,algorithm:Z,input_size:Q.length,elapsed_us:Math.round((performance.now()-$)*1000)}},hashCombined:(Q,Z="xxhash3")=>{let $=Q.join("\x00");switch(Z){case"xxhash64":return H0($);case"sha256":return g0($);default:return z9($)}},contentChanged:(Q,Z)=>z9(Q)!==Z,contentEquals:(Q,Z)=>Q.length===Z.length&&z9(Q)===z9(Z),generateCacheKey:(Q)=>z9(Q.join("\x00"))}}function uQ(Q){return JSON.stringify(Q.map((Z)=>{switch(Z.type){case"text":return{type:"text",text:Z.text};case"image":return{type:"image"};case"tool_use":return{type:"tool_use",name:Z.name,input:Z.input};case"tool_result":return{type:"tool_result",content:Z.content};case"thinking":return{type:"thinking",thinking:Z.thinking};case"redacted_thinking":return{type:"redacted_thinking",data:Z.data};default:return{type:"text",text:""}}}))}function hQ(Q){return I().estimateBlocksFromJson(uQ(Q))}function gQ(Q,Z){return I().estimateMessageTokensJson(Q,uQ(Z))}function S9(Q){return I().hashContentXxhash3(Q)}function C7(Q){return I().hashContentSha256(Q)}function c0(Q,Z){return I().contentChanged(Q,Z)}function R7(Q,Z){return I().contentEquals(Q,Z)}function dQ(Q){return I().generateCacheKey(Q)}async function P7(Q,Z){return I().grepSearch(Q,Z)}async function D7(Q,Z,$=!1,X=100){return I().grepQuick(Q,Z,$,X)}async function N7(Q,Z,$,X=!1){return I().grepFiles(Q,Z,$,X)}async function S7(Q,Z,$,X=!1){return I().grepCount(Q,Z,$,X)}async function I7(Q,Z,$=!1,X=1000){return I().grepFile(Q,Z,$,X)}function mQ(Q){return I().extractToolPairs(Q)}function x7(Q){return I().getSuccessfulToolPairIndices(Q)}function E7(Q,Z){return I().getRecentToolPairIndices(Q,Z)}function T7(Q){return I().calculateToolStats(Q)}var M9=I();class _0{cache=new Map;hits=0;misses=0;name;constructor(Q="cache"){this.name=Q}get(Q){let Z=this.cache.get(Q);if(!Z)return this.misses++,null;if(Z.ttl&&Date.now()>Z.timestamp+Z.ttl)return this.cache.delete(Q),this.misses++,null;return this.hits++,Z.value}set(Q,Z,$){this.cache.set(Q,{value:Z,hash:Q,timestamp:Date.now(),ttl:$})}async getOrCompute(Q,Z,$){let X=S9(Q),V=this.get(X);if(V!==null)return V;let z=await Z();return this.set(X,z,$),z}hasChanged(Q,Z){return c0(Q,Z)}invalidateOlderThan(Q){let Z=Date.now()-Q,$=0;for(let[X,V]of this.cache.entries())if(V.timestamp<Z)this.cache.delete(X),$++;return $}clear(){this.cache.clear(),this.hits=0,this.misses=0}getStats(){let Q=this.hits+this.misses;return{entries:this.cache.size,hits:this.hits,misses:this.misses,hitRate:Q>0?this.hits/Q:0}}getName(){return this.name}}var cQ=new _0("compaction"),b7=new _0("tokens"),u7=new _0("file-hashes");function h7(Q){let Z=JSON.stringify(Q);return S9(Z)}function g7(Q){return S9(Q)}function d7(Q,Z){return!c0(Q,Z)}function lQ(...Q){return dQ(Q)}function m7(Q){let Z=new Map;for(let $ of Q)Z.set($,S9($));return Z}function pQ(Q,Z){let $=lQ(Q,String(Z));return cQ.get($)}function iQ(Q,Z,$){let X=lQ(Q,String(Z));cQ.set(X,JSON.stringify($),300000)}function nQ(Q){let Z=Q.map(($)=>({r:$.role,c:Array.isArray($.content)?$.content.map((X)=>{if(X.type==="text"&&X.text)return{t:X.type,txt:X.text.slice(0,200)};if(X.type==="tool_use")return{t:X.type,n:X.name};return{t:X.type||"unknown"}}):typeof $.content}));return S9(JSON.stringify(Z))}var p0={tokenWarningThreshold:0.8,costUpdateInterval:5,toolSummaryInterval:3,envInfoOnStart:!0},l0={WARNING:0.8,CRITICAL:0.9,EMERGENCY:0.95};function M6(Q){let{current:Z,max:$,threshold:X=l0.WARNING}=Q;if($<=0)return"";let V=Z/$;if(V<X)return"";let z=$-Z,J=Math.round(V*100),Y,K;if(V>=l0.EMERGENCY)Y="emergency",K="\uD83D\uDEA8";else if(V>=l0.CRITICAL)Y="critical",K="\u26A0\uFE0F";else Y="warning",K="\u26A1";let q=[`${K} Token Usage ${Y.toUpperCase()}`,"",`Current: ${Z.toLocaleString()} / ${$.toLocaleString()} tokens (${J}%)`,`Remaining: ${z.toLocaleString()} tokens`];if(Y==="emergency")q.push(""),q.push("Consider summarizing or compacting the conversation to continue.");else if(Y==="critical")q.push(""),q.push("Approaching token limit. Consider wrapping up soon.");return q.join(`
20
+ `)}function C6(Q){let{cost:Z,previousCost:$=0,currency:X="USD"}=Q,V=R6(X),z=oQ(Z,V),J=Z-$,Y=oQ(Math.abs(J),V),K=["\uD83D\uDCB0 Cost Update","",`Total: ${z} ${X}`];if(J!==0){let q=J>0?"+":"-";K.push(`This turn: ${q}${Y} ${X}`)}return K.join(`
21
+ `)}function oQ(Q,Z){if(Q<0.01)return`${Z}${Q.toFixed(4)}`;else if(Q<1)return`${Z}${Q.toFixed(3)}`;return`${Z}${Q.toFixed(2)}`}function R6(Q){return{USD:"$",EUR:"\u20AC",GBP:"\xA3",JPY:"\xA5"}[Q]||Q}function P6(Q){let{tools:Z,maxDisplay:$=10}=Q;if(Z.length===0)return"No tools used this session.";let X=new Map;for(let Y of Z){let K=X.get(Y.name)||0;X.set(Y.name,K+1)}let V=[...X.entries()].sort((Y,K)=>K[1]-Y[1]),z=[`\uD83D\uDD27 Tool Usage Summary (${Z.length} total calls)`,""],J=V.slice(0,$);for(let[Y,K]of J)z.push(` \u2022 ${Y}: ${K} call${K===1?"":"s"}`);if(V.length>$){let Y=V.length-$;z.push(` ... and ${Y} more tool${Y===1?"":"s"}`)}return z.join(`
22
+ `)}function D6(Q){let{workingDirectory:Z,gitStatus:$,platform:X=process.platform,shell:V=process.env.SHELL||"unknown"}=Q,z=["\uD83D\uDCCD Environment Information","",`Working Directory: ${Z}`,`Platform: ${X}`,`Shell: ${V}`];if($){if(z.push(""),z.push("Git Status:"),z.push(` Branch: ${$.branch}`),$.ahead>0||$.behind>0)z.push(` Ahead: ${$.ahead}, Behind: ${$.behind}`);let J=$.staged.length+$.unstaged.length+$.untracked.length+$.conflicted.length;if(J>0){if(z.push(` Changes: ${J} file${J===1?"":"s"}`),$.staged.length>0)z.push(` Staged: ${$.staged.length}`);if($.unstaged.length>0)z.push(` Unstaged: ${$.unstaged.length}`);if($.untracked.length>0)z.push(` Untracked: ${$.untracked.length}`);if($.conflicted.length>0)z.push(` Conflicted: ${$.conflicted.length}`)}else z.push(" Working tree clean")}return z.join(`
23
+ `)}function rQ(Q){let{usage:Z,maxTokens:$,totalCost:X,previousCost:V,toolsUsed:z,workingDirectory:J,gitStatus:Y,turnNumber:K,config:q}=Q,W={...p0,...q},H=[],G=Z.input_tokens+Z.output_tokens,_=M6({current:G,max:$,threshold:W.tokenWarningThreshold});if(_)H.push(_);if(K%W.costUpdateInterval===0){let U=C6({cost:X,previousCost:V});H.push(U)}if(K%W.toolSummaryInterval===0&&z.length>0){let U=P6({tools:z});H.push(U)}if(K===1&&W.envInfoOnStart){let U=D6({workingDirectory:J,gitStatus:Y});H.push(U)}if(H.length===0)return"";return["---","System Reminders:","",...H,"---"].join(`
24
+ `)}var N6=4,S6=5,I6=1,x6=8,E6=0.9,aQ=8000,j0=10,T6=100;function I9(Q){if(!Q||Q.length===0)return 0;return Math.ceil(Q.length/N6)}function sQ(Q){if(G0())try{switch(Q.type){case"text":return M9.estimateTextBlockTokens(Q.text);case"image":return M9.estimateImageBlockTokens();case"tool_use":return M9.estimateToolUseBlockTokens(Q.name,JSON.stringify(Q.input));case"tool_result":if(typeof Q.content==="string")return M9.estimateToolResultBlockTokens(Q.content);return hQ(Q.content)+j0;case"thinking":return M9.estimateThinkingBlockTokens(Q.thinking);case"redacted_thinking":return M9.estimateRedactedThinkingBlockTokens(Q.data);default:return 0}}catch{}switch(Q.type){case"text":return I9(Q.text);case"image":return T6;case"tool_use":let Z=JSON.stringify(Q.input);return I9(Q.name)+I9(Z)+j0;case"tool_result":if(typeof Q.content==="string")return I9(Q.content)+j0;return Q.content.reduce(($,X)=>$+sQ(X),0)+j0;case"thinking":return I9(Q.thinking);case"redacted_thinking":return I9(Q.data);default:return 0}}function y6(Q){if(G0())try{return gQ(Q.role,Q.content)}catch{}let Z=4,$=Q.content.reduce((X,V)=>X+sQ(V),0);return Z+$}function p9(Q){if(!Q||Q.length===0)return 0;return Q.reduce((Z,$)=>Z+y6($),0)}function k6(Q){let Z=[];for(let $ of Q.content)switch($.type){case"text":Z.push($.text);break;case"tool_use":Z.push(`[Tool: ${$.name}(${JSON.stringify($.input)})]`);break;case"tool_result":let X=typeof $.content==="string"?$.content:$.content.map((V)=>V.type==="text"?V.text:"[content]").join("");Z.push(`[Result: ${X.slice(0,500)}${X.length>500?"...":""}]`);break;case"thinking":Z.push(`[Thinking: ${$.thinking.slice(0,200)}...]`);break}return Z.join(`
25
+ `)}function f6(Q){let Z=new Map;if(G0())try{let $=JSON.stringify(Q),X=mQ($);for(let V of X.pairs){let z={};try{z=JSON.parse(V.toolUse.input)}catch{}let J={type:"tool_use",id:V.toolUse.id,name:V.toolUse.name,input:z},Y;if(V.toolResult){let K=V.toolResult.content;try{let q=JSON.parse(V.toolResult.content);if(Array.isArray(q))K=q}catch{}Y={type:"tool_result",tool_use_id:V.toolResult.toolUseId,content:K,is_error:V.toolResult.isError}}Z.set(V.toolUse.id,{use:J,result:Y})}return Z}catch{}for(let $ of Q)for(let X of $.content)if(X.type==="tool_use")Z.set(X.id,{use:X});for(let $ of Q)for(let X of $.content)if(X.type==="tool_result"){let V=Z.get(X.tool_use_id);if(V)V.result=X}return Z}async function b6(Q){if(!Q||Q.length===0)return"";let Z=[];Z.push(`[Context Summary: ${Q.length} messages compacted]
26
+ `);let $=[];for(let V=0;V<Q.length;V++){let z=Q[V];if(!z)continue;let J=z.role.toUpperCase(),Y=k6(z);for(let q of z.content)if(q.type==="tool_use")$.push(`${q.name}`);let K=Y.length>300?`${Y.slice(0,300)}...`:Y;Z.push(`${J}: ${K}
27
+ `)}if($.length>0){let V=$.reduce((J,Y)=>{return J[Y]=(J[Y]||0)+1,J},{}),z=Object.entries(V).map(([J,Y])=>`${J}(${Y})`).join(", ");Z.push(`
28
+ Tools used: ${z}
29
+ `)}let X=Z.join("");if(X.length>aQ)X=X.slice(0,aQ)+`
30
+ ...[truncated]`;return X}async function i0(Q,Z,$={}){let{keepFirst:X=I6,keepLast:V=S6,preserveToolPairs:z=!0}=$,J=p9(Q);if(J<=Z)return{messages:Q,messagesRemoved:0,tokensBefore:J,tokensAfter:J,didCompact:!1};if(Q.length<=X+V)return{messages:Q,messagesRemoved:0,tokensBefore:J,tokensAfter:J,didCompact:!1};let Y=nQ(Q),K=pQ(Y,Z);if(K){let O=Q.slice(0,X),v=Q.slice(-V),L={role:"user",content:[{type:"text",text:`[Previous context has been compacted for continuity]
31
+
32
+ ${K.summary}`}]},S=[...O,L,...v],y=p9(S);return{messages:S,messagesRemoved:Q.length-S.length,tokensBefore:J,tokensAfter:y,didCompact:!0}}let q=Q.slice(0,X),W=Q.slice(X,-V),H=Q.slice(-V),G=await b6(W),_=J-p9([...q,{role:"user",content:[{type:"text",text:G}]},...H]);iQ(Y,Z,{summary:G,tokensSaved:_});let U={role:"user",content:[{type:"text",text:`[Previous context has been compacted for continuity]
33
+
34
+ ${G}`}]},j=[];if(z&&W.length>0){let O=f6(W),v=Array.from(O.values()).slice(-3).filter((L)=>L.result&&!L.result.is_error);for(let L of v)if(j.push(L.use),L.result)j.push(L.result)}let A=[...q,U];if(j.length>0)A.push({role:"assistant",content:j.filter((O)=>O.type==="tool_use")}),A.push({role:"user",content:j.filter((O)=>O.type==="tool_result")});A.push(...H);let w=p9(A),B=Q.length-A.length;return console.log(`Context compaction: ${Q.length} -> ${A.length} messages, ${J} -> ${w} tokens`),{messages:A,messagesRemoved:B,tokensBefore:J,tokensAfter:w,didCompact:!0}}function tQ(Q,Z,$=E6){if(Q.length<x6)return!1;let X=p9(Q),V=Math.floor(Z*$);return X>=V}function n0(Q){if(!Q.didCompact)return{reductionPercent:0,tokensSaved:0};let Z=Q.tokensBefore-Q.tokensAfter,$=Z/Q.tokensBefore*100;return{reductionPercent:Math.round($*100)/100,tokensSaved:Z}}async function V$(Q,Z){let{apiKey:$,model:X="claude-sonnet-4-6",maxTokens:V=4096,systemPrompt:z,tools:J,permissionMode:Y,workingDirectory:K,gitStatus:q=null,reminderConfig:W,cacheConfig:H=W0,thinking:G,extendedThinking:_,stopSequences:U,getStopSequences:j,onText:A,onThinking:w,onToolUse:B,onToolResult:O,onMetrics:v,onReminder:L,onPermissionRequest:S,signal:y}=Z,e=new u0(Y,S),P=[...Q],o=[],f9=[],Q9=0,b9=0,u9=0,q9=0,W9=0,H9=0,k={cacheHits:0,cacheMisses:0,totalCacheReadTokens:0,totalCacheWriteTokens:0,cacheHitRate:0,estimatedSavingsUSD:0},A9={...p0,...W},Z9=!0;while(Z9){if(y?.aborted)break;u9++;let c=o[o.length-1],O9=rQ({usage:c?.usage??{input_tokens:0,output_tokens:0},maxTokens:V,totalCost:Q9,previousCost:q9,toolsUsed:f9,workingDirectory:K,gitStatus:q,turnNumber:u9,config:A9});if(O9)L?.(O9);if(tQ(P,V)){let F=await i0(P,V,{keepFirst:0,keepLast:3,preserveToolPairs:!0});if(F.didCompact&&F.tokensAfter<F.tokensBefore){P.length=0,P.push(...F.messages),W9++;let M=F.tokensBefore-F.tokensAfter;H9+=M;let C=n0(F);console.log(`Context compacted: ${C.reductionPercent}% reduction, ${C.tokensSaved} tokens saved`)}}let h9=u6(P,z,O9),DQ=j?j(u9,{lastStopReason:o[o.length-1]?.stopReason}):U,k0=await TQ(h9,{apiKey:$,model:X,maxTokens:V,systemPrompt:z,cacheConfig:H,thinking:G,extendedThinking:_,stopSequences:DQ,tools:J.map((F)=>({name:F.name,description:F.description,input_schema:F.input_schema})),onToken:A,onThinking:w,onToolUse:B,signal:y}),{message:G9,usage:D9,cacheMetrics:$9,costUSD:R,durationMs:r,ttftMs:v9}=k0,g9={model:X,messageCount:P.length,messageTokens:D9.input_tokens+D9.output_tokens,usage:D9,cacheMetrics:$9,durationMs:r,ttftMs:v9,costUSD:R,stopReason:G9.stop_reason,requestId:G9.id};if(o.push(g9),q9=Q9,Q9+=R,b9+=r,$9)k.cacheHits+=$9.cacheHits,k.cacheMisses+=$9.cacheMisses,k.totalCacheReadTokens+=$9.totalCacheReadTokens,k.totalCacheWriteTokens+=$9.totalCacheWriteTokens,k.estimatedSavingsUSD+=$9.estimatedSavingsUSD;let d9=k.cacheHits+k.cacheMisses;if(k.cacheHitRate=d9>0?k.cacheHits/d9:0,v?.(g9),P.push({role:"assistant",content:G9.content}),G9.stop_reason==="end_turn"||G9.stop_reason==="stop_sequence"){Z9=!1;break}if(G9.stop_reason==="max_tokens"){let F=await i0(P,V,{keepFirst:0,keepLast:3,preserveToolPairs:!0});if(F.didCompact&&F.tokensAfter<F.tokensBefore){P.length=0,P.push(...F.messages),W9++;let M=F.tokensBefore-F.tokensAfter;H9+=M;let C=n0(F);console.log(`Context compacted: ${C.reductionPercent}% reduction, ${C.tokensSaved} tokens saved`);continue}else{Z9=!1;break}}let N9=G9.content.filter((F)=>F.type==="tool_use");if(f9.push(...N9),N9.length===0){Z9=!1;break}let X9=[];if(y?.aborted);else{let F=N9.map(async(C)=>{let f0=J.find((_9)=>_9.name===C.name);if(!f0)return{toolUseId:C.id,result:{type:"tool_result",tool_use_id:C.id,content:`Error: Unknown tool "${C.name}"`,is_error:!0},toolResult:null};let q0=await e.checkPermission(f0.name,C.input);if(q0.decision==="deny"||q0.decision==="denyAlways")return{toolUseId:C.id,result:{type:"tool_result",tool_use_id:C.id,content:`Permission denied for tool "${C.name}"${q0.reason?`: ${q0.reason}`:""}`,is_error:!0},toolResult:null};try{let _9=await f0.handler(C.input,{workingDirectory:K,permissionMode:Y,abortSignal:y});return{toolUseId:C.id,result:{type:"tool_result",tool_use_id:C.id,content:_9.content,is_error:_9.is_error},toolResult:{id:C.id,result:_9}}}catch(_9){let e8=_9 instanceof Error?_9.message:String(_9);return{toolUseId:C.id,result:{type:"tool_result",tool_use_id:C.id,content:`Error: ${e8}`,is_error:!0},toolResult:null}}}),M=await Promise.all(F);for(let C of M)if(X9.push(C.result),C.toolResult)O?.(C.toolResult)}P.push({role:"user",content:X9})}return{messages:P,metrics:o,totalCost:Q9,totalDuration:b9,totalCacheMetrics:k,compactionCount:W9,totalTokensCompacted:H9}}function u6(Q,Z,$){if($&&Q.length>0){let X=[...Q];for(let V=X.length-1;V>=0;V--){let z=X[V];if(z&&z.role==="user"){let J={role:"user",content:Array.isArray(z.content)?h6(z.content,$):[{type:"text",text:`${String(z.content)}
35
+
36
+ ${$}`}]};X[V]=J;break}}return X}return Q}function h6(Q,Z){if(Q.length>0){let X=Q[Q.length-1];if(X&&X.type==="text"){let V={type:"text",text:`${X.text}
37
+
38
+ ${Z}`};return[...Q.slice(0,-1),V]}}let $={type:"text",text:`
39
+
40
+ ${Z}`};return[...Q,$]}function o0(Q){if(Q<0.01)return`$${Q.toFixed(4)}`;return`$${Q.toFixed(2)}`}function z$(Q){let Z=o0(Q.costUSD),$=`${Q.usage.input_tokens.toLocaleString()} input, ${Q.usage.output_tokens.toLocaleString()} output`;if(Q.usage.cache_read_input_tokens||Q.usage.cache_creation_input_tokens){let X=Q.usage.cache_read_input_tokens?.toLocaleString()??"0",V=Q.usage.cache_creation_input_tokens?.toLocaleString()??"0";return`Cost: ${Z} | Tokens: ${$} | Cache: ${X} read, ${V} write`}return`Cost: ${Z} | Tokens: ${$}`}function J$(Q){let Z=o0(Q.costUSD),$=Q.usage.input_tokens+Q.usage.output_tokens;return`Cost: ${Z} | Tokens: ${$.toLocaleString()}`}function Y$(Q){let Z=o0(Q.estimatedSavingsUSD);return`Cache: ${(Q.cacheHitRate*100).toFixed(1)}% hit rate | ${Q.totalCacheReadTokens.toLocaleString()} read | ${Q.totalCacheWriteTokens.toLocaleString()} written | Saved: ${Z}`}import{homedir as g6}from"os";import{join as j9}from"path";class d6{sessionsDir;currentSessionId=null;currentSessionFile=null;writeQueue=Promise.resolve();constructor(Q){this.sessionsDir=Q??j9(g6(),".claude","sessions")}async init(){try{await Bun.write(j9(this.sessionsDir,".gitkeep"),"")}catch{}}generateSessionId(){let Q=Date.now().toString(36),Z=Math.random().toString(36).slice(2,8);return`${Q}-${Z}`}async createSession(Q){await this.init();let Z=this.generateSessionId();this.currentSessionId=Z,this.currentSessionFile=j9(this.sessionsDir,`${Z}.jsonl`);let $={id:Z,created:Date.now(),updated:Date.now(),model:Q.model,workingDirectory:Q.workingDirectory,agentName:Q.agentName,agentColor:Q.agentColor,teamName:Q.teamName};await this.appendEntry($);let X={type:"context",timestamp:Date.now(),workingDirectory:Q.workingDirectory};return await this.appendEntry(X),Z}async resumeSession(Q){let Z=j9(this.sessionsDir,`${Q}.jsonl`);try{let $=await Bun.file(Z).text();if(!$)return null;let X=$.trim().split(`
41
+ `),V=[];for(let z of X)try{V.push(JSON.parse(z))}catch{}return this.parseSessionEntries(V)}catch{return null}}parseSessionEntries(Q){let Z=null,$=[],X=[],V=[],z=null;for(let J of Q){if(!("type"in J)&&"id"in J&&"created"in J){Z=J;continue}if("type"in J){let Y=J;switch(Y.type){case"message":$.push(Y.data);break;case"tool_use":X.push(Y);break;case"metrics":V.push(Y.data);break;case"context":z=Y;break}}}if(!Z)Z={id:"unknown",created:Date.now(),updated:Date.now(),model:"claude-sonnet-4-6",workingDirectory:process.cwd()};return{metadata:Z,messages:$,tools:X,metrics:V,context:z}}async appendEntry(Q){if(!this.currentSessionFile)return;this.writeQueue=this.writeQueue.then(async()=>{let Z=JSON.stringify(Q)+`
42
+ `,$=Bun.file(this.currentSessionFile),X=await $.exists()?await $.text():"";await Bun.write(this.currentSessionFile,X+Z)}),await this.writeQueue}async saveMessage(Q){let Z={type:"message",timestamp:Date.now(),data:Q};await this.appendEntry(Z),await this.updateTimestamp()}async saveToolUse(Q,Z,$,X,V){let z={type:"tool_use",timestamp:Date.now(),toolId:Q,toolName:Z,input:$,result:X,isError:V};await this.appendEntry(z)}async saveMetrics(Q){let Z={type:"metrics",timestamp:Date.now(),data:Q};await this.appendEntry(Z)}async updateTimestamp(){if(!this.currentSessionFile||!this.currentSessionId)return}async listSessions(Q=20){await this.init();let Z=Bun.file(this.sessionsDir),$=[];try{let V=[...new Bun.Glob("*.jsonl").scanSync(this.sessionsDir)],z=await Promise.all(V.map(async(J)=>{let Y=j9(this.sessionsDir,J),K=await Bun.file(Y).stat();return{file:J,fullPath:Y,mtime:K?.mtime??new Date(0)}}));z.sort((J,Y)=>Y.mtime.getTime()-J.mtime.getTime());for(let{file:J,fullPath:Y}of z.slice(0,Q)){let K=J.replace(".jsonl",""),q=await this.getSessionSummary(K,Y);if(q)$.push(q)}}catch{}return $}async getSessionSummary(Q,Z){let $=Z??j9(this.sessionsDir,`${Q}.jsonl`);try{let X=await Bun.file($).text();if(!X)return null;let V=X.trim().split(`
43
+ `),z=null,J=0,Y=0,K=0,q=0,W;for(let H of V)try{let G=JSON.parse(H);if(G.id&&G.created)z=G;else if(G.type==="message"){J++;let _=G.data;if(!W&&_.role==="user"){let U=_.content.find((j)=>j.type==="text");if(U&&"text"in U){if(W=U.text.slice(0,100),U.text.length>100)W+="..."}}}else if(G.type==="metrics")Y+=G.data.costUSD,K+=G.data.usage.input_tokens,q+=G.data.usage.output_tokens}catch{}if(!z)return null;return{id:Q,created:z.created,updated:z.updated,model:z.model,messageCount:J,totalCost:Y,totalTokens:{input:K,output:q},firstMessage:W,workingDirectory:z.workingDirectory}}catch{return null}}getCurrentSessionId(){return this.currentSessionId}async exportSession(Q,Z,$){let X=await this.resumeSession(Q);if(!X)throw Error(`Session not found: ${Q}`);let V,z;switch(Z){case"jsonl":{let Y=j9(this.sessionsDir,`${Q}.jsonl`);V=await Bun.file(Y).text(),z="jsonl";break}case"json":{V=JSON.stringify(X,null,2),z="json";break}case"markdown":{V=this.sessionToMarkdown(X),z="md";break}default:throw Error(`Unsupported format: ${Z}`)}let J=$??j9(process.cwd(),`session-${Q}.${z}`);return await Bun.write(J,V),J}sessionToMarkdown(Q){let Z=[];Z.push(`# Session: ${Q.metadata.id}`),Z.push(""),Z.push(`**Created:** ${new Date(Q.metadata.created).toISOString()}`),Z.push(`**Model:** ${Q.metadata.model}`),Z.push(`**Working Directory:** ${Q.metadata.workingDirectory}`),Z.push(""),Z.push("## Conversation"),Z.push("");for(let $ of Q.messages){let X=$.role==="user"?"**User**":"**Claude**";Z.push(`### ${X}`),Z.push("");for(let V of $.content)if(V.type==="text")Z.push(V.text),Z.push("");else if(V.type==="tool_use"){let z=V;Z.push(`\`\`\`tool:${z.name}`),Z.push(JSON.stringify(z.input,null,2)),Z.push("```"),Z.push("")}else if(V.type==="tool_result"){let z=V;Z.push(`**Result**${z.is_error?" (error)":""}:`),Z.push("```"),Z.push(typeof z.content==="string"?z.content:JSON.stringify(z.content,null,2)),Z.push("```"),Z.push("")}}if(Q.metrics.length>0){Z.push("## Metrics"),Z.push("");let $=Q.metrics.reduce((z,J)=>z+J.costUSD,0),X=Q.metrics.reduce((z,J)=>z+J.usage.input_tokens,0),V=Q.metrics.reduce((z,J)=>z+J.usage.output_tokens,0);Z.push(`- **Total Cost:** $${$.toFixed(4)}`),Z.push(`- **Total Input Tokens:** ${X.toLocaleString()}`),Z.push(`- **Total Output Tokens:** ${V.toLocaleString()}`),Z.push(`- **API Calls:** ${Q.metrics.length}`)}return Z.join(`
44
+ `)}async deleteSession(Q){let Z=j9(this.sessionsDir,`${Q}.jsonl`);try{if(await Bun.file(Z).exists()){let{unlink:X}=await import("fs/promises");return await X(Z),!0}return!1}catch{return!1}}}function m6(Q){let Z=new Date(Q.created),$=new Date(Q.updated),X=c6($),V=[];V.push(`\x1B[1m${Q.id}\x1B[0m (${X})`),V.push(` Model: ${Q.model} | Messages: ${Q.messageCount}`);let z=Q.totalCost<0.01?`$${Q.totalCost.toFixed(4)}`:`$${Q.totalCost.toFixed(2)}`;if(V.push(` Cost: ${z} | Tokens: ${Q.totalTokens.input.toLocaleString()} in, ${Q.totalTokens.output.toLocaleString()} out`),Q.firstMessage)V.push(` Preview: ${Q.firstMessage}`);return V.push(` Directory: ${Q.workingDirectory}`),V.join(`
45
+ `)}function c6(Q){let $=new Date().getTime()-Q.getTime(),X=Math.floor($/60000),V=Math.floor($/3600000),z=Math.floor($/86400000);if(X<1)return"just now";if(X<60)return`${X}m ago`;if(V<24)return`${V}h ago`;if(z<7)return`${z}d ago`;return Q.toLocaleDateString()}function H$(Q){if(Q.length===0){console.log("No sessions found."),console.log(`
46
+ Start a new conversation to create a session.`);return}console.log(`\x1B[1mRecent Sessions (${Q.length})\x1B[0m
47
+ `);for(let Z of Q)console.log(m6(Z)),console.log("");console.log("To resume a session:"),console.log(" coder --resume <session-id>")}import{spawn as r0}from"child_process";import{mkdirSync as eQ,rmSync as l6,existsSync as Q8,readFileSync as p6}from"fs";import{join as i9}from"path";class Z8{teams=new Map;teammates=new Map;messageQueue=new Map;storagePath;constructor(Q="~/.claude/teams"){if(this.storagePath=Q.replace("~",process.env.HOME||""),!Q8(this.storagePath))eQ(this.storagePath,{recursive:!0});this.loadTeams()}createTeam(Q){let Z={...Q,status:"active"};this.teams.set(Q.name,Z);for(let $ of Q.teammates)this.teammates.set($.teammateId,$);return this.persistTeam(Z).catch(($)=>{console.error(`Failed to persist team ${Q.name}:`,$)}),Z}getTeam(Q){return this.teams.get(Q)}listTeams(){return Array.from(this.teams.values())}deleteTeam(Q){let Z=this.teams.get(Q);if(Z){for(let X of Z.teammates)this.teammates.delete(X.teammateId),this.messageQueue.delete(X.teammateId);this.teams.delete(Q);let $=i9(this.storagePath,Q);try{l6($,{recursive:!0,force:!0})}catch(X){console.error(`Failed to delete team directory ${$}:`,X)}}}getTeammate(Q){return this.teammates.get(Q)}updateTeammateStatus(Q,Z){let $=this.teammates.get(Q);if($)$.status=Z}async spawnTeammate(Q,Z={}){let{session:$,workingDir:X=process.cwd()}=Z;if(!process.env.TMUX)await this.spawnInTerminal(Q,{session:$,workingDir:X});else await this.spawnInTmux(Q,{session:$,workingDir:X});this.updateTeammateStatus(Q.teammateId,"in_progress")}async spawnInTerminal(Q,Z){let $=["bun","run","src/cli.ts","--teammate-mode","--agent-id",Q.teammateId,"--agent-name",Q.name,"--team-name",Q.teamName,"--agent-color",Q.color];if(Q.planModeRequired)$.push("--permission-mode","plan");if(process.platform==="darwin"){let X=`
48
+ tell application "Terminal"
49
+ do script "cd ${Z.workingDir} && ${$.join(" ")}"
50
+ activate
51
+ end tell
52
+ `;r0("osascript",["-e",X])}else r0("xterm",["-e",$.join(" ")])}async spawnInTmux(Q,Z){let $=Z.session||process.env.TMUX?.split(",")[0]?.split(":")[0]||"claude";await this.tmuxCommand(["split-window","-t",$,"-c",Z.workingDir]);let X=await this.tmuxCommand(["display-message","-p","#{pane_id}"]);if(X)Q.paneId=X.trim();let V=["bun","run","src/cli.ts","--teammate-mode","--agent-id",Q.teammateId,"--agent-name",Q.name,"--team-name",Q.teamName];await this.tmuxCommand(["send-keys","-t",Q.paneId||"",V.join(" "),"Enter"])}async tmuxCommand(Q){return new Promise((Z)=>{let $=r0("tmux",Q),X="";$.stdout?.on("data",(V)=>{X+=V.toString()}),$.on("close",()=>{Z(X)})})}broadcast(Q,Z,$){let X=this.teams.get(Q);if(!X)return;let V={type:"broadcast",from:$||"system",content:Z,timestamp:Date.now()};for(let z of X.teammates){if($&&z.teammateId===$)continue;let J=this.messageQueue.get(z.teammateId)||[];J.push(V),this.messageQueue.set(z.teammateId,J)}}sendDirect(Q,Z,$){let X={type:"direct",from:Z,to:Q,content:$,timestamp:Date.now()},V=this.messageQueue.get(Q)||[];V.push(X),this.messageQueue.set(Q,V)}getMessages(Q){let Z=this.messageQueue.get(Q)||[];return this.messageQueue.delete(Q),Z}hasMessages(Q){let Z=this.messageQueue.get(Q);return Z!==void 0&&Z.length>0}peekMessages(Q){return this.messageQueue.get(Q)||[]}clearMessages(Q){this.messageQueue.delete(Q)}getMessageCount(Q){return this.messageQueue.get(Q)?.length||0}async persistTeam(Q){let Z=i9(this.storagePath,Q.name),$=i9(Z,"config.json");if(!Q8(Z))eQ(Z,{recursive:!0});await Bun.write(i9(Z,".gitkeep"),"");let X={name:Q.name,description:Q.description,teammates:Q.teammates,taskListId:Q.taskListId,status:Q.status,coordination:Q.coordination,updatedAt:Date.now()};await Bun.write($,JSON.stringify(X,null,2))}loadTeams(){let Q=new Bun.Glob("**/config.json");try{let Z=Array.from(Q.scanSync(this.storagePath));for(let $ of Z)try{let X=i9(this.storagePath,$);if(Bun.file(X).size===0)continue;let J=p6(X,"utf-8"),Y=JSON.parse(J);if(!Y.name||!Y.teammates||!Array.isArray(Y.teammates))continue;let K={name:Y.name,description:Y.description||"",teammates:Y.teammates,taskListId:Y.taskListId||"",status:Y.status||"active",coordination:Y.coordination||{dependencyOrder:[],communicationProtocol:"broadcast",taskAssignmentStrategy:"manual"}};this.teams.set(K.name,K);for(let q of K.teammates)this.teammates.set(q.teammateId,q)}catch(X){}}catch(Z){if(Z.code!=="ENOENT");}}async persistAllTeams(){let Q=Array.from(this.teams.values()).map((Z)=>this.persistTeam(Z));await Promise.all(Q)}}var w$={architect:(Q)=>({name:"architect",teamName:Q,role:"Code Architect",description:"Designs and plans technical architecture, API contracts, and system design",color:"blue",prompt:`You are an architect on the ${Q} team.
53
+ Your role is to design and plan the technical architecture.
54
+ Focus on:
55
+ - System design and component relationships
56
+ - API contracts and interfaces
57
+ - Data models and schemas
58
+ - Trade-offs and design decisions`,planModeRequired:!0,status:"pending"}),implementer:(Q)=>({name:"implementer",teamName:Q,role:"Software Engineer",description:"Implements features and writes clean, working code based on architecture",color:"green",prompt:`You are an implementer on the ${Q} team.
59
+ Your role is to write clean, working code based on the architecture.
60
+ Focus on:
61
+ - Implementing the designed architecture
62
+ - Writing tests
63
+ - Following coding standards
64
+ - Handling edge cases`,planModeRequired:!1,status:"pending"}),reviewer:(Q)=>({name:"reviewer",teamName:Q,role:"Code Reviewer",description:"Reviews code changes for quality, bugs, and best practices",color:"yellow",prompt:`You are a code reviewer on the ${Q} team.
65
+ Your role is to review code changes and provide feedback.
66
+ Focus on:
67
+ - Code quality and readability
68
+ - Potential bugs and issues
69
+ - Performance considerations
70
+ - Test coverage`,planModeRequired:!1,status:"pending"}),tester:(Q)=>({name:"tester",teamName:Q,role:"QA Engineer",description:"Writes tests, finds edge cases, and verifies requirements",color:"orange",prompt:`You are a tester on the ${Q} team.
71
+ Your role is to ensure features work correctly.
72
+ Focus on:
73
+ - Writing comprehensive tests
74
+ - Finding edge cases
75
+ - Verifying requirements
76
+ - Reporting bugs`,planModeRequired:!1,status:"pending"})};function $8(){return`teammate_${Date.now()}_${Math.random().toString(36).slice(2,8)}`}function A$(Q){return{...Q,teammateId:$8(),status:"pending"}}var U0=null;function B9(){if(!U0)U0=new Z8;return U0}function B$(Q){U0=Q}var a0={name:"TeamCreate",description:`Create a new team with multiple teammates for parallel task execution.
77
+
78
+ Teams allow you to spawn multiple AI agents that work together on related tasks.
79
+ Each teammate runs in its own terminal/tmux pane and can communicate with others.
80
+
81
+ Usage:
82
+ - Create a team with a descriptive name and list of teammates
83
+ - Each teammate needs: name, role, description, and optional prompt
84
+ - Teammates can be spawned after creation using TeammateSpawn
85
+
86
+ Returns the team configuration with all teammate IDs for spawning.`,input_schema:{type:"object",properties:{name:{type:"string",description:"Unique team name (e.g., 'feature-auth-team')"},description:{type:"string",description:"Team description and goals"},teammates:{type:"array",description:"List of teammates to create",items:{type:"object",properties:{name:{type:"string",description:"Teammate name (e.g., 'architect', 'implementer')"},role:{type:"string",description:"Role in the team (e.g., 'Code Architect', 'Test Engineer')"},description:{type:"string",description:"Detailed description of responsibilities"},prompt:{type:"string",description:"Custom system prompt for this teammate"},color:{type:"string",description:"Color for UI display (blue, green, yellow, orange, red, purple)"},planModeRequired:{type:"boolean",description:"Whether this teammate requires plan mode"}},required:["name","role","description"]},minItems:1},coordination:{type:"object",description:"Team coordination settings",properties:{dependencyOrder:{type:"array",description:"Order of teammate execution (teammate names)",items:{type:"string"}},communicationProtocol:{type:"string",enum:["broadcast","direct","mixed"],description:"How teammates communicate"},taskAssignmentStrategy:{type:"string",enum:["manual","auto","priority"],description:"How tasks are assigned"}}}},required:["name","description","teammates"]},handler:async(Q,Z)=>{let{name:$,description:X,teammates:V,coordination:z}=Q;try{let J=B9();if(J.getTeam($))return{content:`Error: Team "${$}" already exists. Use a different name or delete the existing team first.`,is_error:!0};let Y=V.map((q,W)=>({teammateId:$8(),name:q.name,teamName:$,role:q.role,description:q.description,prompt:q.prompt||`You are ${q.name}, a ${q.role} on the ${$} team.
87
+
88
+ ${q.description}`,color:q.color||["blue","green","yellow","orange","purple","red"][W%6],planModeRequired:q.planModeRequired??!1,status:"pending"})),K=J.createTeam({name:$,description:X,teammates:Y,taskListId:"",coordination:{dependencyOrder:z?.dependencyOrder||[],communicationProtocol:z?.communicationProtocol||"broadcast",taskAssignmentStrategy:z?.taskAssignmentStrategy||"manual"}});return{content:JSON.stringify({success:!0,team:{name:K.name,description:K.description,status:K.status,coordination:K.coordination},teammates:Y.map((q)=>({teammateId:q.teammateId,name:q.name,role:q.role,color:q.color,status:q.status})),message:`Team "${$}" created with ${Y.length} teammates. Use TeammateSpawn to start them.`},null,2)}}catch(J){return{content:`Error creating team: ${J instanceof Error?J.message:String(J)}`,is_error:!0}}}},s0={name:"TeammateSpawn",description:`Spawn a teammate agent to work on a task.
89
+
90
+ Spawns a new Claude Code instance in a separate terminal/tmux pane.
91
+ The teammate will run autonomously with its own context and can communicate
92
+ with other teammates through the messaging system.
93
+
94
+ Usage:
95
+ - First create a team using TeamCreate
96
+ - Spawn individual teammates using their teammateId
97
+ - Teammates run in their own context with their assigned role/prompt`,input_schema:{type:"object",properties:{teammateId:{type:"string",description:"The teammate ID to spawn (from TeamCreate response)"},teamName:{type:"string",description:"The team name (optional if teammateId is provided)"},task:{type:"string",description:"Initial task/prompt for the teammate"},workingDir:{type:"string",description:"Working directory for the teammate (default: current)"},model:{type:"string",enum:["sonnet","opus","haiku"],description:"Model for the teammate (default: sonnet)"}},required:["teammateId"]},handler:async(Q,Z)=>{let{teammateId:$,task:X}=Q,V=Q.workingDir||Z.workingDirectory,z=Q.model||"sonnet";try{let J=B9(),Y=J.getTeammate($);if(!Y)return{content:`Error: Teammate "${$}" not found. Use TeamList to see available teammates.`,is_error:!0};if(Y.status==="in_progress")return{content:`Teammate "${Y.name}" is already running.`,is_error:!0};if(await J.spawnTeammate(Y,{session:process.env.TMUX?.split(",")[0]?.split(":")[0],workingDir:V}),X)J.sendDirect($,"system",X);return{content:JSON.stringify({success:!0,teammate:{teammateId:Y.teammateId,name:Y.name,teamName:Y.teamName,role:Y.role,status:"in_progress",paneId:Y.paneId},message:`Teammate "${Y.name}" spawned successfully.`,note:"Teammate runs in separate terminal. Use TeammateMessage to communicate."},null,2)}}catch(J){return{content:`Error spawning teammate: ${J instanceof Error?J.message:String(J)}`,is_error:!0}}}},t0={name:"TeammateMessage",description:`Send a message to one or more teammates.
98
+
99
+ Supports two modes:
100
+ - Direct: Send to a specific teammate
101
+ - Broadcast: Send to all teammates in a team
102
+
103
+ Messages are queued and retrieved when teammates check for messages.
104
+ This enables asynchronous coordination between teammates.`,input_schema:{type:"object",properties:{type:{type:"string",enum:["direct","broadcast"],description:"Message type (direct to one, broadcast to all)"},to:{type:"string",description:"Recipient teammateId (for direct messages)"},teamName:{type:"string",description:"Team name (for broadcast messages)"},from:{type:"string",description:"Sender identifier (default: 'system')"},content:{type:"string",description:"Message content"}},required:["type","content"]},handler:async(Q,Z)=>{let{type:$,content:X}=Q,V=Q.from||"system";try{let z=B9();if($==="direct"){let J=Q.to;if(!J)return{content:"Error: 'to' is required for direct messages",is_error:!0};let Y=z.getTeammate(J);if(!Y)return{content:`Error: Teammate "${J}" not found`,is_error:!0};return z.sendDirect(J,V,X),{content:JSON.stringify({success:!0,type:"direct",to:Y.name,from:V,messageCount:z.getMessageCount(J)})}}else{let J=Q.teamName;if(!J)return{content:"Error: 'teamName' is required for broadcast messages",is_error:!0};let Y=z.getTeam(J);if(!Y)return{content:`Error: Team "${J}" not found`,is_error:!0};return z.broadcast(J,X,V),{content:JSON.stringify({success:!0,type:"broadcast",teamName:J,from:V,recipients:Y.teammates.filter((K)=>K.teammateId!==V).map((K)=>({name:K.name,id:K.teammateId}))})}}}catch(z){return{content:`Error sending message: ${z instanceof Error?z.message:String(z)}`,is_error:!0}}}},e0={name:"TeammateStatus",description:`Check the status of teammates and teams.
105
+
106
+ Returns status information including:
107
+ - Team overview with all teammates
108
+ - Individual teammate status (pending, in_progress, idle, completed, failed)
109
+ - Pending message counts
110
+ - Coordination settings`,input_schema:{type:"object",properties:{teamName:{type:"string",description:"Team name to check (optional, shows all if not provided)"},teammateId:{type:"string",description:"Specific teammate ID to check (optional)"}},required:[]},handler:async(Q,Z)=>{let{teamName:$,teammateId:X}=Q;try{let V=B9();if(X){let J=V.getTeammate(X);if(!J)return{content:`Error: Teammate "${X}" not found`,is_error:!0};return{content:JSON.stringify({teammate:{...J,pendingMessages:V.getMessageCount(X)}},null,2)}}if($){let J=V.getTeam($);if(!J)return{content:`Error: Team "${$}" not found`,is_error:!0};return{content:JSON.stringify({team:{name:J.name,description:J.description,status:J.status,coordination:J.coordination},teammates:J.teammates.map((Y)=>({...Y,pendingMessages:V.getMessageCount(Y.teammateId)}))},null,2)}}let z=V.listTeams();return{content:JSON.stringify({teams:z.map((J)=>({name:J.name,description:J.description,status:J.status,teammateCount:J.teammates.length,teammates:J.teammates.map((Y)=>({name:Y.name,status:Y.status,pendingMessages:V.getMessageCount(Y.teammateId)}))})),totalTeams:z.length},null,2)}}catch(V){return{content:`Error getting status: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},QQ={name:"TeamList",description:`List all teams and their teammates.
111
+
112
+ Shows a summary of all configured teams including:
113
+ - Team name, description, status
114
+ - All teammates with their roles and status
115
+ - Coordination settings`,input_schema:{type:"object",properties:{verbose:{type:"boolean",description:"Include detailed information (default: false)"}},required:[]},handler:async(Q,Z)=>{let $=Q.verbose||!1;try{let V=B9().listTeams();if(V.length===0)return{content:"No teams configured. Use TeamCreate to create a team."};let z=V.map((J)=>{let Y={name:J.name,description:J.description,status:J.status,teammateCount:J.teammates.length};if($)return{...Y,coordination:J.coordination,teammates:J.teammates.map((K)=>({id:K.teammateId,name:K.name,role:K.role,status:K.status,color:K.color}))};return{...Y,teammates:J.teammates.map((K)=>`${K.name} (${K.status})`).join(", ")}});return{content:JSON.stringify({teams:z,total:V.length},null,2)}}catch(X){return{content:`Error listing teams: ${X instanceof Error?X.message:String(X)}`,is_error:!0}}}},ZQ={name:"TeammateUpdate",description:`Update a teammate's status or configuration.
116
+
117
+ Used by teammates to report their progress and by coordinators to manage teammates.`,input_schema:{type:"object",properties:{teammateId:{type:"string",description:"The teammate ID to update"},status:{type:"string",enum:["pending","in_progress","idle","completed","failed"],description:"New status for the teammate"}},required:["teammateId"]},handler:async(Q,Z)=>{let{teammateId:$,status:X}=Q;try{let V=B9(),z=V.getTeammate($);if(!z)return{content:`Error: Teammate "${$}" not found`,is_error:!0};if(X)V.updateTeammateStatus($,X);return{content:JSON.stringify({success:!0,teammate:{teammateId:z.teammateId,name:z.name,status:X||z.status}})}}catch(V){return{content:`Error updating teammate: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},$Q={name:"TeammateMessages",description:`Retrieve pending messages for a teammate.
118
+
119
+ Called by teammates to check for new messages from other teammates or the system.
120
+ Messages are retrieved and cleared from the queue.`,input_schema:{type:"object",properties:{teammateId:{type:"string",description:"The teammate ID to get messages for"},peek:{type:"boolean",description:"Peek at messages without clearing them (default: false)"}},required:["teammateId"]},handler:async(Q,Z)=>{let $=Q.teammateId,X=Q.peek||!1;try{let V=B9(),z=V.getTeammate($);if(!z)return{content:`Error: Teammate "${$}" not found`,is_error:!0};let J=X?V.peekMessages($):V.getMessages($);return{content:JSON.stringify({teammateId:$,teammateName:z.name,messageCount:J.length,messages:J.map((Y)=>({type:Y.type,from:Y.from,to:Y.to,content:Y.content,timestamp:new Date(Y.timestamp).toISOString()}))},null,2)}}catch(V){return{content:`Error getting messages: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},XQ={name:"TeamDelete",description:`Delete a team and all its teammates.
121
+
122
+ Warning: This permanently removes the team configuration.
123
+ Running teammates will continue but lose team association.`,input_schema:{type:"object",properties:{name:{type:"string",description:"The team name to delete"}},required:["name"]},handler:async(Q,Z)=>{let $=Q.name;try{let X=B9(),V=X.getTeam($);if(!V)return{content:`Error: Team "${$}" not found`,is_error:!0};let z=V.teammates.length;return X.deleteTeam($),{content:JSON.stringify({success:!0,deletedTeam:$,deletedTeammates:z})}}catch(X){return{content:`Error deleting team: ${X instanceof Error?X.message:String(X)}`,is_error:!0}}}},L$=[a0,QQ,XQ,s0,t0,$Q,e0,ZQ];var VQ=(Q,Z,$)=>{let X=Q instanceof RegExp?X8(Q,$):Q,V=Z instanceof RegExp?X8(Z,$):Z,z=X!==null&&V!=null&&i6(X,V,$);return z&&{start:z[0],end:z[1],pre:$.slice(0,z[0]),body:$.slice(z[0]+X.length,z[1]),post:$.slice(z[1]+V.length)}},X8=(Q,Z)=>{let $=Z.match(Q);return $?$[0]:null},i6=(Q,Z,$)=>{let X,V,z,J=void 0,Y,K=$.indexOf(Q),q=$.indexOf(Z,K+1),W=K;if(K>=0&&q>0){if(Q===Z)return[K,q];X=[],z=$.length;while(W>=0&&!Y){if(W===K)X.push(W),K=$.indexOf(Q,W+1);else if(X.length===1){let H=X.pop();if(H!==void 0)Y=[H,q]}else{if(V=X.pop(),V!==void 0&&V<z)z=V,J=q;q=$.indexOf(Z,W+1)}W=K<q&&K>=0?K:q}if(X.length&&J!==void 0)Y=[z,J]}return Y};var V8="\x00SLASH"+Math.random()+"\x00",z8="\x00OPEN"+Math.random()+"\x00",JQ="\x00CLOSE"+Math.random()+"\x00",J8="\x00COMMA"+Math.random()+"\x00",Y8="\x00PERIOD"+Math.random()+"\x00",n6=new RegExp(V8,"g"),o6=new RegExp(z8,"g"),r6=new RegExp(JQ,"g"),a6=new RegExp(J8,"g"),s6=new RegExp(Y8,"g"),t6=/\\\\/g,e6=/\\{/g,QZ=/\\}/g,ZZ=/\\,/g,$Z=/\\./g,XZ=1e5;function zQ(Q){return!isNaN(Q)?parseInt(Q,10):Q.charCodeAt(0)}function VZ(Q){return Q.replace(t6,V8).replace(e6,z8).replace(QZ,JQ).replace(ZZ,J8).replace($Z,Y8)}function zZ(Q){return Q.replace(n6,"\\").replace(o6,"{").replace(r6,"}").replace(a6,",").replace(s6,".")}function K8(Q){if(!Q)return[""];let Z=[],$=VQ("{","}",Q);if(!$)return Q.split(",");let{pre:X,body:V,post:z}=$,J=X.split(",");J[J.length-1]+="{"+V+"}";let Y=K8(z);if(z.length)J[J.length-1]+=Y.shift(),J.push.apply(J,Y);return Z.push.apply(Z,J),Z}function q8(Q,Z={}){if(!Q)return[];let{max:$=XZ}=Z;if(Q.slice(0,2)==="{}")Q="\\{\\}"+Q.slice(2);return n9(VZ(Q),$,!0).map(zZ)}function JZ(Q){return"{"+Q+"}"}function YZ(Q){return/^-?0\d/.test(Q)}function KZ(Q,Z){return Q<=Z}function qZ(Q,Z){return Q>=Z}function n9(Q,Z,$){let X=[],V=VQ("{","}",Q);if(!V)return[Q];let z=V.pre,J=V.post.length?n9(V.post,Z,!1):[""];if(/\$$/.test(V.pre))for(let Y=0;Y<J.length&&Y<Z;Y++){let K=z+"{"+V.body+"}"+J[Y];X.push(K)}else{let Y=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(V.body),K=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(V.body),q=Y||K,W=V.body.indexOf(",")>=0;if(!q&&!W){if(V.post.match(/,(?!,).*\}/))return Q=V.pre+"{"+V.body+JQ+V.post,n9(Q,Z,!0);return[Q]}let H;if(q)H=V.body.split(/\.\./);else if(H=K8(V.body),H.length===1&&H[0]!==void 0){if(H=n9(H[0],Z,!1).map(JZ),H.length===1)return J.map((_)=>V.pre+H[0]+_)}let G;if(q&&H[0]!==void 0&&H[1]!==void 0){let _=zQ(H[0]),U=zQ(H[1]),j=Math.max(H[0].length,H[1].length),A=H.length===3&&H[2]!==void 0?Math.abs(zQ(H[2])):1,w=KZ;if(U<_)A*=-1,w=qZ;let O=H.some(YZ);G=[];for(let v=_;w(v,U);v+=A){let L;if(K){if(L=String.fromCharCode(v),L==="\\")L=""}else if(L=String(v),O){let S=j-L.length;if(S>0){let y=Array(S+1).join("0");if(v<0)L="-"+y+L.slice(1);else L=y+L}}G.push(L)}}else{G=[];for(let _=0;_<H.length;_++)G.push.apply(G,n9(H[_],Z,!1))}for(let _=0;_<G.length;_++)for(let U=0;U<J.length&&X.length<Z;U++){let j=z+G[_]+J[U];if(!$||q||j)X.push(j)}}return X}var o9=(Q)=>{if(typeof Q!=="string")throw TypeError("invalid pattern");if(Q.length>65536)throw TypeError("pattern is too long")};var WZ={"[:alnum:]":["\\p{L}\\p{Nl}\\p{Nd}",!0],"[:alpha:]":["\\p{L}\\p{Nl}",!0],"[:ascii:]":["\\x00-\\x7f",!1],"[:blank:]":["\\p{Zs}\\t",!0],"[:cntrl:]":["\\p{Cc}",!0],"[:digit:]":["\\p{Nd}",!0],"[:graph:]":["\\p{Z}\\p{C}",!0,!0],"[:lower:]":["\\p{Ll}",!0],"[:print:]":["\\p{C}",!0],"[:punct:]":["\\p{P}",!0],"[:space:]":["\\p{Z}\\t\\r\\n\\v\\f",!0],"[:upper:]":["\\p{Lu}",!0],"[:word:]":["\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}",!0],"[:xdigit:]":["A-Fa-f0-9",!1]},r9=(Q)=>Q.replace(/[[\]\\-]/g,"\\$&"),HZ=(Q)=>Q.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),W8=(Q)=>Q.join(""),H8=(Q,Z)=>{let $=Z;if(Q.charAt($)!=="[")throw Error("not in a brace expression");let X=[],V=[],z=$+1,J=!1,Y=!1,K=!1,q=!1,W=$,H="";Q:while(z<Q.length){let j=Q.charAt(z);if((j==="!"||j==="^")&&z===$+1){q=!0,z++;continue}if(j==="]"&&J&&!K){W=z+1;break}if(J=!0,j==="\\"){if(!K){K=!0,z++;continue}}if(j==="["&&!K){for(let[A,[w,B,O]]of Object.entries(WZ))if(Q.startsWith(A,z)){if(H)return["$.",!1,Q.length-$,!0];if(z+=A.length,O)V.push(w);else X.push(w);Y=Y||B;continue Q}}if(K=!1,H){if(j>H)X.push(r9(H)+"-"+r9(j));else if(j===H)X.push(r9(j));H="",z++;continue}if(Q.startsWith("-]",z+1)){X.push(r9(j+"-")),z+=2;continue}if(Q.startsWith("-",z+1)){H=j,z+=2;continue}X.push(r9(j)),z++}if(W<z)return["",!1,0,!1];if(!X.length&&!V.length)return["$.",!1,Q.length-$,!0];if(V.length===0&&X.length===1&&/^\\?.$/.test(X[0])&&!q){let j=X[0].length===2?X[0].slice(-1):X[0];return[HZ(j),!1,W-$,!1]}let G="["+(q?"^":"")+W8(X)+"]",_="["+(q?"":"^")+W8(V)+"]";return[X.length&&V.length?"("+G+"|"+_+")":X.length?G:_,Y,W-$,!0]};var a=(Q,{windowsPathsNoEscape:Z=!1,magicalBraces:$=!0}={})=>{if($)return Z?Q.replace(/\[([^\/\\])\]/g,"$1"):Q.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");return Z?Q.replace(/\[([^\/\\{}])\]/g,"$1"):Q.replace(/((?!\\).|^)\[([^\/\\{}])\]/g,"$1$2").replace(/\\([^\/{}])/g,"$1")};var g,GZ=new Set(["!","?","+","*","@"]),YQ=(Q)=>GZ.has(Q),G8=(Q)=>YQ(Q.type),_Z=new Map([["!",["@"]],["?",["?","@"]],["@",["@"]],["*",["*","+","?","@"]],["+",["+","@"]]]),jZ=new Map([["!",["?"]],["@",["?"]],["+",["?","*"]]]),UZ=new Map([["!",["?","@"]],["?",["?","@"]],["@",["?","@"]],["*",["*","+","?","@"]],["+",["+","@","?","*"]]]),_8=new Map([["!",new Map([["!","@"]])],["?",new Map([["*","*"],["+","*"]])],["@",new Map([["!","!"],["?","?"],["@","@"],["*","*"],["+","+"]])],["+",new Map([["?","*"],["*","*"]])]]),wZ="(?!(?:^|/)\\.\\.?(?:$|/))",w0="(?!\\.)",AZ=new Set(["[","."]),BZ=new Set(["..","."]),LZ=new Set("().*{}+?[]^$\\!"),FZ=(Q)=>Q.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),KQ="[^/]",j8=KQ+"*?",U8=KQ+"+?",OZ=0;class x9{type;#Q;#X;#V=!1;#Z=[];#J;#M;#B;#H=!1;#Y;#G;#W=!1;id=++OZ;get depth(){return(this.#J?.depth??-1)+1}[Symbol.for("nodejs.util.inspect.custom")](){return{"@@type":"AST",id:this.id,type:this.type,root:this.#Q.id,parent:this.#J?.id,depth:this.depth,partsLength:this.#Z.length,parts:this.#Z}}constructor(Q,Z,$={}){if(this.type=Q,Q)this.#X=!0;if(this.#J=Z,this.#Q=this.#J?this.#J.#Q:this,this.#Y=this.#Q===this?$:this.#Q.#Y,this.#B=this.#Q===this?[]:this.#Q.#B,Q==="!"&&!this.#Q.#H)this.#B.push(this);this.#M=this.#J?this.#J.#Z.length:0}get hasMagic(){if(this.#X!==void 0)return this.#X;for(let Q of this.#Z){if(typeof Q==="string")continue;if(Q.type||Q.hasMagic)return this.#X=!0}return this.#X}toString(){if(this.#G!==void 0)return this.#G;if(!this.type)return this.#G=this.#Z.map((Q)=>String(Q)).join("");else return this.#G=this.type+"("+this.#Z.map((Q)=>String(Q)).join("|")+")"}#K(){if(this!==this.#Q)throw Error("should only call on root");if(this.#H)return this;this.toString(),this.#H=!0;let Q;while(Q=this.#B.pop()){if(Q.type!=="!")continue;let Z=Q,$=Z.#J;while($){for(let X=Z.#M+1;!$.type&&X<$.#Z.length;X++)for(let V of Q.#Z){if(typeof V==="string")throw Error("string part in extglob AST??");V.copyIn($.#Z[X])}Z=$,$=Z.#J}}return this}push(...Q){for(let Z of Q){if(Z==="")continue;if(typeof Z!=="string"&&!(Z instanceof g&&Z.#J===this))throw Error("invalid part: "+Z);this.#Z.push(Z)}}toJSON(){let Q=this.type===null?this.#Z.slice().map((Z)=>typeof Z==="string"?Z:Z.toJSON()):[this.type,...this.#Z.map((Z)=>Z.toJSON())];if(this.isStart()&&!this.type)Q.unshift([]);if(this.isEnd()&&(this===this.#Q||this.#Q.#H&&this.#J?.type==="!"))Q.push({});return Q}isStart(){if(this.#Q===this)return!0;if(!this.#J?.isStart())return!1;if(this.#M===0)return!0;let Q=this.#J;for(let Z=0;Z<this.#M;Z++){let $=Q.#Z[Z];if(!($ instanceof g&&$.type==="!"))return!1}return!0}isEnd(){if(this.#Q===this)return!0;if(this.#J?.type==="!")return!0;if(!this.#J?.isEnd())return!1;if(!this.type)return this.#J?.isEnd();let Q=this.#J?this.#J.#Z.length:0;return this.#M===Q-1}copyIn(Q){if(typeof Q==="string")this.push(Q);else this.push(Q.clone(this))}clone(Q){let Z=new g(this.type,Q);for(let $ of this.#Z)Z.copyIn($);return Z}static#z(Q,Z,$,X,V){let z=X.maxExtglobRecursion??2,J=!1,Y=!1,K=-1,q=!1;if(Z.type===null){let U=$,j="";while(U<Q.length){let A=Q.charAt(U++);if(J||A==="\\"){J=!J,j+=A;continue}if(Y){if(U===K+1){if(A==="^"||A==="!")q=!0}else if(A==="]"&&!(U===K+2&&q))Y=!1;j+=A;continue}else if(A==="["){Y=!0,K=U,q=!1,j+=A;continue}if(!X.noext&&YQ(A)&&Q.charAt(U)==="("&&V<=z){Z.push(j),j="";let B=new g(A,Z);U=g.#z(Q,B,U,X,V+1),Z.push(B);continue}j+=A}return Z.push(j),U}let W=$+1,H=new g(null,Z),G=[],_="";while(W<Q.length){let U=Q.charAt(W++);if(J||U==="\\"){J=!J,_+=U;continue}if(Y){if(W===K+1){if(U==="^"||U==="!")q=!0}else if(U==="]"&&!(W===K+2&&q))Y=!1;_+=U;continue}else if(U==="["){Y=!0,K=W,q=!1,_+=U;continue}if(!X.noext&&YQ(U)&&Q.charAt(W)==="("&&(V<=z||Z&&Z.#j(U))){let A=Z&&Z.#j(U)?0:1;H.push(_),_="";let w=new g(U,H);H.push(w),W=g.#z(Q,w,W,X,V+A);continue}if(U==="|"){H.push(_),_="",G.push(H),H=new g(null,Z);continue}if(U===")"){if(_===""&&Z.#Z.length===0)Z.#W=!0;return H.push(_),_="",Z.push(...G,H),W}_+=U}return Z.type=null,Z.#X=void 0,Z.#Z=[Q.substring($-1)],W}#L(Q){return this.#O(Q,jZ)}#O(Q,Z=_Z){if(!Q||typeof Q!=="object"||Q.type!==null||Q.#Z.length!==1||this.type===null)return!1;let $=Q.#Z[0];if(!$||typeof $!=="object"||$.type===null)return!1;return this.#j($.type,Z)}#j(Q,Z=UZ){return!!Z.get(this.type)?.includes(Q)}#U(Q,Z){let $=Q.#Z[0],X=new g(null,$,this.options);X.#Z.push(""),$.push(X),this.#P(Q,Z)}#P(Q,Z){let $=Q.#Z[0];this.#Z.splice(Z,1,...$.#Z);for(let X of $.#Z)if(typeof X==="object")X.#J=this;this.#G=void 0}#w(Q){return!!_8.get(this.type)?.has(Q)}#v(Q){if(!Q||typeof Q!=="object"||Q.type!==null||Q.#Z.length!==1||this.type===null||this.#Z.length!==1)return!1;let Z=Q.#Z[0];if(!Z||typeof Z!=="object"||Z.type===null)return!1;return this.#w(Z.type)}#C(Q){let Z=_8.get(this.type),$=Q.#Z[0],X=Z?.get($.type);if(!X)return!1;this.#Z=$.#Z;for(let V of this.#Z)if(typeof V==="object")V.#J=this;this.type=X,this.#G=void 0,this.#W=!1}static fromGlob(Q,Z={}){let $=new g(null,void 0,Z);return g.#z(Q,$,0,Z,0),$}toMMPattern(){if(this!==this.#Q)return this.#Q.toMMPattern();let Q=this.toString(),[Z,$,X,V]=this.toRegExpSource();if(!(X||this.#X||this.#Y.nocase&&!this.#Y.nocaseMagicOnly&&Q.toUpperCase()!==Q.toLowerCase()))return $;let J=(this.#Y.nocase?"i":"")+(V?"u":"");return Object.assign(new RegExp(`^${Z}$`,J),{_src:Z,_glob:Q})}get options(){return this.#Y}toRegExpSource(Q){let Z=Q??!!this.#Y.dot;if(this.#Q===this)this.#_(),this.#K();if(!G8(this)){let Y=this.isStart()&&this.isEnd()&&!this.#Z.some((G)=>typeof G!=="string"),K=this.#Z.map((G)=>{let[_,U,j,A]=typeof G==="string"?g.#F(G,this.#X,Y):G.toRegExpSource(Q);return this.#X=this.#X||j,this.#V=this.#V||A,_}).join(""),q="";if(this.isStart()){if(typeof this.#Z[0]==="string"){if(!(this.#Z.length===1&&BZ.has(this.#Z[0]))){let _=AZ,U=Z&&_.has(K.charAt(0))||K.startsWith("\\.")&&_.has(K.charAt(2))||K.startsWith("\\.\\.")&&_.has(K.charAt(4)),j=!Z&&!Q&&_.has(K.charAt(0));q=U?wZ:j?w0:""}}}let W="";if(this.isEnd()&&this.#Q.#H&&this.#J?.type==="!")W="(?:$|\\/)";return[q+K+W,a(K),this.#X=!!this.#X,this.#V]}let $=this.type==="*"||this.type==="+",X=this.type==="!"?"(?:(?!(?:":"(?:",V=this.#A(Z);if(this.isStart()&&this.isEnd()&&!V&&this.type!=="!"){let Y=this.toString(),K=this;return K.#Z=[Y],K.type=null,K.#X=void 0,[Y,a(this.toString()),!1,!1]}let z=!$||Q||Z||!w0?"":this.#A(!0);if(z===V)z="";if(z)V=`(?:${V})(?:${z})*?`;let J="";if(this.type==="!"&&this.#W)J=(this.isStart()&&!Z?w0:"")+U8;else{let Y=this.type==="!"?"))"+(this.isStart()&&!Z&&!Q?w0:"")+j8+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&z?")":this.type==="*"&&z?")?":`)${this.type}`;J=X+V+Y}return[J,a(V),this.#X=!!this.#X,this.#V]}#_(){if(!G8(this)){for(let Q of this.#Z)if(typeof Q==="object")Q.#_()}else{let Q=0,Z=!1;do{Z=!0;for(let $=0;$<this.#Z.length;$++){let X=this.#Z[$];if(typeof X==="object"){if(X.#_(),this.#O(X))Z=!1,this.#P(X,$);else if(this.#L(X))Z=!1,this.#U(X,$);else if(this.#v(X))Z=!1,this.#C(X)}}}while(!Z&&++Q<10)}this.#G=void 0}#A(Q){return this.#Z.map((Z)=>{if(typeof Z==="string")throw Error("string type in extglob ast??");let[$,X,V,z]=Z.toRegExpSource(Q);return this.#V=this.#V||z,$}).filter((Z)=>!(this.isStart()&&this.isEnd())||!!Z).join("|")}static#F(Q,Z,$=!1){let X=!1,V="",z=!1,J=!1;for(let Y=0;Y<Q.length;Y++){let K=Q.charAt(Y);if(X){X=!1,V+=(LZ.has(K)?"\\":"")+K;continue}if(K==="*"){if(J)continue;J=!0,V+=$&&/^[*]+$/.test(Q)?U8:j8,Z=!0;continue}else J=!1;if(K==="\\"){if(Y===Q.length-1)V+="\\\\";else X=!0;continue}if(K==="["){let[q,W,H,G]=H8(Q,Y);if(H){V+=q,z=z||W,Y+=H-1,Z=Z||G;continue}}if(K==="?"){V+=KQ,Z=!0;continue}V+=FZ(K)}return[V,a(Q),!!Z,z]}}g=x9;var E9=(Q,{windowsPathsNoEscape:Z=!1,magicalBraces:$=!1}={})=>{if($)return Z?Q.replace(/[?*()[\]{}]/g,"[$&]"):Q.replace(/[?*()[\]\\{}]/g,"\\$&");return Z?Q.replace(/[?*()[\]]/g,"[$&]"):Q.replace(/[?*()[\]\\]/g,"\\$&")};var b=(Q,Z,$={})=>{if(o9(Z),!$.nocomment&&Z.charAt(0)==="#")return!1;return new p(Z,$).match(Q)},vZ=/^\*+([^+@!?\*\[\(]*)$/,MZ=(Q)=>(Z)=>!Z.startsWith(".")&&Z.endsWith(Q),CZ=(Q)=>(Z)=>Z.endsWith(Q),RZ=(Q)=>{return Q=Q.toLowerCase(),(Z)=>!Z.startsWith(".")&&Z.toLowerCase().endsWith(Q)},PZ=(Q)=>{return Q=Q.toLowerCase(),(Z)=>Z.toLowerCase().endsWith(Q)},DZ=/^\*+\.\*+$/,NZ=(Q)=>!Q.startsWith(".")&&Q.includes("."),SZ=(Q)=>Q!=="."&&Q!==".."&&Q.includes("."),IZ=/^\.\*+$/,xZ=(Q)=>Q!=="."&&Q!==".."&&Q.startsWith("."),EZ=/^\*+$/,TZ=(Q)=>Q.length!==0&&!Q.startsWith("."),yZ=(Q)=>Q.length!==0&&Q!=="."&&Q!=="..",kZ=/^\?+([^+@!?\*\[\(]*)?$/,fZ=([Q,Z=""])=>{let $=B8([Q]);if(!Z)return $;return Z=Z.toLowerCase(),(X)=>$(X)&&X.toLowerCase().endsWith(Z)},bZ=([Q,Z=""])=>{let $=L8([Q]);if(!Z)return $;return Z=Z.toLowerCase(),(X)=>$(X)&&X.toLowerCase().endsWith(Z)},uZ=([Q,Z=""])=>{let $=L8([Q]);return!Z?$:(X)=>$(X)&&X.endsWith(Z)},hZ=([Q,Z=""])=>{let $=B8([Q]);return!Z?$:(X)=>$(X)&&X.endsWith(Z)},B8=([Q])=>{let Z=Q.length;return($)=>$.length===Z&&!$.startsWith(".")},L8=([Q])=>{let Z=Q.length;return($)=>$.length===Z&&$!=="."&&$!==".."},F8=typeof process==="object"&&process?typeof process.env==="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",w8={win32:{sep:"\\"},posix:{sep:"/"}},gZ=F8==="win32"?w8.win32.sep:w8.posix.sep;b.sep=gZ;var D=Symbol("globstar **");b.GLOBSTAR=D;var dZ="[^/]",mZ=dZ+"*?",cZ="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",lZ="(?:(?!(?:\\/|^)\\.).)*?",pZ=(Q,Z={})=>($)=>b($,Q,Z);b.filter=pZ;var l=(Q,Z={})=>Object.assign({},Q,Z),iZ=(Q)=>{if(!Q||typeof Q!=="object"||!Object.keys(Q).length)return b;let Z=b;return Object.assign((X,V,z={})=>Z(X,V,l(Q,z)),{Minimatch:class extends Z.Minimatch{constructor(V,z={}){super(V,l(Q,z))}static defaults(V){return Z.defaults(l(Q,V)).Minimatch}},AST:class extends Z.AST{constructor(V,z,J={}){super(V,z,l(Q,J))}static fromGlob(V,z={}){return Z.AST.fromGlob(V,l(Q,z))}},unescape:(X,V={})=>Z.unescape(X,l(Q,V)),escape:(X,V={})=>Z.escape(X,l(Q,V)),filter:(X,V={})=>Z.filter(X,l(Q,V)),defaults:(X)=>Z.defaults(l(Q,X)),makeRe:(X,V={})=>Z.makeRe(X,l(Q,V)),braceExpand:(X,V={})=>Z.braceExpand(X,l(Q,V)),match:(X,V,z={})=>Z.match(X,V,l(Q,z)),sep:Z.sep,GLOBSTAR:D})};b.defaults=iZ;var O8=(Q,Z={})=>{if(o9(Q),Z.nobrace||!/\{(?:(?!\{).)*\}/.test(Q))return[Q];return q8(Q,{max:Z.braceExpandMax})};b.braceExpand=O8;var nZ=(Q,Z={})=>new p(Q,Z).makeRe();b.makeRe=nZ;var oZ=(Q,Z,$={})=>{let X=new p(Z,$);if(Q=Q.filter((V)=>X.match(V)),X.options.nonull&&!Q.length)Q.push(Z);return Q};b.match=oZ;var A8=/[?*]|[+@!]\(.*?\)|\[|\]/,rZ=(Q)=>Q.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&");class p{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;maxGlobstarRecursion;regexp;constructor(Q,Z={}){o9(Q),Z=Z||{},this.options=Z,this.maxGlobstarRecursion=Z.maxGlobstarRecursion??200,this.pattern=Q,this.platform=Z.platform||F8,this.isWindows=this.platform==="win32";let $="allowWindowsEscape";if(this.windowsPathsNoEscape=!!Z.windowsPathsNoEscape||Z[$]===!1,this.windowsPathsNoEscape)this.pattern=this.pattern.replace(/\\/g,"/");this.preserveMultipleSlashes=!!Z.preserveMultipleSlashes,this.regexp=null,this.negate=!1,this.nonegate=!!Z.nonegate,this.comment=!1,this.empty=!1,this.partial=!!Z.partial,this.nocase=!!this.options.nocase,this.windowsNoMagicRoot=Z.windowsNoMagicRoot!==void 0?Z.windowsNoMagicRoot:!!(this.isWindows&&this.nocase),this.globSet=[],this.globParts=[],this.set=[],this.make()}hasMagic(){if(this.options.magicalBraces&&this.set.length>1)return!0;for(let Q of this.set)for(let Z of Q)if(typeof Z!=="string")return!0;return!1}debug(...Q){}make(){let Q=this.pattern,Z=this.options;if(!Z.nocomment&&Q.charAt(0)==="#"){this.comment=!0;return}if(!Q){this.empty=!0;return}if(this.parseNegate(),this.globSet=[...new Set(this.braceExpand())],Z.debug)this.debug=(...V)=>console.error(...V);this.debug(this.pattern,this.globSet);let $=this.globSet.map((V)=>this.slashSplit(V));this.globParts=this.preprocess($),this.debug(this.pattern,this.globParts);let X=this.globParts.map((V,z,J)=>{if(this.isWindows&&this.windowsNoMagicRoot){let Y=V[0]===""&&V[1]===""&&(V[2]==="?"||!A8.test(V[2]))&&!A8.test(V[3]),K=/^[a-z]:/i.test(V[0]);if(Y)return[...V.slice(0,4),...V.slice(4).map((q)=>this.parse(q))];else if(K)return[V[0],...V.slice(1).map((q)=>this.parse(q))]}return V.map((Y)=>this.parse(Y))});if(this.debug(this.pattern,X),this.set=X.filter((V)=>V.indexOf(!1)===-1),this.isWindows)for(let V=0;V<this.set.length;V++){let z=this.set[V];if(z[0]===""&&z[1]===""&&this.globParts[V][2]==="?"&&typeof z[3]==="string"&&/^[a-z]:$/i.test(z[3]))z[2]="?"}this.debug(this.pattern,this.set)}preprocess(Q){if(this.options.noglobstar){for(let $=0;$<Q.length;$++)for(let X=0;X<Q[$].length;X++)if(Q[$][X]==="**")Q[$][X]="*"}let{optimizationLevel:Z=1}=this.options;if(Z>=2)Q=this.firstPhasePreProcess(Q),Q=this.secondPhasePreProcess(Q);else if(Z>=1)Q=this.levelOneOptimize(Q);else Q=this.adjascentGlobstarOptimize(Q);return Q}adjascentGlobstarOptimize(Q){return Q.map((Z)=>{let $=-1;while(($=Z.indexOf("**",$+1))!==-1){let X=$;while(Z[X+1]==="**")X++;if(X!==$)Z.splice($,X-$)}return Z})}levelOneOptimize(Q){return Q.map((Z)=>{return Z=Z.reduce(($,X)=>{let V=$[$.length-1];if(X==="**"&&V==="**")return $;if(X===".."){if(V&&V!==".."&&V!=="."&&V!=="**")return $.pop(),$}return $.push(X),$},[]),Z.length===0?[""]:Z})}levelTwoFileOptimize(Q){if(!Array.isArray(Q))Q=this.slashSplit(Q);let Z=!1;do{if(Z=!1,!this.preserveMultipleSlashes){for(let X=1;X<Q.length-1;X++){let V=Q[X];if(X===1&&V===""&&Q[0]==="")continue;if(V==="."||V==="")Z=!0,Q.splice(X,1),X--}if(Q[0]==="."&&Q.length===2&&(Q[1]==="."||Q[1]===""))Z=!0,Q.pop()}let $=0;while(($=Q.indexOf("..",$+1))!==-1){let X=Q[$-1];if(X&&X!=="."&&X!==".."&&X!=="**")Z=!0,Q.splice($-1,2),$-=2}}while(Z);return Q.length===0?[""]:Q}firstPhasePreProcess(Q){let Z=!1;do{Z=!1;for(let $ of Q){let X=-1;while((X=$.indexOf("**",X+1))!==-1){let z=X;while($[z+1]==="**")z++;if(z>X)$.splice(X+1,z-X);let J=$[X+1],Y=$[X+2],K=$[X+3];if(J!=="..")continue;if(!Y||Y==="."||Y===".."||!K||K==="."||K==="..")continue;Z=!0,$.splice(X,1);let q=$.slice(0);q[X]="**",Q.push(q),X--}if(!this.preserveMultipleSlashes){for(let z=1;z<$.length-1;z++){let J=$[z];if(z===1&&J===""&&$[0]==="")continue;if(J==="."||J==="")Z=!0,$.splice(z,1),z--}if($[0]==="."&&$.length===2&&($[1]==="."||$[1]===""))Z=!0,$.pop()}let V=0;while((V=$.indexOf("..",V+1))!==-1){let z=$[V-1];if(z&&z!=="."&&z!==".."&&z!=="**"){Z=!0;let Y=V===1&&$[V+1]==="**"?["."]:[];if($.splice(V-1,2,...Y),$.length===0)$.push("");V-=2}}}}while(Z);return Q}secondPhasePreProcess(Q){for(let Z=0;Z<Q.length-1;Z++)for(let $=Z+1;$<Q.length;$++){let X=this.partsMatch(Q[Z],Q[$],!this.preserveMultipleSlashes);if(X){Q[Z]=[],Q[$]=X;break}}return Q.filter((Z)=>Z.length)}partsMatch(Q,Z,$=!1){let X=0,V=0,z=[],J="";while(X<Q.length&&V<Z.length)if(Q[X]===Z[V])z.push(J==="b"?Z[V]:Q[X]),X++,V++;else if($&&Q[X]==="**"&&Z[V]===Q[X+1])z.push(Q[X]),X++;else if($&&Z[V]==="**"&&Q[X]===Z[V+1])z.push(Z[V]),V++;else if(Q[X]==="*"&&Z[V]&&(this.options.dot||!Z[V].startsWith("."))&&Z[V]!=="**"){if(J==="b")return!1;J="a",z.push(Q[X]),X++,V++}else if(Z[V]==="*"&&Q[X]&&(this.options.dot||!Q[X].startsWith("."))&&Q[X]!=="**"){if(J==="a")return!1;J="b",z.push(Z[V]),X++,V++}else return!1;return Q.length===Z.length&&z}parseNegate(){if(this.nonegate)return;let Q=this.pattern,Z=!1,$=0;for(let X=0;X<Q.length&&Q.charAt(X)==="!";X++)Z=!Z,$++;if($)this.pattern=Q.slice($);this.negate=Z}matchOne(Q,Z,$=!1){let X=0,V=0;if(this.isWindows){let J=typeof Q[0]==="string"&&/^[a-z]:$/i.test(Q[0]),Y=!J&&Q[0]===""&&Q[1]===""&&Q[2]==="?"&&/^[a-z]:$/i.test(Q[3]),K=typeof Z[0]==="string"&&/^[a-z]:$/i.test(Z[0]),q=!K&&Z[0]===""&&Z[1]===""&&Z[2]==="?"&&typeof Z[3]==="string"&&/^[a-z]:$/i.test(Z[3]),W=Y?3:J?0:void 0,H=q?3:K?0:void 0;if(typeof W==="number"&&typeof H==="number"){let[G,_]=[Q[W],Z[H]];if(G.toLowerCase()===_.toLowerCase())Z[H]=G,V=H,X=W}}let{optimizationLevel:z=1}=this.options;if(z>=2)Q=this.levelTwoFileOptimize(Q);if(Z.includes(D))return this.#Q(Q,Z,$,X,V);return this.#V(Q,Z,$,X,V)}#Q(Q,Z,$,X,V){let z=Z.indexOf(D,V),J=Z.lastIndexOf(D),[Y,K,q]=$?[Z.slice(V,z),Z.slice(z+1),[]]:[Z.slice(V,z),Z.slice(z+1,J),Z.slice(J+1)];if(Y.length){let w=Q.slice(X,X+Y.length);if(!this.#V(w,Y,$,0,0))return!1;X+=Y.length,V+=Y.length}let W=0;if(q.length){if(q.length+X>Q.length)return!1;let w=Q.length-q.length;if(this.#V(Q,q,$,w,0))W=q.length;else{if(Q[Q.length-1]!==""||X+q.length===Q.length)return!1;if(w--,!this.#V(Q,q,$,w,0))return!1;W=q.length+1}}if(!K.length){let w=!!W;for(let B=X;B<Q.length-W;B++){let O=String(Q[B]);if(w=!0,O==="."||O===".."||!this.options.dot&&O.startsWith("."))return!1}return $||w}let H=[[[],0]],G=H[0],_=0,U=[0];for(let w of K)if(w===D)U.push(_),G=[[],0],H.push(G);else G[0].push(w),_++;let j=H.length-1,A=Q.length-W;for(let w of H)w[1]=A-(U[j--]+w[0].length);return!!this.#X(Q,H,X,0,$,0,!!W)}#X(Q,Z,$,X,V,z,J){let Y=Z[X];if(!Y){for(let W=$;W<Q.length;W++){J=!0;let H=Q[W];if(H==="."||H===".."||!this.options.dot&&H.startsWith("."))return!1}return J}let[K,q]=Y;while($<=q){if(this.#V(Q.slice(0,$+K.length),K,V,$,0)&&z<this.maxGlobstarRecursion){let G=this.#X(Q,Z,$+K.length,X+1,V,z+1,J);if(G!==!1)return G}let H=Q[$];if(H==="."||H===".."||!this.options.dot&&H.startsWith("."))return!1;$++}return V||null}#V(Q,Z,$,X,V){let z,J,Y,K;for(z=X,J=V,K=Q.length,Y=Z.length;z<K&&J<Y;z++,J++){this.debug("matchOne loop");let q=Z[J],W=Q[z];if(this.debug(Z,q,W),q===!1||q===D)return!1;let H;if(typeof q==="string")H=W===q,this.debug("string match",q,W,H);else H=q.test(W),this.debug("pattern match",q,W,H);if(!H)return!1}if(z===K&&J===Y)return!0;else if(z===K)return $;else if(J===Y)return z===K-1&&Q[z]==="";else throw Error("wtf?")}braceExpand(){return O8(this.pattern,this.options)}parse(Q){o9(Q);let Z=this.options;if(Q==="**")return D;if(Q==="")return"";let $,X=null;if($=Q.match(EZ))X=Z.dot?yZ:TZ;else if($=Q.match(vZ))X=(Z.nocase?Z.dot?PZ:RZ:Z.dot?CZ:MZ)($[1]);else if($=Q.match(kZ))X=(Z.nocase?Z.dot?bZ:fZ:Z.dot?uZ:hZ)($);else if($=Q.match(DZ))X=Z.dot?SZ:NZ;else if($=Q.match(IZ))X=xZ;let V=x9.fromGlob(Q,this.options).toMMPattern();if(X&&typeof V==="object")Reflect.defineProperty(V,"test",{value:X});return V}makeRe(){if(this.regexp||this.regexp===!1)return this.regexp;let Q=this.set;if(!Q.length)return this.regexp=!1,this.regexp;let Z=this.options,$=Z.noglobstar?mZ:Z.dot?cZ:lZ,X=new Set(Z.nocase?["i"]:[]),V=Q.map((Y)=>{let K=Y.map((W)=>{if(W instanceof RegExp)for(let H of W.flags.split(""))X.add(H);return typeof W==="string"?rZ(W):W===D?D:W._src});K.forEach((W,H)=>{let G=K[H+1],_=K[H-1];if(W!==D||_===D)return;if(_===void 0)if(G!==void 0&&G!==D)K[H+1]="(?:\\/|"+$+"\\/)?"+G;else K[H]=$;else if(G===void 0)K[H-1]=_+"(?:\\/|\\/"+$+")?";else if(G!==D)K[H-1]=_+"(?:\\/|\\/"+$+"\\/)"+G,K[H+1]=D});let q=K.filter((W)=>W!==D);if(this.partial&&q.length>=1){let W=[];for(let H=1;H<=q.length;H++)W.push(q.slice(0,H).join("/"));return"(?:"+W.join("|")+")"}return q.join("/")}).join("|"),[z,J]=Q.length>1?["(?:",")"]:["",""];if(V="^"+z+V+J+"$",this.partial)V="^(?:\\/|"+z+V.slice(1,-1)+J+")$";if(this.negate)V="^(?!"+V+").+$";try{this.regexp=new RegExp(V,[...X].join(""))}catch(Y){this.regexp=!1}return this.regexp}slashSplit(Q){if(this.preserveMultipleSlashes)return Q.split("/");else if(this.isWindows&&/^\/\/[^\/]+/.test(Q))return["",...Q.split(/\/+/)];else return Q.split(/\/+/)}match(Q,Z=this.partial){if(this.debug("match",Q,this.pattern),this.comment)return!1;if(this.empty)return Q==="";if(Q==="/"&&Z)return!0;let $=this.options;if(this.isWindows)Q=Q.split("\\").join("/");let X=this.slashSplit(Q);this.debug(this.pattern,"split",X);let V=this.set;this.debug(this.pattern,"set",V);let z=X[X.length-1];if(!z)for(let J=X.length-2;!z&&J>=0;J--)z=X[J];for(let J=0;J<V.length;J++){let Y=V[J],K=X;if($.matchBase&&Y.length===1)K=[z];if(this.matchOne(K,Y,Z)){if($.flipNegate)return!0;return!this.negate}}if($.flipNegate)return!1;return this.negate}static defaults(Q){return b.defaults(Q).Minimatch}}b.AST=x9;b.Minimatch=p;b.escape=E9;b.unescape=a;import{fileURLToPath as S5}from"url";var aZ=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,M8=new Set,qQ=typeof process=="object"&&process?process:{},C8=(Q,Z,$,X)=>{typeof qQ.emitWarning=="function"?qQ.emitWarning(Q,Z,$,X):console.error(`[${$}] ${Z}: ${Q}`)},B0=globalThis.AbortController,v8=globalThis.AbortSignal;if(typeof B0>"u"){v8=class{onabort;_onabort=[];reason;aborted=!1;addEventListener($,X){this._onabort.push(X)}},B0=class{constructor(){Z()}signal=new v8;abort($){if(!this.signal.aborted){this.signal.reason=$,this.signal.aborted=!0;for(let X of this.signal._onabort)X($);this.signal.onabort?.($)}}};let Q=qQ.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",Z=()=>{Q&&(Q=!1,C8("AbortController is not defined. If using lru-cache in node 14, load an AbortController polyfill from the `node-abort-controller` package. A minimal polyfill is provided for use by LRUCache.fetch(), but it should not be relied upon in other contexts (eg, passing it to other APIs that use AbortController/AbortSignal might have undesirable effects). You may disable this with LRU_CACHE_IGNORE_AC_WARNING=1 in the env.","NO_ABORT_CONTROLLER","ENOTSUP",Z))}}var sZ=(Q)=>!M8.has(Q),g$=Symbol("type"),L9=(Q)=>Q&&Q===Math.floor(Q)&&Q>0&&isFinite(Q),R8=(Q)=>L9(Q)?Q<=Math.pow(2,8)?Uint8Array:Q<=Math.pow(2,16)?Uint16Array:Q<=Math.pow(2,32)?Uint32Array:Q<=Number.MAX_SAFE_INTEGER?A0:null:null,A0=class extends Array{constructor(Q){super(Q),this.fill(0)}},tZ=class Q{heap;length;static#Q=!1;static create(Z){let $=R8(Z);if(!$)return[];Q.#Q=!0;let X=new Q(Z,$);return Q.#Q=!1,X}constructor(Z,$){if(!Q.#Q)throw TypeError("instantiate Stack using Stack.create(n)");this.heap=new $(Z),this.length=0}push(Z){this.heap[this.length++]=Z}pop(){return this.heap[--this.length]}},a9=class Q{#Q;#X;#V;#Z;#J;#M;#B;#H;get perf(){return this.#H}ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#Y;#G;#W;#K;#z;#L;#O;#j;#U;#P;#w;#v;#C;#_;#A;#F;#D;#$;#y;static unsafeExposeInternals(Z){return{starts:Z.#C,ttls:Z.#_,autopurgeTimers:Z.#A,sizes:Z.#v,keyMap:Z.#W,keyList:Z.#K,valList:Z.#z,next:Z.#L,prev:Z.#O,get head(){return Z.#j},get tail(){return Z.#U},free:Z.#P,isBackgroundFetch:($)=>Z.#q($),backgroundFetch:($,X,V,z)=>Z.#m($,X,V,z),moveToTail:($)=>Z.#f($),indexes:($)=>Z.#I($),rindexes:($)=>Z.#x($),isStale:($)=>Z.#R($)}}get max(){return this.#Q}get maxSize(){return this.#X}get calculatedSize(){return this.#G}get size(){return this.#Y}get fetchMethod(){return this.#M}get memoMethod(){return this.#B}get dispose(){return this.#V}get onInsert(){return this.#Z}get disposeAfter(){return this.#J}constructor(Z){let{max:$=0,ttl:X,ttlResolution:V=1,ttlAutopurge:z,updateAgeOnGet:J,updateAgeOnHas:Y,allowStale:K,dispose:q,onInsert:W,disposeAfter:H,noDisposeOnSet:G,noUpdateTTL:_,maxSize:U=0,maxEntrySize:j=0,sizeCalculation:A,fetchMethod:w,memoMethod:B,noDeleteOnFetchRejection:O,noDeleteOnStaleGet:v,allowStaleOnFetchRejection:L,allowStaleOnFetchAbort:S,ignoreFetchAbort:y,perf:e}=Z;if(e!==void 0&&typeof e?.now!="function")throw TypeError("perf option must have a now() method if specified");if(this.#H=e??aZ,$!==0&&!L9($))throw TypeError("max option must be a nonnegative integer");let P=$?R8($):Array;if(!P)throw Error("invalid max value: "+$);if(this.#Q=$,this.#X=U,this.maxEntrySize=j||this.#X,this.sizeCalculation=A,this.sizeCalculation){if(!this.#X&&!this.maxEntrySize)throw TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw TypeError("sizeCalculation set to non-function")}if(B!==void 0&&typeof B!="function")throw TypeError("memoMethod must be a function if defined");if(this.#B=B,w!==void 0&&typeof w!="function")throw TypeError("fetchMethod must be a function if specified");if(this.#M=w,this.#D=!!w,this.#W=new Map,this.#K=Array($).fill(void 0),this.#z=Array($).fill(void 0),this.#L=new P($),this.#O=new P($),this.#j=0,this.#U=0,this.#P=tZ.create($),this.#Y=0,this.#G=0,typeof q=="function"&&(this.#V=q),typeof W=="function"&&(this.#Z=W),typeof H=="function"?(this.#J=H,this.#w=[]):(this.#J=void 0,this.#w=void 0),this.#F=!!this.#V,this.#y=!!this.#Z,this.#$=!!this.#J,this.noDisposeOnSet=!!G,this.noUpdateTTL=!!_,this.noDeleteOnFetchRejection=!!O,this.allowStaleOnFetchRejection=!!L,this.allowStaleOnFetchAbort=!!S,this.ignoreFetchAbort=!!y,this.maxEntrySize!==0){if(this.#X!==0&&!L9(this.#X))throw TypeError("maxSize must be a positive integer if specified");if(!L9(this.maxEntrySize))throw TypeError("maxEntrySize must be a positive integer if specified");this.#l()}if(this.allowStale=!!K,this.noDeleteOnStaleGet=!!v,this.updateAgeOnGet=!!J,this.updateAgeOnHas=!!Y,this.ttlResolution=L9(V)||V===0?V:1,this.ttlAutopurge=!!z,this.ttl=X||0,this.ttl){if(!L9(this.ttl))throw TypeError("ttl must be a positive integer if specified");this.#E()}if(this.#Q===0&&this.ttl===0&&this.#X===0)throw TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!this.#Q&&!this.#X){let o="LRU_CACHE_UNBOUNDED";sZ(o)&&(M8.add(o),C8("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",o,Q))}}getRemainingTTL(Z){return this.#W.has(Z)?1/0:0}#E(){let Z=new A0(this.#Q),$=new A0(this.#Q);this.#_=Z,this.#C=$;let X=this.ttlAutopurge?Array(this.#Q):void 0;this.#A=X,this.#u=(J,Y,K=this.#H.now())=>{if($[J]=Y!==0?K:0,Z[J]=Y,X?.[J]&&(clearTimeout(X[J]),X[J]=void 0),Y!==0&&X){let q=setTimeout(()=>{this.#R(J)&&this.#S(this.#K[J],"expire")},Y+1);q.unref&&q.unref(),X[J]=q}},this.#N=(J)=>{$[J]=Z[J]!==0?this.#H.now():0},this.#T=(J,Y)=>{if(Z[Y]){let K=Z[Y],q=$[Y];if(!K||!q)return;J.ttl=K,J.start=q,J.now=V||z();let W=J.now-q;J.remainingTTL=K-W}};let V=0,z=()=>{let J=this.#H.now();if(this.ttlResolution>0){V=J;let Y=setTimeout(()=>V=0,this.ttlResolution);Y.unref&&Y.unref()}return J};this.getRemainingTTL=(J)=>{let Y=this.#W.get(J);if(Y===void 0)return 0;let K=Z[Y],q=$[Y];if(!K||!q)return 1/0;let W=(V||z())-q;return K-W},this.#R=(J)=>{let Y=$[J],K=Z[J];return!!K&&!!Y&&(V||z())-Y>K}}#N=()=>{};#T=()=>{};#u=()=>{};#R=()=>!1;#l(){let Z=new A0(this.#Q);this.#G=0,this.#v=Z,this.#b=($)=>{this.#G-=Z[$],Z[$]=0},this.#h=($,X,V,z)=>{if(this.#q(X))return 0;if(!L9(V))if(z){if(typeof z!="function")throw TypeError("sizeCalculation must be a function");if(V=z(X,$),!L9(V))throw TypeError("sizeCalculation return invalid (expect positive integer)")}else throw TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return V},this.#k=($,X,V)=>{if(Z[$]=X,this.#X){let z=this.#X-Z[$];for(;this.#G>z;)this.#d(!0)}this.#G+=Z[$],V&&(V.entrySize=X,V.totalCalculatedSize=this.#G)}}#b=(Z)=>{};#k=(Z,$,X)=>{};#h=(Z,$,X,V)=>{if(X||V)throw TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0};*#I({allowStale:Z=this.allowStale}={}){if(this.#Y)for(let $=this.#U;!(!this.#g($)||((Z||!this.#R($))&&(yield $),$===this.#j));)$=this.#O[$]}*#x({allowStale:Z=this.allowStale}={}){if(this.#Y)for(let $=this.#j;!(!this.#g($)||((Z||!this.#R($))&&(yield $),$===this.#U));)$=this.#L[$]}#g(Z){return Z!==void 0&&this.#W.get(this.#K[Z])===Z}*entries(){for(let Z of this.#I())this.#z[Z]!==void 0&&this.#K[Z]!==void 0&&!this.#q(this.#z[Z])&&(yield[this.#K[Z],this.#z[Z]])}*rentries(){for(let Z of this.#x())this.#z[Z]!==void 0&&this.#K[Z]!==void 0&&!this.#q(this.#z[Z])&&(yield[this.#K[Z],this.#z[Z]])}*keys(){for(let Z of this.#I()){let $=this.#K[Z];$!==void 0&&!this.#q(this.#z[Z])&&(yield $)}}*rkeys(){for(let Z of this.#x()){let $=this.#K[Z];$!==void 0&&!this.#q(this.#z[Z])&&(yield $)}}*values(){for(let Z of this.#I())this.#z[Z]!==void 0&&!this.#q(this.#z[Z])&&(yield this.#z[Z])}*rvalues(){for(let Z of this.#x())this.#z[Z]!==void 0&&!this.#q(this.#z[Z])&&(yield this.#z[Z])}[Symbol.iterator](){return this.entries()}[Symbol.toStringTag]="LRUCache";find(Z,$={}){for(let X of this.#I()){let V=this.#z[X],z=this.#q(V)?V.__staleWhileFetching:V;if(z!==void 0&&Z(z,this.#K[X],this))return this.get(this.#K[X],$)}}forEach(Z,$=this){for(let X of this.#I()){let V=this.#z[X],z=this.#q(V)?V.__staleWhileFetching:V;z!==void 0&&Z.call($,z,this.#K[X],this)}}rforEach(Z,$=this){for(let X of this.#x()){let V=this.#z[X],z=this.#q(V)?V.__staleWhileFetching:V;z!==void 0&&Z.call($,z,this.#K[X],this)}}purgeStale(){let Z=!1;for(let $ of this.#x({allowStale:!0}))this.#R($)&&(this.#S(this.#K[$],"expire"),Z=!0);return Z}info(Z){let $=this.#W.get(Z);if($===void 0)return;let X=this.#z[$],V=this.#q(X)?X.__staleWhileFetching:X;if(V===void 0)return;let z={value:V};if(this.#_&&this.#C){let J=this.#_[$],Y=this.#C[$];if(J&&Y){let K=J-(this.#H.now()-Y);z.ttl=K,z.start=Date.now()}}return this.#v&&(z.size=this.#v[$]),z}dump(){let Z=[];for(let $ of this.#I({allowStale:!0})){let X=this.#K[$],V=this.#z[$],z=this.#q(V)?V.__staleWhileFetching:V;if(z===void 0||X===void 0)continue;let J={value:z};if(this.#_&&this.#C){J.ttl=this.#_[$];let Y=this.#H.now()-this.#C[$];J.start=Math.floor(Date.now()-Y)}this.#v&&(J.size=this.#v[$]),Z.unshift([X,J])}return Z}load(Z){this.clear();for(let[$,X]of Z){if(X.start){let V=Date.now()-X.start;X.start=this.#H.now()-V}this.set($,X.value,X)}}set(Z,$,X={}){if($===void 0)return this.delete(Z),this;let{ttl:V=this.ttl,start:z,noDisposeOnSet:J=this.noDisposeOnSet,sizeCalculation:Y=this.sizeCalculation,status:K}=X,{noUpdateTTL:q=this.noUpdateTTL}=X,W=this.#h(Z,$,X.size||0,Y);if(this.maxEntrySize&&W>this.maxEntrySize)return K&&(K.set="miss",K.maxEntrySizeExceeded=!0),this.#S(Z,"set"),this;let H=this.#Y===0?void 0:this.#W.get(Z);if(H===void 0)H=this.#Y===0?this.#U:this.#P.length!==0?this.#P.pop():this.#Y===this.#Q?this.#d(!1):this.#Y,this.#K[H]=Z,this.#z[H]=$,this.#W.set(Z,H),this.#L[this.#U]=H,this.#O[H]=this.#U,this.#U=H,this.#Y++,this.#k(H,W,K),K&&(K.set="add"),q=!1,this.#y&&this.#Z?.($,Z,"add");else{this.#f(H);let G=this.#z[H];if($!==G){if(this.#D&&this.#q(G)){G.__abortController.abort(Error("replaced"));let{__staleWhileFetching:_}=G;_!==void 0&&!J&&(this.#F&&this.#V?.(_,Z,"set"),this.#$&&this.#w?.push([_,Z,"set"]))}else J||(this.#F&&this.#V?.(G,Z,"set"),this.#$&&this.#w?.push([G,Z,"set"]));if(this.#b(H),this.#k(H,W,K),this.#z[H]=$,K){K.set="replace";let _=G&&this.#q(G)?G.__staleWhileFetching:G;_!==void 0&&(K.oldValue=_)}}else K&&(K.set="update");this.#y&&this.onInsert?.($,Z,$===G?"update":"replace")}if(V!==0&&!this.#_&&this.#E(),this.#_&&(q||this.#u(H,V,z),K&&this.#T(K,H)),!J&&this.#$&&this.#w){let G=this.#w,_;for(;_=G?.shift();)this.#J?.(..._)}return this}pop(){try{for(;this.#Y;){let Z=this.#z[this.#j];if(this.#d(!0),this.#q(Z)){if(Z.__staleWhileFetching)return Z.__staleWhileFetching}else if(Z!==void 0)return Z}}finally{if(this.#$&&this.#w){let Z=this.#w,$;for(;$=Z?.shift();)this.#J?.(...$)}}}#d(Z){let $=this.#j,X=this.#K[$],V=this.#z[$];return this.#D&&this.#q(V)?V.__abortController.abort(Error("evicted")):(this.#F||this.#$)&&(this.#F&&this.#V?.(V,X,"evict"),this.#$&&this.#w?.push([V,X,"evict"])),this.#b($),this.#A?.[$]&&(clearTimeout(this.#A[$]),this.#A[$]=void 0),Z&&(this.#K[$]=void 0,this.#z[$]=void 0,this.#P.push($)),this.#Y===1?(this.#j=this.#U=0,this.#P.length=0):this.#j=this.#L[$],this.#W.delete(X),this.#Y--,$}has(Z,$={}){let{updateAgeOnHas:X=this.updateAgeOnHas,status:V}=$,z=this.#W.get(Z);if(z!==void 0){let J=this.#z[z];if(this.#q(J)&&J.__staleWhileFetching===void 0)return!1;if(this.#R(z))V&&(V.has="stale",this.#T(V,z));else return X&&this.#N(z),V&&(V.has="hit",this.#T(V,z)),!0}else V&&(V.has="miss");return!1}peek(Z,$={}){let{allowStale:X=this.allowStale}=$,V=this.#W.get(Z);if(V===void 0||!X&&this.#R(V))return;let z=this.#z[V];return this.#q(z)?z.__staleWhileFetching:z}#m(Z,$,X,V){let z=$===void 0?void 0:this.#z[$];if(this.#q(z))return z;let J=new B0,{signal:Y}=X;Y?.addEventListener("abort",()=>J.abort(Y.reason),{signal:J.signal});let K={signal:J.signal,options:X,context:V},q=(j,A=!1)=>{let{aborted:w}=J.signal,B=X.ignoreFetchAbort&&j!==void 0,O=X.ignoreFetchAbort||!!(X.allowStaleOnFetchAbort&&j!==void 0);if(X.status&&(w&&!A?(X.status.fetchAborted=!0,X.status.fetchError=J.signal.reason,B&&(X.status.fetchAbortIgnored=!0)):X.status.fetchResolved=!0),w&&!B&&!A)return H(J.signal.reason,O);let v=_,L=this.#z[$];return(L===_||B&&A&&L===void 0)&&(j===void 0?v.__staleWhileFetching!==void 0?this.#z[$]=v.__staleWhileFetching:this.#S(Z,"fetch"):(X.status&&(X.status.fetchUpdated=!0),this.set(Z,j,K.options))),j},W=(j)=>(X.status&&(X.status.fetchRejected=!0,X.status.fetchError=j),H(j,!1)),H=(j,A)=>{let{aborted:w}=J.signal,B=w&&X.allowStaleOnFetchAbort,O=B||X.allowStaleOnFetchRejection,v=O||X.noDeleteOnFetchRejection,L=_;if(this.#z[$]===_&&(!v||!A&&L.__staleWhileFetching===void 0?this.#S(Z,"fetch"):B||(this.#z[$]=L.__staleWhileFetching)),O)return X.status&&L.__staleWhileFetching!==void 0&&(X.status.returnedStale=!0),L.__staleWhileFetching;if(L.__returned===L)throw j},G=(j,A)=>{let w=this.#M?.(Z,z,K);w&&w instanceof Promise&&w.then((B)=>j(B===void 0?void 0:B),A),J.signal.addEventListener("abort",()=>{(!X.ignoreFetchAbort||X.allowStaleOnFetchAbort)&&(j(void 0),X.allowStaleOnFetchAbort&&(j=(B)=>q(B,!0)))})};X.status&&(X.status.fetchDispatched=!0);let _=new Promise(G).then(q,W),U=Object.assign(_,{__abortController:J,__staleWhileFetching:z,__returned:void 0});return $===void 0?(this.set(Z,U,{...K.options,status:void 0}),$=this.#W.get(Z)):this.#z[$]=U,U}#q(Z){if(!this.#D)return!1;let $=Z;return!!$&&$ instanceof Promise&&$.hasOwnProperty("__staleWhileFetching")&&$.__abortController instanceof B0}async fetch(Z,$={}){let{allowStale:X=this.allowStale,updateAgeOnGet:V=this.updateAgeOnGet,noDeleteOnStaleGet:z=this.noDeleteOnStaleGet,ttl:J=this.ttl,noDisposeOnSet:Y=this.noDisposeOnSet,size:K=0,sizeCalculation:q=this.sizeCalculation,noUpdateTTL:W=this.noUpdateTTL,noDeleteOnFetchRejection:H=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:G=this.allowStaleOnFetchRejection,ignoreFetchAbort:_=this.ignoreFetchAbort,allowStaleOnFetchAbort:U=this.allowStaleOnFetchAbort,context:j,forceRefresh:A=!1,status:w,signal:B}=$;if(!this.#D)return w&&(w.fetch="get"),this.get(Z,{allowStale:X,updateAgeOnGet:V,noDeleteOnStaleGet:z,status:w});let O={allowStale:X,updateAgeOnGet:V,noDeleteOnStaleGet:z,ttl:J,noDisposeOnSet:Y,size:K,sizeCalculation:q,noUpdateTTL:W,noDeleteOnFetchRejection:H,allowStaleOnFetchRejection:G,allowStaleOnFetchAbort:U,ignoreFetchAbort:_,status:w,signal:B},v=this.#W.get(Z);if(v===void 0){w&&(w.fetch="miss");let L=this.#m(Z,v,O,j);return L.__returned=L}else{let L=this.#z[v];if(this.#q(L)){let P=X&&L.__staleWhileFetching!==void 0;return w&&(w.fetch="inflight",P&&(w.returnedStale=!0)),P?L.__staleWhileFetching:L.__returned=L}let S=this.#R(v);if(!A&&!S)return w&&(w.fetch="hit"),this.#f(v),V&&this.#N(v),w&&this.#T(w,v),L;let y=this.#m(Z,v,O,j),e=y.__staleWhileFetching!==void 0&&X;return w&&(w.fetch=S?"stale":"refresh",e&&S&&(w.returnedStale=!0)),e?y.__staleWhileFetching:y.__returned=y}}async forceFetch(Z,$={}){let X=await this.fetch(Z,$);if(X===void 0)throw Error("fetch() returned undefined");return X}memo(Z,$={}){let X=this.#B;if(!X)throw Error("no memoMethod provided to constructor");let{context:V,forceRefresh:z,...J}=$,Y=this.get(Z,J);if(!z&&Y!==void 0)return Y;let K=X(Z,Y,{options:J,context:V});return this.set(Z,K,J),K}get(Z,$={}){let{allowStale:X=this.allowStale,updateAgeOnGet:V=this.updateAgeOnGet,noDeleteOnStaleGet:z=this.noDeleteOnStaleGet,status:J}=$,Y=this.#W.get(Z);if(Y!==void 0){let K=this.#z[Y],q=this.#q(K);return J&&this.#T(J,Y),this.#R(Y)?(J&&(J.get="stale"),q?(J&&X&&K.__staleWhileFetching!==void 0&&(J.returnedStale=!0),X?K.__staleWhileFetching:void 0):(z||this.#S(Z,"expire"),J&&X&&(J.returnedStale=!0),X?K:void 0)):(J&&(J.get="hit"),q?K.__staleWhileFetching:(this.#f(Y),V&&this.#N(Y),K))}else J&&(J.get="miss")}#c(Z,$){this.#O[$]=Z,this.#L[Z]=$}#f(Z){Z!==this.#U&&(Z===this.#j?this.#j=this.#L[Z]:this.#c(this.#O[Z],this.#L[Z]),this.#c(this.#U,Z),this.#U=Z)}delete(Z){return this.#S(Z,"delete")}#S(Z,$){let X=!1;if(this.#Y!==0){let V=this.#W.get(Z);if(V!==void 0)if(this.#A?.[V]&&(clearTimeout(this.#A?.[V]),this.#A[V]=void 0),X=!0,this.#Y===1)this.#p($);else{this.#b(V);let z=this.#z[V];if(this.#q(z)?z.__abortController.abort(Error("deleted")):(this.#F||this.#$)&&(this.#F&&this.#V?.(z,Z,$),this.#$&&this.#w?.push([z,Z,$])),this.#W.delete(Z),this.#K[V]=void 0,this.#z[V]=void 0,V===this.#U)this.#U=this.#O[V];else if(V===this.#j)this.#j=this.#L[V];else{let J=this.#O[V];this.#L[J]=this.#L[V];let Y=this.#L[V];this.#O[Y]=this.#O[V]}this.#Y--,this.#P.push(V)}}if(this.#$&&this.#w?.length){let V=this.#w,z;for(;z=V?.shift();)this.#J?.(...z)}return X}clear(){return this.#p("delete")}#p(Z){for(let $ of this.#x({allowStale:!0})){let X=this.#z[$];if(this.#q(X))X.__abortController.abort(Error("deleted"));else{let V=this.#K[$];this.#F&&this.#V?.(X,V,Z),this.#$&&this.#w?.push([X,V,Z])}}if(this.#W.clear(),this.#z.fill(void 0),this.#K.fill(void 0),this.#_&&this.#C){this.#_.fill(0),this.#C.fill(0);for(let $ of this.#A??[])$!==void 0&&clearTimeout($);this.#A?.fill(void 0)}if(this.#v&&this.#v.fill(0),this.#j=0,this.#U=0,this.#P.length=0,this.#G=0,this.#Y=0,this.#$&&this.#w){let $=this.#w,X;for(;X=$?.shift();)this.#J?.(...X)}}};import{posix as q5,win32 as LQ}from"path";import{fileURLToPath as W5}from"url";import{lstatSync as H5,readdir as G5,readdirSync as _5,readlinkSync as j5,realpathSync as U5}from"fs";import*as w5 from"fs";import{lstat as B5,readdir as L5,readlink as F5,realpath as O5}from"fs/promises";import{EventEmitter as UQ}from"events";import I8 from"stream";import{StringDecoder as eZ}from"string_decoder";var P8=typeof process==="object"&&process?process:{stdout:null,stderr:null},Q5=(Q)=>!!Q&&typeof Q==="object"&&(Q instanceof R9||Q instanceof I8||Z5(Q)||$5(Q)),Z5=(Q)=>!!Q&&typeof Q==="object"&&Q instanceof UQ&&typeof Q.pipe==="function"&&Q.pipe!==I8.Writable.prototype.pipe,$5=(Q)=>!!Q&&typeof Q==="object"&&Q instanceof UQ&&typeof Q.write==="function"&&typeof Q.end==="function",U9=Symbol("EOF"),w9=Symbol("maybeEmitEnd"),F9=Symbol("emittedEnd"),L0=Symbol("emittingEnd"),s9=Symbol("emittedError"),F0=Symbol("closed"),D8=Symbol("read"),O0=Symbol("flush"),N8=Symbol("flushChunk"),s=Symbol("encoding"),T9=Symbol("decoder"),x=Symbol("flowing"),t9=Symbol("paused"),y9=Symbol("resume"),E=Symbol("buffer"),u=Symbol("pipes"),T=Symbol("bufferLength"),WQ=Symbol("bufferPush"),v0=Symbol("bufferShift"),f=Symbol("objectMode"),N=Symbol("destroyed"),HQ=Symbol("error"),GQ=Symbol("emitData"),S8=Symbol("emitEnd"),_Q=Symbol("emitEnd2"),J9=Symbol("async"),jQ=Symbol("abort"),M0=Symbol("aborted"),e9=Symbol("signal"),C9=Symbol("dataListeners"),m=Symbol("discarded"),Q0=(Q)=>Promise.resolve().then(Q),X5=(Q)=>Q(),V5=(Q)=>Q==="end"||Q==="finish"||Q==="prefinish",z5=(Q)=>Q instanceof ArrayBuffer||!!Q&&typeof Q==="object"&&Q.constructor&&Q.constructor.name==="ArrayBuffer"&&Q.byteLength>=0,J5=(Q)=>!Buffer.isBuffer(Q)&&ArrayBuffer.isView(Q);class wQ{src;dest;opts;ondrain;constructor(Q,Z,$){this.src=Q,this.dest=Z,this.opts=$,this.ondrain=()=>Q[y9](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(Q){}end(){if(this.unpipe(),this.opts.end)this.dest.end()}}class x8 extends wQ{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe()}constructor(Q,Z,$){super(Q,Z,$);this.proxyErrors=(X)=>this.dest.emit("error",X),Q.on("error",this.proxyErrors)}}var Y5=(Q)=>!!Q.objectMode,K5=(Q)=>!Q.objectMode&&!!Q.encoding&&Q.encoding!=="buffer";class R9 extends UQ{[x]=!1;[t9]=!1;[u]=[];[E]=[];[f];[s];[J9];[T9];[U9]=!1;[F9]=!1;[L0]=!1;[F0]=!1;[s9]=null;[T]=0;[N]=!1;[e9];[M0]=!1;[C9]=0;[m]=!1;writable=!0;readable=!0;constructor(...Q){let Z=Q[0]||{};super();if(Z.objectMode&&typeof Z.encoding==="string")throw TypeError("Encoding and objectMode may not be used together");if(Y5(Z))this[f]=!0,this[s]=null;else if(K5(Z))this[s]=Z.encoding,this[f]=!1;else this[f]=!1,this[s]=null;if(this[J9]=!!Z.async,this[T9]=this[s]?new eZ(this[s]):null,Z&&Z.debugExposeBuffer===!0)Object.defineProperty(this,"buffer",{get:()=>this[E]});if(Z&&Z.debugExposePipes===!0)Object.defineProperty(this,"pipes",{get:()=>this[u]});let{signal:$}=Z;if($)if(this[e9]=$,$.aborted)this[jQ]();else $.addEventListener("abort",()=>this[jQ]())}get bufferLength(){return this[T]}get encoding(){return this[s]}set encoding(Q){throw Error("Encoding must be set at instantiation time")}setEncoding(Q){throw Error("Encoding must be set at instantiation time")}get objectMode(){return this[f]}set objectMode(Q){throw Error("objectMode must be set at instantiation time")}get["async"](){return this[J9]}set["async"](Q){this[J9]=this[J9]||!!Q}[jQ](){this[M0]=!0,this.emit("abort",this[e9]?.reason),this.destroy(this[e9]?.reason)}get aborted(){return this[M0]}set aborted(Q){}write(Q,Z,$){if(this[M0])return!1;if(this[U9])throw Error("write after end");if(this[N])return this.emit("error",Object.assign(Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),!0;if(typeof Z==="function")$=Z,Z="utf8";if(!Z)Z="utf8";let X=this[J9]?Q0:X5;if(!this[f]&&!Buffer.isBuffer(Q)){if(J5(Q))Q=Buffer.from(Q.buffer,Q.byteOffset,Q.byteLength);else if(z5(Q))Q=Buffer.from(Q);else if(typeof Q!=="string")throw Error("Non-contiguous data written to non-objectMode stream")}if(this[f]){if(this[x]&&this[T]!==0)this[O0](!0);if(this[x])this.emit("data",Q);else this[WQ](Q);if(this[T]!==0)this.emit("readable");if($)X($);return this[x]}if(!Q.length){if(this[T]!==0)this.emit("readable");if($)X($);return this[x]}if(typeof Q==="string"&&!(Z===this[s]&&!this[T9]?.lastNeed))Q=Buffer.from(Q,Z);if(Buffer.isBuffer(Q)&&this[s])Q=this[T9].write(Q);if(this[x]&&this[T]!==0)this[O0](!0);if(this[x])this.emit("data",Q);else this[WQ](Q);if(this[T]!==0)this.emit("readable");if($)X($);return this[x]}read(Q){if(this[N])return null;if(this[m]=!1,this[T]===0||Q===0||Q&&Q>this[T])return this[w9](),null;if(this[f])Q=null;if(this[E].length>1&&!this[f])this[E]=[this[s]?this[E].join(""):Buffer.concat(this[E],this[T])];let Z=this[D8](Q||null,this[E][0]);return this[w9](),Z}[D8](Q,Z){if(this[f])this[v0]();else{let $=Z;if(Q===$.length||Q===null)this[v0]();else if(typeof $==="string")this[E][0]=$.slice(Q),Z=$.slice(0,Q),this[T]-=Q;else this[E][0]=$.subarray(Q),Z=$.subarray(0,Q),this[T]-=Q}if(this.emit("data",Z),!this[E].length&&!this[U9])this.emit("drain");return Z}end(Q,Z,$){if(typeof Q==="function")$=Q,Q=void 0;if(typeof Z==="function")$=Z,Z="utf8";if(Q!==void 0)this.write(Q,Z);if($)this.once("end",$);if(this[U9]=!0,this.writable=!1,this[x]||!this[t9])this[w9]();return this}[y9](){if(this[N])return;if(!this[C9]&&!this[u].length)this[m]=!0;if(this[t9]=!1,this[x]=!0,this.emit("resume"),this[E].length)this[O0]();else if(this[U9])this[w9]();else this.emit("drain")}resume(){return this[y9]()}pause(){this[x]=!1,this[t9]=!0,this[m]=!1}get destroyed(){return this[N]}get flowing(){return this[x]}get paused(){return this[t9]}[WQ](Q){if(this[f])this[T]+=1;else this[T]+=Q.length;this[E].push(Q)}[v0](){if(this[f])this[T]-=1;else this[T]-=this[E][0].length;return this[E].shift()}[O0](Q=!1){do;while(this[N8](this[v0]())&&this[E].length);if(!Q&&!this[E].length&&!this[U9])this.emit("drain")}[N8](Q){return this.emit("data",Q),this[x]}pipe(Q,Z){if(this[N])return Q;this[m]=!1;let $=this[F9];if(Z=Z||{},Q===P8.stdout||Q===P8.stderr)Z.end=!1;else Z.end=Z.end!==!1;if(Z.proxyErrors=!!Z.proxyErrors,$){if(Z.end)Q.end()}else if(this[u].push(!Z.proxyErrors?new wQ(this,Q,Z):new x8(this,Q,Z)),this[J9])Q0(()=>this[y9]());else this[y9]();return Q}unpipe(Q){let Z=this[u].find(($)=>$.dest===Q);if(Z){if(this[u].length===1){if(this[x]&&this[C9]===0)this[x]=!1;this[u]=[]}else this[u].splice(this[u].indexOf(Z),1);Z.unpipe()}}addListener(Q,Z){return this.on(Q,Z)}on(Q,Z){let $=super.on(Q,Z);if(Q==="data"){if(this[m]=!1,this[C9]++,!this[u].length&&!this[x])this[y9]()}else if(Q==="readable"&&this[T]!==0)super.emit("readable");else if(V5(Q)&&this[F9])super.emit(Q),this.removeAllListeners(Q);else if(Q==="error"&&this[s9]){let X=Z;if(this[J9])Q0(()=>X.call(this,this[s9]));else X.call(this,this[s9])}return $}removeListener(Q,Z){return this.off(Q,Z)}off(Q,Z){let $=super.off(Q,Z);if(Q==="data"){if(this[C9]=this.listeners("data").length,this[C9]===0&&!this[m]&&!this[u].length)this[x]=!1}return $}removeAllListeners(Q){let Z=super.removeAllListeners(Q);if(Q==="data"||Q===void 0){if(this[C9]=0,!this[m]&&!this[u].length)this[x]=!1}return Z}get emittedEnd(){return this[F9]}[w9](){if(!this[L0]&&!this[F9]&&!this[N]&&this[E].length===0&&this[U9]){if(this[L0]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[F0])this.emit("close");this[L0]=!1}}emit(Q,...Z){let $=Z[0];if(Q!=="error"&&Q!=="close"&&Q!==N&&this[N])return!1;else if(Q==="data")return!this[f]&&!$?!1:this[J9]?(Q0(()=>this[GQ]($)),!0):this[GQ]($);else if(Q==="end")return this[S8]();else if(Q==="close"){if(this[F0]=!0,!this[F9]&&!this[N])return!1;let V=super.emit("close");return this.removeAllListeners("close"),V}else if(Q==="error"){this[s9]=$,super.emit(HQ,$);let V=!this[e9]||this.listeners("error").length?super.emit("error",$):!1;return this[w9](),V}else if(Q==="resume"){let V=super.emit("resume");return this[w9](),V}else if(Q==="finish"||Q==="prefinish"){let V=super.emit(Q);return this.removeAllListeners(Q),V}let X=super.emit(Q,...Z);return this[w9](),X}[GQ](Q){for(let $ of this[u])if($.dest.write(Q)===!1)this.pause();let Z=this[m]?!1:super.emit("data",Q);return this[w9](),Z}[S8](){if(this[F9])return!1;return this[F9]=!0,this.readable=!1,this[J9]?(Q0(()=>this[_Q]()),!0):this[_Q]()}[_Q](){if(this[T9]){let Z=this[T9].end();if(Z){for(let $ of this[u])$.dest.write(Z);if(!this[m])super.emit("data",Z)}}for(let Z of this[u])Z.end();let Q=super.emit("end");return this.removeAllListeners("end"),Q}async collect(){let Q=Object.assign([],{dataLength:0});if(!this[f])Q.dataLength=0;let Z=this.promise();return this.on("data",($)=>{if(Q.push($),!this[f])Q.dataLength+=$.length}),await Z,Q}async concat(){if(this[f])throw Error("cannot concat in objectMode");let Q=await this.collect();return this[s]?Q.join(""):Buffer.concat(Q,Q.dataLength)}async promise(){return new Promise((Q,Z)=>{this.on(N,()=>Z(Error("stream destroyed"))),this.on("error",($)=>Z($)),this.on("end",()=>Q())})}[Symbol.asyncIterator](){this[m]=!1;let Q=!1,Z=async()=>{return this.pause(),Q=!0,{value:void 0,done:!0}};return{next:()=>{if(Q)return Z();let X=this.read();if(X!==null)return Promise.resolve({done:!1,value:X});if(this[U9])return Z();let V,z,J=(W)=>{this.off("data",Y),this.off("end",K),this.off(N,q),Z(),z(W)},Y=(W)=>{this.off("error",J),this.off("end",K),this.off(N,q),this.pause(),V({value:W,done:!!this[U9]})},K=()=>{this.off("error",J),this.off("data",Y),this.off(N,q),Z(),V({done:!0,value:void 0})},q=()=>J(Error("stream destroyed"));return new Promise((W,H)=>{z=H,V=W,this.once(N,q),this.once("error",J),this.once("end",K),this.once("data",Y)})},throw:Z,return:Z,[Symbol.asyncIterator](){return this},[Symbol.asyncDispose]:async()=>{}}}[Symbol.iterator](){this[m]=!1;let Q=!1,Z=()=>{return this.pause(),this.off(HQ,Z),this.off(N,Z),this.off("end",Z),Q=!0,{done:!0,value:void 0}},$=()=>{if(Q)return Z();let X=this.read();return X===null?Z():{done:!1,value:X}};return this.once("end",Z),this.once(HQ,Z),this.once(N,Z),{next:$,throw:Z,return:Z,[Symbol.iterator](){return this},[Symbol.dispose]:()=>{}}}destroy(Q){if(this[N]){if(Q)this.emit("error",Q);else this.emit(N);return this}this[N]=!0,this[m]=!0,this[E].length=0,this[T]=0;let Z=this;if(typeof Z.close==="function"&&!this[F0])Z.close();if(Q)this.emit("error",Q);else this.emit(N);return this}static get isStream(){return Q5}}var A5=U5.native,$0={lstatSync:H5,readdir:G5,readdirSync:_5,readlinkSync:j5,realpathSync:A5,promises:{lstat:B5,readdir:L5,readlink:F5,realpath:O5}},f8=(Q)=>!Q||Q===$0||Q===w5?$0:{...$0,...Q,promises:{...$0.promises,...Q.promises||{}}},b8=/^\\\\\?\\([a-z]:)\\?$/i,v5=(Q)=>Q.replace(/\//g,"\\").replace(b8,"$1\\"),M5=/[\\\/]/,n=0,u8=1,h8=2,Y9=4,g8=6,d8=8,P9=10,m8=12,i=15,Z0=~i,AQ=16,E8=32,X0=64,t=128,C0=256,P0=512,T8=X0|t|P0,C5=1023,BQ=(Q)=>Q.isFile()?d8:Q.isDirectory()?Y9:Q.isSymbolicLink()?P9:Q.isCharacterDevice()?h8:Q.isBlockDevice()?g8:Q.isSocket()?m8:Q.isFIFO()?u8:n,y8=new a9({max:4096}),V0=(Q)=>{let Z=y8.get(Q);if(Z)return Z;let $=Q.normalize("NFKD");return y8.set(Q,$),$},k8=new a9({max:4096}),R0=(Q)=>{let Z=k8.get(Q);if(Z)return Z;let $=V0(Q.toLowerCase());return k8.set(Q,$),$};class FQ extends a9{constructor(){super({max:256})}}class c8 extends a9{constructor(Q=16384){super({maxSize:Q,sizeCalculation:(Z)=>Z.length+1})}}var l8=Symbol("PathScurry setAsCwd");class h{name;root;roots;parent;nocase;isCWD=!1;#Q;#X;get dev(){return this.#X}#V;get mode(){return this.#V}#Z;get nlink(){return this.#Z}#J;get uid(){return this.#J}#M;get gid(){return this.#M}#B;get rdev(){return this.#B}#H;get blksize(){return this.#H}#Y;get ino(){return this.#Y}#G;get size(){return this.#G}#W;get blocks(){return this.#W}#K;get atimeMs(){return this.#K}#z;get mtimeMs(){return this.#z}#L;get ctimeMs(){return this.#L}#O;get birthtimeMs(){return this.#O}#j;get atime(){return this.#j}#U;get mtime(){return this.#U}#P;get ctime(){return this.#P}#w;get birthtime(){return this.#w}#v;#C;#_;#A;#F;#D;#$;#y;#E;#N;get parentPath(){return(this.parent||this).fullpath()}get path(){return this.parentPath}constructor(Q,Z=n,$,X,V,z,J){if(this.name=Q,this.#v=V?R0(Q):V0(Q),this.#$=Z&C5,this.nocase=V,this.roots=X,this.root=$||this,this.#y=z,this.#_=J.fullpath,this.#F=J.relative,this.#D=J.relativePosix,this.parent=J.parent,this.parent)this.#Q=this.parent.#Q;else this.#Q=f8(J.fs)}depth(){if(this.#C!==void 0)return this.#C;if(!this.parent)return this.#C=0;return this.#C=this.parent.depth()+1}childrenCache(){return this.#y}resolve(Q){if(!Q)return this;let Z=this.getRootString(Q),X=Q.substring(Z.length).split(this.splitSep);return Z?this.getRoot(Z).#T(X):this.#T(X)}#T(Q){let Z=this;for(let $ of Q)Z=Z.child($);return Z}children(){let Q=this.#y.get(this);if(Q)return Q;let Z=Object.assign([],{provisional:0});return this.#y.set(this,Z),this.#$&=~AQ,Z}child(Q,Z){if(Q===""||Q===".")return this;if(Q==="..")return this.parent||this;let $=this.children(),X=this.nocase?R0(Q):V0(Q);for(let Y of $)if(Y.#v===X)return Y;let V=this.parent?this.sep:"",z=this.#_?this.#_+V+Q:void 0,J=this.newChild(Q,n,{...Z,parent:this,fullpath:z});if(!this.canReaddir())J.#$|=t;return $.push(J),J}relative(){if(this.isCWD)return"";if(this.#F!==void 0)return this.#F;let Q=this.name,Z=this.parent;if(!Z)return this.#F=this.name;let $=Z.relative();return $+(!$||!Z.parent?"":this.sep)+Q}relativePosix(){if(this.sep==="/")return this.relative();if(this.isCWD)return"";if(this.#D!==void 0)return this.#D;let Q=this.name,Z=this.parent;if(!Z)return this.#D=this.fullpathPosix();let $=Z.relativePosix();return $+(!$||!Z.parent?"":"/")+Q}fullpath(){if(this.#_!==void 0)return this.#_;let Q=this.name,Z=this.parent;if(!Z)return this.#_=this.name;let X=Z.fullpath()+(!Z.parent?"":this.sep)+Q;return this.#_=X}fullpathPosix(){if(this.#A!==void 0)return this.#A;if(this.sep==="/")return this.#A=this.fullpath();if(!this.parent){let X=this.fullpath().replace(/\\/g,"/");if(/^[a-z]:\//i.test(X))return this.#A=`//?/${X}`;else return this.#A=X}let Q=this.parent,Z=Q.fullpathPosix(),$=Z+(!Z||!Q.parent?"":"/")+this.name;return this.#A=$}isUnknown(){return(this.#$&i)===n}isType(Q){return this[`is${Q}`]()}getType(){return this.isUnknown()?"Unknown":this.isDirectory()?"Directory":this.isFile()?"File":this.isSymbolicLink()?"SymbolicLink":this.isFIFO()?"FIFO":this.isCharacterDevice()?"CharacterDevice":this.isBlockDevice()?"BlockDevice":this.isSocket()?"Socket":"Unknown"}isFile(){return(this.#$&i)===d8}isDirectory(){return(this.#$&i)===Y9}isCharacterDevice(){return(this.#$&i)===h8}isBlockDevice(){return(this.#$&i)===g8}isFIFO(){return(this.#$&i)===u8}isSocket(){return(this.#$&i)===m8}isSymbolicLink(){return(this.#$&P9)===P9}lstatCached(){return this.#$&E8?this:void 0}readlinkCached(){return this.#E}realpathCached(){return this.#N}readdirCached(){let Q=this.children();return Q.slice(0,Q.provisional)}canReadlink(){if(this.#E)return!0;if(!this.parent)return!1;let Q=this.#$&i;return!(Q!==n&&Q!==P9||this.#$&C0||this.#$&t)}calledReaddir(){return!!(this.#$&AQ)}isENOENT(){return!!(this.#$&t)}isNamed(Q){return!this.nocase?this.#v===V0(Q):this.#v===R0(Q)}async readlink(){let Q=this.#E;if(Q)return Q;if(!this.canReadlink())return;if(!this.parent)return;try{let Z=await this.#Q.promises.readlink(this.fullpath()),$=(await this.parent.realpath())?.resolve(Z);if($)return this.#E=$}catch(Z){this.#x(Z.code);return}}readlinkSync(){let Q=this.#E;if(Q)return Q;if(!this.canReadlink())return;if(!this.parent)return;try{let Z=this.#Q.readlinkSync(this.fullpath()),$=this.parent.realpathSync()?.resolve(Z);if($)return this.#E=$}catch(Z){this.#x(Z.code);return}}#u(Q){this.#$|=AQ;for(let Z=Q.provisional;Z<Q.length;Z++){let $=Q[Z];if($)$.#R()}}#R(){if(this.#$&t)return;this.#$=(this.#$|t)&Z0,this.#l()}#l(){let Q=this.children();Q.provisional=0;for(let Z of Q)Z.#R()}#b(){this.#$|=P0,this.#k()}#k(){if(this.#$&X0)return;let Q=this.#$;if((Q&i)===Y9)Q&=Z0;this.#$=Q|X0,this.#l()}#h(Q=""){if(Q==="ENOTDIR"||Q==="EPERM")this.#k();else if(Q==="ENOENT")this.#R();else this.children().provisional=0}#I(Q=""){if(Q==="ENOTDIR")this.parent.#k();else if(Q==="ENOENT")this.#R()}#x(Q=""){let Z=this.#$;if(Z|=C0,Q==="ENOENT")Z|=t;if(Q==="EINVAL"||Q==="UNKNOWN")Z&=Z0;if(this.#$=Z,Q==="ENOTDIR"&&this.parent)this.parent.#k()}#g(Q,Z){return this.#m(Q,Z)||this.#d(Q,Z)}#d(Q,Z){let $=BQ(Q),X=this.newChild(Q.name,$,{parent:this}),V=X.#$&i;if(V!==Y9&&V!==P9&&V!==n)X.#$|=X0;return Z.unshift(X),Z.provisional++,X}#m(Q,Z){for(let $=Z.provisional;$<Z.length;$++){let X=Z[$];if((this.nocase?R0(Q.name):V0(Q.name))!==X.#v)continue;return this.#q(Q,X,$,Z)}}#q(Q,Z,$,X){let V=Z.name;if(Z.#$=Z.#$&Z0|BQ(Q),V!==Q.name)Z.name=Q.name;if($!==X.provisional){if($===X.length-1)X.pop();else X.splice($,1);X.unshift(Z)}return X.provisional++,Z}async lstat(){if((this.#$&t)===0)try{return this.#c(await this.#Q.promises.lstat(this.fullpath())),this}catch(Q){this.#I(Q.code)}}lstatSync(){if((this.#$&t)===0)try{return this.#c(this.#Q.lstatSync(this.fullpath())),this}catch(Q){this.#I(Q.code)}}#c(Q){let{atime:Z,atimeMs:$,birthtime:X,birthtimeMs:V,blksize:z,blocks:J,ctime:Y,ctimeMs:K,dev:q,gid:W,ino:H,mode:G,mtime:_,mtimeMs:U,nlink:j,rdev:A,size:w,uid:B}=Q;this.#j=Z,this.#K=$,this.#w=X,this.#O=V,this.#H=z,this.#W=J,this.#P=Y,this.#L=K,this.#X=q,this.#M=W,this.#Y=H,this.#V=G,this.#U=_,this.#z=U,this.#Z=j,this.#B=A,this.#G=w,this.#J=B;let O=BQ(Q);if(this.#$=this.#$&Z0|O|E8,O!==n&&O!==Y9&&O!==P9)this.#$|=X0}#f=[];#S=!1;#p(Q){this.#S=!1;let Z=this.#f.slice();this.#f.length=0,Z.forEach(($)=>$(null,Q))}readdirCB(Q,Z=!1){if(!this.canReaddir()){if(Z)Q(null,[]);else queueMicrotask(()=>Q(null,[]));return}let $=this.children();if(this.calledReaddir()){let V=$.slice(0,$.provisional);if(Z)Q(null,V);else queueMicrotask(()=>Q(null,V));return}if(this.#f.push(Q),this.#S)return;this.#S=!0;let X=this.fullpath();this.#Q.readdir(X,{withFileTypes:!0},(V,z)=>{if(V)this.#h(V.code),$.provisional=0;else{for(let J of z)this.#g(J,$);this.#u($)}this.#p($.slice(0,$.provisional));return})}#i;async readdir(){if(!this.canReaddir())return[];let Q=this.children();if(this.calledReaddir())return Q.slice(0,Q.provisional);let Z=this.fullpath();if(this.#i)await this.#i;else{let $=()=>{};this.#i=new Promise((X)=>$=X);try{for(let X of await this.#Q.promises.readdir(Z,{withFileTypes:!0}))this.#g(X,Q);this.#u(Q)}catch(X){this.#h(X.code),Q.provisional=0}this.#i=void 0,$()}return Q.slice(0,Q.provisional)}readdirSync(){if(!this.canReaddir())return[];let Q=this.children();if(this.calledReaddir())return Q.slice(0,Q.provisional);let Z=this.fullpath();try{for(let $ of this.#Q.readdirSync(Z,{withFileTypes:!0}))this.#g($,Q);this.#u(Q)}catch($){this.#h($.code),Q.provisional=0}return Q.slice(0,Q.provisional)}canReaddir(){if(this.#$&T8)return!1;let Q=i&this.#$;if(!(Q===n||Q===Y9||Q===P9))return!1;return!0}shouldWalk(Q,Z){return(this.#$&Y9)===Y9&&!(this.#$&T8)&&!Q.has(this)&&(!Z||Z(this))}async realpath(){if(this.#N)return this.#N;if((P0|C0|t)&this.#$)return;try{let Q=await this.#Q.promises.realpath(this.fullpath());return this.#N=this.resolve(Q)}catch(Q){this.#b()}}realpathSync(){if(this.#N)return this.#N;if((P0|C0|t)&this.#$)return;try{let Q=this.#Q.realpathSync(this.fullpath());return this.#N=this.resolve(Q)}catch(Q){this.#b()}}[l8](Q){if(Q===this)return;Q.isCWD=!1,this.isCWD=!0;let Z=new Set([]),$=[],X=this;while(X&&X.parent)Z.add(X),X.#F=$.join(this.sep),X.#D=$.join("/"),X=X.parent,$.push("..");X=Q;while(X&&X.parent&&!Z.has(X))X.#F=void 0,X.#D=void 0,X=X.parent}}class D0 extends h{sep="\\";splitSep=M5;constructor(Q,Z=n,$,X,V,z,J){super(Q,Z,$,X,V,z,J)}newChild(Q,Z=n,$={}){return new D0(Q,Z,this.root,this.roots,this.nocase,this.childrenCache(),$)}getRootString(Q){return LQ.parse(Q).root}getRoot(Q){if(Q=v5(Q.toUpperCase()),Q===this.root.name)return this.root;for(let[Z,$]of Object.entries(this.roots))if(this.sameRoot(Q,Z))return this.roots[Q]=$;return this.roots[Q]=new z0(Q,this).root}sameRoot(Q,Z=this.root.name){return Q=Q.toUpperCase().replace(/\//g,"\\").replace(b8,"$1\\"),Q===Z}}class N0 extends h{splitSep="/";sep="/";constructor(Q,Z=n,$,X,V,z,J){super(Q,Z,$,X,V,z,J)}getRootString(Q){return Q.startsWith("/")?"/":""}getRoot(Q){return this.root}newChild(Q,Z=n,$={}){return new N0(Q,Z,this.root,this.roots,this.nocase,this.childrenCache(),$)}}class OQ{root;rootPath;roots;cwd;#Q;#X;#V;nocase;#Z;constructor(Q=process.cwd(),Z,$,{nocase:X,childrenCacheSize:V=16384,fs:z=$0}={}){if(this.#Z=f8(z),Q instanceof URL||Q.startsWith("file://"))Q=W5(Q);let J=Z.resolve(Q);this.roots=Object.create(null),this.rootPath=this.parseRootPath(J),this.#Q=new FQ,this.#X=new FQ,this.#V=new c8(V);let Y=J.substring(this.rootPath.length).split($);if(Y.length===1&&!Y[0])Y.pop();if(X===void 0)throw TypeError("must provide nocase setting to PathScurryBase ctor");this.nocase=X,this.root=this.newRoot(this.#Z),this.roots[this.rootPath]=this.root;let K=this.root,q=Y.length-1,W=Z.sep,H=this.rootPath,G=!1;for(let _ of Y){let U=q--;K=K.child(_,{relative:Array(U).fill("..").join(W),relativePosix:Array(U).fill("..").join("/"),fullpath:H+=(G?"":W)+_}),G=!0}this.cwd=K}depth(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return Q.depth()}childrenCache(){return this.#V}resolve(...Q){let Z="";for(let V=Q.length-1;V>=0;V--){let z=Q[V];if(!z||z===".")continue;if(Z=Z?`${z}/${Z}`:z,this.isAbsolute(z))break}let $=this.#Q.get(Z);if($!==void 0)return $;let X=this.cwd.resolve(Z).fullpath();return this.#Q.set(Z,X),X}resolvePosix(...Q){let Z="";for(let V=Q.length-1;V>=0;V--){let z=Q[V];if(!z||z===".")continue;if(Z=Z?`${z}/${Z}`:z,this.isAbsolute(z))break}let $=this.#X.get(Z);if($!==void 0)return $;let X=this.cwd.resolve(Z).fullpathPosix();return this.#X.set(Z,X),X}relative(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return Q.relative()}relativePosix(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return Q.relativePosix()}basename(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return Q.name}dirname(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return(Q.parent||Q).fullpath()}async readdir(Q=this.cwd,Z={withFileTypes:!0}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$}=Z;if(!Q.canReaddir())return[];else{let X=await Q.readdir();return $?X:X.map((V)=>V.name)}}readdirSync(Q=this.cwd,Z={withFileTypes:!0}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$=!0}=Z;if(!Q.canReaddir())return[];else if($)return Q.readdirSync();else return Q.readdirSync().map((X)=>X.name)}async lstat(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return Q.lstat()}lstatSync(Q=this.cwd){if(typeof Q==="string")Q=this.cwd.resolve(Q);return Q.lstatSync()}async readlink(Q=this.cwd,{withFileTypes:Z}={withFileTypes:!1}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q.withFileTypes,Q=this.cwd;let $=await Q.readlink();return Z?$:$?.fullpath()}readlinkSync(Q=this.cwd,{withFileTypes:Z}={withFileTypes:!1}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q.withFileTypes,Q=this.cwd;let $=Q.readlinkSync();return Z?$:$?.fullpath()}async realpath(Q=this.cwd,{withFileTypes:Z}={withFileTypes:!1}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q.withFileTypes,Q=this.cwd;let $=await Q.realpath();return Z?$:$?.fullpath()}realpathSync(Q=this.cwd,{withFileTypes:Z}={withFileTypes:!1}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q.withFileTypes,Q=this.cwd;let $=Q.realpathSync();return Z?$:$?.fullpath()}async walk(Q=this.cwd,Z={}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$=!0,follow:X=!1,filter:V,walkFilter:z}=Z,J=[];if(!V||V(Q))J.push($?Q:Q.fullpath());let Y=new Set,K=(W,H)=>{Y.add(W),W.readdirCB((G,_)=>{if(G)return H(G);let U=_.length;if(!U)return H();let j=()=>{if(--U===0)H()};for(let A of _){if(!V||V(A))J.push($?A:A.fullpath());if(X&&A.isSymbolicLink())A.realpath().then((w)=>w?.isUnknown()?w.lstat():w).then((w)=>w?.shouldWalk(Y,z)?K(w,j):j());else if(A.shouldWalk(Y,z))K(A,j);else j()}},!0)},q=Q;return new Promise((W,H)=>{K(q,(G)=>{if(G)return H(G);W(J)})})}walkSync(Q=this.cwd,Z={}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$=!0,follow:X=!1,filter:V,walkFilter:z}=Z,J=[];if(!V||V(Q))J.push($?Q:Q.fullpath());let Y=new Set([Q]);for(let K of Y){let q=K.readdirSync();for(let W of q){if(!V||V(W))J.push($?W:W.fullpath());let H=W;if(W.isSymbolicLink()){if(!(X&&(H=W.realpathSync())))continue;if(H.isUnknown())H.lstatSync()}if(H.shouldWalk(Y,z))Y.add(H)}}return J}[Symbol.asyncIterator](){return this.iterate()}iterate(Q=this.cwd,Z={}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;return this.stream(Q,Z)[Symbol.asyncIterator]()}[Symbol.iterator](){return this.iterateSync()}*iterateSync(Q=this.cwd,Z={}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$=!0,follow:X=!1,filter:V,walkFilter:z}=Z;if(!V||V(Q))yield $?Q:Q.fullpath();let J=new Set([Q]);for(let Y of J){let K=Y.readdirSync();for(let q of K){if(!V||V(q))yield $?q:q.fullpath();let W=q;if(q.isSymbolicLink()){if(!(X&&(W=q.realpathSync())))continue;if(W.isUnknown())W.lstatSync()}if(W.shouldWalk(J,z))J.add(W)}}}stream(Q=this.cwd,Z={}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$=!0,follow:X=!1,filter:V,walkFilter:z}=Z,J=new R9({objectMode:!0});if(!V||V(Q))J.write($?Q:Q.fullpath());let Y=new Set,K=[Q],q=0,W=()=>{let H=!1;while(!H){let G=K.shift();if(!G){if(q===0)J.end();return}q++,Y.add(G);let _=(j,A,w=!1)=>{if(j)return J.emit("error",j);if(X&&!w){let B=[];for(let O of A)if(O.isSymbolicLink())B.push(O.realpath().then((v)=>v?.isUnknown()?v.lstat():v));if(B.length){Promise.all(B).then(()=>_(null,A,!0));return}}for(let B of A)if(B&&(!V||V(B))){if(!J.write($?B:B.fullpath()))H=!0}q--;for(let B of A){let O=B.realpathCached()||B;if(O.shouldWalk(Y,z))K.push(O)}if(H&&!J.flowing)J.once("drain",W);else if(!U)W()},U=!0;G.readdirCB(_,!0),U=!1}};return W(),J}streamSync(Q=this.cwd,Z={}){if(typeof Q==="string")Q=this.cwd.resolve(Q);else if(!(Q instanceof h))Z=Q,Q=this.cwd;let{withFileTypes:$=!0,follow:X=!1,filter:V,walkFilter:z}=Z,J=new R9({objectMode:!0}),Y=new Set;if(!V||V(Q))J.write($?Q:Q.fullpath());let K=[Q],q=0,W=()=>{let H=!1;while(!H){let G=K.shift();if(!G){if(q===0)J.end();return}q++,Y.add(G);let _=G.readdirSync();for(let U of _)if(!V||V(U)){if(!J.write($?U:U.fullpath()))H=!0}q--;for(let U of _){let j=U;if(U.isSymbolicLink()){if(!(X&&(j=U.realpathSync())))continue;if(j.isUnknown())j.lstatSync()}if(j.shouldWalk(Y,z))K.push(j)}}if(H&&!J.flowing)J.once("drain",W)};return W(),J}chdir(Q=this.cwd){let Z=this.cwd;this.cwd=typeof Q==="string"?this.cwd.resolve(Q):Q,this.cwd[l8](Z)}}class z0 extends OQ{sep="\\";constructor(Q=process.cwd(),Z={}){let{nocase:$=!0}=Z;super(Q,LQ,"\\",{...Z,nocase:$});this.nocase=$;for(let X=this.cwd;X;X=X.parent)X.nocase=this.nocase}parseRootPath(Q){return LQ.parse(Q).root.toUpperCase()}newRoot(Q){return new D0(this.rootPath,Y9,void 0,this.roots,this.nocase,this.childrenCache(),{fs:Q})}isAbsolute(Q){return Q.startsWith("/")||Q.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(Q)}}class J0 extends OQ{sep="/";constructor(Q=process.cwd(),Z={}){let{nocase:$=!1}=Z;super(Q,q5,"/",{...Z,nocase:$});this.nocase=$}parseRootPath(Q){return"/"}newRoot(Q){return new N0(this.rootPath,Y9,void 0,this.roots,this.nocase,this.childrenCache(),{fs:Q})}isAbsolute(Q){return Q.startsWith("/")}}class S0 extends J0{constructor(Q=process.cwd(),Z={}){let{nocase:$=!0}=Z;super(Q,{...Z,nocase:$})}}var Z1=process.platform==="win32"?D0:N0,p8=process.platform==="win32"?z0:process.platform==="darwin"?S0:J0;var R5=(Q)=>Q.length>=1,P5=(Q)=>Q.length>=1;class k9{#Q;#X;#V;length;#Z;#J;#M;#B;#H;#Y;#G=!0;constructor(Q,Z,$,X){if(!R5(Q))throw TypeError("empty pattern list");if(!P5(Z))throw TypeError("empty glob list");if(Z.length!==Q.length)throw TypeError("mismatched pattern list and glob list lengths");if(this.length=Q.length,$<0||$>=this.length)throw TypeError("index out of range");if(this.#Q=Q,this.#X=Z,this.#V=$,this.#Z=X,this.#V===0){if(this.isUNC()){let[V,z,J,Y,...K]=this.#Q,[q,W,H,G,..._]=this.#X;if(K[0]==="")K.shift(),_.shift();let U=[V,z,J,Y,""].join("/"),j=[q,W,H,G,""].join("/");this.#Q=[U,...K],this.#X=[j,..._],this.length=this.#Q.length}else if(this.isDrive()||this.isAbsolute()){let[V,...z]=this.#Q,[J,...Y]=this.#X;if(z[0]==="")z.shift(),Y.shift();let K=V+"/",q=J+"/";this.#Q=[K,...z],this.#X=[q,...Y],this.length=this.#Q.length}}}pattern(){return this.#Q[this.#V]}isString(){return typeof this.#Q[this.#V]==="string"}isGlobstar(){return this.#Q[this.#V]===D}isRegExp(){return this.#Q[this.#V]instanceof RegExp}globString(){return this.#M=this.#M||(this.#V===0?this.isAbsolute()?this.#X[0]+this.#X.slice(1).join("/"):this.#X.join("/"):this.#X.slice(this.#V).join("/"))}hasMore(){return this.length>this.#V+1}rest(){if(this.#J!==void 0)return this.#J;if(!this.hasMore())return this.#J=null;return this.#J=new k9(this.#Q,this.#X,this.#V+1,this.#Z),this.#J.#Y=this.#Y,this.#J.#H=this.#H,this.#J.#B=this.#B,this.#J}isUNC(){let Q=this.#Q;return this.#H!==void 0?this.#H:this.#H=this.#Z==="win32"&&this.#V===0&&Q[0]===""&&Q[1]===""&&typeof Q[2]==="string"&&!!Q[2]&&typeof Q[3]==="string"&&!!Q[3]}isDrive(){let Q=this.#Q;return this.#B!==void 0?this.#B:this.#B=this.#Z==="win32"&&this.#V===0&&this.length>1&&typeof Q[0]==="string"&&/^[a-z]:$/i.test(Q[0])}isAbsolute(){let Q=this.#Q;return this.#Y!==void 0?this.#Y:this.#Y=Q[0]===""&&Q.length>1||this.isDrive()||this.isUNC()}root(){let Q=this.#Q[0];return typeof Q==="string"&&this.isAbsolute()&&this.#V===0?Q:""}checkFollowGlobstar(){return!(this.#V===0||!this.isGlobstar()||!this.#G)}markFollowGlobstar(){if(this.#V===0||!this.isGlobstar()||!this.#G)return!1;return this.#G=!1,!0}}var D5=typeof process==="object"&&process&&typeof process.platform==="string"?process.platform:"linux";class Y0{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(Q,{nobrace:Z,nocase:$,noext:X,noglobstar:V,platform:z=D5}){this.relative=[],this.absolute=[],this.relativeChildren=[],this.absoluteChildren=[],this.platform=z,this.mmopts={dot:!0,nobrace:Z,nocase:$,noext:X,noglobstar:V,optimizationLevel:2,platform:z,nocomment:!0,nonegate:!0};for(let J of Q)this.add(J)}add(Q){let Z=new p(Q,this.mmopts);for(let $=0;$<Z.set.length;$++){let X=Z.set[$],V=Z.globParts[$];if(!X||!V)throw Error("invalid pattern object");while(X[0]==="."&&V[0]===".")X.shift(),V.shift();let z=new k9(X,V,0,this.platform),J=new p(z.globString(),this.mmopts),Y=V[V.length-1]==="**",K=z.isAbsolute();if(K)this.absolute.push(J);else this.relative.push(J);if(Y)if(K)this.absoluteChildren.push(J);else this.relativeChildren.push(J)}}ignored(Q){let Z=Q.fullpath(),$=`${Z}/`,X=Q.relative()||".",V=`${X}/`;for(let z of this.relative)if(z.match(X)||z.match(V))return!0;for(let z of this.absolute)if(z.match(Z)||z.match($))return!0;return!1}childrenIgnored(Q){let Z=Q.fullpath()+"/",$=(Q.relative()||".")+"/";for(let X of this.relativeChildren)if(X.match($))return!0;for(let X of this.absoluteChildren)if(X.match(Z))return!0;return!1}}class vQ{store;constructor(Q=new Map){this.store=Q}copy(){return new vQ(new Map(this.store))}hasWalked(Q,Z){return this.store.get(Q.fullpath())?.has(Z.globString())}storeWalked(Q,Z){let $=Q.fullpath(),X=this.store.get($);if(X)X.add(Z.globString());else this.store.set($,new Set([Z.globString()]))}}class i8{store=new Map;add(Q,Z,$){let X=(Z?2:0)|($?1:0),V=this.store.get(Q);this.store.set(Q,V===void 0?X:X&V)}entries(){return[...this.store.entries()].map(([Q,Z])=>[Q,!!(Z&2),!!(Z&1)])}}class n8{store=new Map;add(Q,Z){if(!Q.canReaddir())return;let $=this.store.get(Q);if($){if(!$.find((X)=>X.globString()===Z.globString()))$.push(Z)}else this.store.set(Q,[Z])}get(Q){let Z=this.store.get(Q);if(!Z)throw Error("attempting to walk unknown path");return Z}entries(){return this.keys().map((Q)=>[Q,this.store.get(Q)])}keys(){return[...this.store.keys()].filter((Q)=>Q.canReaddir())}}class K0{hasWalkedCache;matches=new i8;subwalks=new n8;patterns;follow;dot;opts;constructor(Q,Z){this.opts=Q,this.follow=!!Q.follow,this.dot=!!Q.dot,this.hasWalkedCache=Z?Z.copy():new vQ}processPatterns(Q,Z){this.patterns=Z;let $=Z.map((X)=>[Q,X]);for(let[X,V]of $){this.hasWalkedCache.storeWalked(X,V);let z=V.root(),J=V.isAbsolute()&&this.opts.absolute!==!1;if(z){X=X.resolve(z==="/"&&this.opts.root!==void 0?this.opts.root:z);let W=V.rest();if(!W){this.matches.add(X,!0,!1);continue}else V=W}if(X.isENOENT())continue;let Y,K,q=!1;while(typeof(Y=V.pattern())==="string"&&(K=V.rest()))X=X.resolve(Y),V=K,q=!0;if(Y=V.pattern(),K=V.rest(),q){if(this.hasWalkedCache.hasWalked(X,V))continue;this.hasWalkedCache.storeWalked(X,V)}if(typeof Y==="string"){let W=Y===".."||Y===""||Y===".";this.matches.add(X.resolve(Y),J,W);continue}else if(Y===D){if(!X.isSymbolicLink()||this.follow||V.checkFollowGlobstar())this.subwalks.add(X,V);let W=K?.pattern(),H=K?.rest();if(!K||(W===""||W===".")&&!H)this.matches.add(X,J,W===""||W===".");else if(W===".."){let G=X.parent||X;if(!H)this.matches.add(G,J,!0);else if(!this.hasWalkedCache.hasWalked(G,H))this.subwalks.add(G,H)}}else if(Y instanceof RegExp)this.subwalks.add(X,V)}return this}subwalkTargets(){return this.subwalks.keys()}child(){return new K0(this.opts,this.hasWalkedCache)}filterEntries(Q,Z){let $=this.subwalks.get(Q),X=this.child();for(let V of Z)for(let z of $){let J=z.isAbsolute(),Y=z.pattern(),K=z.rest();if(Y===D)X.testGlobstar(V,z,K,J);else if(Y instanceof RegExp)X.testRegExp(V,Y,K,J);else X.testString(V,Y,K,J)}return X}testGlobstar(Q,Z,$,X){if(this.dot||!Q.name.startsWith(".")){if(!Z.hasMore())this.matches.add(Q,X,!1);if(Q.canReaddir()){if(this.follow||!Q.isSymbolicLink())this.subwalks.add(Q,Z);else if(Q.isSymbolicLink()){if($&&Z.checkFollowGlobstar())this.subwalks.add(Q,$);else if(Z.markFollowGlobstar())this.subwalks.add(Q,Z)}}}if($){let V=$.pattern();if(typeof V==="string"&&V!==".."&&V!==""&&V!==".")this.testString(Q,V,$.rest(),X);else if(V===".."){let z=Q.parent||Q;this.subwalks.add(z,$)}else if(V instanceof RegExp)this.testRegExp(Q,V,$.rest(),X)}}testRegExp(Q,Z,$,X){if(!Z.test(Q.name))return;if(!$)this.matches.add(Q,X,!1);else this.subwalks.add(Q,$)}testString(Q,Z,$,X){if(!Q.isNamed(Z))return;if(!$)this.matches.add(Q,X,!1);else this.subwalks.add(Q,$)}}var N5=(Q,Z)=>typeof Q==="string"?new Y0([Q],Z):Array.isArray(Q)?new Y0(Q,Z):Q;class MQ{path;patterns;opts;seen=new Set;paused=!1;aborted=!1;#Q=[];#X;#V;signal;maxDepth;includeChildMatches;constructor(Q,Z,$){if(this.patterns=Q,this.path=Z,this.opts=$,this.#V=!$.posix&&$.platform==="win32"?"\\":"/",this.includeChildMatches=$.includeChildMatches!==!1,$.ignore||!this.includeChildMatches){if(this.#X=N5($.ignore??[],$),!this.includeChildMatches&&typeof this.#X.add!=="function")throw Error("cannot ignore child matches, ignore lacks add() method.")}if(this.maxDepth=$.maxDepth||1/0,$.signal)this.signal=$.signal,this.signal.addEventListener("abort",()=>{this.#Q.length=0})}#Z(Q){return this.seen.has(Q)||!!this.#X?.ignored?.(Q)}#J(Q){return!!this.#X?.childrenIgnored?.(Q)}pause(){this.paused=!0}resume(){if(this.signal?.aborted)return;this.paused=!1;let Q=void 0;while(!this.paused&&(Q=this.#Q.shift()))Q()}onResume(Q){if(this.signal?.aborted)return;if(!this.paused)Q();else this.#Q.push(Q)}async matchCheck(Q,Z){if(Z&&this.opts.nodir)return;let $;if(this.opts.realpath){if($=Q.realpathCached()||await Q.realpath(),!$)return;Q=$}let V=Q.isUnknown()||this.opts.stat?await Q.lstat():Q;if(this.opts.follow&&this.opts.nodir&&V?.isSymbolicLink()){let z=await V.realpath();if(z&&(z.isUnknown()||this.opts.stat))await z.lstat()}return this.matchCheckTest(V,Z)}matchCheckTest(Q,Z){return Q&&(this.maxDepth===1/0||Q.depth()<=this.maxDepth)&&(!Z||Q.canReaddir())&&(!this.opts.nodir||!Q.isDirectory())&&(!this.opts.nodir||!this.opts.follow||!Q.isSymbolicLink()||!Q.realpathCached()?.isDirectory())&&!this.#Z(Q)?Q:void 0}matchCheckSync(Q,Z){if(Z&&this.opts.nodir)return;let $;if(this.opts.realpath){if($=Q.realpathCached()||Q.realpathSync(),!$)return;Q=$}let V=Q.isUnknown()||this.opts.stat?Q.lstatSync():Q;if(this.opts.follow&&this.opts.nodir&&V?.isSymbolicLink()){let z=V.realpathSync();if(z&&(z?.isUnknown()||this.opts.stat))z.lstatSync()}return this.matchCheckTest(V,Z)}matchFinish(Q,Z){if(this.#Z(Q))return;if(!this.includeChildMatches&&this.#X?.add){let V=`${Q.relativePosix()}/**`;this.#X.add(V)}let $=this.opts.absolute===void 0?Z:this.opts.absolute;this.seen.add(Q);let X=this.opts.mark&&Q.isDirectory()?this.#V:"";if(this.opts.withFileTypes)this.matchEmit(Q);else if($){let V=this.opts.posix?Q.fullpathPosix():Q.fullpath();this.matchEmit(V+X)}else{let V=this.opts.posix?Q.relativePosix():Q.relative(),z=this.opts.dotRelative&&!V.startsWith(".."+this.#V)?"."+this.#V:"";this.matchEmit(!V?"."+X:z+V+X)}}async match(Q,Z,$){let X=await this.matchCheck(Q,$);if(X)this.matchFinish(X,Z)}matchSync(Q,Z,$){let X=this.matchCheckSync(Q,$);if(X)this.matchFinish(X,Z)}walkCB(Q,Z,$){if(this.signal?.aborted)$();this.walkCB2(Q,Z,new K0(this.opts),$)}walkCB2(Q,Z,$,X){if(this.#J(Q))return X();if(this.signal?.aborted)X();if(this.paused){this.onResume(()=>this.walkCB2(Q,Z,$,X));return}$.processPatterns(Q,Z);let V=1,z=()=>{if(--V===0)X()};for(let[J,Y,K]of $.matches.entries()){if(this.#Z(J))continue;V++,this.match(J,Y,K).then(()=>z())}for(let J of $.subwalkTargets()){if(this.maxDepth!==1/0&&J.depth()>=this.maxDepth)continue;V++;let Y=J.readdirCached();if(J.calledReaddir())this.walkCB3(J,Y,$,z);else J.readdirCB((K,q)=>this.walkCB3(J,q,$,z),!0)}z()}walkCB3(Q,Z,$,X){$=$.filterEntries(Q,Z);let V=1,z=()=>{if(--V===0)X()};for(let[J,Y,K]of $.matches.entries()){if(this.#Z(J))continue;V++,this.match(J,Y,K).then(()=>z())}for(let[J,Y]of $.subwalks.entries())V++,this.walkCB2(J,Y,$.child(),z);z()}walkCBSync(Q,Z,$){if(this.signal?.aborted)$();this.walkCB2Sync(Q,Z,new K0(this.opts),$)}walkCB2Sync(Q,Z,$,X){if(this.#J(Q))return X();if(this.signal?.aborted)X();if(this.paused){this.onResume(()=>this.walkCB2Sync(Q,Z,$,X));return}$.processPatterns(Q,Z);let V=1,z=()=>{if(--V===0)X()};for(let[J,Y,K]of $.matches.entries()){if(this.#Z(J))continue;this.matchSync(J,Y,K)}for(let J of $.subwalkTargets()){if(this.maxDepth!==1/0&&J.depth()>=this.maxDepth)continue;V++;let Y=J.readdirSync();this.walkCB3Sync(J,Y,$,z)}z()}walkCB3Sync(Q,Z,$,X){$=$.filterEntries(Q,Z);let V=1,z=()=>{if(--V===0)X()};for(let[J,Y,K]of $.matches.entries()){if(this.#Z(J))continue;this.matchSync(J,Y,K)}for(let[J,Y]of $.subwalks.entries())V++,this.walkCB2Sync(J,Y,$.child(),z);z()}}class I0 extends MQ{matches=new Set;constructor(Q,Z,$){super(Q,Z,$)}matchEmit(Q){this.matches.add(Q)}async walk(){if(this.signal?.aborted)throw this.signal.reason;if(this.path.isUnknown())await this.path.lstat();return await new Promise((Q,Z)=>{this.walkCB(this.path,this.patterns,()=>{if(this.signal?.aborted)Z(this.signal.reason);else Q(this.matches)})}),this.matches}walkSync(){if(this.signal?.aborted)throw this.signal.reason;if(this.path.isUnknown())this.path.lstatSync();return this.walkCBSync(this.path,this.patterns,()=>{if(this.signal?.aborted)throw this.signal.reason}),this.matches}}class x0 extends MQ{results;constructor(Q,Z,$){super(Q,Z,$);this.results=new R9({signal:this.signal,objectMode:!0}),this.results.on("drain",()=>this.resume()),this.results.on("resume",()=>this.resume())}matchEmit(Q){if(this.results.write(Q),!this.results.flowing)this.pause()}stream(){let Q=this.path;if(Q.isUnknown())Q.lstat().then(()=>{this.walkCB(Q,this.patterns,()=>this.results.end())});else this.walkCB(Q,this.patterns,()=>this.results.end());return this.results}streamSync(){if(this.path.isUnknown())this.path.lstatSync();return this.walkCBSync(this.path,this.patterns,()=>this.results.end()),this.results}}var I5=typeof process==="object"&&process&&typeof process.platform==="string"?process.platform:"linux";class K9{absolute;cwd;root;dot;dotRelative;follow;ignore;magicalBraces;mark;matchBase;maxDepth;nobrace;nocase;nodir;noext;noglobstar;pattern;platform;realpath;scurry;stat;signal;windowsPathsNoEscape;withFileTypes;includeChildMatches;opts;patterns;constructor(Q,Z){if(!Z)throw TypeError("glob options required");if(this.withFileTypes=!!Z.withFileTypes,this.signal=Z.signal,this.follow=!!Z.follow,this.dot=!!Z.dot,this.dotRelative=!!Z.dotRelative,this.nodir=!!Z.nodir,this.mark=!!Z.mark,!Z.cwd)this.cwd="";else if(Z.cwd instanceof URL||Z.cwd.startsWith("file://"))Z.cwd=S5(Z.cwd);if(this.cwd=Z.cwd||"",this.root=Z.root,this.magicalBraces=!!Z.magicalBraces,this.nobrace=!!Z.nobrace,this.noext=!!Z.noext,this.realpath=!!Z.realpath,this.absolute=Z.absolute,this.includeChildMatches=Z.includeChildMatches!==!1,this.noglobstar=!!Z.noglobstar,this.matchBase=!!Z.matchBase,this.maxDepth=typeof Z.maxDepth==="number"?Z.maxDepth:1/0,this.stat=!!Z.stat,this.ignore=Z.ignore,this.withFileTypes&&this.absolute!==void 0)throw Error("cannot set absolute and withFileTypes:true");if(typeof Q==="string")Q=[Q];if(this.windowsPathsNoEscape=!!Z.windowsPathsNoEscape||Z.allowWindowsEscape===!1,this.windowsPathsNoEscape)Q=Q.map((Y)=>Y.replace(/\\/g,"/"));if(this.matchBase){if(Z.noglobstar)throw TypeError("base matching requires globstar");Q=Q.map((Y)=>Y.includes("/")?Y:`./**/${Y}`)}if(this.pattern=Q,this.platform=Z.platform||I5,this.opts={...Z,platform:this.platform},Z.scurry){if(this.scurry=Z.scurry,Z.nocase!==void 0&&Z.nocase!==Z.scurry.nocase)throw Error("nocase option contradicts provided scurry option")}else{let Y=Z.platform==="win32"?z0:Z.platform==="darwin"?S0:Z.platform?J0:p8;this.scurry=new Y(this.cwd,{nocase:Z.nocase,fs:Z.fs})}this.nocase=this.scurry.nocase;let $=this.platform==="darwin"||this.platform==="win32",X={...Z,dot:this.dot,matchBase:this.matchBase,nobrace:this.nobrace,nocase:this.nocase,nocaseMagicOnly:$,nocomment:!0,noext:this.noext,nonegate:!0,optimizationLevel:2,platform:this.platform,windowsPathsNoEscape:this.windowsPathsNoEscape,debug:!!this.opts.debug},V=this.pattern.map((Y)=>new p(Y,X)),[z,J]=V.reduce((Y,K)=>{return Y[0].push(...K.set),Y[1].push(...K.globParts),Y},[[],[]]);this.patterns=z.map((Y,K)=>{let q=J[K];if(!q)throw Error("invalid pattern object");return new k9(Y,q,0,this.platform)})}async walk(){return[...await new I0(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walk()]}walkSync(){return[...new I0(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).walkSync()]}stream(){return new x0(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).stream()}streamSync(){return new x0(this.patterns,this.scurry.cwd,{...this.opts,maxDepth:this.maxDepth!==1/0?this.maxDepth+this.scurry.cwd.depth():1/0,platform:this.platform,nocase:this.nocase,includeChildMatches:this.includeChildMatches}).streamSync()}iterateSync(){return this.streamSync()[Symbol.iterator]()}[Symbol.iterator](){return this.iterateSync()}iterate(){return this.stream()[Symbol.asyncIterator]()}[Symbol.asyncIterator](){return this.iterate()}}var CQ=(Q,Z={})=>{if(!Array.isArray(Q))Q=[Q];for(let $ of Q)if(new p($,Z).hasMagic())return!0;return!1};function T0(Q,Z={}){return new K9(Q,Z).streamSync()}function r8(Q,Z={}){return new K9(Q,Z).stream()}function a8(Q,Z={}){return new K9(Q,Z).walkSync()}async function o8(Q,Z={}){return new K9(Q,Z).walk()}function y0(Q,Z={}){return new K9(Q,Z).iterateSync()}function s8(Q,Z={}){return new K9(Q,Z).iterate()}var x5=T0,E5=Object.assign(r8,{sync:T0}),T5=y0,y5=Object.assign(s8,{sync:y0}),k5=Object.assign(a8,{stream:T0,iterate:y0}),E0=Object.assign(o8,{glob:o8,globSync:a8,sync:k5,globStream:r8,stream:E5,globStreamSync:T0,streamSync:x5,globIterate:s8,iterate:y5,globIterateSync:y0,iterateSync:T5,Glob:K9,hasMagic:CQ,escape:E9,unescape:a});E0.glob=E0;var f5={name:"Read",description:"Reads a file from the local filesystem. You can access any file directly by using this tool.",input_schema:{type:"object",properties:{file_path:{type:"string",description:"The absolute path to the file to read"},offset:{type:"number",description:"The line number to start reading from (1-based)"},limit:{type:"number",description:"The number of lines to read"}},required:["file_path"]},handler:async(Q,Z)=>{let $=Q.file_path,X=Q.offset||1,V=Q.limit||2000;try{let Y=(await Bun.file($).text()).split(`
124
+ `),K=Math.max(0,X-1),q=Math.min(Y.length,K+V);return{content:Y.slice(K,q).map((G,_)=>`${K+_+1} ${G}`).join(`
125
+ `)}}catch(z){return{content:`Error reading file: ${z instanceof Error?z.message:String(z)}`,is_error:!0}}}},b5={name:"Write",description:"Writes a file to the local filesystem. This tool will overwrite the existing file if there is one at the provided path.",input_schema:{type:"object",properties:{file_path:{type:"string",description:"The absolute path to the file to write"},content:{type:"string",description:"The content to write to the file"}},required:["file_path","content"]},handler:async(Q,Z)=>{let{file_path:$,content:X}=Q;try{return await Bun.write($,X),{content:`Successfully wrote to ${$}`}}catch(V){return{content:`Error writing file: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},u5={name:"Edit",description:"Performs exact string replacements in files. Use this tool to modify existing files.",input_schema:{type:"object",properties:{file_path:{type:"string",description:"The absolute path to the file to modify"},old_string:{type:"string",description:"The text to replace"},new_string:{type:"string",description:"The text to replace it with"},replace_all:{type:"boolean",description:"Replace all occurrences (default false)"}},required:["file_path","old_string","new_string"]},handler:async(Q,Z)=>{let{file_path:$,old_string:X,new_string:V}=Q,z=Q.replace_all||!1;try{let Y=await Bun.file($).text();if(z){let K=Y;Y=Y.split(X).join(V);let q=(K.match(new RegExp(h5(X),"g"))||[]).length;if(q===0)return{content:"Error: String not found in file",is_error:!0};return await Bun.write($,Y),{content:`Successfully replaced ${q} occurrences`}}else{let K=Y.indexOf(X);if(K===-1)return{content:"Error: String not found in file",is_error:!0};if(Y.indexOf(X,K+1)!==-1)return{content:"Error: String appears multiple times in file. Use replace_all or provide more context.",is_error:!0};return Y=Y.replace(X,V),await Bun.write($,Y),{content:`Successfully edited ${$}`}}}catch(J){return{content:`Error editing file: ${J instanceof Error?J.message:String(J)}`,is_error:!0}}}};function h5(Q){return Q.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var g5={name:"Bash",description:"Executes a given bash command with optional timeout. Working directory persists between commands.",input_schema:{type:"object",properties:{command:{type:"string",description:"The command to execute"},timeout:{type:"number",description:"Optional timeout in milliseconds (max 600000)"},description:{type:"string",description:"Clear, concise description of what this command does"}},required:["command"]},handler:async(Q,Z)=>{let $=Q.command,X=Q.timeout||120000;try{let V=Bun.spawnSync(["sh","-c",$],{cwd:Z.workingDirectory,timeout:X,maxBuffer:31457280}),z=V.stdout?.toString()||"",J=V.stderr?.toString()||"";if(V.exitCode!==0)return{content:`Exit code: ${V.exitCode}
126
+ ${z}
127
+ ${J}`.trim(),is_error:!0};return{content:z||"(no output)"}}catch(V){return{content:`Error executing command: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},d5={name:"Glob",description:"Fast file pattern matching tool that works with any codebase size. Supports glob patterns.",input_schema:{type:"object",properties:{pattern:{type:"string",description:"The glob pattern to match files"},path:{type:"string",description:"The directory to search (default: current directory)"}},required:["pattern"]},handler:async(Q,Z)=>{let $=Q.pattern,X=Q.path||Z.workingDirectory;try{let V=await E0($,{cwd:X,absolute:!0,nodir:!0});if(V.length===0)return{content:"No files found matching pattern"};return{content:V.sort().join(`
128
+ `)}}catch(V){return{content:`Error searching files: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},m5={name:"Grep",description:"A powerful search tool built on ripgrep. Supports full regex syntax.",input_schema:{type:"object",properties:{pattern:{type:"string",description:"The regular expression pattern to search for"},path:{type:"string",description:"File or directory to search"},glob:{type:"string",description:"Glob pattern to filter files"},output_mode:{type:"string",enum:["content","files_with_matches","count"],description:"Output mode (default: content)"},"-i:":{type:"boolean",description:"Case insensitive search"},"-C:":{type:"number",description:"Context lines around match"},head_limit:{type:"number",description:"Maximum number of results"}},required:["pattern"]},handler:async(Q,Z)=>{let $=Q.pattern,X=Q.path||Z.workingDirectory,V=Q.glob,z=Q.output_mode||"content",J=Q["-i:"],Y=Q["-C:"]||0,K=Q.head_limit||100;try{let W=await I().grepSearch(X,{pattern:$,caseInsensitive:J,glob:V,outputMode:z,contextLines:Y,headLimit:K});if(z==="files_with_matches"){if(W.filesWithMatches.length===0)return{content:"No files matched"};return{content:W.filesWithMatches.join(`
129
+ `)}}if(z==="count")return{content:`${W.totalCount} matches in ${W.filesWithMatches.length} files`};if(W.matches.length===0)return{content:"No matches found"};let G=W.matches.map((_)=>{let U=[`${_.filePath}:${_.lineNumber}:${_.line}`];if(_.beforeContext.length>0)U.unshift(..._.beforeContext.map((j)=>` ${j}`));if(_.afterContext.length>0)U.push(..._.afterContext.map((j)=>` ${j}`));return U.join(`
130
+ `)}).join(`
131
+ `);if(W.truncated)G+=`
132
+
133
+ ... (${W.totalCount} total matches, showing first ${W.matches.length})`;return{content:G}}catch(q){return{content:`Error searching: ${q instanceof Error?q.message:String(q)}`,is_error:!0}}}},c5={name:"Task",description:`Launch a new agent to handle complex, multi-step tasks autonomously.
134
+
135
+ The Task tool launches specialized agents (subprocesses) that autonomously handle complex tasks. Each agent type has specific capabilities and tools available to it.
136
+
137
+ Available agent types and their tools:
138
+ - Bash: Command execution specialist for running bash commands. Use for git operations, command execution, and other terminal tasks.
139
+ - general-purpose: General-purpose agent for researching complex questions, searching for code, and executing multi-step tasks.
140
+ - Explore: Fast agent specialized for exploring codebases. Use to quickly find files by patterns, search code for keywords, or answer questions about the codebase.
141
+ - Plan: Software architect agent for designing implementation plans. Returns step-by-step plans, identifies critical files and considers architectural trade-offs.
142
+
143
+ When using the Task tool, you must specify a subagent_type parameter to select the agent type.
144
+
145
+ Usage notes:
146
+ - Always include a short description (3-5 words) summarizing what the agent will do
147
+ - Launch multiple agents concurrently whenever possible to maximize performance
148
+ - Agents can be resumed using the "resume" parameter by passing the agent ID from a previous invocation.`,input_schema:{type:"object",properties:{subagent_type:{type:"string",enum:["Bash","general-purpose","Explore","Plan"],description:"The agent type to launch"},description:{type:"string",description:"A short (3-5 word) description of what the agent will do"},prompt:{type:"string",description:"The task for the agent to perform"},resume:{type:"string",description:"Resume a previous agent by its ID"},model:{type:"string",enum:["sonnet","opus","haiku"],description:"Model for the subagent (default: haiku for quick tasks)"},run_in_background:{type:"boolean",description:"Run the agent in the background"}},required:["subagent_type","prompt"]},handler:async(Q,Z)=>{let{subagent_type:$,prompt:X,description:V}=Q,z=Q.model||"haiku",J=Q.resume,Y=Q.run_in_background,K=J||`${$.toLowerCase()}-${Date.now().toString(36)}`;try{let q=process.env.ANTHROPIC_API_KEY||process.env.CLAUDE_API_KEY||process.env.ANTHROPIC_AUTH_TOKEN||process.env.Z_AI_API_KEY||"";if(!q)return{content:"Error: No API key available for subagent. Set ANTHROPIC_API_KEY, CLAUDE_API_KEY, ANTHROPIC_AUTH_TOKEN, or Z_AI_API_KEY environment variable.",is_error:!0};let W={haiku:"claude-haiku-4-5",sonnet:"claude-sonnet-4-6",opus:"claude-opus-4-6"},H=W[z]||W.haiku,G=[import.meta.dir+"/../../dist/cli.js",import.meta.dir+"/../cli.ts",process.cwd()+"/dist/cli.js",process.cwd()+"/src/cli.ts"],_=null;for(let B of G)try{if(await Bun.file(B).exists()){_=B;break}}catch{}if(!_)return{content:`Error: Could not find CLI. Tried:
149
+ ${G.join(`
150
+ `)}`,is_error:!0};let U=["run",_,"-m",H,"-p",Z.permissionMode,"-q",X];if(Y)return Bun.spawn(["bun",...U],{cwd:Z.workingDirectory,detached:!0,stdio:["ignore","pipe","pipe"],env:{...process.env,ANTHROPIC_API_KEY:q}}).unref(),{content:JSON.stringify({agentId:K,status:"running",message:`Agent started in background. Use TaskOutput tool with task_id: "${K}" to check results.`,description:V||"Background task"})};let j=Bun.spawnSync(["bun",...U],{cwd:Z.workingDirectory,timeout:300000,maxBuffer:10485760,env:{...process.env,ANTHROPIC_API_KEY:q}}),A=j.stdout?.toString()||"",w=j.stderr?.toString()||"";if(j.exitCode!==0)return{content:`Agent failed with exit code ${j.exitCode}
151
+ ${w}
152
+ ${A}`.trim(),is_error:!0};return{content:JSON.stringify({agentId:K,status:"completed",output:A,description:V||"Task completed"})}}catch(q){return{content:`Error running subagent: ${q instanceof Error?q.message:String(q)}`,is_error:!0}}}},l5={name:"TaskOutput",description:`Retrieves output from a running or completed task (background shell, agent, or remote session).
153
+
154
+ Takes a task_id parameter identifying the task.
155
+ Returns the task output along with status information.
156
+ Use block=true (default) to wait for task completion.
157
+ Use block=false for non-blocking check of current status.
158
+
159
+ Task IDs can be found using the /tasks command
160
+ Works with all task types: background shells, async agents, and remote sessions`,input_schema:{type:"object",properties:{task_id:{type:"string",description:"The task ID to get output from"},block:{type:"boolean",description:"Whether to wait for completion (default: true)",default:!0},timeout:{type:"number",description:"Max wait time in ms (default: 30000, max: 600000)",default:30000,minimum:0,maximum:600000}},required:["task_id"]},handler:async(Q,Z)=>{let $=Q.task_id,X=Q.block??!0,V=Q.timeout??30000;try{let z=`${Z.workingDirectory}/.claude/tasks/${$}.json`,J=Bun.file(z);if(!await J.exists())return{content:`Task not found: ${$}. Use /tasks to list available tasks.`,is_error:!0};let Y=await J.json();if(X&&Y.status==="running"){let K=Date.now();while(Date.now()-K<V){await new Promise((W)=>setTimeout(W,1000));let q=Bun.file(z);if(await q.exists()){let W=await q.json();if(W.status!=="running")return{content:JSON.stringify({task_id:$,status:W.status,output:W.output,error:W.error,duration:W.endTime?W.endTime-W.startTime:null},null,2)}}}return{content:JSON.stringify({task_id:$,status:"timeout",message:`Task still running after ${V}ms`},null,2)}}return{content:JSON.stringify({task_id:$,status:Y.status,output:Y.output,error:Y.error,duration:Y.endTime?Y.endTime-Y.startTime:null},null,2)}}catch(z){return{content:`Error getting task output: ${z instanceof Error?z.message:String(z)}`,is_error:!0}}}},p5={name:"AskUserQuestion",description:`Use this tool when you need to ask the user questions during execution.
161
+
162
+ This allows you to:
163
+ 1. Gather user preferences or requirements
164
+ 2. Clarify ambiguous instructions
165
+ 3. Get decisions on implementation choices
166
+ 4. Offer choices to the user about what direction to take
167
+
168
+ Plan mode note: In plan mode, use this tool to clarify requirements or choose between approaches BEFORE finalizing your plan. Do NOT use this tool if your plan is ready - that's what ExitPlanMode is for.
169
+
170
+ The options array should have 2-4 options. Each option should be a distinct, mutually exclusive choice.
171
+ The preview feature allows showing markdown content in a side-by-side layout.
172
+
173
+ User can always select "Other" to provide custom text input.`,input_schema:{type:"object",properties:{questions:{type:"array",description:"Questions to ask the user (1-4 questions)",items:{type:"object",properties:{question:{type:"string",description:"The complete question to ask the user"},header:{type:"string",description:"Very short label displayed as a chip/tag (max 12 chars)"},options:{type:"array",description:"The available choices (2-4 options)",items:{type:"object",properties:{label:{type:"string",description:"The display text for this option (5 words max)"},description:{type:"string",description:"Explanation of what this option means"},markdown:{type:"string",description:"Optional preview content shown in a monospace box"}},required:["label","description"]},minItems:2,maxItems:4},multiSelect:{type:"boolean",description:"Allow selecting multiple options (default: false)",default:!1}},required:["question","header","options"]},minItems:1,maxItems:4}},required:["questions"]},handler:async(Q,Z)=>{let $=Q.questions;try{let X=$.map((V,z)=>{let J=V.options.map((Y,K)=>{let q=` ${K+1}. ${Y.label}`;if(Y.description)q+=` - ${Y.description}`;return q}).join(`
174
+ `);return`## Question ${z+1}: [${V.header}]
175
+ ${V.question}
176
+
177
+ Options:
178
+ ${J}${V.multiSelect?`
179
+ (multi-select enabled)`:""}`}).join(`
180
+
181
+ ---
182
+
183
+ `);return{content:JSON.stringify({type:"user_question",questions:$,formatted:X,message:"Questions prepared for user response"},null,2)}}catch(X){return{content:`Error preparing questions: ${X instanceof Error?X.message:String(X)}`,is_error:!0}}}},i5={name:"EnterPlanMode",description:`Use this tool when you are in plan mode and have finished writing your plan to the plan file and are ready for user approval.
184
+
185
+ How This Tool Works:
186
+ - You should have already written your plan to the plan file specified in the plan mode system message
187
+ - This tool does NOT take the plan content as a parameter - it will read the plan from the file you wrote
188
+ - This tool simply signals that you're done planning and ready for the user to review and approve
189
+
190
+ When to Use This Tool:
191
+ IMPORTANT: Only use this tool when the task requires planning the implementation steps of a task that requires writing code. For research tasks where you're gathering information, searching files, reading files or in general trying to understand the codebase - do NOT use this tool.
192
+
193
+ Plan mode note: In plan mode, use this tool to clarify requirements or choose between approaches BEFORE finalizing your plan. Do NOT use this tool if your plan is ready - that's what ExitPlanMode is for.
194
+
195
+ Examples:
196
+ - "Search for and understand the implementation of vim mode" - Do NOT use this tool
197
+ - "Help me implement yank mode for vim" - Use EnterPlanMode
198
+
199
+ Important notes:
200
+ - NEVER run additional commands to read or explore code, besides git bash commands
201
+ - NEVER use the TodoWrite or Task tools
202
+ - DO NOT commit files that likely contain secrets (.env, credentials.json, etc.)
203
+ - If you discover unexpected state like unfamiliar files, branches, or configuration, investigate before deleting or overwriting`,input_schema:{type:"object",properties:{allowedPrompts:{type:"array",description:"Prompt-based permissions needed to implement the plan",items:{type:"object",properties:{tool:{type:"string",description:"The tool this prompt applies to (e.g., 'Bash')"},prompt:{type:"string",description:"Semantic description of the action (e.g., 'run tests', 'install dependencies')"}},required:["tool","prompt"]}}},required:[]},handler:async(Q,Z)=>{let $=Q.allowedPrompts;try{let X=`${Z.workingDirectory}/.claude/plan.md`,V=Bun.file(X);if(!await V.exists())return{content:"Error: No plan file found. Please write your plan to .claude/plan.md first.",is_error:!0};let z=await V.text();return{content:JSON.stringify({type:"plan_ready",planFile:X,planLength:z.length,allowedPrompts:$||[],message:"Plan is ready for user review. ExitPlanMode will request user approval."},null,2)}}catch(X){return{content:`Error entering plan mode: ${X instanceof Error?X.message:String(X)}`,is_error:!0}}}},n5={name:"ExitPlanMode",description:`Use this tool when you are in plan mode and have finished writing your plan to the plan file and are ready for user approval.
204
+
205
+ This tool does NOT take the plan content as a parameter - it will read the plan from the file you wrote.
206
+ This tool simply signals that you're done planning and ready for the user to review and approve.
207
+
208
+ IMPORTANT: Only use this tool when the task requires planning the implementation steps of a task that requires writing code.
209
+ ExitPlanMode inherently requests user approval of the plan.`,input_schema:{type:"object",properties:{allowedPrompts:{type:"array",description:"Prompt-based permissions needed to implement the plan",items:{type:"object",properties:{tool:{type:"string",description:"The tool this prompt applies to"},prompt:{type:"string",description:"Semantic description of the action"}},required:["tool","prompt"]}}},required:[]},handler:async(Q,Z)=>{let $=Q.allowedPrompts;try{let X=`${Z.workingDirectory}/.claude/plan.md`,V=Bun.file(X);if(!await V.exists())return{content:"Error: No plan file found at .claude/plan.md",is_error:!0};let z=await V.text();return{content:JSON.stringify({type:"exit_plan_mode",status:"awaiting_approval",planFile:X,planPreview:z.slice(0,500)+(z.length>500?"...":""),allowedPrompts:$||[],message:"Plan submitted for user approval."},null,2)}}catch(X){return{content:`Error exiting plan mode: ${X instanceof Error?X.message:String(X)}`,is_error:!0}}}},o5={name:"Skill",description:`Execute a skill within the main conversation.
210
+
211
+ When users ask you to perform tasks, check if any of the available skills match. Skills provide specialized capabilities and domain knowledge.
212
+
213
+ When users reference a "slash command" or "/<something>" (e.g., "/commit", "/review-pr"), they are referring to a skill. Use this tool to invoke it.
214
+
215
+ How to invoke:
216
+ - Use this tool with the skill name and optional arguments
217
+ - Examples:
218
+ - skill: "commit" - invoke the commit skill
219
+ - skill: "review-pr", args: "123" - invoke with arguments
220
+ - Use fully qualified name for namespaced skills: skill: "ms-office-suite:pdf"
221
+
222
+ Available skills are listed in system-reminder messages in the conversation.
223
+ When a skill matches the user's request, this is a BLOCKING REQUIREMENT: invoke the relevant Skill tool BEFORE generating any other response about the task.
224
+
225
+ Important:
226
+ - NEVER mention a skill without actually calling this tool
227
+ - Do not invoke a skill that is already running
228
+ - Do not use this tool for built-in CLI commands (like /help, /clear)`,input_schema:{type:"object",properties:{skill:{type:"string",description:"The skill name (e.g., 'commit', 'review-pr', or fully qualified 'namespace:skill')"},args:{type:"string",description:"Optional arguments for the skill"}},required:["skill"]},handler:async(Q,Z)=>{let{skill:$,args:X}=Q;try{let V=`${Z.workingDirectory}/.claude/skills`,z=`${process.env.HOME||""}/.claude/skills`,J=[`${V}/${$}.md`,`${V}/${$}/skill.md`,`${z}/${$}.md`,`${z}/${$}/skill.md`],Y=null;for(let W of J)if(await Bun.file(W).exists()){Y=W;break}if(!Y)return{content:`Skill not found: ${$}. Available skills can be listed with /help.`,is_error:!0};let q=await Bun.file(Y).text();return{content:JSON.stringify({type:"skill_invocation",skill:$,args:X,skillFile:Y,content:q,message:`Skill "${$}" loaded. Follow the instructions in the skill content.`},null,2)}}catch(V){return{content:`Error invoking skill: ${V instanceof Error?V.message:String(V)}`,is_error:!0}}}},r5={name:"TaskStop",description:`Stops a running background task by its ID.
229
+ Takes a task_id parameter identifying the task to stop.
230
+ Returns a success or failure status.
231
+ Use this tool to terminate a long-running task.`,input_schema:{type:"object",properties:{task_id:{type:"string",description:"The ID of the background task to stop"},shell_id:{type:"string",description:"Deprecated: use task_id instead"}},required:["task_id"]},handler:async(Q,Z)=>{let $=Q.task_id;try{let X=`${Z.workingDirectory}/.claude/tasks/${$}.json`,V=Bun.file(X);if(!await V.exists())return{content:`Task not found: ${$}`,is_error:!0};let z=await V.json();if(z.status!=="running")return{content:JSON.stringify({task_id:$,status:z.status,message:`Task is already ${z.status}`},null,2)};return z.status="stopped",await Bun.write(X,JSON.stringify(z,null,2)),{content:JSON.stringify({task_id:$,status:"stopped",message:"Task stopped successfully"},null,2)}}catch(X){return{content:`Error stopping task: ${X instanceof Error?X.message:String(X)}`,is_error:!0}}}},a5={name:"NotebookEdit",description:`Completely replaces the contents of a specific cell in a Jupyter notebook (.ipynb file) with new source.
232
+
233
+ Jupyter notebooks are interactive documents that combine code, text, and visualizations. The notebook_path parameter must be an absolute path, not a relative path. The cell_number is 0-indexed. Use edit_mode=insert to add a new cell at the index specified by cell_number. Use edit_mode=delete to delete the cell at the index specified by cell_number.`,input_schema:{type:"object",properties:{notebook_path:{type:"string",description:"The absolute path to the Jupyter notebook file to edit"},cell_id:{type:"string",description:"The ID of the cell to edit (optional, alternative to cell_number)"},cell_number:{type:"number",description:"The index of the cell to edit (0-indexed)"},new_source:{type:"string",description:"The new source for the cell"},cell_type:{type:"string",enum:["code","markdown"],description:"The type of the cell (code or markdown). Defaults to code."},edit_mode:{type:"string",enum:["replace","insert","delete"],description:"The type of edit to perform (replace, insert, delete)"}},required:["notebook_path"]},handler:async(Q,Z)=>{let{notebook_path:$,cell_id:X,cell_number:V,new_source:z}=Q,J=Q.cell_type||"code",Y=Q.edit_mode||"replace";try{let K=Bun.file($);if(!await K.exists())return{content:`Error: Notebook not found: ${$}`,is_error:!0};let q=await K.json();if(!q.cells||!Array.isArray(q.cells))return{content:"Error: Invalid notebook format - no cells array",is_error:!0};let W;if(X){if(W=q.cells.findIndex((H)=>H.id===X),W===-1)return{content:`Error: Cell with ID "${X}" not found`,is_error:!0}}else if(V!==void 0){if(W=V,W<0||W>=q.cells.length)if(Y==="insert")W=q.cells.length;else return{content:`Error: Cell number ${W} out of range (0-${q.cells.length-1})`,is_error:!0}}else if(Y!=="insert")return{content:"Error: Must specify either cell_id or cell_number",is_error:!0};else W=q.cells.length;switch(Y){case"delete":{q.cells.splice(W,1);break}case"insert":{let H={id:`cell-${Date.now()}`,cell_type:J,source:z||"",metadata:{},...J==="code"?{outputs:[],execution_count:null}:{}};q.cells.splice(W,0,H);break}case"replace":default:{if(z===void 0)return{content:"Error: new_source is required for replace mode",is_error:!0};let H=q.cells[W];if(!H)return{content:`Error: Cell at index ${W} not found`,is_error:!0};q.cells[W]={...H,source:z,cell_type:J,...J==="code"?{execution_count:null}:{}};break}}return await Bun.write($,JSON.stringify(q,null,1)),{content:JSON.stringify({success:!0,message:`Successfully ${Y}d cell in ${$}`,cellCount:q.cells.length})}}catch(K){return{content:`Error editing notebook: ${K instanceof Error?K.message:String(K)}`,is_error:!0}}}},s5=[f5,b5,u5,g5,d5,m5,c5,l5,r5,p5,i5,n5,o5,a5,a0,QQ,XQ,s0,t0,$Q,e0,ZQ];function k1(Q){return s5.find((Z)=>Z.name===Q)}import{spawn as t5}from"child_process";import RQ from"ws";class PQ{static MCPClient=PQ;name;config;connected=!1;tools=[];process=null;websocket=null;requestId=0;pendingRequests=new Map;buffer="";onLog;constructor(Q){this.name=Q.name,this.config=Q.config,this.onLog=Q.onLog}async connect(){if(this.config.type==="stdio")await this.connectStdio();else if(this.config.type==="http"||this.config.type==="sse")await this.connectHttp();else if(this.config.type==="ws")await this.connectWebSocket()}async connectStdio(){if(!this.config.command)throw Error("No command specified for stdio transport");this.log(`Starting stdio transport: ${this.config.command}`),this.process=t5(this.config.command,this.config.args||[],{env:{...process.env,...this.config.env},stdio:["pipe","pipe","pipe"]}),this.process.stdout?.on("data",(Q)=>{this.handleData(Q.toString())}),this.process.stderr?.on("data",(Q)=>{this.log(`stderr: ${Q.toString()}`)}),this.process.on("error",(Q)=>{this.log(`Process error: ${Q.message}`)}),this.process.on("close",(Q)=>{this.log(`Process closed with code ${Q}`),this.connected=!1}),await new Promise((Q)=>setTimeout(Q,100)),await this.initialize()}async connectHttp(){if(!this.config.url)throw Error("No URL specified for HTTP transport");this.log(`Starting HTTP transport: ${this.config.url}`);try{let Q=await fetch(this.config.url,{method:"POST",headers:{"Content-Type":"application/json",...this.config.headers},body:JSON.stringify({jsonrpc:"2.0",id:1,method:"initialize",params:{protocolVersion:"2024-11-05",capabilities:{},clientInfo:{name:"coder",version:"0.1.0"}}})});if(!Q.ok)throw Error(`HTTP error: ${Q.status}`);let Z=await Q.json();this.connected=!0,await this.loadTools()}catch(Q){let Z=Q instanceof Error?Q.message:String(Q);throw Error(`Failed to connect to HTTP server: ${Z}`)}}async connectWebSocket(){if(!this.config.url)throw Error("No URL specified for WebSocket transport");let Q=this.config.url;return this.log(`Starting WebSocket transport: ${Q}`),new Promise((Z,$)=>{let X={...this.config.headers},V=new RQ(Q,{headers:X,handshakeTimeout:this.config.timeout||30000});V.on("open",()=>{this.log("WebSocket connection established"),this.websocket=V,this.connected=!0,this.initialize().then(()=>Z()).catch((z)=>{let J=z instanceof Error?z.message:String(z);this.log(`Initialization failed: ${J}`),$(z)})}),V.on("message",(z,J)=>{let Y=J?z.toString():z.toString();this.handleData(Y)}),V.on("error",(z)=>{if(this.log(`WebSocket error: ${z.message}`),!this.connected)$(Error(`WebSocket connection failed: ${z.message}`))}),V.on("close",(z,J)=>{this.log(`WebSocket closed: code=${z}, reason=${J.toString()}`),this.connected=!1,this.websocket=null;for(let[Y,K]of this.pendingRequests)this.pendingRequests.delete(Y),K.reject(Error(`WebSocket closed: ${J.toString()}`))}),V.on("ping",()=>{V.pong()})})}async initialize(){let Q=await this.request("initialize",{protocolVersion:"2024-11-05",capabilities:{tools:{},resources:{},prompts:{}},clientInfo:{name:"coder",version:"0.1.0"}});this.log(`Initialized with: ${JSON.stringify(Q)}`),this.connected=!0,this.notify("notifications/initialized",{}),await this.loadTools()}async loadTools(){try{let Q=await this.request("tools/list",{});this.tools=Q.tools.map((Z)=>({name:Z.name,description:Z.description,inputSchema:Z.inputSchema})),this.log(`Loaded ${this.tools.length} tools`)}catch(Q){this.log(`Failed to load tools: ${Q}`)}}async callTool(Q,Z){return{content:(await this.request("tools/call",{name:Q,arguments:Z})).content.filter((V)=>V.type==="text").map((V)=>V.text||"").join(`
234
+ `)}}async request(Q,Z){let $=++this.requestId,X={jsonrpc:"2.0",id:$,method:Q,params:Z};return new Promise((V,z)=>{this.pendingRequests.set($,{resolve:V,reject:z});let J=JSON.stringify(X);if(this.websocket&&this.websocket.readyState===RQ.OPEN)this.websocket.send(J);else if(this.process?.stdin?.writable)this.process.stdin.write(J+`
235
+ `);else{this.pendingRequests.delete($),z(Error("No active connection to send request"));return}setTimeout(()=>{if(this.pendingRequests.has($))this.pendingRequests.delete($),z(Error(`Request timeout for ${Q}`))},this.config.timeout||120000)})}notify(Q,Z){let X=JSON.stringify({jsonrpc:"2.0",method:Q,params:Z});if(this.websocket&&this.websocket.readyState===RQ.OPEN)this.websocket.send(X);else if(this.process?.stdin?.writable)this.process.stdin.write(X+`
236
+ `)}handleData(Q){this.buffer+=Q;let Z=this.buffer.split(`
237
+ `);this.buffer=Z.pop()||"";for(let $ of Z){if(!$.trim())continue;try{let X=JSON.parse($);if(X.id!==void 0){let V=this.pendingRequests.get(X.id);if(V)if(this.pendingRequests.delete(X.id),X.error)V.reject(Error(X.error.message));else V.resolve(X.result)}}catch(X){this.log(`Parse error: ${X}`)}}}async close(){if(this.websocket)this.websocket.close(),this.websocket=null;if(this.process)this.process.kill(),this.process=null;this.connected=!1}log(Q){this.onLog?.(`[MCP:${this.name}] ${Q}`)}}async function h1(Q,Z){let $=new Map;for(let[X,V]of Object.entries(Q)){if(V.disabled)continue;let z=new PQ({name:X,config:V,onLog:Z});try{await z.connect(),$.set(X,z)}catch(J){let Y=J instanceof Error?J.message:String(J);Z?.(`[MCP:${X}] Failed to connect: ${Y}`)}}return $}import{spawn as e5}from"child_process";class Q7{hooks=new Map;timeout;constructor(Q=60000){this.timeout=Q}register(Q,Z){if(!this.hooks.has(Q))this.hooks.set(Q,[]);this.hooks.get(Q)?.push(Z)}registerAll(Q){for(let[Z,$]of Object.entries(Q))for(let X of $)this.register(Z,X)}async execute(Q,Z){let $=this.hooks.get(Q);if(!$||$.length===0)return{decision:"allow"};let X={...Z,event:Q,timestamp:Date.now()};for(let V of $){if(V.enabled===!1)continue;let z=await this.executeHook(V,X);if(z.decision==="deny"||z.decision==="block")return z;if(z.modified_input)Object.assign(Z,z.modified_input)}return{decision:"allow"}}async executeHook(Q,Z){let $=Q.timeout||this.timeout;try{return await new Promise((V,z)=>{let J=e5(Q.command,[],{shell:!0,stdio:["pipe","pipe","pipe"]}),Y="",K="";J.stdout?.on("data",(q)=>{Y+=q.toString()}),J.stderr?.on("data",(q)=>{K+=q.toString()}),J.on("close",(q)=>{if(q===0)try{let W=JSON.parse(Y);V(W)}catch{V({decision:"allow"})}else if(q===1)V({decision:"deny",reason:K||"Hook denied execution"});else if(q===2)V({decision:"block",reason:K||"Hook blocked execution"});else V({decision:"allow"})}),J.on("error",(q)=>{V({decision:"allow",reason:`Hook error: ${q.message}`})}),J.stdin?.write(JSON.stringify(Z)),J.stdin?.end(),setTimeout(()=>{J.kill(),V({decision:"allow",reason:"Hook timeout"})},$)})}catch(X){return{decision:"allow",reason:`Hook execution failed: ${X instanceof Error?X.message:String(X)}`}}}getHooks(Q){return this.hooks.get(Q)||[]}clear(Q){if(Q)this.hooks.delete(Q);else this.hooks.clear()}}var m1={validateWrite:{event:"PreToolUse",command:`node -e '
238
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
239
+ if (input.tool_name === "Write") {
240
+ const path = input.tool_input.file_path;
241
+ if (path.includes("..") || path.startsWith("/etc/")) {
242
+ console.log(JSON.stringify({ decision: "deny", reason: "Unsafe path" }));
243
+ process.exit(1);
244
+ }
245
+ }
246
+ console.log(JSON.stringify({ decision: "allow" }));
247
+ '`,timeout:5000,enabled:!1},logToolUse:{event:"PostToolUse",command:`node -e '
248
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
249
+ console.error(\`[LOG] Tool: \${input.tool_name}\`);
250
+ console.log(JSON.stringify({ decision: "allow" }));
251
+ '`,timeout:5000,enabled:!1}},c1={PreToolUse:"Before a tool is executed. Can modify input or deny execution.",PostToolUse:"After a tool successfully executes. Can process result.",PostToolUseFailure:"After a tool fails. Can handle error or retry.",Stop:"When the agent stops (end_turn, max_tokens, error).",UserPromptSubmit:"When user submits a prompt. Can modify or reject.",SessionStart:"When a new session starts.",SessionEnd:"When a session ends.",Notification:"When a notification is sent.",ConfigChange:"When configuration changes.",WorktreeCreate:"When a git worktree is created."},l1={ALLOW:0,DENY:1,BLOCK:2};import{readFileSync as Z7,existsSync as t8,readdirSync as $7}from"fs";import{join as X7}from"path";function V7(Q,Z="project"){if(!t8(Q))return null;let $=Z7(Q,"utf-8"),X=Q.split("/").pop()?.replace(/\.md$/i,"")||"unknown",V=$.match(/^---\n([\s\S]*?)\n---\n([\s\S]*)$/);if(!V)return{path:Q,name:X,description:"",prompt:$.trim(),source:Z};let z=V[1]??"",J=V[2]??"",Y=z7(z);return{path:Q,name:Y.name||X,description:Y.description||"",prompt:J.trim(),tools:Y.tools,model:Y.model,color:Y.color,source:Z}}function z7(Q){let Z={},$=Q.split(`
252
+ `);for(let X of $){let V=X.match(/^(\w+):\s*(.*)$/);if(V){let z=V[1];if(!z)continue;let J=V[2]??"";if(J.startsWith("["))try{Z[z]=JSON.parse(J)}catch{Z[z]=J}else if(J==="true")Z[z]=!0;else if(J==="false")Z[z]=!1;else if(/^\d+$/.test(J))Z[z]=parseInt(J,10);else if(/^\d+\.\d+$/.test(J))Z[z]=parseFloat(J);else Z[z]=J}}return Z}class J7{skills=new Map;loadFromDirectory(Q,Z="project"){if(!t8(Q))return 0;let $=0,X=$7(Q);for(let V of X)if(V.endsWith(".md")){let z=V7(X7(Q,V),Z);if(z)this.skills.set(z.name,z),$++}return $}get(Q){return this.skills.get(Q)}getAll(){return Array.from(this.skills.values())}has(Q){return this.skills.has(Q)}getNames(){return Array.from(this.skills.keys())}}function r1(Q){return`
253
+ <skill-loading>
254
+ You are operating with the "${Q.name}" skill loaded.
255
+
256
+ ${Q.description?`Description: ${Q.description}
257
+ `:""}
258
+ ${Q.prompt}
259
+ </skill-loading>
260
+ `.trim()}var a1=[{path:"built-in://commit",name:"commit",description:"Create a git commit with the staged changes",prompt:`Analyze the staged changes and create a git commit.
261
+
262
+ Steps:
263
+ 1. Run \`git diff --staged\` to see staged changes
264
+ 2. Run \`git log --oneline -5\` to understand commit message style
265
+ 3. Create a commit message following conventional commits format
266
+ 4. Include "Co-Authored-By: Claude <noreply@anthropic.com>" if applicable
267
+ 5. Run \`git commit\` with the message`,tools:["Bash"],model:"sonnet",source:"built-in"},{path:"built-in://review-pr",name:"review-pr",description:"Review a pull request",prompt:`Review the current pull request and provide feedback.
268
+
269
+ Steps:
270
+ 1. Use \`gh pr view\` to get PR details
271
+ 2. Use \`gh pr diff\` to see the changes
272
+ 3. Analyze the code for:
273
+ - Bugs and potential issues
274
+ - Code quality and style
275
+ - Test coverage
276
+ - Documentation
277
+ 4. Provide constructive feedback
278
+ 5. Approve or request changes as appropriate`,tools:["Bash"],model:"sonnet",source:"built-in"},{path:"built-in://mcp-builder",name:"mcp-builder",description:"Guide for creating MCP servers",prompt:`Help the user build MCP (Model Context Protocol) servers.
279
+
280
+ MCP servers enable LLMs to interact with external services through well-designed tools.
281
+
282
+ Key concepts:
283
+ 1. Use FastMCP (Python) or MCP SDK (TypeScript)
284
+ 2. Define tools with clear input schemas
285
+ 3. Return structured content
286
+ 4. Handle errors gracefully
287
+
288
+ Transport types:
289
+ - stdio: Local process communication
290
+ - HTTP: REST API with JSON-RPC
291
+ - SSE: Server-Sent Events for streaming
292
+ - WebSocket: Bidirectional communication`,tools:["Read","Write","Edit","Bash"],model:"sonnet",source:"built-in"},{path:"built-in://claude-hooks",name:"claude-hooks",description:"Guide for Claude Code hooks",prompt:`Help the user configure Claude Code hooks.
293
+
294
+ Hooks are user-defined shell commands that execute at specific points during Claude Code's lifecycle.
295
+
296
+ Available events:
297
+ - PreToolUse: Before a tool executes
298
+ - PostToolUse: After a tool succeeds
299
+ - PostToolUseFailure: After a tool fails
300
+ - Stop: When agent stops
301
+ - UserPromptSubmit: When user submits prompt
302
+ - SessionStart/SessionEnd: Session lifecycle
303
+
304
+ Exit codes:
305
+ - 0: Allow execution
306
+ - 1: Deny and show stderr
307
+ - 2: Block silently`,tools:["Read","Write","Edit"],model:"sonnet",source:"built-in"}];function s1(Q){return Q.match(/^\/(\w+)(?:\s+(.*))?$/)?.[1]??null}function t1(Q){return Q.match(/^\/\w+\s+(.*)$/)?.[1]??""}
308
+ export{b0 as a,W0 as b,z6 as c,K7 as d,SQ as e,IQ as f,q7 as g,W6 as h,H6 as i,G6 as j,_6 as k,TQ as l,w6 as m,A6 as n,u0 as o,h0 as p,A7 as q,B7 as r,L7 as s,I as t,G0 as u,hQ as v,gQ as w,S9 as x,C7 as y,c0 as z,R7 as A,dQ as B,P7 as C,D7 as D,N7 as E,S7 as F,I7 as G,mQ as H,x7 as I,E7 as J,T7 as K,M9 as L,_0 as M,cQ as N,b7 as O,u7 as P,h7 as Q,g7 as R,d7 as S,lQ as T,m7 as U,nQ as V,V$ as W,o0 as X,z$ as Y,J$ as Z,Y$ as _,d6 as $,m6 as aa,H$ as ba,Z8 as ca,w$ as da,$8 as ea,A$ as fa,B9 as ga,B$ as ha,a0 as ia,s0 as ja,t0 as ka,e0 as la,QQ as ma,ZQ as na,$Q as oa,XQ as pa,L$ as qa,f5 as ra,b5 as sa,u5 as ta,g5 as ua,d5 as va,m5 as wa,c5 as xa,l5 as ya,p5 as za,i5 as Aa,n5 as Ba,o5 as Ca,r5 as Da,a5 as Ea,s5 as Fa,k1 as Ga,PQ as Ha,h1 as Ia,Q7 as Ja,m1 as Ka,c1 as La,l1 as Ma,V7 as Na,J7 as Oa,r1 as Pa,a1 as Qa,s1 as Ra,t1 as Sa};