@mk-co/neox-cli 2.0.41 → 2.0.42
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli/main.js +471 -470
- package/dist/sdk/index.js +227 -227
- package/package.json +1 -1
package/dist/sdk/index.js
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import*as
|
|
2
|
-
`)}function
|
|
1
|
+
import*as Ce from'fs';import Ce__default,{realpathSync,readlinkSync,readdirSync,readdir as readdir$1,lstatSync,createReadStream,readFileSync,existsSync,mkdirSync,writeFileSync}from'fs';import*as X from'path';import X__default,{join,dirname,win32,posix}from'path';import*as Js from'os';import Js__default,{homedir,platform}from'os';import*as Z from'fs/promises';import Z__default,{realpath,readlink,readdir,lstat,readFile}from'fs/promises';import Ii from'readline';import {createHash,randomBytes,randomUUID}from'crypto';import Sc from'fast-glob';import {spawn,fork}from'child_process';import {execa,execaSync}from'execa';import ap from'puppeteer-core';import {EventEmitter}from'events';import*as Va from'net';import {fileURLToPath}from'url';import Dl from'stream';import {StringDecoder}from'string_decoder';import Tg from'ajv';import nf from'axios';import Cu from'simple-git';import*as Ru from'chokidar';var Iu=Object.create;var ki=Object.defineProperty;var Mu=Object.getOwnPropertyDescriptor;var Au=Object.getOwnPropertyNames;var Pu=Object.getPrototypeOf,Ou=Object.prototype.hasOwnProperty;var Lu=(r,e)=>()=>(r&&(e=r(r=0)),e);var fa=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),Du=(r,e)=>{for(var t in e)ki(r,t,{get:e[t],enumerable:true});},$u=(r,e,t,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Au(e))!Ou.call(r,n)&&n!==t&&ki(r,n,{get:()=>e[n],enumerable:!(s=Mu(e,n))||s.enumerable});return r};var Nu=(r,e,t)=>(t=r!=null?Iu(Pu(r)):{},$u(ki(t,"default",{value:r,enumerable:true}),r));var ba={};Du(ba,{cliHealthMonitor:()=>Bu,cliLogger:()=>f,debugLog:()=>de,generateCurlCommand:()=>wt,installCrashHandler:()=>Wu,logCurlCommand:()=>Ci});function ju(r,e){let t=new WeakSet;try{return JSON.stringify(r,(s,n)=>{if(e&&s){let i=s.toLowerCase();if(Uu.has(i))return "[REDACTED]"}if(typeof n=="bigint")return n.toString();if(n instanceof Error)return {name:n.name,message:n.message,stack:n.stack};if(typeof n=="function")return "[Function]";if(typeof n=="object"&&n!==null){if(t.has(n))return "[Circular]";t.add(n);}return n})}catch{return JSON.stringify({error:"[Unserializable payload]"})}}function wt(r,e,t,s=true){let n=["curl -X POST \\"];n.push(` '${r}' \\`);for(let[o,a]of Object.entries(e)){let l=a;if(s){let c=o.toLowerCase();if(c==="authorization"||c==="x-api-key"||c==="anthropic-api-key")if(l.startsWith("Bearer ")){let u=l.slice(7);l=`Bearer ${u.slice(0,8)}...${u.slice(-4)}`;}else l.length>12&&(l=`${l.slice(0,8)}...${l.slice(-4)}`);}n.push(` -H '${o}: ${l}' \\`);}let i=ju(t,s);return n.push(` -d '${Gu(i)}'`),n.join(`
|
|
2
|
+
`)}function Gu(r){return r.replace(/'/g,"'\\''")}function Ci(r,e,t){if(process.env.CLI_DEBUG!=="1")return;let s=wt(r,e,t);f.info("CURL","=== LLM Request CURL Command ==="),f.info("CURL",s),f.info("CURL","=== End CURL Command ==="),process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log(`
|
|
3
3
|
[CURL] === LLM Request CURL Command ===`),console.log(s),console.log(`[CURL] === End CURL Command ===
|
|
4
|
-
`));}function
|
|
5
|
-
`}safeStringify(e){let t=new WeakSet;return JSON.stringify(e,(s,n)=>{if(typeof n=="object"&&n!==null){if(t.has(n))return "[Circular]";t.add(n);}return s==="parser"||s==="socket"||s==="_httpMessage"||s==="req"||s==="res"?"[Omitted]":n&&n.type==="Buffer"&&Array.isArray(n.data)?"[Buffer]":typeof n=="function"?"[Function]":n instanceof Error?{name:n.name,message:n.message,stack:n.stack}:n})}write(e,t,s,n){if(!this.enabled)return;let i=this.ensureStream();if(!i||this.backpressured&&e==="debug")return;let o=this.formatMessage(e,t,s,n);!i.write(o)&&!this.backpressured&&(this.backpressured=true,i.once("drain",()=>{this.backpressured=false;}));}debug(e,t,s){this.write("debug",e,t,s);}info(e,t,s){this.write("info",e,t,s);}warn(e,t,s){this.write("warn",e,t,s);}error(e,t,s){this.write("error",e,t,s);}log(e,...t){let s=t.map(n=>{if(typeof n=="string")return n;try{return this.safeStringify(n)}catch{return String(n)}}).join(" ");this.write("info",e,s);}setEnabled(e){this.enabled=e;}getLogDir(){return this.logDir}getCurrentLogFile(){return this.currentLogFile}close(){this.writeStream&&(this.writeStream.end(),this.writeStream=null,this.currentLogFile=null);}},f=new _i,Ou=new Set(["api_key","apikey","authorization","token","access_token","refresh_token","password","secret"]);Si=class{intervalId=null;lastHeartbeat=Date.now();heartbeatCount=0;stdinPausedCount=0;enabled=false;pid=process.pid;start(e=5e3){if(!(this.intervalId||process.env.CLI_DEBUG!=="1")){if(!process.stdin.isTTY){f.debug("HEALTH",`Skipping health monitor in non-TTY process (pid=${this.pid})`);return}this.enabled=true,this.lastHeartbeat=Date.now(),this.heartbeatCount=0,this.stdinPausedCount=0,f.info("HEALTH",`Health monitor started (interval: ${e}ms, pid=${this.pid})`),this.intervalId=setInterval(()=>{this.checkHealth();},e),this.intervalId.unref();}}stop(){this.intervalId&&(clearInterval(this.intervalId),this.intervalId=null,this.enabled=false,f.info("HEALTH","Health monitor stopped"));}stdinDestroyedCount=0;checkHealth(){let e=Date.now(),t=e-this.lastHeartbeat;this.lastHeartbeat=e,this.heartbeatCount++;let s=this.getStdinState();if(s.isPaused?this.stdinPausedCount++:this.stdinPausedCount=0,s.destroyed){if(this.stdinDestroyedCount++,this.stdinDestroyedCount>=3){f.warn("HEALTH",`[pid=${this.pid}] stdin destroyed for ${this.stdinDestroyedCount} checks, exiting to avoid zombie process`),this.stop(),setTimeout(()=>{process.exit(0);},100);return}}else this.stdinDestroyedCount=0;f.debug("HEALTH",`[pid=${this.pid}] Heartbeat #${this.heartbeatCount}`,{elapsed:`${t}ms`,stdin:s,stdinPausedCount:this.stdinPausedCount}),this.stdinPausedCount>=3&&f.warn("HEALTH",`[pid=${this.pid}] \u26A0\uFE0F stdin has been paused for ${this.stdinPausedCount} consecutive checks!`,{stdin:s}),t>1e4&&f.warn("HEALTH",`[pid=${this.pid}] \u26A0\uFE0F Event loop delay detected: ${t}ms (expected ~5000ms)`);}getStdinState(){let e=process.stdin;return {isPaused:typeof e.isPaused=="function"?e.isPaused():false,isTTY:!!e.isTTY,isRaw:!!e.isRaw,readable:e.readable,destroyed:e.destroyed}}logStdinState(e){if(process.env.CLI_DEBUG!=="1")return;let t=this.getStdinState();f.debug("STDIN",`[${e}] stdin state`,t);}logInkState(e,t){process.env.CLI_DEBUG==="1"&&f.debug("INK",`[${e}]`,t);}},$u=new Si;});var nl=ma((Z0,sl)=>{sl.exports=el;function el(r,e,t){r instanceof RegExp&&(r=Qa(r,t)),e instanceof RegExp&&(e=Qa(e,t));var s=tl(r,e,t);return s&&{start:s[0],end:s[1],pre:t.slice(0,s[0]),body:t.slice(s[0]+r.length,s[1]),post:t.slice(s[1]+e.length)}}function Qa(r,e){var t=e.match(r);return t?t[0]:null}el.range=tl;function tl(r,e,t){var s,n,i,o,a,l=t.indexOf(r),c=t.indexOf(e,l+1),u=l;if(l>=0&&c>0){if(r===e)return [l,c];for(s=[],i=t.length;u>=0&&!a;)u==l?(s.push(u),l=t.indexOf(r,u+1)):s.length==1?a=[s.pop(),c]:(n=s.pop(),n<i&&(i=n,o=c),c=t.indexOf(e,u+1)),u=l<c&&l>=0?l:c;s.length&&(a=[i,o]);}return a}});var pl=ma((Q0,ul)=>{var rl=nl();ul.exports=Id;var il="\0SLASH"+Math.random()+"\0",ol="\0OPEN"+Math.random()+"\0",eo="\0CLOSE"+Math.random()+"\0",al="\0COMMA"+Math.random()+"\0",ll="\0PERIOD"+Math.random()+"\0";function Qi(r){return parseInt(r,10)==r?parseInt(r,10):r.charCodeAt(0)}function Rd(r){return r.split("\\\\").join(il).split("\\{").join(ol).split("\\}").join(eo).split("\\,").join(al).split("\\.").join(ll)}function Ed(r){return r.split(il).join("\\").split(ol).join("{").split(eo).join("}").split(al).join(",").split(ll).join(".")}function cl(r){if(!r)return [""];var e=[],t=rl("{","}",r);if(!t)return r.split(",");var s=t.pre,n=t.body,i=t.post,o=s.split(",");o[o.length-1]+="{"+n+"}";var a=cl(i);return i.length&&(o[o.length-1]+=a.shift(),o.push.apply(o,a)),e.push.apply(e,o),e}function Id(r){return r?(r.substr(0,2)==="{}"&&(r="\\{\\}"+r.substr(2)),rn(Rd(r),true).map(Ed)):[]}function Md(r){return "{"+r+"}"}function Ad(r){return /^-?0\d/.test(r)}function Pd(r,e){return r<=e}function Od(r,e){return r>=e}function rn(r,e){var t=[],s=rl("{","}",r);if(!s)return [r];var n=s.pre,i=s.post.length?rn(s.post,false):[""];if(/\$$/.test(s.pre))for(var o=0;o<i.length;o++){var a=n+"{"+s.body+"}"+i[o];t.push(a);}else {var l=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(s.body),c=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(s.body),u=l||c,p=s.body.indexOf(",")>=0;if(!u&&!p)return s.post.match(/,(?!,).*\}/)?(r=s.pre+"{"+s.body+eo+s.post,rn(r)):[r];var d;if(u)d=s.body.split(/\.\./);else if(d=cl(s.body),d.length===1&&(d=rn(d[0],false).map(Md),d.length===1))return i.map(function(T){return s.pre+d[0]+T});var m;if(u){var h=Qi(d[0]),g=Qi(d[1]),y=Math.max(d[0].length,d[1].length),b=d.length==3?Math.abs(Qi(d[2])):1,w=Pd,S=g<h;S&&(b*=-1,w=Od);var x=d.some(Ad);m=[];for(var R=h;w(R,g);R+=b){var L;if(c)L=String.fromCharCode(R),L==="\\"&&(L="");else if(L=String(R),x){var H=y-L.length;if(H>0){var U=new Array(H+1).join("0");R<0?L="-"+U+L.slice(1):L=U+L;}}m.push(L);}}else {m=[];for(var v=0;v<d.length;v++)m.push.apply(m,rn(d[v],false));}for(var v=0;v<m.length;v++)for(var o=0;o<i.length;o++){var a=n+m[v]+i[o];(!e||u||a)&&t.push(a);}}return t}});de();var Kn=class{hosts=new Map;hostConfigs=new Map;workspacePath=null;setWorkspace(e){this.workspacePath=e;for(let t of this.hosts.values())try{t.setWorkDir(e);}catch{}}getWorkspace(){return this.workspacePath}getHost(e){return this.hosts.get(e)}hasHost(e){return this.hosts.has(e)}getHostConfig(e){return this.hostConfigs.get(e)}clearHost(e){this.hosts.delete(e),this.hostConfigs.delete(e);}clearAll(){for(let e of this.hosts.values())try{e.interrupt();}catch{}this.hosts.clear(),this.hostConfigs.clear();}forEachHost(e){for(let[t,s]of this.hosts.entries())e(s,t);}async getOrCreateHost(e){let{sessionId:t,configKey:s,createHost:n}=e,i=this.hosts.get(t);if(i){let a=this.hostConfigs.get(t);if(a===s)return f.info("HOST_CONTROLLER",`\u{1F504} Reusing existing host for session=${t}, configKey=${s}`),i;f.info("HOST_CONTROLLER",`\u{1F5D1}\uFE0F Clearing old host: session=${t}, oldKey=${a}, newKey=${s}`),this.clearHost(t);}f.info("HOST_CONTROLLER",`\u2728 Creating NEW host: session=${t}, configKey=${s}`);let o=await n();return this.hosts.set(t,o),this.hostConfigs.set(t,s),this.workspacePath&&o.setWorkDir(this.workspacePath),o}};function te(r){return r===null?"":typeof r=="string"?r:r.filter(e=>e.type==="text").map(e=>e.text).join("")}var Fu={unknown:0,normal:1,warn:2,soft_limit:3,limit:4};function Vn(r){if(!r)return 0;let e=r.trim();return e.length?Math.ceil(e.length/4):0}function mt(r){let e=te(r.content),t=Vn(e),s=r.tool_calls?.length?Vn(JSON.stringify(r.tool_calls)):0;return t+s}function ze(r){return r.reduce((e,t)=>e+mt(t),0)}function cs(r){let e={systemTokens:0,userTokens:0,assistantTokens:0,toolCallTokens:0,toolResultTokens:0,totalTokens:0};for(let t of r){let s=te(t.content),n=Vn(s),i=t.tool_calls?.length?Vn(JSON.stringify(t.tool_calls)):0;switch(t.role){case "system":e.systemTokens+=n;break;case "user":e.userTokens+=n;break;case "assistant":e.assistantTokens+=n,e.toolCallTokens+=i;break;case "tool":e.toolResultTokens+=n;break;default:e.userTokens+=n+i;}}return e.totalTokens=e.systemTokens+e.userTokens+e.assistantTokens+e.toolCallTokens+e.toolResultTokens,e}function Uu(r,e,t){return !r.contextWindow&&!r.autoCompactLimit?"unknown":r.autoCompactLimit&&e>=r.autoCompactLimit?"limit":t===void 0||r.contextWindow===void 0?"unknown":t>=r.warnThresholds.hard?"limit":t>=r.warnThresholds.soft?"soft_limit":t>=r.warnThresholds.warn?"warn":"normal"}var Yn=class{profile;promptTokensActual=0;completionTokensActual=0;promptTokensEstimate=0;completionTokensEstimate=0;constructor(e){this.profile=e;}updateProfile(e){this.profile=e,this.reset();}reset(){this.promptTokensActual=0,this.completionTokensActual=0,this.promptTokensEstimate=0,this.completionTokensEstimate=0;}setPromptEstimateFromMessages(e){return this.promptTokensActual>0?(this.completionTokensEstimate=0,this.getSnapshot()):(this.promptTokensEstimate=ze(e),this.promptTokensActual=0,this.completionTokensActual=0,this.completionTokensEstimate=0,this.getSnapshot())}addEstimatedOutputTokens(e){return this.completionTokensEstimate=Math.max(0,this.completionTokensEstimate+e),this.getSnapshot()}recordActualUsage(e,t,s){return this.promptTokensActual=e,this.completionTokensActual=t,this.promptTokensEstimate=0,this.completionTokensEstimate=0,this.getSnapshot(s)}getSnapshot(e){let t=this.promptTokensActual||this.promptTokensEstimate,s=this.completionTokensActual+this.completionTokensEstimate,n=t+s,i=this.profile.contextWindow?n/this.profile.contextWindow:void 0,o=Uu(this.profile,n,i);return {profile:this.profile,tokensUsed:n,promptTokens:t,completionTokens:s,messageCount:e,pressure:i,state:o,timestamp:Date.now()}}getStateRank(e){return Fu[e]}estimateMessagesForDisplay(e){return ze(e)}recordCalibration(e,t,s){if(process.env.CLI_DEBUG){let n=t+s,i=e>0?n/e:0;console.log(`[MemoryPressure] \u6821\u51C6: \u4F30\u7B97=${e}, \u5B9E\u9645=${n}, \u6BD4\u7387=${i.toFixed(3)}`);}}};function us(){let r=new Date,e=r.toISOString().slice(0,10).replace(/-/g,""),t=r.toISOString().slice(11,19).replace(/:/g,""),s=Math.random().toString(36).slice(2,6);return `session_${e}_${t}_${s}`}var Ht=class r{sessionId;filePath;directory;options;sequenceNumber=0;initialized=false;constructor(e){typeof e=="string"&&(e={sessionId:e}),this.sessionId=e.sessionId,this.options=e,this.directory=e.directory||Y__default.join(qs__default.homedir(),".neox","sessions"),this.filePath=Y__default.join(this.directory,`${this.sessionId}.jsonl`);}async ensureDirectory(){await Q__default.mkdir(this.directory,{recursive:true});}async ensureInitialized(){if(!this.initialized){await this.ensureDirectory();try{await Q__default.access(this.filePath);let e=await this.readAllItems();e.length>0&&(this.sequenceNumber=Math.max(...e.map(t=>t.seq))+1);}catch{if(this.options.autoCreateMeta!==false){let e={sessionId:this.sessionId,createdAt:new Date().toISOString(),agentName:this.options.agentName,model:this.options.model};await this.appendItem({type:"meta",data:e});}}this.initialized=true;}}async readAllItems(){let e=[];try{let t=xe__default.createReadStream(this.filePath,{encoding:"utf-8"}),s=Ti.createInterface({input:t,crlfDelay:1/0});for await(let n of s)if(n.trim())try{let i=JSON.parse(n);e.push(i);}catch{console.warn(`Invalid JSONL line: ${n.slice(0,50)}...`);}}catch(t){if(t.code!=="ENOENT")throw t}return e.sort((t,s)=>t.seq-s.seq),e}async appendItem(e){await this.ensureDirectory();let t={item:e,timestamp:Date.now(),seq:this.sequenceNumber++},s=JSON.stringify(t)+`
|
|
6
|
-
`;await
|
|
7
|
-
`);await
|
|
8
|
-
`:"","utf-8"),e.length>0?this.sequenceNumber=Math.max(...e.map(s=>s.seq))+1:this.sequenceNumber=0;}async getItems(e){await this.ensureInitialized();let s=(await this.readAllItems()).map(n=>n.item);return e===void 0?s:s.slice(-e)}async addItems(e){if(e.length!==0){await this.ensureInitialized();for(let t of e)await this.appendItem(t);}}async popItem(){await this.ensureInitialized();let e=await this.readAllItems();if(e.length===0)return null;let t=e.pop();return await this.writeAllItems(e),t.item}async popItems(e){if(e<=0)return [];await this.ensureInitialized();let t=await this.readAllItems();if(t.length===0)return [];let s=Math.min(e,t.length),n=t.splice(-s);return await this.writeAllItems(t),n.map(i=>i.item)}async createCheckpoint(e,t){await this.ensureInitialized();let s=`cp_${Date.now()}_${Math.random().toString(36).slice(2,6)}`,n={type:"checkpoint",data:{id:s,name:e,description:t}};return await this.appendItem(n),s}async rollbackToCheckpoint(e){await this.ensureInitialized();let t=await this.readAllItems(),s=t.findIndex(o=>o.item.type==="checkpoint"&&o.item.data.id===e);if(s===-1)throw new Error(`Checkpoint not found: ${e}`);let n=t.slice(0,s+1),i=t.length-n.length;return await this.writeAllItems(n),i}async getCheckpoints(){await this.ensureInitialized();let e=await this.readAllItems(),t=[];for(let s of e)if(s.item.type==="checkpoint"){let n=s.item;t.push({id:n.data.id,name:n.data.name,timestamp:s.timestamp});}return t}async clearSession(){try{await Q__default.unlink(this.filePath);}catch(e){if(e.code!=="ENOENT")throw e}this.sequenceNumber=0,this.initialized=false;}async getMeta(){await this.ensureInitialized();let e=await this.readAllItems();for(let t of e)if(t.item.type==="meta")return t.item.data;return null}async getMessages(){await this.ensureInitialized();let e=await this.readAllItems(),t=[];for(let s of e)s.item.type==="message"&&t.push(s.item.data);return t}async getItemCount(){return (await this.readAllItems()).length}async getTimeline(){return await this.ensureInitialized(),await this.readAllItems()}async replaceTimeline(e){await this.ensureDirectory();let t=e.map((s,n)=>({item:s.item,timestamp:s.timestamp??Date.now(),seq:n}));await this.writeAllItems(t),this.initialized=true;}static async listSessions(e){let t=e||Y__default.join(qs__default.homedir(),".neox","sessions");try{return (await Q__default.readdir(t)).filter(n=>n.endsWith(".jsonl")).map(n=>n.replace(".jsonl",""))}catch{return []}}static async getMostRecentId(e){let t=e||Y__default.join(qs__default.homedir(),".neox","sessions");try{let n=(await Q__default.readdir(t)).filter(o=>o.endsWith(".jsonl"));if(n.length===0)return null;let i=await Promise.all(n.map(async o=>({name:o.replace(".jsonl",""),mtime:(await Q__default.stat(Y__default.join(t,o))).mtime})));return i.sort((o,a)=>a.mtime.getTime()-o.mtime.getTime()),i[0].name}catch{return null}}static async deleteSession(e,t){let s=t||Y__default.join(qs__default.homedir(),".neox","sessions"),n=Y__default.join(s,`${e}.jsonl`);try{return await Q__default.unlink(n),!0}catch{return false}}static async getSessionInfo(e,t){let s=t||Y__default.join(qs__default.homedir(),".neox","sessions"),n=Y__default.join(s,`${e}.jsonl`);try{let i=await Q__default.stat(n);return {sessionId:e,filePath:n,size:i.size,createdAt:i.birthtime,updatedAt:i.mtime}}catch{return null}}static create(e){return new r({sessionId:us(),...e})}};de();function J(r,e,t,s){return {type:"ephemeral",status:e,tool:r,summary:t,final:e==="success"||e==="already_done",...s}}function me(r,e,t,s,n){return {type:"contextual",status:e,tool:r,summary:t,content:s,...n}}function Mt(r,e,t,s){return {type:"summarized",status:e,tool:r,summary:t,...s}}function fa(r){f.info("TOOL_RESULT",`\u{1F504} getResultForLLM input: ${r.tool}`,{type:r.type,status:r.status,tool:r.tool,hasContent:!!r.content,contentLength:r.content?.length||0,summary:r.summary?.substring(0,100)});let e;if(r.type==="ephemeral")if(r.status==="error")r.tool==="edit_file"?e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,error:r.error,verify_hint:r.verify_hint,file_path:r.file_path,actual_content:r.actual_content,expected_start_line:r.expected_start_line,similar_matches:r.metadata?.similar_matches,suggestions:r.metadata?.suggestions}):e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,error:r.error,verify_hint:r.verify_hint,file_path:r.file_path,similar_matches:r.metadata?.similar_matches,suggestions:r.metadata?.suggestions});else {let t=r.metadata?.edit_info;if(r.tool==="edit_file"&&t){let s=t.old_string?t.old_string.length>1e3?t.old_string.substring(0,1e3)+"...":t.old_string:void 0,n=t.new_string?t.new_string.length>1e3?t.new_string.substring(0,1e3)+"...":t.new_string:void 0;e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,final:r.final,file_path:r.file_path,old_string_preview:s,new_string_preview:n,start_line:t.start_line});}else e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,final:r.final,file_path:r.file_path});}else r.type==="summarized"?e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,error:r.error}):e=JSON.stringify(r);return f.info("TOOL_RESULT",`\u2705 getResultForLLM output: ${r.tool}`,{type:r.type,tool:r.tool,llmResultLength:e.length,llmResultPreview:e.substring(0,500)}),e}var vi={write_file:"ephemeral",Write:"ephemeral",edit_file:"ephemeral",Edit:"ephemeral",create_directory:"ephemeral",mkdir:"ephemeral",delete_file:"ephemeral",rename_file:"ephemeral",apply_patch:"ephemeral",move_file:"ephemeral",copy_file:"ephemeral",git_commit:"ephemeral",git_add:"ephemeral",git_push:"ephemeral",git_checkout:"ephemeral",git_branch:"ephemeral",git_merge:"ephemeral",git_stash:"ephemeral",npm_install:"ephemeral",npm_uninstall:"ephemeral",pip_install:"ephemeral",readfile:"contextual",search:"contextual",grep:"contextual",Grep:"contextual",glob:"contextual",Glob:"contextual",search_files:"contextual",ripgrep:"contextual",ls:"contextual",list_directory:"contextual",show_tree:"contextual",git_diff:"contextual",git_status:"contextual",git_blame:"contextual",git_branch_list:"contextual",git_log:"contextual",git_show:"contextual",web_search:"contextual",WebSearch:"contextual",web_fetch:"contextual",WebFetch:"contextual",analyze_code:"contextual",search_symbol:"contextual",get_definitions:"contextual",get_references:"contextual",execute_shell:"summarized",Bash:"summarized",bash:"summarized",shell:"summarized",run_tests:"summarized",run_lint:"summarized",run_format:"summarized",test:"summarized",pytest:"summarized",jest:"summarized",build:"summarized",compile:"summarized",npm_build:"summarized",code_interpreter:"summarized",python_exec:"summarized",browser_debug:"summarized"};function xi(r){if(r.startsWith("mcp__"))return "summarized";if(r in vi)return vi[r];let e=r.toLowerCase();for(let[t,s]of Object.entries(vi))if(t.toLowerCase()===e)return s;return "contextual"}function ya(r){return xi(r)==="contextual"}de();function Js(r){if(!r)return 0;let e=0;for(let t of r){let s=t.codePointAt(0)||0;s>=19968&&s<=40959||s>=12288&&s<=12351||s>=65280&&s<=65519||s>=44032&&s<=55215?e+=.67:e+=.25;}return Math.ceil(e)}var Ks=class{messages=[];maxMessages;constructor(e=500){this.maxMessages=e;}add(e){let t=typeof e.content=="string"?e.content:JSON.stringify(e.content),s=Js(t),n={...e,_timestamp:Date.now(),_estimatedTokens:s};if(this.messages.push(n),e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0&&process.env.CLI_DEBUG==="1"&&f.debug("MEMORY","Assistant message with tool_calls added:",{toolCallCount:e.tool_calls.length,toolCallIds:e.tool_calls.map(i=>({id:i.id,name:i.function.name}))}),this.messages.length>this.maxMessages){let i=this.messages.filter(l=>l.role==="system"),a=this.messages.filter(l=>l.role!=="system").slice(-(this.maxMessages-i.length));this.messages=[...i,...a];}}addToolResult(e,t,s){let n=xi(t),i=null;try{let c=JSON.parse(s);c.type&&c.status&&c.summary&&(i=c);}catch{}let o,a=n;f.info("MEMORY","addToolResult: parsedResult\uFF1A"+i),f.info("MEMORY","addToolResult: effectiveResultType\uFF1A"+a),i?(a=i.type||n,o=fa(i),f.info("MEMORY","\u7CBE\u7B80\u7ED3\u679C: content \uFF1A"+o),f.info("MEMORY",`addToolResult: ${t} parsed as ToolResult`,{parsedResult:JSON.stringify(i).substring(0,500),contentAfter:o.substring(0,500),rawLength:s.length,contentLength:o.length})):(o=s,f.debug("MEMORY",`addToolResult: ${t} using raw output`,{rawOutput:s.substring(0,500),rawLength:s.length}));let l={role:"tool",tool_call_id:e,name:t,content:o,_resultType:a,_toolName:t,_timestamp:Date.now(),_estimatedTokens:Js(o)};if(process.env.CLI_DEBUG==="1"&&f.debug("MEMORY","Tool result message added:",{toolName:t,toolCallId:e,contentLength:o.length,contentPreview:o.substring(0,200)}),this.messages.push(l),this.messages.length>this.maxMessages){let c=this.messages.filter(d=>d.role==="system"),p=this.messages.filter(d=>d.role!=="system").slice(-(this.maxMessages-c.length));this.messages=[...c,...p];}}stripMetadata(e){let{_resultType:t,_toolName:s,_timestamp:n,_estimatedTokens:i,_tag:o,...a}=e;return a}getAll(){return this.messages.map(e=>this.stripMetadata(e))}getRawMessages(){return this.messages}getMessagesForLLM(){let e=this.messages.map(t=>this.stripMetadata(t));if(process.env.CLI_DEBUG==="1"){let t=e.filter(i=>i.role==="assistant"),s=e.filter(i=>i.role==="tool");f.debug("MEMORY","Messages for LLM:",{totalMessages:e.length,assistantCount:t.length,toolCount:s.length,messageSequence:e.map(i=>i.role).join(" -> ")}),e.slice(-5).forEach((i,o)=>{i.role==="assistant"&&i.tool_calls?f.debug("MEMORY",`Message ${e.length-5+o} (assistant):`,{toolCalls:i.tool_calls.map(a=>({id:a.id,name:a.function.name}))}):i.role==="tool"&&f.debug("MEMORY",`Message ${e.length-5+o} (tool):`,{name:i.name,tool_call_id:i.tool_call_id,contentLength:typeof i.content=="string"?i.content.length:0});});}return e}hasConversationMessages(){return this.messages.some(e=>e.role==="user"||e.role==="assistant")}upsertSystemTagged(e,t){let s=t.trim();if(!s){this.removeSystemTagged(e);return}let n=this.messages.findIndex(a=>a.role==="system"&&a._tag===e);if(n>=0){let a=this.messages[n];if(a.content===s)return;this.messages[n]={...a,content:s,_timestamp:Date.now(),_estimatedTokens:Js(s)};return}let i={role:"system",content:s,_tag:e,_timestamp:Date.now(),_estimatedTokens:Js(s)},o=this.getSystemInsertIndex();this.messages=[...this.messages.slice(0,o),i,...this.messages.slice(o)];}removeSystemTagged(e){let t=this.messages.length;this.messages=this.messages.filter(s=>!(s.role==="system"&&s._tag===e)),t!==this.messages.length&&process.env.CLI_DEBUG==="1"&&f.debug("MEMORY",`Removed system tag: ${e}`);}getSystemInsertIndex(){let e=0;for(;e<this.messages.length&&this.messages[e].role==="system";)e+=1;return e}cleanupEphemeral(){let e=this.messages.length,t=new Set;for(let s of this.messages)if(s.role==="assistant"&&s.tool_calls)for(let n of s.tool_calls)n.id&&t.add(n.id);return this.messages=this.messages.filter(s=>s._resultType!=="ephemeral"||s.role!=="tool"||!s.tool_call_id?true:t.has(s.tool_call_id)),e-this.messages.length}getStats(){let e={total:this.messages.length,ephemeral:0,contextual:0,summarized:0,other:0};for(let t of this.messages)t._resultType==="ephemeral"?e.ephemeral++:t._resultType==="contextual"?e.contextual++:t._resultType==="summarized"?e.summarized++:e.other++;return e}checkContextHealth(){let e={ephemeral:{count:0,tokens:0},contextual:{count:0,tokens:0},summarized:{count:0,tokens:0},other:{count:0,tokens:0}},t=0,s=0,n=0;for(let a of this.messages){let l=a._estimatedTokens||Js(typeof a.content=="string"?a.content:JSON.stringify(a.content));t+=l,a.role==="tool"?(n++,s+=l,a._resultType==="ephemeral"?(e.ephemeral.count++,e.ephemeral.tokens+=l):a._resultType==="contextual"?(e.contextual.count++,e.contextual.tokens+=l):a._resultType==="summarized"?(e.summarized.count++,e.summarized.tokens+=l):(e.other.count++,e.other.tokens+=l)):(e.other.count++,e.other.tokens+=l);}let i=t>0?s/t:0,o=[];return i>.5?o.push(`Tool results\u5360\u7528 ${(i*100).toFixed(1)}% \u7684\u4E0A\u4E0B\u6587\uFF08\u8D85\u8FC750%\u8B66\u6212\u7EBF\uFF09`):i>.4&&o.push(`Tool results\u5360\u7528 ${(i*100).toFixed(1)}% \u7684\u4E0A\u4E0B\u6587\uFF08\u63A5\u8FD1\u8B66\u6212\u7EBF\uFF09`),t>18e4?o.push(`\u4E0A\u4E0B\u6587\u5DF2\u8FBE ${t} tokens\uFF08\u8D85\u8FC7180k\uFF0C\u5EFA\u8BAE\u6E05\u7406\uFF09`):t>15e4&&o.push(`\u4E0A\u4E0B\u6587\u5DF2\u8FBE ${t} tokens\uFF08\u63A5\u8FD1180k\uFF09`),n>100?o.push(`\u5DE5\u5177\u8C03\u7528\u5386\u53F2\u8FC7\u957F\uFF08${n} \u6761\uFF09`):n>60&&o.push(`\u5DE5\u5177\u8C03\u7528\u5386\u53F2\u8F83\u957F\uFF08${n} \u6761\uFF09`),e.ephemeral.count>10&&o.push(`\u79EF\u7D2F\u4E86 ${e.ephemeral.count} \u6761 ephemeral \u6D88\u606F\uFF0C\u5EFA\u8BAE\u6E05\u7406`),{totalTokens:t,toolResultTokens:s,toolResultRatio:i,messageCount:this.messages.length,toolMessageCount:n,warnings:o,shouldCompress:i>.3||t>12e4,shouldCleanup:t>15e4||e.ephemeral.count>5,byType:e}}getTokenSummary(){let e=this.checkContextHealth(),t=[`Total: ${e.totalTokens} tokens`,`Tool: ${e.toolResultTokens} (${(e.toolResultRatio*100).toFixed(1)}%)`,`Messages: ${e.messageCount}`];return e.byType.ephemeral.count>0&&t.push(`Ephemeral: ${e.byType.ephemeral.count}`),t.join(" | ")}getMemoryFootprint(){let e=JSON.stringify(this.messages),t=new Blob([e]).size,s=Math.round(t/1024*10)/10,n=this.messages.length*150,i=t+n,o=Math.round(i/1024*10)/10;return {totalKB:o,messagesKB:s,messageCount:this.messages.length,averageKBPerMessage:this.messages.length>0?Math.round(o/this.messages.length*10)/10:0}}logMemoryStats(){let e=this.checkContextHealth(),t=this.getMemoryFootprint();f.info("MEMORY_STATS","ShortTermMemory snapshot",{memoryTotalKB:t.totalKB,memoryMessagesKB:t.messagesKB,avgKBPerMessage:t.averageKBPerMessage,totalTokens:e.totalTokens,toolResultTokens:e.toolResultTokens,toolResultRatio:`${(e.toolResultRatio*100).toFixed(1)}%`,messageCount:e.messageCount,toolMessageCount:e.toolMessageCount,maxMessages:this.maxMessages,byType:{ephemeral:`${e.byType.ephemeral.count} msgs, ${e.byType.ephemeral.tokens} tokens`,contextual:`${e.byType.contextual.count} msgs, ${e.byType.contextual.tokens} tokens`,summarized:`${e.byType.summarized.count} msgs, ${e.byType.summarized.tokens} tokens`,other:`${e.byType.other.count} msgs, ${e.byType.other.tokens} tokens`},warnings:e.warnings.length>0?e.warnings:["None"],shouldCompress:e.shouldCompress,shouldCleanup:e.shouldCleanup});}clear(){let e=this.messages.filter(t=>t.role==="system");this.messages=e;}setMessages(e){let t=Array.isArray(e)?e:[],s=t.filter(a=>a.role==="system"),n=t.filter(a=>a.role!=="system"),i=Math.max(0,this.maxMessages-s.length),o=i>0?n.slice(-i):[];this.messages=[...s,...o].map(a=>({...a,_timestamp:Date.now()}));}get length(){return this.messages.length}};var At=class{directory;options;sessionCache=new Map;constructor(e){this.options=e||{},this.directory=e?.directory||Y__default.join(qs__default.homedir(),".neox","sessions");}async getSession(e){if(this.sessionCache.has(e))return this.sessionCache.get(e);let t=new Ht({sessionId:e,directory:this.directory,agentName:this.options.defaultAgentName,model:this.options.defaultModel});return this.sessionCache.set(e,t),t}async listSessions(){let e=[];try{await Q__default.mkdir(this.directory,{recursive:!0});let t=await Q__default.readdir(this.directory);for(let s of t){if(!s.endsWith(".jsonl"))continue;let n=s.replace(".jsonl",""),i=Y__default.join(this.directory,s);try{let o=await Q__default.stat(i),a=await this.readSessionMeta(i),l=await this.countItems(i);e.push({sessionId:n,createdAt:o.birthtime,updatedAt:o.mtime,itemCount:l,agentName:a?.agentName});}catch{}}}catch(t){if(t.code!=="ENOENT")throw t}return e.sort((t,s)=>s.updatedAt.getTime()-t.updatedAt.getTime()),e}async getMostRecent(){let e=await this.listSessions();return e.length===0?null:this.getSession(e[0].sessionId)}async deleteSession(e){this.sessionCache.delete(e);let t=Y__default.join(this.directory,`${e}.jsonl`);try{return await Q__default.unlink(t),!0}catch{return false}}async searchSessions(e){let t=await this.listSessions(),s=e.toLowerCase(),n=[];for(let i of t){if(i.sessionId.toLowerCase().includes(s)){n.push(i);continue}if(i.agentName?.toLowerCase().includes(s)){n.push(i);continue}let o=Y__default.join(this.directory,`${i.sessionId}.jsonl`);await this.searchInFile(o,s)&&n.push(i);}return n}async createSession(e){let t=e?.sessionId||us(),s=new Ht({sessionId:t,directory:this.directory,agentName:e?.agentName||this.options.defaultAgentName,model:e?.model||this.options.defaultModel});return this.sessionCache.set(t,s),s}async getOrCreateSession(e){return e?this.getSession(e):this.createSession()}async continueOrCreate(){let e=await this.getMostRecent();return e||this.createSession()}async cleanupOldSessions(e=30){let t=await this.listSessions(),s=Date.now()-e*24*60*60*1e3,n=0;for(let i of t)i.updatedAt.getTime()<s&&await this.deleteSession(i.sessionId)&&n++;return n}getDirectory(){return this.directory}async getSessionCount(){return (await this.listSessions()).length}async exportSession(e){let t=await this.getSession(e),s=await t.getItems(),n=await t.getMeta();return JSON.stringify({sessionId:e,meta:n,items:s,exportedAt:new Date().toISOString()},null,2)}async readSessionMeta(e){try{let t=createReadStream(e,{encoding:"utf-8"}),s=Ti.createInterface({input:t,crlfDelay:1/0});for await(let n of s)if(n.trim())try{let i=JSON.parse(n);if(i.item?.type==="meta")return s.close(),i.item.data}catch{}}catch{}return null}async countItems(e){let t=0;try{let s=createReadStream(e,{encoding:"utf-8"}),n=Ti.createInterface({input:s,crlfDelay:1/0});for await(let i of n)i.trim()&&t++;}catch{}return t}async searchInFile(e,t){try{let s=createReadStream(e,{encoding:"utf-8"}),n=Ti.createInterface({input:s,crlfDelay:1/0});for await(let i of n)if(i.toLowerCase().includes(t))return n.close(),!0}catch{}return false}};var Ju={python:{command:"python3",args:["{file}"],extension:".py",useTempFile:true},javascript:{command:"node",args:["{file}"],extension:".js",useTempFile:true},typescript:{command:"npx",args:["tsx","{file}"],extension:".ts",useTempFile:true},bash:{command:"bash",args:["{file}"],extension:".sh",useTempFile:true},shell:{command:"sh",args:["{file}"],extension:".sh",useTempFile:true}},Ku={timeout:3e4,maxMemoryMB:512,maxCPUPercent:50,allowNetwork:true,allowFileSystem:true,workingDirectory:process.cwd(),env:{},captureImages:false,maxOutputSize:1e4},ot=class{config;constructor(e={}){this.config={...Ku,...e};}async execute(e,t){let s=Date.now(),n=Ju[t];if(!n)return {success:false,stdout:"",stderr:"",exitCode:1,executionTime:0,error:`Unsupported language: ${t}`};if(!await this.checkRuntimeAvailable(n.command))return {success:false,stdout:"",stderr:"",exitCode:1,executionTime:0,error:`Runtime not found: ${n.command}. Please install it first.`};let o=null;try{n.useTempFile&&(o=await this.createTempFile(e,n.extension));let a=n.args.map(h=>h.replace("{file}",o||"")),l=o?Y__default.dirname(o):this.config.workingDirectory,c=[n.command,...a].join(" "),u={...Object.fromEntries(Object.entries(process.env).filter(([h,g])=>g!==void 0)),...this.config.env};t==="python"&&this.config.captureImages&&(u.MPLBACKEND="Agg");let p=await this.executeCommand(n.command,a,u,l),d=[];this.config.captureImages&&o&&(d=await this.captureGeneratedImages(Y__default.dirname(o)));let m=Date.now()-s;return {...p,executionTime:m,command:c,workingDirectory:l,images:d&&d.length>0?d:void 0}}catch(a){let l=Date.now()-s;return {success:false,stdout:a.stdout||"",stderr:a.stderr||"",exitCode:a.exitCode||1,executionTime:l,error:a.message,timedOut:a.timedOut||false}}finally{o&&await this.cleanupTempFile(o);}}async checkRuntimeAvailable(e){try{return await execa(e,["--version"],{timeout:5e3}),!0}catch{return false}}async createTempFile(e,t){let s=await Q__default.mkdtemp(Y__default.join(qs__default.tmpdir(),"neox-code-")),n=Y__default.join(s,`script${t}`);return await Q__default.writeFile(n,e,"utf-8"),n}async executeCommand(e,t,s,n){try{let{stdout:i,stderr:o,exitCode:a}=await execa(e,t,{timeout:this.config.timeout,cwd:n,env:s,all:!0,reject:!1}),l=this.truncateOutput(i),c=this.truncateOutput(o);return {success:a===0,stdout:l,stderr:c,exitCode:a||0}}catch(i){throw i.timedOut?{stdout:i.stdout||"",stderr:i.stderr||"",exitCode:-1,message:`Execution timed out after ${this.config.timeout}ms`,timedOut:true}:{stdout:i.stdout||"",stderr:i.stderr||"",exitCode:i.exitCode||1,message:i.message}}}truncateOutput(e){if(e.length<=this.config.maxOutputSize)return e;let t=Math.floor(this.config.maxOutputSize/2);return e.slice(0,t)+`
|
|
4
|
+
`));}function de(r,e,t){if(process.env.CLI_DEBUG==="1"&&(f.debug(r,e,t),process.env.CLI_DEBUG_CONSOLE==="1")){let s=r?`[${r}]`:"";t!==void 0?console.log(s,e,t):console.log(s,e);}}function Wu(){process.on("uncaughtException",r=>{f.error("CRASH","Uncaught Exception",{name:r.name,message:r.message,stack:r.stack}),setTimeout(()=>process.exit(1),100);}),process.on("unhandledRejection",r=>{f.error("CRASH","Unhandled Rejection",{reason:r instanceof Error?{name:r.name,message:r.message,stack:r.stack}:r});});try{process.on("SIGTTIN","ignore"),process.on("SIGTTOU","ignore"),f.info("SIGNAL","TTY control signals (SIGTTIN/SIGTTOU) initialized in crashHandler");}catch{}process.on("exit",()=>{f.close();});}var Ti,f,Uu,xi,Bu,me=Lu(()=>{Ti=class{logDir;enabled=true;initialized=false;writeStream=null;currentLogFile=null;backpressured=false;constructor(){this.logDir=X__default.join(Js__default.homedir(),".neox","logs");}init(){if(!this.initialized)try{Ce__default.existsSync(this.logDir)||Ce__default.mkdirSync(this.logDir,{recursive:!0}),this.initialized=!0;}catch{this.enabled=false;}}getLogFilePath(){let e=new Date().toISOString().split("T")[0];return X__default.join(this.logDir,`cli-${e}.log`)}ensureStream(){if(!this.enabled||(this.init(),!this.initialized))return null;let e=this.getLogFilePath();return this.currentLogFile!==e&&(this.writeStream&&this.writeStream.end(),this.writeStream=Ce__default.createWriteStream(e,{flags:"a"}),this.writeStream.on("error",()=>{this.enabled=false,this.currentLogFile=null;let t=this.writeStream;this.writeStream=null;try{t?.destroy();}catch{}}),this.currentLogFile=e),this.writeStream}formatLocalTime(){let e=new Date,t=e.getFullYear(),s=String(e.getMonth()+1).padStart(2,"0"),n=String(e.getDate()).padStart(2,"0"),i=String(e.getHours()).padStart(2,"0"),o=String(e.getMinutes()).padStart(2,"0"),a=String(e.getSeconds()).padStart(2,"0"),l=String(e.getMilliseconds()).padStart(3,"0");return `${t}-${s}-${n} ${i}:${o}:${a}.${l}`}formatMessage(e,t,s,n){let i=this.formatLocalTime(),o=e.toUpperCase().padEnd(5),a=t?`[${t}]`:"",l=`${i} ${o} ${a} ${s}`;if(n!==void 0)try{let c=this.safeStringify(n);l+=` ${c}`;}catch{l+=" [Serialization Error]";}return l+`
|
|
5
|
+
`}safeStringify(e){let t=new WeakSet;return JSON.stringify(e,(s,n)=>{if(typeof n=="object"&&n!==null){if(t.has(n))return "[Circular]";t.add(n);}return s==="parser"||s==="socket"||s==="_httpMessage"||s==="req"||s==="res"?"[Omitted]":n&&n.type==="Buffer"&&Array.isArray(n.data)?"[Buffer]":typeof n=="function"?"[Function]":n instanceof Error?{name:n.name,message:n.message,stack:n.stack}:n})}write(e,t,s,n){if(!this.enabled)return;let i=this.ensureStream();if(!i||this.backpressured&&e==="debug")return;let o=this.formatMessage(e,t,s,n);!i.write(o)&&!this.backpressured&&(this.backpressured=true,i.once("drain",()=>{this.backpressured=false;}));}debug(e,t,s){this.write("debug",e,t,s);}info(e,t,s){this.write("info",e,t,s);}warn(e,t,s){this.write("warn",e,t,s);}error(e,t,s){this.write("error",e,t,s);}log(e,...t){let s=t.map(n=>{if(typeof n=="string")return n;try{return this.safeStringify(n)}catch{return String(n)}}).join(" ");this.write("info",e,s);}setEnabled(e){this.enabled=e;}getLogDir(){return this.logDir}getCurrentLogFile(){return this.currentLogFile}close(){this.writeStream&&(this.writeStream.end(),this.writeStream=null,this.currentLogFile=null);}},f=new Ti,Uu=new Set(["api_key","apikey","authorization","token","access_token","refresh_token","password","secret"]);xi=class{intervalId=null;lastHeartbeat=Date.now();heartbeatCount=0;stdinPausedCount=0;enabled=false;pid=process.pid;start(e=5e3){if(!(this.intervalId||process.env.CLI_DEBUG!=="1")){if(!process.stdin.isTTY){f.debug("HEALTH",`Skipping health monitor in non-TTY process (pid=${this.pid})`);return}this.enabled=true,this.lastHeartbeat=Date.now(),this.heartbeatCount=0,this.stdinPausedCount=0,f.info("HEALTH",`Health monitor started (interval: ${e}ms, pid=${this.pid})`),this.intervalId=setInterval(()=>{this.checkHealth();},e),this.intervalId.unref();}}stop(){this.intervalId&&(clearInterval(this.intervalId),this.intervalId=null,this.enabled=false,f.info("HEALTH","Health monitor stopped"));}stdinDestroyedCount=0;checkHealth(){let e=Date.now(),t=e-this.lastHeartbeat;this.lastHeartbeat=e,this.heartbeatCount++;let s=this.getStdinState();if(s.isPaused?this.stdinPausedCount++:this.stdinPausedCount=0,s.destroyed){if(this.stdinDestroyedCount++,this.stdinDestroyedCount>=3){f.warn("HEALTH",`[pid=${this.pid}] stdin destroyed for ${this.stdinDestroyedCount} checks, exiting to avoid zombie process`),this.stop(),setTimeout(()=>{process.exit(0);},100);return}}else this.stdinDestroyedCount=0;f.debug("HEALTH",`[pid=${this.pid}] Heartbeat #${this.heartbeatCount}`,{elapsed:`${t}ms`,stdin:s,stdinPausedCount:this.stdinPausedCount}),this.stdinPausedCount>=3&&f.warn("HEALTH",`[pid=${this.pid}] \u26A0\uFE0F stdin has been paused for ${this.stdinPausedCount} consecutive checks!`,{stdin:s}),t>1e4&&f.warn("HEALTH",`[pid=${this.pid}] \u26A0\uFE0F Event loop delay detected: ${t}ms (expected ~5000ms)`);}getStdinState(){let e=process.stdin;return {isPaused:typeof e.isPaused=="function"?e.isPaused():false,isTTY:!!e.isTTY,isRaw:!!e.isRaw,readable:e.readable,destroyed:e.destroyed}}logStdinState(e){if(process.env.CLI_DEBUG!=="1")return;let t=this.getStdinState();f.debug("STDIN",`[${e}] stdin state`,t);}logInkState(e,t){process.env.CLI_DEBUG==="1"&&f.debug("INK",`[${e}]`,t);}},Bu=new xi;});var ol=fa((aw,il)=>{il.exports=nl;function nl(r,e,t){r instanceof RegExp&&(r=sl(r,t)),e instanceof RegExp&&(e=sl(e,t));var s=rl(r,e,t);return s&&{start:s[0],end:s[1],pre:t.slice(0,s[0]),body:t.slice(s[0]+r.length,s[1]),post:t.slice(s[1]+e.length)}}function sl(r,e){var t=e.match(r);return t?t[0]:null}nl.range=rl;function rl(r,e,t){var s,n,i,o,a,l=t.indexOf(r),c=t.indexOf(e,l+1),u=l;if(l>=0&&c>0){if(r===e)return [l,c];for(s=[],i=t.length;u>=0&&!a;)u==l?(s.push(u),l=t.indexOf(r,u+1)):s.length==1?a=[s.pop(),c]:(n=s.pop(),n<i&&(i=n,o=c),c=t.indexOf(e,u+1)),u=l<c&&l>=0?l:c;s.length&&(a=[i,o]);}return a}});var hl=fa((lw,ml)=>{var al=ol();ml.exports=Dd;var ll="\0SLASH"+Math.random()+"\0",cl="\0OPEN"+Math.random()+"\0",ro="\0CLOSE"+Math.random()+"\0",ul="\0COMMA"+Math.random()+"\0",pl="\0PERIOD"+Math.random()+"\0";function no(r){return parseInt(r,10)==r?parseInt(r,10):r.charCodeAt(0)}function Od(r){return r.split("\\\\").join(ll).split("\\{").join(cl).split("\\}").join(ro).split("\\,").join(ul).split("\\.").join(pl)}function Ld(r){return r.split(ll).join("\\").split(cl).join("{").split(ro).join("}").split(ul).join(",").split(pl).join(".")}function dl(r){if(!r)return [""];var e=[],t=al("{","}",r);if(!t)return r.split(",");var s=t.pre,n=t.body,i=t.post,o=s.split(",");o[o.length-1]+="{"+n+"}";var a=dl(i);return i.length&&(o[o.length-1]+=a.shift(),o.push.apply(o,a)),e.push.apply(e,o),e}function Dd(r){return r?(r.substr(0,2)==="{}"&&(r="\\{\\}"+r.substr(2)),on(Od(r),true).map(Ld)):[]}function $d(r){return "{"+r+"}"}function Nd(r){return /^-?0\d/.test(r)}function Fd(r,e){return r<=e}function Ud(r,e){return r>=e}function on(r,e){var t=[],s=al("{","}",r);if(!s)return [r];var n=s.pre,i=s.post.length?on(s.post,false):[""];if(/\$$/.test(s.pre))for(var o=0;o<i.length;o++){var a=n+"{"+s.body+"}"+i[o];t.push(a);}else {var l=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(s.body),c=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(s.body),u=l||c,p=s.body.indexOf(",")>=0;if(!u&&!p)return s.post.match(/,(?!,).*\}/)?(r=s.pre+"{"+s.body+ro+s.post,on(r)):[r];var d;if(u)d=s.body.split(/\.\./);else if(d=dl(s.body),d.length===1&&(d=on(d[0],false).map($d),d.length===1))return i.map(function(C){return s.pre+d[0]+C});var m;if(u){var h=no(d[0]),g=no(d[1]),y=Math.max(d[0].length,d[1].length),b=d.length==3?Math.abs(no(d[2])):1,w=Fd,S=g<h;S&&(b*=-1,w=Ud);var x=d.some(Nd);m=[];for(var R=h;w(R,g);R+=b){var $;if(c)$=String.fromCharCode(R),$==="\\"&&($="");else if($=String(R),x){var G=y-$.length;if(G>0){var U=new Array(G+1).join("0");R<0?$="-"+U+$.slice(1):$=U+$;}}m.push($);}}else {m=[];for(var T=0;T<d.length;T++)m.push.apply(m,on(d[T],false));}for(var T=0;T<m.length;T++)for(var o=0;o<i.length;o++){var a=n+m[T]+i[o];(!e||u||a)&&t.push(a);}}return t}});me();var Vn=class{hosts=new Map;hostConfigs=new Map;workspacePath=null;setWorkspace(e){this.workspacePath=e;for(let t of this.hosts.values())try{t.setWorkDir(e);}catch{}}getWorkspace(){return this.workspacePath}getHost(e){return this.hosts.get(e)}hasHost(e){return this.hosts.has(e)}getHostConfig(e){return this.hostConfigs.get(e)}clearHost(e){this.hosts.delete(e),this.hostConfigs.delete(e);}clearAll(){for(let e of this.hosts.values())try{e.interrupt();}catch{}this.hosts.clear(),this.hostConfigs.clear();}forEachHost(e){for(let[t,s]of this.hosts.entries())e(s,t);}async getOrCreateHost(e){let{sessionId:t,configKey:s,createHost:n}=e,i=this.hosts.get(t);if(i){let a=this.hostConfigs.get(t);if(a===s)return f.info("HOST_CONTROLLER",`\u{1F504} Reusing existing host for session=${t}, configKey=${s}`),i;f.info("HOST_CONTROLLER",`\u{1F5D1}\uFE0F Clearing old host: session=${t}, oldKey=${a}, newKey=${s}`),this.clearHost(t);}f.info("HOST_CONTROLLER",`\u2728 Creating NEW host: session=${t}, configKey=${s}`);let o=await n();return this.hosts.set(t,o),this.hostConfigs.set(t,s),this.workspacePath&&o.setWorkDir(this.workspacePath),o}};function se(r){return r===null?"":typeof r=="string"?r:r.filter(e=>e.type==="text").map(e=>e.text).join("")}var Hu={unknown:0,normal:1,warn:2,soft_limit:3,limit:4};function Yn(r){if(!r)return 0;let e=r.trim();return e.length?Math.ceil(e.length/4):0}function mt(r){let e=se(r.content),t=Yn(e),s=r.tool_calls?.length?Yn(JSON.stringify(r.tool_calls)):0;return t+s}function ze(r){return r.reduce((e,t)=>e+mt(t),0)}function cs(r){let e={systemTokens:0,userTokens:0,assistantTokens:0,toolCallTokens:0,toolResultTokens:0,totalTokens:0};for(let t of r){let s=se(t.content),n=Yn(s),i=t.tool_calls?.length?Yn(JSON.stringify(t.tool_calls)):0;switch(t.role){case "system":e.systemTokens+=n;break;case "user":e.userTokens+=n;break;case "assistant":e.assistantTokens+=n,e.toolCallTokens+=i;break;case "tool":e.toolResultTokens+=n;break;default:e.userTokens+=n+i;}}return e.totalTokens=e.systemTokens+e.userTokens+e.assistantTokens+e.toolCallTokens+e.toolResultTokens,e}function zu(r,e,t){return !r.contextWindow&&!r.autoCompactLimit?"unknown":r.autoCompactLimit&&e>=r.autoCompactLimit?"limit":t===void 0||r.contextWindow===void 0?"unknown":t>=r.warnThresholds.hard?"limit":t>=r.warnThresholds.soft?"soft_limit":t>=r.warnThresholds.warn?"warn":"normal"}var Xn=class{profile;promptTokensActual=0;completionTokensActual=0;promptTokensEstimate=0;completionTokensEstimate=0;constructor(e){this.profile=e;}updateProfile(e){this.profile=e,this.reset();}reset(){this.promptTokensActual=0,this.completionTokensActual=0,this.promptTokensEstimate=0,this.completionTokensEstimate=0;}setPromptEstimateFromMessages(e){return this.promptTokensActual>0?(this.completionTokensEstimate=0,this.getSnapshot()):(this.promptTokensEstimate=ze(e),this.promptTokensActual=0,this.completionTokensActual=0,this.completionTokensEstimate=0,this.getSnapshot())}addEstimatedOutputTokens(e){return this.completionTokensEstimate=Math.max(0,this.completionTokensEstimate+e),this.getSnapshot()}recordActualUsage(e,t,s){return this.promptTokensActual=e,this.completionTokensActual=t,this.promptTokensEstimate=0,this.completionTokensEstimate=0,this.getSnapshot(s)}getSnapshot(e){let t=this.promptTokensActual||this.promptTokensEstimate,s=this.completionTokensActual+this.completionTokensEstimate,n=t+s,i=this.profile.contextWindow?n/this.profile.contextWindow:void 0,o=zu(this.profile,n,i);return {profile:this.profile,tokensUsed:n,promptTokens:t,completionTokens:s,messageCount:e,pressure:i,state:o,timestamp:Date.now()}}getStateRank(e){return Hu[e]}estimateMessagesForDisplay(e){return ze(e)}recordCalibration(e,t,s){if(process.env.CLI_DEBUG){let n=t+s,i=e>0?n/e:0;console.log(`[MemoryPressure] \u6821\u51C6: \u4F30\u7B97=${e}, \u5B9E\u9645=${n}, \u6BD4\u7387=${i.toFixed(3)}`);}}};function us(){let r=new Date,e=r.toISOString().slice(0,10).replace(/-/g,""),t=r.toISOString().slice(11,19).replace(/:/g,""),s=Math.random().toString(36).slice(2,6);return `session_${e}_${t}_${s}`}var Ht=class r{sessionId;filePath;directory;options;sequenceNumber=0;initialized=false;constructor(e){typeof e=="string"&&(e={sessionId:e}),this.sessionId=e.sessionId,this.options=e,this.directory=e.directory||X__default.join(Js__default.homedir(),".neox","sessions"),this.filePath=X__default.join(this.directory,`${this.sessionId}.jsonl`);}async ensureDirectory(){await Z__default.mkdir(this.directory,{recursive:true});}async ensureInitialized(){if(!this.initialized){await this.ensureDirectory();try{await Z__default.access(this.filePath);let e=await this.readAllItems();e.length>0&&(this.sequenceNumber=Math.max(...e.map(t=>t.seq))+1);}catch{if(this.options.autoCreateMeta!==false){let e={sessionId:this.sessionId,createdAt:new Date().toISOString(),agentName:this.options.agentName,model:this.options.model};await this.appendItem({type:"meta",data:e});}}this.initialized=true;}}async readAllItems(){let e=[];try{let t=Ce__default.createReadStream(this.filePath,{encoding:"utf-8"}),s=Ii.createInterface({input:t,crlfDelay:1/0});for await(let n of s)if(n.trim())try{let i=JSON.parse(n);e.push(i);}catch{console.warn(`Invalid JSONL line: ${n.slice(0,50)}...`);}}catch(t){if(t.code!=="ENOENT")throw t}return e.sort((t,s)=>t.seq-s.seq),e}async appendItem(e){await this.ensureDirectory();let t={item:e,timestamp:Date.now(),seq:this.sequenceNumber++},s=JSON.stringify(t)+`
|
|
6
|
+
`;await Z__default.appendFile(this.filePath,s,"utf-8");}async writeAllItems(e){await this.ensureDirectory();let t=e.map(s=>JSON.stringify(s)).join(`
|
|
7
|
+
`);await Z__default.writeFile(this.filePath,t?t+`
|
|
8
|
+
`:"","utf-8"),e.length>0?this.sequenceNumber=Math.max(...e.map(s=>s.seq))+1:this.sequenceNumber=0;}async getItems(e){await this.ensureInitialized();let s=(await this.readAllItems()).map(n=>n.item);return e===void 0?s:s.slice(-e)}async addItems(e){if(e.length!==0){await this.ensureInitialized();for(let t of e)await this.appendItem(t);}}async popItem(){await this.ensureInitialized();let e=await this.readAllItems();if(e.length===0)return null;let t=e.pop();return await this.writeAllItems(e),t.item}async popItems(e){if(e<=0)return [];await this.ensureInitialized();let t=await this.readAllItems();if(t.length===0)return [];let s=Math.min(e,t.length),n=t.splice(-s);return await this.writeAllItems(t),n.map(i=>i.item)}async createCheckpoint(e,t){await this.ensureInitialized();let s=`cp_${Date.now()}_${Math.random().toString(36).slice(2,6)}`,n={type:"checkpoint",data:{id:s,name:e,description:t}};return await this.appendItem(n),s}async rollbackToCheckpoint(e){await this.ensureInitialized();let t=await this.readAllItems(),s=t.findIndex(o=>o.item.type==="checkpoint"&&o.item.data.id===e);if(s===-1)throw new Error(`Checkpoint not found: ${e}`);let n=t.slice(0,s+1),i=t.length-n.length;return await this.writeAllItems(n),i}async getCheckpoints(){await this.ensureInitialized();let e=await this.readAllItems(),t=[];for(let s of e)if(s.item.type==="checkpoint"){let n=s.item;t.push({id:n.data.id,name:n.data.name,timestamp:s.timestamp});}return t}async clearSession(){try{await Z__default.unlink(this.filePath);}catch(e){if(e.code!=="ENOENT")throw e}this.sequenceNumber=0,this.initialized=false;}async getMeta(){await this.ensureInitialized();let e=await this.readAllItems();for(let t of e)if(t.item.type==="meta")return t.item.data;return null}async getMessages(){await this.ensureInitialized();let e=await this.readAllItems(),t=[];for(let s of e)s.item.type==="message"&&t.push(s.item.data);return t}async getItemCount(){return (await this.readAllItems()).length}async getTimeline(){return await this.ensureInitialized(),await this.readAllItems()}async replaceTimeline(e){await this.ensureDirectory();let t=e.map((s,n)=>({item:s.item,timestamp:s.timestamp??Date.now(),seq:n}));await this.writeAllItems(t),this.initialized=true;}static async listSessions(e){let t=e||X__default.join(Js__default.homedir(),".neox","sessions");try{return (await Z__default.readdir(t)).filter(n=>n.endsWith(".jsonl")).map(n=>n.replace(".jsonl",""))}catch{return []}}static async getMostRecentId(e){let t=e||X__default.join(Js__default.homedir(),".neox","sessions");try{let n=(await Z__default.readdir(t)).filter(o=>o.endsWith(".jsonl"));if(n.length===0)return null;let i=await Promise.all(n.map(async o=>({name:o.replace(".jsonl",""),mtime:(await Z__default.stat(X__default.join(t,o))).mtime})));return i.sort((o,a)=>a.mtime.getTime()-o.mtime.getTime()),i[0].name}catch{return null}}static async deleteSession(e,t){let s=t||X__default.join(Js__default.homedir(),".neox","sessions"),n=X__default.join(s,`${e}.jsonl`);try{return await Z__default.unlink(n),!0}catch{return false}}static async getSessionInfo(e,t){let s=t||X__default.join(Js__default.homedir(),".neox","sessions"),n=X__default.join(s,`${e}.jsonl`);try{let i=await Z__default.stat(n);return {sessionId:e,filePath:n,size:i.size,createdAt:i.birthtime,updatedAt:i.mtime}}catch{return null}}static create(e){return new r({sessionId:us(),...e})}};me();function V(r,e,t,s){return {type:"ephemeral",status:e,tool:r,summary:t,final:e==="success"||e==="already_done",...s}}function he(r,e,t,s,n){return {type:"contextual",status:e,tool:r,summary:t,content:s,...n}}function Mt(r,e,t,s){return {type:"summarized",status:e,tool:r,summary:t,...s}}function wa(r){f.info("TOOL_RESULT",`\u{1F504} getResultForLLM input: ${r.tool}`,{type:r.type,status:r.status,tool:r.tool,hasContent:!!r.content,contentLength:r.content?.length||0,summary:r.summary?.substring(0,100)});let e;if(r.type==="ephemeral")if(r.status==="error")r.tool==="edit_file"?e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,error:r.error,verify_hint:r.verify_hint,file_path:r.file_path,actual_content:r.actual_content,expected_start_line:r.expected_start_line,similar_matches:r.metadata?.similar_matches,suggestions:r.metadata?.suggestions}):e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,error:r.error,verify_hint:r.verify_hint,file_path:r.file_path,similar_matches:r.metadata?.similar_matches,suggestions:r.metadata?.suggestions});else {let t=r.metadata?.edit_info;if(r.tool==="edit_file"&&t){let s=t.old_string?t.old_string.length>1e3?t.old_string.substring(0,1e3)+"...":t.old_string:void 0,n=t.new_string?t.new_string.length>1e3?t.new_string.substring(0,1e3)+"...":t.new_string:void 0;e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,final:r.final,file_path:r.file_path,old_string_preview:s,new_string_preview:n,start_line:t.start_line});}else e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,final:r.final,file_path:r.file_path});}else r.type==="summarized"?e=JSON.stringify({status:r.status,tool:r.tool,summary:r.summary,error:r.error}):e=JSON.stringify(r);return f.info("TOOL_RESULT",`\u2705 getResultForLLM output: ${r.tool}`,{type:r.type,tool:r.tool,llmResultLength:e.length,llmResultPreview:e.substring(0,500)}),e}var Ri={write_file:"ephemeral",Write:"ephemeral",edit_file:"ephemeral",Edit:"ephemeral",create_directory:"ephemeral",mkdir:"ephemeral",delete_file:"ephemeral",rename_file:"ephemeral",apply_patch:"ephemeral",move_file:"ephemeral",copy_file:"ephemeral",git_commit:"ephemeral",git_add:"ephemeral",git_push:"ephemeral",git_checkout:"ephemeral",git_branch:"ephemeral",git_merge:"ephemeral",git_stash:"ephemeral",npm_install:"ephemeral",npm_uninstall:"ephemeral",pip_install:"ephemeral",readfile:"contextual",search:"contextual",grep:"contextual",Grep:"contextual",glob:"contextual",Glob:"contextual",search_files:"contextual",ripgrep:"contextual",ls:"contextual",list_directory:"contextual",show_tree:"contextual",git_diff:"contextual",git_status:"contextual",git_blame:"contextual",git_branch_list:"contextual",git_log:"contextual",git_show:"contextual",web_search:"contextual",WebSearch:"contextual",web_fetch:"contextual",WebFetch:"contextual",analyze_code:"contextual",search_symbol:"contextual",get_definitions:"contextual",get_references:"contextual",execute_shell:"summarized",Bash:"summarized",bash:"summarized",shell:"summarized",run_tests:"summarized",run_lint:"summarized",run_format:"summarized",test:"summarized",pytest:"summarized",jest:"summarized",build:"summarized",compile:"summarized",npm_build:"summarized",code_interpreter:"summarized",python_exec:"summarized",browser_debug:"summarized"};function Ei(r){if(r.startsWith("mcp__"))return "summarized";if(r in Ri)return Ri[r];let e=r.toLowerCase();for(let[t,s]of Object.entries(Ri))if(t.toLowerCase()===e)return s;return "contextual"}function _a(r){return Ei(r)==="contextual"}me();function Ks(r){if(!r)return 0;let e=0;for(let t of r){let s=t.codePointAt(0)||0;s>=19968&&s<=40959||s>=12288&&s<=12351||s>=65280&&s<=65519||s>=44032&&s<=55215?e+=.67:e+=.25;}return Math.ceil(e)}var Vs=class{messages=[];maxMessages;constructor(e=500){this.maxMessages=e;}add(e){let t=typeof e.content=="string"?e.content:JSON.stringify(e.content),s=Ks(t),n={...e,_timestamp:Date.now(),_estimatedTokens:s};if(this.messages.push(n),e.role==="assistant"&&e.tool_calls&&e.tool_calls.length>0&&process.env.CLI_DEBUG==="1"&&f.debug("MEMORY","Assistant message with tool_calls added:",{toolCallCount:e.tool_calls.length,toolCallIds:e.tool_calls.map(i=>({id:i.id,name:i.function.name}))}),this.messages.length>this.maxMessages){let i=this.messages.filter(l=>l.role==="system"),a=this.messages.filter(l=>l.role!=="system").slice(-(this.maxMessages-i.length));this.messages=[...i,...a];}}addToolResult(e,t,s){let n=Ei(t),i=null;try{let c=JSON.parse(s);c.type&&c.status&&c.summary&&(i=c);}catch{}let o,a=n;f.info("MEMORY","addToolResult: parsedResult\uFF1A"+i),f.info("MEMORY","addToolResult: effectiveResultType\uFF1A"+a),i?(a=i.type||n,o=wa(i),f.info("MEMORY","\u7CBE\u7B80\u7ED3\u679C: content \uFF1A"+o),f.info("MEMORY",`addToolResult: ${t} parsed as ToolResult`,{parsedResult:JSON.stringify(i).substring(0,500),contentAfter:o.substring(0,500),rawLength:s.length,contentLength:o.length})):(o=s,f.debug("MEMORY",`addToolResult: ${t} using raw output`,{rawOutput:s.substring(0,500),rawLength:s.length}));let l={role:"tool",tool_call_id:e,name:t,content:o,_resultType:a,_toolName:t,_timestamp:Date.now(),_estimatedTokens:Ks(o)};if(process.env.CLI_DEBUG==="1"&&f.debug("MEMORY","Tool result message added:",{toolName:t,toolCallId:e,contentLength:o.length,contentPreview:o.substring(0,200)}),this.messages.push(l),this.messages.length>this.maxMessages){let c=this.messages.filter(d=>d.role==="system"),p=this.messages.filter(d=>d.role!=="system").slice(-(this.maxMessages-c.length));this.messages=[...c,...p];}}stripMetadata(e){let{_resultType:t,_toolName:s,_timestamp:n,_estimatedTokens:i,_tag:o,...a}=e;return a}getAll(){return this.messages.map(e=>this.stripMetadata(e))}getRawMessages(){return this.messages}getMessagesForLLM(){let e=this.messages.map(t=>this.stripMetadata(t));if(process.env.CLI_DEBUG==="1"){let t=e.filter(i=>i.role==="assistant"),s=e.filter(i=>i.role==="tool");f.debug("MEMORY","Messages for LLM:",{totalMessages:e.length,assistantCount:t.length,toolCount:s.length,messageSequence:e.map(i=>i.role).join(" -> ")}),e.slice(-5).forEach((i,o)=>{i.role==="assistant"&&i.tool_calls?f.debug("MEMORY",`Message ${e.length-5+o} (assistant):`,{toolCalls:i.tool_calls.map(a=>({id:a.id,name:a.function.name}))}):i.role==="tool"&&f.debug("MEMORY",`Message ${e.length-5+o} (tool):`,{name:i.name,tool_call_id:i.tool_call_id,contentLength:typeof i.content=="string"?i.content.length:0});});}return e}hasConversationMessages(){return this.messages.some(e=>e.role==="user"||e.role==="assistant")}upsertSystemTagged(e,t){let s=t.trim();if(!s){this.removeSystemTagged(e);return}let n=this.messages.findIndex(a=>a.role==="system"&&a._tag===e);if(n>=0){let a=this.messages[n];if(a.content===s)return;this.messages[n]={...a,content:s,_timestamp:Date.now(),_estimatedTokens:Ks(s)};return}let i={role:"system",content:s,_tag:e,_timestamp:Date.now(),_estimatedTokens:Ks(s)},o=this.getSystemInsertIndex();this.messages=[...this.messages.slice(0,o),i,...this.messages.slice(o)];}removeSystemTagged(e){let t=this.messages.length;this.messages=this.messages.filter(s=>!(s.role==="system"&&s._tag===e)),t!==this.messages.length&&process.env.CLI_DEBUG==="1"&&f.debug("MEMORY",`Removed system tag: ${e}`);}getSystemInsertIndex(){let e=0;for(;e<this.messages.length&&this.messages[e].role==="system";)e+=1;return e}cleanupEphemeral(){let e=this.messages.length,t=new Set;for(let s of this.messages)if(s.role==="assistant"&&s.tool_calls)for(let n of s.tool_calls)n.id&&t.add(n.id);return this.messages=this.messages.filter(s=>s._resultType!=="ephemeral"||s.role!=="tool"||!s.tool_call_id?true:t.has(s.tool_call_id)),e-this.messages.length}getStats(){let e={total:this.messages.length,ephemeral:0,contextual:0,summarized:0,other:0};for(let t of this.messages)t._resultType==="ephemeral"?e.ephemeral++:t._resultType==="contextual"?e.contextual++:t._resultType==="summarized"?e.summarized++:e.other++;return e}checkContextHealth(){let e={ephemeral:{count:0,tokens:0},contextual:{count:0,tokens:0},summarized:{count:0,tokens:0},other:{count:0,tokens:0}},t=0,s=0,n=0;for(let a of this.messages){let l=a._estimatedTokens||Ks(typeof a.content=="string"?a.content:JSON.stringify(a.content));t+=l,a.role==="tool"?(n++,s+=l,a._resultType==="ephemeral"?(e.ephemeral.count++,e.ephemeral.tokens+=l):a._resultType==="contextual"?(e.contextual.count++,e.contextual.tokens+=l):a._resultType==="summarized"?(e.summarized.count++,e.summarized.tokens+=l):(e.other.count++,e.other.tokens+=l)):(e.other.count++,e.other.tokens+=l);}let i=t>0?s/t:0,o=[];return i>.5?o.push(`Tool results\u5360\u7528 ${(i*100).toFixed(1)}% \u7684\u4E0A\u4E0B\u6587\uFF08\u8D85\u8FC750%\u8B66\u6212\u7EBF\uFF09`):i>.4&&o.push(`Tool results\u5360\u7528 ${(i*100).toFixed(1)}% \u7684\u4E0A\u4E0B\u6587\uFF08\u63A5\u8FD1\u8B66\u6212\u7EBF\uFF09`),t>18e4?o.push(`\u4E0A\u4E0B\u6587\u5DF2\u8FBE ${t} tokens\uFF08\u8D85\u8FC7180k\uFF0C\u5EFA\u8BAE\u6E05\u7406\uFF09`):t>15e4&&o.push(`\u4E0A\u4E0B\u6587\u5DF2\u8FBE ${t} tokens\uFF08\u63A5\u8FD1180k\uFF09`),n>100?o.push(`\u5DE5\u5177\u8C03\u7528\u5386\u53F2\u8FC7\u957F\uFF08${n} \u6761\uFF09`):n>60&&o.push(`\u5DE5\u5177\u8C03\u7528\u5386\u53F2\u8F83\u957F\uFF08${n} \u6761\uFF09`),e.ephemeral.count>10&&o.push(`\u79EF\u7D2F\u4E86 ${e.ephemeral.count} \u6761 ephemeral \u6D88\u606F\uFF0C\u5EFA\u8BAE\u6E05\u7406`),{totalTokens:t,toolResultTokens:s,toolResultRatio:i,messageCount:this.messages.length,toolMessageCount:n,warnings:o,shouldCompress:i>.3||t>12e4,shouldCleanup:t>15e4||e.ephemeral.count>5,byType:e}}getTokenSummary(){let e=this.checkContextHealth(),t=[`Total: ${e.totalTokens} tokens`,`Tool: ${e.toolResultTokens} (${(e.toolResultRatio*100).toFixed(1)}%)`,`Messages: ${e.messageCount}`];return e.byType.ephemeral.count>0&&t.push(`Ephemeral: ${e.byType.ephemeral.count}`),t.join(" | ")}getMemoryFootprint(){let e=JSON.stringify(this.messages),t=new Blob([e]).size,s=Math.round(t/1024*10)/10,n=this.messages.length*150,i=t+n,o=Math.round(i/1024*10)/10;return {totalKB:o,messagesKB:s,messageCount:this.messages.length,averageKBPerMessage:this.messages.length>0?Math.round(o/this.messages.length*10)/10:0}}logMemoryStats(){let e=this.checkContextHealth(),t=this.getMemoryFootprint();f.info("MEMORY_STATS","ShortTermMemory snapshot",{memoryTotalKB:t.totalKB,memoryMessagesKB:t.messagesKB,avgKBPerMessage:t.averageKBPerMessage,totalTokens:e.totalTokens,toolResultTokens:e.toolResultTokens,toolResultRatio:`${(e.toolResultRatio*100).toFixed(1)}%`,messageCount:e.messageCount,toolMessageCount:e.toolMessageCount,maxMessages:this.maxMessages,byType:{ephemeral:`${e.byType.ephemeral.count} msgs, ${e.byType.ephemeral.tokens} tokens`,contextual:`${e.byType.contextual.count} msgs, ${e.byType.contextual.tokens} tokens`,summarized:`${e.byType.summarized.count} msgs, ${e.byType.summarized.tokens} tokens`,other:`${e.byType.other.count} msgs, ${e.byType.other.tokens} tokens`},warnings:e.warnings.length>0?e.warnings:["None"],shouldCompress:e.shouldCompress,shouldCleanup:e.shouldCleanup});}clear(){let e=this.messages.filter(t=>t.role==="system");this.messages=e;}setMessages(e){let t=Array.isArray(e)?e:[],s=t.filter(a=>a.role==="system"),n=t.filter(a=>a.role!=="system"),i=Math.max(0,this.maxMessages-s.length),o=i>0?n.slice(-i):[];this.messages=[...s,...o].map(a=>({...a,_timestamp:Date.now()}));}get length(){return this.messages.length}};var At=class{directory;options;sessionCache=new Map;constructor(e){this.options=e||{},this.directory=e?.directory||X__default.join(Js__default.homedir(),".neox","sessions");}async getSession(e){if(this.sessionCache.has(e))return this.sessionCache.get(e);let t=new Ht({sessionId:e,directory:this.directory,agentName:this.options.defaultAgentName,model:this.options.defaultModel});return this.sessionCache.set(e,t),t}async listSessions(){let e=[];try{await Z__default.mkdir(this.directory,{recursive:!0});let t=await Z__default.readdir(this.directory);for(let s of t){if(!s.endsWith(".jsonl"))continue;let n=s.replace(".jsonl",""),i=X__default.join(this.directory,s);try{let o=await Z__default.stat(i),a=await this.readSessionMeta(i),l=await this.countItems(i);e.push({sessionId:n,createdAt:o.birthtime,updatedAt:o.mtime,itemCount:l,agentName:a?.agentName});}catch{}}}catch(t){if(t.code!=="ENOENT")throw t}return e.sort((t,s)=>s.updatedAt.getTime()-t.updatedAt.getTime()),e}async getMostRecent(){let e=await this.listSessions();return e.length===0?null:this.getSession(e[0].sessionId)}async deleteSession(e){this.sessionCache.delete(e);let t=X__default.join(this.directory,`${e}.jsonl`);try{return await Z__default.unlink(t),!0}catch{return false}}async searchSessions(e){let t=await this.listSessions(),s=e.toLowerCase(),n=[];for(let i of t){if(i.sessionId.toLowerCase().includes(s)){n.push(i);continue}if(i.agentName?.toLowerCase().includes(s)){n.push(i);continue}let o=X__default.join(this.directory,`${i.sessionId}.jsonl`);await this.searchInFile(o,s)&&n.push(i);}return n}async createSession(e){let t=e?.sessionId||us(),s=new Ht({sessionId:t,directory:this.directory,agentName:e?.agentName||this.options.defaultAgentName,model:e?.model||this.options.defaultModel});return this.sessionCache.set(t,s),s}async getOrCreateSession(e){return e?this.getSession(e):this.createSession()}async continueOrCreate(){let e=await this.getMostRecent();return e||this.createSession()}async cleanupOldSessions(e=30){let t=await this.listSessions(),s=Date.now()-e*24*60*60*1e3,n=0;for(let i of t)i.updatedAt.getTime()<s&&await this.deleteSession(i.sessionId)&&n++;return n}getDirectory(){return this.directory}async getSessionCount(){return (await this.listSessions()).length}async exportSession(e){let t=await this.getSession(e),s=await t.getItems(),n=await t.getMeta();return JSON.stringify({sessionId:e,meta:n,items:s,exportedAt:new Date().toISOString()},null,2)}async readSessionMeta(e){try{let t=createReadStream(e,{encoding:"utf-8"}),s=Ii.createInterface({input:t,crlfDelay:1/0});for await(let n of s)if(n.trim())try{let i=JSON.parse(n);if(i.item?.type==="meta")return s.close(),i.item.data}catch{}}catch{}return null}async countItems(e){let t=0;try{let s=createReadStream(e,{encoding:"utf-8"}),n=Ii.createInterface({input:s,crlfDelay:1/0});for await(let i of n)i.trim()&&t++;}catch{}return t}async searchInFile(e,t){try{let s=createReadStream(e,{encoding:"utf-8"}),n=Ii.createInterface({input:s,crlfDelay:1/0});for await(let i of n)if(i.toLowerCase().includes(t))return n.close(),!0}catch{}return false}};var Qu={python:{command:"python3",args:["{file}"],extension:".py",useTempFile:true},javascript:{command:"node",args:["{file}"],extension:".js",useTempFile:true},typescript:{command:"npx",args:["tsx","{file}"],extension:".ts",useTempFile:true},bash:{command:"bash",args:["{file}"],extension:".sh",useTempFile:true},shell:{command:"sh",args:["{file}"],extension:".sh",useTempFile:true}},ep={timeout:3e4,maxMemoryMB:512,maxCPUPercent:50,allowNetwork:true,allowFileSystem:true,workingDirectory:process.cwd(),env:{},captureImages:false,maxOutputSize:1e4},ot=class{config;constructor(e={}){this.config={...ep,...e};}async execute(e,t){let s=Date.now(),n=Qu[t];if(!n)return {success:false,stdout:"",stderr:"",exitCode:1,executionTime:0,error:`Unsupported language: ${t}`};if(!await this.checkRuntimeAvailable(n.command))return {success:false,stdout:"",stderr:"",exitCode:1,executionTime:0,error:`Runtime not found: ${n.command}. Please install it first.`};let o=null;try{n.useTempFile&&(o=await this.createTempFile(e,n.extension));let a=n.args.map(h=>h.replace("{file}",o||"")),l=o?X__default.dirname(o):this.config.workingDirectory,c=[n.command,...a].join(" "),u={...Object.fromEntries(Object.entries(process.env).filter(([h,g])=>g!==void 0)),...this.config.env};t==="python"&&this.config.captureImages&&(u.MPLBACKEND="Agg");let p=await this.executeCommand(n.command,a,u,l),d=[];this.config.captureImages&&o&&(d=await this.captureGeneratedImages(X__default.dirname(o)));let m=Date.now()-s;return {...p,executionTime:m,command:c,workingDirectory:l,images:d&&d.length>0?d:void 0}}catch(a){let l=Date.now()-s;return {success:false,stdout:a.stdout||"",stderr:a.stderr||"",exitCode:a.exitCode||1,executionTime:l,error:a.message,timedOut:a.timedOut||false}}finally{o&&await this.cleanupTempFile(o);}}async checkRuntimeAvailable(e){try{return await execa(e,["--version"],{timeout:5e3}),!0}catch{return false}}async createTempFile(e,t){let s=await Z__default.mkdtemp(X__default.join(Js__default.tmpdir(),"neox-code-")),n=X__default.join(s,`script${t}`);return await Z__default.writeFile(n,e,"utf-8"),n}async executeCommand(e,t,s,n){try{let{stdout:i,stderr:o,exitCode:a}=await execa(e,t,{timeout:this.config.timeout,cwd:n,env:s,all:!0,reject:!1}),l=this.truncateOutput(i),c=this.truncateOutput(o);return {success:a===0,stdout:l,stderr:c,exitCode:a||0}}catch(i){throw i.timedOut?{stdout:i.stdout||"",stderr:i.stderr||"",exitCode:-1,message:`Execution timed out after ${this.config.timeout}ms`,timedOut:true}:{stdout:i.stdout||"",stderr:i.stderr||"",exitCode:i.exitCode||1,message:i.message}}}truncateOutput(e){if(e.length<=this.config.maxOutputSize)return e;let t=Math.floor(this.config.maxOutputSize/2);return e.slice(0,t)+`
|
|
9
9
|
|
|
10
10
|
... [Truncated ${e.length-this.config.maxOutputSize} characters] ...
|
|
11
11
|
|
|
12
|
-
`+e.slice(-t)}async captureGeneratedImages(e){try{let s=(await
|
|
12
|
+
`+e.slice(-t)}async captureGeneratedImages(e){try{let s=(await Z__default.readdir(e)).filter(i=>/\.(png|jpg|jpeg|svg)$/i.test(i)),n=[];for(let i of s){let o=X__default.join(e,i),l=(await Z__default.readFile(o)).toString("base64");n.push({type:"base64",data:l,filename:i});}return n}catch{return []}}async cleanupTempFile(e){try{let t=X__default.dirname(e);await Z__default.rm(t,{recursive:!0,force:!0});}catch{}}static formatResult(e){let t=[];return e.success?t.push(`\u2705 Code executed successfully
|
|
13
13
|
`):t.push(`\u274C Code execution failed
|
|
14
14
|
`),t.push(`\u23F1\uFE0F Execution time: ${e.executionTime}ms`),t.push(`\u{1F522} Exit code: ${e.exitCode}`),(e.command||e.workingDirectory)&&(t.push(`
|
|
15
15
|
\u{1F6E0}\uFE0F Command:`),e.command&&t.push(`$ ${e.command}`),e.workingDirectory&&t.push(`CWD: ${e.workingDirectory}`)),e.timedOut&&t.push("\u23F0 Execution timed out"),e.stdout&&(t.push(`
|
|
@@ -17,7 +17,7 @@ import*as xe from'fs';import xe__default,{realpathSync,readlinkSync,readdirSync,
|
|
|
17
17
|
\u26A0\uFE0F Errors/Warnings:`),t.push("```"),t.push(e.stderr),t.push("```")),e.error&&(t.push(`
|
|
18
18
|
\u274C Error:`),t.push(e.error)),e.images&&e.images.length>0&&(t.push(`
|
|
19
19
|
\u{1F5BC}\uFE0F Generated ${e.images.length} image(s):`),e.images.forEach((s,n)=>{t.push(` ${n+1}. ${s.filename||"image"} (${s.type})`);})),t.join(`
|
|
20
|
-
`)}},
|
|
20
|
+
`)}},Ta=new ot;async function Xs(r,e,t){return (t?new ot(t):Ta).execute(r,e)}function Ai(r){let e=new ot(r);return {name:"execute_code",description:`Execute code in multiple languages (Python, JavaScript, TypeScript, Bash/Shell).
|
|
21
21
|
Supports data analysis, calculations, file operations, and more.
|
|
22
22
|
Can capture generated images (matplotlib plots, etc.) if configured.
|
|
23
23
|
|
|
@@ -25,13 +25,13 @@ Configuration:
|
|
|
25
25
|
- Timeout: ${r?.timeout||3e4}ms
|
|
26
26
|
- Network access: ${r?.allowNetwork!==false?"Enabled":"Disabled"}
|
|
27
27
|
- File system access: ${r?.allowFileSystem!==false?"Enabled":"Disabled"}
|
|
28
|
-
- Image capture: ${r?.captureImages?"Enabled":"Disabled"}`,parameters:{type:"object",properties:{code:{type:"string",description:"The code to execute"},language:{type:"string",enum:["python","javascript","typescript","bash","shell"],description:"Programming language to use"}},required:["code","language"]},async function({code:t,language:s}){let n=await e.execute(t,s);return ot.formatResult(n)}}}var
|
|
28
|
+
- Image capture: ${r?.captureImages?"Enabled":"Disabled"}`,parameters:{type:"object",properties:{code:{type:"string",description:"The code to execute"},language:{type:"string",enum:["python","javascript","typescript","bash","shell"],description:"Programming language to use"}},required:["code","language"]},async function({code:t,language:s}){let n=await e.execute(t,s);return ot.formatResult(n)}}}var Pi={name:"execute_python",description:`Execute Python code for calculations, data analysis, and scripting.
|
|
29
29
|
Useful for: math calculations, data processing, file operations, web scraping, etc.
|
|
30
|
-
Libraries commonly available: numpy, pandas, matplotlib, requests, etc.`,parameters:{type:"object",properties:{code:{type:"string",description:"Python code to execute"},capture_images:{type:"boolean",description:"Capture matplotlib plots and other images"}},required:["code"]},async function({code:r,capture_images:e=false}){let t=await
|
|
30
|
+
Libraries commonly available: numpy, pandas, matplotlib, requests, etc.`,parameters:{type:"object",properties:{code:{type:"string",description:"Python code to execute"},capture_images:{type:"boolean",description:"Capture matplotlib plots and other images"}},required:["code"]},async function({code:r,capture_images:e=false}){let t=await Xs(r,"python",{captureImages:e});return ot.formatResult(t)}},Oi={name:"execute_javascript",description:`Execute JavaScript (Node.js) code for calculations, data processing, and scripting.
|
|
31
31
|
Useful for: JSON processing, string manipulation, async operations, etc.
|
|
32
|
-
Has access to Node.js built-in modules.`,parameters:{type:"object",properties:{code:{type:"string",description:"JavaScript code to execute"}},required:["code"]},async function({code:r}){let e=await
|
|
32
|
+
Has access to Node.js built-in modules.`,parameters:{type:"object",properties:{code:{type:"string",description:"JavaScript code to execute"}},required:["code"]},async function({code:r}){let e=await Xs(r,"javascript");return ot.formatResult(e)}},Li={name:"execute_bash",description:`Execute Bash/Shell scripts for system operations and file management.
|
|
33
33
|
Useful for: file operations, text processing, system commands, git operations, etc.
|
|
34
|
-
Has full access to system commands and utilities.`,parameters:{type:"object",properties:{code:{type:"string",description:"Bash script to execute"}},required:["code"]},async function({code:r}){let e=await
|
|
34
|
+
Has full access to system commands and utilities.`,parameters:{type:"object",properties:{code:{type:"string",description:"Bash script to execute"}},required:["code"]},async function({code:r}){let e=await Xs(r,"bash");return ot.formatResult(e)}};Ai({timeout:3e4,allowNetwork:true,allowFileSystem:true,captureImages:true,maxOutputSize:1e4});Ai({timeout:1e4,allowNetwork:false,allowFileSystem:false,captureImages:false,maxOutputSize:5e3});var er={name:"debug_in_browser",capabilities:["debug"],description:`\u5728\u771F\u5B9E\u6D4F\u89C8\u5668\u73AF\u5883\u4E2D\u6253\u5F00\u6307\u5B9A URL \u5E76\u6536\u96C6\u8C03\u8BD5\u4FE1\u606F\u3002
|
|
35
35
|
|
|
36
36
|
\u8FD9\u4E2A\u5DE5\u5177\u4F1A\uFF1A
|
|
37
37
|
1. \u81EA\u52A8\u542F\u52A8 Chrome \u6D4F\u89C8\u5668\uFF08headless \u6A21\u5F0F\uFF09
|
|
@@ -162,7 +162,7 @@ auto_login: { username: "admin", password: "123456" }`,properties:{username:{typ
|
|
|
162
162
|
- \u9700\u8981\u67E5\u770B\u9875\u9762\u5B9E\u9645\u6E32\u67D3\u6548\u679C\uFF08\u5E03\u5C40\u3001\u6837\u5F0F\u3001\u5185\u5BB9\uFF09
|
|
163
163
|
- \u7528\u6237\u62A5\u544A UI \u663E\u793A\u95EE\u9898\u4F46\u6CA1\u6709\u63D0\u4F9B\u622A\u56FE
|
|
164
164
|
|
|
165
|
-
\u9ED8\u8BA4 false\uFF0C\u56E0\u4E3A\u622A\u56FE\u4F1A\u589E\u52A0\u54CD\u5E94\u5927\u5C0F\u3002`,default:false},headless:{type:"boolean",description:"\u662F\u5426\u4F7F\u7528 headless \u6A21\u5F0F\uFF08\u4E0D\u663E\u793A\u6D4F\u89C8\u5668\u7A97\u53E3\uFF09\u3002\u9ED8\u8BA4 true\u3002\u6CE8\u610F\uFF1A\u5982\u679C\u540C\u65F6\u8BBE\u7F6E open_for_login: true \u4E0E allow_manual_login: true\uFF0C\u6B64\u53C2\u6570\u4F1A\u88AB\u5FFD\u7565",default:true}},required:[]},async function(r){throw new Error("debug_in_browser tool must be created via createDebugInBrowserTool(workspacePath) to provide workspace context")}};
|
|
165
|
+
\u9ED8\u8BA4 false\uFF0C\u56E0\u4E3A\u622A\u56FE\u4F1A\u589E\u52A0\u54CD\u5E94\u5927\u5C0F\u3002`,default:false},headless:{type:"boolean",description:"\u662F\u5426\u4F7F\u7528 headless \u6A21\u5F0F\uFF08\u4E0D\u663E\u793A\u6D4F\u89C8\u5668\u7A97\u53E3\uFF09\u3002\u9ED8\u8BA4 true\u3002\u6CE8\u610F\uFF1A\u5982\u679C\u540C\u65F6\u8BBE\u7F6E open_for_login: true \u4E0E allow_manual_login: true\uFF0C\u6B64\u53C2\u6570\u4F1A\u88AB\u5FFD\u7565",default:true}},required:[]},async function(r){throw new Error("debug_in_browser tool must be created via createDebugInBrowserTool(workspacePath) to provide workspace context")}};me();var zt=null;function tr(){if(zt!==null)return zt;if(process.platform!=="linux")return zt=false,false;if(process.env.WSL_DISTRO_NAME||process.env.WSLENV||process.env.WSL_INTEROP)return zt=true,true;try{let r=Ce__default.readFileSync("/proc/version","utf-8").toLowerCase();if(r.includes("microsoft")||r.includes("wsl"))return zt=!0,!0}catch{}try{if(Ce__default.existsSync("/proc/sys/fs/binfmt_misc/WSLInterop"))return zt=!0,!0}catch{}return zt=false,false}var Zs=join(homedir(),".neox","browser-profile");function Di(){return Zs}function sr(){return existsSync(Zs)||(mkdirSync(Zs,{recursive:true}),f.info("CHROME",`Created browser profile directory: ${Zs}`)),Zs}async function Ra(){let r=platform(),e={darwin:["/Applications/Google Chrome.app/Contents/MacOS/Google Chrome","/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary","/Applications/Chromium.app/Contents/MacOS/Chromium"],win32:["C:\\Program Files\\Google\\Chrome\\Application\\chrome.exe","C:\\Program Files (x86)\\Google\\Chrome\\Application\\chrome.exe",(process.env.LOCALAPPDATA||"")+"\\Google\\Chrome\\Application\\chrome.exe","C:\\Program Files\\Google\\Chrome Beta\\Application\\chrome.exe"],linux:["/usr/bin/google-chrome","/usr/bin/google-chrome-stable","/usr/bin/chromium","/usr/bin/chromium-browser","/snap/bin/chromium"],wsl:["/mnt/c/Program Files/Google/Chrome/Application/chrome.exe","/mnt/c/Program Files (x86)/Google/Chrome/Application/chrome.exe","/mnt/c/Users/"+(process.env.USER||"")+"/AppData/Local/Google/Chrome/Application/chrome.exe"]},t;tr()?(t=[...e.linux||[],...e.wsl||[]],f.debug("CHROME","WSL detected, checking both Linux and Windows Chrome paths")):t=e[r]||[];for(let s of t)if(existsSync(s))return f.info("CHROME",`Found Chrome at: ${s}`),{path:s,version:"unknown",available:true};return f.warn("CHROME","No Chrome installation found"),null}async function $i(r={}){let{headless:e=true,useProfile:t=true}=r,s=await Ra();if(!s)throw new Error("Chrome not found. Please install Google Chrome from https://www.google.com/chrome/");f.info("CHROME",`Launching Chrome (headless: ${e}, useProfile: ${t})...`);let n={executablePath:s.path,headless:e,args:["--no-sandbox","--disable-setuid-sandbox","--disable-dev-shm-usage","--disable-accelerated-2d-canvas","--no-first-run","--no-zygote","--disable-gpu"],defaultViewport:{width:1280,height:720}};if(t){let o=sr();n.userDataDir=o,f.info("CHROME",`Using profile directory: ${o}`);}let i=await ap.launch(n);return f.info("CHROME","Chrome launched successfully"),i}me();var lp=["xhr","fetch"],Ea=["stylesheet","script","image","font","media"];function cp(r,e){return r?e==="error"?r>=400:e==="4xx"?r>=400&&r<500:e==="5xx"?r>=500:e.split(",").map(s=>parseInt(s.trim(),10)).includes(r):false}async function nr(r,e,t){let s=Date.now(),n={xhr_only:true,include_body:true,body_max_length:5e3,max_results:20,...t.network_filter},i=t.network_capture_mode||"cdp",o=[],a=[],c=new Map,u=new Map,p=`
|
|
166
166
|
(function() {
|
|
167
167
|
if (window.__NEOX_INJECTED__) return;
|
|
168
168
|
window.__NEOX_CONSOLE_LOGS__ = window.__NEOX_CONSOLE_LOGS__ || [];
|
|
@@ -219,14 +219,14 @@ auto_login: { username: "admin", password: "123456" }`,properties:{username:{typ
|
|
|
219
219
|
|
|
220
220
|
window.__NEOX_INJECTED__ = true;
|
|
221
221
|
})();
|
|
222
|
-
`;(t.collect_console!==false||t.collect_errors!==false)&&(await r.evaluateOnNewDocument(p),r.on("framenavigated",async
|
|
223
|
-
`)||"",file:
|
|
224
|
-
`)||"",file:T.url,line:T.lineNumber,timestamp:Date.now()}),f.debug("BROWSER",`[CDP Log Error] ${T.text}`)):(o.push({type:"error",timestamp:Date.now(),message:T.text}),f.debug("BROWSER",`[CDP Log] error: ${T.text}`)):_==="warning"&&o.push({type:"warn",timestamp:Date.now(),message:T.text});};if(t.collect_console!==false&&d.on("Runtime.consoleAPICalled",m),t.collect_errors!==false&&(d.on("Runtime.exceptionThrown",h),d.on("Log.entryAdded",g),r.on("pageerror",v=>{let T=v;a.push({type:"exception",message:T.message,stack:T.stack||"",timestamp:Date.now()}),f.debug("BROWSER",`[Puppeteer pageerror] ${T.message}`);}),r.on("requestfailed",v=>{let T=v.failure();a.push({type:"browser_error",message:`Request failed: ${T?.errorText||"Unknown error"}`,stack:"",file:v.url(),timestamp:Date.now()});})),t.collect_network!==false&&(i==="cdp"||i==="both")&&(d.on("Network.requestWillBeSent",v=>{let T={url:v.request.url,method:v.request.method,resource_type:v.type?.toLowerCase()||"other",request_headers:v.request.headers,timing:{start:v.timestamp*1e3,end:0,duration:0}},_=v.type?.toLowerCase()||"other";if(!(n.xhr_only&&!["xhr","fetch"].includes(_))&&!(!n.xhr_only&&Ta.includes(_))){if(v.request.postData){let k=n.body_max_length||5e3,M=v.request.postData;M.length>k?T.request_body=M.substring(0,k)+"...[truncated]":T.request_body=M;}u.set(v.requestId,T),f.debug("BROWSER",`[CDP Network] ${_.toUpperCase()} ${T.method} ${T.url}`);}}),d.on("Network.responseReceived",v=>{let T=u.get(v.requestId);T&&T.timing&&(T.status=v.response.status,T.status_text=v.response.statusText,T.response_headers=v.response.headers,T.timing.end=v.timestamp*1e3,T.timing.duration=T.timing.end-T.timing.start,f.debug("BROWSER",`[CDP Network] Response ${T.status} ${T.url} (${T.timing.duration.toFixed(0)}ms)`));}),d.on("Network.loadingFailed",v=>{let T=u.get(v.requestId);T&&(T.error=v.errorText,T.timing&&(T.timing.end=v.timestamp*1e3,T.timing.duration=T.timing.end-T.timing.start),f.debug("BROWSER",`[CDP Network] Failed ${T.url}: ${T.error}`));})),t.collect_console!==false&&r.on("console",v=>{let T=v.type();o.push({type:T,timestamp:Date.now(),message:v.text(),args:v.args().map(_=>_.toString())}),f.debug("BROWSER",`[Puppeteer console] ${T}: ${v.text().substring(0,100)}`);}),t.collect_network!==false&&(i==="puppeteer"||i==="both")){let v=null;if(n.url_pattern)try{v=new RegExp(n.url_pattern,"i");}catch{f.warn("BROWSER",`Invalid URL pattern: ${n.url_pattern}`);}r.on("request",T=>{let _=T.url(),k=T.resourceType();if(n.xhr_only&&!sp.includes(k)||!n.xhr_only&&Ta.includes(k)||v&&!v.test(_))return;`${T.method()}-${_}-${Date.now()}`;let W={url:_,method:T.method(),resource_type:k,request_headers:T.headers(),timing:{start:Date.now(),end:0,duration:0}},E=T.postData();if(E){let D=n.body_max_length||5e3;E.length>D?W.request_body=E.substring(0,D)+"...[truncated]":W.request_body=E;}c.set(_,W),f.debug("BROWSER",`[Network] ${k.toUpperCase()} ${T.method()} ${_}`);}),r.on("response",async T=>{let _=T.url(),k=c.get(_);if(!k||!k.timing)return;k.status=T.status(),k.status_text=T.statusText(),k.response_headers=T.headers(),k.timing.end=Date.now(),k.timing.duration=k.timing.end-k.timing.start;let M=k.status>=400;if(n.include_body&&(M||n.status_filter))try{let E=T.headers()["content-type"]||"";if(E.includes("json")||E.includes("text")||E.includes("html")){let D=await T.text(),N=n.body_max_length||5e3;D.length>N?(k.response_body=D.substring(0,N),k.response_truncated=!0):k.response_body=D;}}catch(E){f.debug("BROWSER",`Failed to get response body for ${_}: ${E}`);}f.debug("BROWSER",`[Network] Response ${k.status} ${_} (${k.timing.duration}ms)`);}),r.on("requestfailed",T=>{let _=T.url(),k=c.get(_),M=T.failure();k&&(k.error=M?.errorText||"Request failed",k.timing&&(k.timing.end=Date.now(),k.timing.duration=k.timing.end-k.timing.start)),a.push({type:"browser_error",message:`Request failed: ${M?.errorText||"Unknown error"}`,stack:"",file:_,timestamp:Date.now()});});}f.info("BROWSER",`Navigating to: ${e}`),await r.goto(e,{waitUntil:"networkidle2",timeout:3e4});try{await d.send("Runtime.enable"),await d.send("Log.enable"),f.debug("BROWSER","Re-enabled Runtime and Log domains after navigation");}catch{f.debug("BROWSER","Failed to re-enable CDP domains (may already be enabled)");}if(t.collect_console!==false||t.collect_errors!==false)try{await r.evaluate(p),f.debug("BROWSER","Ensured script injection after page.goto");}catch{f.debug("BROWSER","Script already injected or page not ready");}let y=t.wait_time||3e3;if(f.info("BROWSER",`Waiting ${y}ms for async content...`),await new Promise(v=>setTimeout(v,y)),f.debug("BROWSER","Starting to extract injected logs..."),t.collect_console!==false||t.collect_errors!==false)try{f.debug("BROWSER","Calling page.evaluate to get __NEOX_CONSOLE_LOGS__...");let v=await r.evaluate(()=>({consoleLogs:window.__NEOX_CONSOLE_LOGS__||[],errors:window.__NEOX_ERRORS__||[]}));f.debug("BROWSER",`Extracted ${v.consoleLogs.length} console logs and ${v.errors.length} errors from injected script`);for(let k of v.consoleLogs)f.debug("BROWSER",` [${k.type}] ${k.message?.substring(0,100)}`);let T=new Map;for(let k of v.consoleLogs){let M=`${k.type}:${k.message}`;T.has(M)||T.set(M,{type:k.type,timestamp:k.timestamp,message:k.message});}for(let k of o){let M=`${k.type}:${k.message}`;T.has(M)||T.set(M,k);}o.length=0,o.push(...Array.from(T.values()));let _=new Map;for(let k of v.errors){let M=`${k.type}:${k.message}`;_.has(M)||_.set(M,{type:k.type,message:k.message,stack:k.stack||"",file:k.file,line:k.line,column:k.column,timestamp:k.timestamp});}for(let k of a){let M=`${k.type}:${k.message}`;_.has(M)||_.set(M,k);}a.length=0,a.push(...Array.from(_.values())),f.info("BROWSER",`Final: ${o.length} console logs, ${a.length} errors`);}catch(v){f.error("BROWSER","Failed to extract injected logs",{error:v});}let b;if(t.collect_performance!==false)try{let v=await r.metrics(),T=await r.evaluate(()=>{let _=window.performance,k=_.timing,M=_.getEntriesByType("paint"),W=document.querySelectorAll("*"),E=0,D=0,N=0,$=Math.min(1e3,W.length),j=Math.max(1,Math.floor(W.length/$));for(let A=0;A<W.length;A+=j){let P=W[A],V=window.getComputedStyle(P);V.display!=="none"&&V.visibility!=="hidden"&&V.opacity!=="0"?E++:D++;let F=0,ie=P.parentElement;for(;ie;)F++,ie=ie.parentElement;N=Math.max(N,F);}let Z=W.length/$;return E=Math.round(E*Z),D=Math.round(D*Z),{domContentLoaded:k.domContentLoadedEventEnd-k.navigationStart,loadComplete:k.loadEventEnd-k.navigationStart,paintMetrics:{first_paint:M.find(A=>A.name==="first-paint")?.startTime||0,first_contentful_paint:M.find(A=>A.name==="first-contentful-paint")?.startTime||0},memory:_.memory?{used_heap:_.memory.usedJSHeapSize,total_heap:_.memory.totalJSHeapSize,heap_limit:_.memory.jsHeapSizeLimit}:void 0,domStats:{visible_nodes:E,hidden_nodes:D,max_depth:N}}});b={dom_content_loaded:T.domContentLoaded,load_complete:T.loadComplete,dom_nodes:v.Nodes||0,js_heap_size:v.JSHeapUsedSize||0,event_listeners:v.JSEventListeners||0,paint_metrics:T.paintMetrics,memory:T.memory,dom_stats:T.domStats},f.info("BROWSER",`Performance: ${b.dom_nodes} nodes, ${(b.js_heap_size/1024/1024).toFixed(1)}MB heap`);}catch(v){f.error("BROWSER","Failed to collect performance metrics",{error:v});}let w;if(t.take_screenshot===true)try{w=await r.screenshot({encoding:"base64"});}catch(v){f.error("BROWSER","Failed to capture screenshot",{error:v});}try{await d.detach();}catch{}if(i==="cdp"||i==="both")for(let[v,T]of u.entries())Array.from(c.values()).find(k=>k.url===T.url)||c.set(v,T);let S=Array.from(c.values());i==="cdp"&&(S=Array.from(u.values()));let x=S.length;n.status_filter&&(S=S.filter(v=>np(v.status,n.status_filter)));let R=S.filter(v=>v.error||v.status&&v.status>=400).length;S.sort((v,T)=>{let _=v.error||v.status&&v.status>=400,k=T.error||T.status&&T.status>=400;return _&&!k?-1:!_&&k?1:(v.timing?.start||0)-(T.timing?.start||0)});let L=n.max_results||20;S.length>L&&(S=S.slice(0,L));let H={total_captured:x,filtered_count:S.length,error_count:R};f.info("BROWSER",`Network: ${x} captured, ${S.length} returned, ${R} errors`);let U=Date.now()-s;return {console_logs:o,errors:a,network_requests:S,network_stats:H,performance:b,screenshot:w,load_time:U}}function nr(r){let e=[];r.errors&&r.errors.length>0&&(e.push(`\u{1F534} \u53D1\u73B0 ${r.errors.length} \u4E2A JavaScript \u5F02\u5E38\uFF1A`),r.errors.slice(0,5).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`),o.file&&e.push(` \u4F4D\u7F6E\uFF1A${o.file}:${o.line||""}`);}),e.push(""));let t=r.console_logs?.filter(o=>o.type==="error")||[];t.length>0&&(e.push(`\u{1F534} \u53D1\u73B0 ${t.length} \u4E2A console.error \u65E5\u5FD7\uFF1A`),t.slice(0,5).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`);}),e.push(""));let s=r.console_logs?.filter(o=>o.type==="warn")||[];s.length>0&&(e.push(`\u26A0\uFE0F ${s.length} \u4E2A console.warn \u8B66\u544A\uFF1A`),s.slice(0,3).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`);}),e.push(""));let n=r.console_logs?.filter(o=>o.type==="debug")||[];if(n.length>0&&(e.push(`\u{1F50D} ${n.length} \u4E2A console.debug \u65E5\u5FD7\uFF1A`),n.slice(0,3).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`);}),e.push("")),r.errors?.length===0&&t.length===0&&s.length===0&&(e.push("\u2705 \u672A\u53D1\u73B0 JavaScript \u9519\u8BEF\u6216\u8B66\u544A"),e.push("")),r.network_stats){let o=r.network_stats;e.push(`\u{1F310} \u7F51\u7EDC\u8BF7\u6C42\uFF1A\u5171\u6355\u83B7 ${o.total_captured} \u4E2A\uFF0C\u8FD4\u56DE ${o.filtered_count} \u4E2A\uFF0C${o.error_count} \u4E2A\u9519\u8BEF`);}let i=r.network_requests?.filter(o=>o.error||o.status&&o.status>=400)||[];if(i.length>0&&(e.push(`\u{1F534} ${i.length} \u4E2A API \u9519\u8BEF\u8BF7\u6C42\uFF1A`),i.slice(0,5).forEach((o,a)=>{if(e.push(` ${a+1}. [${o.status||"Failed"}] ${o.method} ${o.url}`),o.response_body){let l=o.response_body.substring(0,200);e.push(` \u54CD\u5E94: ${l}${o.response_body.length>200?"...":""}`);}o.error&&e.push(` \u9519\u8BEF: ${o.error}`);}),e.push("")),r.performance){let o=r.performance;if(o.dom_nodes>15e3?e.push(`\u{1F534} \u4E25\u91CD\u8B66\u544A\uFF1ADOM \u8282\u70B9\u8FC7\u591A (${o.dom_nodes.toLocaleString()}), \u9875\u9762\u6027\u80FD\u6781\u5DEE`):o.dom_nodes>1e4?e.push(`\u26A0\uFE0F \u8B66\u544A\uFF1ADOM \u8282\u70B9\u504F\u591A (${o.dom_nodes.toLocaleString()}), \u53EF\u80FD\u5F71\u54CD\u6027\u80FD`):o.dom_nodes>5e3&&e.push(`\u26A1 \u63D0\u793A\uFF1ADOM \u8282\u70B9\u8F83\u591A (${o.dom_nodes.toLocaleString()}), \u5EFA\u8BAE\u4F18\u5316`),o.dom_stats){let a=o.dom_stats,l=a.hidden_nodes/o.dom_nodes*100;e.push(` \u{1F4CA} \u53EF\u89C1: ${a.visible_nodes.toLocaleString()}, \u9690\u85CF: ${a.hidden_nodes.toLocaleString()} (${l.toFixed(1)}%), \u6700\u5927\u6DF1\u5EA6: ${a.max_depth} \u5C42`),l>40&&e.push(" \u26A0\uFE0F \u9690\u85CF\u8282\u70B9\u5360\u6BD4\u8FC7\u9AD8\uFF0C\u53EF\u80FD\u5B58\u5728\u672A\u6E05\u7406\u7684 DOM \u5143\u7D20"),a.max_depth>30&&e.push(` \u26A0\uFE0F DOM \u5D4C\u5957\u5C42\u7EA7\u8FC7\u6DF1 (${a.max_depth}), \u53EF\u80FD\u5B58\u5728\u6027\u80FD\u95EE\u9898`);}if(o.memory){let a=o.memory.used_heap/1024/1024,l=o.memory.heap_limit/1024/1024,c=o.memory.used_heap/o.memory.heap_limit*100;c>80?e.push(`\u26A1 \u5185\u5B58\u8B66\u544A\uFF1A\u5806\u4F7F\u7528\u7387 ${c.toFixed(1)}% (${a.toFixed(1)}MB / ${l.toFixed(1)}MB), \u63A5\u8FD1\u9650\u5236`):a>100&&e.push(`\u26A1 \u5185\u5B58\u63D0\u793A\uFF1A\u5806\u5185\u5B58\u8F83\u5927 ${a.toFixed(1)}MB`);}else o.js_heap_size>50*1024*1024&&e.push(`\u26A1 \u6027\u80FD\u8B66\u544A\uFF1AJS \u5806\u5185\u5B58\u8FC7\u5927 (${(o.js_heap_size/1024/1024).toFixed(1)}MB)`);o.paint_metrics&&o.paint_metrics.first_contentful_paint>3e3&&e.push(`\u26A1 \u6E32\u67D3\u6162\uFF1A\u9996\u6B21\u5185\u5BB9\u7ED8\u5236 ${o.paint_metrics.first_contentful_paint.toFixed(0)}ms (\u5EFA\u8BAE < 1500ms)`),o.load_complete>5e3&&e.push(`\u26A1 \u52A0\u8F7D\u6162\uFF1A\u9875\u9762\u5B8C\u5168\u52A0\u8F7D\u8017\u65F6 ${o.load_complete.toFixed(0)}ms (\u5EFA\u8BAE < 3000ms)`);}return e.join(`
|
|
225
|
-
`)||"\u2705 \u9875\u9762\u8FD0\u884C\u6B63\u5E38\uFF0C\u672A\u53D1\u73B0\u660E\u663E\u95EE\u9898"}async function Ca(r){let e=await rp(r);if(e)return {url:`http://localhost:${e}`,port:e,protocol:"http",source:"vite.config"};let t=await ip(r);if(t)return {url:`http://localhost:${t}`,port:t,protocol:"http",source:"package.json"};let s=await op(r);if(s)return {url:`http://localhost:${s}`,port:s,protocol:"http",source:"env"};let n=await ap(r);return {url:`http://localhost:${n}`,port:n,protocol:"http",source:"default"}}async function rp(r){try{let e=join(r,"vite.config.js"),s=(await readFile(e,"utf-8")).match(/server\s*:\s*\{[^}]*port\s*:\s*(\d+)/);return s?parseInt(s[1]):null}catch{return null}}async function ip(r){try{let e=join(r,"package.json"),t=await readFile(e,"utf-8"),n=JSON.parse(t).scripts?.dev||"",i=n.match(/--port\s+(\d+)/);if(i)return parseInt(i[1]);let o=n.match(/PORT=(\d+)/);return o?parseInt(o[1]):null}catch{return null}}async function op(r){try{let e=join(r,".env"),s=(await readFile(e,"utf-8")).match(/(?:VITE_)?PORT\s*=\s*(\d+)/);return s?parseInt(s[1]):null}catch{return null}}async function ap(r){try{let e=join(r,"package.json"),t=await readFile(e,"utf-8"),s=JSON.parse(t),n={...s.dependencies,...s.devDependencies};return n.vite?5173:n.next||n["react-scripts"]?3e3:n.vue?8080:n.nuxt?3e3:n.svelte?5e3:3e3}catch{return 3e3}}async function Oi(r,e=3e3){try{let t=new AbortController,s=setTimeout(()=>t.abort(),e),n=await fetch(r,{method:"HEAD",signal:t.signal});return clearTimeout(s),n.ok}catch{return false}}async function Li(r){let e=await Ca(r);if(await Oi(e.url))return e;let s=[5173,3e3,8080,5e3,4200,8e3];for(let n of s){let i=`http://localhost:${n}`;if(await Oi(i))return {url:i,port:n,protocol:"http",source:"default"}}return null}de();var dp="headers.json";function Ra(r){try{return new URL(r).hostname}catch{return r}}function Ea(){let r=tr();return join(r,dp)}function Ia(){let r=Ea();if(!existsSync(r))return {};try{let e=readFileSync(r,"utf-8");return JSON.parse(e)}catch(e){return f.warn("HEADERS","Failed to read headers config",{error:e}),{}}}function Ma(r){let e=Ea();try{let t=JSON.stringify(r,null,2);writeFileSync(e,t,"utf-8"),f.info("HEADERS","Headers config saved",{path:e});}catch(t){f.error("HEADERS","Failed to save headers config",{error:t});}}function or(r,e){let t=Ra(r),s=Ia(),n=mp(e);if(Object.keys(n).length===0){f.info("HEADERS","No headers to save for domain",{domain:t});return}s[t]={headers:n,lastUsed:Date.now(),createdAt:s[t]?.createdAt||Date.now(),url:r},Ma(s),f.info("HEADERS","Saved headers for domain",{domain:t,headerCount:Object.keys(n).length});}function Di(r){let e=Ra(r),t=Ia(),s=t[e];return s?(s.lastUsed=Date.now(),Ma(t),f.info("HEADERS","Retrieved headers for domain",{domain:e,headerCount:Object.keys(s.headers).length}),s.headers):(f.info("HEADERS","No saved headers for domain",{domain:e}),null)}function mp(r){let e={},t=[/^authorization$/i,/^x-/i,/^cookie$/i,/^token$/i,/^auth/i,/^api-key$/i,/^api_key$/i,/^apikey$/i],s=new Set(["user-agent","accept","accept-encoding","accept-language","content-type","content-length","host","origin","referer","connection","cache-control","pragma","upgrade-insecure-requests","sec-fetch-site","sec-fetch-mode","sec-fetch-dest","sec-ch-ua","sec-ch-ua-mobile","sec-ch-ua-platform"]);for(let[n,i]of Object.entries(r)){let o=n.toLowerCase();if(s.has(o))continue;t.some(l=>l.test(n))&&(e[n]=i);}return e}var hp=["login","signin","sign-in","sign_in","auth","oauth","sso","account","passport","cas","saml","oidc"],gp=['input[type="password"]','form[action*="login"]','form[action*="signin"]','form[action*="auth"]','button[type="submit"]:has-text("\u767B\u5F55")','button[type="submit"]:has-text("Login")','button[type="submit"]:has-text("Sign in")'],fp=['input[name="username"]','input[name="user"]','input[name="email"]','input[name="account"]','input[name="login"]','input[name="userId"]','input[name="loginId"]','input[id="username"]','input[id="user"]','input[id="email"]','input[id="account"]','input[id="login"]','input[type="email"]','input[type="text"][autocomplete="username"]','input[placeholder*="\u7528\u6237\u540D"]','input[placeholder*="\u8D26\u53F7"]','input[placeholder*="\u90AE\u7BB1"]','input[placeholder*="\u624B\u673A"]','input[placeholder*="Username"]','input[placeholder*="Email"]'],yp=['input[type="password"]','input[name="password"]','input[name="pwd"]','input[name="pass"]','input[id="password"]','input[id="pwd"]'],bp=['button[type="submit"]','input[type="submit"]','button:has-text("\u767B\u5F55")','button:has-text("Login")','button:has-text("Sign in")','button:has-text("Log in")','button:has-text("\u786E\u5B9A")','button:has-text("Submit")','a:has-text("\u767B\u5F55")',".login-btn",".submit-btn","#login-btn","#submit"];async function Aa(r,e){let t={},s=false,n=o=>{if(s)return;o.url();let l=o.resourceType();if(l==="xhr"||l==="fetch"||l==="document"){let c=o.headers();Object.assign(t,c);}},i=o=>{if(s)return;let a=o.status();o.url();let c=o.request().resourceType();a>=200&&a<300&&(c==="xhr"||c==="fetch")&&(s=true);};return r.on("request",n),r.on("response",i),t}async function wp(r,e){let t=Di(e);return !t||Object.keys(t).length===0?false:(await r.setExtraHTTPHeaders(t),true)}async function $i(r,e){let t=r.url(),s=t.toLowerCase();if(t!==e&&hp.some(i=>s.includes(i)))return {detected:true,original_url:e,redirected_url:t,redirect_type:"url_change",reason:`\u9875\u9762\u88AB\u91CD\u5B9A\u5411\u5230\u767B\u5F55\u9875\u9762: ${t}`};try{for(let n of gp)if(await r.$(n))return {detected:!0,original_url:e,redirected_url:t,redirect_type:"login_form",reason:`\u9875\u9762\u5305\u542B\u767B\u5F55\u8868\u5355\u5143\u7D20: ${n}`}}catch{}try{let n=await r.title(),i=n.toLowerCase(),o=["login","\u767B\u5F55","sign in","\u767B\u5165","authenticate","\u8BA4\u8BC1"];for(let a of o)if(i.includes(a))return {detected:!0,original_url:e,redirected_url:t,redirect_type:"auth_keyword",reason:`\u9875\u9762\u6807\u9898\u5305\u542B\u767B\u5F55\u5173\u952E\u8BCD: "${n}"`}}catch{}return {detected:false,original_url:e}}async function _p(r,e,t){try{t?.("auto_login_start",{message:"\u6B63\u5728\u81EA\u52A8\u586B\u5199\u767B\u5F55\u8868\u5355..."});let s=null;if(e.username_selector&&(s=await r.$(e.username_selector)),!s)for(let o of fp)try{if(s=await r.$(o),s)break}catch{}if(!s)return {success:!1,error:"\u627E\u4E0D\u5230\u7528\u6237\u540D\u8F93\u5165\u6846"};let n=null;if(e.password_selector&&(n=await r.$(e.password_selector)),!n)for(let o of yp)try{if(n=await r.$(o),n)break}catch{}if(!n)return {success:!1,error:"\u627E\u4E0D\u5230\u5BC6\u7801\u8F93\u5165\u6846"};let i=null;if(e.submit_selector&&(i=await r.$(e.submit_selector)),!i)for(let o of bp)try{if(i=await r.$(o),i)break}catch{}return i?(await s.click({clickCount:3}),await s.type(e.username,{delay:50}),t?.("auto_login_progress",{message:"\u5DF2\u586B\u5199\u7528\u6237\u540D"}),await n.click({clickCount:3}),await n.type(e.password,{delay:50}),t?.("auto_login_progress",{message:"\u5DF2\u586B\u5199\u5BC6\u7801"}),t?.("auto_login_progress",{message:"\u6B63\u5728\u63D0\u4EA4\u767B\u5F55..."}),await Promise.all([r.waitForNavigation({waitUntil:"networkidle0",timeout:3e4}).catch(()=>{}),i.click()]),await new Promise(o=>setTimeout(o,2e3)),{success:!0}):{success:!1,error:"\u627E\u4E0D\u5230\u767B\u5F55\u6309\u94AE"}}catch(s){return {success:false,error:String(s)}}}async function ar(r,e,t){let s=null,i=r.open_for_login===true&&r.allow_manual_login===true,o=r.auto_login&&r.auto_login.username&&r.auto_login.password;try{let a=r.url||"auto";if(a==="auto"){t?.("detecting");let y=await Li(e);if(!y){let b={success:!1,error:"\u672A\u627E\u5230\u8FD0\u884C\u4E2D\u7684\u5F00\u53D1\u670D\u52A1\u5668\u3002\u8BF7\u5148\u542F\u52A8\u5F00\u53D1\u670D\u52A1\u5668\uFF08\u5982 npm run dev\uFF09",url:"",load_time:0,timestamp:Date.now(),summary:"\u9519\u8BEF\uFF1A\u672A\u627E\u5230\u5F00\u53D1\u670D\u52A1\u5668"};return t?.("error",{error:b.error}),b}a=y.url,t?.("detected",{url:a});}t?.("launching",{url:a});let l=i?!1:r.headless!==!1,c=r.use_profile!==!1;s=await Pi({headless:l,useProfile:c}),t?.("loading",{url:a});let u=await s.newPage(),p=await wp(u,a);p&&t?.("headers_applied",{message:"\u5DF2\u5E94\u7528\u4FDD\u5B58\u7684\u8BA4\u8BC1 headers"}),await u.goto(a,{waitUntil:"networkidle0",timeout:3e4});let d=await $i(u,a);if(o&&d.detected){t?.("auto_login",{message:"\u68C0\u6D4B\u5230\u767B\u5F55\u9875\u9762\uFF0C\u6B63\u5728\u81EA\u52A8\u767B\u5F55..."});let y=Aa(u,a),b=await _p(u,r.auto_login,t);if(!b.success)return await s.close(),{success:!1,url:a,load_time:0,timestamp:Date.now(),summary:`\u274C \u81EA\u52A8\u767B\u5F55\u5931\u8D25: ${b.error}`,login_redirect:d,needs_login:!0};let w=await $i(u,a),S=await y;if(w.detected)return await s.close(),{success:!1,url:a,load_time:0,timestamp:Date.now(),summary:"\u274C \u81EA\u52A8\u767B\u5F55\u5931\u8D25\uFF0C\u53EF\u80FD\u662F\u8D26\u53F7\u6216\u5BC6\u7801\u9519\u8BEF\uFF0C\u8BF7\u68C0\u67E5\u540E\u91CD\u8BD5",login_redirect:w,needs_login:!0};{Object.keys(S).length>0&&(or(a,S),t?.("headers_saved",{headerCount:Object.keys(S).length})),t?.("auto_login_success",{message:"\u2705 \u81EA\u52A8\u767B\u5F55\u6210\u529F"}),t?.("collecting",{url:a});let x=await sr(u,a,{wait_time:r.wait_time,collect_console:r.collect_console,collect_errors:r.collect_errors,collect_network:r.collect_network,collect_performance:r.collect_performance,take_screenshot:r.take_screenshot,network_capture_mode:r.network_capture_mode||"cdp",network_filter:{xhr_only:r.network_xhr_only,url_pattern:r.network_url_pattern,status_filter:r.network_status_filter,include_body:r.network_include_body,body_max_length:r.network_body_max_length,max_results:r.network_max_results}}),R=nr({console_logs:x.console_logs,errors:x.errors,network_requests:x.network_requests,network_stats:x.network_stats,performance:x.performance});return await s.close(),{success:!0,url:a,load_time:x.load_time,timestamp:Date.now(),console_logs:x.console_logs,errors:x.errors,network_requests:x.network_requests,performance:x.performance,screenshot:x.screenshot,summary:`\u2705 \u81EA\u52A8\u767B\u5F55\u6210\u529F\uFF01
|
|
222
|
+
`;(t.collect_console!==false||t.collect_errors!==false)&&(await r.evaluateOnNewDocument(p),r.on("framenavigated",async T=>{if(T===r.mainFrame())try{await T.evaluate(p),f.debug("BROWSER",`Re-injected script after navigation to ${T.url()}`);}catch{}}));let d=await r.createCDPSession();await d.send("Runtime.enable"),await d.send("Log.enable"),t.collect_network!==false&&(i==="cdp"||i==="both")&&(await d.send("Network.enable"),f.debug("BROWSER","Network domain enabled (CDP mode)"));let m=T=>{let{type:C,args:_,timestamp:k}=T,N={log:"log",debug:"debug",info:"info",warning:"warn",error:"error",trace:"trace",assert:"error"}[C]||"log",E=_.map(A=>A.value!==void 0?String(A.value):A.description?A.description:A.preview?.properties?JSON.stringify(A.preview.properties.reduce((F,H)=>(F[H.name]=H.value,F),{})):String(A.type)).join(" ");o.push({type:N,timestamp:k?Math.floor(k):Date.now(),message:E}),f.debug("BROWSER",`[CDP] ${N}: ${E.substring(0,100)}`);},h=T=>{let{exceptionDetails:C}=T,_=C.exception?.description||C.text||"Unknown error";a.push({type:"exception",message:_,stack:C.stackTrace?.callFrames?.map(k=>` at ${k.functionName||"(anonymous)"} (${k.url}:${k.lineNumber}:${k.columnNumber})`).join(`
|
|
223
|
+
`)||"",file:C.url,line:C.lineNumber,column:C.columnNumber,timestamp:Date.now()}),f.debug("BROWSER",`[CDP Exception] ${_}`);},g=T=>{let{entry:C}=T,_=C.level;_==="error"?C.text&&(C.text.includes("Uncaught")||C.text.includes("Error"))?(a.push({type:"exception",message:C.text,stack:C.stackTrace?.callFrames?.map(k=>` at ${k.functionName||"(anonymous)"} (${k.url}:${k.lineNumber}:${k.columnNumber})`).join(`
|
|
224
|
+
`)||"",file:C.url,line:C.lineNumber,timestamp:Date.now()}),f.debug("BROWSER",`[CDP Log Error] ${C.text}`)):(o.push({type:"error",timestamp:Date.now(),message:C.text}),f.debug("BROWSER",`[CDP Log] error: ${C.text}`)):_==="warning"&&o.push({type:"warn",timestamp:Date.now(),message:C.text});};if(t.collect_console!==false&&d.on("Runtime.consoleAPICalled",m),t.collect_errors!==false&&(d.on("Runtime.exceptionThrown",h),d.on("Log.entryAdded",g),r.on("pageerror",T=>{let C=T;a.push({type:"exception",message:C.message,stack:C.stack||"",timestamp:Date.now()}),f.debug("BROWSER",`[Puppeteer pageerror] ${C.message}`);}),r.on("requestfailed",T=>{let C=T.failure();a.push({type:"browser_error",message:`Request failed: ${C?.errorText||"Unknown error"}`,stack:"",file:T.url(),timestamp:Date.now()});})),t.collect_network!==false&&(i==="cdp"||i==="both")&&(d.on("Network.requestWillBeSent",T=>{let C={url:T.request.url,method:T.request.method,resource_type:T.type?.toLowerCase()||"other",request_headers:T.request.headers,timing:{start:T.timestamp*1e3,end:0,duration:0}},_=T.type?.toLowerCase()||"other";if(!(n.xhr_only&&!["xhr","fetch"].includes(_))&&!(!n.xhr_only&&Ea.includes(_))){if(T.request.postData){let k=n.body_max_length||5e3,D=T.request.postData;D.length>k?C.request_body=D.substring(0,k)+"...[truncated]":C.request_body=D;}u.set(T.requestId,C),f.debug("BROWSER",`[CDP Network] ${_.toUpperCase()} ${C.method} ${C.url}`);}}),d.on("Network.responseReceived",T=>{let C=u.get(T.requestId);C&&C.timing&&(C.status=T.response.status,C.status_text=T.response.statusText,C.response_headers=T.response.headers,C.timing.end=T.timestamp*1e3,C.timing.duration=C.timing.end-C.timing.start,f.debug("BROWSER",`[CDP Network] Response ${C.status} ${C.url} (${C.timing.duration.toFixed(0)}ms)`));}),d.on("Network.loadingFailed",T=>{let C=u.get(T.requestId);C&&(C.error=T.errorText,C.timing&&(C.timing.end=T.timestamp*1e3,C.timing.duration=C.timing.end-C.timing.start),f.debug("BROWSER",`[CDP Network] Failed ${C.url}: ${C.error}`));})),t.collect_console!==false&&r.on("console",T=>{let C=T.type();o.push({type:C,timestamp:Date.now(),message:T.text(),args:T.args().map(_=>_.toString())}),f.debug("BROWSER",`[Puppeteer console] ${C}: ${T.text().substring(0,100)}`);}),t.collect_network!==false&&(i==="puppeteer"||i==="both")){let T=null;if(n.url_pattern)try{T=new RegExp(n.url_pattern,"i");}catch{f.warn("BROWSER",`Invalid URL pattern: ${n.url_pattern}`);}r.on("request",C=>{let _=C.url(),k=C.resourceType();if(n.xhr_only&&!lp.includes(k)||!n.xhr_only&&Ea.includes(k)||T&&!T.test(_))return;`${C.method()}-${_}-${Date.now()}`;let N={url:_,method:C.method(),resource_type:k,request_headers:C.headers(),timing:{start:Date.now(),end:0,duration:0}},E=C.postData();if(E){let A=n.body_max_length||5e3;E.length>A?N.request_body=E.substring(0,A)+"...[truncated]":N.request_body=E;}c.set(_,N),f.debug("BROWSER",`[Network] ${k.toUpperCase()} ${C.method()} ${_}`);}),r.on("response",async C=>{let _=C.url(),k=c.get(_);if(!k||!k.timing)return;k.status=C.status(),k.status_text=C.statusText(),k.response_headers=C.headers(),k.timing.end=Date.now(),k.timing.duration=k.timing.end-k.timing.start;let D=k.status>=400;if(n.include_body&&(D||n.status_filter))try{let E=C.headers()["content-type"]||"";if(E.includes("json")||E.includes("text")||E.includes("html")){let A=await C.text(),F=n.body_max_length||5e3;A.length>F?(k.response_body=A.substring(0,F),k.response_truncated=!0):k.response_body=A;}}catch(E){f.debug("BROWSER",`Failed to get response body for ${_}: ${E}`);}f.debug("BROWSER",`[Network] Response ${k.status} ${_} (${k.timing.duration}ms)`);}),r.on("requestfailed",C=>{let _=C.url(),k=c.get(_),D=C.failure();k&&(k.error=D?.errorText||"Request failed",k.timing&&(k.timing.end=Date.now(),k.timing.duration=k.timing.end-k.timing.start)),a.push({type:"browser_error",message:`Request failed: ${D?.errorText||"Unknown error"}`,stack:"",file:_,timestamp:Date.now()});});}f.info("BROWSER",`Navigating to: ${e}`),await r.goto(e,{waitUntil:"networkidle2",timeout:3e4});try{await d.send("Runtime.enable"),await d.send("Log.enable"),f.debug("BROWSER","Re-enabled Runtime and Log domains after navigation");}catch{f.debug("BROWSER","Failed to re-enable CDP domains (may already be enabled)");}if(t.collect_console!==false||t.collect_errors!==false)try{await r.evaluate(p),f.debug("BROWSER","Ensured script injection after page.goto");}catch{f.debug("BROWSER","Script already injected or page not ready");}let y=t.wait_time||3e3;if(f.info("BROWSER",`Waiting ${y}ms for async content...`),await new Promise(T=>setTimeout(T,y)),f.debug("BROWSER","Starting to extract injected logs..."),t.collect_console!==false||t.collect_errors!==false)try{f.debug("BROWSER","Calling page.evaluate to get __NEOX_CONSOLE_LOGS__...");let T=await r.evaluate(()=>({consoleLogs:window.__NEOX_CONSOLE_LOGS__||[],errors:window.__NEOX_ERRORS__||[]}));f.debug("BROWSER",`Extracted ${T.consoleLogs.length} console logs and ${T.errors.length} errors from injected script`);for(let k of T.consoleLogs)f.debug("BROWSER",` [${k.type}] ${k.message?.substring(0,100)}`);let C=new Map;for(let k of T.consoleLogs){let D=`${k.type}:${k.message}`;C.has(D)||C.set(D,{type:k.type,timestamp:k.timestamp,message:k.message});}for(let k of o){let D=`${k.type}:${k.message}`;C.has(D)||C.set(D,k);}o.length=0,o.push(...Array.from(C.values()));let _=new Map;for(let k of T.errors){let D=`${k.type}:${k.message}`;_.has(D)||_.set(D,{type:k.type,message:k.message,stack:k.stack||"",file:k.file,line:k.line,column:k.column,timestamp:k.timestamp});}for(let k of a){let D=`${k.type}:${k.message}`;_.has(D)||_.set(D,k);}a.length=0,a.push(...Array.from(_.values())),f.info("BROWSER",`Final: ${o.length} console logs, ${a.length} errors`);}catch(T){f.error("BROWSER","Failed to extract injected logs",{error:T});}let b;if(t.collect_performance!==false)try{let T=await r.metrics(),C=await r.evaluate(()=>{let _=window.performance,k=_.timing,D=_.getEntriesByType("paint"),N=document.querySelectorAll("*"),E=0,A=0,F=0,H=Math.min(1e3,N.length),M=Math.max(1,Math.floor(N.length/H));for(let P=0;P<N.length;P+=M){let q=N[P],B=window.getComputedStyle(q);B.display!=="none"&&B.visibility!=="hidden"&&B.opacity!=="0"?E++:A++;let j=0,Y=q.parentElement;for(;Y;)j++,Y=Y.parentElement;F=Math.max(F,j);}let ee=N.length/H;return E=Math.round(E*ee),A=Math.round(A*ee),{domContentLoaded:k.domContentLoadedEventEnd-k.navigationStart,loadComplete:k.loadEventEnd-k.navigationStart,paintMetrics:{first_paint:D.find(P=>P.name==="first-paint")?.startTime||0,first_contentful_paint:D.find(P=>P.name==="first-contentful-paint")?.startTime||0},memory:_.memory?{used_heap:_.memory.usedJSHeapSize,total_heap:_.memory.totalJSHeapSize,heap_limit:_.memory.jsHeapSizeLimit}:void 0,domStats:{visible_nodes:E,hidden_nodes:A,max_depth:F}}});b={dom_content_loaded:C.domContentLoaded,load_complete:C.loadComplete,dom_nodes:T.Nodes||0,js_heap_size:T.JSHeapUsedSize||0,event_listeners:T.JSEventListeners||0,paint_metrics:C.paintMetrics,memory:C.memory,dom_stats:C.domStats},f.info("BROWSER",`Performance: ${b.dom_nodes} nodes, ${(b.js_heap_size/1024/1024).toFixed(1)}MB heap`);}catch(T){f.error("BROWSER","Failed to collect performance metrics",{error:T});}let w;if(t.take_screenshot===true)try{w=await r.screenshot({encoding:"base64"});}catch(T){f.error("BROWSER","Failed to capture screenshot",{error:T});}try{await d.detach();}catch{}if(i==="cdp"||i==="both")for(let[T,C]of u.entries())Array.from(c.values()).find(k=>k.url===C.url)||c.set(T,C);let S=Array.from(c.values());i==="cdp"&&(S=Array.from(u.values()));let x=S.length;n.status_filter&&(S=S.filter(T=>cp(T.status,n.status_filter)));let R=S.filter(T=>T.error||T.status&&T.status>=400).length;S.sort((T,C)=>{let _=T.error||T.status&&T.status>=400,k=C.error||C.status&&C.status>=400;return _&&!k?-1:!_&&k?1:(T.timing?.start||0)-(C.timing?.start||0)});let $=n.max_results||20;S.length>$&&(S=S.slice(0,$));let G={total_captured:x,filtered_count:S.length,error_count:R};f.info("BROWSER",`Network: ${x} captured, ${S.length} returned, ${R} errors`);let U=Date.now()-s;return {console_logs:o,errors:a,network_requests:S,network_stats:G,performance:b,screenshot:w,load_time:U}}function rr(r){let e=[];r.errors&&r.errors.length>0&&(e.push(`\u{1F534} \u53D1\u73B0 ${r.errors.length} \u4E2A JavaScript \u5F02\u5E38\uFF1A`),r.errors.slice(0,5).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`),o.file&&e.push(` \u4F4D\u7F6E\uFF1A${o.file}:${o.line||""}`);}),e.push(""));let t=r.console_logs?.filter(o=>o.type==="error")||[];t.length>0&&(e.push(`\u{1F534} \u53D1\u73B0 ${t.length} \u4E2A console.error \u65E5\u5FD7\uFF1A`),t.slice(0,5).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`);}),e.push(""));let s=r.console_logs?.filter(o=>o.type==="warn")||[];s.length>0&&(e.push(`\u26A0\uFE0F ${s.length} \u4E2A console.warn \u8B66\u544A\uFF1A`),s.slice(0,3).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`);}),e.push(""));let n=r.console_logs?.filter(o=>o.type==="debug")||[];if(n.length>0&&(e.push(`\u{1F50D} ${n.length} \u4E2A console.debug \u65E5\u5FD7\uFF1A`),n.slice(0,3).forEach((o,a)=>{e.push(` ${a+1}. ${o.message}`);}),e.push("")),r.errors?.length===0&&t.length===0&&s.length===0&&(e.push("\u2705 \u672A\u53D1\u73B0 JavaScript \u9519\u8BEF\u6216\u8B66\u544A"),e.push("")),r.network_stats){let o=r.network_stats;e.push(`\u{1F310} \u7F51\u7EDC\u8BF7\u6C42\uFF1A\u5171\u6355\u83B7 ${o.total_captured} \u4E2A\uFF0C\u8FD4\u56DE ${o.filtered_count} \u4E2A\uFF0C${o.error_count} \u4E2A\u9519\u8BEF`);}let i=r.network_requests?.filter(o=>o.error||o.status&&o.status>=400)||[];if(i.length>0&&(e.push(`\u{1F534} ${i.length} \u4E2A API \u9519\u8BEF\u8BF7\u6C42\uFF1A`),i.slice(0,5).forEach((o,a)=>{if(e.push(` ${a+1}. [${o.status||"Failed"}] ${o.method} ${o.url}`),o.response_body){let l=o.response_body.substring(0,200);e.push(` \u54CD\u5E94: ${l}${o.response_body.length>200?"...":""}`);}o.error&&e.push(` \u9519\u8BEF: ${o.error}`);}),e.push("")),r.performance){let o=r.performance;if(o.dom_nodes>15e3?e.push(`\u{1F534} \u4E25\u91CD\u8B66\u544A\uFF1ADOM \u8282\u70B9\u8FC7\u591A (${o.dom_nodes.toLocaleString()}), \u9875\u9762\u6027\u80FD\u6781\u5DEE`):o.dom_nodes>1e4?e.push(`\u26A0\uFE0F \u8B66\u544A\uFF1ADOM \u8282\u70B9\u504F\u591A (${o.dom_nodes.toLocaleString()}), \u53EF\u80FD\u5F71\u54CD\u6027\u80FD`):o.dom_nodes>5e3&&e.push(`\u26A1 \u63D0\u793A\uFF1ADOM \u8282\u70B9\u8F83\u591A (${o.dom_nodes.toLocaleString()}), \u5EFA\u8BAE\u4F18\u5316`),o.dom_stats){let a=o.dom_stats,l=a.hidden_nodes/o.dom_nodes*100;e.push(` \u{1F4CA} \u53EF\u89C1: ${a.visible_nodes.toLocaleString()}, \u9690\u85CF: ${a.hidden_nodes.toLocaleString()} (${l.toFixed(1)}%), \u6700\u5927\u6DF1\u5EA6: ${a.max_depth} \u5C42`),l>40&&e.push(" \u26A0\uFE0F \u9690\u85CF\u8282\u70B9\u5360\u6BD4\u8FC7\u9AD8\uFF0C\u53EF\u80FD\u5B58\u5728\u672A\u6E05\u7406\u7684 DOM \u5143\u7D20"),a.max_depth>30&&e.push(` \u26A0\uFE0F DOM \u5D4C\u5957\u5C42\u7EA7\u8FC7\u6DF1 (${a.max_depth}), \u53EF\u80FD\u5B58\u5728\u6027\u80FD\u95EE\u9898`);}if(o.memory){let a=o.memory.used_heap/1024/1024,l=o.memory.heap_limit/1024/1024,c=o.memory.used_heap/o.memory.heap_limit*100;c>80?e.push(`\u26A1 \u5185\u5B58\u8B66\u544A\uFF1A\u5806\u4F7F\u7528\u7387 ${c.toFixed(1)}% (${a.toFixed(1)}MB / ${l.toFixed(1)}MB), \u63A5\u8FD1\u9650\u5236`):a>100&&e.push(`\u26A1 \u5185\u5B58\u63D0\u793A\uFF1A\u5806\u5185\u5B58\u8F83\u5927 ${a.toFixed(1)}MB`);}else o.js_heap_size>50*1024*1024&&e.push(`\u26A1 \u6027\u80FD\u8B66\u544A\uFF1AJS \u5806\u5185\u5B58\u8FC7\u5927 (${(o.js_heap_size/1024/1024).toFixed(1)}MB)`);o.paint_metrics&&o.paint_metrics.first_contentful_paint>3e3&&e.push(`\u26A1 \u6E32\u67D3\u6162\uFF1A\u9996\u6B21\u5185\u5BB9\u7ED8\u5236 ${o.paint_metrics.first_contentful_paint.toFixed(0)}ms (\u5EFA\u8BAE < 1500ms)`),o.load_complete>5e3&&e.push(`\u26A1 \u52A0\u8F7D\u6162\uFF1A\u9875\u9762\u5B8C\u5168\u52A0\u8F7D\u8017\u65F6 ${o.load_complete.toFixed(0)}ms (\u5EFA\u8BAE < 3000ms)`);}return e.join(`
|
|
225
|
+
`)||"\u2705 \u9875\u9762\u8FD0\u884C\u6B63\u5E38\uFF0C\u672A\u53D1\u73B0\u660E\u663E\u95EE\u9898"}async function Ia(r){let e=await up(r);if(e)return {url:`http://localhost:${e}`,port:e,protocol:"http",source:"vite.config"};let t=await pp(r);if(t)return {url:`http://localhost:${t}`,port:t,protocol:"http",source:"package.json"};let s=await dp(r);if(s)return {url:`http://localhost:${s}`,port:s,protocol:"http",source:"env"};let n=await mp(r);return {url:`http://localhost:${n}`,port:n,protocol:"http",source:"default"}}async function up(r){try{let e=join(r,"vite.config.js"),s=(await readFile(e,"utf-8")).match(/server\s*:\s*\{[^}]*port\s*:\s*(\d+)/);return s?parseInt(s[1]):null}catch{return null}}async function pp(r){try{let e=join(r,"package.json"),t=await readFile(e,"utf-8"),n=JSON.parse(t).scripts?.dev||"",i=n.match(/--port\s+(\d+)/);if(i)return parseInt(i[1]);let o=n.match(/PORT=(\d+)/);return o?parseInt(o[1]):null}catch{return null}}async function dp(r){try{let e=join(r,".env"),s=(await readFile(e,"utf-8")).match(/(?:VITE_)?PORT\s*=\s*(\d+)/);return s?parseInt(s[1]):null}catch{return null}}async function mp(r){try{let e=join(r,"package.json"),t=await readFile(e,"utf-8"),s=JSON.parse(t),n={...s.dependencies,...s.devDependencies};return n.vite?5173:n.next||n["react-scripts"]?3e3:n.vue?8080:n.nuxt?3e3:n.svelte?5e3:3e3}catch{return 3e3}}async function Ni(r,e=3e3){try{let t=new AbortController,s=setTimeout(()=>t.abort(),e),n=await fetch(r,{method:"HEAD",signal:t.signal});return clearTimeout(s),n.ok}catch{return false}}async function Fi(r){let e=await Ia(r);if(await Ni(e.url))return e;let s=[5173,3e3,8080,5e3,4200,8e3];for(let n of s){let i=`http://localhost:${n}`;if(await Ni(i))return {url:i,port:n,protocol:"http",source:"default"}}return null}me();var bp="headers.json";function Ma(r){try{return new URL(r).hostname}catch{return r}}function Aa(){let r=sr();return join(r,bp)}function Pa(){let r=Aa();if(!existsSync(r))return {};try{let e=readFileSync(r,"utf-8");return JSON.parse(e)}catch(e){return f.warn("HEADERS","Failed to read headers config",{error:e}),{}}}function Oa(r){let e=Aa();try{let t=JSON.stringify(r,null,2);writeFileSync(e,t,"utf-8"),f.info("HEADERS","Headers config saved",{path:e});}catch(t){f.error("HEADERS","Failed to save headers config",{error:t});}}function ar(r,e){let t=Ma(r),s=Pa(),n=wp(e);if(Object.keys(n).length===0){f.info("HEADERS","No headers to save for domain",{domain:t});return}s[t]={headers:n,lastUsed:Date.now(),createdAt:s[t]?.createdAt||Date.now(),url:r},Oa(s),f.info("HEADERS","Saved headers for domain",{domain:t,headerCount:Object.keys(n).length});}function Ui(r){let e=Ma(r),t=Pa(),s=t[e];return s?(s.lastUsed=Date.now(),Oa(t),f.info("HEADERS","Retrieved headers for domain",{domain:e,headerCount:Object.keys(s.headers).length}),s.headers):(f.info("HEADERS","No saved headers for domain",{domain:e}),null)}function wp(r){let e={},t=[/^authorization$/i,/^x-/i,/^cookie$/i,/^token$/i,/^auth/i,/^api-key$/i,/^api_key$/i,/^apikey$/i],s=new Set(["user-agent","accept","accept-encoding","accept-language","content-type","content-length","host","origin","referer","connection","cache-control","pragma","upgrade-insecure-requests","sec-fetch-site","sec-fetch-mode","sec-fetch-dest","sec-ch-ua","sec-ch-ua-mobile","sec-ch-ua-platform"]);for(let[n,i]of Object.entries(r)){let o=n.toLowerCase();if(s.has(o))continue;t.some(l=>l.test(n))&&(e[n]=i);}return e}var _p=["login","signin","sign-in","sign_in","auth","oauth","sso","account","passport","cas","saml","oidc"],Sp=['input[type="password"]','form[action*="login"]','form[action*="signin"]','form[action*="auth"]','button[type="submit"]:has-text("\u767B\u5F55")','button[type="submit"]:has-text("Login")','button[type="submit"]:has-text("Sign in")'],kp=['input[name="username"]','input[name="user"]','input[name="email"]','input[name="account"]','input[name="login"]','input[name="userId"]','input[name="loginId"]','input[id="username"]','input[id="user"]','input[id="email"]','input[id="account"]','input[id="login"]','input[type="email"]','input[type="text"][autocomplete="username"]','input[placeholder*="\u7528\u6237\u540D"]','input[placeholder*="\u8D26\u53F7"]','input[placeholder*="\u90AE\u7BB1"]','input[placeholder*="\u624B\u673A"]','input[placeholder*="Username"]','input[placeholder*="Email"]'],vp=['input[type="password"]','input[name="password"]','input[name="pwd"]','input[name="pass"]','input[id="password"]','input[id="pwd"]'],Tp=['button[type="submit"]','input[type="submit"]','button:has-text("\u767B\u5F55")','button:has-text("Login")','button:has-text("Sign in")','button:has-text("Log in")','button:has-text("\u786E\u5B9A")','button:has-text("Submit")','a:has-text("\u767B\u5F55")',".login-btn",".submit-btn","#login-btn","#submit"];async function La(r,e){let t={},s=false,n=o=>{if(s)return;o.url();let l=o.resourceType();if(l==="xhr"||l==="fetch"||l==="document"){let c=o.headers();Object.assign(t,c);}},i=o=>{if(s)return;let a=o.status();o.url();let c=o.request().resourceType();a>=200&&a<300&&(c==="xhr"||c==="fetch")&&(s=true);};return r.on("request",n),r.on("response",i),t}async function xp(r,e){let t=Ui(e);return !t||Object.keys(t).length===0?false:(await r.setExtraHTTPHeaders(t),true)}async function ji(r,e){let t=r.url(),s=t.toLowerCase();if(t!==e&&_p.some(i=>s.includes(i)))return {detected:true,original_url:e,redirected_url:t,redirect_type:"url_change",reason:`\u9875\u9762\u88AB\u91CD\u5B9A\u5411\u5230\u767B\u5F55\u9875\u9762: ${t}`};try{for(let n of Sp)if(await r.$(n))return {detected:!0,original_url:e,redirected_url:t,redirect_type:"login_form",reason:`\u9875\u9762\u5305\u542B\u767B\u5F55\u8868\u5355\u5143\u7D20: ${n}`}}catch{}try{let n=await r.title(),i=n.toLowerCase(),o=["login","\u767B\u5F55","sign in","\u767B\u5165","authenticate","\u8BA4\u8BC1"];for(let a of o)if(i.includes(a))return {detected:!0,original_url:e,redirected_url:t,redirect_type:"auth_keyword",reason:`\u9875\u9762\u6807\u9898\u5305\u542B\u767B\u5F55\u5173\u952E\u8BCD: "${n}"`}}catch{}return {detected:false,original_url:e}}async function Cp(r,e,t){try{t?.("auto_login_start",{message:"\u6B63\u5728\u81EA\u52A8\u586B\u5199\u767B\u5F55\u8868\u5355..."});let s=null;if(e.username_selector&&(s=await r.$(e.username_selector)),!s)for(let o of kp)try{if(s=await r.$(o),s)break}catch{}if(!s)return {success:!1,error:"\u627E\u4E0D\u5230\u7528\u6237\u540D\u8F93\u5165\u6846"};let n=null;if(e.password_selector&&(n=await r.$(e.password_selector)),!n)for(let o of vp)try{if(n=await r.$(o),n)break}catch{}if(!n)return {success:!1,error:"\u627E\u4E0D\u5230\u5BC6\u7801\u8F93\u5165\u6846"};let i=null;if(e.submit_selector&&(i=await r.$(e.submit_selector)),!i)for(let o of Tp)try{if(i=await r.$(o),i)break}catch{}return i?(await s.click({clickCount:3}),await s.type(e.username,{delay:50}),t?.("auto_login_progress",{message:"\u5DF2\u586B\u5199\u7528\u6237\u540D"}),await n.click({clickCount:3}),await n.type(e.password,{delay:50}),t?.("auto_login_progress",{message:"\u5DF2\u586B\u5199\u5BC6\u7801"}),t?.("auto_login_progress",{message:"\u6B63\u5728\u63D0\u4EA4\u767B\u5F55..."}),await Promise.all([r.waitForNavigation({waitUntil:"networkidle0",timeout:3e4}).catch(()=>{}),i.click()]),await new Promise(o=>setTimeout(o,2e3)),{success:!0}):{success:!1,error:"\u627E\u4E0D\u5230\u767B\u5F55\u6309\u94AE"}}catch(s){return {success:false,error:String(s)}}}async function lr(r,e,t){let s=null,i=r.open_for_login===true&&r.allow_manual_login===true,o=r.auto_login&&r.auto_login.username&&r.auto_login.password;try{let a=r.url||"auto";if(a==="auto"){t?.("detecting");let y=await Fi(e);if(!y){let b={success:!1,error:"\u672A\u627E\u5230\u8FD0\u884C\u4E2D\u7684\u5F00\u53D1\u670D\u52A1\u5668\u3002\u8BF7\u5148\u542F\u52A8\u5F00\u53D1\u670D\u52A1\u5668\uFF08\u5982 npm run dev\uFF09",url:"",load_time:0,timestamp:Date.now(),summary:"\u9519\u8BEF\uFF1A\u672A\u627E\u5230\u5F00\u53D1\u670D\u52A1\u5668"};return t?.("error",{error:b.error}),b}a=y.url,t?.("detected",{url:a});}t?.("launching",{url:a});let l=i?!1:r.headless!==!1,c=r.use_profile!==!1;s=await $i({headless:l,useProfile:c}),t?.("loading",{url:a});let u=await s.newPage(),p=await xp(u,a);p&&t?.("headers_applied",{message:"\u5DF2\u5E94\u7528\u4FDD\u5B58\u7684\u8BA4\u8BC1 headers"}),await u.goto(a,{waitUntil:"networkidle0",timeout:3e4});let d=await ji(u,a);if(o&&d.detected){t?.("auto_login",{message:"\u68C0\u6D4B\u5230\u767B\u5F55\u9875\u9762\uFF0C\u6B63\u5728\u81EA\u52A8\u767B\u5F55..."});let y=La(u,a),b=await Cp(u,r.auto_login,t);if(!b.success)return await s.close(),{success:!1,url:a,load_time:0,timestamp:Date.now(),summary:`\u274C \u81EA\u52A8\u767B\u5F55\u5931\u8D25: ${b.error}`,login_redirect:d,needs_login:!0};let w=await ji(u,a),S=await y;if(w.detected)return await s.close(),{success:!1,url:a,load_time:0,timestamp:Date.now(),summary:"\u274C \u81EA\u52A8\u767B\u5F55\u5931\u8D25\uFF0C\u53EF\u80FD\u662F\u8D26\u53F7\u6216\u5BC6\u7801\u9519\u8BEF\uFF0C\u8BF7\u68C0\u67E5\u540E\u91CD\u8BD5",login_redirect:w,needs_login:!0};{Object.keys(S).length>0&&(ar(a,S),t?.("headers_saved",{headerCount:Object.keys(S).length})),t?.("auto_login_success",{message:"\u2705 \u81EA\u52A8\u767B\u5F55\u6210\u529F"}),t?.("collecting",{url:a});let x=await nr(u,a,{wait_time:r.wait_time,collect_console:r.collect_console,collect_errors:r.collect_errors,collect_network:r.collect_network,collect_performance:r.collect_performance,take_screenshot:r.take_screenshot,network_capture_mode:r.network_capture_mode||"cdp",network_filter:{xhr_only:r.network_xhr_only,url_pattern:r.network_url_pattern,status_filter:r.network_status_filter,include_body:r.network_include_body,body_max_length:r.network_body_max_length,max_results:r.network_max_results}}),R=rr({console_logs:x.console_logs,errors:x.errors,network_requests:x.network_requests,network_stats:x.network_stats,performance:x.performance});return await s.close(),{success:!0,url:a,load_time:x.load_time,timestamp:Date.now(),console_logs:x.console_logs,errors:x.errors,network_requests:x.network_requests,performance:x.performance,screenshot:x.screenshot,summary:`\u2705 \u81EA\u52A8\u767B\u5F55\u6210\u529F\uFF01
|
|
226
226
|
|
|
227
227
|
${R}`,login_redirect:{detected:!1,original_url:a},needs_login:!1,captured_headers:S}}}if(d.detected&&!i&&!o)return await s.close(),{success:!1,url:a,load_time:0,timestamp:Date.now(),summary:`\u26A0\uFE0F \u9875\u9762\u9700\u8981\u767B\u5F55: ${d.reason}
|
|
228
228
|
|
|
229
|
-
\u{1F4A1} \u63D0\u793A\uFF1A\u5F53\u524D\u8FD0\u884C\u4E0D\u652F\u6301\u624B\u52A8\u767B\u5F55\uFF0C\u8BF7\u63D0\u4F9B\u8D26\u53F7\u5BC6\u7801\u4EE5\u81EA\u52A8\u767B\u5F55\uFF1B\u82E5\u65E0\u6CD5\u63D0\u4F9B\u5219\u653E\u5F03\u8BE5\u9875\u9762\u8C03\u8BD5\u3002`,login_redirect:d,needs_login:!0};if(i){t?.("waiting_login",{message:"\u6D4F\u89C8\u5668\u5DF2\u6253\u5F00\uFF0C\u8BF7\u5728\u6D4F\u89C8\u5668\u4E2D\u5B8C\u6210\u767B\u5F55...",profile_path:
|
|
229
|
+
\u{1F4A1} \u63D0\u793A\uFF1A\u5F53\u524D\u8FD0\u884C\u4E0D\u652F\u6301\u624B\u52A8\u767B\u5F55\uFF0C\u8BF7\u63D0\u4F9B\u8D26\u53F7\u5BC6\u7801\u4EE5\u81EA\u52A8\u767B\u5F55\uFF1B\u82E5\u65E0\u6CD5\u63D0\u4F9B\u5219\u653E\u5F03\u8BE5\u9875\u9762\u8C03\u8BD5\u3002`,login_redirect:d,needs_login:!0};if(i){t?.("waiting_login",{message:"\u6D4F\u89C8\u5668\u5DF2\u6253\u5F00\uFF0C\u8BF7\u5728\u6D4F\u89C8\u5668\u4E2D\u5B8C\u6210\u767B\u5F55...",profile_path:Di()});let y=La(u,a),b=r.login_wait_time||12e4;try{await u.waitForNavigation({timeout:b,waitUntil:"networkidle0"});}catch{}let w=await ji(u,a),S=await y;return w.detected?(await s.close(),{success:!1,url:a,load_time:0,timestamp:Date.now(),summary:"\u26A0\uFE0F \u767B\u5F55\u672A\u5B8C\u6210\u6216\u8D85\u65F6\uFF0C\u8BF7\u91CD\u8BD5",login_redirect:w,needs_login:!0}):(Object.keys(S).length>0&&(ar(a,S),t?.("headers_saved",{headerCount:Object.keys(S).length})),await s.close(),{success:!0,url:a,load_time:0,timestamp:Date.now(),summary:`\u2705 \u767B\u5F55\u6210\u529F\uFF01\u540E\u7EED\u8BBF\u95EE ${a} \u5C06\u81EA\u52A8\u4FDD\u6301\u767B\u5F55\u72B6\u6001\uFF08\u5DF2\u4FDD\u5B58 ${Object.keys(S).length} \u4E2A\u8BA4\u8BC1 headers\uFF09\u3002`,login_redirect:{detected:!1,original_url:a},needs_login:!1,captured_headers:S})}t?.("collecting",{url:a});let m=await nr(u,a,{wait_time:r.wait_time,collect_console:r.collect_console,collect_errors:r.collect_errors,collect_network:r.collect_network,collect_performance:r.collect_performance,take_screenshot:r.take_screenshot,network_capture_mode:r.network_capture_mode||"cdp",network_filter:{xhr_only:r.network_xhr_only,url_pattern:r.network_url_pattern,status_filter:r.network_status_filter,include_body:r.network_include_body,body_max_length:r.network_body_max_length,max_results:r.network_max_results}});t?.("analyzing");let h=rr({console_logs:m.console_logs,errors:m.errors,network_requests:m.network_requests,network_stats:m.network_stats,performance:m.performance});await s.close();let g={success:!0,url:a,load_time:m.load_time,timestamp:Date.now(),console_logs:m.console_logs,errors:m.errors,network_requests:m.network_requests,performance:m.performance,screenshot:m.screenshot,summary:h,login_redirect:d,needs_login:!1,used_saved_headers:p};return t?.("completed",{result:g}),g}catch(a){if(s)try{await s.close();}catch{}let l={success:false,error:String(a),url:r.url||"",load_time:0,timestamp:Date.now(),summary:`\u9519\u8BEF\uFF1A${a}`};return t?.("error",{error:l.error}),l}}function Gi(){if(typeof globalThis<"u"&&globalThis.window?.electronAPI)return globalThis.window.electronAPI;throw new Error("Terminal tools are only available in Electron UI mode")}var Rp={name:"terminal_execute",description:`Execute a shell command in a terminal session and return the output.
|
|
230
230
|
|
|
231
231
|
Use this tool when you need to:
|
|
232
232
|
- Run shell commands (npm, git, python, etc.)
|
|
@@ -241,7 +241,7 @@ Examples:
|
|
|
241
241
|
- Run tests: "npm test"
|
|
242
242
|
- Check git status: "git status"
|
|
243
243
|
- Build project: "npm run build"
|
|
244
|
-
- List files: "ls -la"`,parameters:{type:"object",properties:{command:{type:"string",description:'The shell command to execute (e.g., "npm test", "git status")'},cwd:{type:"string",description:"Optional working directory for the command (absolute path)"},timeout:{type:"number",description:"Optional timeout in milliseconds (default: 30000)"},sessionId:{type:"string",description:"Optional terminal session ID to reuse. If not provided, a new session will be created."}},required:["command"]},function:async r=>{let{command:e,cwd:t,timeout:s=3e4,sessionId:n}=r,i=
|
|
244
|
+
- List files: "ls -la"`,parameters:{type:"object",properties:{command:{type:"string",description:'The shell command to execute (e.g., "npm test", "git status")'},cwd:{type:"string",description:"Optional working directory for the command (absolute path)"},timeout:{type:"number",description:"Optional timeout in milliseconds (default: 30000)"},sessionId:{type:"string",description:"Optional terminal session ID to reuse. If not provided, a new session will be created."}},required:["command"]},function:async r=>{let{command:e,cwd:t,timeout:s=3e4,sessionId:n}=r,i=Gi();try{let o=n;o||(o=(await i.terminalCreate({cwd:t})).sessionId);let a=await i.terminalExecute(o,e,s);return n||await i.terminalDestroy(o),JSON.stringify({success:!0,output:a.stdout+a.stderr,exitCode:a.exitCode,stdout:a.stdout,stderr:a.stderr},null,2)}catch(o){return JSON.stringify({success:false,error:o.message||"Failed to execute command"},null,2)}}},Ep={name:"terminal_create",description:`Create a new terminal session for interactive use.
|
|
245
245
|
|
|
246
246
|
Use this tool when you need to:
|
|
247
247
|
- Start a long-running interactive process
|
|
@@ -256,10 +256,10 @@ After creating a session, you'll receive a sessionId that you can use for:
|
|
|
256
256
|
Example workflow:
|
|
257
257
|
1. Create session: terminal_create({ cwd: "/path/to/project" })
|
|
258
258
|
2. Execute commands: terminal_execute({ sessionId, command: "npm start" })
|
|
259
|
-
3. Clean up: terminal_destroy({ sessionId })`,parameters:{type:"object",properties:{cwd:{type:"string",description:"Optional working directory for the terminal (absolute path)"},shell:{type:"string",description:'Optional shell to use (e.g., "bash", "zsh", "powershell"). Defaults to system shell.'},cols:{type:"number",description:"Optional terminal width in columns (default: 80)"},rows:{type:"number",description:"Optional terminal height in rows (default: 24)"}},required:[]},function:async r=>{let{cwd:e,shell:t,cols:s,rows:n}=r,i=
|
|
259
|
+
3. Clean up: terminal_destroy({ sessionId })`,parameters:{type:"object",properties:{cwd:{type:"string",description:"Optional working directory for the terminal (absolute path)"},shell:{type:"string",description:'Optional shell to use (e.g., "bash", "zsh", "powershell"). Defaults to system shell.'},cols:{type:"number",description:"Optional terminal width in columns (default: 80)"},rows:{type:"number",description:"Optional terminal height in rows (default: 24)"}},required:[]},function:async r=>{let{cwd:e,shell:t,cols:s,rows:n}=r,i=Gi();try{let o=await i.terminalCreate({cwd:e,shell:t,cols:s,rows:n});return JSON.stringify({success:!0,sessionId:o.sessionId,cwd:o.cwd,shell:o.shell,message:`Terminal session created: ${o.sessionId}. Use this sessionId for subsequent operations.`},null,2)}catch(o){return JSON.stringify({success:false,error:o.message||"Failed to create terminal session"},null,2)}}},Ip={name:"terminal_destroy",description:`Close and clean up a terminal session.
|
|
260
260
|
|
|
261
261
|
Use this tool when you're done with a terminal session to free up resources.
|
|
262
|
-
All running processes in the session will be terminated.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The terminal session ID to destroy"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=
|
|
262
|
+
All running processes in the session will be terminated.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The terminal session ID to destroy"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Gi();try{return await t.terminalDestroy(e),JSON.stringify({success:!0,message:`Terminal session ${e} destroyed successfully`},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to destroy terminal session"},null,2)}}},Bi=[Rp,Ep,Ip],Da=["terminal"];function cr(){return Bi.map(r=>({...r,capabilities:r.capabilities?Array.from(new Set([...r.capabilities,...Da])):Da}))}function Ve(){if(typeof globalThis<"u"&&globalThis.window?.electronAPI)return globalThis.window.electronAPI;throw new Error("Editor tools are only available in Electron UI mode")}var Mp={name:"set_breakpoint",description:`Set a breakpoint at a specific line in a file.
|
|
263
263
|
|
|
264
264
|
Use this tool when you need to:
|
|
265
265
|
- Pause execution at a specific line to inspect state
|
|
@@ -276,15 +276,15 @@ Examples:
|
|
|
276
276
|
- Log point: { file: "/path/to/file.js", line: 42, logMessage: "Count: {count}", source: "llm" }
|
|
277
277
|
|
|
278
278
|
IMPORTANT: Always use source: "llm" to indicate the breakpoint was set by you.
|
|
279
|
-
This helps users distinguish between their breakpoints and yours.`,parameters:{type:"object",properties:{file:{type:"string",description:'Absolute path to the file (e.g., "/Users/name/project/src/app.js")'},line:{type:"number",description:"Line number (1-indexed) where the breakpoint should be set"},condition:{type:"string",description:`Optional condition expression (e.g., "x > 10", "user.name === 'Alice'")`},logMessage:{type:"string",description:'Optional log message for log points (e.g., "Value: {variable}")'},source:{type:"string",enum:["llm","user"],description:'MUST be "llm" to indicate this breakpoint was set by the AI'}},required:["file","line","source"]},function:async r=>{let{file:e,line:t,condition:s,logMessage:n,source:i}=r,o=Ve();if(i!=="llm")return JSON.stringify({success:false,error:'Breakpoints set by AI must have source: "llm"'},null,2);try{let a=await o.debugAddBreakpoint({file:e,line:t,condition:s,logMessage:n,source:i});return JSON.stringify({success:!0,breakpointId:a.id,file:a.file,line:a.line,enabled:a.enabled,message:`Breakpoint set at ${e}:${t}${s?` (condition: ${s})`:""}`},null,2)}catch(a){return JSON.stringify({success:false,error:a.message||"Failed to set breakpoint"},null,2)}}},
|
|
279
|
+
This helps users distinguish between their breakpoints and yours.`,parameters:{type:"object",properties:{file:{type:"string",description:'Absolute path to the file (e.g., "/Users/name/project/src/app.js")'},line:{type:"number",description:"Line number (1-indexed) where the breakpoint should be set"},condition:{type:"string",description:`Optional condition expression (e.g., "x > 10", "user.name === 'Alice'")`},logMessage:{type:"string",description:'Optional log message for log points (e.g., "Value: {variable}")'},source:{type:"string",enum:["llm","user"],description:'MUST be "llm" to indicate this breakpoint was set by the AI'}},required:["file","line","source"]},function:async r=>{let{file:e,line:t,condition:s,logMessage:n,source:i}=r,o=Ve();if(i!=="llm")return JSON.stringify({success:false,error:'Breakpoints set by AI must have source: "llm"'},null,2);try{let a=await o.debugAddBreakpoint({file:e,line:t,condition:s,logMessage:n,source:i});return JSON.stringify({success:!0,breakpointId:a.id,file:a.file,line:a.line,enabled:a.enabled,message:`Breakpoint set at ${e}:${t}${s?` (condition: ${s})`:""}`},null,2)}catch(a){return JSON.stringify({success:false,error:a.message||"Failed to set breakpoint"},null,2)}}},Ap={name:"remove_breakpoint",description:`Remove a specific breakpoint by ID.
|
|
280
280
|
|
|
281
281
|
Use this tool when you're done debugging a particular location
|
|
282
|
-
and want to clean up the breakpoint you previously set.`,parameters:{type:"object",properties:{breakpointId:{type:"string",description:"The ID of the breakpoint to remove (returned from set_breakpoint)"}},required:["breakpointId"]},function:async r=>{let{breakpointId:e}=r,t=Ve();try{return await t.debugRemoveBreakpoint(e),JSON.stringify({success:!0,message:`Breakpoint ${e} removed`},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to remove breakpoint"},null,2)}}},
|
|
282
|
+
and want to clean up the breakpoint you previously set.`,parameters:{type:"object",properties:{breakpointId:{type:"string",description:"The ID of the breakpoint to remove (returned from set_breakpoint)"}},required:["breakpointId"]},function:async r=>{let{breakpointId:e}=r,t=Ve();try{return await t.debugRemoveBreakpoint(e),JSON.stringify({success:!0,message:`Breakpoint ${e} removed`},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to remove breakpoint"},null,2)}}},Pp={name:"list_breakpoints",description:`List all breakpoints, optionally filtered by file.
|
|
283
283
|
|
|
284
284
|
Use this tool to:
|
|
285
285
|
- See what breakpoints are currently set
|
|
286
286
|
- Check if a breakpoint already exists before setting a new one
|
|
287
|
-
- Review breakpoints set by both you and the user`,parameters:{type:"object",properties:{file:{type:"string",description:"Optional file path to filter breakpoints (absolute path)"}},required:[]},function:async r=>{let{file:e}=r,t=Ve();try{let s=await t.debugGetBreakpoints(e);return JSON.stringify({success:!0,breakpoints:s.map(n=>({id:n.id,file:n.file,line:n.line,enabled:n.enabled,verified:n.verified,source:n.source,condition:n.condition,logMessage:n.logMessage})),count:s.length},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to list breakpoints"},null,2)}}},
|
|
287
|
+
- Review breakpoints set by both you and the user`,parameters:{type:"object",properties:{file:{type:"string",description:"Optional file path to filter breakpoints (absolute path)"}},required:[]},function:async r=>{let{file:e}=r,t=Ve();try{let s=await t.debugGetBreakpoints(e);return JSON.stringify({success:!0,breakpoints:s.map(n=>({id:n.id,file:n.file,line:n.line,enabled:n.enabled,verified:n.verified,source:n.source,condition:n.condition,logMessage:n.logMessage})),count:s.length},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to list breakpoints"},null,2)}}},Op={name:"clear_breakpoints",description:`Clear all breakpoints in a file or globally.
|
|
288
288
|
|
|
289
289
|
Use this tool when you want to:
|
|
290
290
|
- Clean up all breakpoints after debugging
|
|
@@ -292,7 +292,7 @@ Use this tool when you want to:
|
|
|
292
292
|
- Remove all breakpoints from a specific file
|
|
293
293
|
|
|
294
294
|
WARNING: This will remove ALL breakpoints (both user and LLM set).
|
|
295
|
-
Use with caution.`,parameters:{type:"object",properties:{file:{type:"string",description:"Optional file path to clear breakpoints from (absolute path). If not provided, clears ALL breakpoints."}},required:[]},function:async r=>{let{file:e}=r,t=Ve();try{return await t.debugClearBreakpoints(e),JSON.stringify({success:!0,message:e?`All breakpoints cleared from ${e}`:"All breakpoints cleared globally"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to clear breakpoints"},null,2)}}},
|
|
295
|
+
Use with caution.`,parameters:{type:"object",properties:{file:{type:"string",description:"Optional file path to clear breakpoints from (absolute path). If not provided, clears ALL breakpoints."}},required:[]},function:async r=>{let{file:e}=r,t=Ve();try{return await t.debugClearBreakpoints(e),JSON.stringify({success:!0,message:e?`All breakpoints cleared from ${e}`:"All breakpoints cleared globally"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to clear breakpoints"},null,2)}}},Lp={name:"start_debug_session",description:`Start a debugging session for a program.
|
|
296
296
|
|
|
297
297
|
Use this tool to begin debugging a Node.js, Python, or Java application.
|
|
298
298
|
After starting, the program will run until it hits a breakpoint or completes.
|
|
@@ -308,21 +308,21 @@ Example:
|
|
|
308
308
|
program: "/path/to/app.js",
|
|
309
309
|
args: ["--port", "3000"],
|
|
310
310
|
cwd: "/path/to/project"
|
|
311
|
-
}`,parameters:{type:"object",properties:{type:{type:"string",enum:["node","python","java"],description:"The type of program to debug"},program:{type:"string",description:"Absolute path to the program entry point (e.g., main.js, app.py, Main.java)"},args:{type:"array",items:{type:"string"},description:"Optional command-line arguments for the program"},cwd:{type:"string",description:"Optional working directory (defaults to program directory)"},env:{type:"object",description:'Optional environment variables (e.g., { "NODE_ENV": "development" })'}},required:["type","program"]},function:async r=>{let{type:e,program:t,args:s,cwd:n,env:i}=r,o=Ve();try{let a=await o.debugStartSession({type:e,program:t,args:s,cwd:n,env:i});return JSON.stringify({success:!0,sessionId:a.id,message:`Debug session started: ${a.id}. Use this sessionId for debug operations.`},null,2)}catch(a){return JSON.stringify({success:false,error:a.message||"Failed to start debug session"},null,2)}}},
|
|
311
|
+
}`,parameters:{type:"object",properties:{type:{type:"string",enum:["node","python","java"],description:"The type of program to debug"},program:{type:"string",description:"Absolute path to the program entry point (e.g., main.js, app.py, Main.java)"},args:{type:"array",items:{type:"string"},description:"Optional command-line arguments for the program"},cwd:{type:"string",description:"Optional working directory (defaults to program directory)"},env:{type:"object",description:'Optional environment variables (e.g., { "NODE_ENV": "development" })'}},required:["type","program"]},function:async r=>{let{type:e,program:t,args:s,cwd:n,env:i}=r,o=Ve();try{let a=await o.debugStartSession({type:e,program:t,args:s,cwd:n,env:i});return JSON.stringify({success:!0,sessionId:a.id,message:`Debug session started: ${a.id}. Use this sessionId for debug operations.`},null,2)}catch(a){return JSON.stringify({success:false,error:a.message||"Failed to start debug session"},null,2)}}},Dp={name:"stop_debug_session",description:`Stop a running debugging session.
|
|
312
312
|
|
|
313
313
|
Use this tool when you're done debugging to clean up resources
|
|
314
|
-
and terminate the debugged program.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID to stop"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStopSession(e),JSON.stringify({success:!0,message:`Debug session ${e} stopped`},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to stop debug session"},null,2)}}}
|
|
314
|
+
and terminate the debugged program.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID to stop"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStopSession(e),JSON.stringify({success:!0,message:`Debug session ${e} stopped`},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to stop debug session"},null,2)}}},$p={name:"debug_continue",description:`Continue program execution until the next breakpoint is hit or the program completes.
|
|
315
315
|
|
|
316
|
-
Use this tool after hitting a breakpoint to resume execution.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugContinue(e),JSON.stringify({success:!0,message:"Program execution continued"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to continue execution"},null,2)}}},
|
|
316
|
+
Use this tool after hitting a breakpoint to resume execution.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugContinue(e),JSON.stringify({success:!0,message:"Program execution continued"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to continue execution"},null,2)}}},Np={name:"debug_step_over",description:`Step over the current line of code.
|
|
317
317
|
|
|
318
318
|
Executes the current line and stops at the next line in the same function.
|
|
319
|
-
Function calls are executed without stepping into them.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStepOver(e),JSON.stringify({success:!0,message:"Stepped over current line"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to step over"},null,2)}}},
|
|
319
|
+
Function calls are executed without stepping into them.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStepOver(e),JSON.stringify({success:!0,message:"Stepped over current line"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to step over"},null,2)}}},Fp={name:"debug_step_into",description:`Step into the current function call.
|
|
320
320
|
|
|
321
321
|
If the current line contains a function call, steps into that function.
|
|
322
|
-
Otherwise, behaves like step_over.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStepInto(e),JSON.stringify({success:!0,message:"Stepped into function"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to step into"},null,2)}}},
|
|
322
|
+
Otherwise, behaves like step_over.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStepInto(e),JSON.stringify({success:!0,message:"Stepped into function"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to step into"},null,2)}}},Up={name:"debug_step_out",description:`Step out of the current function.
|
|
323
323
|
|
|
324
324
|
Continues execution until the current function returns,
|
|
325
|
-
then stops at the call site.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStepOut(e),JSON.stringify({success:!0,message:"Stepped out of function"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to step out"},null,2)}}},
|
|
325
|
+
then stops at the call site.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{return await t.debugStepOut(e),JSON.stringify({success:!0,message:"Stepped out of function"},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to step out"},null,2)}}},jp={name:"get_variables",description:`Get the values of all variables in the current scope.
|
|
326
326
|
|
|
327
327
|
Use this tool when stopped at a breakpoint to inspect:
|
|
328
328
|
- Local variables
|
|
@@ -330,12 +330,12 @@ Use this tool when stopped at a breakpoint to inspect:
|
|
|
330
330
|
- Closure variables
|
|
331
331
|
- Global variables
|
|
332
332
|
|
|
333
|
-
Optionally specify a frameId to inspect a different stack frame.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},frameId:{type:"number",description:"Optional stack frame ID (0 = current frame, 1 = caller, etc.)"}},required:["sessionId"]},function:async r=>{let{sessionId:e,frameId:t}=r,s=Ve();try{let n=await s.debugGetVariables(e,t);return JSON.stringify({success:!0,variables:n,count:n.length},null,2)}catch(n){return JSON.stringify({success:false,error:n.message||"Failed to get variables"},null,2)}}},
|
|
333
|
+
Optionally specify a frameId to inspect a different stack frame.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},frameId:{type:"number",description:"Optional stack frame ID (0 = current frame, 1 = caller, etc.)"}},required:["sessionId"]},function:async r=>{let{sessionId:e,frameId:t}=r,s=Ve();try{let n=await s.debugGetVariables(e,t);return JSON.stringify({success:!0,variables:n,count:n.length},null,2)}catch(n){return JSON.stringify({success:false,error:n.message||"Failed to get variables"},null,2)}}},Gp={name:"get_stack_trace",description:`Get the current call stack (stack trace).
|
|
334
334
|
|
|
335
335
|
Use this tool when stopped at a breakpoint to understand:
|
|
336
336
|
- How the program reached the current location
|
|
337
337
|
- The chain of function calls
|
|
338
|
-
- Which files and lines are in the call path`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{let s=await t.debugGetStackTrace(e);return JSON.stringify({success:!0,stackTrace:s,depth:s.length},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to get stack trace"},null,2)}}}
|
|
338
|
+
- Which files and lines are in the call path`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"}},required:["sessionId"]},function:async r=>{let{sessionId:e}=r,t=Ve();try{let s=await t.debugGetStackTrace(e);return JSON.stringify({success:!0,stackTrace:s,depth:s.length},null,2)}catch(s){return JSON.stringify({success:false,error:s.message||"Failed to get stack trace"},null,2)}}},Bp={name:"evaluate_expression",description:`Evaluate an expression in the current debug context.
|
|
339
339
|
|
|
340
340
|
Use this tool to:
|
|
341
341
|
- Check the value of a specific variable or expression
|
|
@@ -347,9 +347,9 @@ Examples:
|
|
|
347
347
|
- "user.name" - Get a property value
|
|
348
348
|
- "count > 10" - Evaluate a condition
|
|
349
349
|
- "formatDate(timestamp)" - Call a function
|
|
350
|
-
- "arr[0] + arr[1]" - Perform calculations`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},expression:{type:"string",description:'The expression to evaluate (e.g., "user.name", "count > 10")'},frameId:{type:"number",description:"Optional stack frame ID to evaluate in (default: current frame)"}},required:["sessionId","expression"]},function:async r=>{let{sessionId:e,expression:t,frameId:s}=r,n=Ve();try{let i=await n.debugEvaluate(e,t,s);return JSON.stringify({success:!0,result:i.value,type:i.type},null,2)}catch(i){return JSON.stringify({success:false,error:i.message||"Failed to evaluate expression"},null,2)}}},
|
|
351
|
-
`)}catch(s){return JSON.stringify({error:s.message})}}function
|
|
352
|
-
... [\u8F93\u51FA\u5DF2\u622A\u65AD\uFF0C\u4F7F\u7528\u66F4\u5177\u4F53\u7684 directory \u53C2\u6570\u67E5\u770B\u5B50\u76EE\u5F55]`};function
|
|
350
|
+
- "arr[0] + arr[1]" - Perform calculations`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},expression:{type:"string",description:'The expression to evaluate (e.g., "user.name", "count > 10")'},frameId:{type:"number",description:"Optional stack frame ID to evaluate in (default: current frame)"}},required:["sessionId","expression"]},function:async r=>{let{sessionId:e,expression:t,frameId:s}=r,n=Ve();try{let i=await n.debugEvaluate(e,t,s);return JSON.stringify({success:!0,result:i.value,type:i.type},null,2)}catch(i){return JSON.stringify({success:false,error:i.message||"Failed to evaluate expression"},null,2)}}},Wi=[Mp,Ap,Pp,Op,Lp,Dp,$p,Np,Fp,Up,jp,Gp,Bp],$a=["editor"];function ur(){return Wi.map(r=>({...r,capabilities:r.capabilities?Array.from(new Set([...r.capabilities,...$a])):$a}))}me();me();var Wp=new Set([".git",".svn",".hg",".idea",".vscode",".vs",".fleet",".DS_Store","__MACOSX","Thumbs.db"]),Hp={nodejs:{detectFiles:["package.json","package-lock.json","yarn.lock","pnpm-lock.yaml"],skipDirs:["node_modules","dist","build","out",".next",".nuxt",".output",".cache",".parcel-cache",".turbo","coverage",".nyc_output","storybook-static"],skipPatterns:[/\.min\.js$/,/\.bundle\.js$/,/\.chunk\.js$/],interestingDirs:["src","lib","app","pages","components","hooks","utils","services","api","types","styles","public","assets","test","tests","__tests__","spec"],description:"Node.js/JavaScript/TypeScript \u9879\u76EE"},python:{detectFiles:["setup.py","pyproject.toml","requirements.txt","Pipfile","poetry.lock"],skipDirs:["__pycache__",".pytest_cache",".mypy_cache",".tox",".nox","venv",".venv","env",".env","virtualenv",".eggs","*.egg-info","dist","build",".ipynb_checkpoints","htmlcov"],skipPatterns:[/\.pyc$/,/\.pyo$/],interestingDirs:["src","lib","app","apps","core","api","models","views","services","utils","tests","test","scripts","notebooks","docs"],description:"Python \u9879\u76EE"},java:{detectFiles:["pom.xml","build.gradle","build.gradle.kts","settings.gradle"],skipDirs:["target","build","out",".gradle","bin",".mvn","gradle"],skipPatterns:[/\.class$/],interestingDirs:["src","main","java","kotlin","resources","test","webapp","templates"],description:"Java/Kotlin/Gradle/Maven \u9879\u76EE"},golang:{detectFiles:["go.mod","go.sum"],skipDirs:["vendor","bin"],interestingDirs:["cmd","pkg","internal","api","web","configs","scripts","test","tests","docs"],description:"Go \u9879\u76EE"},rust:{detectFiles:["Cargo.toml","Cargo.lock"],skipDirs:["target"],interestingDirs:["src","benches","examples","tests"],description:"Rust \u9879\u76EE"},cpp:{detectFiles:["CMakeLists.txt","Makefile","meson.build","configure.ac"],skipDirs:["build","cmake-build-debug","cmake-build-release","bin","obj","out",".ccache"],skipPatterns:[/\.o$/,/\.obj$/,/\.a$/,/\.so$/,/\.dll$/,/\.exe$/],interestingDirs:["src","include","lib","tests","test","examples","docs"],description:"C/C++ \u9879\u76EE"},ruby:{detectFiles:["Gemfile","Gemfile.lock","Rakefile",".ruby-version"],skipDirs:["vendor/bundle",".bundle","tmp","log","coverage","node_modules"],interestingDirs:["app","lib","config","db","spec","test","public","views"],description:"Ruby/Rails \u9879\u76EE"},php:{detectFiles:["composer.json","composer.lock","artisan"],skipDirs:["vendor","node_modules","storage/framework","bootstrap/cache"],interestingDirs:["app","src","config","database","resources","routes","tests","public"],description:"PHP/Laravel/Composer \u9879\u76EE"},dotnet:{detectFiles:["*.csproj","*.fsproj","*.sln","packages.config"],skipDirs:["bin","obj","packages",".nuget","TestResults"],skipPatterns:[/\.dll$/,/\.exe$/,/\.pdb$/],interestingDirs:["src","lib","tests","Controllers","Models","Views","Services","Data"],description:".NET/C#/F# \u9879\u76EE"},swift:{detectFiles:["Package.swift","*.xcodeproj","*.xcworkspace","Podfile"],skipDirs:["Pods","DerivedData","build",".build","Carthage","xcuserdata"],interestingDirs:["Sources","Tests","Resources","Assets"],description:"Swift/iOS/macOS \u9879\u76EE"},flutter:{detectFiles:["pubspec.yaml","pubspec.lock"],skipDirs:[".dart_tool","build",".pub-cache","android/build","ios/Pods","web/build"],interestingDirs:["lib","test","assets","android","ios","web","macos","linux","windows"],description:"Flutter/Dart \u9879\u76EE"},elixir:{detectFiles:["mix.exs","mix.lock"],skipDirs:["_build","deps",".elixir_ls","cover"],interestingDirs:["lib","test","config","priv","assets"],description:"Elixir/Phoenix \u9879\u76EE"}},zp=new Set(["src","lib","app","core","api","test","tests","docs","doc","examples","scripts","config","configs"]);async function qp(r){let e={types:[],skipDirs:new Set(Wp),skipPatterns:[],interestingDirs:new Set(zp),descriptions:[]};try{let t=await Z__default.readdir(r),s=new Set(t);for(let[n,i]of Object.entries(Hp))i.detectFiles.some(a=>{if(a.includes("*")){let l=a.replace("*","");return t.some(c=>c.endsWith(l)||c.startsWith(l.replace(".","")))}return s.has(a)})&&(e.types.push(n),e.descriptions.push(i.description),i.skipDirs.forEach(a=>e.skipDirs.add(a)),i.skipPatterns&&e.skipPatterns.push(...i.skipPatterns),i.interestingDirs.forEach(a=>e.interestingDirs.add(a)));}catch{}return e}function Hi(r,e){if(e.skipDirs.has(r))return true;for(let t of e.skipDirs)if(t.includes("*")){let s=t.replace("*","");if(r.endsWith(s)||r.startsWith(s.replace(".","")))return true}return false}function Jp(r,e){return e.interestingDirs.has(r)}async function Na(r,e,t){let{maxDepth:s,currentDepth:n,shallow:i,expandInteresting:o}=t;if(n>s)return [];try{let a=await Z__default.readdir(r,{withFileTypes:!0}),l=[],c=a.filter(p=>p.isDirectory()&&!p.name.startsWith(".")),u=a.filter(p=>p.isFile()&&!p.name.startsWith("."));for(let p of c){let d=X__default.join(r,p.name);if(Hi(p.name,e)){let m=0;try{m=(await Z__default.readdir(d)).length;}catch{}l.push({name:p.name,path:d,isDirectory:!0,skipped:!0,skipReason:Kp(p.name,e),itemCount:m});}else {let m=Jp(p.name,e),g=(i?!1:o&&m||n<s)?await Na(d,e,{maxDepth:s,currentDepth:n+1,shallow:i,expandInteresting:o}):void 0;l.push({name:p.name,path:d,isDirectory:!0,isInteresting:m,children:g});}}if(!i||n===0)for(let p of u){let d=X__default.join(r,p.name),m=!1;for(let h of e.skipPatterns)if(h.test(p.name)){m=!0;break}if(!m)try{let h=await Z__default.stat(d);l.push({name:p.name,path:d,isDirectory:!1,size:h.size});}catch{l.push({name:p.name,path:d,isDirectory:!1});}}return l}catch{return []}}function Kp(r,e){return ["node_modules","vendor","Pods","deps",".dart_tool","packages"].includes(r)?"dependencies":["dist","build","out","target",".next",".nuxt","bin","obj"].includes(r)?"build output":r.includes("cache")||r.startsWith(".")&&r.includes("_")?"cache":["coverage","htmlcov",".nyc_output"].includes(r)?"coverage":["venv",".venv","env","virtualenv"].includes(r)?"virtual env":"auto-skipped"}function Vp(r){return r<1024?`${r}B`:r<1024*1024?`${(r/1024).toFixed(1)}KB`:`${(r/(1024*1024)).toFixed(1)}MB`}function zi(r,e=""){let t=[];for(let s=0;s<r.length;s++){let n=r[s],i=s===r.length-1,o=i?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",a=i?" ":"\u2502 ";if(n.isDirectory)if(n.skipped){let l=n.itemCount!==void 0?` (${n.itemCount} items)`:"";t.push(`${e}${o}[~] ${n.name}/ [>>] ${n.skipReason}${l}`);}else n.isInteresting?(t.push(`${e}${o}[+] ${n.name}/ [*]`),n.children&&n.children.length>0&&t.push(...zi(n.children,e+a))):(t.push(`${e}${o}[~] ${n.name}/`),n.children&&n.children.length>0&&t.push(...zi(n.children,e+a)));else {let l=n.size!==void 0?` (${Vp(n.size)})`:"";t.push(`${e}${o}[] ${n.name}${l}`);}}return t}async function Yp(r,e,t){try{let s=await Z__default.readdir(r,{withFileTypes:!0}),n=[],i=[];for(let c of s)c.name.startsWith(".")||(c.isDirectory()?Hi(c.name,t)||n.push(c.name):Xp(c.name)&&i.push(c.name));let o=[],a=n.find(c=>["src","lib","app","core","packages"].includes(c));if(a){let c=X__default.join(r,a);try{let u=await Z__default.readdir(c,{withFileTypes:!0});for(let p of u)p.isDirectory()&&!p.name.startsWith(".")&&!Hi(p.name,t)&&o.push(p.name);}catch{}}let l=[];return l.push(`\u{1F4C1} Path: ${e}`),l.push(""),t.descriptions.length>0&&l.push(`\u{1F4E6} Project Type: ${t.descriptions.join(", ")}`),n.length>0&&l.push(`\u{1F4C2} Root Directories: ${n.sort().join(", ")}`),o.length>0&&l.push(`\u{1F527} Modules: ${o.sort().join(", ")}`),i.length>0&&l.push(`\u2699\uFE0F Config Files: ${i.slice(0,5).join(", ")}`),l.push(""),l.push('\u{1F4A1} Tip: Use search(pattern="keyword", path="src/", recursive=true) to locate code'),l.join(`
|
|
351
|
+
`)}catch(s){return JSON.stringify({error:s.message})}}function Xp(r){return new Set(["package.json","tsconfig.json","pom.xml","build.gradle","Cargo.toml","go.mod","requirements.txt","pyproject.toml","Makefile","Dockerfile","docker-compose.yml",".env.example","README.md"]).has(r)}var ds={maxLines:500,maxChars:15e3,truncationMessage:`
|
|
352
|
+
... [\u8F93\u51FA\u5DF2\u622A\u65AD\uFF0C\u4F7F\u7528\u66F4\u5177\u4F53\u7684 directory \u53C2\u6570\u67E5\u770B\u5B50\u76EE\u5F55]`};function Zp(r){let e=0,t=[];for(let s=0;s<r.length&&s<ds.maxLines;s++){let n=r[s];if(e+n.length>ds.maxChars){t.push(ds.truncationMessage);break}t.push(n),e+=n.length+1;}return r.length>ds.maxLines&&!t.includes(ds.truncationMessage)&&t.push(ds.truncationMessage),t}var Qp="NEOX_WORKDIR";function Fa(){let r=process.env[Qp];return r&&r.trim()?X__default.resolve(r):process.cwd()}function ed(r){let e=Fa();return !r||r.trim()===""||r.trim()==="."?e:X__default.isAbsolute(r)?X__default.resolve(r):X__default.resolve(e,r)}function td(r){let e=Fa(),t=X__default.relative(e,r);return t&&!t.startsWith("..")&&!X__default.isAbsolute(t)?t:r}var Ua={name:"smart_tree",description:`\u667A\u80FD\u76EE\u5F55\u626B\u63CF\u5DE5\u5177 - \u81EA\u52A8\u8BC6\u522B\u9879\u76EE\u7C7B\u578B\u5E76\u4F18\u5316\u663E\u793A\u3002
|
|
353
353
|
|
|
354
354
|
\u3010\u5206\u5C42\u641C\u7D22\u7B56\u7565\u3011
|
|
355
355
|
\u8FD9\u662F Layer 1: \u7ED3\u6784\u611F\u77E5\u5DE5\u5177\u3002\u914D\u5408 search (Layer 2: \u8BED\u4E49\u5B9A\u4F4D) \u4F7F\u7528\u6548\u679C\u6700\u4F73\u3002
|
|
@@ -366,11 +366,11 @@ Examples:
|
|
|
366
366
|
- deep: \u5B8C\u5168\u5C55\u5F00\u6240\u6709\u76EE\u5F55
|
|
367
367
|
|
|
368
368
|
\u793A\u4F8B:
|
|
369
|
-
{"mode": "structure"} \u2192 {"root_dirs": ["src","config","test"], "modules": ["auth","health","order"]}`,parameters:{type:"object",properties:{directory:{type:"string",description:"\u76EE\u5F55\u8DEF\u5F84 (\u9ED8\u8BA4: \u5F53\u524D\u5DE5\u4F5C\u76EE\u5F55)"},mode:{type:"string",enum:["structure","shallow","normal","deep"],description:"\u626B\u63CF\u6A21\u5F0F: structure(\u7ED3\u6784JSON), shallow(\u6D45\u5C42), normal(\u6B63\u5E38), deep(\u6DF1\u5C42)\u3002\u9ED8\u8BA4: structure"},max_depth:{type:"number",description:"\u6700\u5927\u6DF1\u5EA6 (structure/shallow \u56FA\u5B9A\u4E3A 1-2\uFF0C\u5176\u4ED6\u6A21\u5F0F\u9ED8\u8BA4 3)"}}},async function({directory:r=".",mode:e="structure",max_depth:t}){try{let s=
|
|
370
|
-
`)}catch(s){return s.code==="ENOENT"?`[x] \u76EE\u5F55\u4E0D\u5B58\u5728: ${r}`:`[x] \u626B\u63CF\u5931\u8D25: ${s.message}`}}};function
|
|
371
|
-
\u274C Permission denied: Cannot write to config file`),console.error(` Location: ${
|
|
372
|
-
Please check directory permissions or try:`),console.error(` sudo chown -R $USER "${
|
|
373
|
-
`)):console.error("[Config] Failed to save configuration:",t.message),e}}var
|
|
369
|
+
{"mode": "structure"} \u2192 {"root_dirs": ["src","config","test"], "modules": ["auth","health","order"]}`,parameters:{type:"object",properties:{directory:{type:"string",description:"\u76EE\u5F55\u8DEF\u5F84 (\u9ED8\u8BA4: \u5F53\u524D\u5DE5\u4F5C\u76EE\u5F55)"},mode:{type:"string",enum:["structure","shallow","normal","deep"],description:"\u626B\u63CF\u6A21\u5F0F: structure(\u7ED3\u6784JSON), shallow(\u6D45\u5C42), normal(\u6B63\u5E38), deep(\u6DF1\u5C42)\u3002\u9ED8\u8BA4: structure"},max_depth:{type:"number",description:"\u6700\u5927\u6DF1\u5EA6 (structure/shallow \u56FA\u5B9A\u4E3A 1-2\uFF0C\u5176\u4ED6\u6A21\u5F0F\u9ED8\u8BA4 3)"}}},async function({directory:r=".",mode:e="structure",max_depth:t}){try{let s=ed(r),n=td(s);if(!(await Z__default.stat(s)).isDirectory())return `[x] \u4E0D\u662F\u76EE\u5F55: ${n}`;let o=await qp(s);if(e==="structure")return await Yp(s,n,o);let a=e==="shallow",l=t??(a?1:e==="deep"?5:3),u=await Na(s,o,{maxDepth:l,currentDepth:0,shallow:a,expandInteresting:e!=="shallow"}),p=[];p.push(`[~] ${n}/`),p.push(""),o.types.length>0?p.push(`[?] \u68C0\u6D4B\u5230\u9879\u76EE\u7C7B\u578B: ${o.descriptions.join(", ")}`):p.push("[?] \u672A\u68C0\u6D4B\u5230\u7279\u5B9A\u9879\u76EE\u7C7B\u578B"),p.push(`\u{1F4CA} \u626B\u63CF\u6A21\u5F0F: ${e} | \u6700\u5927\u6DF1\u5EA6: ${l}`),p.push(""),p.push("\u56FE\u4F8B: [+][*] \u91CD\u70B9\u76EE\u5F55 | [~][>>] \u5DF2\u8DF3\u8FC7 | [~] \u666E\u901A\u76EE\u5F55"),p.push("\u2500".repeat(50)),p.push(""),u.length===0?p.push("(\u7A7A\u76EE\u5F55)"):p.push(...zi(u));let d=ja(u),m=Ga(u);return p.push(""),p.push("\u2500".repeat(50)),p.push(`\u7EDF\u8BA1: ${m} \u4E2A\u91CD\u70B9\u76EE\u5F55 | ${d} \u4E2A\u5DF2\u8DF3\u8FC7\u76EE\u5F55`),a&&(p.push(""),p.push('\u{1F4A1} \u63D0\u793A: \u4F7F\u7528 mode="normal" \u6DF1\u5165\u63A2\u7D22\u611F\u5174\u8DA3\u7684\u76EE\u5F55')),Zp(p).join(`
|
|
370
|
+
`)}catch(s){return s.code==="ENOENT"?`[x] \u76EE\u5F55\u4E0D\u5B58\u5728: ${r}`:`[x] \u626B\u63CF\u5931\u8D25: ${s.message}`}}};function ja(r){let e=0;for(let t of r)t.skipped&&e++,t.children&&(e+=ja(t.children));return e}function Ga(r){let e=0;for(let t of r)t.isInteresting&&e++,t.children&&(e+=Ga(t.children));return e}function rd(){return X__default.join(Js__default.homedir(),".neox")}var Qs=rd(),qi=X__default.join(Qs,"config.json");X__default.join(Qs,"sounds");function Wa(r){let e=r,t=false;if(typeof e.supervisor<"u"&&(e={...e},delete e.supervisor,t=true),e.collab?.supervisorAgent){e===r&&(e={...e});let s={...e.collab};delete s.supervisorAgent,Object.keys(s).length===0?delete e.collab:e.collab={...s,workerPool:s.workerPool??[]},t=true;}return {config:e,changed:t}}function en(){try{let r=Ce__default.readFileSync(qi,"utf-8"),e=JSON.parse(r),{config:t,changed:s}=Wa(e);if(s)try{Ha(t);}catch{}return t}catch{return {}}}function Ha(r){try{let{config:e}=Wa(r);Ce__default.existsSync(Qs)||Ce__default.mkdirSync(Qs,{recursive:!0}),Ce__default.writeFileSync(qi,JSON.stringify(e,null,2),"utf-8");}catch(e){let t=e;throw t.code==="EACCES"||t.code==="EPERM"?(console.error(`
|
|
371
|
+
\u274C Permission denied: Cannot write to config file`),console.error(` Location: ${qi}`),console.error(`
|
|
372
|
+
Please check directory permissions or try:`),console.error(` sudo chown -R $USER "${Qs}"
|
|
373
|
+
`)):console.error("[Config] Failed to save configuration:",t.message),e}}var id=/^user_([0-9a-f]{64})_account__session_([0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})$/,od=/^[0-9a-f]{64}$/,ad=/session_([0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})/i;function za(r){let e=r.toString("hex");return `${e.slice(0,8)}-${e.slice(8,12)}-${e.slice(12,16)}-${e.slice(16,20)}-${e.slice(20)}`}function ld(){let r=randomBytes(16);return r[6]=r[6]&15|64,r[8]=r[8]&63|128,za(r)}function cd(r){return r.match(id)?.[1]??null}function ud(r){let e=createHash("sha256").update(r).digest(),t=Buffer.from(e.subarray(0,16));return t[6]=t[6]&15|64,t[8]=t[8]&63|128,za(t)}function pd(){let r=en(),e=typeof r.anthropicClientId=="string"?r.anthropicClientId.trim().toLowerCase():"";if(e&&od.test(e))return e;let t=typeof r.anthropicProxyUserId=="string"?r.anthropicProxyUserId.trim().toLowerCase():"",n=(t?cd(t):null)||randomBytes(32).toString("hex");return r.anthropicClientId=n,Ha(r),n}function qa(r,e){let t=pd(),n=(r?r.match(ad):null)?.[1]?.toLowerCase()||ud(r||e||ld());return `user_${t}_account__session_${n}`}var Ki={name:"web_search",description:`Search the web using Google (via Serper.dev API).
|
|
374
374
|
|
|
375
375
|
Use cases:
|
|
376
376
|
- Search for documentation: {"query": "React hooks useEffect tutorial"}
|
|
@@ -378,7 +378,7 @@ Use cases:
|
|
|
378
378
|
- Search for latest information: {"query": "Node.js 20 new features"}
|
|
379
379
|
- Search for code examples: {"query": "Python async await example"}
|
|
380
380
|
|
|
381
|
-
Returns top search results with title, URL, and description.`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query string"},max_results:{type:"number",description:"Maximum number of results to return (default: 10, max: 20)"}},required:["query"]},async function({query:r,max_results:e=10}){let t=Date.now();try{if(!r||r.trim().length===0)return "\u2717 \u641C\u7D22\u5931\u8D25: \u8BF7\u63D0\u4F9B\u641C\u7D22\u5173\u952E\u8BCD";let n=
|
|
381
|
+
Returns top search results with title, URL, and description.`,parameters:{type:"object",properties:{query:{type:"string",description:"Search query string"},max_results:{type:"number",description:"Maximum number of results to return (default: 10, max: 20)"}},required:["query"]},async function({query:r,max_results:e=10}){let t=Date.now();try{if(!r||r.trim().length===0)return "\u2717 \u641C\u7D22\u5931\u8D25: \u8BF7\u63D0\u4F9B\u641C\u7D22\u5173\u952E\u8BCD";let n=en().webSearch?.apiKey;if(!n)return `\u2717 \u641C\u7D22\u5931\u8D25: \u672A\u914D\u7F6E Serper.dev API Key
|
|
382
382
|
|
|
383
383
|
\u8BF7\u5728\u8BBE\u7F6E\u9875\u9762 \u2192 Agent \u2192 Web Search \u4E2D\u914D\u7F6E API Key
|
|
384
384
|
\u6CE8\u518C\u5730\u5740: https://serper.dev (\u514D\u8D39 2500 \u6B21\u641C\u7D22)`;let i=await fetch("https://google.serper.dev/search",{method:"POST",headers:{"X-API-KEY":n,"Content-Type":"application/json"},body:JSON.stringify({q:r.trim(),num:Math.min(Math.max(1,e),20)})});if(!i.ok)return i.status===401?`\u2717 \u641C\u7D22\u5931\u8D25: API Key \u65E0\u6548
|
|
@@ -411,7 +411,7 @@ Returns top search results with title, URL, and description.`,parameters:{type:"
|
|
|
411
411
|
[@] ${p.hostname}
|
|
412
412
|
`;}),u+="\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501",u}catch(s){let n=Date.now()-t;return s.message?.includes("ENOTFOUND")||s.message?.includes("network")?`\u2717 \u641C\u7D22\u5931\u8D25: \u7F51\u7EDC\u8FDE\u63A5\u9519\u8BEF
|
|
413
413
|
\u8BF7\u68C0\u67E5\u7F51\u7EDC\u8FDE\u63A5\u540E\u91CD\u8BD5`:s.message?.includes("timeout")?`\u2717 \u641C\u7D22\u5931\u8D25: \u8BF7\u6C42\u8D85\u65F6 (${n}ms)
|
|
414
|
-
\u8BF7\u7A0D\u540E\u91CD\u8BD5`:`\u2717 \u641C\u7D22\u5931\u8D25: ${s.message||"\u672A\u77E5\u9519\u8BEF"}`}}},
|
|
414
|
+
\u8BF7\u7A0D\u540E\u91CD\u8BD5`:`\u2717 \u641C\u7D22\u5931\u8D25: ${s.message||"\u672A\u77E5\u9519\u8BEF"}`}}},Ja={name:"web_fetch",description:`Fetch content from a URL and extract readable text.
|
|
415
415
|
|
|
416
416
|
Use cases:
|
|
417
417
|
- Read documentation pages: {"url": "https://docs.example.com/api"}
|
|
@@ -424,7 +424,7 @@ Note: Works best with text-based pages. May not work well with JavaScript-heavy
|
|
|
424
424
|
`).replace(/[ \t]+\n/g,`
|
|
425
425
|
`).replace(/\n{3,}/g,`
|
|
426
426
|
|
|
427
|
-
`).trim(),h=[];if(t){let w=/<a[^>]+href=["']([^"']+)["'][^>]*>([^<]*)<\/a>/gi,S;for(;(S=w.exec(p))!==null;){let x=S[1],R=S[2].trim();if(x&&R&&!x.startsWith("#")&&!x.startsWith("javascript:"))try{let
|
|
427
|
+
`).trim(),h=[];if(t){let w=/<a[^>]+href=["']([^"']+)["'][^>]*>([^<]*)<\/a>/gi,S;for(;(S=w.exec(p))!==null;){let x=S[1],R=S[2].trim();if(x&&R&&!x.startsWith("#")&&!x.startsWith("javascript:"))try{let $=new URL(x,r).href;h.push({text:R,href:$});}catch{}}h=h.filter((x,R,$)=>R===$.findIndex(G=>G.href===x.href)).slice(0,20);}let g=Math.min(Math.max(1e3,e),5e4),y=m.length>g;y&&(m=m.slice(0,g)+`
|
|
428
428
|
|
|
429
429
|
... (\u5185\u5BB9\u5DF2\u622A\u65AD)`);let b=`\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
430
430
|
[@] Web Fetch
|
|
@@ -450,19 +450,19 @@ ${m}
|
|
|
450
450
|
URL: ${r}`:n.message?.includes("ENOTFOUND")?`\u2717 \u83B7\u53D6\u5931\u8D25: \u65E0\u6CD5\u89E3\u6790\u57DF\u540D
|
|
451
451
|
URL: ${r}`:n.message?.includes("ECONNREFUSED")?`\u2717 \u83B7\u53D6\u5931\u8D25: \u8FDE\u63A5\u88AB\u62D2\u7EDD
|
|
452
452
|
URL: ${r}`:`\u2717 \u83B7\u53D6\u5931\u8D25: ${n.message||"\u672A\u77E5\u9519\u8BEF"}
|
|
453
|
-
URL: ${r}`}}};
|
|
453
|
+
URL: ${r}`}}};me();function Ka(r){return {...er,async function(e){try{f.debug("BROWSER","Starting browser debug",{url:e.url});let t=await lr(e,r,(n,i)=>{f.debug("BROWSER",`Status: ${n}`,i);});f.debug("BROWSER","Browser debug completed",{success:t.success});let s={success:t.success,url:t.url,summary:t.summary,stats:{console_logs:t.console_logs?.length||0,errors:t.errors?.length||0,network_requests:t.network_requests?.length||0,load_time_ms:t.load_time},console_logs:t.console_logs?.slice(0,10).map(n=>({type:n.type,message:n.message})),errors:t.errors?.slice(0,5).map(n=>({type:n.type,message:n.message,file:n.file,line:n.line}))};return t.screenshot&&(s.screenshot={format:"base64",data:t.screenshot,note:"\u9875\u9762\u622A\u56FE\uFF08base64 \u7F16\u7801\uFF09"}),JSON.stringify(s,null,2)}catch(t){return f.error("BROWSER","Browser debug failed",{error:t.message}),JSON.stringify({success:false,error:t.message,url:e.url||"",load_time:0,timestamp:Date.now(),summary:`\u9519\u8BEF\uFF1A${t.message}`},null,2)}}}}var tn=class extends EventEmitter{socket=null;sequenceNumber=1;pendingRequests=new Map;buffer="";connected=false;DEFAULT_TIMEOUT=3e4;async connect(e,t,s=1e4){return new Promise((n,i)=>{this.socket=new Va.Socket;let o=setTimeout(()=>{this.socket?.destroy(),i(new Error(`Connection timeout after ${s}ms`));},s);this.socket.connect(t,e,()=>{clearTimeout(o),this.connected=true,this.emit("connected"),n();}),this.socket.on("data",a=>{this.handleData(a);}),this.socket.on("error",a=>{clearTimeout(o),this.emit("error",a),this.connected||i(a);}),this.socket.on("close",()=>{this.connected=false,this.emit("disconnected"),this.pendingRequests.forEach(({reject:a,timeout:l})=>{clearTimeout(l),a(new Error("Connection closed"));}),this.pendingRequests.clear();});})}disconnect(){this.socket&&(this.socket.end(),this.socket=null),this.connected=false;}isConnected(){return this.connected}async sendRequest(e,t,s=this.DEFAULT_TIMEOUT){if(!this.connected||!this.socket)throw new Error("Not connected to debug server");let n=this.sequenceNumber++,i={seq:n,type:"request",command:e,arguments:t};return new Promise((o,a)=>{let l=setTimeout(()=>{this.pendingRequests.delete(n),a(new Error(`Request timeout: ${e} (${s}ms)`));},s);this.pendingRequests.set(n,{resolve:o,reject:a,timeout:l}),this.send(i);})}send(e){let t=JSON.stringify(e),n=`Content-Length: ${Buffer.byteLength(t,"utf8")}\r
|
|
454
454
|
\r
|
|
455
|
-
`,i=Buffer.concat([Buffer.from(n,"utf8"),Buffer.from(t,"utf8")]);this.socket?.write(i);}handleData(e){for(this.buffer+=e.toString("utf8");;){let t=this.buffer.match(/Content-Length: (\d+)\r\n\r\n/);if(!t)break;let s=parseInt(t[1],10),n=t[0].length,i=t.index+n,o=i+s;if(this.buffer.length<o)break;let a=this.buffer.substring(i,o);this.buffer=this.buffer.substring(o);try{let l=JSON.parse(a);this.handleMessage(l);}catch(l){console.error("Failed to parse DAP message:",l);}}}handleMessage(e){if(e.type==="response"){let t=e,s=this.pendingRequests.get(t.request_seq);s&&(clearTimeout(s.timeout),this.pendingRequests.delete(t.request_seq),t.success?s.resolve(t):s.reject(new Error(t.message||"Request failed")));}else if(e.type==="event"){let t=e;this.emit("event",t),this.emit(`event:${t.event}`,t.body);}}async initialize(e){return await this.sendRequest("initialize",e)}async launch(e){return await this.sendRequest("launch",e)}async attach(e){return await this.sendRequest("attach",e)}async setBreakpoints(e){return await this.sendRequest("setBreakpoints",e)}async configurationDone(){return await this.sendRequest("configurationDone")}async continue(e){return await this.sendRequest("continue",e)}async next(e){return await this.sendRequest("next",e)}async stepIn(e){return await this.sendRequest("stepIn",e)}async stepOut(e){return await this.sendRequest("stepOut",e)}async pause(e){return await this.sendRequest("pause",{threadId:e})}async stackTrace(e){return await this.sendRequest("stackTrace",e)}async scopes(e){return await this.sendRequest("scopes",e)}async variables(e){return await this.sendRequest("variables",e)}async evaluate(e){return await this.sendRequest("evaluate",e)}async threads(){return await this.sendRequest("threads")}async exceptionInfo(e){return await this.sendRequest("exceptionInfo",e)}async disconnectRequest(e={}){return await this.sendRequest("disconnect",e)}async restart(){return await this.sendRequest("restart")}async terminate(){return await this.sendRequest("terminate")}};var
|
|
455
|
+
`,i=Buffer.concat([Buffer.from(n,"utf8"),Buffer.from(t,"utf8")]);this.socket?.write(i);}handleData(e){for(this.buffer+=e.toString("utf8");;){let t=this.buffer.match(/Content-Length: (\d+)\r\n\r\n/);if(!t)break;let s=parseInt(t[1],10),n=t[0].length,i=t.index+n,o=i+s;if(this.buffer.length<o)break;let a=this.buffer.substring(i,o);this.buffer=this.buffer.substring(o);try{let l=JSON.parse(a);this.handleMessage(l);}catch(l){console.error("Failed to parse DAP message:",l);}}}handleMessage(e){if(e.type==="response"){let t=e,s=this.pendingRequests.get(t.request_seq);s&&(clearTimeout(s.timeout),this.pendingRequests.delete(t.request_seq),t.success?s.resolve(t):s.reject(new Error(t.message||"Request failed")));}else if(e.type==="event"){let t=e;this.emit("event",t),this.emit(`event:${t.event}`,t.body);}}async initialize(e){return await this.sendRequest("initialize",e)}async launch(e){return await this.sendRequest("launch",e)}async attach(e){return await this.sendRequest("attach",e)}async setBreakpoints(e){return await this.sendRequest("setBreakpoints",e)}async configurationDone(){return await this.sendRequest("configurationDone")}async continue(e){return await this.sendRequest("continue",e)}async next(e){return await this.sendRequest("next",e)}async stepIn(e){return await this.sendRequest("stepIn",e)}async stepOut(e){return await this.sendRequest("stepOut",e)}async pause(e){return await this.sendRequest("pause",{threadId:e})}async stackTrace(e){return await this.sendRequest("stackTrace",e)}async scopes(e){return await this.sendRequest("scopes",e)}async variables(e){return await this.sendRequest("variables",e)}async evaluate(e){return await this.sendRequest("evaluate",e)}async threads(){return await this.sendRequest("threads")}async exceptionInfo(e){return await this.sendRequest("exceptionInfo",e)}async disconnectRequest(e={}){return await this.sendRequest("disconnect",e)}async restart(){return await this.sendRequest("restart")}async terminate(){return await this.sendRequest("terminate")}};var dr=class extends EventEmitter{process=null;port=0;isRunning=false;config;constructor(e){super(),this.config=e;}async start(){if(this.isRunning)throw new Error("Java Debug Server is already running");try{await Z.access(this.config.jarPath);}catch{throw new Error(`Java Debug JAR not found at: ${this.config.jarPath}
|
|
456
456
|
Please download it from https://github.com/microsoft/java-debug/releases`)}let e=this.getJavaCommand();return new Promise((t,s)=>{let n=this.config.startupTimeout||1e4,i="",o=setTimeout(()=>{this.isRunning||(this.stop(),s(new Error(`Java Debug Server startup timeout (${n}ms)
|
|
457
457
|
Output so far:
|
|
458
458
|
${i}`)));},n);this.process=spawn(e,["-jar",this.config.jarPath],{stdio:["pipe","pipe","pipe"]}),this.process.stdout?.on("data",a=>{let l=a.toString();i+=l,this.emit("stdout",l);let c=l.match(/Listening.*?address:\s*(\d+)/i);c&&(this.port=parseInt(c[1],10),this.isRunning=true,clearTimeout(o),this.emit("started",this.port),t(this.port));let u=l.match(/listening.*?port\s*(\d+)/i);u&&(this.port=parseInt(u[1],10),this.isRunning=true,clearTimeout(o),this.emit("started",this.port),t(this.port));}),this.process.stderr?.on("data",a=>{let l=a.toString();i+=l,this.emit("stderr",l),l.toLowerCase().includes("error")&&this.emit("error",new Error(l));}),this.process.on("exit",(a,l)=>{this.isRunning=false,this.emit("exit",{code:a,signal:l}),a!==0&&a!==null&&s(new Error(`Java Debug Server exited with code ${a}
|
|
459
|
-
${i}`));}),this.process.on("error",a=>{clearTimeout(o),this.isRunning=false,this.emit("error",a),s(a);});})}stop(){this.process&&(this.process.kill(),this.process=null),this.isRunning=false,this.port=0,this.emit("stopped");}getPort(){return this.port}isServerRunning(){return this.isRunning}getJavaCommand(){return this.config.javaHome?
|
|
459
|
+
${i}`));}),this.process.on("error",a=>{clearTimeout(o),this.isRunning=false,this.emit("error",a),s(a);});})}stop(){this.process&&(this.process.kill(),this.process=null),this.isRunning=false,this.port=0,this.emit("stopped");}getPort(){return this.port}isServerRunning(){return this.isRunning}getJavaCommand(){return this.config.javaHome?X.join(this.config.javaHome,"bin","java"):process.env.JAVA_HOME?X.join(process.env.JAVA_HOME,"bin","java"):"java"}async initialize(){if(!this.process||!this.isRunning)throw new Error("Server is not running");let e={jsonrpc:"2.0",id:1,method:"initialize",params:{processId:process.pid,capabilities:{}}};this.sendLSPMessage(e);let t={jsonrpc:"2.0",method:"initialized",params:{}};this.sendLSPMessage(t);}sendLSPMessage(e){if(!this.process?.stdin)throw new Error("Server stdin is not available");let t=JSON.stringify(e),i=`Content-Length: ${Buffer.byteLength(t,"utf8")}\r
|
|
460
460
|
\r
|
|
461
|
-
`+t;this.process.stdin.write(i);}async startDAPServer(){return new Promise((e,t)=>{let s=setTimeout(()=>{t(new Error("Timeout waiting for DAP server to start"));},5e3),n=o=>{let a=o.match(/DAP.*?port\s*(\d+)/i);if(a){let l=parseInt(a[1],10);clearTimeout(s),this.removeListener("stdout",n),e(l);}};this.on("stdout",n);let i={jsonrpc:"2.0",id:2,method:"vscode.java.startDebugSession",params:{}};this.sendLSPMessage(i);})}};var
|
|
461
|
+
`+t;this.process.stdin.write(i);}async startDAPServer(){return new Promise((e,t)=>{let s=setTimeout(()=>{t(new Error("Timeout waiting for DAP server to start"));},5e3),n=o=>{let a=o.match(/DAP.*?port\s*(\d+)/i);if(a){let l=parseInt(a[1],10);clearTimeout(s),this.removeListener("stdout",n),e(l);}};this.on("stdout",n);let i={jsonrpc:"2.0",id:2,method:"vscode.java.startDebugSession",params:{}};this.sendLSPMessage(i);})}};var mr=class extends EventEmitter{sessions=new Map;config;sessionIdCounter=0;constructor(e){super(),this.config=e,this.config.sessionTimeout&&setInterval(()=>{this.cleanupInactiveSessions();},6e4);}async launch(e){let t=this.generateSessionId();try{let s=new dr({jarPath:this.config.javaDebugJarPath,javaHome:this.config.javaHome,startupTimeout:this.config.defaultTimeout}),n=await s.start(),i=new tn;await i.connect("localhost",n),await i.initialize({clientID:"neox",clientName:"Neox Java Debugger",adapterID:"java",pathFormat:"path",linesStartAt1:!0,columnsStartAt1:!0}),await i.launch({mainClass:e.mainClass,projectName:e.projectPath.split("/").pop(),classPaths:e.classpath?[e.classpath]:[],args:e.args?.join(" "),vmArgs:e.vmArgs?.join(" "),cwd:e.cwd||e.projectPath,stopOnEntry:e.stopOnEntry}),await i.configurationDone();let o={id:t,status:"running",breakpoints:new Map,createdAt:Date.now(),lastActivity:Date.now()};return this.sessions.set(t,{session:o,client:i,server:s}),this.setupClientListeners(t,i),{sessionId:t,status:"running",message:`Debug session started for ${e.mainClass}`}}catch(s){throw new Error(`Failed to launch debug session: ${s.message}`)}}async attach(e){let t=this.generateSessionId();try{let s=new tn;await s.connect(e.hostName||"localhost",e.port),await s.initialize({clientID:"neox",clientName:"Neox Java Debugger",adapterID:"java",pathFormat:"path",linesStartAt1:!0,columnsStartAt1:!0}),await s.attach({hostName:e.hostName||"localhost",port:e.port,timeout:e.timeout||5e3}),await s.configurationDone();let n={id:t,status:"running",breakpoints:new Map,createdAt:Date.now(),lastActivity:Date.now()};return this.sessions.set(t,{session:n,client:s,server:null}),this.setupClientListeners(t,s),{sessionId:t,status:"running",message:`Attached to Java process on ${e.hostName||"localhost"}:${e.port}`}}catch(s){throw new Error(`Failed to attach to process: ${s.message}`)}}async setBreakpoint(e){let t=this.getSessionContext(e.sessionId);t.session.lastActivity=Date.now();try{let n=(await t.client.setBreakpoints({source:{path:e.filePath},breakpoints:[{line:e.line,condition:e.condition,hitCondition:e.hitCondition,logMessage:e.logMessage}]})).body.breakpoints[0];return t.session.breakpoints.has(e.filePath)||t.session.breakpoints.set(e.filePath,[]),t.session.breakpoints.get(e.filePath).push(n),{breakpointId:n.id||-1,verified:n.verified,line:n.line||e.line,message:n.verified?`Breakpoint set at line ${n.line}`:`Breakpoint not verified: ${n.message||"Unknown reason"}`}}catch(s){throw new Error(`Failed to set breakpoint: ${s.message}`)}}async continue(e){let t=this.getSessionContext(e.sessionId);t.session.lastActivity=Date.now();try{let s=e.threadId||t.session.currentThreadId||1;return await t.client.continue({threadId:s}),t.session.status="running",await this.waitForStoppedOrTimeout(t,s)}catch(s){throw new Error(`Failed to continue execution: ${s.message}`)}}async stepOver(e){return await this.performStep(e,"stepOver")}async stepInto(e){return await this.performStep(e,"stepInto")}async stepOut(e){return await this.performStep(e,"stepOut")}async getVariables(e){let t=this.getSessionContext(e.sessionId);t.session.lastActivity=Date.now();try{let s=t.session.currentThreadId||1,n=e.frameId||t.session.currentFrameId||0,i=await t.client.stackTrace({threadId:s,startFrame:0,levels:1});if(i.body.stackFrames.length===0)throw new Error("No stack frames available");let o=i.body.stackFrames[0],a=await t.client.scopes({frameId:o.id}),l=[];for(let c of a.body.scopes){if(e.filter==="local"&&c.name!=="Local"||e.filter==="arguments"&&c.name!=="Arguments")continue;let u=await t.client.variables({variablesReference:c.variablesReference});l.push(...u.body.variables);}return {variables:l.map(c=>({name:c.name,value:c.value,type:c.type||"unknown",variablesReference:c.variablesReference})),message:`Retrieved ${l.length} variables`}}catch(s){throw new Error(`Failed to get variables: ${s.message}`)}}async getStackTrace(e){let t=this.getSessionContext(e.sessionId);t.session.lastActivity=Date.now();try{let s=e.threadId||t.session.currentThreadId||1,n=await t.client.stackTrace({threadId:s,startFrame:0,levels:50});return {stackFrames:n.body.stackFrames.map(i=>({id:i.id,name:i.name,source:{path:i.source?.path||"unknown",line:i.line},presentationHint:i.presentationHint})),totalFrames:n.body.totalFrames||n.body.stackFrames.length,message:`Retrieved ${n.body.stackFrames.length} stack frames`}}catch(s){throw new Error(`Failed to get stack trace: ${s.message}`)}}async evaluate(e){let t=this.getSessionContext(e.sessionId);t.session.lastActivity=Date.now();try{let s=e.frameId||t.session.currentFrameId,n=await t.client.evaluate({expression:e.expression,frameId:s,context:e.context||"repl"});return {result:n.body.result,type:n.body.type||"unknown",variablesReference:n.body.variablesReference,message:`Expression evaluated: ${n.body.result}`}}catch(s){throw new Error(`Failed to evaluate expression: ${s.message}`)}}async stop(e){let t=this.getSessionContext(e.sessionId);try{return await t.client.disconnectRequest({terminateDebuggee:e.terminateDebuggee!==!1}),t.server&&t.server.stop(),this.sessions.delete(e.sessionId),{status:"terminated",message:"Debug session stopped"}}catch(s){return this.sessions.delete(e.sessionId),{status:"terminated",message:`Debug session stopped (with error: ${s.message})`}}}getSession(e){return this.sessions.get(e)?.session||null}listSessions(){return Array.from(this.sessions.values()).map(e=>e.session)}generateSessionId(){return `java-debug-${Date.now()}-${++this.sessionIdCounter}`}getSessionContext(e){let t=this.sessions.get(e);if(!t)throw new Error(`Debug session not found: ${e}`);return t}setupClientListeners(e,t){t.on("event",s=>{let n=this.sessions.get(e);if(n){switch(s.event){case "stopped":n.session.status="stopped",n.session.currentThreadId=s.body.threadId,n.session.stoppedReason=s.body.reason,n.session.lastActivity=Date.now();break;case "continued":n.session.status="running",n.session.lastActivity=Date.now();break;case "terminated":n.session.status="terminated",n.session.lastActivity=Date.now();break}this.emit("session:event",{sessionId:e,event:s.event,body:s.body});}});}async waitForStoppedOrTimeout(e,t,s=5e3){return new Promise(n=>{let i=setTimeout(()=>{e.client.off("event:stopped",o),e.client.off("event:terminated",o),n({status:"running",message:"Program is running"});},s),o=a=>{clearTimeout(i),e.client.off("event:stopped",o),e.client.off("event:terminated",o),a.reason?n({status:"stopped",stoppedReason:a.reason,location:a.source?{filePath:a.source.path,line:a.line,column:a.column||0}:void 0,message:`Program stopped: ${a.reason}`}):n({status:"terminated",message:"Program terminated"});};e.client.once("event:stopped",o),e.client.once("event:terminated",o);})}async performStep(e,t){let s=this.getSessionContext(e.sessionId);s.session.lastActivity=Date.now();try{let n=e.threadId||s.session.currentThreadId||1;switch(t){case "stepOver":await s.client.next({threadId:n});break;case "stepInto":await s.client.stepIn({threadId:n});break;case "stepOut":await s.client.stepOut({threadId:n});break}return new Promise((i,o)=>{let a=setTimeout(()=>{o(new Error("Step operation timeout"));},5e3);s.client.once("event:stopped",async l=>{clearTimeout(a);try{let u=(await s.client.stackTrace({threadId:n,startFrame:0,levels:1})).body.stackFrames[0];s.session.currentFrameId=u.id,i({status:"stopped",location:{filePath:u.source?.path||"unknown",line:u.line,method:u.name},message:`Stepped to ${u.name} at line ${u.line}`});}catch(c){o(c);}});})}catch(n){throw new Error(`Failed to perform step: ${n.message}`)}}cleanupInactiveSessions(){if(!this.config.sessionTimeout)return;let e=Date.now();for(let[t,s]of this.sessions.entries())e-s.session.lastActivity>this.config.sessionTimeout&&(console.log(`Cleaning up inactive session: ${t}`),this.stop({sessionId:t}).catch(i=>{console.error(`Failed to stop inactive session ${t}:`,i);}));}};var yd=fileURLToPath(import.meta.url),bd=X.dirname(yd);async function wd(){let r=process,e=[...r.resourcesPath?[X.join(r.resourcesPath,"java-debug","com.microsoft.java.debug.plugin.jar")]:[],X.join(process.cwd(),"resources","java-debug","com.microsoft.java.debug.plugin.jar"),X.join(bd,"..","..","..","resources","java-debug","com.microsoft.java.debug.plugin.jar")];for(let t of e)try{return await Z.access(t),console.log(`\u2713 \u627E\u5230\u5185\u7F6E Java Debug JAR: ${t}`),t}catch{}return null}async function Xa(r){if(r)try{return await Z.access(r),console.log(`\u2713 \u4F7F\u7528\u914D\u7F6E\u7684 Java Debug JAR: ${r}`),r}catch{console.warn(`\u26A0\uFE0F \u914D\u7F6E\u7684 JAR \u8DEF\u5F84\u65E0\u6548: ${r}`);}let e=await wd();if(e)return e;throw new Error(`Java Debug JAR \u672A\u627E\u5230\uFF01
|
|
462
462
|
\u8BF7\u6267\u884C\u4EE5\u4E0B\u6B65\u9AA4\u4E4B\u4E00\uFF1A
|
|
463
463
|
1. \u8FD0\u884C npm run setup-java-debug \u81EA\u52A8\u4E0B\u8F7D
|
|
464
464
|
2. \u5728\u914D\u7F6E\u4E2D\u6307\u5B9A JAR \u8DEF\u5F84
|
|
465
|
-
3. \u624B\u52A8\u4E0B\u8F7D\u5E76\u7F16\u8BD1\uFF1Ahttps://github.com/microsoft/java-debug`)}var
|
|
465
|
+
3. \u624B\u52A8\u4E0B\u8F7D\u5E76\u7F16\u8BD1\uFF1Ahttps://github.com/microsoft/java-debug`)}var Xi=null;function at(){if(!Xi)throw new Error("Java Debug Session Manager not initialized. Call createJavaDebugTools() first.");return Xi}async function Zi(r){let e=await Xa(r);Xi=new mr({javaDebugJarPath:e,defaultTimeout:3e4,maxSessions:5,sessionTimeout:1800*1e3});let t=[_d,Sd,kd,vd,Td,xd,Cd,Rd,Ed,Id,Md],s=["debug"];return t.map(n=>({...n,capabilities:n.capabilities?Array.from(new Set([...n.capabilities,...s])):s}))}var _d={name:"java_debug_launch",description:`Launch a Java application in debug mode.
|
|
466
466
|
|
|
467
467
|
Use this tool when you need to start debugging a Java program from the beginning.
|
|
468
468
|
|
|
@@ -471,7 +471,7 @@ Examples:
|
|
|
471
471
|
- Debug a standalone Java program
|
|
472
472
|
- Debug with specific JVM arguments or classpath
|
|
473
473
|
|
|
474
|
-
After launching, you'll receive a sessionId that you must use for all subsequent debug operations.`,parameters:{type:"object",properties:{mainClass:{type:"string",description:'The fully qualified main class name (e.g., "com.example.Main", "org.springframework.boot.SpringApplication")'},projectPath:{type:"string",description:"The absolute path to the Java project root directory"},classpath:{type:"string",description:"Optional classpath for the application (JAR files, directories)"},args:{type:"array",items:{type:"string"},description:'Optional program arguments (e.g., ["--port", "8080", "--debug"])'},vmArgs:{type:"array",items:{type:"string"},description:'Optional JVM arguments (e.g., ["-Xmx512m", "-Dspring.profiles.active=dev"])'},stopOnEntry:{type:"boolean",description:"Stop at the entry point (main method). Default: false"},cwd:{type:"string",description:"Working directory for the application. Default: projectPath"}},required:["mainClass","projectPath"]},async function(r){try{let t=await at().launch(r);return JSON.stringify({success:!0,sessionId:t.sessionId,status:t.status,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
474
|
+
After launching, you'll receive a sessionId that you must use for all subsequent debug operations.`,parameters:{type:"object",properties:{mainClass:{type:"string",description:'The fully qualified main class name (e.g., "com.example.Main", "org.springframework.boot.SpringApplication")'},projectPath:{type:"string",description:"The absolute path to the Java project root directory"},classpath:{type:"string",description:"Optional classpath for the application (JAR files, directories)"},args:{type:"array",items:{type:"string"},description:'Optional program arguments (e.g., ["--port", "8080", "--debug"])'},vmArgs:{type:"array",items:{type:"string"},description:'Optional JVM arguments (e.g., ["-Xmx512m", "-Dspring.profiles.active=dev"])'},stopOnEntry:{type:"boolean",description:"Stop at the entry point (main method). Default: false"},cwd:{type:"string",description:"Working directory for the application. Default: projectPath"}},required:["mainClass","projectPath"]},async function(r){try{let t=await at().launch(r);return JSON.stringify({success:!0,sessionId:t.sessionId,status:t.status,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Sd={name:"java_debug_attach",description:`Attach to a running Java process for debugging.
|
|
475
475
|
|
|
476
476
|
Use this tool when the Java application is already running with JDWP enabled.
|
|
477
477
|
|
|
@@ -483,7 +483,7 @@ Common JDWP ports:
|
|
|
483
483
|
- 8000
|
|
484
484
|
- Custom port specified by the application
|
|
485
485
|
|
|
486
|
-
After attaching, you'll receive a sessionId for all subsequent debug operations.`,parameters:{type:"object",properties:{port:{type:"number",description:"The JDWP port number (usually 5005 or 8000)"},hostName:{type:"string",description:'The hostname to connect to. Default: "localhost"'},timeout:{type:"number",description:"Connection timeout in milliseconds. Default: 5000"}},required:["port"]},async function(r){try{let t=await at().attach(r);return JSON.stringify({success:!0,sessionId:t.sessionId,status:t.status,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
486
|
+
After attaching, you'll receive a sessionId for all subsequent debug operations.`,parameters:{type:"object",properties:{port:{type:"number",description:"The JDWP port number (usually 5005 or 8000)"},hostName:{type:"string",description:'The hostname to connect to. Default: "localhost"'},timeout:{type:"number",description:"Connection timeout in milliseconds. Default: 5000"}},required:["port"]},async function(r){try{let t=await at().attach(r);return JSON.stringify({success:!0,sessionId:t.sessionId,status:t.status,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},kd={name:"java_debug_set_breakpoint",description:`Set a breakpoint at a specific line in a Java source file.
|
|
487
487
|
|
|
488
488
|
The program will pause when execution reaches this line, allowing you to inspect variables and stack trace.
|
|
489
489
|
|
|
@@ -495,7 +495,7 @@ You can set:
|
|
|
495
495
|
|
|
496
496
|
Examples:
|
|
497
497
|
- Set breakpoint at line 25: {"sessionId": "...", "filePath": "/path/Main.java", "line": 25}
|
|
498
|
-
- Conditional breakpoint: {"sessionId": "...", "filePath": "/path/Main.java", "line": 30, "condition": "count > 10"}`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID from java_debug_launch or java_debug_attach"},filePath:{type:"string",description:"The absolute path to the Java source file"},line:{type:"number",description:"The line number where to set the breakpoint (1-indexed)"},condition:{type:"string",description:'Optional condition expression (e.g., "count > 10", "user != null"). Breakpoint only triggers when condition is true.'},hitCondition:{type:"string",description:'Optional hit condition (e.g., ">5", "==3"). Breakpoint triggers after this many hits.'},logMessage:{type:"string",description:"Optional log message (logpoint). The breakpoint will log this message instead of pausing. Use {variable} for interpolation."}},required:["sessionId","filePath","line"]},async function(r){try{let t=await at().setBreakpoint(r);return JSON.stringify({success:!0,breakpointId:t.breakpointId,verified:t.verified,line:t.line,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
498
|
+
- Conditional breakpoint: {"sessionId": "...", "filePath": "/path/Main.java", "line": 30, "condition": "count > 10"}`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID from java_debug_launch or java_debug_attach"},filePath:{type:"string",description:"The absolute path to the Java source file"},line:{type:"number",description:"The line number where to set the breakpoint (1-indexed)"},condition:{type:"string",description:'Optional condition expression (e.g., "count > 10", "user != null"). Breakpoint only triggers when condition is true.'},hitCondition:{type:"string",description:'Optional hit condition (e.g., ">5", "==3"). Breakpoint triggers after this many hits.'},logMessage:{type:"string",description:"Optional log message (logpoint). The breakpoint will log this message instead of pausing. Use {variable} for interpolation."}},required:["sessionId","filePath","line"]},async function(r){try{let t=await at().setBreakpoint(r);return JSON.stringify({success:!0,breakpointId:t.breakpointId,verified:t.verified,line:t.line,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},vd={name:"java_debug_continue",description:`Continue program execution until the next breakpoint or program termination.
|
|
499
499
|
|
|
500
500
|
Use this tool to:
|
|
501
501
|
- Resume execution after hitting a breakpoint
|
|
@@ -510,7 +510,7 @@ The tool will return:
|
|
|
510
510
|
When the program stops at a breakpoint, you can then use:
|
|
511
511
|
- java_debug_get_variables to inspect variables
|
|
512
512
|
- java_debug_get_stack_trace to see the call stack
|
|
513
|
-
- java_debug_evaluate to test expressions`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().continue(r);return JSON.stringify({success:!0,status:t.status,stoppedReason:t.stoppedReason,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
513
|
+
- java_debug_evaluate to test expressions`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().continue(r);return JSON.stringify({success:!0,status:t.status,stoppedReason:t.stoppedReason,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Td={name:"java_debug_step_over",description:`Execute the current line and move to the next line (step over).
|
|
514
514
|
|
|
515
515
|
If the current line contains a method call, the entire method executes without stopping inside it.
|
|
516
516
|
|
|
@@ -522,7 +522,7 @@ Use this when:
|
|
|
522
522
|
Example workflow:
|
|
523
523
|
1. Set breakpoint at line 20
|
|
524
524
|
2. Continue execution (stops at line 20)
|
|
525
|
-
3. Step over to line 21, 22, 23... until you find the issue`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().stepOver(r);return JSON.stringify({success:!0,status:t.status,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
525
|
+
3. Step over to line 21, 22, 23... until you find the issue`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().stepOver(r);return JSON.stringify({success:!0,status:t.status,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},xd={name:"java_debug_step_into",description:`Execute the current line and step into method calls.
|
|
526
526
|
|
|
527
527
|
If the current line contains a method call, execution stops at the first line inside that method.
|
|
528
528
|
|
|
@@ -534,7 +534,7 @@ Use this when:
|
|
|
534
534
|
Example:
|
|
535
535
|
Line 20: result = processData(input);
|
|
536
536
|
|
|
537
|
-
After step into, you'll be inside processData() at its first line.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().stepInto(r);return JSON.stringify({success:!0,status:t.status,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
537
|
+
After step into, you'll be inside processData() at its first line.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().stepInto(r);return JSON.stringify({success:!0,status:t.status,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Cd={name:"java_debug_step_out",description:`Execute until the current method returns (step out).
|
|
538
538
|
|
|
539
539
|
Execution continues until the current method completes and returns to its caller.
|
|
540
540
|
|
|
@@ -545,7 +545,7 @@ Use this when:
|
|
|
545
545
|
|
|
546
546
|
Example:
|
|
547
547
|
You're at line 15 inside processData() method.
|
|
548
|
-
After step out, you'll be at the line that called processData().`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().stepOut(r);return JSON.stringify({success:!0,status:t.status,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
548
|
+
After step out, you'll be at the line that called processData().`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().stepOut(r);return JSON.stringify({success:!0,status:t.status,location:t.location,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Rd={name:"java_debug_get_variables",description:`Get the values of variables in the current scope.
|
|
549
549
|
|
|
550
550
|
Use this tool when the program is paused (at a breakpoint or after stepping) to inspect:
|
|
551
551
|
- Local variables
|
|
@@ -564,7 +564,7 @@ Example use case:
|
|
|
564
564
|
1. Program stops at breakpoint line 25
|
|
565
565
|
2. Call java_debug_get_variables to see all variable values
|
|
566
566
|
3. Analyze which variables have unexpected values
|
|
567
|
-
4. Identify the bug!`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},frameId:{type:"number",description:"Optional stack frame ID. Default: current frame (0 = topmost frame)"},filter:{type:"string",enum:["local","arguments","all"],description:'Filter variables by type. Default: "all"'}},required:["sessionId"]},async function(r){try{let t=await at().getVariables(r);return JSON.stringify({success:!0,variables:t.variables,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
567
|
+
4. Identify the bug!`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},frameId:{type:"number",description:"Optional stack frame ID. Default: current frame (0 = topmost frame)"},filter:{type:"string",enum:["local","arguments","all"],description:'Filter variables by type. Default: "all"'}},required:["sessionId"]},async function(r){try{let t=await at().getVariables(r);return JSON.stringify({success:!0,variables:t.variables,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Ed={name:"java_debug_get_stack_trace",description:`Get the current call stack (stack trace).
|
|
568
568
|
|
|
569
569
|
The stack trace shows the sequence of method calls that led to the current point of execution.
|
|
570
570
|
|
|
@@ -583,7 +583,7 @@ Frame 2: The method that called Frame 1
|
|
|
583
583
|
Example output:
|
|
584
584
|
Frame 0: processUser() at UserService.java:42
|
|
585
585
|
Frame 1: handleRequest() at RequestHandler.java:28
|
|
586
|
-
Frame 2: main() at Main.java:15`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().getStackTrace(r);return JSON.stringify({success:!0,stackFrames:t.stackFrames,totalFrames:t.totalFrames,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
586
|
+
Frame 2: main() at Main.java:15`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},threadId:{type:"number",description:"Optional thread ID. Default: main thread"}},required:["sessionId"]},async function(r){try{let t=await at().getStackTrace(r);return JSON.stringify({success:!0,stackFrames:t.stackFrames,totalFrames:t.totalFrames,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Id={name:"java_debug_evaluate",description:`Evaluate a Java expression in the current debug context.
|
|
587
587
|
|
|
588
588
|
This is an extremely powerful tool that lets you:
|
|
589
589
|
- Check variable values with custom logic
|
|
@@ -606,35 +606,35 @@ Example debugging workflow:
|
|
|
606
606
|
2. Evaluate: "user != null" -> false
|
|
607
607
|
3. Look at stack trace to see where user was initialized
|
|
608
608
|
4. Evaluate: "getUserFromCache(userId)" to test if cache has the user
|
|
609
|
-
5. Identify that cache lookup is failing`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},expression:{type:"string",description:'The Java expression to evaluate (e.g., "user.getName()", "count > 10", "items.size()")'},frameId:{type:"number",description:"Optional stack frame ID. Default: current frame"},context:{type:"string",enum:["watch","repl","hover"],description:'Evaluation context. Default: "repl"'}},required:["sessionId","expression"]},async function(r){try{let t=await at().evaluate(r);return JSON.stringify({success:!0,result:t.result,type:t.type,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},
|
|
609
|
+
5. Identify that cache lookup is failing`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},expression:{type:"string",description:'The Java expression to evaluate (e.g., "user.getName()", "count > 10", "items.size()")'},frameId:{type:"number",description:"Optional stack frame ID. Default: current frame"},context:{type:"string",enum:["watch","repl","hover"],description:'Evaluation context. Default: "repl"'}},required:["sessionId","expression"]},async function(r){try{let t=await at().evaluate(r);return JSON.stringify({success:!0,result:t.result,type:t.type,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}},Md={name:"java_debug_stop",description:`Stop the debug session and optionally terminate the debugged program.
|
|
610
610
|
|
|
611
611
|
Always call this tool when you're done debugging to clean up resources.
|
|
612
612
|
|
|
613
|
-
By default, this will terminate the debugged program. Set terminateDebuggee=false to disconnect without killing the program.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},terminateDebuggee:{type:"boolean",description:"Whether to terminate the debugged program. Default: true"}},required:["sessionId"]},async function(r){try{let t=await at().stop(r);return JSON.stringify({success:!0,status:t.status,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}};var
|
|
613
|
+
By default, this will terminate the debugged program. Set terminateDebuggee=false to disconnect without killing the program.`,parameters:{type:"object",properties:{sessionId:{type:"string",description:"The debug session ID"},terminateDebuggee:{type:"boolean",description:"Whether to terminate the debugged program. Default: true"}},required:["sessionId"]},async function(r){try{let t=await at().stop(r);return JSON.stringify({success:!0,status:t.status,message:t.message},null,2)}catch(e){return JSON.stringify({success:false,error:e.message},null,2)}}};var Za={enabled:false,autoPrompt:true,languages:["typescript","javascript","python","java","go","rust"],include:["**/*.ts","**/*.tsx","**/*.js","**/*.jsx","**/*.py","**/*.java","**/*.go","**/*.rs"],exclude:["**/node_modules/**","**/.git/**","**/dist/**","**/build/**","**/__pycache__/**","**/target/**","**/vendor/**"],cacheDir:".neox/index",maxFileSize:5},sn=200,hr=10,nn=4e3,hs=700;function Qa(r){return createHash("md5").update(r).digest("hex")}async function el(r){try{return await Z.access(r),!0}catch{return false}}async function rn(r){try{await Z.mkdir(r,{recursive:!0});}catch(e){if(e.code!=="EEXIST")throw e}}async function Qi(r,e,t){let n=(await Z.readFile(r,"utf-8")).split(`
|
|
614
614
|
`),i=n.length,o=Math.max(0,e-1),a=Math.min(n.length,t);return {lines:n.slice(o,a),totalLines:i}}function $e(r,e){return r.map((t,s)=>`${String(e+s).padStart(6)} \u2502 ${t}`).join(`
|
|
615
|
-
`)}function ys(r,e){let s=
|
|
616
|
-
`),d=p.length;if(d<=i){let g=Math.min(d,l),y=p.slice(0,g);return {success:true,path:t,totalLines:d,startLine:1,endLine:g,content:$e(y,1),truncated:g<d,strategy:"full"}}let m=Math.min(o,d),h=p.slice(0,m);return {success:true,path:t,totalLines:d,startLine:1,endLine:m,content:$e(h,1),truncated:m<d,strategy:"chunk"}}return this.readChunk(e,t,1,o)}switch(s.type){case "line":return this.readByLine(e,t,s.start,s.end,o);case "pattern":return this.readByPattern(e,t,s.regex,{matchIndex:s.matchIndex||1,context:s.context||a,chunkSize:o});case "symbol":return this.readBySymbol(e,t,s.name,{kind:s.kind,fuzzy:s.fuzzy,chunkSize:o,useIndex:c});case "function":return this.readBySymbol(e,t,s.name,{kind:"function",className:s.className,chunkSize:o,useIndex:c});case "class":return this.readBySymbol(e,t,s.name,{kind:"class",chunkSize:o,useIndex:c});case "range":return this.readByRange(e,t,s.startPattern,s.endPattern,o);default:return this.readChunk(e,t,1,o)}}async readByLine(e,t,s,n,i){let o=n||s+i-1,{lines:a,totalLines:l}=await
|
|
615
|
+
`)}function ys(r,e){let s=X.relative(e,r).split(X.sep),n=s.findIndex(i=>["src","lib","app","core","packages","modules"].includes(i));return n>=0&&n+1<s.length?s[n+1]:s[0]||"root"}function eo(r){let e=X.extname(r).toLowerCase();return {".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".mjs":"javascript",".cjs":"javascript",".py":"python",".java":"java",".go":"go",".rs":"rust",".c":"c",".cpp":"cpp",".cc":"cpp",".h":"c",".hpp":"cpp",".cs":"csharp",".rb":"ruby",".php":"php",".swift":"swift",".kt":"kotlin",".scala":"scala",".vue":"vue",".svelte":"svelte"}[e]||null}function Pt(r,e,t="{([",s="})]"){let n=[],i=false;for(let o=e;o<r.length;o++){let a=r[o];for(let l of a){let c=t.indexOf(l),u=s.indexOf(l);c!==-1?(n.push(s[c]),i=true):u!==-1&&n.length>0&&n[n.length-1]===l&&n.pop();}if(i&&n.length===0)return o+1}return Math.min(e+500,r.length)}function tl(r,e,t=["^\\s*(export\\s+)?(async\\s+)?function\\s+","^\\s*(export\\s+)?class\\s+","^\\s*(export\\s+)?(const|let|var)\\s+\\w+\\s*=\\s*(async\\s+)?\\(","^\\s*(export\\s+)?(const|let|var)\\s+\\w+\\s*=\\s*(async\\s+)?function","^\\s*(public|private|protected|static|async)*\\s*\\w+\\s*\\(","^\\s*def\\s+","^\\s*class\\s+","^\\s*func\\s+","^\\s*fn\\s+"]){let s=t.map(n=>new RegExp(n));for(let n=e;n>=0;n--){let i=r[n];for(let o of s)if(o.test(i))return n;if(n<e&&i.trim()===""){let o=r.slice(0,n).reverse().findIndex(a=>a.trim()!=="");if(o>=0){let a=r[n-1-o];if(!a.trim().startsWith("@")&&!a.trim().startsWith("#")&&!a.trim().startsWith("//")&&!a.trim().startsWith("/*"))break}}}return Math.max(0,e-5)}function to(r,e){let t=r.length>e.length?r:e,s=r.length>e.length?e:r;if(t.length===0)return 1;let n=Pd(t,s);return (t.length-n)/t.length}function Pd(r,e){let t=r.length,s=e.length,n=Array(t+1).fill(null).map(()=>Array(s+1).fill(0));for(let i=0;i<=t;i++)n[i][0]=i;for(let i=0;i<=s;i++)n[0][i]=i;for(let i=1;i<=t;i++)for(let o=1;o<=s;o++)r[i-1]===e[o-1]?n[i][o]=n[i-1][o-1]:n[i][o]=Math.min(n[i-1][o]+1,n[i][o-1]+1,n[i-1][o-1]+1);return n[t][s]}function bs(r){return r.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g,"")}var gr=class{workspacePath;indexManager=null;constructor(e){this.workspacePath=e;}setIndexManager(e){this.indexManager=e;}async read(e){let{path:t,locator:s,mode:n="smart",autoFullThreshold:i,chunkSize:o=sn,expandContext:a=hr,maxLines:l=nn,useIndex:c=true}=e;try{let u=this.resolvePath(t);if((await Z.stat(u)).isDirectory())return this.errorResult(t,"\u8FD9\u662F\u4E00\u4E2A\u76EE\u5F55\uFF0C\u4E0D\u662F\u6587\u4EF6");switch(n){case "full":return this.readFull(u,t,l);case "chunk":return !s||s.type!=="line"?this.readChunk(u,t,1,o):this.readChunk(u,t,s.start,s.end?s.end-s.start+1:o);default:return this.smartRead(u,t,s,{autoFullThreshold:i,chunkSize:o,expandContext:a,maxLines:l,useIndex:c})}}catch(u){return u.code==="ENOENT"?this.errorResult(t,"\u6587\u4EF6\u4E0D\u5B58\u5728"):this.errorResult(t,u.message)}}async smartRead(e,t,s,n){let{autoFullThreshold:i,chunkSize:o,expandContext:a,maxLines:l,useIndex:c}=n;if(!s){if(typeof i=="number"&&i>0){let u=await Z.readFile(e,"utf-8"),p=bs(u).split(`
|
|
616
|
+
`),d=p.length;if(d<=i){let g=Math.min(d,l),y=p.slice(0,g);return {success:true,path:t,totalLines:d,startLine:1,endLine:g,content:$e(y,1),truncated:g<d,strategy:"full"}}let m=Math.min(o,d),h=p.slice(0,m);return {success:true,path:t,totalLines:d,startLine:1,endLine:m,content:$e(h,1),truncated:m<d,strategy:"chunk"}}return this.readChunk(e,t,1,o)}switch(s.type){case "line":return this.readByLine(e,t,s.start,s.end,o);case "pattern":return this.readByPattern(e,t,s.regex,{matchIndex:s.matchIndex||1,context:s.context||a,chunkSize:o});case "symbol":return this.readBySymbol(e,t,s.name,{kind:s.kind,fuzzy:s.fuzzy,chunkSize:o,useIndex:c});case "function":return this.readBySymbol(e,t,s.name,{kind:"function",className:s.className,chunkSize:o,useIndex:c});case "class":return this.readBySymbol(e,t,s.name,{kind:"class",chunkSize:o,useIndex:c});case "range":return this.readByRange(e,t,s.startPattern,s.endPattern,o);default:return this.readChunk(e,t,1,o)}}async readByLine(e,t,s,n,i){let o=n||s+i-1,{lines:a,totalLines:l}=await Qi(e,s,o);return {success:true,path:t,totalLines:l,startLine:s,endLine:Math.min(o,l),content:$e(a,s),truncated:o<l,strategy:"chunk"}}async readByPattern(e,t,s,n){let{matchIndex:i,context:o,chunkSize:a}=n,c=(await Z.readFile(e,"utf-8")).split(`
|
|
617
617
|
`),u=c.length,p;try{p=new RegExp(s,"gi");}catch(b){return this.errorResult(t,`\u65E0\u6548\u7684\u6B63\u5219\u8868\u8FBE\u5F0F: ${b.message}`)}let d=[];if(c.forEach((b,w)=>{p.test(b)&&d.push(w+1),p.lastIndex=0;}),d.length===0)return {success:true,path:t,totalLines:u,startLine:1,endLine:Math.min(a,u),content:`\u672A\u627E\u5230\u5339\u914D: "${s}"
|
|
618
618
|
|
|
619
|
-
`+$e(c.slice(0,Math.min(50,u)),1),truncated:false,strategy:"grep",metadata:{module:ys(e,this.workspacePath)}};let m=d[Math.min(i-1,d.length-1)],h=Math.max(1,m-o),g=Math.min(u,m+a-o),y=c.slice(h-1,g);return {success:true,path:t,totalLines:u,startLine:h,endLine:g,content:$e(y,h),truncated:g<u,strategy:"grep",metadata:{matchedLine:m,module:ys(e,this.workspacePath)}}}async readBySymbol(e,t,s,n){let{kind:i,className:o,fuzzy:a,chunkSize:l,useIndex:c}=n;if(c&&this.indexManager){let p=await this.readBySymbolFromIndex(e,t,s,i,o);if(p)return p}let u=this.buildSymbolPattern(s,i,o);return this.readSymbolBlock(e,t,u,s,l)}async readBySymbolFromIndex(e,t,s,n,i){if(!this.indexManager)return null;try{let o=await this.indexManager.getFileIndex(e);if(!o)return null;let a;if(i){let u=o.symbols.find(p=>p.kind==="class"&&p.name===i);u?.children&&(a=u.children.find(p=>p.name===s));}else a=o.symbols.find(u=>n&&u.kind!==n?!1:u.name===s);if(!a)return null;let{lines:l,totalLines:c}=await
|
|
619
|
+
`+$e(c.slice(0,Math.min(50,u)),1),truncated:false,strategy:"grep",metadata:{module:ys(e,this.workspacePath)}};let m=d[Math.min(i-1,d.length-1)],h=Math.max(1,m-o),g=Math.min(u,m+a-o),y=c.slice(h-1,g);return {success:true,path:t,totalLines:u,startLine:h,endLine:g,content:$e(y,h),truncated:g<u,strategy:"grep",metadata:{matchedLine:m,module:ys(e,this.workspacePath)}}}async readBySymbol(e,t,s,n){let{kind:i,className:o,fuzzy:a,chunkSize:l,useIndex:c}=n;if(c&&this.indexManager){let p=await this.readBySymbolFromIndex(e,t,s,i,o);if(p)return p}let u=this.buildSymbolPattern(s,i,o);return this.readSymbolBlock(e,t,u,s,l)}async readBySymbolFromIndex(e,t,s,n,i){if(!this.indexManager)return null;try{let o=await this.indexManager.getFileIndex(e);if(!o)return null;let a;if(i){let u=o.symbols.find(p=>p.kind==="class"&&p.name===i);u?.children&&(a=u.children.find(p=>p.name===s));}else a=o.symbols.find(u=>n&&u.kind!==n?!1:u.name===s);if(!a)return null;let{lines:l,totalLines:c}=await Qi(e,a.startLine,a.endLine);return {success:!0,path:t,totalLines:c,startLine:a.startLine,endLine:a.endLine,content:$e(l,a.startLine),truncated:!1,strategy:"index",metadata:{symbol:a,module:ys(e,this.workspacePath)}}}catch{return null}}async readSymbolBlock(e,t,s,n,i){let a=(await Z.readFile(e,"utf-8")).split(`
|
|
620
620
|
`),l=a.length,c;try{c=new RegExp(s,"i");}catch{c=new RegExp(n.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),"i");}let u=-1;for(let g=0;g<a.length;g++)if(c.test(a[g])){u=g;break}if(u===-1)return {success:true,path:t,totalLines:l,startLine:1,endLine:Math.min(i,l),content:`\u672A\u627E\u5230\u7B26\u53F7: "${n}"
|
|
621
621
|
|
|
622
|
-
`+$e(a.slice(0,Math.min(50,l)),1),truncated:false,strategy:"grep"};let p=
|
|
622
|
+
`+$e(a.slice(0,Math.min(50,l)),1),truncated:false,strategy:"grep"};let p=tl(a,u),d=Pt(a,p),m=Math.min(d,p+i),h=a.slice(p,m);return {success:true,path:t,totalLines:l,startLine:p+1,endLine:m,content:$e(h,p+1),truncated:m<d,strategy:"grep",metadata:{matchedLine:u+1,module:ys(e,this.workspacePath)}}}async readByRange(e,t,s,n,i){let a=(await Z.readFile(e,"utf-8")).split(`
|
|
623
623
|
`),l=a.length,c,u;try{c=new RegExp(s,"i"),u=new RegExp(n,"i");}catch(g){return this.errorResult(t,`\u65E0\u6548\u7684\u6B63\u5219\u8868\u8FBE\u5F0F: ${g.message}`)}let p=-1,d=-1;for(let g=0;g<a.length;g++)if(p===-1&&c.test(a[g])&&(p=g),p!==-1&&u.test(a[g])){d=g;break}if(p===-1)return {success:true,path:t,totalLines:l,startLine:1,endLine:Math.min(i,l),content:`\u672A\u627E\u5230\u8D77\u59CB\u6A21\u5F0F: "${s}"
|
|
624
624
|
|
|
625
|
-
`+$e(a.slice(0,Math.min(50,l)),1),truncated:false,strategy:"grep"};d===-1&&(d=Math.min(p+i-1,l-1));let m=Math.min(d+1,p+i),h=a.slice(p,m);return {success:true,path:t,totalLines:l,startLine:p+1,endLine:m,content:$e(h,p+1),truncated:m<d+1,strategy:"grep",metadata:{module:ys(e,this.workspacePath)}}}async readChunk(e,t,s,n){let i=await
|
|
626
|
-
`),a=o.length,l=Math.max(1,s),c=Math.min(l+n-1,a),u=o.slice(l-1,c);return {success:true,path:t,totalLines:a,startLine:l,endLine:c,content:$e(u,l),truncated:c<a,strategy:"chunk"}}async readFull(e,t,s){let n=await
|
|
627
|
-
`),o=i.length,a=Math.min(o,s),l=i.slice(0,a);return {success:true,path:t,totalLines:o,startLine:1,endLine:a,content:$e(l,1),truncated:a<o,strategy:"full"}}buildSymbolPattern(e,t,s){let n=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),i={function:`(function|async\\s+function|const|let|var)\\s+${n}\\s*[=(<]`,class:`class\\s+${n}(\\s+extends|\\s+implements|\\s*\\{|\\s*$)`,interface:`interface\\s+${n}(\\s+extends|\\s*\\{|\\s*$)`,method:s?`(${n}|${s}\\.${n})\\s*\\(`:`${n}\\s*\\(`,variable:`(const|let|var)\\s+${n}\\s*[=:]`,type:`type\\s+${n}\\s*[=<]`,enum:`enum\\s+${n}\\s*\\{`,constant:`(const|final|static\\s+final)\\s+[A-Z_]+\\s*${n}`};return t&&i[t]?i[t]:`(function|class|interface|type|enum|const|let|var|def|fn|func)\\s+${n}|${n}\\s*(=|\\()`}resolvePath(e){return Y.isAbsolute(e)?e:Y.resolve(this.workspacePath,e)}errorResult(e,t){return {success:false,path:e,totalLines:0,startLine:0,endLine:0,content:"",truncated:false,strategy:"chunk",error:t}}};function Zi(r){return new hr(r)}var wl=Au(pl());var on=r=>{if(typeof r!="string")throw new TypeError("invalid pattern");if(r.length>65536)throw new TypeError("pattern is too long")};var Ld={"[:alnum:]":["\\p{L}\\p{Nl}\\p{Nd}",true],"[:alpha:]":["\\p{L}\\p{Nl}",true],"[:ascii:]":["\\x00-\\x7f",false],"[:blank:]":["\\p{Zs}\\t",true],"[:cntrl:]":["\\p{Cc}",true],"[:digit:]":["\\p{Nd}",true],"[:graph:]":["\\p{Z}\\p{C}",true,true],"[:lower:]":["\\p{Ll}",true],"[:print:]":["\\p{C}",true],"[:punct:]":["\\p{P}",true],"[:space:]":["\\p{Z}\\t\\r\\n\\v\\f",true],"[:upper:]":["\\p{Lu}",true],"[:word:]":["\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}",true],"[:xdigit:]":["A-Fa-f0-9",false]},an=r=>r.replace(/[[\]\\-]/g,"\\$&"),Dd=r=>r.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),dl=r=>r.join(""),ml=(r,e)=>{let t=e;if(r.charAt(t)!=="[")throw new Error("not in a brace expression");let s=[],n=[],i=t+1,o=false,a=false,l=false,c=false,u=t,p="";e:for(;i<r.length;){let g=r.charAt(i);if((g==="!"||g==="^")&&i===t+1){c=true,i++;continue}if(g==="]"&&o&&!l){u=i+1;break}if(o=true,g==="\\"&&!l){l=true,i++;continue}if(g==="["&&!l){for(let[y,[b,w,S]]of Object.entries(Ld))if(r.startsWith(y,i)){if(p)return ["$.",false,r.length-t,true];i+=y.length,S?n.push(b):s.push(b),a=a||w;continue e}}if(l=false,p){g>p?s.push(an(p)+"-"+an(g)):g===p&&s.push(an(g)),p="",i++;continue}if(r.startsWith("-]",i+1)){s.push(an(g+"-")),i+=2;continue}if(r.startsWith("-",i+1)){p=g,i+=2;continue}s.push(an(g)),i++;}if(u<i)return ["",false,0,false];if(!s.length&&!n.length)return ["$.",false,r.length-t,true];if(n.length===0&&s.length===1&&/^\\?.$/.test(s[0])&&!c){let g=s[0].length===2?s[0].slice(-1):s[0];return [Dd(g),false,u-t,false]}let d="["+(c?"^":"")+dl(s)+"]",m="["+(c?"":"^")+dl(n)+"]";return [s.length&&n.length?"("+d+"|"+m+")":s.length?d:m,a,u-t,true]};var lt=(r,{windowsPathsNoEscape:e=false}={})=>e?r.replace(/\[([^\/\\])\]/g,"$1"):r.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var $d=new Set(["!","?","+","*","@"]),hl=r=>$d.has(r),Nd="(?!(?:^|/)\\.\\.?(?:$|/))",fr="(?!\\.)",Fd=new Set(["[","."]),Ud=new Set(["..","."]),jd=new Set("().*{}+?[]^$\\!"),Gd=r=>r.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),to="[^/]",gl=to+"*?",fl=to+"+?",ws=class r{type;#e;#t;#i=false;#n=[];#o;#_;#c;#p=false;#a;#l;#r=false;constructor(e,t,s={}){this.type=e,e&&(this.#t=true),this.#o=t,this.#e=this.#o?this.#o.#e:this,this.#a=this.#e===this?s:this.#e.#a,this.#c=this.#e===this?[]:this.#e.#c,e==="!"&&!this.#e.#p&&this.#c.push(this),this.#_=this.#o?this.#o.#n.length:0;}get hasMagic(){if(this.#t!==void 0)return this.#t;for(let e of this.#n)if(typeof e!="string"&&(e.type||e.hasMagic))return this.#t=true;return this.#t}toString(){return this.#l!==void 0?this.#l:this.type?this.#l=this.type+"("+this.#n.map(e=>String(e)).join("|")+")":this.#l=this.#n.map(e=>String(e)).join("")}#f(){if(this!==this.#e)throw new Error("should only call on root");if(this.#p)return this;this.toString(),this.#p=true;let e;for(;e=this.#c.pop();){if(e.type!=="!")continue;let t=e,s=t.#o;for(;s;){for(let n=t.#_+1;!s.type&&n<s.#n.length;n++)for(let i of e.#n){if(typeof i=="string")throw new Error("string part in extglob AST??");i.copyIn(s.#n[n]);}t=s,s=t.#o;}}return this}push(...e){for(let t of e)if(t!==""){if(typeof t!="string"&&!(t instanceof r&&t.#o===this))throw new Error("invalid part: "+t);this.#n.push(t);}}toJSON(){let e=this.type===null?this.#n.slice().map(t=>typeof t=="string"?t:t.toJSON()):[this.type,...this.#n.map(t=>t.toJSON())];return this.isStart()&&!this.type&&e.unshift([]),this.isEnd()&&(this===this.#e||this.#e.#p&&this.#o?.type==="!")&&e.push({}),e}isStart(){if(this.#e===this)return true;if(!this.#o?.isStart())return false;if(this.#_===0)return true;let e=this.#o;for(let t=0;t<this.#_;t++){let s=e.#n[t];if(!(s instanceof r&&s.type==="!"))return false}return true}isEnd(){if(this.#e===this||this.#o?.type==="!")return true;if(!this.#o?.isEnd())return false;if(!this.type)return this.#o?.isEnd();let e=this.#o?this.#o.#n.length:0;return this.#_===e-1}copyIn(e){typeof e=="string"?this.push(e):this.push(e.clone(this));}clone(e){let t=new r(this.type,e);for(let s of this.#n)t.copyIn(s);return t}static#y(e,t,s,n){let i=false,o=false,a=-1,l=false;if(t.type===null){let m=s,h="";for(;m<e.length;){let g=e.charAt(m++);if(i||g==="\\"){i=!i,h+=g;continue}if(o){m===a+1?(g==="^"||g==="!")&&(l=true):g==="]"&&!(m===a+2&&l)&&(o=false),h+=g;continue}else if(g==="["){o=true,a=m,l=false,h+=g;continue}if(!n.noext&&hl(g)&&e.charAt(m)==="("){t.push(h),h="";let y=new r(g,t);m=r.#y(e,y,m,n),t.push(y);continue}h+=g;}return t.push(h),m}let c=s+1,u=new r(null,t),p=[],d="";for(;c<e.length;){let m=e.charAt(c++);if(i||m==="\\"){i=!i,d+=m;continue}if(o){c===a+1?(m==="^"||m==="!")&&(l=true):m==="]"&&!(c===a+2&&l)&&(o=false),d+=m;continue}else if(m==="["){o=true,a=c,l=false,d+=m;continue}if(hl(m)&&e.charAt(c)==="("){u.push(d),d="";let h=new r(m,u);u.push(h),c=r.#y(e,h,c,n);continue}if(m==="|"){u.push(d),d="",p.push(u),u=new r(null,t);continue}if(m===")")return d===""&&t.#n.length===0&&(t.#r=true),u.push(d),d="",t.push(...p,u),c;d+=m;}return t.type=null,t.#t=void 0,t.#n=[e.substring(s-1)],c}static fromGlob(e,t={}){let s=new r(null,void 0,t);return r.#y(e,s,0,t),s}toMMPattern(){if(this!==this.#e)return this.#e.toMMPattern();let e=this.toString(),[t,s,n,i]=this.toRegExpSource();if(!(n||this.#t||this.#a.nocase&&!this.#a.nocaseMagicOnly&&e.toUpperCase()!==e.toLowerCase()))return s;let a=(this.#a.nocase?"i":"")+(i?"u":"");return Object.assign(new RegExp(`^${t}$`,a),{_src:t,_glob:e})}get options(){return this.#a}toRegExpSource(e){let t=e??!!this.#a.dot;if(this.#e===this&&this.#f(),!this.type){let l=this.isStart()&&this.isEnd(),c=this.#n.map(m=>{let[h,g,y,b]=typeof m=="string"?r.#d(m,this.#t,l):m.toRegExpSource(e);return this.#t=this.#t||y,this.#i=this.#i||b,h}).join(""),u="";if(this.isStart()&&typeof this.#n[0]=="string"&&!(this.#n.length===1&&Ud.has(this.#n[0]))){let h=Fd,g=t&&h.has(c.charAt(0))||c.startsWith("\\.")&&h.has(c.charAt(2))||c.startsWith("\\.\\.")&&h.has(c.charAt(4)),y=!t&&!e&&h.has(c.charAt(0));u=g?Nd:y?fr:"";}let p="";return this.isEnd()&&this.#e.#p&&this.#o?.type==="!"&&(p="(?:$|\\/)"),[u+c+p,lt(c),this.#t=!!this.#t,this.#i]}let s=this.type==="*"||this.type==="+",n=this.type==="!"?"(?:(?!(?:":"(?:",i=this.#m(t);if(this.isStart()&&this.isEnd()&&!i&&this.type!=="!"){let l=this.toString();return this.#n=[l],this.type=null,this.#t=void 0,[l,lt(this.toString()),false,false]}let o=!s||e||t||!fr?"":this.#m(true);o===i&&(o=""),o&&(i=`(?:${i})(?:${o})*?`);let a="";if(this.type==="!"&&this.#r)a=(this.isStart()&&!t?fr:"")+fl;else {let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?fr:"")+gl+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&o?")":this.type==="*"&&o?")?":`)${this.type}`;a=n+i+l;}return [a,lt(i),this.#t=!!this.#t,this.#i]}#m(e){return this.#n.map(t=>{if(typeof t=="string")throw new Error("string type in extglob ast??");let[s,n,i,o]=t.toRegExpSource(e);return this.#i=this.#i||o,s}).filter(t=>!(this.isStart()&&this.isEnd())||!!t).join("|")}static#d(e,t,s=false){let n=false,i="",o=false;for(let a=0;a<e.length;a++){let l=e.charAt(a);if(n){n=false,i+=(jd.has(l)?"\\":"")+l;continue}if(l==="\\"){a===e.length-1?i+="\\\\":n=true;continue}if(l==="["){let[c,u,p,d]=ml(e,a);if(p){i+=c,o=o||u,a+=p-1,t=t||d;continue}}if(l==="*"){s&&e==="*"?i+=fl:i+=gl,t=true;continue}if(l==="?"){i+=to,t=true;continue}i+=Gd(l);}return [i,lt(e),!!t,o]}};var _s=(r,{windowsPathsNoEscape:e=false}={})=>e?r.replace(/[?*()[\]]/g,"[$&]"):r.replace(/[?*()[\]\\]/g,"\\$&");var Ge=(r,e,t={})=>(on(e),!t.nocomment&&e.charAt(0)==="#"?false:new Ye(e,t).match(r)),Bd=/^\*+([^+@!?\*\[\(]*)$/,Wd=r=>e=>!e.startsWith(".")&&e.endsWith(r),Hd=r=>e=>e.endsWith(r),zd=r=>(r=r.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(r)),qd=r=>(r=r.toLowerCase(),e=>e.toLowerCase().endsWith(r)),Jd=/^\*+\.\*+$/,Kd=r=>!r.startsWith(".")&&r.includes("."),Vd=r=>r!=="."&&r!==".."&&r.includes("."),Yd=/^\.\*+$/,Xd=r=>r!=="."&&r!==".."&&r.startsWith("."),Zd=/^\*+$/,Qd=r=>r.length!==0&&!r.startsWith("."),em=r=>r.length!==0&&r!=="."&&r!=="..",tm=/^\?+([^+@!?\*\[\(]*)?$/,sm=([r,e=""])=>{let t=_l([r]);return e?(e=e.toLowerCase(),s=>t(s)&&s.toLowerCase().endsWith(e)):t},nm=([r,e=""])=>{let t=Sl([r]);return e?(e=e.toLowerCase(),s=>t(s)&&s.toLowerCase().endsWith(e)):t},rm=([r,e=""])=>{let t=Sl([r]);return e?s=>t(s)&&s.endsWith(e):t},im=([r,e=""])=>{let t=_l([r]);return e?s=>t(s)&&s.endsWith(e):t},_l=([r])=>{let e=r.length;return t=>t.length===e&&!t.startsWith(".")},Sl=([r])=>{let e=r.length;return t=>t.length===e&&t!=="."&&t!==".."},kl=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",yl={win32:{sep:"\\"},posix:{sep:"/"}},om=kl==="win32"?yl.win32.sep:yl.posix.sep;Ge.sep=om;var Pe=Symbol("globstar **");Ge.GLOBSTAR=Pe;var am="[^/]",lm=am+"*?",cm="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",um="(?:(?!(?:\\/|^)\\.).)*?",pm=(r,e={})=>t=>Ge(t,r,e);Ge.filter=pm;var et=(r,e={})=>Object.assign({},r,e),dm=r=>{if(!r||typeof r!="object"||!Object.keys(r).length)return Ge;let e=Ge;return Object.assign((s,n,i={})=>e(s,n,et(r,i)),{Minimatch:class extends e.Minimatch{constructor(n,i={}){super(n,et(r,i));}static defaults(n){return e.defaults(et(r,n)).Minimatch}},AST:class extends e.AST{constructor(n,i,o={}){super(n,i,et(r,o));}static fromGlob(n,i={}){return e.AST.fromGlob(n,et(r,i))}},unescape:(s,n={})=>e.unescape(s,et(r,n)),escape:(s,n={})=>e.escape(s,et(r,n)),filter:(s,n={})=>e.filter(s,et(r,n)),defaults:s=>e.defaults(et(r,s)),makeRe:(s,n={})=>e.makeRe(s,et(r,n)),braceExpand:(s,n={})=>e.braceExpand(s,et(r,n)),match:(s,n,i={})=>e.match(s,n,et(r,i)),sep:e.sep,GLOBSTAR:Pe})};Ge.defaults=dm;var vl=(r,e={})=>(on(r),e.nobrace||!/\{(?:(?!\{).)*\}/.test(r)?[r]:(0, wl.default)(r));Ge.braceExpand=vl;var mm=(r,e={})=>new Ye(r,e).makeRe();Ge.makeRe=mm;var hm=(r,e,t={})=>{let s=new Ye(e,t);return r=r.filter(n=>s.match(n)),s.options.nonull&&!r.length&&r.push(e),r};Ge.match=hm;var bl=/[?*]|[+@!]\(.*?\)|\[|\]/,gm=r=>r.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Ye=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){on(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||kl,this.isWindows=this.platform==="win32",this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===false,this.windowsPathsNoEscape&&(this.pattern=this.pattern.replace(/\\/g,"/")),this.preserveMultipleSlashes=!!t.preserveMultipleSlashes,this.regexp=null,this.negate=false,this.nonegate=!!t.nonegate,this.comment=false,this.empty=false,this.partial=!!t.partial,this.nocase=!!this.options.nocase,this.windowsNoMagicRoot=t.windowsNoMagicRoot!==void 0?t.windowsNoMagicRoot:!!(this.isWindows&&this.nocase),this.globSet=[],this.globParts=[],this.set=[],this.make();}hasMagic(){if(this.options.magicalBraces&&this.set.length>1)return true;for(let e of this.set)for(let t of e)if(typeof t!="string")return true;return false}debug(...e){}make(){let e=this.pattern,t=this.options;if(!t.nocomment&&e.charAt(0)==="#"){this.comment=true;return}if(!e){this.empty=true;return}this.parseNegate(),this.globSet=[...new Set(this.braceExpand())],t.debug&&(this.debug=(...i)=>console.error(...i)),this.debug(this.pattern,this.globSet);let s=this.globSet.map(i=>this.slashSplit(i));this.globParts=this.preprocess(s),this.debug(this.pattern,this.globParts);let n=this.globParts.map((i,o,a)=>{if(this.isWindows&&this.windowsNoMagicRoot){let l=i[0]===""&&i[1]===""&&(i[2]==="?"||!bl.test(i[2]))&&!bl.test(i[3]),c=/^[a-z]:/i.test(i[0]);if(l)return [...i.slice(0,4),...i.slice(4).map(u=>this.parse(u))];if(c)return [i[0],...i.slice(1).map(u=>this.parse(u))]}return i.map(l=>this.parse(l))});if(this.debug(this.pattern,n),this.set=n.filter(i=>i.indexOf(false)===-1),this.isWindows)for(let i=0;i<this.set.length;i++){let o=this.set[i];o[0]===""&&o[1]===""&&this.globParts[i][2]==="?"&&typeof o[3]=="string"&&/^[a-z]:$/i.test(o[3])&&(o[2]="?");}this.debug(this.pattern,this.set);}preprocess(e){if(this.options.noglobstar)for(let s=0;s<e.length;s++)for(let n=0;n<e[s].length;n++)e[s][n]==="**"&&(e[s][n]="*");let{optimizationLevel:t=1}=this.options;return t>=2?(e=this.firstPhasePreProcess(e),e=this.secondPhasePreProcess(e)):t>=1?e=this.levelOneOptimize(e):e=this.adjascentGlobstarOptimize(e),e}adjascentGlobstarOptimize(e){return e.map(t=>{let s=-1;for(;(s=t.indexOf("**",s+1))!==-1;){let n=s;for(;t[n+1]==="**";)n++;n!==s&&t.splice(s,n-s);}return t})}levelOneOptimize(e){return e.map(t=>(t=t.reduce((s,n)=>{let i=s[s.length-1];return n==="**"&&i==="**"?s:n===".."&&i&&i!==".."&&i!=="."&&i!=="**"?(s.pop(),s):(s.push(n),s)},[]),t.length===0?[""]:t))}levelTwoFileOptimize(e){Array.isArray(e)||(e=this.slashSplit(e));let t=false;do{if(t=false,!this.preserveMultipleSlashes){for(let n=1;n<e.length-1;n++){let i=e[n];n===1&&i===""&&e[0]===""||(i==="."||i==="")&&(t=true,e.splice(n,1),n--);}e[0]==="."&&e.length===2&&(e[1]==="."||e[1]==="")&&(t=true,e.pop());}let s=0;for(;(s=e.indexOf("..",s+1))!==-1;){let n=e[s-1];n&&n!=="."&&n!==".."&&n!=="**"&&(t=true,e.splice(s-1,2),s-=2);}}while(t);return e.length===0?[""]:e}firstPhasePreProcess(e){let t=false;do{t=false;for(let s of e){let n=-1;for(;(n=s.indexOf("**",n+1))!==-1;){let o=n;for(;s[o+1]==="**";)o++;o>n&&s.splice(n+1,o-n);let a=s[n+1],l=s[n+2],c=s[n+3];if(a!==".."||!l||l==="."||l===".."||!c||c==="."||c==="..")continue;t=true,s.splice(n,1);let u=s.slice(0);u[n]="**",e.push(u),n--;}if(!this.preserveMultipleSlashes){for(let o=1;o<s.length-1;o++){let a=s[o];o===1&&a===""&&s[0]===""||(a==="."||a==="")&&(t=true,s.splice(o,1),o--);}s[0]==="."&&s.length===2&&(s[1]==="."||s[1]==="")&&(t=true,s.pop());}let i=0;for(;(i=s.indexOf("..",i+1))!==-1;){let o=s[i-1];if(o&&o!=="."&&o!==".."&&o!=="**"){t=true;let l=i===1&&s[i+1]==="**"?["."]:[];s.splice(i-1,2,...l),s.length===0&&s.push(""),i-=2;}}}}while(t);return e}secondPhasePreProcess(e){for(let t=0;t<e.length-1;t++)for(let s=t+1;s<e.length;s++){let n=this.partsMatch(e[t],e[s],!this.preserveMultipleSlashes);if(n){e[t]=[],e[s]=n;break}}return e.filter(t=>t.length)}partsMatch(e,t,s=false){let n=0,i=0,o=[],a="";for(;n<e.length&&i<t.length;)if(e[n]===t[i])o.push(a==="b"?t[i]:e[n]),n++,i++;else if(s&&e[n]==="**"&&t[i]===e[n+1])o.push(e[n]),n++;else if(s&&t[i]==="**"&&e[n]===t[i+1])o.push(t[i]),i++;else if(e[n]==="*"&&t[i]&&(this.options.dot||!t[i].startsWith("."))&&t[i]!=="**"){if(a==="b")return false;a="a",o.push(e[n]),n++,i++;}else if(t[i]==="*"&&e[n]&&(this.options.dot||!e[n].startsWith("."))&&e[n]!=="**"){if(a==="a")return false;a="b",o.push(t[i]),n++,i++;}else return false;return e.length===t.length&&o}parseNegate(){if(this.nonegate)return;let e=this.pattern,t=false,s=0;for(let n=0;n<e.length&&e.charAt(n)==="!";n++)t=!t,s++;s&&(this.pattern=e.slice(s)),this.negate=t;}matchOne(e,t,s=false){let n=this.options;if(this.isWindows){let g=typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0]),y=!g&&e[0]===""&&e[1]===""&&e[2]==="?"&&/^[a-z]:$/i.test(e[3]),b=typeof t[0]=="string"&&/^[a-z]:$/i.test(t[0]),w=!b&&t[0]===""&&t[1]===""&&t[2]==="?"&&typeof t[3]=="string"&&/^[a-z]:$/i.test(t[3]),S=y?3:g?0:void 0,x=w?3:b?0:void 0;if(typeof S=="number"&&typeof x=="number"){let[R,L]=[e[S],t[x]];R.toLowerCase()===L.toLowerCase()&&(t[x]=R,x>S?t=t.slice(x):S>x&&(e=e.slice(S)));}}let{optimizationLevel:i=1}=this.options;i>=2&&(e=this.levelTwoFileOptimize(e)),this.debug("matchOne",this,{file:e,pattern:t}),this.debug("matchOne",e.length,t.length);for(var o=0,a=0,l=e.length,c=t.length;o<l&&a<c;o++,a++){this.debug("matchOne loop");var u=t[a],p=e[o];if(this.debug(t,u,p),u===false)return false;if(u===Pe){this.debug("GLOBSTAR",[t,u,p]);var d=o,m=a+1;if(m===c){for(this.debug("** at the end");o<l;o++)if(e[o]==="."||e[o]===".."||!n.dot&&e[o].charAt(0)===".")return false;return true}for(;d<l;){var h=e[d];if(this.debug(`
|
|
625
|
+
`+$e(a.slice(0,Math.min(50,l)),1),truncated:false,strategy:"grep"};d===-1&&(d=Math.min(p+i-1,l-1));let m=Math.min(d+1,p+i),h=a.slice(p,m);return {success:true,path:t,totalLines:l,startLine:p+1,endLine:m,content:$e(h,p+1),truncated:m<d+1,strategy:"grep",metadata:{module:ys(e,this.workspacePath)}}}async readChunk(e,t,s,n){let i=await Z.readFile(e,"utf-8"),o=bs(i).split(`
|
|
626
|
+
`),a=o.length,l=Math.max(1,s),c=Math.min(l+n-1,a),u=o.slice(l-1,c);return {success:true,path:t,totalLines:a,startLine:l,endLine:c,content:$e(u,l),truncated:c<a,strategy:"chunk"}}async readFull(e,t,s){let n=await Z.readFile(e,"utf-8"),i=bs(n).split(`
|
|
627
|
+
`),o=i.length,a=Math.min(o,s),l=i.slice(0,a);return {success:true,path:t,totalLines:o,startLine:1,endLine:a,content:$e(l,1),truncated:a<o,strategy:"full"}}buildSymbolPattern(e,t,s){let n=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),i={function:`(function|async\\s+function|const|let|var)\\s+${n}\\s*[=(<]`,class:`class\\s+${n}(\\s+extends|\\s+implements|\\s*\\{|\\s*$)`,interface:`interface\\s+${n}(\\s+extends|\\s*\\{|\\s*$)`,method:s?`(${n}|${s}\\.${n})\\s*\\(`:`${n}\\s*\\(`,variable:`(const|let|var)\\s+${n}\\s*[=:]`,type:`type\\s+${n}\\s*[=<]`,enum:`enum\\s+${n}\\s*\\{`,constant:`(const|final|static\\s+final)\\s+[A-Z_]+\\s*${n}`};return t&&i[t]?i[t]:`(function|class|interface|type|enum|const|let|var|def|fn|func)\\s+${n}|${n}\\s*(=|\\()`}resolvePath(e){return X.isAbsolute(e)?e:X.resolve(this.workspacePath,e)}errorResult(e,t){return {success:false,path:e,totalLines:0,startLine:0,endLine:0,content:"",truncated:false,strategy:"chunk",error:t}}};function so(r){return new gr(r)}var kl=Nu(hl());var an=r=>{if(typeof r!="string")throw new TypeError("invalid pattern");if(r.length>65536)throw new TypeError("pattern is too long")};var jd={"[:alnum:]":["\\p{L}\\p{Nl}\\p{Nd}",true],"[:alpha:]":["\\p{L}\\p{Nl}",true],"[:ascii:]":["\\x00-\\x7f",false],"[:blank:]":["\\p{Zs}\\t",true],"[:cntrl:]":["\\p{Cc}",true],"[:digit:]":["\\p{Nd}",true],"[:graph:]":["\\p{Z}\\p{C}",true,true],"[:lower:]":["\\p{Ll}",true],"[:print:]":["\\p{C}",true],"[:punct:]":["\\p{P}",true],"[:space:]":["\\p{Z}\\t\\r\\n\\v\\f",true],"[:upper:]":["\\p{Lu}",true],"[:word:]":["\\p{L}\\p{Nl}\\p{Nd}\\p{Pc}",true],"[:xdigit:]":["A-Fa-f0-9",false]},ln=r=>r.replace(/[[\]\\-]/g,"\\$&"),Gd=r=>r.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),gl=r=>r.join(""),fl=(r,e)=>{let t=e;if(r.charAt(t)!=="[")throw new Error("not in a brace expression");let s=[],n=[],i=t+1,o=false,a=false,l=false,c=false,u=t,p="";e:for(;i<r.length;){let g=r.charAt(i);if((g==="!"||g==="^")&&i===t+1){c=true,i++;continue}if(g==="]"&&o&&!l){u=i+1;break}if(o=true,g==="\\"&&!l){l=true,i++;continue}if(g==="["&&!l){for(let[y,[b,w,S]]of Object.entries(jd))if(r.startsWith(y,i)){if(p)return ["$.",false,r.length-t,true];i+=y.length,S?n.push(b):s.push(b),a=a||w;continue e}}if(l=false,p){g>p?s.push(ln(p)+"-"+ln(g)):g===p&&s.push(ln(g)),p="",i++;continue}if(r.startsWith("-]",i+1)){s.push(ln(g+"-")),i+=2;continue}if(r.startsWith("-",i+1)){p=g,i+=2;continue}s.push(ln(g)),i++;}if(u<i)return ["",false,0,false];if(!s.length&&!n.length)return ["$.",false,r.length-t,true];if(n.length===0&&s.length===1&&/^\\?.$/.test(s[0])&&!c){let g=s[0].length===2?s[0].slice(-1):s[0];return [Gd(g),false,u-t,false]}let d="["+(c?"^":"")+gl(s)+"]",m="["+(c?"":"^")+gl(n)+"]";return [s.length&&n.length?"("+d+"|"+m+")":s.length?d:m,a,u-t,true]};var lt=(r,{windowsPathsNoEscape:e=false}={})=>e?r.replace(/\[([^\/\\])\]/g,"$1"):r.replace(/((?!\\).|^)\[([^\/\\])\]/g,"$1$2").replace(/\\([^\/])/g,"$1");var Bd=new Set(["!","?","+","*","@"]),yl=r=>Bd.has(r),Wd="(?!(?:^|/)\\.\\.?(?:$|/))",yr="(?!\\.)",Hd=new Set(["[","."]),zd=new Set(["..","."]),qd=new Set("().*{}+?[]^$\\!"),Jd=r=>r.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),io="[^/]",bl=io+"*?",wl=io+"+?",ws=class r{type;#e;#t;#i=false;#n=[];#o;#_;#c;#p=false;#a;#l;#r=false;constructor(e,t,s={}){this.type=e,e&&(this.#t=true),this.#o=t,this.#e=this.#o?this.#o.#e:this,this.#a=this.#e===this?s:this.#e.#a,this.#c=this.#e===this?[]:this.#e.#c,e==="!"&&!this.#e.#p&&this.#c.push(this),this.#_=this.#o?this.#o.#n.length:0;}get hasMagic(){if(this.#t!==void 0)return this.#t;for(let e of this.#n)if(typeof e!="string"&&(e.type||e.hasMagic))return this.#t=true;return this.#t}toString(){return this.#l!==void 0?this.#l:this.type?this.#l=this.type+"("+this.#n.map(e=>String(e)).join("|")+")":this.#l=this.#n.map(e=>String(e)).join("")}#f(){if(this!==this.#e)throw new Error("should only call on root");if(this.#p)return this;this.toString(),this.#p=true;let e;for(;e=this.#c.pop();){if(e.type!=="!")continue;let t=e,s=t.#o;for(;s;){for(let n=t.#_+1;!s.type&&n<s.#n.length;n++)for(let i of e.#n){if(typeof i=="string")throw new Error("string part in extglob AST??");i.copyIn(s.#n[n]);}t=s,s=t.#o;}}return this}push(...e){for(let t of e)if(t!==""){if(typeof t!="string"&&!(t instanceof r&&t.#o===this))throw new Error("invalid part: "+t);this.#n.push(t);}}toJSON(){let e=this.type===null?this.#n.slice().map(t=>typeof t=="string"?t:t.toJSON()):[this.type,...this.#n.map(t=>t.toJSON())];return this.isStart()&&!this.type&&e.unshift([]),this.isEnd()&&(this===this.#e||this.#e.#p&&this.#o?.type==="!")&&e.push({}),e}isStart(){if(this.#e===this)return true;if(!this.#o?.isStart())return false;if(this.#_===0)return true;let e=this.#o;for(let t=0;t<this.#_;t++){let s=e.#n[t];if(!(s instanceof r&&s.type==="!"))return false}return true}isEnd(){if(this.#e===this||this.#o?.type==="!")return true;if(!this.#o?.isEnd())return false;if(!this.type)return this.#o?.isEnd();let e=this.#o?this.#o.#n.length:0;return this.#_===e-1}copyIn(e){typeof e=="string"?this.push(e):this.push(e.clone(this));}clone(e){let t=new r(this.type,e);for(let s of this.#n)t.copyIn(s);return t}static#y(e,t,s,n){let i=false,o=false,a=-1,l=false;if(t.type===null){let m=s,h="";for(;m<e.length;){let g=e.charAt(m++);if(i||g==="\\"){i=!i,h+=g;continue}if(o){m===a+1?(g==="^"||g==="!")&&(l=true):g==="]"&&!(m===a+2&&l)&&(o=false),h+=g;continue}else if(g==="["){o=true,a=m,l=false,h+=g;continue}if(!n.noext&&yl(g)&&e.charAt(m)==="("){t.push(h),h="";let y=new r(g,t);m=r.#y(e,y,m,n),t.push(y);continue}h+=g;}return t.push(h),m}let c=s+1,u=new r(null,t),p=[],d="";for(;c<e.length;){let m=e.charAt(c++);if(i||m==="\\"){i=!i,d+=m;continue}if(o){c===a+1?(m==="^"||m==="!")&&(l=true):m==="]"&&!(c===a+2&&l)&&(o=false),d+=m;continue}else if(m==="["){o=true,a=c,l=false,d+=m;continue}if(yl(m)&&e.charAt(c)==="("){u.push(d),d="";let h=new r(m,u);u.push(h),c=r.#y(e,h,c,n);continue}if(m==="|"){u.push(d),d="",p.push(u),u=new r(null,t);continue}if(m===")")return d===""&&t.#n.length===0&&(t.#r=true),u.push(d),d="",t.push(...p,u),c;d+=m;}return t.type=null,t.#t=void 0,t.#n=[e.substring(s-1)],c}static fromGlob(e,t={}){let s=new r(null,void 0,t);return r.#y(e,s,0,t),s}toMMPattern(){if(this!==this.#e)return this.#e.toMMPattern();let e=this.toString(),[t,s,n,i]=this.toRegExpSource();if(!(n||this.#t||this.#a.nocase&&!this.#a.nocaseMagicOnly&&e.toUpperCase()!==e.toLowerCase()))return s;let a=(this.#a.nocase?"i":"")+(i?"u":"");return Object.assign(new RegExp(`^${t}$`,a),{_src:t,_glob:e})}get options(){return this.#a}toRegExpSource(e){let t=e??!!this.#a.dot;if(this.#e===this&&this.#f(),!this.type){let l=this.isStart()&&this.isEnd(),c=this.#n.map(m=>{let[h,g,y,b]=typeof m=="string"?r.#d(m,this.#t,l):m.toRegExpSource(e);return this.#t=this.#t||y,this.#i=this.#i||b,h}).join(""),u="";if(this.isStart()&&typeof this.#n[0]=="string"&&!(this.#n.length===1&&zd.has(this.#n[0]))){let h=Hd,g=t&&h.has(c.charAt(0))||c.startsWith("\\.")&&h.has(c.charAt(2))||c.startsWith("\\.\\.")&&h.has(c.charAt(4)),y=!t&&!e&&h.has(c.charAt(0));u=g?Wd:y?yr:"";}let p="";return this.isEnd()&&this.#e.#p&&this.#o?.type==="!"&&(p="(?:$|\\/)"),[u+c+p,lt(c),this.#t=!!this.#t,this.#i]}let s=this.type==="*"||this.type==="+",n=this.type==="!"?"(?:(?!(?:":"(?:",i=this.#m(t);if(this.isStart()&&this.isEnd()&&!i&&this.type!=="!"){let l=this.toString();return this.#n=[l],this.type=null,this.#t=void 0,[l,lt(this.toString()),false,false]}let o=!s||e||t||!yr?"":this.#m(true);o===i&&(o=""),o&&(i=`(?:${i})(?:${o})*?`);let a="";if(this.type==="!"&&this.#r)a=(this.isStart()&&!t?yr:"")+wl;else {let l=this.type==="!"?"))"+(this.isStart()&&!t&&!e?yr:"")+bl+")":this.type==="@"?")":this.type==="?"?")?":this.type==="+"&&o?")":this.type==="*"&&o?")?":`)${this.type}`;a=n+i+l;}return [a,lt(i),this.#t=!!this.#t,this.#i]}#m(e){return this.#n.map(t=>{if(typeof t=="string")throw new Error("string type in extglob ast??");let[s,n,i,o]=t.toRegExpSource(e);return this.#i=this.#i||o,s}).filter(t=>!(this.isStart()&&this.isEnd())||!!t).join("|")}static#d(e,t,s=false){let n=false,i="",o=false;for(let a=0;a<e.length;a++){let l=e.charAt(a);if(n){n=false,i+=(qd.has(l)?"\\":"")+l;continue}if(l==="\\"){a===e.length-1?i+="\\\\":n=true;continue}if(l==="["){let[c,u,p,d]=fl(e,a);if(p){i+=c,o=o||u,a+=p-1,t=t||d;continue}}if(l==="*"){s&&e==="*"?i+=wl:i+=bl,t=true;continue}if(l==="?"){i+=io,t=true;continue}i+=Jd(l);}return [i,lt(e),!!t,o]}};var _s=(r,{windowsPathsNoEscape:e=false}={})=>e?r.replace(/[?*()[\]]/g,"[$&]"):r.replace(/[?*()[\]\\]/g,"\\$&");var Ge=(r,e,t={})=>(an(e),!t.nocomment&&e.charAt(0)==="#"?false:new Ye(e,t).match(r)),Kd=/^\*+([^+@!?\*\[\(]*)$/,Vd=r=>e=>!e.startsWith(".")&&e.endsWith(r),Yd=r=>e=>e.endsWith(r),Xd=r=>(r=r.toLowerCase(),e=>!e.startsWith(".")&&e.toLowerCase().endsWith(r)),Zd=r=>(r=r.toLowerCase(),e=>e.toLowerCase().endsWith(r)),Qd=/^\*+\.\*+$/,em=r=>!r.startsWith(".")&&r.includes("."),tm=r=>r!=="."&&r!==".."&&r.includes("."),sm=/^\.\*+$/,nm=r=>r!=="."&&r!==".."&&r.startsWith("."),rm=/^\*+$/,im=r=>r.length!==0&&!r.startsWith("."),om=r=>r.length!==0&&r!=="."&&r!=="..",am=/^\?+([^+@!?\*\[\(]*)?$/,lm=([r,e=""])=>{let t=vl([r]);return e?(e=e.toLowerCase(),s=>t(s)&&s.toLowerCase().endsWith(e)):t},cm=([r,e=""])=>{let t=Tl([r]);return e?(e=e.toLowerCase(),s=>t(s)&&s.toLowerCase().endsWith(e)):t},um=([r,e=""])=>{let t=Tl([r]);return e?s=>t(s)&&s.endsWith(e):t},pm=([r,e=""])=>{let t=vl([r]);return e?s=>t(s)&&s.endsWith(e):t},vl=([r])=>{let e=r.length;return t=>t.length===e&&!t.startsWith(".")},Tl=([r])=>{let e=r.length;return t=>t.length===e&&t!=="."&&t!==".."},xl=typeof process=="object"&&process?typeof process.env=="object"&&process.env&&process.env.__MINIMATCH_TESTING_PLATFORM__||process.platform:"posix",_l={win32:{sep:"\\"},posix:{sep:"/"}},dm=xl==="win32"?_l.win32.sep:_l.posix.sep;Ge.sep=dm;var Oe=Symbol("globstar **");Ge.GLOBSTAR=Oe;var mm="[^/]",hm=mm+"*?",gm="(?:(?!(?:\\/|^)(?:\\.{1,2})($|\\/)).)*?",fm="(?:(?!(?:\\/|^)\\.).)*?",ym=(r,e={})=>t=>Ge(t,r,e);Ge.filter=ym;var et=(r,e={})=>Object.assign({},r,e),bm=r=>{if(!r||typeof r!="object"||!Object.keys(r).length)return Ge;let e=Ge;return Object.assign((s,n,i={})=>e(s,n,et(r,i)),{Minimatch:class extends e.Minimatch{constructor(n,i={}){super(n,et(r,i));}static defaults(n){return e.defaults(et(r,n)).Minimatch}},AST:class extends e.AST{constructor(n,i,o={}){super(n,i,et(r,o));}static fromGlob(n,i={}){return e.AST.fromGlob(n,et(r,i))}},unescape:(s,n={})=>e.unescape(s,et(r,n)),escape:(s,n={})=>e.escape(s,et(r,n)),filter:(s,n={})=>e.filter(s,et(r,n)),defaults:s=>e.defaults(et(r,s)),makeRe:(s,n={})=>e.makeRe(s,et(r,n)),braceExpand:(s,n={})=>e.braceExpand(s,et(r,n)),match:(s,n,i={})=>e.match(s,n,et(r,i)),sep:e.sep,GLOBSTAR:Oe})};Ge.defaults=bm;var Cl=(r,e={})=>(an(r),e.nobrace||!/\{(?:(?!\{).)*\}/.test(r)?[r]:(0, kl.default)(r));Ge.braceExpand=Cl;var wm=(r,e={})=>new Ye(r,e).makeRe();Ge.makeRe=wm;var _m=(r,e,t={})=>{let s=new Ye(e,t);return r=r.filter(n=>s.match(n)),s.options.nonull&&!r.length&&r.push(e),r};Ge.match=_m;var Sl=/[?*]|[+@!]\(.*?\)|\[|\]/,Sm=r=>r.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&"),Ye=class{options;set;pattern;windowsPathsNoEscape;nonegate;negate;comment;empty;preserveMultipleSlashes;partial;globSet;globParts;nocase;isWindows;platform;windowsNoMagicRoot;regexp;constructor(e,t={}){an(e),t=t||{},this.options=t,this.pattern=e,this.platform=t.platform||xl,this.isWindows=this.platform==="win32",this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===false,this.windowsPathsNoEscape&&(this.pattern=this.pattern.replace(/\\/g,"/")),this.preserveMultipleSlashes=!!t.preserveMultipleSlashes,this.regexp=null,this.negate=false,this.nonegate=!!t.nonegate,this.comment=false,this.empty=false,this.partial=!!t.partial,this.nocase=!!this.options.nocase,this.windowsNoMagicRoot=t.windowsNoMagicRoot!==void 0?t.windowsNoMagicRoot:!!(this.isWindows&&this.nocase),this.globSet=[],this.globParts=[],this.set=[],this.make();}hasMagic(){if(this.options.magicalBraces&&this.set.length>1)return true;for(let e of this.set)for(let t of e)if(typeof t!="string")return true;return false}debug(...e){}make(){let e=this.pattern,t=this.options;if(!t.nocomment&&e.charAt(0)==="#"){this.comment=true;return}if(!e){this.empty=true;return}this.parseNegate(),this.globSet=[...new Set(this.braceExpand())],t.debug&&(this.debug=(...i)=>console.error(...i)),this.debug(this.pattern,this.globSet);let s=this.globSet.map(i=>this.slashSplit(i));this.globParts=this.preprocess(s),this.debug(this.pattern,this.globParts);let n=this.globParts.map((i,o,a)=>{if(this.isWindows&&this.windowsNoMagicRoot){let l=i[0]===""&&i[1]===""&&(i[2]==="?"||!Sl.test(i[2]))&&!Sl.test(i[3]),c=/^[a-z]:/i.test(i[0]);if(l)return [...i.slice(0,4),...i.slice(4).map(u=>this.parse(u))];if(c)return [i[0],...i.slice(1).map(u=>this.parse(u))]}return i.map(l=>this.parse(l))});if(this.debug(this.pattern,n),this.set=n.filter(i=>i.indexOf(false)===-1),this.isWindows)for(let i=0;i<this.set.length;i++){let o=this.set[i];o[0]===""&&o[1]===""&&this.globParts[i][2]==="?"&&typeof o[3]=="string"&&/^[a-z]:$/i.test(o[3])&&(o[2]="?");}this.debug(this.pattern,this.set);}preprocess(e){if(this.options.noglobstar)for(let s=0;s<e.length;s++)for(let n=0;n<e[s].length;n++)e[s][n]==="**"&&(e[s][n]="*");let{optimizationLevel:t=1}=this.options;return t>=2?(e=this.firstPhasePreProcess(e),e=this.secondPhasePreProcess(e)):t>=1?e=this.levelOneOptimize(e):e=this.adjascentGlobstarOptimize(e),e}adjascentGlobstarOptimize(e){return e.map(t=>{let s=-1;for(;(s=t.indexOf("**",s+1))!==-1;){let n=s;for(;t[n+1]==="**";)n++;n!==s&&t.splice(s,n-s);}return t})}levelOneOptimize(e){return e.map(t=>(t=t.reduce((s,n)=>{let i=s[s.length-1];return n==="**"&&i==="**"?s:n===".."&&i&&i!==".."&&i!=="."&&i!=="**"?(s.pop(),s):(s.push(n),s)},[]),t.length===0?[""]:t))}levelTwoFileOptimize(e){Array.isArray(e)||(e=this.slashSplit(e));let t=false;do{if(t=false,!this.preserveMultipleSlashes){for(let n=1;n<e.length-1;n++){let i=e[n];n===1&&i===""&&e[0]===""||(i==="."||i==="")&&(t=true,e.splice(n,1),n--);}e[0]==="."&&e.length===2&&(e[1]==="."||e[1]==="")&&(t=true,e.pop());}let s=0;for(;(s=e.indexOf("..",s+1))!==-1;){let n=e[s-1];n&&n!=="."&&n!==".."&&n!=="**"&&(t=true,e.splice(s-1,2),s-=2);}}while(t);return e.length===0?[""]:e}firstPhasePreProcess(e){let t=false;do{t=false;for(let s of e){let n=-1;for(;(n=s.indexOf("**",n+1))!==-1;){let o=n;for(;s[o+1]==="**";)o++;o>n&&s.splice(n+1,o-n);let a=s[n+1],l=s[n+2],c=s[n+3];if(a!==".."||!l||l==="."||l===".."||!c||c==="."||c==="..")continue;t=true,s.splice(n,1);let u=s.slice(0);u[n]="**",e.push(u),n--;}if(!this.preserveMultipleSlashes){for(let o=1;o<s.length-1;o++){let a=s[o];o===1&&a===""&&s[0]===""||(a==="."||a==="")&&(t=true,s.splice(o,1),o--);}s[0]==="."&&s.length===2&&(s[1]==="."||s[1]==="")&&(t=true,s.pop());}let i=0;for(;(i=s.indexOf("..",i+1))!==-1;){let o=s[i-1];if(o&&o!=="."&&o!==".."&&o!=="**"){t=true;let l=i===1&&s[i+1]==="**"?["."]:[];s.splice(i-1,2,...l),s.length===0&&s.push(""),i-=2;}}}}while(t);return e}secondPhasePreProcess(e){for(let t=0;t<e.length-1;t++)for(let s=t+1;s<e.length;s++){let n=this.partsMatch(e[t],e[s],!this.preserveMultipleSlashes);if(n){e[t]=[],e[s]=n;break}}return e.filter(t=>t.length)}partsMatch(e,t,s=false){let n=0,i=0,o=[],a="";for(;n<e.length&&i<t.length;)if(e[n]===t[i])o.push(a==="b"?t[i]:e[n]),n++,i++;else if(s&&e[n]==="**"&&t[i]===e[n+1])o.push(e[n]),n++;else if(s&&t[i]==="**"&&e[n]===t[i+1])o.push(t[i]),i++;else if(e[n]==="*"&&t[i]&&(this.options.dot||!t[i].startsWith("."))&&t[i]!=="**"){if(a==="b")return false;a="a",o.push(e[n]),n++,i++;}else if(t[i]==="*"&&e[n]&&(this.options.dot||!e[n].startsWith("."))&&e[n]!=="**"){if(a==="a")return false;a="b",o.push(t[i]),n++,i++;}else return false;return e.length===t.length&&o}parseNegate(){if(this.nonegate)return;let e=this.pattern,t=false,s=0;for(let n=0;n<e.length&&e.charAt(n)==="!";n++)t=!t,s++;s&&(this.pattern=e.slice(s)),this.negate=t;}matchOne(e,t,s=false){let n=this.options;if(this.isWindows){let g=typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0]),y=!g&&e[0]===""&&e[1]===""&&e[2]==="?"&&/^[a-z]:$/i.test(e[3]),b=typeof t[0]=="string"&&/^[a-z]:$/i.test(t[0]),w=!b&&t[0]===""&&t[1]===""&&t[2]==="?"&&typeof t[3]=="string"&&/^[a-z]:$/i.test(t[3]),S=y?3:g?0:void 0,x=w?3:b?0:void 0;if(typeof S=="number"&&typeof x=="number"){let[R,$]=[e[S],t[x]];R.toLowerCase()===$.toLowerCase()&&(t[x]=R,x>S?t=t.slice(x):S>x&&(e=e.slice(S)));}}let{optimizationLevel:i=1}=this.options;i>=2&&(e=this.levelTwoFileOptimize(e)),this.debug("matchOne",this,{file:e,pattern:t}),this.debug("matchOne",e.length,t.length);for(var o=0,a=0,l=e.length,c=t.length;o<l&&a<c;o++,a++){this.debug("matchOne loop");var u=t[a],p=e[o];if(this.debug(t,u,p),u===false)return false;if(u===Oe){this.debug("GLOBSTAR",[t,u,p]);var d=o,m=a+1;if(m===c){for(this.debug("** at the end");o<l;o++)if(e[o]==="."||e[o]===".."||!n.dot&&e[o].charAt(0)===".")return false;return true}for(;d<l;){var h=e[d];if(this.debug(`
|
|
628
628
|
globstar while`,e,d,t,m,h),this.matchOne(e.slice(d),t.slice(m),s))return this.debug("globstar found match!",d,l,h),true;if(h==="."||h===".."||!n.dot&&h.charAt(0)==="."){this.debug("dot detected!",e,d,t,m);break}this.debug("globstar swallow a segment, and continue"),d++;}return !!(s&&(this.debug(`
|
|
629
|
-
>>> no match, partial?`,e,d,t,m),d===l))}let g;if(typeof u=="string"?(g=p===u,this.debug("string match",u,p,g)):(g=u.test(p),this.debug("pattern match",u,p,g)),!g)return false}if(o===l&&a===c)return true;if(o===l)return s;if(a===c)return o===l-1&&e[o]==="";throw new Error("wtf?")}braceExpand(){return vl(this.pattern,this.options)}parse(e){on(e);let t=this.options;if(e==="**")return Pe;if(e==="")return "";let s,n=null;(s=e.match(Zd))?n=t.dot?em:Qd:(s=e.match(Bd))?n=(t.nocase?t.dot?qd:zd:t.dot?Hd:Wd)(s[1]):(s=e.match(tm))?n=(t.nocase?t.dot?nm:sm:t.dot?rm:im)(s):(s=e.match(Jd))?n=t.dot?Vd:Kd:(s=e.match(Yd))&&(n=Xd);let i=ws.fromGlob(e,this.options).toMMPattern();return n&&typeof i=="object"&&Reflect.defineProperty(i,"test",{value:n}),i}makeRe(){if(this.regexp||this.regexp===false)return this.regexp;let e=this.set;if(!e.length)return this.regexp=false,this.regexp;let t=this.options,s=t.noglobstar?lm:t.dot?cm:um,n=new Set(t.nocase?["i"]:[]),i=e.map(l=>{let c=l.map(u=>{if(u instanceof RegExp)for(let p of u.flags.split(""))n.add(p);return typeof u=="string"?gm(u):u===Pe?Pe:u._src});return c.forEach((u,p)=>{let d=c[p+1],m=c[p-1];u!==Pe||m===Pe||(m===void 0?d!==void 0&&d!==Pe?c[p+1]="(?:\\/|"+s+"\\/)?"+d:c[p]=s:d===void 0?c[p-1]=m+"(?:\\/|"+s+")?":d!==Pe&&(c[p-1]=m+"(?:\\/|\\/"+s+"\\/)"+d,c[p+1]=Pe));}),c.filter(u=>u!==Pe).join("/")}).join("|"),[o,a]=e.length>1?["(?:",")"]:["",""];i="^"+o+i+a+"$",this.negate&&(i="^(?!"+i+").+$");try{this.regexp=new RegExp(i,[...n].join(""));}catch{this.regexp=false;}return this.regexp}slashSplit(e){return this.preserveMultipleSlashes?e.split("/"):this.isWindows&&/^\/\/[^\/]+/.test(e)?["",...e.split(/\/+/)]:e.split(/\/+/)}match(e,t=this.partial){if(this.debug("match",e,this.pattern),this.comment)return false;if(this.empty)return e==="";if(e==="/"&&t)return true;let s=this.options;this.isWindows&&(e=e.split("\\").join("/"));let n=this.slashSplit(e);this.debug(this.pattern,"split",n);let i=this.set;this.debug(this.pattern,"set",i);let o=n[n.length-1];if(!o)for(let a=n.length-2;!o&&a>=0;a--)o=n[a];for(let a=0;a<i.length;a++){let l=i[a],c=n;if(s.matchBase&&l.length===1&&(c=[o]),this.matchOne(c,l,t))return s.flipNegate?true:!this.negate}return s.flipNegate?false:this.negate}static defaults(e){return Ge.defaults(e).Minimatch}};Ge.AST=ws;Ge.Minimatch=Ye;Ge.escape=_s;Ge.unescape=lt;var Ss=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,Tl=new Set,so=typeof process=="object"&&process?process:{},Cl=(r,e,t,s)=>{typeof so.emitWarning=="function"?so.emitWarning(r,e,t,s):console.error(`[${t}] ${e}: ${r}`);},yr=globalThis.AbortController,xl=globalThis.AbortSignal;if(typeof yr>"u"){xl=class{onabort;_onabort=[];reason;aborted=false;addEventListener(s,n){this._onabort.push(n);}},yr=class{constructor(){e();}signal=new xl;abort(s){if(!this.signal.aborted){this.signal.reason=s,this.signal.aborted=true;for(let n of this.signal._onabort)n(s);this.signal.onabort?.(s);}}};let r=so.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{r&&(r=false,Cl("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",e));};}var fm=r=>!Tl.has(r);var Ot=r=>r&&r===Math.floor(r)&&r>0&&isFinite(r),Rl=r=>Ot(r)?r<=Math.pow(2,8)?Uint8Array:r<=Math.pow(2,16)?Uint16Array:r<=Math.pow(2,32)?Uint32Array:r<=Number.MAX_SAFE_INTEGER?ks:null:null,ks=class extends Array{constructor(e){super(e),this.fill(0);}},no=class r{heap;length;static#e=false;static create(e){let t=Rl(e);if(!t)return [];r.#e=true;let s=new r(e,t);return r.#e=false,s}constructor(e,t){if(!r.#e)throw new TypeError("instantiate Stack using Stack.create(n)");this.heap=new t(e),this.length=0;}push(e){this.heap[this.length++]=e;}pop(){return this.heap[--this.length]}},ln=class r{#e;#t;#i;#n;#o;#_;ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#c;#p;#a;#l;#r;#f;#y;#m;#d;#v;#g;#x;#T;#w;#S;#k;#h;static unsafeExposeInternals(e){return {starts:e.#T,ttls:e.#w,sizes:e.#x,keyMap:e.#a,keyList:e.#l,valList:e.#r,next:e.#f,prev:e.#y,get head(){return e.#m},get tail(){return e.#d},free:e.#v,isBackgroundFetch:t=>e.#u(t),backgroundFetch:(t,s,n,i)=>e.#F(t,s,n,i),moveToTail:t=>e.#j(t),indexes:t=>e.#R(t),rindexes:t=>e.#E(t),isStale:t=>e.#b(t)}}get max(){return this.#e}get maxSize(){return this.#t}get calculatedSize(){return this.#p}get size(){return this.#c}get fetchMethod(){return this.#o}get memoMethod(){return this.#_}get dispose(){return this.#i}get disposeAfter(){return this.#n}constructor(e){let{max:t=0,ttl:s,ttlResolution:n=1,ttlAutopurge:i,updateAgeOnGet:o,updateAgeOnHas:a,allowStale:l,dispose:c,disposeAfter:u,noDisposeOnSet:p,noUpdateTTL:d,maxSize:m=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:y,memoMethod:b,noDeleteOnFetchRejection:w,noDeleteOnStaleGet:S,allowStaleOnFetchRejection:x,allowStaleOnFetchAbort:R,ignoreFetchAbort:L}=e;if(t!==0&&!Ot(t))throw new TypeError("max option must be a nonnegative integer");let H=t?Rl(t):Array;if(!H)throw new Error("invalid max value: "+t);if(this.#e=t,this.#t=m,this.maxEntrySize=h||this.#t,this.sizeCalculation=g,this.sizeCalculation){if(!this.#t&&!this.maxEntrySize)throw new TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw new TypeError("sizeCalculation set to non-function")}if(b!==void 0&&typeof b!="function")throw new TypeError("memoMethod must be a function if defined");if(this.#_=b,y!==void 0&&typeof y!="function")throw new TypeError("fetchMethod must be a function if specified");if(this.#o=y,this.#k=!!y,this.#a=new Map,this.#l=new Array(t).fill(void 0),this.#r=new Array(t).fill(void 0),this.#f=new H(t),this.#y=new H(t),this.#m=0,this.#d=0,this.#v=no.create(t),this.#c=0,this.#p=0,typeof c=="function"&&(this.#i=c),typeof u=="function"?(this.#n=u,this.#g=[]):(this.#n=void 0,this.#g=void 0),this.#S=!!this.#i,this.#h=!!this.#n,this.noDisposeOnSet=!!p,this.noUpdateTTL=!!d,this.noDeleteOnFetchRejection=!!w,this.allowStaleOnFetchRejection=!!x,this.allowStaleOnFetchAbort=!!R,this.ignoreFetchAbort=!!L,this.maxEntrySize!==0){if(this.#t!==0&&!Ot(this.#t))throw new TypeError("maxSize must be a positive integer if specified");if(!Ot(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");this.#M();}if(this.allowStale=!!l,this.noDeleteOnStaleGet=!!S,this.updateAgeOnGet=!!o,this.updateAgeOnHas=!!a,this.ttlResolution=Ot(n)||n===0?n:1,this.ttlAutopurge=!!i,this.ttl=s||0,this.ttl){if(!Ot(this.ttl))throw new TypeError("ttl must be a positive integer if specified");this.#I();}if(this.#e===0&&this.ttl===0&&this.#t===0)throw new TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!this.#e&&!this.#t){let U="LRU_CACHE_UNBOUNDED";fm(U)&&(Tl.add(U),Cl("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",U,r));}}getRemainingTTL(e){return this.#a.has(e)?1/0:0}#I(){let e=new ks(this.#e),t=new ks(this.#e);this.#w=e,this.#T=t,this.#P=(i,o,a=Ss.now())=>{if(t[i]=o!==0?a:0,e[i]=o,o!==0&&this.ttlAutopurge){let l=setTimeout(()=>{this.#b(i)&&this.#A(this.#l[i],"expire");},o+1);l.unref&&l.unref();}},this.#C=i=>{t[i]=e[i]!==0?Ss.now():0;},this.#s=(i,o)=>{if(e[o]){let a=e[o],l=t[o];if(!a||!l)return;i.ttl=a,i.start=l,i.now=s||n();let c=i.now-l;i.remainingTTL=a-c;}};let s=0,n=()=>{let i=Ss.now();if(this.ttlResolution>0){s=i;let o=setTimeout(()=>s=0,this.ttlResolution);o.unref&&o.unref();}return i};this.getRemainingTTL=i=>{let o=this.#a.get(i);if(o===void 0)return 0;let a=e[o],l=t[o];if(!a||!l)return 1/0;let c=(s||n())-l;return a-c},this.#b=i=>{let o=t[i],a=e[i];return !!a&&!!o&&(s||n())-o>a};}#C=()=>{};#s=()=>{};#P=()=>{};#b=()=>false;#M(){let e=new ks(this.#e);this.#p=0,this.#x=e,this.#O=t=>{this.#p-=e[t],e[t]=0;},this.#D=(t,s,n,i)=>{if(this.#u(s))return 0;if(!Ot(n))if(i){if(typeof i!="function")throw new TypeError("sizeCalculation must be a function");if(n=i(s,t),!Ot(n))throw new TypeError("sizeCalculation return invalid (expect positive integer)")}else throw new TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return n},this.#L=(t,s,n)=>{if(e[t]=s,this.#t){let i=this.#t-e[t];for(;this.#p>i;)this.#N(true);}this.#p+=e[t],n&&(n.entrySize=s,n.totalCalculatedSize=this.#p);};}#O=e=>{};#L=(e,t,s)=>{};#D=(e,t,s,n)=>{if(s||n)throw new TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0};*#R({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#d;!(!this.#$(t)||((e||!this.#b(t))&&(yield t),t===this.#m));)t=this.#y[t];}*#E({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#m;!(!this.#$(t)||((e||!this.#b(t))&&(yield t),t===this.#d));)t=this.#f[t];}#$(e){return e!==void 0&&this.#a.get(this.#l[e])===e}*entries(){for(let e of this.#R())this.#r[e]!==void 0&&this.#l[e]!==void 0&&!this.#u(this.#r[e])&&(yield [this.#l[e],this.#r[e]]);}*rentries(){for(let e of this.#E())this.#r[e]!==void 0&&this.#l[e]!==void 0&&!this.#u(this.#r[e])&&(yield [this.#l[e],this.#r[e]]);}*keys(){for(let e of this.#R()){let t=this.#l[e];t!==void 0&&!this.#u(this.#r[e])&&(yield t);}}*rkeys(){for(let e of this.#E()){let t=this.#l[e];t!==void 0&&!this.#u(this.#r[e])&&(yield t);}}*values(){for(let e of this.#R())this.#r[e]!==void 0&&!this.#u(this.#r[e])&&(yield this.#r[e]);}*rvalues(){for(let e of this.#E())this.#r[e]!==void 0&&!this.#u(this.#r[e])&&(yield this.#r[e]);}[Symbol.iterator](){return this.entries()}[Symbol.toStringTag]="LRUCache";find(e,t={}){for(let s of this.#R()){let n=this.#r[s],i=this.#u(n)?n.__staleWhileFetching:n;if(i!==void 0&&e(i,this.#l[s],this))return this.get(this.#l[s],t)}}forEach(e,t=this){for(let s of this.#R()){let n=this.#r[s],i=this.#u(n)?n.__staleWhileFetching:n;i!==void 0&&e.call(t,i,this.#l[s],this);}}rforEach(e,t=this){for(let s of this.#E()){let n=this.#r[s],i=this.#u(n)?n.__staleWhileFetching:n;i!==void 0&&e.call(t,i,this.#l[s],this);}}purgeStale(){let e=false;for(let t of this.#E({allowStale:true}))this.#b(t)&&(this.#A(this.#l[t],"expire"),e=true);return e}info(e){let t=this.#a.get(e);if(t===void 0)return;let s=this.#r[t],n=this.#u(s)?s.__staleWhileFetching:s;if(n===void 0)return;let i={value:n};if(this.#w&&this.#T){let o=this.#w[t],a=this.#T[t];if(o&&a){let l=o-(Ss.now()-a);i.ttl=l,i.start=Date.now();}}return this.#x&&(i.size=this.#x[t]),i}dump(){let e=[];for(let t of this.#R({allowStale:true})){let s=this.#l[t],n=this.#r[t],i=this.#u(n)?n.__staleWhileFetching:n;if(i===void 0||s===void 0)continue;let o={value:i};if(this.#w&&this.#T){o.ttl=this.#w[t];let a=Ss.now()-this.#T[t];o.start=Math.floor(Date.now()-a);}this.#x&&(o.size=this.#x[t]),e.unshift([s,o]);}return e}load(e){this.clear();for(let[t,s]of e){if(s.start){let n=Date.now()-s.start;s.start=Ss.now()-n;}this.set(t,s.value,s);}}set(e,t,s={}){if(t===void 0)return this.delete(e),this;let{ttl:n=this.ttl,start:i,noDisposeOnSet:o=this.noDisposeOnSet,sizeCalculation:a=this.sizeCalculation,status:l}=s,{noUpdateTTL:c=this.noUpdateTTL}=s,u=this.#D(e,t,s.size||0,a);if(this.maxEntrySize&&u>this.maxEntrySize)return l&&(l.set="miss",l.maxEntrySizeExceeded=true),this.#A(e,"set"),this;let p=this.#c===0?void 0:this.#a.get(e);if(p===void 0)p=this.#c===0?this.#d:this.#v.length!==0?this.#v.pop():this.#c===this.#e?this.#N(false):this.#c,this.#l[p]=e,this.#r[p]=t,this.#a.set(e,p),this.#f[this.#d]=p,this.#y[p]=this.#d,this.#d=p,this.#c++,this.#L(p,u,l),l&&(l.set="add"),c=false;else {this.#j(p);let d=this.#r[p];if(t!==d){if(this.#k&&this.#u(d)){d.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:m}=d;m!==void 0&&!o&&(this.#S&&this.#i?.(m,e,"set"),this.#h&&this.#g?.push([m,e,"set"]));}else o||(this.#S&&this.#i?.(d,e,"set"),this.#h&&this.#g?.push([d,e,"set"]));if(this.#O(p),this.#L(p,u,l),this.#r[p]=t,l){l.set="replace";let m=d&&this.#u(d)?d.__staleWhileFetching:d;m!==void 0&&(l.oldValue=m);}}else l&&(l.set="update");}if(n!==0&&!this.#w&&this.#I(),this.#w&&(c||this.#P(p,n,i),l&&this.#s(l,p)),!o&&this.#h&&this.#g){let d=this.#g,m;for(;m=d?.shift();)this.#n?.(...m);}return this}pop(){try{for(;this.#c;){let e=this.#r[this.#m];if(this.#N(!0),this.#u(e)){if(e.__staleWhileFetching)return e.__staleWhileFetching}else if(e!==void 0)return e}}finally{if(this.#h&&this.#g){let e=this.#g,t;for(;t=e?.shift();)this.#n?.(...t);}}}#N(e){let t=this.#m,s=this.#l[t],n=this.#r[t];return this.#k&&this.#u(n)?n.__abortController.abort(new Error("evicted")):(this.#S||this.#h)&&(this.#S&&this.#i?.(n,s,"evict"),this.#h&&this.#g?.push([n,s,"evict"])),this.#O(t),e&&(this.#l[t]=void 0,this.#r[t]=void 0,this.#v.push(t)),this.#c===1?(this.#m=this.#d=0,this.#v.length=0):this.#m=this.#f[t],this.#a.delete(s),this.#c--,t}has(e,t={}){let{updateAgeOnHas:s=this.updateAgeOnHas,status:n}=t,i=this.#a.get(e);if(i!==void 0){let o=this.#r[i];if(this.#u(o)&&o.__staleWhileFetching===void 0)return false;if(this.#b(i))n&&(n.has="stale",this.#s(n,i));else return s&&this.#C(i),n&&(n.has="hit",this.#s(n,i)),true}else n&&(n.has="miss");return false}peek(e,t={}){let{allowStale:s=this.allowStale}=t,n=this.#a.get(e);if(n===void 0||!s&&this.#b(n))return;let i=this.#r[n];return this.#u(i)?i.__staleWhileFetching:i}#F(e,t,s,n){let i=t===void 0?void 0:this.#r[t];if(this.#u(i))return i;let o=new yr,{signal:a}=s;a?.addEventListener("abort",()=>o.abort(a.reason),{signal:o.signal});let l={signal:o.signal,options:s,context:n},c=(g,y=false)=>{let{aborted:b}=o.signal,w=s.ignoreFetchAbort&&g!==void 0;if(s.status&&(b&&!y?(s.status.fetchAborted=true,s.status.fetchError=o.signal.reason,w&&(s.status.fetchAbortIgnored=true)):s.status.fetchResolved=true),b&&!w&&!y)return p(o.signal.reason);let S=m;return this.#r[t]===m&&(g===void 0?S.__staleWhileFetching?this.#r[t]=S.__staleWhileFetching:this.#A(e,"fetch"):(s.status&&(s.status.fetchUpdated=true),this.set(e,g,l.options))),g},u=g=>(s.status&&(s.status.fetchRejected=true,s.status.fetchError=g),p(g)),p=g=>{let{aborted:y}=o.signal,b=y&&s.allowStaleOnFetchAbort,w=b||s.allowStaleOnFetchRejection,S=w||s.noDeleteOnFetchRejection,x=m;if(this.#r[t]===m&&(!S||x.__staleWhileFetching===void 0?this.#A(e,"fetch"):b||(this.#r[t]=x.__staleWhileFetching)),w)return s.status&&x.__staleWhileFetching!==void 0&&(s.status.returnedStale=true),x.__staleWhileFetching;if(x.__returned===x)throw g},d=(g,y)=>{let b=this.#o?.(e,i,l);b&&b instanceof Promise&&b.then(w=>g(w===void 0?void 0:w),y),o.signal.addEventListener("abort",()=>{(!s.ignoreFetchAbort||s.allowStaleOnFetchAbort)&&(g(void 0),s.allowStaleOnFetchAbort&&(g=w=>c(w,true)));});};s.status&&(s.status.fetchDispatched=true);let m=new Promise(d).then(c,u),h=Object.assign(m,{__abortController:o,__staleWhileFetching:i,__returned:void 0});return t===void 0?(this.set(e,h,{...l.options,status:void 0}),t=this.#a.get(e)):this.#r[t]=h,h}#u(e){if(!this.#k)return false;let t=e;return !!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof yr}async fetch(e,t={}){let{allowStale:s=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,ttl:o=this.ttl,noDisposeOnSet:a=this.noDisposeOnSet,size:l=0,sizeCalculation:c=this.sizeCalculation,noUpdateTTL:u=this.noUpdateTTL,noDeleteOnFetchRejection:p=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:d=this.allowStaleOnFetchRejection,ignoreFetchAbort:m=this.ignoreFetchAbort,allowStaleOnFetchAbort:h=this.allowStaleOnFetchAbort,context:g,forceRefresh:y=false,status:b,signal:w}=t;if(!this.#k)return b&&(b.fetch="get"),this.get(e,{allowStale:s,updateAgeOnGet:n,noDeleteOnStaleGet:i,status:b});let S={allowStale:s,updateAgeOnGet:n,noDeleteOnStaleGet:i,ttl:o,noDisposeOnSet:a,size:l,sizeCalculation:c,noUpdateTTL:u,noDeleteOnFetchRejection:p,allowStaleOnFetchRejection:d,allowStaleOnFetchAbort:h,ignoreFetchAbort:m,status:b,signal:w},x=this.#a.get(e);if(x===void 0){b&&(b.fetch="miss");let R=this.#F(e,x,S,g);return R.__returned=R}else {let R=this.#r[x];if(this.#u(R)){let T=s&&R.__staleWhileFetching!==void 0;return b&&(b.fetch="inflight",T&&(b.returnedStale=true)),T?R.__staleWhileFetching:R.__returned=R}let L=this.#b(x);if(!y&&!L)return b&&(b.fetch="hit"),this.#j(x),n&&this.#C(x),b&&this.#s(b,x),R;let H=this.#F(e,x,S,g),v=H.__staleWhileFetching!==void 0&&s;return b&&(b.fetch=L?"stale":"refresh",v&&L&&(b.returnedStale=true)),v?H.__staleWhileFetching:H.__returned=H}}async forceFetch(e,t={}){let s=await this.fetch(e,t);if(s===void 0)throw new Error("fetch() returned undefined");return s}memo(e,t={}){let s=this.#_;if(!s)throw new Error("no memoMethod provided to constructor");let{context:n,forceRefresh:i,...o}=t,a=this.get(e,o);if(!i&&a!==void 0)return a;let l=s(e,a,{options:o,context:n});return this.set(e,l,o),l}get(e,t={}){let{allowStale:s=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,status:o}=t,a=this.#a.get(e);if(a!==void 0){let l=this.#r[a],c=this.#u(l);return o&&this.#s(o,a),this.#b(a)?(o&&(o.get="stale"),c?(o&&s&&l.__staleWhileFetching!==void 0&&(o.returnedStale=true),s?l.__staleWhileFetching:void 0):(i||this.#A(e,"expire"),o&&s&&(o.returnedStale=true),s?l:void 0)):(o&&(o.get="hit"),c?l.__staleWhileFetching:(this.#j(a),n&&this.#C(a),l))}else o&&(o.get="miss");}#U(e,t){this.#y[t]=e,this.#f[e]=t;}#j(e){e!==this.#d&&(e===this.#m?this.#m=this.#f[e]:this.#U(this.#y[e],this.#f[e]),this.#U(this.#d,e),this.#d=e);}delete(e){return this.#A(e,"delete")}#A(e,t){let s=false;if(this.#c!==0){let n=this.#a.get(e);if(n!==void 0)if(s=true,this.#c===1)this.#G(t);else {this.#O(n);let i=this.#r[n];if(this.#u(i)?i.__abortController.abort(new Error("deleted")):(this.#S||this.#h)&&(this.#S&&this.#i?.(i,e,t),this.#h&&this.#g?.push([i,e,t])),this.#a.delete(e),this.#l[n]=void 0,this.#r[n]=void 0,n===this.#d)this.#d=this.#y[n];else if(n===this.#m)this.#m=this.#f[n];else {let o=this.#y[n];this.#f[o]=this.#f[n];let a=this.#f[n];this.#y[a]=this.#y[n];}this.#c--,this.#v.push(n);}}if(this.#h&&this.#g?.length){let n=this.#g,i;for(;i=n?.shift();)this.#n?.(...i);}return s}clear(){return this.#G("delete")}#G(e){for(let t of this.#E({allowStale:true})){let s=this.#r[t];if(this.#u(s))s.__abortController.abort(new Error("deleted"));else {let n=this.#l[t];this.#S&&this.#i?.(s,n,e),this.#h&&this.#g?.push([s,n,e]);}}if(this.#a.clear(),this.#r.fill(void 0),this.#l.fill(void 0),this.#w&&this.#T&&(this.#w.fill(0),this.#T.fill(0)),this.#x&&this.#x.fill(0),this.#m=0,this.#d=0,this.#v.length=0,this.#p=0,this.#c=0,this.#h&&this.#g){let t=this.#g,s;for(;s=t?.shift();)this.#n?.(...s);}}};var El=typeof process=="object"&&process?process:{stdout:null,stderr:null},bm=r=>!!r&&typeof r=="object"&&(r instanceof Dt||r instanceof Pl||wm(r)||_m(r)),wm=r=>!!r&&typeof r=="object"&&r instanceof EventEmitter&&typeof r.pipe=="function"&&r.pipe!==Pl.Writable.prototype.pipe,_m=r=>!!r&&typeof r=="object"&&r instanceof EventEmitter&&typeof r.write=="function"&&typeof r.end=="function",vt=Symbol("EOF"),xt=Symbol("maybeEmitEnd"),Lt=Symbol("emittedEnd"),br=Symbol("emittingEnd"),cn=Symbol("emittedError"),wr=Symbol("closed"),Il=Symbol("read"),_r=Symbol("flush"),Ml=Symbol("flushChunk"),ct=Symbol("encoding"),vs=Symbol("decoder"),Ie=Symbol("flowing"),un=Symbol("paused"),xs=Symbol("resume"),Me=Symbol("buffer"),Be=Symbol("pipes"),Ae=Symbol("bufferLength"),ro=Symbol("bufferPush"),Sr=Symbol("bufferShift"),Ne=Symbol("objectMode"),ke=Symbol("destroyed"),io=Symbol("error"),oo=Symbol("emitData"),Al=Symbol("emitEnd"),ao=Symbol("emitEnd2"),gt=Symbol("async"),lo=Symbol("abort"),kr=Symbol("aborted"),pn=Symbol("signal"),Jt=Symbol("dataListeners"),Xe=Symbol("discarded"),dn=r=>Promise.resolve().then(r),Sm=r=>r(),km=r=>r==="end"||r==="finish"||r==="prefinish",vm=r=>r instanceof ArrayBuffer||!!r&&typeof r=="object"&&r.constructor&&r.constructor.name==="ArrayBuffer"&&r.byteLength>=0,xm=r=>!Buffer.isBuffer(r)&&ArrayBuffer.isView(r),vr=class{src;dest;opts;ondrain;constructor(e,t,s){this.src=e,this.dest=t,this.opts=s,this.ondrain=()=>e[xs](),this.dest.on("drain",this.ondrain);}unpipe(){this.dest.removeListener("drain",this.ondrain);}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end();}},co=class extends vr{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe();}constructor(e,t,s){super(e,t,s),this.proxyErrors=n=>t.emit("error",n),e.on("error",this.proxyErrors);}},Tm=r=>!!r.objectMode,Cm=r=>!r.objectMode&&!!r.encoding&&r.encoding!=="buffer",Dt=class extends EventEmitter{[Ie]=false;[un]=false;[Be]=[];[Me]=[];[Ne];[ct];[gt];[vs];[vt]=false;[Lt]=false;[br]=false;[wr]=false;[cn]=null;[Ae]=0;[ke]=false;[pn];[kr]=false;[Jt]=0;[Xe]=false;writable=true;readable=true;constructor(...e){let t=e[0]||{};if(super(),t.objectMode&&typeof t.encoding=="string")throw new TypeError("Encoding and objectMode may not be used together");Tm(t)?(this[Ne]=true,this[ct]=null):Cm(t)?(this[ct]=t.encoding,this[Ne]=false):(this[Ne]=false,this[ct]=null),this[gt]=!!t.async,this[vs]=this[ct]?new StringDecoder(this[ct]):null,t&&t.debugExposeBuffer===true&&Object.defineProperty(this,"buffer",{get:()=>this[Me]}),t&&t.debugExposePipes===true&&Object.defineProperty(this,"pipes",{get:()=>this[Be]});let{signal:s}=t;s&&(this[pn]=s,s.aborted?this[lo]():s.addEventListener("abort",()=>this[lo]()));}get bufferLength(){return this[Ae]}get encoding(){return this[ct]}set encoding(e){throw new Error("Encoding must be set at instantiation time")}setEncoding(e){throw new Error("Encoding must be set at instantiation time")}get objectMode(){return this[Ne]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[gt]}set async(e){this[gt]=this[gt]||!!e;}[lo](){this[kr]=true,this.emit("abort",this[pn]?.reason),this.destroy(this[pn]?.reason);}get aborted(){return this[kr]}set aborted(e){}write(e,t,s){if(this[kr])return false;if(this[vt])throw new Error("write after end");if(this[ke])return this.emit("error",Object.assign(new Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),true;typeof t=="function"&&(s=t,t="utf8"),t||(t="utf8");let n=this[gt]?dn:Sm;if(!this[Ne]&&!Buffer.isBuffer(e)){if(xm(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if(vm(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[Ne]?(this[Ie]&&this[Ae]!==0&&this[_r](true),this[Ie]?this.emit("data",e):this[ro](e),this[Ae]!==0&&this.emit("readable"),s&&n(s),this[Ie]):e.length?(typeof e=="string"&&!(t===this[ct]&&!this[vs]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[ct]&&(e=this[vs].write(e)),this[Ie]&&this[Ae]!==0&&this[_r](true),this[Ie]?this.emit("data",e):this[ro](e),this[Ae]!==0&&this.emit("readable"),s&&n(s),this[Ie]):(this[Ae]!==0&&this.emit("readable"),s&&n(s),this[Ie])}read(e){if(this[ke])return null;if(this[Xe]=false,this[Ae]===0||e===0||e&&e>this[Ae])return this[xt](),null;this[Ne]&&(e=null),this[Me].length>1&&!this[Ne]&&(this[Me]=[this[ct]?this[Me].join(""):Buffer.concat(this[Me],this[Ae])]);let t=this[Il](e||null,this[Me][0]);return this[xt](),t}[Il](e,t){if(this[Ne])this[Sr]();else {let s=t;e===s.length||e===null?this[Sr]():typeof s=="string"?(this[Me][0]=s.slice(e),t=s.slice(0,e),this[Ae]-=e):(this[Me][0]=s.subarray(e),t=s.subarray(0,e),this[Ae]-=e);}return this.emit("data",t),!this[Me].length&&!this[vt]&&this.emit("drain"),t}end(e,t,s){return typeof e=="function"&&(s=e,e=void 0),typeof t=="function"&&(s=t,t="utf8"),e!==void 0&&this.write(e,t),s&&this.once("end",s),this[vt]=true,this.writable=false,(this[Ie]||!this[un])&&this[xt](),this}[xs](){this[ke]||(!this[Jt]&&!this[Be].length&&(this[Xe]=true),this[un]=false,this[Ie]=true,this.emit("resume"),this[Me].length?this[_r]():this[vt]?this[xt]():this.emit("drain"));}resume(){return this[xs]()}pause(){this[Ie]=false,this[un]=true,this[Xe]=false;}get destroyed(){return this[ke]}get flowing(){return this[Ie]}get paused(){return this[un]}[ro](e){this[Ne]?this[Ae]+=1:this[Ae]+=e.length,this[Me].push(e);}[Sr](){return this[Ne]?this[Ae]-=1:this[Ae]-=this[Me][0].length,this[Me].shift()}[_r](e=false){do;while(this[Ml](this[Sr]())&&this[Me].length);!e&&!this[Me].length&&!this[vt]&&this.emit("drain");}[Ml](e){return this.emit("data",e),this[Ie]}pipe(e,t){if(this[ke])return e;this[Xe]=false;let s=this[Lt];return t=t||{},e===El.stdout||e===El.stderr?t.end=false:t.end=t.end!==false,t.proxyErrors=!!t.proxyErrors,s?t.end&&e.end():(this[Be].push(t.proxyErrors?new co(this,e,t):new vr(this,e,t)),this[gt]?dn(()=>this[xs]()):this[xs]()),e}unpipe(e){let t=this[Be].find(s=>s.dest===e);t&&(this[Be].length===1?(this[Ie]&&this[Jt]===0&&(this[Ie]=false),this[Be]=[]):this[Be].splice(this[Be].indexOf(t),1),t.unpipe());}addListener(e,t){return this.on(e,t)}on(e,t){let s=super.on(e,t);if(e==="data")this[Xe]=false,this[Jt]++,!this[Be].length&&!this[Ie]&&this[xs]();else if(e==="readable"&&this[Ae]!==0)super.emit("readable");else if(km(e)&&this[Lt])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[cn]){let n=t;this[gt]?dn(()=>n.call(this,this[cn])):n.call(this,this[cn]);}return s}removeListener(e,t){return this.off(e,t)}off(e,t){let s=super.off(e,t);return e==="data"&&(this[Jt]=this.listeners("data").length,this[Jt]===0&&!this[Xe]&&!this[Be].length&&(this[Ie]=false)),s}removeAllListeners(e){let t=super.removeAllListeners(e);return (e==="data"||e===void 0)&&(this[Jt]=0,!this[Xe]&&!this[Be].length&&(this[Ie]=false)),t}get emittedEnd(){return this[Lt]}[xt](){!this[br]&&!this[Lt]&&!this[ke]&&this[Me].length===0&&this[vt]&&(this[br]=true,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[wr]&&this.emit("close"),this[br]=false);}emit(e,...t){let s=t[0];if(e!=="error"&&e!=="close"&&e!==ke&&this[ke])return false;if(e==="data")return !this[Ne]&&!s?false:this[gt]?(dn(()=>this[oo](s)),true):this[oo](s);if(e==="end")return this[Al]();if(e==="close"){if(this[wr]=true,!this[Lt]&&!this[ke])return false;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[cn]=s,super.emit(io,s);let i=!this[pn]||this.listeners("error").length?super.emit("error",s):false;return this[xt](),i}else if(e==="resume"){let i=super.emit("resume");return this[xt](),i}else if(e==="finish"||e==="prefinish"){let i=super.emit(e);return this.removeAllListeners(e),i}let n=super.emit(e,...t);return this[xt](),n}[oo](e){for(let s of this[Be])s.dest.write(e)===false&&this.pause();let t=this[Xe]?false:super.emit("data",e);return this[xt](),t}[Al](){return this[Lt]?false:(this[Lt]=true,this.readable=false,this[gt]?(dn(()=>this[ao]()),true):this[ao]())}[ao](){if(this[vs]){let t=this[vs].end();if(t){for(let s of this[Be])s.dest.write(t);this[Xe]||super.emit("data",t);}}for(let t of this[Be])t.end();let e=super.emit("end");return this.removeAllListeners("end"),e}async collect(){let e=Object.assign([],{dataLength:0});this[Ne]||(e.dataLength=0);let t=this.promise();return this.on("data",s=>{e.push(s),this[Ne]||(e.dataLength+=s.length);}),await t,e}async concat(){if(this[Ne])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[ct]?e.join(""):Buffer.concat(e,e.dataLength)}async promise(){return new Promise((e,t)=>{this.on(ke,()=>t(new Error("stream destroyed"))),this.on("error",s=>t(s)),this.on("end",()=>e());})}[Symbol.asyncIterator](){this[Xe]=false;let e=false,t=async()=>(this.pause(),e=true,{value:void 0,done:true});return {next:()=>{if(e)return t();let n=this.read();if(n!==null)return Promise.resolve({done:false,value:n});if(this[vt])return t();let i,o,a=p=>{this.off("data",l),this.off("end",c),this.off(ke,u),t(),o(p);},l=p=>{this.off("error",a),this.off("end",c),this.off(ke,u),this.pause(),i({value:p,done:!!this[vt]});},c=()=>{this.off("error",a),this.off("data",l),this.off(ke,u),t(),i({done:true,value:void 0});},u=()=>a(new Error("stream destroyed"));return new Promise((p,d)=>{o=d,i=p,this.once(ke,u),this.once("error",a),this.once("end",c),this.once("data",l);})},throw:t,return:t,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[Xe]=false;let e=false,t=()=>(this.pause(),this.off(io,t),this.off(ke,t),this.off("end",t),e=true,{done:true,value:void 0}),s=()=>{if(e)return t();let n=this.read();return n===null?t():{done:false,value:n}};return this.once("end",t),this.once(io,t),this.once(ke,t),{next:s,throw:t,return:t,[Symbol.iterator](){return this}}}destroy(e){if(this[ke])return e?this.emit("error",e):this.emit(ke),this;this[ke]=true,this[Xe]=true,this[Me].length=0,this[Ae]=0;let t=this;return typeof t.close=="function"&&!this[wr]&&t.close(),e?this.emit("error",e):this.emit(ke),this}static get isStream(){return bm}};var Dm=realpathSync.native,hn={lstatSync:lstatSync,readdir:readdir$1,readdirSync:readdirSync,readlinkSync:readlinkSync,realpathSync:Dm,promises:{lstat:lstat,readdir:readdir,readlink:readlink,realpath:realpath}},Nl=r=>!r||r===hn||r===xe?hn:{...hn,...r,promises:{...hn.promises,...r.promises||{}}},Fl=/^\\\\\?\\([a-z]:)\\?$/i,jm=r=>r.replace(/\//g,"\\").replace(Fl,"$1\\"),Gm=/[\\\/]/,st=0,Ul=1,jl=2,ft=4,Gl=6,Bl=8,Kt=10,Wl=12,tt=15,mn=~tt,po=16,Ol=32,gn=64,ut=128,xr=256,Cr=512,Ll=gn|ut|Cr,Bm=1023,mo=r=>r.isFile()?Bl:r.isDirectory()?ft:r.isSymbolicLink()?Kt:r.isCharacterDevice()?jl:r.isBlockDevice()?Gl:r.isSocket()?Wl:r.isFIFO()?Ul:st,Dl=new Map,fn=r=>{let e=Dl.get(r);if(e)return e;let t=r.normalize("NFKD");return Dl.set(r,t),t},$l=new Map,Tr=r=>{let e=$l.get(r);if(e)return e;let t=fn(r.toLowerCase());return $l.set(r,t),t},Rr=class extends ln{constructor(){super({max:256});}},go=class extends ln{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1});}},Hl=Symbol("PathScurry setAsCwd"),Fe=class{name;root;roots;parent;nocase;isCWD=false;#e;#t;get dev(){return this.#t}#i;get mode(){return this.#i}#n;get nlink(){return this.#n}#o;get uid(){return this.#o}#_;get gid(){return this.#_}#c;get rdev(){return this.#c}#p;get blksize(){return this.#p}#a;get ino(){return this.#a}#l;get size(){return this.#l}#r;get blocks(){return this.#r}#f;get atimeMs(){return this.#f}#y;get mtimeMs(){return this.#y}#m;get ctimeMs(){return this.#m}#d;get birthtimeMs(){return this.#d}#v;get atime(){return this.#v}#g;get mtime(){return this.#g}#x;get ctime(){return this.#x}#T;get birthtime(){return this.#T}#w;#S;#k;#h;#I;#C;#s;#P;#b;#M;get parentPath(){return (this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=st,s,n,i,o,a){this.name=e,this.#w=i?Tr(e):fn(e),this.#s=t&Bm,this.nocase=i,this.roots=n,this.root=s||this,this.#P=o,this.#k=a.fullpath,this.#I=a.relative,this.#C=a.relativePosix,this.parent=a.parent,this.parent?this.#e=this.parent.#e:this.#e=Nl(a.fs);}depth(){return this.#S!==void 0?this.#S:this.parent?this.#S=this.parent.depth()+1:this.#S=0}childrenCache(){return this.#P}resolve(e){if(!e)return this;let t=this.getRootString(e),n=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#O(n):this.#O(n)}#O(e){let t=this;for(let s of e)t=t.child(s);return t}children(){let e=this.#P.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#P.set(this,t),this.#s&=~po,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let s=this.children(),n=this.nocase?Tr(e):fn(e);for(let l of s)if(l.#w===n)return l;let i=this.parent?this.sep:"",o=this.#k?this.#k+i+e:void 0,a=this.newChild(e,st,{...t,parent:this,fullpath:o});return this.canReaddir()||(a.#s|=ut),s.push(a),a}relative(){if(this.isCWD)return "";if(this.#I!==void 0)return this.#I;let e=this.name,t=this.parent;if(!t)return this.#I=this.name;let s=t.relative();return s+(!s||!t.parent?"":this.sep)+e}relativePosix(){if(this.sep==="/")return this.relative();if(this.isCWD)return "";if(this.#C!==void 0)return this.#C;let e=this.name,t=this.parent;if(!t)return this.#C=this.fullpathPosix();let s=t.relativePosix();return s+(!s||!t.parent?"":"/")+e}fullpath(){if(this.#k!==void 0)return this.#k;let e=this.name,t=this.parent;if(!t)return this.#k=this.name;let n=t.fullpath()+(t.parent?this.sep:"")+e;return this.#k=n}fullpathPosix(){if(this.#h!==void 0)return this.#h;if(this.sep==="/")return this.#h=this.fullpath();if(!this.parent){let n=this.fullpath().replace(/\\/g,"/");return /^[a-z]:\//i.test(n)?this.#h=`//?/${n}`:this.#h=n}let e=this.parent,t=e.fullpathPosix(),s=t+(!t||!e.parent?"":"/")+this.name;return this.#h=s}isUnknown(){return (this.#s&tt)===st}isType(e){return this[`is${e}`]()}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.#s&tt)===Bl}isDirectory(){return (this.#s&tt)===ft}isCharacterDevice(){return (this.#s&tt)===jl}isBlockDevice(){return (this.#s&tt)===Gl}isFIFO(){return (this.#s&tt)===Ul}isSocket(){return (this.#s&tt)===Wl}isSymbolicLink(){return (this.#s&Kt)===Kt}lstatCached(){return this.#s&Ol?this:void 0}readlinkCached(){return this.#b}realpathCached(){return this.#M}readdirCached(){let e=this.children();return e.slice(0,e.provisional)}canReadlink(){if(this.#b)return true;if(!this.parent)return false;let e=this.#s&tt;return !(e!==st&&e!==Kt||this.#s&xr||this.#s&ut)}calledReaddir(){return !!(this.#s&po)}isENOENT(){return !!(this.#s&ut)}isNamed(e){return this.nocase?this.#w===Tr(e):this.#w===fn(e)}async readlink(){let e=this.#b;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=await this.#e.promises.readlink(this.fullpath()),s=(await this.parent.realpath())?.resolve(t);if(s)return this.#b=s}catch(t){this.#u(t.code);return}}readlinkSync(){let e=this.#b;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=this.#e.readlinkSync(this.fullpath()),s=this.parent.realpathSync()?.resolve(t);if(s)return this.#b=s}catch(t){this.#u(t.code);return}}#L(e){this.#s|=po;for(let t=e.provisional;t<e.length;t++){let s=e[t];s&&s.#D();}}#D(){this.#s&ut||(this.#s=(this.#s|ut)&mn,this.#R());}#R(){let e=this.children();e.provisional=0;for(let t of e)t.#D();}#E(){this.#s|=Cr,this.#$();}#$(){if(this.#s&gn)return;let e=this.#s;(e&tt)===ft&&(e&=mn),this.#s=e|gn,this.#R();}#N(e=""){e==="ENOTDIR"||e==="EPERM"?this.#$():e==="ENOENT"?this.#D():this.children().provisional=0;}#F(e=""){e==="ENOTDIR"?this.parent.#$():e==="ENOENT"&&this.#D();}#u(e=""){let t=this.#s;t|=xr,e==="ENOENT"&&(t|=ut),(e==="EINVAL"||e==="UNKNOWN")&&(t&=mn),this.#s=t,e==="ENOTDIR"&&this.parent&&this.parent.#$();}#U(e,t){return this.#A(e,t)||this.#j(e,t)}#j(e,t){let s=mo(e),n=this.newChild(e.name,s,{parent:this}),i=n.#s&tt;return i!==ft&&i!==Kt&&i!==st&&(n.#s|=gn),t.unshift(n),t.provisional++,n}#A(e,t){for(let s=t.provisional;s<t.length;s++){let n=t[s];if((this.nocase?Tr(e.name):fn(e.name))===n.#w)return this.#G(e,n,s,t)}}#G(e,t,s,n){let i=t.name;return t.#s=t.#s&mn|mo(e),i!==e.name&&(t.name=e.name),s!==n.provisional&&(s===n.length-1?n.pop():n.splice(s,1),n.unshift(t)),n.provisional++,t}async lstat(){if((this.#s&ut)===0)try{return this.#z(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#F(e.code);}}lstatSync(){if((this.#s&ut)===0)try{return this.#z(this.#e.lstatSync(this.fullpath())),this}catch(e){this.#F(e.code);}}#z(e){let{atime:t,atimeMs:s,birthtime:n,birthtimeMs:i,blksize:o,blocks:a,ctime:l,ctimeMs:c,dev:u,gid:p,ino:d,mode:m,mtime:h,mtimeMs:g,nlink:y,rdev:b,size:w,uid:S}=e;this.#v=t,this.#f=s,this.#T=n,this.#d=i,this.#p=o,this.#r=a,this.#x=l,this.#m=c,this.#t=u,this.#_=p,this.#a=d,this.#i=m,this.#g=h,this.#y=g,this.#n=y,this.#c=b,this.#l=w,this.#o=S;let x=mo(e);this.#s=this.#s&mn|x|Ol,x!==st&&x!==ft&&x!==Kt&&(this.#s|=gn);}#W=[];#H=false;#q(e){this.#H=false;let t=this.#W.slice();this.#W.length=0,t.forEach(s=>s(null,e));}readdirCB(e,t=false){if(!this.canReaddir()){t?e(null,[]):queueMicrotask(()=>e(null,[]));return}let s=this.children();if(this.calledReaddir()){let i=s.slice(0,s.provisional);t?e(null,i):queueMicrotask(()=>e(null,i));return}if(this.#W.push(e),this.#H)return;this.#H=true;let n=this.fullpath();this.#e.readdir(n,{withFileTypes:true},(i,o)=>{if(i)this.#N(i.code),s.provisional=0;else {for(let a of o)this.#U(a,s);this.#L(s);}this.#q(s.slice(0,s.provisional));});}#B;async readdir(){if(!this.canReaddir())return [];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();if(this.#B)await this.#B;else {let s=()=>{};this.#B=new Promise(n=>s=n);try{for(let n of await this.#e.promises.readdir(t,{withFileTypes:!0}))this.#U(n,e);this.#L(e);}catch(n){this.#N(n.code),e.provisional=0;}this.#B=void 0,s();}return e.slice(0,e.provisional)}readdirSync(){if(!this.canReaddir())return [];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();try{for(let s of this.#e.readdirSync(t,{withFileTypes:!0}))this.#U(s,e);this.#L(e);}catch(s){this.#N(s.code),e.provisional=0;}return e.slice(0,e.provisional)}canReaddir(){if(this.#s&Ll)return false;let e=tt&this.#s;return e===st||e===ft||e===Kt}shouldWalk(e,t){return (this.#s&ft)===ft&&!(this.#s&Ll)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#M)return this.#M;if(!((Cr|xr|ut)&this.#s))try{let e=await this.#e.promises.realpath(this.fullpath());return this.#M=this.resolve(e)}catch{this.#E();}}realpathSync(){if(this.#M)return this.#M;if(!((Cr|xr|ut)&this.#s))try{let e=this.#e.realpathSync(this.fullpath());return this.#M=this.resolve(e)}catch{this.#E();}}[Hl](e){if(e===this)return;e.isCWD=false,this.isCWD=true;let t=new Set([]),s=[],n=this;for(;n&&n.parent;)t.add(n),n.#I=s.join(this.sep),n.#C=s.join("/"),n=n.parent,s.push("..");for(n=e;n&&n.parent&&!t.has(n);)n.#I=void 0,n.#C=void 0,n=n.parent;}},Er=class r extends Fe{sep="\\";splitSep=Gm;constructor(e,t=st,s,n,i,o,a){super(e,t,s,n,i,o,a);}newChild(e,t=st,s={}){return new r(e,t,this.root,this.roots,this.nocase,this.childrenCache(),s)}getRootString(e){return win32.parse(e).root}getRoot(e){if(e=jm(e.toUpperCase()),e===this.root.name)return this.root;for(let[t,s]of Object.entries(this.roots))if(this.sameRoot(e,t))return this.roots[e]=s;return this.roots[e]=new Ts(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(Fl,"$1\\"),e===t}},Ir=class r extends Fe{splitSep="/";sep="/";constructor(e,t=st,s,n,i,o,a){super(e,t,s,n,i,o,a);}getRootString(e){return e.startsWith("/")?"/":""}getRoot(e){return this.root}newChild(e,t=st,s={}){return new r(e,t,this.root,this.roots,this.nocase,this.childrenCache(),s)}},Mr=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#n;constructor(e=process.cwd(),t,s,{nocase:n,childrenCacheSize:i=16*1024,fs:o=hn}={}){this.#n=Nl(o),(e instanceof URL||e.startsWith("file://"))&&(e=fileURLToPath(e));let a=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(a),this.#e=new Rr,this.#t=new Rr,this.#i=new go(i);let l=a.substring(this.rootPath.length).split(s);if(l.length===1&&!l[0]&&l.pop(),n===void 0)throw new TypeError("must provide nocase setting to PathScurryBase ctor");this.nocase=n,this.root=this.newRoot(this.#n),this.roots[this.rootPath]=this.root;let c=this.root,u=l.length-1,p=t.sep,d=this.rootPath,m=false;for(let h of l){let g=u--;c=c.child(h,{relative:new Array(g).fill("..").join(p),relativePosix:new Array(g).fill("..").join("/"),fullpath:d+=(m?"":p)+h}),m=true;}this.cwd=c;}depth(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.depth()}childrenCache(){return this.#i}resolve(...e){let t="";for(let i=e.length-1;i>=0;i--){let o=e[i];if(!(!o||o===".")&&(t=t?`${o}/${t}`:o,this.isAbsolute(o)))break}let s=this.#e.get(t);if(s!==void 0)return s;let n=this.cwd.resolve(t).fullpath();return this.#e.set(t,n),n}resolvePosix(...e){let t="";for(let i=e.length-1;i>=0;i--){let o=e[i];if(!(!o||o===".")&&(t=t?`${o}/${t}`:o,this.isAbsolute(o)))break}let s=this.#t.get(t);if(s!==void 0)return s;let n=this.cwd.resolve(t).fullpathPosix();return this.#t.set(t,n),n}relative(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relative()}relativePosix(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relativePosix()}basename(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.name}dirname(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),(e.parent||e).fullpath()}async readdir(e=this.cwd,t={withFileTypes:true}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s}=t;if(e.canReaddir()){let n=await e.readdir();return s?n:n.map(i=>i.name)}else return []}readdirSync(e=this.cwd,t={withFileTypes:true}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true}=t;return e.canReaddir()?s?e.readdirSync():e.readdirSync().map(n=>n.name):[]}async lstat(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstat()}lstatSync(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstatSync()}async readlink(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=await e.readlink();return t?s:s?.fullpath()}readlinkSync(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=e.readlinkSync();return t?s:s?.fullpath()}async realpath(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=await e.realpath();return t?s:s?.fullpath()}realpathSync(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=e.realpathSync();return t?s:s?.fullpath()}async walk(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=[];(!i||i(e))&&a.push(s?e:e.fullpath());let l=new Set,c=(p,d)=>{l.add(p),p.readdirCB((m,h)=>{if(m)return d(m);let g=h.length;if(!g)return d();let y=()=>{--g===0&&d();};for(let b of h)(!i||i(b))&&a.push(s?b:b.fullpath()),n&&b.isSymbolicLink()?b.realpath().then(w=>w?.isUnknown()?w.lstat():w).then(w=>w?.shouldWalk(l,o)?c(w,y):y()):b.shouldWalk(l,o)?c(b,y):y();},true);},u=e;return new Promise((p,d)=>{c(u,m=>{if(m)return d(m);p(a);});})}walkSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=[];(!i||i(e))&&a.push(s?e:e.fullpath());let l=new Set([e]);for(let c of l){let u=c.readdirSync();for(let p of u){(!i||i(p))&&a.push(s?p:p.fullpath());let d=p;if(p.isSymbolicLink()){if(!(n&&(d=p.realpathSync())))continue;d.isUnknown()&&d.lstatSync();}d.shouldWalk(l,o)&&l.add(d);}}return a}[Symbol.asyncIterator](){return this.iterate()}iterate(e=this.cwd,t={}){return typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd),this.stream(e,t)[Symbol.asyncIterator]()}[Symbol.iterator](){return this.iterateSync()}*iterateSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t;(!i||i(e))&&(yield s?e:e.fullpath());let a=new Set([e]);for(let l of a){let c=l.readdirSync();for(let u of c){(!i||i(u))&&(yield s?u:u.fullpath());let p=u;if(u.isSymbolicLink()){if(!(n&&(p=u.realpathSync())))continue;p.isUnknown()&&p.lstatSync();}p.shouldWalk(a,o)&&a.add(p);}}}stream(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=new Dt({objectMode:true});(!i||i(e))&&a.write(s?e:e.fullpath());let l=new Set,c=[e],u=0,p=()=>{let d=false;for(;!d;){let m=c.shift();if(!m){u===0&&a.end();return}u++,l.add(m);let h=(y,b,w=false)=>{if(y)return a.emit("error",y);if(n&&!w){let S=[];for(let x of b)x.isSymbolicLink()&&S.push(x.realpath().then(R=>R?.isUnknown()?R.lstat():R));if(S.length){Promise.all(S).then(()=>h(null,b,true));return}}for(let S of b)S&&(!i||i(S))&&(a.write(s?S:S.fullpath())||(d=true));u--;for(let S of b){let x=S.realpathCached()||S;x.shouldWalk(l,o)&&c.push(x);}d&&!a.flowing?a.once("drain",p):g||p();},g=true;m.readdirCB(h,true),g=false;}};return p(),a}streamSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=new Dt({objectMode:true}),l=new Set;(!i||i(e))&&a.write(s?e:e.fullpath());let c=[e],u=0,p=()=>{let d=false;for(;!d;){let m=c.shift();if(!m){u===0&&a.end();return}u++,l.add(m);let h=m.readdirSync();for(let g of h)(!i||i(g))&&(a.write(s?g:g.fullpath())||(d=true));u--;for(let g of h){let y=g;if(g.isSymbolicLink()){if(!(n&&(y=g.realpathSync())))continue;y.isUnknown()&&y.lstatSync();}y.shouldWalk(l,o)&&c.push(y);}}d&&!a.flowing&&a.once("drain",p);};return p(),a}chdir(e=this.cwd){let t=this.cwd;this.cwd=typeof e=="string"?this.cwd.resolve(e):e,this.cwd[Hl](t);}},Ts=class extends Mr{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:s=true}=t;super(e,win32,"\\",{...t,nocase:s}),this.nocase=s;for(let n=this.cwd;n;n=n.parent)n.nocase=this.nocase;}parseRootPath(e){return win32.parse(e).root.toUpperCase()}newRoot(e){return new Er(this.rootPath,ft,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},Cs=class extends Mr{sep="/";constructor(e=process.cwd(),t={}){let{nocase:s=false}=t;super(e,posix,"/",{...t,nocase:s}),this.nocase=s;}parseRootPath(e){return "/"}newRoot(e){return new Ir(this.rootPath,ft,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},yn=class extends Cs{constructor(e=process.cwd(),t={}){let{nocase:s=true}=t;super(e,{...t,nocase:s});}};process.platform==="win32"?Er:Ir;var zl=process.platform==="win32"?Ts:process.platform==="darwin"?yn:Cs;var Wm=r=>r.length>=1,Hm=r=>r.length>=1,Rs=class r{#e;#t;#i;length;#n;#o;#_;#c;#p;#a;#l=true;constructor(e,t,s,n){if(!Wm(e))throw new TypeError("empty pattern list");if(!Hm(t))throw new TypeError("empty glob list");if(t.length!==e.length)throw new TypeError("mismatched pattern list and glob list lengths");if(this.length=e.length,s<0||s>=this.length)throw new TypeError("index out of range");if(this.#e=e,this.#t=t,this.#i=s,this.#n=n,this.#i===0){if(this.isUNC()){let[i,o,a,l,...c]=this.#e,[u,p,d,m,...h]=this.#t;c[0]===""&&(c.shift(),h.shift());let g=[i,o,a,l,""].join("/"),y=[u,p,d,m,""].join("/");this.#e=[g,...c],this.#t=[y,...h],this.length=this.#e.length;}else if(this.isDrive()||this.isAbsolute()){let[i,...o]=this.#e,[a,...l]=this.#t;o[0]===""&&(o.shift(),l.shift());let c=i+"/",u=a+"/";this.#e=[c,...o],this.#t=[u,...l],this.length=this.#e.length;}}}pattern(){return this.#e[this.#i]}isString(){return typeof this.#e[this.#i]=="string"}isGlobstar(){return this.#e[this.#i]===Pe}isRegExp(){return this.#e[this.#i]instanceof RegExp}globString(){return this.#_=this.#_||(this.#i===0?this.isAbsolute()?this.#t[0]+this.#t.slice(1).join("/"):this.#t.join("/"):this.#t.slice(this.#i).join("/"))}hasMore(){return this.length>this.#i+1}rest(){return this.#o!==void 0?this.#o:this.hasMore()?(this.#o=new r(this.#e,this.#t,this.#i+1,this.#n),this.#o.#a=this.#a,this.#o.#p=this.#p,this.#o.#c=this.#c,this.#o):this.#o=null}isUNC(){let e=this.#e;return this.#p!==void 0?this.#p:this.#p=this.#n==="win32"&&this.#i===0&&e[0]===""&&e[1]===""&&typeof e[2]=="string"&&!!e[2]&&typeof e[3]=="string"&&!!e[3]}isDrive(){let e=this.#e;return this.#c!==void 0?this.#c:this.#c=this.#n==="win32"&&this.#i===0&&this.length>1&&typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0])}isAbsolute(){let e=this.#e;return this.#a!==void 0?this.#a:this.#a=e[0]===""&&e.length>1||this.isDrive()||this.isUNC()}root(){let e=this.#e[0];return typeof e=="string"&&this.isAbsolute()&&this.#i===0?e:""}checkFollowGlobstar(){return !(this.#i===0||!this.isGlobstar()||!this.#l)}markFollowGlobstar(){return this.#i===0||!this.isGlobstar()||!this.#l?false:(this.#l=false,true)}};var zm=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",Es=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:s,noext:n,noglobstar:i,platform:o=zm}){this.relative=[],this.absolute=[],this.relativeChildren=[],this.absoluteChildren=[],this.platform=o,this.mmopts={dot:true,nobrace:t,nocase:s,noext:n,noglobstar:i,optimizationLevel:2,platform:o,nocomment:true,nonegate:true};for(let a of e)this.add(a);}add(e){let t=new Ye(e,this.mmopts);for(let s=0;s<t.set.length;s++){let n=t.set[s],i=t.globParts[s];if(!n||!i)throw new Error("invalid pattern object");for(;n[0]==="."&&i[0]===".";)n.shift(),i.shift();let o=new Rs(n,i,0,this.platform),a=new Ye(o.globString(),this.mmopts),l=i[i.length-1]==="**",c=o.isAbsolute();c?this.absolute.push(a):this.relative.push(a),l&&(c?this.absoluteChildren.push(a):this.relativeChildren.push(a));}}ignored(e){let t=e.fullpath(),s=`${t}/`,n=e.relative()||".",i=`${n}/`;for(let o of this.relative)if(o.match(n)||o.match(i))return true;for(let o of this.absolute)if(o.match(t)||o.match(s))return true;return false}childrenIgnored(e){let t=e.fullpath()+"/",s=(e.relative()||".")+"/";for(let n of this.relativeChildren)if(n.match(s))return true;for(let n of this.absoluteChildren)if(n.match(t))return true;return false}};var fo=class r{store;constructor(e=new Map){this.store=e;}copy(){return new r(new Map(this.store))}hasWalked(e,t){return this.store.get(e.fullpath())?.has(t.globString())}storeWalked(e,t){let s=e.fullpath(),n=this.store.get(s);n?n.add(t.globString()):this.store.set(s,new Set([t.globString()]));}},yo=class{store=new Map;add(e,t,s){let n=(t?2:0)|(s?1:0),i=this.store.get(e);this.store.set(e,i===void 0?n:n&i);}entries(){return [...this.store.entries()].map(([e,t])=>[e,!!(t&2),!!(t&1)])}},bo=class{store=new Map;add(e,t){if(!e.canReaddir())return;let s=this.store.get(e);s?s.find(n=>n.globString()===t.globString())||s.push(t):this.store.set(e,[t]);}get(e){let t=this.store.get(e);if(!t)throw new Error("attempting to walk unknown path");return t}entries(){return this.keys().map(e=>[e,this.store.get(e)])}keys(){return [...this.store.keys()].filter(e=>e.canReaddir())}},bn=class r{hasWalkedCache;matches=new yo;subwalks=new bo;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new fo;}processPatterns(e,t){this.patterns=t;let s=t.map(n=>[e,n]);for(let[n,i]of s){this.hasWalkedCache.storeWalked(n,i);let o=i.root(),a=i.isAbsolute()&&this.opts.absolute!==false;if(o){n=n.resolve(o==="/"&&this.opts.root!==void 0?this.opts.root:o);let p=i.rest();if(p)i=p;else {this.matches.add(n,true,false);continue}}if(n.isENOENT())continue;let l,c,u=false;for(;typeof(l=i.pattern())=="string"&&(c=i.rest());)n=n.resolve(l),i=c,u=true;if(l=i.pattern(),c=i.rest(),u){if(this.hasWalkedCache.hasWalked(n,i))continue;this.hasWalkedCache.storeWalked(n,i);}if(typeof l=="string"){let p=l===".."||l===""||l===".";this.matches.add(n.resolve(l),a,p);continue}else if(l===Pe){(!n.isSymbolicLink()||this.follow||i.checkFollowGlobstar())&&this.subwalks.add(n,i);let p=c?.pattern(),d=c?.rest();if(!c||(p===""||p===".")&&!d)this.matches.add(n,a,p===""||p===".");else if(p===".."){let m=n.parent||n;d?this.hasWalkedCache.hasWalked(m,d)||this.subwalks.add(m,d):this.matches.add(m,a,true);}}else l instanceof RegExp&&this.subwalks.add(n,i);}return this}subwalkTargets(){return this.subwalks.keys()}child(){return new r(this.opts,this.hasWalkedCache)}filterEntries(e,t){let s=this.subwalks.get(e),n=this.child();for(let i of t)for(let o of s){let a=o.isAbsolute(),l=o.pattern(),c=o.rest();l===Pe?n.testGlobstar(i,o,c,a):l instanceof RegExp?n.testRegExp(i,l,c,a):n.testString(i,l,c,a);}return n}testGlobstar(e,t,s,n){if((this.dot||!e.name.startsWith("."))&&(t.hasMore()||this.matches.add(e,n,false),e.canReaddir()&&(this.follow||!e.isSymbolicLink()?this.subwalks.add(e,t):e.isSymbolicLink()&&(s&&t.checkFollowGlobstar()?this.subwalks.add(e,s):t.markFollowGlobstar()&&this.subwalks.add(e,t)))),s){let i=s.pattern();if(typeof i=="string"&&i!==".."&&i!==""&&i!==".")this.testString(e,i,s.rest(),n);else if(i===".."){let o=e.parent||e;this.subwalks.add(o,s);}else i instanceof RegExp&&this.testRegExp(e,i,s.rest(),n);}}testRegExp(e,t,s,n){t.test(e.name)&&(s?this.subwalks.add(e,s):this.matches.add(e,n,false));}testString(e,t,s,n){e.isNamed(t)&&(s?this.subwalks.add(e,s):this.matches.add(e,n,false));}};var qm=(r,e)=>typeof r=="string"?new Es([r],e):Array.isArray(r)?new Es(r,e):r,Ar=class{path;patterns;opts;seen=new Set;paused=false;aborted=false;#e=[];#t;#i;signal;maxDepth;includeChildMatches;constructor(e,t,s){if(this.patterns=e,this.path=t,this.opts=s,this.#i=!s.posix&&s.platform==="win32"?"\\":"/",this.includeChildMatches=s.includeChildMatches!==false,(s.ignore||!this.includeChildMatches)&&(this.#t=qm(s.ignore??[],s),!this.includeChildMatches&&typeof this.#t.add!="function")){let n="cannot ignore child matches, ignore lacks add() method.";throw new Error(n)}this.maxDepth=s.maxDepth||1/0,s.signal&&(this.signal=s.signal,this.signal.addEventListener("abort",()=>{this.#e.length=0;}));}#n(e){return this.seen.has(e)||!!this.#t?.ignored?.(e)}#o(e){return !!this.#t?.childrenIgnored?.(e)}pause(){this.paused=true;}resume(){if(this.signal?.aborted)return;this.paused=false;let e;for(;!this.paused&&(e=this.#e.shift());)e();}onResume(e){this.signal?.aborted||(this.paused?this.#e.push(e):e());}async matchCheck(e,t){if(t&&this.opts.nodir)return;let s;if(this.opts.realpath){if(s=e.realpathCached()||await e.realpath(),!s)return;e=s;}let i=e.isUnknown()||this.opts.stat?await e.lstat():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let o=await i.realpath();o&&(o.isUnknown()||this.opts.stat)&&await o.lstat();}return this.matchCheckTest(i,t)}matchCheckTest(e,t){return e&&(this.maxDepth===1/0||e.depth()<=this.maxDepth)&&(!t||e.canReaddir())&&(!this.opts.nodir||!e.isDirectory())&&(!this.opts.nodir||!this.opts.follow||!e.isSymbolicLink()||!e.realpathCached()?.isDirectory())&&!this.#n(e)?e:void 0}matchCheckSync(e,t){if(t&&this.opts.nodir)return;let s;if(this.opts.realpath){if(s=e.realpathCached()||e.realpathSync(),!s)return;e=s;}let i=e.isUnknown()||this.opts.stat?e.lstatSync():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let o=i.realpathSync();o&&(o?.isUnknown()||this.opts.stat)&&o.lstatSync();}return this.matchCheckTest(i,t)}matchFinish(e,t){if(this.#n(e))return;if(!this.includeChildMatches&&this.#t?.add){let i=`${e.relativePosix()}/**`;this.#t.add(i);}let s=this.opts.absolute===void 0?t:this.opts.absolute;this.seen.add(e);let n=this.opts.mark&&e.isDirectory()?this.#i:"";if(this.opts.withFileTypes)this.matchEmit(e);else if(s){let i=this.opts.posix?e.fullpathPosix():e.fullpath();this.matchEmit(i+n);}else {let i=this.opts.posix?e.relativePosix():e.relative(),o=this.opts.dotRelative&&!i.startsWith(".."+this.#i)?"."+this.#i:"";this.matchEmit(i?o+i+n:"."+n);}}async match(e,t,s){let n=await this.matchCheck(e,s);n&&this.matchFinish(n,t);}matchSync(e,t,s){let n=this.matchCheckSync(e,s);n&&this.matchFinish(n,t);}walkCB(e,t,s){this.signal?.aborted&&s(),this.walkCB2(e,t,new bn(this.opts),s);}walkCB2(e,t,s,n){if(this.#o(e))return n();if(this.signal?.aborted&&n(),this.paused){this.onResume(()=>this.walkCB2(e,t,s,n));return}s.processPatterns(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||(i++,this.match(a,l,c).then(()=>o()));for(let a of s.subwalkTargets()){if(this.maxDepth!==1/0&&a.depth()>=this.maxDepth)continue;i++;let l=a.readdirCached();a.calledReaddir()?this.walkCB3(a,l,s,o):a.readdirCB((c,u)=>this.walkCB3(a,u,s,o),true);}o();}walkCB3(e,t,s,n){s=s.filterEntries(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||(i++,this.match(a,l,c).then(()=>o()));for(let[a,l]of s.subwalks.entries())i++,this.walkCB2(a,l,s.child(),o);o();}walkCBSync(e,t,s){this.signal?.aborted&&s(),this.walkCB2Sync(e,t,new bn(this.opts),s);}walkCB2Sync(e,t,s,n){if(this.#o(e))return n();if(this.signal?.aborted&&n(),this.paused){this.onResume(()=>this.walkCB2Sync(e,t,s,n));return}s.processPatterns(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||this.matchSync(a,l,c);for(let a of s.subwalkTargets()){if(this.maxDepth!==1/0&&a.depth()>=this.maxDepth)continue;i++;let l=a.readdirSync();this.walkCB3Sync(a,l,s,o);}o();}walkCB3Sync(e,t,s,n){s=s.filterEntries(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||this.matchSync(a,l,c);for(let[a,l]of s.subwalks.entries())i++,this.walkCB2Sync(a,l,s.child(),o);o();}},wn=class extends Ar{matches=new Set;constructor(e,t,s){super(e,t,s);}matchEmit(e){this.matches.add(e);}async walk(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&await this.path.lstat(),await new Promise((e,t)=>{this.walkCB(this.path,this.patterns,()=>{this.signal?.aborted?t(this.signal.reason):e(this.matches);});}),this.matches}walkSync(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>{if(this.signal?.aborted)throw this.signal.reason}),this.matches}},_n=class extends Ar{results;constructor(e,t,s){super(e,t,s),this.results=new Dt({signal:this.signal,objectMode:true}),this.results.on("drain",()=>this.resume()),this.results.on("resume",()=>this.resume());}matchEmit(e){this.results.write(e),this.results.flowing||this.pause();}stream(){let e=this.path;return e.isUnknown()?e.lstat().then(()=>{this.walkCB(e,this.patterns,()=>this.results.end());}):this.walkCB(e,this.patterns,()=>this.results.end()),this.results}streamSync(){return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>this.results.end()),this.results}};var Km=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",pt=class{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(e,t){if(!t)throw new TypeError("glob options required");if(this.withFileTypes=!!t.withFileTypes,this.signal=t.signal,this.follow=!!t.follow,this.dot=!!t.dot,this.dotRelative=!!t.dotRelative,this.nodir=!!t.nodir,this.mark=!!t.mark,t.cwd?(t.cwd instanceof URL||t.cwd.startsWith("file://"))&&(t.cwd=fileURLToPath(t.cwd)):this.cwd="",this.cwd=t.cwd||"",this.root=t.root,this.magicalBraces=!!t.magicalBraces,this.nobrace=!!t.nobrace,this.noext=!!t.noext,this.realpath=!!t.realpath,this.absolute=t.absolute,this.includeChildMatches=t.includeChildMatches!==false,this.noglobstar=!!t.noglobstar,this.matchBase=!!t.matchBase,this.maxDepth=typeof t.maxDepth=="number"?t.maxDepth:1/0,this.stat=!!t.stat,this.ignore=t.ignore,this.withFileTypes&&this.absolute!==void 0)throw new Error("cannot set absolute and withFileTypes:true");if(typeof e=="string"&&(e=[e]),this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===false,this.windowsPathsNoEscape&&(e=e.map(l=>l.replace(/\\/g,"/"))),this.matchBase){if(t.noglobstar)throw new TypeError("base matching requires globstar");e=e.map(l=>l.includes("/")?l:`./**/${l}`);}if(this.pattern=e,this.platform=t.platform||Km,this.opts={...t,platform:this.platform},t.scurry){if(this.scurry=t.scurry,t.nocase!==void 0&&t.nocase!==t.scurry.nocase)throw new Error("nocase option contradicts provided scurry option")}else {let l=t.platform==="win32"?Ts:t.platform==="darwin"?yn:t.platform?Cs:zl;this.scurry=new l(this.cwd,{nocase:t.nocase,fs:t.fs});}this.nocase=this.scurry.nocase;let s=this.platform==="darwin"||this.platform==="win32",n={...t,dot:this.dot,matchBase:this.matchBase,nobrace:this.nobrace,nocase:this.nocase,nocaseMagicOnly:s,nocomment:true,noext:this.noext,nonegate:true,optimizationLevel:2,platform:this.platform,windowsPathsNoEscape:this.windowsPathsNoEscape,debug:!!this.opts.debug},i=this.pattern.map(l=>new Ye(l,n)),[o,a]=i.reduce((l,c)=>(l[0].push(...c.set),l[1].push(...c.globParts),l),[[],[]]);this.patterns=o.map((l,c)=>{let u=a[c];if(!u)throw new Error("invalid pattern object");return new Rs(l,u,0,this.platform)});}async walk(){return [...await new wn(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 wn(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 _n(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 _n(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 wo=(r,e={})=>{Array.isArray(r)||(r=[r]);for(let t of r)if(new Ye(t,e).hasMagic())return true;return false};function Pr(r,e={}){return new pt(r,e).streamSync()}function Jl(r,e={}){return new pt(r,e).stream()}function Kl(r,e={}){return new pt(r,e).walkSync()}async function ql(r,e={}){return new pt(r,e).walk()}function Or(r,e={}){return new pt(r,e).iterateSync()}function Vl(r,e={}){return new pt(r,e).iterate()}var Vm=Pr,Ym=Object.assign(Jl,{sync:Pr}),Xm=Or,Zm=Object.assign(Vl,{sync:Or}),Qm=Object.assign(Kl,{stream:Pr,iterate:Or}),Is=Object.assign(ql,{glob:ql,globSync:Kl,sync:Qm,globStream:Jl,stream:Ym,globStreamSync:Pr,streamSync:Vm,globIterate:Vl,iterate:Zm,globIterateSync:Or,iterateSync:Xm,Glob:pt,hasMagic:wo,escape:_s,unescape:lt});Is.glob=Is;var Sn=class{languageId="typescript";extensions=[".ts",".tsx",".js",".jsx",".mjs",".cjs"];async parse(e,t){let s=e.split(`
|
|
629
|
+
>>> no match, partial?`,e,d,t,m),d===l))}let g;if(typeof u=="string"?(g=p===u,this.debug("string match",u,p,g)):(g=u.test(p),this.debug("pattern match",u,p,g)),!g)return false}if(o===l&&a===c)return true;if(o===l)return s;if(a===c)return o===l-1&&e[o]==="";throw new Error("wtf?")}braceExpand(){return Cl(this.pattern,this.options)}parse(e){an(e);let t=this.options;if(e==="**")return Oe;if(e==="")return "";let s,n=null;(s=e.match(rm))?n=t.dot?om:im:(s=e.match(Kd))?n=(t.nocase?t.dot?Zd:Xd:t.dot?Yd:Vd)(s[1]):(s=e.match(am))?n=(t.nocase?t.dot?cm:lm:t.dot?um:pm)(s):(s=e.match(Qd))?n=t.dot?tm:em:(s=e.match(sm))&&(n=nm);let i=ws.fromGlob(e,this.options).toMMPattern();return n&&typeof i=="object"&&Reflect.defineProperty(i,"test",{value:n}),i}makeRe(){if(this.regexp||this.regexp===false)return this.regexp;let e=this.set;if(!e.length)return this.regexp=false,this.regexp;let t=this.options,s=t.noglobstar?hm:t.dot?gm:fm,n=new Set(t.nocase?["i"]:[]),i=e.map(l=>{let c=l.map(u=>{if(u instanceof RegExp)for(let p of u.flags.split(""))n.add(p);return typeof u=="string"?Sm(u):u===Oe?Oe:u._src});return c.forEach((u,p)=>{let d=c[p+1],m=c[p-1];u!==Oe||m===Oe||(m===void 0?d!==void 0&&d!==Oe?c[p+1]="(?:\\/|"+s+"\\/)?"+d:c[p]=s:d===void 0?c[p-1]=m+"(?:\\/|"+s+")?":d!==Oe&&(c[p-1]=m+"(?:\\/|\\/"+s+"\\/)"+d,c[p+1]=Oe));}),c.filter(u=>u!==Oe).join("/")}).join("|"),[o,a]=e.length>1?["(?:",")"]:["",""];i="^"+o+i+a+"$",this.negate&&(i="^(?!"+i+").+$");try{this.regexp=new RegExp(i,[...n].join(""));}catch{this.regexp=false;}return this.regexp}slashSplit(e){return this.preserveMultipleSlashes?e.split("/"):this.isWindows&&/^\/\/[^\/]+/.test(e)?["",...e.split(/\/+/)]:e.split(/\/+/)}match(e,t=this.partial){if(this.debug("match",e,this.pattern),this.comment)return false;if(this.empty)return e==="";if(e==="/"&&t)return true;let s=this.options;this.isWindows&&(e=e.split("\\").join("/"));let n=this.slashSplit(e);this.debug(this.pattern,"split",n);let i=this.set;this.debug(this.pattern,"set",i);let o=n[n.length-1];if(!o)for(let a=n.length-2;!o&&a>=0;a--)o=n[a];for(let a=0;a<i.length;a++){let l=i[a],c=n;if(s.matchBase&&l.length===1&&(c=[o]),this.matchOne(c,l,t))return s.flipNegate?true:!this.negate}return s.flipNegate?false:this.negate}static defaults(e){return Ge.defaults(e).Minimatch}};Ge.AST=ws;Ge.Minimatch=Ye;Ge.escape=_s;Ge.unescape=lt;var Ss=typeof performance=="object"&&performance&&typeof performance.now=="function"?performance:Date,El=new Set,oo=typeof process=="object"&&process?process:{},Il=(r,e,t,s)=>{typeof oo.emitWarning=="function"?oo.emitWarning(r,e,t,s):console.error(`[${t}] ${e}: ${r}`);},br=globalThis.AbortController,Rl=globalThis.AbortSignal;if(typeof br>"u"){Rl=class{onabort;_onabort=[];reason;aborted=false;addEventListener(s,n){this._onabort.push(n);}},br=class{constructor(){e();}signal=new Rl;abort(s){if(!this.signal.aborted){this.signal.reason=s,this.signal.aborted=true;for(let n of this.signal._onabort)n(s);this.signal.onabort?.(s);}}};let r=oo.env?.LRU_CACHE_IGNORE_AC_WARNING!=="1",e=()=>{r&&(r=false,Il("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",e));};}var km=r=>!El.has(r);var Ot=r=>r&&r===Math.floor(r)&&r>0&&isFinite(r),Ml=r=>Ot(r)?r<=Math.pow(2,8)?Uint8Array:r<=Math.pow(2,16)?Uint16Array:r<=Math.pow(2,32)?Uint32Array:r<=Number.MAX_SAFE_INTEGER?ks:null:null,ks=class extends Array{constructor(e){super(e),this.fill(0);}},ao=class r{heap;length;static#e=false;static create(e){let t=Ml(e);if(!t)return [];r.#e=true;let s=new r(e,t);return r.#e=false,s}constructor(e,t){if(!r.#e)throw new TypeError("instantiate Stack using Stack.create(n)");this.heap=new t(e),this.length=0;}push(e){this.heap[this.length++]=e;}pop(){return this.heap[--this.length]}},cn=class r{#e;#t;#i;#n;#o;#_;ttl;ttlResolution;ttlAutopurge;updateAgeOnGet;updateAgeOnHas;allowStale;noDisposeOnSet;noUpdateTTL;maxEntrySize;sizeCalculation;noDeleteOnFetchRejection;noDeleteOnStaleGet;allowStaleOnFetchAbort;allowStaleOnFetchRejection;ignoreFetchAbort;#c;#p;#a;#l;#r;#f;#y;#m;#d;#v;#g;#T;#x;#w;#S;#k;#h;static unsafeExposeInternals(e){return {starts:e.#x,ttls:e.#w,sizes:e.#T,keyMap:e.#a,keyList:e.#l,valList:e.#r,next:e.#f,prev:e.#y,get head(){return e.#m},get tail(){return e.#d},free:e.#v,isBackgroundFetch:t=>e.#u(t),backgroundFetch:(t,s,n,i)=>e.#F(t,s,n,i),moveToTail:t=>e.#j(t),indexes:t=>e.#R(t),rindexes:t=>e.#E(t),isStale:t=>e.#b(t)}}get max(){return this.#e}get maxSize(){return this.#t}get calculatedSize(){return this.#p}get size(){return this.#c}get fetchMethod(){return this.#o}get memoMethod(){return this.#_}get dispose(){return this.#i}get disposeAfter(){return this.#n}constructor(e){let{max:t=0,ttl:s,ttlResolution:n=1,ttlAutopurge:i,updateAgeOnGet:o,updateAgeOnHas:a,allowStale:l,dispose:c,disposeAfter:u,noDisposeOnSet:p,noUpdateTTL:d,maxSize:m=0,maxEntrySize:h=0,sizeCalculation:g,fetchMethod:y,memoMethod:b,noDeleteOnFetchRejection:w,noDeleteOnStaleGet:S,allowStaleOnFetchRejection:x,allowStaleOnFetchAbort:R,ignoreFetchAbort:$}=e;if(t!==0&&!Ot(t))throw new TypeError("max option must be a nonnegative integer");let G=t?Ml(t):Array;if(!G)throw new Error("invalid max value: "+t);if(this.#e=t,this.#t=m,this.maxEntrySize=h||this.#t,this.sizeCalculation=g,this.sizeCalculation){if(!this.#t&&!this.maxEntrySize)throw new TypeError("cannot set sizeCalculation without setting maxSize or maxEntrySize");if(typeof this.sizeCalculation!="function")throw new TypeError("sizeCalculation set to non-function")}if(b!==void 0&&typeof b!="function")throw new TypeError("memoMethod must be a function if defined");if(this.#_=b,y!==void 0&&typeof y!="function")throw new TypeError("fetchMethod must be a function if specified");if(this.#o=y,this.#k=!!y,this.#a=new Map,this.#l=new Array(t).fill(void 0),this.#r=new Array(t).fill(void 0),this.#f=new G(t),this.#y=new G(t),this.#m=0,this.#d=0,this.#v=ao.create(t),this.#c=0,this.#p=0,typeof c=="function"&&(this.#i=c),typeof u=="function"?(this.#n=u,this.#g=[]):(this.#n=void 0,this.#g=void 0),this.#S=!!this.#i,this.#h=!!this.#n,this.noDisposeOnSet=!!p,this.noUpdateTTL=!!d,this.noDeleteOnFetchRejection=!!w,this.allowStaleOnFetchRejection=!!x,this.allowStaleOnFetchAbort=!!R,this.ignoreFetchAbort=!!$,this.maxEntrySize!==0){if(this.#t!==0&&!Ot(this.#t))throw new TypeError("maxSize must be a positive integer if specified");if(!Ot(this.maxEntrySize))throw new TypeError("maxEntrySize must be a positive integer if specified");this.#M();}if(this.allowStale=!!l,this.noDeleteOnStaleGet=!!S,this.updateAgeOnGet=!!o,this.updateAgeOnHas=!!a,this.ttlResolution=Ot(n)||n===0?n:1,this.ttlAutopurge=!!i,this.ttl=s||0,this.ttl){if(!Ot(this.ttl))throw new TypeError("ttl must be a positive integer if specified");this.#I();}if(this.#e===0&&this.ttl===0&&this.#t===0)throw new TypeError("At least one of max, maxSize, or ttl is required");if(!this.ttlAutopurge&&!this.#e&&!this.#t){let U="LRU_CACHE_UNBOUNDED";km(U)&&(El.add(U),Il("TTL caching without ttlAutopurge, max, or maxSize can result in unbounded memory consumption.","UnboundedCacheWarning",U,r));}}getRemainingTTL(e){return this.#a.has(e)?1/0:0}#I(){let e=new ks(this.#e),t=new ks(this.#e);this.#w=e,this.#x=t,this.#P=(i,o,a=Ss.now())=>{if(t[i]=o!==0?a:0,e[i]=o,o!==0&&this.ttlAutopurge){let l=setTimeout(()=>{this.#b(i)&&this.#A(this.#l[i],"expire");},o+1);l.unref&&l.unref();}},this.#C=i=>{t[i]=e[i]!==0?Ss.now():0;},this.#s=(i,o)=>{if(e[o]){let a=e[o],l=t[o];if(!a||!l)return;i.ttl=a,i.start=l,i.now=s||n();let c=i.now-l;i.remainingTTL=a-c;}};let s=0,n=()=>{let i=Ss.now();if(this.ttlResolution>0){s=i;let o=setTimeout(()=>s=0,this.ttlResolution);o.unref&&o.unref();}return i};this.getRemainingTTL=i=>{let o=this.#a.get(i);if(o===void 0)return 0;let a=e[o],l=t[o];if(!a||!l)return 1/0;let c=(s||n())-l;return a-c},this.#b=i=>{let o=t[i],a=e[i];return !!a&&!!o&&(s||n())-o>a};}#C=()=>{};#s=()=>{};#P=()=>{};#b=()=>false;#M(){let e=new ks(this.#e);this.#p=0,this.#T=e,this.#O=t=>{this.#p-=e[t],e[t]=0;},this.#D=(t,s,n,i)=>{if(this.#u(s))return 0;if(!Ot(n))if(i){if(typeof i!="function")throw new TypeError("sizeCalculation must be a function");if(n=i(s,t),!Ot(n))throw new TypeError("sizeCalculation return invalid (expect positive integer)")}else throw new TypeError("invalid size value (must be positive integer). When maxSize or maxEntrySize is used, sizeCalculation or size must be set.");return n},this.#L=(t,s,n)=>{if(e[t]=s,this.#t){let i=this.#t-e[t];for(;this.#p>i;)this.#N(true);}this.#p+=e[t],n&&(n.entrySize=s,n.totalCalculatedSize=this.#p);};}#O=e=>{};#L=(e,t,s)=>{};#D=(e,t,s,n)=>{if(s||n)throw new TypeError("cannot set size without setting maxSize or maxEntrySize on cache");return 0};*#R({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#d;!(!this.#$(t)||((e||!this.#b(t))&&(yield t),t===this.#m));)t=this.#y[t];}*#E({allowStale:e=this.allowStale}={}){if(this.#c)for(let t=this.#m;!(!this.#$(t)||((e||!this.#b(t))&&(yield t),t===this.#d));)t=this.#f[t];}#$(e){return e!==void 0&&this.#a.get(this.#l[e])===e}*entries(){for(let e of this.#R())this.#r[e]!==void 0&&this.#l[e]!==void 0&&!this.#u(this.#r[e])&&(yield [this.#l[e],this.#r[e]]);}*rentries(){for(let e of this.#E())this.#r[e]!==void 0&&this.#l[e]!==void 0&&!this.#u(this.#r[e])&&(yield [this.#l[e],this.#r[e]]);}*keys(){for(let e of this.#R()){let t=this.#l[e];t!==void 0&&!this.#u(this.#r[e])&&(yield t);}}*rkeys(){for(let e of this.#E()){let t=this.#l[e];t!==void 0&&!this.#u(this.#r[e])&&(yield t);}}*values(){for(let e of this.#R())this.#r[e]!==void 0&&!this.#u(this.#r[e])&&(yield this.#r[e]);}*rvalues(){for(let e of this.#E())this.#r[e]!==void 0&&!this.#u(this.#r[e])&&(yield this.#r[e]);}[Symbol.iterator](){return this.entries()}[Symbol.toStringTag]="LRUCache";find(e,t={}){for(let s of this.#R()){let n=this.#r[s],i=this.#u(n)?n.__staleWhileFetching:n;if(i!==void 0&&e(i,this.#l[s],this))return this.get(this.#l[s],t)}}forEach(e,t=this){for(let s of this.#R()){let n=this.#r[s],i=this.#u(n)?n.__staleWhileFetching:n;i!==void 0&&e.call(t,i,this.#l[s],this);}}rforEach(e,t=this){for(let s of this.#E()){let n=this.#r[s],i=this.#u(n)?n.__staleWhileFetching:n;i!==void 0&&e.call(t,i,this.#l[s],this);}}purgeStale(){let e=false;for(let t of this.#E({allowStale:true}))this.#b(t)&&(this.#A(this.#l[t],"expire"),e=true);return e}info(e){let t=this.#a.get(e);if(t===void 0)return;let s=this.#r[t],n=this.#u(s)?s.__staleWhileFetching:s;if(n===void 0)return;let i={value:n};if(this.#w&&this.#x){let o=this.#w[t],a=this.#x[t];if(o&&a){let l=o-(Ss.now()-a);i.ttl=l,i.start=Date.now();}}return this.#T&&(i.size=this.#T[t]),i}dump(){let e=[];for(let t of this.#R({allowStale:true})){let s=this.#l[t],n=this.#r[t],i=this.#u(n)?n.__staleWhileFetching:n;if(i===void 0||s===void 0)continue;let o={value:i};if(this.#w&&this.#x){o.ttl=this.#w[t];let a=Ss.now()-this.#x[t];o.start=Math.floor(Date.now()-a);}this.#T&&(o.size=this.#T[t]),e.unshift([s,o]);}return e}load(e){this.clear();for(let[t,s]of e){if(s.start){let n=Date.now()-s.start;s.start=Ss.now()-n;}this.set(t,s.value,s);}}set(e,t,s={}){if(t===void 0)return this.delete(e),this;let{ttl:n=this.ttl,start:i,noDisposeOnSet:o=this.noDisposeOnSet,sizeCalculation:a=this.sizeCalculation,status:l}=s,{noUpdateTTL:c=this.noUpdateTTL}=s,u=this.#D(e,t,s.size||0,a);if(this.maxEntrySize&&u>this.maxEntrySize)return l&&(l.set="miss",l.maxEntrySizeExceeded=true),this.#A(e,"set"),this;let p=this.#c===0?void 0:this.#a.get(e);if(p===void 0)p=this.#c===0?this.#d:this.#v.length!==0?this.#v.pop():this.#c===this.#e?this.#N(false):this.#c,this.#l[p]=e,this.#r[p]=t,this.#a.set(e,p),this.#f[this.#d]=p,this.#y[p]=this.#d,this.#d=p,this.#c++,this.#L(p,u,l),l&&(l.set="add"),c=false;else {this.#j(p);let d=this.#r[p];if(t!==d){if(this.#k&&this.#u(d)){d.__abortController.abort(new Error("replaced"));let{__staleWhileFetching:m}=d;m!==void 0&&!o&&(this.#S&&this.#i?.(m,e,"set"),this.#h&&this.#g?.push([m,e,"set"]));}else o||(this.#S&&this.#i?.(d,e,"set"),this.#h&&this.#g?.push([d,e,"set"]));if(this.#O(p),this.#L(p,u,l),this.#r[p]=t,l){l.set="replace";let m=d&&this.#u(d)?d.__staleWhileFetching:d;m!==void 0&&(l.oldValue=m);}}else l&&(l.set="update");}if(n!==0&&!this.#w&&this.#I(),this.#w&&(c||this.#P(p,n,i),l&&this.#s(l,p)),!o&&this.#h&&this.#g){let d=this.#g,m;for(;m=d?.shift();)this.#n?.(...m);}return this}pop(){try{for(;this.#c;){let e=this.#r[this.#m];if(this.#N(!0),this.#u(e)){if(e.__staleWhileFetching)return e.__staleWhileFetching}else if(e!==void 0)return e}}finally{if(this.#h&&this.#g){let e=this.#g,t;for(;t=e?.shift();)this.#n?.(...t);}}}#N(e){let t=this.#m,s=this.#l[t],n=this.#r[t];return this.#k&&this.#u(n)?n.__abortController.abort(new Error("evicted")):(this.#S||this.#h)&&(this.#S&&this.#i?.(n,s,"evict"),this.#h&&this.#g?.push([n,s,"evict"])),this.#O(t),e&&(this.#l[t]=void 0,this.#r[t]=void 0,this.#v.push(t)),this.#c===1?(this.#m=this.#d=0,this.#v.length=0):this.#m=this.#f[t],this.#a.delete(s),this.#c--,t}has(e,t={}){let{updateAgeOnHas:s=this.updateAgeOnHas,status:n}=t,i=this.#a.get(e);if(i!==void 0){let o=this.#r[i];if(this.#u(o)&&o.__staleWhileFetching===void 0)return false;if(this.#b(i))n&&(n.has="stale",this.#s(n,i));else return s&&this.#C(i),n&&(n.has="hit",this.#s(n,i)),true}else n&&(n.has="miss");return false}peek(e,t={}){let{allowStale:s=this.allowStale}=t,n=this.#a.get(e);if(n===void 0||!s&&this.#b(n))return;let i=this.#r[n];return this.#u(i)?i.__staleWhileFetching:i}#F(e,t,s,n){let i=t===void 0?void 0:this.#r[t];if(this.#u(i))return i;let o=new br,{signal:a}=s;a?.addEventListener("abort",()=>o.abort(a.reason),{signal:o.signal});let l={signal:o.signal,options:s,context:n},c=(g,y=false)=>{let{aborted:b}=o.signal,w=s.ignoreFetchAbort&&g!==void 0;if(s.status&&(b&&!y?(s.status.fetchAborted=true,s.status.fetchError=o.signal.reason,w&&(s.status.fetchAbortIgnored=true)):s.status.fetchResolved=true),b&&!w&&!y)return p(o.signal.reason);let S=m;return this.#r[t]===m&&(g===void 0?S.__staleWhileFetching?this.#r[t]=S.__staleWhileFetching:this.#A(e,"fetch"):(s.status&&(s.status.fetchUpdated=true),this.set(e,g,l.options))),g},u=g=>(s.status&&(s.status.fetchRejected=true,s.status.fetchError=g),p(g)),p=g=>{let{aborted:y}=o.signal,b=y&&s.allowStaleOnFetchAbort,w=b||s.allowStaleOnFetchRejection,S=w||s.noDeleteOnFetchRejection,x=m;if(this.#r[t]===m&&(!S||x.__staleWhileFetching===void 0?this.#A(e,"fetch"):b||(this.#r[t]=x.__staleWhileFetching)),w)return s.status&&x.__staleWhileFetching!==void 0&&(s.status.returnedStale=true),x.__staleWhileFetching;if(x.__returned===x)throw g},d=(g,y)=>{let b=this.#o?.(e,i,l);b&&b instanceof Promise&&b.then(w=>g(w===void 0?void 0:w),y),o.signal.addEventListener("abort",()=>{(!s.ignoreFetchAbort||s.allowStaleOnFetchAbort)&&(g(void 0),s.allowStaleOnFetchAbort&&(g=w=>c(w,true)));});};s.status&&(s.status.fetchDispatched=true);let m=new Promise(d).then(c,u),h=Object.assign(m,{__abortController:o,__staleWhileFetching:i,__returned:void 0});return t===void 0?(this.set(e,h,{...l.options,status:void 0}),t=this.#a.get(e)):this.#r[t]=h,h}#u(e){if(!this.#k)return false;let t=e;return !!t&&t instanceof Promise&&t.hasOwnProperty("__staleWhileFetching")&&t.__abortController instanceof br}async fetch(e,t={}){let{allowStale:s=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,ttl:o=this.ttl,noDisposeOnSet:a=this.noDisposeOnSet,size:l=0,sizeCalculation:c=this.sizeCalculation,noUpdateTTL:u=this.noUpdateTTL,noDeleteOnFetchRejection:p=this.noDeleteOnFetchRejection,allowStaleOnFetchRejection:d=this.allowStaleOnFetchRejection,ignoreFetchAbort:m=this.ignoreFetchAbort,allowStaleOnFetchAbort:h=this.allowStaleOnFetchAbort,context:g,forceRefresh:y=false,status:b,signal:w}=t;if(!this.#k)return b&&(b.fetch="get"),this.get(e,{allowStale:s,updateAgeOnGet:n,noDeleteOnStaleGet:i,status:b});let S={allowStale:s,updateAgeOnGet:n,noDeleteOnStaleGet:i,ttl:o,noDisposeOnSet:a,size:l,sizeCalculation:c,noUpdateTTL:u,noDeleteOnFetchRejection:p,allowStaleOnFetchRejection:d,allowStaleOnFetchAbort:h,ignoreFetchAbort:m,status:b,signal:w},x=this.#a.get(e);if(x===void 0){b&&(b.fetch="miss");let R=this.#F(e,x,S,g);return R.__returned=R}else {let R=this.#r[x];if(this.#u(R)){let C=s&&R.__staleWhileFetching!==void 0;return b&&(b.fetch="inflight",C&&(b.returnedStale=true)),C?R.__staleWhileFetching:R.__returned=R}let $=this.#b(x);if(!y&&!$)return b&&(b.fetch="hit"),this.#j(x),n&&this.#C(x),b&&this.#s(b,x),R;let G=this.#F(e,x,S,g),T=G.__staleWhileFetching!==void 0&&s;return b&&(b.fetch=$?"stale":"refresh",T&&$&&(b.returnedStale=true)),T?G.__staleWhileFetching:G.__returned=G}}async forceFetch(e,t={}){let s=await this.fetch(e,t);if(s===void 0)throw new Error("fetch() returned undefined");return s}memo(e,t={}){let s=this.#_;if(!s)throw new Error("no memoMethod provided to constructor");let{context:n,forceRefresh:i,...o}=t,a=this.get(e,o);if(!i&&a!==void 0)return a;let l=s(e,a,{options:o,context:n});return this.set(e,l,o),l}get(e,t={}){let{allowStale:s=this.allowStale,updateAgeOnGet:n=this.updateAgeOnGet,noDeleteOnStaleGet:i=this.noDeleteOnStaleGet,status:o}=t,a=this.#a.get(e);if(a!==void 0){let l=this.#r[a],c=this.#u(l);return o&&this.#s(o,a),this.#b(a)?(o&&(o.get="stale"),c?(o&&s&&l.__staleWhileFetching!==void 0&&(o.returnedStale=true),s?l.__staleWhileFetching:void 0):(i||this.#A(e,"expire"),o&&s&&(o.returnedStale=true),s?l:void 0)):(o&&(o.get="hit"),c?l.__staleWhileFetching:(this.#j(a),n&&this.#C(a),l))}else o&&(o.get="miss");}#U(e,t){this.#y[t]=e,this.#f[e]=t;}#j(e){e!==this.#d&&(e===this.#m?this.#m=this.#f[e]:this.#U(this.#y[e],this.#f[e]),this.#U(this.#d,e),this.#d=e);}delete(e){return this.#A(e,"delete")}#A(e,t){let s=false;if(this.#c!==0){let n=this.#a.get(e);if(n!==void 0)if(s=true,this.#c===1)this.#G(t);else {this.#O(n);let i=this.#r[n];if(this.#u(i)?i.__abortController.abort(new Error("deleted")):(this.#S||this.#h)&&(this.#S&&this.#i?.(i,e,t),this.#h&&this.#g?.push([i,e,t])),this.#a.delete(e),this.#l[n]=void 0,this.#r[n]=void 0,n===this.#d)this.#d=this.#y[n];else if(n===this.#m)this.#m=this.#f[n];else {let o=this.#y[n];this.#f[o]=this.#f[n];let a=this.#f[n];this.#y[a]=this.#y[n];}this.#c--,this.#v.push(n);}}if(this.#h&&this.#g?.length){let n=this.#g,i;for(;i=n?.shift();)this.#n?.(...i);}return s}clear(){return this.#G("delete")}#G(e){for(let t of this.#E({allowStale:true})){let s=this.#r[t];if(this.#u(s))s.__abortController.abort(new Error("deleted"));else {let n=this.#l[t];this.#S&&this.#i?.(s,n,e),this.#h&&this.#g?.push([s,n,e]);}}if(this.#a.clear(),this.#r.fill(void 0),this.#l.fill(void 0),this.#w&&this.#x&&(this.#w.fill(0),this.#x.fill(0)),this.#T&&this.#T.fill(0),this.#m=0,this.#d=0,this.#v.length=0,this.#p=0,this.#c=0,this.#h&&this.#g){let t=this.#g,s;for(;s=t?.shift();)this.#n?.(...s);}}};var Al=typeof process=="object"&&process?process:{stdout:null,stderr:null},Tm=r=>!!r&&typeof r=="object"&&(r instanceof Dt||r instanceof Dl||xm(r)||Cm(r)),xm=r=>!!r&&typeof r=="object"&&r instanceof EventEmitter&&typeof r.pipe=="function"&&r.pipe!==Dl.Writable.prototype.pipe,Cm=r=>!!r&&typeof r=="object"&&r instanceof EventEmitter&&typeof r.write=="function"&&typeof r.end=="function",vt=Symbol("EOF"),Tt=Symbol("maybeEmitEnd"),Lt=Symbol("emittedEnd"),wr=Symbol("emittingEnd"),un=Symbol("emittedError"),_r=Symbol("closed"),Pl=Symbol("read"),Sr=Symbol("flush"),Ol=Symbol("flushChunk"),ct=Symbol("encoding"),vs=Symbol("decoder"),Ie=Symbol("flowing"),pn=Symbol("paused"),Ts=Symbol("resume"),Me=Symbol("buffer"),Be=Symbol("pipes"),Ae=Symbol("bufferLength"),lo=Symbol("bufferPush"),kr=Symbol("bufferShift"),Ne=Symbol("objectMode"),Te=Symbol("destroyed"),co=Symbol("error"),uo=Symbol("emitData"),Ll=Symbol("emitEnd"),po=Symbol("emitEnd2"),gt=Symbol("async"),mo=Symbol("abort"),vr=Symbol("aborted"),dn=Symbol("signal"),Jt=Symbol("dataListeners"),Xe=Symbol("discarded"),mn=r=>Promise.resolve().then(r),Rm=r=>r(),Em=r=>r==="end"||r==="finish"||r==="prefinish",Im=r=>r instanceof ArrayBuffer||!!r&&typeof r=="object"&&r.constructor&&r.constructor.name==="ArrayBuffer"&&r.byteLength>=0,Mm=r=>!Buffer.isBuffer(r)&&ArrayBuffer.isView(r),Tr=class{src;dest;opts;ondrain;constructor(e,t,s){this.src=e,this.dest=t,this.opts=s,this.ondrain=()=>e[Ts](),this.dest.on("drain",this.ondrain);}unpipe(){this.dest.removeListener("drain",this.ondrain);}proxyErrors(e){}end(){this.unpipe(),this.opts.end&&this.dest.end();}},ho=class extends Tr{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe();}constructor(e,t,s){super(e,t,s),this.proxyErrors=n=>t.emit("error",n),e.on("error",this.proxyErrors);}},Am=r=>!!r.objectMode,Pm=r=>!r.objectMode&&!!r.encoding&&r.encoding!=="buffer",Dt=class extends EventEmitter{[Ie]=false;[pn]=false;[Be]=[];[Me]=[];[Ne];[ct];[gt];[vs];[vt]=false;[Lt]=false;[wr]=false;[_r]=false;[un]=null;[Ae]=0;[Te]=false;[dn];[vr]=false;[Jt]=0;[Xe]=false;writable=true;readable=true;constructor(...e){let t=e[0]||{};if(super(),t.objectMode&&typeof t.encoding=="string")throw new TypeError("Encoding and objectMode may not be used together");Am(t)?(this[Ne]=true,this[ct]=null):Pm(t)?(this[ct]=t.encoding,this[Ne]=false):(this[Ne]=false,this[ct]=null),this[gt]=!!t.async,this[vs]=this[ct]?new StringDecoder(this[ct]):null,t&&t.debugExposeBuffer===true&&Object.defineProperty(this,"buffer",{get:()=>this[Me]}),t&&t.debugExposePipes===true&&Object.defineProperty(this,"pipes",{get:()=>this[Be]});let{signal:s}=t;s&&(this[dn]=s,s.aborted?this[mo]():s.addEventListener("abort",()=>this[mo]()));}get bufferLength(){return this[Ae]}get encoding(){return this[ct]}set encoding(e){throw new Error("Encoding must be set at instantiation time")}setEncoding(e){throw new Error("Encoding must be set at instantiation time")}get objectMode(){return this[Ne]}set objectMode(e){throw new Error("objectMode must be set at instantiation time")}get async(){return this[gt]}set async(e){this[gt]=this[gt]||!!e;}[mo](){this[vr]=true,this.emit("abort",this[dn]?.reason),this.destroy(this[dn]?.reason);}get aborted(){return this[vr]}set aborted(e){}write(e,t,s){if(this[vr])return false;if(this[vt])throw new Error("write after end");if(this[Te])return this.emit("error",Object.assign(new Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),true;typeof t=="function"&&(s=t,t="utf8"),t||(t="utf8");let n=this[gt]?mn:Rm;if(!this[Ne]&&!Buffer.isBuffer(e)){if(Mm(e))e=Buffer.from(e.buffer,e.byteOffset,e.byteLength);else if(Im(e))e=Buffer.from(e);else if(typeof e!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[Ne]?(this[Ie]&&this[Ae]!==0&&this[Sr](true),this[Ie]?this.emit("data",e):this[lo](e),this[Ae]!==0&&this.emit("readable"),s&&n(s),this[Ie]):e.length?(typeof e=="string"&&!(t===this[ct]&&!this[vs]?.lastNeed)&&(e=Buffer.from(e,t)),Buffer.isBuffer(e)&&this[ct]&&(e=this[vs].write(e)),this[Ie]&&this[Ae]!==0&&this[Sr](true),this[Ie]?this.emit("data",e):this[lo](e),this[Ae]!==0&&this.emit("readable"),s&&n(s),this[Ie]):(this[Ae]!==0&&this.emit("readable"),s&&n(s),this[Ie])}read(e){if(this[Te])return null;if(this[Xe]=false,this[Ae]===0||e===0||e&&e>this[Ae])return this[Tt](),null;this[Ne]&&(e=null),this[Me].length>1&&!this[Ne]&&(this[Me]=[this[ct]?this[Me].join(""):Buffer.concat(this[Me],this[Ae])]);let t=this[Pl](e||null,this[Me][0]);return this[Tt](),t}[Pl](e,t){if(this[Ne])this[kr]();else {let s=t;e===s.length||e===null?this[kr]():typeof s=="string"?(this[Me][0]=s.slice(e),t=s.slice(0,e),this[Ae]-=e):(this[Me][0]=s.subarray(e),t=s.subarray(0,e),this[Ae]-=e);}return this.emit("data",t),!this[Me].length&&!this[vt]&&this.emit("drain"),t}end(e,t,s){return typeof e=="function"&&(s=e,e=void 0),typeof t=="function"&&(s=t,t="utf8"),e!==void 0&&this.write(e,t),s&&this.once("end",s),this[vt]=true,this.writable=false,(this[Ie]||!this[pn])&&this[Tt](),this}[Ts](){this[Te]||(!this[Jt]&&!this[Be].length&&(this[Xe]=true),this[pn]=false,this[Ie]=true,this.emit("resume"),this[Me].length?this[Sr]():this[vt]?this[Tt]():this.emit("drain"));}resume(){return this[Ts]()}pause(){this[Ie]=false,this[pn]=true,this[Xe]=false;}get destroyed(){return this[Te]}get flowing(){return this[Ie]}get paused(){return this[pn]}[lo](e){this[Ne]?this[Ae]+=1:this[Ae]+=e.length,this[Me].push(e);}[kr](){return this[Ne]?this[Ae]-=1:this[Ae]-=this[Me][0].length,this[Me].shift()}[Sr](e=false){do;while(this[Ol](this[kr]())&&this[Me].length);!e&&!this[Me].length&&!this[vt]&&this.emit("drain");}[Ol](e){return this.emit("data",e),this[Ie]}pipe(e,t){if(this[Te])return e;this[Xe]=false;let s=this[Lt];return t=t||{},e===Al.stdout||e===Al.stderr?t.end=false:t.end=t.end!==false,t.proxyErrors=!!t.proxyErrors,s?t.end&&e.end():(this[Be].push(t.proxyErrors?new ho(this,e,t):new Tr(this,e,t)),this[gt]?mn(()=>this[Ts]()):this[Ts]()),e}unpipe(e){let t=this[Be].find(s=>s.dest===e);t&&(this[Be].length===1?(this[Ie]&&this[Jt]===0&&(this[Ie]=false),this[Be]=[]):this[Be].splice(this[Be].indexOf(t),1),t.unpipe());}addListener(e,t){return this.on(e,t)}on(e,t){let s=super.on(e,t);if(e==="data")this[Xe]=false,this[Jt]++,!this[Be].length&&!this[Ie]&&this[Ts]();else if(e==="readable"&&this[Ae]!==0)super.emit("readable");else if(Em(e)&&this[Lt])super.emit(e),this.removeAllListeners(e);else if(e==="error"&&this[un]){let n=t;this[gt]?mn(()=>n.call(this,this[un])):n.call(this,this[un]);}return s}removeListener(e,t){return this.off(e,t)}off(e,t){let s=super.off(e,t);return e==="data"&&(this[Jt]=this.listeners("data").length,this[Jt]===0&&!this[Xe]&&!this[Be].length&&(this[Ie]=false)),s}removeAllListeners(e){let t=super.removeAllListeners(e);return (e==="data"||e===void 0)&&(this[Jt]=0,!this[Xe]&&!this[Be].length&&(this[Ie]=false)),t}get emittedEnd(){return this[Lt]}[Tt](){!this[wr]&&!this[Lt]&&!this[Te]&&this[Me].length===0&&this[vt]&&(this[wr]=true,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[_r]&&this.emit("close"),this[wr]=false);}emit(e,...t){let s=t[0];if(e!=="error"&&e!=="close"&&e!==Te&&this[Te])return false;if(e==="data")return !this[Ne]&&!s?false:this[gt]?(mn(()=>this[uo](s)),true):this[uo](s);if(e==="end")return this[Ll]();if(e==="close"){if(this[_r]=true,!this[Lt]&&!this[Te])return false;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(e==="error"){this[un]=s,super.emit(co,s);let i=!this[dn]||this.listeners("error").length?super.emit("error",s):false;return this[Tt](),i}else if(e==="resume"){let i=super.emit("resume");return this[Tt](),i}else if(e==="finish"||e==="prefinish"){let i=super.emit(e);return this.removeAllListeners(e),i}let n=super.emit(e,...t);return this[Tt](),n}[uo](e){for(let s of this[Be])s.dest.write(e)===false&&this.pause();let t=this[Xe]?false:super.emit("data",e);return this[Tt](),t}[Ll](){return this[Lt]?false:(this[Lt]=true,this.readable=false,this[gt]?(mn(()=>this[po]()),true):this[po]())}[po](){if(this[vs]){let t=this[vs].end();if(t){for(let s of this[Be])s.dest.write(t);this[Xe]||super.emit("data",t);}}for(let t of this[Be])t.end();let e=super.emit("end");return this.removeAllListeners("end"),e}async collect(){let e=Object.assign([],{dataLength:0});this[Ne]||(e.dataLength=0);let t=this.promise();return this.on("data",s=>{e.push(s),this[Ne]||(e.dataLength+=s.length);}),await t,e}async concat(){if(this[Ne])throw new Error("cannot concat in objectMode");let e=await this.collect();return this[ct]?e.join(""):Buffer.concat(e,e.dataLength)}async promise(){return new Promise((e,t)=>{this.on(Te,()=>t(new Error("stream destroyed"))),this.on("error",s=>t(s)),this.on("end",()=>e());})}[Symbol.asyncIterator](){this[Xe]=false;let e=false,t=async()=>(this.pause(),e=true,{value:void 0,done:true});return {next:()=>{if(e)return t();let n=this.read();if(n!==null)return Promise.resolve({done:false,value:n});if(this[vt])return t();let i,o,a=p=>{this.off("data",l),this.off("end",c),this.off(Te,u),t(),o(p);},l=p=>{this.off("error",a),this.off("end",c),this.off(Te,u),this.pause(),i({value:p,done:!!this[vt]});},c=()=>{this.off("error",a),this.off("data",l),this.off(Te,u),t(),i({done:true,value:void 0});},u=()=>a(new Error("stream destroyed"));return new Promise((p,d)=>{o=d,i=p,this.once(Te,u),this.once("error",a),this.once("end",c),this.once("data",l);})},throw:t,return:t,[Symbol.asyncIterator](){return this}}}[Symbol.iterator](){this[Xe]=false;let e=false,t=()=>(this.pause(),this.off(co,t),this.off(Te,t),this.off("end",t),e=true,{done:true,value:void 0}),s=()=>{if(e)return t();let n=this.read();return n===null?t():{done:false,value:n}};return this.once("end",t),this.once(co,t),this.once(Te,t),{next:s,throw:t,return:t,[Symbol.iterator](){return this}}}destroy(e){if(this[Te])return e?this.emit("error",e):this.emit(Te),this;this[Te]=true,this[Xe]=true,this[Me].length=0,this[Ae]=0;let t=this;return typeof t.close=="function"&&!this[_r]&&t.close(),e?this.emit("error",e):this.emit(Te),this}static get isStream(){return Tm}};var Gm=realpathSync.native,gn={lstatSync:lstatSync,readdir:readdir$1,readdirSync:readdirSync,readlinkSync:readlinkSync,realpathSync:Gm,promises:{lstat:lstat,readdir:readdir,readlink:readlink,realpath:realpath}},jl=r=>!r||r===gn||r===Ce?gn:{...gn,...r,promises:{...gn.promises,...r.promises||{}}},Gl=/^\\\\\?\\([a-z]:)\\?$/i,qm=r=>r.replace(/\//g,"\\").replace(Gl,"$1\\"),Jm=/[\\\/]/,st=0,Bl=1,Wl=2,ft=4,Hl=6,zl=8,Kt=10,ql=12,tt=15,hn=~tt,fo=16,$l=32,fn=64,ut=128,xr=256,Rr=512,Nl=fn|ut|Rr,Km=1023,yo=r=>r.isFile()?zl:r.isDirectory()?ft:r.isSymbolicLink()?Kt:r.isCharacterDevice()?Wl:r.isBlockDevice()?Hl:r.isSocket()?ql:r.isFIFO()?Bl:st,Fl=new Map,yn=r=>{let e=Fl.get(r);if(e)return e;let t=r.normalize("NFKD");return Fl.set(r,t),t},Ul=new Map,Cr=r=>{let e=Ul.get(r);if(e)return e;let t=yn(r.toLowerCase());return Ul.set(r,t),t},Er=class extends cn{constructor(){super({max:256});}},wo=class extends cn{constructor(e=16*1024){super({maxSize:e,sizeCalculation:t=>t.length+1});}},Jl=Symbol("PathScurry setAsCwd"),Fe=class{name;root;roots;parent;nocase;isCWD=false;#e;#t;get dev(){return this.#t}#i;get mode(){return this.#i}#n;get nlink(){return this.#n}#o;get uid(){return this.#o}#_;get gid(){return this.#_}#c;get rdev(){return this.#c}#p;get blksize(){return this.#p}#a;get ino(){return this.#a}#l;get size(){return this.#l}#r;get blocks(){return this.#r}#f;get atimeMs(){return this.#f}#y;get mtimeMs(){return this.#y}#m;get ctimeMs(){return this.#m}#d;get birthtimeMs(){return this.#d}#v;get atime(){return this.#v}#g;get mtime(){return this.#g}#T;get ctime(){return this.#T}#x;get birthtime(){return this.#x}#w;#S;#k;#h;#I;#C;#s;#P;#b;#M;get parentPath(){return (this.parent||this).fullpath()}get path(){return this.parentPath}constructor(e,t=st,s,n,i,o,a){this.name=e,this.#w=i?Cr(e):yn(e),this.#s=t&Km,this.nocase=i,this.roots=n,this.root=s||this,this.#P=o,this.#k=a.fullpath,this.#I=a.relative,this.#C=a.relativePosix,this.parent=a.parent,this.parent?this.#e=this.parent.#e:this.#e=jl(a.fs);}depth(){return this.#S!==void 0?this.#S:this.parent?this.#S=this.parent.depth()+1:this.#S=0}childrenCache(){return this.#P}resolve(e){if(!e)return this;let t=this.getRootString(e),n=e.substring(t.length).split(this.splitSep);return t?this.getRoot(t).#O(n):this.#O(n)}#O(e){let t=this;for(let s of e)t=t.child(s);return t}children(){let e=this.#P.get(this);if(e)return e;let t=Object.assign([],{provisional:0});return this.#P.set(this,t),this.#s&=~fo,t}child(e,t){if(e===""||e===".")return this;if(e==="..")return this.parent||this;let s=this.children(),n=this.nocase?Cr(e):yn(e);for(let l of s)if(l.#w===n)return l;let i=this.parent?this.sep:"",o=this.#k?this.#k+i+e:void 0,a=this.newChild(e,st,{...t,parent:this,fullpath:o});return this.canReaddir()||(a.#s|=ut),s.push(a),a}relative(){if(this.isCWD)return "";if(this.#I!==void 0)return this.#I;let e=this.name,t=this.parent;if(!t)return this.#I=this.name;let s=t.relative();return s+(!s||!t.parent?"":this.sep)+e}relativePosix(){if(this.sep==="/")return this.relative();if(this.isCWD)return "";if(this.#C!==void 0)return this.#C;let e=this.name,t=this.parent;if(!t)return this.#C=this.fullpathPosix();let s=t.relativePosix();return s+(!s||!t.parent?"":"/")+e}fullpath(){if(this.#k!==void 0)return this.#k;let e=this.name,t=this.parent;if(!t)return this.#k=this.name;let n=t.fullpath()+(t.parent?this.sep:"")+e;return this.#k=n}fullpathPosix(){if(this.#h!==void 0)return this.#h;if(this.sep==="/")return this.#h=this.fullpath();if(!this.parent){let n=this.fullpath().replace(/\\/g,"/");return /^[a-z]:\//i.test(n)?this.#h=`//?/${n}`:this.#h=n}let e=this.parent,t=e.fullpathPosix(),s=t+(!t||!e.parent?"":"/")+this.name;return this.#h=s}isUnknown(){return (this.#s&tt)===st}isType(e){return this[`is${e}`]()}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.#s&tt)===zl}isDirectory(){return (this.#s&tt)===ft}isCharacterDevice(){return (this.#s&tt)===Wl}isBlockDevice(){return (this.#s&tt)===Hl}isFIFO(){return (this.#s&tt)===Bl}isSocket(){return (this.#s&tt)===ql}isSymbolicLink(){return (this.#s&Kt)===Kt}lstatCached(){return this.#s&$l?this:void 0}readlinkCached(){return this.#b}realpathCached(){return this.#M}readdirCached(){let e=this.children();return e.slice(0,e.provisional)}canReadlink(){if(this.#b)return true;if(!this.parent)return false;let e=this.#s&tt;return !(e!==st&&e!==Kt||this.#s&xr||this.#s&ut)}calledReaddir(){return !!(this.#s&fo)}isENOENT(){return !!(this.#s&ut)}isNamed(e){return this.nocase?this.#w===Cr(e):this.#w===yn(e)}async readlink(){let e=this.#b;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=await this.#e.promises.readlink(this.fullpath()),s=(await this.parent.realpath())?.resolve(t);if(s)return this.#b=s}catch(t){this.#u(t.code);return}}readlinkSync(){let e=this.#b;if(e)return e;if(this.canReadlink()&&this.parent)try{let t=this.#e.readlinkSync(this.fullpath()),s=this.parent.realpathSync()?.resolve(t);if(s)return this.#b=s}catch(t){this.#u(t.code);return}}#L(e){this.#s|=fo;for(let t=e.provisional;t<e.length;t++){let s=e[t];s&&s.#D();}}#D(){this.#s&ut||(this.#s=(this.#s|ut)&hn,this.#R());}#R(){let e=this.children();e.provisional=0;for(let t of e)t.#D();}#E(){this.#s|=Rr,this.#$();}#$(){if(this.#s&fn)return;let e=this.#s;(e&tt)===ft&&(e&=hn),this.#s=e|fn,this.#R();}#N(e=""){e==="ENOTDIR"||e==="EPERM"?this.#$():e==="ENOENT"?this.#D():this.children().provisional=0;}#F(e=""){e==="ENOTDIR"?this.parent.#$():e==="ENOENT"&&this.#D();}#u(e=""){let t=this.#s;t|=xr,e==="ENOENT"&&(t|=ut),(e==="EINVAL"||e==="UNKNOWN")&&(t&=hn),this.#s=t,e==="ENOTDIR"&&this.parent&&this.parent.#$();}#U(e,t){return this.#A(e,t)||this.#j(e,t)}#j(e,t){let s=yo(e),n=this.newChild(e.name,s,{parent:this}),i=n.#s&tt;return i!==ft&&i!==Kt&&i!==st&&(n.#s|=fn),t.unshift(n),t.provisional++,n}#A(e,t){for(let s=t.provisional;s<t.length;s++){let n=t[s];if((this.nocase?Cr(e.name):yn(e.name))===n.#w)return this.#G(e,n,s,t)}}#G(e,t,s,n){let i=t.name;return t.#s=t.#s&hn|yo(e),i!==e.name&&(t.name=e.name),s!==n.provisional&&(s===n.length-1?n.pop():n.splice(s,1),n.unshift(t)),n.provisional++,t}async lstat(){if((this.#s&ut)===0)try{return this.#z(await this.#e.promises.lstat(this.fullpath())),this}catch(e){this.#F(e.code);}}lstatSync(){if((this.#s&ut)===0)try{return this.#z(this.#e.lstatSync(this.fullpath())),this}catch(e){this.#F(e.code);}}#z(e){let{atime:t,atimeMs:s,birthtime:n,birthtimeMs:i,blksize:o,blocks:a,ctime:l,ctimeMs:c,dev:u,gid:p,ino:d,mode:m,mtime:h,mtimeMs:g,nlink:y,rdev:b,size:w,uid:S}=e;this.#v=t,this.#f=s,this.#x=n,this.#d=i,this.#p=o,this.#r=a,this.#T=l,this.#m=c,this.#t=u,this.#_=p,this.#a=d,this.#i=m,this.#g=h,this.#y=g,this.#n=y,this.#c=b,this.#l=w,this.#o=S;let x=yo(e);this.#s=this.#s&hn|x|$l,x!==st&&x!==ft&&x!==Kt&&(this.#s|=fn);}#W=[];#H=false;#q(e){this.#H=false;let t=this.#W.slice();this.#W.length=0,t.forEach(s=>s(null,e));}readdirCB(e,t=false){if(!this.canReaddir()){t?e(null,[]):queueMicrotask(()=>e(null,[]));return}let s=this.children();if(this.calledReaddir()){let i=s.slice(0,s.provisional);t?e(null,i):queueMicrotask(()=>e(null,i));return}if(this.#W.push(e),this.#H)return;this.#H=true;let n=this.fullpath();this.#e.readdir(n,{withFileTypes:true},(i,o)=>{if(i)this.#N(i.code),s.provisional=0;else {for(let a of o)this.#U(a,s);this.#L(s);}this.#q(s.slice(0,s.provisional));});}#B;async readdir(){if(!this.canReaddir())return [];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();if(this.#B)await this.#B;else {let s=()=>{};this.#B=new Promise(n=>s=n);try{for(let n of await this.#e.promises.readdir(t,{withFileTypes:!0}))this.#U(n,e);this.#L(e);}catch(n){this.#N(n.code),e.provisional=0;}this.#B=void 0,s();}return e.slice(0,e.provisional)}readdirSync(){if(!this.canReaddir())return [];let e=this.children();if(this.calledReaddir())return e.slice(0,e.provisional);let t=this.fullpath();try{for(let s of this.#e.readdirSync(t,{withFileTypes:!0}))this.#U(s,e);this.#L(e);}catch(s){this.#N(s.code),e.provisional=0;}return e.slice(0,e.provisional)}canReaddir(){if(this.#s&Nl)return false;let e=tt&this.#s;return e===st||e===ft||e===Kt}shouldWalk(e,t){return (this.#s&ft)===ft&&!(this.#s&Nl)&&!e.has(this)&&(!t||t(this))}async realpath(){if(this.#M)return this.#M;if(!((Rr|xr|ut)&this.#s))try{let e=await this.#e.promises.realpath(this.fullpath());return this.#M=this.resolve(e)}catch{this.#E();}}realpathSync(){if(this.#M)return this.#M;if(!((Rr|xr|ut)&this.#s))try{let e=this.#e.realpathSync(this.fullpath());return this.#M=this.resolve(e)}catch{this.#E();}}[Jl](e){if(e===this)return;e.isCWD=false,this.isCWD=true;let t=new Set([]),s=[],n=this;for(;n&&n.parent;)t.add(n),n.#I=s.join(this.sep),n.#C=s.join("/"),n=n.parent,s.push("..");for(n=e;n&&n.parent&&!t.has(n);)n.#I=void 0,n.#C=void 0,n=n.parent;}},Ir=class r extends Fe{sep="\\";splitSep=Jm;constructor(e,t=st,s,n,i,o,a){super(e,t,s,n,i,o,a);}newChild(e,t=st,s={}){return new r(e,t,this.root,this.roots,this.nocase,this.childrenCache(),s)}getRootString(e){return win32.parse(e).root}getRoot(e){if(e=qm(e.toUpperCase()),e===this.root.name)return this.root;for(let[t,s]of Object.entries(this.roots))if(this.sameRoot(e,t))return this.roots[e]=s;return this.roots[e]=new xs(e,this).root}sameRoot(e,t=this.root.name){return e=e.toUpperCase().replace(/\//g,"\\").replace(Gl,"$1\\"),e===t}},Mr=class r extends Fe{splitSep="/";sep="/";constructor(e,t=st,s,n,i,o,a){super(e,t,s,n,i,o,a);}getRootString(e){return e.startsWith("/")?"/":""}getRoot(e){return this.root}newChild(e,t=st,s={}){return new r(e,t,this.root,this.roots,this.nocase,this.childrenCache(),s)}},Ar=class{root;rootPath;roots;cwd;#e;#t;#i;nocase;#n;constructor(e=process.cwd(),t,s,{nocase:n,childrenCacheSize:i=16*1024,fs:o=gn}={}){this.#n=jl(o),(e instanceof URL||e.startsWith("file://"))&&(e=fileURLToPath(e));let a=t.resolve(e);this.roots=Object.create(null),this.rootPath=this.parseRootPath(a),this.#e=new Er,this.#t=new Er,this.#i=new wo(i);let l=a.substring(this.rootPath.length).split(s);if(l.length===1&&!l[0]&&l.pop(),n===void 0)throw new TypeError("must provide nocase setting to PathScurryBase ctor");this.nocase=n,this.root=this.newRoot(this.#n),this.roots[this.rootPath]=this.root;let c=this.root,u=l.length-1,p=t.sep,d=this.rootPath,m=false;for(let h of l){let g=u--;c=c.child(h,{relative:new Array(g).fill("..").join(p),relativePosix:new Array(g).fill("..").join("/"),fullpath:d+=(m?"":p)+h}),m=true;}this.cwd=c;}depth(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.depth()}childrenCache(){return this.#i}resolve(...e){let t="";for(let i=e.length-1;i>=0;i--){let o=e[i];if(!(!o||o===".")&&(t=t?`${o}/${t}`:o,this.isAbsolute(o)))break}let s=this.#e.get(t);if(s!==void 0)return s;let n=this.cwd.resolve(t).fullpath();return this.#e.set(t,n),n}resolvePosix(...e){let t="";for(let i=e.length-1;i>=0;i--){let o=e[i];if(!(!o||o===".")&&(t=t?`${o}/${t}`:o,this.isAbsolute(o)))break}let s=this.#t.get(t);if(s!==void 0)return s;let n=this.cwd.resolve(t).fullpathPosix();return this.#t.set(t,n),n}relative(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relative()}relativePosix(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.relativePosix()}basename(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.name}dirname(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),(e.parent||e).fullpath()}async readdir(e=this.cwd,t={withFileTypes:true}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s}=t;if(e.canReaddir()){let n=await e.readdir();return s?n:n.map(i=>i.name)}else return []}readdirSync(e=this.cwd,t={withFileTypes:true}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true}=t;return e.canReaddir()?s?e.readdirSync():e.readdirSync().map(n=>n.name):[]}async lstat(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstat()}lstatSync(e=this.cwd){return typeof e=="string"&&(e=this.cwd.resolve(e)),e.lstatSync()}async readlink(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=await e.readlink();return t?s:s?.fullpath()}readlinkSync(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=e.readlinkSync();return t?s:s?.fullpath()}async realpath(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=await e.realpath();return t?s:s?.fullpath()}realpathSync(e=this.cwd,{withFileTypes:t}={withFileTypes:false}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e.withFileTypes,e=this.cwd);let s=e.realpathSync();return t?s:s?.fullpath()}async walk(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=[];(!i||i(e))&&a.push(s?e:e.fullpath());let l=new Set,c=(p,d)=>{l.add(p),p.readdirCB((m,h)=>{if(m)return d(m);let g=h.length;if(!g)return d();let y=()=>{--g===0&&d();};for(let b of h)(!i||i(b))&&a.push(s?b:b.fullpath()),n&&b.isSymbolicLink()?b.realpath().then(w=>w?.isUnknown()?w.lstat():w).then(w=>w?.shouldWalk(l,o)?c(w,y):y()):b.shouldWalk(l,o)?c(b,y):y();},true);},u=e;return new Promise((p,d)=>{c(u,m=>{if(m)return d(m);p(a);});})}walkSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=[];(!i||i(e))&&a.push(s?e:e.fullpath());let l=new Set([e]);for(let c of l){let u=c.readdirSync();for(let p of u){(!i||i(p))&&a.push(s?p:p.fullpath());let d=p;if(p.isSymbolicLink()){if(!(n&&(d=p.realpathSync())))continue;d.isUnknown()&&d.lstatSync();}d.shouldWalk(l,o)&&l.add(d);}}return a}[Symbol.asyncIterator](){return this.iterate()}iterate(e=this.cwd,t={}){return typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd),this.stream(e,t)[Symbol.asyncIterator]()}[Symbol.iterator](){return this.iterateSync()}*iterateSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t;(!i||i(e))&&(yield s?e:e.fullpath());let a=new Set([e]);for(let l of a){let c=l.readdirSync();for(let u of c){(!i||i(u))&&(yield s?u:u.fullpath());let p=u;if(u.isSymbolicLink()){if(!(n&&(p=u.realpathSync())))continue;p.isUnknown()&&p.lstatSync();}p.shouldWalk(a,o)&&a.add(p);}}}stream(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=new Dt({objectMode:true});(!i||i(e))&&a.write(s?e:e.fullpath());let l=new Set,c=[e],u=0,p=()=>{let d=false;for(;!d;){let m=c.shift();if(!m){u===0&&a.end();return}u++,l.add(m);let h=(y,b,w=false)=>{if(y)return a.emit("error",y);if(n&&!w){let S=[];for(let x of b)x.isSymbolicLink()&&S.push(x.realpath().then(R=>R?.isUnknown()?R.lstat():R));if(S.length){Promise.all(S).then(()=>h(null,b,true));return}}for(let S of b)S&&(!i||i(S))&&(a.write(s?S:S.fullpath())||(d=true));u--;for(let S of b){let x=S.realpathCached()||S;x.shouldWalk(l,o)&&c.push(x);}d&&!a.flowing?a.once("drain",p):g||p();},g=true;m.readdirCB(h,true),g=false;}};return p(),a}streamSync(e=this.cwd,t={}){typeof e=="string"?e=this.cwd.resolve(e):e instanceof Fe||(t=e,e=this.cwd);let{withFileTypes:s=true,follow:n=false,filter:i,walkFilter:o}=t,a=new Dt({objectMode:true}),l=new Set;(!i||i(e))&&a.write(s?e:e.fullpath());let c=[e],u=0,p=()=>{let d=false;for(;!d;){let m=c.shift();if(!m){u===0&&a.end();return}u++,l.add(m);let h=m.readdirSync();for(let g of h)(!i||i(g))&&(a.write(s?g:g.fullpath())||(d=true));u--;for(let g of h){let y=g;if(g.isSymbolicLink()){if(!(n&&(y=g.realpathSync())))continue;y.isUnknown()&&y.lstatSync();}y.shouldWalk(l,o)&&c.push(y);}}d&&!a.flowing&&a.once("drain",p);};return p(),a}chdir(e=this.cwd){let t=this.cwd;this.cwd=typeof e=="string"?this.cwd.resolve(e):e,this.cwd[Jl](t);}},xs=class extends Ar{sep="\\";constructor(e=process.cwd(),t={}){let{nocase:s=true}=t;super(e,win32,"\\",{...t,nocase:s}),this.nocase=s;for(let n=this.cwd;n;n=n.parent)n.nocase=this.nocase;}parseRootPath(e){return win32.parse(e).root.toUpperCase()}newRoot(e){return new Ir(this.rootPath,ft,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")||e.startsWith("\\")||/^[a-z]:(\/|\\)/i.test(e)}},Cs=class extends Ar{sep="/";constructor(e=process.cwd(),t={}){let{nocase:s=false}=t;super(e,posix,"/",{...t,nocase:s}),this.nocase=s;}parseRootPath(e){return "/"}newRoot(e){return new Mr(this.rootPath,ft,void 0,this.roots,this.nocase,this.childrenCache(),{fs:e})}isAbsolute(e){return e.startsWith("/")}},bn=class extends Cs{constructor(e=process.cwd(),t={}){let{nocase:s=true}=t;super(e,{...t,nocase:s});}};process.platform==="win32"?Ir:Mr;var Kl=process.platform==="win32"?xs:process.platform==="darwin"?bn:Cs;var Vm=r=>r.length>=1,Ym=r=>r.length>=1,Rs=class r{#e;#t;#i;length;#n;#o;#_;#c;#p;#a;#l=true;constructor(e,t,s,n){if(!Vm(e))throw new TypeError("empty pattern list");if(!Ym(t))throw new TypeError("empty glob list");if(t.length!==e.length)throw new TypeError("mismatched pattern list and glob list lengths");if(this.length=e.length,s<0||s>=this.length)throw new TypeError("index out of range");if(this.#e=e,this.#t=t,this.#i=s,this.#n=n,this.#i===0){if(this.isUNC()){let[i,o,a,l,...c]=this.#e,[u,p,d,m,...h]=this.#t;c[0]===""&&(c.shift(),h.shift());let g=[i,o,a,l,""].join("/"),y=[u,p,d,m,""].join("/");this.#e=[g,...c],this.#t=[y,...h],this.length=this.#e.length;}else if(this.isDrive()||this.isAbsolute()){let[i,...o]=this.#e,[a,...l]=this.#t;o[0]===""&&(o.shift(),l.shift());let c=i+"/",u=a+"/";this.#e=[c,...o],this.#t=[u,...l],this.length=this.#e.length;}}}pattern(){return this.#e[this.#i]}isString(){return typeof this.#e[this.#i]=="string"}isGlobstar(){return this.#e[this.#i]===Oe}isRegExp(){return this.#e[this.#i]instanceof RegExp}globString(){return this.#_=this.#_||(this.#i===0?this.isAbsolute()?this.#t[0]+this.#t.slice(1).join("/"):this.#t.join("/"):this.#t.slice(this.#i).join("/"))}hasMore(){return this.length>this.#i+1}rest(){return this.#o!==void 0?this.#o:this.hasMore()?(this.#o=new r(this.#e,this.#t,this.#i+1,this.#n),this.#o.#a=this.#a,this.#o.#p=this.#p,this.#o.#c=this.#c,this.#o):this.#o=null}isUNC(){let e=this.#e;return this.#p!==void 0?this.#p:this.#p=this.#n==="win32"&&this.#i===0&&e[0]===""&&e[1]===""&&typeof e[2]=="string"&&!!e[2]&&typeof e[3]=="string"&&!!e[3]}isDrive(){let e=this.#e;return this.#c!==void 0?this.#c:this.#c=this.#n==="win32"&&this.#i===0&&this.length>1&&typeof e[0]=="string"&&/^[a-z]:$/i.test(e[0])}isAbsolute(){let e=this.#e;return this.#a!==void 0?this.#a:this.#a=e[0]===""&&e.length>1||this.isDrive()||this.isUNC()}root(){let e=this.#e[0];return typeof e=="string"&&this.isAbsolute()&&this.#i===0?e:""}checkFollowGlobstar(){return !(this.#i===0||!this.isGlobstar()||!this.#l)}markFollowGlobstar(){return this.#i===0||!this.isGlobstar()||!this.#l?false:(this.#l=false,true)}};var Xm=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",Es=class{relative;relativeChildren;absolute;absoluteChildren;platform;mmopts;constructor(e,{nobrace:t,nocase:s,noext:n,noglobstar:i,platform:o=Xm}){this.relative=[],this.absolute=[],this.relativeChildren=[],this.absoluteChildren=[],this.platform=o,this.mmopts={dot:true,nobrace:t,nocase:s,noext:n,noglobstar:i,optimizationLevel:2,platform:o,nocomment:true,nonegate:true};for(let a of e)this.add(a);}add(e){let t=new Ye(e,this.mmopts);for(let s=0;s<t.set.length;s++){let n=t.set[s],i=t.globParts[s];if(!n||!i)throw new Error("invalid pattern object");for(;n[0]==="."&&i[0]===".";)n.shift(),i.shift();let o=new Rs(n,i,0,this.platform),a=new Ye(o.globString(),this.mmopts),l=i[i.length-1]==="**",c=o.isAbsolute();c?this.absolute.push(a):this.relative.push(a),l&&(c?this.absoluteChildren.push(a):this.relativeChildren.push(a));}}ignored(e){let t=e.fullpath(),s=`${t}/`,n=e.relative()||".",i=`${n}/`;for(let o of this.relative)if(o.match(n)||o.match(i))return true;for(let o of this.absolute)if(o.match(t)||o.match(s))return true;return false}childrenIgnored(e){let t=e.fullpath()+"/",s=(e.relative()||".")+"/";for(let n of this.relativeChildren)if(n.match(s))return true;for(let n of this.absoluteChildren)if(n.match(t))return true;return false}};var _o=class r{store;constructor(e=new Map){this.store=e;}copy(){return new r(new Map(this.store))}hasWalked(e,t){return this.store.get(e.fullpath())?.has(t.globString())}storeWalked(e,t){let s=e.fullpath(),n=this.store.get(s);n?n.add(t.globString()):this.store.set(s,new Set([t.globString()]));}},So=class{store=new Map;add(e,t,s){let n=(t?2:0)|(s?1:0),i=this.store.get(e);this.store.set(e,i===void 0?n:n&i);}entries(){return [...this.store.entries()].map(([e,t])=>[e,!!(t&2),!!(t&1)])}},ko=class{store=new Map;add(e,t){if(!e.canReaddir())return;let s=this.store.get(e);s?s.find(n=>n.globString()===t.globString())||s.push(t):this.store.set(e,[t]);}get(e){let t=this.store.get(e);if(!t)throw new Error("attempting to walk unknown path");return t}entries(){return this.keys().map(e=>[e,this.store.get(e)])}keys(){return [...this.store.keys()].filter(e=>e.canReaddir())}},wn=class r{hasWalkedCache;matches=new So;subwalks=new ko;patterns;follow;dot;opts;constructor(e,t){this.opts=e,this.follow=!!e.follow,this.dot=!!e.dot,this.hasWalkedCache=t?t.copy():new _o;}processPatterns(e,t){this.patterns=t;let s=t.map(n=>[e,n]);for(let[n,i]of s){this.hasWalkedCache.storeWalked(n,i);let o=i.root(),a=i.isAbsolute()&&this.opts.absolute!==false;if(o){n=n.resolve(o==="/"&&this.opts.root!==void 0?this.opts.root:o);let p=i.rest();if(p)i=p;else {this.matches.add(n,true,false);continue}}if(n.isENOENT())continue;let l,c,u=false;for(;typeof(l=i.pattern())=="string"&&(c=i.rest());)n=n.resolve(l),i=c,u=true;if(l=i.pattern(),c=i.rest(),u){if(this.hasWalkedCache.hasWalked(n,i))continue;this.hasWalkedCache.storeWalked(n,i);}if(typeof l=="string"){let p=l===".."||l===""||l===".";this.matches.add(n.resolve(l),a,p);continue}else if(l===Oe){(!n.isSymbolicLink()||this.follow||i.checkFollowGlobstar())&&this.subwalks.add(n,i);let p=c?.pattern(),d=c?.rest();if(!c||(p===""||p===".")&&!d)this.matches.add(n,a,p===""||p===".");else if(p===".."){let m=n.parent||n;d?this.hasWalkedCache.hasWalked(m,d)||this.subwalks.add(m,d):this.matches.add(m,a,true);}}else l instanceof RegExp&&this.subwalks.add(n,i);}return this}subwalkTargets(){return this.subwalks.keys()}child(){return new r(this.opts,this.hasWalkedCache)}filterEntries(e,t){let s=this.subwalks.get(e),n=this.child();for(let i of t)for(let o of s){let a=o.isAbsolute(),l=o.pattern(),c=o.rest();l===Oe?n.testGlobstar(i,o,c,a):l instanceof RegExp?n.testRegExp(i,l,c,a):n.testString(i,l,c,a);}return n}testGlobstar(e,t,s,n){if((this.dot||!e.name.startsWith("."))&&(t.hasMore()||this.matches.add(e,n,false),e.canReaddir()&&(this.follow||!e.isSymbolicLink()?this.subwalks.add(e,t):e.isSymbolicLink()&&(s&&t.checkFollowGlobstar()?this.subwalks.add(e,s):t.markFollowGlobstar()&&this.subwalks.add(e,t)))),s){let i=s.pattern();if(typeof i=="string"&&i!==".."&&i!==""&&i!==".")this.testString(e,i,s.rest(),n);else if(i===".."){let o=e.parent||e;this.subwalks.add(o,s);}else i instanceof RegExp&&this.testRegExp(e,i,s.rest(),n);}}testRegExp(e,t,s,n){t.test(e.name)&&(s?this.subwalks.add(e,s):this.matches.add(e,n,false));}testString(e,t,s,n){e.isNamed(t)&&(s?this.subwalks.add(e,s):this.matches.add(e,n,false));}};var Zm=(r,e)=>typeof r=="string"?new Es([r],e):Array.isArray(r)?new Es(r,e):r,Pr=class{path;patterns;opts;seen=new Set;paused=false;aborted=false;#e=[];#t;#i;signal;maxDepth;includeChildMatches;constructor(e,t,s){if(this.patterns=e,this.path=t,this.opts=s,this.#i=!s.posix&&s.platform==="win32"?"\\":"/",this.includeChildMatches=s.includeChildMatches!==false,(s.ignore||!this.includeChildMatches)&&(this.#t=Zm(s.ignore??[],s),!this.includeChildMatches&&typeof this.#t.add!="function")){let n="cannot ignore child matches, ignore lacks add() method.";throw new Error(n)}this.maxDepth=s.maxDepth||1/0,s.signal&&(this.signal=s.signal,this.signal.addEventListener("abort",()=>{this.#e.length=0;}));}#n(e){return this.seen.has(e)||!!this.#t?.ignored?.(e)}#o(e){return !!this.#t?.childrenIgnored?.(e)}pause(){this.paused=true;}resume(){if(this.signal?.aborted)return;this.paused=false;let e;for(;!this.paused&&(e=this.#e.shift());)e();}onResume(e){this.signal?.aborted||(this.paused?this.#e.push(e):e());}async matchCheck(e,t){if(t&&this.opts.nodir)return;let s;if(this.opts.realpath){if(s=e.realpathCached()||await e.realpath(),!s)return;e=s;}let i=e.isUnknown()||this.opts.stat?await e.lstat():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let o=await i.realpath();o&&(o.isUnknown()||this.opts.stat)&&await o.lstat();}return this.matchCheckTest(i,t)}matchCheckTest(e,t){return e&&(this.maxDepth===1/0||e.depth()<=this.maxDepth)&&(!t||e.canReaddir())&&(!this.opts.nodir||!e.isDirectory())&&(!this.opts.nodir||!this.opts.follow||!e.isSymbolicLink()||!e.realpathCached()?.isDirectory())&&!this.#n(e)?e:void 0}matchCheckSync(e,t){if(t&&this.opts.nodir)return;let s;if(this.opts.realpath){if(s=e.realpathCached()||e.realpathSync(),!s)return;e=s;}let i=e.isUnknown()||this.opts.stat?e.lstatSync():e;if(this.opts.follow&&this.opts.nodir&&i?.isSymbolicLink()){let o=i.realpathSync();o&&(o?.isUnknown()||this.opts.stat)&&o.lstatSync();}return this.matchCheckTest(i,t)}matchFinish(e,t){if(this.#n(e))return;if(!this.includeChildMatches&&this.#t?.add){let i=`${e.relativePosix()}/**`;this.#t.add(i);}let s=this.opts.absolute===void 0?t:this.opts.absolute;this.seen.add(e);let n=this.opts.mark&&e.isDirectory()?this.#i:"";if(this.opts.withFileTypes)this.matchEmit(e);else if(s){let i=this.opts.posix?e.fullpathPosix():e.fullpath();this.matchEmit(i+n);}else {let i=this.opts.posix?e.relativePosix():e.relative(),o=this.opts.dotRelative&&!i.startsWith(".."+this.#i)?"."+this.#i:"";this.matchEmit(i?o+i+n:"."+n);}}async match(e,t,s){let n=await this.matchCheck(e,s);n&&this.matchFinish(n,t);}matchSync(e,t,s){let n=this.matchCheckSync(e,s);n&&this.matchFinish(n,t);}walkCB(e,t,s){this.signal?.aborted&&s(),this.walkCB2(e,t,new wn(this.opts),s);}walkCB2(e,t,s,n){if(this.#o(e))return n();if(this.signal?.aborted&&n(),this.paused){this.onResume(()=>this.walkCB2(e,t,s,n));return}s.processPatterns(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||(i++,this.match(a,l,c).then(()=>o()));for(let a of s.subwalkTargets()){if(this.maxDepth!==1/0&&a.depth()>=this.maxDepth)continue;i++;let l=a.readdirCached();a.calledReaddir()?this.walkCB3(a,l,s,o):a.readdirCB((c,u)=>this.walkCB3(a,u,s,o),true);}o();}walkCB3(e,t,s,n){s=s.filterEntries(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||(i++,this.match(a,l,c).then(()=>o()));for(let[a,l]of s.subwalks.entries())i++,this.walkCB2(a,l,s.child(),o);o();}walkCBSync(e,t,s){this.signal?.aborted&&s(),this.walkCB2Sync(e,t,new wn(this.opts),s);}walkCB2Sync(e,t,s,n){if(this.#o(e))return n();if(this.signal?.aborted&&n(),this.paused){this.onResume(()=>this.walkCB2Sync(e,t,s,n));return}s.processPatterns(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||this.matchSync(a,l,c);for(let a of s.subwalkTargets()){if(this.maxDepth!==1/0&&a.depth()>=this.maxDepth)continue;i++;let l=a.readdirSync();this.walkCB3Sync(a,l,s,o);}o();}walkCB3Sync(e,t,s,n){s=s.filterEntries(e,t);let i=1,o=()=>{--i===0&&n();};for(let[a,l,c]of s.matches.entries())this.#n(a)||this.matchSync(a,l,c);for(let[a,l]of s.subwalks.entries())i++,this.walkCB2Sync(a,l,s.child(),o);o();}},_n=class extends Pr{matches=new Set;constructor(e,t,s){super(e,t,s);}matchEmit(e){this.matches.add(e);}async walk(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&await this.path.lstat(),await new Promise((e,t)=>{this.walkCB(this.path,this.patterns,()=>{this.signal?.aborted?t(this.signal.reason):e(this.matches);});}),this.matches}walkSync(){if(this.signal?.aborted)throw this.signal.reason;return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>{if(this.signal?.aborted)throw this.signal.reason}),this.matches}},Sn=class extends Pr{results;constructor(e,t,s){super(e,t,s),this.results=new Dt({signal:this.signal,objectMode:true}),this.results.on("drain",()=>this.resume()),this.results.on("resume",()=>this.resume());}matchEmit(e){this.results.write(e),this.results.flowing||this.pause();}stream(){let e=this.path;return e.isUnknown()?e.lstat().then(()=>{this.walkCB(e,this.patterns,()=>this.results.end());}):this.walkCB(e,this.patterns,()=>this.results.end()),this.results}streamSync(){return this.path.isUnknown()&&this.path.lstatSync(),this.walkCBSync(this.path,this.patterns,()=>this.results.end()),this.results}};var eh=typeof process=="object"&&process&&typeof process.platform=="string"?process.platform:"linux",pt=class{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(e,t){if(!t)throw new TypeError("glob options required");if(this.withFileTypes=!!t.withFileTypes,this.signal=t.signal,this.follow=!!t.follow,this.dot=!!t.dot,this.dotRelative=!!t.dotRelative,this.nodir=!!t.nodir,this.mark=!!t.mark,t.cwd?(t.cwd instanceof URL||t.cwd.startsWith("file://"))&&(t.cwd=fileURLToPath(t.cwd)):this.cwd="",this.cwd=t.cwd||"",this.root=t.root,this.magicalBraces=!!t.magicalBraces,this.nobrace=!!t.nobrace,this.noext=!!t.noext,this.realpath=!!t.realpath,this.absolute=t.absolute,this.includeChildMatches=t.includeChildMatches!==false,this.noglobstar=!!t.noglobstar,this.matchBase=!!t.matchBase,this.maxDepth=typeof t.maxDepth=="number"?t.maxDepth:1/0,this.stat=!!t.stat,this.ignore=t.ignore,this.withFileTypes&&this.absolute!==void 0)throw new Error("cannot set absolute and withFileTypes:true");if(typeof e=="string"&&(e=[e]),this.windowsPathsNoEscape=!!t.windowsPathsNoEscape||t.allowWindowsEscape===false,this.windowsPathsNoEscape&&(e=e.map(l=>l.replace(/\\/g,"/"))),this.matchBase){if(t.noglobstar)throw new TypeError("base matching requires globstar");e=e.map(l=>l.includes("/")?l:`./**/${l}`);}if(this.pattern=e,this.platform=t.platform||eh,this.opts={...t,platform:this.platform},t.scurry){if(this.scurry=t.scurry,t.nocase!==void 0&&t.nocase!==t.scurry.nocase)throw new Error("nocase option contradicts provided scurry option")}else {let l=t.platform==="win32"?xs:t.platform==="darwin"?bn:t.platform?Cs:Kl;this.scurry=new l(this.cwd,{nocase:t.nocase,fs:t.fs});}this.nocase=this.scurry.nocase;let s=this.platform==="darwin"||this.platform==="win32",n={...t,dot:this.dot,matchBase:this.matchBase,nobrace:this.nobrace,nocase:this.nocase,nocaseMagicOnly:s,nocomment:true,noext:this.noext,nonegate:true,optimizationLevel:2,platform:this.platform,windowsPathsNoEscape:this.windowsPathsNoEscape,debug:!!this.opts.debug},i=this.pattern.map(l=>new Ye(l,n)),[o,a]=i.reduce((l,c)=>(l[0].push(...c.set),l[1].push(...c.globParts),l),[[],[]]);this.patterns=o.map((l,c)=>{let u=a[c];if(!u)throw new Error("invalid pattern object");return new Rs(l,u,0,this.platform)});}async walk(){return [...await new _n(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 _n(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 Sn(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 Sn(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 vo=(r,e={})=>{Array.isArray(r)||(r=[r]);for(let t of r)if(new Ye(t,e).hasMagic())return true;return false};function Or(r,e={}){return new pt(r,e).streamSync()}function Yl(r,e={}){return new pt(r,e).stream()}function Xl(r,e={}){return new pt(r,e).walkSync()}async function Vl(r,e={}){return new pt(r,e).walk()}function Lr(r,e={}){return new pt(r,e).iterateSync()}function Zl(r,e={}){return new pt(r,e).iterate()}var th=Or,sh=Object.assign(Yl,{sync:Or}),nh=Lr,rh=Object.assign(Zl,{sync:Lr}),ih=Object.assign(Xl,{stream:Or,iterate:Lr}),Is=Object.assign(Vl,{glob:Vl,globSync:Xl,sync:ih,globStream:Yl,stream:sh,globStreamSync:Or,streamSync:th,globIterate:Zl,iterate:rh,globIterateSync:Lr,iterateSync:nh,Glob:pt,hasMagic:vo,escape:_s,unescape:lt});Is.glob=Is;var kn=class{languageId="typescript";extensions=[".ts",".tsx",".js",".jsx",".mjs",".cjs"];async parse(e,t){let s=e.split(`
|
|
630
630
|
`),n=[],i={class:/^(\s*)(export\s+)?(abstract\s+)?class\s+(\w+)(\s+extends\s+\w+)?(\s+implements\s+[\w,\s]+)?/,interface:/^(\s*)(export\s+)?interface\s+(\w+)(\s+extends\s+[\w,\s]+)?/,type:/^(\s*)(export\s+)?type\s+(\w+)\s*[=<]/,enum:/^(\s*)(export\s+)?enum\s+(\w+)/,function:/^(\s*)(export\s+)?(async\s+)?function\s+(\w+)\s*[<(]/,constFunction:/^(\s*)(export\s+)?(const|let|var)\s+(\w+)\s*[=:]\s*(async\s+)?(\([^)]*\)|[a-zA-Z_]\w*)\s*(=>|:.*=>)/,variable:/^(\s*)(export\s+)?(const|let|var)\s+(\w+)\s*[=:]/,method:/^(\s+)(public\s+|private\s+|protected\s+)?(static\s+)?(async\s+)?(\w+)\s*[<(]/,property:/^(\s+)(public\s+|private\s+|protected\s+)?(static\s+)?(readonly\s+)?(\w+)\s*[=:?]/},o=null,a=0;for(let l=0;l<s.length;l++){let c=s[l],u=l+1;if(o){let g=c.match(/^(\s*)/)?.[1].length||0;c.trim()&&g<=a&&!c.match(/^\s*[})\]]/)&&(o.endLine=l,n.push(o),o=null);}if(c.trim().startsWith("//")||c.trim().startsWith("/*")||!c.trim())continue;let p=c.match(i.class);if(p){if(o&&(o.endLine=l,n.push(o)),a=p[1].length,o={name:p[4],kind:"class",startLine:u,endLine:this.findSymbolEnd(s,l),children:[]},l>0){let g=s[l-1].trim();g.startsWith("/**")||g.startsWith("/*")?o.docstring=this.extractDocstring(s,l-1):g.startsWith("//")&&(o.docstring=g.replace(/^\/\/\s*/,""));}continue}let d=c.match(i.interface);if(d){n.push({name:d[3],kind:"interface",startLine:u,endLine:this.findSymbolEnd(s,l)});continue}let m=c.match(i.type);if(m){n.push({name:m[3],kind:"type",startLine:u,endLine:this.findTypeEnd(s,l)});continue}let h=c.match(i.enum);if(h){n.push({name:h[3],kind:"enum",startLine:u,endLine:this.findSymbolEnd(s,l)});continue}if(!o){let g=c.match(i.function);if(g){n.push({name:g[4],kind:"function",startLine:u,endLine:this.findSymbolEnd(s,l)});continue}let y=c.match(i.constFunction);if(y){n.push({name:y[4],kind:"function",startLine:u,endLine:this.findSymbolEnd(s,l)});continue}let b=c.match(i.variable);if(b&&!i.constFunction.test(c)){n.push({name:b[4],kind:"variable",startLine:u,endLine:u});continue}}if(o){let g=c.match(i.method);if(g&&!["if","for","while","switch","catch","constructor"].includes(g[5])){let b={name:g[5],kind:(g[5]==="constructor","method"),startLine:u,endLine:this.findSymbolEnd(s,l),parent:o.name};o.children.push(b);continue}let y=c.match(i.property);if(y&&!["if","for","while","switch","catch","return","const","let","var"].includes(y[5])){let b={name:y[5],kind:"variable",startLine:u,endLine:u,parent:o.name};o.children.push(b);}}}return o&&(o.endLine=s.length,n.push(o)),n}findSymbolEnd(e,t){return Pt(e,t)}findTypeEnd(e,t){for(let s=t;s<e.length;s++){let n=e[s];if(n.includes(";")||s>t&&/^(export|type|interface|class|function|const|let|var)/.test(n.trim()))return s+1}return t+1}extractDocstring(e,t){let s=[],n=t;for(;n>=0;){let i=e[n].trim();if(i.startsWith("/**")||i.startsWith("/*"))break;n--;}for(let i=n;i<=t;i++){let o=e[i].trim();o=o.replace(/^\/\*\*?\s*/,"").replace(/\*\/\s*$/,"").replace(/^\*\s?/,""),o&&s.push(o);}return s.join(`
|
|
631
|
-
`)}buildSymbolPattern(e,t){let s=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");switch(t){case "function":return `(function|async\\s+function|const|let|var)\\s+${s}\\s*[=(<]`;case "class":return `class\\s+${s}(\\s+extends|\\s+implements|\\s*\\{)`;case "interface":return `interface\\s+${s}(\\s+extends|\\s*\\{)`;case "type":return `type\\s+${s}\\s*[=<]`;case "enum":return `enum\\s+${s}\\s*\\{`;case "method":return `(async\\s+)?${s}\\s*\\(`;case "variable":return `(const|let|var)\\s+${s}\\s*[=:]`;default:return `(function|class|interface|type|enum|const|let|var)\\s+${s}|${s}\\s*(=|\\()`}}};var
|
|
631
|
+
`)}buildSymbolPattern(e,t){let s=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");switch(t){case "function":return `(function|async\\s+function|const|let|var)\\s+${s}\\s*[=(<]`;case "class":return `class\\s+${s}(\\s+extends|\\s+implements|\\s*\\{)`;case "interface":return `interface\\s+${s}(\\s+extends|\\s*\\{)`;case "type":return `type\\s+${s}\\s*[=<]`;case "enum":return `enum\\s+${s}\\s*\\{`;case "method":return `(async\\s+)?${s}\\s*\\(`;case "variable":return `(const|let|var)\\s+${s}\\s*[=:]`;default:return `(function|class|interface|type|enum|const|let|var)\\s+${s}|${s}\\s*(=|\\()`}}};var vn=class{languageId="python";extensions=[".py",".pyw"];async parse(e,t){let s=e.split(`
|
|
632
632
|
`),n=[],i={class:/^(\s*)class\s+(\w+)(\s*\([^)]*\))?\s*:/,function:/^(\s*)(async\s+)?def\s+(\w+)\s*\(/,variable:/^([A-Z][A-Z0-9_]*)\s*[=:]/},o=null,a=-1;for(let l=0;l<s.length;l++){let c=s[l],u=l+1,p=c.match(/^(\s*)/)?.[1].length||0;if(o&&c.trim()&&p<=a&&(o.endLine=l,n.push(o),o=null,a=-1),c.trim().startsWith("#")||!c.trim())continue;let d=c.match(i.class);if(d){o&&(o.endLine=l,n.push(o)),a=d[1].length,o={name:d[2],kind:"class",startLine:u,endLine:this.findClassEnd(s,l,a),children:[],docstring:this.extractDocstring(s,l+1)};continue}let m=c.match(i.function);if(m){let h=m[1].length,g=m[3],y=o&&h>a,b={name:g,kind:y?"method":"function",startLine:u,endLine:this.findFunctionEnd(s,l,h),docstring:this.extractDocstring(s,l+1)};y&&o?(b.parent=o.name,o.children.push(b)):n.push(b);continue}if(!o&&c.match(i.variable)){let h=c.match(i.variable);h&&n.push({name:h[1],kind:"constant",startLine:u,endLine:u});}}return o&&(o.endLine=s.length,n.push(o)),n}findClassEnd(e,t,s){for(let n=t+1;n<e.length;n++){let i=e[n];if(!i.trim())continue;if((i.match(/^(\s*)/)?.[1].length||0)<=s)return n}return e.length}findFunctionEnd(e,t,s){let n=false;for(let i=t+1;i<e.length;i++){let o=e[i];if(!o.trim())continue;let a=o.match(/^(\s*)/)?.[1].length||0;if(a>s){n=true;continue}if(n&&a<=s)return i}return e.length}extractDocstring(e,t){if(t>=e.length)return;let s=e[t].trim();if(s.startsWith('"""')||s.startsWith("'''")){let n=s.startsWith('"""')?'"""':"'''";if(s.endsWith(n)&&s.length>6)return s.slice(3,-3);let i=[s.slice(3)];for(let o=t+1;o<e.length;o++){let a=e[o].trim();if(a.endsWith(n)){i.push(a.slice(0,-3));break}i.push(a);}return i.join(`
|
|
633
|
-
`).trim()}}buildSymbolPattern(e,t){let s=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");switch(t){case "function":case "method":return `(async\\s+)?def\\s+${s}\\s*\\(`;case "class":return `class\\s+${s}(\\s*\\(|\\s*:)`;case "variable":case "constant":return `^${s}\\s*[=:]`;default:return `(def|class)\\s+${s}|^${s}\\s*[=:]`}}};var
|
|
634
|
-
`),n=[],i={function:[/^(\s*)(export\s+)?(public\s+|private\s+|protected\s+)?(static\s+)?(async\s+)?(function\s+)?(\w+)\s*\([^)]*\)\s*[:{]/,/^(\s*)func\s+(\w+)\s*\(/,/^(\s*)(pub\s+)?fn\s+(\w+)\s*[<(]/,/^(\s*)(async\s+)?def\s+(\w+)\s*\(/,/^(\s*)def\s+(\w+)/],class:[/^(\s*)(export\s+)?(public\s+|abstract\s+)?(class|struct)\s+(\w+)/,/^(\s*)type\s+(\w+)\s+struct/,/^(\s*)(pub\s+)?struct\s+(\w+)/,/^(\s*)impl\s+(\w+)/],interface:[/^(\s*)(export\s+)?interface\s+(\w+)/,/^(\s*)type\s+(\w+)\s+interface/,/^(\s*)(pub\s+)?trait\s+(\w+)/],constant:[/^(\s*)(export\s+)?(const|final|static\s+final)\s+([A-Z_][A-Z0-9_]*)\s*[=:]/]};for(let o=0;o<s.length;o++){let a=s[o],l=o+1;if(!this.isComment(a)){for(let c of i.function){let u=a.match(c);if(u){let p=this.extractName(u);p&&!this.isKeyword(p)&&n.push({name:p,kind:"function",startLine:l,endLine:Pt(s,o)});break}}for(let c of i.class){let u=a.match(c);if(u){let p=this.extractName(u);p&&n.push({name:p,kind:"class",startLine:l,endLine:Pt(s,o)});break}}for(let c of i.interface){let u=a.match(c);if(u){let p=this.extractName(u);p&&n.push({name:p,kind:"interface",startLine:l,endLine:Pt(s,o)});break}}for(let c of i.constant){let u=a.match(c);if(u){let p=this.extractName(u);p&&n.push({name:p,kind:"constant",startLine:l,endLine:l});break}}}}return n}extractName(e){for(let t=e.length-1;t>0;t--){let s=e[t];if(s&&/^\w+$/.test(s)&&!this.isModifier(s))return s}return null}isModifier(e){return ["public","private","protected","static","final","abstract","async","export","const","let","var","function","class","interface","type","enum","struct","impl","fn","func","def","pub","trait"].includes(e.toLowerCase())}isKeyword(e){return ["if","else","for","while","do","switch","case","break","continue","return","try","catch","finally","throw","new","this","super","null","undefined","true","false","import","from","as","default","with","in","of","get","set","constructor"].includes(e)}isComment(e){let t=e.trim();return t.startsWith("//")||t.startsWith("#")||t.startsWith("/*")||t.startsWith("*")||t.startsWith("--")}buildSymbolPattern(e,t){let s=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");switch(t){case "function":return `(function|func|fn|def)\\s+${s}|${s}\\s*\\(`;case "class":return `(class|struct|type)\\s+${s}`;case "interface":return `(interface|trait)\\s+${s}`;default:return `(function|class|interface|struct|type|func|fn|def)\\s+${s}|${s}\\s*[=(]`}}};var xn=class{parsers=new Map;constructor(){this.register(new
|
|
633
|
+
`).trim()}}buildSymbolPattern(e,t){let s=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");switch(t){case "function":case "method":return `(async\\s+)?def\\s+${s}\\s*\\(`;case "class":return `class\\s+${s}(\\s*\\(|\\s*:)`;case "variable":case "constant":return `^${s}\\s*[=:]`;default:return `(def|class)\\s+${s}|^${s}\\s*[=:]`}}};var Tn=class{languageId="generic";extensions=["*"];async parse(e,t){let s=e.split(`
|
|
634
|
+
`),n=[],i={function:[/^(\s*)(export\s+)?(public\s+|private\s+|protected\s+)?(static\s+)?(async\s+)?(function\s+)?(\w+)\s*\([^)]*\)\s*[:{]/,/^(\s*)func\s+(\w+)\s*\(/,/^(\s*)(pub\s+)?fn\s+(\w+)\s*[<(]/,/^(\s*)(async\s+)?def\s+(\w+)\s*\(/,/^(\s*)def\s+(\w+)/],class:[/^(\s*)(export\s+)?(public\s+|abstract\s+)?(class|struct)\s+(\w+)/,/^(\s*)type\s+(\w+)\s+struct/,/^(\s*)(pub\s+)?struct\s+(\w+)/,/^(\s*)impl\s+(\w+)/],interface:[/^(\s*)(export\s+)?interface\s+(\w+)/,/^(\s*)type\s+(\w+)\s+interface/,/^(\s*)(pub\s+)?trait\s+(\w+)/],constant:[/^(\s*)(export\s+)?(const|final|static\s+final)\s+([A-Z_][A-Z0-9_]*)\s*[=:]/]};for(let o=0;o<s.length;o++){let a=s[o],l=o+1;if(!this.isComment(a)){for(let c of i.function){let u=a.match(c);if(u){let p=this.extractName(u);p&&!this.isKeyword(p)&&n.push({name:p,kind:"function",startLine:l,endLine:Pt(s,o)});break}}for(let c of i.class){let u=a.match(c);if(u){let p=this.extractName(u);p&&n.push({name:p,kind:"class",startLine:l,endLine:Pt(s,o)});break}}for(let c of i.interface){let u=a.match(c);if(u){let p=this.extractName(u);p&&n.push({name:p,kind:"interface",startLine:l,endLine:Pt(s,o)});break}}for(let c of i.constant){let u=a.match(c);if(u){let p=this.extractName(u);p&&n.push({name:p,kind:"constant",startLine:l,endLine:l});break}}}}return n}extractName(e){for(let t=e.length-1;t>0;t--){let s=e[t];if(s&&/^\w+$/.test(s)&&!this.isModifier(s))return s}return null}isModifier(e){return ["public","private","protected","static","final","abstract","async","export","const","let","var","function","class","interface","type","enum","struct","impl","fn","func","def","pub","trait"].includes(e.toLowerCase())}isKeyword(e){return ["if","else","for","while","do","switch","case","break","continue","return","try","catch","finally","throw","new","this","super","null","undefined","true","false","import","from","as","default","with","in","of","get","set","constructor"].includes(e)}isComment(e){let t=e.trim();return t.startsWith("//")||t.startsWith("#")||t.startsWith("/*")||t.startsWith("*")||t.startsWith("--")}buildSymbolPattern(e,t){let s=e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&");switch(t){case "function":return `(function|func|fn|def)\\s+${s}|${s}\\s*\\(`;case "class":return `(class|struct|type)\\s+${s}`;case "interface":return `(interface|trait)\\s+${s}`;default:return `(function|class|interface|struct|type|func|fn|def)\\s+${s}|${s}\\s*[=(]`}}};var xn=class{parsers=new Map;constructor(){this.register(new kn),this.register(new vn),this.register(new Tn);}register(e){this.parsers.set(e.languageId,e);for(let t of e.extensions){let s=this.getLanguageFromExtension(t);s&&this.parsers.has(s);}}getParser(e){return this.parsers.has(e)?this.parsers.get(e):e==="javascript"?this.parsers.get("typescript")||null:this.parsers.get("generic")||null}getLanguageFromExtension(e){return {".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".py":"python",".java":"java",".go":"go",".rs":"rust"}[e]||null}getSupportedLanguages(){return Array.from(this.parsers.keys()).filter(e=>e!=="generic")}};var oh="1.0.0",Dr=class{workspacePath;config;metadata=null;fileIndexCache=new Map;parserRegistry;constructor(e,t={}){this.workspacePath=e,this.config={...Za,...t},this.parserRegistry=new xn;}get indexDir(){return X.join(this.workspacePath,this.config.cacheDir)}async hasIndex(){let e=X.join(this.indexDir,"meta.json");return el(e)}async loadMetadata(){if(this.metadata)return this.metadata;let e=X.join(this.indexDir,"meta.json");try{let t=await Z.readFile(e,"utf-8");return this.metadata=JSON.parse(t),this.metadata}catch{return null}}async saveMetadata(){if(!this.metadata)return;await rn(this.indexDir);let e=X.join(this.indexDir,"meta.json");await Z.writeFile(e,JSON.stringify(this.metadata,null,2));}async buildIndex(e={}){let t=Date.now(),s=[],{paths:n=this.config.include,languages:i=this.config.languages,force:o=false,onProgress:a}=e;await rn(this.indexDir),await rn(X.join(this.indexDir,"files"));let l=[];for(let p of n){let d=await Is(p,{cwd:this.workspacePath,absolute:true,ignore:this.config.exclude});for(let m of d){let h=eo(m);h&&i.includes(h)&&l.push(m);}}let c=0,u=0;for(let p=0;p<l.length;p++){let d=l[p];a?.(p+1,l.length,d);try{if(!o){let h=await this.getFileIndex(d);if(h){let g=await Z.stat(d);if(h.mtime>=g.mtimeMs){u+=h.symbols.length,c++;continue}}}let m=await this.indexFile(d);m&&(await this.saveFileIndex(m),this.fileIndexCache.set(d,m),u+=m.symbols.length,c++);}catch(m){s.push({file:d,error:m.message});}}return this.metadata={version:oh,createdAt:this.metadata?.createdAt||Date.now(),updatedAt:Date.now(),fileCount:c,symbolCount:u,languages:i,indexDir:this.config.cacheDir},await this.saveMetadata(),{success:s.length===0,filesIndexed:c,symbolsFound:u,timeMs:Date.now()-t,errors:s}}async indexFile(e){let t=eo(e);if(!t)return null;let s=this.parserRegistry.getParser(t);if(!s)return null;try{let n=await Z.readFile(e,"utf-8"),i=await Z.stat(e),o=await s.parse(n,e),a=this.extractImports(n,t),l=this.extractExports(n,t);return {path:e,hash:Qa(n),mtime:i.mtimeMs,totalLines:n.split(`
|
|
635
635
|
`).length,symbols:o,imports:a,exports:l}}catch{return null}}extractImports(e,t){let s=[],n=e.split(`
|
|
636
636
|
`);if(["typescript","javascript"].includes(t)){let i=/^import\s+(?:(?:\{([^}]+)\}|(\w+))\s+from\s+)?['"]([^'"]+)['"]/;n.forEach((o,a)=>{let l=o.match(i);if(l){let c=l[1]?.split(",").map(u=>u.trim())||(l[2]?[l[2]]:[]);s.push({module:l[3],line:a+1,names:c.filter(Boolean)});}});}if(t==="python"){let i=/^(?:from\s+(\S+)\s+import\s+(.+)|import\s+(\S+))/;n.forEach((o,a)=>{let l=o.match(i);if(l){let c=l[1]||l[3],u=l[2]?.split(",").map(p=>p.trim())||[];s.push({module:c,line:a+1,names:u});}});}return s}extractExports(e,t){let s=[],n=e.split(`
|
|
637
|
-
`);if(["typescript","javascript"].includes(t)){let i=/^export\s+(?:(default)\s+)?(?:(class|function|const|let|var|interface|type|enum)\s+)?(\w+)?/;n.forEach((o,a)=>{let l=o.match(i);if(l){let c=l[2],u=l[3]||(l[1]?"default":"");u&&s.push({name:u,line:a+1,kind:c});}});}return s}async getFileIndex(e){if(this.fileIndexCache.has(e))return this.fileIndexCache.get(e);let t=this.getFileIndexPath(e);try{let s=await
|
|
637
|
+
`);if(["typescript","javascript"].includes(t)){let i=/^export\s+(?:(default)\s+)?(?:(class|function|const|let|var|interface|type|enum)\s+)?(\w+)?/;n.forEach((o,a)=>{let l=o.match(i);if(l){let c=l[2],u=l[3]||(l[1]?"default":"");u&&s.push({name:u,line:a+1,kind:c});}});}return s}async getFileIndex(e){if(this.fileIndexCache.has(e))return this.fileIndexCache.get(e);let t=this.getFileIndexPath(e);try{let s=await Z.readFile(t,"utf-8"),n=JSON.parse(s);return this.fileIndexCache.set(e,n),n}catch{return null}}async saveFileIndex(e){let t=this.getFileIndexPath(e.path);await rn(X.dirname(t)),await Z.writeFile(t,JSON.stringify(e,null,2));}getFileIndexPath(e){let s=X.relative(this.workspacePath,e).replace(/[/\\]/g,"_").replace(/\./g,"_");return X.join(this.indexDir,"files",`${s}.json`)}async searchSymbol(e){let{query:t,kind:s,fuzzy:n=false,limit:i=20}=e,o=[],a=X.join(this.indexDir,"files");try{let l=await Z.readdir(a);for(let c of l)if(c.endsWith(".json"))try{let u=await Z.readFile(X.join(a,c),"utf-8"),p=JSON.parse(u);for(let d of p.symbols){if(s&&d.kind!==s)continue;let m=0;if(n){if(m=to(t.toLowerCase(),d.name.toLowerCase()),m<.5)continue}else {if(!d.name.toLowerCase().includes(t.toLowerCase()))continue;m=d.name.toLowerCase()===t.toLowerCase()?1:.8;}if(o.push({symbol:d,file:p.path,score:m}),d.children)for(let h of d.children){if(s&&h.kind!==s)continue;let g=0;if(n){if(g=to(t.toLowerCase(),h.name.toLowerCase()),g<.5)continue}else {if(!h.name.toLowerCase().includes(t.toLowerCase()))continue;g=h.name.toLowerCase()===t.toLowerCase()?1:.8;}o.push({symbol:{...h,parent:d.name},file:p.path,score:g});}}}catch{continue}}catch{}return o.sort((l,c)=>c.score-l.score).slice(0,i)}async invalidate(e){this.fileIndexCache.delete(e);let t=this.getFileIndexPath(e);try{await Z.unlink(t);}catch{}}async clear(){this.fileIndexCache.clear(),this.metadata=null;try{await Z.rm(this.indexDir,{recursive:!0,force:!0});}catch{}}async getStats(){let e=await this.loadMetadata();if(!e)return {hasIndex:false,fileCount:0,symbolCount:0,lastUpdated:null,size:0};let t=0;try{let s=X.join(this.indexDir,"files"),n=await Z.readdir(s);for(let i of n){let o=await Z.stat(X.join(s,i));t+=o.size;}}catch{}return {hasIndex:true,fileCount:e.fileCount,symbolCount:e.symbolCount,lastUpdated:new Date(e.updatedAt),size:t}}};function To(r,e){return new Dr(r,e)}var Ms=null,As=null,Nr=null,Vt={small:hs,large:1e3},Ql=12e3,ah=120,$r=20,lh=3,ch=200,xo=200;function uh(r){return (!Ms||Nr!==r)&&(Ms=so(r),Nr=r,As&&Ms.setIndexManager(As)),Ms}function Cn(r){return (!As||Nr!==r)&&(As=To(r),Nr=r,Ms&&Ms.setIndexManager(As)),As}function ph(r){return process.cwd()}function yt(r){let e=ph();return X.relative(e,r)||r}function ec(r,e){let t=X.relative(r,e);return t===""?true:!t.startsWith("..")&&!X.isAbsolute(t)}function dh(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}async function Co(r){let e=r||process.cwd(),s=await Cn(e).getStats();return {hasIndex:s.hasIndex,fileCount:s.fileCount,symbolCount:s.symbolCount,lastUpdated:s.lastUpdated}}async function tc(r){let e=await Co(r);return e.hasIndex?`
|
|
638
638
|
\u{1F4D6} readfile \u7B56\u7565\u63D0\u793A (\u7D22\u5F15\u5DF2\u542F\u7528, ${e.symbolCount} \u7B26\u53F7):
|
|
639
639
|
- \u5C0F\u6587\u4EF6 (\u2264${Vt.small}\u884C): \u9ED8\u8BA4 full \u8BFB\u53D6
|
|
640
640
|
- \u5927\u6587\u4EF6 (>${Vt.large}\u884C): \u4F18\u5148\u7528 symbol/function/class \u5B9A\u4F4D
|
|
@@ -645,8 +645,8 @@ globstar while`,e,d,t,m,h),this.matchOne(e.slice(d),t.slice(m),s))return this.de
|
|
|
645
645
|
- \u7D22\u5F15\u672A\u6784\u5EFA\uFF0C\u4F7F\u7528 pattern/grep \u5B9A\u4F4D
|
|
646
646
|
- \u5C0F\u6587\u4EF6 (\u2264${Vt.small}\u884C): \u9ED8\u8BA4 full \u8BFB\u53D6
|
|
647
647
|
- \u5927\u6587\u4EF6: \u5148\u7528 pattern/list_matches \u5B9A\u4F4D\uFF0C\u518D\u7528 anchor_lines/ranges \u6279\u91CF\u8BFB\u53D6
|
|
648
|
-
- \u{1F4A1} \u8FD0\u884C build_index() \u53EF\u4EE5\u542F\u7528\u7B26\u53F7\u5B9A\u4F4D\u529F\u80FD`}async function
|
|
649
|
-
`)}function
|
|
648
|
+
- \u{1F4A1} \u8FD0\u884C build_index() \u53EF\u4EE5\u542F\u7528\u7B26\u53F7\u5B9A\u4F4D\u529F\u80FD`}async function Ro(r){let e=await Co(r);await tc(r);let s=["## readfile \u6587\u4EF6\u8BFB\u53D6\u7B56\u7565",""];return e.hasIndex?(s.push(`\u2705 \u4EE3\u7801\u7D22\u5F15\u5DF2\u542F\u7528 (${e.fileCount} \u6587\u4EF6, ${e.symbolCount} \u7B26\u53F7)`),s.push(""),s.push("### \u6309\u6587\u4EF6\u5927\u5C0F\u9009\u62E9\u7B56\u7565:"),s.push(""),s.push("| \u6587\u4EF6\u5927\u5C0F | \u63A8\u8350\u7B56\u7565 | \u793A\u4F8B |"),s.push("|---------|---------|------|"),s.push(`| \u2264${Vt.small}\u884C | full \u81EA\u52A8\u8BFB\u53D6 | \`readfile(path)\` |`),s.push(`| ${Vt.small}-${Vt.large}\u884C | \u5747\u53EF | \u6309\u9700\u9009\u62E9 |`),s.push(`| >${Vt.large}\u884C | **symbol/function** | \`readfile(path, function="xxx")\` |`)):(s.push("\u26A0\uFE0F \u4EE3\u7801\u7D22\u5F15\u672A\u6784\u5EFA"),s.push(""),s.push("\u5F53\u524D\u53EF\u7528\u7B56\u7565:"),s.push("- `start_line`: \u6309\u884C\u53F7\u8BFB\u53D6"),s.push("- `pattern`: \u6B63\u5219\u5339\u914D\u5B9A\u4F4D\uFF08\u53EF\u914D\u5408 list_matches\uFF09"),s.push("- `range_start/end`: \u8303\u56F4\u8BFB\u53D6"),s.push(""),s.push("\u{1F4A1} \u8FD0\u884C `build_index()` \u542F\u7528\u7B26\u53F7\u5B9A\u4F4D\u529F\u80FD")),s.join(`
|
|
649
|
+
`)}function Eo(r){let e=()=>r||process.cwd(),t={name:"readfile",description:`\u3010\u667A\u80FD\u6587\u4EF6\u8BFB\u53D6\u3011\u7CBE\u51C6\u5B9A\u4F4D\u4EE3\u7801\u4F4D\u7F6E\uFF0C\u652F\u6301\u591A\u79CD\u5B9A\u4F4D\u65B9\u5F0F\u3002
|
|
650
650
|
|
|
651
651
|
\u{1F525} \u57FA\u7840\u7528\u6CD5:
|
|
652
652
|
readfile(path="src/main.ts") \u2192 \u8BFB\u53D6\u6587\u4EF6\u5F00\u5934 200 \u884C
|
|
@@ -690,24 +690,24 @@ readfile(path="src/main.ts", range_start="// BEGIN CONFIG", range_end="// END CO
|
|
|
690
690
|
- \u{1F525} edit_file \u524D\u5FC5\u987B\u5148 readfile(..., for_edit=true) - old_string \u987B\u4ECE\u8F93\u51FA\u7CBE\u786E\u590D\u5236
|
|
691
691
|
- for_edit=true \u4F1A\u5305\u542B COPY \u533A\u5757\uFF08\u8F93\u51FA\u66F4\u5927\uFF09
|
|
692
692
|
- max_output_chars \u53EF\u9650\u5236\u8F93\u51FA\u957F\u5EA6
|
|
693
|
-
- \u652F\u6301 TypeScript/JavaScript/Python/Java \u7B49\u591A\u79CD\u8BED\u8A00`,parameters:{type:"object",properties:{path:{type:"string",description:"\u6587\u4EF6\u8DEF\u5F84 (\u5FC5\u9700)"},start_line:{type:"number",description:"\u8D77\u59CB\u884C\u53F7 (1-indexed)"},end_line:{type:"number",description:"\u7ED3\u675F\u884C\u53F7"},num_lines:{type:"number",description:`\u8BFB\u53D6\u884C\u6570 (\u9ED8\u8BA4: ${
|
|
694
|
-
`);return {absPath:
|
|
695
|
-
`)}let ye=
|
|
696
|
-
`)}catch(
|
|
697
|
-
`).length,
|
|
698
|
-
${
|
|
699
|
-
`).trimEnd()}catch(
|
|
700
|
-
`).map(ye=>{let
|
|
701
|
-
`);
|
|
702
|
-
`)},
|
|
693
|
+
- \u652F\u6301 TypeScript/JavaScript/Python/Java \u7B49\u591A\u79CD\u8BED\u8A00`,parameters:{type:"object",properties:{path:{type:"string",description:"\u6587\u4EF6\u8DEF\u5F84 (\u5FC5\u9700)"},start_line:{type:"number",description:"\u8D77\u59CB\u884C\u53F7 (1-indexed)"},end_line:{type:"number",description:"\u7ED3\u675F\u884C\u53F7"},num_lines:{type:"number",description:`\u8BFB\u53D6\u884C\u6570 (\u9ED8\u8BA4: ${sn})`},symbol:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (\u51FD\u6570\u540D\u3001\u7C7B\u540D\u3001\u53D8\u91CF\u540D\u7B49)"},symbol_kind:{type:"string",description:"\u7B26\u53F7\u7C7B\u578B: function, class, interface, method, variable, type, enum",enum:["function","class","interface","method","variable","type","enum"]},class_name:{type:"string",description:"\u6240\u5C5E\u7C7B\u540D (\u7528\u4E8E\u5B9A\u4F4D\u7C7B\u7684\u65B9\u6CD5)"},function:{type:"string",description:"\u51FD\u6570\u540D (\u5FEB\u6377\u65B9\u5F0F\uFF0C\u7B49\u540C\u4E8E symbol + symbol_kind=function)"},class:{type:"string",description:"\u7C7B\u540D (\u5FEB\u6377\u65B9\u5F0F\uFF0C\u7B49\u540C\u4E8E symbol + symbol_kind=class)"},pattern:{type:"string",description:"\u641C\u7D22\u6A21\u5F0F (\u6B63\u5219\u8868\u8FBE\u5F0F)"},match_index:{type:"number",description:"\u5339\u914D\u7B2C\u51E0\u4E2A\u7ED3\u679C (\u9ED8\u8BA4: 1)"},list_matches:{type:"boolean",description:"\u4EC5\u5217\u51FA\u5339\u914D\u884C\u6458\u8981 (\u9ED8\u8BA4: false, \u9700\u914D\u5408 pattern)"},range_start:{type:"string",description:"\u8303\u56F4\u5F00\u59CB\u6A21\u5F0F"},range_end:{type:"string",description:"\u8303\u56F4\u7ED3\u675F\u6A21\u5F0F"},ranges:{type:"array",items:{type:"object",properties:{start:{type:"number"},end:{type:"number"}},required:["start"]},description:'\u591A\u4E2A\u884C\u8303\u56F4\u6279\u91CF\u8BFB\u53D6 (e.g., [{"start":10,"end":120},{"start":300,"end":480}])'},anchor_lines:{type:"array",items:{type:"number"},description:"\u6309\u884C\u53F7\u6279\u91CF\u8BFB\u53D6 (\u4F1A\u4EE5\u884C\u53F7\u4E3A\u4E2D\u5FC3\u5C55\u5F00 num_lines \u6216 context)"},context:{type:"number",description:"\u4E0A\u4E0B\u6587\u884C\u6570 (\u9ED8\u8BA4: 10)"},use_index:{type:"boolean",description:"\u662F\u5426\u4F7F\u7528\u7D22\u5F15 (\u9ED8\u8BA4: true, \u5982\u679C\u7D22\u5F15\u53EF\u7528)"},for_edit:{type:"boolean",description:"\u662F\u5426\u5305\u542B edit_file \u53EF\u590D\u5236\u7684\u539F\u59CB\u5185\u5BB9\u5757 (\u9ED8\u8BA4: false)"},max_output_chars:{type:"number",description:`\u6700\u5927\u8F93\u51FA\u5B57\u7B26\u6570 (\u9ED8\u8BA4: ${Ql})`},read_all:{type:"boolean",description:"\u4E00\u6B21\u6027\u8BFB\u53D6\u6574\u4E2A\u6587\u4EF6 (\u5FFD\u7565 num_lines \u9650\u5236\uFF0C\u9002\u7528\u4E8E\u5C0F\u6587\u4EF6\u5982 SKILL.md)"}},required:["path"]},async function(l){let{path:c,start_line:u,end_line:p,num_lines:d,symbol:m,symbol_kind:h,class_name:g,function:y,class:b,pattern:w,match_index:S,list_matches:x,range_start:R,range_end:$,ranges:G,anchor_lines:U,context:T,use_index:C=true,for_edit:_,max_output_chars:k,read_all:D}=l,N=e(),E=uh(N),A=_===true,F=typeof T=="number"?Math.max(0,T):hr,H=typeof k=="number"&&k>0?Math.floor(k):Ql,M=D?nn:d||(A?ah:sn);M=Math.min(M,nn),!d&&w&&(M=Math.max($r,F*2+1));let ee=Array.isArray(G)&&G.length>0,P=Array.isArray(U)&&U.length>0,q=x===true;if(A&&(ee||P||q))return "\u2717 for_edit=true \u6682\u4E0D\u652F\u6301 list_matches / ranges / anchor_lines\uFF0C\u8BF7\u4F7F\u7528\u5355\u6B21 readfile \u83B7\u53D6\u53EF\u7F16\u8F91\u7247\u6BB5\u3002";let B=()=>X.isAbsolute(c)?c:X.resolve(N,c),j=async()=>{let W=B(),ie=await Z.readFile(W,"utf-8"),v=bs(ie).split(`
|
|
694
|
+
`);return {absPath:W,lines:v,totalLines:v.length}},Y=(W,ie,Q)=>{let v=Math.max(1,Math.floor(W)),I=typeof ie=="number"?Math.floor(ie):v+M-1,J=Math.min(Q,Math.max(I,v));return {start:v,end:J}},ae=W=>{let ie=W.filter(v=>Number.isFinite(v.start)&&Number.isFinite(v.end)).sort((v,I)=>v.start-I.start),Q=[];for(let v of ie){let I=Q[Q.length-1];!I||v.start>I.end+1?Q.push({...v}):I.end=Math.max(I.end,v.end);}return Q};if(q){if(!w)return "\u2717 list_matches \u9700\u8981\u914D\u5408 pattern \u4F7F\u7528";try{let{absPath:W,lines:ie,totalLines:Q}=await j(),v;try{v=new RegExp(w,"gi");}catch(re){return `\u2717 \u65E0\u6548\u7684\u6B63\u5219\u8868\u8FBE\u5F0F: ${re.message}`}let I=[];ie.forEach((re,te)=>{v.test(re)&&I.push({line:te+1,text:re}),v.lastIndex=0;});let J=yt(W);if(I.length===0){let re=$e(ie.slice(0,Math.min(50,Q)),1);return [`\u2713 \u6587\u4EF6: ${J}`,`\u603B\u884C\u6570: ${Q} | \u5339\u914D: 0`,"\u7B56\u7565: grep-list","",`\u672A\u627E\u5230\u5339\u914D: "${w}"`,"","--- \u5185\u5BB9\uFF08\u5E26\u884C\u53F7\uFF0C\u4FBF\u4E8E\u9605\u8BFB\uFF09---",re].join(`
|
|
695
|
+
`)}let ye=xo+12,O=Math.max(5,Math.min(ch,Math.floor(H/ye))),K=I.slice(0,O),L=K.map(re=>{let te=re.text.length>xo?`${re.text.slice(0,xo)}...`:re.text;return `${String(re.line).padStart(6)} \u2502 ${te}`}),z=[`\u2713 \u6587\u4EF6: ${J}`,`\u603B\u884C\u6570: ${Q} | \u5339\u914D: ${I.length}`,"\u7B56\u7565: grep-list","",`--- \u5339\u914D\u6458\u8981\uFF08\u524D ${L.length}/${I.length}\uFF09---`,...L];L.length<I.length&&z.push("","\u26A0\uFE0F \u6458\u8981\u5DF2\u622A\u65AD\uFF0C\u8C03\u6574 max_output_chars \u6216\u7F29\u5C0F pattern");let ue=K.slice(0,5).map(re=>re.line).join(", ");return z.push("",`\u{1F4A1} \u8BFB\u53D6\u5339\u914D\u9644\u8FD1: readfile(path="${J}", anchor_lines=[${ue}], num_lines=${Math.min(200,M)})`),z.join(`
|
|
696
|
+
`)}catch(W){return `\u2717 \u8BFB\u53D6\u5931\u8D25: ${W.message}`}}if(ee||P)try{let{absPath:W,lines:ie,totalLines:Q}=await j(),v=[];if(ee)for(let L of G)!L||typeof L.start!="number"||v.push(Y(L.start,L.end,Q));else if(P){let L=Math.max(1,d||F*2+1);for(let z of U){if(typeof z!="number"||Number.isNaN(z))continue;let ue=Math.max(1,Math.floor(z-Math.floor(L/2))),re=Math.min(Q,ue+L-1);v.push({start:ue,end:re});}}if(v.length===0)return "\u2717 ranges/anchor_lines \u4E3A\u7A7A\uFF0C\u65E0\u6CD5\u8BFB\u53D6";let I=ae(v),ye=[`\u2713 \u6587\u4EF6: ${yt(W)}`,`\u603B\u884C\u6570: ${Q} | \u533A\u5757: ${I.length}`,"\u7B56\u7565: batch-range","","--- \u5185\u5BB9\uFF08\u5E26\u884C\u53F7\uFF0C\u4FBF\u4E8E\u9605\u8BFB\uFF09---"],O=ye.join(`
|
|
697
|
+
`).length,K=0;for(let[L,z]of I.entries()){let ue=$e(ie.slice(z.start-1,z.end),z.start),te=`${`# \u533A\u5757 ${L+1}: ${z.start}-${z.end}`}
|
|
698
|
+
${ue}`;if(O+te.length+2>H&&K>0)break;ye.push(te,""),O+=te.length+2,K+=1;}return K<I.length&&ye.push(`\u26A0\uFE0F \u8F93\u51FA\u5DF2\u622A\u65AD\uFF0C\u4EC5\u663E\u793A\u524D ${K} \u4E2A\u533A\u5757`),ye.join(`
|
|
699
|
+
`).trimEnd()}catch(W){return `\u2717 \u8BFB\u53D6\u5931\u8D25: ${W.message}`}let _e;u?_e={type:"line",start:u,end:p}:y?_e={type:"function",name:y,className:g}:b?_e={type:"class",name:b}:m?_e={type:"symbol",name:m,kind:h}:w?_e={type:"pattern",regex:w,matchIndex:S,context:F}:R&&$&&(_e={type:"range",startPattern:R,endPattern:$});let Pe=W=>{let Q=[`\u2713 \u6587\u4EF6: ${yt(W.path)}`,`\u603B\u884C\u6570: ${W.totalLines} | \u663E\u793A: \u7B2C ${W.startLine}-${W.endLine} \u884C`,`\u7B56\u7565: ${W.strategy}${W.metadata?.matchedLine?` | \u5339\u914D\u884C: ${W.metadata.matchedLine}`:""}`];if(W.metadata?.symbol&&Q.push(`\u7B26\u53F7: ${W.metadata.symbol.name} (${W.metadata.symbol.kind})`),W.truncated&&(Q.push(""),Q.push(`\u26A0\uFE0F \u5185\u5BB9\u5DF2\u622A\u65AD\uFF0C\u4F7F\u7528 start_line=${W.endLine+1} \u7EE7\u7EED\u8BFB\u53D6`)),Q.push(""),Q.push("--- \u5185\u5BB9\uFF08\u5E26\u884C\u53F7\uFF0C\u4FBF\u4E8E\u9605\u8BFB\uFF09---"),Q.push(W.content),A){let J=W.content.split(`
|
|
700
|
+
`).map(ye=>{let O=ye.match(/^\s*\d+\s*│\s?(.*)$/);return O?O[1]:ye}).join(`
|
|
701
|
+
`);Q.push(""),Q.push("--- \u{1F525} COPY THIS FOR edit_file old_string (\u4E0D\u5E26\u884C\u53F7) ---"),Q.push(J),Q.push("--- END ---");}return Q.join(`
|
|
702
|
+
`)},ne=0,le="",be=!d;for(;;){let W=await E.read({path:c,locator:_e,mode:"smart",autoFullThreshold:be?hs:void 0,chunkSize:M,expandContext:F,useIndex:C});if(!W.success)return `\u2717 \u8BFB\u53D6\u5931\u8D25: ${W.error}
|
|
703
703
|
|
|
704
704
|
\u{1F4A1} \u63D0\u793A:
|
|
705
705
|
- \u68C0\u67E5\u6587\u4EF6\u8DEF\u5F84\u662F\u5426\u6B63\u786E
|
|
706
|
-
- \u4F7F\u7528 search_files \u67E5\u627E\u6587\u4EF6`;if(
|
|
706
|
+
- \u4F7F\u7528 search_files \u67E5\u627E\u6587\u4EF6`;if(le=Pe(W),!_e&&W.totalLines>hs&&W.strategy==="chunk"&&(le+=`
|
|
707
707
|
|
|
708
708
|
\u{1F4A1} \u5EFA\u8BAE:
|
|
709
709
|
- \u4F7F\u7528 pattern/list_matches \u5B9A\u4F4D\uFF0C\u518D\u7528 anchor_lines/ranges \u6279\u91CF\u8BFB\u53D6
|
|
710
|
-
- \u6216\u6307\u5B9A start_line/num_lines \u7CBE\u51C6\u8BFB\u53D6`),
|
|
710
|
+
- \u6216\u6307\u5B9A start_line/num_lines \u7CBE\u51C6\u8BFB\u53D6`),be&&W.strategy==="full"&&le.length>H){be=false;let v=Math.max(.1,Math.min(.9,H/le.length));M=Math.max($r,Math.floor(M*v)),ne+=1;continue}if(d||le.length<=H||ne>=lh||M<=$r)return le;let ie=Math.max(.1,Math.min(.9,H/le.length)),Q=Math.max($r,Math.floor(M*ie));if(Q>=M)return le;M=Q,ne+=1;}}},s={name:"build_index",description:`\u3010\u6784\u5EFA\u4EE3\u7801\u7D22\u5F15\u3011\u4E3A\u9879\u76EE\u6784\u5EFA AST \u7D22\u5F15\uFF0C\u63D0\u5347\u4EE3\u7801\u5BFC\u822A\u901F\u5EA6\u3002
|
|
711
711
|
|
|
712
712
|
\u26A1 \u7279\u6027:
|
|
713
713
|
- \u89E3\u6790 TypeScript/JavaScript/Python \u4EE3\u7801\u7ED3\u6784
|
|
@@ -722,7 +722,7 @@ build_index(paths=["src/**/*.ts"]) \u2192 \u53EA\u7D22\u5F15\u6307\u5B9A\u8D
|
|
|
722
722
|
|
|
723
723
|
\u{1F4CA} \u7D22\u5F15\u540E\u53EF\u4EE5\u4F7F\u7528:
|
|
724
724
|
- readfile \u7684\u7B26\u53F7\u5B9A\u4F4D\u4F1A\u66F4\u5FEB\u66F4\u51C6\u786E
|
|
725
|
-
- search_symbol \u53EF\u4EE5\u5FEB\u901F\u641C\u7D22\u7B26\u53F7`,parameters:{type:"object",properties:{paths:{type:"array",items:{type:"string"},description:"\u8981\u7D22\u5F15\u7684\u8DEF\u5F84\u6A21\u5F0F (\u9ED8\u8BA4: \u9879\u76EE\u4E2D\u7684\u6240\u6709\u4EE3\u7801\u6587\u4EF6)"},languages:{type:"array",items:{type:"string"},description:"\u8BED\u8A00\u5217\u8868 (\u9ED8\u8BA4: typescript, javascript, python)"},force:{type:"boolean",description:"\u5F3A\u5236\u91CD\u5EFA\u7D22\u5F15 (\u5FFD\u7565\u7F13\u5B58)"}}},async function(l){let{paths:c,languages:u,force:p=false}=l,d=e(),h=await
|
|
725
|
+
- search_symbol \u53EF\u4EE5\u5FEB\u901F\u641C\u7D22\u7B26\u53F7`,parameters:{type:"object",properties:{paths:{type:"array",items:{type:"string"},description:"\u8981\u7D22\u5F15\u7684\u8DEF\u5F84\u6A21\u5F0F (\u9ED8\u8BA4: \u9879\u76EE\u4E2D\u7684\u6240\u6709\u4EE3\u7801\u6587\u4EF6)"},languages:{type:"array",items:{type:"string"},description:"\u8BED\u8A00\u5217\u8868 (\u9ED8\u8BA4: typescript, javascript, python)"},force:{type:"boolean",description:"\u5F3A\u5236\u91CD\u5EFA\u7D22\u5F15 (\u5FFD\u7565\u7F13\u5B58)"}}},async function(l){let{paths:c,languages:u,force:p=false}=l,d=e(),h=await Cn(d).buildIndex({paths:c,languages:u,force:p,onProgress:(y,b,w)=>{}}),g=[h.success?"\u2713 \u7D22\u5F15\u6784\u5EFA\u5B8C\u6210":"\u26A0\uFE0F \u7D22\u5F15\u6784\u5EFA\u5B8C\u6210 (\u6709\u9519\u8BEF)","","\u{1F4CA} \u7EDF\u8BA1:",` \u6587\u4EF6\u6570: ${h.filesIndexed}`,` \u7B26\u53F7\u6570: ${h.symbolsFound}`,` \u8017\u65F6: ${(h.timeMs/1e3).toFixed(2)}s`];if(h.errors.length>0){g.push(""),g.push("\u274C \u9519\u8BEF:");for(let y of h.errors.slice(0,5))g.push(` ${yt(y.file)}: ${y.error}`);h.errors.length>5&&g.push(` ... \u8FD8\u6709 ${h.errors.length-5} \u4E2A\u9519\u8BEF`);}return g.push(""),g.push("\u{1F4A1} \u73B0\u5728\u53EF\u4EE5\u4F7F\u7528 readfile \u7684\u7B26\u53F7\u5B9A\u4F4D\u529F\u80FD\uFF0C\u6216\u4F7F\u7528 search_symbol \u641C\u7D22\u7B26\u53F7"),g.join(`
|
|
726
726
|
`)}},n={name:"search_symbol",description:`\u3010\u641C\u7D22\u7B26\u53F7\u3011\u5728\u7D22\u5F15\u4E2D\u641C\u7D22\u51FD\u6570\u3001\u7C7B\u3001\u63A5\u53E3\u7B49\u7B26\u53F7\u3002
|
|
727
727
|
|
|
728
728
|
\u26A0\uFE0F \u9700\u8981\u5148\u8FD0\u884C build_index \u6784\u5EFA\u7D22\u5F15
|
|
@@ -736,7 +736,7 @@ search_symbol(query="usr", fuzzy=true) \u2192 \u6A21\u7CCA\u641C\u7D22
|
|
|
736
736
|
\u{1F4CB} \u8FD4\u56DE:
|
|
737
737
|
- \u7B26\u53F7\u540D\u79F0\u548C\u7C7B\u578B
|
|
738
738
|
- \u6240\u5728\u6587\u4EF6\u548C\u884C\u53F7
|
|
739
|
-
- \u53EF\u76F4\u63A5\u7528\u4E8E readfile \u5B9A\u4F4D`,parameters:{type:"object",properties:{query:{type:"string",description:"\u641C\u7D22\u5173\u952E\u8BCD"},kind:{type:"string",description:"\u7B26\u53F7\u7C7B\u578B: function, class, interface, method, variable, type, enum",enum:["function","class","interface","method","variable","type","enum"]},fuzzy:{type:"boolean",description:"\u6A21\u7CCA\u5339\u914D (\u9ED8\u8BA4: false)"},limit:{type:"number",description:"\u6700\u5927\u7ED3\u679C\u6570 (\u9ED8\u8BA4: 20)"}},required:["query"]},async function(l){let{query:c,kind:u,fuzzy:p=false,limit:d=20}=l,m=e(),h=
|
|
739
|
+
- \u53EF\u76F4\u63A5\u7528\u4E8E readfile \u5B9A\u4F4D`,parameters:{type:"object",properties:{query:{type:"string",description:"\u641C\u7D22\u5173\u952E\u8BCD"},kind:{type:"string",description:"\u7B26\u53F7\u7C7B\u578B: function, class, interface, method, variable, type, enum",enum:["function","class","interface","method","variable","type","enum"]},fuzzy:{type:"boolean",description:"\u6A21\u7CCA\u5339\u914D (\u9ED8\u8BA4: false)"},limit:{type:"number",description:"\u6700\u5927\u7ED3\u679C\u6570 (\u9ED8\u8BA4: 20)"}},required:["query"]},async function(l){let{query:c,kind:u,fuzzy:p=false,limit:d=20}=l,m=e(),h=Cn(m);if(!await h.hasIndex())return `\u2717 \u7D22\u5F15\u4E0D\u5B58\u5728
|
|
740
740
|
|
|
741
741
|
\u{1F4A1} \u8BF7\u5148\u8FD0\u884C build_index() \u6784\u5EFA\u7D22\u5F15:
|
|
742
742
|
build_index() \u2192 \u7D22\u5F15\u6574\u4E2A\u9879\u76EE
|
|
@@ -755,9 +755,9 @@ search_symbol(query="usr", fuzzy=true) \u2192 \u6A21\u7CCA\u641C\u7D22
|
|
|
755
755
|
\u793A\u4F8B:
|
|
756
756
|
get_definitions(query="UserService") \u2192 \u67E5\u627E\u5B9A\u4E49
|
|
757
757
|
get_definitions(symbol="handleLogin", kind="function")
|
|
758
|
-
get_definitions(query="User", path="src/auth") \u2192 \u9650\u5B9A\u76EE\u5F55`,parameters:{type:"object",properties:{query:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (\u4F18\u5148)"},symbol:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (query \u7684\u522B\u540D)"},kind:{type:"string",description:"\u7B26\u53F7\u7C7B\u578B: function, class, interface, method, variable, type, enum",enum:["function","class","interface","method","variable","type","enum"]},path:{type:"string",description:"\u9650\u5B9A\u641C\u7D22\u76EE\u5F55 (\u76F8\u5BF9\u5DE5\u4F5C\u533A)"},fuzzy:{type:"boolean",description:"\u6A21\u7CCA\u5339\u914D (\u9ED8\u8BA4: false)"},limit:{type:"number",description:"\u6700\u5927\u7ED3\u679C\u6570 (\u9ED8\u8BA4: 20)"}}},permission:{category:"read",allowInAskMode:true},async function(l){let c=typeof l.query=="string"?l.query:typeof l.symbol=="string"?l.symbol:"";if(!c.trim())return "\u2717 \u7F3A\u5C11\u53C2\u6570: query (\u6216 symbol)";let u=e(),p=
|
|
758
|
+
get_definitions(query="User", path="src/auth") \u2192 \u9650\u5B9A\u76EE\u5F55`,parameters:{type:"object",properties:{query:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (\u4F18\u5148)"},symbol:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (query \u7684\u522B\u540D)"},kind:{type:"string",description:"\u7B26\u53F7\u7C7B\u578B: function, class, interface, method, variable, type, enum",enum:["function","class","interface","method","variable","type","enum"]},path:{type:"string",description:"\u9650\u5B9A\u641C\u7D22\u76EE\u5F55 (\u76F8\u5BF9\u5DE5\u4F5C\u533A)"},fuzzy:{type:"boolean",description:"\u6A21\u7CCA\u5339\u914D (\u9ED8\u8BA4: false)"},limit:{type:"number",description:"\u6700\u5927\u7ED3\u679C\u6570 (\u9ED8\u8BA4: 20)"}}},permission:{category:"read",allowInAskMode:true},async function(l){let c=typeof l.query=="string"?l.query:typeof l.symbol=="string"?l.symbol:"";if(!c.trim())return "\u2717 \u7F3A\u5C11\u53C2\u6570: query (\u6216 symbol)";let u=e(),p=Cn(u);if(!await p.hasIndex())return `\u2717 \u7D22\u5F15\u4E0D\u5B58\u5728
|
|
759
759
|
|
|
760
|
-
\u{1F4A1} \u8BF7\u5148\u8FD0\u884C build_index() \u6784\u5EFA\u7D22\u5F15`;let m=typeof l.limit=="number"&&l.limit>0?Math.min(l.limit,100):20,h=l.kind,g=!!l.fuzzy,y=await p.searchSymbol({query:c,kind:h,fuzzy:g,limit:m});if(l.path){let w=
|
|
760
|
+
\u{1F4A1} \u8BF7\u5148\u8FD0\u884C build_index() \u6784\u5EFA\u7D22\u5F15`;let m=typeof l.limit=="number"&&l.limit>0?Math.min(l.limit,100):20,h=l.kind,g=!!l.fuzzy,y=await p.searchSymbol({query:c,kind:h,fuzzy:g,limit:m});if(l.path){let w=X.resolve(u,l.path);if(!ec(u,w))return "\u2717 \u8DEF\u5F84\u4E0D\u5728 workspace \u5185";y=y.filter(S=>{let x=X.resolve(S.file);return x===w||x.startsWith(w+X.sep)});}if(y.length===0)return `\u2713 \u67E5\u627E: "${c}"
|
|
761
761
|
|
|
762
762
|
\u672A\u627E\u5230\u5B9A\u4E49
|
|
763
763
|
|
|
@@ -770,10 +770,10 @@ get_definitions(query="User", path="src/auth") \u2192 \u9650\u5B9A\u76EE\u5F55`
|
|
|
770
770
|
\u793A\u4F8B:
|
|
771
771
|
get_references(query="UserService")
|
|
772
772
|
get_references(symbol="handleLogin", path="src/auth")
|
|
773
|
-
get_references(query="FeatureFlag", file_pattern="*.ts")`,parameters:{type:"object",properties:{query:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (\u4F18\u5148)"},symbol:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (query \u7684\u522B\u540D)"},path:{type:"string",description:"\u641C\u7D22\u8DEF\u5F84 (\u76F8\u5BF9\u5DE5\u4F5C\u533A\uFF0C\u9ED8\u8BA4: \u5F53\u524D\u5DE5\u4F5C\u533A)"},file_pattern:{type:"string",description:'\u6587\u4EF6\u8FC7\u6EE4 (e.g., "*.ts", "*.{js,ts}")'},case_insensitive:{type:"boolean",description:"\u5FFD\u7565\u5927\u5C0F\u5199 (\u9ED8\u8BA4: false)"},regex:{type:"boolean",description:"\u5C06 query \u4F5C\u4E3A\u6B63\u5219 (\u9ED8\u8BA4: false)"},context_lines:{type:"number",description:"\u4E0A\u4E0B\u6587\u884C\u6570 (\u9ED8\u8BA4: 2)"},max_matches:{type:"number",description:"\u6700\u5927\u5339\u914D\u6570 (\u9ED8\u8BA4: 200)"}}},permission:{category:"read",allowInAskMode:true},async function(l){let c=typeof l.query=="string"?l.query:typeof l.symbol=="string"?l.symbol:"";if(!c.trim())return "\u2717 \u7F3A\u5C11\u53C2\u6570: query (\u6216 symbol)";let u=e(),p=
|
|
774
|
-
`),k=new Set,
|
|
775
|
-
\u25B8 ${
|
|
776
|
-
`)}};return [t,s,n,i,o,{name:"index_stats",description:"\u3010\u7D22\u5F15\u7EDF\u8BA1\u3011\u67E5\u770B\u5F53\u524D\u9879\u76EE\u7684\u7D22\u5F15\u72B6\u6001\u548C\u7EDF\u8BA1\u4FE1\u606F\u3002",parameters:{type:"object",properties:{}},async function(){let l=e(),u=await
|
|
773
|
+
get_references(query="FeatureFlag", file_pattern="*.ts")`,parameters:{type:"object",properties:{query:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (\u4F18\u5148)"},symbol:{type:"string",description:"\u7B26\u53F7\u540D\u79F0 (query \u7684\u522B\u540D)"},path:{type:"string",description:"\u641C\u7D22\u8DEF\u5F84 (\u76F8\u5BF9\u5DE5\u4F5C\u533A\uFF0C\u9ED8\u8BA4: \u5F53\u524D\u5DE5\u4F5C\u533A)"},file_pattern:{type:"string",description:'\u6587\u4EF6\u8FC7\u6EE4 (e.g., "*.ts", "*.{js,ts}")'},case_insensitive:{type:"boolean",description:"\u5FFD\u7565\u5927\u5C0F\u5199 (\u9ED8\u8BA4: false)"},regex:{type:"boolean",description:"\u5C06 query \u4F5C\u4E3A\u6B63\u5219 (\u9ED8\u8BA4: false)"},context_lines:{type:"number",description:"\u4E0A\u4E0B\u6587\u884C\u6570 (\u9ED8\u8BA4: 2)"},max_matches:{type:"number",description:"\u6700\u5927\u5339\u914D\u6570 (\u9ED8\u8BA4: 200)"}}},permission:{category:"read",allowInAskMode:true},async function(l){let c=typeof l.query=="string"?l.query:typeof l.symbol=="string"?l.symbol:"";if(!c.trim())return "\u2717 \u7F3A\u5C11\u53C2\u6570: query (\u6216 symbol)";let u=e(),p=X.resolve(u,l.path||".");if(!ec(u,p))return "\u2717 \u8DEF\u5F84\u4E0D\u5728 workspace \u5185";let d;try{d=await Z.stat(p);}catch{return "\u2717 \u8DEF\u5F84\u4E0D\u5B58\u5728"}let m=typeof l.context_lines=="number"&&l.context_lines>=0?Math.min(l.context_lines,10):2,h=typeof l.max_matches=="number"&&l.max_matches>0?Math.min(l.max_matches,1e3):200,g=!!l.case_insensitive,y=!!l.regex,b;try{let T=y?c:dh(c);b=new RegExp(T,g?"gi":"g");}catch(T){return `\u2717 \u65E0\u6548\u7684\u6B63\u5219\u8868\u8FBE\u5F0F: ${T.message}`}let w=[];if(d.isDirectory()){let T=l.file_pattern||"**/*";w=await Is(T,{cwd:p,absolute:true,nodir:true,ignore:["**/node_modules/**","**/.git/**","**/dist/**","**/build/**","**/out/**","**/.next/**","**/coverage/**","**/__pycache__/**","**/target/**","**/vendor/**"]});}else w=[p];if(w.length===0)return "\u2713 \u672A\u627E\u5230\u53EF\u641C\u7D22\u7684\u6587\u4EF6";let S=[],x=0,R=0,$=0;for(let T of w){if(x>=h)break;try{let C=await Z.readFile(T,"utf-8");if(C.includes("\0"))continue;let _=C.split(`
|
|
774
|
+
`),k=new Set,D=new Map;for(let N=0;N<_.length&&!(x>=h);N++){let E=_[N],A=b.test(E);if(b.lastIndex=0,A){k.add(N),x++;let F=Math.max(0,N-m),H=Math.min(_.length-1,N+m);for(let M=F;M<=H;M++){let ee=D.get(M);D.set(M,{line:_[M],isMatch:ee?.isMatch||M===N});}}}if(R++,k.size>0){$++;let E=Array.from(D.keys()).sort((A,F)=>A-F).map(A=>({lineNum:A+1,line:D.get(A)?.line||"",isMatch:D.get(A)?.isMatch||!1}));S.push({file:T,matches:E,matchCount:k.size});}}catch{continue}}let G=yt(p),U=[`\u2713 \u5F15\u7528: "${c}"`,`\u25B8 \u8DEF\u5F84: ${G}`,l.file_pattern?`\u25B8 \u6587\u4EF6\u8FC7\u6EE4: ${l.file_pattern}`:"",g?"\u25B8 \u6A21\u5F0F: \u5FFD\u7565\u5927\u5C0F\u5199":"",y?"\u25B8 \u6A21\u5F0F: \u6B63\u5219":"","",`\u6587\u4EF6: ${R} \u5DF2\u641C\u7D22, ${$} \u6709\u5339\u914D`,`\u5339\u914D: ${x}${x>=h?" (\u5DF2\u8FBE\u4E0A\u9650)":""}`].filter(T=>T!=="");for(let T of S){let C=yt(T.file);U.push(`
|
|
775
|
+
\u25B8 ${C} (${T.matchCount} \u5904)`),U.push("\u2500".repeat(50));let _=-10;for(let k of T.matches){k.lineNum>_+1&&_>0&&U.push(" \u2504\u2504\u2504");let D=k.isMatch?"\u25B6":" ";U.push(`${D}${String(k.lineNum).padStart(5)} \u2502 ${k.line}`),_=k.lineNum;}}return S.length===0&&(U.push("\u672A\u627E\u5230\u5339\u914D\u5185\u5BB9"),U.push(""),U.push("\u{1F4A1} \u5EFA\u8BAE:"),U.push(" - \u68C0\u67E5\u5173\u952E\u8BCD\u62FC\u5199"),U.push(" - \u4F7F\u7528 regex=true \u8FDB\u884C\u66F4\u7CBE\u786E\u5339\u914D"),U.push(" - \u7F29\u5C0F\u6216\u6269\u5927 path/file_pattern \u8303\u56F4")),U.join(`
|
|
776
|
+
`)}};return [t,s,n,i,o,{name:"index_stats",description:"\u3010\u7D22\u5F15\u7EDF\u8BA1\u3011\u67E5\u770B\u5F53\u524D\u9879\u76EE\u7684\u7D22\u5F15\u72B6\u6001\u548C\u7EDF\u8BA1\u4FE1\u606F\u3002",parameters:{type:"object",properties:{}},async function(){let l=e(),u=await Cn(l).getStats();if(!u.hasIndex)return `\u{1F4CA} \u7D22\u5F15\u72B6\u6001: \u672A\u6784\u5EFA
|
|
777
777
|
|
|
778
778
|
\u{1F4A1} \u8FD0\u884C build_index() \u6784\u5EFA\u7D22\u5F15\u4EE5\u83B7\u5F97\u66F4\u597D\u7684\u4EE3\u7801\u5BFC\u822A\u4F53\u9A8C`;let p=(u.size/1024).toFixed(1),d=(u.size/(1024*1024)).toFixed(2),m=u.size>1024*1024?`${d}MB`:`${p}KB`;return `\u{1F4CA} \u7D22\u5F15\u72B6\u6001: \u5DF2\u6784\u5EFA
|
|
779
779
|
|
|
@@ -783,8 +783,8 @@ get_references(query="FeatureFlag", file_pattern="*.ts")`,parameters:{type:"obje
|
|
|
783
783
|
\u7D22\u5F15\u5927\u5C0F: ${m}
|
|
784
784
|
\u6700\u540E\u66F4\u65B0: ${u.lastUpdated?.toLocaleString()||"N/A"}
|
|
785
785
|
|
|
786
|
-
\u{1F4A1} \u4F7F\u7528 build_index(force=true) \u53EF\u4EE5\u91CD\u5EFA\u7D22\u5F15`}}]}
|
|
787
|
-
`)){let s=t.indexOf("=");if(s>0){let n=t.substring(0,s),i=t.substring(s+1);e[n]=i;}}return e}async function tc(r={}){if(He)return;if(Yt){await Yt;return}let e={...process.env};if(process.platform==="win32"){He=e;return}let t=er(),s=r.maxWaitMs??(t?800:5e3),n=r.background??t,i=async o=>{try{let a=process.env.SHELL||"/bin/zsh";f.debug("SHELL","Preloading shell environment asynchronously...");let l=await execa(a,["-lc","env"],{encoding:"utf8",timeout:o,reject:!1,stdin:"ignore",stdout:"pipe",stderr:"ignore"});if(l.stdout){let c=ec(l.stdout),u=Ql(c,e);return f.debug("SHELL","Preloaded shell environment successfully",{pathLength:u.PATH?.length}),u}}catch(a){f.warn("SHELL","Failed to preload shell environment",{error:a});}return null};if(n){He=e,Yt=(async()=>{let o=await i(s);if(o){He=o;return}let a=await i(5e3);a&&(He=a);})().finally(()=>{Yt=null;});return}Yt=(async()=>{He=await i(s)??e;})().finally(()=>{Yt=null;}),await Yt;}function sc(){if(He)return He;process.env.CLI_DEBUG==="1"&&f.warn("SHELL","\u26A0\uFE0F getShellEnv() cache miss - this should not happen! Call preloadShellEnv() during init.");let r={...process.env};if(process.platform==="win32")return He=r,He;try{let e=process.env.SHELL||"/bin/zsh",t=execaSync(e,["-ilc","env"],{encoding:"utf8",timeout:5e3,reject:!1});if(t.stdout){let s=ec(t.stdout);He=Ql(s,r),process.env.CLI_DEBUG==="1"&&f.debug("SHELL","Loaded shell environment (sync fallback), PATH length:",{pathLength:He.PATH?.length});}else He=r;}catch(e){f.warn("SHELL","Failed to load shell environment",{error:e}),He=r;}return He}de();var Co=class extends EventEmitter{processes=new Map;nextId=1;register(e){let t={pid:e.pid,command:e.command,cwd:e.cwd,startTime:new Date,status:"running",background:e.background,processRef:e.processRef};return this.processes.set(e.pid,t),f.debug("PROCESS_MGR",`Registered process PID=${e.pid}`,{command:e.command.substring(0,50),background:e.background}),this.emit("process:start",t),t}markCompleted(e,t){let s=this.processes.get(e);s&&(s.status=t===0?"completed":"failed",s.exitCode=t,s.endTime=new Date,f.debug("PROCESS_MGR",`Process completed PID=${e}`,{exitCode:t,duration:s.endTime.getTime()-s.startTime.getTime()}),this.emit("process:exit",s),setTimeout(()=>{this.processes.delete(e);},1e3));}unregister(e){this.processes.get(e)&&(this.processes.delete(e),f.debug("PROCESS_MGR",`Unregistered process PID=${e}`));}getRunning(){return Array.from(this.processes.values()).filter(e=>e.status==="running")}getBackgroundRunning(){return Array.from(this.processes.values()).filter(e=>e.status==="running"&&e.background)}getAll(){return Array.from(this.processes.values())}getRecent(e=10){return Array.from(this.processes.values()).sort((t,s)=>s.startTime.getTime()-t.startTime.getTime()).slice(0,e)}get(e){return this.processes.get(e)}isAlive(e){try{return process.kill(e,0),!0}catch{return false}}refreshStatus(){for(let[e,t]of this.processes.entries())t.status==="running"&&(this.isAlive(e)||(t.status="completed",t.endTime=new Date,f.debug("PROCESS_MGR",`Process ${e} is no longer alive, marked as completed`)));}kill(e,t="SIGTERM",s=false){let n=this.processes.get(e);try{return process.kill(e,t),f.info("PROCESS_MGR",`Sent ${t} to process PID=${e}`),s&&setTimeout(()=>{try{this.isAlive(e)&&(process.kill(e,"SIGKILL"),f.info("PROCESS_MGR",`Force killed process PID=${e}`));}catch{}},2e3),n&&(n.status="killed",n.endTime=new Date,this.emit("process:kill",n)),!0}catch(i){return i.code==="ESRCH"?(n&&(n.status="completed",n.endTime=new Date),f.debug("PROCESS_MGR",`Process ${e} not found (already exited)`),false):(f.error("PROCESS_MGR",`Failed to kill process ${e}`,{error:i.message}),false)}}killProcessGroup(e,t="SIGTERM"){try{process.kill(-e,t),f.info("PROCESS_MGR",`Sent ${t} to process group PID=${e}`);let s=this.processes.get(e);return s&&(s.status="killed",s.endTime=new Date,this.emit("process:kill",s)),!0}catch{return this.kill(e,t)}}killAll(e=false){let t=this.getRunning(),s=0,n=0;for(let i of t)(i.background?this.killProcessGroup(i.pid):this.kill(i.pid,"SIGTERM",e))?s++:n++;return f.info("PROCESS_MGR",`Killed ${s} processes, ${n} failed`),{killed:s,failed:n}}cleanup(e=20){let s=this.getAll().filter(i=>i.status!=="running");s.sort((i,o)=>{let a=i.endTime?.getTime()||0;return (o.endTime?.getTime()||0)-a});let n=0;for(let i=e;i<s.length;i++)this.processes.delete(s[i].pid),n++;return n}getStats(){let e=this.getAll();return {total:e.length,running:e.filter(t=>t.status==="running").length,backgroundRunning:e.filter(t=>t.status==="running"&&t.background).length,completed:e.filter(t=>t.status==="completed").length,failed:e.filter(t=>t.status==="failed").length,killed:e.filter(t=>t.status==="killed").length}}formatProcess(e){let t=e.endTime?e.endTime.getTime()-e.startTime.getTime():Date.now()-e.startTime.getTime(),s=this.formatDuration(t),n=this.getStatusIcon(e.status),i=e.background?" [BG]":"",o=e.command.length>40?e.command.substring(0,37)+"...":e.command;return `${n} PID ${e.pid}${i} | ${o} | ${s}`}getStatusIcon(e){switch(e){case "running":return "\u{1F7E2}";case "completed":return "\u2705";case "failed":return "\u274C";case "killed":return "\u{1F6D1}";default:return "\u26AA"}}formatDuration(e){return e<1e3?`${e}ms`:e<6e4?`${(e/1e3).toFixed(1)}s`:e<36e5?`${Math.floor(e/6e4)}m ${Math.floor(e%6e4/1e3)}s`:`${Math.floor(e/36e5)}h ${Math.floor(e%36e5/6e4)}m`}reset(){this.processes.clear(),f.debug("PROCESS_MGR","Process manager reset");}},nc=new Co;var Nr={terminal:true,editor:false,debug:true,trace:true},Ro={...Nr,editor:true};de();function uh(){let r=process.platform;if(r==="darwin")return Y__default.join(qs__default.homedir(),"Library","Application Support","Neox");if(r==="win32")return Y__default.join(process.env.APPDATA||Y__default.join(qs__default.homedir(),"AppData","Roaming"),"Neox");{let e=process.env.XDG_CONFIG_HOME||Y__default.join(qs__default.homedir(),".config");return Y__default.join(e,"neox")}}var ic=uh(),Io=Y__default.join(ic,"token-usage.json"),rc=3e3,Mo=class{stats=null;directoriesReady;saveDebounceTimer=null;constructor(){this.directoriesReady=this.ensureDirectories();}async ensureDirectories(){await Q__default.mkdir(ic,{recursive:true});}async ensureReady(){try{await this.directoriesReady;}catch(e){throw f.error("TokenUsage","Failed to initialize directories",{error:e.message}),e}}generateId(){return `${Date.now()}-${Math.random().toString(36).slice(2,9)}`}async load(){if(await this.ensureReady(),this.stats)return this.stats;try{let e=await Q__default.readFile(Io,"utf-8");return this.stats=JSON.parse(e),f.info("TokenUsage","Loaded usage statistics"),this.stats}catch{return f.info("TokenUsage","No existing usage file, creating new"),this.stats={version:"1.0.0",lastUpdated:Date.now(),providers:{},records:[]},this.stats}}async save(){this.saveDebounceTimer&&clearTimeout(this.saveDebounceTimer),this.saveDebounceTimer=setTimeout(async()=>{await this.saveImmediate();},1e3);}async saveImmediate(){if(await this.ensureReady(),!!this.stats)try{this.stats.lastUpdated=Date.now();let e=`${Io}.${Date.now()}.tmp`;await Q__default.writeFile(e,JSON.stringify(this.stats,null,2),"utf-8"),await Q__default.rename(e,Io),f.info("TokenUsage","Saved usage statistics");}catch(e){f.error("TokenUsage","Failed to save",{error:e.message});}}async recordUsage(e){let t=await this.load(),s={id:this.generateId(),...e};t.records.push(s),t.records.length>rc&&(t.records=t.records.slice(-rc)),t.providers[e.provider]||(t.providers[e.provider]={provider:e.provider,totalRequests:0,successRequests:0,failedRequests:0,totalInputTokens:0,totalOutputTokens:0,totalTokens:0,totalCachedTokens:0,totalOpenaiCachedTokens:0,totalAnthropicCacheReadTokens:0,totalAnthropicCacheCreationTokens:0,totalAnthropicCacheCreation5mTokens:0,totalAnthropicCacheCreation1hTokens:0,avgDuration:0,lastRequestTime:0,models:{}});let n=t.providers[e.provider];n.totalRequests++,e.success?n.successRequests++:n.failedRequests++,n.totalInputTokens+=e.inputTokens,n.totalOutputTokens+=e.outputTokens,n.totalTokens+=e.totalTokens,n.totalCachedTokens+=e.cachedTokens||0,n.totalOpenaiCachedTokens+=e.openaiCachedTokens||0,n.totalAnthropicCacheReadTokens+=e.anthropicCacheReadTokens||0,n.totalAnthropicCacheCreationTokens+=e.anthropicCacheCreationTokens||0,n.totalAnthropicCacheCreation5mTokens+=e.anthropicCacheCreation5mTokens||0,n.totalAnthropicCacheCreation1hTokens+=e.anthropicCacheCreation1hTokens||0,n.lastRequestTime=e.timestamp;let i=n.avgDuration*(n.totalRequests-1)+e.duration;n.avgDuration=Math.round(i/n.totalRequests),n.models[e.model]||(n.models[e.model]={requests:0,inputTokens:0,outputTokens:0,totalTokens:0,cachedTokens:0});let o=n.models[e.model];o.requests++,o.inputTokens+=e.inputTokens,o.outputTokens+=e.outputTokens,o.totalTokens+=e.totalTokens,o.cachedTokens+=e.cachedTokens||0,await this.save();}async getProviderStats(){let e=await this.load();return Object.values(e.providers).sort((t,s)=>s.lastRequestTime-t.lastRequestTime)}async getProviderRecords(e,t=100){return (await this.load()).records.filter(n=>n.provider===e).slice(-t).reverse()}async getRecentRecords(e=50){return (await this.load()).records.slice(-e).reverse()}async getSummary(){let e=await this.load(),t=Object.values(e.providers),s=t.reduce((a,l)=>a+l.totalInputTokens,0),n=t.reduce((a,l)=>a+l.totalCachedTokens,0),i=t.reduce((a,l)=>a+l.totalOpenaiCachedTokens,0),o=t.reduce((a,l)=>a+l.totalAnthropicCacheReadTokens,0);return {totalRequests:t.reduce((a,l)=>a+l.totalRequests,0),totalTokens:t.reduce((a,l)=>a+l.totalTokens,0),totalInputTokens:s,totalOutputTokens:t.reduce((a,l)=>a+l.totalOutputTokens,0),totalCachedTokens:n,totalOpenaiCachedTokens:i,totalAnthropicCacheReadTokens:o,totalAnthropicCacheCreationTokens:t.reduce((a,l)=>a+l.totalAnthropicCacheCreationTokens,0),cacheHitRate:s>0?n/s:0,providerCount:t.length,lastRequestTime:Math.max(...t.map(a=>a.lastRequestTime),0)}}async clearAll(){this.stats={version:"1.0.0",lastUpdated:Date.now(),providers:{},records:[]},await this.saveImmediate(),f.info("TokenUsage","Cleared all usage statistics");}async clearProvider(e){let t=await this.load();delete t.providers[e],t.records=t.records.filter(s=>s.provider!==e),await this.saveImmediate(),f.info("TokenUsage","Cleared usage for provider",{provider:e});}},oc=new Mo;function Rn(){return {logger:f,shellEnv:{preloadShellEnv:tc,getShellEnv:sc},processManager:nc,capabilities:Nr,tokenUsage:oc}}var Ur={name:"update_plan",description:`Updates the task plan.
|
|
786
|
+
\u{1F4A1} \u4F7F\u7528 build_index(force=true) \u53EF\u4EE5\u91CD\u5EFA\u7D22\u5F15`}}]}me();me();var He=null,Yt=null;function sc(r,e){return {...r,...e,PATH:r.PATH||e.PATH||"",JAVA_HOME:r.JAVA_HOME||e.JAVA_HOME||"",MAVEN_HOME:r.MAVEN_HOME||e.MAVEN_HOME||"",M2_HOME:r.M2_HOME||e.M2_HOME||"",NODE_PATH:r.NODE_PATH||e.NODE_PATH||"",GOPATH:r.GOPATH||e.GOPATH||"",CARGO_HOME:r.CARGO_HOME||e.CARGO_HOME||"",RUSTUP_HOME:r.RUSTUP_HOME||e.RUSTUP_HOME||"",PYENV_ROOT:r.PYENV_ROOT||e.PYENV_ROOT||"",CONDA_PREFIX:r.CONDA_PREFIX||e.CONDA_PREFIX||""}}function nc(r){let e={};for(let t of r.split(`
|
|
787
|
+
`)){let s=t.indexOf("=");if(s>0){let n=t.substring(0,s),i=t.substring(s+1);e[n]=i;}}return e}async function rc(r={}){if(He)return;if(Yt){await Yt;return}let e={...process.env};if(process.platform==="win32"){He=e;return}let t=tr(),s=r.maxWaitMs??(t?800:5e3),n=r.background??t,i=async o=>{try{let a=process.env.SHELL||"/bin/zsh";f.debug("SHELL","Preloading shell environment asynchronously...");let l=await execa(a,["-lc","env"],{encoding:"utf8",timeout:o,reject:!1,stdin:"ignore",stdout:"pipe",stderr:"ignore"});if(l.stdout){let c=nc(l.stdout),u=sc(c,e);return f.debug("SHELL","Preloaded shell environment successfully",{pathLength:u.PATH?.length}),u}}catch(a){f.warn("SHELL","Failed to preload shell environment",{error:a});}return null};if(n){He=e,Yt=(async()=>{let o=await i(s);if(o){He=o;return}let a=await i(5e3);a&&(He=a);})().finally(()=>{Yt=null;});return}Yt=(async()=>{He=await i(s)??e;})().finally(()=>{Yt=null;}),await Yt;}function ic(){if(He)return He;process.env.CLI_DEBUG==="1"&&f.warn("SHELL","\u26A0\uFE0F getShellEnv() cache miss - this should not happen! Call preloadShellEnv() during init.");let r={...process.env};if(process.platform==="win32")return He=r,He;try{let e=process.env.SHELL||"/bin/zsh",t=execaSync(e,["-ilc","env"],{encoding:"utf8",timeout:5e3,reject:!1});if(t.stdout){let s=nc(t.stdout);He=sc(s,r),process.env.CLI_DEBUG==="1"&&f.debug("SHELL","Loaded shell environment (sync fallback), PATH length:",{pathLength:He.PATH?.length});}else He=r;}catch(e){f.warn("SHELL","Failed to load shell environment",{error:e}),He=r;}return He}me();var Io=class extends EventEmitter{processes=new Map;nextId=1;register(e){let t={pid:e.pid,command:e.command,cwd:e.cwd,startTime:new Date,status:"running",background:e.background,processRef:e.processRef};return this.processes.set(e.pid,t),f.debug("PROCESS_MGR",`Registered process PID=${e.pid}`,{command:e.command.substring(0,50),background:e.background}),this.emit("process:start",t),t}markCompleted(e,t){let s=this.processes.get(e);s&&(s.status=t===0?"completed":"failed",s.exitCode=t,s.endTime=new Date,f.debug("PROCESS_MGR",`Process completed PID=${e}`,{exitCode:t,duration:s.endTime.getTime()-s.startTime.getTime()}),this.emit("process:exit",s),setTimeout(()=>{this.processes.delete(e);},1e3));}unregister(e){this.processes.get(e)&&(this.processes.delete(e),f.debug("PROCESS_MGR",`Unregistered process PID=${e}`));}getRunning(){return Array.from(this.processes.values()).filter(e=>e.status==="running")}getBackgroundRunning(){return Array.from(this.processes.values()).filter(e=>e.status==="running"&&e.background)}getAll(){return Array.from(this.processes.values())}getRecent(e=10){return Array.from(this.processes.values()).sort((t,s)=>s.startTime.getTime()-t.startTime.getTime()).slice(0,e)}get(e){return this.processes.get(e)}isAlive(e){try{return process.kill(e,0),!0}catch{return false}}refreshStatus(){for(let[e,t]of this.processes.entries())t.status==="running"&&(this.isAlive(e)||(t.status="completed",t.endTime=new Date,f.debug("PROCESS_MGR",`Process ${e} is no longer alive, marked as completed`)));}kill(e,t="SIGTERM",s=false){let n=this.processes.get(e);try{return process.kill(e,t),f.info("PROCESS_MGR",`Sent ${t} to process PID=${e}`),s&&setTimeout(()=>{try{this.isAlive(e)&&(process.kill(e,"SIGKILL"),f.info("PROCESS_MGR",`Force killed process PID=${e}`));}catch{}},2e3),n&&(n.status="killed",n.endTime=new Date,this.emit("process:kill",n)),!0}catch(i){return i.code==="ESRCH"?(n&&(n.status="completed",n.endTime=new Date),f.debug("PROCESS_MGR",`Process ${e} not found (already exited)`),false):(f.error("PROCESS_MGR",`Failed to kill process ${e}`,{error:i.message}),false)}}killProcessGroup(e,t="SIGTERM"){try{process.kill(-e,t),f.info("PROCESS_MGR",`Sent ${t} to process group PID=${e}`);let s=this.processes.get(e);return s&&(s.status="killed",s.endTime=new Date,this.emit("process:kill",s)),!0}catch{return this.kill(e,t)}}killAll(e=false){let t=this.getRunning(),s=0,n=0;for(let i of t)(i.background?this.killProcessGroup(i.pid):this.kill(i.pid,"SIGTERM",e))?s++:n++;return f.info("PROCESS_MGR",`Killed ${s} processes, ${n} failed`),{killed:s,failed:n}}cleanup(e=20){let s=this.getAll().filter(i=>i.status!=="running");s.sort((i,o)=>{let a=i.endTime?.getTime()||0;return (o.endTime?.getTime()||0)-a});let n=0;for(let i=e;i<s.length;i++)this.processes.delete(s[i].pid),n++;return n}getStats(){let e=this.getAll();return {total:e.length,running:e.filter(t=>t.status==="running").length,backgroundRunning:e.filter(t=>t.status==="running"&&t.background).length,completed:e.filter(t=>t.status==="completed").length,failed:e.filter(t=>t.status==="failed").length,killed:e.filter(t=>t.status==="killed").length}}formatProcess(e){let t=e.endTime?e.endTime.getTime()-e.startTime.getTime():Date.now()-e.startTime.getTime(),s=this.formatDuration(t),n=this.getStatusIcon(e.status),i=e.background?" [BG]":"",o=e.command.length>40?e.command.substring(0,37)+"...":e.command;return `${n} PID ${e.pid}${i} | ${o} | ${s}`}getStatusIcon(e){switch(e){case "running":return "\u{1F7E2}";case "completed":return "\u2705";case "failed":return "\u274C";case "killed":return "\u{1F6D1}";default:return "\u26AA"}}formatDuration(e){return e<1e3?`${e}ms`:e<6e4?`${(e/1e3).toFixed(1)}s`:e<36e5?`${Math.floor(e/6e4)}m ${Math.floor(e%6e4/1e3)}s`:`${Math.floor(e/36e5)}h ${Math.floor(e%36e5/6e4)}m`}reset(){this.processes.clear(),f.debug("PROCESS_MGR","Process manager reset");}},oc=new Io;var Ur={terminal:true,editor:false,debug:true,trace:true},Mo={...Ur,editor:true};me();function fh(){let r=process.platform;if(r==="darwin")return X__default.join(Js__default.homedir(),"Library","Application Support","Neox");if(r==="win32")return X__default.join(process.env.APPDATA||X__default.join(Js__default.homedir(),"AppData","Roaming"),"Neox");{let e=process.env.XDG_CONFIG_HOME||X__default.join(Js__default.homedir(),".config");return X__default.join(e,"neox")}}var lc=fh(),Po=X__default.join(lc,"token-usage.json"),ac=3e3,Oo=class{stats=null;directoriesReady;saveDebounceTimer=null;constructor(){this.directoriesReady=this.ensureDirectories();}async ensureDirectories(){await Z__default.mkdir(lc,{recursive:true});}async ensureReady(){try{await this.directoriesReady;}catch(e){throw f.error("TokenUsage","Failed to initialize directories",{error:e.message}),e}}generateId(){return `${Date.now()}-${Math.random().toString(36).slice(2,9)}`}async load(){if(await this.ensureReady(),this.stats)return this.stats;try{let e=await Z__default.readFile(Po,"utf-8");return this.stats=JSON.parse(e),f.info("TokenUsage","Loaded usage statistics"),this.stats}catch{return f.info("TokenUsage","No existing usage file, creating new"),this.stats={version:"1.0.0",lastUpdated:Date.now(),providers:{},records:[]},this.stats}}async save(){this.saveDebounceTimer&&clearTimeout(this.saveDebounceTimer),this.saveDebounceTimer=setTimeout(async()=>{await this.saveImmediate();},1e3);}async saveImmediate(){if(await this.ensureReady(),!!this.stats)try{this.stats.lastUpdated=Date.now();let e=`${Po}.${Date.now()}.tmp`;await Z__default.writeFile(e,JSON.stringify(this.stats,null,2),"utf-8"),await Z__default.rename(e,Po),f.info("TokenUsage","Saved usage statistics");}catch(e){f.error("TokenUsage","Failed to save",{error:e.message});}}async recordUsage(e){let t=await this.load(),s={id:this.generateId(),...e};t.records.push(s),t.records.length>ac&&(t.records=t.records.slice(-ac)),t.providers[e.provider]||(t.providers[e.provider]={provider:e.provider,totalRequests:0,successRequests:0,failedRequests:0,totalInputTokens:0,totalOutputTokens:0,totalTokens:0,totalCachedTokens:0,totalOpenaiCachedTokens:0,totalAnthropicCacheReadTokens:0,totalAnthropicCacheCreationTokens:0,totalAnthropicCacheCreation5mTokens:0,totalAnthropicCacheCreation1hTokens:0,avgDuration:0,lastRequestTime:0,models:{}});let n=t.providers[e.provider];n.totalRequests++,e.success?n.successRequests++:n.failedRequests++,n.totalInputTokens+=e.inputTokens,n.totalOutputTokens+=e.outputTokens,n.totalTokens+=e.totalTokens,n.totalCachedTokens+=e.cachedTokens||0,n.totalOpenaiCachedTokens+=e.openaiCachedTokens||0,n.totalAnthropicCacheReadTokens+=e.anthropicCacheReadTokens||0,n.totalAnthropicCacheCreationTokens+=e.anthropicCacheCreationTokens||0,n.totalAnthropicCacheCreation5mTokens+=e.anthropicCacheCreation5mTokens||0,n.totalAnthropicCacheCreation1hTokens+=e.anthropicCacheCreation1hTokens||0,n.lastRequestTime=e.timestamp;let i=n.avgDuration*(n.totalRequests-1)+e.duration;n.avgDuration=Math.round(i/n.totalRequests),n.models[e.model]||(n.models[e.model]={requests:0,inputTokens:0,outputTokens:0,totalTokens:0,cachedTokens:0});let o=n.models[e.model];o.requests++,o.inputTokens+=e.inputTokens,o.outputTokens+=e.outputTokens,o.totalTokens+=e.totalTokens,o.cachedTokens+=e.cachedTokens||0,await this.save();}async getProviderStats(){let e=await this.load();return Object.values(e.providers).sort((t,s)=>s.lastRequestTime-t.lastRequestTime)}async getProviderRecords(e,t=100){return (await this.load()).records.filter(n=>n.provider===e).slice(-t).reverse()}async getRecentRecords(e=50){return (await this.load()).records.slice(-e).reverse()}async getSummary(){let e=await this.load(),t=Object.values(e.providers),s=t.reduce((a,l)=>a+l.totalInputTokens,0),n=t.reduce((a,l)=>a+l.totalCachedTokens,0),i=t.reduce((a,l)=>a+l.totalOpenaiCachedTokens,0),o=t.reduce((a,l)=>a+l.totalAnthropicCacheReadTokens,0);return {totalRequests:t.reduce((a,l)=>a+l.totalRequests,0),totalTokens:t.reduce((a,l)=>a+l.totalTokens,0),totalInputTokens:s,totalOutputTokens:t.reduce((a,l)=>a+l.totalOutputTokens,0),totalCachedTokens:n,totalOpenaiCachedTokens:i,totalAnthropicCacheReadTokens:o,totalAnthropicCacheCreationTokens:t.reduce((a,l)=>a+l.totalAnthropicCacheCreationTokens,0),cacheHitRate:s>0?n/s:0,providerCount:t.length,lastRequestTime:Math.max(...t.map(a=>a.lastRequestTime),0)}}async clearAll(){this.stats={version:"1.0.0",lastUpdated:Date.now(),providers:{},records:[]},await this.saveImmediate(),f.info("TokenUsage","Cleared all usage statistics");}async clearProvider(e){let t=await this.load();delete t.providers[e],t.records=t.records.filter(s=>s.provider!==e),await this.saveImmediate(),f.info("TokenUsage","Cleared usage for provider",{provider:e});}},cc=new Oo;function En(){return {logger:f,shellEnv:{preloadShellEnv:rc,getShellEnv:ic},processManager:oc,capabilities:Ur,tokenUsage:cc}}var Gr={name:"update_plan",description:`Updates the task plan.
|
|
788
788
|
|
|
789
789
|
Provide an optional explanation and a list of plan items, each with a step and status.
|
|
790
790
|
At most one step can be in_progress at a time.
|
|
@@ -793,9 +793,9 @@ Rules:
|
|
|
793
793
|
- Keep step descriptions short (5-7 words)
|
|
794
794
|
- Only ONE step should be "in_progress" at any time
|
|
795
795
|
- Mark completed steps as "completed"
|
|
796
|
-
- Update the plan whenever you complete a step or start a new one`,parameters:{type:"object",properties:{explanation:{type:"string",description:"Optional explanation for the plan update"},plan:{type:"array",description:"The list of steps",items:{type:"object",properties:{step:{type:"string",description:"Step description (5-7 words)"},status:{type:"string",enum:["pending","in_progress","completed"],description:"Step status: pending, in_progress, or completed"}},required:["step","status"]}}},required:["plan"]}};function
|
|
797
|
-
`),a="",c=null;for(let u of o){if(!u.trim()||u.trim().startsWith("#"))continue;let p=u.search(/\S/),d=u.trim();if(d.startsWith("- ")){let h=d.slice(2).trim();a&&Array.isArray(i[a])?i[a].push(h):c&&a&&(Array.isArray(c[a])||(c[a]=[]),c[a].push(h));continue}let m=d.indexOf(":");if(m>0){let h=d.slice(0,m).trim(),g=d.slice(m+1).trim();if(p===0)if(a=h,c=null,g==="")i[h]={},c=i[h];else if(g.startsWith("[")&&g.endsWith("]")){let y=g.slice(1,-1);i[h]=y.split(",").map(b=>b.trim().replace(/^["']|["']$/g,"")).filter(Boolean);}else i[h]=
|
|
798
|
-
`)}getUserSkillsDir(){return
|
|
796
|
+
- Update the plan whenever you complete a step or start a new one`,parameters:{type:"object",properties:{explanation:{type:"string",description:"Optional explanation for the plan update"},plan:{type:"array",description:"The list of steps",items:{type:"object",properties:{step:{type:"string",description:"Step description (5-7 words)"},status:{type:"string",enum:["pending","in_progress","completed"],description:"Step status: pending, in_progress, or completed"}},required:["step","status"]}}},required:["plan"]}};function uc(r){return r.plan.filter(t=>t.status==="in_progress").length>1?JSON.stringify({success:false,error:"At most one step can be in_progress at a time"}):JSON.stringify({success:true,message:"Plan updated"})}function yh(r){let e=/^---\s*\n([\s\S]*?)\n---\s*\n([\s\S]*)$/,t=r.match(e);if(!t)return {metadata:{},body:r};let s=t[1],n=t[2],i={},o=s.split(`
|
|
797
|
+
`),a="",c=null;for(let u of o){if(!u.trim()||u.trim().startsWith("#"))continue;let p=u.search(/\S/),d=u.trim();if(d.startsWith("- ")){let h=d.slice(2).trim();a&&Array.isArray(i[a])?i[a].push(h):c&&a&&(Array.isArray(c[a])||(c[a]=[]),c[a].push(h));continue}let m=d.indexOf(":");if(m>0){let h=d.slice(0,m).trim(),g=d.slice(m+1).trim();if(p===0)if(a=h,c=null,g==="")i[h]={},c=i[h];else if(g.startsWith("[")&&g.endsWith("]")){let y=g.slice(1,-1);i[h]=y.split(",").map(b=>b.trim().replace(/^["']|["']$/g,"")).filter(Boolean);}else i[h]=pc(g);else if(c){if(g==="")c[h]={};else if(g.startsWith("[")&&g.endsWith("]")){let y=g.slice(1,-1);c[h]=y.split(",").map(b=>b.trim().replace(/^["']|["']$/g,"")).filter(Boolean);}else c[h]=pc(g);a=h;}}}return {metadata:i,body:n}}function pc(r){let e=r.replace(/^["']|["']$/g,"");if(e==="true")return true;if(e==="false")return false;let t=Number(e);return !isNaN(t)&&e!==""?t:e}function bh(r){let e=r.name||"",t=r.description||"";if(!e)throw new Error("Skill metadata must have a name");if(!t)throw new Error("Skill metadata must have a description");if(e.length>64)throw new Error("Skill name must be at most 64 characters");if(t.length>200)throw new Error("Skill description must be at most 200 characters");let s={name:e,description:t};return r.dependencies&&(s.dependencies=r.dependencies),r.context&&(s.context=r.context),r.agent&&(s.agent=r.agent),r["user-invocable"]!==void 0&&(s["user-invocable"]=r["user-invocable"]),r.hooks&&typeof r.hooks=="object"&&(s.hooks=r.hooks),r.neox&&typeof r.neox=="object"&&(s.neox=r.neox),s}var In=class{async loadFromDirectory(e,t){let s=[];if(!Ce.existsSync(e))return s;let n=Ce.readdirSync(e,{withFileTypes:true});for(let i of n){if(!i.isDirectory())continue;let o=X.join(e,i.name),a=X.join(o,"SKILL.md");if(Ce.existsSync(a))try{let l=await this.loadSkill(o,i.name,t);s.push(l);}catch(l){console.warn(`Failed to load skill from ${o}:`,l instanceof Error?l.message:l);}}return s}async loadSkill(e,t,s){let n=X.join(e,"SKILL.md"),i=Ce.readFileSync(n,"utf-8"),{metadata:o,body:a}=this.parseSkillFile(i),l=bh(o),c=await this.loadSupportFiles(e);return {id:t,path:n,source:s,metadata:l,content:a.trim(),supportFiles:c.size>0?c:void 0}}parseSkillFile(e){return yh(e)}async loadSupportFiles(e){let t=new Map,s=Ce.readdirSync(e,{withFileTypes:true});for(let n of s){if(!n.isFile()||n.name==="SKILL.md")continue;let i=X.join(e,n.name),o=X.extname(n.name).toLowerCase();if([".txt",".md",".json",".yaml",".yml",".sh",".js",".ts",".py"].includes(o))try{let l=Ce.readFileSync(i,"utf-8");t.set(n.name,l);}catch{}}return t}};var Do=class{skills=new Map;aliasIndex=new Map;loader=new In;initialized=false;register(e){if(this.skills.set(e.id,e),e.metadata.neox?.aliases)for(let t of e.metadata.neox.aliases)this.aliasIndex.set(t,e.id);}unregister(e){let t=this.skills.get(e);if(t){if(t.metadata.neox?.aliases)for(let s of t.metadata.neox.aliases)this.aliasIndex.delete(s);this.skills.delete(e);}}find(e){let t=this.skills.get(e);if(t)return t;let s=this.aliasIndex.get(e);if(s)return this.skills.get(s);let n=e.toLowerCase();for(let[i,o]of Array.from(this.skills.entries()))if(i.toLowerCase()===n||o.metadata.name.toLowerCase()===n)return o}has(e){return this.find(e)!==void 0}list(e){let t=Array.from(this.skills.values());return e?.category&&(t=t.filter(s=>s.metadata.neox?.category===e.category)),e?.source&&(t=t.filter(s=>s.source===e.source)),e?.userInvocable!==void 0&&(t=t.filter(s=>s.metadata["user-invocable"]===e.userInvocable)),t.sort((s,n)=>s.id.localeCompare(n.id))}get size(){return this.skills.size}async loadBuiltin(){let e=fileURLToPath(import.meta.url),t=X.dirname(e),s=X.join(t,"..","skills","builtin"),n=await this.loader.loadFromDirectory(s,"builtin");for(let i of n)this.register(i);}async loadUser(){let e=X.join(Js.homedir(),".neox","skills"),t=await this.loader.loadFromDirectory(e,"user");for(let s of t)this.register(s);}async loadWorkspace(e){let t=X.join(e,".neox","skills"),s=await this.loader.loadFromDirectory(t,"workspace");for(let n of s)this.register(n);}async initialize(e){this.initialized||(await this.loadBuiltin(),await this.loadUser(),e&&await this.loadWorkspace(e),this.initialized=true);}async refresh(e){this.skills.clear(),this.aliasIndex.clear(),this.initialized=false,await this.initialize(e);}getSkillsForPrompt(){let e=this.list({userInvocable:true});if(e.length===0)return "";let t=["## Available Skills",""];for(let s of e){let n=s.metadata.neox?.aliases,i=n?.length?` (aliases: ${n.join(", ")})`:"";t.push(`- /${s.id}: ${s.metadata.description}${i}`);}return t.join(`
|
|
798
|
+
`)}getUserSkillsDir(){return X.join(Js.homedir(),".neox","skills")}getWorkspaceSkillsDir(e){return X.join(e,".neox","skills")}async importFromUrl(e,t,s){try{let n=new URL(e),i=await fetch(e);if(!i.ok)return {success:!1,error:`HTTP ${i.status}: ${i.statusText}`};let o=await i.text(),{metadata:a}=this.loader.parseSkillFile(o);if(!a.name)return {success:!1,error:"Invalid SKILL.md: missing name field"};let l=this.generateSkillId(a.name),c=t==="user"?this.getUserSkillsDir():this.getWorkspaceSkillsDir(s),u=X.join(c,l);Ce.mkdirSync(u,{recursive:!0}),Ce.writeFileSync(X.join(u,"SKILL.md"),o,"utf-8");let p=await this.loader.loadSkill(u,l,t);return this.register(p),{success:!0,skillId:l}}catch(n){return {success:false,error:n instanceof Error?n.message:String(n)}}}async importFromPath(e,t,s){try{let n=X.resolve(e),i=Ce.statSync(n),o,a;if(i.isDirectory()?(o=X.join(n,"SKILL.md"),a=n):(o=n,a=X.dirname(n)),!Ce.existsSync(o))return {success:!1,error:`SKILL.md not found at ${o}`};let l=Ce.readFileSync(o,"utf-8"),{metadata:c}=this.loader.parseSkillFile(l);if(!c.name)return {success:!1,error:"Invalid SKILL.md: missing name field"};let u=this.generateSkillId(c.name),p=t==="user"?this.getUserSkillsDir():this.getWorkspaceSkillsDir(s),d=X.join(p,u);Ce.mkdirSync(d,{recursive:!0}),Ce.copyFileSync(o,X.join(d,"SKILL.md"));let m=Ce.readdirSync(a,{withFileTypes:!0});for(let g of m)g.isFile()&&g.name!=="SKILL.md"&&Ce.copyFileSync(X.join(a,g.name),X.join(d,g.name));let h=await this.loader.loadSkill(d,u,t);return this.register(h),{success:!0,skillId:u}}catch(n){return {success:false,error:n instanceof Error?n.message:String(n)}}}async createSkill(e){try{let{id:t,name:s,description:n,category:i,target:o,workDir:a}=e;if(!/^[a-z][a-z0-9-]*$/.test(t))return {success:!1,error:"Skill ID must start with lowercase letter and contain only lowercase letters, numbers, and hyphens"};if(this.has(t))return {success:!1,error:`Skill '${t}' already exists`};let l=o==="user"?this.getUserSkillsDir():this.getWorkspaceSkillsDir(a),c=X.join(l,t);if(Ce.existsSync(c))return {success:!1,error:`Directory already exists: ${c}`};let u=`---
|
|
799
799
|
name: "${s}"
|
|
800
800
|
description: "${n}"
|
|
801
801
|
user-invocable: true
|
|
@@ -818,48 +818,48 @@ ${n}
|
|
|
818
818
|
\u7528\u6237: /${t}
|
|
819
819
|
AI: [\u6280\u80FD\u6267\u884C\u7ED3\u679C]
|
|
820
820
|
\`\`\`
|
|
821
|
-
`;
|
|
822
|
-
`)}getAllowedTools(e){return e.metadata.neox?.allowedTools}getRequiredTools(e){return e.metadata.neox?.requiredTools}getDangerLevel(e){return e.metadata.neox?.dangerLevel??"safe"}};var
|
|
821
|
+
`;Ce.mkdirSync(c,{recursive:!0}),Ce.writeFileSync(X.join(c,"SKILL.md"),u,"utf-8");let p=await this.loader.loadSkill(c,t,o);return this.register(p),{success:!0,path:c}}catch(t){return {success:false,error:t instanceof Error?t.message:String(t)}}}async deleteSkill(e){try{let t=this.find(e);if(!t)return {success:!1,error:`Skill '${e}' not found`};if(t.source==="builtin")return {success:!1,error:"Cannot delete built-in skills"};let s=X.dirname(t.path);return Ce.rmSync(s,{recursive:!0,force:!0}),this.unregister(e),{success:!0}}catch(t){return {success:false,error:t instanceof Error?t.message:String(t)}}}generateSkillId(e){return e.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"").slice(0,32)}},Zt=new Do;function _h(r){let e={named:{},positional:[],raw:r};if(!r.trim())return e;let t=[],s="",n=false,i="";for(let o of r)(o==='"'||o==="'")&&!n?(n=true,i=o):o===i&&n?(n=false,i=""):o===" "&&!n?(s.trim()&&t.push(s.trim()),s=""):s+=o;s.trim()&&t.push(s.trim());for(let o=0;o<t.length;o++){let a=t[o];if(a.startsWith("--")){let l=a.indexOf("=");if(l>0){let c=a.slice(2,l),u=a.slice(l+1);e.named[c]=u;}else {let c=a.slice(2),u=t[o+1];u&&!u.startsWith("-")?(e.named[c]=u,o++):e.named[c]="true";}}else if(a.startsWith("-")&&a.length===2){let l=a.slice(1),c=t[o+1];c&&!c.startsWith("-")?(e.named[l]=c,o++):e.named[l]="true";}else e.positional.push(a);}return e}var Br=class{constructor(e){this.registry=e;}async execute(e,t,s){let n=this.registry.find(e);if(!n)return {success:false,error:`Skill not found: ${e}`};try{let i=_h(t);return {success:!0,output:this.buildPrompt(n,i,s)}}catch(i){return {success:false,error:i instanceof Error?i.message:String(i)}}}buildPrompt(e,t,s){let n=[];if(n.push(`# Skill: ${e.metadata.name}`),n.push(""),t.raw&&(n.push("## User Arguments"),n.push(`Raw: ${t.raw}`),Object.keys(t.named).length>0&&n.push(`Named: ${JSON.stringify(t.named)}`),t.positional.length>0&&n.push(`Positional: ${t.positional.join(", ")}`),n.push("")),n.push("## Context"),n.push(`Working Directory: ${s.workDir}`),n.push(""),n.push(e.content),e.supportFiles&&e.supportFiles.size>0){n.push(""),n.push("## Support Files");for(let[i,o]of Array.from(e.supportFiles.entries()))n.push(`### ${i}`),n.push("```"),n.push(o),n.push("```");}return n.join(`
|
|
822
|
+
`)}getAllowedTools(e){return e.metadata.neox?.allowedTools}getRequiredTools(e){return e.metadata.neox?.requiredTools}getDangerLevel(e){return e.metadata.neox?.dangerLevel??"safe"}};var Sh=new Set(["readfile","search","search_files","list_directory","show_tree","analyze_code","search_symbol","get_definitions","get_references","git_status","git_diff","git_blame","git_branch_list"]);function Wr(r){if(r.parallelSafety==="safe"||r.parallelSafety==="unsafe")return r.parallelSafety;let e=r.permission?.category;return e==="read"?"safe":e==="write"||e==="execute"||e==="system"?"unsafe":Sh.has(r.name)?"safe":"unsafe"}function dc(r,e){let t={terminal:e?.terminal===true,editor:e?.editor===true,debug:e?.debug===true,trace:e?.trace===true},s=new Set,n=new Set;for(let i of r)s.add(i.name),Wr(i)==="safe"&&n.add(i.name);return {capabilities:t,enabledTools:s,parallelSafeTools:n}}function mc(r){return r.map(e=>({...e,parallelSafety:Wr(e)}))}var kc="NEOX_WORKDIR",xh="NEOX_WORKER",Ch=En(),Le=Ch,we=Le.logger;function vc(r){Le=r,we=r.logger;}var $o=new Map,Rh=300*1e3;function Eh(r,e){return e?r.filter(t=>!t.capabilities||t.capabilities.length===0?true:t.capabilities.every(s=>e[s]===true)):r}async function Ih(r){await(r??Le).shellEnv.preloadShellEnv();}function Mh(){let r=process.env.NEOX_WORKER_ENTRY;if(r&&Ce__default.existsSync(r))return r;let e=process.argv[1];if(e&&e.endsWith(".js")&&Ce__default.existsSync(e))return e;let t=X__default.resolve(process.cwd(),"dist","cli","main.js");return Ce__default.existsSync(t)?t:null}async function Ah(r,e,t,s){if(process.env.NEOX_SHELL_WORKER_DISABLED==="1")return null;let n=Mh();return n?new Promise(i=>{let o=fork(n,[],{env:{...process.env,[xh]:"execute_shell"},stdio:["ignore","ignore","ignore","ipc"]}),a=false,l=Number(process.env.NEOX_SHELL_WORKER_WATCHDOG_MS)||6e4,c=setTimeout(()=>{we.warn("SHELL_WORKER",`execute_shell running > ${l}ms`,{command:r});},l),u=()=>{clearTimeout(c),s&&s.removeEventListener("abort",d),o.removeAllListeners();},p=m=>{a||(a=true,u(),i(m));},d=()=>{o.connected&&o.send({type:"abort"}),setTimeout(()=>{if(!a){try{o.kill("SIGTERM");}catch{}p({success:true,output:`\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
823
823
|
\u25B8 \u5DE5\u4F5C\u76EE\u5F55: ${t}
|
|
824
824
|
\u25B8 \u6267\u884C\u547D\u4EE4: ${r}
|
|
825
825
|
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
826
826
|
|
|
827
827
|
\u26A0 \u547D\u4EE4\u88AB\u7528\u6237\u4E2D\u65AD
|
|
828
|
-
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`,background:false});}},500),setTimeout(()=>{if(!a)try{o.kill("SIGKILL");}catch{}},2e3);};s&&(s.aborted?d():s.addEventListener("abort",d,{once:true})),o.on("message",m=>{if(!(!m||typeof m!="object")){if(m.type==="background_exit"){typeof m.pid=="number"&&
|
|
829
|
-
... (truncated)`,truncated:true}}async function Ue(r,e,t,s){let n=Date.now();return new Promise((i,o)=>{let a=spawn(r,e,{cwd:t,env:{...
|
|
830
|
-
`).length;return JSON.stringify(
|
|
831
|
-
`).length,u=l?"updated":"created";return JSON.stringify(
|
|
828
|
+
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`,background:false});}},500),setTimeout(()=>{if(!a)try{o.kill("SIGKILL");}catch{}},2e3);};s&&(s.aborted?d():s.addEventListener("abort",d,{once:true})),o.on("message",m=>{if(!(!m||typeof m!="object")){if(m.type==="background_exit"){typeof m.pid=="number"&&Le.processManager.markCompleted(m.pid,m.exitCode??0);return}m.type==="result"&&p({success:!!m.success,output:String(m.output??""),background:!!m.background,pid:typeof m.pid=="number"?m.pid:void 0,exitCode:typeof m.exitCode=="number"?m.exitCode:void 0});}}),o.on("exit",m=>{a||(we.warn("SHELL_WORKER","Worker exited before result",{code:m,command:r}),p(null));}),o.send({type:"execute_shell",payload:{command:r,background:e,workspaceRoot:t}});}):(we.warn("SHELL_WORKER","Worker entry not found, fallback to inline execution"),null)}function gc(r){return r.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function qe(){let r=process.env[kc];return r&&r.trim()?X__default.resolve(r):process.cwd()}function De(r){let e=qe();if(!r||r.trim()===""||r.trim()===".")return e;let t=r.trim();if(t.startsWith("~/"))return X__default.resolve(X__default.join(Js__default.homedir(),t.slice(2)));let s=X__default.isAbsolute(t),n=process.platform!=="win32"&&t.startsWith(`Users${X__default.sep}`);if(s||n){let l=!s&&n?X__default.join(X__default.sep,t):t;return X__default.resolve(l)}t=t.replace(/^[.\\/]+/,"");let i=t.split(/[\\/]+/).filter(Boolean),o=X__default.basename(e);i.length>0&&i[0]===o&&i.shift();let a=X__default.join(e,...i);return X__default.resolve(a)}function Ee(r){let e=qe(),t=X__default.relative(e,r);return t&&!t.startsWith("..")&&!X__default.isAbsolute(t)?t:r}var fc=12e3,yc=4e3,bc=1e6;function Ct(r){let e=qe(),t=X__default.relative(e,r);return t===""?true:!t.startsWith("..")&&!X__default.isAbsolute(t)}function Hr(r,e){return r.length<=e?{text:r,truncated:false}:{text:r.slice(0,e)+`
|
|
829
|
+
... (truncated)`,truncated:true}}async function Ue(r,e,t,s){let n=Date.now();return new Promise((i,o)=>{let a=spawn(r,e,{cwd:t,env:{...Le.shellEnv.getShellEnv(),TERM:"dumb"},stdio:["ignore","pipe","pipe"],detached:false}),l="",c="",u=false;a.stdout?.on("data",m=>{l+=m.toString();}),a.stderr?.on("data",m=>{c+=m.toString();});let p=null;s?.timeoutMs&&(p=setTimeout(()=>{u=true,a.kill("SIGTERM"),setTimeout(()=>{a.killed||a.kill("SIGKILL");},1e3);},s.timeoutMs));let d=()=>{u=true,a.kill("SIGTERM"),setTimeout(()=>{a.killed||a.kill("SIGKILL");},1e3);};s?.signal&&(s.signal.aborted?d():s.signal.addEventListener("abort",d,{once:true})),a.on("close",m=>{p&&clearTimeout(p),s?.signal&&s.signal.removeEventListener("abort",d),i({stdout:l,stderr:c,exitCode:u?-1:m??0,durationMs:Date.now()-n});}),a.on("error",m=>{p&&clearTimeout(p),s?.signal&&s.signal.removeEventListener("abort",d),i({stdout:l,stderr:c,exitCode:-1,durationMs:Date.now()-n});});})}async function es(r,e){try{let t=await Ue("git",["rev-parse","--show-toplevel"],r,{signal:e,timeoutMs:8e3});return t.exitCode!==0||!t.stdout.trim()?{error:"Not a git repository"}:{repoRoot:t.stdout.trim()}}catch(t){return {error:t?.message||"Not a git repository"}}}function Lh(r){let e=r.trim().split(/\s+/).filter(Boolean);return {command:e[0]||"",args:e.slice(1)}}var Dh={name:"write_file",description:"Write content to a file (create or overwrite)",parameters:{type:"object",properties:{file_path:{type:"string",description:"Path to the file to write"},content:{type:"string",description:"Content to write to the file"},mode:{type:"string",description:"Write mode: overwrite or append",enum:["overwrite","append"]}},required:["file_path","content"]},async function({file_path:r,content:e,mode:t="overwrite"}){if(!r)return JSON.stringify(V("write_file","error","Missing required parameter: file_path",{error:"file_path is required",verify_hint:"Please provide the file_path parameter."}));if(e==null)return JSON.stringify(V("write_file","error","Missing required parameter: content",{error:"content is required",verify_hint:"Please provide the content parameter with the text to write."}));let s=typeof e=="string"?e:String(e);if(s.trim()==="")return JSON.stringify(V("write_file","error","Content is empty - this is likely an error",{error:"Empty content provided",verify_hint:"Please provide non-empty content to write."}));let n=De(r),i=createHash("sha256").update(s).digest("hex").substring(0,16),o=$o.get(n),a=Date.now();if(o&&o.checksum===i&&o.success&&a-o.timestamp<Rh){let l=s.split(`
|
|
830
|
+
`).length;return JSON.stringify(V("write_file","already_done",`File already written with identical content (${l} lines, ${s.length} bytes)`,{file_path:n,checksum:i,verify_hint:`Use "readfile ${r}" to verify the content if needed.`,metadata:{lines:l,bytes:s.length}}))}try{let l=!1;try{await Z__default.access(n),l=!0;}catch{}await Z__default.mkdir(X__default.dirname(n),{recursive:!0}),t==="append"?await Z__default.appendFile(n,s,"utf-8"):await Z__default.writeFile(n,s,"utf-8"),$o.set(n,{checksum:i,timestamp:a,success:!0});let c=s.split(`
|
|
831
|
+
`).length,u=l?"updated":"created";return JSON.stringify(V("write_file","success",`File ${u}: ${X__default.basename(n)} (${c} lines, ${s.length} bytes)`,{file_path:n,checksum:i,verify_hint:`Use "readfile ${r}" to verify the content.`,metadata:{action:u,lines:c,bytes:s.length}}))}catch(l){return $o.set(n,{checksum:i,timestamp:a,success:false}),JSON.stringify(V("write_file","error",`Failed to write file: ${l.message}`,{file_path:n,error:l.message,verify_hint:"Check file permissions and path validity."}))}}};function $h(r){let e=r.includes(`\r
|
|
832
832
|
`)?`\r
|
|
833
833
|
`:`
|
|
834
|
-
`,t=r.endsWith(e),s=r.split(/\r?\n/);return t&&s[s.length-1]===""&&s.pop(),{lines:s,lineEnding:e,hasTrailingNewline:t}}function
|
|
834
|
+
`,t=r.endsWith(e),s=r.split(/\r?\n/);return t&&s[s.length-1]===""&&s.pop(),{lines:s,lineEnding:e,hasTrailingNewline:t}}function wc(r){let e=r.trim(),t="";for(let s of e)switch(s){case "\u2010":case "\u2011":case "\u2012":case "\u2013":case "\u2014":case "\u2015":case "\u2212":t+="-";break;case "\u2018":case "\u2019":case "\u201A":case "\u201B":t+="'";break;case "\u201C":case "\u201D":case "\u201E":case "\u201F":t+='"';break;case "\xA0":case "\u2002":case "\u2003":case "\u2004":case "\u2005":case "\u2006":case "\u2007":case "\u2008":case "\u2009":case "\u200A":case "\u202F":case "\u205F":case "\u3000":t+=" ";break;default:t+=s;break}return t}function No(r,e,t){if(e.length===0)return t;if(e.length>r.length)return null;let s=r.length-e.length;for(let n=t;n<=s;n+=1){let i=true;for(let o=0;o<e.length;o+=1)if(r[n+o]!==e[o]){i=false;break}if(i)return n}for(let n=t;n<=s;n+=1){let i=true;for(let o=0;o<e.length;o+=1)if(r[n+o].trimEnd()!==e[o].trimEnd()){i=false;break}if(i)return n}for(let n=t;n<=s;n+=1){let i=true;for(let o=0;o<e.length;o+=1)if(r[n+o].trim()!==e[o].trim()){i=false;break}if(i)return n}for(let n=t;n<=s;n+=1){let i=true;for(let o=0;o<e.length;o+=1)if(wc(r[n+o])!==wc(e[o])){i=false;break}if(i)return n}return null}var Nh=2e5;function Fh(r,e){let t=r.length,s=e.length;if(t*s>Nh)return [...r.map(c=>({type:"delete",line:c})),...e.map(c=>({type:"insert",line:c}))];let i=Array.from({length:t+1},()=>new Array(s+1).fill(0));for(let c=t-1;c>=0;c-=1)for(let u=s-1;u>=0;u-=1)i[c][u]=r[c]===e[u]?i[c+1][u+1]+1:Math.max(i[c+1][u],i[c][u+1]);let o=[],a=0,l=0;for(;a<t&&l<s;){if(r[a]===e[l]){o.push({type:"equal",line:r[a]}),a+=1,l+=1;continue}i[a+1][l]>=i[a][l+1]?(o.push({type:"delete",line:r[a]}),a+=1):(o.push({type:"insert",line:e[l]}),l+=1);}for(;a<t;)o.push({type:"delete",line:r[a]}),a+=1;for(;l<s;)o.push({type:"insert",line:e[l]}),l+=1;return o}function Uh(r,e){if(r.length===0&&e.length===0)return [];let t=Fh(r,e),s=[],n=0,i=0,o=0;for(;o<t.length;){if(t[o].type==="equal"){n+=1,i+=1,o+=1;continue}let a=n,l=[],c=[];for(;o<t.length&&t[o].type!=="equal";){let u=t[o];u.type==="delete"?(l.push(u.line),n+=1):(c.push(u.line),i+=1),o+=1;}s.push({oldStart:a,oldLines:l,newLines:c});}return s}var jh={name:"edit_file",description:`Edit file by replacing a target block with a new block.
|
|
835
835
|
Edits apply line-level hunks (only changed lines are replaced).
|
|
836
836
|
Matches are robust (exact -> trim_end -> trim -> normalize) to avoid brittle edits.
|
|
837
|
-
Use change_context to anchor a location and keep old_string minimal.`,parameters:{type:"object",properties:{file_path:{type:"string",description:"Path to the file to edit"},path:{type:"string",description:"Alias of file_path (fallback)"},filePath:{type:"string",description:"Alias of file_path (camelCase fallback)"},file:{type:"string",description:"Alias of file_path (short fallback)"},old_string:{type:"string",description:"Exact string to find and replace (must match exactly, including whitespace)"},old:{type:"string",description:"Alias of old_string (fallback)"},new_string:{type:"string",description:"New string to replace with"},new:{type:"string",description:"Alias of new_string (fallback)"},change_context:{type:"string",description:"Optional anchor (line or block) to locate the edit area (apply_patch-style @@ context)"},changeContext:{type:"string",description:"Alias of change_context (camelCase fallback)"},context:{type:"string",description:"Alias of change_context (fallback)"},replace_all:{type:"boolean",description:"Replace all occurrences (default: false, only first match)"},replaceAll:{type:"boolean",description:"Alias of replace_all (camelCase fallback)"}},required:["file_path","old_string","new_string"]},async function(r){let e=r.file_path||r.path||r.filePath||r.file,t=r.old_string??r.old,s=r.new_string??r.new,n=r.replace_all??r.replaceAll??false,i=r.change_context??r.changeContext??r.context,o=
|
|
837
|
+
Use change_context to anchor a location and keep old_string minimal.`,parameters:{type:"object",properties:{file_path:{type:"string",description:"Path to the file to edit"},path:{type:"string",description:"Alias of file_path (fallback)"},filePath:{type:"string",description:"Alias of file_path (camelCase fallback)"},file:{type:"string",description:"Alias of file_path (short fallback)"},old_string:{type:"string",description:"Exact string to find and replace (must match exactly, including whitespace)"},old:{type:"string",description:"Alias of old_string (fallback)"},new_string:{type:"string",description:"New string to replace with"},new:{type:"string",description:"Alias of new_string (fallback)"},change_context:{type:"string",description:"Optional anchor (line or block) to locate the edit area (apply_patch-style @@ context)"},changeContext:{type:"string",description:"Alias of change_context (camelCase fallback)"},context:{type:"string",description:"Alias of change_context (fallback)"},replace_all:{type:"boolean",description:"Replace all occurrences (default: false, only first match)"},replaceAll:{type:"boolean",description:"Alias of replace_all (camelCase fallback)"}},required:["file_path","old_string","new_string"]},async function(r){let e=r.file_path||r.path||r.filePath||r.file,t=r.old_string??r.old,s=r.new_string??r.new,n=r.replace_all??r.replaceAll??false,i=r.change_context??r.changeContext??r.context,o=De(e);Ee(o);if(!e)return JSON.stringify(V("edit_file","error","Missing required parameter: file_path",{error:"file_path (or path) is required"}));if(t==null)return JSON.stringify(V("edit_file","error","Missing required parameter: old_string",{error:"old_string is required"}));if(s==null)return JSON.stringify(V("edit_file","error","Missing required parameter: new_string",{error:"new_string is required"}));let l;try{l=await Z__default.readFile(o,"utf-8");}catch{return JSON.stringify(V("edit_file","error",`File not found: ${e}`,{file_path:o,error:"File not found",verify_hint:"Use write_file to create a new file, or check the file path."}))}try{let{lines:c,lineEnding:u,hasTrailingNewline:p}=$h(l),d=t.split(/\r?\n/),m=s.split(/\r?\n/);if(d.length===1&&d[0]==="")return JSON.stringify(V("edit_file","error","old_string cannot be empty",{file_path:o,error:"old_string cannot be empty"}));let h=0;if(i){let k=i.split(/\r?\n/),D=No(c,k,0);if(D===null)return JSON.stringify(V("edit_file","error",`change_context not found in ${X__default.basename(o)}`,{file_path:o,error:"change_context not found",verify_hint:`Use "readfile ${e}" to verify the context lines.`}));h=D+k.length;}let g=[],y=h;for(;y<=c.length;){let k=No(c,d,y),D=d,N=m;if(k===null&&d.length>0&&d[d.length-1]===""){let E=d.slice(0,-1);E.length>0&&(k=No(c,E,y),k!==null&&(D=E,N=m[m.length-1]===""?m.slice(0,-1):m));}if(k===null)break;g.push({start:k,oldLines:D,newLines:N}),y=k+D.length;}if(g.length===0)return JSON.stringify(V("edit_file","error",`Target block not found in ${X__default.basename(o)}`,{file_path:o,error:"old_string not found",verify_hint:`Use "readfile ${e}" and reduce old_string or provide change_context.`}));let b=n?g:[g[0]],w=c.slice(),S=[];for(let k of b.slice().reverse()){let D=c.slice(k.start,k.start+k.oldLines.length),N=Uh(D,k.newLines);if(N.length!==0){for(let E of N)S.push({startLine:k.start+E.oldStart+1,oldLines:E.oldLines,newLines:E.newLines});for(let E of N.slice().reverse())w.splice(k.start+E.oldStart,E.oldLines.length,...E.newLines);}}p&&(w=[...w,""]);let x=w.join(u);if(x===l)return JSON.stringify(V("edit_file","already_done","No changes needed (content already matches)",{file_path:o,verify_hint:`Use "readfile ${e}" to verify the content if needed.`}));await Z__default.writeFile(o,x,"utf-8");let R=S.slice().sort((k,D)=>k.startLine-D.startLine),$=R[0],G=$?$.oldLines:[],U=$?$.newLines:[],T=$?$.startLine:1,C=w.length,_=!n&&g.length>1?`Found ${g.length} matches, only replaced the first one. Use replace_all=true to replace all.`:void 0;return JSON.stringify(V("edit_file","success",`Edited ${X__default.basename(o)}: ${b.length} replacement(s) at line ${T}`,{file_path:o,verify_hint:`Use "readfile ${e}" to verify the changes.`,metadata:{replacements:b.length,start_line:T,old_lines:G.length,new_lines:U.length,total_lines:C,warning:_,hunks:R.map(k=>({old_string:k.oldLines.join(`
|
|
838
838
|
`),new_string:k.newLines.join(`
|
|
839
|
-
`),start_line:k.startLine,old_line_count:k.oldLines.length,new_line_count:k.newLines.length})),edit_info:{old_string:
|
|
839
|
+
`),start_line:k.startLine,old_line_count:k.oldLines.length,new_line_count:k.newLines.length})),edit_info:{old_string:G.join(`
|
|
840
840
|
`),new_string:U.join(`
|
|
841
|
-
`),start_line:
|
|
841
|
+
`),start_line:T,old_line_count:G.length,new_line_count:U.length}}}))}catch(c){return JSON.stringify(V("edit_file","error",`Failed to edit file: ${c.message}`,{file_path:o,error:c.message,verify_hint:"Check file permissions or try using write_file to rewrite the entire file."}))}}},Gh={name:"search_files",description:`Fast file pattern matching tool (Glob).
|
|
842
842
|
|
|
843
843
|
Use this to find files by name patterns:
|
|
844
844
|
- "**/*.ts" - all TypeScript files
|
|
845
845
|
- "src/**/*.jsx" - JSX files in src
|
|
846
846
|
- "**/test*.js" - test files anywhere
|
|
847
847
|
|
|
848
|
-
For searching file CONTENTS, use search instead.`,parameters:{type:"object",properties:{pattern:{type:"string",description:"Glob pattern (e.g., **/*.ts, src/**/*.jsx, **/test*.js)"},directory:{type:"string",description:"Directory to search in (default: current directory)"},include_hidden:{type:"boolean",description:"Include hidden files (default: false)"}},required:["pattern"]},async function({pattern:r,directory:e=".",include_hidden:t=false}){try{let s=
|
|
848
|
+
For searching file CONTENTS, use search instead.`,parameters:{type:"object",properties:{pattern:{type:"string",description:"Glob pattern (e.g., **/*.ts, src/**/*.jsx, **/test*.js)"},directory:{type:"string",description:"Directory to search in (default: current directory)"},include_hidden:{type:"boolean",description:"Include hidden files (default: false)"}},required:["pattern"]},async function({pattern:r,directory:e=".",include_hidden:t=false}){try{let s=De(e),n=await Sc(r,{cwd:s,absolute:!1,dot:t,ignore:["**/node_modules/**","**/.git/**"]});if(n.length===0)return `\u2713 \u641C\u7D22: "${r}" \u5728 ${Ee(s)}
|
|
849
849
|
\u672A\u627E\u5230\u5339\u914D\u7684\u6587\u4EF6
|
|
850
850
|
|
|
851
851
|
\u5EFA\u8BAE:
|
|
852
852
|
- \u68C0\u67E5\u8DEF\u5F84\u662F\u5426\u6B63\u786E
|
|
853
|
-
- \u5C1D\u8BD5\u66F4\u5BBD\u6CDB\u7684\u6A21\u5F0F: "**/*${r.replace(/\*\*/g,"").replace(/\*/g,"")}"`;n.sort();let i=[`\u2713 \u627E\u5230 ${n.length} \u4E2A\u6587\u4EF6`];i.push(`\u25B8 \u76EE\u5F55: ${
|
|
853
|
+
- \u5C1D\u8BD5\u66F4\u5BBD\u6CDB\u7684\u6A21\u5F0F: "**/*${r.replace(/\*\*/g,"").replace(/\*/g,"")}"`;n.sort();let i=[`\u2713 \u627E\u5230 ${n.length} \u4E2A\u6587\u4EF6`];i.push(`\u25B8 \u76EE\u5F55: ${Ee(s)}`),i.push(`\u25B8 \u6A21\u5F0F: ${r}
|
|
854
854
|
`);let o=50;return n.slice(0,o).forEach(l=>{i.push(` ${l}`);}),n.length>o&&i.push(`
|
|
855
855
|
... \u8FD8\u6709 ${n.length-o} \u4E2A\u6587\u4EF6`),i.join(`
|
|
856
|
-
`)}catch(s){return `\u2717 \u641C\u7D22\u5931\u8D25: ${s.message}`}}},
|
|
856
|
+
`)}catch(s){return `\u2717 \u641C\u7D22\u5931\u8D25: ${s.message}`}}},Bh={name:"list_directory",description:"List contents of a directory",parameters:{type:"object",properties:{directory:{type:"string",description:"Directory path (default: current directory)"},show_hidden:{type:"boolean",description:"Show hidden files"}}},async function({directory:r=".",show_hidden:e=false}){try{let t=De(r),s=await Z__default.readdir(t,{withFileTypes:!0}),n=e?s:s.filter(l=>!l.name.startsWith(".")),i=n.filter(l=>l.isDirectory()).map(l=>l.name),o=n.filter(l=>l.isFile()).map(l=>l.name),a=[`\u2713 \u76EE\u5F55: ${Ee(t)}
|
|
857
857
|
`];if(i.length>0&&(a.push("\u5B50\u76EE\u5F55:"),i.forEach(l=>a.push(` - ${l}/`))),o.length>0){a.push(`
|
|
858
|
-
\u6587\u4EF6:`);for(let l of o){let c=await
|
|
859
|
-
`)}catch(t){return `\u2717 \u5217\u51FA\u76EE\u5F55\u5931\u8D25: ${t.message}`}}}
|
|
860
|
-
`).filter(c=>c.startsWith("+++ ")||c.startsWith("--- "));for(let c of s){let u=c.slice(4).trim();if(u==="/dev/null")continue;let p=u.replace(/^a\//,"").replace(/^b\//,"");if(p.startsWith("/")||/^[A-Za-z]:[\\/]/.test(p))return JSON.stringify(
|
|
861
|
-
`).trim();return JSON.stringify(
|
|
862
|
-
`).trim();return JSON.stringify(
|
|
858
|
+
\u6587\u4EF6:`);for(let l of o){let c=await Z__default.stat(X__default.join(t,l)),u=c.size<1024?`${c.size}B`:c.size<1024*1024?`${(c.size/1024).toFixed(1)}KB`:`${(c.size/(1024*1024)).toFixed(1)}MB`;a.push(` - ${l} (${u})`);}}return i.length===0&&o.length===0&&a.push("(\u7A7A\u76EE\u5F55)"),a.join(`
|
|
859
|
+
`)}catch(t){return `\u2717 \u5217\u51FA\u76EE\u5F55\u5931\u8D25: ${t.message}`}}},Wh={name:"create_directory",description:"Create a new directory",parameters:{type:"object",properties:{directory:{type:"string",description:"Directory path to create"}},required:["directory"]},async function({directory:r}){if(!r)return JSON.stringify(V("create_directory","error","Missing required parameter: directory",{error:"directory path is required",verify_hint:"Please provide the directory path to create."}));let e=De(r),t=Ee(e);try{try{if((await Z__default.stat(e)).isDirectory())return JSON.stringify(V("create_directory","already_done",`Directory already exists: ${t}`,{file_path:e,verify_hint:`Use "list_directory ${r}" to view contents.`}))}catch{}return await Z__default.mkdir(e,{recursive:!0}),JSON.stringify(V("create_directory","success",`Directory created: ${t}`,{file_path:e,verify_hint:`Use "list_directory ${r}" to verify.`}))}catch(s){return JSON.stringify(V("create_directory","error",`Failed to create directory: ${s.message}`,{file_path:e,error:s.message,verify_hint:"Check path validity and permissions."}))}}},Hh={name:"delete_file",description:"Delete a file or directory (directory requires recursive=true)",parameters:{type:"object",properties:{path:{type:"string",description:"Path to the file or directory to delete"},recursive:{type:"boolean",description:"Allow deleting directories recursively (default: false)"},force:{type:"boolean",description:"Ignore missing paths (default: false)"}},required:["path"]},permission:{category:"write",allowInAskMode:false},async function({path:r,recursive:e=false,force:t=false}){if(!r)return JSON.stringify(V("delete_file","error","Missing required parameter: path",{error:"path is required"}));let s=De(r),n=Ee(s),i=qe();if(!Ct(s))return JSON.stringify(V("delete_file","error","Path is \u062E\u0627\u0631\u062C workspace\uFF0C\u5DF2\u62D2\u7EDD",{file_path:s,error:"Path is outside workspace",verify_hint:"Use a path within the workspace."}));if(s===i)return JSON.stringify(V("delete_file","error","Refusing to delete workspace root",{file_path:s,error:"Refusing to delete workspace root"}));try{let o=await Z__default.lstat(s).catch(()=>null);if(!o)return JSON.stringify(t?V("delete_file","already_done",`Path already removed: ${n}`,{file_path:s}):V("delete_file","error",`Path not found: ${n}`,{file_path:s,error:"Path not found"}));if(o.isDirectory()){if(!e)return JSON.stringify(V("delete_file","error",`Refusing to delete directory without recursive=true: ${n}`,{file_path:s,error:"Directory deletion requires recursive=true"}));await Z__default.rm(s,{recursive:!0,force:t});}else await Z__default.rm(s,{force:t});return JSON.stringify(V("delete_file","success",`Deleted: ${n}`,{file_path:s,verify_hint:`Use "list_directory ${X__default.dirname(n)}" to verify.`}))}catch(o){return JSON.stringify(V("delete_file","error",`Failed to delete: ${n}`,{file_path:s,error:o.message}))}}},zh={name:"rename_file",description:"Rename or move a file/directory within the workspace",parameters:{type:"object",properties:{source_path:{type:"string",description:"Existing path to rename or move"},destination_path:{type:"string",description:"New path"},overwrite:{type:"boolean",description:"Overwrite destination if it exists (default: false)"},create_dirs:{type:"boolean",description:"Create destination parent directories if missing (default: true)"}},required:["source_path","destination_path"]},permission:{category:"write",allowInAskMode:false},async function({source_path:r,destination_path:e,overwrite:t=false,create_dirs:s=true}){if(!r||!e)return JSON.stringify(V("rename_file","error","Missing required parameters: source_path, destination_path",{error:"source_path and destination_path are required"}));let n=De(r),i=De(e),o=Ee(n),a=Ee(i),l=qe();if(!Ct(n)||!Ct(i))return JSON.stringify(V("rename_file","error","Path is outside workspace\uFF0C\u5DF2\u62D2\u7EDD",{file_path:`${n} -> ${i}`,error:"Path is outside workspace"}));if(n===l||i===l)return JSON.stringify(V("rename_file","error","Refusing to rename workspace root",{file_path:n}));try{await Z__default.lstat(n);}catch{return JSON.stringify(V("rename_file","error",`Source not found: ${o}`,{file_path:n,error:"Source not found"}))}let c=await Z__default.lstat(i).catch(()=>null);if(c&&!t)return JSON.stringify(V("rename_file","error",`Destination already exists: ${a}`,{file_path:i,error:"Destination already exists"}));try{return c&&t&&await Z__default.rm(i,{recursive:!0,force:!0}),s&&await Z__default.mkdir(X__default.dirname(i),{recursive:!0}),await Z__default.rename(n,i),JSON.stringify(V("rename_file","success",`Renamed: ${o} \u2192 ${a}`,{file_path:i,verify_hint:`Use "list_directory ${X__default.dirname(a)}" to verify.`,metadata:{from:n,to:i}}))}catch(u){return JSON.stringify(V("rename_file","error",`Failed to rename: ${o}`,{file_path:n,error:u.message}))}}},qh={name:"apply_patch",description:"Apply a unified diff patch (git apply style)",parameters:{type:"object",properties:{patch:{type:"string",description:"Unified diff patch content"},strip:{type:"number",description:"Strip leading path components (git apply -p, default: 0)"},reverse:{type:"boolean",description:"Apply patch in reverse (default: false)"}},required:["patch"]},permission:{category:"write",allowInAskMode:false},async function({patch:r,strip:e=0,reverse:t=false}){if(!r||typeof r!="string")return JSON.stringify(V("apply_patch","error","Missing required parameter: patch",{error:"patch is required"}));if(!Number.isInteger(e)||e<0||e>10)return JSON.stringify(V("apply_patch","error","Invalid strip value (must be an integer between 0 and 10)",{error:"Invalid strip value"}));if(Buffer.byteLength(r,"utf8")>bc)return JSON.stringify(V("apply_patch","error",`Patch too large (max ${bc} bytes)`,{error:"Patch too large"}));let s=r.split(`
|
|
860
|
+
`).filter(c=>c.startsWith("+++ ")||c.startsWith("--- "));for(let c of s){let u=c.slice(4).trim();if(u==="/dev/null")continue;let p=u.replace(/^a\//,"").replace(/^b\//,"");if(p.startsWith("/")||/^[A-Za-z]:[\\/]/.test(p))return JSON.stringify(V("apply_patch","error","Patch contains absolute paths",{error:"Absolute paths are not allowed in patch"}));if(p.split(/[\\/]+/).includes(".."))return JSON.stringify(V("apply_patch","error","Patch contains path traversal",{error:"Path traversal is not allowed in patch"}))}let n=qe(),{repoRoot:i,error:o}=await es(n);if(!i)return JSON.stringify(V("apply_patch","error",`Not a git repository: ${o||"unknown error"}`,{error:"Not a git repository"}));let a=await Z__default.mkdtemp(X__default.join(Js__default.tmpdir(),"neox-patch-")),l=X__default.join(a,"apply.patch");try{await Z__default.writeFile(l,r,"utf8");let c=["apply"];e>0&&c.push(`-p${e}`),t&&c.push("--reverse");let u=await Ue("git",[...c,"--check",l],i);if(u.exitCode!==0){let d=[u.stdout,u.stderr].filter(Boolean).join(`
|
|
861
|
+
`).trim();return JSON.stringify(V("apply_patch","error","Patch check failed",{error:d||"Patch check failed",verify_hint:"Ensure the patch applies cleanly to the current workspace state."}))}let p=await Ue("git",[...c,"--whitespace=nowarn",l],i);if(p.exitCode!==0){let d=[p.stdout,p.stderr].filter(Boolean).join(`
|
|
862
|
+
`).trim();return JSON.stringify(V("apply_patch","error","Patch apply failed",{error:d||"Patch apply failed"}))}return JSON.stringify(V("apply_patch","success","Patch applied successfully",{verify_hint:"Use git diff or readfile to verify changes."}))}catch(c){return JSON.stringify(V("apply_patch","error","Patch apply failed",{error:c.message}))}finally{await Z__default.rm(a,{recursive:true,force:true}).catch(()=>{});}}},Jh=process.env.NEOX_SANDBOX==="on";var Kh={name:"execute_shell",description:`Execute shell command with smart background process management.
|
|
863
863
|
|
|
864
864
|
\u{1F525} CRITICAL - Background Process Behavior:
|
|
865
865
|
- background=true: For LONG-RUNNING processes (npm run dev, servers, watch modes)
|
|
@@ -885,9 +885,9 @@ For searching file CONTENTS, use search instead.`,parameters:{type:"object",prop
|
|
|
885
885
|
|
|
886
886
|
\u{1F4CC} Process Management:
|
|
887
887
|
- Use /processes to list all running background processes
|
|
888
|
-
- Use /kill <pid> to stop a background process before retrying`,parameters:{type:"object",properties:{command:{type:"string",description:"Shell command to execute"},background:{type:"boolean",description:"Run in background. Use TRUE for: npm run dev, servers, watch modes, npm install (large projects), db migrations, docker builds. Use FALSE for: quick commands like ls, git status, cat. Default: false"}},required:["command"]},async function({command:r,background:e=false},t){if(
|
|
888
|
+
- Use /kill <pid> to stop a background process before retrying`,parameters:{type:"object",properties:{command:{type:"string",description:"Shell command to execute"},background:{type:"boolean",description:"Run in background. Use TRUE for: npm run dev, servers, watch modes, npm install (large projects), db migrations, docker builds. Use FALSE for: quick commands like ls, git status, cat. Default: false"}},required:["command"]},async function({command:r,background:e=false},t){if(Jh){let u=["ls","pwd","echo","cat","grep","find","wc","head","tail"],p=r.trim().split(" ")[0];if(!u.includes(p))return `\u2717 \u6C99\u7BB1\u6A21\u5F0F\uFF1A\u4E0D\u5141\u8BB8\u6267\u884C\u547D\u4EE4: ${p}
|
|
889
889
|
\u5141\u8BB8\u7684\u547D\u4EE4: ${u.join(", ")}
|
|
890
|
-
\u63D0\u793A: \u4F7F\u7528 /sandbox off \u5173\u95ED\u6C99\u7BB1\u6A21\u5F0F`}let n=qe(),i=t?.signal,o=r.trim().endsWith("&"),a=r.includes("|");e&&(o||a)&&(
|
|
890
|
+
\u63D0\u793A: \u4F7F\u7528 /sandbox off \u5173\u95ED\u6C99\u7BB1\u6A21\u5F0F`}let n=qe(),i=t?.signal,o=r.trim().endsWith("&"),a=r.includes("|");e&&(o||a)&&(we.warn("SHELL","\u68C0\u6D4B\u5230\u540E\u53F0\u6A21\u5F0F\u4E0B\u4F7F\u7528\u4E86 '&' \u6216\u7BA1\u9053\u7B26\u53F7\uFF0C\u8FD9\u53EF\u80FD\u5BFC\u81F4\u975E\u9884\u671F\u884C\u4E3A"),o&&we.info("SHELL","\u63D0\u793A: background=true \u53C2\u6570\u5DF2\u7ECF\u5904\u7406\u540E\u53F0\u8FD0\u884C\uFF0C\u65E0\u9700\u5728\u547D\u4EE4\u672B\u5C3E\u6DFB\u52A0 '&'"),a&&we.warn("SHELL","\u8B66\u544A: \u540E\u53F0\u6A21\u5F0F\u4E0B\u4F7F\u7528\u7BA1\u9053\u53EF\u80FD\u5BFC\u81F4\u8F93\u51FA\u622A\u65AD\u6216\u8FDB\u7A0B\u610F\u5916\u9000\u51FA"));let c=await Ah(r,e,n,i);if(c){if(c.background&&c.pid){Le.processManager.get(c.pid)||Le.processManager.register({pid:c.pid,command:r,cwd:n,background:true});let u=Le.processManager.getBackgroundRunning().length;return c.output.replace(/当前后台进程总数:\s*\d+/,`\u5F53\u524D\u540E\u53F0\u8FDB\u7A0B\u603B\u6570: ${u}`)}return c.output}if(e){let u=r.trim().replace(/\s+/g," ").replace(/\s*&\s*$/,""),p=Le.processManager.getBackgroundRunning().find(d=>d.command.trim().replace(/\s+/g," ").replace(/\s*&\s*$/,"")===u);if(p){let d=Math.floor((Date.now()-p.startTime.getTime())/1e3),m=Le.processManager.getBackgroundRunning().length;return `\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
891
891
|
\u25B8 \u5DE5\u4F5C\u76EE\u5F55: ${n}
|
|
892
892
|
\u25B8 \u6267\u884C\u547D\u4EE4: ${r}
|
|
893
893
|
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
@@ -906,8 +906,8 @@ For searching file CONTENTS, use search instead.`,parameters:{type:"object",prop
|
|
|
906
906
|
- /processes - \u67E5\u770B\u6240\u6709\u540E\u53F0\u8FDB\u7A0B\u72B6\u6001
|
|
907
907
|
- /kill ${p.pid} - \u7EC8\u6B62\u73B0\u6709\u8FDB\u7A0B\u540E\u91CD\u65B0\u542F\u52A8
|
|
908
908
|
- lsof -i :\u7AEF\u53E3\u53F7 - \u68C0\u67E5\u7AEF\u53E3\u5360\u7528\u60C5\u51B5
|
|
909
|
-
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`}try{let d=execa(r,{shell:!0,cwd:n,detached:!0,stdio:["ignore","pipe","pipe"],env:
|
|
910
|
-
... (\u8F93\u51FA\u8FC7\u957F\uFF0C\u5DF2\u622A\u65AD)`:y,w=
|
|
909
|
+
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`}try{let d=execa(r,{shell:!0,cwd:n,detached:!0,stdio:["ignore","pipe","pipe"],env:Le.shellEnv.getShellEnv()});d.unref();let m=d.pid;m&&(Le.processManager.register({pid:m,command:r,cwd:n,background:!0,processRef:d}),d.on("exit",S=>{Le.processManager.markCompleted(m,S??0);})),i&&m&&i.addEventListener("abort",()=>{we.info("SHELL",`\u6536\u5230\u4E2D\u65AD\u4FE1\u53F7\uFF0C\u7EC8\u6B62\u540E\u53F0\u8FDB\u7A0B PID: ${m}`),Le.processManager.killProcessGroup(m);});let h=[],g=8e3;d.stdout?.on("data",S=>{let x=S.toString();h.push(x),process.env.CLI_DEBUG==="1"&&we.debug("SHELL_STDOUT",x.trim());}),d.stderr?.on("data",S=>{let x=S.toString();h.push(x),process.env.CLI_DEBUG==="1"&&we.debug("SHELL_STDERR",x.trim());}),we.info("SHELL",`\u6B63\u5728\u6536\u96C6\u8FDB\u7A0B\u8F93\u51FA (${g/1e3}\u79D2)...`),await new Promise((S,x)=>{let R=setTimeout(S,g);i&&i.addEventListener("abort",()=>{clearTimeout(R),x(new Error("Command interrupted by user"));});});let y=h.join(""),b=y.length>3e3?y.slice(0,3e3)+`
|
|
910
|
+
... (\u8F93\u51FA\u8FC7\u957F\uFF0C\u5DF2\u622A\u65AD)`:y,w=Le.processManager.getBackgroundRunning().length;return `\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
911
911
|
\u25B8 \u5DE5\u4F5C\u76EE\u5F55: ${n}
|
|
912
912
|
\u25B8 \u6267\u884C\u547D\u4EE4: ${r}
|
|
913
913
|
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
@@ -941,7 +941,7 @@ ${b||"(\u6682\u65E0\u8F93\u51FA)"}
|
|
|
941
941
|
|
|
942
942
|
\u2717 \u540E\u53F0\u542F\u52A8\u5931\u8D25:
|
|
943
943
|
${d.message}
|
|
944
|
-
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`}}try{let{stdout:u,stderr:p,exitCode:d}=await execa(r,{shell:!0,timeout:12e4,cwd:n,reject:!1,signal:i,env:
|
|
944
|
+
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`}}try{let{stdout:u,stderr:p,exitCode:d}=await execa(r,{shell:!0,timeout:12e4,cwd:n,reject:!1,signal:i,env:Le.shellEnv.getShellEnv(),stdio:["ignore","pipe","pipe"]}),m=`\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
945
945
|
`;return m+=`\u25B8 \u5DE5\u4F5C\u76EE\u5F55: ${n}
|
|
946
946
|
`,m+=`\u25B8 \u6267\u884C\u547D\u4EE4: ${r}
|
|
947
947
|
`,m+=`\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501
|
|
@@ -985,25 +985,25 @@ ${u.stderr?`\u25E6 \u9519\u8BEF\u4FE1\u606F:
|
|
|
985
985
|
${u.stderr}
|
|
986
986
|
|
|
987
987
|
`:""}
|
|
988
|
-
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`}}},
|
|
989
|
-
`];async function n(i,o="",a=0){if(a>=e)return;let u=(await
|
|
990
|
-
`)}catch(t){return `\u2717 \u663E\u793A\u76EE\u5F55\u6811\u5931\u8D25: ${t.message}`}}},
|
|
991
|
-
`).trim();return o.exitCode!==0?JSON.stringify(
|
|
992
|
-
`).trim();return a.exitCode!==0?JSON.stringify(
|
|
993
|
-
`).trim();return c.exitCode!==0?JSON.stringify(
|
|
994
|
-
`).trim();return o.exitCode!==0?JSON.stringify(
|
|
995
|
-
`).trim();return JSON.stringify(
|
|
996
|
-
`).trim();return JSON.stringify(
|
|
997
|
-
`).trim();return JSON.stringify(
|
|
998
|
-
`).trim();return JSON.stringify(
|
|
999
|
-
`),m=
|
|
1000
|
-
`),p=
|
|
988
|
+
\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501\u2501`}}},Vh={name:"show_tree",description:"Display directory tree structure",parameters:{type:"object",properties:{directory:{type:"string",description:"Directory path (default: current directory)"},max_depth:{type:"number",description:"Maximum depth to traverse (default: 3)"}}},async function({directory:r=".",max_depth:e=3}){try{let t=De(r),s=[`${Ee(t)}/
|
|
989
|
+
`];async function n(i,o="",a=0){if(a>=e)return;let u=(await Z__default.readdir(i,{withFileTypes:!0})).filter(p=>!p.name.startsWith(".")).sort((p,d)=>p.isDirectory()&&!d.isDirectory()?-1:!p.isDirectory()&&d.isDirectory()?1:p.name.localeCompare(d.name));for(let p=0;p<u.length;p++){let d=u[p],m=p===u.length-1,h=m?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ",g=m?" ":"\u2502 ";if(d.isDirectory())s.push(`${o}${h}${d.name}/`),await n(X__default.join(i,d.name),o+g,a+1);else {let y=await Z__default.stat(X__default.join(i,d.name)),b=y.size<1024?`${y.size}B`:y.size<1024*1024?`${(y.size/1024).toFixed(1)}KB`:`${(y.size/(1024*1024)).toFixed(1)}MB`;s.push(`${o}${h}${d.name} (${b})`);}}}return await n(t),s.join(`
|
|
990
|
+
`)}catch(t){return `\u2717 \u663E\u793A\u76EE\u5F55\u6811\u5931\u8D25: ${t.message}`}}},Yh={name:"git_status",description:"Show git status (short by default)",parameters:{type:"object",properties:{path:{type:"string",description:"Path inside the repo (default: workspace root)"},short:{type:"boolean",description:"Use short format (default: true)"}}},permission:{category:"read",allowInAskMode:true},async function({path:r=".",short:e=true}){let t=De(r);if(!Ct(t))return JSON.stringify(he("git_status","error","git status failed: path outside workspace",void 0,{error:"path outside workspace"}));let{repoRoot:s,error:n}=await es(t);if(!s)return JSON.stringify(he("git_status","error",`git status failed: ${n||"not a git repository"}`,void 0,{error:n||"not a git repository"}));let i=["status"];e&&i.push("-sb");let o=await Ue("git",i,s),a=[o.stdout,o.stderr].filter(Boolean).join(`
|
|
991
|
+
`).trim();return o.exitCode!==0?JSON.stringify(he("git_status","error","git status failed",a||void 0,{error:a||"git status failed"})):JSON.stringify(he("git_status","success",a?"git status ok":"git status clean",a||"\u2713 clean"))}},Xh={name:"git_diff",description:"Show git diff",parameters:{type:"object",properties:{path:{type:"string",description:"Path inside the repo (default: workspace root)"},staged:{type:"boolean",description:"Show staged diff (default: false)"},file_path:{type:"string",description:"Limit diff to a specific file"}}},permission:{category:"read",allowInAskMode:true},async function({path:r=".",staged:e=false,file_path:t}){let s=De(r);if(!Ct(s))return JSON.stringify(he("git_diff","error","git diff failed: path outside workspace",void 0,{error:"path outside workspace"}));let{repoRoot:n,error:i}=await es(s);if(!n)return JSON.stringify(he("git_diff","error",`git diff failed: ${i||"not a git repository"}`,void 0,{error:i||"not a git repository"}));let o=["diff"];if(e&&o.push("--staged"),t){let c=De(t);if(!Ct(c))return JSON.stringify(he("git_diff","error","git diff failed: path outside workspace",void 0,{error:"path outside workspace"}));let u=X__default.relative(n,c);if(u.startsWith("..")||X__default.isAbsolute(u))return JSON.stringify(he("git_diff","error","git diff failed: file outside repo",void 0,{error:"file outside repo"}));o.push("--",u);}let a=await Ue("git",o,n),l=[a.stdout,a.stderr].filter(Boolean).join(`
|
|
992
|
+
`).trim();return a.exitCode!==0?JSON.stringify(he("git_diff","error","git diff failed",l||void 0,{error:l||"git diff failed"})):JSON.stringify(he("git_diff","success",l?"git diff ok":"no diff",l||""))}},Zh={name:"git_blame",description:"Show git blame for a file",parameters:{type:"object",properties:{file_path:{type:"string",description:"File path to blame (required)"},start_line:{type:"number",description:"Start line (1-based)"},end_line:{type:"number",description:"End line (1-based)"}},required:["file_path"]},permission:{category:"read",allowInAskMode:true},async function({file_path:r,start_line:e,end_line:t}){if(!r)return JSON.stringify(he("git_blame","error","git blame failed: file_path is required",void 0,{error:"file_path is required"}));let s=De(r);if(!Ct(s))return JSON.stringify(he("git_blame","error","git blame failed: path outside workspace",void 0,{error:"path outside workspace"}));let{repoRoot:n,error:i}=await es(X__default.dirname(s));if(!n)return JSON.stringify(he("git_blame","error",`git blame failed: ${i||"not a git repository"}`,void 0,{error:i||"not a git repository"}));let o=e&&t?`${e},${t}`:void 0,a=X__default.relative(n,s);if(a.startsWith("..")||X__default.isAbsolute(a))return JSON.stringify(he("git_blame","error","git blame failed: file outside repo",void 0,{error:"file outside repo"}));let l=["blame","--",a];o&&l.splice(1,0,"-L",o);let c=await Ue("git",l,n),u=[c.stdout,c.stderr].filter(Boolean).join(`
|
|
993
|
+
`).trim();return c.exitCode!==0?JSON.stringify(he("git_blame","error","git blame failed",u||void 0,{error:u||"git blame failed"})):JSON.stringify(he("git_blame","success","git blame ok",u||""))}},Qh={name:"git_branch_list",description:"List git branches",parameters:{type:"object",properties:{path:{type:"string",description:"Path inside the repo (default: workspace root)"},all:{type:"boolean",description:"Include remote branches (default: false)"}}},permission:{category:"read",allowInAskMode:true},async function({path:r=".",all:e=false}){let t=De(r);if(!Ct(t))return JSON.stringify(he("git_branch_list","error","git branch failed: path outside workspace",void 0,{error:"path outside workspace"}));let{repoRoot:s,error:n}=await es(t);if(!s)return JSON.stringify(he("git_branch_list","error",`git branch failed: ${n||"not a git repository"}`,void 0,{error:n||"not a git repository"}));let i=["branch","--list"];e&&i.push("--all");let o=await Ue("git",i,s),a=[o.stdout,o.stderr].filter(Boolean).join(`
|
|
994
|
+
`).trim();return o.exitCode!==0?JSON.stringify(he("git_branch_list","error","git branch failed",a||void 0,{error:a||"git branch failed"})):JSON.stringify(he("git_branch_list","success","git branches",a||""))}},eg={name:"git_branch",description:"Create a git branch",parameters:{type:"object",properties:{name:{type:"string",description:"Branch name to create"},checkout:{type:"boolean",description:"Checkout after creation (default: false)"}},required:["name"]},permission:{category:"write",allowInAskMode:false},async function({name:r,checkout:e=false}){let t=qe(),{repoRoot:s,error:n}=await es(t);if(!s)return JSON.stringify(V("git_branch","error",`Not a git repository: ${n||"unknown error"}`,{error:"Not a git repository"}));if(!r)return JSON.stringify(V("git_branch","error","Branch name is required (use git_branch_list to list branches)",{error:"name is required"}));let i=typeof r=="string"?r.trim():"",o=/^[A-Za-z0-9._\\/-]+$/.test(i);if(!i||!o||i.includes("..")||i.startsWith("/")||i.endsWith("/"))return JSON.stringify(V("git_branch","error","Invalid branch name",{error:"Invalid branch name"}));let l=await Ue("git",["branch",i],s);if(l.exitCode!==0){let c=[l.stdout,l.stderr].filter(Boolean).join(`
|
|
995
|
+
`).trim();return JSON.stringify(V("git_branch","error","Failed to create branch",{error:c||"Failed to create branch"}))}if(e){let c=await Ue("git",["checkout",i],s);if(c.exitCode!==0){let u=[c.stdout,c.stderr].filter(Boolean).join(`
|
|
996
|
+
`).trim();return JSON.stringify(V("git_branch","error","Branch created but checkout failed",{error:u||"Checkout failed"}))}}return JSON.stringify(V("git_branch","success",e?`Branch created and checked out: ${i}`:`Branch created: ${i}`,{metadata:{branch:i,checkout:e}}))}},tg={name:"git_commit",description:"Create a git commit",parameters:{type:"object",properties:{message:{type:"string",description:"Commit message"},add_all:{type:"boolean",description:"Run git add -A before commit (default: false)"}},required:["message"]},permission:{category:"write",allowInAskMode:false},async function({message:r,add_all:e=false}){let t=qe(),{repoRoot:s,error:n}=await es(t);if(!s)return JSON.stringify(V("git_commit","error",`Not a git repository: ${n||"unknown error"}`,{error:"Not a git repository"}));let i=typeof r=="string"?r.trim():"";if(!i||i.length<3)return JSON.stringify(V("git_commit","error","Commit message is too short",{error:"Commit message is too short"}));if(e){let a=await Ue("git",["add","-A"],s);if(a.exitCode!==0){let l=[a.stdout,a.stderr].filter(Boolean).join(`
|
|
997
|
+
`).trim();return JSON.stringify(V("git_commit","error","git add -A failed",{error:l||"git add failed"}))}}let o=await Ue("git",["commit","-m",i],s);if(o.exitCode!==0){let a=[o.stdout,o.stderr].filter(Boolean).join(`
|
|
998
|
+
`).trim();return JSON.stringify(V("git_commit","error","git commit failed",{error:a||"git commit failed"}))}return JSON.stringify(V("git_commit","success",`Commit created: ${i}`,{metadata:{message:i}}))}};async function sg(r){let e=Z__default.stat(X__default.join(r,"package.json")).then(()=>true).catch(()=>false),t=Z__default.stat(X__default.join(r,"pnpm-lock.yaml")).then(()=>true).catch(()=>false),s=Z__default.stat(X__default.join(r,"yarn.lock")).then(()=>true).catch(()=>false),n=Z__default.stat(X__default.join(r,"bun.lockb")).then(()=>true).catch(()=>false),i=Z__default.stat(X__default.join(r,"pyproject.toml")).then(()=>true).catch(()=>false),o=Z__default.stat(X__default.join(r,"pytest.ini")).then(()=>true).catch(()=>false),a=Z__default.stat(X__default.join(r,"go.mod")).then(()=>true).catch(()=>false),l=Z__default.stat(X__default.join(r,"Cargo.toml")).then(()=>true).catch(()=>false),c=Z__default.stat(X__default.join(r,"Makefile")).then(()=>true).catch(()=>false);return Promise.all([e,t,s,n,i,o,a,l,c]).then(([u,p,d,m,h,g,y,b,w])=>u?p?"pnpm":d?"yarn":m?"bun":"npm":h||g?"pytest":y?"go":b?"cargo":w?"make":null)}function ng(r,e,t){switch(r){case "npm":case "pnpm":case "yarn":case "bun":return {command:r,args:["run",e==="test"?"test":e==="lint"?"lint":"format",...t]};case "pytest":return {command:"pytest",args:t};case "go":return e==="test"?{command:"go",args:["test","./...",...t]}:e==="lint"?{command:"golangci-lint",args:["run",...t]}:{command:"gofmt",args:["-w",...t]};case "cargo":return e==="test"?{command:"cargo",args:["test",...t]}:e==="lint"?{command:"cargo",args:["clippy","--",...t]}:{command:"cargo",args:["fmt",...t]};case "make":return {command:"make",args:[e,...t]};default:return {command:"npm",args:["run",e,...t]}}}async function jo(r,e,t){let s=De(t.cwd||".");if(!Ct(s))return JSON.stringify(Mt(r,"error","Command rejected: path outside workspace",{error:"cwd is outside workspace"}));if(t.extra_args!==void 0&&!Array.isArray(t.extra_args))return JSON.stringify(Mt(r,"error","Invalid extra_args: expected an array of strings",{error:"extra_args must be an array"}));let n=Array.isArray(t.extra_args)?t.extra_args.map(l=>String(l)):[],i=t.preset||await sg(s),o=t.command,a=[];if(o){let l=Lh(o);if(!l.command)return JSON.stringify(Mt(r,"error","Invalid command",{error:"Command is empty"}));let c=new Set(["npm","pnpm","yarn","bun","pytest","go","cargo","make"]);if(!c.has(l.command))return JSON.stringify(Mt(r,"error","Command not allowed",{error:`Allowed commands: ${Array.from(c).join(", ")}`}));let u=l.args.concat(n),p=await Ue(l.command,u,s,{timeoutMs:t.timeout_ms||3e5}),d=[p.stdout,p.stderr].filter(Boolean).join(`
|
|
999
|
+
`),m=Hr(d,fc),h=p.exitCode===0?`${r} succeeded (${p.durationMs}ms)`:`${r} failed with exit code ${p.exitCode}`;return JSON.stringify(Mt(r,p.exitCode===0?"success":"error",h,{error:p.exitCode===0?void 0:Hr(d,yc).text,metadata:{command:[l.command,...u].join(" "),exit_code:p.exitCode,duration_ms:p.durationMs,output_truncated:m.truncated}}))}if(i){let l=ng(i,e,n);a=l.args;let c=await Ue(l.command,a,s,{timeoutMs:t.timeout_ms||3e5}),u=[c.stdout,c.stderr].filter(Boolean).join(`
|
|
1000
|
+
`),p=Hr(u,fc),d=c.exitCode===0?`${r} succeeded (${c.durationMs}ms)`:`${r} failed with exit code ${c.exitCode}`;return JSON.stringify(Mt(r,c.exitCode===0?"success":"error",d,{error:c.exitCode===0?void 0:Hr(u,yc).text,metadata:{command:[l.command,...a].join(" "),exit_code:c.exitCode,duration_ms:c.durationMs,output_truncated:p.truncated}}))}return JSON.stringify(Mt(r,"error","Unable to detect project type for command",{error:"No preset detected. Provide preset."}))}var rg={name:"run_tests",description:"Run project tests with a structured command",parameters:{type:"object",properties:{preset:{type:"string",description:"Command preset (npm|pnpm|yarn|bun|pytest|go|cargo|make)"},command:{type:"string",description:"Explicit command (overrides preset)"},extra_args:{type:"array",items:{type:"string"},description:"Additional args for the command"},cwd:{type:"string",description:"Working directory (default: workspace root)"},timeout_ms:{type:"number",description:"Timeout in milliseconds (default: 300000)"}}},permission:{category:"execute",allowInAskMode:false},async function(r){return jo("run_tests","test",r)}},ig={name:"run_lint",description:"Run project lint with a structured command",parameters:{type:"object",properties:{preset:{type:"string",description:"Command preset (npm|pnpm|yarn|bun|pytest|go|cargo|make)"},command:{type:"string",description:"Explicit command (overrides preset)"},extra_args:{type:"array",items:{type:"string"},description:"Additional args for the command"},cwd:{type:"string",description:"Working directory (default: workspace root)"},timeout_ms:{type:"number",description:"Timeout in milliseconds (default: 300000)"}}},permission:{category:"execute",allowInAskMode:false},async function(r){return jo("run_lint","lint",r)}},og={name:"run_format",description:"Run project formatting with a structured command",parameters:{type:"object",properties:{preset:{type:"string",description:"Command preset (npm|pnpm|yarn|bun|pytest|go|cargo|make)"},command:{type:"string",description:"Explicit command (overrides preset)"},extra_args:{type:"array",items:{type:"string"},description:"Additional args for the command"},cwd:{type:"string",description:"Working directory (default: workspace root)"},timeout_ms:{type:"number",description:"Timeout in milliseconds (default: 300000)"}}},permission:{category:"execute",allowInAskMode:false},async function(r){return jo("run_format","format",r)}},ag={name:"analyze_code",description:"Analyze code file structure and statistics",parameters:{type:"object",properties:{file_path:{type:"string",description:"Path to code file"}},required:["file_path"]},async function({file_path:r}){try{let e=De(r),s=(await Z__default.readFile(e,"utf-8")).split(`
|
|
1001
1001
|
`),n=s.length,i=s.filter(d=>d.trim()&&!d.trim().startsWith("//")).length,o=s.filter(d=>d.trim().startsWith("//")).length,a=n-i-o,l=s.filter(d=>d.trim().startsWith("import ")||d.trim().startsWith("from ")),c=s.filter(d=>d.trim().startsWith("function ")||d.trim().startsWith("async function")),u=s.filter(d=>d.trim().startsWith("class ")),p=[`\u2713 \u4EE3\u7801\u5206\u6790: ${r}
|
|
1002
1002
|
`,"\u7EDF\u8BA1:",` \u603B\u884C\u6570: ${n}`,` \u4EE3\u7801\u884C: ${i}`,` \u6CE8\u91CA\u884C: ${o}`,` \u7A7A\u767D\u884C: ${a}`];return l.length>0&&(p.push(`
|
|
1003
1003
|
\u5BFC\u5165 (${l.length} \u4E2A):`),l.slice(0,5).forEach(d=>p.push(` - ${d.trim()}`)),l.length>5&&p.push(` ... \u8FD8\u6709 ${l.length-5} \u4E2A\u5BFC\u5165`)),u.length>0&&(p.push(`
|
|
1004
1004
|
\u7C7B\u5B9A\u4E49 (${u.length} \u4E2A):`),u.forEach(d=>p.push(` - ${d.trim()}`))),c.length>0&&(p.push(`
|
|
1005
1005
|
\u51FD\u6570\u5B9A\u4E49 (${c.length} \u4E2A):`),c.slice(0,10).forEach(d=>p.push(` - ${d.trim()}`)),c.length>10&&p.push(` ... \u8FD8\u6709 ${c.length-10} \u4E2A\u51FD\u6570`)),p.join(`
|
|
1006
|
-
`)}catch(e){return `\u2717 \u5206\u6790\u5931\u8D25: ${e.message}`}}},
|
|
1006
|
+
`)}catch(e){return `\u2717 \u5206\u6790\u5931\u8D25: ${e.message}`}}},Fo=["!**/node_modules/**","!**/.git/**","!**/dist/**","!**/build/**","!**/out/**","!**/.next/**","!**/coverage/**","!**/__pycache__/**","!**/target/**","!**/vendor/**"],Mn=null,Qt=null;async function Uo(){if(Qt!==null)return Qt;try{let{rgPath:r}=await import('@vscode/ripgrep');return Qt=r,we.info("SEARCH",`Using bundled ripgrep: ${r}`),Qt}catch(r){we.warn("SEARCH",`Bundled ripgrep not available: ${r.message}`);try{if((await Ue("rg",["--version"],qe(),{timeoutMs:2e3})).exitCode===0)return Qt="rg",we.info("SEARCH","Using system ripgrep"),Qt}catch{}}return Qt=null,null}async function lg(){return Mn!==null||(Mn=await Uo()!==null,Mn?we.info("SEARCH","ripgrep available"):we.warn("SEARCH","ripgrep not available, using fallback")),Mn}function cg(r){let e=r.case_insensitive??true,t=[],s=(n,i,o)=>{if(!n.pattern||!n.pattern.trim())return;let a=(n.op||i).toLowerCase(),l=n.regex??o,c=n.case_insensitive??e;t.push({id:`q${t.length+1}`,pattern:n.pattern,op:a==="and"||a==="or"||a==="not"?a:i,regex:l,caseInsensitive:c});};if((r.pattern||r.query)&&s({pattern:r.pattern||r.query||"",op:r.op},"or",true),Array.isArray(r.keywords))for(let n of r.keywords)s({pattern:n},"or",false);if(Array.isArray(r.queries))for(let n of r.queries)s(n,"or",n.regex??true);return t}var ug={name:"search",description:`\u3010\u5168\u5C40\u641C\u7D22\u3011\u652F\u6301\u591A\u5173\u952E\u8BCD\u3001\u591A\u67E5\u8BE2\u3001\u8DE8\u76EE\u5F55\u81EA\u52A8\u5B9A\u4F4D\u3002
|
|
1007
1007
|
|
|
1008
1008
|
\u{1F525} \u6781\u7B80\u7528\u6CD5\uFF1A
|
|
1009
1009
|
search(pattern="\u767B\u5F55") \u2192 \u5168\u5C40\u5185\u5BB9\u641C\u7D22
|
|
@@ -1019,16 +1019,16 @@ search(mode="files", pattern="*.ts") \u2192 \u6587\u4EF6\u540D\u641C\u7D22
|
|
|
1019
1019
|
\u8F93\u51FA\u7279\u70B9:
|
|
1020
1020
|
- \u6BCF\u6761\u7ED3\u679C\u5E26 [\u6A21\u5757] \u524D\u7F00
|
|
1021
1021
|
- \u663E\u793A\u6A21\u5757\u5206\u5E03\u7EDF\u8BA1
|
|
1022
|
-
- \u63D0\u4F9B readfile \u6279\u91CF\u8BFB\u53D6\u63D0\u793A`,parameters:{type:"object",properties:{pattern:{type:"string",description:'\u641C\u7D22\u6A21\u5F0F (\u9ED8\u8BA4\u6B63\u5219)\u3002\u793A\u4F8B: "error", "\u767B\u5F55", "function\\s+\\w+"'},query:{type:"string",description:"pattern \u7684\u522B\u540D"},keywords:{type:"array",items:{type:"string"},description:"\u591A\u5173\u952E\u8BCD OR \u641C\u7D22 (\u5B57\u9762\u91CF\u5339\u914D)"},queries:{type:"array",items:{type:"object",properties:{pattern:{type:"string"},op:{type:"string",enum:["and","or","not"]},regex:{type:"boolean"},case_insensitive:{type:"boolean"}},required:["pattern"]},description:"\u9AD8\u7EA7\u591A\u67E5\u8BE2 (\u652F\u6301 and/or/not)"},op:{type:"string",enum:["and","or","not"],description:"pattern \u7684\u903B\u8F91\u64CD\u4F5C (\u9ED8\u8BA4 or)"},mode:{type:"string",enum:["content","files"],description:"\u641C\u7D22\u6A21\u5F0F: \u5185\u5BB9\u641C\u7D22\u6216\u6587\u4EF6\u540D\u641C\u7D22 (\u9ED8\u8BA4: content)"},path:{type:"string",description:"\u641C\u7D22\u8DEF\u5F84 (\u53EF\u9009\uFF0C\u9ED8\u8BA4: \u5F53\u524D\u5DE5\u4F5C\u76EE\u5F55)"},recursive:{type:"boolean",description:"\u9012\u5F52\u5B50\u76EE\u5F55 (\u53EF\u9009\uFF0C\u76EE\u5F55\u9ED8\u8BA4 true\uFF0C\u6587\u4EF6\u9ED8\u8BA4 false)"},file_pattern:{type:"string",description:'\u6587\u4EF6\u7C7B\u578B\u8FC7\u6EE4 (e.g., "*.ts", "*.{js,jsx,ts,tsx}")'},include_hidden:{type:"boolean",description:"\u5305\u542B\u9690\u85CF\u6587\u4EF6 (\u9ED8\u8BA4: false)"},case_insensitive:{type:"boolean",description:"\u5FFD\u7565\u5927\u5C0F\u5199 (\u9ED8\u8BA4: true)"},context_lines:{type:"number",description:"\u4E0A\u4E0B\u6587\u884C\u6570 (\u9ED8\u8BA4: 2)"},max_matches:{type:"number",description:"\u6700\u5927\u5339\u914D\u6570 (\u9ED8\u8BA4: 200)"},count_only:{type:"boolean",description:"\u4EC5\u8FD4\u56DE\u8BA1\u6570 (\u5FEB\u901F\u4E86\u89E3\u5339\u914D\u5206\u5E03)"}}},async function({pattern:r,query:e,keywords:t,queries:s,op:n,mode:i="content",path:o,recursive:a,file_pattern:l,include_hidden:c=false,case_insensitive:u=true,context_lines:p=2,max_matches:d=200,count_only:m=false},h){try{let g=Date.now();
|
|
1023
|
-
Please report this issue.`,{error:"ripgrep not available"}));if(b(),i==="files"){let
|
|
1024
|
-
`).filter(Boolean).map(it=>{let
|
|
1025
|
-
`),{metadata:{mode:"files",strategy:
|
|
1026
|
-
Error: ${
|
|
1027
|
-
Command: ${
|
|
1028
|
-
`)){if(b(),Ke++,Ke%w===0&&await S(),!
|
|
1029
|
-
... \u8FD8\u6709\u66F4\u591A\u5339\u914D (\u5DF2\u8FBE ${d} \u4E0A\u9650)`);break}let
|
|
1030
|
-
\u25B8 [${
|
|
1031
|
-
`),{metadata:{mode:"content",strategy:
|
|
1022
|
+
- \u63D0\u4F9B readfile \u6279\u91CF\u8BFB\u53D6\u63D0\u793A`,parameters:{type:"object",properties:{pattern:{type:"string",description:'\u641C\u7D22\u6A21\u5F0F (\u9ED8\u8BA4\u6B63\u5219)\u3002\u793A\u4F8B: "error", "\u767B\u5F55", "function\\s+\\w+"'},query:{type:"string",description:"pattern \u7684\u522B\u540D"},keywords:{type:"array",items:{type:"string"},description:"\u591A\u5173\u952E\u8BCD OR \u641C\u7D22 (\u5B57\u9762\u91CF\u5339\u914D)"},queries:{type:"array",items:{type:"object",properties:{pattern:{type:"string"},op:{type:"string",enum:["and","or","not"]},regex:{type:"boolean"},case_insensitive:{type:"boolean"}},required:["pattern"]},description:"\u9AD8\u7EA7\u591A\u67E5\u8BE2 (\u652F\u6301 and/or/not)"},op:{type:"string",enum:["and","or","not"],description:"pattern \u7684\u903B\u8F91\u64CD\u4F5C (\u9ED8\u8BA4 or)"},mode:{type:"string",enum:["content","files"],description:"\u641C\u7D22\u6A21\u5F0F: \u5185\u5BB9\u641C\u7D22\u6216\u6587\u4EF6\u540D\u641C\u7D22 (\u9ED8\u8BA4: content)"},path:{type:"string",description:"\u641C\u7D22\u8DEF\u5F84 (\u53EF\u9009\uFF0C\u9ED8\u8BA4: \u5F53\u524D\u5DE5\u4F5C\u76EE\u5F55)"},recursive:{type:"boolean",description:"\u9012\u5F52\u5B50\u76EE\u5F55 (\u53EF\u9009\uFF0C\u76EE\u5F55\u9ED8\u8BA4 true\uFF0C\u6587\u4EF6\u9ED8\u8BA4 false)"},file_pattern:{type:"string",description:'\u6587\u4EF6\u7C7B\u578B\u8FC7\u6EE4 (e.g., "*.ts", "*.{js,jsx,ts,tsx}")'},include_hidden:{type:"boolean",description:"\u5305\u542B\u9690\u85CF\u6587\u4EF6 (\u9ED8\u8BA4: false)"},case_insensitive:{type:"boolean",description:"\u5FFD\u7565\u5927\u5C0F\u5199 (\u9ED8\u8BA4: true)"},context_lines:{type:"number",description:"\u4E0A\u4E0B\u6587\u884C\u6570 (\u9ED8\u8BA4: 2)"},max_matches:{type:"number",description:"\u6700\u5927\u5339\u914D\u6570 (\u9ED8\u8BA4: 200)"},count_only:{type:"boolean",description:"\u4EC5\u8FD4\u56DE\u8BA1\u6570 (\u5FEB\u901F\u4E86\u89E3\u5339\u914D\u5206\u5E03)"}}},async function({pattern:r,query:e,keywords:t,queries:s,op:n,mode:i="content",path:o,recursive:a,file_pattern:l,include_hidden:c=false,case_insensitive:u=true,context_lines:p=2,max_matches:d=200,count_only:m=false},h){try{let g=Date.now();we.debug("SEARCH",`>>> searchTool.execute START, pattern=${r||e||t?.join(",")}`);let y=h?.signal,b=()=>{if(y?.aborted){let O=new Error("Operation cancelled");throw O.name="AbortError",O}},w=200,S=async()=>{await new Promise(O=>setImmediate(O));},R=De(o||"."),$="workspace",G=qe();if(o&&X__default.isAbsolute(o))$="absolute";else if(o&&!Ce__default.existsSync(R)){let O=G,K=null;for(;;){let L=X__default.resolve(O,o);if(Ce__default.existsSync(L)){K=L;break}let z=X__default.dirname(O);if(z===O)break;O=z;}K&&(R=K,$="ancestor");}let U=Ee(R);b();let T;try{T=await Z__default.stat(R);}catch(O){return JSON.stringify(he("search","error",`search failed: ${O.message}`,void 0,{error:O.message}))}let C=T.isDirectory(),_=a!==void 0?a:C,k=cg({pattern:r,query:e,keywords:t,queries:s,op:n,case_insensitive:u});if(b(),k.length===0)return JSON.stringify(he("search","error","search failed: no query provided",void 0,{error:"Provide pattern/keywords/queries"}));let D=k.filter(O=>O.op!=="not"),N=k.filter(O=>O.op==="and"),E=k.filter(O=>O.op==="or"),A=k.filter(O=>O.op==="not");if(D.length===0)return JSON.stringify(he("search","error","search failed: only NOT queries provided",void 0,{error:"At least one non-NOT query is required"}));let F=k.filter(O=>O.regex).map(O=>{try{return new RegExp(O.pattern),null}catch(K){return `${O.pattern}: ${K.message}`}}).filter(O=>!!O);if(F.length>0)return JSON.stringify(he("search","error",`search failed: invalid regex (${F[0]})`,void 0,{error:`Invalid regex: ${F.join("; ")}`}));let H=[];E.length>0&&H.push(E.map(O=>O.pattern).join(" OR ")),N.length>0&&H.push(`AND ${N.map(O=>O.pattern).join(" + ")}`),A.length>0&&H.push(`NOT ${A.map(O=>O.pattern).join(" + ")}`);let M=H.join(" ");we.debug("SEARCH",`>>> Before isRipgrepAvailable, elapsed=${Date.now()-g}ms`);let ee=await lg();we.debug("SEARCH",`<<< After isRipgrepAvailable, elapsed=${Date.now()-g}ms`);let P=Math.min(200,Math.max(80,p*4+40));if(we.info("SEARCH",`Strategy: ${ee?"ripgrep":"fallback"}`),!ee)return JSON.stringify(he("search","error","search failed: ripgrep not available",`Ripgrep is required for search. This is unexpected since ripgrep should be bundled.
|
|
1023
|
+
Please report this issue.`,{error:"ripgrep not available"}));if(b(),i==="files"){let O=await(async()=>{if(!C)return [Ee(R)];if(ee){let pe=await Uo();if(!pe)throw new Error("ripgrep not available (this should not happen)");let ke=["--files"];c&&ke.push("--hidden"),!_&&C&&ke.push("--max-depth","1"),l&&ke.push("-g",l),Fo.forEach(it=>ke.push("-g",it)),ke.push("--",R);let Qe=await Ue(pe,ke,qe(),{signal:y});if(Qe.exitCode!==0&&Qe.exitCode!==1)throw new Error(Qe.stderr||"rg files search failed");return Qe.stdout.split(`
|
|
1024
|
+
`).filter(Boolean).map(it=>{let zs=X__default.isAbsolute(it)?X__default.resolve(it):X__default.resolve(qe(),it);return Ee(zs)})}let te=l||"**/*",Ke=_?te:te.replace("**/","");return (await Sc(Ke,{cwd:R,absolute:!0,dot:c,onlyFiles:!0,ignore:Fo.map(pe=>pe.replace("!",""))})).map(pe=>Ee(pe))})();b();let K=k.map(te=>{let Ke=te.regex?te.pattern:gc(te.pattern),Se=te.caseInsensitive?"i":"";return {query:te,regex:new RegExp(Ke,Se)}}),L=[],z=0;for(let te of O){b();let Ke=te,Se=K.map(ve=>({op:ve.query.op,hit:ve.regex.test(Ke)})),pe=Se.some(ve=>ve.op==="or"&&ve.hit),ke=Se.filter(ve=>ve.op==="and").every(ve=>ve.hit);!Se.some(ve=>ve.op==="not"&&ve.hit)&&(N.length===0||ke)&&(E.length===0||pe)&&L.push(te),z++,z%w===0&&await S();}let ue=[`\u2713 \u6587\u4EF6\u641C\u7D22: ${M}`,`\u25B8 \u8DEF\u5F84: ${U}${_?" (\u9012\u5F52)":""}${$==="ancestor"?" (auto-resolved)":""}`,l?`\u25B8 \u6587\u4EF6\u8FC7\u6EE4: ${l}`:"",c?"\u25B8 \u5305\u542B\u9690\u85CF\u6587\u4EF6":"","",`\u627E\u5230 ${L.length} \u4E2A\u6587\u4EF6`,""].filter(te=>te!==""),re=50;return L.slice(0,re).forEach(te=>ue.push(` ${te}`)),L.length>re&&ue.push(` ... \u8FD8\u6709 ${L.length-re} \u4E2A\u6587\u4EF6`),JSON.stringify(he("search","success",L.length>0?`search files "${M}" (${L.length} files)`:`search files "${M}" (no matches)`,ue.join(`
|
|
1025
|
+
`),{metadata:{mode:"files",strategy:ee?"rg":"glob",regex:k.some(te=>te.regex),case_insensitive:u,path:U,resolved_from:$,files:L,queries:k}}))}let q=new Map,B=new Map,j=0,Y=A.map(O=>{let K=O.regex?O.pattern:gc(O.pattern),L=O.caseInsensitive?"i":"";return new RegExp(K,L)}),ae=[];if(ee){let O=await Uo();if(!O)throw new Error("ripgrep not available (this should not happen)");for(let K of D){b();let L=["--json","--with-filename","--line-number","--column","-a"];L.push("-C",String(p)),K.caseInsensitive&&L.push("-i"),K.regex||L.push("-F"),c&&L.push("--hidden"),!_&&C&&L.push("--max-depth","1"),l&&L.push("-g",l),Fo.forEach(Se=>L.push("-g",Se)),L.push("--",K.pattern,R);let z=`${O} ${L.join(" ")}`;ae.push(z);let ue="",re=0,te="";try{let Se=await Ue(O,L,qe(),{signal:y});ue=Se.stdout,te=Se.stderr||"",re=Se.exitCode;}catch(Se){if(Se?.name==="AbortError"||y?.aborted)throw Se;te=Se?.message||Se?.stderr||String(Se),re=Se?.exitCode||2;}if(re!==0&&re!==1){let Se=te?`
|
|
1026
|
+
Error: ${te}`:"",pe=`
|
|
1027
|
+
Command: ${O} ${L.join(" ")}`;throw new Error(`ripgrep failed (exit code ${re})${Se}${pe}`)}let Ke=0;for(let Se of ue.split(`
|
|
1028
|
+
`)){if(b(),Ke++,Ke%w===0&&await S(),!Se.trim())continue;let pe;try{pe=JSON.parse(Se);}catch{continue}if(pe.type==="summary"){let ls=pe.data?.stats;ls&&typeof ls.searches=="number"&&(j=Math.max(j,ls.searches));continue}let ke=pe.type==="match",Qe=pe.type==="context";if(!ke&&!Qe)continue;let ve=pe.data,it=ve?.path?.text,zs=ve?.line_number,ma=ve?.lines?.text,ha=Array.isArray(ve?.submatches)?ve.submatches[0]:void 0;if(!it||!zs||typeof ma!="string")continue;let ga=ma.replace(/\n$/,""),Si=q.get(it)||new Map,qs=Si.get(zs)||{line:ga,queryIds:new Set};if(qs.line=ga,ke){qs.queryIds.add(K.id),qs.column===void 0&&ha?.start!==void 0&&(qs.column=ha.start+1);let ls=B.get(it)||new Set;ls.add(K.id),B.set(it,ls);}Si.set(zs,qs),q.set(it,Si);}}}let _e=new Set(N.map(O=>O.id)),Pe=[],ne=0,le=0,be=0,W=[],ie=[],Q=0;for(let[O,K]of q.entries()){if(b(),ne>=d&&!m)break;Q++,Q%w===0&&await S();let L=B.get(O)||new Set,z=!0;if(_e.forEach(pe=>{L.has(pe)||(z=!1);}),!z)continue;let re=Array.from(K.keys()).sort((pe,ke)=>pe-ke).filter(pe=>{let ke=K.get(pe);return ke?!Y.some(Qe=>Qe.test(ke.line)):!1});if(re.length===0)continue;le++,ne+=re.length;let te=Ee(O);if(W.push({file:te,anchor_lines:re.slice(0,20),num_lines:P}),m){Pe.push({file:O,matches:[],matchCount:re.length});continue}b();let Ke=[];Array.from(K.keys()).sort((pe,ke)=>pe-ke).forEach(pe=>{let ke=K.get(pe);if(!ke)return;let Qe=re.includes(pe);if(Ke.push({lineNum:pe,line:ke.line,isMatch:Qe}),Qe&&ie.length<d){for(let ve of ke.queryIds)if(ie.push({file:te,line:pe,column:ke.column,preview:ke.line,queryId:ve}),ie.length>=d)break}}),Pe.push({file:O,matches:Ke,matchCount:re.length});}Pe.sort((O,K)=>Ee(O.file).localeCompare(Ee(K.file)));let v=O=>{let L=Ee(O).split(X__default.sep),z=L.findIndex(ue=>["src","lib","app","core","packages"].includes(ue));return z>=0&&z+1<L.length?L[z+1]:L[0]||"root"},I=[`\u2713 \u641C\u7D22: ${M}`,`\u25B8 \u8DEF\u5F84: ${U}${_?" (\u9012\u5F52)":""}${$==="ancestor"?" (auto-resolved)":""}`,l?`\u25B8 \u6587\u4EF6\u8FC7\u6EE4: ${l}`:"",u?"\u25B8 \u6A21\u5F0F: \u5FFD\u7565\u5927\u5C0F\u5199":"",ee?"\u25B8 \u7B56\u7565: ripgrep":"\u25B8 \u7B56\u7565: fallback","","\u2501\u2501\u2501\u2501 \u7ED3\u679C\u6458\u8981 \u2501\u2501\u2501\u2501",j>0?`\u6587\u4EF6: ${j} \u5DF2\u641C\u7D22, ${le} \u6709\u5339\u914D`:`\u6587\u4EF6: ${le} \u6709\u5339\u914D`,`\u5339\u914D: ${ne}${ne>=d?" (\u5DF2\u8FBE\u4E0A\u9650)":""}`].filter(O=>O!==""),J=new Map,ye=0;for(let O of Pe){ye++,ye%w===0&&await S();let K=v(O.file);J.set(K,(J.get(K)||0)+O.matchCount);}if(J.size>1){I.push(""),I.push("\u{1F4E6} \u6A21\u5757\u5206\u5E03:");let O=Array.from(J.entries()).sort((K,L)=>L[1]-K[1]);for(let[K,L]of O.slice(0,5))I.push(` ${K}: ${L}`);O.length>5&&I.push(` ... \u8FD8\u6709 ${O.length-5} \u4E2A\u6A21\u5757`);}if(I.push(""),m){I.push("\u{1F4CB} \u6587\u4EF6\u5217\u8868:");let O=0;for(let K of Pe){O++,O%w===0&&await S();let L=Ee(K.file),z=v(K.file);I.push(` [${z}] ${L}: ${K.matchCount}`);}}else {let O=0,K=100;for(let L of Pe){if(b(),be>=d){I.push(`
|
|
1029
|
+
... \u8FD8\u6709\u66F4\u591A\u5339\u914D (\u5DF2\u8FBE ${d} \u4E0A\u9650)`);break}let z=Ee(L.file),ue=v(L.file);I.push(`
|
|
1030
|
+
\u25B8 [${ue}] ${z} (${L.matchCount} \u5904)`),I.push("\u2500".repeat(50));let re=-10;for(let te of L.matches){if(be>=d)break;O++,O%K===0&&await S(),te.lineNum>re+1&&re>0&&I.push(" \u2504\u2504\u2504");let Ke=te.isMatch?"\u25B6":" ";I.push(`${Ke}${String(te.lineNum).padStart(5)} \u2502 ${te.line}`),re=te.lineNum,te.isMatch&&be++;}}}return Pe.length===0?(I.push("\u672A\u627E\u5230\u5339\u914D\u5185\u5BB9"),I.push(""),I.push("\u{1F4A1} \u5EFA\u8BAE:"),I.push(" - \u5C1D\u8BD5 case_insensitive: true"),I.push(" - \u5C1D\u8BD5 recursive: true \u641C\u7D22\u5B50\u76EE\u5F55"),I.push(" - \u4F7F\u7528 keywords \u6216 queries \u7EC4\u5408\u641C\u7D22"),I.push(' - \u67E5\u6587\u4EF6\u540D\u8BF7\u7528 mode="files"')):W.length>0&&(I.push(""),I.push("\u{1F4A1} \u6279\u91CF\u8BFB\u53D6:"),W.slice(0,3).forEach(O=>{I.push(` readfile(path="${O.file}", anchor_lines=[${O.anchor_lines.join(",")}], num_lines=${O.num_lines})`);})),JSON.stringify(he("search","success",Pe.length>0?`search "${M}" (${ne} matches)`:`search "${M}" (no matches)`,I.join(`
|
|
1031
|
+
`),{metadata:{mode:"content",strategy:ee?"rg":"fallback",regex:k.some(O=>O.regex),case_insensitive:u,path:U,resolved_from:$,queries:k,matches:ie,read_hints:W,files_with_matches:le,command:ae.length>0?ae[0]:void 0}}))}catch(g){return JSON.stringify(he("search","error",`search failed: ${g.message}`,void 0,{error:g.message}))}}},pg={name:Gr.name,description:Gr.description,parameters:Gr.parameters,permission:{category:"read",allowInAskMode:true},async function(r){return uc(r)}},dg={name:"use_skill",description:`Execute a registered skill to get specialized instructions for a task.
|
|
1032
1032
|
|
|
1033
1033
|
Skills are pre-defined instruction sets for common tasks like:
|
|
1034
1034
|
- commit: Git commit workflow with best practices
|
|
@@ -1036,28 +1036,28 @@ Skills are pre-defined instruction sets for common tasks like:
|
|
|
1036
1036
|
|
|
1037
1037
|
When you recognize a user's intent matches a skill, call this tool to get the detailed instructions, then follow them to complete the task.
|
|
1038
1038
|
|
|
1039
|
-
Example: User says "\u5E2E\u6211\u63D0\u4EA4\u4EE3\u7801" \u2192 call use_skill(skill="commit")`,parameters:{type:"object",properties:{skill:{type:"string",description:'Skill name or alias (e.g., "commit", "review")'},args:{type:"string",description:'Optional arguments to pass to the skill (e.g., "-m \\"commit message\\"")'}},required:["skill"]},permission:{category:"read",allowInAskMode:true},async function(r){let{skill:e,args:t=""}=r,s=process.env[
|
|
1039
|
+
Example: User says "\u5E2E\u6211\u63D0\u4EA4\u4EE3\u7801" \u2192 call use_skill(skill="commit")`,parameters:{type:"object",properties:{skill:{type:"string",description:'Skill name or alias (e.g., "commit", "review")'},args:{type:"string",description:'Optional arguments to pass to the skill (e.g., "-m \\"commit message\\"")'}},required:["skill"]},permission:{category:"read",allowInAskMode:true},async function(r){let{skill:e,args:t=""}=r,s=process.env[kc]||process.cwd();await Zt.initialize(s);let n=Zt.find(e);if(!n){let l=Zt.list({userInvocable:true}).map(c=>c.id).join(", ");return `\u274C Skill not found: "${e}"
|
|
1040
1040
|
|
|
1041
1041
|
Available skills: ${l||"(none)"}
|
|
1042
1042
|
|
|
1043
|
-
To list all skills, use the /skills command.`}let o=await new
|
|
1043
|
+
To list all skills, use the /skills command.`}let o=await new Br(Zt).execute(e,t,{workDir:s,args:t,rawInput:`/${e} ${t}`.trim()});return o.success?`\u2705 Skill "${n.metadata.name}" loaded successfully.
|
|
1044
1044
|
|
|
1045
1045
|
\u{1F4CB} **Follow these instructions carefully:**
|
|
1046
1046
|
|
|
1047
1047
|
${o.output}
|
|
1048
1048
|
|
|
1049
1049
|
---
|
|
1050
|
-
\u26A0\uFE0F IMPORTANT: Now execute the above instructions step by step. Do not ask for confirmation unless the instructions explicitly require it.`:`\u274C Skill execution failed: ${o.error}`}},
|
|
1051
|
-
`+p.detail);}let u=a||
|
|
1052
|
-
`+u.detail);}return new he({category:"retryable_http",code:`HTTP_${o}`,message:c,retryable:true,retryAfter:a,context:{httpStatus:o,requestId:l,rawMessage:i},originalError:t})}if(o===401)return new he({category:"fatal_auth",code:"UNAUTHORIZED",message:i||"Authentication failed. Please check your API key.",retryable:false,context:{httpStatus:o,requestId:l},originalError:t});if(o===403)return new he({category:"fatal_auth",code:"FORBIDDEN",message:i||"Access denied. Please check your API permissions.",retryable:false,context:{httpStatus:o,requestId:l},originalError:t});if(o===400)return Sc(e)?new he({category:"fatal_context",code:"CONTEXT_WINDOW_EXCEEDED",message:"Context window exceeded. Please start a new conversation or clear history.",retryable:false,context:{httpStatus:o,requestId:l},originalError:t}):i.includes("Upstream request failed")||i.includes("upstream")||i.includes("gateway")?new he({category:"retryable_http",code:"PROXY_UPSTREAM_FAILED",message:i||"Proxy upstream request failed",retryable:true,context:{httpStatus:o,requestId:l},originalError:t}):new he({category:"fatal_invalid",code:"INVALID_REQUEST",message:i,retryable:false,context:{httpStatus:o,requestId:l},originalError:t});if(o>=400&&o<500)return new he({category:"fatal_invalid",code:`HTTP_${o}`,message:i,retryable:false,context:{httpStatus:o,requestId:l},originalError:t})}if(Uo(r)){let o=r.code,a=r.name;if(o==="ERR_CANCELED"||a==="CanceledError"||a==="AbortError")return new he({category:"canceled",code:"CANCELED",message:"Request was canceled",retryable:false,originalError:t});if(o==="ECONNREFUSED"||o==="ENOTFOUND"||o==="ECONNRESET")return new he({category:"retryable_network",code:o,message:`Network error: ${e}`,retryable:true,originalError:t});if(o==="ETIMEDOUT"||o==="ESOCKETTIMEDOUT")return new he({category:"retryable_network",code:"TIMEOUT",message:`Connection timeout: ${e}`,retryable:true,originalError:t})}return r instanceof Error&&r.name==="AbortError"?new he({category:"canceled",code:"CANCELED",message:"Request was canceled",retryable:false,originalError:r}):Uo(r)&&r.code==="STREAM_INCOMPLETE"?new he({category:"retryable_stream",code:"STREAM_INCOMPLETE",message:`\u7F51\u7EDC\u4E2D\u65AD: ${e}`,retryable:true,context:{toolName:r.toolName,rawMessage:e},originalError:t}):r?.code==="STREAM_TIMEOUT"?new he({category:"retryable_stream",code:"STREAM_TIMEOUT",message:`API \u4EE3\u7406\u54CD\u5E94\u8D85\u65F6: ${e}`,retryable:true,context:{rawMessage:e},originalError:t}):e.includes("stream")||e.includes("Stream")||e.includes("SSE")||e.includes("disconnected")||e.includes("incomplete")||e.includes("message_stop")?new he({category:"retryable_stream",code:"STREAM_ERROR",message:`\u7F51\u7EDC\u4E2D\u65AD: ${e}`,retryable:true,originalError:t}):Sc(e)?new he({category:"fatal_context",code:"CONTEXT_WINDOW_EXCEEDED",message:"Context window exceeded. Please start a new conversation or clear history.",retryable:false,originalError:t}):pg(e)?new he({category:"fatal_limit",code:"QUOTA_EXCEEDED",message:e,retryable:false,originalError:t}):new he({category:"internal",code:"UNKNOWN",message:e,retryable:false,originalError:t})}function kc(r,e,t){let s=e||"";return s.trim().endsWith("}")?(r==="write_file"||r==="edit_file")&&!s.includes('"content"')?new he({category:"tool_truncated",code:"TOOL_MISSING_CONTENT",message:"The content field is missing (likely truncated)",retryable:false,context:{toolName:r,receivedLength:s.length,rawMessage:t.message},originalError:t}):t.message.includes("JSON")||t.message.includes("Unexpected")||t.message.includes("parse")?new he({category:"tool_json_invalid",code:"JSON_PARSE_ERROR",message:`Invalid JSON in tool arguments: ${t.message}`,retryable:true,context:{toolName:r,receivedLength:s.length,rawMessage:t.message},originalError:t}):new he({category:"tool_json_invalid",code:"TOOL_ERROR",message:t.message,retryable:true,context:{toolName:r},originalError:t}):new he({category:"tool_truncated",code:"TOOL_ARGS_TRUNCATED",message:"Tool arguments were truncated during streaming",retryable:false,context:{toolName:r,receivedLength:s.length,rawMessage:t.message},originalError:t})}function Hr(r){switch(r.category){case "retryable_rate_limit":return `API \u4EE3\u7406\u901F\u7387\u9650\u5236\uFF0C${r.retryAfter?Math.ceil(r.retryAfter/1e3):3} \u79D2\u540E\u81EA\u52A8\u91CD\u8BD5...`;case "retryable_http":return "The request will be automatically retried.";case "retryable_stream":return "\u7F51\u7EDC\u8FDE\u63A5\u4E2D\u65AD\uFF0C\u6B63\u5728\u81EA\u52A8\u91CD\u8FDE...";case "retryable_network":return "\u7F51\u7EDC\u8FDE\u63A5\u5F02\u5E38\uFF0C\u6B63\u5728\u81EA\u52A8\u91CD\u8BD5...";case "fatal_auth":return "Please check your API key and ensure it has the necessary permissions.";case "fatal_limit":return "You have reached your usage limit. Please check your billing settings or wait for the limit to reset.";case "fatal_context":return "The conversation is too long. Please start a new conversation or use /compact to summarize history.";case "fatal_invalid":return "Please check your request parameters and try again.";case "tool_truncated":return "The tool call was truncated. Please use edit_file with smaller, targeted changes instead of rewriting entire files.";case "tool_json_invalid":return "The tool arguments were invalid. The LLM will retry with corrected parameters.";case "tool_timeout":return "The tool execution timed out. Please try again with a smaller operation.";case "tool_denied":return "The tool call was denied. You can manually approve or adjust permissions.";default:return "An unexpected error occurred. Please try again."}}var Et={requestMaxRetries:10,streamMaxRetries:5,toolMaxRetries:2,initialDelayMs:1e3,backoffFactor:2,maxDelayMs:3e4,jitterRange:.2,streamIdleTimeoutMs:3e5};function Nt(r,e){return {...Et,...r,...e?.requestMaxRetries!==void 0&&{requestMaxRetries:e.requestMaxRetries},...e?.streamMaxRetries!==void 0&&{streamMaxRetries:e.streamMaxRetries},...e?.streamIdleTimeoutMs!==void 0&&{streamIdleTimeoutMs:e.streamIdleTimeoutMs}}}var $t={openai:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:3e5},anthropic:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:3e5},yunwu:{requestMaxRetries:3,streamMaxRetries:10,streamIdleTimeoutMs:9e4},azure:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:6e5},proxy:{requestMaxRetries:10,streamMaxRetries:10,streamIdleTimeoutMs:18e4},gemini:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:3e5}};function Os(r,e){let t=r.toLowerCase();if(t.includes("yunwu"))return $t.yunwu;if(t.includes("azure"))return $t.azure;if(e){let s=e.toLowerCase();if(s.includes("yunwu"))return $t.yunwu;if(s.includes("azure"))return $t.azure;if(!(s.includes("api.anthropic.com")||s.includes("api.openai.com")))return $t.proxy}return t.includes("anthropic")?$t.anthropic:t.includes("gemini")?$t.gemini:$t.openai}var vc=100,xc=200,Tc=1800*1e3;var Pn=class extends Error{constructor(e){super(e),this.name="GuardrailTripwireTriggered";}},Ls=class extends Pn{guardrail_result;constructor(e){let t=`Input guardrail "${e.guardrail.name}" triggered: ${e.output.output_info?.reason||"Safety check failed"}`;super(t),this.name="InputGuardrailTripwireTriggered",this.guardrail_result=e;}getDetails(){return {guardrail_name:this.guardrail_result.guardrail.name,execution_time_ms:this.guardrail_result.execution_time_ms,output_info:this.guardrail_result.output.output_info}}},Ds=class extends Pn{guardrail_result;blocked_output;constructor(e){let t=`Output guardrail "${e.guardrail.name}" triggered: ${e.output.output_info?.reason||"Output safety check failed"}`;super(t),this.name="OutputGuardrailTripwireTriggered",this.guardrail_result=e,this.blocked_output=e.agent_output;}getDetails(){return {guardrail_name:this.guardrail_result.guardrail.name,execution_time_ms:this.guardrail_result.execution_time_ms,output_info:this.guardrail_result.output.output_info,blocked_output:this.blocked_output}}},rt=class extends Pn{guardrail_result;constructor(e){let t=`Tool guardrail "${e.guardrail.name}" triggered: ${e.output.output_info?.reason||"Tool safety check failed"}`;super(t),this.name="ToolGuardrailTripwireTriggered",this.guardrail_result=e;}getDetails(){return {guardrail_name:this.guardrail_result.guardrail.name,execution_time_ms:this.guardrail_result.execution_time_ms,output_info:this.guardrail_result.output.output_info,behavior:this.guardrail_result.output.behavior}}};var ss=class{static async runInputGuardrails(e,t,s,n){if(e.length===0)return [];let i=e.map(async o=>{let a=Date.now();try{let l=await o.guardrail_function(t,s,n),c={guardrail:o,output:l,execution_time_ms:Date.now()-a};if(l.tripwire_triggered)throw new Ls(c);return c}catch(l){if(l instanceof Ls)throw l;let c={guardrail:o,output:{tripwire_triggered:true,output_info:{error:l instanceof Error?l.message:String(l),reason:"Guardrail execution failed"}},execution_time_ms:Date.now()-a};throw new Ls(c)}});return await Promise.all(i)}static async runOutputGuardrails(e,t,s,n){if(e.length===0)return [];let i=e.map(async o=>{let a=Date.now();try{let l=await o.guardrail_function(t,s,n),c={guardrail:o,agent_output:n,output:l,execution_time_ms:Date.now()-a};if(l.tripwire_triggered)throw new Ds(c);return c}catch(l){if(l instanceof Ds)throw l;let c={guardrail:o,agent_output:n,output:{tripwire_triggered:true,output_info:{error:l instanceof Error?l.message:String(l),reason:"Guardrail execution failed"}},execution_time_ms:Date.now()-a};throw new Ds(c)}});return await Promise.all(i)}static async runToolInputGuardrails(e,t){let s=[];for(let n of e){let i=Date.now();try{let o=await n.guardrail_function(t),a={guardrail:n,output:o,execution_time_ms:Date.now()-i};if(s.push(a),o.behavior.type==="raise_exception")throw new rt(a);if(o.behavior.type==="reject_content")return {results:s,should_execute:!1,rejection_message:o.behavior.message}}catch(o){if(o instanceof rt)throw o;let a={guardrail:n,output:{output_info:{error:o instanceof Error?o.message:String(o)},behavior:{type:"raise_exception"}},execution_time_ms:Date.now()-i};throw new rt(a)}}return {results:s,should_execute:true}}static async runToolOutputGuardrails(e,t){let s=[];for(let n of e){let i=Date.now();try{let o=await n.guardrail_function(t),a={guardrail:n,output:o,execution_time_ms:Date.now()-i};if(s.push(a),o.behavior.type==="raise_exception")throw new rt(a);if(o.behavior.type==="reject_content")return {results:s,should_use_output:!1,replacement_message:o.behavior.message}}catch(o){if(o instanceof rt)throw o;let a={guardrail:n,output:{output_info:{error:o instanceof Error?o.message:String(o)},behavior:{type:"raise_exception"}},execution_time_ms:Date.now()-i};throw new rt(a)}}return {results:s,should_use_output:true}}};var Cc=null,Rc=false;function On(){if(!Rc&&(Rc=true,typeof process<"u"&&process.env&&!process.env.NEOX_UI_MODE))try{Promise.resolve().then(()=>(de(),ga)).then(r=>{Cc=r.cliLogger;}).catch(()=>{});}catch{}return Cc}var Ec=new WeakMap,jo=null;function Ic(){return {writtenFiles:new Map,editedFiles:new Map,editDetails:new Map,fileReadCache:new Map,toolCallHistory:[],createdAt:Date.now()}}function Mc(r){if(r){let e=Ec.get(r);return e?process.env.CLI_DEBUG==="1"&&On()?.debug("SESSION",`Retrieved EXISTING SessionState for context: ${Object.keys(r).join(",")}, history: ${e.toolCallHistory.length}`):(e=Ic(),Ec.set(r,e),process.env.CLI_DEBUG==="1"&&On()?.debug("SESSION",`Created NEW SessionState for context: ${Object.keys(r).join(",")}`)),e}return jo||(jo=Ic()),jo}function Go(r,e,t,s){let n=Mc(r);if(process.env.CLI_DEBUG==="1"){let i=On();i?.debug("SESSION","recordToolCall called:"),i?.debug("SESSION",` - tool: ${e}`),i?.debug("SESSION",` - success: ${s}`),i?.debug("SESSION",` - context exists: ${!!r}`),i?.debug("SESSION",` - context identity: ${r?Object.keys(r).join(","):"none"}`),i?.debug("SESSION",` - history length before: ${n.toolCallHistory.length}`);}n.toolCallHistory.push({name:e,args:t,timestamp:Date.now(),success:s}),process.env.CLI_DEBUG==="1"&&On()?.debug("SESSION",` - history length after: ${n.toolCallHistory.length}`),n.toolCallHistory.length>100&&n.toolCallHistory.shift();}function Ac(r,e=10){let t=Mc(r);if(process.env.CLI_DEBUG==="1"){let s=On();s?.debug("SESSION","getRecentToolCalls called:"),s?.debug("SESSION",` - context exists: ${!!r}`),s?.debug("SESSION",` - context identity: ${r?Object.keys(r).join(","):"none"}`),s?.debug("SESSION",` - total history length: ${t.toolCallHistory.length}`),s?.debug("SESSION",` - limit: ${e}`),s?.debug("SESSION",` - returning ${Math.min(t.toolCallHistory.length,e)} calls`);}return t.toolCallHistory.slice(-e)}var fg=fileURLToPath(import.meta.url),Wo=dirname(fg),Ho=class{logDir;enabled;consoleEnabled;constructor(){this.logDir=this.getLogDirectory(),this.enabled=process.env.MARKOR_TRACING==="1",this.consoleEnabled=process.env.CLI_DEBUG_CONSOLE==="1";try{this.initLogDir(),this.consoleEnabled&&console.log("[Logger] Initialized at:",this.logDir);}catch(e){console.error("[Logger] Failed to initialize:",e.message),this.enabled=false;}}setEnabled(e){this.enabled=e;}getLogDirectory(){if(Wo.includes(".asar")||Wo.includes("app.asar")){try{if(typeof process<"u"&&process.type==="browser"){let e=process.env.ELECTRON_USER_DATA;if(e)return Y__default.join(e,"logs")}}catch{}return Y__default.join(qs__default.tmpdir(),"neox-logs")}return Y__default.join(Wo,"../../logs")}initLogDir(){try{xe__default.existsSync(this.logDir)||xe__default.mkdirSync(this.logDir,{recursive:!0});}catch(e){let t=e;t.code==="EACCES"||t.code==="EPERM"?this.enabled=false:(console.warn(`[Logger] Warning: Cannot create log directory: ${t.message}`),this.enabled=false);}}getLogFile(e){let t=new Date().toISOString().split("T")[0];return Y__default.join(this.logDir,`${e}-${t}.log`)}write(e,t){if(!this.enabled)return;let s=new Date().toISOString(),n=typeof t=="string"?{message:t}:t||{},i=this.safeStringify({timestamp:s,...n})+`
|
|
1053
|
-
`;if(this.enabled)try{let o=this.getLogFile(e);
|
|
1054
|
-
`)}return t}var
|
|
1050
|
+
\u26A0\uFE0F IMPORTANT: Now execute the above instructions step by step. Do not ask for confirmation unless the instructions explicitly require it.`:`\u274C Skill execution failed: ${o.error}`}},Tc=[Dh,jh,Hh,zh,qh,Gh,Bh,Wh,Yh,Xh,Zh,Qh,eg,tg,rg,ig,og,Kh,Vh,Ua,ag,ug,Pi,Oi,Li,Ja,pg,dg];async function Go(r,e){e&&vc(e);let t=e?.capabilities??Le.capabilities,s=en(),n=[...Tc];if(r&&n.push(Ka(r)),s.webSearch?.enabled&&n.push(Ki),s.javaDebug?.enabled)try{let c=await Zi(s.javaDebug?.jarPath);n.push(...c),we.info("TOOLS",`Java Debug \u5DE5\u5177\u5DF2\u542F\u7528 (${c.length} \u4E2A\u5DE5\u5177)`);}catch(c){we.error("TOOLS",`Java Debug \u5DE5\u5177\u52A0\u8F7D\u5931\u8D25: ${c.message}`),we.error("TOOLS","\u63D0\u793A: \u8FD0\u884C npm run setup-java-debug \u81EA\u52A8\u4E0B\u8F7D JAR \u6587\u4EF6");}if(s.smartRead?.enabled!==false)try{let c=Eo(r);n.push(...c),we.info("TOOLS",`readfile \u5DE5\u5177\u5DF2\u542F\u7528 (${c.length} \u4E2A\u5DE5\u5177)`);}catch(c){we.error("TOOLS",`readfile \u5DE5\u5177\u52A0\u8F7D\u5931\u8D25: ${c.message}`);}let i=typeof process<"u"&&process.type==="renderer";t?.terminal&&i&&n.push(...cr()),t?.editor&&i&&n.push(...ur());let o=Eh(n,t),a=s.enabledTools||{},l=o.filter(c=>a[c.name]!==false);return mc(l)}function zr(r){return {output_info:r,behavior:{type:"allow"}}}function xc(r,e){return {output_info:e,behavior:{type:"reject_content",message:r}}}function mg(r){let e=r.match(/Error\s+(?:code\s+)?(\d{3})/i);if(e)return e[1];let t=r.match(/(\d{3}):\s*([^<\n]+)/);return t?t[1]:null}function hg(r){let e=r.match(/<title>[^|]*\|\s*\d{3}:\s*([^<]+)<\/title>/i);if(e)return e[1].trim();let t=r.match(/<h1[^>]*>(?:<[^>]+>)*([^<]+?(?:\s+\d{3})?)<\/(?:[^>]+>)*<\/h1>/i);if(t)return t[1].replace(/Error code\s+\d{3}/i,"").trim();let s=r.match(/Error\s+code\s+(\d{3})/i);if(s){let i=s[1];return {502:"Bad gateway",503:"Service unavailable",504:"Gateway timeout",520:"Unknown error",521:"Web server is down",522:"Connection timed out",523:"Origin is unreachable",524:"A timeout occurred"}[i]||"Server error"}let n=r.match(/<span[^>]*class="inline-block"[^>]*>([^<]+)<\/span>/i);return n?n[1].trim():null}function gg(r){let e=r.match(/truncate[^>]*>([a-zA-Z0-9.-]+\.[a-zA-Z]{2,})<\/span>/);if(e)return e[1];let t=r.match(/<title>([a-zA-Z0-9.-]+\.[a-zA-Z]{2,})/);return t?t[1]:null}function Pn(r){return r.trim().startsWith("<!DOCTYPE html")||r.trim().startsWith("<html")||/<html[^>]*>/i.test(r)}function fg(r){let e=r.match(/^data:\s*(\{.*\})/m);return e?e[1]:null}function ts(r,e){let t=fg(r);if(t)try{let o=JSON.parse(t);if(o.error){let a=o.error,l=a.type||a.code||(e?`HTTP_${e}`:"API_ERROR"),c=a.message||"API error",u;if(a.type==="usage_limit_reached"){let p=a.resets_at?new Date(a.resets_at*1e3).toLocaleString():void 0,d=a.resets_in_seconds;if(d){let m=Math.floor(d/3600),h=Math.floor(d%3600/60);u=`Usage limit reached (${a.plan_type||"unknown"} plan). Resets in ${m}h ${h}m.`;}else p&&(u=`Usage limit reached (${a.plan_type||"unknown"} plan). Resets at ${p}.`);}return {code:l,message:c,detail:u}}}catch{}if(r.trim().startsWith("{"))try{let o=JSON.parse(r);if(o.error){let a=o.error;return {code:a.type||a.code||(e?`HTTP_${e}`:"API_ERROR"),message:a.message||"API error"}}}catch{}if(Pn(r)){let o=mg(r)||String(e||"UNKNOWN"),a=hg(r)||"Server error",l=gg(r),c;return l&&(l.includes("cloudflare")?c=`The server (${l}) is protected by Cloudflare but is not responding.`:c=`The API server (${l}) is not responding. This may be a temporary issue with your API provider.`),{code:`HTTP_${o}`,message:a,detail:c}}let s=r.match(/OpenAI.*error:\s*(\d+)\s*-\s*(.*)/i);if(s){let o=s[1],a=s[2];if(Pn(a)){let l=ts(a,parseInt(o,10));return {code:l.code,message:l.message,detail:l.detail}}return a=a.trim(),a.length>200&&(a=a.slice(0,200)+"..."),{code:`HTTP_${o}`,message:a}}let n=r.match(/Anthropic.*error:\s*(\d+)\s*-\s*(.*)/i);if(n){let o=n[1],a=n[2].trim();return a.length>200&&(a=a.slice(0,200)+"..."),{code:`HTTP_${o}`,message:a}}if(r.includes("ECONNREFUSED"))return {code:"NETWORK_ERROR",message:"Connection refused",detail:"Unable to connect to the API server. Please check your network connection."};if(r.includes("ETIMEDOUT")||r.includes("timeout"))return {code:"TIMEOUT",message:"Connection timeout",detail:"The request took too long to complete. Please try again."};if(r.includes("ENOTFOUND"))return {code:"DNS_ERROR",message:"Server not found",detail:"Could not resolve the API server address. Please check your API base URL."};if(/context.*window.*exceeded/i.test(r)||/maximum.*context.*length/i.test(r))return {code:"CONTEXT_EXCEEDED",message:"Context window exceeded",detail:"The conversation is too long. Please start a new session or use /compact."};if(/rate.*limit/i.test(r)||r.includes("429"))return {code:"RATE_LIMIT",message:"Rate limit exceeded",detail:"Too many requests. Please wait a moment before trying again."};if(r.includes("401")||/unauthorized/i.test(r))return {code:"AUTH_ERROR",message:"Authentication failed",detail:"Please check your API key in settings."};if(r.includes("403")||/forbidden/i.test(r))return {code:"FORBIDDEN",message:"Access denied",detail:"Your API key does not have permission for this operation."};let i=r;return i=i.replace(/^Error:\s*/i,""),i=i.replace(/^Request failed with status code\s+\d+:\s*/i,""),i.length>300&&(i=i.slice(0,300)+"..."),{code:e?`HTTP_${e}`:"UNKNOWN",message:i}}var ge=class r extends Error{category;code;retryable;retryAfter;context;originalError;constructor(e){super(e.message),this.name="NeoxError",this.category=e.category,this.code=e.code,this.retryable=e.retryable,this.retryAfter=e.retryAfter,this.context=e.context,this.originalError=e.originalError,Error.captureStackTrace&&Error.captureStackTrace(this,r);}withContext(e){return new r({...this,context:{...this.context,...e}})}toJSON(){return {name:this.name,category:this.category,code:this.code,message:this.message,retryable:this.retryable,retryAfter:this.retryAfter,context:this.context,stack:this.stack}}};function Rt(r){if(!r)return;if(typeof r!="string")return typeof r=="number"&&r>0?Math.ceil(r*1e3):void 0;let e=r.trim(),t=e.match(/^(\d+(?:\.\d+)?)\s*ms$/i);if(t){let i=parseFloat(t[1]);return i>0?Math.ceil(i):void 0}let s=parseFloat(e);if(!isNaN(s)&&s>0)return Math.ceil(s*1e3);let n=new Date(e);if(!isNaN(n.getTime())){let i=n.getTime()-Date.now();return i>0?Math.ceil(i):void 0}}function yg(r){switch(r){case 502:return 3e3;case 503:return 5e3;case 504:return 2e3;default:return 2e3}}function qr(r){if(!r)return;let e=r["retry-after"]||r["Retry-After"];if(e){let i=Rt(e);if(i)return i}let t=r["retry-after-ms"]||r["Retry-After-Ms"];if(t){let i=parseFloat(t);if(!isNaN(i)&&i>0)return Math.ceil(i)}let s=r["x-ratelimit-reset-requests"];if(s){let i=Rt(s);if(i)return i}let n=r["anthropic-ratelimit-requests-reset"];if(n){let i=new Date(n);if(!isNaN(i.getTime())){let o=i.getTime()-Date.now();return o>0?Math.ceil(o):void 0}}}function Bo(r){return typeof r=="object"&&r!==null&&"message"in r&&typeof r.message=="string"}function Cc(r){return [/context.*window.*exceeded/i,/context.*length.*exceeded/i,/maximum.*context.*length/i,/token.*limit.*exceeded/i,/input.*too.*long/i].some(t=>t.test(r))}function bg(r){return [/quota.*exceeded/i,/usage.*limit/i,/rate.*limit/i,/insufficient.*quota/i,/billing/i].some(t=>t.test(r))}function wg(r){if(r){if(typeof r=="string")return r;if(typeof r=="object"){if(typeof r.error=="string")return r.error;if(r.error?.message)return r.error.message;if(r.message)return r.message}}}function nt(r){if(r instanceof ge)return r;let e=r instanceof Error?r.message:String(r),t=r instanceof Error?r:void 0,s=Bo(r)?r:void 0,i=(s?wg(s.response?.data):void 0)||e;if(s?.response?.status){let o=s.response.status,a=qr(s.response.headers),l=s.response.headers?.["x-request-id"]||s.response.headers?.["cf-ray"];if(o===429){let c=s.response.data,u=c?.error?.type;return u==="usage_limit_reached"||u==="usage_not_included"?new ge({category:"fatal_limit",code:"USAGE_LIMIT_REACHED",message:c?.error?.message||"Usage limit reached",retryable:false,context:{httpStatus:o,requestId:l},originalError:t}):new ge({category:"retryable_http",code:`HTTP_${o}`,message:i,retryable:true,retryAfter:a,context:{httpStatus:o,requestId:l},originalError:t})}if(o===502||o===503||o===504){let c=i;if(Pn(i)){let p=ts(i,o);c=p.message,p.detail&&(c+=`
|
|
1051
|
+
`+p.detail);}let u=a||yg(o);return new ge({category:"retryable_rate_limit",code:`PROXY_${o}`,message:c||`API \u4EE3\u7406\u670D\u52A1\u6682\u65F6\u4E0D\u53EF\u7528 (${o})`,retryable:true,retryAfter:u,context:{httpStatus:o,requestId:l,rawMessage:i},originalError:t})}if(o>=500){let c=i;if(Pn(i)){let u=ts(i,o);c=u.message,u.detail&&(c+=`
|
|
1052
|
+
`+u.detail);}return new ge({category:"retryable_http",code:`HTTP_${o}`,message:c,retryable:true,retryAfter:a,context:{httpStatus:o,requestId:l,rawMessage:i},originalError:t})}if(o===401)return new ge({category:"fatal_auth",code:"UNAUTHORIZED",message:i||"Authentication failed. Please check your API key.",retryable:false,context:{httpStatus:o,requestId:l},originalError:t});if(o===403)return new ge({category:"fatal_auth",code:"FORBIDDEN",message:i||"Access denied. Please check your API permissions.",retryable:false,context:{httpStatus:o,requestId:l},originalError:t});if(o===400)return Cc(e)?new ge({category:"fatal_context",code:"CONTEXT_WINDOW_EXCEEDED",message:"Context window exceeded. Please start a new conversation or clear history.",retryable:false,context:{httpStatus:o,requestId:l},originalError:t}):i.includes("Upstream request failed")||i.includes("upstream")||i.includes("gateway")?new ge({category:"retryable_http",code:"PROXY_UPSTREAM_FAILED",message:i||"Proxy upstream request failed",retryable:true,context:{httpStatus:o,requestId:l},originalError:t}):new ge({category:"fatal_invalid",code:"INVALID_REQUEST",message:i,retryable:false,context:{httpStatus:o,requestId:l},originalError:t});if(o>=400&&o<500)return new ge({category:"fatal_invalid",code:`HTTP_${o}`,message:i,retryable:false,context:{httpStatus:o,requestId:l},originalError:t})}if(Bo(r)){let o=r.code,a=r.name;if(o==="ERR_CANCELED"||a==="CanceledError"||a==="AbortError")return new ge({category:"canceled",code:"CANCELED",message:"Request was canceled",retryable:false,originalError:t});if(o==="ECONNREFUSED"||o==="ENOTFOUND"||o==="ECONNRESET")return new ge({category:"retryable_network",code:o,message:`Network error: ${e}`,retryable:true,originalError:t});if(o==="ETIMEDOUT"||o==="ESOCKETTIMEDOUT")return new ge({category:"retryable_network",code:"TIMEOUT",message:`Connection timeout: ${e}`,retryable:true,originalError:t})}return r instanceof Error&&r.name==="AbortError"?new ge({category:"canceled",code:"CANCELED",message:"Request was canceled",retryable:false,originalError:r}):Bo(r)&&r.code==="STREAM_INCOMPLETE"?new ge({category:"retryable_stream",code:"STREAM_INCOMPLETE",message:`\u7F51\u7EDC\u4E2D\u65AD: ${e}`,retryable:true,context:{toolName:r.toolName,rawMessage:e},originalError:t}):r?.code==="STREAM_TIMEOUT"?new ge({category:"retryable_stream",code:"STREAM_TIMEOUT",message:`API \u4EE3\u7406\u54CD\u5E94\u8D85\u65F6: ${e}`,retryable:true,context:{rawMessage:e},originalError:t}):e.includes("stream")||e.includes("Stream")||e.includes("SSE")||e.includes("disconnected")||e.includes("incomplete")||e.includes("message_stop")?new ge({category:"retryable_stream",code:"STREAM_ERROR",message:`\u7F51\u7EDC\u4E2D\u65AD: ${e}`,retryable:true,originalError:t}):Cc(e)?new ge({category:"fatal_context",code:"CONTEXT_WINDOW_EXCEEDED",message:"Context window exceeded. Please start a new conversation or clear history.",retryable:false,originalError:t}):bg(e)?new ge({category:"fatal_limit",code:"QUOTA_EXCEEDED",message:e,retryable:false,originalError:t}):new ge({category:"internal",code:"UNKNOWN",message:e,retryable:false,originalError:t})}function Rc(r,e,t){let s=e||"";return s.trim().endsWith("}")?(r==="write_file"||r==="edit_file")&&!s.includes('"content"')?new ge({category:"tool_truncated",code:"TOOL_MISSING_CONTENT",message:"The content field is missing (likely truncated)",retryable:false,context:{toolName:r,receivedLength:s.length,rawMessage:t.message},originalError:t}):t.message.includes("JSON")||t.message.includes("Unexpected")||t.message.includes("parse")?new ge({category:"tool_json_invalid",code:"JSON_PARSE_ERROR",message:`Invalid JSON in tool arguments: ${t.message}`,retryable:true,context:{toolName:r,receivedLength:s.length,rawMessage:t.message},originalError:t}):new ge({category:"tool_json_invalid",code:"TOOL_ERROR",message:t.message,retryable:true,context:{toolName:r},originalError:t}):new ge({category:"tool_truncated",code:"TOOL_ARGS_TRUNCATED",message:"Tool arguments were truncated during streaming",retryable:false,context:{toolName:r,receivedLength:s.length,rawMessage:t.message},originalError:t})}function Jr(r){switch(r.category){case "retryable_rate_limit":return `API \u4EE3\u7406\u901F\u7387\u9650\u5236\uFF0C${r.retryAfter?Math.ceil(r.retryAfter/1e3):3} \u79D2\u540E\u81EA\u52A8\u91CD\u8BD5...`;case "retryable_http":return "The request will be automatically retried.";case "retryable_stream":return "\u7F51\u7EDC\u8FDE\u63A5\u4E2D\u65AD\uFF0C\u6B63\u5728\u81EA\u52A8\u91CD\u8FDE...";case "retryable_network":return "\u7F51\u7EDC\u8FDE\u63A5\u5F02\u5E38\uFF0C\u6B63\u5728\u81EA\u52A8\u91CD\u8BD5...";case "fatal_auth":return "Please check your API key and ensure it has the necessary permissions.";case "fatal_limit":return "You have reached your usage limit. Please check your billing settings or wait for the limit to reset.";case "fatal_context":return "The conversation is too long. Please start a new conversation or use /compact to summarize history.";case "fatal_invalid":return "Please check your request parameters and try again.";case "tool_truncated":return "The tool call was truncated. Please use edit_file with smaller, targeted changes instead of rewriting entire files.";case "tool_json_invalid":return "The tool arguments were invalid. The LLM will retry with corrected parameters.";case "tool_timeout":return "The tool execution timed out. Please try again with a smaller operation.";case "tool_denied":return "The tool call was denied. You can manually approve or adjust permissions.";default:return "An unexpected error occurred. Please try again."}}var Et={requestMaxRetries:10,streamMaxRetries:5,toolMaxRetries:2,initialDelayMs:1e3,backoffFactor:2,maxDelayMs:3e4,jitterRange:.2,streamIdleTimeoutMs:3e5};function Nt(r,e){return {...Et,...r,...e?.requestMaxRetries!==void 0&&{requestMaxRetries:e.requestMaxRetries},...e?.streamMaxRetries!==void 0&&{streamMaxRetries:e.streamMaxRetries},...e?.streamIdleTimeoutMs!==void 0&&{streamIdleTimeoutMs:e.streamIdleTimeoutMs}}}var $t={openai:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:3e5},anthropic:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:3e5},yunwu:{requestMaxRetries:3,streamMaxRetries:10,streamIdleTimeoutMs:9e4},azure:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:6e5},proxy:{requestMaxRetries:10,streamMaxRetries:10,streamIdleTimeoutMs:18e4},gemini:{requestMaxRetries:4,streamMaxRetries:5,streamIdleTimeoutMs:3e5}};function Os(r,e){let t=r.toLowerCase();if(t.includes("yunwu"))return $t.yunwu;if(t.includes("azure"))return $t.azure;if(e){let s=e.toLowerCase();if(s.includes("yunwu"))return $t.yunwu;if(s.includes("azure"))return $t.azure;if(!(s.includes("api.anthropic.com")||s.includes("api.openai.com")))return $t.proxy}return t.includes("anthropic")?$t.anthropic:t.includes("gemini")?$t.gemini:$t.openai}var Ec=100,Ic=200,Mc=1800*1e3;var On=class extends Error{constructor(e){super(e),this.name="GuardrailTripwireTriggered";}},Ls=class extends On{guardrail_result;constructor(e){let t=`Input guardrail "${e.guardrail.name}" triggered: ${e.output.output_info?.reason||"Safety check failed"}`;super(t),this.name="InputGuardrailTripwireTriggered",this.guardrail_result=e;}getDetails(){return {guardrail_name:this.guardrail_result.guardrail.name,execution_time_ms:this.guardrail_result.execution_time_ms,output_info:this.guardrail_result.output.output_info}}},Ds=class extends On{guardrail_result;blocked_output;constructor(e){let t=`Output guardrail "${e.guardrail.name}" triggered: ${e.output.output_info?.reason||"Output safety check failed"}`;super(t),this.name="OutputGuardrailTripwireTriggered",this.guardrail_result=e,this.blocked_output=e.agent_output;}getDetails(){return {guardrail_name:this.guardrail_result.guardrail.name,execution_time_ms:this.guardrail_result.execution_time_ms,output_info:this.guardrail_result.output.output_info,blocked_output:this.blocked_output}}},rt=class extends On{guardrail_result;constructor(e){let t=`Tool guardrail "${e.guardrail.name}" triggered: ${e.output.output_info?.reason||"Tool safety check failed"}`;super(t),this.name="ToolGuardrailTripwireTriggered",this.guardrail_result=e;}getDetails(){return {guardrail_name:this.guardrail_result.guardrail.name,execution_time_ms:this.guardrail_result.execution_time_ms,output_info:this.guardrail_result.output.output_info,behavior:this.guardrail_result.output.behavior}}};var ss=class{static async runInputGuardrails(e,t,s,n){if(e.length===0)return [];let i=e.map(async o=>{let a=Date.now();try{let l=await o.guardrail_function(t,s,n),c={guardrail:o,output:l,execution_time_ms:Date.now()-a};if(l.tripwire_triggered)throw new Ls(c);return c}catch(l){if(l instanceof Ls)throw l;let c={guardrail:o,output:{tripwire_triggered:true,output_info:{error:l instanceof Error?l.message:String(l),reason:"Guardrail execution failed"}},execution_time_ms:Date.now()-a};throw new Ls(c)}});return await Promise.all(i)}static async runOutputGuardrails(e,t,s,n){if(e.length===0)return [];let i=e.map(async o=>{let a=Date.now();try{let l=await o.guardrail_function(t,s,n),c={guardrail:o,agent_output:n,output:l,execution_time_ms:Date.now()-a};if(l.tripwire_triggered)throw new Ds(c);return c}catch(l){if(l instanceof Ds)throw l;let c={guardrail:o,agent_output:n,output:{tripwire_triggered:true,output_info:{error:l instanceof Error?l.message:String(l),reason:"Guardrail execution failed"}},execution_time_ms:Date.now()-a};throw new Ds(c)}});return await Promise.all(i)}static async runToolInputGuardrails(e,t){let s=[];for(let n of e){let i=Date.now();try{let o=await n.guardrail_function(t),a={guardrail:n,output:o,execution_time_ms:Date.now()-i};if(s.push(a),o.behavior.type==="raise_exception")throw new rt(a);if(o.behavior.type==="reject_content")return {results:s,should_execute:!1,rejection_message:o.behavior.message}}catch(o){if(o instanceof rt)throw o;let a={guardrail:n,output:{output_info:{error:o instanceof Error?o.message:String(o)},behavior:{type:"raise_exception"}},execution_time_ms:Date.now()-i};throw new rt(a)}}return {results:s,should_execute:true}}static async runToolOutputGuardrails(e,t){let s=[];for(let n of e){let i=Date.now();try{let o=await n.guardrail_function(t),a={guardrail:n,output:o,execution_time_ms:Date.now()-i};if(s.push(a),o.behavior.type==="raise_exception")throw new rt(a);if(o.behavior.type==="reject_content")return {results:s,should_use_output:!1,replacement_message:o.behavior.message}}catch(o){if(o instanceof rt)throw o;let a={guardrail:n,output:{output_info:{error:o instanceof Error?o.message:String(o)},behavior:{type:"raise_exception"}},execution_time_ms:Date.now()-i};throw new rt(a)}}return {results:s,should_use_output:true}}};var Ac=null,Pc=false;function Ln(){if(!Pc&&(Pc=true,typeof process<"u"&&process.env&&!process.env.NEOX_UI_MODE))try{Promise.resolve().then(()=>(me(),ba)).then(r=>{Ac=r.cliLogger;}).catch(()=>{});}catch{}return Ac}var Oc=new WeakMap,Wo=null;function Lc(){return {writtenFiles:new Map,editedFiles:new Map,editDetails:new Map,fileReadCache:new Map,toolCallHistory:[],createdAt:Date.now()}}function Dc(r){if(r){let e=Oc.get(r);return e?process.env.CLI_DEBUG==="1"&&Ln()?.debug("SESSION",`Retrieved EXISTING SessionState for context: ${Object.keys(r).join(",")}, history: ${e.toolCallHistory.length}`):(e=Lc(),Oc.set(r,e),process.env.CLI_DEBUG==="1"&&Ln()?.debug("SESSION",`Created NEW SessionState for context: ${Object.keys(r).join(",")}`)),e}return Wo||(Wo=Lc()),Wo}function Ho(r,e,t,s){let n=Dc(r);if(process.env.CLI_DEBUG==="1"){let i=Ln();i?.debug("SESSION","recordToolCall called:"),i?.debug("SESSION",` - tool: ${e}`),i?.debug("SESSION",` - success: ${s}`),i?.debug("SESSION",` - context exists: ${!!r}`),i?.debug("SESSION",` - context identity: ${r?Object.keys(r).join(","):"none"}`),i?.debug("SESSION",` - history length before: ${n.toolCallHistory.length}`);}n.toolCallHistory.push({name:e,args:t,timestamp:Date.now(),success:s}),process.env.CLI_DEBUG==="1"&&Ln()?.debug("SESSION",` - history length after: ${n.toolCallHistory.length}`),n.toolCallHistory.length>100&&n.toolCallHistory.shift();}function $c(r,e=10){let t=Dc(r);if(process.env.CLI_DEBUG==="1"){let s=Ln();s?.debug("SESSION","getRecentToolCalls called:"),s?.debug("SESSION",` - context exists: ${!!r}`),s?.debug("SESSION",` - context identity: ${r?Object.keys(r).join(","):"none"}`),s?.debug("SESSION",` - total history length: ${t.toolCallHistory.length}`),s?.debug("SESSION",` - limit: ${e}`),s?.debug("SESSION",` - returning ${Math.min(t.toolCallHistory.length,e)} calls`);}return t.toolCallHistory.slice(-e)}var vg=fileURLToPath(import.meta.url),qo=dirname(vg),Jo=class{logDir;enabled;consoleEnabled;constructor(){this.logDir=this.getLogDirectory(),this.enabled=process.env.MARKOR_TRACING==="1",this.consoleEnabled=process.env.CLI_DEBUG_CONSOLE==="1";try{this.initLogDir(),this.consoleEnabled&&console.log("[Logger] Initialized at:",this.logDir);}catch(e){console.error("[Logger] Failed to initialize:",e.message),this.enabled=false;}}setEnabled(e){this.enabled=e;}getLogDirectory(){if(qo.includes(".asar")||qo.includes("app.asar")){try{if(typeof process<"u"&&process.type==="browser"){let e=process.env.ELECTRON_USER_DATA;if(e)return X__default.join(e,"logs")}}catch{}return X__default.join(Js__default.tmpdir(),"neox-logs")}return X__default.join(qo,"../../logs")}initLogDir(){try{Ce__default.existsSync(this.logDir)||Ce__default.mkdirSync(this.logDir,{recursive:!0});}catch(e){let t=e;t.code==="EACCES"||t.code==="EPERM"?this.enabled=false:(console.warn(`[Logger] Warning: Cannot create log directory: ${t.message}`),this.enabled=false);}}getLogFile(e){let t=new Date().toISOString().split("T")[0];return X__default.join(this.logDir,`${e}-${t}.log`)}write(e,t){if(!this.enabled)return;let s=new Date().toISOString(),n=typeof t=="string"?{message:t}:t||{},i=this.safeStringify({timestamp:s,...n})+`
|
|
1053
|
+
`;if(this.enabled)try{let o=this.getLogFile(e);Ce__default.appendFileSync(o,i,"utf-8");}catch(o){(o.code==="EACCES"||o.code==="EPERM")&&(this.enabled=false);}}safeStringify(e){let t=new WeakSet;return JSON.stringify(e,(s,n)=>{if(typeof n=="object"&&n!==null){if(t.has(n))return "[Circular]";t.add(n);}return s==="parser"||s==="socket"||s==="_httpMessage"||s==="req"||s==="res"?"[Omitted]":n&&n.type==="Buffer"&&Array.isArray(n.data)?"[Buffer]":typeof n=="function"?"[Function]":n})}llmRequest(e,t,s,n,i){let o=s.tools?.map(a=>({name:a.name,description:a.description,parameters:a.parameters}));this.write("llm",{type:"REQUEST",provider:e,model:t,url:n,headers:i,messagesCount:s.messages?.length||0,messages:s.messages,toolsCount:s.tools?.length||0,tools:o,temperature:s.temperature});}llmResponse(e,t,s,n){this.write("llm",{type:"RESPONSE",provider:e,duration:`${t}ms`,usage:s,finishReason:n.finish_reason,content:n.content,contentLength:n.content?.length||0,toolCallsCount:n.tool_calls?.length||0,toolCalls:n.tool_calls});}llmError(e,t){let s={type:"ERROR",provider:e,error:t.message,status:t.response?.status};if(t.response?.data)try{let n=t.response.data;typeof n=="string"?s.data=n:typeof n=="object"&&(s.data={error:n.error,message:n.message,type:n.type,code:n.code});}catch{s.data="[Could not serialize response data]";}this.write("llm",s);}agentStart(e){this.write("agent",{type:"START",task:e});}agentIteration(e,t){this.write("agent",{type:"ITERATION",iteration:e,action:t});}agentComplete(e,t,s){this.write("agent",{type:"COMPLETE",iterations:e,toolCalls:t,usage:s});}agentError(e){this.write("agent",{type:"ERROR",error:e});}toolCall(e,t){this.write("tool",{type:"CALL",tool:e,args:t});}toolResult(e,t,s,n){this.write("tool",{type:"RESULT",tool:e,success:t,resultLength:s,duration:`${n}ms`});}toolError(e,t){this.write("tool",{type:"ERROR",tool:e,error:t});}},oe=new Jo;function Nc(r,e){let t=r||"Unknown error",s=t.toLowerCase(),n=e?.providerName?.trim()||"LLM";if(s.includes("timeout")){let i=Math.round((e?.timeoutMs??12e4)/1e3);return [`\u23F1\uFE0F ${n} \u8BF7\u6C42\u8D85\u65F6 (${i}s)\u3002${n} \u63A5\u53E3\u5F53\u524D\u53EF\u80FD\u4E0D\u7A33\u5B9A\uFF0C\u53EF\u4EE5\u7A0D\u540E\u91CD\u8BD5\u6216\u5207\u6362\u5176\u4ED6\u6A21\u578B\u3002`,"\u5982\u679C\u591A\u6B21\u8D85\u65F6\u8BF7\u544A\u8BC9\u6211\u4EEC\uFF0C\u65B9\u4FBF\u6392\u67E5\u3002",`\u539F\u59CB\u9519\u8BEF\uFF1A${t}`].join(`
|
|
1054
|
+
`)}return t}var xg=new Tg({allErrors:true,strict:false});function Cg(r){let e=(r||"").trim();if(e.startsWith("```")){let t=e.match(/```(?:json)?\s*([\s\S]*?)```/i);if(t&&t[1])return t[1].trim()}return e}function Rg(r){return !r||r.length===0?[]:r.map(e=>{let t=e.instancePath||e.schemaPath||"";return e.keyword==="additionalProperties"&&typeof e.params?.additionalProperty=="string"?`${t} should not contain property "${e.params.additionalProperty}"`:`${t} ${e.message||""}`.trim()})}var Vr=class{constructor(e){this.definition=e;this.validateFn=xg.compile(e.schema);}validateFn;get responseFormatPayload(){return {type:"json_schema",json_schema:{name:this.definition.name,schema:this.definition.schema,strict:this.definition.strict??true}}}buildSystemPrompt(){let e=JSON.stringify(this.definition.schema,null,2);return [`You must respond with valid JSON that exactly matches the schema "${this.definition.name}".`,"Do not include explanations, markdown code fences, or additional commentary.","Schema:",e].join(`
|
|
1055
1055
|
|
|
1056
|
-
`)}validate(e){let t=
|
|
1056
|
+
`)}validate(e){let t=Cg(e||"");if(!t)return {ok:false,reason:"empty_output",message:"The model returned an empty response."};let s;try{s=JSON.parse(t);}catch(i){return {ok:false,reason:"parse_error",message:i?.message||"Failed to parse JSON output."}}return this.validateFn(s)?{ok:true,parsed:s,normalized:JSON.stringify(s,null,2)}:{ok:false,reason:"schema_mismatch",message:"Response does not match the required JSON schema.",errors:Rg(this.validateFn.errors)}}buildRetryPrompt(e){let t=[`Your previous response did not satisfy the required JSON schema "${this.definition.name}".`];return e.errors&&e.errors.length>0?t.push(`Validation issues:
|
|
1057
1057
|
- `+e.errors.join(`
|
|
1058
1058
|
- `)):e.message&&t.push(`Validation issue: ${e.message}`),t.push("Return ONLY valid minified JSON (no code fences, no commentary) that matches the schema below:",JSON.stringify(this.definition.schema,null,2)),t.join(`
|
|
1059
1059
|
|
|
1060
|
-
`)}};function
|
|
1060
|
+
`)}};function Vo(r,e={}){let{initialDelayMs:t=Et.initialDelayMs,backoffFactor:s=Et.backoffFactor,maxDelayMs:n=Et.maxDelayMs,jitterRange:i=Et.jitterRange}=e,o=Math.max(0,r-1),a=t*Math.pow(s,o),l=1+(Math.random()*2-1)*i,c=a*l,u=Math.min(c,n);return Math.floor(u)}function Ft(r,e,t){return r!==void 0&&r>0?r:Vo(e,t)}function $s(r){return new Promise(e=>setTimeout(e,r))}function ns(r,e){return new Promise((t,s)=>{if(e?.aborted){s(new DOMException("Aborted","AbortError"));return}let n=setTimeout(t,r),i=()=>{clearTimeout(n),s(new DOMException("Aborted","AbortError"));};e?.addEventListener("abort",i,{once:true});let o=()=>{e?.removeEventListener("abort",i);};setTimeout(()=>{o(),t();},r);})}function Je(r){if(r<1e3)return `${r}ms`;let e=r/1e3;return e<60?`${e.toFixed(1)}s`:`${(e/60).toFixed(1)}m`}var Eg={initialDelayMs:3e3,backoffFactor:2.5,maxDelayMs:6e4,jitterRange:.3},Ig={initialDelayMs:1e3,backoffFactor:1.5,maxDelayMs:1e4,jitterRange:.2};function Mg(r,e){if(e!==void 0&&e>0){let t=1+Math.random()*.2;return Math.floor(e*t)}return Vo(r,Eg)}function Dn(r,e,t){return r==="retryable_rate_limit"?Mg(e,t):r==="retryable_stream"||r==="retryable_network"?Vo(e,Ig):Ft(t,e)}me();me();var Ag=2e3,Fc={Read:"file_read",Write:"file_write",Edit:"file_edit",Glob:"file_search",Grep:"file_search",NotebookEdit:"file_edit",Bash:"bash",BashOutput:"bash",WebFetch:"web_fetch",WebSearch:"web_search",Task:"task"},Pg={file_read:{system:`\u4F60\u662F\u4E00\u4E2A\u4EE3\u7801\u5206\u6790\u52A9\u624B\u3002\u8BF7\u5C06\u6587\u4EF6\u5185\u5BB9\u538B\u7F29\u4E3A\u7B80\u6D01\u6458\u8981\uFF0C\u4FDD\u7559\uFF1A
|
|
1061
1061
|
1. \u6587\u4EF6\u7C7B\u578B\u548C\u4E3B\u8981\u529F\u80FD
|
|
1062
1062
|
2. \u5173\u952E\u7684\u51FD\u6570/\u7C7B/\u63A5\u53E3\u5B9A\u4E49\uFF08\u53EA\u4FDD\u7559\u7B7E\u540D\uFF09
|
|
1063
1063
|
3. \u91CD\u8981\u7684\u914D\u7F6E\u9879\u6216\u5E38\u91CF
|
|
@@ -1122,9 +1122,9 @@ ${r}
|
|
|
1122
1122
|
\u683C\u5F0F\uFF1A[\u4EFB\u52A1\u7C7B\u578B] \u7ED3\u8BBA: \u6458\u8981`,user:r=>`\u4EFB\u52A1\u7ED3\u679C:
|
|
1123
1123
|
${r}
|
|
1124
1124
|
|
|
1125
|
-
\u8BF7\u538B\u7F29\u8FD9\u4E2A\u4EFB\u52A1\u7ED3\u679C\u3002`}},Ut=class{supportedTools=Object.keys(
|
|
1125
|
+
\u8BF7\u538B\u7F29\u8FD9\u4E2A\u4EFB\u52A1\u7ED3\u679C\u3002`}},Ut=class{supportedTools=Object.keys(Fc);debug;llmProvider;model;constructor(e){this.debug=e?.debug??process.env.CLI_DEBUG==="1",this.llmProvider=e?.llmProvider,this.model=e?.model;}getToolType(e){return e.startsWith("mcp__")?"mcp":Fc[e]||"other"}needsLLMCompression(e,t,s){let n=this.getToolType(e);if(["web_fetch","web_search","task"].includes(n))return true;let o=128e3,a=2e5,l=s||o,c=Math.max(.3,Math.min(2,l/a)),p={file_read:2e4,file_write:8e3,file_edit:5e3,file_search:1e4,bash:15e3,web_fetch:0,web_search:0,image_analysis:3e3,mcp:1e4,task:0,other:15e3}[n]??15e3,d=Math.floor(p*c);return this.debug&&f.debug("ToolCompressor",`[${e}] contextWindow=${l}${s?"":"(default)"}, scaleFactor=${c.toFixed(2)}, threshold=${d}`),t.length>d}async compress(e,t,s){let n=this.getToolType(e),i=t.length,o=this.extractMetadata(n,t,e),a=this.needsLLMCompression(e,t,s.contextWindow),l=s.llmProvider||this.llmProvider,c,u=false;if(a&&l&&s.enableLLMCompression!==false){let p=await this.compressWithLLM(n,t,l,s.model||this.model,o);p?(c=p,u=true):c=this.compressWithRules(n,t,o);}else c=this.compressWithRules(n,t,o);if(this.debug){let p=((1-c.length/i)*100).toFixed(1);f.debug("ToolCompressor",`[${e}] ${i} \u2192 ${c.length} chars (${p}% saved, LLM: ${u})`);}return {content:c,originalLength:i,compressedLength:c.length,strategy:n,usedLLM:u,metadata:o}}extractMetadata(e,t,s){let n={};switch(e){case "file_read":case "file_write":case "file_edit":let i=t.match(/(?:file|path)[:\s]+([^\n]+)/i);i&&(n.filePath=i[1].trim());break;case "bash":let o=t.match(/(?:command|cmd)[:\s]+([^\n]+)/i);o&&(n.command=o[1].trim()),/error|failed|exit code [1-9]/i.test(t)&&(n.exitCode=1);break;case "web_fetch":case "web_search":let a=t.match(/https?:\/\/[^\s\)]+/g);a&&(n.urls=[...new Set(a)].slice(0,10));break}return n}async compressWithLLM(e,t,s,n,i){let o=Pg[e];if(!o)return null;try{let l=t.length>8e3?t.slice(0,8e3)+`
|
|
1126
1126
|
|
|
1127
|
-
...[\u5185\u5BB9\u8FC7\u957F\uFF0C\u5DF2\u622A\u65AD]...`:t,c=await s.chat([{role:"system",content:o.system},{role:"user",content:o.user(l,i?.filePath)}],{model:n,temperature:.2});return
|
|
1127
|
+
...[\u5185\u5BB9\u8FC7\u957F\uFF0C\u5DF2\u622A\u65AD]...`:t,c=await s.chat([{role:"system",content:o.system},{role:"user",content:o.user(l,i?.filePath)}],{model:n,temperature:.2});return se(c.choices[0]?.message?.content)?.trim()||null}catch(a){return f.warn("ToolCompressor",`LLM compression failed: ${a.message}`),null}}compressWithRules(e,t,s){let n=Ag;switch(e){case "file_read":return this.compressFileRead(t,s?.filePath,n);case "file_edit":return this.compressFileEdit(t,n);case "bash":return this.compressBash(t,s?.command,n);case "web_fetch":case "web_search":return this.compressWebContent(t,s?.urls,n);case "file_search":return this.compressSearchResult(t,n);default:return this.truncateWithContext(t,n)}}compressFileRead(e,t,s=2e3){let n=e.split(`
|
|
1128
1128
|
`),i=t?`\u{1F4C4} ${t}
|
|
1129
1129
|
`:"";if(e.length<=s)return i+e;let o=Math.floor(s*.6/80),a=Math.floor(s*.3/80),l=n.slice(0,o).join(`
|
|
1130
1130
|
`),c=n.slice(-a).join(`
|
|
@@ -1154,7 +1154,7 @@ ${t.slice(0,5).map(o=>`- ${o}`).join(`
|
|
|
1154
1154
|
|
|
1155
1155
|
... [\u7701\u7565 ${a} \u5B57\u7B26] ...
|
|
1156
1156
|
|
|
1157
|
-
${o}`}truncate(e,t){return e.length<=t?e:e.slice(0,t-3)+"..."}};new Ut;
|
|
1157
|
+
${o}`}truncate(e,t){return e.length<=t?e:e.slice(0,t-3)+"..."}};new Ut;me();var Og=15,Lg=[/error/i,/错误/,/failed/i,/失败/,/exception/i,/异常/,/❌/,/warning/i,/警告/],$n={system:`\u4F60\u662F\u4E00\u4E2A\u5BF9\u8BDD\u5386\u53F2\u538B\u7F29\u52A9\u624B\u3002\u8BF7\u5C06\u5BF9\u8BDD\u538B\u7F29\u4E3A\u7B80\u6D01\u6458\u8981\uFF0C\u4FDD\u7559\uFF1A
|
|
1158
1158
|
1. \u7528\u6237\u7684\u6838\u5FC3\u9700\u6C42\u548C\u76EE\u6807
|
|
1159
1159
|
2. \u5173\u952E\u51B3\u7B56\u548C\u5176\u7406\u7531
|
|
1160
1160
|
3. \u91CD\u8981\u7684\u4EE3\u7801\u53D8\u66F4\uFF08\u6587\u4EF6\u8DEF\u5F84\u3001\u51FD\u6570\u540D\uFF09
|
|
@@ -1179,14 +1179,14 @@ ${o}`}truncate(e,t){return e.length<=t?e:e.slice(0,t-3)+"..."}};new Ut;de();var
|
|
|
1179
1179
|
- \u4FDD\u7559\u6280\u672F\u7EC6\u8282\uFF08\u6587\u4EF6\u540D\u3001\u51FD\u6570\u540D\u3001\u9519\u8BEF\u4FE1\u606F\uFF09
|
|
1180
1180
|
- \u603B\u957F\u5EA6\u63A7\u5236\u5728 800 \u5B57\u4EE5\u5185`,user:r=>`\u8BF7\u538B\u7F29\u4EE5\u4E0B\u5BF9\u8BDD\u5386\u53F2:
|
|
1181
1181
|
|
|
1182
|
-
${r}`},Ns=class{debug;toolCompressor;minRecentMessages;constructor(e){this.debug=e?.debug??process.env.CLI_DEBUG==="1",this.toolCompressor=e?.toolCompressor??new Ut({debug:this.debug}),this.minRecentMessages=e?.minRecentMessages??
|
|
1183
|
-
${w}`,name:"CompressedHistory"},x=mt(S);l+x<=t&&(a.push({message:S,priority:2,tokens:x,index:-1,type:"user",reason:"LLM batch compressed"}),l+=x,this.debug&&n.push(`[MessageCompressor] LLM \u6279\u91CF\u538B\u7F29: ${p.length} \u6761 \u2192 1 \u6761\u6458\u8981`));}}if(!a.find(w=>w.reason==="LLM batch compressed")){let w=[...p].sort((S,x)=>x.index-S.index);for(let S of w){let x=await this.compressMessage(S.message,s);l+x.compressedTokens<=t&&(a.push({...S,message:x.message,tokens:x.compressedTokens}),l+=x.compressedTokens);}}}let h=[...a].sort((w,S)=>w.index===-1||S.index===-1?0:w.index-S.index).map(w=>w.message),g=ze(h),y=e.length-a.length,b=a.filter(w=>w.reason.includes("LLM")).length;return this.debug&&(n.push(`[MessageCompressor] \u6700\u7EC8: ${h.length} \u6761, ${g} tokens`),n.push(`[MessageCompressor] \u8282\u7701: ${i-g} tokens`)),{messages:h,originalCount:e.length,compressedCount:h.length,originalTokens:i,compressedTokens:g,savedTokens:i-g,stats:{droppedMessages:y,llmCompressedMessages:b,truncatedMessages:0,preservedMessages:a.length-b},debugInfo:this.debug?n:void 0}}getMessageType(e){return e.role==="system"?"system":e.role==="user"?"user":e.role==="tool"?"tool_result":e.role==="assistant"?e.tool_calls&&e.tool_calls.length>0?"tool_call":"assistant":"user"}prioritizeMessages(e){let t=[];for(let s=0;s<e.length;s++){let n=e[s],i=mt(n),o=this.getMessageType(n),a=e.length-s,l,c;o==="system"?(l=0,c="system message"):a<=this.minRecentMessages?(l=0,c=`recent message (${a} from end)`):this.containsError(n)?(l=1,c="contains error"):o==="tool_call"?(l=1,c="tool calls"):o==="tool_result"?(l=1,c="tool result"):o==="user"?(l=2,c="user message"):o==="assistant"?(l=2,c="assistant message"):(l=3,c="default"),t.push({message:n,priority:l,tokens:i,index:s,type:o,reason:c});}return t}containsError(e){let t=
|
|
1182
|
+
${r}`},Ns=class{debug;toolCompressor;minRecentMessages;constructor(e){this.debug=e?.debug??process.env.CLI_DEBUG==="1",this.toolCompressor=e?.toolCompressor??new Ut({debug:this.debug}),this.minRecentMessages=e?.minRecentMessages??Og;}async compressMessage(e,t){let s=mt(e),n=this.getMessageType(e);if(n==="system")return {message:e,originalTokens:s,compressedTokens:s,compressionRatio:1,usedLLM:false,strategy:"preserve_system"};if(n==="tool_result"&&e.role==="tool"){let o=e.name||"unknown",a=se(e.content),l=await this.toolCompressor.compress(o,a,t),c={...e,content:l.content},u=mt(c);return {message:c,originalTokens:s,compressedTokens:u,compressionRatio:u/s,usedLLM:l.usedLLM,strategy:`tool_${l.strategy}`}}let i=se(e.content);if(i.length>3e3&&t.llmProvider&&t.enableLLMCompression!==false){let o=await this.compressLongContent(i,t);if(o){let a={...e,content:o},l=mt(a);return {message:a,originalTokens:s,compressedTokens:l,compressionRatio:l/s,usedLLM:true,strategy:"llm_content_compression"}}}return {message:e,originalTokens:s,compressedTokens:s,compressionRatio:1,usedLLM:false,strategy:"preserve"}}async compressMessages(e,t){let s=[],n=ze(e),i=t.tokenBudget||n;return this.debug&&(s.push(`[MessageCompressor] \u5F00\u59CB\u538B\u7F29: ${e.length} \u6761\u6D88\u606F, ${n} tokens`),s.push(`[MessageCompressor] Token \u9884\u7B97: ${i}`)),n<=i?this.compressLargeMessages(e,t,s):this.compressWithPriority(e,i,t,s)}async compressLargeMessages(e,t,s){let n=ze(e),i=[],o=0,a=0;for(let c of e)if(mt(c)>2e3&&c.role!=="system"){let p=await this.compressMessage(c,t);i.push(p.message),p.usedLLM?o++:p.compressionRatio<1&&a++;}else i.push(c);let l=ze(i);return this.debug&&s.push(`[MessageCompressor] \u5927\u6D88\u606F\u538B\u7F29\u5B8C\u6210: LLM=${o}, \u622A\u65AD=${a}`),{messages:i,originalCount:e.length,compressedCount:i.length,originalTokens:n,compressedTokens:l,savedTokens:n-l,stats:{droppedMessages:0,llmCompressedMessages:o,truncatedMessages:a,preservedMessages:e.length-o-a},debugInfo:this.debug?s:void 0}}async compressWithPriority(e,t,s,n){let i=ze(e),o=this.prioritizeMessages(e);if(this.debug){let w=this.countPriorities(o);n.push(`[MessageCompressor] \u4F18\u5148\u7EA7\u5206\u5E03: CRITICAL=${w.critical}, HIGH=${w.high}, MEDIUM=${w.medium}, LOW=${w.low}`);}let a=[],l=0;for(let w of o)w.priority===0&&(a.push(w),l+=w.tokens);this.debug&&n.push(`[MessageCompressor] CRITICAL \u4FDD\u7559\u540E: ${a.length} \u6761, ${l} tokens`);let c=o.filter(w=>w.priority===1&&!a.includes(w));for(let w of c){let S=await this.compressMessage(w.message,s),x=S.compressedTokens;l+x<=t&&(a.push({...w,message:S.message,tokens:x}),l+=x);}this.debug&&n.push(`[MessageCompressor] HIGH \u4FDD\u7559\u540E: ${a.length} \u6761, ${l} tokens`);let u=t-l,p=o.filter(w=>(w.priority===2||w.priority===3)&&!a.includes(w));if(p.reduce((w,S)=>w+S.tokens,0)<=u)for(let w of p){let S=await this.compressMessage(w.message,s);a.push({...w,message:S.message,tokens:S.compressedTokens}),l+=S.compressedTokens;}else {if(s.llmProvider&&s.enableLLMCompression!==false&&p.length>=5){let w=await this.compressBatchWithLLM(p.map(S=>S.message),s);if(w){let S={role:"user",content:`[\u538B\u7F29\u7684\u5386\u53F2\u8BB0\u5F55]
|
|
1183
|
+
${w}`,name:"CompressedHistory"},x=mt(S);l+x<=t&&(a.push({message:S,priority:2,tokens:x,index:-1,type:"user",reason:"LLM batch compressed"}),l+=x,this.debug&&n.push(`[MessageCompressor] LLM \u6279\u91CF\u538B\u7F29: ${p.length} \u6761 \u2192 1 \u6761\u6458\u8981`));}}if(!a.find(w=>w.reason==="LLM batch compressed")){let w=[...p].sort((S,x)=>x.index-S.index);for(let S of w){let x=await this.compressMessage(S.message,s);l+x.compressedTokens<=t&&(a.push({...S,message:x.message,tokens:x.compressedTokens}),l+=x.compressedTokens);}}}let h=[...a].sort((w,S)=>w.index===-1||S.index===-1?0:w.index-S.index).map(w=>w.message),g=ze(h),y=e.length-a.length,b=a.filter(w=>w.reason.includes("LLM")).length;return this.debug&&(n.push(`[MessageCompressor] \u6700\u7EC8: ${h.length} \u6761, ${g} tokens`),n.push(`[MessageCompressor] \u8282\u7701: ${i-g} tokens`)),{messages:h,originalCount:e.length,compressedCount:h.length,originalTokens:i,compressedTokens:g,savedTokens:i-g,stats:{droppedMessages:y,llmCompressedMessages:b,truncatedMessages:0,preservedMessages:a.length-b},debugInfo:this.debug?n:void 0}}getMessageType(e){return e.role==="system"?"system":e.role==="user"?"user":e.role==="tool"?"tool_result":e.role==="assistant"?e.tool_calls&&e.tool_calls.length>0?"tool_call":"assistant":"user"}prioritizeMessages(e){let t=[];for(let s=0;s<e.length;s++){let n=e[s],i=mt(n),o=this.getMessageType(n),a=e.length-s,l,c;o==="system"?(l=0,c="system message"):a<=this.minRecentMessages?(l=0,c=`recent message (${a} from end)`):this.containsError(n)?(l=1,c="contains error"):o==="tool_call"?(l=1,c="tool calls"):o==="tool_result"?(l=1,c="tool result"):o==="user"?(l=2,c="user message"):o==="assistant"?(l=2,c="assistant message"):(l=3,c="default"),t.push({message:n,priority:l,tokens:i,index:s,type:o,reason:c});}return t}containsError(e){let t=se(e.content);return Lg.some(s=>s.test(t))}countPriorities(e){return {critical:e.filter(t=>t.priority===0).length,high:e.filter(t=>t.priority===1).length,medium:e.filter(t=>t.priority===2).length,low:e.filter(t=>t.priority===3).length}}async compressLongContent(e,t){if(!t.llmProvider)return null;try{let n=/[\u4e00-\u9fa5]/.test(e)?$n.systemZh:$n.system,i=6e3,o=e.length>i?e.slice(0,i)+`
|
|
1184
1184
|
|
|
1185
1185
|
...[\u5185\u5BB9\u8FC7\u957F\uFF0C\u5DF2\u622A\u65AD]...`:e,a=await t.llmProvider.chat([{role:"system",content:n},{role:"user",content:`\u8BF7\u538B\u7F29\u4EE5\u4E0B\u5185\u5BB9:
|
|
1186
1186
|
|
|
1187
|
-
${o}`}],{model:t.model,temperature:.2});return
|
|
1187
|
+
${o}`}],{model:t.model,temperature:.2});return se(a.choices[0]?.message?.content)||null}catch(s){return f.warn("MessageCompressor",`LLM compression failed: ${s.message}`),null}}async compressBatchWithLLM(e,t){if(!t.llmProvider)return null;try{let s=e.map(a=>{let l=a.role==="assistant"?"Assistant":a.role==="user"?"User":a.role==="tool"?"Tool":a.role,c=se(a.content),u=c.length>800?c.slice(0,800)+"...":c;return `[${l}] ${u}`}).join(`
|
|
1188
1188
|
|
|
1189
|
-
`),i=/[\u4e00-\u9fa5]/.test(s)?Dn.systemZh:Dn.system,o=await t.llmProvider.chat([{role:"system",content:i},{role:"user",content:Dn.user(s)}],{model:t.model,temperature:.3});return te(o.choices[0]?.message?.content)||null}catch(s){return f.warn("MessageCompressor",`Batch LLM compression failed: ${s.message}`),null}}};new Ns;var Eg={debug:false,minRecentMessages:15,defaultTokenBudget:1e5,enableLLMCompression:true,llmTimeout:3e4},Jr=class{config;toolCompressor;messageCompressor;llmProvider;model;contextWindow;constructor(e){this.config={...Eg,...e},this.config.debug=this.config.debug||process.env.CLI_DEBUG==="1",this.toolCompressor=new Ut({debug:this.config.debug}),this.messageCompressor=new Ns({debug:this.config.debug,toolCompressor:this.toolCompressor,minRecentMessages:this.config.minRecentMessages});}setLLMProvider(e,t){this.llmProvider=e,this.model=t;}setContextWindow(e){this.contextWindow=e,this.config.debug&&f.info("UnifiedCompressor",`Context window set to: ${e}`);}registerToolCompressor(e){f.info("UnifiedCompressor","Custom tool compressor registered");}setMessageCompressor(e){this.messageCompressor=e,f.info("UnifiedCompressor","Custom message compressor set");}async compressHistory(e,t,s){let n=Date.now(),i=ze(e),o={llmProvider:s?.llmProvider||this.llmProvider,model:s?.model||this.model,tokenBudget:t,contextWindow:s?.contextWindow||this.contextWindow,iteration:s?.iteration,enableLLMCompression:s?.enableLLMCompression??this.config.enableLLMCompression,timeout:s?.timeout??this.config.llmTimeout,signal:s?.signal,debug:this.config.debug};if(this.config.debug&&f.debug("UnifiedCompressor",`\u5F00\u59CB\u538B\u7F29: ${e.length} \u6761\u6D88\u606F, ${i} tokens \u2192 \u9884\u7B97 ${t} tokens`),i<=t){let c=await this.compressLargeMessagesOnly(e,o);return this.config.debug&&f.debug("UnifiedCompressor",`\u5728\u9884\u7B97\u5185\uFF0C\u4EC5\u538B\u7F29\u5927\u6D88\u606F: ${c.savedTokens} tokens \u8282\u7701`),c}let a=await this.messageCompressor.compressMessages(e,o),l=Date.now()-n;return this.config.debug&&f.debug("UnifiedCompressor",`\u538B\u7F29\u5B8C\u6210 (${l}ms): ${a.originalCount} \u2192 ${a.compressedCount} \u6761, ${a.originalTokens} \u2192 ${a.compressedTokens} tokens (\u8282\u7701 ${a.savedTokens} tokens, ${(a.savedTokens/a.originalTokens*100).toFixed(1)}%)`),a}async compressLargeMessagesOnly(e,t){let s=ze(e),n=[],i=0,o=0;for(let l of e)if(mt(l)>2e3&&l.role!=="system"){let u=await this.messageCompressor.compressMessage(l,t);n.push(u.message),u.usedLLM?i++:u.compressionRatio<1&&o++;}else n.push(l);let a=ze(n);return {messages:n,originalCount:e.length,compressedCount:n.length,originalTokens:s,compressedTokens:a,savedTokens:s-a,stats:{droppedMessages:0,llmCompressedMessages:i,truncatedMessages:o,preservedMessages:e.length-i-o}}}async compressToolResult(e,t,s){let n={llmProvider:s?.llmProvider||this.llmProvider,model:s?.model||this.model,enableLLMCompression:s?.enableLLMCompression??this.config.enableLLMCompression,timeout:s?.timeout??this.config.llmTimeout,debug:this.config.debug};return (await this.toolCompressor.compress(e,t,n)).content}getStats(){return {config:this.config,hasLLMProvider:!!this.llmProvider}}};function Ig(r,e){if(typeof r!="string")return null;let t=r.trim();if(!t.startsWith("{"))return null;try{let s=JSON.parse(t);return !s||typeof s!="object"||s.tool!==e||typeof s.status!="string"?null:s.status}catch{return null}}var Kr=class r{static READ_ONLY_TOOLS=new Set(["readfile","search","search_files","list_directory","show_tree","analyze_code","search_symbol","get_definitions","get_references","git_status","git_diff","git_blame","git_branch_list"]);static STATE_MODIFYING_TOOLS=new Set(["write_file","edit_file","create_directory","delete_file","rename_file","apply_patch","execute_shell","execute_bash","execute_python","execute_javascript","git_commit","git_branch","run_tests","run_lint","run_format"]);static TOOL_METADATA=new Map([["readfile",{name:"readfile",isReadOnly:true,category:"read",description:"Read file contents"}],["search",{name:"search",isReadOnly:true,category:"read",description:"Search file contents"}],["search_files",{name:"search_files",isReadOnly:true,category:"read",description:"Search files by name"}],["list_directory",{name:"list_directory",isReadOnly:true,category:"read",description:"List directory contents"}],["show_tree",{name:"show_tree",isReadOnly:true,category:"read",description:"Show directory tree"}],["analyze_code",{name:"analyze_code",isReadOnly:true,category:"read",description:"Analyze code structure"}],["search_symbol",{name:"search_symbol",isReadOnly:true,category:"read",description:"Search symbols in index"}],["get_definitions",{name:"get_definitions",isReadOnly:true,category:"read",description:"Find symbol definitions"}],["get_references",{name:"get_references",isReadOnly:true,category:"read",description:"Find symbol references"}],["git_status",{name:"git_status",isReadOnly:true,category:"read",description:"Show git status"}],["git_diff",{name:"git_diff",isReadOnly:true,category:"read",description:"Show git diff"}],["git_blame",{name:"git_blame",isReadOnly:true,category:"read",description:"Show git blame"}],["git_branch_list",{name:"git_branch_list",isReadOnly:true,category:"read",description:"List git branches"}],["write_file",{name:"write_file",isReadOnly:false,category:"write",description:"Write file"}],["edit_file",{name:"edit_file",isReadOnly:false,category:"write",description:"Edit file"}],["create_directory",{name:"create_directory",isReadOnly:false,category:"write",description:"Create directory"}],["delete_file",{name:"delete_file",isReadOnly:false,category:"write",description:"Delete file"}],["rename_file",{name:"rename_file",isReadOnly:false,category:"write",description:"Rename file"}],["apply_patch",{name:"apply_patch",isReadOnly:false,category:"write",description:"Apply patch"}],["git_commit",{name:"git_commit",isReadOnly:false,category:"write",description:"Git commit"}],["git_branch",{name:"git_branch",isReadOnly:false,category:"write",description:"Git branch"}],["run_tests",{name:"run_tests",isReadOnly:false,category:"execute",description:"Run tests"}],["run_lint",{name:"run_lint",isReadOnly:false,category:"execute",description:"Run lint"}],["run_format",{name:"run_format",isReadOnly:false,category:"execute",description:"Run format"}],["execute_shell",{name:"execute_shell",isReadOnly:false,category:"execute",description:"Execute shell command"}],["execute_bash",{name:"execute_bash",isReadOnly:false,category:"execute",description:"Execute bash script"}],["execute_python",{name:"execute_python",isReadOnly:false,category:"execute",description:"Execute Python code"}],["execute_javascript",{name:"execute_javascript",isReadOnly:false,category:"execute",description:"Execute JavaScript code"}]]);static isReadOnly(e){return r.READ_ONLY_TOOLS.has(e)}static isStateModifying(e){return r.STATE_MODIFYING_TOOLS.has(e)}static getMetadata(e){return r.TOOL_METADATA.get(e)}analyzePlan(e){let t=[],s=[];for(let n of e){let i=n.function.name;r.isReadOnly(i)?t.push(n):s.push(n);}return {parallel:t,sequential:s,totalTools:e.length,parallelCount:t.length,sequentialCount:s.length}}async executeSingleTool(e,t,s){let n=Date.now();if(s?.aborted)return {id:e.id,name:e.function.name,output:"Error: Operation cancelled",success:false,executionTime:Date.now()-n};let i=t.find(o=>o.name===e.function.name);if(!i)return {id:e.id,name:e.function.name,output:`Error: Tool ${e.function.name} not found`,success:false,executionTime:Date.now()-n};try{let o=e.function.arguments.trim(),a=o?JSON.parse(o):{},l=await i.function(a,{signal:s}),c=!0;return Ig(l,e.function.name)==="error"&&(c=!1),s?.aborted?{id:e.id,name:e.function.name,output:"Error: Operation cancelled",success:!1,executionTime:Date.now()-n}:{id:e.id,name:e.function.name,output:l,success:c,executionTime:Date.now()-n}}catch(o){return o.name==="AbortError"||s?.aborted?{id:e.id,name:e.function.name,output:"Error: Operation cancelled",success:false,executionTime:Date.now()-n}:{id:e.id,name:e.function.name,output:`Error: ${o.message}`,success:false,executionTime:Date.now()-n}}}async execute(e,t,s,n){let i=Date.now(),o=this.analyzePlan(e);process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log("[ParallelExecutor] Execution Plan:"),console.log(` Total: ${o.totalTools} tools`),console.log(` Parallel (read-only): ${o.parallelCount} tools`),console.log(` Sequential (state-modifying): ${o.sequentialCount} tools`));let a=new Map,l=0,c=0;if(o.parallel.length>0){let y=Date.now();process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Executing ${o.parallel.length} read-only tools in parallel...`);let b=o.parallel.map(S=>this.executeSingleTool(S,t,n).then(x=>(s&&s(x),x))),w=await Promise.all(b);l=Date.now()-y;for(let S of w)a.set(S.id,S);process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Parallel execution completed in ${l}ms`);}if(o.sequential.length>0){let y=Date.now();process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Executing ${o.sequential.length} state-modifying tools sequentially...`);for(let b of o.sequential){if(n?.aborted){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Execution interrupted before ${b.function.name}`);break}let w=await this.executeSingleTool(b,t,n);if(s&&s(w),a.set(w.id,w),n?.aborted){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Execution interrupted after ${b.function.name}`);break}}c=Date.now()-y,process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Sequential execution completed in ${c}ms`);}let u=e.map(y=>{let b=a.get(y.id);return b||{id:y.id,name:y.function.name,output:"Error: Result not found",success:false}}),p=Date.now()-i,d=u.reduce((y,b)=>y+(b.executionTime||0),0),m=d-p,h=d>0?d/p:1,g={totalTime:p,parallelTime:l,sequentialTime:c,timeSaved:m,speedup:h};return process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log("[ParallelExecutor] Performance Stats:"),console.log(` Total time: ${p}ms`),console.log(` Parallel time: ${l}ms`),console.log(` Sequential time: ${c}ms`),console.log(` Estimated sequential time: ${d}ms`),console.log(` Time saved: ${m}ms`),console.log(` Speedup: ${h.toFixed(2)}x`)),{results:u,stats:g}}getToolClassification(e){let t=r.isReadOnly(e),s=r.getMetadata(e);return {isReadOnly:t,category:s?.category||"unknown",canParallel:t}}static canExecuteInParallel(e){return e.every(t=>r.READ_ONLY_TOOLS.has(t))}static getReadOnlyTools(){return Array.from(r.READ_ONLY_TOOLS)}static getStateModifyingTools(){return Array.from(r.STATE_MODIFYING_TOOLS)}};var rs={environment:{zh:r=>`## \u73AF\u5883
|
|
1189
|
+
`),i=/[\u4e00-\u9fa5]/.test(s)?$n.systemZh:$n.system,o=await t.llmProvider.chat([{role:"system",content:i},{role:"user",content:$n.user(s)}],{model:t.model,temperature:.3});return se(o.choices[0]?.message?.content)||null}catch(s){return f.warn("MessageCompressor",`Batch LLM compression failed: ${s.message}`),null}}};new Ns;var Dg={debug:false,minRecentMessages:15,defaultTokenBudget:1e5,enableLLMCompression:true,llmTimeout:3e4},Yr=class{config;toolCompressor;messageCompressor;llmProvider;model;contextWindow;constructor(e){this.config={...Dg,...e},this.config.debug=this.config.debug||process.env.CLI_DEBUG==="1",this.toolCompressor=new Ut({debug:this.config.debug}),this.messageCompressor=new Ns({debug:this.config.debug,toolCompressor:this.toolCompressor,minRecentMessages:this.config.minRecentMessages});}setLLMProvider(e,t){this.llmProvider=e,this.model=t;}setContextWindow(e){this.contextWindow=e,this.config.debug&&f.info("UnifiedCompressor",`Context window set to: ${e}`);}registerToolCompressor(e){f.info("UnifiedCompressor","Custom tool compressor registered");}setMessageCompressor(e){this.messageCompressor=e,f.info("UnifiedCompressor","Custom message compressor set");}async compressHistory(e,t,s){let n=Date.now(),i=ze(e),o={llmProvider:s?.llmProvider||this.llmProvider,model:s?.model||this.model,tokenBudget:t,contextWindow:s?.contextWindow||this.contextWindow,iteration:s?.iteration,enableLLMCompression:s?.enableLLMCompression??this.config.enableLLMCompression,timeout:s?.timeout??this.config.llmTimeout,signal:s?.signal,debug:this.config.debug};if(this.config.debug&&f.debug("UnifiedCompressor",`\u5F00\u59CB\u538B\u7F29: ${e.length} \u6761\u6D88\u606F, ${i} tokens \u2192 \u9884\u7B97 ${t} tokens`),i<=t){let c=await this.compressLargeMessagesOnly(e,o);return this.config.debug&&f.debug("UnifiedCompressor",`\u5728\u9884\u7B97\u5185\uFF0C\u4EC5\u538B\u7F29\u5927\u6D88\u606F: ${c.savedTokens} tokens \u8282\u7701`),c}let a=await this.messageCompressor.compressMessages(e,o),l=Date.now()-n;return this.config.debug&&f.debug("UnifiedCompressor",`\u538B\u7F29\u5B8C\u6210 (${l}ms): ${a.originalCount} \u2192 ${a.compressedCount} \u6761, ${a.originalTokens} \u2192 ${a.compressedTokens} tokens (\u8282\u7701 ${a.savedTokens} tokens, ${(a.savedTokens/a.originalTokens*100).toFixed(1)}%)`),a}async compressLargeMessagesOnly(e,t){let s=ze(e),n=[],i=0,o=0;for(let l of e)if(mt(l)>2e3&&l.role!=="system"){let u=await this.messageCompressor.compressMessage(l,t);n.push(u.message),u.usedLLM?i++:u.compressionRatio<1&&o++;}else n.push(l);let a=ze(n);return {messages:n,originalCount:e.length,compressedCount:n.length,originalTokens:s,compressedTokens:a,savedTokens:s-a,stats:{droppedMessages:0,llmCompressedMessages:i,truncatedMessages:o,preservedMessages:e.length-i-o}}}async compressToolResult(e,t,s){let n={llmProvider:s?.llmProvider||this.llmProvider,model:s?.model||this.model,enableLLMCompression:s?.enableLLMCompression??this.config.enableLLMCompression,timeout:s?.timeout??this.config.llmTimeout,debug:this.config.debug};return (await this.toolCompressor.compress(e,t,n)).content}getStats(){return {config:this.config,hasLLMProvider:!!this.llmProvider}}};function $g(r){return r.replace(/\uFEFF/g,"").replace(/[“”]/g,'"').replace(/[‘’]/g,"'").replace(/,\s*([}\]])/g,"$1").trim()}function Ng(r){let e=r.trim();if(!e)return null;let t=e.match(/```(?:json)?\s*([\s\S]*?)\s*```/i);if(t?.[1])return t[1].trim();let s=e.indexOf("{"),n=e.lastIndexOf("}");return s>=0&&n>s?e.slice(s,n+1).trim():null}function Uc(r){try{let e=JSON.parse(r);return e&&typeof e=="object"&&!Array.isArray(e)?{ok:!0,value:e}:{ok:!1,error:"arguments should be a JSON object"}}catch(e){return {ok:false,error:e?.message||"invalid JSON"}}}function Fs(r){let e=(r||"").trim();if(!e)return {ok:true,args:{},raw:e,normalized:"{}",repaired:false};let t=Uc(e);if(t.ok)return {ok:true,args:t.value,raw:e,normalized:e,repaired:false};let s=Ng(e),n=$g(s||e),i=Uc(n);return i.ok?{ok:true,args:i.value,raw:e,normalized:n,repaired:n!==e,reason:t.error}:{ok:false,args:{},raw:e,normalized:n,repaired:n!==e,reason:i.error||t.error}}function Fg(r,e){if(typeof r!="string")return null;let t=r.trim();if(!t.startsWith("{"))return null;try{let s=JSON.parse(t);return !s||typeof s!="object"||s.tool!==e||typeof s.status!="string"?null:s.status}catch{return null}}var Xr=class r{static READ_ONLY_TOOLS=new Set(["readfile","search","search_files","list_directory","show_tree","analyze_code","search_symbol","get_definitions","get_references","git_status","git_diff","git_blame","git_branch_list"]);static STATE_MODIFYING_TOOLS=new Set(["write_file","edit_file","create_directory","delete_file","rename_file","apply_patch","execute_shell","execute_bash","execute_python","execute_javascript","git_commit","git_branch","run_tests","run_lint","run_format"]);static TOOL_METADATA=new Map([["readfile",{name:"readfile",isReadOnly:true,category:"read",description:"Read file contents"}],["search",{name:"search",isReadOnly:true,category:"read",description:"Search file contents"}],["search_files",{name:"search_files",isReadOnly:true,category:"read",description:"Search files by name"}],["list_directory",{name:"list_directory",isReadOnly:true,category:"read",description:"List directory contents"}],["show_tree",{name:"show_tree",isReadOnly:true,category:"read",description:"Show directory tree"}],["analyze_code",{name:"analyze_code",isReadOnly:true,category:"read",description:"Analyze code structure"}],["search_symbol",{name:"search_symbol",isReadOnly:true,category:"read",description:"Search symbols in index"}],["get_definitions",{name:"get_definitions",isReadOnly:true,category:"read",description:"Find symbol definitions"}],["get_references",{name:"get_references",isReadOnly:true,category:"read",description:"Find symbol references"}],["git_status",{name:"git_status",isReadOnly:true,category:"read",description:"Show git status"}],["git_diff",{name:"git_diff",isReadOnly:true,category:"read",description:"Show git diff"}],["git_blame",{name:"git_blame",isReadOnly:true,category:"read",description:"Show git blame"}],["git_branch_list",{name:"git_branch_list",isReadOnly:true,category:"read",description:"List git branches"}],["write_file",{name:"write_file",isReadOnly:false,category:"write",description:"Write file"}],["edit_file",{name:"edit_file",isReadOnly:false,category:"write",description:"Edit file"}],["create_directory",{name:"create_directory",isReadOnly:false,category:"write",description:"Create directory"}],["delete_file",{name:"delete_file",isReadOnly:false,category:"write",description:"Delete file"}],["rename_file",{name:"rename_file",isReadOnly:false,category:"write",description:"Rename file"}],["apply_patch",{name:"apply_patch",isReadOnly:false,category:"write",description:"Apply patch"}],["git_commit",{name:"git_commit",isReadOnly:false,category:"write",description:"Git commit"}],["git_branch",{name:"git_branch",isReadOnly:false,category:"write",description:"Git branch"}],["run_tests",{name:"run_tests",isReadOnly:false,category:"execute",description:"Run tests"}],["run_lint",{name:"run_lint",isReadOnly:false,category:"execute",description:"Run lint"}],["run_format",{name:"run_format",isReadOnly:false,category:"execute",description:"Run format"}],["execute_shell",{name:"execute_shell",isReadOnly:false,category:"execute",description:"Execute shell command"}],["execute_bash",{name:"execute_bash",isReadOnly:false,category:"execute",description:"Execute bash script"}],["execute_python",{name:"execute_python",isReadOnly:false,category:"execute",description:"Execute Python code"}],["execute_javascript",{name:"execute_javascript",isReadOnly:false,category:"execute",description:"Execute JavaScript code"}]]);static isReadOnly(e){return r.READ_ONLY_TOOLS.has(e)}static isStateModifying(e){return r.STATE_MODIFYING_TOOLS.has(e)}static getMetadata(e){return r.TOOL_METADATA.get(e)}analyzePlan(e,t,s){let n=[],i=[];for(let o of e){let a=o.function.name,l=t.find(p=>p.name===a),c=s?.parallelSafeTools.has(a)===true;(s?c:l?Wr(l)==="safe":r.isReadOnly(a))?n.push(o):i.push(o);}return {parallel:n,sequential:i,totalTools:e.length,parallelCount:n.length,sequentialCount:i.length}}async executeSingleTool(e,t,s){let n=Date.now();if(s?.aborted)return {id:e.id,name:e.function.name,output:"Error: Operation cancelled",success:false,executionTime:Date.now()-n};let i=t.find(o=>o.name===e.function.name);if(!i)return {id:e.id,name:e.function.name,output:`Error: Tool ${e.function.name} not found`,success:false,executionTime:Date.now()-n};try{let o=Fs(e.function.arguments);if(!o.ok)return {id:e.id,name:e.function.name,output:`Error: Invalid JSON arguments for ${e.function.name}: ${o.reason||"parse failed"}`,success:!1,executionTime:Date.now()-n};let a=await i.function(o.args,{signal:s}),l=!0;return Fg(a,e.function.name)==="error"&&(l=!1),s?.aborted?{id:e.id,name:e.function.name,output:"Error: Operation cancelled",success:!1,executionTime:Date.now()-n}:{id:e.id,name:e.function.name,output:a,success:l,executionTime:Date.now()-n}}catch(o){return o.name==="AbortError"||s?.aborted?{id:e.id,name:e.function.name,output:"Error: Operation cancelled",success:false,executionTime:Date.now()-n}:{id:e.id,name:e.function.name,output:`Error: ${o.message}`,success:false,executionTime:Date.now()-n}}}async execute(e,t,s,n){let i=Date.now(),o=dc(t),a=this.analyzePlan(e,t,o);process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log("[ParallelExecutor] Execution Plan:"),console.log(` Total: ${a.totalTools} tools`),console.log(` Parallel (read-only): ${a.parallelCount} tools`),console.log(` Sequential (state-modifying): ${a.sequentialCount} tools`));let l=new Map,c=0,u=0;if(a.parallel.length>0){let b=Date.now();process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Executing ${a.parallel.length} read-only tools in parallel...`);let w=a.parallel.map(x=>this.executeSingleTool(x,t,n).then(R=>(s&&s(R),R))),S=await Promise.all(w);c=Date.now()-b;for(let x of S)l.set(x.id,x);process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Parallel execution completed in ${c}ms`);}if(a.sequential.length>0){let b=Date.now();process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Executing ${a.sequential.length} state-modifying tools sequentially...`);for(let w of a.sequential){if(n?.aborted){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Execution interrupted before ${w.function.name}`);break}let S=await this.executeSingleTool(w,t,n);if(s&&s(S),l.set(S.id,S),n?.aborted){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Execution interrupted after ${w.function.name}`);break}}u=Date.now()-b,process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[ParallelExecutor] Sequential execution completed in ${u}ms`);}let p=e.map(b=>{let w=l.get(b.id);return w||{id:b.id,name:b.function.name,output:"Error: Result not found",success:false}}),d=Date.now()-i,m=p.reduce((b,w)=>b+(w.executionTime||0),0),h=m-d,g=m>0?m/d:1,y={totalTime:d,parallelTime:c,sequentialTime:u,timeSaved:h,speedup:g};return process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log("[ParallelExecutor] Performance Stats:"),console.log(` Total time: ${d}ms`),console.log(` Parallel time: ${c}ms`),console.log(` Sequential time: ${u}ms`),console.log(` Estimated sequential time: ${m}ms`),console.log(` Time saved: ${h}ms`),console.log(` Speedup: ${g.toFixed(2)}x`)),{results:p,stats:y}}getToolClassification(e){let t=r.isReadOnly(e),s=r.getMetadata(e);return {isReadOnly:t,category:s?.category||"unknown",canParallel:t}}static canExecuteInParallel(e){return e.every(t=>r.READ_ONLY_TOOLS.has(t))}static getReadOnlyTools(){return Array.from(r.READ_ONLY_TOOLS)}static getStateModifyingTools(){return Array.from(r.STATE_MODIFYING_TOOLS)}};var rs={environment:{zh:r=>`## \u73AF\u5883
|
|
1190
1190
|
- \u5DE5\u4F5C\u76EE\u5F55: ${r}
|
|
1191
1191
|
- Shell \u6BCF\u6B21\u8C03\u7528\u72EC\u7ACB\uFF0Ccd \u4E0D\u8DE8\u8C03\u7528\u6301\u7EED`,en:r=>`## Environment
|
|
1192
1192
|
- Working directory: ${r}
|
|
@@ -1212,8 +1212,8 @@ ${o}`}],{model:t.model,temperature:.2});return te(a.choices[0]?.message?.content
|
|
|
1212
1212
|
**Large file chunking** (when necessary):
|
|
1213
1213
|
1. Files >300 lines or 10KB \u2192 Write in chunks, each chunk <200 lines
|
|
1214
1214
|
2. First step write_file: Create skeleton structure
|
|
1215
|
-
3. Subsequent edit_file: Replace section by section (readfile before each edit!)`},toolResults:{zh:'## \u7406\u89E3\u5DE5\u5177\u7ED3\u679C\n\n- `write_file` / `edit_file` \u8FD4\u56DE\u7ED3\u6784\u5316\u7ED3\u679C\uFF1A\n - `"status": "success" + "final": true` \u2192 \u4FEE\u6539\u6210\u529F\uFF0C\u4E0D\u91CD\u590D\u64CD\u4F5C\n - `"status": "already_done"` \u2192 \u5DF2\u5B8C\u6210\uFF0C\u7EE7\u7EED\u4E0B\u4E00\u4E2A\u4EFB\u52A1\n - `"status": "error"` \u2192 \u8BFB\u53D6\u9519\u8BEF\u4FE1\u606F\u5E76\u4FEE\u590D\n- \u4FEE\u6539\u5B8C\u6210\u540E\u4F7F\u7528 `readfile` \u9A8C\u8BC1\u5173\u952E\u51FD\u6570/\u7C7B\u5185\u5BB9\n- readfile \u5931\u8D25 \u2192 \u6269\u5927\u8303\u56F4\u6216\u8C03\u6574\u5173\u952E\u8BCD\uFF0C\u518D\u5C1D\u8BD5',en:'## Understanding Tool Results\n\n- `write_file` / `edit_file` return structured results:\n - `"status": "success" + "final": true` \u2192 Modification successful, don\'t repeat\n - `"status": "already_done"` \u2192 Already complete, proceed to next task\n - `"status": "error"` \u2192 Read error message and fix\n- After modification, use `readfile` to verify key functions/classes\n- readfile fails \u2192 Expand scope or adjust keywords, then retry'},specializedTools:{zh:"## \u4E13\u7528\u5DE5\u5177\n\n- **Git**\uFF1A`git_status` / `git_diff` / `git_blame` / `git_branch_list` / `git_branch` / `git_commit`\n- **\u6587\u4EF6\u64CD\u4F5C**\uFF1A`delete_file` / `rename_file` / `apply_patch`\n- **\u5BFC\u822A**\uFF1A`search_symbol` / `get_definitions` / `get_references`\uFF08\u7D22\u5F15\u53EF\u7528\u65F6\u4F18\u5148\uFF09\n- **\u6D4B\u8BD5**\uFF1A`run_tests` / `run_lint` / `run_format`\uFF08\u907F\u514D\u7528 shell \u4EE3\u66FF\uFF09\n- \u82E5\u89E6\u8FBE\u8FED\u4EE3/\u5DE5\u5177/\u8FD0\u884C\u65F6\u95F4\u9650\u5236\uFF0C\u5148\u603B\u7ED3\u8FDB\u5EA6\u5E76\u8BE2\u95EE\u662F\u5426\u7EE7\u7EED",en:"## Specialized Tools\n\n- **Git**: `git_status` / `git_diff` / `git_blame` / `git_branch_list` / `git_branch` / `git_commit`\n- **File operations**: `delete_file` / `rename_file` / `apply_patch`\n- **Navigation**: `search_symbol` / `get_definitions` / `get_references` (prefer when index available)\n- **Tests**: `run_tests` / `run_lint` / `run_format` (avoid using shell instead)\n- If hitting iteration/tool/runtime limits, summarize progress and ask to continue"},errorRecovery:{zh:"## \u9519\u8BEF\u6062\u590D\n\n- `edit_file` \u5931\u8D25\uFF1A\u91CD\u65B0 `readfile(path, for_edit=true)`\uFF0C\u7F29\u5C0F `old_string`\uFF0C\u5FC5\u8981\u65F6\u52A0 `change_context`\n- \u8FDE\u7EED\u5931\u8D25 2 \u6B21\uFF1A\u6539\u7528 `write_file` \u91CD\u5199\u6574\u4E2A\u6587\u4EF6\n- \u8FDE\u7EED\u5931\u8D25 3 \u6B21\uFF1A\u505C\u6B62\u5F53\u524D\u65B9\u6CD5\uFF0C\u62A5\u544A\u7ED9\u7528\u6237\n- \u7981\u6B62\u4F7F\u7528 sed/awk \u7B49 shell \u547D\u4EE4\u7F16\u8F91\u6587\u4EF6",en:"## Error Recovery\n\n- `edit_file` fails: Re-`readfile(path, for_edit=true)`, reduce `old_string`, add `change_context` if needed\n- 2 consecutive fails: Use `write_file` to rewrite entire file\n- 3 consecutive fails: Stop current approach, report to user\n- Never use sed/awk or other shell commands to edit files"},outputFormat:{zh:"## \u8F93\u51FA\u8981\u6C42\n\n- \u7528\u4E2D\u6587\u56DE\u590D\n- \u64CD\u4F5C\u540E\u7B80\u77ED\u786E\u8BA4\n- \u4E0D\u521B\u5EFA\u7528\u6237\u672A\u8981\u6C42\u7684\u6587\u4EF6\n- \u9047\u5230\u9519\u8BEF\u4F18\u5148\u7528 readfile \u9A8C\u8BC1\uFF0C\u4E0D\u76F2\u76EE\u91CD\u590D\u64CD\u4F5C\n\n### Markdown \u683C\u5F0F\u89C4\u8303\n- \u6807\u9898\u5FC5\u987B\u5728 # \u540E\u52A0\u7A7A\u683C\uFF1A`### \u6807\u9898` \u2713\uFF0C`###\u6807\u9898` \u2717\n- \u7C97\u4F53/\u659C\u4F53\u6807\u8BB0\u4E0E\u6587\u5B57\u4E4B\u95F4\u4E0D\u52A0\u7A7A\u683C\uFF1A`**\u7C97\u4F53**` \u2713\n- \u5217\u8868\u9879 `-` \u540E\u5FC5\u987B\u52A0\u7A7A\u683C\uFF1A`- \u9879\u76EE` \u2713",en:"## Output Requirements\n\n- Reply in English\n- Brief confirmation after operations\n- Don't create unrequested files\n- When encountering errors, verify with readfile first, don't blindly repeat operations\n\n### Markdown Format Rules\n- Headings must have space after #: `### Title` \u2713, `###Title` \u2717\n- Bold/italic markers without space to text: `**bold**` \u2713\n- List items must have space after `-`: `- item` \u2713"}};function
|
|
1216
|
-
`)}var
|
|
1215
|
+
3. Subsequent edit_file: Replace section by section (readfile before each edit!)`},toolResults:{zh:'## \u7406\u89E3\u5DE5\u5177\u7ED3\u679C\n\n- `write_file` / `edit_file` \u8FD4\u56DE\u7ED3\u6784\u5316\u7ED3\u679C\uFF1A\n - `"status": "success" + "final": true` \u2192 \u4FEE\u6539\u6210\u529F\uFF0C\u4E0D\u91CD\u590D\u64CD\u4F5C\n - `"status": "already_done"` \u2192 \u5DF2\u5B8C\u6210\uFF0C\u7EE7\u7EED\u4E0B\u4E00\u4E2A\u4EFB\u52A1\n - `"status": "error"` \u2192 \u8BFB\u53D6\u9519\u8BEF\u4FE1\u606F\u5E76\u4FEE\u590D\n- \u4FEE\u6539\u5B8C\u6210\u540E\u4F7F\u7528 `readfile` \u9A8C\u8BC1\u5173\u952E\u51FD\u6570/\u7C7B\u5185\u5BB9\n- readfile \u5931\u8D25 \u2192 \u6269\u5927\u8303\u56F4\u6216\u8C03\u6574\u5173\u952E\u8BCD\uFF0C\u518D\u5C1D\u8BD5',en:'## Understanding Tool Results\n\n- `write_file` / `edit_file` return structured results:\n - `"status": "success" + "final": true` \u2192 Modification successful, don\'t repeat\n - `"status": "already_done"` \u2192 Already complete, proceed to next task\n - `"status": "error"` \u2192 Read error message and fix\n- After modification, use `readfile` to verify key functions/classes\n- readfile fails \u2192 Expand scope or adjust keywords, then retry'},specializedTools:{zh:"## \u4E13\u7528\u5DE5\u5177\n\n- **Git**\uFF1A`git_status` / `git_diff` / `git_blame` / `git_branch_list` / `git_branch` / `git_commit`\n- **\u6587\u4EF6\u64CD\u4F5C**\uFF1A`delete_file` / `rename_file` / `apply_patch`\n- **\u5BFC\u822A**\uFF1A`search_symbol` / `get_definitions` / `get_references`\uFF08\u7D22\u5F15\u53EF\u7528\u65F6\u4F18\u5148\uFF09\n- **\u6D4B\u8BD5**\uFF1A`run_tests` / `run_lint` / `run_format`\uFF08\u907F\u514D\u7528 shell \u4EE3\u66FF\uFF09\n- \u82E5\u89E6\u8FBE\u8FED\u4EE3/\u5DE5\u5177/\u8FD0\u884C\u65F6\u95F4\u9650\u5236\uFF0C\u5148\u603B\u7ED3\u8FDB\u5EA6\u5E76\u8BE2\u95EE\u662F\u5426\u7EE7\u7EED",en:"## Specialized Tools\n\n- **Git**: `git_status` / `git_diff` / `git_blame` / `git_branch_list` / `git_branch` / `git_commit`\n- **File operations**: `delete_file` / `rename_file` / `apply_patch`\n- **Navigation**: `search_symbol` / `get_definitions` / `get_references` (prefer when index available)\n- **Tests**: `run_tests` / `run_lint` / `run_format` (avoid using shell instead)\n- If hitting iteration/tool/runtime limits, summarize progress and ask to continue"},errorRecovery:{zh:"## \u9519\u8BEF\u6062\u590D\n\n- `edit_file` \u5931\u8D25\uFF1A\u91CD\u65B0 `readfile(path, for_edit=true)`\uFF0C\u7F29\u5C0F `old_string`\uFF0C\u5FC5\u8981\u65F6\u52A0 `change_context`\n- \u8FDE\u7EED\u5931\u8D25 2 \u6B21\uFF1A\u6539\u7528 `write_file` \u91CD\u5199\u6574\u4E2A\u6587\u4EF6\n- \u8FDE\u7EED\u5931\u8D25 3 \u6B21\uFF1A\u505C\u6B62\u5F53\u524D\u65B9\u6CD5\uFF0C\u62A5\u544A\u7ED9\u7528\u6237\n- \u7981\u6B62\u4F7F\u7528 sed/awk \u7B49 shell \u547D\u4EE4\u7F16\u8F91\u6587\u4EF6",en:"## Error Recovery\n\n- `edit_file` fails: Re-`readfile(path, for_edit=true)`, reduce `old_string`, add `change_context` if needed\n- 2 consecutive fails: Use `write_file` to rewrite entire file\n- 3 consecutive fails: Stop current approach, report to user\n- Never use sed/awk or other shell commands to edit files"},outputFormat:{zh:"## \u8F93\u51FA\u8981\u6C42\n\n- \u7528\u4E2D\u6587\u56DE\u590D\n- \u64CD\u4F5C\u540E\u7B80\u77ED\u786E\u8BA4\n- \u4E0D\u521B\u5EFA\u7528\u6237\u672A\u8981\u6C42\u7684\u6587\u4EF6\n- \u9047\u5230\u9519\u8BEF\u4F18\u5148\u7528 readfile \u9A8C\u8BC1\uFF0C\u4E0D\u76F2\u76EE\u91CD\u590D\u64CD\u4F5C\n\n### Markdown \u683C\u5F0F\u89C4\u8303\n- \u6807\u9898\u5FC5\u987B\u5728 # \u540E\u52A0\u7A7A\u683C\uFF1A`### \u6807\u9898` \u2713\uFF0C`###\u6807\u9898` \u2717\n- \u7C97\u4F53/\u659C\u4F53\u6807\u8BB0\u4E0E\u6587\u5B57\u4E4B\u95F4\u4E0D\u52A0\u7A7A\u683C\uFF1A`**\u7C97\u4F53**` \u2713\n- \u5217\u8868\u9879 `-` \u540E\u5FC5\u987B\u52A0\u7A7A\u683C\uFF1A`- \u9879\u76EE` \u2713",en:"## Output Requirements\n\n- Reply in English\n- Brief confirmation after operations\n- Don't create unrequested files\n- When encountering errors, verify with readfile first, don't blindly repeat operations\n\n### Markdown Format Rules\n- Headings must have space after #: `### Title` \u2713, `###Title` \u2717\n- Bold/italic markers without space to text: `**bold**` \u2713\n- List items must have space after `-`: `- item` \u2713"}};function jc(r,e="zh"){let t=[];return t.push(rs.environment[e](r)),t.push(""),t.push(rs.toolUsage[e]),t.push(""),t.push(rs.editRules[e]),t.push(""),t.push(rs.toolResults[e]),t.push(""),t.push(rs.specializedTools[e]),t.push(""),t.push(rs.errorRecovery[e]),t.push(""),t.push(rs.outputFormat[e]),t.join(`
|
|
1216
|
+
`)}var Ug={identity:{zh:`\u4F60\u662F Neox AI \u52A9\u624B\uFF0C\u53EF\u4EE5\u5E2E\u52A9\u7528\u6237\u5B8C\u6210\u5404\u79CD\u4EFB\u52A1\u3002
|
|
1217
1217
|
|
|
1218
1218
|
**\u6838\u5FC3\u539F\u5219**\uFF1A
|
|
1219
1219
|
- \u5FEB\u901F\u7406\u89E3\u7528\u6237\u610F\u56FE
|
|
@@ -1259,9 +1259,9 @@ For complex multi-step tasks, use the update_plan tool to create an execution pl
|
|
|
1259
1259
|
- Only one step can be in_progress at a time
|
|
1260
1260
|
- Update plan status as work progresses
|
|
1261
1261
|
|
|
1262
|
-
Example scenarios: refactoring code, adding features, project migration, performance optimization, etc.`}};function
|
|
1262
|
+
Example scenarios: refactoring code, adding features, project migration, performance optimization, etc.`}};function Gc(r="zh"){return Ug.identity[r]}function Zr(r){let{workDir:e,language:t="zh"}=r,s=[],n=t==="zh"?`\u5DE5\u4F5C\u76EE\u5F55: ${e}
|
|
1263
1263
|
Shell \u6BCF\u6B21\u8C03\u7528\u72EC\u7ACB\uFF0Ccd \u4E0D\u8DE8\u8C03\u7528\u6301\u7EED`:`Working directory: ${e}
|
|
1264
|
-
Shell calls are independent; cd does not persist across calls`;s.push(n),s.push(""),s.push(
|
|
1264
|
+
Shell calls are independent; cd does not persist across calls`;s.push(n),s.push(""),s.push(Gc(t)),s.push(""),s.push(jc(e,t)),s.push("");let i=Zt.getSkillsForPrompt();if(i){let o=t==="zh"?`## \u53EF\u7528\u6280\u80FD (Skills)
|
|
1265
1265
|
|
|
1266
1266
|
\u4EE5\u4E0B\u662F\u5DF2\u6CE8\u518C\u7684\u6280\u80FD\u3002\u5F53\u7528\u6237\u7684\u610F\u56FE\u5339\u914D\u67D0\u4E2A\u6280\u80FD\u65F6\uFF0C\u4F7F\u7528 \`use_skill\` \u5DE5\u5177\u6765\u83B7\u53D6\u8BE5\u6280\u80FD\u7684\u8BE6\u7EC6\u6307\u4EE4\uFF0C\u7136\u540E\u9075\u5FAA\u6307\u4EE4\u5B8C\u6210\u4EFB\u52A1\u3002
|
|
1267
1267
|
|
|
@@ -1274,7 +1274,7 @@ Below are registered skills. When user intent matches a skill, use the \`use_ski
|
|
|
1274
1274
|
**Important**: Don't ask "do you want to use /commit skill?", instead automatically call \`use_skill\` tool based on user intent.
|
|
1275
1275
|
|
|
1276
1276
|
`;s.push(o+i),s.push("");}return s.push(t==="zh"?"\u5F00\u59CB\u5DE5\u4F5C\u3002":"Start working."),s.join(`
|
|
1277
|
-
`)}var
|
|
1277
|
+
`)}var jg=`You are Codex, based on GPT-5. You are running as a coding agent in the Codex CLI on a user's computer.
|
|
1278
1278
|
|
|
1279
1279
|
## General
|
|
1280
1280
|
|
|
@@ -1390,7 +1390,7 @@ You are producing plain text that will later be styled by the CLI. Follow these
|
|
|
1390
1390
|
* Optionally include line/column (1\u2011based): :line[:column] or #Lline[Ccolumn] (column defaults to 1).
|
|
1391
1391
|
* Do not use URIs like file://, vscode://, or https://.
|
|
1392
1392
|
* Do not provide range of lines
|
|
1393
|
-
* Examples: src/app.ts, src/app.ts:42, b/server/index.js#L10, C:\\repo\\project\\main.rs:12:5`;function
|
|
1393
|
+
* Examples: src/app.ts, src/app.ts:42, b/server/index.js#L10, C:\\repo\\project\\main.rs:12:5`;function Yo(r){let{workDir:e,language:t="zh",useCodexStyle:s=false}=r;return s?jg:Zr({workDir:e,language:t})}function Bc(r,e,t="zh"){return t==="zh"?`\u6587\u4EF6\u7F16\u8F91\u5931\u8D25: ${r}
|
|
1394
1394
|
|
|
1395
1395
|
\u9519\u8BEF\u4FE1\u606F: ${e}
|
|
1396
1396
|
|
|
@@ -1404,7 +1404,7 @@ Error: ${e}
|
|
|
1404
1404
|
Suggestions:
|
|
1405
1405
|
1. Re-read with readfile(path, for_edit=true)
|
|
1406
1406
|
2. Ensure old_string matches exactly (spaces, newlines)
|
|
1407
|
-
3. If failing repeatedly, consider rewriting with write_file`}
|
|
1407
|
+
3. If failing repeatedly, consider rewriting with write_file`}me();me();var Xo=class{history=[];maxHistory=20;interventionCount=0;hashArgs(e,t){let s={};e==="readfile"?Object.assign(s,t):e==="edit_file"||e==="Edit"?(s.file_path=t.file_path||t.path,t.old_string&&typeof t.old_string=="string"&&(s.old_string_prefix=t.old_string.substring(0,200))):e==="write_file"||e==="Write"?s.file_path=t.file_path||t.path:t.file_path?s.file_path=t.file_path:t.path?s.path=t.path:t.directory?s.directory=t.directory:Object.assign(s,t);let n=`${e}:${JSON.stringify(s)}`;return createHash("sha256").update(n).digest("hex").substring(0,16)}record(e,t,s){let n=this.hashArgs(e,t),i=t.file_path||t.path||t.directory;process.env.CLI_DEBUG==="1"&&f.debug("LOOP_DETECTOR",`Recording ${e}:`,{hash:n.substring(0,8),argsPreview:JSON.stringify(t).substring(0,150),historyLengthBefore:this.history.length}),this.history.push({hash:n,toolName:e,args:t,timestamp:Date.now(),resultStatus:s,filePath:i}),this.history.length>this.maxHistory&&this.history.shift();}updateLastStatus(e){this.history.length>0&&(this.history[this.history.length-1].resultStatus=e);}detect(e,t){let s=this.hashArgs(e,t),n=this.history.filter(i=>i.hash===s);return process.env.CLI_DEBUG==="1"&&f.debug("LOOP_DETECTOR",`Detecting loop for ${e}:`,{hash:s.substring(0,8),historyCount:this.history.length,sameHashCount:n.length,args:JSON.stringify(t).substring(0,100)}),n.length>=4?4:n.length>=3?3:n.length>=2?2:0}wasLastSuccessful(e,t){let s=this.hashArgs(e,t),n=[...this.history].reverse().find(i=>i.hash===s);return n?.resultStatus==="success"||n?.resultStatus==="already_done"}getLastFilePath(e,t){let s=this.hashArgs(e,t);return [...this.history].reverse().find(i=>i.hash===s)?.filePath}didSwitchTool(e){return this.history.length<2?true:this.history[this.history.length-1]?.toolName!==e}incrementIntervention(){return ++this.interventionCount}getInterventionCount(){return this.interventionCount}generateIntervention(e,t,s){let n=this.getLastFilePath(t,s)||s.file_path||s.path||s.directory,i=this.wasLastSuccessful(t,s),o=this.getVerifyCommand(t,n),a=this.getAlternativeAction(t,n);switch(e){case 2:return {level:e,wasSuccessful:i,shouldTerminate:false,message:`
|
|
1408
1408
|
[SYSTEM NOTICE]
|
|
1409
1409
|
You have called "${t}" ${this.getCallCount(t,s)} times with similar arguments.
|
|
1410
1410
|
${i?"\u26A0\uFE0F Previous calls already returned SUCCESS.":""}
|
|
@@ -1440,7 +1440,7 @@ Please:
|
|
|
1440
1440
|
- Check if the file/path exists
|
|
1441
1441
|
- Verify your approach
|
|
1442
1442
|
- Try a different method
|
|
1443
|
-
`.trim()};default:return {level:0,shouldTerminate:false,message:""}}}getVerifyCommand(e,t){return e==="readfile"?t?"Use search to locate specific content, or list_directory to check if file exists":"":e==="write_file"||e==="Write"||e==="edit_file"||e==="Edit"?t?`Use readfile "${t}" to verify the changes`:"":e==="search"||e==="search_files"||e==="Glob"?"Try a different search pattern or read the file directly":e==="execute_shell"||e==="execute_bash"||e==="Bash"?"Check the command output from previous calls":""}getAlternativeAction(e,t){return e==="readfile"?"The file content should already be in your context from previous reads - use it directly":e==="write_file"||e==="Write"?"The file was already written - verify with readfile if needed":e==="edit_file"||e==="Edit"?"The edit may have already been applied - use readfile to check current content":e==="search"||e==="search_files"||e==="Glob"?"Search results should already be available - try a different pattern if not found":"Review the output from previous calls before retrying"}getCallCount(e,t){let s=this.hashArgs(e,t);return this.history.filter(n=>n.hash===s).length}reset(){this.history=[],this.interventionCount=0;}getHistory(){return [...this.history]}getRecentDuplicates(){let e=new Map;for(let t of this.history){let s=`${t.toolName}:${t.hash}`;e.set(s,(e.get(s)||0)+1);}return e}};function
|
|
1443
|
+
`.trim()};default:return {level:0,shouldTerminate:false,message:""}}}getVerifyCommand(e,t){return e==="readfile"?t?"Use search to locate specific content, or list_directory to check if file exists":"":e==="write_file"||e==="Write"||e==="edit_file"||e==="Edit"?t?`Use readfile "${t}" to verify the changes`:"":e==="search"||e==="search_files"||e==="Glob"?"Try a different search pattern or read the file directly":e==="execute_shell"||e==="execute_bash"||e==="Bash"?"Check the command output from previous calls":""}getAlternativeAction(e,t){return e==="readfile"?"The file content should already be in your context from previous reads - use it directly":e==="write_file"||e==="Write"?"The file was already written - verify with readfile if needed":e==="edit_file"||e==="Edit"?"The edit may have already been applied - use readfile to check current content":e==="search"||e==="search_files"||e==="Glob"?"Search results should already be available - try a different pattern if not found":"Review the output from previous calls before retrying"}getCallCount(e,t){let s=this.hashArgs(e,t);return this.history.filter(n=>n.hash===s).length}reset(){this.history=[],this.interventionCount=0;}getHistory(){return [...this.history]}getRecentDuplicates(){let e=new Map;for(let t of this.history){let s=`${t.toolName}:${t.hash}`;e.set(s,(e.get(s)||0)+1);}return e}};function Wc(){return new Xo}var Us=class{config;toolPermissions=new Map;permissionMemory=new Map;constructor(e={}){this.config=e;}setToolPermission(e){this.toolPermissions.set(e.toolName,e);}setToolPermissions(e){e.forEach(t=>this.setToolPermission(t));}async checkPermission(e,t){let s=e.name,n=this.getToolCategory(e),i=this.getToolPermission(e);if(i==="deny")return {allowed:false,source:"config",reason:this.toolPermissions.get(s)?.reason||`Tool "${s}" is denied`};if(i==="allow")return {allowed:true,source:"config"};let o=this.checkMemory(s);if(o)return {allowed:o.decision,source:"remembered",reason:o.decision?void 0:"User previously denied this tool"};if(!this.config.approvalHandler)return {allowed:true,source:"config",reason:"No approval handler configured - auto-approved"};try{let a=this.toolPermissions.get(s),l=await this.config.approvalHandler({toolName:s,toolCategory:n,args:t,reason:a?.reason,allowRemember:a?.allowRemember??!0});return l.remember&&this.saveMemory(s,l.approved),{allowed:l.approved,source:"user",reason:l.approved?void 0:"User denied approval",remember:l.remember}}catch(a){return {allowed:false,source:"config",reason:`Approval handler failed: ${a instanceof Error?a.message:String(a)}`}}}getToolPermission(e){let t=this.toolPermissions.get(e.name);return t?t.permission:e.permission?.defaultPermission?e.permission.defaultPermission:this.config.defaultPermission??"ask"}getToolCategory(e){return e.permission?.category?e.permission.category:this.inferToolCategory(e.name)}inferToolCategory(e){let t=e.toLowerCase();return t.includes("read")||t.includes("grep")||t.includes("glob")||t.includes("search")||t.includes("list")||t.includes("show")?"read":t.includes("write")||t.includes("edit")||t.includes("create")||t.includes("delete")||t.includes("update")?"write":t.includes("bash")||t.includes("exec")||t.includes("run")||t.includes("command")?"execute":t.includes("fetch")||t.includes("request")||t.includes("api")||t.includes("http")||t.includes("download")?"network":"system"}checkMemory(e){let t=this.permissionMemory.get(e);return t?t.expiresAt&&Date.now()>t.expiresAt?(this.permissionMemory.delete(e),null):t:null}saveMemory(e,t){let s=this.config.memoryExpirationMs?Date.now()+this.config.memoryExpirationMs:void 0;this.permissionMemory.set(e,{toolName:e,decision:t,timestamp:Date.now(),expiresAt:s});}clearMemory(e){e?this.permissionMemory.delete(e):this.permissionMemory.clear();}setApprovalHandler(e){this.config.approvalHandler=e;}};var jt=class{static strategies=new Map;static register(e){this.strategies.set(e.mode,e);}static getStrategy(e){let t=this.strategies.get(e);if(!t)throw new Error(`No strategy registered for mode: ${e}`);return t}static getAllModes(){return Array.from(this.strategies.keys())}};var Nn=class{mode="ask";filterTools(e){return e.filter(t=>this.isReadOnlyTool(t))}getSystemPrompt(){return `You are in ASK mode (read-only). You can:
|
|
1444
1444
|
- Read files and search code
|
|
1445
1445
|
- Analyze and understand the codebase
|
|
1446
1446
|
- Answer questions about the project
|
|
@@ -1448,7 +1448,7 @@ Please:
|
|
|
1448
1448
|
|
|
1449
1449
|
You CANNOT make any changes. If the user needs edits, inform them that you are in read-only mode and suggest they switch to AGENT mode.
|
|
1450
1450
|
|
|
1451
|
-
Available operations: Reading, Searching, Analyzing, Exploring.`}shouldAutoApprove(){return true}getDescription(){return "Read-only mode - Analyze and explore code without making changes"}getIcon(){return "\u{1F512}"}isReadOnlyTool(e){if(e.permission?.allowInAskMode===true)return true;if(e.permission?.allowInAskMode===false)return false;if(e.permission?.category)return e.permission.category==="read";let t=e.name.toLowerCase();return ["read","grep","glob","search","list","show","get","fetch","find","view","cat","ls","describe","inspect","analyze","check"].some(n=>t.includes(n))}};var
|
|
1451
|
+
Available operations: Reading, Searching, Analyzing, Exploring.`}shouldAutoApprove(){return true}getDescription(){return "Read-only mode - Analyze and explore code without making changes"}getIcon(){return "\u{1F512}"}isReadOnlyTool(e){if(e.permission?.allowInAskMode===true)return true;if(e.permission?.allowInAskMode===false)return false;if(e.permission?.category)return e.permission.category==="read";let t=e.name.toLowerCase();return ["read","grep","glob","search","list","show","get","fetch","find","view","cat","ls","describe","inspect","analyze","check"].some(n=>t.includes(n))}};var Un=class{mode="agent";filterTools(e){return e}getSystemPrompt(){return `You are in AGENT mode (standard). You have access to:
|
|
1452
1452
|
- Read and analyze the codebase
|
|
1453
1453
|
- Make file edits and create new files
|
|
1454
1454
|
- Run commands and scripts
|
|
@@ -1459,7 +1459,7 @@ Some dangerous operations may require user approval before execution. When reque
|
|
|
1459
1459
|
- Mention any potential risks
|
|
1460
1460
|
- Wait for user confirmation before proceeding
|
|
1461
1461
|
|
|
1462
|
-
Available operations: All tools (with approval for dangerous operations).`}shouldAutoApprove(){return false}getDescription(){return "Standard mode - Full access with approval for dangerous operations"}getIcon(){return "\u2699\uFE0F"}};var
|
|
1462
|
+
Available operations: All tools (with approval for dangerous operations).`}shouldAutoApprove(){return false}getDescription(){return "Standard mode - Full access with approval for dangerous operations"}getIcon(){return "\u2699\uFE0F"}};var jn=class{mode="auto";filterTools(e){return e}getSystemPrompt(){return `You are in AUTO mode (automatic). You have full access to:
|
|
1463
1463
|
- Read and write files
|
|
1464
1464
|
- Execute commands
|
|
1465
1465
|
- Make changes to the project
|
|
@@ -1473,33 +1473,33 @@ All operations will execute automatically without user confirmation. You should:
|
|
|
1473
1473
|
|
|
1474
1474
|
\u26A0\uFE0F Important: Since there's no approval step, double-check your actions before executing.
|
|
1475
1475
|
|
|
1476
|
-
Available operations: All tools (auto-approved).`}shouldAutoApprove(){return true}getDescription(){return "Automatic mode - All operations execute without approval (use with caution)"}getIcon(){return "\u26A1"}};jt.register(new
|
|
1476
|
+
Available operations: All tools (auto-approved).`}shouldAutoApprove(){return true}getDescription(){return "Automatic mode - All operations execute without approval (use with caution)"}getIcon(){return "\u26A1"}};jt.register(new Nn);jt.register(new Un);jt.register(new jn);function Zo(r){return jt.getStrategy(r)}var zc=2e4,Bg=15e3;function Vc(r,e){let t=process.env[r];if(!t)return e;let s=Number(t);return !Number.isFinite(s)||s<=0?e:Math.floor(s)}function qc(r,e){let t=r??e;return t===0||t===1/0?null:!Number.isFinite(t)||t<0?e:Math.floor(t)}function Qr(){let r=new Error("Request aborted");return r.name="AbortError",r.code="ERR_CANCELED",r.category="canceled",r}async function Jc(r,e){if(r?.aborted)throw Qr();return e()}function Wg(r,e){let t=Math.round(e/1e3),s=new Error(r==="first_chunk"?`Stream timeout: no response for ${t}s`:`Stream timeout: no data for ${t}s`);return s.code="STREAM_TIMEOUT",s.category="retryable_network",s.isNetworkInterrupt=true,s.streamTimeoutPhase=r,s.timeoutMs=e,s}var Hg=Vc("NEOX_STREAM_FIRST_CHUNK_TIMEOUT_MS",6e4),zg=Vc("NEOX_STREAM_CHUNK_TIMEOUT_MS",18e4),qg=process.env.NEOX_STREAM_WATCHDOG_DISABLED==="1";function Kc(r,e=Bg){if(!r||r.length<=e)return r;let t=r.split(`
|
|
1477
1477
|
`).length,s=r.length,n=Math.floor(e*.4),i=Math.floor(e*.4),o=n,a=r.length-i;for(;o>0&&(r.charCodeAt(o)&192)===128;)o--;for(;a<r.length&&(r.charCodeAt(a)&192)===128;)a++;let l=r.slice(0,o),c=r.slice(a),p=`
|
|
1478
1478
|
|
|
1479
1479
|
\u2026[${s-l.length-c.length} chars truncated, total ${t} lines]\u2026
|
|
1480
1480
|
|
|
1481
|
-
`;return l+p+c}var Xr=class{llmProvider;providerName;model;tools;memory;config;agentName;agentDescription;instructions;contextInjection;userData;plannerMode;inputGuardrails=[];outputGuardrails=[];toolInputGuardrails=[];toolOutputGuardrails=[];structuredOutput;structuredValidator;maxInputTokensOverride;maxInputTokens;minHistoryMessages;parallelExecutor;unifiedCompressor;compressionMode;toolMetricsHistory=[];workspacePath;disableSystemPrompt;runContext;permissionManager;modeStrategy;currentMode;loopDetector;enablePlanMode;constructor(e){if(this.llmProvider=e.llmProvider,this.providerName=e.providerName,this.model=e.model,this.tools=e.tools,this.memory=e.memory,this.config=e.config,this.agentName=e.agentName||"DefaultAgent",this.agentDescription=e.agentDescription||"",this.instructions=e.instructions,this.contextInjection=e.contextInjection,this.userData=e.userData,this.plannerMode=e.plannerMode??false,this.structuredOutput=e.structuredOutput,this.maxInputTokensOverride=e.maxInputTokensOverride,this.maxInputTokens=this.computeMaxInputTokens(e.contextWindow,e.tailTokenBudget,this.maxInputTokensOverride),this.minHistoryMessages=Math.max(1,e.minHistoryMessages??6),e.structuredOutput&&(this.structuredValidator=new qr(e.structuredOutput)),this.inputGuardrails=e.inputGuardrails||[],this.outputGuardrails=e.outputGuardrails||[],this.toolInputGuardrails=e.toolInputGuardrails||[],this.toolOutputGuardrails=e.toolOutputGuardrails||[],this.parallelExecutor=new Kr,this.compressionMode=e.compressionMode??"sync",this.workspacePath=e.workspacePath,this.unifiedCompressor=new Jr({debug:process.env.CLI_DEBUG==="1",minRecentMessages:this.minHistoryMessages,enableLLMCompression:true}),this.disableSystemPrompt=e.disableSystemPrompt??false,this.unifiedCompressor.setLLMProvider(this.llmProvider,this.model),e.contextWindow&&this.unifiedCompressor.setContextWindow(e.contextWindow),this.currentMode=e.config.mode??"agent",this.modeStrategy=Vo(this.currentMode),this.permissionManager=e.permissionManager??new Fs({defaultPermission:"ask"}),this.loopDetector=Nc(),this.enablePlanMode=e.enablePlanMode??true,e.approvalHandler){let t=e.approvalHandler;this.permissionManager.setApprovalHandler(async s=>({approved:await t({id:"",name:s.toolName,args:s.args}),remember:false}));}}setApprovalHandler(e){if(!e){this.permissionManager.setApprovalHandler(void 0);return}this.permissionManager.setApprovalHandler(async t=>({approved:await e({id:"",name:t.toolName,args:t.args}),remember:false}));}setMode(e){this.currentMode=e,this.modeStrategy=Vo(e),f.info("Runner",`Mode switched to: ${e}`);}getMode(){return this.currentMode}getPermissionManager(){return this.permissionManager}computeMaxInputTokens(e,t,s){if(s&&s>0)return s;let i=e&&e>0?e:19e4,o=.7,a=Math.floor(i*o),l=Math.min(t??Uc,Math.floor(i*.1)),c=Math.max(2e3,a-l);if(process.env.CLI_DEBUG==="1"||process.env.CLI_DEBUG_CONSOLE==="1"){let u=`[Context] maxInputTokens=${c} (contextWindow=${i}, override=${s}, tailBudget=${t??Uc}, safety=${o})`;console.log(u);}return c}async*withStreamWatchdog(e,t){if(Ng){for await(let o of e)yield o;return}let s=e[Symbol.asyncIterator](),n=t?new Promise((o,a)=>{t.aborted?a(Yr()):t.addEventListener("abort",()=>a(Yr()),{once:true});}):null,i=false;for(;;){if(t?.aborted){if(s.return)try{await s.return();}catch{}throw Yr()}let o=i?$g:Dg,a=null,l=new Promise((c,u)=>{a=setTimeout(()=>{u(Lg(i?"idle":"first_chunk",o));},o);});try{let c=await Promise.race(n?[s.next(),l,n]:[s.next(),l]);if(a&&clearTimeout(a),c.done)return;i=!0,yield c.value;}catch(c){if(a&&clearTimeout(a),s.return)try{await s.return();}catch{}throw c?.code==="STREAM_TIMEOUT"&&f.warn("RUNNER",`[watchdog] ${c.message}`),c}}}async applyContextWindow(e=0){if(!this.maxInputTokens)return null;let t=this.memory.getMessagesForLLM(),s=await this.unifiedCompressor.compressHistory(t,this.maxInputTokens,{iteration:e,enableLLMCompression:true});if(s.stats.droppedMessages>0||s.stats.llmCompressedMessages>0){this.memory.setMessages(s.messages);let n=this.compressionMode==="async"?"Async":"Sync",i=(s.originalTokens/1e3).toFixed(1),o=(s.compressedTokens/1e3).toFixed(1),a=(s.savedTokens/1e3).toFixed(1),l=s.originalCount,c=s.compressedCount;f.info("Context",`[${n}] \u538B\u7F29\u5B8C\u6210: ${l}\u6761/${i}K \u2192 ${c}\u6761/${o}K (\u8282\u7701 ${a}K, \u4E22\u5F03${s.stats.droppedMessages}\u6761, LLM\u538B\u7F29${s.stats.llmCompressedMessages}\u6761)`),s.debugInfo&&s.debugInfo.forEach(u=>f.debug("Context",u));}return s}setCompressionMode(e){this.compressionMode=e,f.info("Context",`Compression mode set to: ${e}`);}getCompressionMode(){return this.compressionMode}async getInstructions(e){if(typeof this.instructions=="string")return this.instructions;let t={name:this.agentName,description:this.agentDescription};return await this.instructions(e,t)}async getContextInjection(e){if(!this.contextInjection)return null;let s=(typeof this.contextInjection=="string"?this.contextInjection:await this.contextInjection(e,{name:this.agentName,description:this.agentDescription}))?.trim();return s||null}shouldIncludeLastRun(e){let t=e.trim().toLowerCase();return t?/上次|之前|前面|上一步|上轮|继续|回顾|resume|continue|previous|last time/.test(t):false}createRunContext(e,t=0){return {task:e,timestamp:Date.now(),currentTime:new Date,iteration:t,userData:this.userData,systemStatus:void 0}}setUserData(e){this.userData={...this.userData,...e};}async*run(e,t,s){this.runContext={task:e,timestamp:Date.now(),currentTime:new Date,iteration:0,userData:this.userData},this.loopDetector.reset(),process.env.CLI_DEBUG==="1"&&(f.debug("MK",` hasSignal: ${!!s}`),f.debug("RUNNER","========================================"),f.debug("RUNNER","=== runner.run ENTRY ==="),f.debug("RUNNER",` task: "${e?.substring(0,50)}..."`),f.debug("RUNNER",` hasImages: ${!!t&&t.length>0}`),f.debug("RUNNER",` hasSignal: ${!!s}`)),se.agentStart(e),yield {type:"agent_updated_stream_event",new_agent:{name:this.agentName}};let n=this.createRunContext(e,0),i=this.memory.hasConversationMessages?.()??this.memory.getMessagesForLLM().some(T=>T.role==="user"||T.role==="assistant"),o=!i||this.shouldIncludeLastRun(e);n.userData={...n.userData??{},hasConversation:i,includeLastRun:o},this.inputGuardrails.length>0&&(yield {type:"raw_response_event",data:{type:"input_guardrails.check_start",count:this.inputGuardrails.length},event_type:"input_guardrails.check_start"},await ss.runInputGuardrails(this.inputGuardrails,n,this.agentName,e),yield {type:"raw_response_event",data:{type:"input_guardrails.check_passed"},event_type:"input_guardrails.check_passed"});let a=await this.getInstructions(n),l=await this.getContextInjection(n);process.env.CLI_DEBUG==="1"&&(console.log("[RUNNER] dynamicInstructions length:",a?.length||0),console.log("[RUNNER] dynamicInstructions START:",a?.substring(0,200)),console.log("[RUNNER] dynamicInstructions END:",a?.substring(a.length-500)),console.log("[RUNNER] contains \u534F\u4F5C\u6A21\u5F0F:",a?.includes("\u534F\u4F5C\u6A21\u5F0F")),console.log("[RUNNER] contains delegate_task:",a?.includes("delegate_task")));let c=this.memory.getMessagesForLLM(),u=c.some(T=>T.role==="system");if(process.env.CLI_DEBUG==="1"&&(console.log("[RUNNER] hasSystemPrompt:",u,"existingMessages count:",c.length),console.log("[RUNNER] disableSystemPrompt:",this.disableSystemPrompt)),this.disableSystemPrompt)u&&this.memory.clear(),a&&this.memory.add({role:"system",content:a});else if(!u){let T=this.modeStrategy.getSystemPrompt();this.memory.add({role:"system",content:T}),this.memory.add({role:"system",content:a}),this.structuredValidator&&this.memory.add({role:"system",content:this.structuredValidator.buildSystemPrompt()});try{let _=await xo(this.workspacePath);_&&this.memory.add({role:"system",content:_});}catch{}}if(l?this.memory.upsertSystemTagged?this.memory.upsertSystemTagged("context_injection",l):u||this.memory.add({role:"system",content:l}):this.memory.removeSystemTagged?.("context_injection"),t&&t.length>0){let T=[{type:"text",text:e},...t.map(_=>({type:"image_url",image_url:{url:_,detail:"auto"}}))];this.memory.add({role:"user",content:T});}else this.memory.add({role:"user",content:e});let p=Date.now(),d=0,m="",h=0,g={totalTokens:0,promptTokens:0,completionTokens:0},y=false,b=0,w=null,S=new Map,x=0,R=Et.streamMaxRetries,L=Number.isFinite(this.config.maxIterations)?this.config.maxIterations:vc,H=L===0||L===1/0,U=jc(this.config.maxToolCalls,xc),v=jc(this.config.maxRuntimeMs,Tc);for(;H||d<L;){if(s?.aborted){w="interrupted",y=true,yield {type:"error",error:"Task interrupted by user."};break}if(v!==null&&Date.now()-p>=v){w="runtime_limit",y=true,yield {type:"error",error:`Reached max runtime (${Je(v)}). Please summarize progress and ask whether to continue.`};break}if(U!==null&&h>=U){w="tool_call_limit",y=true,yield {type:"error",error:`Reached max tool calls (${U}). Please summarize progress and ask whether to continue.`};break}d++;let T=null;if(this.maxInputTokens){let k=ze(this.memory.getMessagesForLLM()),M=this.maxInputTokens*.97;k>M&&(T=await this.applyContextWindow(d));}T&&(T.stats.droppedMessages>0||T.stats.llmCompressedMessages>0)&&(yield {type:"context_compaction",status:"completed",originalMessages:T.originalCount,keptMessages:T.messages.length,droppedMessages:T.stats.droppedMessages,compressedMessages:T.stats.llmCompressedMessages,originalTokens:T.originalTokens,finalTokens:T.compressedTokens,budgetTokens:this.maxInputTokens||0,useLLM:T.stats.llmCompressedMessages>0,timestamp:Date.now()});let _=this.memory.checkContextHealth();if((_.warnings.length>0||_.shouldCleanup)&&(yield {type:"raw_response_event",data:{type:"context_health",totalTokens:_.totalTokens,toolResultTokens:_.toolResultTokens,toolResultRatio:_.toolResultRatio,messageCount:_.messageCount,toolMessageCount:_.toolMessageCount,warnings:_.warnings,shouldCompress:_.shouldCompress,shouldCleanup:_.shouldCleanup,byType:_.byType},event_type:"context_health"},_.shouldCleanup&&_.byType.ephemeral.count>5)){let k=this.memory.cleanupEphemeral();k>0&&f.info("Runner",`Cleaned ${k} ephemeral messages`);}f.debug("Runner",this.memory.getTokenSummary()),se.agentIteration(d,"thinking"),yield {type:"iteration_start",iteration:d};try{yield {type:"raw_response_event",data:{type:"response.created",response:{id:`resp_${Date.now()}`,model:this.model}},event_type:"response.created"};let k=this.memory.getMessagesForLLM();if(f.info("LLM",`Request: model=${this.model}, messages=${k.length}, tools=${this.tools.length}`),f.debug("LLM","Request messages",{messageCount:k.length,lastMessage:k[k.length-1]?.content?.toString().substring(0,200)}),process.env.CLI_DEBUG==="1"){let P=k.filter(V=>V.role==="system");console.log("[RUNNER] System messages count:",P.length);for(let V=0;V<P.length;V++){let F=P[V].content,ie=typeof F=="string"?F:JSON.stringify(F);console.log(`[RUNNER] System[${V}] length:`,ie?.length||0),console.log(`[RUNNER] System[${V}] contains \u534F\u4F5C\u6A21\u5F0F:`,ie?.includes("\u534F\u4F5C\u6A21\u5F0F")||!1),console.log(`[RUNNER] System[${V}] contains delegate_task:`,ie?.includes("delegate_task")||!1),console.log(`[RUNNER] System[${V}] preview:`,ie?.substring(0,300)||"");}}let M=this.modeStrategy.filterTools(this.tools);process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`Mode: ${this.currentMode}, Available tools: ${M.length}/${this.tools.length}`);let W=this.llmProvider.chatStreamed(this.memory.getMessagesForLLM(),{model:this.model,tools:M,temperature:this.config.temperature,structuredOutput:this.structuredOutput,maxInputTokens:this.maxInputTokens,disableSystemPrompt:this.disableSystemPrompt,signal:s}),E="",D="",N=[],$=[],j="",Z={prompt_tokens:0,completion_tokens:0,total_tokens:0};for await(let P of this.withStreamWatchdog(W,s)){if(P.type==="stream_retry"){yield P;continue}if(P.type==="stream_recovered"){yield {type:"stream_recovered",attempt:P.attempt,maxRetries:P.maxRetries};continue}yield {type:"raw_response_event",data:P,event_type:P.choices?.[0]?.delta?"response.delta":"response.chunk"};let V=P.choices?.[0]?.delta;if(P.usage){Z={prompt_tokens:P.usage.prompt_tokens||Z.prompt_tokens,completion_tokens:P.usage.completion_tokens||Z.completion_tokens,total_tokens:P.usage.total_tokens||Z.total_tokens,cached_tokens:P.usage.cached_tokens,cache_read_input_tokens:P.usage.cache_read_input_tokens,cache_creation_input_tokens:P.usage.cache_creation_input_tokens,prompt_tokens_details:P.usage.prompt_tokens_details},g={promptTokens:Z.prompt_tokens,completionTokens:Z.completion_tokens,totalTokens:Z.total_tokens};let F=!!P.choices?.[0]?.finish_reason;yield {type:"token_usage",usage:Z,is_final:F};}if(V){if(V.reasoning_content&&(D+=V.reasoning_content,yield {type:"reasoning_delta",delta:V.reasoning_content}),V.reasoning_complete&&(yield {type:"reasoning_complete"}),V.content&&(E+=V.content,m=E,yield {type:"text_delta",delta:V.content}),V.tool_calls)for(let F of V.tool_calls){let ie=F.index;$[ie]||($[ie]={id:F.id||`call_${Math.floor(Date.now())}_${ie}`,type:"function",function:{name:"",arguments:""}}),F.id&&($[ie].id=F.id),F.function?.name&&($[ie].function.name=F.function.name),F.function?.arguments&&($[ie].function.arguments+=F.function.arguments,yield {type:"tool_call_delta",id:$[ie].id,name:$[ie].function.name,arguments_delta:F.function.arguments}),F.thoughtSignature&&($[ie].thoughtSignature=F.thoughtSignature);}P.choices?.[0]?.finish_reason&&(j=P.choices[0].finish_reason),P.thinking_blocks&&Array.isArray(P.thinking_blocks)&&(N=P.thinking_blocks.map(F=>({type:F.type,thinking:F.thinking,signature:F.signature,data:F.data})));}}E&&(yield {type:"text_done"}),process.env.CLI_DEBUG_CONSOLE==="1"&&process.env.NEOX_UI_MODE==="1"&&console.log("[Runner] \u{1F3AF} Emitting response.completed event (after LLM response)"),yield {type:"raw_response_event",data:{type:"response.completed"},event_type:"response.completed"};let A={role:"assistant",content:(E||"").trimEnd()};if(D&&(A.reasoning_content=D),N.length>0&&(A.thinking_blocks=N),$.length>0&&(A.tool_calls=$.map(P=>({...P,function:{...P.function,arguments:P.function.arguments}}))),this.memory.add(A),process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} Stream ended. toolCalls.length=${$.length}, fullContent.length=${E.length}`),$.length>0){let P=/\[omitted\s+\w+:\s*\d+\s*lines?,\s*\d+\s*chars?\]/i;for(let C of $){let O=C.function.arguments||"";if(P.test(O)){console.error("[Runner] \u{1F6A8} Placeholder string detected in tool arguments!"),console.error(`[Runner] Tool: ${C.function.name}`),console.error(`[Runner] Arguments preview: ${O.substring(0,500)}`),yield {type:"raw_response_event",data:{type:"error.placeholder_detected",message:"Model generated placeholder string instead of actual content. This usually happens when the model sees truncated data in conversation history.",tool:C.function.name},event_type:"error.placeholder_detected"},yield {type:"error",error:'Error: Model attempted to write placeholder text ("[omitted ...]") instead of actual content. This happens when conversation history contains truncated data. Please start a new conversation.'},y=!0;break}}if(y)break;if(U!==null&&h+$.length>U){w="tool_call_limit",y=!0,yield {type:"error",error:`Tool call budget exceeded (max ${U}, requested ${$.length}). Please summarize progress and ask whether to continue.`};break}if($.length>1){let C=$.map(G=>G.function.name),O=[...new Set(C)];O.length===1&&C.length>1?f.info("RUNNER",`\u{1F504} Parallel calls: ${C.length}x ${O[0]} (different parameters)`):f.info("RUNNER",`\u{1F504} Parallel calls: ${C.join(", ")}`);}for(let C of $){h++,yield {type:"run_item_stream_event",name:"tool_called",item:{type:"tool_call_item",id:C.id,name:C.function.name,arguments:C.function.arguments,timestamp:Date.now()}},yield {type:"tool_call_start",id:C.id,name:C.function.name};let G=!1;try{C.function.arguments&&(JSON.parse(C.function.arguments),G=!0);}catch(q){se.toolError(C.function.name,`Invalid JSON arguments (${q.message}): ${C.function.arguments.substring(0,200)}...`),console.error(`[Runner] \u26A0\uFE0F Tool ${C.function.name} has invalid JSON arguments`),console.error(`[Runner] Arguments length: ${C.function.arguments.length}`),console.error(`[Runner] First 200 chars: ${C.function.arguments.substring(0,200)}`),console.error(`[Runner] Last 200 chars: ${C.function.arguments.substring(Math.max(0,C.function.arguments.length-200))}`);}yield {type:"tool_call_done",id:C.id,name:C.function.name,arguments:C.function.arguments,success:G},yield {type:"raw_response_event",data:{type:"response.function_call_arguments.done",call_id:C.id,name:C.function.name,arguments:C.function.arguments},event_type:"response.function_call_arguments.done"};}let V=new Set,F=null,ie=$.length>1;process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`Processing ${$.length} tool call(s)`,{isParallel:ie,tools:$.map(C=>C.function.name)});for(let C of $){let O={};try{let I=C.function.arguments?.trim()||"";O=I?JSON.parse(I):{};}catch(I){se.toolError(C.function.name,`Loop detection skipped: invalid JSON (${I.message})`);continue}let G=this.loopDetector.detect(C.function.name,O);if(this.loopDetector.record(C.function.name,O),G===0)continue;let q=this.loopDetector.generateIntervention(G,C.function.name,O);if(this.memory.add({role:"system",content:q.message}),G===2&&ya(C.function.name))continue;if(yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:C.id,name:C.function.name,output:q.message,success:!1,timestamp:Date.now()}},yield {type:"tool_output",name:C.function.name,output:q.message,success:!1},this.memory.addToolResult(C.id,C.function.name,q.message),this.loopDetector.updateLastStatus("error"),V.add(C.id),q.shouldTerminate){F=q;break}}if(F&&(yield {type:"error",error:F.message},y=!0),y)break;let De=V.size>0?$.filter(C=>!V.has(C.id)):$,X=new Set(this.modeStrategy.filterTools(this.tools).map(C=>C.name)),le=C=>C.replace(/["\s/>]+$/g,"").trim(),ce=[];for(let C of De){let O=le(C.function.name);if(X.has(O)||X.has(C.function.name)){ce.push(C);continue}let G=`Tool "${C.function.name}" is not allowed in ${this.currentMode} mode`;se.toolError(C.function.name,G),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:C.id,name:C.function.name,output:G,success:!1,timestamp:Date.now()}},yield {type:"tool_output",name:C.function.name,output:G,success:!1},this.memory.addToolResult(C.id,C.function.name,G),f.info("PERMISSION",`Tool blocked by mode: ${C.function.name} - ${G}`);}if(ce.length===0)continue;let ne=ce.map(C=>({id:C.id,type:"function",function:{name:C.function.name,arguments:C.function.arguments}})),Te=!1;if(process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} Before permission check. shouldAutoApprove=${this.modeStrategy.shouldAutoApprove()}, parallelToolCalls=${ne.length}`),!this.modeStrategy.shouldAutoApprove()){let C=new Set;try{for(let O of ce)try{let G=O.function.arguments.trim(),q=G?JSON.parse(G):{},_e=this.tools.find(I=>I.name===O.function.name);if(!_e){f.warn("RUNNER",`Tool not found: ${O.function.name}`);continue}let ye=await Gc(s,async()=>this.permissionManager.checkPermission(_e,q));if(!ye.allowed){C.add(O.id);let I=ye.reason||`Tool "${O.function.name}" was denied`;se.toolError(O.function.name,I),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:O.id,name:O.function.name,output:I,success:!1,timestamp:Date.now()}},yield {type:"tool_output",name:O.function.name,output:I,success:!1};let z=JSON.stringify({type:"ephemeral",status:"error",tool:O.function.name,summary:"Tool execution denied by user",error:I,final:!0});this.memory.addToolResult(O.id,O.function.name,z),f.info("PERMISSION",`Tool denied: ${O.function.name} - ${I}`),Te=!0;}}catch(G){if(G?.name==="AbortError"||G?.code==="ERR_CANCELED")throw G;se.toolError(O.function.name,G?.message||"permission check failed");}}catch(O){if(O?.name==="AbortError"||O?.code==="ERR_CANCELED"){f.info("RUNNER","Interrupt detected during permission check"),y=!0;break}throw O}if(ce=ce.filter(O=>!C.has(O.id)),ne=ne.filter(O=>!C.has(O.id)),Te){f.info("RUNNER","User denied tool - terminating current turn");break}if(ne.length===0)continue}if(process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} After permission check. parallelToolCalls=${ne.length}, userDeniedTool=${Te}`),this.toolInputGuardrails.length>0){let C=new Set;try{for(let O of ce)try{let G=O.function.arguments.trim(),q=G?JSON.parse(G):{},_e={tool_name:O.function.name,tool_input:q,tool_call_id:O.id},ye=this.tools.find(B=>B.name===O.function.name);if(!ye)continue;this.runContext.iteration=d;let I=await Gc(s,async()=>ss.runToolInputGuardrails(this.toolInputGuardrails,{context:this.runContext,tool_context:_e,agent_name:this.agentName,tool:ye}));if(!I.should_execute){C.add(O.id);let B=I.rejection_message||`Tool ${O.function.name} was blocked by guardrail`;se.toolError(O.function.name,`Blocked by guardrail: ${B}`),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:O.id,name:O.function.name,output:B,success:!1,timestamp:Date.now()}},yield {type:"tool_output",name:O.function.name,output:B,success:!1},this.memory.addToolResult(O.id,O.function.name,B),Go(this.runContext,O.function.name,q,!1);}}catch(G){if(G?.name==="AbortError"||G?.code==="ERR_CANCELED")throw G;if(G instanceof rt){se.toolError(O.function.name,`Guardrail tripwire triggered: ${G.message}`),yield {type:"error",error:`Guardrail tripwire triggered for ${O.function.name}: ${G.message}`},y=!0;break}se.toolError(O.function.name,`Guardrail check failed: ${G?.message}`);}}catch(O){if(O?.name==="AbortError"||O?.code==="ERR_CANCELED"){f.info("RUNNER","Interrupt detected during guardrails check"),y=!0;break}throw O}if(y)break;if(ce=ce.filter(O=>!C.has(O.id)),ne=ne.filter(O=>!C.has(O.id)),ne.length===0)continue}process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} Before tool execution. parallelToolCalls=${ne.length}`);let K=await this.parallelExecutor.execute(ne,this.tools,C=>{if(se.toolCall(C.name,{}),C.success){let G=typeof C.output=="string"?C.output.length:JSON.stringify(C.output).length;se.toolResult(C.name,!0,G,C.executionTime||0);}else se.toolError(C.name,C.output);let O={type:"tool_call_output_item",id:C.id,name:C.name,output:C.output,success:C.success,timestamp:Date.now()};},s);for(let C of K.results){if(this.toolMetricsHistory.push({name:C.name,duration:C.executionTime||0,success:C.success}),this.toolMetricsHistory.length>50&&this.toolMetricsHistory.shift(),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:C.id,name:C.name,output:C.output,success:C.success,timestamp:Date.now()}},yield {type:"tool_output",name:C.name,output:C.output,success:C.success},C.name==="update_plan"&&C.success)try{f.info("PLAN_UPDATE","\u{1F525} Detected update_plan tool call",{resultId:C.id,toolCallsCount:$.length});let I=$.find(B=>B.id===C.id);if(I){f.info("PLAN_UPDATE","\u{1F525} Found original call",{callId:I.id,argsLength:I.function.arguments?.length});let B=JSON.parse(I.function.arguments||"{}");f.info("PLAN_UPDATE","\u{1F525} Parsed plan args",{hasExplanation:!!B.explanation,planSteps:B.plan?.length}),yield {type:"plan_update",explanation:B.explanation,plan:B.plan,timestamp:Date.now()},f.info("PLAN_UPDATE","\u2705 Emitted plan_update event");}else f.warn("PLAN_UPDATE","\u274C Could not find original tool call",{resultId:C.id,availableIds:$.map(B=>B.id)});}catch(I){f.error("PLAN_UPDATE","\u274C Failed to parse plan",{error:I});}let G=typeof C.output=="string"?Bc(C.output):Bc(JSON.stringify(C.output));G=this.enrichToolResult(G,C.name,C.executionTime||0);let q=$.find(I=>I.id===C.id),_e={};if(q)try{_e=JSON.parse(q.function.arguments||"{}");}catch{}if(this.toolOutputGuardrails.length>0)try{let I=this.tools.find(B=>B.name===C.name);if(I){let B={tool_name:C.name,tool_input:_e,tool_call_id:C.id},z=await ss.runToolOutputGuardrails(this.toolOutputGuardrails,{context:this.runContext,tool_context:B,agent_name:this.agentName,tool:I,output:C.output});z.should_use_output||(G=z.replacement_message||"[Output blocked by guardrail]",se.toolError(C.name,"Output blocked by guardrail"));}}catch(I){I instanceof rt&&se.toolError(C.name,`Output guardrail tripwire triggered: ${I.message}`);}if(!C.success&&typeof C.output=="string"){let I=C.output.toLowerCase();if(I.includes("operation cancelled")||I.includes("command interrupted")||I.includes("request aborted")){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Runner] Detected cancellation in tool output, breaking loop"),f.info("RUNNER","\u68C0\u6D4B\u5230\u5DE5\u5177\u4E2D\u65AD\u4FE1\u53F7\uFF0C\u7EC8\u6B62\u6267\u884C\u5FAA\u73AF"),y=!0;break}}Go(this.runContext,C.name,_e,C.success),f.info("TOOL_RESULT",`\u{1F4E6} Tool raw output: ${C.name}`,{toolName:C.name,success:C.success,rawLength:typeof C.output=="string"?C.output.length:JSON.stringify(C.output).length,truncatedLength:G.length,outputPreview:G.substring(0,500)}),this.memory.addToolResult(C.id,C.name,G);let ye=C.success?"success":"error";try{let I=typeof C.output=="string"?C.output:JSON.stringify(C.output),B=JSON.parse(I);B.status==="already_done"?ye="already_done":B.status==="success"?ye="success":B.status==="error"&&(ye="error");}catch{}if(this.loopDetector.updateLastStatus(ye),ye==="error"){let I=(S.get(C.name)||0)+1;if(S.set(C.name,I),C.name==="edit_file"&&(I===2||I===3)){let B=typeof C.output=="string"?C.output:JSON.stringify(C.output),z=C.name,oe=$c(z,B);this.memory.add({role:"system",content:oe});}}else S.set(C.name,0);}if(d>0&&d%5===0){let C=this.buildPerformanceHint();C&&(this.memory.add({role:"system",content:C}),process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Runner] Performance hint injected:",C));}if(process.env.CLI_DEBUG_CONSOLE==="1"&&K.stats&&(yield {type:"raw_response_event",data:{type:"parallel_execution.stats",stats:K.stats},event_type:"parallel_execution.stats"}),s?.aborted){y=!0;break}continue}else {if(this.plannerMode&&b<2&&this.shouldAutoContinuePlan(E)){b++;let P=this.buildPlanFollowupPrompt();yield {type:"raw_response_event",data:{type:"plan.auto_continue",plan_text:E,followup_prompt:P,count:b},event_type:"plan.auto_continue"},this.memory.add({role:"user",content:P});continue}if(E&&(yield {type:"run_item_stream_event",name:"message_output_created",item:{type:"message_output_item",content:E,role:"assistant",timestamp:Date.now()}}),process.env.CLI_DEBUG==="1"&&(f.info("RUNNER","=== Loop Exit: No Tool Calls ==="),f.info("RUNNER",`Finish Reason: ${j}`),f.info("RUNNER",`Content Length: ${E.length}`),f.info("RUNNER",`Content Preview: ${E.slice(0,300)}`),f.info("RUNNER",`Tool Calls Count: ${$.length}`),f.info("RUNNER",`Iteration: ${d}`)),this.structuredValidator){let P=this.structuredValidator.validate(E);if(P.ok)m=P.normalized||E,yield {type:"raw_response_event",data:{type:"structured_output.accepted",schema:this.structuredOutput?.name,normalized_text:m,parsed:P.parsed},event_type:"structured_output.accepted"};else {yield {type:"raw_response_event",data:{type:"structured_output.retry",schema:this.structuredOutput?.name,reason:P.reason,message:P.message,errors:P.errors},event_type:"structured_output.retry"},this.memory.add({role:"system",content:this.structuredValidator.buildRetryPrompt(P)}),m="";continue}}else m=E;this.outputGuardrails.length>0&&m&&(yield {type:"raw_response_event",data:{type:"output_guardrails.check_start",count:this.outputGuardrails.length},event_type:"output_guardrails.check_start"},await ss.runOutputGuardrails(this.outputGuardrails,n,this.agentName,m),yield {type:"raw_response_event",data:{type:"output_guardrails.check_passed"},event_type:"output_guardrails.check_passed"});break}}catch(k){if(k?.type==="stream_retry"){yield k;continue}let M=k instanceof he?k:nt(k);if(process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Runner] Error classified:",{category:M.category,code:M.code,retryable:M.retryable,message:M.message}),M.category==="canceled"){w="interrupted",y=true,yield {type:"error",error:"Task interrupted by user."};break}if(M.retryable&&x<R){x++;let N=Ln(M.category,x,M.retryAfter),$=M.category==="retryable_rate_limit",j=M.code==="STREAM_TIMEOUT",Z=M.category==="retryable_network"||M.category==="retryable_stream";f.warn("RUNNER",`Retrying after ${Je(N)} (attempt ${x}/${R}): ${M.message}`),yield {type:"raw_response_event",data:{type:"runner.stream_retry",error:M.message,errorCode:M.code,attempt:x,maxRetries:R,delayMs:N,isRateLimit:$,isStreamTimeout:j,isNetworkError:Z},event_type:"runner.stream_retry"},await $s(N),d--;continue}let W=Hr(M),E=M.message;W&&!E.includes(W)&&(E=`${E}
|
|
1481
|
+
`;return l+p+c}var ei=class{llmProvider;providerName;model;tools;memory;config;agentName;agentDescription;instructions;contextInjection;userData;plannerMode;inputGuardrails=[];outputGuardrails=[];toolInputGuardrails=[];toolOutputGuardrails=[];structuredOutput;structuredValidator;maxInputTokensOverride;maxInputTokens;minHistoryMessages;parallelExecutor;unifiedCompressor;compressionMode;toolMetricsHistory=[];workspacePath;disableSystemPrompt;runContext;permissionManager;modeStrategy;currentMode;loopDetector;enablePlanMode;constructor(e){if(this.llmProvider=e.llmProvider,this.providerName=e.providerName,this.model=e.model,this.tools=e.tools,this.memory=e.memory,this.config=e.config,this.agentName=e.agentName||"DefaultAgent",this.agentDescription=e.agentDescription||"",this.instructions=e.instructions,this.contextInjection=e.contextInjection,this.userData=e.userData,this.plannerMode=e.plannerMode??false,this.structuredOutput=e.structuredOutput,this.maxInputTokensOverride=e.maxInputTokensOverride,this.maxInputTokens=this.computeMaxInputTokens(e.contextWindow,e.tailTokenBudget,this.maxInputTokensOverride),this.minHistoryMessages=Math.max(1,e.minHistoryMessages??6),e.structuredOutput&&(this.structuredValidator=new Vr(e.structuredOutput)),this.inputGuardrails=e.inputGuardrails||[],this.outputGuardrails=e.outputGuardrails||[],this.toolInputGuardrails=e.toolInputGuardrails||[],this.toolOutputGuardrails=e.toolOutputGuardrails||[],this.parallelExecutor=new Xr,this.compressionMode=e.compressionMode??"sync",this.workspacePath=e.workspacePath,this.unifiedCompressor=new Yr({debug:process.env.CLI_DEBUG==="1",minRecentMessages:this.minHistoryMessages,enableLLMCompression:true}),this.disableSystemPrompt=e.disableSystemPrompt??false,this.unifiedCompressor.setLLMProvider(this.llmProvider,this.model),e.contextWindow&&this.unifiedCompressor.setContextWindow(e.contextWindow),this.currentMode=e.config.mode??"agent",this.modeStrategy=Zo(this.currentMode),this.permissionManager=e.permissionManager??new Us({defaultPermission:"ask"}),this.loopDetector=Wc(),this.enablePlanMode=e.enablePlanMode??true,e.approvalHandler){let t=e.approvalHandler;this.permissionManager.setApprovalHandler(async s=>({approved:await t({id:"",name:s.toolName,args:s.args}),remember:false}));}}setApprovalHandler(e){if(!e){this.permissionManager.setApprovalHandler(void 0);return}this.permissionManager.setApprovalHandler(async t=>({approved:await e({id:"",name:t.toolName,args:t.args}),remember:false}));}setMode(e){this.currentMode=e,this.modeStrategy=Zo(e),f.info("Runner",`Mode switched to: ${e}`);}getMode(){return this.currentMode}getPermissionManager(){return this.permissionManager}computeMaxInputTokens(e,t,s){if(s&&s>0)return s;let i=e&&e>0?e:19e4,o=.7,a=Math.floor(i*o),l=Math.min(t??zc,Math.floor(i*.1)),c=Math.max(2e3,a-l);if(process.env.CLI_DEBUG==="1"||process.env.CLI_DEBUG_CONSOLE==="1"){let u=`[Context] maxInputTokens=${c} (contextWindow=${i}, override=${s}, tailBudget=${t??zc}, safety=${o})`;console.log(u);}return c}async*withStreamWatchdog(e,t){if(qg){for await(let o of e)yield o;return}let s=e[Symbol.asyncIterator](),n=t?new Promise((o,a)=>{t.aborted?a(Qr()):t.addEventListener("abort",()=>a(Qr()),{once:true});}):null,i=false;for(;;){if(t?.aborted){if(s.return)try{await s.return();}catch{}throw Qr()}let o=i?zg:Hg,a=null,l=new Promise((c,u)=>{a=setTimeout(()=>{u(Wg(i?"idle":"first_chunk",o));},o);});try{let c=await Promise.race(n?[s.next(),l,n]:[s.next(),l]);if(a&&clearTimeout(a),c.done)return;i=!0,yield c.value;}catch(c){if(a&&clearTimeout(a),s.return)try{await s.return();}catch{}throw c?.code==="STREAM_TIMEOUT"&&f.warn("RUNNER",`[watchdog] ${c.message}`),c}}}async applyContextWindow(e=0){if(!this.maxInputTokens)return null;let t=this.memory.getMessagesForLLM(),s=await this.unifiedCompressor.compressHistory(t,this.maxInputTokens,{iteration:e,enableLLMCompression:true});if(s.stats.droppedMessages>0||s.stats.llmCompressedMessages>0){this.memory.setMessages(s.messages);let n=this.compressionMode==="async"?"Async":"Sync",i=(s.originalTokens/1e3).toFixed(1),o=(s.compressedTokens/1e3).toFixed(1),a=(s.savedTokens/1e3).toFixed(1),l=s.originalCount,c=s.compressedCount;f.info("Context",`[${n}] \u538B\u7F29\u5B8C\u6210: ${l}\u6761/${i}K \u2192 ${c}\u6761/${o}K (\u8282\u7701 ${a}K, \u4E22\u5F03${s.stats.droppedMessages}\u6761, LLM\u538B\u7F29${s.stats.llmCompressedMessages}\u6761)`),s.debugInfo&&s.debugInfo.forEach(u=>f.debug("Context",u));}return s}setCompressionMode(e){this.compressionMode=e,f.info("Context",`Compression mode set to: ${e}`);}getCompressionMode(){return this.compressionMode}async getInstructions(e){if(typeof this.instructions=="string")return this.instructions;let t={name:this.agentName,description:this.agentDescription};return await this.instructions(e,t)}async getContextInjection(e){if(!this.contextInjection)return null;let s=(typeof this.contextInjection=="string"?this.contextInjection:await this.contextInjection(e,{name:this.agentName,description:this.agentDescription}))?.trim();return s||null}shouldIncludeLastRun(e){let t=e.trim().toLowerCase();return t?/上次|之前|前面|上一步|上轮|继续|回顾|resume|continue|previous|last time/.test(t):false}createRunContext(e,t=0){return {task:e,timestamp:Date.now(),currentTime:new Date,iteration:t,userData:this.userData,systemStatus:void 0}}setUserData(e){this.userData={...this.userData,...e};}async*run(e,t,s){this.runContext={task:e,timestamp:Date.now(),currentTime:new Date,iteration:0,userData:this.userData},this.loopDetector.reset(),process.env.CLI_DEBUG==="1"&&(f.debug("MK",` hasSignal: ${!!s}`),f.debug("RUNNER","========================================"),f.debug("RUNNER","=== runner.run ENTRY ==="),f.debug("RUNNER",` task: "${e?.substring(0,50)}..."`),f.debug("RUNNER",` hasImages: ${!!t&&t.length>0}`),f.debug("RUNNER",` hasSignal: ${!!s}`)),oe.agentStart(e),yield {type:"agent_updated_stream_event",new_agent:{name:this.agentName}};let n=this.createRunContext(e,0),i=this.memory.hasConversationMessages?.()??this.memory.getMessagesForLLM().some(_=>_.role==="user"||_.role==="assistant"),o=!i||this.shouldIncludeLastRun(e);n.userData={...n.userData??{},hasConversation:i,includeLastRun:o},this.inputGuardrails.length>0&&(yield {type:"raw_response_event",data:{type:"input_guardrails.check_start",count:this.inputGuardrails.length},event_type:"input_guardrails.check_start"},await ss.runInputGuardrails(this.inputGuardrails,n,this.agentName,e),yield {type:"raw_response_event",data:{type:"input_guardrails.check_passed"},event_type:"input_guardrails.check_passed"});let a=await this.getInstructions(n),l=await this.getContextInjection(n);process.env.CLI_DEBUG==="1"&&(console.log("[RUNNER] dynamicInstructions length:",a?.length||0),console.log("[RUNNER] dynamicInstructions START:",a?.substring(0,200)),console.log("[RUNNER] dynamicInstructions END:",a?.substring(a.length-500)),console.log("[RUNNER] contains \u534F\u4F5C\u6A21\u5F0F:",a?.includes("\u534F\u4F5C\u6A21\u5F0F")),console.log("[RUNNER] contains delegate_task:",a?.includes("delegate_task")));let c=this.memory.getMessagesForLLM(),u=c.some(_=>_.role==="system");if(process.env.CLI_DEBUG==="1"&&(console.log("[RUNNER] hasSystemPrompt:",u,"existingMessages count:",c.length),console.log("[RUNNER] disableSystemPrompt:",this.disableSystemPrompt)),this.disableSystemPrompt)u&&this.memory.clear(),a&&this.memory.add({role:"system",content:a});else if(!u){let _=this.modeStrategy.getSystemPrompt();this.memory.add({role:"system",content:_}),this.memory.add({role:"system",content:a}),this.structuredValidator&&this.memory.add({role:"system",content:this.structuredValidator.buildSystemPrompt()});try{let k=await Ro(this.workspacePath);k&&this.memory.add({role:"system",content:k});}catch{}}if(l?this.memory.upsertSystemTagged?this.memory.upsertSystemTagged("context_injection",l):u||this.memory.add({role:"system",content:l}):this.memory.removeSystemTagged?.("context_injection"),t&&t.length>0){let _=[{type:"text",text:e},...t.map(k=>({type:"image_url",image_url:{url:k,detail:"auto"}}))];this.memory.add({role:"user",content:_});}else this.memory.add({role:"user",content:e});let p=Date.now(),d=0,m="",h=0,g={totalTokens:0,promptTokens:0,completionTokens:0},y=false,b=0,w=null,S=new Map,x=0,R=Et.streamMaxRetries,$=false,G=Number.isFinite(this.config.maxIterations)?this.config.maxIterations:Ec,U=G===0||G===1/0,T=qc(this.config.maxToolCalls,Ic),C=qc(this.config.maxRuntimeMs,Mc);for(;U||d<G;){if(s?.aborted){w="interrupted",y=true,yield {type:"error",error:"Task interrupted by user."};break}if(C!==null&&Date.now()-p>=C){w="runtime_limit",y=true,yield {type:"error",error:`Reached max runtime (${Je(C)}). Please summarize progress and ask whether to continue.`};break}if(T!==null&&h>=T){w="tool_call_limit",y=true,yield {type:"error",error:`Reached max tool calls (${T}). Please summarize progress and ask whether to continue.`};break}d++;let _=null;if(this.maxInputTokens){let D=ze(this.memory.getMessagesForLLM()),N=this.maxInputTokens*.97;D>N&&(_=await this.applyContextWindow(d));}_&&(_.stats.droppedMessages>0||_.stats.llmCompressedMessages>0)&&(yield {type:"context_compaction",status:"completed",originalMessages:_.originalCount,keptMessages:_.messages.length,droppedMessages:_.stats.droppedMessages,compressedMessages:_.stats.llmCompressedMessages,originalTokens:_.originalTokens,finalTokens:_.compressedTokens,budgetTokens:this.maxInputTokens||0,useLLM:_.stats.llmCompressedMessages>0,timestamp:Date.now()});let k=this.memory.checkContextHealth();if((k.warnings.length>0||k.shouldCleanup)&&(yield {type:"raw_response_event",data:{type:"context_health",totalTokens:k.totalTokens,toolResultTokens:k.toolResultTokens,toolResultRatio:k.toolResultRatio,messageCount:k.messageCount,toolMessageCount:k.toolMessageCount,warnings:k.warnings,shouldCompress:k.shouldCompress,shouldCleanup:k.shouldCleanup,byType:k.byType},event_type:"context_health"},k.shouldCleanup&&k.byType.ephemeral.count>5)){let D=this.memory.cleanupEphemeral();D>0&&f.info("Runner",`Cleaned ${D} ephemeral messages`);}f.debug("Runner",this.memory.getTokenSummary()),oe.agentIteration(d,"thinking"),yield {type:"iteration_start",iteration:d};try{yield {type:"raw_response_event",data:{type:"response.created",response:{id:`resp_${Date.now()}`,model:this.model}},event_type:"response.created"};let D=this.memory.getMessagesForLLM();if(f.info("LLM",`Request: model=${this.model}, messages=${D.length}, tools=${this.tools.length}`),f.debug("LLM","Request messages",{messageCount:D.length,lastMessage:D[D.length-1]?.content?.toString().substring(0,200)}),process.env.CLI_DEBUG==="1"){let B=D.filter(j=>j.role==="system");console.log("[RUNNER] System messages count:",B.length);for(let j=0;j<B.length;j++){let Y=B[j].content,ae=typeof Y=="string"?Y:JSON.stringify(Y);console.log(`[RUNNER] System[${j}] length:`,ae?.length||0),console.log(`[RUNNER] System[${j}] contains \u534F\u4F5C\u6A21\u5F0F:`,ae?.includes("\u534F\u4F5C\u6A21\u5F0F")||!1),console.log(`[RUNNER] System[${j}] contains delegate_task:`,ae?.includes("delegate_task")||!1),console.log(`[RUNNER] System[${j}] preview:`,ae?.substring(0,300)||"");}}let N=this.modeStrategy.filterTools(this.tools);process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`Mode: ${this.currentMode}, Available tools: ${N.length}/${this.tools.length}`);let E=this.llmProvider.chatStreamed(this.memory.getMessagesForLLM(),{model:this.model,tools:N,temperature:this.config.temperature,structuredOutput:this.structuredOutput,maxInputTokens:this.maxInputTokens,disableSystemPrompt:this.disableSystemPrompt,signal:s}),A="",F="",H=[],M=[],ee="",P={prompt_tokens:0,completion_tokens:0,total_tokens:0};for await(let B of this.withStreamWatchdog(E,s)){if(B.type==="stream_retry"){$=!0,yield B;continue}if(B.type==="stream_recovered"){yield {type:"stream_recovered",attempt:B.attempt,maxRetries:B.maxRetries};continue}yield {type:"raw_response_event",data:B,event_type:B.choices?.[0]?.delta?"response.delta":"response.chunk"};let j=B.choices?.[0]?.delta;if(B.usage){P={prompt_tokens:B.usage.prompt_tokens||P.prompt_tokens,completion_tokens:B.usage.completion_tokens||P.completion_tokens,total_tokens:B.usage.total_tokens||P.total_tokens,cached_tokens:B.usage.cached_tokens,cache_read_input_tokens:B.usage.cache_read_input_tokens,cache_creation_input_tokens:B.usage.cache_creation_input_tokens,prompt_tokens_details:B.usage.prompt_tokens_details},g={promptTokens:P.prompt_tokens,completionTokens:P.completion_tokens,totalTokens:P.total_tokens};let Y=!!B.choices?.[0]?.finish_reason;yield {type:"token_usage",usage:P,is_final:Y};}if(j){if(j.reasoning_content&&(F+=j.reasoning_content,yield {type:"reasoning_delta",delta:j.reasoning_content}),j.reasoning_complete&&(yield {type:"reasoning_complete"}),j.content&&(A+=j.content,m=A,yield {type:"text_delta",delta:j.content}),j.tool_calls)for(let Y of j.tool_calls){let ae=Y.index;M[ae]||(M[ae]={id:Y.id||`call_${Math.floor(Date.now())}_${ae}`,type:"function",function:{name:"",arguments:""}}),Y.id&&(M[ae].id=Y.id),Y.function?.name&&(M[ae].function.name=Y.function.name),Y.function?.arguments&&(M[ae].function.arguments+=Y.function.arguments,yield {type:"tool_call_delta",id:M[ae].id,name:M[ae].function.name,arguments_delta:Y.function.arguments}),Y.thoughtSignature&&(M[ae].thoughtSignature=Y.thoughtSignature);}B.choices?.[0]?.finish_reason&&(ee=B.choices[0].finish_reason),B.thinking_blocks&&Array.isArray(B.thinking_blocks)&&(H=B.thinking_blocks.map(Y=>({type:Y.type,thinking:Y.thinking,signature:Y.signature,data:Y.data})));}}A&&(yield {type:"text_done"}),process.env.CLI_DEBUG_CONSOLE==="1"&&process.env.NEOX_UI_MODE==="1"&&console.log("[Runner] \u{1F3AF} Emitting response.completed event (after LLM response)"),yield {type:"raw_response_event",data:{type:"response.completed"},event_type:"response.completed"};let q={role:"assistant",content:(A||"").trimEnd()};if(F&&(q.reasoning_content=F),H.length>0&&(q.thinking_blocks=H),M.length>0&&(q.tool_calls=M.map(B=>({...B,function:{...B.function,arguments:B.function.arguments}}))),this.memory.add(q),process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} Stream ended. toolCalls.length=${M.length}, fullContent.length=${A.length}`),M.length>0){let B=/\[omitted\s+\w+:\s*\d+\s*lines?,\s*\d+\s*chars?\]/i;for(let v of M){let I=v.function.arguments||"";if(B.test(I)){console.error("[Runner] \u{1F6A8} Placeholder string detected in tool arguments!"),console.error(`[Runner] Tool: ${v.function.name}`),console.error(`[Runner] Arguments preview: ${I.substring(0,500)}`),yield {type:"raw_response_event",data:{type:"error.placeholder_detected",message:"Model generated placeholder string instead of actual content. This usually happens when the model sees truncated data in conversation history.",tool:v.function.name},event_type:"error.placeholder_detected"},yield {type:"error",error:'Error: Model attempted to write placeholder text ("[omitted ...]") instead of actual content. This happens when conversation history contains truncated data. Please start a new conversation.'},y=!0;break}}if(y)break;if(T!==null&&h+M.length>T){w="tool_call_limit",y=!0,yield {type:"error",error:`Tool call budget exceeded (max ${T}, requested ${M.length}). Please summarize progress and ask whether to continue.`};break}if(M.length>1){let v=M.map(J=>J.function.name),I=[...new Set(v)];I.length===1&&v.length>1?f.info("RUNNER",`\u{1F504} Parallel calls: ${v.length}x ${I[0]} (different parameters)`):f.info("RUNNER",`\u{1F504} Parallel calls: ${v.join(", ")}`);}let j=new Map;for(let v of M)j.set(v.id,Fs(v.function.arguments));for(let v of M){h++,yield {type:"run_item_stream_event",name:"tool_called",item:{type:"tool_call_item",id:v.id,name:v.function.name,arguments:v.function.arguments,timestamp:Date.now()}},yield {type:"tool_call_start",id:v.id,name:v.function.name};let J=j.get(v.id),ye=J?.ok??!1;ye?J?.repaired&&f.warn("RUNNER","Tool arguments repaired from non-standard JSON",{tool:v.function.name,callId:v.id}):oe.toolError(v.function.name,`Invalid JSON arguments (${J?.reason||"parse failed"}): ${v.function.arguments.substring(0,200)}...`),yield {type:"tool_call_done",id:v.id,name:v.function.name,arguments:v.function.arguments,success:ye},yield {type:"raw_response_event",data:{type:"response.function_call_arguments.done",call_id:v.id,name:v.function.name,arguments:v.function.arguments},event_type:"response.function_call_arguments.done"};}let Y=new Set,ae=null,_e=M.length>1;process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`Processing ${M.length} tool call(s)`,{isParallel:_e,tools:M.map(v=>v.function.name)});for(let v of M){let I=j.get(v.id);if(!I?.ok){let z=`Invalid JSON arguments for tool "${v.function.name}": ${I?.reason||"parse failed"}. Return strict JSON object arguments.`;yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:v.id,name:v.function.name,output:z,success:!1,timestamp:Date.now()}},yield {type:"tool_output",id:v.id,name:v.function.name,output:z,success:!1},this.memory.addToolResult(v.id,v.function.name,z),this.loopDetector.updateLastStatus("error"),Y.add(v.id);continue}let J=I.args,ye=this.loopDetector.detect(v.function.name,J);if(this.loopDetector.record(v.function.name,J),ye===0)continue;let O=this.loopDetector.generateIntervention(ye,v.function.name,J);if(this.memory.add({role:"system",content:O.message}),ye===2&&_a(v.function.name))continue;if(yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:v.id,name:v.function.name,output:O.message,success:!1,timestamp:Date.now()}},yield {type:"tool_output",id:v.id,name:v.function.name,output:O.message,success:!1},this.memory.addToolResult(v.id,v.function.name,O.message),this.loopDetector.updateLastStatus("error"),Y.add(v.id),O.shouldTerminate){ae=O;break}}if(ae&&(yield {type:"error",error:ae.message},y=!0),y)break;let Pe=Y.size>0?M.filter(v=>!Y.has(v.id)):M,ne=new Set(this.modeStrategy.filterTools(this.tools).map(v=>v.name)),le=v=>v.replace(/["\s/>]+$/g,"").trim(),be=[];for(let v of Pe){let I=le(v.function.name);if(ne.has(I)||ne.has(v.function.name)){be.push(v);continue}let J=`Tool "${v.function.name}" is not allowed in ${this.currentMode} mode`;oe.toolError(v.function.name,J),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:v.id,name:v.function.name,output:J,success:!1,timestamp:Date.now()}},yield {type:"tool_output",id:v.id,name:v.function.name,output:J,success:!1},this.memory.addToolResult(v.id,v.function.name,J),f.info("PERMISSION",`Tool blocked by mode: ${v.function.name} - ${J}`);}if(be.length===0)continue;let W=be.map(v=>({id:v.id,type:"function",function:{name:v.function.name,arguments:(()=>{let I=j.get(v.id);return I?.ok?JSON.stringify(I.args):v.function.arguments})()}})),ie=!1;if(process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} Before permission check. shouldAutoApprove=${this.modeStrategy.shouldAutoApprove()}, parallelToolCalls=${W.length}`),!this.modeStrategy.shouldAutoApprove()){let v=new Set;try{for(let I of be)try{let J=j.get(I.id);if(!J?.ok)continue;let ye=J.args,O=this.tools.find(L=>L.name===I.function.name);if(!O){f.warn("RUNNER",`Tool not found: ${I.function.name}`);continue}let K=await Jc(s,async()=>this.permissionManager.checkPermission(O,ye));if(!K.allowed){v.add(I.id);let L=K.reason||`Tool "${I.function.name}" was denied`;oe.toolError(I.function.name,L),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:I.id,name:I.function.name,output:L,success:!1,timestamp:Date.now()}},yield {type:"tool_output",id:I.id,name:I.function.name,output:L,success:!1};let ue=JSON.stringify({type:"ephemeral",status:"error",tool:I.function.name,summary:"Tool execution denied by user",error:L,final:!0});this.memory.addToolResult(I.id,I.function.name,ue),f.info("PERMISSION",`Tool denied: ${I.function.name} - ${L}`),ie=!0;}}catch(J){if(J?.name==="AbortError"||J?.code==="ERR_CANCELED")throw J;oe.toolError(I.function.name,J?.message||"permission check failed");}}catch(I){if(I?.name==="AbortError"||I?.code==="ERR_CANCELED"){f.info("RUNNER","Interrupt detected during permission check"),y=!0;break}throw I}if(be=be.filter(I=>!v.has(I.id)),W=W.filter(I=>!v.has(I.id)),ie){f.info("RUNNER","User denied tool - terminating current turn");break}if(W.length===0)continue}if(process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} After permission check. parallelToolCalls=${W.length}, userDeniedTool=${ie}`),this.toolInputGuardrails.length>0){let v=new Set;try{for(let I of be)try{let J=j.get(I.id);if(!J?.ok)continue;let ye=J.args,O={tool_name:I.function.name,tool_input:ye,tool_call_id:I.id},K=this.tools.find(z=>z.name===I.function.name);if(!K)continue;this.runContext.iteration=d;let L=await Jc(s,async()=>ss.runToolInputGuardrails(this.toolInputGuardrails,{context:this.runContext,tool_context:O,agent_name:this.agentName,tool:K}));if(!L.should_execute){v.add(I.id);let z=L.rejection_message||`Tool ${I.function.name} was blocked by guardrail`;oe.toolError(I.function.name,`Blocked by guardrail: ${z}`),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:I.id,name:I.function.name,output:z,success:!1,timestamp:Date.now()}},yield {type:"tool_output",id:I.id,name:I.function.name,output:z,success:!1},this.memory.addToolResult(I.id,I.function.name,z),Ho(this.runContext,I.function.name,ye,!1);}}catch(J){if(J?.name==="AbortError"||J?.code==="ERR_CANCELED")throw J;if(J instanceof rt){oe.toolError(I.function.name,`Guardrail tripwire triggered: ${J.message}`),yield {type:"error",error:`Guardrail tripwire triggered for ${I.function.name}: ${J.message}`},y=!0;break}oe.toolError(I.function.name,`Guardrail check failed: ${J?.message}`);}}catch(I){if(I?.name==="AbortError"||I?.code==="ERR_CANCELED"){f.info("RUNNER","Interrupt detected during guardrails check"),y=!0;break}throw I}if(y)break;if(be=be.filter(I=>!v.has(I.id)),W=W.filter(I=>!v.has(I.id)),W.length===0)continue}process.env.CLI_DEBUG==="1"&&f.debug("RUNNER",`\u{1F525} Before tool execution. parallelToolCalls=${W.length}`);let Q=await this.parallelExecutor.execute(W,this.tools,v=>{if(oe.toolCall(v.name,{}),v.success){let J=typeof v.output=="string"?v.output.length:JSON.stringify(v.output).length;oe.toolResult(v.name,!0,J,v.executionTime||0);}else oe.toolError(v.name,v.output);let I={type:"tool_call_output_item",id:v.id,name:v.name,output:v.output,success:v.success,timestamp:Date.now()};},s);for(let v of Q.results){if(this.toolMetricsHistory.push({name:v.name,duration:v.executionTime||0,success:v.success}),this.toolMetricsHistory.length>50&&this.toolMetricsHistory.shift(),yield {type:"run_item_stream_event",name:"tool_output",item:{type:"tool_call_output_item",id:v.id,name:v.name,output:v.output,success:v.success,timestamp:Date.now()}},yield {type:"tool_output",id:v.id,name:v.name,output:v.output,success:v.success},v.name==="update_plan"&&v.success)try{f.info("PLAN_UPDATE","\u{1F525} Detected update_plan tool call",{resultId:v.id,toolCallsCount:M.length});let L=M.find(z=>z.id===v.id);if(L){f.info("PLAN_UPDATE","\u{1F525} Found original call",{callId:L.id,argsLength:L.function.arguments?.length});let z=Fs(L.function.arguments||"{}");if(!z.ok)throw new Error(z.reason||"Invalid update_plan arguments");let ue=z.args;f.info("PLAN_UPDATE","\u{1F525} Parsed plan args",{hasExplanation:!!ue.explanation,planSteps:ue.plan?.length}),yield {type:"plan_update",explanation:ue.explanation,plan:ue.plan,timestamp:Date.now()},f.info("PLAN_UPDATE","\u2705 Emitted plan_update event");}else f.warn("PLAN_UPDATE","\u274C Could not find original tool call",{resultId:v.id,availableIds:M.map(z=>z.id)});}catch(L){f.error("PLAN_UPDATE","\u274C Failed to parse plan",{error:L});}let J=typeof v.output=="string"?Kc(v.output):Kc(JSON.stringify(v.output));J=this.enrichToolResult(J,v.name,v.executionTime||0);let ye=M.find(L=>L.id===v.id),O={};if(ye){let L=Fs(ye.function.arguments||"{}");L.ok&&(O=L.args);}if(this.toolOutputGuardrails.length>0)try{let L=this.tools.find(z=>z.name===v.name);if(L){let z={tool_name:v.name,tool_input:O,tool_call_id:v.id},ue=await ss.runToolOutputGuardrails(this.toolOutputGuardrails,{context:this.runContext,tool_context:z,agent_name:this.agentName,tool:L,output:v.output});ue.should_use_output||(J=ue.replacement_message||"[Output blocked by guardrail]",oe.toolError(v.name,"Output blocked by guardrail"));}}catch(L){L instanceof rt&&oe.toolError(v.name,`Output guardrail tripwire triggered: ${L.message}`);}if(!v.success&&typeof v.output=="string"){let L=v.output.toLowerCase();if(L.includes("operation cancelled")||L.includes("command interrupted")||L.includes("request aborted")){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Runner] Detected cancellation in tool output, breaking loop"),f.info("RUNNER","\u68C0\u6D4B\u5230\u5DE5\u5177\u4E2D\u65AD\u4FE1\u53F7\uFF0C\u7EC8\u6B62\u6267\u884C\u5FAA\u73AF"),y=!0;break}}Ho(this.runContext,v.name,O,v.success),f.info("TOOL_RESULT",`\u{1F4E6} Tool raw output: ${v.name}`,{toolName:v.name,success:v.success,rawLength:typeof v.output=="string"?v.output.length:JSON.stringify(v.output).length,truncatedLength:J.length,outputPreview:J.substring(0,500)}),this.memory.addToolResult(v.id,v.name,J);let K=v.success?"success":"error";try{let L=typeof v.output=="string"?v.output:JSON.stringify(v.output),z=JSON.parse(L);z.status==="already_done"?K="already_done":z.status==="success"?K="success":z.status==="error"&&(K="error");}catch{}if(this.loopDetector.updateLastStatus(K),K==="error"){let L=(S.get(v.name)||0)+1;if(S.set(v.name,L),v.name==="edit_file"&&(L===2||L===3)){let z=typeof v.output=="string"?v.output:JSON.stringify(v.output),ue=v.name,re=Bc(ue,z);this.memory.add({role:"system",content:re});}}else S.set(v.name,0);}if(d>0&&d%5===0){let v=this.buildPerformanceHint();v&&(this.memory.add({role:"system",content:v}),process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Runner] Performance hint injected:",v));}if(process.env.CLI_DEBUG_CONSOLE==="1"&&Q.stats&&(yield {type:"raw_response_event",data:{type:"parallel_execution.stats",stats:Q.stats},event_type:"parallel_execution.stats"}),s?.aborted){y=!0;break}continue}else {if(this.plannerMode&&b<2&&this.shouldAutoContinuePlan(A)){b++;let B=this.buildPlanFollowupPrompt();yield {type:"raw_response_event",data:{type:"plan.auto_continue",plan_text:A,followup_prompt:B,count:b},event_type:"plan.auto_continue"},this.memory.add({role:"user",content:B});continue}if(A&&(yield {type:"run_item_stream_event",name:"message_output_created",item:{type:"message_output_item",content:A,role:"assistant",timestamp:Date.now()}}),process.env.CLI_DEBUG==="1"&&(f.info("RUNNER","=== Loop Exit: No Tool Calls ==="),f.info("RUNNER",`Finish Reason: ${ee}`),f.info("RUNNER",`Content Length: ${A.length}`),f.info("RUNNER",`Content Preview: ${A.slice(0,300)}`),f.info("RUNNER",`Tool Calls Count: ${M.length}`),f.info("RUNNER",`Iteration: ${d}`)),this.structuredValidator){let B=this.structuredValidator.validate(A);if(B.ok)m=B.normalized||A,yield {type:"raw_response_event",data:{type:"structured_output.accepted",schema:this.structuredOutput?.name,normalized_text:m,parsed:B.parsed},event_type:"structured_output.accepted"};else {yield {type:"raw_response_event",data:{type:"structured_output.retry",schema:this.structuredOutput?.name,reason:B.reason,message:B.message,errors:B.errors},event_type:"structured_output.retry"},this.memory.add({role:"system",content:this.structuredValidator.buildRetryPrompt(B)}),m="";continue}}else m=A;this.outputGuardrails.length>0&&m&&(yield {type:"raw_response_event",data:{type:"output_guardrails.check_start",count:this.outputGuardrails.length},event_type:"output_guardrails.check_start"},await ss.runOutputGuardrails(this.outputGuardrails,n,this.agentName,m),yield {type:"raw_response_event",data:{type:"output_guardrails.check_passed"},event_type:"output_guardrails.check_passed"});break}}catch(D){if(D?.type==="stream_retry"){$=true,yield D;continue}let N=D instanceof ge?D:nt(D);if(process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Runner] Error classified:",{category:N.category,code:N.code,retryable:N.retryable,message:N.message}),N.category==="canceled"){w="interrupted",y=true,yield {type:"error",error:"Task interrupted by user."};break}if(N.retryable&&x<R&&!$){x++;let H=Dn(N.category,x,N.retryAfter),M=N.category==="retryable_rate_limit",ee=N.code==="STREAM_TIMEOUT",P=N.category==="retryable_network"||N.category==="retryable_stream";f.warn("RUNNER",`Retrying after ${Je(H)} (attempt ${x}/${R}): ${N.message}`),yield {type:"raw_response_event",data:{type:"runner.stream_retry",error:N.message,errorCode:N.code,attempt:x,maxRetries:R,delayMs:H,isRateLimit:M,isStreamTimeout:ee,isNetworkError:P},event_type:"runner.stream_retry"},await $s(H),d--;continue}let E=Jr(N),A=N.message;E&&!A.includes(E)&&(A=`${A}
|
|
1482
1482
|
|
|
1483
|
-
\u{1F4A1} Suggestion: ${
|
|
1483
|
+
\u{1F4A1} Suggestion: ${E}`),y=true;let F=Nc(A,{providerName:this.providerName});oe.agentError(F),yield {type:"raw_response_event",data:{type:"error.classified",category:N.category,code:N.code,message:N.message,retryable:N.retryable,suggestion:E,context:N.context},event_type:"error.classified"},yield {type:"error",error:F};break}}!y&&!U&&d>=G&&!m&&(w=w||"iteration_limit",y=true,yield {type:"error",error:`Reached max iterations (${G}). Please summarize progress and ask whether to continue.`}),y||(oe.agentComplete(d,h,g),f.info("LLM",`Complete: iterations=${d}, toolCalls=${h}, tokens=${g.totalTokens} (prompt=${g.promptTokens}, completion=${g.completionTokens})`)),process.env.CLI_DEBUG==="1"&&(f.debug("RUNNER","=== runner.run COMPLETING ==="),f.debug("RUNNER",` iterations: ${d}`),f.debug("RUNNER",` toolCalls: ${h}`),f.debug("RUNNER",` encounteredError: ${y}`),w&&f.debug("RUNNER",` stoppedBy: ${w}`)),yield {type:"run_done"},process.env.CLI_DEBUG==="1"&&f.debug("RUNNER","=== runner.run END (run_done yielded) ===");}shouldAutoContinuePlan(e){if(!this.plannerMode)return false;let t=(e||"").trim();if(t.length<40)return false;let s=t.toLowerCase();return ["planned steps","plan:","execution plan","\u884C\u52A8\u8BA1\u5212","\u8BA1\u5212\uFF1A","\u8BA1\u5212\u5982\u4E0B","\u65B9\u6848\uFF1A","\u6B65\u9AA4\u8BA1\u5212"].some(a=>s.includes(a))?(t.match(/(^|\n)\s*[-*•]\s+/g)||[]).length+(t.match(/(^|\n)\s*\d+\.\s+/g)||[]).length>=2:false}buildPlanFollowupPrompt(){return "Plan approved. Continue executing the plan step by step and start working immediately."}enrichToolResult(e,t,s){if(s<1e3)return e;let n=s>=1e3?`${(s/1e3).toFixed(1)}s`:`${s}ms`;return `\u23F1\uFE0F [${t} took ${n}]
|
|
1484
1484
|
|
|
1485
1485
|
`+e}buildPerformanceHint(){let e=this.toolMetricsHistory.slice(-15);if(e.length<5)return null;let t=new Map;for(let i of e)if(i.duration>2e3){let o=t.get(i.name)||{count:0,totalTime:0};t.set(i.name,{count:o.count+1,totalTime:o.totalTime+i.duration});}let s=new Map;for(let i of e){let o=s.get(i.name)||{total:0,failed:0};s.set(i.name,{total:o.total+1,failed:o.failed+(i.success?0:1)});}let n=[];for(let[i,o]of t.entries())o.count>=3&&n.push(`\u26A0\uFE0F Tool "${i}" is slow (>2s), called ${o.count} times, total ${(o.totalTime/1e3).toFixed(1)}s. Consider caching results or using alternatives.`);for(let[i,o]of s.entries()){let a=o.failed/o.total;o.total>=3&&a>=.5&&n.push(`\u26A0\uFE0F Tool "${i}" has ${Math.round(a*100)}% failure rate (${o.failed}/${o.total}). Check arguments or try different approach.`);}return n.length===0?null:`
|
|
1486
1486
|
[Performance Notice]
|
|
1487
1487
|
${n.join(`
|
|
1488
1488
|
`)}
|
|
1489
|
-
`}};
|
|
1489
|
+
`}};me();var Kg={name:"require_read_before_edit",guardrail_function:async r=>{let{tool_name:e,tool_input:t}=r.tool_context;if(e!=="edit_file")return zr();let s=t.file_path;if(!s)return zr();let n=l=>X__default.resolve(l).replace(/\\/g,"/"),i=n(s),o=$c(r.context,20);return process.env.CLI_DEBUG==="1"&&(f.debug("GUARDRAIL",`Checking edit for: ${s}`),f.debug("GUARDRAIL",`Normalized path: ${i}`),f.debug("GUARDRAIL",`Recent tool calls (${o.length}):`),o.forEach((l,c)=>{if(l.name==="readfile"){let u=l.args.path,p=u?n(u):"undefined";f.debug("GUARDRAIL",` [${c}] readfile: ${u} (normalized: ${p}) success=${l.success}`);}})),o.some(l=>{if(l.name!=="readfile"||!l.success)return false;let c=l.args.path;if(!c)return false;let p=n(c)===i||c===s;return process.env.CLI_DEBUG==="1"&&p&&f.debug("GUARDRAIL",` \u2713 Found matching readfile: ${c}`),p})?zr():(f.warn("GUARDRAIL",`Edit without recent readfile: ${s} (abs: ${i})`),process.env.CLI_DEBUG==="1"&&f.debug("GUARDRAIL",`Available readfile calls: ${o.filter(l=>l.name==="readfile").length}`),xc(`\u26A0\uFE0F \u7F16\u8F91\u524D\u8BF7\u5148\u8BFB\u53D6\u6587\u4EF6
|
|
1490
1490
|
|
|
1491
1491
|
\u6587\u4EF6: ${s}
|
|
1492
1492
|
|
|
1493
1493
|
\u{1F4A1} \u8BF7\u5148\u4F7F\u7528 readfile \u8BFB\u53D6\u6587\u4EF6\u5185\u5BB9\uFF0C\u786E\u8BA4\u5F53\u524D\u72B6\u6001\u540E\u518D\u8FDB\u884C\u7F16\u8F91\u3002
|
|
1494
|
-
\u8FD9\u53EF\u4EE5\u907F\u514D\u57FA\u4E8E\u8FC7\u65F6\u4FE1\u606F\u8FDB\u884C\u7F16\u8F91\u3002`,{file_path:s,suggestion:"use readfile first"}))}};var
|
|
1494
|
+
\u8FD9\u53EF\u4EE5\u907F\u514D\u57FA\u4E8E\u8FC7\u65F6\u4FE1\u606F\u8FDB\u884C\u7F16\u8F91\u3002`,{file_path:s,suggestion:"use readfile first"}))}};var Yc=[Kg],Xc=[];var bt=class{prepareRequest(e,t){let{model:s,temperature:n,maxInputTokens:i,disableSystemPrompt:o,systemPromptOverride:a,...l}=t,c=this.constraints.validateParams({model:s,temperature:n,max_tokens:i,...l}),u=this.constraints.normalizeParams({model:s,temperature:n,max_tokens:i,...l}),p=o?null:a&&a.trim().length>0?a:this.promptBuilder.buildSystemPrompt({workDir:process.cwd(),language:this.detectLanguage(),modelName:s}),d=o||!p?e:this.injectSystemPrompt(e,p),m={...u,model:s,maxInputTokens:this.applyTokenLimits(s,i)};return {messages:d,options:m,validation:{valid:c.valid,errors:c.errors,warnings:c.warnings}}}injectSystemPrompt(e,t){if(e.some(n=>n.role==="system")){let n=e.filter(a=>a.role==="system").map(a=>this.normalizeSystemContent(a.content)).filter(a=>a.length>0),i=n.length>0?[t,...n].join(`
|
|
1495
1495
|
|
|
1496
|
-
`):t,o=e.filter(a=>a.role!=="system");return [{role:"system",content:i},...o]}return [{role:"system",content:t},...e]}normalizeSystemContent(e){return e?typeof e=="string"?e.trim():Array.isArray(e)?e.map(s=>!s||typeof s!="object"?"":s.type==="text"&&typeof s.text=="string"?s.text:"").join("").trim():String(e).trim():""}applyTokenLimits(e,t){if(!e)return t;let s=this.constraints.getTokenLimits(e);return Math.min(t||4096,s.maxOutput)}detectLanguage(){return process.env.NEOX_LANGUAGE==="en"?"en":"zh"}};var jg={"gpt-5.2":{id:"gpt-5.2",displayName:"GPT-5.2",provider:"openai",maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:96,reasoning:98,vision:92,creativity:94,speed:75,cost:25},releaseDate:"2025-12-11",notes:'400K \u4E0A\u4E0B\u6587\u7A97\u53E3,128K \u8F93\u51FA\u9650\u5236,\u4EE3\u53F7"Garlic"'},"gpt-5.2-codex":{id:"gpt-5.2-codex",displayName:"GPT-5.2 Codex",provider:"openai",aliases:["gpt-5.2-codex"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:98,reasoning:97,vision:90,creativity:92,speed:70,cost:20},releaseDate:"2025-12-10",notes:"GPT-5.2 \u7684 Codex \u9ED8\u8BA4\u7248\u672C,\u4E13\u4E3A\u7F16\u7A0B\u4EFB\u52A1\u4F18\u5316"},"gpt-5.2-codex-high":{id:"gpt-5.2-codex-high",displayName:"GPT-5.2 Codex High",provider:"openai",aliases:["gpt-5.2-codex-h"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:99,reasoning:98,vision:90,creativity:93,speed:60,cost:15},releaseDate:"2025-12-10",notes:"GPT-5.2 Codex \u9AD8\u6027\u80FD\u6A21\u5F0F,\u6700\u5F3A\u7F16\u7A0B\u80FD\u529B,\u66F4\u6162\u66F4\u8D35"},"gpt-5.2-codex-medium":{id:"gpt-5.2-codex-medium",displayName:"GPT-5.2 Codex Medium",provider:"openai",aliases:["gpt-5.2-codex-m"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:95,reasoning:94,vision:88,creativity:90,speed:80,cost:40},releaseDate:"2025-12-10",notes:"GPT-5.2 Codex \u5E73\u8861\u6A21\u5F0F,\u6027\u4EF7\u6BD4\u4F18\u9009"},"gpt-5.1":{id:"gpt-5.1",displayName:"GPT-5.1",provider:"openai",maxInputTokens:272e3,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:94,reasoning:96,vision:90,creativity:92,speed:80,cost:30},notes:"272K \u4E0A\u4E0B\u6587,128K \u8F93\u51FA,\u9002\u5408\u957F\u4E0A\u4E0B\u6587\u4EFB\u52A1"},"gpt-5.1-codex":{id:"gpt-5.1-codex",displayName:"GPT-5.1 Codex",provider:"openai",aliases:["gpt-5-codex","gpt-5.1-codex-max"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:97,reasoning:95,vision:88,creativity:90,speed:75,cost:25},notes:"Codex \u4F18\u5316\u7248,400K \u4E0A\u4E0B\u6587,\u4E13\u4E3A agentic \u7F16\u7A0B\u5DE5\u4F5C\u6D41\u8BBE\u8BA1"},"gpt-5.1-codex-mini":{id:"gpt-5.1-codex-mini",displayName:"GPT-5.1 Codex Mini",provider:"openai",aliases:["gpt-5-codex-mini"],maxInputTokens:272e3,maxOutputTokens:128e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:0,creativity:85,speed:92,cost:85},notes:"\u66F4\u5FEB\u66F4\u4FBF\u5B9C\u7684 Codex \u7248\u672C"},"gpt-5":{id:"gpt-5",displayName:"GPT-5",provider:"openai",maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:94,vision:90,creativity:94,speed:80,cost:35},deprecated:true,replacedBy:"gpt-5.1",notes:"\u5DF2\u88AB GPT-5.1 \u66FF\u4EE3"},"gpt-4.1":{id:"gpt-4.1",displayName:"GPT-4.1",provider:"openai",aliases:["gpt-4.1-2025-04-14"],maxInputTokens:1e6,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:92,vision:88,creativity:90,speed:65,cost:15},releaseDate:"2025-04-14",notes:"\u8D85\u5927 1M+ \u4E0A\u4E0B\u6587\u7A97\u53E3,\u9002\u5408\u5904\u7406\u5927\u578B\u4EE3\u7801\u5E93"},"gpt-4o":{id:"gpt-4o",displayName:"GPT-4o",provider:"openai",aliases:["gpt-4o-2024-11-20","gpt-4o-2024-08-06"],maxInputTokens:128e3,maxOutputTokens:16384,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:85,vision:88,creativity:88,speed:75,cost:50}},"gpt-4o-mini":{id:"gpt-4o-mini",displayName:"GPT-4o Mini",provider:"openai",aliases:["gpt-4o-mini-2024-07-18"],maxInputTokens:128e3,maxOutputTokens:16384,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:75,reasoning:72,vision:80,creativity:75,speed:92,cost:90}},o3:{id:"o3",displayName:"o3",provider:"openai",maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:92,reasoning:99,vision:0,creativity:78,speed:40,cost:15},notes:"\u65B0\u4E00\u4EE3\u63A8\u7406\u6A21\u578B,\u63A8\u7406\u80FD\u529B\u6700\u5F3A"},"o3-mini":{id:"o3-mini",displayName:"o3 Mini",provider:"openai",aliases:["o3-mini-2025-01-31"],maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:88,reasoning:95,vision:0,creativity:75,speed:65,cost:60}},"o4-mini":{id:"o4-mini",displayName:"o4 Mini",provider:"openai",maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:90,reasoning:96,vision:0,creativity:76,speed:70,cost:55}},o1:{id:"o1",displayName:"o1",provider:"openai",aliases:["o1-2024-12-17"],maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:88,reasoning:95,vision:0,creativity:75,speed:45,cost:25}},"o1-mini":{id:"o1-mini",displayName:"o1 Mini",provider:"openai",aliases:["o1-mini-2024-09-12"],maxInputTokens:128e3,maxOutputTokens:65536,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:82,reasoning:88,vision:0,creativity:70,speed:70,cost:70}},"codex-mini-latest":{id:"codex-mini-latest",displayName:"Codex Mini (Latest)",provider:"openai",maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:82,vision:0,creativity:75,speed:88,cost:80}},"gpt-4-turbo":{id:"gpt-4-turbo",displayName:"GPT-4 Turbo",provider:"openai",aliases:["gpt-4-turbo-2024-04-09"],maxInputTokens:128e3,maxOutputTokens:4096,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:87,vision:85,creativity:90,speed:70,cost:40}},"gpt-3.5-turbo":{id:"gpt-3.5-turbo",displayName:"GPT-3.5 Turbo",provider:"openai",maxInputTokens:16385,maxOutputTokens:4096,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:65,reasoning:60,vision:0,creativity:70,speed:95,cost:98}}},Gg={"claude-opus-4-6":{id:"claude-opus-4-6",displayName:"Claude Opus 4.6",provider:"anthropic",aliases:["claude-opus-4.6"],maxInputTokens:2e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:99,reasoning:98,vision:91,creativity:96,speed:66,cost:18},notes:"Claude Opus 4.6 (latest alias)"},"claude-opus-4-5-20251101":{id:"claude-opus-4-5-20251101",displayName:"Claude Opus 4.5",provider:"anthropic",aliases:["claude-opus-4.5"],maxInputTokens:2e5,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:98,reasoning:97,vision:90,creativity:95,speed:65,cost:20},releaseDate:"2025-11-24",notes:"\u6700\u5F3A Claude \u6A21\u578B,\u652F\u6301 Extended Thinking,\u4F01\u4E1A\u7248\u53EF\u6269\u5C55\u81F3 1M \u4E0A\u4E0B\u6587"},"claude-sonnet-4-5-20250929":{id:"claude-sonnet-4-5-20250929",displayName:"Claude Sonnet 4.5",provider:"anthropic",aliases:["claude-sonnet-4.5","claude-sonnet-4-5-20250929-thinking"],maxInputTokens:2e5,maxOutputTokens:16e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:90,vision:88,creativity:90,speed:80,cost:50},releaseDate:"2025-09-29",notes:"\u5E73\u8861\u6027\u80FD\u4E0E\u6210\u672C,beta \u7248\u672C\u652F\u6301 1M \u4E0A\u4E0B\u6587"},"claude-sonnet-4-20250514":{id:"claude-sonnet-4-20250514",displayName:"Claude Sonnet 4",provider:"anthropic",aliases:["claude-sonnet-4"],maxInputTokens:2e5,maxOutputTokens:16e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:85,creativity:88,speed:82,cost:55},notes:"2025-08-12 \u5347\u7EA7\u652F\u6301 1M beta \u4E0A\u4E0B\u6587"},"claude-opus-4-20250514":{id:"claude-opus-4-20250514",displayName:"Claude Opus 4",provider:"anthropic",aliases:["claude-opus-4"],maxInputTokens:2e5,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:96,reasoning:95,vision:88,creativity:94,speed:70,cost:25}},"claude-haiku-4-5-20251001":{id:"claude-haiku-4-5-20251001",displayName:"Claude Haiku 4.5",provider:"anthropic",aliases:["claude-haiku-4.5"],maxInputTokens:2e5,maxOutputTokens:8e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:78,reasoning:75,vision:80,creativity:75,speed:95,cost:95},notes:"\u6700\u5FEB\u6700\u4FBF\u5B9C\u7684 Claude 4.5 \u6A21\u578B"},"claude-3-5-sonnet-20241022":{id:"claude-3-5-sonnet-20241022",displayName:"Claude 3.5 Sonnet (New)",provider:"anthropic",aliases:["claude-3.5-sonnet-new","claude-3-5-sonnet-latest"],maxInputTokens:2e5,maxOutputTokens:16e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:85,creativity:87,speed:85,cost:55},releaseDate:"2024-10-22",notes:"Claude 3.5 Sonnet \u5347\u7EA7\u7248"},"claude-3-5-haiku-20241022":{id:"claude-3-5-haiku-20241022",displayName:"Claude 3.5 Haiku",provider:"anthropic",aliases:["claude-3.5-haiku"],maxInputTokens:2e5,maxOutputTokens:8e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:75,reasoning:72,vision:78,creativity:73,speed:98,cost:98},releaseDate:"2024-10-22",notes:"\u6700\u5FEB\u6700\u4FBF\u5B9C\u7684 Claude 3.5 \u6A21\u578B"}},Bg={"gemini-3-pro-preview":{id:"gemini-3-pro-preview",displayName:"Gemini 3 Pro Preview",provider:"gemini",aliases:["gemini-3-pro","gemini-3.0-pro-preview"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:94,reasoning:95,vision:96,creativity:94,speed:72,cost:35},releaseDate:"2026-01",notes:"Gemini 3 \u9884\u89C8\u7248,UI/\u89C6\u89C9\u8BBE\u8BA1\u4E13\u957F,1M \u4E0A\u4E0B\u6587"},"gemini-3.0-pro":{id:"gemini-3.0-pro",displayName:"Gemini 3.0 Pro",provider:"gemini",aliases:["gemini-3.0-pro-latest"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:95,reasoning:96,vision:94,creativity:92,speed:70,cost:30},releaseDate:"2025-12",notes:"Flagship multimodal model with 1M context, high-precision reasoning"},"gemini-2.5-flash":{id:"gemini-2.5-flash",displayName:"Gemini 2.5 Flash",provider:"gemini",aliases:["gemini-2.5-flash-latest"],maxInputTokens:1048576,maxOutputTokens:65535,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:90,creativity:87,speed:92,cost:85},releaseDate:"2025-03",notes:"Fast and cost-efficient, ~1500 pages or 30K lines of code"},"gemini-2.5-pro":{id:"gemini-2.5-pro",displayName:"Gemini 2.5 Pro",provider:"gemini",aliases:["gemini-2.5-pro-latest"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:93,reasoning:92,vision:92,creativity:90,speed:75,cost:40},releaseDate:"2025-03",notes:"Balanced performance with 1M context window"},"gemini-2.0-flash-thinking":{id:"gemini-2.0-flash-thinking",displayName:"Gemini 2.0 Flash Thinking",provider:"gemini",aliases:["gemini-2.0-flash-thinking-exp","gemini-2.0-flash-thinking-experimental"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:92,reasoning:94,vision:90,creativity:88,speed:85,cost:50},releaseDate:"2024-12-19",notes:"Shows model thought process, 1M context window"},"gemini-2.0-flash":{id:"gemini-2.0-flash",displayName:"Gemini 2.0 Flash",provider:"gemini",aliases:["gemini-2.0-flash-exp","gemini-2.0-flash-experimental"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:89,vision:90,creativity:87,speed:95,cost:75},releaseDate:"2024-12-11",notes:"Twice as fast as Gemini 1.5 Pro, multimodal with native image generation"},"gemini-1.5-pro":{id:"gemini-1.5-pro",displayName:"Gemini 1.5 Pro",provider:"gemini",aliases:["gemini-1.5-pro-latest","gemini-pro"],maxInputTokens:2e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:87,vision:88,creativity:85,speed:70,cost:50},releaseDate:"2024-05",notes:"2M context window - largest available, supports context caching"},"gemini-1.5-flash":{id:"gemini-1.5-flash",displayName:"Gemini 1.5 Flash",provider:"gemini",aliases:["gemini-1.5-flash-latest","gemini-flash"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:83,vision:85,creativity:82,speed:90,cost:85},releaseDate:"2024-05",notes:"Fast and efficient with 1M context, supports code execution"},"gemini-1.5-flash-8b":{id:"gemini-1.5-flash-8b",displayName:"Gemini 1.5 Flash-8B",provider:"gemini",aliases:["gemini-flash-8b"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:80,reasoning:78,vision:82,creativity:77,speed:98,cost:95},releaseDate:"2024-10",notes:"Smaller 8B model, extremely fast and cost-effective"},"gemini-1.0-pro":{id:"gemini-1.0-pro",displayName:"Gemini 1.0 Pro",provider:"gemini",aliases:["gemini-pro-1.0"],maxInputTokens:32768,maxOutputTokens:8192,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:75,reasoning:73,vision:0,creativity:75,speed:85,cost:90},releaseDate:"2023-12",notes:"Original Gemini Pro, text-only"},"gemini-1.0-pro-vision":{id:"gemini-1.0-pro-vision",displayName:"Gemini 1.0 Pro Vision",provider:"gemini",aliases:["gemini-pro-vision"],maxInputTokens:16384,maxOutputTokens:2048,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:70,reasoning:68,vision:80,creativity:72,speed:80,cost:88},releaseDate:"2023-12",notes:"Original multimodal Gemini with vision support"}},Wg={"kimi-k2-0905-preview":{id:"kimi-k2-0905-preview",displayName:"Kimi K2 (0905 Preview)",provider:"kimi",aliases:["kimi-k2","kimi-k2-preview"],maxInputTokens:256e3,maxOutputTokens:8192,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:90,vision:0,creativity:80,speed:85,cost:70},releaseDate:"2025-09",notes:"MoE \u67B6\u6784 K2 \u9884\u89C8\u7248\uFF0C256K \u4E0A\u4E0B\u6587"}},Hg={"deepseek-v3.2":{id:"deepseek-v3.2",displayName:"DeepSeek V3.2",provider:"deepseek",aliases:["deepseek-v3.2-exp"],maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:90,vision:0,creativity:80,speed:85,cost:95},releaseDate:"2025-09-29",notes:"\u5B9E\u9A8C\u7248\u672C,\u6027\u80FD\u663E\u8457\u63D0\u5347"},"deepseek-v3.1":{id:"deepseek-v3.1",displayName:"DeepSeek V3.1",provider:"deepseek",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:0,creativity:78,speed:88,cost:96},releaseDate:"2025-08",notes:"\u6DF7\u5408\u67B6\u6784\u6A21\u578B"},"deepseek-chat":{id:"deepseek-chat",displayName:"DeepSeek Chat",provider:"deepseek",maxInputTokens:64e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:82,vision:0,creativity:75,speed:85,cost:95},notes:"\u901A\u7528\u5BF9\u8BDD\u6A21\u578B,\u6210\u672C\u6781\u4F4E"},"deepseek-coder":{id:"deepseek-coder",displayName:"DeepSeek Coder",provider:"deepseek",maxInputTokens:64e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:95,reasoning:85,vision:0,creativity:70,speed:88,cost:96},notes:"\u4E13\u4E3A\u7F16\u7A0B\u4F18\u5316,\u4EE3\u7801\u80FD\u529B\u7A81\u51FA"},"deepseek-reasoner":{id:"deepseek-reasoner",displayName:"DeepSeek Reasoner",provider:"deepseek",maxInputTokens:64e3,maxOutputTokens:64e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:88,reasoning:96,vision:0,creativity:75,speed:60,cost:90},notes:"\u63A8\u7406\u4E13\u7528\u6A21\u578B,\u652F\u6301\u957F\u8F93\u51FA"}},zg={"minimax-text-01":{id:"minimax-text-01",displayName:"MiniMax Text-01",provider:"minimax",maxInputTokens:4e6,maxOutputTokens:1e6,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:90,vision:0,creativity:85,speed:55,cost:70},notes:"4M \u4E0A\u4E0B\u6587\u7A97\u53E3,Lightning Attention + MoE \u67B6\u6784,\u5F00\u6E90\u53EF\u7528"},"minimax-m1-80k":{id:"minimax-m1-80k",displayName:"MiniMax M1-80K",provider:"minimax",maxInputTokens:1e6,maxOutputTokens:8e4,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:90,reasoning:92,vision:0,creativity:82,speed:65,cost:75},notes:"1M \u4E0A\u4E0B\u6587 + 80K \u601D\u8003\u9884\u7B97"},"minimax-m2.1":{id:"minimax-m2.1",displayName:"MiniMax M2.1",provider:"minimax",maxInputTokens:2e5,maxOutputTokens:64e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:93,reasoning:88,vision:0,creativity:80,speed:82,cost:85},releaseDate:"2025-12",notes:"\u7F16\u7A0B\u548C Agentic \u5DE5\u4F5C\u6D41\u4F18\u5316,\u652F\u6301\u591A\u8BED\u8A00"},"minimax-vl-01":{id:"minimax-vl-01",displayName:"MiniMax VL-01",provider:"minimax",maxInputTokens:4e6,maxOutputTokens:1e6,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:88,vision:92,creativity:88,speed:60,cost:65},notes:"\u591A\u6A21\u6001\u6A21\u578B,\u652F\u6301\u6587\u672C\u548C\u56FE\u50CF"}},qg={"glm-4.7":{id:"glm-4.7",displayName:"GLM-4.7",provider:"glm",maxInputTokens:2e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:85,creativity:87,speed:80,cost:70},releaseDate:"2025-12-22",notes:"\u6700\u65B0\u7248\u672C,200K \u4E0A\u4E0B\u6587,128K \u8F93\u51FA"},"glm-4.6":{id:"glm-4.6",displayName:"GLM-4.6",provider:"glm",maxInputTokens:2e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:86,vision:83,creativity:85,speed:82,cost:75},releaseDate:"2025-09-10",notes:"\u4ECE 128K \u6269\u5C55\u81F3 200K \u4E0A\u4E0B\u6587"},"glm-4.5":{id:"glm-4.5",displayName:"GLM-4.5",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:86,reasoning:84,vision:80,creativity:83,speed:85,cost:80},releaseDate:"2025-07"},"glm-4-flash":{id:"glm-4-flash",displayName:"GLM-4 Flash",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:82,reasoning:80,vision:78,creativity:80,speed:95,cost:92},notes:"\u5FEB\u901F\u6A21\u578B,\u76F8\u5F53\u4E8E 300 \u9875\u4E66\u7684\u4E0A\u4E0B\u6587"},"glm-4-plus":{id:"glm-4-plus",displayName:"GLM-4 Plus",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:86,vision:82,creativity:85,speed:78,cost:65}},"glm-4-air":{id:"glm-4-air",displayName:"GLM-4 Air",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:80,reasoning:78,vision:0,creativity:78,speed:90,cost:88}},"glm-4-long":{id:"glm-4-long",displayName:"GLM-4 Long",provider:"glm",maxInputTokens:1e6,maxOutputTokens:128e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:88,vision:0,creativity:80,speed:50,cost:60},notes:"\u8D85\u957F\u4E0A\u4E0B\u6587\u4E13\u7528,1M tokens"},"glm-4-airx":{id:"glm-4-airx",displayName:"GLM-4 AirX",provider:"glm",maxInputTokens:8e3,maxOutputTokens:4096,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:70,reasoning:68,vision:0,creativity:70,speed:98,cost:98},notes:"\u8D85\u8F7B\u91CF\u7EA7\u6A21\u578B,\u6781\u5FEB\u901F\u5EA6"}},Yo=class{models=new Map;constructor(){this.registerModels(jg),this.registerModels(Gg),this.registerModels(Bg),this.registerModels(Wg),this.registerModels(Hg),this.registerModels(zg),this.registerModels(qg);}registerModels(e){for(let[t,s]of Object.entries(e))if(this.models.set(t,s),s.aliases)for(let n of s.aliases)this.models.set(n,s);}getModel(e){return this.models.get(e)}getAllModels(){let e=new Map;for(let t of this.models.values())e.set(t.id,t);return Array.from(e.values())}getModelsByProvider(e){return this.getAllModels().filter(t=>t.provider===e)}hasModel(e){return this.models.has(e)}toModelCapability(e){let t=this.getModel(e);if(t)return {modelAlias:t.id,strengths:this.inferStrengths(t),scores:{coding:t.scores?.coding??50,reasoning:t.scores?.reasoning??50,vision:t.scores?.vision??0,creativity:t.scores?.creativity??50,speed:t.scores?.speed??50,cost:t.scores?.cost??50},features:{supportsVision:t.supportsVision??false,supportsTools:t.supportsTools??false,supportsFunctionCalling:t.supportsFunctionCalling??false,supportsStreaming:t.supportsStreaming??false,maxContextTokens:t.maxInputTokens,maxOutputTokens:t.maxOutputTokens}}}inferStrengths(e){let t=[],s=e.scores??{};return (s.coding??0)>=85&&t.push("coding"),(s.reasoning??0)>=85&&t.push("reasoning"),(s.vision??0)>=85&&t.push("image_analysis"),(s.creativity??0)>=85&&t.push("creative_writing"),t}},qc=new Yo;var Gt=class{validateParams(e){let t=this.getConstraints(),s=[],n=[];for(let i of Object.keys(e))t.supportedParams.has(i)||n.push(`Parameter '${i}' is not supported by this provider and will be ignored`);if(t.validators){for(let[i,o]of Object.entries(t.validators))if(e[i]!==void 0){let a=o(e[i],e);a===false?s.push(`Invalid value for parameter '${i}': ${e[i]}`):typeof a=="string"&&s.push(`Parameter '${i}': ${a}`);}}if(e.model&&e.max_tokens!==void 0){let i=this.getTokenLimits(e.model);i.found&&e.max_tokens>i.maxInput?s.push(`max_tokens (${e.max_tokens}) exceeds model context window (${i.maxInput}) for ${e.model}`):i.found&&e.max_tokens>i.maxOutput&&n.push(`max_tokens (${e.max_tokens}) exceeds recommended output limit (${i.maxOutput}) for ${e.model}, but is within context window`);}return {valid:s.length===0,errors:s,warnings:n.length>0?n:void 0}}getTokenLimits(e){let t=qc.getModel(e);if(t)return {maxOutput:t.maxOutputTokens,maxInput:t.maxInputTokens,found:true,source:"model"};let s=this.getConstraints(),n=s.maxOutputTokens[e],i=s.maxInputTokens[e];if(n!==void 0&&i!==void 0)return {maxOutput:n,maxInput:i,found:true,source:"model"};for(let[o,a]of Object.entries(s.maxOutputTokens))if(this.matchPattern(e,o))return {maxOutput:a,maxInput:s.maxInputTokens[o]||128e3,found:true,source:"model"};return {maxOutput:4096,maxInput:128e3,found:false,source:"fallback"}}normalizeParams(e){let t=this.getConstraints(),s={};for(let[n,i]of Object.entries(e)){let o=t.paramAliases?.[n]||n;t.supportedParams.has(n)&&(s[o]=i);}if(t.defaults)for(let[n,i]of Object.entries(t.defaults))s[n]===void 0&&(s[n]=i);return s}matchPattern(e,t){return t.includes("*")?new RegExp("^"+t.replace(/\*/g,".*")+"$").test(e):e===t}isParamSupported(e){return this.getConstraints().supportedParams.has(e)}getParamAlias(e){return this.getConstraints().paramAliases?.[e]||e}};function je(r,e){return t=>{let s=Number(t);return isNaN(s)?"Must be a number":s<r||s>e?`Must be between ${r} and ${e}`:true}}function Us(r){return e=>r.includes(e)?true:`Must be one of: ${r.join(", ")}`}function Jc(r){return e=>{let t=typeof e;return t!==r?`Expected ${r}, got ${t}`:true}}function Zr(...r){return (e,t)=>{for(let s of r){let n=s(e,t);if(n!==true)return n}return true}}var is=class extends Gt{getConstraints(){return {maxOutputTokens:{"gpt-4o":16384,"gpt-4o-2024-11-20":16384,"gpt-4o-2024-08-06":16384,"gpt-4o-2024-05-13":4096,"gpt-4o-mini":16384,"gpt-4o-mini-2024-07-18":16384,"gpt-4-turbo":4096,"gpt-4-turbo-2024-04-09":4096,"gpt-4-turbo-preview":4096,"gpt-4-0125-preview":4096,"gpt-4-1106-preview":4096,"gpt-4":8192,"gpt-4-0613":8192,"gpt-4-0314":8192,"gpt-3.5-turbo":4096,"gpt-3.5-turbo-0125":4096,"gpt-3.5-turbo-1106":4096,o1:1e5,"o1-2024-12-17":1e5,"o1-preview":32768,"o1-preview-2024-09-12":32768,"o1-mini":65536,"o1-mini-2024-09-12":65536,o3:1e5,"o3-mini":1e5,"o3-mini-2025-01-31":1e5,"o4-mini":1e5,"gpt-5":1e5,"gpt-5.1":1e5,"gpt-5.1-codex":1e5,"gpt-5.1-codex-max":1e5,"gpt-5.1-codex-mini":1e5,"gpt-5.2":1e5,"gpt-5.2-codex":1e5,"gpt-5-codex":1e5,"gpt-5-codex-mini":1e5,"codex-mini-latest":1e5,"gpt-4.1":1e5,"gpt-4.1-2025-04-14":1e5,"gpt-4o*":16384,"gpt-4-turbo*":4096,"gpt-4.1*":1e5,"gpt-4*":8192,"gpt-3.5*":4096,"gpt-5*":1e5,"codex*":1e5,"o1*":1e5,"o3*":1e5,"o4*":1e5},maxInputTokens:{"gpt-4o":128e3,"gpt-4o-mini":128e3,"gpt-4-turbo":128e3,"gpt-4-turbo-2024-04-09":128e3,"gpt-4.1":1047576,"gpt-4.1-2025-04-14":1047576,"gpt-4":8192,"gpt-4-32k":32768,"gpt-3.5-turbo":16385,"gpt-3.5-turbo-16k":16385,"gpt-5":272e3,"gpt-5.1":272e3,"gpt-5.1-codex":272e3,"gpt-5.1-codex-max":272e3,"gpt-5.1-codex-mini":272e3,"gpt-5-codex":272e3,"gpt-5-codex-mini":272e3,"gpt-5.2":4e5,"gpt-5.2-codex":4e5,"codex-mini-latest":2e5,o1:2e5,"o1-preview":128e3,"o1-mini":128e3,o3:2e5,"o3-mini":2e5,"o4-mini":2e5,"gpt-4o*":128e3,"gpt-4-turbo*":128e3,"gpt-4.1*":1047576,"gpt-5*":272e3,"gpt-5.2*":4e5,"codex*":272e3,"o1*":2e5,"o3*":2e5,"o4*":2e5},supportedParams:new Set(["model","messages","stream","stream_options","max_tokens","max_completion_tokens","temperature","top_p","top_k","frequency_penalty","presence_penalty","stop","n","seed","reasoning_effort","verbosity","tools","tool_choice","parallel_tool_calls","response_format","logprobs","top_logprobs","logit_bias","modalities","audio","user","safety_identifier","store","service_tier","prompt_cache_key","prompt_cache_retention","metadata","prediction","extra_body","search_parameters","web_search_options"]),validators:{temperature:je(0,2),top_p:je(0,1),frequency_penalty:je(-2,2),presence_penalty:je(-2,2),reasoning_effort:Us(["low","medium","high"]),verbosity:Us(["low","medium","high"]),tool_choice:e=>typeof e=="string"?["none","auto","required"].includes(e)||"Must be 'none', 'auto', or 'required'":typeof e=="object"&&e.type==="function"?true:"Invalid tool_choice format","response_format.type":Us(["text","json_object","json_schema"]),stream:e=>typeof e=="boolean"||"Must be a boolean",n:Zr(e=>typeof e=="number"||"Must be a number",je(1,10)),max_tokens:(e,t)=>{let s=Number(e);if(isNaN(s))return "Must be a number";if(s<1)return "Must be at least 1";t?.model||"";return true}},defaults:{temperature:1,top_p:1,n:1,stream:false,max_tokens:4096}}}isResponsesAPIModel(e){return e.startsWith("o1")||e.startsWith("o3")}supportsReasoning(e){return this.isResponsesAPIModel(e)}supportsVision(e){return e.includes("gpt-4o")||e.includes("gpt-4-turbo")||e.includes("gpt-4-vision")}supportsTools(e){return e.startsWith("o1-preview")||e.startsWith("o1-mini")?false:e.includes("gpt-4")||e.includes("gpt-3.5-turbo")||e.startsWith("o3")}getRecommendedMaxTokens(e,t){let s=this.getTokenLimits(e);switch(t){case "short":return Math.min(1024,s.maxOutput);case "medium":return Math.min(4096,s.maxOutput);case "long":return s.maxOutput;default:return Math.min(4096,s.maxOutput)}}};var Bt=class{combinePromptSections(e){return e.filter(s=>s.content.trim().length>0).sort((s,n)=>(s.order||0)-(n.order||0)).map(s=>s.title?`# ${s.title}
|
|
1496
|
+
`):t,o=e.filter(a=>a.role!=="system");return [{role:"system",content:i},...o]}return [{role:"system",content:t},...e]}normalizeSystemContent(e){return e?typeof e=="string"?e.trim():Array.isArray(e)?e.map(s=>!s||typeof s!="object"?"":s.type==="text"&&typeof s.text=="string"?s.text:"").join("").trim():String(e).trim():""}applyTokenLimits(e,t){if(!e)return t;let s=this.constraints.getTokenLimits(e);return Math.min(t||4096,s.maxOutput)}detectLanguage(){return process.env.NEOX_LANGUAGE==="en"?"en":"zh"}};var Vg={"gpt-5.2":{id:"gpt-5.2",displayName:"GPT-5.2",provider:"openai",maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:96,reasoning:98,vision:92,creativity:94,speed:75,cost:25},releaseDate:"2025-12-11",notes:'400K \u4E0A\u4E0B\u6587\u7A97\u53E3,128K \u8F93\u51FA\u9650\u5236,\u4EE3\u53F7"Garlic"'},"gpt-5.2-codex":{id:"gpt-5.2-codex",displayName:"GPT-5.2 Codex",provider:"openai",aliases:["gpt-5.2-codex"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:98,reasoning:97,vision:90,creativity:92,speed:70,cost:20},releaseDate:"2025-12-10",notes:"GPT-5.2 \u7684 Codex \u9ED8\u8BA4\u7248\u672C,\u4E13\u4E3A\u7F16\u7A0B\u4EFB\u52A1\u4F18\u5316"},"gpt-5.2-codex-high":{id:"gpt-5.2-codex-high",displayName:"GPT-5.2 Codex High",provider:"openai",aliases:["gpt-5.2-codex-h"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:99,reasoning:98,vision:90,creativity:93,speed:60,cost:15},releaseDate:"2025-12-10",notes:"GPT-5.2 Codex \u9AD8\u6027\u80FD\u6A21\u5F0F,\u6700\u5F3A\u7F16\u7A0B\u80FD\u529B,\u66F4\u6162\u66F4\u8D35"},"gpt-5.2-codex-medium":{id:"gpt-5.2-codex-medium",displayName:"GPT-5.2 Codex Medium",provider:"openai",aliases:["gpt-5.2-codex-m"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:95,reasoning:94,vision:88,creativity:90,speed:80,cost:40},releaseDate:"2025-12-10",notes:"GPT-5.2 Codex \u5E73\u8861\u6A21\u5F0F,\u6027\u4EF7\u6BD4\u4F18\u9009"},"gpt-5.1":{id:"gpt-5.1",displayName:"GPT-5.1",provider:"openai",maxInputTokens:272e3,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:94,reasoning:96,vision:90,creativity:92,speed:80,cost:30},notes:"272K \u4E0A\u4E0B\u6587,128K \u8F93\u51FA,\u9002\u5408\u957F\u4E0A\u4E0B\u6587\u4EFB\u52A1"},"gpt-5.1-codex":{id:"gpt-5.1-codex",displayName:"GPT-5.1 Codex",provider:"openai",aliases:["gpt-5-codex","gpt-5.1-codex-max"],maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:97,reasoning:95,vision:88,creativity:90,speed:75,cost:25},notes:"Codex \u4F18\u5316\u7248,400K \u4E0A\u4E0B\u6587,\u4E13\u4E3A agentic \u7F16\u7A0B\u5DE5\u4F5C\u6D41\u8BBE\u8BA1"},"gpt-5.1-codex-mini":{id:"gpt-5.1-codex-mini",displayName:"GPT-5.1 Codex Mini",provider:"openai",aliases:["gpt-5-codex-mini"],maxInputTokens:272e3,maxOutputTokens:128e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:0,creativity:85,speed:92,cost:85},notes:"\u66F4\u5FEB\u66F4\u4FBF\u5B9C\u7684 Codex \u7248\u672C"},"gpt-5":{id:"gpt-5",displayName:"GPT-5",provider:"openai",maxInputTokens:4e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:94,vision:90,creativity:94,speed:80,cost:35},deprecated:true,replacedBy:"gpt-5.1",notes:"\u5DF2\u88AB GPT-5.1 \u66FF\u4EE3"},"gpt-4.1":{id:"gpt-4.1",displayName:"GPT-4.1",provider:"openai",aliases:["gpt-4.1-2025-04-14"],maxInputTokens:1e6,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:92,vision:88,creativity:90,speed:65,cost:15},releaseDate:"2025-04-14",notes:"\u8D85\u5927 1M+ \u4E0A\u4E0B\u6587\u7A97\u53E3,\u9002\u5408\u5904\u7406\u5927\u578B\u4EE3\u7801\u5E93"},"gpt-4o":{id:"gpt-4o",displayName:"GPT-4o",provider:"openai",aliases:["gpt-4o-2024-11-20","gpt-4o-2024-08-06"],maxInputTokens:128e3,maxOutputTokens:16384,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:85,vision:88,creativity:88,speed:75,cost:50}},"gpt-4o-mini":{id:"gpt-4o-mini",displayName:"GPT-4o Mini",provider:"openai",aliases:["gpt-4o-mini-2024-07-18"],maxInputTokens:128e3,maxOutputTokens:16384,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:75,reasoning:72,vision:80,creativity:75,speed:92,cost:90}},o3:{id:"o3",displayName:"o3",provider:"openai",maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:92,reasoning:99,vision:0,creativity:78,speed:40,cost:15},notes:"\u65B0\u4E00\u4EE3\u63A8\u7406\u6A21\u578B,\u63A8\u7406\u80FD\u529B\u6700\u5F3A"},"o3-mini":{id:"o3-mini",displayName:"o3 Mini",provider:"openai",aliases:["o3-mini-2025-01-31"],maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:88,reasoning:95,vision:0,creativity:75,speed:65,cost:60}},"o4-mini":{id:"o4-mini",displayName:"o4 Mini",provider:"openai",maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:90,reasoning:96,vision:0,creativity:76,speed:70,cost:55}},o1:{id:"o1",displayName:"o1",provider:"openai",aliases:["o1-2024-12-17"],maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:88,reasoning:95,vision:0,creativity:75,speed:45,cost:25}},"o1-mini":{id:"o1-mini",displayName:"o1 Mini",provider:"openai",aliases:["o1-mini-2024-09-12"],maxInputTokens:128e3,maxOutputTokens:65536,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:82,reasoning:88,vision:0,creativity:70,speed:70,cost:70}},"codex-mini-latest":{id:"codex-mini-latest",displayName:"Codex Mini (Latest)",provider:"openai",maxInputTokens:2e5,maxOutputTokens:1e5,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:82,vision:0,creativity:75,speed:88,cost:80}},"gpt-4-turbo":{id:"gpt-4-turbo",displayName:"GPT-4 Turbo",provider:"openai",aliases:["gpt-4-turbo-2024-04-09"],maxInputTokens:128e3,maxOutputTokens:4096,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:87,vision:85,creativity:90,speed:70,cost:40}},"gpt-3.5-turbo":{id:"gpt-3.5-turbo",displayName:"GPT-3.5 Turbo",provider:"openai",maxInputTokens:16385,maxOutputTokens:4096,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:65,reasoning:60,vision:0,creativity:70,speed:95,cost:98}}},Yg={"claude-opus-4-6":{id:"claude-opus-4-6",displayName:"Claude Opus 4.6",provider:"anthropic",aliases:["claude-opus-4.6"],maxInputTokens:2e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:99,reasoning:98,vision:91,creativity:96,speed:66,cost:18},notes:"Claude Opus 4.6 (latest alias)"},"claude-opus-4-5-20251101":{id:"claude-opus-4-5-20251101",displayName:"Claude Opus 4.5",provider:"anthropic",aliases:["claude-opus-4.5"],maxInputTokens:2e5,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:98,reasoning:97,vision:90,creativity:95,speed:65,cost:20},releaseDate:"2025-11-24",notes:"\u6700\u5F3A Claude \u6A21\u578B,\u652F\u6301 Extended Thinking,\u4F01\u4E1A\u7248\u53EF\u6269\u5C55\u81F3 1M \u4E0A\u4E0B\u6587"},"claude-sonnet-4-5-20250929":{id:"claude-sonnet-4-5-20250929",displayName:"Claude Sonnet 4.5",provider:"anthropic",aliases:["claude-sonnet-4.5","claude-sonnet-4-5-20250929-thinking"],maxInputTokens:2e5,maxOutputTokens:16e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:90,vision:88,creativity:90,speed:80,cost:50},releaseDate:"2025-09-29",notes:"\u5E73\u8861\u6027\u80FD\u4E0E\u6210\u672C,beta \u7248\u672C\u652F\u6301 1M \u4E0A\u4E0B\u6587"},"claude-sonnet-4-20250514":{id:"claude-sonnet-4-20250514",displayName:"Claude Sonnet 4",provider:"anthropic",aliases:["claude-sonnet-4"],maxInputTokens:2e5,maxOutputTokens:16e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:85,creativity:88,speed:82,cost:55},notes:"2025-08-12 \u5347\u7EA7\u652F\u6301 1M beta \u4E0A\u4E0B\u6587"},"claude-opus-4-20250514":{id:"claude-opus-4-20250514",displayName:"Claude Opus 4",provider:"anthropic",aliases:["claude-opus-4"],maxInputTokens:2e5,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:96,reasoning:95,vision:88,creativity:94,speed:70,cost:25}},"claude-haiku-4-5-20251001":{id:"claude-haiku-4-5-20251001",displayName:"Claude Haiku 4.5",provider:"anthropic",aliases:["claude-haiku-4.5"],maxInputTokens:2e5,maxOutputTokens:8e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:78,reasoning:75,vision:80,creativity:75,speed:95,cost:95},notes:"\u6700\u5FEB\u6700\u4FBF\u5B9C\u7684 Claude 4.5 \u6A21\u578B"},"claude-3-5-sonnet-20241022":{id:"claude-3-5-sonnet-20241022",displayName:"Claude 3.5 Sonnet (New)",provider:"anthropic",aliases:["claude-3.5-sonnet-new","claude-3-5-sonnet-latest"],maxInputTokens:2e5,maxOutputTokens:16e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:85,creativity:87,speed:85,cost:55},releaseDate:"2024-10-22",notes:"Claude 3.5 Sonnet \u5347\u7EA7\u7248"},"claude-3-5-haiku-20241022":{id:"claude-3-5-haiku-20241022",displayName:"Claude 3.5 Haiku",provider:"anthropic",aliases:["claude-3.5-haiku"],maxInputTokens:2e5,maxOutputTokens:8e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:75,reasoning:72,vision:78,creativity:73,speed:98,cost:98},releaseDate:"2024-10-22",notes:"\u6700\u5FEB\u6700\u4FBF\u5B9C\u7684 Claude 3.5 \u6A21\u578B"}},Xg={"gemini-3-pro-preview":{id:"gemini-3-pro-preview",displayName:"Gemini 3 Pro Preview",provider:"gemini",aliases:["gemini-3-pro","gemini-3.0-pro-preview"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:94,reasoning:95,vision:96,creativity:94,speed:72,cost:35},releaseDate:"2026-01",notes:"Gemini 3 \u9884\u89C8\u7248,UI/\u89C6\u89C9\u8BBE\u8BA1\u4E13\u957F,1M \u4E0A\u4E0B\u6587"},"gemini-3.0-pro":{id:"gemini-3.0-pro",displayName:"Gemini 3.0 Pro",provider:"gemini",aliases:["gemini-3.0-pro-latest"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:95,reasoning:96,vision:94,creativity:92,speed:70,cost:30},releaseDate:"2025-12",notes:"Flagship multimodal model with 1M context, high-precision reasoning"},"gemini-2.5-flash":{id:"gemini-2.5-flash",displayName:"Gemini 2.5 Flash",provider:"gemini",aliases:["gemini-2.5-flash-latest"],maxInputTokens:1048576,maxOutputTokens:65535,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:90,creativity:87,speed:92,cost:85},releaseDate:"2025-03",notes:"Fast and cost-efficient, ~1500 pages or 30K lines of code"},"gemini-2.5-pro":{id:"gemini-2.5-pro",displayName:"Gemini 2.5 Pro",provider:"gemini",aliases:["gemini-2.5-pro-latest"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:93,reasoning:92,vision:92,creativity:90,speed:75,cost:40},releaseDate:"2025-03",notes:"Balanced performance with 1M context window"},"gemini-2.0-flash-thinking":{id:"gemini-2.0-flash-thinking",displayName:"Gemini 2.0 Flash Thinking",provider:"gemini",aliases:["gemini-2.0-flash-thinking-exp","gemini-2.0-flash-thinking-experimental"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:92,reasoning:94,vision:90,creativity:88,speed:85,cost:50},releaseDate:"2024-12-19",notes:"Shows model thought process, 1M context window"},"gemini-2.0-flash":{id:"gemini-2.0-flash",displayName:"Gemini 2.0 Flash",provider:"gemini",aliases:["gemini-2.0-flash-exp","gemini-2.0-flash-experimental"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:89,vision:90,creativity:87,speed:95,cost:75},releaseDate:"2024-12-11",notes:"Twice as fast as Gemini 1.5 Pro, multimodal with native image generation"},"gemini-1.5-pro":{id:"gemini-1.5-pro",displayName:"Gemini 1.5 Pro",provider:"gemini",aliases:["gemini-1.5-pro-latest","gemini-pro"],maxInputTokens:2e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:87,vision:88,creativity:85,speed:70,cost:50},releaseDate:"2024-05",notes:"2M context window - largest available, supports context caching"},"gemini-1.5-flash":{id:"gemini-1.5-flash",displayName:"Gemini 1.5 Flash",provider:"gemini",aliases:["gemini-1.5-flash-latest","gemini-flash"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:83,vision:85,creativity:82,speed:90,cost:85},releaseDate:"2024-05",notes:"Fast and efficient with 1M context, supports code execution"},"gemini-1.5-flash-8b":{id:"gemini-1.5-flash-8b",displayName:"Gemini 1.5 Flash-8B",provider:"gemini",aliases:["gemini-flash-8b"],maxInputTokens:1e6,maxOutputTokens:65536,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:80,reasoning:78,vision:82,creativity:77,speed:98,cost:95},releaseDate:"2024-10",notes:"Smaller 8B model, extremely fast and cost-effective"},"gemini-1.0-pro":{id:"gemini-1.0-pro",displayName:"Gemini 1.0 Pro",provider:"gemini",aliases:["gemini-pro-1.0"],maxInputTokens:32768,maxOutputTokens:8192,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:75,reasoning:73,vision:0,creativity:75,speed:85,cost:90},releaseDate:"2023-12",notes:"Original Gemini Pro, text-only"},"gemini-1.0-pro-vision":{id:"gemini-1.0-pro-vision",displayName:"Gemini 1.0 Pro Vision",provider:"gemini",aliases:["gemini-pro-vision"],maxInputTokens:16384,maxOutputTokens:2048,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:70,reasoning:68,vision:80,creativity:72,speed:80,cost:88},releaseDate:"2023-12",notes:"Original multimodal Gemini with vision support"}},Zg={"kimi-k2-0905-preview":{id:"kimi-k2-0905-preview",displayName:"Kimi K2 (0905 Preview)",provider:"kimi",aliases:["kimi-k2","kimi-k2-preview"],maxInputTokens:256e3,maxOutputTokens:8192,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:90,vision:0,creativity:80,speed:85,cost:70},releaseDate:"2025-09",notes:"MoE \u67B6\u6784 K2 \u9884\u89C8\u7248\uFF0C256K \u4E0A\u4E0B\u6587"}},Qg={"deepseek-v3.2":{id:"deepseek-v3.2",displayName:"DeepSeek V3.2",provider:"deepseek",aliases:["deepseek-v3.2-exp"],maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:92,reasoning:90,vision:0,creativity:80,speed:85,cost:95},releaseDate:"2025-09-29",notes:"\u5B9E\u9A8C\u7248\u672C,\u6027\u80FD\u663E\u8457\u63D0\u5347"},"deepseek-v3.1":{id:"deepseek-v3.1",displayName:"DeepSeek V3.1",provider:"deepseek",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:0,creativity:78,speed:88,cost:96},releaseDate:"2025-08",notes:"\u6DF7\u5408\u67B6\u6784\u6A21\u578B"},"deepseek-chat":{id:"deepseek-chat",displayName:"DeepSeek Chat",provider:"deepseek",maxInputTokens:64e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:82,vision:0,creativity:75,speed:85,cost:95},notes:"\u901A\u7528\u5BF9\u8BDD\u6A21\u578B,\u6210\u672C\u6781\u4F4E"},"deepseek-coder":{id:"deepseek-coder",displayName:"DeepSeek Coder",provider:"deepseek",maxInputTokens:64e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:95,reasoning:85,vision:0,creativity:70,speed:88,cost:96},notes:"\u4E13\u4E3A\u7F16\u7A0B\u4F18\u5316,\u4EE3\u7801\u80FD\u529B\u7A81\u51FA"},"deepseek-reasoner":{id:"deepseek-reasoner",displayName:"DeepSeek Reasoner",provider:"deepseek",maxInputTokens:64e3,maxOutputTokens:64e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:88,reasoning:96,vision:0,creativity:75,speed:60,cost:90},notes:"\u63A8\u7406\u4E13\u7528\u6A21\u578B,\u652F\u6301\u957F\u8F93\u51FA"}},ef={"minimax-text-01":{id:"minimax-text-01",displayName:"MiniMax Text-01",provider:"minimax",maxInputTokens:4e6,maxOutputTokens:1e6,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:90,vision:0,creativity:85,speed:55,cost:70},notes:"4M \u4E0A\u4E0B\u6587\u7A97\u53E3,Lightning Attention + MoE \u67B6\u6784,\u5F00\u6E90\u53EF\u7528"},"minimax-m1-80k":{id:"minimax-m1-80k",displayName:"MiniMax M1-80K",provider:"minimax",maxInputTokens:1e6,maxOutputTokens:8e4,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,supportsThinking:true,scores:{coding:90,reasoning:92,vision:0,creativity:82,speed:65,cost:75},notes:"1M \u4E0A\u4E0B\u6587 + 80K \u601D\u8003\u9884\u7B97"},"minimax-m2.1":{id:"minimax-m2.1",displayName:"MiniMax M2.1",provider:"minimax",maxInputTokens:2e5,maxOutputTokens:64e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:93,reasoning:88,vision:0,creativity:80,speed:82,cost:85},releaseDate:"2025-12",notes:"\u7F16\u7A0B\u548C Agentic \u5DE5\u4F5C\u6D41\u4F18\u5316,\u652F\u6301\u591A\u8BED\u8A00"},"minimax-vl-01":{id:"minimax-vl-01",displayName:"MiniMax VL-01",provider:"minimax",maxInputTokens:4e6,maxOutputTokens:1e6,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:88,vision:92,creativity:88,speed:60,cost:65},notes:"\u591A\u6A21\u6001\u6A21\u578B,\u652F\u6301\u6587\u672C\u548C\u56FE\u50CF"}},tf={"glm-4.7":{id:"glm-4.7",displayName:"GLM-4.7",provider:"glm",maxInputTokens:2e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:90,reasoning:88,vision:85,creativity:87,speed:80,cost:70},releaseDate:"2025-12-22",notes:"\u6700\u65B0\u7248\u672C,200K \u4E0A\u4E0B\u6587,128K \u8F93\u51FA"},"glm-4.6":{id:"glm-4.6",displayName:"GLM-4.6",provider:"glm",maxInputTokens:2e5,maxOutputTokens:128e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:86,vision:83,creativity:85,speed:82,cost:75},releaseDate:"2025-09-10",notes:"\u4ECE 128K \u6269\u5C55\u81F3 200K \u4E0A\u4E0B\u6587"},"glm-4.5":{id:"glm-4.5",displayName:"GLM-4.5",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:86,reasoning:84,vision:80,creativity:83,speed:85,cost:80},releaseDate:"2025-07"},"glm-4-flash":{id:"glm-4-flash",displayName:"GLM-4 Flash",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:82,reasoning:80,vision:78,creativity:80,speed:95,cost:92},notes:"\u5FEB\u901F\u6A21\u578B,\u76F8\u5F53\u4E8E 300 \u9875\u4E66\u7684\u4E0A\u4E0B\u6587"},"glm-4-plus":{id:"glm-4-plus",displayName:"GLM-4 Plus",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:true,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:88,reasoning:86,vision:82,creativity:85,speed:78,cost:65}},"glm-4-air":{id:"glm-4-air",displayName:"GLM-4 Air",provider:"glm",maxInputTokens:128e3,maxOutputTokens:32e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:80,reasoning:78,vision:0,creativity:78,speed:90,cost:88}},"glm-4-long":{id:"glm-4-long",displayName:"GLM-4 Long",provider:"glm",maxInputTokens:1e6,maxOutputTokens:128e3,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:85,reasoning:88,vision:0,creativity:80,speed:50,cost:60},notes:"\u8D85\u957F\u4E0A\u4E0B\u6587\u4E13\u7528,1M tokens"},"glm-4-airx":{id:"glm-4-airx",displayName:"GLM-4 AirX",provider:"glm",maxInputTokens:8e3,maxOutputTokens:4096,supportsVision:false,supportsTools:true,supportsFunctionCalling:true,supportsStreaming:true,scores:{coding:70,reasoning:68,vision:0,creativity:70,speed:98,cost:98},notes:"\u8D85\u8F7B\u91CF\u7EA7\u6A21\u578B,\u6781\u5FEB\u901F\u5EA6"}},Qo=class{models=new Map;constructor(){this.registerModels(Vg),this.registerModels(Yg),this.registerModels(Xg),this.registerModels(Zg),this.registerModels(Qg),this.registerModels(ef),this.registerModels(tf);}registerModels(e){for(let[t,s]of Object.entries(e))if(this.models.set(t,s),s.aliases)for(let n of s.aliases)this.models.set(n,s);}getModel(e){return this.models.get(e)}getAllModels(){let e=new Map;for(let t of this.models.values())e.set(t.id,t);return Array.from(e.values())}getModelsByProvider(e){return this.getAllModels().filter(t=>t.provider===e)}hasModel(e){return this.models.has(e)}toModelCapability(e){let t=this.getModel(e);if(t)return {modelAlias:t.id,strengths:this.inferStrengths(t),scores:{coding:t.scores?.coding??50,reasoning:t.scores?.reasoning??50,vision:t.scores?.vision??0,creativity:t.scores?.creativity??50,speed:t.scores?.speed??50,cost:t.scores?.cost??50},features:{supportsVision:t.supportsVision??false,supportsTools:t.supportsTools??false,supportsFunctionCalling:t.supportsFunctionCalling??false,supportsStreaming:t.supportsStreaming??false,maxContextTokens:t.maxInputTokens,maxOutputTokens:t.maxOutputTokens}}}inferStrengths(e){let t=[],s=e.scores??{};return (s.coding??0)>=85&&t.push("coding"),(s.reasoning??0)>=85&&t.push("reasoning"),(s.vision??0)>=85&&t.push("image_analysis"),(s.creativity??0)>=85&&t.push("creative_writing"),t}},Zc=new Qo;var Gt=class{validateParams(e){let t=this.getConstraints(),s=[],n=[];for(let i of Object.keys(e))t.supportedParams.has(i)||n.push(`Parameter '${i}' is not supported by this provider and will be ignored`);if(t.validators){for(let[i,o]of Object.entries(t.validators))if(e[i]!==void 0){let a=o(e[i],e);a===false?s.push(`Invalid value for parameter '${i}': ${e[i]}`):typeof a=="string"&&s.push(`Parameter '${i}': ${a}`);}}if(e.model&&e.max_tokens!==void 0){let i=this.getTokenLimits(e.model);i.found&&e.max_tokens>i.maxInput?s.push(`max_tokens (${e.max_tokens}) exceeds model context window (${i.maxInput}) for ${e.model}`):i.found&&e.max_tokens>i.maxOutput&&n.push(`max_tokens (${e.max_tokens}) exceeds recommended output limit (${i.maxOutput}) for ${e.model}, but is within context window`);}return {valid:s.length===0,errors:s,warnings:n.length>0?n:void 0}}getTokenLimits(e){let t=Zc.getModel(e);if(t)return {maxOutput:t.maxOutputTokens,maxInput:t.maxInputTokens,found:true,source:"model"};let s=this.getConstraints(),n=s.maxOutputTokens[e],i=s.maxInputTokens[e];if(n!==void 0&&i!==void 0)return {maxOutput:n,maxInput:i,found:true,source:"model"};for(let[o,a]of Object.entries(s.maxOutputTokens))if(this.matchPattern(e,o))return {maxOutput:a,maxInput:s.maxInputTokens[o]||128e3,found:true,source:"model"};return {maxOutput:4096,maxInput:128e3,found:false,source:"fallback"}}normalizeParams(e){let t=this.getConstraints(),s={};for(let[n,i]of Object.entries(e)){let o=t.paramAliases?.[n]||n;t.supportedParams.has(n)&&(s[o]=i);}if(t.defaults)for(let[n,i]of Object.entries(t.defaults))s[n]===void 0&&(s[n]=i);return s}matchPattern(e,t){return t.includes("*")?new RegExp("^"+t.replace(/\*/g,".*")+"$").test(e):e===t}isParamSupported(e){return this.getConstraints().supportedParams.has(e)}getParamAlias(e){return this.getConstraints().paramAliases?.[e]||e}};function je(r,e){return t=>{let s=Number(t);return isNaN(s)?"Must be a number":s<r||s>e?`Must be between ${r} and ${e}`:true}}function js(r){return e=>r.includes(e)?true:`Must be one of: ${r.join(", ")}`}function Qc(r){return e=>{let t=typeof e;return t!==r?`Expected ${r}, got ${t}`:true}}function ti(...r){return (e,t)=>{for(let s of r){let n=s(e,t);if(n!==true)return n}return true}}var is=class extends Gt{getConstraints(){return {maxOutputTokens:{"gpt-4o":16384,"gpt-4o-2024-11-20":16384,"gpt-4o-2024-08-06":16384,"gpt-4o-2024-05-13":4096,"gpt-4o-mini":16384,"gpt-4o-mini-2024-07-18":16384,"gpt-4-turbo":4096,"gpt-4-turbo-2024-04-09":4096,"gpt-4-turbo-preview":4096,"gpt-4-0125-preview":4096,"gpt-4-1106-preview":4096,"gpt-4":8192,"gpt-4-0613":8192,"gpt-4-0314":8192,"gpt-3.5-turbo":4096,"gpt-3.5-turbo-0125":4096,"gpt-3.5-turbo-1106":4096,o1:1e5,"o1-2024-12-17":1e5,"o1-preview":32768,"o1-preview-2024-09-12":32768,"o1-mini":65536,"o1-mini-2024-09-12":65536,o3:1e5,"o3-mini":1e5,"o3-mini-2025-01-31":1e5,"o4-mini":1e5,"gpt-5":1e5,"gpt-5.1":1e5,"gpt-5.1-codex":1e5,"gpt-5.1-codex-max":1e5,"gpt-5.1-codex-mini":1e5,"gpt-5.2":1e5,"gpt-5.2-codex":1e5,"gpt-5-codex":1e5,"gpt-5-codex-mini":1e5,"codex-mini-latest":1e5,"gpt-4.1":1e5,"gpt-4.1-2025-04-14":1e5,"gpt-4o*":16384,"gpt-4-turbo*":4096,"gpt-4.1*":1e5,"gpt-4*":8192,"gpt-3.5*":4096,"gpt-5*":1e5,"codex*":1e5,"o1*":1e5,"o3*":1e5,"o4*":1e5},maxInputTokens:{"gpt-4o":128e3,"gpt-4o-mini":128e3,"gpt-4-turbo":128e3,"gpt-4-turbo-2024-04-09":128e3,"gpt-4.1":1047576,"gpt-4.1-2025-04-14":1047576,"gpt-4":8192,"gpt-4-32k":32768,"gpt-3.5-turbo":16385,"gpt-3.5-turbo-16k":16385,"gpt-5":272e3,"gpt-5.1":272e3,"gpt-5.1-codex":272e3,"gpt-5.1-codex-max":272e3,"gpt-5.1-codex-mini":272e3,"gpt-5-codex":272e3,"gpt-5-codex-mini":272e3,"gpt-5.2":4e5,"gpt-5.2-codex":4e5,"codex-mini-latest":2e5,o1:2e5,"o1-preview":128e3,"o1-mini":128e3,o3:2e5,"o3-mini":2e5,"o4-mini":2e5,"gpt-4o*":128e3,"gpt-4-turbo*":128e3,"gpt-4.1*":1047576,"gpt-5*":272e3,"gpt-5.2*":4e5,"codex*":272e3,"o1*":2e5,"o3*":2e5,"o4*":2e5},supportedParams:new Set(["model","messages","stream","stream_options","max_tokens","max_completion_tokens","temperature","top_p","top_k","frequency_penalty","presence_penalty","stop","n","seed","reasoning_effort","verbosity","tools","tool_choice","parallel_tool_calls","response_format","logprobs","top_logprobs","logit_bias","modalities","audio","user","safety_identifier","store","service_tier","prompt_cache_key","prompt_cache_retention","metadata","prediction","extra_body","search_parameters","web_search_options"]),validators:{temperature:je(0,2),top_p:je(0,1),frequency_penalty:je(-2,2),presence_penalty:je(-2,2),reasoning_effort:js(["low","medium","high"]),verbosity:js(["low","medium","high"]),tool_choice:e=>typeof e=="string"?["none","auto","required"].includes(e)||"Must be 'none', 'auto', or 'required'":typeof e=="object"&&e.type==="function"?true:"Invalid tool_choice format","response_format.type":js(["text","json_object","json_schema"]),stream:e=>typeof e=="boolean"||"Must be a boolean",n:ti(e=>typeof e=="number"||"Must be a number",je(1,10)),max_tokens:(e,t)=>{let s=Number(e);if(isNaN(s))return "Must be a number";if(s<1)return "Must be at least 1";t?.model||"";return true}},defaults:{temperature:1,top_p:1,n:1,stream:false,max_tokens:4096}}}isResponsesAPIModel(e){return e.startsWith("o1")||e.startsWith("o3")}supportsReasoning(e){return this.isResponsesAPIModel(e)}supportsVision(e){return e.includes("gpt-4o")||e.includes("gpt-4-turbo")||e.includes("gpt-4-vision")}supportsTools(e){return e.startsWith("o1-preview")||e.startsWith("o1-mini")?false:e.includes("gpt-4")||e.includes("gpt-3.5-turbo")||e.startsWith("o3")}getRecommendedMaxTokens(e,t){let s=this.getTokenLimits(e);switch(t){case "short":return Math.min(1024,s.maxOutput);case "medium":return Math.min(4096,s.maxOutput);case "long":return s.maxOutput;default:return Math.min(4096,s.maxOutput)}}};var Bt=class{combinePromptSections(e){return e.filter(s=>s.content.trim().length>0).sort((s,n)=>(s.order||0)-(n.order||0)).map(s=>s.title?`# ${s.title}
|
|
1497
1497
|
|
|
1498
1498
|
${s.content}`:s.content).join(`
|
|
1499
1499
|
|
|
1500
1500
|
`)}getWorkingDirectorySection(e,t){return t==="zh"?{title:"\u5DE5\u4F5C\u76EE\u5F55",content:`\u5F53\u524D\u5DE5\u4F5C\u76EE\u5F55: ${e}`,order:10}:{title:"Working Directory",content:`Current working directory: ${e}`,order:10}}modelMatches(e,t){return e?t.includes("*")?new RegExp("^"+t.replace(/\*/g,".*")+"$").test(e):e===t:false}isModelType(e,...t){return e?t.some(s=>this.modelMatches(e,s)):false}};function os(r){return r.replace(/\n{3,}/g,`
|
|
1501
1501
|
|
|
1502
|
-
`).trim()}var
|
|
1502
|
+
`).trim()}var sf=`You are Claude Code, Anthropic's official CLI for Claude.
|
|
1503
1503
|
|
|
1504
1504
|
You are an interactive CLI tool that helps users with software engineering tasks. Use the instructions below and the tools available to you to assist the user.
|
|
1505
1505
|
|
|
@@ -1537,7 +1537,7 @@ When planning tasks, provide concrete implementation steps without time estimate
|
|
|
1537
1537
|
You have access to the TodoWrite tools to help you manage and plan tasks. Use these tools VERY frequently to ensure that you are tracking your tasks and giving the user visibility into your progress.
|
|
1538
1538
|
These tools are also EXTREMELY helpful for planning tasks, and for breaking down larger complex tasks into smaller steps. If you do not use this tool when planning, you may forget to do important tasks - and that is unacceptable.
|
|
1539
1539
|
|
|
1540
|
-
It is critical that you mark todos as completed as soon as you are done with a task. Do not batch up multiple tasks before marking them as completed.`.trim(),as=class extends Bt{buildSystemPrompt(e){let{workDir:t,language:s="zh",modelName:n,customInstructions:i}=e;return this.isResponsesAPIModel(n)?this.buildResponsesAPIPrompt(i):this.buildChatCompletionsPrompt(t,s,n,i)}buildResponsesAPIPrompt(e){let t=
|
|
1540
|
+
It is critical that you mark todos as completed as soon as you are done with a task. Do not batch up multiple tasks before marking them as completed.`.trim(),as=class extends Bt{buildSystemPrompt(e){let{workDir:t,language:s="zh",modelName:n,customInstructions:i}=e;return this.isResponsesAPIModel(n)?this.buildResponsesAPIPrompt(i):this.buildChatCompletionsPrompt(t,s,n,i)}buildResponsesAPIPrompt(e){let t=sf;return e&&e.trim()&&(t+=`
|
|
1541
1541
|
|
|
1542
1542
|
# Custom Instructions
|
|
1543
1543
|
|
|
@@ -1611,22 +1611,22 @@ Tool results are returned via messages with role "tool".`}getGeneralRules(e){ret
|
|
|
1611
1611
|
1. **Accuracy First**: Ensure correctness of code and suggestions
|
|
1612
1612
|
2. **Be Concise**: Avoid redundancy, answer directly
|
|
1613
1613
|
3. **Safety First**: No malicious code, be aware of security risks
|
|
1614
|
-
4. **Stay Professional**: Objective, technical communication style`}getModelDisplayName(e){return e?e.includes("o3")?"OpenAI o3":e.includes("o1")?"OpenAI o1":e.includes("gpt-4o")?"GPT-4o":e.includes("gpt-4")?"GPT-4":e.includes("gpt-3.5")?"GPT-3.5":e:"GPT-4"}isResponsesAPIModel(e){return this.isModelType(e,"o1*","o3*")}supportsVision(e){return this.isModelType(e,"gpt-4o*","gpt-4-turbo*","gpt-4-vision*")}};
|
|
1614
|
+
4. **Stay Professional**: Objective, technical communication style`}getModelDisplayName(e){return e?e.includes("o3")?"OpenAI o3":e.includes("o1")?"OpenAI o1":e.includes("gpt-4o")?"GPT-4o":e.includes("gpt-4")?"GPT-4":e.includes("gpt-3.5")?"GPT-3.5":e:"GPT-4"}isResponsesAPIModel(e){return this.isModelType(e,"o1*","o3*")}supportsVision(e){return this.isModelType(e,"gpt-4o*","gpt-4-turbo*","gpt-4-vision*")}};me();var cf=16e3;function eu(r,e=cf){if(!r||r.length<=e)return r;let t=r.split(`
|
|
1615
1615
|
`).length,s=r.length,n=Math.floor(e*.4),i=Math.floor(e*.4),o=n,a=r.length-i;for(;o>0&&(r.charCodeAt(o)&192)===128;)o--;for(;a<r.length&&(r.charCodeAt(a)&192)===128;)a++;let l=r.slice(0,o),c=r.slice(a),p=`
|
|
1616
1616
|
|
|
1617
1617
|
\u2026[${s-l.length-c.length} chars truncated, total ${t} lines]\u2026
|
|
1618
1618
|
|
|
1619
|
-
`;return l+p+c}function
|
|
1620
|
-
`),m=[`curl -X POST "${u}"`,...p,`-d '${JSON.stringify(c)}'`,"--no-buffer"].join(" ");f.info("CURL","\u2550".repeat(80)),f.info("CURL","Multi-line CURL command:"),f.info("CURL",d),f.info("CURL","\u2550".repeat(80)),f.info("CURL","One-line CURL (copy-paste ready):"),f.info("CURL",m),f.info("CURL","\u2550".repeat(80));}try{if(l?.aborted){let g=new Error("Request aborted");throw g.name="AbortError",g}let p=Date.now(),d={Accept:"text/event-stream",conversation_id:this.sessionId,session_id:this.sessionId,originator:"codex_cli_rs","x-codex-beta-features":"shell_snapshot"},m=await this.client.post("/responses",c,{responseType:"stream",signal:l,headers:d});if(process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Responses API Stream Started",{status:m.status}),m.status!==200){let g="";for await(let b of m.data)g+=b.toString();let y=ts(g,m.status);throw new Error(`OpenAI Responses API error: ${m.status} - ${y.message}`)}yield*this.parseResponsesAPIStream(m.data,l);let h=Date.now()-p;
|
|
1621
|
-
`+g.detail:""}`;}else h=p.message||"Unknown error";throw new Error(h)}}buildResponsesAPIPayload(e,t){let{model:s,tools:n,temperature:i,structuredOutput:o,maxInputTokens:a}=t,l=this.convertToResponsesInput(e),c=this.buildResponsesInstructions(e);if(!c)throw new Error("[OpenAI Responses API] instructions field is required but no system message found");if(!l||l.length===0)throw new Error("[OpenAI Responses API] input array is empty - at least one user message is required");if(process.env.CLI_DEBUG==="1"){f.debug("OpenAI","Building Responses API payload",{instructionsLength:c.length,instructionsPreview:c.substring(0,300),inputItems:l.length,inputPreview:JSON.stringify(l.slice(0,2),null,2)}),f.debug("OpenAI","Full input array for Response API:",{totalMessages:e.length,messageRoles:e.map(y=>y.role),inputCount:l.length,fullInput:JSON.stringify(l,null,2)});let d=l.filter(y=>y.type==="function_call"),m=l.filter(y=>y.type==="function_call_output");f.debug("OpenAI","Function call ID matching check:",{callCount:d.length,outputCount:m.length,callIds:d.map(y=>({id:y.id||y.call_id,name:y.name})),outputIds:m.map(y=>({call_id:y.call_id}))});let h=new Set(d.map(y=>y.call_id||y.id)),g=m.filter(y=>!h.has(y.call_id));g.length>0&&f.warn("OpenAI",`\u26A0\uFE0F Found ${g.length} unmatched function_call_output!`,{unmatchedCallIds:g.map(y=>y.call_id)});}let u={model:s,instructions:c,input:l};n&&n.length>0&&(u.tools=n.map(d=>this.formatResponsesFunctionTool(d)),u.tool_choice="auto",u.parallel_tool_calls=true,process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Added ${u.tools.length} tools`));let p=
|
|
1619
|
+
`;return l+p+c}function tu(r,e={}){let t={...r};return !e.allowServiceTier&&"service_tier"in t&&delete t.service_tier,e.disableStore&&"store"in t&&delete t.store,!e.allowSafetyIdentifier&&"safety_identifier"in t&&delete t.safety_identifier,t}function su(r,e){if(!r)return null;if(e?.reasoning)return {effort:e.reasoning.effort||"low",verbosity:e.reasoning.verbosity||"low",summary:e.reasoning.summary||"auto"};let t=process.env.CD_REASONING_EFFORT||process.env.NEOX_REASONING_EFFORT,s=process.env.CD_REASONING_VERBOSITY||process.env.NEOX_REASONING_VERBOSITY,n=process.env.CD_REASONING_SUMMARY||process.env.NEOX_REASONING_SUMMARY;return t||s||n?{effort:t||"low",verbosity:s||"low",summary:n||"auto"}:null}var It=class{client;defaultModel;isProxy;useResponsesAPI;apiEndpoint;streamFormat;retryConfig;baseUrl;privacySettings;sessionId;doubaoThinking;apiKey;modelConfig;structuredOutputMode;constructor(e){this.baseUrl=e.baseUrl||"https://api.openai.com/v1",this.isProxy=e.baseUrl?!e.baseUrl.includes("api.openai.com"):false,this.useResponsesAPI=e.useResponsesAPI||false,this.apiEndpoint=e.apiEndpoint||"/chat/completions",this.streamFormat=e.streamFormat||"openai",this.apiKey=e.apiKey,this.sessionId=e.sessionId||`session-${Date.now()}-${Math.random().toString(36).slice(2,11)}`,this.privacySettings=e.privacySettings||{},this.doubaoThinking=e.doubaoThinking,this.modelConfig=e.modelConfig,this.structuredOutputMode=e.structuredOutputMode||"json_schema",this.client=nf.create({baseURL:this.baseUrl,headers:{Authorization:`Bearer ${e.apiKey}`,"Content-Type":"application/json"},timeout:12e4}),this.defaultModel=e.defaultModel||"gpt-4";let t=Os("openai",this.baseUrl);this.retryConfig=Nt(void 0,{...t,...e.retry}),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Initialized with:",{baseUrl:this.baseUrl,isProxy:this.isProxy,useResponsesAPI:this.useResponsesAPI,apiEndpoint:this.apiEndpoint,streamFormat:this.streamFormat});}async chat(e,t={}){let{model:s=this.defaultModel}=t;return this.shouldUseResponsesAPI(s)?this.chatWithResponsesAPI(e,t):this.chatWithChatCompletions(e,t)}async*chatStreamed(e,t={}){let{model:s=this.defaultModel}=t;this.shouldUseResponsesAPI(s)?yield*this.chatStreamedWithResponsesAPI(e,t):yield*this.chatStreamedWithChatCompletions(e,t);}async chatWithChatCompletions(e,t){let{model:s=this.defaultModel,tools:n,temperature:i=.7,maxInputTokens:o}=t,a=this.buildChatCompletionsPayload(e,{model:s,tools:n,temperature:i,structuredOutput:t.structuredOutput,maxInputTokens:o,stream:false}),l=`${this.client.defaults.baseURL}/chat/completions`;oe.llmRequest("openai",s,a,l,{Authorization:"Bearer ***"}),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Chat Completions Request",{url:l,payload:a});let c=this.retryConfig.requestMaxRetries,u=null;for(let p=0;p<=c;p++)try{let d=Date.now(),m=await this.client.post("/chat/completions",a),h=Date.now()-d;return oe.llmResponse("openai",h,m.data.usage,m.data.choices[0]),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Chat Completions Response",{duration:`${h}ms`,data:m.data}),m.data}catch(d){u=d;let m=nt(d);if(f.error("OpenAI",`Request Error - URL: ${l}`),f.error("OpenAI",`Error: ${d.message}`),d.response?.data)try{let b=d.response.data;if(typeof b=="string")f.error("OpenAI",`Response: ${b.substring(0,500)}`);else if(b&&typeof b=="object"){let w={error:b.error,message:b.message,type:b.type,code:b.code};f.error("OpenAI",`Response: ${JSON.stringify(w).substring(0,500)}`);}}catch{f.error("OpenAI","Response: [Could not serialize error data]");}if(process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Chat Completions Error",{url:l,message:d.message,category:m.category,retryable:m.retryable,attempt:`${p+1}/${c+1}`}),oe.llmError("openai",d),!m.retryable||p===c)throw m;let h=d.response?.headers?.["retry-after"],g=Rt(h),y=Ft(g,p+1,this.retryConfig);f.info("OpenAI",`Request failed (${m.code}), retrying in ${Je(y)} (${p+1}/${c})...`),await $s(y);}throw u||new Error("Unknown error during retry")}async*chatStreamedWithChatCompletions(e,t){let{model:s=this.defaultModel,tools:n,temperature:i=.7,maxInputTokens:o,signal:a}=t,l=this.buildChatCompletionsPayload(e,{model:s,tools:n,temperature:i,structuredOutput:t.structuredOutput,maxInputTokens:o,stream:true}),c=`${this.client.defaults.baseURL}${this.apiEndpoint}`;oe.llmRequest("openai-stream",s,l,c,{Authorization:"Bearer ***"}),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Chat Completions Stream Request",{url:c,endpoint:this.apiEndpoint,payload:l});let u=this.retryConfig.streamMaxRetries,p=0;for(;;)try{if(a?.aborted){let g=new Error("Request aborted");throw g.name="AbortError",g}let d=Date.now(),m=await this.client.post(this.apiEndpoint,l,{responseType:"stream",signal:a});if(process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Stream Started",{status:m.status}),m.status!==200){let g="";for await(let y of m.data)g+=y.toString();throw new Error(`OpenAI API error: ${m.status} - ${g}`)}this.streamFormat==="anthropic"?yield*this.parseAnthropicStreamResponse(m.data):yield*this.parseOpenAIStreamResponse(m.data,a);let h=Date.now()-d;oe.llmResponse("openai-stream",h,{},{}),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Stream Complete",{duration:`${h}ms`});return}catch(d){let m=nt(d);if(f.error("OpenAI",`Stream Error - Request URL: ${c}`),f.error("OpenAI",`Error: ${d.message}`),d.response?.data)try{let h=d.response.data;if(typeof h=="string")f.error("OpenAI",`Response: ${h.substring(0,500)}`);else if(h&&typeof h=="object"){let g={error:h.error,message:h.message,type:h.type,code:h.code};f.error("OpenAI",`Response: ${JSON.stringify(g).substring(0,500)}`);}}catch{f.error("OpenAI","Response: [Could not serialize error data]");}if(process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Stream Error Details",{url:c,message:d.message,retryable:m.retryable,status:d.response?.status}),oe.llmError("openai-stream",d),m.retryable&&p<u){p++;let h=d.response?.headers?.["retry-after"],g=Rt(h),y=Ft(g,p,this.retryConfig);f.info("OpenAI",`Stream failed (${m.code}), reconnecting in ${Je(y)} (${p}/${u})...`),yield {choices:[],type:"stream_retry",error:m.message,errorCode:m.code,attempt:p,maxRetries:u,delayMs:y};try{await ns(y,a);}catch(b){throw b?.name==="AbortError",b}continue}throw m}}buildChatCompletionsPayload(e,t){let{model:s,tools:n,temperature:i,structuredOutput:o,maxInputTokens:a,stream:l}=t,c=this.formatMessagesForChatCompletions(e);if(this.baseUrl.includes("ark.cn-beijing.volces.com")){let m={model:s,messages:c,stream:l};return this.doubaoThinking&&s.includes("doubao-seed")&&(m.thinking={type:this.doubaoThinking.type},process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Doubao thinking mode: ${this.doubaoThinking.type}`)),n&&n.length>0&&(m.tools=n.map(h=>({type:"function",function:{name:h.name,description:h.description,parameters:h.parameters}})),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Added ${m.tools.length} tools to Doubao payload`)),m}let p={model:s,messages:c,temperature:i,stream:l};l&&(p.stream_options={include_usage:true}),a!==void 0&&(p.max_tokens=a);let d=su(false);return d&&(p.reasoning_effort=d.effort,d.verbosity&&(p.verbosity=d.verbosity)),n&&n.length>0&&(p.tools=n.map(m=>({type:"function",function:{name:m.name,description:m.description,parameters:m.parameters}})),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Added ${p.tools.length} tools to Chat Completions payload`)),o&&(this.structuredOutputMode==="json_object"?p.response_format={type:"json_object"}:p.response_format={type:"json_schema",json_schema:{name:o.name,schema:o.schema,strict:o.strict??true}}),tu(p,this.privacySettings)}formatMessagesForChatCompletions(e){return e.filter(t=>{let s=t.content&&(typeof t.content=="string"?t.content.trim().length>0:Array.isArray(t.content)&&t.content.length>0),n=t.tool_calls&&t.tool_calls.length>0;return s||n}).map(t=>{let s={role:t.role,content:null};if(t.role==="tool"){let n=typeof t.content=="string"?t.content:se(t.content);s.content=eu(n);}else Array.isArray(t.content)?s.content=t.content:t.tool_calls&&t.tool_calls.length>0?s.content=t.content||"":s.content=t.content||null;return t.name&&(s.name=t.name),t.tool_call_id&&(s.tool_call_id=t.tool_call_id),t.tool_calls&&(s.tool_calls=t.tool_calls.map(n=>({id:n.id,type:"function",function:{name:n.function.name,arguments:n.function.arguments}}))),s})}async chatWithResponsesAPI(e,t){let s="",n=[],i;for await(let o of this.chatStreamedWithResponsesAPI(e,t)){let a=o.choices?.[0]?.delta;if(a&&(a.content&&(s+=a.content),a.tool_calls))for(let l of a.tool_calls){let c=n.find(u=>u.index===l.index);c?l.function?.arguments&&(c.function.arguments+=l.function.arguments):n.push({id:l.id||`call_${n.length}`,type:"function",function:{name:l.function?.name||"",arguments:l.function?.arguments||""},index:l.index});}o.usage&&(i=o.usage);}return {id:`chatcmpl-${Date.now()}`,choices:[{message:{role:"assistant",content:s||null,...n.length>0?{tool_calls:n}:{}},finish_reason:"stop"}],usage:i||{total_tokens:0,prompt_tokens:0,completion_tokens:0}}}async*chatStreamedWithResponsesAPI(e,t){let{model:s=this.defaultModel,tools:n,temperature:i=.7,structuredOutput:o,maxInputTokens:a,signal:l}=t,c=this.buildResponsesAPIPayload(e,{model:s,tools:n,temperature:i,structuredOutput:o,maxInputTokens:a}),u=`${this.client.defaults.baseURL}/responses`;if(oe.llmRequest("openai-responses-stream",s,c,u,{Authorization:"Bearer ***"}),process.env.CLI_DEBUG==="1"){f.info("OpenAI","Responses API Stream Request",{url:u,toolsCount:c.tools?.length||0}),process.env.CLI_DEBUG_PAYLOAD==="1"&&f.debug("OpenAI","Full Payload",c);let p=['-H "Content-Type: application/json"','-H "Accept: text/event-stream"',`-H "Authorization: Bearer ${this.apiKey}"`,`-H "conversation_id: ${this.sessionId}"`,`-H "session_id: ${this.sessionId}"`,'-H "user-agent: neox-cli/1.0.0"'],d=[`curl -X POST "${u}"`,...p,`-d '${JSON.stringify(c)}'`,"--no-buffer"].join(` \\
|
|
1620
|
+
`),m=[`curl -X POST "${u}"`,...p,`-d '${JSON.stringify(c)}'`,"--no-buffer"].join(" ");f.info("CURL","\u2550".repeat(80)),f.info("CURL","Multi-line CURL command:"),f.info("CURL",d),f.info("CURL","\u2550".repeat(80)),f.info("CURL","One-line CURL (copy-paste ready):"),f.info("CURL",m),f.info("CURL","\u2550".repeat(80));}try{if(l?.aborted){let g=new Error("Request aborted");throw g.name="AbortError",g}let p=Date.now(),d={Accept:"text/event-stream",conversation_id:this.sessionId,session_id:this.sessionId,originator:"codex_cli_rs","x-codex-beta-features":"shell_snapshot"},m=await this.client.post("/responses",c,{responseType:"stream",signal:l,headers:d});if(process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Responses API Stream Started",{status:m.status}),m.status!==200){let g="";for await(let b of m.data)g+=b.toString();let y=ts(g,m.status);throw new Error(`OpenAI Responses API error: ${m.status} - ${y.message}`)}yield*this.parseResponsesAPIStream(m.data,l);let h=Date.now()-p;oe.llmResponse("openai-responses-stream",h,{},{}),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Responses API Stream Complete",{duration:`${h}ms`});}catch(p){let d,m=p.response?.status;if(p.response?.data){let g=p.response.data;try{if(g&&typeof g.on=="function"){let y="";try{for await(let b of g)y+=b.toString();d=y;}catch{d="[Could not read error stream]";}}else if(typeof g=="string")d=g;else if(g&&typeof g=="object"){let y={error:g.error,message:g.message,type:g.type,code:g.code};d=JSON.stringify(y);}}catch{d="[Could not parse error data]";}}process.env.CLI_DEBUG==="1"&&f.error("OpenAI","Responses API Stream Error",{status:m,errorData:d,message:p.message}),oe.llmError("openai-responses-stream",p);let h;if(m&&d){let g=ts(d,m);h=`${g.message}${g.detail?`
|
|
1621
|
+
`+g.detail:""}`;}else h=p.message||"Unknown error";throw new Error(h)}}buildResponsesAPIPayload(e,t){let{model:s,tools:n,temperature:i,structuredOutput:o,maxInputTokens:a}=t,l=this.convertToResponsesInput(e),c=this.buildResponsesInstructions(e);if(!c)throw new Error("[OpenAI Responses API] instructions field is required but no system message found");if(!l||l.length===0)throw new Error("[OpenAI Responses API] input array is empty - at least one user message is required");if(process.env.CLI_DEBUG==="1"){f.debug("OpenAI","Building Responses API payload",{instructionsLength:c.length,instructionsPreview:c.substring(0,300),inputItems:l.length,inputPreview:JSON.stringify(l.slice(0,2),null,2)}),f.debug("OpenAI","Full input array for Response API:",{totalMessages:e.length,messageRoles:e.map(y=>y.role),inputCount:l.length,fullInput:JSON.stringify(l,null,2)});let d=l.filter(y=>y.type==="function_call"),m=l.filter(y=>y.type==="function_call_output");f.debug("OpenAI","Function call ID matching check:",{callCount:d.length,outputCount:m.length,callIds:d.map(y=>({id:y.id||y.call_id,name:y.name})),outputIds:m.map(y=>({call_id:y.call_id}))});let h=new Set(d.map(y=>y.call_id||y.id)),g=m.filter(y=>!h.has(y.call_id));g.length>0&&f.warn("OpenAI",`\u26A0\uFE0F Found ${g.length} unmatched function_call_output!`,{unmatchedCallIds:g.map(y=>y.call_id)});}let u={model:s,instructions:c,input:l};n&&n.length>0&&(u.tools=n.map(d=>this.formatResponsesFunctionTool(d)),u.tool_choice="auto",u.parallel_tool_calls=true,process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Added ${u.tools.length} tools`));let p=su(true,this.modelConfig);return p&&(u.reasoning={effort:p.effort,summary:p.summary||"auto"}),u.store=false,u.stream=true,p&&(u.include=["reasoning.encrypted_content"]),u.prompt_cache_key=this.sessionId,tu(u,this.privacySettings)}buildResponsesInstructions(e){let t=Yo({workDir:process.cwd(),language:"zh",useCodexStyle:true});return process.env.CLI_DEBUG==="1"&&(f.debug("OpenAI","Using official Codex instructions for Responses API"),f.debug("OpenAI",`Instructions length: ${t.length} chars`),f.debug("OpenAI",`Instructions preview: ${t.substring(0,200)}...`)),t}convertToResponsesInput(e){let s=this.filterIncompleteToolCalls(e).filter(o=>o.role!=="system").flatMap(o=>this.convertMessageToResponsesItems(o)),n=this.extractMemoryContext(e);n&&s.unshift({type:"message",role:"user",status:"completed",content:[{type:"input_text",text:`<memory_context>
|
|
1622
1622
|
${n}
|
|
1623
|
-
</memory_context>`}]});let i=this.getGPTAgentInstructions();if(i&&s.unshift({type:"message",role:"user",status:"completed",content:[{type:"input_text",text:i}]}),process.env.CLI_DEBUG==="1"){let o=s.filter(l=>l.type==="function_call"),a=s.filter(l=>l.type==="function_call_output");if(f.debug("OpenAI","Responses API input structure:",{totalItems:s.length,functionCalls:o.length,functionCallOutputs:a.length}),o.length>0||a.length>0){f.debug("OpenAI","Function calls in input:",o.map(p=>({call_id:p.call_id,name:p.name}))),f.debug("OpenAI","Function call outputs in input:",a.map(p=>({call_id:p.call_id})));let l=new Set(o.map(p=>p.call_id)),c=new Set(a.map(p=>p.call_id)),u=[...l].filter(p=>!c.has(p));u.length>0&&f.warn("OpenAI","\u26A0\uFE0F Found function_calls without outputs:",u);}}return s}extractMemoryContext(e){let t=e.filter(n=>n.role==="system"),s=["## \u9879\u76EE\u8BB0\u5FC6","## \u4E0A\u6B21\u4EFB\u52A1\u6458\u8981","## Project Memory","## Last Run Summary"];for(let n of t){let i=typeof n.content=="string"?n.content:
|
|
1623
|
+
</memory_context>`}]});let i=this.getGPTAgentInstructions();if(i&&s.unshift({type:"message",role:"user",status:"completed",content:[{type:"input_text",text:i}]}),process.env.CLI_DEBUG==="1"){let o=s.filter(l=>l.type==="function_call"),a=s.filter(l=>l.type==="function_call_output");if(f.debug("OpenAI","Responses API input structure:",{totalItems:s.length,functionCalls:o.length,functionCallOutputs:a.length}),o.length>0||a.length>0){f.debug("OpenAI","Function calls in input:",o.map(p=>({call_id:p.call_id,name:p.name}))),f.debug("OpenAI","Function call outputs in input:",a.map(p=>({call_id:p.call_id})));let l=new Set(o.map(p=>p.call_id)),c=new Set(a.map(p=>p.call_id)),u=[...l].filter(p=>!c.has(p));u.length>0&&f.warn("OpenAI","\u26A0\uFE0F Found function_calls without outputs:",u);}}return s}extractMemoryContext(e){let t=e.filter(n=>n.role==="system"),s=["## \u9879\u76EE\u8BB0\u5FC6","## \u4E0A\u6B21\u4EFB\u52A1\u6458\u8981","## Project Memory","## Last Run Summary"];for(let n of t){let i=typeof n.content=="string"?n.content:se(n.content);if(i&&s.some(o=>i.includes(o)))return i.trim()}return null}filterIncompleteToolCalls(e){let t=[];for(let s=0;s<e.length;s++){let n=e[s];if(n.role==="assistant"&&n.tool_calls&&n.tool_calls.length>0&&!this.hasToolOutputsInHistory(n,e,s)){process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Filtering incomplete assistant message:",{toolCalls:n.tool_calls.map(o=>({id:o.id,name:o.function.name})),reason:"Missing tool outputs in message history"});continue}t.push(n);}return t}hasToolOutputsInHistory(e,t,s){if(!e.tool_calls)return true;let n=new Set(e.tool_calls.map(o=>o.id)),i=new Set;for(let o=s+1;o<t.length;o++){let a=t[o];if(a.role==="tool"&&a.tool_call_id&&i.add(a.tool_call_id),a.role==="assistant")break}for(let o of n)if(!i.has(o))return false;return true}convertMessageToResponsesItems(e){if(e.role==="assistant"){let s=[],n=se(e.content);if(n.trim().length>0&&s.push({type:"message",role:"assistant",status:"completed",content:[{type:"output_text",text:n,annotations:[]}]}),Array.isArray(e.tool_calls)&&e.tool_calls.length>0)for(let i of e.tool_calls){let o=i.id;process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Function call ID (no normalization):",{originalId:o,toolName:i.function.name,argsLength:i.function.arguments?.length||0}),s.push({type:"function_call",call_id:o,name:i.function.name,arguments:i.function.arguments||"",status:"completed"}),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Sending function_call to API:",{call_id:o,name:i.function.name});}return s}if(e.role==="tool"){let s=e.tool_call_id||e.name,n=se(e.content),i=eu(n);return process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Sending function_call_output (no normalization):",{callId:s,toolName:e.name,outputLength:i.length,wasTruncated:n.length!==i.length}),[{type:"function_call_output",call_id:s,output:i}]}if(Array.isArray(e.content)){let s=[];for(let n of e.content)n.type==="text"&&n.text.trim()?s.push({type:"input_text",text:n.text}):n.type==="image_url"&&s.push({type:"input_image",image_url:n.image_url.url});return s.length===0?[]:[{type:"message",role:"user",content:s}]}let t=se(e.content);return !t||t.trim().length===0?[]:[{type:"message",role:"user",content:[{type:"input_text",text:t}]}]}getGPTAgentInstructions(){try{let e=fileURLToPath(import.meta.url),t=dirname(e),s=join(t,"../prompts/gpt-agents-instructions.md"),n=readFileSync(s,"utf-8"),i=`# AGENTS.md instructions for GPT models
|
|
1624
1624
|
|
|
1625
1625
|
<INSTRUCTIONS>
|
|
1626
1626
|
${n}
|
|
1627
1627
|
</INSTRUCTIONS>`;return process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Loaded GPT Agent instructions:",{path:s,length:n.length,preview:n.substring(0,200)}),i}catch(e){return process.env.CLI_DEBUG==="1"&&f.warn("OpenAI","Failed to load GPT Agent instructions:",e),null}}formatResponsesFunctionTool(e){return {type:"function",name:e.name,description:e.description,parameters:e.parameters,strict:false}}makeSchemaNullable(e){if(!e||typeof e!="object")return e;let t={...e};return t.type&&(Array.isArray(t.type)?t.type.includes("null")||(t.type=[...t.type,"null"]):t.type!=="null"&&(t.type=[t.type,"null"])),Array.isArray(t.enum)&&!t.enum.includes(null)&&(t.enum=[...t.enum,null]),Array.isArray(t.anyOf)&&(t.anyOf=t.anyOf.map(s=>this.makeSchemaNullable(s))),Array.isArray(t.oneOf)&&(t.oneOf=t.oneOf.map(s=>this.makeSchemaNullable(s))),Array.isArray(t.allOf)&&(t.allOf=t.allOf.map(s=>this.makeSchemaNullable(s))),t}async*parseOpenAIStreamResponse(e,t){let s="",n=0,i=()=>new Promise(o=>setImmediate(o));for await(let o of e){if(t?.aborted)throw process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Stream aborted by signal"),new Error("Request aborted");n++%20===0&&await i(),s+=o.toString();let a=s.split(`
|
|
1628
1628
|
`);s=a.pop()||"";for(let l of a){let c=l.trim();if(!c||!c.startsWith("data: "))continue;let u=c.slice(6);if(u==="[DONE]"){process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Stream Received [DONE]");return}try{let p=JSON.parse(u);process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Stream Chunk",p),yield p;}catch{process.env.CLI_DEBUG==="1"&&f.warn("OpenAI","Stream Invalid JSON",{data:u});}}}}async*parseResponsesAPIStream(e,t){let s=new Map,n=0,i=null,o=null,a=false,l=false,c=2e5,u=1e5,p=h=>{let g={...h};return l||(g.role="assistant",l=true),{choices:[{index:0,delta:g}]}};for await(let h of this.parseOpenAIStreamResponse(e,t))if(!(!h||typeof h!="object"))switch(h.type){case "response.output_text.delta":{let g=typeof h.delta=="string"?h.delta:"";if(!g)break;a=true,yield p({content:g});break}case "response.output_item.added":{if(h.item?.type==="function_call"){let g=h.item.id||`item_${h.output_index}`,y={id:h.item.call_id||h.item.id||`call_${Date.now()}_${n}`,name:h.item.name,index:n++,arguments:"",completed:false};s.set(g,y),process.env.CLI_DEBUG==="1"&&f.debug("OpenAI","Function call added from stream:",{key:g,id:y.id,call_id:h.item.call_id,item_id:h.item.id,name:y.name,index:y.index}),a=true,yield p({tool_calls:[{index:y.index,id:y.id,type:"function",function:{name:y.name}}]});}break}case "response.function_call_arguments.delta":{let g=h.item_id?s.get(h.item_id):void 0;if(!g)break;let y=Buffer.byteLength(g.arguments,"utf8");if(y>=c){process.env.CLI_DEBUG==="1"&&f.warn("OpenAI",`Tool ${g.name} arguments exceeded maximum size (${y} bytes), truncating`);break}let b=typeof h.delta=="string"?h.delta:"";if(!b)break;y>5e4&&await new Promise(S=>setImmediate(S)),g.arguments+=b,a=true;let w=Buffer.byteLength(g.arguments,"utf8");w>u&&y<=u&&f.warn("OpenAI",`Tool ${g.name} arguments size exceeds ${u} bytes (${w} bytes)`),yield p({tool_calls:[{index:g.index,id:g.id,type:"function",function:{name:g.name,arguments:b}}]});break}case "response.output_item.done":{if(h.item?.type==="function_call"){let g=h.item.id||`item_${h.output_index}`,y=s.get(g);if(y&&(y.completed=true,process.env.CLI_DEBUG==="1")){let b=Buffer.byteLength(y.arguments,"utf8");f.debug("OpenAI",`Tool ${y.name} arguments complete (${b} bytes)`);}}break}case "response.completed":{i=h.response,o=h.response?.usage;break}case "response.error":case "response.failed":{let g=h.error?.message||h.error?.code||h.message||"Responses stream failed";throw new Error(g)}}let d=[];for(let[h,g]of s.entries())g.completed||d.push(`${g.name} (${Buffer.byteLength(g.arguments,"utf8")} bytes)`);if(d.length>0&&(f.error("OpenAI",`\u26A0\uFE0F Responses API stream ended with ${d.length} incomplete tool calls: ${d.join(", ")}`),f.error("OpenAI","This indicates a streaming issue with the API/proxy server. The tool calls received incomplete arguments and may fail execution.")),!a&&i){let h=Array.isArray(i.output)?i.output:[],g="";for(let y of h)if(y?.type==="message"&&Array.isArray(y.content))for(let b of y.content)b?.type==="output_text"&&typeof b.text=="string"&&(g+=b.text);g&&(yield {choices:[{index:0,delta:{role:"assistant",content:g}}]});}let m={choices:[{index:0,delta:{},finish_reason:"stop"}]};o&&(m.usage=this.normalizeUsage(o)),yield m;}async*parseAnthropicStreamResponse(e){let t="",s=[],n=0,i=false,o=null;for await(let l of e){t+=l.toString();let c=t.split(`
|
|
1629
|
-
`);t=c.pop()||"";for(let u of c){let p=u.trim();if(!p||!p.startsWith("data: "))continue;let d=p.slice(6);if(d!=="[DONE]")try{let m=JSON.parse(d);switch(m.type){case "message_start":m.message?.usage&&(o=m.message.usage);break;case "content_block_start":if(m.content_block?.type==="text")i||(i=!0,yield {choices:[{delta:{role:"assistant"},index:0}]});else if(m.content_block?.type==="tool_use"){let h=m.content_block;s.push({index:n,id:h.id,type:"function",function:{name:h.name,arguments:""}}),yield {choices:[{delta:{tool_calls:[{index:n,id:h.id,type:"function",function:{name:h.name}}]},index:0}]},n++;}break;case "content_block_delta":if(m.delta?.type==="text_delta")yield {choices:[{delta:{content:m.delta.text||""},index:0}]};else if(m.delta?.type==="input_json_delta"){let h=m.delta.partial_json||"";if(s.length>0){let g=s[s.length-1];g.function.arguments+=h,yield {choices:[{delta:{tool_calls:[{index:g.index,function:{arguments:h}}]},index:0}]};}}break;case "message_delta":m.usage&&(o=m.usage);break;case "error":throw new Error(m.error?.message||"Stream error")}}catch{}}}let a={choices:[{delta:{},finish_reason:s.length>0?"tool_calls":"stop",index:0}]};o&&(a.usage=this.normalizeUsage(o)),yield a;}normalizeUsage(e){let t={prompt_tokens:e.input_tokens??e.prompt_tokens??0,completion_tokens:e.output_tokens??e.completion_tokens??0,total_tokens:0};return t.total_tokens=t.prompt_tokens+t.completion_tokens,e.prompt_tokens_details?.cached_tokens!==void 0&&(t.prompt_tokens_details={cached_tokens:e.prompt_tokens_details.cached_tokens,text_tokens:e.prompt_tokens_details.text_tokens,audio_tokens:e.prompt_tokens_details.audio_tokens,image_tokens:e.prompt_tokens_details.image_tokens}),e.completion_tokens_details&&(t.completion_tokens_details={text_tokens:e.completion_tokens_details.text_tokens,audio_tokens:e.completion_tokens_details.audio_tokens,reasoning_tokens:e.completion_tokens_details.reasoning_tokens}),e.prompt_cache_hit_tokens!==void 0&&(t.prompt_cache_hit_tokens=e.prompt_cache_hit_tokens),e.cache_read_input_tokens!==void 0&&(t.cache_read_input_tokens=e.cache_read_input_tokens),e.cache_creation_input_tokens!==void 0&&(t.cache_creation_input_tokens=e.cache_creation_input_tokens),t}shouldUseResponsesAPI(e){return this.useResponsesAPI}setSessionId(e){this.sessionId=e,process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Session ID updated to: ${e}`);}getSessionId(){return this.sessionId}setDoubaoThinking(e){this.doubaoThinking=e,process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Doubao thinking updated to: ${e?.type||"undefined"}`);}getDoubaoThinking(){return this.doubaoThinking}};
|
|
1629
|
+
`);t=c.pop()||"";for(let u of c){let p=u.trim();if(!p||!p.startsWith("data: "))continue;let d=p.slice(6);if(d!=="[DONE]")try{let m=JSON.parse(d);switch(m.type){case "message_start":m.message?.usage&&(o=m.message.usage);break;case "content_block_start":if(m.content_block?.type==="text")i||(i=!0,yield {choices:[{delta:{role:"assistant"},index:0}]});else if(m.content_block?.type==="tool_use"){let h=m.content_block;s.push({index:n,id:h.id,type:"function",function:{name:h.name,arguments:""}}),yield {choices:[{delta:{tool_calls:[{index:n,id:h.id,type:"function",function:{name:h.name}}]},index:0}]},n++;}break;case "content_block_delta":if(m.delta?.type==="text_delta")yield {choices:[{delta:{content:m.delta.text||""},index:0}]};else if(m.delta?.type==="input_json_delta"){let h=m.delta.partial_json||"";if(s.length>0){let g=s[s.length-1];g.function.arguments+=h,yield {choices:[{delta:{tool_calls:[{index:g.index,function:{arguments:h}}]},index:0}]};}}break;case "message_delta":m.usage&&(o=m.usage);break;case "error":throw new Error(m.error?.message||"Stream error")}}catch{}}}let a={choices:[{delta:{},finish_reason:s.length>0?"tool_calls":"stop",index:0}]};o&&(a.usage=this.normalizeUsage(o)),yield a;}normalizeUsage(e){let t={prompt_tokens:e.input_tokens??e.prompt_tokens??0,completion_tokens:e.output_tokens??e.completion_tokens??0,total_tokens:0};return t.total_tokens=t.prompt_tokens+t.completion_tokens,e.prompt_tokens_details?.cached_tokens!==void 0&&(t.prompt_tokens_details={cached_tokens:e.prompt_tokens_details.cached_tokens,text_tokens:e.prompt_tokens_details.text_tokens,audio_tokens:e.prompt_tokens_details.audio_tokens,image_tokens:e.prompt_tokens_details.image_tokens}),e.completion_tokens_details&&(t.completion_tokens_details={text_tokens:e.completion_tokens_details.text_tokens,audio_tokens:e.completion_tokens_details.audio_tokens,reasoning_tokens:e.completion_tokens_details.reasoning_tokens}),e.prompt_cache_hit_tokens!==void 0&&(t.prompt_cache_hit_tokens=e.prompt_cache_hit_tokens),e.cache_read_input_tokens!==void 0&&(t.cache_read_input_tokens=e.cache_read_input_tokens),e.cache_creation_input_tokens!==void 0&&(t.cache_creation_input_tokens=e.cache_creation_input_tokens),t}shouldUseResponsesAPI(e){return this.useResponsesAPI}setSessionId(e){this.sessionId=e,process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Session ID updated to: ${e}`);}getSessionId(){return this.sessionId}setDoubaoThinking(e){this.doubaoThinking=e,process.env.CLI_DEBUG==="1"&&f.debug("OpenAI",`Doubao thinking updated to: ${e?.type||"undefined"}`);}getDoubaoThinking(){return this.doubaoThinking}};me();var si=class extends bt{constraints;promptBuilder;provider;defaultModel;constructor(e){super(),this.constraints=new is,this.promptBuilder=new as,this.defaultModel=e.defaultModel||"gpt-4o";let{apiKey:t,baseUrl:s,defaultModel:n,useResponsesAPI:i,maxTokens:o,maxInputTokens:a,...l}=e;this.provider=new It({apiKey:t,baseUrl:s,defaultModel:this.defaultModel,useResponsesAPI:i,maxTokens:o,maxInputTokens:a,...l});}prepareRequest(e,t){let s=t.model||this.defaultModel,n=this.constraints.isResponsesAPIModel(s),i=super.prepareRequest(e,{...t,model:s});return n&&i.options.temperature===void 0&&delete i.options.temperature,i}async chat(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}return s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("OpenAIAdapter","Warnings",s.validation.warnings),this.provider.chat(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens})}async*chatStreamed(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("OpenAIAdapter","Warnings",s.validation.warnings),yield*this.provider.chatStreamed(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens,signal:t.signal});}getProvider(){return this.provider}getModelCapabilities(e){let t=e||this.defaultModel;return {supportsVision:this.constraints.supportsVision(t),supportsTools:this.constraints.supportsTools(t),supportsReasoning:this.constraints.supportsReasoning(t),isResponsesAPI:this.constraints.isResponsesAPIModel(t),tokenLimits:this.constraints.getTokenLimits(t)}}};var Gn=class extends Gt{getConstraints(){return {maxOutputTokens:{"claude-3-5-sonnet-20241022":8192,"claude-3-5-sonnet-20240620":8192,"claude-3-5-haiku-20241022":8192,"claude-3-opus-20240229":4096,"claude-3-sonnet-20240229":4096,"claude-3-haiku-20240307":4096,"claude-2.1":4096,"claude-2.0":4096,"claude-instant-1.2":4096,"claude-3-5*":8192,"claude-3*":4096,"claude-2*":4096},maxInputTokens:{"claude-3-5-sonnet-20241022":2e5,"claude-3-5-sonnet-20240620":2e5,"claude-3-5-haiku-20241022":2e5,"claude-3-opus-20240229":2e5,"claude-3-sonnet-20240229":2e5,"claude-3-haiku-20240307":2e5,"claude-2.1":2e5,"claude-2.0":1e5,"claude-instant-1.2":1e5,"claude-3*":2e5,"claude-2*":2e5},supportedParams:new Set(["model","messages","system","stream","max_tokens","temperature","top_p","top_k","stop_sequences","tools","tool_choice","thinking","metadata"]),paramAliases:{max_completion_tokens:"max_tokens",stop:"stop_sequences"},validators:{temperature:je(0,1),top_p:je(0,1),top_k:ti(e=>Number.isInteger(e)||"Must be an integer",je(1,500)),max_tokens:e=>{let t=Number(e);return isNaN(t)?"Must be a number":t<1?"Must be at least 1":true},"thinking.type":js(["enabled","disabled"]),"thinking.budget_tokens":e=>{let t=Number(e);return isNaN(t)?"Must be a number":t<1024?"Budget tokens must be at least 1024":t>1e4?"Budget tokens cannot exceed 10000":true},tool_choice:e=>typeof e=="string"?["auto","any","tool"].includes(e)||"Must be 'auto', 'any', or 'tool'":typeof e=="object"&&e.type==="tool"?e.name?true:'tool_choice.name is required when type is "tool"':"Invalid tool_choice format",stop_sequences:e=>Array.isArray(e)?e.length>4?"Maximum 4 stop sequences allowed":e.every(t=>typeof t=="string")?true:"All stop sequences must be strings":"Must be an array",stream:e=>typeof e=="boolean"||"Must be a boolean","metadata.user_id":e=>typeof e!="string"?"Must be a string":e.length>64?"Maximum 64 characters":e.includes("@")||/\d{10,}/.test(e)?"user_id should not contain PII (email, phone number, etc.)":true},defaults:{temperature:1,top_p:1,stream:false}}}supportsThinking(e){return e.includes("claude-3-5-sonnet")||e.includes("claude-3-opus")}supportsVision(e){return e.includes("claude-3")}supportsTools(e){return e.includes("claude-3")}supportsPromptCaching(e){return e.includes("claude-3-5")||e.includes("claude-3-opus")||e.includes("claude-3-sonnet")}getRecommendedMaxTokens(e,t){let s=this.getTokenLimits(e);switch(t){case "short":return Math.min(1024,s.maxOutput);case "medium":return Math.min(4096,s.maxOutput);case "long":return s.maxOutput;default:return Math.min(4096,s.maxOutput)}}validateSystemPrompt(e){if(typeof e=="string")return e.length===0?{valid:false,error:"System prompt cannot be empty"}:e.length>1e5?{valid:false,error:"System prompt too long (max 100K chars)"}:{valid:true};if(Array.isArray(e)){for(let t of e){if(t.type!=="text")return {valid:false,error:'System prompt blocks must be of type "text"'};if(!t.text||t.text.trim().length===0)return {valid:false,error:"System prompt text blocks cannot be empty"}}return {valid:true}}return {valid:false,error:"System prompt must be a string or array of text blocks"}}getCachingRecommendation(e,t){return this.supportsPromptCaching(e)?t<2e3?{shouldUseCache:false,cacheTTL:"5m",reason:"Prompt too short, caching overhead not worth it"}:t<1e4?{shouldUseCache:true,cacheTTL:"5m",reason:"Medium prompt, 5-minute cache recommended"}:{shouldUseCache:true,cacheTTL:"1h",reason:"Long prompt, 1-hour cache recommended for cost savings"}:{shouldUseCache:false,cacheTTL:"5m",reason:"Model does not support prompt caching"}}};var Bn=class extends Bt{buildSystemPrompt(e){let{workDir:t,language:s="zh",customInstructions:n}=e,i=Zr({workDir:t,language:s});return n&&n.trim()&&(i+=`
|
|
1630
1630
|
|
|
1631
1631
|
# Custom Instructions
|
|
1632
1632
|
|
|
@@ -1680,21 +1680,21 @@ Claude uses standard tool calling format:
|
|
|
1680
1680
|
}
|
|
1681
1681
|
\`\`\`
|
|
1682
1682
|
|
|
1683
|
-
Tool results are returned via tool_result messages.`}supportsExtendedThinking(e){return e?e.includes("claude-3-5-sonnet")||e.includes("claude-3-opus"):false}supportsPromptCaching(e){return e?e.includes("claude-3-5")||e.includes("claude-3-opus")||e.includes("claude-3-sonnet"):false}getCachingRecommendation(e){return e<2e3?{shouldUseCache:false,cacheTTL:"5m",reason:"Prompt too short, caching overhead not worth it"}:e<1e4?{shouldUseCache:true,cacheTTL:"5m",reason:"Medium prompt, 5-minute cache recommended"}:{shouldUseCache:true,cacheTTL:"1h",reason:"Long prompt, 1-hour cache recommended for cost savings"}}};
|
|
1683
|
+
Tool results are returned via tool_result messages.`}supportsExtendedThinking(e){return e?e.includes("claude-3-5-sonnet")||e.includes("claude-3-opus"):false}supportsPromptCaching(e){return e?e.includes("claude-3-5")||e.includes("claude-3-opus")||e.includes("claude-3-sonnet"):false}getCachingRecommendation(e){return e<2e3?{shouldUseCache:false,cacheTTL:"5m",reason:"Prompt too short, caching overhead not worth it"}:e<1e4?{shouldUseCache:true,cacheTTL:"5m",reason:"Medium prompt, 5-minute cache recommended"}:{shouldUseCache:true,cacheTTL:"1h",reason:"Long prompt, 1-hour cache recommended for cost savings"}}};me();var pf=15e3,Hn=2*1024*1024,df=1.5*1024*1024;function mf(r,e=pf){if(!r||r.length<=e)return r;let t=r.split(`
|
|
1684
1684
|
`).length,s=r.length,n=Math.floor(e*.4),i=Math.floor(e*.4),o=n,a=r.length-i;for(;o>0&&(r.charCodeAt(o)&192)===128;)o--;for(;a<r.length&&(r.charCodeAt(a)&192)===128;)a++;let l=r.slice(0,o),c=r.slice(a),p=`
|
|
1685
1685
|
|
|
1686
1686
|
\u2026[${s-l.length-c.length} chars truncated, total ${t} lines]\u2026
|
|
1687
1687
|
|
|
1688
|
-
`;return l+p+c}function
|
|
1689
|
-
...[truncated ${s.length-e} chars]`:s:"No headers"}var
|
|
1690
|
-
`);t=p.pop()||"";for(let d of p){let m=d.trim();if(!m||!m.startsWith("data: "))continue;let h=m.slice(6);if(h!=="[DONE]")try{let g=JSON.parse(h);if(process.env.CLI_DEBUG==="1"){let y=JSON.stringify(g).substring(0,80);f.debug("SSE",`${g.type.padEnd(20)} ${y}${JSON.stringify(g).length>80?"...":""}`);}switch(g.type){case "message_start":a=g.message?.id||"",o=g.message?.usage;break;case "content_block_start":if(g.content_block?.type==="tool_use"){let y=g.content_block,b=this.isProxyMode?
|
|
1691
|
-
`),
|
|
1692
|
-
`+n})):(a.push({type:"text",text:
|
|
1693
|
-
`+n,cache_control:{type:"ephemeral"}})),process.env.CLI_DEBUG==="1"&&n){let c=["## \u9879\u76EE\u8BB0\u5FC6","## \u4E0A\u6B21\u4EFB\u52A1\u6458\u8981","## Project Memory","## Last Run Summary"],u=c.some(m=>n.includes(m)),p=c.reduce((m,h)=>m>=0?m:n.indexOf(h),-1),d=p>=0?n.slice(p,p+300):void 0;f.info("MEMORY_INJECT","Anthropic system memory check",{hasMemory:u,systemLength:n.length,snippet:d});}let l={model:this.normalizeModelName(s),system:a,metadata:this.buildMetadata(t.metadata),max_tokens:this.maxTokens};return (!t.thinking?.type||t.thinking.type==="disabled")&&(l.temperature=t.temperature??.7),l.stream=true,l.messages=o,t.tools?.length&&(l.tools=this.buildToolsPayload(t.tools,t)),t.webSearch?.enabled&&(l.tools=l.tools||[],l.tools.push(this.buildWebSearchTool(t.webSearch))),l.tools?.length>0&&this.ensureLastToolCacheControl(l.tools,t),this.shouldEnableThinking(s,t)&&(l.thinking=this.buildThinkingPayload(t),delete l.temperature,l.temperature=1),this.checkRequestBudget(l),l}checkRequestBudget(e){let s=JSON.stringify(e).length;if(s>
|
|
1688
|
+
`;return l+p+c}function nu(r,e=2e3){let t=r&&typeof r.toJSON=="function"?r.toJSON():r,s="";try{s=JSON.stringify(t??{},null,2);}catch{s=String(t??"");}return s?s.length>e?`${s.slice(0,e)}
|
|
1689
|
+
...[truncated ${s.length-e} chars]`:s:"No headers"}var ea="You are Claude Code, Anthropic's official CLI for Claude.",hf=["claude-code-20250219","interleaved-thinking-2025-05-14"],ri="2023-06-01",ii=64,gf=1024;var ru=18e4,iu=6e4,ou={readfile:"Read",write_file:"Write",edit_file:"Edit",glob_search:"Glob",glob:"Glob",search:"Grep",execute_shell:"Bash",bash:"Bash",shell:"Bash",todo_write:"TodoWrite",task:"Task",web_fetch:"WebFetch",web_search:"WebSearch",notebook_edit:"NotebookEdit",ask_user:"AskUserQuestion"},ta={Read:"readfile",Write:"write_file",Edit:"edit_file",Glob:"glob_search",Grep:"search",Bash:"execute_shell",TodoWrite:"todo_write",Task:"task",WebFetch:"web_fetch",WebSearch:"web_search",NotebookEdit:"notebook_edit",AskUserQuestion:"ask_user"},Gs=class{client;defaultModel;maxTokens;retryConfig;baseUrl;authToken;isProxyMode;claudeCodeUserId;betaFeatures;systemPromptPrefix;sanitizeToolsForProxy;disableCaching;thinkingConfig=null;constructor(e){this.authToken=e.authToken,this.baseUrl=(e.baseUrl||"https://api.anthropic.com").replace(/\/+$/,"");let t=this.baseUrl.includes("api.anthropic.com");this.isProxyMode=e.forceClaudeCodeMode||!t;let s=typeof e.userId=="string"?e.userId.trim():"";this.claudeCodeUserId=s?this.sanitizeUserId(s):this.generateSafeUserId(),this.betaFeatures=e.betaFeatures||hf,this.systemPromptPrefix=e.systemPromptPrefix||(this.isProxyMode?ea:null),this.sanitizeToolsForProxy=false,this.disableCaching=e.disableCaching||false,this.client=nf.create({baseURL:this.baseUrl,headers:this.buildHeaders(),timeout:3e5,validateStatus:()=>true}),this.defaultModel=e.defaultModel||"claude-sonnet-4-5-20250929",this.maxTokens=e.maxTokens||32e3;let n=Os("anthropic",this.baseUrl);this.retryConfig=Nt(void 0,{...n,...e.retry}),this.debugLog("Initialized",{baseUrl:this.baseUrl,isProxyMode:this.isProxyMode,defaultModel:this.defaultModel,betaFeatures:this.betaFeatures});}setThinking(e){this.thinkingConfig=e,this.debugLog("Thinking config updated",{config:e});}setUserId(e){let t=e?.trim?.()||"";t&&(this.claudeCodeUserId=this.sanitizeUserId(t));}isCacheControlError(e){let t="";try{let s=e.response?.data;if(typeof s=="string")t=s.toLowerCase();else if(s&&typeof s=="object"){let n={error:s.error,message:s.message,type:s.type,code:s.code};t=JSON.stringify(n).toLowerCase();}else t=String(e.message||"").toLowerCase();}catch{t=String(e.message||"").toLowerCase();}return t.includes("cache_control")||t.includes("ttl=")||t.includes("ephemeral")||t.includes("cache")&&t.includes("block")}async chat(e,t={}){let s={...t,disableCaching:t.disableCaching??this.disableCaching,thinking:t.thinking??this.thinkingConfig??void 0},n=this.retryConfig.requestMaxRetries,i=null,o=s.disableCaching||false;for(let a=0;a<=n;a++){let l={...s,...o?{disableCaching:true}:{}},c=this.buildPayload(e,l);a===0&&this.logRequest(t.model||this.defaultModel,c);try{let u=Date.now(),p=this.isProxyMode?"/v1/messages?beta=true":"/v1/messages",d=await this.client.post(p,c,{responseType:"stream",signal:t.signal});if(d.status!==200){let g="";for await(let S of d.data)g+=S.toString();let y=`${this.baseUrl}${p}`,b=wt(y,this.buildHeaders(),c,!1);f.error("CURL","=== [chat] API Error - Full Request CURL ==="),f.error("CURL",b),f.error("CURL",`=== Error Headers: ${nu(d.headers)} ===`),f.error("CURL",`=== Error Response: ${g.substring(0,1e3)} ===`);let w=new Error(`Anthropic API error: ${d.status}`);w.response={status:d.status,headers:d.headers,data:g};try{let S=JSON.parse(g);w.response.data=S,S.error?.message?w.message=`Anthropic API error: ${d.status} - ${S.error.message}`:S.message&&(w.message=`Anthropic API error: ${d.status} - ${S.message}`),this.debugLog("API Error Details",S);}catch{this.debugLog("API Error (non-JSON)",{status:d.status,dataLength:g.length});}throw w}let m=await this.collectStreamResponse(d.data),h=Date.now()-u;return oe.llmResponse("anthropic",h,m.usage,m.choices[0]),this.debugLog("Response",{duration:`${h}ms`,usage:m.usage}),m}catch(u){await this.normalizeAxiosStreamError(u),i=u;let p=nt(u);if(p.code==="PROXY_UPSTREAM_FAILED"){let y=JSON.stringify(c||{}).length,b=Array.isArray(e)?e.length:0,w=Array.isArray(e)?e.reduce((S,x)=>x?.content?typeof x.content=="string"?S+x.content.length:Array.isArray(x.content)?S+x.content.map(R=>typeof R.text=="string"?R.text.length:0).reduce((R,$)=>R+$,0):S:S,0):0;f.warn("Anthropic","Upstream request failed (PROXY_UPSTREAM_FAILED)",{attempt:`${a+1}/${n+1}`,payloadSize:y,msgCount:b,promptChars:w,status:u.response?.status});}if(this.debugLog("Error",{message:u.message,category:p.category,code:p.code,attempt:`${a+1}/${n+1}`}),oe.llmError("anthropic",u),this.isCacheControlError(u)&&!o){o=true,this.disableCaching=true,this.debugLog("Cache control not supported, disabling caching for retry",{errorMessage:u.message,attempt:a+1}),f.warn("Anthropic","\u26A0\uFE0F Provider \u4E0D\u652F\u6301 cache_control\uFF0C\u5DF2\u81EA\u52A8\u7981\u7528\u7F13\u5B58\u91CD\u8BD5...");continue}if(!p.retryable||a===n)throw p;let d=qr(u.response?.headers),m=Dn(p.category,a+1,d||p.retryAfter),h=p.category==="retryable_rate_limit",g=h?`\u23F3 API \u4EE3\u7406\u901F\u7387\u9650\u5236\uFF0C${Je(m)} \u540E\u91CD\u8BD5...`:`Retrying in ${Je(m)}...`;this.debugLog("Retrying",{delay:Je(m),attempt:a+1,isRateLimit:h,serverDelay:d?Je(d):"none",retryMsg:g});try{await ns(m,s.signal);}catch(y){throw y?.name==="AbortError"&&this.debugLog("Chat retry interrupted by user"),y}}}throw i||new Error("Unknown error during retry")}async collectStreamResponse(e){let t="",s="",n=[],i="",o=null,a="";for await(let c of e){let u=c.toString();t+=u;let p=t.split(`
|
|
1690
|
+
`);t=p.pop()||"";for(let d of p){let m=d.trim();if(!m||!m.startsWith("data: "))continue;let h=m.slice(6);if(h!=="[DONE]")try{let g=JSON.parse(h);if(process.env.CLI_DEBUG==="1"){let y=JSON.stringify(g).substring(0,80);f.debug("SSE",`${g.type.padEnd(20)} ${y}${JSON.stringify(g).length>80?"...":""}`);}switch(g.type){case "message_start":a=g.message?.id||"",o=g.message?.usage;break;case "content_block_start":if(g.content_block?.type==="tool_use"){let y=g.content_block,b=this.isProxyMode?ta[y.name]||this.fromClaudeCodeToolName(y.name):y.name;n.push({id:y.id,type:"function",function:{name:b,arguments:""}});}break;case "content_block_delta":g.delta?.type==="text_delta"?s+=g.delta.text||"":g.delta?.type==="input_json_delta"?n.length>0&&(n[n.length-1].function.arguments+=g.delta.partial_json||""):g.delta?.type==="thinking_delta"&&(i+=g.delta.thinking||"");break;case "message_delta":g.usage&&(o={...o,...g.usage});break}}catch(g){process.env.CLI_DEBUG==="1"&&f.warn("Anthropic",`Stream parse error: ${g}, data: ${h.substring(0,200)}`);}}}let l=this.buildUsageFromRaw(o);return {id:a,choices:[{message:{role:"assistant",content:s||"",tool_calls:n.length>0?n:void 0,...i?{reasoning_content:i}:{}},finish_reason:n.length>0?"tool_calls":"stop"}],usage:l}}async*chatStreamed(e,t={}){let s={...t,disableCaching:t.disableCaching??this.disableCaching,thinking:t.thinking??this.thinkingConfig??void 0},n=this.retryConfig.streamMaxRetries,i=0,o=s.disableCaching||false,a=true;for(;;){let l={...s,...o?{disableCaching:true}:{}},c=this.buildPayload(e,l);c.stream=true,a&&(this.logRequest(t.model||this.defaultModel,c,true),a=false);try{let u=Date.now(),p=this.isProxyMode?"/v1/messages?beta=true":"/v1/messages",d=await this.client.post(p,c,{responseType:"stream",signal:t.signal});if(this.debugLog("Stream started",{status:d.status}),d.status!==200){let k="";for await(let A of d.data)k+=A.toString();let D=`${this.baseUrl}${p}`,N=wt(D,this.buildHeaders(),c,!1);f.error("CURL","=== [chatStreamed] API Error - Full Request CURL ==="),f.error("CURL",N),f.error("CURL",`=== Error Headers: ${nu(d.headers)} ===`),f.error("CURL",`=== Error Response: ${k.substring(0,1e3)} ===`);let E=new Error(`Anthropic API error: ${d.status}`);E.response={status:d.status,headers:d.headers,data:k};try{let A=JSON.parse(k);E.response.data=A,A.error?.message?E.message=`Anthropic API error: ${d.status} - ${A.error.message}`:A.message&&(E.message=`Anthropic API error: ${d.status} - ${A.message}`),this.debugLog("API Error Details (stream)",A);}catch{this.debugLog("API Error (non-JSON, stream)",{status:d.status,dataLength:k.length});}throw E}let m="",h=[],g=0,y=!1,b=null,w=!1,S=Date.now(),x=0,R=0,$=null,G=null,U=[],T=null;for await(let k of this.createTimeoutStream(d.data,t.signal)){S=Date.now();let D=k.toString();m+=D;let N=m.split(/\n\n+/);m=N.pop()||"";for(let E of N){let A=E.split(`
|
|
1691
|
+
`),F="";for(let H of A){let M=H.trim();if(M&&!M.startsWith("event:"))if(M.startsWith("data:")){let ee=M.slice(5);ee.startsWith(" ")&&(ee=ee.slice(1)),F+=ee;}else F+=M;}if(!(!F||F==="[DONE]"))try{let H=F.trim(),M=JSON.parse(H);if(process.env.CLI_DEBUG==="1"){let q=JSON.stringify(M).substring(0,80);f.debug("SSE",`${M.type.padEnd(20)} ${q}${JSON.stringify(M).length>80?"...":""}`);}let ee=Date.now(),P=this.handleStreamEvent(M,h,g,y,b);if(process.env.CLI_DEBUG==="1"){let q=Date.now()-ee;q>50&&f.warn("SSE",`\u26A0\uFE0F Slow event handling: ${M.type} took ${q}ms`);}if(P.yield){let q=Date.now();if(yield P.yield,process.env.CLI_DEBUG==="1"){let B=Date.now()-q;B>100&&f.warn("SSE",`\u26A0\uFE0F Slow yield consumer: ${M.type} yield took ${B}ms`);}}if(P.roleSent!==void 0&&(y=P.roleSent),P.incrementToolIndex&&g++,P.usage&&(b=P.usage),P.error)throw new Error(P.error);P.contentBlockStart&&(R++,P.blockType&&(G=P.blockType)),P.contentBlockStop&&(x++,G==="thinking"&&(yield {choices:[{delta:{reasoning_complete:!0},index:0}]}),G=null),P.messageStop&&(w=!0),P.stopReason&&($=P.stopReason),M.type==="content_block_start"?M.content_block?.type==="thinking"?T={type:"thinking",thinking:"",signature:""}:M.content_block?.type==="redacted_thinking"&&U.push({type:"redacted_thinking",data:M.content_block.data}):M.type==="content_block_delta"?T&&(M.delta?.type==="thinking_delta"?T.thinking+=M.delta.thinking||"":M.delta?.type==="signature_delta"&&(T.signature+=M.delta.signature||"")):M.type==="content_block_stop"&&T&&(U.push({type:T.type,thinking:T.thinking,signature:T.signature}),T=null);}catch{}}}let C=Date.now()-u;if(this.debugLog("Stream completion check",{messageStopReceived:w,stopReason:$,contentBlocksStarted:R,contentBlocksCompleted:x,toolCallsCount:h.length,duration:`${C}ms`}),!w&&!$){let k=new Error(`Stream incomplete: message_stop not received (blocks: ${R} started, ${x} completed)`);throw k.code="STREAM_INCOMPLETE",k.isNetworkInterrupt=!0,this.debugLog("Stream incomplete detected",{messageStopReceived:w,stopReason:$,contentBlocksStarted:R,contentBlocksCompleted:x,toolCallsCount:h.length,duration:`${C}ms`}),k}if(R!==x)if($==="max_tokens")this.debugLog("Content blocks mismatch due to max_tokens (expected, not an error)",{contentBlocksStarted:R,contentBlocksCompleted:x,stopReason:$}),f.warn("Anthropic","\u26A0\uFE0F Response truncated due to max_tokens limit. Consider increasing max_tokens or breaking down the task.");else {let k=new Error(`Stream incomplete: content blocks mismatch (${R} started, ${x} completed)`);throw k.code="STREAM_INCOMPLETE",k.isNetworkInterrupt=!0,this.debugLog("Content blocks mismatch",{contentBlocksStarted:R,contentBlocksCompleted:x,stopReason:$}),k}if(h.length>0&&$!=="max_tokens")for(let k of h){let D=k.function?.arguments||"";if(D&&D.trim())try{JSON.parse(D);}catch{let N=new Error(`Stream incomplete: tool arguments truncated for ${k.function?.name}`);throw N.code="STREAM_INCOMPLETE",N.isNetworkInterrupt=!0,N.toolName=k.function?.name,this.debugLog("Tool arguments truncated",{toolName:k.function?.name,argsLength:D.length,argsPreview:D.substring(0,100)}),N}}else if($==="max_tokens"&&h.length>0){let k=h[h.length-1],D=k?.function?.arguments||"";try{JSON.parse(D);}catch{this.debugLog("Tool arguments truncated due to max_tokens (expected)",{toolName:k?.function?.name,argsLength:D.length}),f.warn("Anthropic",`\u26A0\uFE0F Tool call ${k?.function?.name} arguments truncated due to max_tokens. The tool call will be incomplete.`);}}this.debugLog("finalUsage before build",b);let _=this.buildUsageFromRaw(b);this.debugLog("usage after build",_),!y&&h.length===0&&f.warn("Anthropic",`\u26A0\uFE0F Stream completed with no content! duration: ${C}ms, usage: ${JSON.stringify(b)}`),oe.llmResponse("anthropic-stream",C,_||{},{}),this.debugLog("Stream complete",{duration:`${C}ms`}),yield {choices:[{delta:{},finish_reason:"stop",index:0}],..._?{usage:_}:{},...U.length>0?{thinking_blocks:U}:{}};return}catch(u){await this.normalizeAxiosStreamError(u);let p=nt(u);this.debugLog("Stream error",{message:u.message,category:p.category,retryable:p.retryable});let d=this.isProxyMode?"/v1/messages?beta=true":"/v1/messages",m=`${this.baseUrl}${d}`,h=wt(m,this.buildHeaders(),c,false);if(f.error("CURL","=== [chatStreamed catch] Stream Error - Full Request CURL ==="),f.error("CURL",h),f.error("CURL",`=== Error: ${p.message} ===`),oe.llmError("anthropic-stream",u),this.isCacheControlError(u)&&!o){o=true,this.disableCaching=true,this.debugLog("Cache control not supported, disabling caching for retry",{errorMessage:u.message,attempt:i+1}),f.warn("Anthropic","\u26A0\uFE0F Provider \u4E0D\u652F\u6301 cache_control\uFF0C\u5DF2\u81EA\u52A8\u7981\u7528\u7F13\u5B58\u91CD\u8BD5...");continue}if(p.retryable&&i<n){i++;let g=qr(u.response?.headers),y=Dn(p.category,i,g||p.retryAfter),b=p.category==="retryable_rate_limit",w=p.category==="retryable_stream";this.debugLog("Stream retrying",{delay:Je(y),attempt:`${i}/${n}`,isRateLimit:b,isStreamIncomplete:w}),yield {type:"stream_retry",error:p.message,errorCode:p.code,attempt:i,maxRetries:n,delayMs:y,isRateLimit:b,isNetworkError:w};try{await ns(y,t.signal);}catch(S){throw S?.name==="AbortError"&&this.debugLog("Stream retry interrupted by user"),S}this.debugLog("Stream retry starting",{attempt:i}),yield {type:"stream_recovered",attempt:i,maxRetries:n};continue}throw p}}}buildPayload(e,t){let s=t.model||this.defaultModel,{system:n,anthropicMessages:i}=this.convertMessages(e,t),o=i,a=[];if(t.disableCaching?(a.push({type:"text",text:ea}),n&&a.push({type:"text",text:`
|
|
1692
|
+
`+n})):(a.push({type:"text",text:ea,cache_control:{type:"ephemeral"}}),n&&a.push({type:"text",text:`
|
|
1693
|
+
`+n,cache_control:{type:"ephemeral"}})),process.env.CLI_DEBUG==="1"&&n){let c=["## \u9879\u76EE\u8BB0\u5FC6","## \u4E0A\u6B21\u4EFB\u52A1\u6458\u8981","## Project Memory","## Last Run Summary"],u=c.some(m=>n.includes(m)),p=c.reduce((m,h)=>m>=0?m:n.indexOf(h),-1),d=p>=0?n.slice(p,p+300):void 0;f.info("MEMORY_INJECT","Anthropic system memory check",{hasMemory:u,systemLength:n.length,snippet:d});}let l={model:this.normalizeModelName(s),system:a,metadata:this.buildMetadata(t.metadata),max_tokens:this.maxTokens};return (!t.thinking?.type||t.thinking.type==="disabled")&&(l.temperature=t.temperature??.7),l.stream=true,l.messages=o,t.tools?.length&&(l.tools=this.buildToolsPayload(t.tools,t)),t.webSearch?.enabled&&(l.tools=l.tools||[],l.tools.push(this.buildWebSearchTool(t.webSearch))),l.tools?.length>0&&this.ensureLastToolCacheControl(l.tools,t),this.shouldEnableThinking(s,t)&&(l.thinking=this.buildThinkingPayload(t),delete l.temperature,l.temperature=1),this.checkRequestBudget(l),l}checkRequestBudget(e){let s=JSON.stringify(e).length;if(s>Hn){if(this.debugLog("Request body exceeds limit",{bodySize:s,limit:Hn,messageCount:e.messages?.length||0}),e.messages){let i=[...e.messages.map((o,a)=>({index:a,role:o.role,contentSize:JSON.stringify(o.content||"").length}))].sort((o,a)=>a.contentSize-o.contentSize);this.debugLog("Largest messages in request",{top5:i.slice(0,5)});}console.warn(`[Anthropic] \u26A0\uFE0F Request body size (${(s/1024/1024).toFixed(2)}MB) exceeds ${(Hn/1024/1024).toFixed(1)}MB limit. Request may fail.`);}else s>df&&this.debugLog("Request body approaching limit",{bodySize:s,limit:Hn,percentage:(s/Hn*100).toFixed(1)+"%"});}mergeSystemIntoMessages(e,t){let s=[...t],n=s.findIndex(i=>i.role==="user");if(n>=0){let i=s[n],o={type:"text",text:`<system_context>
|
|
1694
1694
|
${e}
|
|
1695
|
-
</system_context>`};Array.isArray(i.content)?s[n]={...i,content:[o,...i.content]}:typeof i.content=="string"&&(s[n]={...i,content:[o,{type:"text",text:i.content}]});}return s}buildToolsPayload(e,t){return e.map(n=>this.transformToolDefinition(n))}ensureLastToolCacheControl(e,t){if(e.length===0||t.disableCaching)return;let s=e[e.length-1];s.cache_control={type:"ephemeral"},this.debugLog("Added cache_control to last tool",{toolName:s.name});}buildWebSearchTool(e){let t={type:"web_search_20250305",name:"web_search"};return e.max_uses&&(t.max_uses=e.max_uses),e.user_location&&(t.user_location=e.user_location),t}buildThinkingPayload(e){let t=e.thinking?.budget_tokens||this.maxTokens-1;return {type:"enabled",budget_tokens:Math.max(t,
|
|
1695
|
+
</system_context>`};Array.isArray(i.content)?s[n]={...i,content:[o,...i.content]}:typeof i.content=="string"&&(s[n]={...i,content:[o,{type:"text",text:i.content}]});}return s}buildToolsPayload(e,t){return e.map(n=>this.transformToolDefinition(n))}ensureLastToolCacheControl(e,t){if(e.length===0||t.disableCaching)return;let s=e[e.length-1];s.cache_control={type:"ephemeral"},this.debugLog("Added cache_control to last tool",{toolName:s.name});}buildWebSearchTool(e){let t={type:"web_search_20250305",name:"web_search"};return e.max_uses&&(t.max_uses=e.max_uses),e.user_location&&(t.user_location=e.user_location),t}buildThinkingPayload(e){let t=e.thinking?.budget_tokens||this.maxTokens-1;return {type:"enabled",budget_tokens:Math.max(t,gf)}}buildMetadata(e){let t={...e};return t.user_id?t.user_id=this.sanitizeUserId(t.user_id):t.user_id=this.claudeCodeUserId,t}shouldEnableThinking(e,t){return t.thinking?.type==="enabled"?true:t.thinking?.type==="disabled"?false:!!(e.endsWith("-thinking")||e.includes("opus-4-6")||e.includes("opus-4.6")||e.includes("opus-4-5")||e.includes("opus-4.5"))}normalizeModelName(e){return e.endsWith("-thinking")?e.replace(/-thinking$/,""):e}convertMessages(e,t){let s=this.normalizeMessages(e),n=[],i=[];for(let u of s){if(u.role==="system"){let d=se(u.content).trim();d&&n.push(d);continue}let p=this.convertSingleMessage(u);p&&i.push(p);}let o=this.mergeConsecutiveUserMessages(i),l=this.validateToolResultPairs(o);return l.length>0&&l[0].role!=="user"&&l.unshift({role:"user",content:[{type:"text",text:"..."}]}),l.length>0&&!t.disableCaching&&this.addMessageCacheControl(l),{system:n.length>0?n.join(`
|
|
1696
1696
|
|
|
1697
|
-
`):null,anthropicMessages:l}}addMessageCacheControl(e){let t=false;for(let s=e.length-1;s>=0;s--){let n=e[s];if(!(n.role!=="user"||!Array.isArray(n.content))){for(let i=n.content.length-1;i>=0;i--){let o=n.content[i];if(!t&&o.type==="tool_result"){o.cache_control={type:"ephemeral"},t=true,this.debugLog("Added cache_control to tool_result",{tool_use_id:o.tool_use_id});break}}if(t)break}}t||this.addTextBlockCacheControl(e);}addTextBlockCacheControl(e){for(let t=e.length-1;t>=0;t--){let s=e[t];if(s.role==="user"&&Array.isArray(s.content)){for(let n=s.content.length-1;n>=0;n--)if(s.content[n].type==="text"){s.content[n].cache_control={type:"ephemeral"},this.debugLog("Added cache_control to user text block");return}}}}validateToolResultPairs(e){let t=new Set,s=new Set;for(let o of e)if(Array.isArray(o.content))for(let a of o.content)a.type==="tool_use"&&a.id&&t.add(a.id),a.type==="tool_result"&&a.tool_use_id&&s.add(a.tool_use_id);let n=new Set;for(let o of t)s.has(o)&&n.add(o);this.debugLog("Tool pairing analysis",{toolUseCount:t.size,toolResultCount:s.size,pairedCount:n.size,orphanToolUseIds:Array.from(t).filter(o=>!n.has(o)),orphanToolResultIds:Array.from(s).filter(o=>!n.has(o))});let i=[];for(let o of e){if(!Array.isArray(o.content)){i.push(o);continue}let a=o.content.filter(l=>{if(l.type==="tool_use"){let c=n.has(l.id);return c||this.debugLog("Removing orphan tool_use",{id:l.id}),c}if(l.type==="tool_result"){let c=n.has(l.tool_use_id);return c||this.debugLog("Removing orphan tool_result",{tool_use_id:l.tool_use_id}),c}return true});a.length>0?i.push({...o,content:a}):this.debugLog("Skipping empty message after tool pairing filter",{role:o.role});}return i}mergeConsecutiveUserMessages(e){if(e.length===0)return [];let t=[];for(let s of e){let n=t[t.length-1];if(n&&n.role==="user"&&s.role==="user"){let i=Array.isArray(n.content)?n.content:[{type:"text",text:n.content}],o=Array.isArray(s.content)?s.content:[{type:"text",text:s.content}];n.content=[...i,...o];}else t.push(s);}return t}convertSingleMessage(e){if(e.role==="tool"){let s=te(e.content),n=nf(s);return s.length!==n.length&&this.debugLog("Tool output truncated",{tool_call_id:e.tool_call_id,original:s.length,truncated:n.length}),{role:"user",content:[{type:"tool_result",tool_use_id:e.tool_call_id,content:n}]}}if(e.role==="assistant"){let s=[],n=false;if(e.thinking_blocks&&e.thinking_blocks.length>0){n=true;for(let o of e.thinking_blocks)if(o.type==="thinking"){let a={type:"thinking",thinking:o.thinking};o.signature!==void 0&&(a.signature=o.signature),s.push(a);}else if(o.type==="redacted_thinking"){let a={type:"redacted_thinking"};o.data!==void 0&&(a.data=o.data),s.push(a);}}let i=te(e.content);if(i){let o=i.trimEnd();s.push({type:"text",text:o||"."});}else n&&(s.push({type:"text",text:"."}),this.debugLog("Added placeholder text after thinking (no text content)"));if(e.tool_calls)for(let o of e.tool_calls){let a=(o.function.arguments||"").trim(),l={};if(a.length>0)try{l=JSON.parse(a);}catch{this.debugLog("Failed to parse tool arguments",{tool:o.function.name});}let c=this.isProxyMode?eu[o.function.name]||this.toClaudeCodeToolName(o.function.name):o.function.name;s.push({type:"tool_use",id:o.id,name:c,input:l});}if(s.length>0){let o=s[s.length-1];this.debugLog("Assistant message final check",{contentLength:s.length,lastBlockType:o.type,hasThinkingBlocks:n,blockTypes:s.map(a=>a.type),lastBlockTextPreview:o.type==="text"?(o.text||"").substring(0,50):void 0}),o.type==="thinking"||o.type==="redacted_thinking"?(s.push({type:"text",text:"."}),this.debugLog("Fixed: Added text block after thinking")):o.type==="text"&&(!o.text||!o.text.trim())&&s.some(l=>l.type==="thinking"||l.type==="redacted_thinking")&&(o.text=".",this.debugLog("Fixed: Ensured text block has content after thinking"));}return s.length>0?{role:"assistant",content:s}:null}if(Array.isArray(e.content)){let s=e.content.filter(o=>o.type==="text");if(!e.content.some(o=>o.type!=="text")&&s.length===1){let o=s[0].text;return o.trim()?{role:"user",content:o}:null}let i=this.convertMultimodalContent(e.content);return i.length>0?{role:"user",content:i}:null}let t=te(e.content);return t.trim()?{role:"user",content:t}:null}convertMultimodalContent(e){let t=[];for(let s of e)if(s.type==="text")t.push({type:"text",text:s.text});else if(s.type==="image_url"){let n=this.convertImageUrl(s.image_url.url);n&&t.push(n);}return t}convertImageUrl(e){if(e.startsWith("data:")){let t=e.match(/^data:([^;]+);base64,(.+)$/);if(t)return {type:"image",source:{type:"base64",media_type:t[1],data:t[2]}}}else return {type:"image",source:{type:"url",url:e}};return null}normalizeMessages(e){let t=e.filter(s=>{let n=s.role==="assistant"&&!!(s.tool_calls&&s.tool_calls.length>0),i=s.role==="assistant"&&!!(s.thinking_blocks&&s.thinking_blocks.length>0);return n||i?true:s.content?typeof s.content=="string"?s.content.trim().length>0:Array.isArray(s.content)?s.content.length>0:true:false});return t.length===0?[]:(this.validateMessageAlternation(t),t)}validateMessageAlternation(e){let t=e.filter(n=>n.role!=="system"),s=false;for(let n=1;n<t.length;n++)t[n].role===t[n-1].role&&(s=true,this.debugLog("Message alternation warning",{index:n,prevRole:t[n-1].role,currentRole:t[n].role}));!s&&t.length>1&&this.debugLog("Message alternation OK",{messageCount:t.length,roles:t.map(n=>n.role)});}convertResponse(e){this.debugLog("Raw response",e);let t=e.content||[],s="",n=[],i="";for(let a of t)if(a.type==="text")s+=a.text;else if(a.type==="tool_use"){let l=this.isProxyMode?Zo[a.name]||this.fromClaudeCodeToolName(a.name):a.name;n.push({id:a.id,type:"function",function:{name:l,arguments:JSON.stringify(a.input)}});}else a.type==="thinking"&&(i=a.thinking||"");let o=this.buildUsageFromRaw(e.usage);return {id:e.id,choices:[{message:{role:"assistant",content:s||"",tool_calls:n.length>0?n:void 0,...i?{reasoning_content:i}:{}},finish_reason:this.convertStopReason(e.stop_reason)}],usage:o}}buildUsageFromRaw(e){if(!e)return {prompt_tokens:0,completion_tokens:0,total_tokens:0};let t={prompt_tokens:e.input_tokens||0,completion_tokens:e.output_tokens||0,total_tokens:(e.input_tokens||0)+(e.output_tokens||0)};return e.cache_read_input_tokens&&(t.cache_read_input_tokens=e.cache_read_input_tokens),e.cache_creation_input_tokens&&(t.cache_creation_input_tokens=e.cache_creation_input_tokens),e.cache_creation&&(e.cache_creation.ephemeral_5m_input_tokens&&(t.cache_creation_5m_tokens=e.cache_creation.ephemeral_5m_input_tokens),e.cache_creation.ephemeral_1h_input_tokens&&(t.cache_creation_1h_tokens=e.cache_creation.ephemeral_1h_input_tokens)),t}convertStopReason(e){switch(e){case "end_turn":return "stop";case "max_tokens":return "length";case "tool_use":return "tool_calls";default:return "stop"}}handleStreamEvent(e,t,s,n,i){switch(e.type){case "message_start":return this.debugLog("message_start usage",e.message?.usage),process.env.CLI_DEBUG==="1"&&e.message&&f.debug("Anthropic",`message_start full: ${JSON.stringify(e.message,null,2)}`),{usage:e.message?.usage};case "content_block_start":return {...this.handleContentBlockStart(e,t,s,n),contentBlockStart:true};case "content_block_delta":return this.handleContentBlockDelta(e,t);case "content_block_stop":return this.validateToolArguments(t),{contentBlockStop:true};case "message_delta":this.debugLog("message_delta usage",{eventUsage:e.usage,currentUsage:i});let a=e.delta?.stop_reason||e.stop_reason;if(a&&this.debugLog("message_delta stop_reason",a),e.usage&&i){let u={...i,...e.usage};return this.debugLog("merged usage",u),{usage:u,stopReason:a}}return {usage:e.usage||i,stopReason:a};case "message_stop":return this.debugLog("Message stop received"),{messageStop:true};case "ping":return {};case "error":return {error:e.error?.message||"Stream error"};default:let l=e.type?.toLowerCase()||"";if(l==="done"||l==="stream_end"||l==="end")return this.debugLog("Alternative message stop received",{type:e.type}),{messageStop:true};let c=e.stop_reason||e.delta?.stop_reason;return c?(this.debugLog("stop_reason found in unknown event",{type:e.type,stopReason:c}),{stopReason:c}):(this.debugLog("Unknown event type",{type:e.type}),{})}}handleContentBlockStart(e,t,s,n){let i=e.content_block?.type;if(i==="text")return n?{blockType:i}:{yield:{choices:[{delta:{role:"assistant"},index:0}]},roleSent:true,blockType:i};if(i==="tool_use"){let o=e.content_block,a=this.isProxyMode?Zo[o.name]||this.fromClaudeCodeToolName(o.name):o.name,l="";return o.input&&typeof o.input=="object"&&Object.keys(o.input).length>0&&(l=JSON.stringify(o.input)),t.push({index:s,id:o.id,type:"function",function:{name:a,arguments:l}}),{yield:{choices:[{delta:{tool_calls:[{index:s,id:o.id,type:"function",function:{name:a}}]},index:0}]},incrementToolIndex:true,blockType:i}}else if(i==="thinking")return {blockType:i};return {blockType:i}}handleContentBlockDelta(e,t){if(e.delta?.type==="text_delta")return {yield:{choices:[{delta:{content:e.delta.text||""},index:0}]}};if(e.delta?.type==="input_json_delta"){let s=e.delta.partial_json||"";if(t.length>0){let n=t[t.length-1];return n.function.arguments+=s,{yield:{choices:[{delta:{tool_calls:[{index:n.index,function:{arguments:s}}]},index:0}]}}}}else {if(e.delta?.type==="thinking_delta")return {yield:{choices:[{delta:{reasoning_content:e.delta.thinking},index:0}]}};if(e.delta?.type==="signature_delta")return {}}return {}}validateToolArguments(e){if(e.length===0)return;let t=e[e.length-1];if(t.function.arguments)try{JSON.parse(t.function.arguments);}catch{let s=this.tryFixJson(t.function.arguments);s?(t.function.arguments=s,this.debugLog("Auto-fixed tool arguments",{tool:t.function.name})):this.debugLog("Invalid tool arguments JSON",{tool:t.function.name});}}tryFixJson(e){let t=e.trim();if(!t.endsWith("}")){t+="}";try{return JSON.parse(t),t}catch{}}t=e.replace(/,\s*$/,""),t.endsWith("}")||(t+="}");try{return JSON.parse(t),t}catch{}let s=0,n=0,i=false,o=false;for(let a of e){if(o){o=false;continue}if(a==="\\"){o=true;continue}if(a==='"'){i=!i;continue}i||(a==="{"?s++:a==="}"?s--:a==="["?n++:a==="]"&&n--);}for(t=e,i&&(t+='"');n>0;)t+="]",n--;for(;s>0;)t+="}",s--;try{return JSON.parse(t),t}catch{return null}}transformToolDefinition(e){let t=this.isProxyMode?eu[e.name]||this.toClaudeCodeToolName(e.name):e.name;if(this.isProxyMode){let i=this.stripSchemaPropertyDescriptions(e.parameters);return {name:t,description:e.description,input_schema:i}}if(!this.sanitizeToolsForProxy)return {name:t,description:e.description,input_schema:e.parameters};let s=this.truncateDescription(e.description||e.name),n=this.stripSchemaDescriptions(e.parameters);return {name:t,description:s,input_schema:n}}stripSchemaPropertyDescriptions(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(s=>this.stripSchemaPropertyDescriptions(s));let t={...e};if(t.properties&&typeof t.properties=="object"){let s={};for(let[n,i]of Object.entries(t.properties))if(i&&typeof i=="object"){let o={...i};delete o.description,o.properties&&(o.properties=this.stripSchemaPropertyDescriptions({properties:o.properties}).properties),o.items&&(o.items=this.stripSchemaPropertyDescriptions(o.items)),s[n]=o;}else s[n]=i;t.properties=s;}t.items&&(t.items=this.stripSchemaPropertyDescriptions(t.items));for(let s of ["oneOf","anyOf","allOf"])t[s]&&Array.isArray(t[s])&&(t[s]=t[s].map(n=>this.stripSchemaPropertyDescriptions(n)));return t}toClaudeCodeToolName(e){return e.split("_").map(t=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}fromClaudeCodeToolName(e){return e.replace(/["\s/>]+$/g,"").trim().replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}truncateDescription(e){if(!e)return "Utility tool";let t=e.replace(/\s+/g," ").trim();return t?t.length>120?`${t.slice(0,117)}...`:t:"Utility tool"}stripSchemaDescriptions(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(s=>this.stripSchemaDescriptions(s));let t={...e};if(delete t.description,t.properties&&typeof t.properties=="object"){let s={};for(let[n,i]of Object.entries(t.properties))s[n]=this.stripSchemaDescriptions(i);t.properties=s;}for(let s of ["items","oneOf","anyOf","allOf"])t[s]&&(t[s]=Array.isArray(t[s])?t[s].map(n=>this.stripSchemaDescriptions(n)):this.stripSchemaDescriptions(t[s]));return t}buildHeaders(){return this.isProxyMode?this.buildClaudeCodeHeaders():this.buildOfficialHeaders()}buildOfficialHeaders(){return {"anthropic-api-key":this.authToken,"anthropic-version":ti,"Content-Type":"application/json"}}buildClaudeCodeHeaders(){return {Accept:"application/json","X-Stainless-Retry-Count":"0","X-Stainless-Timeout":"600","X-Stainless-Lang":"js","X-Stainless-Package-Version":"0.70.0","X-Stainless-OS":"MacOS","X-Stainless-Arch":"arm64","X-Stainless-Runtime":"node","X-Stainless-Runtime-Version":process.version,"anthropic-dangerous-direct-browser-access":"true","anthropic-version":ti,"x-app":"cli","User-Agent":"claude-cli/2.0.55 (external, cli)",Authorization:`Bearer ${this.authToken}`,"Content-Type":"application/json","anthropic-beta":this.betaFeatures.join(","),"x-stainless-helper-method":"stream","accept-language":"*","sec-fetch-mode":"cors","accept-encoding":"br, gzip, deflate"}}generateSafeUserId(){if(this.isProxyMode){let s=randomBytes(32).toString("hex"),n=this.generateUUID();return `user_${s}_account__session_${n}`}let e=randomBytes(16).toString("hex"),t=randomBytes(4).toString("hex");return `user_${e}_session_${t}`}generateUUID(){let e=randomBytes(16);e[6]=e[6]&15|64,e[8]=e[8]&63|128;let t=e.toString("hex");return `${t.slice(0,8)}-${t.slice(8,12)}-${t.slice(12,16)}-${t.slice(16,20)}-${t.slice(20)}`}sanitizeUserId(e){if(this.isProxyMode){if(/^[\w.+-]+@[\w.-]+\.\w+$/.test(e)){let t=createHash("sha256").update(e).digest("hex"),s=this.generateUUID();return `user_${t}_account__session_${s}`}if(/^\+?[\d\s-]{10,}$/.test(e)){let t=createHash("sha256").update(e).digest("hex"),s=this.generateUUID();return `user_${t}_account__session_${s}`}return e}return e.length>si?createHash("sha256").update(e).digest("hex").slice(0,si):/^[\w.+-]+@[\w.-]+\.\w+$/.test(e)?createHash("sha256").update(e).digest("hex").slice(0,si):/^\+?[\d\s-]{10,}$/.test(e)?createHash("sha256").update(e).digest("hex").slice(0,si):e}async normalizeAxiosStreamError(e){let t=e?.response?.data;if(!(!t||typeof t!="object"||!(typeof t.pipe=="function")))try{let n=await this.readStreamToString(t);try{e.response.data=JSON.parse(n);}catch{e.response.data=n;}}catch{}}readStreamToString(e){return new Promise((t,s)=>{let n=[];e.on("data",i=>{n.push(typeof i=="string"?Buffer.from(i):i);}),e.on("end",()=>t(Buffer.concat(n).toString("utf-8"))),e.on("error",s);})}async*createTimeoutStream(e,t){let s=false,n=Date.now(),i=0,o=e[Symbol.asyncIterator](),a=()=>new Promise(l=>setImmediate(l));for(process.env.CLI_DEBUG==="1"&&f.debug("STREAM","\u{1F30A} Stream processing started");;){if(t?.aborted)throw this.debugLog("Stream aborted by signal"),process.env.CLI_DEBUG==="1"&&f.debug("STREAM",`\u26D4 Stream aborted after ${i} chunks`),e.destroy?.(),new Error("Request aborted");await a();let l=s?Zc:Qc,c;try{let u=t?new Promise((m,h)=>{let g=()=>{h(new Error("Request aborted"));};t.aborted?g():t.addEventListener("abort",g,{once:!0});}):null,p=[o.next(),new Promise((m,h)=>{c=setTimeout(()=>{h(new Error(s?`Stream idle timeout: no data for ${Zc/1e3}s`:`Stream first chunk timeout: no response for ${Qc/1e3}s`));},l);})];u&&p.push(u);let d=await Promise.race(p);if(c&&clearTimeout(c),d.done){process.env.CLI_DEBUG==="1"&&f.debug("STREAM",`\u2705 Stream completed successfully (${i} chunks, ${Date.now()-n}ms)`);return}s=!0,n=Date.now(),i++,process.env.CLI_DEBUG==="1"&&i%100===0&&f.debug("STREAM",`\u{1F4E6} Processed ${i} chunks`),yield d.value;}catch(u){c&&clearTimeout(c);let p=u.message?.includes("aborted")||u.message==="Request aborted";throw this.debugLog("Stream timeout or abort",{error:u.message,isAbort:p,receivedFirstChunk:s,idleTime:`${(Date.now()-n)/1e3}s`}),e.destroy?.(),p?(u.name="AbortError",u.code="ERR_CANCELED",u.category="canceled",u):(u.code="STREAM_TIMEOUT",u.isNetworkInterrupt=true,u)}}}debugLog(e,t){process.env.CLI_DEBUG==="1"&&f.debug("Anthropic",t?`${e} ${JSON.stringify(t,null,2)}`:e);}logRequest(e,t,s=false){process.env.CLI_DEBUG_PAYLOAD==="1"&&this.debugLog("Full payload",JSON.stringify(t,null,2));let n=this.isProxyMode?"/v1/messages?beta=true":"/v1/messages",i=`${this.baseUrl}${n}`,o=this.buildHeaders();ki(i,o,t);let a=this.isProxyMode?{Authorization:"Bearer ***","anthropic-version":ti,"anthropic-beta":this.betaFeatures.join(","),"Content-Type":"application/json"}:{"anthropic-api-key":"***","anthropic-version":ti,"Content-Type":"application/json"};se.llmRequest(s?"anthropic-stream":"anthropic",e,t,i,a),this.debugLog(`${s?"Stream ":""}Request`,{url:i,model:e,isProxyMode:this.isProxyMode});}};de();var ni=class extends bt{constraints;promptBuilder;provider;defaultModel;disableCaching;constructor(e){super(),this.constraints=new jn,this.promptBuilder=new Gn,this.defaultModel=e.defaultModel||"claude-3-5-sonnet-20241022",this.disableCaching=e.disableCaching||false;let{authToken:t,baseUrl:s,defaultModel:n,maxTokens:i,disableCaching:o,userId:a,...l}=e;this.provider=new js({authToken:t,baseUrl:s,defaultModel:this.defaultModel,maxTokens:i,disableCaching:this.disableCaching,userId:a,...l});}prepareRequest(e,t){let s=t.model||this.defaultModel,n=super.prepareRequest(e,{...t,model:s}),i={...n.options};if(i.maxInputTokens!==void 0&&(i.max_tokens=i.maxInputTokens,delete i.maxInputTokens),!i.max_tokens){let o=this.constraints.getTokenLimits(s);i.max_tokens=Math.min(4096,o.maxOutput);}if(!this.disableCaching&&this.constraints.supportsPromptCaching(s)){let o=n.messages[0]?.content?.length||0,a=this.promptBuilder.getCachingRecommendation(o);a.shouldUseCache&&(i.enableCaching=true,i.cacheTtl=a.cacheTTL);}return {...n,options:i}}async chat(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}return s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("AnthropicAdapter","Warnings",s.validation.warnings),this.provider.chat(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,maxInputTokens:s.options.max_tokens,enableCaching:s.options.enableCaching,cacheTtl:s.options.cacheTtl,signal:t.signal})}async*chatStreamed(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("AnthropicAdapter","Warnings",s.validation.warnings),yield*this.provider.chatStreamed(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,maxInputTokens:s.options.max_tokens,enableCaching:s.options.enableCaching,cacheTtl:s.options.cacheTtl,signal:t.signal});}getProvider(){return this.provider}getModelCapabilities(e){let t=e||this.defaultModel;return {supportsVision:this.constraints.supportsVision(t),supportsTools:this.constraints.supportsTools(t),supportsThinking:this.constraints.supportsThinking?.(t)||false,supportsPromptCaching:this.constraints.supportsPromptCaching(t),tokenLimits:this.constraints.getTokenLimits(t)}}getCachingRecommendation(e){return this.promptBuilder.getCachingRecommendation(e)}};var ri=class extends is{getConstraints(){let e=super.getConstraints(),t={...e.validators??{}};t.temperature=je(0,1);let s=t.tool_choice;t.tool_choice=i=>i==="required"?"tool_choice=required is not supported by Kimi API":typeof s=="function"?s(i):true;let n=t.n;return t.n=(i,o)=>{let a=typeof n=="function"?n(i,o):true;if(a!==true)return a;let l=o?.temperature??1,c=typeof l=="number"?l:Number(l),u=typeof i=="number"?i:Number(i);return !Number.isNaN(c)&&c<=.001&&u>1?"temperature <= 0.001 requires n=1 for Kimi API":true},{...e,validators:t}}};de();var ii=class extends bt{constraints;promptBuilder;provider;defaultModel;constructor(e){super(),this.constraints=new ri,this.promptBuilder=new as,this.defaultModel=e.defaultModel||"kimi-k2-0905-preview";let{apiKey:t,baseUrl:s,defaultModel:n,maxTokens:i,maxInputTokens:o,...a}=e;this.provider=new It({apiKey:t,baseUrl:s,defaultModel:this.defaultModel,maxTokens:i,maxInputTokens:o,...a,structuredOutputMode:"json_object"});}prepareRequest(e,t){let s=t.model||this.defaultModel;return super.prepareRequest(e,{...t,model:s})}async chat(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}return s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("KimiAdapter","Warnings",s.validation.warnings),this.provider.chat(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens})}async*chatStreamed(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("KimiAdapter","Warnings",s.validation.warnings),yield*this.provider.chatStreamed(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens,signal:t.signal});}getProvider(){return this.provider}};var oi=class extends Gt{getConstraints(){return {maxOutputTokens:{},maxInputTokens:{},supportedParams:new Set(["model","messages","stream","max_tokens","temperature","topP","topK","stopSequences","tools","structuredOutput","signal"]),validators:{temperature:je(0,2),topP:je(0,1),topK:je(1,128),max_tokens:e=>{let t=Number(e);return Number.isNaN(t)?"Must be a number":t<1?"Must be at least 1":true},stopSequences:e=>Array.isArray(e)?e.some(s=>typeof s!="string"||s.length===0)?"All stop sequences must be non-empty strings":true:"Must be an array of strings",stream:Jc("boolean")},defaults:{temperature:1}}}};var Hn=class extends Bt{buildSystemPrompt(e){let{workDir:t,language:s="zh",modelName:n,customInstructions:i}=e,o=[];return o.push({content:this.getCoreInstructions(s,n),order:0}),o.push(this.getWorkingDirectorySection(t,s)),o.push({content:this.getCapabilitiesSection(s,n),order:20}),o.push({title:s==="zh"?"\u53C2\u6570\u7EA6\u675F":"Parameter Constraints",content:this.getConstraintInstructions(s),order:30}),o.push({title:s==="zh"?"\u5DE5\u5177\u8C03\u7528":"Tool Usage",content:this.getToolUseInstructions(s),order:40}),o.push({content:this.getGeneralRules(s),order:50}),i&&i.trim()&&o.push({title:s==="zh"?"\u81EA\u5B9A\u4E49\u6307\u4EE4":"Custom Instructions",content:i.trim(),order:60}),os(this.combinePromptSections(o))}getConstraintInstructions(e){return e==="zh"?`- temperature: 0.0 - 2.0
|
|
1697
|
+
`):null,anthropicMessages:l}}addMessageCacheControl(e){let t=false;for(let s=e.length-1;s>=0;s--){let n=e[s];if(!(n.role!=="user"||!Array.isArray(n.content))){for(let i=n.content.length-1;i>=0;i--){let o=n.content[i];if(!t&&o.type==="tool_result"){o.cache_control={type:"ephemeral"},t=true,this.debugLog("Added cache_control to tool_result",{tool_use_id:o.tool_use_id});break}}if(t)break}}t||this.addTextBlockCacheControl(e);}addTextBlockCacheControl(e){for(let t=e.length-1;t>=0;t--){let s=e[t];if(s.role==="user"&&Array.isArray(s.content)){for(let n=s.content.length-1;n>=0;n--)if(s.content[n].type==="text"){s.content[n].cache_control={type:"ephemeral"},this.debugLog("Added cache_control to user text block");return}}}}validateToolResultPairs(e){let t=new Set,s=new Set;for(let o of e)if(Array.isArray(o.content))for(let a of o.content)a.type==="tool_use"&&a.id&&t.add(a.id),a.type==="tool_result"&&a.tool_use_id&&s.add(a.tool_use_id);let n=new Set;for(let o of t)s.has(o)&&n.add(o);this.debugLog("Tool pairing analysis",{toolUseCount:t.size,toolResultCount:s.size,pairedCount:n.size,orphanToolUseIds:Array.from(t).filter(o=>!n.has(o)),orphanToolResultIds:Array.from(s).filter(o=>!n.has(o))});let i=[];for(let o of e){if(!Array.isArray(o.content)){i.push(o);continue}let a=o.content.filter(l=>{if(l.type==="tool_use"){let c=n.has(l.id);return c||this.debugLog("Removing orphan tool_use",{id:l.id}),c}if(l.type==="tool_result"){let c=n.has(l.tool_use_id);return c||this.debugLog("Removing orphan tool_result",{tool_use_id:l.tool_use_id}),c}return true});a.length>0?i.push({...o,content:a}):this.debugLog("Skipping empty message after tool pairing filter",{role:o.role});}return i}mergeConsecutiveUserMessages(e){if(e.length===0)return [];let t=[];for(let s of e){let n=t[t.length-1];if(n&&n.role==="user"&&s.role==="user"){let i=Array.isArray(n.content)?n.content:[{type:"text",text:n.content}],o=Array.isArray(s.content)?s.content:[{type:"text",text:s.content}];n.content=[...i,...o];}else t.push(s);}return t}convertSingleMessage(e){if(e.role==="tool"){let s=se(e.content),n=mf(s);return s.length!==n.length&&this.debugLog("Tool output truncated",{tool_call_id:e.tool_call_id,original:s.length,truncated:n.length}),{role:"user",content:[{type:"tool_result",tool_use_id:e.tool_call_id,content:n}]}}if(e.role==="assistant"){let s=[],n=false;if(e.thinking_blocks&&e.thinking_blocks.length>0){n=true;for(let o of e.thinking_blocks)if(o.type==="thinking"){let a={type:"thinking",thinking:o.thinking};o.signature!==void 0&&(a.signature=o.signature),s.push(a);}else if(o.type==="redacted_thinking"){let a={type:"redacted_thinking"};o.data!==void 0&&(a.data=o.data),s.push(a);}}let i=se(e.content);if(i){let o=i.trimEnd();s.push({type:"text",text:o||"."});}else n&&(s.push({type:"text",text:"."}),this.debugLog("Added placeholder text after thinking (no text content)"));if(e.tool_calls)for(let o of e.tool_calls){let a=(o.function.arguments||"").trim(),l={};if(a.length>0)try{l=JSON.parse(a);}catch{this.debugLog("Failed to parse tool arguments",{tool:o.function.name});}let c=this.isProxyMode?ou[o.function.name]||this.toClaudeCodeToolName(o.function.name):o.function.name;s.push({type:"tool_use",id:o.id,name:c,input:l});}if(s.length>0){let o=s[s.length-1];this.debugLog("Assistant message final check",{contentLength:s.length,lastBlockType:o.type,hasThinkingBlocks:n,blockTypes:s.map(a=>a.type),lastBlockTextPreview:o.type==="text"?(o.text||"").substring(0,50):void 0}),o.type==="thinking"||o.type==="redacted_thinking"?(s.push({type:"text",text:"."}),this.debugLog("Fixed: Added text block after thinking")):o.type==="text"&&(!o.text||!o.text.trim())&&s.some(l=>l.type==="thinking"||l.type==="redacted_thinking")&&(o.text=".",this.debugLog("Fixed: Ensured text block has content after thinking"));}return s.length>0?{role:"assistant",content:s}:null}if(Array.isArray(e.content)){let s=e.content.filter(o=>o.type==="text");if(!e.content.some(o=>o.type!=="text")&&s.length===1){let o=s[0].text;return o.trim()?{role:"user",content:o}:null}let i=this.convertMultimodalContent(e.content);return i.length>0?{role:"user",content:i}:null}let t=se(e.content);return t.trim()?{role:"user",content:t}:null}convertMultimodalContent(e){let t=[];for(let s of e)if(s.type==="text")t.push({type:"text",text:s.text});else if(s.type==="image_url"){let n=this.convertImageUrl(s.image_url.url);n&&t.push(n);}return t}convertImageUrl(e){if(e.startsWith("data:")){let t=e.match(/^data:([^;]+);base64,(.+)$/);if(t)return {type:"image",source:{type:"base64",media_type:t[1],data:t[2]}}}else return {type:"image",source:{type:"url",url:e}};return null}normalizeMessages(e){let t=e.filter(s=>{let n=s.role==="assistant"&&!!(s.tool_calls&&s.tool_calls.length>0),i=s.role==="assistant"&&!!(s.thinking_blocks&&s.thinking_blocks.length>0);return n||i?true:s.content?typeof s.content=="string"?s.content.trim().length>0:Array.isArray(s.content)?s.content.length>0:true:false});return t.length===0?[]:(this.validateMessageAlternation(t),t)}validateMessageAlternation(e){let t=e.filter(n=>n.role!=="system"),s=false;for(let n=1;n<t.length;n++)t[n].role===t[n-1].role&&(s=true,this.debugLog("Message alternation warning",{index:n,prevRole:t[n-1].role,currentRole:t[n].role}));!s&&t.length>1&&this.debugLog("Message alternation OK",{messageCount:t.length,roles:t.map(n=>n.role)});}convertResponse(e){this.debugLog("Raw response",e);let t=e.content||[],s="",n=[],i="";for(let a of t)if(a.type==="text")s+=a.text;else if(a.type==="tool_use"){let l=this.isProxyMode?ta[a.name]||this.fromClaudeCodeToolName(a.name):a.name;n.push({id:a.id,type:"function",function:{name:l,arguments:JSON.stringify(a.input)}});}else a.type==="thinking"&&(i=a.thinking||"");let o=this.buildUsageFromRaw(e.usage);return {id:e.id,choices:[{message:{role:"assistant",content:s||"",tool_calls:n.length>0?n:void 0,...i?{reasoning_content:i}:{}},finish_reason:this.convertStopReason(e.stop_reason)}],usage:o}}buildUsageFromRaw(e){if(!e)return {prompt_tokens:0,completion_tokens:0,total_tokens:0};let t={prompt_tokens:e.input_tokens||0,completion_tokens:e.output_tokens||0,total_tokens:(e.input_tokens||0)+(e.output_tokens||0)};return e.cache_read_input_tokens&&(t.cache_read_input_tokens=e.cache_read_input_tokens),e.cache_creation_input_tokens&&(t.cache_creation_input_tokens=e.cache_creation_input_tokens),e.cache_creation&&(e.cache_creation.ephemeral_5m_input_tokens&&(t.cache_creation_5m_tokens=e.cache_creation.ephemeral_5m_input_tokens),e.cache_creation.ephemeral_1h_input_tokens&&(t.cache_creation_1h_tokens=e.cache_creation.ephemeral_1h_input_tokens)),t}convertStopReason(e){switch(e){case "end_turn":return "stop";case "max_tokens":return "length";case "tool_use":return "tool_calls";default:return "stop"}}handleStreamEvent(e,t,s,n,i){switch(e.type){case "message_start":return this.debugLog("message_start usage",e.message?.usage),process.env.CLI_DEBUG==="1"&&e.message&&f.debug("Anthropic",`message_start full: ${JSON.stringify(e.message,null,2)}`),{usage:e.message?.usage};case "content_block_start":return {...this.handleContentBlockStart(e,t,s,n),contentBlockStart:true};case "content_block_delta":return this.handleContentBlockDelta(e,t);case "content_block_stop":return this.validateToolArguments(t),{contentBlockStop:true};case "message_delta":this.debugLog("message_delta usage",{eventUsage:e.usage,currentUsage:i});let a=e.delta?.stop_reason||e.stop_reason;if(a&&this.debugLog("message_delta stop_reason",a),e.usage&&i){let u={...i,...e.usage};return this.debugLog("merged usage",u),{usage:u,stopReason:a}}return {usage:e.usage||i,stopReason:a};case "message_stop":return this.debugLog("Message stop received"),{messageStop:true};case "ping":return {};case "error":return {error:e.error?.message||"Stream error"};default:let l=e.type?.toLowerCase()||"";if(l==="done"||l==="stream_end"||l==="end")return this.debugLog("Alternative message stop received",{type:e.type}),{messageStop:true};let c=e.stop_reason||e.delta?.stop_reason;return c?(this.debugLog("stop_reason found in unknown event",{type:e.type,stopReason:c}),{stopReason:c}):(this.debugLog("Unknown event type",{type:e.type}),{})}}handleContentBlockStart(e,t,s,n){let i=e.content_block?.type;if(i==="text")return n?{blockType:i}:{yield:{choices:[{delta:{role:"assistant"},index:0}]},roleSent:true,blockType:i};if(i==="tool_use"){let o=e.content_block,a=this.isProxyMode?ta[o.name]||this.fromClaudeCodeToolName(o.name):o.name,l="";return o.input&&typeof o.input=="object"&&Object.keys(o.input).length>0&&(l=JSON.stringify(o.input)),t.push({index:s,id:o.id,type:"function",function:{name:a,arguments:l}}),{yield:{choices:[{delta:{tool_calls:[{index:s,id:o.id,type:"function",function:{name:a}}]},index:0}]},incrementToolIndex:true,blockType:i}}else if(i==="thinking")return {blockType:i};return {blockType:i}}handleContentBlockDelta(e,t){if(e.delta?.type==="text_delta")return {yield:{choices:[{delta:{content:e.delta.text||""},index:0}]}};if(e.delta?.type==="input_json_delta"){let s=e.delta.partial_json||"";if(t.length>0){let n=t[t.length-1];return n.function.arguments+=s,{yield:{choices:[{delta:{tool_calls:[{index:n.index,function:{arguments:s}}]},index:0}]}}}}else {if(e.delta?.type==="thinking_delta")return {yield:{choices:[{delta:{reasoning_content:e.delta.thinking},index:0}]}};if(e.delta?.type==="signature_delta")return {}}return {}}validateToolArguments(e){if(e.length===0)return;let t=e[e.length-1];if(t.function.arguments)try{JSON.parse(t.function.arguments);}catch{let s=this.tryFixJson(t.function.arguments);s?(t.function.arguments=s,this.debugLog("Auto-fixed tool arguments",{tool:t.function.name})):this.debugLog("Invalid tool arguments JSON",{tool:t.function.name});}}tryFixJson(e){let t=e.trim();if(!t.endsWith("}")){t+="}";try{return JSON.parse(t),t}catch{}}t=e.replace(/,\s*$/,""),t.endsWith("}")||(t+="}");try{return JSON.parse(t),t}catch{}let s=0,n=0,i=false,o=false;for(let a of e){if(o){o=false;continue}if(a==="\\"){o=true;continue}if(a==='"'){i=!i;continue}i||(a==="{"?s++:a==="}"?s--:a==="["?n++:a==="]"&&n--);}for(t=e,i&&(t+='"');n>0;)t+="]",n--;for(;s>0;)t+="}",s--;try{return JSON.parse(t),t}catch{return null}}transformToolDefinition(e){let t=this.isProxyMode?ou[e.name]||this.toClaudeCodeToolName(e.name):e.name;if(this.isProxyMode){let i=this.stripSchemaPropertyDescriptions(e.parameters);return {name:t,description:e.description,input_schema:i}}if(!this.sanitizeToolsForProxy)return {name:t,description:e.description,input_schema:e.parameters};let s=this.truncateDescription(e.description||e.name),n=this.stripSchemaDescriptions(e.parameters);return {name:t,description:s,input_schema:n}}stripSchemaPropertyDescriptions(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(s=>this.stripSchemaPropertyDescriptions(s));let t={...e};if(t.properties&&typeof t.properties=="object"){let s={};for(let[n,i]of Object.entries(t.properties))if(i&&typeof i=="object"){let o={...i};delete o.description,o.properties&&(o.properties=this.stripSchemaPropertyDescriptions({properties:o.properties}).properties),o.items&&(o.items=this.stripSchemaPropertyDescriptions(o.items)),s[n]=o;}else s[n]=i;t.properties=s;}t.items&&(t.items=this.stripSchemaPropertyDescriptions(t.items));for(let s of ["oneOf","anyOf","allOf"])t[s]&&Array.isArray(t[s])&&(t[s]=t[s].map(n=>this.stripSchemaPropertyDescriptions(n)));return t}toClaudeCodeToolName(e){return e.split("_").map(t=>t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}fromClaudeCodeToolName(e){return e.replace(/["\s/>]+$/g,"").trim().replace(/([A-Z])/g,"_$1").toLowerCase().replace(/^_/,"")}truncateDescription(e){if(!e)return "Utility tool";let t=e.replace(/\s+/g," ").trim();return t?t.length>120?`${t.slice(0,117)}...`:t:"Utility tool"}stripSchemaDescriptions(e){if(!e||typeof e!="object")return e;if(Array.isArray(e))return e.map(s=>this.stripSchemaDescriptions(s));let t={...e};if(delete t.description,t.properties&&typeof t.properties=="object"){let s={};for(let[n,i]of Object.entries(t.properties))s[n]=this.stripSchemaDescriptions(i);t.properties=s;}for(let s of ["items","oneOf","anyOf","allOf"])t[s]&&(t[s]=Array.isArray(t[s])?t[s].map(n=>this.stripSchemaDescriptions(n)):this.stripSchemaDescriptions(t[s]));return t}buildHeaders(){return this.isProxyMode?this.buildClaudeCodeHeaders():this.buildOfficialHeaders()}buildOfficialHeaders(){return {"anthropic-api-key":this.authToken,"anthropic-version":ri,"Content-Type":"application/json"}}buildClaudeCodeHeaders(){return {Accept:"application/json","X-Stainless-Retry-Count":"0","X-Stainless-Timeout":"600","X-Stainless-Lang":"js","X-Stainless-Package-Version":"0.70.0","X-Stainless-OS":"MacOS","X-Stainless-Arch":"arm64","X-Stainless-Runtime":"node","X-Stainless-Runtime-Version":process.version,"anthropic-dangerous-direct-browser-access":"true","anthropic-version":ri,"x-app":"cli","User-Agent":"claude-cli/2.0.55 (external, cli)",Authorization:`Bearer ${this.authToken}`,"Content-Type":"application/json","anthropic-beta":this.betaFeatures.join(","),"x-stainless-helper-method":"stream","accept-language":"*","sec-fetch-mode":"cors","accept-encoding":"br, gzip, deflate"}}generateSafeUserId(){if(this.isProxyMode){let s=randomBytes(32).toString("hex"),n=this.generateUUID();return `user_${s}_account__session_${n}`}let e=randomBytes(16).toString("hex"),t=randomBytes(4).toString("hex");return `user_${e}_session_${t}`}generateUUID(){let e=randomBytes(16);e[6]=e[6]&15|64,e[8]=e[8]&63|128;let t=e.toString("hex");return `${t.slice(0,8)}-${t.slice(8,12)}-${t.slice(12,16)}-${t.slice(16,20)}-${t.slice(20)}`}sanitizeUserId(e){if(this.isProxyMode){if(/^[\w.+-]+@[\w.-]+\.\w+$/.test(e)){let t=createHash("sha256").update(e).digest("hex"),s=this.generateUUID();return `user_${t}_account__session_${s}`}if(/^\+?[\d\s-]{10,}$/.test(e)){let t=createHash("sha256").update(e).digest("hex"),s=this.generateUUID();return `user_${t}_account__session_${s}`}return e}return e.length>ii?createHash("sha256").update(e).digest("hex").slice(0,ii):/^[\w.+-]+@[\w.-]+\.\w+$/.test(e)?createHash("sha256").update(e).digest("hex").slice(0,ii):/^\+?[\d\s-]{10,}$/.test(e)?createHash("sha256").update(e).digest("hex").slice(0,ii):e}async normalizeAxiosStreamError(e){let t=e?.response?.data;if(!(!t||typeof t!="object"||!(typeof t.pipe=="function")))try{let n=await this.readStreamToString(t);try{e.response.data=JSON.parse(n);}catch{e.response.data=n;}}catch{}}readStreamToString(e){return new Promise((t,s)=>{let n=[];e.on("data",i=>{n.push(typeof i=="string"?Buffer.from(i):i);}),e.on("end",()=>t(Buffer.concat(n).toString("utf-8"))),e.on("error",s);})}async*createTimeoutStream(e,t){let s=false,n=Date.now(),i=0,o=e[Symbol.asyncIterator](),a=()=>new Promise(l=>setImmediate(l));for(process.env.CLI_DEBUG==="1"&&f.debug("STREAM","\u{1F30A} Stream processing started");;){if(t?.aborted)throw this.debugLog("Stream aborted by signal"),process.env.CLI_DEBUG==="1"&&f.debug("STREAM",`\u26D4 Stream aborted after ${i} chunks`),e.destroy?.(),new Error("Request aborted");await a();let l=s?ru:iu,c;try{let u=t?new Promise((m,h)=>{let g=()=>{h(new Error("Request aborted"));};t.aborted?g():t.addEventListener("abort",g,{once:!0});}):null,p=[o.next(),new Promise((m,h)=>{c=setTimeout(()=>{h(new Error(s?`Stream idle timeout: no data for ${ru/1e3}s`:`Stream first chunk timeout: no response for ${iu/1e3}s`));},l);})];u&&p.push(u);let d=await Promise.race(p);if(c&&clearTimeout(c),d.done){process.env.CLI_DEBUG==="1"&&f.debug("STREAM",`\u2705 Stream completed successfully (${i} chunks, ${Date.now()-n}ms)`);return}s=!0,n=Date.now(),i++,process.env.CLI_DEBUG==="1"&&i%100===0&&f.debug("STREAM",`\u{1F4E6} Processed ${i} chunks`),yield d.value;}catch(u){c&&clearTimeout(c);let p=u.message?.includes("aborted")||u.message==="Request aborted";throw this.debugLog("Stream timeout or abort",{error:u.message,isAbort:p,receivedFirstChunk:s,idleTime:`${(Date.now()-n)/1e3}s`}),e.destroy?.(),p?(u.name="AbortError",u.code="ERR_CANCELED",u.category="canceled",u):(u.code="STREAM_TIMEOUT",u.isNetworkInterrupt=true,u)}}}debugLog(e,t){process.env.CLI_DEBUG==="1"&&f.debug("Anthropic",t?`${e} ${JSON.stringify(t,null,2)}`:e);}logRequest(e,t,s=false){process.env.CLI_DEBUG_PAYLOAD==="1"&&this.debugLog("Full payload",JSON.stringify(t,null,2));let n=this.isProxyMode?"/v1/messages?beta=true":"/v1/messages",i=`${this.baseUrl}${n}`,o=this.buildHeaders();Ci(i,o,t);let a=this.isProxyMode?{Authorization:"Bearer ***","anthropic-version":ri,"anthropic-beta":this.betaFeatures.join(","),"Content-Type":"application/json"}:{"anthropic-api-key":"***","anthropic-version":ri,"Content-Type":"application/json"};oe.llmRequest(s?"anthropic-stream":"anthropic",e,t,i,a),this.debugLog(`${s?"Stream ":""}Request`,{url:i,model:e,isProxyMode:this.isProxyMode});}};me();var oi=class extends bt{constraints;promptBuilder;provider;defaultModel;disableCaching;constructor(e){super(),this.constraints=new Gn,this.promptBuilder=new Bn,this.defaultModel=e.defaultModel||"claude-3-5-sonnet-20241022",this.disableCaching=e.disableCaching||false;let{authToken:t,baseUrl:s,defaultModel:n,maxTokens:i,disableCaching:o,userId:a,...l}=e;this.provider=new Gs({authToken:t,baseUrl:s,defaultModel:this.defaultModel,maxTokens:i,disableCaching:this.disableCaching,userId:a,...l});}prepareRequest(e,t){let s=t.model||this.defaultModel,n=super.prepareRequest(e,{...t,model:s}),i={...n.options};if(i.maxInputTokens!==void 0&&(i.max_tokens=i.maxInputTokens,delete i.maxInputTokens),!i.max_tokens){let o=this.constraints.getTokenLimits(s);i.max_tokens=Math.min(4096,o.maxOutput);}if(!this.disableCaching&&this.constraints.supportsPromptCaching(s)){let o=n.messages[0]?.content?.length||0,a=this.promptBuilder.getCachingRecommendation(o);a.shouldUseCache&&(i.enableCaching=true,i.cacheTtl=a.cacheTTL);}return {...n,options:i}}async chat(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}return s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("AnthropicAdapter","Warnings",s.validation.warnings),this.provider.chat(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,maxInputTokens:s.options.max_tokens,enableCaching:s.options.enableCaching,cacheTtl:s.options.cacheTtl,signal:t.signal})}async*chatStreamed(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("AnthropicAdapter","Warnings",s.validation.warnings),yield*this.provider.chatStreamed(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,maxInputTokens:s.options.max_tokens,enableCaching:s.options.enableCaching,cacheTtl:s.options.cacheTtl,signal:t.signal});}getProvider(){return this.provider}getModelCapabilities(e){let t=e||this.defaultModel;return {supportsVision:this.constraints.supportsVision(t),supportsTools:this.constraints.supportsTools(t),supportsThinking:this.constraints.supportsThinking?.(t)||false,supportsPromptCaching:this.constraints.supportsPromptCaching(t),tokenLimits:this.constraints.getTokenLimits(t)}}getCachingRecommendation(e){return this.promptBuilder.getCachingRecommendation(e)}};var ai=class extends is{getConstraints(){let e=super.getConstraints(),t={...e.validators??{}};t.temperature=je(0,1);let s=t.tool_choice;t.tool_choice=i=>i==="required"?"tool_choice=required is not supported by Kimi API":typeof s=="function"?s(i):true;let n=t.n;return t.n=(i,o)=>{let a=typeof n=="function"?n(i,o):true;if(a!==true)return a;let l=o?.temperature??1,c=typeof l=="number"?l:Number(l),u=typeof i=="number"?i:Number(i);return !Number.isNaN(c)&&c<=.001&&u>1?"temperature <= 0.001 requires n=1 for Kimi API":true},{...e,validators:t}}};me();var li=class extends bt{constraints;promptBuilder;provider;defaultModel;constructor(e){super(),this.constraints=new ai,this.promptBuilder=new as,this.defaultModel=e.defaultModel||"kimi-k2-0905-preview";let{apiKey:t,baseUrl:s,defaultModel:n,maxTokens:i,maxInputTokens:o,...a}=e;this.provider=new It({apiKey:t,baseUrl:s,defaultModel:this.defaultModel,maxTokens:i,maxInputTokens:o,...a,structuredOutputMode:"json_object"});}prepareRequest(e,t){let s=t.model||this.defaultModel;return super.prepareRequest(e,{...t,model:s})}async chat(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}return s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("KimiAdapter","Warnings",s.validation.warnings),this.provider.chat(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens})}async*chatStreamed(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("KimiAdapter","Warnings",s.validation.warnings),yield*this.provider.chatStreamed(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens,signal:t.signal});}getProvider(){return this.provider}};var ci=class extends Gt{getConstraints(){return {maxOutputTokens:{},maxInputTokens:{},supportedParams:new Set(["model","messages","stream","max_tokens","temperature","topP","topK","stopSequences","tools","structuredOutput","signal"]),validators:{temperature:je(0,2),topP:je(0,1),topK:je(1,128),max_tokens:e=>{let t=Number(e);return Number.isNaN(t)?"Must be a number":t<1?"Must be at least 1":true},stopSequences:e=>Array.isArray(e)?e.some(s=>typeof s!="string"||s.length===0)?"All stop sequences must be non-empty strings":true:"Must be an array of strings",stream:Qc("boolean")},defaults:{temperature:1}}}};var zn=class extends Bt{buildSystemPrompt(e){let{workDir:t,language:s="zh",modelName:n,customInstructions:i}=e,o=[];return o.push({content:this.getCoreInstructions(s,n),order:0}),o.push(this.getWorkingDirectorySection(t,s)),o.push({content:this.getCapabilitiesSection(s,n),order:20}),o.push({title:s==="zh"?"\u53C2\u6570\u7EA6\u675F":"Parameter Constraints",content:this.getConstraintInstructions(s),order:30}),o.push({title:s==="zh"?"\u5DE5\u5177\u8C03\u7528":"Tool Usage",content:this.getToolUseInstructions(s),order:40}),o.push({content:this.getGeneralRules(s),order:50}),i&&i.trim()&&o.push({title:s==="zh"?"\u81EA\u5B9A\u4E49\u6307\u4EE4":"Custom Instructions",content:i.trim(),order:60}),os(this.combinePromptSections(o))}getConstraintInstructions(e){return e==="zh"?`- temperature: 0.0 - 2.0
|
|
1698
1698
|
- topP: 0.0 - 1.0
|
|
1699
1699
|
- topK: >= 1
|
|
1700
1700
|
- maxOutputTokens: \u63A7\u5236\u8F93\u51FA\u957F\u5EA6
|
|
@@ -1738,24 +1738,24 @@ Your primary responsibilities:
|
|
|
1738
1738
|
1. **Accuracy first**: ensure correctness
|
|
1739
1739
|
2. **Be concise**: avoid redundancy
|
|
1740
1740
|
3. **Safety first**: avoid destructive actions
|
|
1741
|
-
4. **Professional tone**: objective and technical`}getModelDisplayName(e){return e?e.includes("gemini-3")?"Gemini 3":e.includes("gemini-2.5")?"Gemini 2.5":e.includes("gemini-2.0")?"Gemini 2.0":e.includes("gemini-1.5")?"Gemini 1.5":e.includes("gemini-1.0")?"Gemini 1.0":e:"Gemini"}supportsVision(e){return e?e.includes("vision")?true:this.isModelType(e,"gemini-1.5*","gemini-2*","gemini-3*"):false}};de();function cf(r){let e="/v1beta/models";if(!r)return e;let t=r.trim();if(!t)return e;let s=t.startsWith("/")?t:`/${t}`;return s=s.replace(/\/+$/,""),s.includes("/models")||(s=`${s}/models`),s}function uf(r){try{let e=JSON.parse(r);return e&&typeof e=="object"?e:{value:e}}catch{return {}}}function su(r){if(r==null)return "{}";if(typeof r=="string"){let e=r.trim();return e?e.startsWith("{")||e.startsWith("[")?e:JSON.stringify({value:e}):"{}"}try{return JSON.stringify(r)}catch{return "{}"}}var pf="skip_thought_signature_validator",nu=8192;function ru(r){return r.includes("gemini-3")||r.includes("preview")}function df(r){let e=-1;for(let s=r.length-1;s>=0;s--){let n=r[s];if(n.role==="user"&&n.parts?.some(i=>i.text)){e=s;break}}if(e===-1)return r;let t=r.slice();for(let s=e;s<t.length;s++){let n=t[s];if(n.role==="model"&&n.parts){let i=n.parts.slice();for(let o=0;o<i.length;o++){let a=i[o];if(a.functionCall){a.thoughtSignature||(i[o]={...a,thoughtSignature:pf},t[s]={...n,parts:i});break}}}}return t}var Gs=class{client;apiKey;baseURL;pathPrefix;userId;retryConfig;authMode;thinkingSettings=null;constructor(e,t="https://generativelanguage.googleapis.com",s,n){this.apiKey=e,this.baseURL=t.replace(/\/$/,""),this.pathPrefix=cf(n?.pathPrefix),this.userId=randomUUID(),this.authMode=this.resolveAuthMode(n?.authMode),this.retryConfig=Nt(Os("gemini"),s);let i={"Content-Type":"application/json","User-Agent":`GeminiCLI/v22.16.0 (${qs__default.platform()}; ${qs__default.arch()})`,"x-goog-api-client":"google-genai-sdk/1.30.0 gl-node/v22.16.0","x-gemini-api-privileged-user-id":this.userId};this.authMode==="header"?i["x-goog-api-key"]=this.apiKey:this.authMode==="bearer"&&(i.Authorization=`Bearer ${this.apiKey}`),this.client=Kg.create({baseURL:this.baseURL,timeout:6e5,headers:i});}resolveAuthMode(e){if(e&&e!=="auto")return e;let t=this.baseURL.includes("generativelanguage.googleapis.com"),s=this.apiKey.startsWith("AIza");return t||s?"query":"bearer"}setThinking(e){this.thinkingSettings=e,process.env.CLI_DEBUG==="1"&&pe("GEMINI","Thinking config updated",{config:e});}getThinking(){return this.thinkingSettings}convertMessages(e){let t=this.filterIncompleteToolCalls(e),s=[],n=[],i=[],o=()=>{i.length>0&&(n.push({parts:i,role:"user"}),i=[]);};for(let l of t)if(l.role==="system"){let c=te(l.content);c&&s.push(c);}else if(l.role==="user"){o();let c=[];if(typeof l.content=="string")c.push({text:l.content});else if(Array.isArray(l.content)){for(let u of l.content)if(u.type==="text")c.push({text:u.text});else if(u.type==="image_url"){let p=u.image_url.url;if(p.startsWith("data:")){let d=p.match(/^data:([^;]+);base64,(.+)$/);d&&c.push({inlineData:{mimeType:d[1],data:d[2]}});}}}n.push({parts:c,role:"user"});}else if(l.role==="assistant"){o();let c=[],u=te(l.content);if(u&&c.push({text:u}),l.tool_calls)for(let p of l.tool_calls){let d={functionCall:{name:p.function.name,args:uf(p.function.arguments),id:p.id}};p.thoughtSignature&&(d.thoughtSignature=p.thoughtSignature),c.push(d);}n.push({parts:c,role:"model"});}else if(l.role==="tool"){let c=te(l.content)||"",p={name:l.name||"unknown",response:{output:c}};l.tool_call_id&&(p.id=l.tool_call_id),i.push({functionResponse:p});}o();let a={contents:n};return s.length>0&&(a.systemInstruction={parts:s.map(l=>({text:l})),role:"user"}),a}filterIncompleteToolCalls(e){let t=[],s=0;for(;s<e.length;){let n=e[s];if(n.role==="system"){t.push(n),s++;continue}if(n.role==="assistant"&&n.tool_calls&&n.tool_calls.length>0){let i=n.tool_calls,o=i.length,a=i.every(h=>!!h.id),l=[],c=[],u=s+1;for(;u<e.length;){let h=e[u];if(h.role==="system"){l.push(h),u++;continue}if(h.role!=="tool")break;l.push(h),c.push(h),u++;}let p=c.length,d=c.every(h=>!!h.tool_call_id),m=p===o;if(m&&a&&d){let h=new Set(c.map(g=>g.tool_call_id).filter(g=>!!g));for(let g of i)if(!h.has(g.id)){m=false;break}}if(m){t.push(n);for(let h of l)t.push(h);}else {process.env.CLI_DEBUG==="1"&&f.debug("GEMINI","Filtering incomplete tool call turn",{toolCalls:i.map(h=>({id:h.id,name:h.function.name})),responseCount:p});for(let h of l)h.role==="system"&&t.push(h);}s=u;continue}if(n.role==="tool"){process.env.CLI_DEBUG==="1"&&f.debug("GEMINI","Dropping orphan tool message",{toolCallId:n.tool_call_id,toolName:n.name}),s++;continue}t.push(n),s++;}return t}convertTools(e){return !e||e.length===0?[]:[{functionDeclarations:e.map(s=>({name:s.name,description:s.description,parameters:{type:s.parameters.type,properties:s.parameters.properties,required:s.parameters.required,additionalProperties:s.parameters.additionalProperties},parametersJsonSchema:{type:s.parameters.type,properties:s.parameters.properties,required:s.parameters.required,additionalProperties:s.parameters.additionalProperties}}))}]}buildGenerationConfig(e){let t={temperature:e.temperature??1,topP:e.topP??.95,topK:e.topK??64};return e.maxOutputTokens!==void 0&&(t.maxOutputTokens=e.maxOutputTokens),e.stopSequences&&e.stopSequences.length>0&&(t.stopSequences=e.stopSequences),e.structuredOutput&&(t.responseMimeType="application/json",t.responseSchema=e.structuredOutput.schema),e.enableThinking&&(t.thinkingConfig={thinkingBudget:e.thinkingBudget??nu,includeThoughts:true}),t}parseSSELine(e){let t=e.trim();if(!t||(t.startsWith("data:")&&(t=t.slice(5).trim()),t==="[DONE]")||!t.startsWith("{"))return null;try{return JSON.parse(t)}catch{return null}}convertResponse(e,t){let s=e.candidates[0];if(!s)throw new Error("No candidate in Gemini response");let n=s.content?.parts||[],i=null,o=[];for(let c of n)c.text?i=(i||"")+c.text:c.functionCall&&o.push({id:c.functionCall.id||`call_${Date.now()}_${Math.random().toString(36).substr(2,9)}`,type:"function",function:{name:c.functionCall.name,arguments:su(c.functionCall.args)}});let a=e.usageMetadata||{promptTokenCount:0,candidatesTokenCount:0,totalTokenCount:0},l=s.finishReason==="STOP"?o.length>0?"tool_calls":"stop":(s.finishReason||"stop").toLowerCase();return {id:t,choices:[{message:{role:"assistant",content:i,tool_calls:o.length>0?o:void 0},finish_reason:l}],usage:{prompt_tokens:a.promptTokenCount,completion_tokens:a.candidatesTokenCount,total_tokens:a.totalTokenCount,cached_tokens:a.cachedContentTokenCount}}}async makeRequest(e,t){let s,n=0;for(;n<=this.retryConfig.requestMaxRetries;)try{return await e()}catch(i){s=i,n++;let o=nt(i),a=Rt(i.response?.headers?.["retry-after"]);if(!o.retryable||n>this.retryConfig.requestMaxRetries)break;let l=Ft(a,n,this.retryConfig);await $s(l);}throw s}async chat(e,t){let s=t.model||"gemini-2.5-flash",{contents:n,systemInstruction:i}=this.convertMessages(e),o=this.convertTools(t.tools||[]),a=this.buildGenerationConfig({temperature:t.temperature,structuredOutput:t.structuredOutput,topP:t.topP,topK:t.topK,stopSequences:t.stopSequences,maxOutputTokens:t.maxInputTokens}),l={contents:n,systemInstruction:i,generationConfig:a};o.length>0&&(l.tools=o);let c=`gemini-${Date.now()}`,u=`${this.pathPrefix}/${s}:generateContent`,p=this.authMode==="query"?{key:this.apiKey}:void 0;return this.makeRequest(async()=>{let d=await this.client.post(u,l,{params:p,signal:t.signal});return this.convertResponse(d.data,c)},"chat")}async*chatStreamed(e,t){let s=t.model||"gemini-2.5-flash",{contents:n,systemInstruction:i}=this.convertMessages(e),o=this.convertTools(t.tools||[]),a=ru(s),l=this.thinkingSettings?.type==="enabled",c=this.thinkingSettings?.type==="disabled",u=t.enableThinking!==void 0?t.enableThinking:l?true:c?false:a,p=t.thinkingBudget??this.thinkingSettings?.budget??nu,d=this.buildGenerationConfig({temperature:t.temperature,structuredOutput:t.structuredOutput,topP:t.topP,topK:t.topK,stopSequences:t.stopSequences,maxOutputTokens:t.maxInputTokens,enableThinking:u,thinkingBudget:p}),h={contents:ru(s)?df(n):n,systemInstruction:i,generationConfig:d};o.length>0&&(h.tools=o);let g=`gemini-${Date.now()}`,y=`${this.pathPrefix}/${s}:streamGenerateContent`,b=`${this.baseURL}${y}`,w=this.authMode==="query"?{key:this.apiKey,alt:"sse"}:{alt:"sse"},S=new URL(b);for(let[H,U]of Object.entries(w))S.searchParams.append(H,U);let x={"Content-Type":"application/json",Accept:"*/*"};if(this.authMode==="header"?x["x-goog-api-key"]=this.apiKey:this.authMode==="bearer"&&(x.Authorization=`Bearer ${this.apiKey}`),process.env.CLI_DEBUG==="1"){f.info("GEMINI","=== Gemini Stream Request ==="),f.info("GEMINI",`URL: ${S.toString()}`),f.info("GEMINI",`Model: ${s}`),f.info("GEMINI",`AuthMode: ${this.authMode}`),f.info("GEMINI",`Tools: ${o.length>0?o[0].functionDeclarations.length:0}`),f.info("GEMINI",`Contents: ${n.length} messages`);let H=wt(S.toString(),x,h);f.info("GEMINI_CURL",H),f.debug("GEMINI","Request body:",{contentsCount:h.contents.length,hasSystemInstruction:!!h.systemInstruction,toolsCount:h.tools?.[0]?.functionDeclarations?.length||0,generationConfig:h.generationConfig});}if(process.env.CLI_DEBUG==="1"){pe("GEMINI","[Gemini Stream Request]"),pe("GEMINI",`URL: ${S.toString()}`),pe("GEMINI",`Model: ${s}`),pe("GEMINI",`Tools: ${o.length>0?o[0].functionDeclarations.length:0}`),pe("GEMINI",`Contents: ${n.length} messages`);let H=wt(S.toString(),x,h);pe("GEMINI_CURL",H);}let R=Date.now(),L=await this.makeRequest(async()=>{let H=this.authMode==="query"?{key:this.apiKey,alt:"sse"}:{alt:"sse"};return await this.client.post(y,h,{params:H,responseType:"stream",signal:t.signal,headers:{Accept:"*/*","Accept-Language":"*","sec-fetch-mode":"cors","Accept-Encoding":"br, gzip, deflate"}})},"chatStreamed");process.env.CLI_DEBUG==="1"&&(pe("GEMINI","[Gemini Stream Started]"),pe("GEMINI",`Status: ${L.status}`)),yield*this.streamGenerator(L.data,g,R);}async*streamGenerator(e,t,s){let n="",i=[],o="",a=[],l,c=u=>{let p=[],d=u.candidates?.[0];if(!d)return process.env.CLI_DEBUG==="1"&&pe("GEMINI",`No candidate in response: ${JSON.stringify(u).slice(0,200)}`),p;u.usageMetadata&&(l=u.usageMetadata);let m=d.content?.parts;if(!m||m.length===0)process.env.CLI_DEBUG==="1"&&pe("GEMINI",`No parts in candidate: ${JSON.stringify(d).slice(0,200)}`);else for(let h of m){if(h.thought&&!h.thoughtSignature&&h.text){process.env.CLI_DEBUG==="1"&&pe("GEMINI",`Yielding reasoning: ${h.text.slice(0,50)}...`),p.push({choices:[{index:0,delta:{reasoning_content:h.text}}]});continue}if(h.text)h.thoughtSignature&&process.env.CLI_DEBUG==="1"?pe("GEMINI",`Yielding final answer (with signature): ${h.text.slice(0,100)}...`):process.env.CLI_DEBUG==="1"&&pe("GEMINI",`Yielding content: ${h.text.slice(0,100)}...`),o+=h.text,p.push({choices:[{index:0,delta:{content:h.text}}]});else if(h.functionCall){let g={id:h.functionCall.id||`call_${Date.now()}_${Math.random().toString(36).substr(2,9)}`,type:"function",function:{name:h.functionCall.name,arguments:su(h.functionCall.args)},...h.thoughtSignature?{thoughtSignature:h.thoughtSignature}:{}};a.push(g),p.push({choices:[{index:0,delta:{tool_calls:[{index:a.length-1,id:g.id,type:"function",function:{name:g.function.name,arguments:g.function.arguments},...g.thoughtSignature?{thoughtSignature:g.thoughtSignature}:{}}]}}]});}}if(d.finishReason){let h=l||{promptTokenCount:0,candidatesTokenCount:0,totalTokenCount:0};if(process.env.CLI_DEBUG==="1"){let y=s?Date.now()-s:0;f.info("GEMINI","=== Gemini Stream Complete ==="),f.info("GEMINI",`Duration: ${y}ms`),f.info("GEMINI",`Finish Reason: ${d.finishReason}`),f.info("GEMINI",`Tool Calls: ${a.length}`),f.info("GEMINI",`Accumulated Content Length: ${o.length}`),f.info("GEMINI",`Usage: prompt=${h.promptTokenCount}, completion=${h.candidatesTokenCount}, total=${h.totalTokenCount}`),o&&f.info("GEMINI",`Content Preview: ${o.slice(0,500)}...`),a.length>0&&f.info("GEMINI","Tool Calls Detail:",a.map(b=>({id:b.id,name:b.function.name,argsLength:b.function.arguments.length})));}if(process.env.CLI_DEBUG==="1"){let y=s?Date.now()-s:0;pe("GEMINI","[Gemini Stream Complete]"),pe("GEMINI",`Duration: ${y}ms`),pe("GEMINI",`Finish Reason: ${d.finishReason}`),pe("GEMINI",`Tool Calls: ${a.length}`),pe("GEMINI",`Accumulated Content Length: ${o.length}`),pe("GEMINI",`Usage: prompt=${h.promptTokenCount}, completion=${h.candidatesTokenCount}, total=${h.totalTokenCount}`),o&&pe("GEMINI",`Content Preview: ${o.slice(0,500)}`);}let g=d.finishReason==="STOP"?a.length>0?"tool_calls":"stop":d.finishReason.toLowerCase();p.push({id:t,choices:[{index:0,delta:{},finish_reason:g}],usage:{prompt_tokens:h.promptTokenCount,completion_tokens:h.candidatesTokenCount,total_tokens:h.totalTokenCount,cached_tokens:h.cachedContentTokenCount}});}return p};try{for await(let u of e){let p=u.toString();n+=p,process.env.CLI_DEBUG==="1"&&pe("GEMINI",`Raw chunk (${p.length} bytes): ${p.slice(0,200)}...`);let d=n.split(/\r?\n/);n=d.pop()||"";for(let m of d){let h=m.trimEnd();if(!h){if(i.length===0)continue;let y=i.join(`
|
|
1742
|
-
`);i=[];let b=this.parseSSELine(y);if(!b){process.env.CLI_DEBUG==="1"&&y.length>0&&
|
|
1743
|
-
`));if(u)for(let p of c(u))yield p;}}catch(u){if(process.env.CLI_DEBUG==="1"){let p=s?Date.now()-s:0;
|
|
1741
|
+
4. **Professional tone**: objective and technical`}getModelDisplayName(e){return e?e.includes("gemini-3")?"Gemini 3":e.includes("gemini-2.5")?"Gemini 2.5":e.includes("gemini-2.0")?"Gemini 2.0":e.includes("gemini-1.5")?"Gemini 1.5":e.includes("gemini-1.0")?"Gemini 1.0":e:"Gemini"}supportsVision(e){return e?e.includes("vision")?true:this.isModelType(e,"gemini-1.5*","gemini-2*","gemini-3*"):false}};me();function bf(r){let e="/v1beta/models";if(!r)return e;let t=r.trim();if(!t)return e;let s=t.startsWith("/")?t:`/${t}`;return s=s.replace(/\/+$/,""),s.includes("/models")||(s=`${s}/models`),s}function wf(r){try{let e=JSON.parse(r);return e&&typeof e=="object"?e:{value:e}}catch{return {}}}function lu(r){if(r==null)return "{}";if(typeof r=="string"){let e=r.trim();return e?e.startsWith("{")||e.startsWith("[")?e:JSON.stringify({value:e}):"{}"}try{return JSON.stringify(r)}catch{return "{}"}}var _f="skip_thought_signature_validator",cu=8192;function uu(r){return r.includes("gemini-3")||r.includes("preview")}function Sf(r){let e=-1;for(let s=r.length-1;s>=0;s--){let n=r[s];if(n.role==="user"&&n.parts?.some(i=>i.text)){e=s;break}}if(e===-1)return r;let t=r.slice();for(let s=e;s<t.length;s++){let n=t[s];if(n.role==="model"&&n.parts){let i=n.parts.slice();for(let o=0;o<i.length;o++){let a=i[o];if(a.functionCall){a.thoughtSignature||(i[o]={...a,thoughtSignature:_f},t[s]={...n,parts:i});break}}}}return t}var Bs=class{client;apiKey;baseURL;pathPrefix;userId;retryConfig;authMode;thinkingSettings=null;constructor(e,t="https://generativelanguage.googleapis.com",s,n){this.apiKey=e,this.baseURL=t.replace(/\/$/,""),this.pathPrefix=bf(n?.pathPrefix),this.userId=randomUUID(),this.authMode=this.resolveAuthMode(n?.authMode),this.retryConfig=Nt(Os("gemini"),s);let i={"Content-Type":"application/json","User-Agent":`GeminiCLI/v22.16.0 (${Js__default.platform()}; ${Js__default.arch()})`,"x-goog-api-client":"google-genai-sdk/1.30.0 gl-node/v22.16.0","x-gemini-api-privileged-user-id":this.userId};this.authMode==="header"?i["x-goog-api-key"]=this.apiKey:this.authMode==="bearer"&&(i.Authorization=`Bearer ${this.apiKey}`),this.client=nf.create({baseURL:this.baseURL,timeout:6e5,headers:i});}resolveAuthMode(e){if(e&&e!=="auto")return e;let t=this.baseURL.includes("generativelanguage.googleapis.com"),s=this.apiKey.startsWith("AIza");return t||s?"query":"bearer"}setThinking(e){this.thinkingSettings=e,process.env.CLI_DEBUG==="1"&&de("GEMINI","Thinking config updated",{config:e});}getThinking(){return this.thinkingSettings}convertMessages(e){let t=this.filterIncompleteToolCalls(e),s=[],n=[],i=[],o=()=>{i.length>0&&(n.push({parts:i,role:"user"}),i=[]);};for(let l of t)if(l.role==="system"){let c=se(l.content);c&&s.push(c);}else if(l.role==="user"){o();let c=[];if(typeof l.content=="string")c.push({text:l.content});else if(Array.isArray(l.content)){for(let u of l.content)if(u.type==="text")c.push({text:u.text});else if(u.type==="image_url"){let p=u.image_url.url;if(p.startsWith("data:")){let d=p.match(/^data:([^;]+);base64,(.+)$/);d&&c.push({inlineData:{mimeType:d[1],data:d[2]}});}}}n.push({parts:c,role:"user"});}else if(l.role==="assistant"){o();let c=[],u=se(l.content);if(u&&c.push({text:u}),l.tool_calls)for(let p of l.tool_calls){let d={functionCall:{name:p.function.name,args:wf(p.function.arguments),id:p.id}};p.thoughtSignature&&(d.thoughtSignature=p.thoughtSignature),c.push(d);}n.push({parts:c,role:"model"});}else if(l.role==="tool"){let c=se(l.content)||"",p={name:l.name||"unknown",response:{output:c}};l.tool_call_id&&(p.id=l.tool_call_id),i.push({functionResponse:p});}o();let a={contents:n};return s.length>0&&(a.systemInstruction={parts:s.map(l=>({text:l})),role:"user"}),a}filterIncompleteToolCalls(e){let t=[],s=0;for(;s<e.length;){let n=e[s];if(n.role==="system"){t.push(n),s++;continue}if(n.role==="assistant"&&n.tool_calls&&n.tool_calls.length>0){let i=n.tool_calls,o=i.length,a=i.every(h=>!!h.id),l=[],c=[],u=s+1;for(;u<e.length;){let h=e[u];if(h.role==="system"){l.push(h),u++;continue}if(h.role!=="tool")break;l.push(h),c.push(h),u++;}let p=c.length,d=c.every(h=>!!h.tool_call_id),m=p===o;if(m&&a&&d){let h=new Set(c.map(g=>g.tool_call_id).filter(g=>!!g));for(let g of i)if(!h.has(g.id)){m=false;break}}if(m){t.push(n);for(let h of l)t.push(h);}else {process.env.CLI_DEBUG==="1"&&f.debug("GEMINI","Filtering incomplete tool call turn",{toolCalls:i.map(h=>({id:h.id,name:h.function.name})),responseCount:p});for(let h of l)h.role==="system"&&t.push(h);}s=u;continue}if(n.role==="tool"){process.env.CLI_DEBUG==="1"&&f.debug("GEMINI","Dropping orphan tool message",{toolCallId:n.tool_call_id,toolName:n.name}),s++;continue}t.push(n),s++;}return t}convertTools(e){return !e||e.length===0?[]:[{functionDeclarations:e.map(s=>({name:s.name,description:s.description,parameters:{type:s.parameters.type,properties:s.parameters.properties,required:s.parameters.required,additionalProperties:s.parameters.additionalProperties},parametersJsonSchema:{type:s.parameters.type,properties:s.parameters.properties,required:s.parameters.required,additionalProperties:s.parameters.additionalProperties}}))}]}buildGenerationConfig(e){let t={temperature:e.temperature??1,topP:e.topP??.95,topK:e.topK??64};return e.maxOutputTokens!==void 0&&(t.maxOutputTokens=e.maxOutputTokens),e.stopSequences&&e.stopSequences.length>0&&(t.stopSequences=e.stopSequences),e.structuredOutput&&(t.responseMimeType="application/json",t.responseSchema=e.structuredOutput.schema),e.enableThinking&&(t.thinkingConfig={thinkingBudget:e.thinkingBudget??cu,includeThoughts:true}),t}parseSSELine(e){let t=e.trim();if(!t||(t.startsWith("data:")&&(t=t.slice(5).trim()),t==="[DONE]")||!t.startsWith("{"))return null;try{return JSON.parse(t)}catch{return null}}convertResponse(e,t){let s=e.candidates[0];if(!s)throw new Error("No candidate in Gemini response");let n=s.content?.parts||[],i=null,o=[];for(let c of n)c.text?i=(i||"")+c.text:c.functionCall&&o.push({id:c.functionCall.id||`call_${Date.now()}_${Math.random().toString(36).substr(2,9)}`,type:"function",function:{name:c.functionCall.name,arguments:lu(c.functionCall.args)}});let a=e.usageMetadata||{promptTokenCount:0,candidatesTokenCount:0,totalTokenCount:0},l=s.finishReason==="STOP"?o.length>0?"tool_calls":"stop":(s.finishReason||"stop").toLowerCase();return {id:t,choices:[{message:{role:"assistant",content:i,tool_calls:o.length>0?o:void 0},finish_reason:l}],usage:{prompt_tokens:a.promptTokenCount,completion_tokens:a.candidatesTokenCount,total_tokens:a.totalTokenCount,cached_tokens:a.cachedContentTokenCount}}}async makeRequest(e,t){let s,n=0;for(;n<=this.retryConfig.requestMaxRetries;)try{return await e()}catch(i){s=i,n++;let o=nt(i),a=Rt(i.response?.headers?.["retry-after"]);if(!o.retryable||n>this.retryConfig.requestMaxRetries)break;let l=Ft(a,n,this.retryConfig);await $s(l);}throw s}async chat(e,t){let s=t.model||"gemini-2.5-flash",{contents:n,systemInstruction:i}=this.convertMessages(e),o=this.convertTools(t.tools||[]),a=this.buildGenerationConfig({temperature:t.temperature,structuredOutput:t.structuredOutput,topP:t.topP,topK:t.topK,stopSequences:t.stopSequences,maxOutputTokens:t.maxInputTokens}),l={contents:n,systemInstruction:i,generationConfig:a};o.length>0&&(l.tools=o);let c=`gemini-${Date.now()}`,u=`${this.pathPrefix}/${s}:generateContent`,p=this.authMode==="query"?{key:this.apiKey}:void 0;return this.makeRequest(async()=>{let d=await this.client.post(u,l,{params:p,signal:t.signal});return this.convertResponse(d.data,c)},"chat")}async*chatStreamed(e,t){let s=t.model||"gemini-2.5-flash",{contents:n,systemInstruction:i}=this.convertMessages(e),o=this.convertTools(t.tools||[]),a=uu(s),l=this.thinkingSettings?.type==="enabled",c=this.thinkingSettings?.type==="disabled",u=t.enableThinking!==void 0?t.enableThinking:l?true:c?false:a,p=t.thinkingBudget??this.thinkingSettings?.budget??cu,d=this.buildGenerationConfig({temperature:t.temperature,structuredOutput:t.structuredOutput,topP:t.topP,topK:t.topK,stopSequences:t.stopSequences,maxOutputTokens:t.maxInputTokens,enableThinking:u,thinkingBudget:p}),h={contents:uu(s)?Sf(n):n,systemInstruction:i,generationConfig:d};o.length>0&&(h.tools=o);let g=`gemini-${Date.now()}`,y=`${this.pathPrefix}/${s}:streamGenerateContent`,b=`${this.baseURL}${y}`,w=this.authMode==="query"?{key:this.apiKey,alt:"sse"}:{alt:"sse"},S=new URL(b);for(let[G,U]of Object.entries(w))S.searchParams.append(G,U);let x={"Content-Type":"application/json",Accept:"*/*"};if(this.authMode==="header"?x["x-goog-api-key"]=this.apiKey:this.authMode==="bearer"&&(x.Authorization=`Bearer ${this.apiKey}`),process.env.CLI_DEBUG==="1"){f.info("GEMINI","=== Gemini Stream Request ==="),f.info("GEMINI",`URL: ${S.toString()}`),f.info("GEMINI",`Model: ${s}`),f.info("GEMINI",`AuthMode: ${this.authMode}`),f.info("GEMINI",`Tools: ${o.length>0?o[0].functionDeclarations.length:0}`),f.info("GEMINI",`Contents: ${n.length} messages`);let G=wt(S.toString(),x,h);f.info("GEMINI_CURL",G),f.debug("GEMINI","Request body:",{contentsCount:h.contents.length,hasSystemInstruction:!!h.systemInstruction,toolsCount:h.tools?.[0]?.functionDeclarations?.length||0,generationConfig:h.generationConfig});}if(process.env.CLI_DEBUG==="1"){de("GEMINI","[Gemini Stream Request]"),de("GEMINI",`URL: ${S.toString()}`),de("GEMINI",`Model: ${s}`),de("GEMINI",`Tools: ${o.length>0?o[0].functionDeclarations.length:0}`),de("GEMINI",`Contents: ${n.length} messages`);let G=wt(S.toString(),x,h);de("GEMINI_CURL",G);}let R=Date.now(),$=await this.makeRequest(async()=>{let G=this.authMode==="query"?{key:this.apiKey,alt:"sse"}:{alt:"sse"};return await this.client.post(y,h,{params:G,responseType:"stream",signal:t.signal,headers:{Accept:"*/*","Accept-Language":"*","sec-fetch-mode":"cors","Accept-Encoding":"br, gzip, deflate"}})},"chatStreamed");process.env.CLI_DEBUG==="1"&&(de("GEMINI","[Gemini Stream Started]"),de("GEMINI",`Status: ${$.status}`)),yield*this.streamGenerator($.data,g,R);}async*streamGenerator(e,t,s){let n="",i=[],o="",a=[],l,c=u=>{let p=[],d=u.candidates?.[0];if(!d)return process.env.CLI_DEBUG==="1"&&de("GEMINI",`No candidate in response: ${JSON.stringify(u).slice(0,200)}`),p;u.usageMetadata&&(l=u.usageMetadata);let m=d.content?.parts;if(!m||m.length===0)process.env.CLI_DEBUG==="1"&&de("GEMINI",`No parts in candidate: ${JSON.stringify(d).slice(0,200)}`);else for(let h of m){if(h.thought&&!h.thoughtSignature&&h.text){process.env.CLI_DEBUG==="1"&&de("GEMINI",`Yielding reasoning: ${h.text.slice(0,50)}...`),p.push({choices:[{index:0,delta:{reasoning_content:h.text}}]});continue}if(h.text)h.thoughtSignature&&process.env.CLI_DEBUG==="1"?de("GEMINI",`Yielding final answer (with signature): ${h.text.slice(0,100)}...`):process.env.CLI_DEBUG==="1"&&de("GEMINI",`Yielding content: ${h.text.slice(0,100)}...`),o+=h.text,p.push({choices:[{index:0,delta:{content:h.text}}]});else if(h.functionCall){let g={id:h.functionCall.id||`call_${Date.now()}_${Math.random().toString(36).substr(2,9)}`,type:"function",function:{name:h.functionCall.name,arguments:lu(h.functionCall.args)},...h.thoughtSignature?{thoughtSignature:h.thoughtSignature}:{}};a.push(g),p.push({choices:[{index:0,delta:{tool_calls:[{index:a.length-1,id:g.id,type:"function",function:{name:g.function.name,arguments:g.function.arguments},...g.thoughtSignature?{thoughtSignature:g.thoughtSignature}:{}}]}}]});}}if(d.finishReason){let h=l||{promptTokenCount:0,candidatesTokenCount:0,totalTokenCount:0};if(process.env.CLI_DEBUG==="1"){let y=s?Date.now()-s:0;f.info("GEMINI","=== Gemini Stream Complete ==="),f.info("GEMINI",`Duration: ${y}ms`),f.info("GEMINI",`Finish Reason: ${d.finishReason}`),f.info("GEMINI",`Tool Calls: ${a.length}`),f.info("GEMINI",`Accumulated Content Length: ${o.length}`),f.info("GEMINI",`Usage: prompt=${h.promptTokenCount}, completion=${h.candidatesTokenCount}, total=${h.totalTokenCount}`),o&&f.info("GEMINI",`Content Preview: ${o.slice(0,500)}...`),a.length>0&&f.info("GEMINI","Tool Calls Detail:",a.map(b=>({id:b.id,name:b.function.name,argsLength:b.function.arguments.length})));}if(process.env.CLI_DEBUG==="1"){let y=s?Date.now()-s:0;de("GEMINI","[Gemini Stream Complete]"),de("GEMINI",`Duration: ${y}ms`),de("GEMINI",`Finish Reason: ${d.finishReason}`),de("GEMINI",`Tool Calls: ${a.length}`),de("GEMINI",`Accumulated Content Length: ${o.length}`),de("GEMINI",`Usage: prompt=${h.promptTokenCount}, completion=${h.candidatesTokenCount}, total=${h.totalTokenCount}`),o&&de("GEMINI",`Content Preview: ${o.slice(0,500)}`);}let g=d.finishReason==="STOP"?a.length>0?"tool_calls":"stop":d.finishReason.toLowerCase();p.push({id:t,choices:[{index:0,delta:{},finish_reason:g}],usage:{prompt_tokens:h.promptTokenCount,completion_tokens:h.candidatesTokenCount,total_tokens:h.totalTokenCount,cached_tokens:h.cachedContentTokenCount}});}return p};try{for await(let u of e){let p=u.toString();n+=p,process.env.CLI_DEBUG==="1"&&de("GEMINI",`Raw chunk (${p.length} bytes): ${p.slice(0,200)}...`);let d=n.split(/\r?\n/);n=d.pop()||"";for(let m of d){let h=m.trimEnd();if(!h){if(i.length===0)continue;let y=i.join(`
|
|
1742
|
+
`);i=[];let b=this.parseSSELine(y);if(!b){process.env.CLI_DEBUG==="1"&&y.length>0&&de("GEMINI",`Failed to parse event: ${y.slice(0,100)}...`);continue}for(let w of c(b))yield w;continue}if(h.startsWith("data:")){i.push(h.slice(5).trimStart());continue}let g=this.parseSSELine(h);if(!g){process.env.CLI_DEBUG==="1"&&h.length>0&&de("GEMINI",`Failed to parse line: ${h.slice(0,100)}...`);continue}for(let y of c(g))yield y;}}if(i.length>0){let u=this.parseSSELine(i.join(`
|
|
1743
|
+
`));if(u)for(let p of c(u))yield p;}}catch(u){if(process.env.CLI_DEBUG==="1"){let p=s?Date.now()-s:0;de("GEMINI","[Gemini Stream Error]"),de("GEMINI",`Duration: ${p}ms`),de("GEMINI",`Error: ${u.message||u}`),u.response?.data&&de("GEMINI",`Response: ${JSON.stringify(u.response.data)}`);}throw u}}};me();var ui=class extends bt{constraints;promptBuilder;provider;defaultModel;constructor(e){super(),this.constraints=new ci,this.promptBuilder=new zn,this.defaultModel=e.defaultModel||"gemini-2.5-flash";let{apiKey:t,baseUrl:s,urlSuffix:n,retry:i}=e;this.provider=new Bs(t,s,i,{pathPrefix:n});}prepareRequest(e,t){let s=t.model||this.defaultModel;return super.prepareRequest(e,{...t,model:s})}async chat(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}return s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("GeminiAdapter","Warnings",s.validation.warnings),this.provider.chat(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens,topP:s.options.topP,topK:s.options.topK,stopSequences:s.options.stopSequences})}async*chatStreamed(e,t){let s=this.prepareRequest(e,t);if(!s.validation?.valid){let n=s.validation?.errors||[];throw new Error(`Invalid parameters: ${n.join(", ")}`)}s.validation?.warnings&&s.validation.warnings.length>0&&f.warn("GeminiAdapter","Warnings",s.validation.warnings),yield*this.provider.chatStreamed(s.messages,{model:s.options.model,tools:s.options.tools,temperature:s.options.temperature,structuredOutput:s.options.structuredOutput,maxInputTokens:s.options.maxInputTokens,topP:s.options.topP,topK:s.options.topK,stopSequences:s.options.stopSequences,signal:t.signal});}getProvider(){return this.provider}};var Ws=class r{static createAdapter(e,t){switch(e){case "openai":return r.createOpenAIAdapter(t,false);case "openai-responses":return r.createOpenAIAdapter(t,true);case "kimi":return r.createKimiAdapter(t);case "anthropic":case "anthropic-openai":return r.createAnthropicAdapter(t);case "doubao":throw new Error("Doubao adapter not yet implemented. Use Phase 5.");case "gemini":return r.createGeminiAdapter(t);default:throw new Error(`Unsupported provider protocol: ${e}`)}}static createOpenAIAdapter(e,t){let s={apiKey:e.apiKey,baseUrl:e.baseUrl,defaultModel:e.defaultModel||e.lastSelectedModel,useResponsesAPI:t,maxTokens:e.maxTokens,maxInputTokens:e.maxInputTokens};return new si(s)}static createAnthropicAdapter(e){let t={authToken:e.apiKey,baseUrl:e.baseUrl,defaultModel:e.defaultModel||e.lastSelectedModel,maxTokens:e.maxTokens&&e.maxTokens<=8192?e.maxTokens:void 0,disableCaching:false};return new oi(t)}static createKimiAdapter(e){let t={apiKey:e.apiKey,baseUrl:e.baseUrl,defaultModel:e.defaultModel||e.lastSelectedModel,maxTokens:e.maxTokens,maxInputTokens:e.maxInputTokens};return new li(t)}static createGeminiAdapter(e){let t={apiKey:e.apiKey,baseUrl:e.baseUrl,urlSuffix:e.urlSuffix,defaultModel:e.defaultModel||e.lastSelectedModel,retry:e.retry};return new ui(t)}static isProtocolSupported(e){return ["openai","openai-responses","anthropic","anthropic-openai","kimi","gemini"].includes(e)}static getProtocolDisplayName(e){return {openai:"OpenAI (Chat Completions)","openai-responses":"OpenAI (Responses API)",anthropic:"Anthropic (Claude)","anthropic-openai":"Anthropic (OpenAI Format)",doubao:"\u8C46\u5305 (Doubao)",gemini:"Google Gemini",kimi:"Kimi (Moonshot)"}[e]||e}};var vf=16e3;function Tf(r,e=vf){if(!r||r.length<=e)return r;let t=r.split(`
|
|
1744
1744
|
`).length,s=r.length,n=Math.floor(e*.4),i=Math.floor(e*.4),o=n,a=r.length-i;for(;o>0&&(r.charCodeAt(o)&192)===128;)o--;for(;a<r.length&&(r.charCodeAt(a)&192)===128;)a++;let l=r.slice(0,o),c=r.slice(a),p=`
|
|
1745
1745
|
|
|
1746
1746
|
\u2026[${s-l.length-c.length} chars truncated, total ${t} lines]\u2026
|
|
1747
1747
|
|
|
1748
|
-
`;return l+p+c}var
|
|
1748
|
+
`;return l+p+c}var pi=class{client;defaultModel;retryConfig;baseUrl;thinking;reasoning;caching;store;lastResponseId=null;sessionResponseIds=new Map;constructor(e){this.baseUrl=e.baseUrl||"https://ark.cn-beijing.volces.com/api/v3",this.defaultModel=e.defaultModel||"doubao-seed-1-6-251015",this.thinking=e.thinking,this.reasoning=e.reasoning,this.caching=e.caching||{type:"enabled"},this.store=e.store??true,this.client=nf.create({baseURL:this.baseUrl,headers:{Authorization:`Bearer ${e.apiKey}`,"Content-Type":"application/json"},timeout:18e4}),this.retryConfig=Nt(void 0,{requestMaxRetries:3,streamMaxRetries:5,...e.retry}),process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Doubao] Initialized with:",{baseUrl:this.baseUrl,defaultModel:this.defaultModel,thinking:this.thinking,caching:this.caching,store:this.store});}async chat(e,t={}){let s="",n="",i=[],o,a;for await(let l of this.chatStreamed(e,t)){let c=l.choices?.[0]?.delta;if(c&&(c.content&&(s+=c.content),c.reasoning_content&&(n+=c.reasoning_content),c.tool_calls))for(let u of c.tool_calls){let p=i.find(d=>d.index===u.index);p?u.function?.arguments&&(p.function.arguments+=u.function.arguments):i.push({id:u.id||`call_${i.length}`,type:"function",function:{name:u.function?.name||"",arguments:u.function?.arguments||""},index:u.index});}l.usage&&(o=l.usage),l.id&&(a=l.id);}return a&&(this.lastResponseId=a,t.sessionId&&this.sessionResponseIds.set(t.sessionId,a)),{id:a||`chatcmpl-${Date.now()}`,choices:[{message:{role:"assistant",content:s||null,reasoning_content:n||void 0,...i.length>0?{tool_calls:i}:{}},finish_reason:i.length>0?"tool_calls":"stop"}],usage:o||{prompt_tokens:0,completion_tokens:0,total_tokens:0}}}async*chatStreamed(e,t={}){let{model:s=this.defaultModel,tools:n,temperature:i=.7,sessionId:o,signal:a}=t,l=t.previousResponseId;!l&&o&&(l=this.sessionResponseIds.get(o)),l||(l=this.lastResponseId||void 0);let c=this.buildPayload(e,{model:s,tools:n,temperature:i,structuredOutput:t.structuredOutput,maxInputTokens:t.maxInputTokens,previousResponseId:l}),u=`${this.baseUrl}/responses`;oe.llmRequest("doubao-responses",s,c,u,{Authorization:"Bearer ***"}),process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log(`
|
|
1749
1749
|
[Doubao Responses API Request]`),console.log("URL:",u),console.log("Payload:",JSON.stringify(c,null,2)));let p=this.retryConfig.streamMaxRetries,d=0;for(;;)try{if(a?.aborted){let y=new Error("Request aborted");throw y.name="AbortError",y}let m=Date.now(),h=await this.client.post("/responses",c,{responseType:"stream",signal:a,headers:{Accept:"text/event-stream"}});if(process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log(`
|
|
1750
|
-
[Doubao Stream Started]`),console.log("Status:",h.status)),h.status!==200){let y="";for await(let b of h.data)y+=b.toString();throw new Error(`Doubao API error: ${h.status} - ${y}`)}yield*this.parseStreamResponse(h.data);let g=Date.now()-m;
|
|
1750
|
+
[Doubao Stream Started]`),console.log("Status:",h.status)),h.status!==200){let y="";for await(let b of h.data)y+=b.toString();throw new Error(`Doubao API error: ${h.status} - ${y}`)}yield*this.parseStreamResponse(h.data);let g=Date.now()-m;oe.llmResponse("doubao-responses",g,{},{}),process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log(`
|
|
1751
1751
|
[Doubao Stream Complete]`),console.log("Duration:",`${g}ms`));return}catch(m){let h="";if(m.response?.data)try{if(typeof m.response.data.on=="function"){let y=[];for await(let w of m.response.data)y.push(Buffer.from(w));let b=Buffer.concat(y).toString("utf-8");try{let w=JSON.parse(b),S=w.error||{message:w.message,code:w.code,type:w.type};h=JSON.stringify(S,null,2);}catch{h=b;}}else if(typeof m.response.data=="string")h=m.response.data;else if(m.response.data.error){let y=m.response.data.error,b={message:y.message,code:y.code,type:y.type};h=JSON.stringify(b,null,2);}else {let y=m.response.data,b={message:y.message,code:y.code,type:y.type,error:y.error};h=JSON.stringify(b,null,2);}}catch(y){h=`HTTP ${m.response?.status||"unknown"} (\u65E0\u6CD5\u8BFB\u53D6\u54CD\u5E94\u4F53: ${y})`;}let g=nt(m);if(process.env.CLI_DEBUG_CONSOLE==="1"&&(console.log(`
|
|
1752
1752
|
[Doubao Stream Error]`),console.log("Message:",m.message),console.log("Status:",m.response?.status),console.log("Error Details:",h||"none"),console.log("Retryable:",g.retryable)),h&&(g.message=`${m.message}
|
|
1753
|
-
${h}`),
|
|
1753
|
+
${h}`),oe.llmError("doubao-responses",m),g.retryable&&d<p){d++;let y=m.response?.headers?.["retry-after"],b=Rt(y),w=Ft(b,d,this.retryConfig);console.log(`[Doubao] Stream failed (${g.code}), reconnecting in ${Je(w)} (${d}/${p})...`),yield {choices:[],type:"stream_retry",error:g.message,errorCode:g.code,attempt:d,maxRetries:p,delayMs:w};try{await ns(w,t.signal);}catch(S){throw S?.name==="AbortError",S}continue}throw g}}getResponseId(e){return e?this.sessionResponseIds.get(e)||null:this.lastResponseId}setResponseId(e,t){this.lastResponseId=e,t&&this.sessionResponseIds.set(t,e);}clearSession(e){e?this.sessionResponseIds.delete(e):this.lastResponseId=null;}setThinking(e){this.thinking=e;}setCaching(e){this.caching=e;}buildPayload(e,t){let {model:s,tools:n,temperature:i,structuredOutput:o,maxInputTokens:a,previousResponseId:l}=t,c=this.convertToDoubaoInput(e,l);this.extractSystemInstructions(e);let p={model:s,input:c,stream:true,temperature:i};return l&&(p.previous_response_id=l),this.thinking&&(p.thinking=this.thinking),this.reasoning&&(p.reasoning=this.reasoning),n&&n.length>0&&(p.tools=n.map(d=>({type:"function",name:d.name,description:d.description,parameters:d.parameters})),process.env.CLI_DEBUG_CONSOLE==="1"&&console.log(`[Doubao] Added ${p.tools.length} tools`)),o&&(p.text={format:{type:"json_schema",name:o.name,schema:o.schema}}),p}extractSystemInstructions(e){let t=e.filter(s=>s.role==="system").map(s=>se(s.content).trim()).filter(s=>s.length>0);return t.length>0?t.join(`
|
|
1754
1754
|
|
|
1755
|
-
`):void 0}convertToDoubaoInput(e,t){let s=new Map;if(!e.some(o=>o.role==="tool"||o.role==="assistant"&&Array.isArray(o.tool_calls)&&o.tool_calls.length>0))return e.map(o=>({role:o.role,content:
|
|
1755
|
+
`):void 0}convertToDoubaoInput(e,t){let s=new Map;if(!e.some(o=>o.role==="tool"||o.role==="assistant"&&Array.isArray(o.tool_calls)&&o.tool_calls.length>0))return e.map(o=>({role:o.role,content:se(o.content)}));let i=e.filter(o=>o.role!=="system");if(t){let o=[],a=false;for(let l=i.length-1;l>=0;l--){let c=i[l];if(c.role==="user"&&!a)o.unshift(...this.convertMessageToInputItems(c,s)),a=true;else if(c.role==="tool"&&a)o.unshift(...this.convertMessageToInputItems(c,s));else if(a)break}return o}return i.flatMap(o=>this.convertMessageToInputItems(o,s)).filter(o=>o!==null)}convertMessageToInputItems(e,t){if(e.role==="assistant"){let n=[],i=se(e.content);if(i.trim().length>0&&n.push({type:"message",role:"assistant",status:"completed",content:[{type:"input_text",text:i}]}),Array.isArray(e.tool_calls)&&e.tool_calls.length>0)for(let o of e.tool_calls){let a=this.normalizeCallId(o.id,t);n.push({type:"function_call",id:a,call_id:a,name:o.function.name,arguments:o.function.arguments||"",status:"completed"});}return n}if(e.role==="tool"){let n=this.normalizeCallId(e.tool_call_id||e.name,t),i=se(e.content),o=Tf(i);return [{type:"function_call_output",call_id:n,output:o}]}if(Array.isArray(e.content)){let n=[];for(let i of e.content)i.type==="text"&&i.text.trim()?n.push({type:"input_text",text:i.text}):i.type==="image_url"&&n.push({type:"input_image",image_url:i.image_url.url});return n.length===0?[]:[{type:"message",role:"user",content:n}]}let s=se(e.content);return !s||s.trim().length===0?[]:[{type:"message",role:"user",content:[{type:"input_text",text:s}]}]}normalizeCallId(e,t){if(e&&t.has(e))return t.get(e);let s;return e?s=e.startsWith("fc_")?e:`fc_${e}`:s=`fc_${Math.random().toString(36).slice(2,10)}`,e?t.set(e,s):t.set(s,s),s}async*parseStreamResponse(e){let t="",s=new Map,n=0,i=null,o=null,a=false,l=false,c,u=d=>{let m={...d};return l||(m.role="assistant",l=true),{id:c,choices:[{index:0,delta:m}]}};for await(let d of e){t+=d.toString();let m=t.split(`
|
|
1756
1756
|
`);t=m.pop()||"";for(let h of m){let g=h.trim();if(!g||!g.startsWith("data: "))continue;let y=g.slice(6);if(y==="[DONE]"){process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Doubao Stream] Received [DONE]");continue}let b;try{b=JSON.parse(y);}catch{process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Doubao Stream] Invalid JSON:",y);continue}switch(process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[Doubao Stream Event]",b.type,JSON.stringify(b,null,2).slice(0,200)),b.type){case "response.created":case "response.in_progress":b.response?.id&&(c=b.response.id);break;case "response.output_text.delta":{let w=typeof b.delta=="string"?b.delta:"";if(!w)break;a=true,yield u({content:w});break}case "response.reasoning_summary_text.delta":{let w=typeof b.delta=="string"?b.delta:"";if(!w)break;a=true,yield u({reasoning_content:w});break}case "response.reasoning_summary_part.added":case "response.reasoning_summary_part.done":break;case "response.output_item.added":{if(b.item?.type==="function_call"){let w=b.item,S=w.id||`item_${b.output_index}`,x={id:w.call_id||w.id||`call_${Date.now()}_${n}`,name:w.name,index:n++,arguments:""};s.set(S,x),a=true,yield u({tool_calls:[{index:x.index,id:x.id,type:"function",function:{name:x.name}}]});}else if(b.item?.type==="reasoning"){let w=b.item;if(w.summary?.length>0){let S=w.summary.map(x=>x.text).join(`
|
|
1757
1757
|
`);S&&(yield u({reasoning_content:S}));}}break}case "response.function_call_arguments.delta":{let w=b.item_id?s.get(b.item_id):void 0;if(!w)break;let S=typeof b.delta=="string"?b.delta:"";if(!S)break;w.arguments+=S,a=true,yield u({tool_calls:[{index:w.index,id:w.id,type:"function",function:{name:w.name,arguments:S}}]});break}case "response.completed":{i=b.response||null,o=b.response?.usage||null,b.response?.id&&(c=b.response.id,this.lastResponseId=c);break}case "response.error":case "response.failed":{let w=b.error?.message||b.error?.code||"Doubao stream failed";throw new Error(w)}}}}if(!a&&i){let d=Array.isArray(i.output)?i.output:[],m="",h="";for(let g of d)if(g?.type==="message"&&Array.isArray(g.content))for(let y of g.content)y?.type==="output_text"&&typeof y.text=="string"&&(m+=y.text);else if(g?.type==="reasoning"){let y=g;y.summary?.length>0&&(h=y.summary.map(b=>b.text).join(`
|
|
1758
|
-
`));}(m||h)&&(yield {id:c,choices:[{index:0,delta:{role:"assistant",content:m||void 0,reasoning_content:h||void 0}}]});}let p={id:c,choices:[{index:0,delta:{},finish_reason:s.size>0?"tool_calls":"stop"}]};o&&(p.usage=this.normalizeUsage(o)),yield p;}normalizeUsage(e){let t={prompt_tokens:e.input_tokens||0,completion_tokens:e.output_tokens||0,total_tokens:e.total_tokens||0};return e.input_tokens_details?.cached_tokens!==void 0&&(t.cached_tokens=e.input_tokens_details.cached_tokens,t.prompt_tokens_details={cached_tokens:e.input_tokens_details.cached_tokens}),e.output_tokens_details?.reasoning_tokens!==void 0&&(t.completion_tokens_details={reasoning_tokens:e.output_tokens_details.reasoning_tokens}),t}};var
|
|
1758
|
+
`));}(m||h)&&(yield {id:c,choices:[{index:0,delta:{role:"assistant",content:m||void 0,reasoning_content:h||void 0}}]});}let p={id:c,choices:[{index:0,delta:{},finish_reason:s.size>0?"tool_calls":"stop"}]};o&&(p.usage=this.normalizeUsage(o)),yield p;}normalizeUsage(e){let t={prompt_tokens:e.input_tokens||0,completion_tokens:e.output_tokens||0,total_tokens:e.total_tokens||0};return e.input_tokens_details?.cached_tokens!==void 0&&(t.cached_tokens=e.input_tokens_details.cached_tokens,t.prompt_tokens_details={cached_tokens:e.input_tokens_details.cached_tokens}),e.output_tokens_details?.reasoning_tokens!==void 0&&(t.completion_tokens_details={reasoning_tokens:e.output_tokens_details.reasoning_tokens}),t}};var sa="# \u4F1A\u8BDD\u5386\u53F2\u6458\u8981",xf=60,Cf=200,Rf=`You are a highly skilled assistant tasked with summarizing conversation history.
|
|
1759
1759
|
|
|
1760
1760
|
Your goal is to create a concise yet comprehensive summary that captures:
|
|
1761
1761
|
1. The main topics and objectives discussed
|
|
@@ -1772,7 +1772,7 @@ Guidelines:
|
|
|
1772
1772
|
- Write in the same language as the conversation (Chinese if Chinese, English if English)
|
|
1773
1773
|
- Format the summary clearly with sections if needed
|
|
1774
1774
|
|
|
1775
|
-
Output only the summary, no additional commentary.`,
|
|
1775
|
+
Output only the summary, no additional commentary.`,Ef=`\u4F60\u662F\u4E00\u4E2A\u4E13\u4E1A\u7684\u5BF9\u8BDD\u5386\u53F2\u603B\u7ED3\u52A9\u624B\u3002
|
|
1776
1776
|
|
|
1777
1777
|
\u4F60\u7684\u76EE\u6807\u662F\u521B\u5EFA\u4E00\u4E2A\u7B80\u6D01\u4F46\u5168\u9762\u7684\u6458\u8981\uFF0C\u9700\u8981\u5305\u542B\uFF1A
|
|
1778
1778
|
1. \u8BA8\u8BBA\u7684\u4E3B\u8981\u4E3B\u9898\u548C\u76EE\u6807
|
|
@@ -1789,7 +1789,7 @@ Output only the summary, no additional commentary.`,wf=`\u4F60\u662F\u4E00\u4E2A
|
|
|
1789
1789
|
- \u4F7F\u7528\u4E0E\u5BF9\u8BDD\u76F8\u540C\u7684\u8BED\u8A00\uFF08\u4E2D\u6587\u5BF9\u8BDD\u7528\u4E2D\u6587\uFF0C\u82F1\u6587\u5BF9\u8BDD\u7528\u82F1\u6587\uFF09
|
|
1790
1790
|
- \u5982\u679C\u9700\u8981\uFF0C\u4F7F\u7528\u5206\u8282\u6765\u6E05\u6670\u5730\u683C\u5F0F\u5316\u6458\u8981
|
|
1791
1791
|
|
|
1792
|
-
\u53EA\u8F93\u51FA\u6458\u8981\uFF0C\u4E0D\u8981\u6DFB\u52A0\u989D\u5916\u7684\u8BC4\u8BBA\u3002`;function
|
|
1792
|
+
\u53EA\u8F93\u51FA\u6458\u8981\uFF0C\u4E0D\u8981\u6DFB\u52A0\u989D\u5916\u7684\u8BC4\u8BBA\u3002`;function If(r){for(let e of r){let t=se(e.content);if(/[\u4e00-\u9fa5]/.test(t))return "zh"}return "en"}function Mf(r){let e=[];for(let t of r){let s=t.role==="assistant"?"Assistant":t.role==="user"?"User":t.role==="tool"?"Tool Result":t.role,n=se(t.content),i="";if(t.tool_calls?.length&&(i=` [Called tools: ${t.tool_calls.map(a=>a.function.name).join(", ")}]`),n||i){let o=n.length>1e3?n.slice(0,1e3)+"...[truncated]":n;e.push(`[${s}]${i}
|
|
1793
1793
|
${o}`);}}return `Please summarize the following conversation history:
|
|
1794
1794
|
|
|
1795
1795
|
---
|
|
@@ -1799,18 +1799,18 @@ ${e.join(`
|
|
|
1799
1799
|
`)}
|
|
1800
1800
|
---
|
|
1801
1801
|
|
|
1802
|
-
Provide a comprehensive summary:`}function
|
|
1802
|
+
Provide a comprehensive summary:`}function qn(r){let t=se(r.content).length,s=r.tool_calls?JSON.stringify(r.tool_calls).length:0;return Math.ceil((t+s)/4)}function ra(r,e){return r.length<=e?r:r.slice(0,e-1).trimEnd()+"\u2026"}function Af(r){return r.replace(/\s+/g," ").trim()}function na(r,e){if(r.length===0)return {summary:"",lines:0};let t=[];for(let n of r){if(t.length>=xf)break;let i=n.role==="assistant"?"Assistant":n.role==="user"?"User":n.role,o=se(n.content),l=(o?Af(o):"")||(n.tool_calls?.length?`Tool calls: ${n.tool_calls.map(c=>c.function.name).join(", ")}`:"No textual content");t.push(`- [${i}] ${ra(l,Cf)}`);}return {summary:`${e}
|
|
1803
1803
|
${t.join(`
|
|
1804
|
-
`)}`,lines:t.length}}async function
|
|
1804
|
+
`)}`,lines:t.length}}async function ia(r){let{session:e,profile:t,llmProvider:s,model:n,onProgress:i,timeout:o=6e4,signal:a}=r,l=r.tailTokenBudget??t.tailTokenBudget??2e4;if(!l||l<=0)return null;i?.("analyzing","Analyzing conversation history...");let c=await e.getTimeline(),u=c.map((P,q)=>({entry:P,index:q})).filter(({entry:P})=>P.item.type==="message");if(u.length===0)return null;u.filter(({entry:P})=>P.item.data.role==="system");let d=u.filter(({entry:P})=>P.item.data.role!=="system");if(d.length===0)return null;let m=0,h=d.length;for(let P=d.length-1;P>=0;P--){let q=d[P].entry.item.data;if(m+=qn(q),m>=l){h=P;break}}if(h>=d.length){if(d.length<=2)return null;h=Math.floor(d.length/2);}let g=d.slice(0,h).map(({entry:P})=>P.item.data);if(g.length===0)return null;let y={userTokens:0,assistantTokens:0,toolTokens:0,totalTokens:0};for(let P of g){let q=qn(P);P.role==="user"?y.userTokens+=q:P.role==="assistant"?y.assistantTokens+=q:P.role==="tool"&&(y.toolTokens+=q),y.totalTokens+=q;}let b=d.slice(h).map(({entry:P})=>P.item.data),w={userTokens:0,assistantTokens:0,toolTokens:0,totalTokens:0};for(let P of b){let q=qn(P);P.role==="user"?w.userTokens+=q:P.role==="assistant"?w.assistantTokens+=q:P.role==="tool"&&(w.toolTokens+=q),w.totalTokens+=q;}let S=y.totalTokens;i?.("summarizing",`Summarizing ${g.length} messages with AI...`);let x=If(g),R=x==="zh"?Ef:Rf,$=Mf(g),G,U;try{let P=new AbortController,q=setTimeout(()=>P.abort(),o),B=a?AbortSignal.any([a,P.signal]):P.signal;try{let j=await s.chat([{role:"system",content:R},{role:"user",content:$}],{model:n,temperature:.3,signal:B});clearTimeout(q),G=se(j.choices[0]?.message?.content)||"",U=j.usage?.total_tokens;}catch(j){throw clearTimeout(q),j?.name==="AbortError"||j?.code==="ABORT_ERR"?console.warn("[SmartCompact] LLM call timed out or was cancelled, falling back to lightweight"):console.error("[SmartCompact] LLM call failed:",j.message),j}if(!G.trim()){console.warn("[SmartCompact] LLM returned empty summary, falling back to lightweight");let{summary:j}=na(g,sa);G=j;}}catch(P){console.error("[SmartCompact] LLM call failed, falling back to lightweight:",P.message);let{summary:q}=na(g,sa);G=q;}i?.("saving","Saving compacted history...");let C=`${x==="zh"?"# \u5BF9\u8BDD\u5386\u53F2\u6458\u8981\uFF08AI \u751F\u6210\uFF09":"# Conversation Summary (AI Generated)"}
|
|
1805
1805
|
|
|
1806
|
-
${
|
|
1807
|
-
`)?`echo "${this.escapeShellArg(s)}" > ${this.escapeShellPath(t)}`:`# Use editor to create ${t}`}escapeShellArg(e){return e.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}escapeShellPath(e){return /[\s()[\]{}$`!*?<>|&;]/.test(e)?`"${this.escapeShellArg(e)}"`:e}};function Ws(r,e){let t=["path","file_path","filePath","filename","directory","folder","dir","file","output_path","input_path"];for(let s of t)if(e[s]&&typeof e[s]=="string")return e[s];switch(r){case "Execute":case "execute":if(e.command&&typeof e.command=="string"){let n=e.command,i=n.match(/(?:^|\s)([./~][\w/.-]+\.\w+)(?:\s|$)/);return i?i[1]:n.substring(0,50)+(n.length>50?"...":"")}break;case "search":return e.path||e.directory||".";case "Glob":case "find_files":let s=e.folder||e.path||".";return e.patterns&&Array.isArray(e.patterns)?`${s} (${e.patterns.join(", ")})`:s;case "read_multiple_files":if(e.files&&Array.isArray(e.files))return e.files.length>1?`${e.files.length} files`:e.files[0];break}}function au(r,e){let t=ou(r);if(t)return `MCP ${t.serverId}/${t.toolName}`;switch(r){case "readfile":let s=Ws(r,e);return s?`Reading ${s}`:"Reading file";case "write_file":case "create_file":let n=Ws(r,e);return n?`Writing ${n}`:"Writing file";case "edit_file":case "Edit":let i=Ws(r,e);return i?`Editing ${i}`:"Editing file";case "search":let o=e.pattern||e.query;return o?`Searching for "${o}"`:"Searching code";case "list_directory":case "LS":return `Listing ${Ws(r,e)||"."}`;case "Glob":case "find_files":return e.patterns&&Array.isArray(e.patterns)?`Finding files: ${e.patterns.join(", ")}`:"Finding files";case "Execute":case "execute":let l=e.command||"";return l.length>60?`Running: ${l.substring(0,60)}...`:`Running: ${l}`;case "read_multiple_files":return e.files&&Array.isArray(e.files)?`Reading ${e.files.length} files`:"Reading multiple files";default:return `Executing ${r}`}}var pi=class{batchTimeWindow;activeBatches=new Map;pendingCalls=new Map;batchableTools=new Set(["readfile","write_file","create_file","list_directory","LS","Glob","find_files","read_multiple_files"]);constructor(e=200){this.batchTimeWindow=e;}detectBatch(e,t,s,n,i){if(!this.isBatchable(t))return {type:"single",merge:false};let o=this.pendingCalls.get(t)||[];if(o.length===0)return this.pendingCalls.set(t,[{toolId:e,toolName:t,targetPath:s,startTime:i,args:n}]),{type:"single",merge:false};let a=o[o.length-1];if(i-a.startTime>this.batchTimeWindow)return this.pendingCalls.set(t,[{toolId:e,toolName:t,targetPath:s,startTime:i,args:n}]),{type:"single",merge:false};if(o.some(u=>u.targetPath===s))return {type:"single",merge:false};if(o.length===1){let u=this.createBatch(a,e,s,i);return o.push({toolId:e,toolName:t,targetPath:s,startTime:i,args:n}),{type:"batch",merge:false,batchId:u,shouldCreateBatch:true}}else {let u=this.findActiveBatch(t);return u?(o.push({toolId:e,toolName:t,targetPath:s,startTime:i,args:n}),this.updateBatch(u,s,i),{type:"batch",merge:true,batchId:u}):(this.pendingCalls.set(t,[{toolId:e,toolName:t,targetPath:s,startTime:i,args:n}]),{type:"single",merge:false})}}recordCompletion(e,t){let s=this.findActiveBatch(e);if(s){let n=this.activeBatches.get(s);n&&(n.completed++,n.completed>=n.total&&this.completeBatch(s));}}getBatchInfo(e){return this.activeBatches.get(e)}isBatchable(e){return this.batchableTools.has(e)}createBatch(e,t,s,n){let i=`batch-${e.toolName}-${n}`;return this.activeBatches.set(i,{batchId:i,toolName:e.toolName,targets:[e.targetPath,s],startTime:e.startTime,lastCallTime:n,completed:0,total:2}),i}updateBatch(e,t,s){let n=this.activeBatches.get(e);n&&(n.targets.push(t),n.total++,n.lastCallTime=s);}findActiveBatch(e){for(let[t,s]of this.activeBatches.entries())if(s.toolName===e)return t}completeBatch(e){this.activeBatches.delete(e);let t=this.activeBatches.get(e);t&&this.pendingCalls.delete(t.toolName);}cleanupExpiredBatches(e){let t=this.batchTimeWindow*5,s=[];this.activeBatches.forEach((i,o)=>{e-i.lastCallTime>t&&s.push(o);}),s.forEach(i=>this.completeBatch(i));let n=[];this.pendingCalls.forEach((i,o)=>{if(i.length>0){let a=i[i.length-1];e-a.startTime>t&&n.push(o);}}),n.forEach(i=>this.pendingCalls.delete(i));}reset(){this.activeBatches.clear(),this.pendingCalls.clear();}getStats(){let e=[];return this.activeBatches.forEach((t,s)=>{e.push({batchId:s,toolName:t.toolName,total:t.total,completed:t.completed});}),{activeBatches:this.activeBatches.size,pendingCalls:this.pendingCalls.size,batches:e}}};de();var vf={default:["Thinking...","Processing...","Analyzing...","Pondering...","Contemplating..."]};var di={};function xf(r,e,t=true){di[e]||(di[e]=0);let s=di[e]%r.length,n=r[s];return t&&(di[e]=(s+1)%r.length),n}function lu(){let r=vf.default;return xf(r,"default")}function cu(r){if(!r||r.trim().length===0)return null;let e=r.trim();if(!e.endsWith("}")){let l=e+"}";try{return JSON.parse(l),console.log("[JsonRepair] Fixed by adding closing }"),l}catch{}}let t=e.replace(/,\s*$/,"");if(!t.endsWith("}")){let l=t+"}";try{return JSON.parse(l),console.log("[JsonRepair] Fixed by removing trailing comma and adding }"),l}catch{}}if(e.lastIndexOf('"')>0){let l=0,c=false;for(let u=0;u<e.length;u++){if(c){c=false;continue}if(e[u]==="\\"){c=true;continue}e[u]==='"'&&l++;}if(l%2===1){let u=e+'"}';try{return JSON.parse(u),console.log("[JsonRepair] Fixed by closing unclosed string"),u}catch{}}}let n=0,i=0,o=false,a=false;for(let l of e){if(a){a=false;continue}if(l==="\\"){a=true;continue}if(l==='"'){o=!o;continue}o||(l==="{"?n++:l==="}"?n--:l==="["?i++:l==="]"&&i--);}for(o&&(e+='"');i>0;)e+="]",i--;for(;n>0;)e+="}",n--;try{return JSON.parse(e),console.log("[JsonRepair] Fixed by force-closing structures"),e}catch{return null}}function uu(r,e){if(!e||e.trim().length===0)return {isTruncated:false};if(!e.trim().endsWith("}"))return {isTruncated:true,reason:"JSON structure incomplete - missing closing brace"};if(r==="write_file"||r==="edit_file"){if(!e.includes('"content"')&&!e.includes('"new_string"'))return {isTruncated:true,reason:"File content field is missing - likely truncated during streaming"};let s=e.match(/"content"\s*:\s*"([^]*)/);if(s){let n=s[1],i=0,o=false;for(let a of n){if(o){o=false;continue}if(a==="\\"){o=true;continue}if(a==='"'){i++;break}}if(i===0)return {isTruncated:true,reason:"Content string is unclosed - truncated during streaming"}}}return {isTruncated:false}}function pu(r,e,t){let s=kc(r,e,t),n=Hr(s);return {success:false,error:s.code,code:s.code,category:s.category,message:s.message,suggestion:n,retryable:s.retryable,receivedArgs:e?.substring(0,500)}}var mu=12e3,mi=class{runner;memory;sessionManager;sessionSync;session;sessionEnabled;memoryPressure;compatProfile;workDir;model;systemPrompt;sandboxSetter;llmProvider;sessionSeed;sessionTotalInputTokens=0;sessionTotalOutputTokens=0;lastMemoryPressureState="unknown";autoCompactionInProgress=false;isRunning=false;shouldInterrupt=false;abortController=null;interruptResolver=null;interruptPromise=null;compressionMode="sync";eventEmitter=new EventEmitter;descriptionExtractor=new ci;commandGenerator=new ui;lastAssistantMessage="";batchDetector=new pi;toolCallIdCounter=0;recentToolCalls=new Map;currentTaskMetadata;pendingInjectedMessages=[];constructor(e){this.runner=e.runner,this.memory=e.memory,this.sessionManager=e.sessionManager,this.sessionSync=e.sessionSync,this.session=e.session,this.sessionEnabled=e.sessionEnabled??true,this.workDir=Y__default.resolve(e.workDir),this.model=e.model,this.systemPrompt=e.systemPrompt,this.memoryPressure=e.memoryPressure,this.compatProfile=e.compatProfile,this.sandboxSetter=e.setSandboxMode,this.llmProvider=e.llmProvider,this.sessionSeed=randomBytes(16).toString("hex"),this.syncWorkspaceEnv(),this.applyAnthropicSessionUserId();}on(e){return this.eventEmitter.on("event",e),()=>this.eventEmitter.off("event",e)}setWorkDir(e){this.workDir=Y__default.resolve(e),this.syncWorkspaceEnv();}setSession(e,t){this.session=e||void 0,this.sessionSync=t,this.applyAnthropicSessionUserId();}applyAnthropicSessionUserId(){let t=this.llmProvider?.getProvider?.();if(!t||typeof t.setUserId!="function")return;let s=this.session?.sessionId,n=Wa(s,this.sessionSeed);t.setUserId(n);}interrupt(){this.shouldInterrupt=true,this.abortController&&this.abortController.abort(),this.interruptResolver&&this.interruptResolver();}createInterruptPromise(){return this.interruptPromise?this.interruptPromise:(this.interruptPromise=new Promise(e=>{this.interruptResolver=()=>e({interrupted:true});}),this.interruptPromise)}clearInterruptPromise(){this.interruptResolver=null,this.interruptPromise=null;}emitEvent(e){if(e.type==="plan_update"&&f.info("EMIT_EVENT","\u{1F525} Emitting plan_update via eventEmitter",{listenerCount:this.eventEmitter.listenerCount("event"),hasExplanation:!!e.explanation,planSteps:e.plan?.length}),e.type==="text"&&process.env.CLI_DEBUG==="1"){let t=e.delta||"";f.debug("EMIT_EVENT",`Emitting text event: "${t.substring(0,20)}...", listeners=${this.eventEmitter.listenerCount("event")}`);}this.eventEmitter.emit("event",e),e.type==="plan_update"&&f.info("EMIT_EVENT","\u2705 plan_update emitted");}emitLog(e,t,s){process.env.CLI_DEBUG&&(f.debug("EMIT",`emitLog: level=${e}, message="${t.substring(0,50)}..."`),f.debug("EMIT",` eventEmitter.listenerCount: ${this.eventEmitter.listenerCount("event")}`)),this.emitEvent({type:"log",level:e,message:t,detail:s});}emitCompacting(e,t){process.env.CLI_DEBUG&&f.debug("EMIT",`emitCompacting: message="${e.substring(0,50)}..."`),this.emitEvent({type:"compacting",message:e,detail:t});}injectUserMessage(e,t){if(!this.isRunning)return f.debug("INJECT","Cannot inject message: no task running"),0;this.pendingInjectedMessages.push({text:e,timestamp:new Date,images:t});let s=this.pendingInjectedMessages.length;return f.info("INJECT",`\u{1F4E8} Message queued at position ${s}: "${e.substring(0,50)}..."`),this.emitEvent({type:"queued_message_added",position:s,text:e}),s}hasPendingInjectedMessages(){return this.pendingInjectedMessages.length>0}getPendingMessagesForDisplay(){return [...this.pendingInjectedMessages]}getAndClearPendingMessages(){let e=[...this.pendingInjectedMessages];return this.pendingInjectedMessages=[],e}processPendingInjectedMessages(){if(this.pendingInjectedMessages.length===0)return 0;let e=[...this.pendingInjectedMessages];this.pendingInjectedMessages=[],process.env.CLI_DEBUG&&f.debug("INJECT",`Processing ${e.length} injected messages`);for(let t of e){let s=[];if(t.text&&s.push({type:"text",text:t.text}),t.images&&t.images.length>0)for(let i of t.images)s.push({type:"image",source:{type:"base64",media_type:i.mediaType,data:i.data}});let n={role:"user",content:s.length===1&&s[0].type==="text"?s[0].text:s};this.memory.add(n);}return e.length}updateRuntime(e){this.runner=e.runner,this.memory=e.memory,this.model=e.model,e.systemPrompt&&(this.systemPrompt=e.systemPrompt);}setCompressionMode(e){this.compressionMode=e,f.info("RUNTIME",`Compression mode set to: ${e}`);}getCompressionMode(){return this.compressionMode}prepareTaskInput(e,t){let s=e,n=t?.attachments?.filter(i=>i.type==="url")||[];return n.length>0&&(s=`Attachments:
|
|
1806
|
+
${G}`,_=u.length-g.length,k=u[0]?.entry.timestamp??Date.now(),D={item:{type:"message",data:{role:"user",content:C,name:"SmartCompactSummary"}},timestamp:k,seq:0},N={item:{type:"compacted",data:{summary:ra(G,2e3),originalCount:g.length,compactedAt:new Date().toISOString(),method:"smart",llmTokensUsed:U}},timestamp:k,seq:0},E=[],A=false,F=new Set(d.slice(0,h).map(({entry:P})=>P));for(let P of c){if(P.item.type!=="message"){E.push({...P});continue}if(P.item.data.role==="system"){E.push({...P});continue}F.has(P)?A||(E.push({...D}),E.push({...N}),A=true):E.push({...P});}if(!A)return null;let H=E.map((P,q)=>({item:P.item,timestamp:P.timestamp??Date.now(),seq:q}));await e.replaceTimeline(H);let M=qn({content:C}),ee={before:y,after:{userTokens:w.userTokens,assistantTokens:w.assistantTokens,toolTokens:w.toolTokens,summaryTokens:M,totalTokens:w.totalTokens+M},saved:{userTokens:y.userTokens,assistantTokens:y.assistantTokens,toolTokens:y.toolTokens,totalTokens:y.totalTokens-M}};return {removedMessages:g.length,keptMessages:_,summaryText:C,estimatedTokensSaved:S,llmTokensUsed:U,detailedStats:ee}}async function pu(r){let{session:e,profile:t}=r,s=r.tailTokenBudget??t.tailTokenBudget??2e4;if(!s||s<=0)return null;let n=await e.getTimeline(),i=n.map((R,$)=>({entry:R,index:$})).filter(({entry:R})=>R.item.type==="message");if(i.length===0)return null;i.filter(({entry:R})=>R.item.data.role==="system");let a=i.filter(({entry:R})=>R.item.data.role!=="system");if(a.length===0)return null;let l=0,c=a.length;for(let R=a.length-1;R>=0;R--){let $=a[R].entry.item.data;if(l+=qn($),l>=s){c=R;break}}if(c>=a.length){if(a.length<=2)return null;c=Math.floor(a.length/2);}let u=a.slice(0,c).map(({entry:R})=>R.item.data);if(u.length===0)return null;let{summary:p,lines:d}=na(u,r.summaryHeader??sa);if(!p.trim())return null;let m=a.length-u.length,h=a[0]?.entry.timestamp??Date.now(),g={item:{type:"message",data:{role:"user",content:p,name:"CompatSummary"}},timestamp:h,seq:0},y={item:{type:"compacted",data:{summary:ra(p,2e3),originalCount:u.length,compactedAt:new Date().toISOString()}},timestamp:h,seq:0},b=[],w=false,S=new Set(a.slice(0,c).map(({entry:R})=>R));for(let R of n){if(R.item.type!=="message"){b.push({...R});continue}if(R.item.data.role==="system"){b.push({...R});continue}S.has(R)?w||(b.push({...g}),b.push({...y}),w=true):b.push({...R});}if(!w)return null;let x=b.map((R,$)=>({item:R.item,timestamp:R.timestamp??Date.now(),seq:$}));return await e.replaceTimeline(x),{removedMessages:u.length,keptMessages:m,summaryText:p,summaryLines:d}}function du(r){if(!r.startsWith("mcp__"))return null;let e=r.split("__");if(e.length<3)return null;let t=e[1],s=e.slice(2).join("__");return !t||!s?null:{serverId:t,toolName:s}}var di=class{extractFromAssistantMessage(e,t){if(!e||e.length===0)return;let s=[/I(?:'ll| will) (\w+.*?) to (.*?)(?:\.|$)/i,/Let me (\w+.*?) to (.*?)(?:\.|$)/i,/(?:I'm|I am) going to (\w+.*?) to (.*?)(?:\.|$)/i,/(?:I'm|I am) (\w+ing.*?) to (.*?)(?:\.|$)/i,/To (.*?)[,,] I(?:'ll| will) (\w+.*?)(?:\.|$)/i,/(?:First|Now|Next|Then)[,,] (?:I'll |I will |let me )?(\w+.*?)(?:\.|$)/i,/(?:我将|我会|让我)([^。,,]+)(?:来|以便|用于)([^。,,]+)/,/(?:首先|现在|接下来|然后)[,,](?:我将|我会|让我)?([^。,,]+)/];for(let o of s){let a=e.match(o);if(a){let l=a[2]||a[1];if(l&&l.length>0&&l.length<200)return l.trim()}}let n=t.toLowerCase(),i=e.split(/[.。!!??]/);for(let o of i)if(o.toLowerCase().includes(n)||o.toLowerCase().includes("read")||o.toLowerCase().includes("search")||o.toLowerCase().includes("file")){let a=o.trim();if(a.length>10&&a.length<200)return a}}extractActionFromToolName(e){return {readfile:"read",write_file:"write",create_file:"create",edit_file:"edit",Edit:"edit",search:"search",list_directory:"list",LS:"list",Glob:"find",find_files:"find",Execute:"execute",execute:"execute"}[e]||e.toLowerCase()}},mi=class{generateEquivalentCommand(e,t){switch(e){case "search":return this.generateSearchCommand(t);case "Glob":case "find_files":return this.generateFindCommand(t);case "Execute":case "execute":return this.generateExecuteCommand(t);case "readfile":return this.generateReadCommand(t);case "list_directory":case "LS":return this.generateLsCommand(t);case "write_file":case "create_file":return this.generateWriteCommand(t);default:return}}generateSearchCommand(e){let t="rg";e.case_insensitive&&(t+=" -i"),e.line_numbers&&(t+=" -n"),e.context_lines?t+=` -C ${e.context_lines}`:e.context?t+=` -C ${e.context}`:(e.context_before&&(t+=` -B ${e.context_before}`),e.context_after&&(t+=` -A ${e.context_after}`));let s=e.pattern||"";t+=` "${this.escapeShellArg(s)}"`;let n=e.path||e.directory||".";return t+=` ${this.escapeShellPath(n)}`,e.type&&(t+=` --type=${e.type}`),e.file_pattern?t+=` -g "${this.escapeShellArg(e.file_pattern)}"`:e.glob_pattern&&(t+=` -g "${this.escapeShellArg(e.glob_pattern)}"`),t}generateFindCommand(e){let t="find",s=e.folder||e.path||".";if(t+=` ${this.escapeShellPath(s)}`,e.patterns&&Array.isArray(e.patterns)&&e.patterns.length>0)if(e.patterns.length===1)t+=` -name "${this.escapeShellArg(e.patterns[0])}"`;else {let n=e.patterns.map(i=>`-name "${this.escapeShellArg(i)}"`).join(" -o ");t+=` \\( ${n} \\)`;}return e.excludePatterns&&Array.isArray(e.excludePatterns)&&e.excludePatterns.forEach(n=>{t+=` ! -path "${this.escapeShellArg(n)}"`;}),e.maxDepth&&(t+=` -maxdepth ${e.maxDepth}`),e.type==="f"?t+=" -type f":e.type==="d"&&(t+=" -type d"),t}generateExecuteCommand(e){return e.command||""}generateReadCommand(e){let t=e.path||e.file_path||e.filename||"";if(e.start_line&&e.num_lines){let s=e.start_line+e.num_lines-1;return `sed -n '${e.start_line},${s}p' ${this.escapeShellPath(t)}`}return e.num_lines&&!e.start_line?`head -n ${e.num_lines} ${this.escapeShellPath(t)}`:`cat ${this.escapeShellPath(t)}`}generateLsCommand(e){let t="ls";(e.all||e.show_hidden)&&(t+=" -a"),(e.long||e.detailed)&&(t+=" -l"),t.includes("-")||(t+=" -la");let s=e.path||e.directory||e.directory_path||".";return t+=` ${this.escapeShellPath(s)}`,t}generateWriteCommand(e){let t=e.path||e.file_path||e.filename||"",s=e.content||"";return s.length<100&&!s.includes(`
|
|
1807
|
+
`)?`echo "${this.escapeShellArg(s)}" > ${this.escapeShellPath(t)}`:`# Use editor to create ${t}`}escapeShellArg(e){return e.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}escapeShellPath(e){return /[\s()[\]{}$`!*?<>|&;]/.test(e)?`"${this.escapeShellArg(e)}"`:e}};function Hs(r,e){let t=["path","file_path","filePath","filename","directory","folder","dir","file","output_path","input_path"];for(let s of t)if(e[s]&&typeof e[s]=="string")return e[s];switch(r){case "Execute":case "execute":if(e.command&&typeof e.command=="string"){let n=e.command,i=n.match(/(?:^|\s)([./~][\w/.-]+\.\w+)(?:\s|$)/);return i?i[1]:n.substring(0,50)+(n.length>50?"...":"")}break;case "search":return e.path||e.directory||".";case "Glob":case "find_files":let s=e.folder||e.path||".";return e.patterns&&Array.isArray(e.patterns)?`${s} (${e.patterns.join(", ")})`:s;case "read_multiple_files":if(e.files&&Array.isArray(e.files))return e.files.length>1?`${e.files.length} files`:e.files[0];break}}function mu(r,e){let t=du(r);if(t)return `MCP ${t.serverId}/${t.toolName}`;switch(r){case "readfile":let s=Hs(r,e);return s?`Reading ${s}`:"Reading file";case "write_file":case "create_file":let n=Hs(r,e);return n?`Writing ${n}`:"Writing file";case "edit_file":case "Edit":let i=Hs(r,e);return i?`Editing ${i}`:"Editing file";case "search":let o=e.pattern||e.query;return o?`Searching for "${o}"`:"Searching code";case "list_directory":case "LS":return `Listing ${Hs(r,e)||"."}`;case "Glob":case "find_files":return e.patterns&&Array.isArray(e.patterns)?`Finding files: ${e.patterns.join(", ")}`:"Finding files";case "Execute":case "execute":let l=e.command||"";return l.length>60?`Running: ${l.substring(0,60)}...`:`Running: ${l}`;case "read_multiple_files":return e.files&&Array.isArray(e.files)?`Reading ${e.files.length} files`:"Reading multiple files";default:return `Executing ${r}`}}var hi=class{batchTimeWindow;activeBatches=new Map;pendingCalls=new Map;batchableTools=new Set(["readfile","write_file","create_file","list_directory","LS","Glob","find_files","read_multiple_files"]);constructor(e=200){this.batchTimeWindow=e;}detectBatch(e,t,s,n,i){if(!this.isBatchable(t))return {type:"single",merge:false};let o=this.pendingCalls.get(t)||[];if(o.length===0)return this.pendingCalls.set(t,[{toolId:e,toolName:t,targetPath:s,startTime:i,args:n}]),{type:"single",merge:false};let a=o[o.length-1];if(i-a.startTime>this.batchTimeWindow)return this.pendingCalls.set(t,[{toolId:e,toolName:t,targetPath:s,startTime:i,args:n}]),{type:"single",merge:false};if(o.some(u=>u.targetPath===s))return {type:"single",merge:false};if(o.length===1){let u=this.createBatch(a,e,s,i);return o.push({toolId:e,toolName:t,targetPath:s,startTime:i,args:n}),{type:"batch",merge:false,batchId:u,shouldCreateBatch:true}}else {let u=this.findActiveBatch(t);return u?(o.push({toolId:e,toolName:t,targetPath:s,startTime:i,args:n}),this.updateBatch(u,s,i),{type:"batch",merge:true,batchId:u}):(this.pendingCalls.set(t,[{toolId:e,toolName:t,targetPath:s,startTime:i,args:n}]),{type:"single",merge:false})}}recordCompletion(e,t){let s=this.findActiveBatch(e);if(s){let n=this.activeBatches.get(s);n&&(n.completed++,n.completed>=n.total&&this.completeBatch(s));}}getBatchInfo(e){return this.activeBatches.get(e)}isBatchable(e){return this.batchableTools.has(e)}createBatch(e,t,s,n){let i=`batch-${e.toolName}-${n}`;return this.activeBatches.set(i,{batchId:i,toolName:e.toolName,targets:[e.targetPath,s],startTime:e.startTime,lastCallTime:n,completed:0,total:2}),i}updateBatch(e,t,s){let n=this.activeBatches.get(e);n&&(n.targets.push(t),n.total++,n.lastCallTime=s);}findActiveBatch(e){for(let[t,s]of this.activeBatches.entries())if(s.toolName===e)return t}completeBatch(e){this.activeBatches.delete(e);let t=this.activeBatches.get(e);t&&this.pendingCalls.delete(t.toolName);}cleanupExpiredBatches(e){let t=this.batchTimeWindow*5,s=[];this.activeBatches.forEach((i,o)=>{e-i.lastCallTime>t&&s.push(o);}),s.forEach(i=>this.completeBatch(i));let n=[];this.pendingCalls.forEach((i,o)=>{if(i.length>0){let a=i[i.length-1];e-a.startTime>t&&n.push(o);}}),n.forEach(i=>this.pendingCalls.delete(i));}reset(){this.activeBatches.clear(),this.pendingCalls.clear();}getStats(){let e=[];return this.activeBatches.forEach((t,s)=>{e.push({batchId:s,toolName:t.toolName,total:t.total,completed:t.completed});}),{activeBatches:this.activeBatches.size,pendingCalls:this.pendingCalls.size,batches:e}}};me();var Pf={default:["Thinking...","Processing...","Analyzing...","Pondering...","Contemplating..."]};var gi={};function Of(r,e,t=true){gi[e]||(gi[e]=0);let s=gi[e]%r.length,n=r[s];return t&&(gi[e]=(s+1)%r.length),n}function hu(){let r=Pf.default;return Of(r,"default")}function gu(r){if(!r||r.trim().length===0)return null;let e=r.trim();if(!e.endsWith("}")){let l=e+"}";try{return JSON.parse(l),console.log("[JsonRepair] Fixed by adding closing }"),l}catch{}}let t=e.replace(/,\s*$/,"");if(!t.endsWith("}")){let l=t+"}";try{return JSON.parse(l),console.log("[JsonRepair] Fixed by removing trailing comma and adding }"),l}catch{}}if(e.lastIndexOf('"')>0){let l=0,c=false;for(let u=0;u<e.length;u++){if(c){c=false;continue}if(e[u]==="\\"){c=true;continue}e[u]==='"'&&l++;}if(l%2===1){let u=e+'"}';try{return JSON.parse(u),console.log("[JsonRepair] Fixed by closing unclosed string"),u}catch{}}}let n=0,i=0,o=false,a=false;for(let l of e){if(a){a=false;continue}if(l==="\\"){a=true;continue}if(l==='"'){o=!o;continue}o||(l==="{"?n++:l==="}"?n--:l==="["?i++:l==="]"&&i--);}for(o&&(e+='"');i>0;)e+="]",i--;for(;n>0;)e+="}",n--;try{return JSON.parse(e),console.log("[JsonRepair] Fixed by force-closing structures"),e}catch{return null}}function fu(r,e){if(!e||e.trim().length===0)return {isTruncated:false};if(!e.trim().endsWith("}"))return {isTruncated:true,reason:"JSON structure incomplete - missing closing brace"};if(r==="write_file"||r==="edit_file"){if(!e.includes('"content"')&&!e.includes('"new_string"'))return {isTruncated:true,reason:"File content field is missing - likely truncated during streaming"};let s=e.match(/"content"\s*:\s*"([^]*)/);if(s){let n=s[1],i=0,o=false;for(let a of n){if(o){o=false;continue}if(a==="\\"){o=true;continue}if(a==='"'){i++;break}}if(i===0)return {isTruncated:true,reason:"Content string is unclosed - truncated during streaming"}}}return {isTruncated:false}}function yu(r,e,t){let s=Rc(r,e,t),n=Jr(s);return {success:false,error:s.code,code:s.code,category:s.category,message:s.message,suggestion:n,retryable:s.retryable,receivedArgs:e?.substring(0,500)}}var fi=class{state="idle";lastStatusKey="";lastStatusAt=0;shouldEmit(e){if(e.type==="status"){let t=e.timestamp??Date.now(),s=`${e.status}:${e.message}`;if(s===this.lastStatusKey&&t-this.lastStatusAt<200)return false;this.lastStatusKey=s,this.lastStatusAt=t;}return this.transition(e),true}getState(){return this.state}transition(e){switch(e.type){case "thinking":case "reasoning":case "reasoning_complete":case "text":this.state="thinking";return;case "tool_call_start":this.state="tool_running";return;case "tool_call_end":case "tool_output":this.state="thinking";return;case "status":e.status==="tool_call"?this.state="tool_running":e.status==="thinking"?this.state="thinking":e.status==="complete"?this.state="completed":e.status==="error"&&(this.state="error");return;case "run_result":this.state="completed";return;case "error":case "error_classified":this.state="error";return;default:return}}};var wu=12e3,yi=class{runner;memory;sessionManager;sessionSync;session;sessionEnabled;memoryPressure;compatProfile;workDir;model;systemPrompt;sandboxSetter;llmProvider;sessionSeed;sessionTotalInputTokens=0;sessionTotalOutputTokens=0;lastMemoryPressureState="unknown";autoCompactionInProgress=false;isRunning=false;shouldInterrupt=false;abortController=null;interruptResolver=null;interruptPromise=null;compressionMode="sync";eventEmitter=new EventEmitter;eventSequence=0;hostStateMachine=new fi;descriptionExtractor=new di;commandGenerator=new mi;lastAssistantMessage="";batchDetector=new hi;toolCallIdCounter=0;recentToolCalls=new Map;currentTaskMetadata;pendingInjectedMessages=[];constructor(e){this.runner=e.runner,this.memory=e.memory,this.sessionManager=e.sessionManager,this.sessionSync=e.sessionSync,this.session=e.session,this.sessionEnabled=e.sessionEnabled??true,this.workDir=X__default.resolve(e.workDir),this.model=e.model,this.systemPrompt=e.systemPrompt,this.memoryPressure=e.memoryPressure,this.compatProfile=e.compatProfile,this.sandboxSetter=e.setSandboxMode,this.llmProvider=e.llmProvider,this.sessionSeed=randomBytes(16).toString("hex"),this.syncWorkspaceEnv(),this.applyAnthropicSessionUserId();}on(e){return this.eventEmitter.on("event",e),()=>this.eventEmitter.off("event",e)}setWorkDir(e){this.workDir=X__default.resolve(e),this.syncWorkspaceEnv();}setSession(e,t){this.session=e||void 0,this.sessionSync=t,this.applyAnthropicSessionUserId();}applyAnthropicSessionUserId(){let t=this.llmProvider?.getProvider?.();if(!t||typeof t.setUserId!="function")return;let s=this.session?.sessionId,n=qa(s,this.sessionSeed);t.setUserId(n);}interrupt(){this.shouldInterrupt=true,this.abortController&&this.abortController.abort(),this.interruptResolver&&this.interruptResolver();}createInterruptPromise(){return this.interruptPromise?this.interruptPromise:(this.interruptPromise=new Promise(e=>{this.interruptResolver=()=>e({interrupted:true});}),this.interruptPromise)}clearInterruptPromise(){this.interruptResolver=null,this.interruptPromise=null;}emitEvent(e){let t=e;if(t.timestamp||(t.timestamp=Date.now()),t.sequence=++this.eventSequence,t.eventId=`${this.session?.sessionId||"runtime"}:${t.sequence}:${e.type}`,!!this.hostStateMachine.shouldEmit(t)){if(e.type==="plan_update"&&f.info("EMIT_EVENT","\u{1F525} Emitting plan_update via eventEmitter",{listenerCount:this.eventEmitter.listenerCount("event"),hasExplanation:!!e.explanation,planSteps:e.plan?.length}),e.type==="text"&&process.env.CLI_DEBUG==="1"){let s=e.delta||"";f.debug("EMIT_EVENT",`Emitting text event: "${s.substring(0,20)}...", listeners=${this.eventEmitter.listenerCount("event")}`);}this.eventEmitter.emit("event",t),e.type==="plan_update"&&f.info("EMIT_EVENT","\u2705 plan_update emitted");}}emitLog(e,t,s){process.env.CLI_DEBUG&&(f.debug("EMIT",`emitLog: level=${e}, message="${t.substring(0,50)}..."`),f.debug("EMIT",` eventEmitter.listenerCount: ${this.eventEmitter.listenerCount("event")}`)),this.emitEvent({type:"log",level:e,message:t,detail:s});}emitCompacting(e,t){process.env.CLI_DEBUG&&f.debug("EMIT",`emitCompacting: message="${e.substring(0,50)}..."`),this.emitEvent({type:"compacting",message:e,detail:t});}injectUserMessage(e,t){if(!this.isRunning)return f.debug("INJECT","Cannot inject message: no task running"),0;this.pendingInjectedMessages.push({text:e,timestamp:new Date,images:t});let s=this.pendingInjectedMessages.length;return f.info("INJECT",`\u{1F4E8} Message queued at position ${s}: "${e.substring(0,50)}..."`),this.emitEvent({type:"queued_message_added",position:s,text:e}),s}hasPendingInjectedMessages(){return this.pendingInjectedMessages.length>0}getPendingMessagesForDisplay(){return [...this.pendingInjectedMessages]}getAndClearPendingMessages(){let e=[...this.pendingInjectedMessages];return this.pendingInjectedMessages=[],e}processPendingInjectedMessages(){if(this.pendingInjectedMessages.length===0)return 0;let e=[...this.pendingInjectedMessages];this.pendingInjectedMessages=[],process.env.CLI_DEBUG&&f.debug("INJECT",`Processing ${e.length} injected messages`);for(let t of e){let s=[];if(t.text&&s.push({type:"text",text:t.text}),t.images&&t.images.length>0)for(let i of t.images)s.push({type:"image",source:{type:"base64",media_type:i.mediaType,data:i.data}});let n={role:"user",content:s.length===1&&s[0].type==="text"?s[0].text:s};this.memory.add(n);}return e.length}updateRuntime(e){this.runner=e.runner,this.memory=e.memory,this.model=e.model,e.systemPrompt&&(this.systemPrompt=e.systemPrompt);}setCompressionMode(e){this.compressionMode=e,f.info("RUNTIME",`Compression mode set to: ${e}`);}getCompressionMode(){return this.compressionMode}prepareTaskInput(e,t){let s=e,n=t?.attachments?.filter(i=>i.type==="url")||[];return n.length>0&&(s=`Attachments:
|
|
1808
1808
|
${n.map((o,a)=>`Attachment ${a+1}: [URL: ${o.data}]`).join(`
|
|
1809
1809
|
`)}
|
|
1810
1810
|
|
|
1811
1811
|
${s}`),t?.mode==="ask"&&(s=`Mode: ASK (respond conversationally and avoid unnecessary tool calls).
|
|
1812
1812
|
|
|
1813
|
-
${s}`),s.trim()}extractImageUrls(e){return e?.attachments?.length?e.attachments.filter(t=>t.type==="image"&&t.data).map(t=>t.data):[]}async handleMemorySnapshot(e,t=false){e&&(this.emitEvent({type:"memory_snapshot",snapshot:e}),await this.maybeAnnounceMemoryPressure(e,t));}async maybeAnnounceMemoryPressure(e,t=false){if(!e.profile.contextWindow){this.lastMemoryPressureState=e.state;return}let s={unknown:0,normal:1,warn:2,soft_limit:3,limit:4},n=s[this.lastMemoryPressureState]??0;if((s[e.state]??0)>n&&e.state!=="normal"&&e.state!=="unknown"){let o=e.pressure!==void 0?Math.round(e.pressure*100):void 0,a=`${e.tokensUsed.toLocaleString()} / ${e.profile.contextWindow.toLocaleString()} tokens`,l="\u4E0A\u4E0B\u6587\u538B\u529B\u5DF2\u5347\u9AD8\uFF0C\u5EFA\u8BAE\u5C3D\u5FEB\u6267\u884C /compact \u6216\u4F7F\u7528 /new \u5F00\u542F\u65B0\u4F1A\u8BDD\u3002";e.state==="soft_limit"?l="\u4E0A\u4E0B\u6587\u5DF2\u975E\u5E38\u63A5\u8FD1\u6781\u9650\uFF0C\u6267\u884C /compact \u53EF\u907F\u514D\u6A21\u578B\u622A\u65AD\u3002":e.state==="limit"&&(l="\u4E0A\u4E0B\u6587\u5DF2\u5230\u8FBE\u6781\u9650\uFF0C\u5FC5\u987B\u6267\u884C /compact \u6216 /new \u624D\u80FD\u7EE7\u7EED\u3002");let c=o!==void 0?`\u26A0\uFE0F \u4E0A\u4E0B\u6587\u4F7F\u7528 ${o}% (${a})`:`\u26A0\uFE0F \u4E0A\u4E0B\u6587\u4F7F\u7528\u504F\u9AD8 (${a})`;this.emitLog("warn",c,l);}this.lastMemoryPressureState=e.state,!t&&this.shouldScheduleAutoCompaction(e.state)&&await this.runPendingAutoCompactionIfIdle();}shouldScheduleAutoCompaction(e){return this.sessionEnabled?e==="warn"||e==="soft_limit"||e==="limit":false}async runPendingAutoCompactionIfIdle(){if(!this.sessionSync||!this.compatProfile||!this.memoryPressure||this.autoCompactionInProgress)return;let e=this.sessionSync.getMemory().getMessagesForLLM(),t=this.memoryPressure.setPromptEstimateFromMessages(e),n=(await this.sessionSync.getSession().getTimeline()).filter(o=>o.item.type==="message").length,i=cs(this.sessionSync.getMemory().getAll());this.autoCompactionInProgress=true;try{let o=this.sessionSync.getSession(),a="";if(t.profile.contextWindow){let l=Math.round(t.tokensUsed/t.profile.contextWindow*100),c=Math.round(t.tokensUsed/1e3),u=Math.round(t.profile.contextWindow/1e3);a=`${c}K / ${u}K tokens (${l}%)`;}if(this.llmProvider){this.emitCompacting("\u26A1 \u6B63\u5728\u667A\u80FD\u538B\u7F29\u5386\u53F2",`\u5F53\u524D\u4E0A\u4E0B\u6587: ${a}\uFF0C\u4F7F\u7528 AI \u751F\u6210\u9AD8\u8D28\u91CF\u4E0A\u4E0B\u6587\u6458\u8981...`),this.emitEvent({type:"status",status:"compacting",message:"\u26A1 Auto-compacting history..."});let l=await
|
|
1813
|
+
${s}`),s.trim()}extractImageUrls(e){return e?.attachments?.length?e.attachments.filter(t=>t.type==="image"&&t.data).map(t=>t.data):[]}async handleMemorySnapshot(e,t=false){e&&(this.emitEvent({type:"memory_snapshot",snapshot:e}),await this.maybeAnnounceMemoryPressure(e,t));}async maybeAnnounceMemoryPressure(e,t=false){if(!e.profile.contextWindow){this.lastMemoryPressureState=e.state;return}let s={unknown:0,normal:1,warn:2,soft_limit:3,limit:4},n=s[this.lastMemoryPressureState]??0;if((s[e.state]??0)>n&&e.state!=="normal"&&e.state!=="unknown"){let o=e.pressure!==void 0?Math.round(e.pressure*100):void 0,a=`${e.tokensUsed.toLocaleString()} / ${e.profile.contextWindow.toLocaleString()} tokens`,l="\u4E0A\u4E0B\u6587\u538B\u529B\u5DF2\u5347\u9AD8\uFF0C\u5EFA\u8BAE\u5C3D\u5FEB\u6267\u884C /compact \u6216\u4F7F\u7528 /new \u5F00\u542F\u65B0\u4F1A\u8BDD\u3002";e.state==="soft_limit"?l="\u4E0A\u4E0B\u6587\u5DF2\u975E\u5E38\u63A5\u8FD1\u6781\u9650\uFF0C\u6267\u884C /compact \u53EF\u907F\u514D\u6A21\u578B\u622A\u65AD\u3002":e.state==="limit"&&(l="\u4E0A\u4E0B\u6587\u5DF2\u5230\u8FBE\u6781\u9650\uFF0C\u5FC5\u987B\u6267\u884C /compact \u6216 /new \u624D\u80FD\u7EE7\u7EED\u3002");let c=o!==void 0?`\u26A0\uFE0F \u4E0A\u4E0B\u6587\u4F7F\u7528 ${o}% (${a})`:`\u26A0\uFE0F \u4E0A\u4E0B\u6587\u4F7F\u7528\u504F\u9AD8 (${a})`;this.emitLog("warn",c,l);}this.lastMemoryPressureState=e.state,!t&&this.shouldScheduleAutoCompaction(e.state)&&await this.runPendingAutoCompactionIfIdle();}shouldScheduleAutoCompaction(e){return this.sessionEnabled?e==="warn"||e==="soft_limit"||e==="limit":false}async runPendingAutoCompactionIfIdle(){if(!this.sessionSync||!this.compatProfile||!this.memoryPressure||this.autoCompactionInProgress)return;let e=this.sessionSync.getMemory().getMessagesForLLM(),t=this.memoryPressure.setPromptEstimateFromMessages(e),n=(await this.sessionSync.getSession().getTimeline()).filter(o=>o.item.type==="message").length,i=cs(this.sessionSync.getMemory().getAll());this.autoCompactionInProgress=true;try{let o=this.sessionSync.getSession(),a="";if(t.profile.contextWindow){let l=Math.round(t.tokensUsed/t.profile.contextWindow*100),c=Math.round(t.tokensUsed/1e3),u=Math.round(t.profile.contextWindow/1e3);a=`${c}K / ${u}K tokens (${l}%)`;}if(this.llmProvider){this.emitCompacting("\u26A1 \u6B63\u5728\u667A\u80FD\u538B\u7F29\u5386\u53F2",`\u5F53\u524D\u4E0A\u4E0B\u6587: ${a}\uFF0C\u4F7F\u7528 AI \u751F\u6210\u9AD8\u8D28\u91CF\u4E0A\u4E0B\u6587\u6458\u8981...`),this.emitEvent({type:"status",status:"compacting",message:"\u26A1 Auto-compacting history..."});let l=await ia({session:o,profile:this.compatProfile,llmProvider:this.llmProvider,model:this.model,timeout:6e4,onProgress:(b,w)=>{let x={analyzing:"\u25C6 \u5206\u6790\u5BF9\u8BDD\u5386\u53F2...",summarizing:"\u26A1 AI \u6B63\u5728\u751F\u6210\u6458\u8981...",saving:"\u25B8 \u4FDD\u5B58\u538B\u7F29\u7ED3\u679C..."}[b]||w||"Compacting...";this.emitCompacting(x,w&&b?w:void 0),this.emitEvent({type:"status",status:"compacting",message:x});}});if(!l){this.emitCompacting("\u2139\uFE0F \u65E0\u9700\u538B\u7F29","\u5BF9\u8BDD\u5386\u53F2\u8F83\u77ED\uFF0C\u6240\u6709\u6D88\u606F\u90FD\u5728\u4FDD\u7559\u9884\u7B97\u5185\uFF0820K tokens\uFF09"),this.emitEvent({type:"status",status:"complete",message:"No compaction needed"});return}await this.sessionSync.loadHistory();let c="";if(this.memoryPressure){this.memoryPressure.reset();let b=this.memoryPressure.setPromptEstimateFromMessages(this.sessionSync.getMemory().getMessagesForLLM());if(this.handleMemorySnapshot(b,!0),b.profile.contextWindow){let w=Math.round(b.tokensUsed/b.profile.contextWindow*100),S=(b.tokensUsed/1e3).toFixed(1),x=(b.profile.contextWindow/1e3).toFixed(0);c=`${S}K / ${x}K (${w}%)`;}}let p=(await o.getTimeline()).filter(b=>b.item.type==="message"),d=cs(this.memory.getAll()),m=l.llmTokensUsed!==void 0;this.emitEvent({type:"context_compaction",status:"completed",originalMessages:n,keptMessages:p.length,droppedMessages:m?0:l.removedMessages,compressedMessages:m?l.removedMessages:0,originalTokens:i.totalTokens,finalTokens:d.totalTokens,budgetTokens:t.profile.contextWindow||0,useLLM:m,timestamp:Date.now()});let h=(l.estimatedTokensSaved/1e3).toFixed(1),g=l.llmTokensUsed?` (LLM: ${l.llmTokensUsed} tokens)`:"",y=`\u{1F4CA} \u79FB\u9664 ${l.removedMessages} \u6761\u5386\u53F2\uFF0C\u4FDD\u7559 ${l.keptMessages} \u6761\u8FD1\u671F\u6D88\u606F\uFF0C\u8282\u7701\u7EA6 ${h}K tokens${g}`;if(a&&c&&(y+=`
|
|
1814
1814
|
|
|
1815
1815
|
\u{1F4C8} Context: ${a} \u2192 ${c}`),l.detailedStats){let{before:b,after:w,saved:S}=l.detailedStats,x=R=>(R/1e3).toFixed(1)+"K";y+=`
|
|
1816
1816
|
|
|
@@ -1824,38 +1824,38 @@ ${s}`),s.trim()}extractImageUrls(e){return e?.attachments?.length?e.attachments.
|
|
|
1824
1824
|
\u2502 \u603B\u8BA1: ${x(w.totalTokens)}`,y+=`
|
|
1825
1825
|
\u2514\u2500 \u8282\u7701\uFF1A`,y+=`
|
|
1826
1826
|
User: ${x(S.userTokens)} \u2022 Assistant: ${x(S.assistantTokens)} \u2022 Tool: ${x(S.toolTokens)}`,y+=`
|
|
1827
|
-
\u51C0\u8282\u7701: ${x(S.totalTokens)}`;}this.emitCompacting("\u2713 \u667A\u80FD\u538B\u7F29\u5B8C\u6210",y),this.emitEvent({type:"status",status:"complete",message:"Compaction complete"});}else {this.emitCompacting("\u25B8 \u6B63\u5728\u81EA\u52A8\u538B\u7F29\u5386\u53F2",`\u5F53\u524D\u4E0A\u4E0B\u6587: ${a}\uFF0C\u4E3A\u907F\u514D\u4E0A\u4E0B\u6587\u6EA2\u51FA\uFF0C\u5C06\u603B\u7ED3\u8F83\u65E7\u7684\u6D88\u606F\u3002`),this.emitEvent({type:"status",status:"compacting",message:"\u25B8 Auto-compacting history..."});let l=await
|
|
1828
|
-
\u5F53\u524D\u4E0A\u4E0B\u6587: ${m.tokensUsed.toLocaleString()} / ${m.profile.contextWindow.toLocaleString()} tokens (${h}%)`;}}let p=(await o.getTimeline()).filter(m=>m.item.type==="message"),d=cs(this.memory.getAll());this.emitEvent({type:"context_compaction",status:"completed",originalMessages:n,keptMessages:p.length,droppedMessages:l.removedMessages,compressedMessages:0,originalTokens:i.totalTokens,finalTokens:d.totalTokens,budgetTokens:t.profile.contextWindow||0,useLLM:!1,timestamp:Date.now()}),this.emitCompacting("\u2713 \u81EA\u52A8\u538B\u7F29\u5B8C\u6210",`\u6458\u8981 ${l.summaryLines} \u884C\uFF0C\u79FB\u9664 ${l.removedMessages} \u6761\u5386\u53F2\uFF0C\u4FDD\u7559 ${l.keptMessages} \u6761\u8FD1\u671F\u6D88\u606F\u3002${c}`),this.emitEvent({type:"status",status:"complete",message:"Compaction complete"});}}catch(o){let a=o?.message||String(o);this.emitLog("error","\u81EA\u52A8\u538B\u7F29\u5931\u8D25",`\u9519\u8BEF\u8BE6\u60C5: ${a}`),process.env.CLI_DEBUG==="1"&&f.error("[COMPACTION] Failed:",o);}finally{this.autoCompactionInProgress=false;}}async runTask(e,t){if(process.env.CLI_DEBUG==="1"&&(f.debug("TASK","========================================"),f.debug("TASK","=== runTask ENTRY ==="),f.debug("TASK",` userInput: "${e?.substring(0,50)}..."`),f.debug("TASK",` isRunning: ${this.isRunning}`),f.debug("TASK",` shouldInterrupt: ${this.shouldInterrupt}`),f.debug("TASK",` stdin.isPaused: ${process.stdin.isPaused?.()}`),f.debug("TASK",` stdin.destroyed: ${process.stdin.destroyed}`)),this.syncWorkspaceEnv(),!e.trim())throw new Error("Input is required");if(this.shouldInterrupt=false,this.isRunning=true,this.abortController=new AbortController,t?.abortSignal){let w=t.abortSignal;if(w.aborted)this.shouldInterrupt=true,this.abortController.abort();else {let S=()=>{this.shouldInterrupt=true,this.abortController?.abort();};w.addEventListener("abort",S,{once:true});}}let s=t?.metadata?.mode,n=this.runner.getMode(),i=s==="ask"&&n!=="ask";i&&this.runner.setMode("ask");let o=this.prepareTaskInput(e,t?.metadata),a=this.extractImageUrls(t?.metadata);if(this.currentTaskMetadata=t?.metadata,this.sessionSync&&this.sessionEnabled)try{let w=this.sessionSync.getTurnCount()+1,S=await this.sessionSync.createCheckpoint(`turn_${w}`);this.emitEvent({type:"checkpoint",id:S,auto:!0});}catch(w){f.error("TASK","\u68C0\u67E5\u70B9\u521B\u5EFA\u5931\u8D25\uFF01 \u4E8B\u4EF6\u53D1\u9001\u5931\u8D25\uFF01",w),console.error("Failed to create auto checkpoint",w);}this.emitEvent({type:"status",status:"thinking",message:"Starting..."});let l=Date.now(),c="",u=0,p=0,d=0,m="",h="",g="",y=0,b=0;try{let w=this.abortController?.signal;process.env.CLI_DEBUG==="1"&&f.debug("TASK","=== \u5F00\u59CBagent loop \u5FAA\u73AF ===");let S=0,x=this.createInterruptPromise(),R=this.runner.run(o,a.length>0?a:void 0,w)[Symbol.asyncIterator]();for(;;){let
|
|
1829
|
-
`))&&(this.emitEvent({type:"status",status:"thinking",message:"Generating response..."}),this.emitEvent({type:"text",delta:_.delta}));}break;case "reasoning_delta":_.delta&&this.emitEvent({type:"reasoning",delta:_.delta,timestamp:Date.now()});break;case "reasoning_complete":this.emitEvent({type:"reasoning_complete",timestamp:Date.now()});break;case "tool_call_start":p++,h="",y=0,g=_.name||"",this.emitEvent({type:"status",status:"tool_call",message:`Calling: ${_.name}`});break;case "tool_call_delta":if(_.arguments_delta){h+=_.arguments_delta,y+=_.arguments_delta.length;let E=Math.ceil(_.arguments_delta.length/4);if(b+=E,_.arguments_delta.trim().length>0&&this.emitEvent({type:"tool_call_delta",name:g||_.name||"unknown",argumentsDelta:_.arguments_delta}),y>1e3){let
|
|
1830
|
-
`).replace(/\\t/g," ").replace(/\\"/g,'"').replace(/\\\\/g,"\\"),
|
|
1831
|
-
`),K=ne.length<=5;X.length>2e3&&(X=X.slice(-2e3)),K?this.emitEvent({type:"file_stream",filePath:P,content:X,language:ce[le]||le,description:m.trim()||"Generating code...",timestamp:Date.now()}):this.emitEvent({type:"status",status:"tool_call",message:`Writing ${P} (${ne.length} lines)...`});}}}catch{f.error("MK","\u4E0D\u5B8C\u6574\u7684json \u5904\u7406");}}}break;case "tool_call_done":{if(_.name&&_.arguments)try{let E=_.arguments.trim(),D=uu(_.name,E);if(D.isTruncated){process.env.CLI_DEBUG_CONSOLE==="1"&&f.log("MK",`[AgentHost] \u26A0\uFE0F Truncation detected: ${D.reason}`);let X=cu(E);if(X)process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[AgentHost] \u2705 JSON repaired successfully"),E=X;else throw new Error(`Tool arguments truncated: ${D.reason}`)}let N=E?JSON.parse(E):{};process.env.CLI_DEBUG_CONSOLE==="1"&&f.debug("TOOL",`\u2705 Tool call parsed: ${_.name}`,{argsLength:E.length});let $=Ws(_.name,N),j=this.descriptionExtractor.extractFromAssistantMessage(m,_.name);j||(j=au(_.name,N));let Z=this.commandGenerator.generateEquivalentCommand(_.name,N),A=`tool-${++this.toolCallIdCounter}-${Math.floor(Date.now())}`,P=Date.now(),V=this.batchDetector.detectBatch(A,_.name,$||"",N,P);this.recentToolCalls.set(_.name,{toolId:A,batchId:V.batchId,targetPath:$,args:N});let F={targetPath:$,argsPreview:JSON.stringify(N).substring(0,200)};_.name==="search"&&N.pattern?F.pattern=N.pattern.substring(0,80):(_.name==="readfile"||_.name==="edit_file")&&N.path&&(F.file=N.path),f.info("TOOL",`\u{1F916} [AGENT] Call: ${_.name}`,F),this.emitEvent({type:"tool_call_start",name:_.name,args:N,targetPath:$,description:j,equivalentCommand:Z,timestamp:P+Math.random()*.1,toolId:A,isBatch:V.type==="batch",batchId:V.batchId});let ie=_.name==="write_file"||_.name==="Write",De=N.file_path||N.filePath||N.path;ie&&De&&N.content&&(await this.emitFileStreamEvent(De,N.content,m.trim()||void 0),m="");}catch(E){console.error("[AgentHost] \u274C Failed to parse tool arguments for:",_.name),console.error("[AgentHost] Error:",E.message),console.error("[AgentHost] Arguments length:",_.arguments?.length||0),process.env.CLI_DEBUG_CONSOLE==="1"&&(console.error("[AgentHost] First 200 chars:",_.arguments?.substring(0,200)||""),console.error("[AgentHost] Last 200 chars:",_.arguments?.substring(Math.max(0,(_.arguments?.length||0)-200))||""));let D=pu(_.name,_.arguments||"",E),N=D.category==="tool_truncated"?`\u274C Tool ${_.name}: content truncated during streaming`:`\u274C Tool ${_.name}: ${D.code}`;this.emitEvent({type:"status",status:"error",message:N}),this.emitEvent({type:"tool_call_start",name:_.name,args:{_raw:_.arguments?.substring(0,500)||"",_error:D.code,_errorCategory:D.category,_errorMessage:D.message,_suggestion:D.suggestion,_retryable:D.retryable},timestamp:Date.now()}),this.emitEvent({type:"tool_output",name:_.name,output:JSON.stringify(D),success:!1});}break}case "tool_output":if(_.name&&_.output!==void 0){let E=typeof _.output=="string"?_.output:JSON.stringify(_.output),D=E.length,N=_.success??!0,$=E.slice(0,mu),j=E.length>mu;f.info("TOOL",`\u{1F916} [AGENT] Result: ${_.name} ${N?"\u2713":"\u2717"}`,{success:N,resultLength:D,outputString:E});let Z=this.recentToolCalls.get(_.name),{toolId:A,batchId:P,targetPath:V,args:F}=Z||{},ie=V||(F&&typeof F.directory=="string"?F.directory:void 0),De=_.name==="show_tree"?`show_tree: ${ie||"."} (${D} chars)`:void 0;if(N&&ie&&this.batchDetector.recordCompletion(_.name,ie),this.emitEvent({type:"tool_call_end",name:_.name,success:N,resultLength:D,timestamp:Date.now()+Math.random()*.1,toolId:A,batchId:P,targetPath:ie,summary:De,output:$,outputTruncated:j,args:F}),_.name==="write_file"&&_.success&&F?.file_path&&F?.content){try{let X=F.file_path,le=F.content,ce=X.split(".").pop()?.toLowerCase()||"",ne={ts:"typescript",tsx:"tsx",js:"javascript",jsx:"jsx",py:"python",rb:"ruby",go:"go",rs:"rust",java:"java",kt:"kotlin",swift:"swift",c:"c",cpp:"cpp",h:"c",hpp:"cpp",css:"css",scss:"scss",less:"less",html:"html",vue:"vue",svelte:"svelte",json:"json",yaml:"yaml",yml:"yaml",md:"markdown",sql:"sql",sh:"bash"};this.emitEvent({type:"write_file_stream",filePath:X,content:le,isComplete:!0,language:ne[ce]||ce,timestamp:Date.now()});}catch(X){f.error("TOOL","write_file_stream \u53D1\u9001\u5931\u8D25",X);}await this.handleWriteFile(F.file_path,F.content,void 0);}if(_.name==="edit_file"&&_.success&&this.sessionSync&&this.sessionEnabled)try{let X=JSON.parse(E),le=X.metadata?.edit_info||X.edit_info,ce=X.metadata?.hunks;if(f.info("TOOL","edit file\u7684\u7ED3\u679C "+X),f.info("TOOL","edit file\u7684editInfo "+le),X.status==="success"&&le){let ne=[];if(Array.isArray(ce)&&ce.length>0)for(let Te of ce)ne.push({type:"file_edit_snapshot",data:{filePath:X.file_path,oldString:Te.old_string,newString:Te.new_string,startLine:Te.start_line,oldLineCount:Te.old_line_count,newLineCount:Te.new_line_count,replaceAll:!1,replacementCount:1}});else ne.push({type:"file_edit_snapshot",data:{filePath:X.file_path,oldString:le.old_string,newString:le.new_string,startLine:le.start_line,oldLineCount:le.old_line_count,newLineCount:le.new_line_count,replaceAll:(X.metadata?.replacements||X.replacements)>1,replacementCount:X.metadata?.replacements||X.replacements}});await this.sessionSync.getSession().addItems(ne);}}catch{f.error("TOOL","session\u7684edit file \u4FDD\u5B58\u5931\u8D25 ");}if(_.name==="edit_file"&&_.success)try{let X=JSON.parse(E),le=X.metadata?.edit_info||X.edit_info;if(X.status==="success"&&le){let ce=Array.isArray(X.metadata?.hunks)?X.metadata.hunks.map(K=>({oldString:K.old_string,newString:K.new_string,startLine:K.start_line})):void 0,ne=X.file_path.split(".").pop()?.toLowerCase()||"",Te={ts:"typescript",tsx:"tsx",js:"javascript",jsx:"jsx",py:"python",rb:"ruby",go:"go",rs:"rust",java:"java",kt:"kotlin",swift:"swift",c:"c",cpp:"cpp",h:"c",hpp:"cpp",css:"css",scss:"scss",less:"less",html:"html",vue:"vue",svelte:"svelte",json:"json",yaml:"yaml",yml:"yaml",md:"markdown",sql:"sql",sh:"bash"};this.emitEvent({type:"edit_file_stream",filePath:X.file_path,oldString:le.old_string,newString:le.new_string,startLine:le.start_line,hunks:ce,isComplete:!0,language:Te[ne]||ne,timestamp:Date.now()});}}catch{f.error("TOOL","edit file \u4FDD\u5B58\u5931\u8D25 ");}this.emitEvent({type:"tool_output",name:_.name,output:_.output,success:N});}break;case "token_usage":if(_.usage){d=_.usage.total_tokens;let E=_.usage.prompt_tokens||0,D=_.usage.completion_tokens||0,N=_.usage.prompt_tokens_details?.cached_tokens||0,$=_.usage.cache_read_input_tokens||0,j=_.usage.cache_creation_input_tokens||0,Z=N||$||_.usage.cached_tokens||0,A=E+$+j+N;if(f.debug("CACHE","\u{1F525} Cache token calculation:"),f.debug("CACHE",` actualInputTokens=${E}`),f.debug("CACHE",` anthropicCacheReadTokens=${$}`),f.debug("CACHE",` anthropicCacheCreationTokens=${j}`),f.debug("CACHE",` openaiCachedTokens=${N}`),f.debug("CACHE",` fullContextInputTokens=${A}`),f.debug("CACHE",` formula: ${E} + ${$} + ${j} + ${N} = ${A}`),this.sessionTotalInputTokens+=A,this.sessionTotalOutputTokens+=D,process.env.CLI_DEBUG&&(f.debug("CONTEXT","token_usage event received:"),f.debug("CONTEXT",` actualInputTokens=${E}, actualOutputTokens=${D}`),f.debug("CONTEXT",` anthropicCacheReadTokens=${$}, openaiCachedTokens=${N}`),f.debug("CONTEXT",` anthropicCacheCreationTokens=${j}`),f.debug("CONTEXT",` fullContextInputTokens=${A}`),f.debug("CONTEXT",` sessionTotalInput=${this.sessionTotalInputTokens}, sessionTotalOutput=${this.sessionTotalOutputTokens}`),f.debug("CONTEXT",` memoryPressure initialized: ${!!this.memoryPressure}`)),this.memoryPressure){let P=this.memory.getMessagesForLLM(),V=this.memoryPressure.estimateMessagesForDisplay(P);this.memoryPressure.recordCalibration(V,E,$);let F=this.memoryPressure.recordActualUsage(A,D,P.length);f.debug("SNAPSHOT","\u{1F525} Snapshot values:"),f.debug("SNAPSHOT",` fullContextInputTokens (passed to recordActualUsage)=${A}`),f.debug("SNAPSHOT",` snapshot.promptTokens (returned)=${F.promptTokens}`),f.debug("SNAPSHOT",` snapshot.tokensUsed=${F.tokensUsed}`),f.debug("SNAPSHOT",` snapshot.pressure=${F.pressure}`),process.env.CLI_DEBUG&&(f.debug("CONTEXT","recordActualUsage snapshot:"),f.debug("CONTEXT",` tokensUsed=${F.tokensUsed}, promptTokens=${F.promptTokens}`),f.debug("CONTEXT",` completionTokens=${F.completionTokens}, contextWindow=${F.profile.contextWindow}`),f.debug("CONTEXT",` pressure=${F.pressure}, state=${F.state}`)),await this.handleMemorySnapshot(F);}b=0,this.emitEvent({type:"token_usage",promptTokens:A,completionTokens:D,totalTokens:A+D,cachedTokens:Z>0?Z:void 0,openaiCachedTokens:N>0?N:void 0,anthropicCacheReadTokens:$>0?$:void 0,anthropicCacheCreationTokens:j>0?j:void 0,sessionPromptTokens:this.sessionTotalInputTokens,sessionCompletionTokens:this.sessionTotalOutputTokens});}break;case "context_compaction":this.emitEvent({type:"context_compaction",status:_.status,originalMessages:_.originalMessages,keptMessages:_.keptMessages,droppedMessages:_.droppedMessages,compressedMessages:_.compressedMessages,originalTokens:_.originalTokens,finalTokens:_.finalTokens,budgetTokens:_.budgetTokens,useLLM:_.useLLM,timestamp:_.timestamp??Date.now()});break;case "raw_response_event":if(_.event_type==="input_guardrails.check_start")this.emitEvent({type:"status",status:"thinking",message:"Checking input guardrails..."});else if(_.event_type==="output_guardrails.check_start")this.emitEvent({type:"status",status:"thinking",message:"Checking output guardrails..."});else if(_.event_type==="structured_output.retry"){this.emitEvent({type:"text_complete"}),c="";let E=Array.isArray(_.data?.errors)&&_.data.errors.length>0?_.data.errors.join("; "):_.data?.message;this.emitLog("warn","Structured output validation failed",E),this.emitEvent({type:"status",status:"error",message:"Structured output invalid, retrying..."});}else if(_.event_type==="structured_output.accepted")typeof _.data?.normalized_text=="string"&&(c=_.data.normalized_text),this.emitLog("info","Structured output ready",_.data?.schema?`Schema: ${_.data.schema}`:void 0);else if(_.event_type==="error.classified"){let E=_.data;this.emitEvent({type:"error_classified",category:E.category||"INTERNAL",code:E.code||"UNKNOWN_ERROR",message:E.message||"An unknown error occurred",suggestion:E.suggestion,retryable:E.retryable??!1});}else if(_.event_type==="context_compaction"){let E=_.data;if(this.memoryPressure&&E.finalTokens!==void 0){let $=this.memoryPressure.setPromptEstimateFromMessages(this.memory.getMessagesForLLM());this.handleMemorySnapshot($,!0);}let D=E.droppedMessages||0,N=E.compressedMessages||0;if(D>0||N>0){let $=(E.originalTokens||0)-(E.finalTokens||0),j=E.useLLM?"\u667A\u80FD\u538B\u7F29":"\u88C1\u526A";this.emitLog("info",`\u25B8 \u4E0A\u4E0B\u6587${j}`,`\u79FB\u9664 ${D} \u6761\u6D88\u606F${N>0?`\uFF0C\u538B\u7F29 ${N} \u6761`:""}\uFF0C\u8282\u7701\u7EA6 ${$.toLocaleString()} tokens`),this.emitEvent({type:"status",status:"compacting",message:`Context compacted: -${D} messages`});}}else _.event_type==="response.completed"&&(process.env.CLI_DEBUG_CONSOLE==="1"&&f.debug("EVENTS","\u{1F4E4} Forwarding response.completed"),this.emitEvent({type:"raw_response_event",data:_.data,event_type:_.event_type}));break;case "run_done":break;case "error":f.error("AGENT",`Error: ${_.error||"Unknown error"}`),this.emitEvent({type:"error",message:_.error||"Unknown error"}),this.emitEvent({type:"status",status:"error",message:`Error: ${_.error||"Unknown error"}`});break;case "stream_retry":let k=_;this.emitEvent({type:"stream_retry",error:k.error,errorCode:k.errorCode||"STREAM_ERROR",attempt:k.attempt,maxRetries:k.maxRetries,delayMs:k.delayMs});break;case "stream_recovered":let M=_;this.emitEvent({type:"stream_recovered",attempt:M.attempt,maxRetries:M.maxRetries});break;case "plan_update":let W=_;f.info("RUNTIME_HOST","\u{1F525} Forwarding plan_update event",{hasExplanation:!!W.explanation,planSteps:W.plan?.length}),this.emitEvent({type:"plan_update",explanation:W.explanation,plan:W.plan,timestamp:W.timestamp||Date.now()});break}}process.env.CLI_DEBUG==="1"&&(f.debug("TASK","=== runner.run loop COMPLETED ==="),f.debug("TASK",` Total events: ${S}`),f.debug("TASK",` stdin.isPaused: ${process.stdin.isPaused?.()}`)),this.emitEvent({type:"text_complete"});let L=Date.now()-l,H=c;if(this.shouldInterrupt)this.emitEvent({type:"status",status:"error",message:"Task interrupted"});else if(this.emitEvent({type:"status",status:"complete",message:"Complete!"}),this.emitLog("info","Task complete",`${u} iterations, ${p} tool calls, ${d} tokens, ${(L/1e3).toFixed(2)}s`),this.sessionSync&&this.sessionEnabled&&H)try{await this.sessionSync.saveTurn({role:"user",content:o},{role:"assistant",content:H});}catch{}let U={output:H,totalTokens:d,durationMs:L,iterations:u,toolCalls:p,interrupted:this.shouldInterrupt};return this.emitEvent({type:"run_result",output:H,totalTokens:d,iterations:u,toolCalls:p,durationMs:L}),U}catch(w){if(w?.code==="ERR_CANCELED"||w?.name==="CanceledError"||w?.name==="AbortError"||w?.category==="canceled"||this.shouldInterrupt){this.emitEvent({type:"text_complete"}),this.emitEvent({type:"status",status:"error",message:"Task interrupted"}),this.emitLog("info","Task interrupted by user");let R=Date.now()-l;return {output:c,totalTokens:d,durationMs:R,iterations:u,toolCalls:p,interrupted:true}}let x=w?.message||String(w)||"Unknown error";throw this.emitEvent({type:"text_complete"}),this.emitEvent({type:"status",status:"error",message:`Error: ${x}`}),this.emitLog("error",`Error: ${x}`),w}finally{process.env.CLI_DEBUG&&(f.debug("TASK","=== runTask finally block START ==="),f.debug("TASK",` isRunning was: ${this.isRunning}`)),i&&this.runner.setMode(n),this.isRunning=false,this.abortController=null,this.clearInterruptPromise(),process.env.CLI_DEBUG&&f.debug("TASK","=== runTask finally block END ===");}}syncWorkspaceEnv(){this.workDir&&(process.env.NEOX_WORKDIR=this.workDir);}async listSessions(){return this.sessionManager.listSessions()}getCurrentSessionId(){return this.session?.sessionId}async getSessionInfo(){if(!this.sessionSync)throw new Error("Session is not ready");return this.sessionSync.getSessionInfo()}async emitFileStreamEvent(e,t,s){let n=e.split(".").pop()||"",o={js:"javascript",ts:"typescript",tsx:"typescript",py:"python",html:"html",css:"css",json:"json",md:"markdown"}[n]||n,a=Date.now();this.emitEvent({type:"file_stream",filePath:e,content:t,isComplete:false,language:o,description:s,timestamp:a});}async handleWriteFile(e,t,s){let n=e.split(".").pop()||"",o={js:"javascript",ts:"typescript",tsx:"typescript",py:"python",html:"html",css:"css",json:"json",md:"markdown"}[n]||n,a=Date.now();try{let l=await import('fs'),c=await import('path'),u=c.isAbsolute(e)?c.resolve(e):c.resolve(this.workDir,e);if(this.sessionSync&&this.sessionEnabled)try{let p=null,d="create";l.existsSync(u)&&(d="modify",p=null);let m={type:"file_snapshot",data:{filePath:e,originalContent:p,operation:d,newContent:t}};await this.sessionSync.getSession().addItems([m]);}catch(p){console.debug("Failed to capture file snapshot",p);}this.emitEvent({type:"file_stream",filePath:e,content:t,isComplete:!0,language:o,description:s,timestamp:a}),this.emitLog("info",`\u2713 Saved ${e}`,`${t.split(`
|
|
1827
|
+
\u51C0\u8282\u7701: ${x(S.totalTokens)}`;}this.emitCompacting("\u2713 \u667A\u80FD\u538B\u7F29\u5B8C\u6210",y),this.emitEvent({type:"status",status:"complete",message:"Compaction complete"});}else {this.emitCompacting("\u25B8 \u6B63\u5728\u81EA\u52A8\u538B\u7F29\u5386\u53F2",`\u5F53\u524D\u4E0A\u4E0B\u6587: ${a}\uFF0C\u4E3A\u907F\u514D\u4E0A\u4E0B\u6587\u6EA2\u51FA\uFF0C\u5C06\u603B\u7ED3\u8F83\u65E7\u7684\u6D88\u606F\u3002`),this.emitEvent({type:"status",status:"compacting",message:"\u25B8 Auto-compacting history..."});let l=await pu({session:o,profile:this.compatProfile});if(!l){this.emitCompacting("\u2139\uFE0F \u65E0\u9700\u538B\u7F29","\u5BF9\u8BDD\u5386\u53F2\u8F83\u77ED\uFF0C\u6240\u6709\u6D88\u606F\u90FD\u5728\u4FDD\u7559\u9884\u7B97\u5185\uFF0820K tokens\uFF09"),this.emitEvent({type:"status",status:"complete",message:"No compaction needed"});return}await this.sessionSync.loadHistory();let c="";if(this.memoryPressure){this.memoryPressure.reset();let m=this.memoryPressure.setPromptEstimateFromMessages(this.sessionSync.getMemory().getMessagesForLLM());if(this.handleMemorySnapshot(m,!0),m.profile.contextWindow){let h=Math.round(m.tokensUsed/m.profile.contextWindow*100);c=`
|
|
1828
|
+
\u5F53\u524D\u4E0A\u4E0B\u6587: ${m.tokensUsed.toLocaleString()} / ${m.profile.contextWindow.toLocaleString()} tokens (${h}%)`;}}let p=(await o.getTimeline()).filter(m=>m.item.type==="message"),d=cs(this.memory.getAll());this.emitEvent({type:"context_compaction",status:"completed",originalMessages:n,keptMessages:p.length,droppedMessages:l.removedMessages,compressedMessages:0,originalTokens:i.totalTokens,finalTokens:d.totalTokens,budgetTokens:t.profile.contextWindow||0,useLLM:!1,timestamp:Date.now()}),this.emitCompacting("\u2713 \u81EA\u52A8\u538B\u7F29\u5B8C\u6210",`\u6458\u8981 ${l.summaryLines} \u884C\uFF0C\u79FB\u9664 ${l.removedMessages} \u6761\u5386\u53F2\uFF0C\u4FDD\u7559 ${l.keptMessages} \u6761\u8FD1\u671F\u6D88\u606F\u3002${c}`),this.emitEvent({type:"status",status:"complete",message:"Compaction complete"});}}catch(o){let a=o?.message||String(o);this.emitLog("error","\u81EA\u52A8\u538B\u7F29\u5931\u8D25",`\u9519\u8BEF\u8BE6\u60C5: ${a}`),process.env.CLI_DEBUG==="1"&&f.error("[COMPACTION] Failed:",o);}finally{this.autoCompactionInProgress=false;}}async runTask(e,t){if(process.env.CLI_DEBUG==="1"&&(f.debug("TASK","========================================"),f.debug("TASK","=== runTask ENTRY ==="),f.debug("TASK",` userInput: "${e?.substring(0,50)}..."`),f.debug("TASK",` isRunning: ${this.isRunning}`),f.debug("TASK",` shouldInterrupt: ${this.shouldInterrupt}`),f.debug("TASK",` stdin.isPaused: ${process.stdin.isPaused?.()}`),f.debug("TASK",` stdin.destroyed: ${process.stdin.destroyed}`)),this.syncWorkspaceEnv(),!e.trim())throw new Error("Input is required");if(this.shouldInterrupt=false,this.isRunning=true,this.abortController=new AbortController,t?.abortSignal){let w=t.abortSignal;if(w.aborted)this.shouldInterrupt=true,this.abortController.abort();else {let S=()=>{this.shouldInterrupt=true,this.abortController?.abort();};w.addEventListener("abort",S,{once:true});}}let s=t?.metadata?.mode,n=this.runner.getMode(),i=s==="ask"&&n!=="ask";i&&this.runner.setMode("ask");let o=this.prepareTaskInput(e,t?.metadata),a=this.extractImageUrls(t?.metadata);if(this.currentTaskMetadata=t?.metadata,this.sessionSync&&this.sessionEnabled)try{let w=this.sessionSync.getTurnCount()+1,S=await this.sessionSync.createCheckpoint(`turn_${w}`);this.emitEvent({type:"checkpoint",id:S,auto:!0});}catch(w){f.error("TASK","\u68C0\u67E5\u70B9\u521B\u5EFA\u5931\u8D25\uFF01 \u4E8B\u4EF6\u53D1\u9001\u5931\u8D25\uFF01",w),console.error("Failed to create auto checkpoint",w);}this.emitEvent({type:"status",status:"thinking",message:"Starting..."});let l=Date.now(),c="",u=0,p=0,d=0,m="",h="",g="",y=0,b=0;try{let w=this.abortController?.signal;process.env.CLI_DEBUG==="1"&&f.debug("TASK","=== \u5F00\u59CBagent loop \u5FAA\u73AF ===");let S=0,x=this.createInterruptPromise(),R=this.runner.run(o,a.length>0?a:void 0,w)[Symbol.asyncIterator]();for(;;){let T=R.next();T.catch(()=>{});let C=await Promise.race([T,x]);if("interrupted"in C){if(this.shouldInterrupt=!0,R.return)try{R.return(void 0)?.catch?.(()=>{});}catch{}break}if(C.done)break;let _=C.value;if(S++,process.env.CLI_DEBUG==="1"&&f.debug("TASK",` \u4E8B\u4EF6 #${S}: ${_.type}`),this.shouldInterrupt){process.env.CLI_DEBUG==="1"&&f.debug("TASK"," shouldInterrupt=true, \u9000\u51FAloop");break}switch(_.type){case "iteration_start":if(this.emitEvent({type:"text_complete"}),u=_.iteration||0,u>1){let E=this.processPendingInjectedMessages();E>0&&(f.info("INJECT",`\u2705 Processed ${E} injected messages at iteration ${u}`),this.emitEvent({type:"queued_messages_processed",count:E}));}if(this.emitEvent({type:"thinking",iteration:u,timestamp:Date.now()}),this.emitEvent({type:"status",status:"thinking",message:hu()}),b=0,this.memoryPressure){let E=this.memory.getMessagesForLLM();process.env.CLI_DEBUG&&(f.debug("CONTEXT",`\u8FED\u4EE3\u5F00\u59CB: \u77ED\u671F\u8BB0\u5FC6 \u6709 ${E.length} \u6D88\u606F`),E.forEach((A,F)=>{let H=typeof A.content=="string"?A.content.length:JSON.stringify(A.content).length;f.debug("CONTEXT",` [${F}] role=${A.role}, content_len=${H}`);}));}break;case "text_delta":if(_.delta){c+=_.delta,m+=_.delta;let E=Math.ceil(_.delta.length/4);b+=E,(_.delta.trim().length>0||_.delta.includes(`
|
|
1829
|
+
`))&&(this.emitEvent({type:"status",status:"thinking",message:"Generating response..."}),this.emitEvent({type:"text",delta:_.delta}));}break;case "reasoning_delta":_.delta&&this.emitEvent({type:"reasoning",delta:_.delta,timestamp:Date.now()});break;case "reasoning_complete":this.emitEvent({type:"reasoning_complete",timestamp:Date.now()});break;case "tool_call_start":p++,h="",y=0,g=_.name||"",this.emitEvent({type:"status",status:"tool_call",message:`Calling: ${_.name}`});break;case "tool_call_delta":if(_.arguments_delta){h+=_.arguments_delta,y+=_.arguments_delta.length;let E=Math.ceil(_.arguments_delta.length/4);if(b+=E,_.arguments_delta.trim().length>0&&this.emitEvent({type:"tool_call_delta",name:g||_.name||"unknown",argumentsDelta:_.arguments_delta}),y>1e3){let M=1-h.trim().length/y;M>.9&&(console.error(`[AgentHost] \u26A0\uFE0F Abnormal tool call: ${g} - ${(M*100).toFixed(1)}% whitespace (${y} bytes)`),this.emitLog("warn",`Model output abnormal: ${g} generating mostly whitespace content`));}if(g==="write_file"||g==="Write"||_.name==="write_file"||_.name==="Write"){let H=Math.floor(y/80),M=(y/1024).toFixed(1);this.emitEvent({type:"status",status:"tool_call",message:`\u26A1 Generating... ${M}KB (~${H} lines)`});try{let ee=h.match(/"file_path"\s*:\s*"([^"]+)"/),P=h.match(/"content"\s*:\s*"/);if(ee&&P){let q=ee[1],B=h.indexOf('"',P.index+9+1)+1;if(B>0){let j=h.substring(B),Y=-1,ae=0;for(let ie=0;ie<j.length;ie++)if(j[ie]==="\\")ae++;else {if(j[ie]==='"'&&ae%2===0){Y=ie;break}ae=0;}Y>0&&(j=j.substring(0,Y));let _e=j.replace(/\\n/g,`
|
|
1830
|
+
`).replace(/\\t/g," ").replace(/\\"/g,'"').replace(/\\\\/g,"\\"),Pe=q.split(".").pop()||"",ne={js:"javascript",ts:"typescript",tsx:"typescript",py:"python",html:"html",css:"css",json:"json",md:"markdown"},le=_e.split(`
|
|
1831
|
+
`),W=le.length<=5;_e.length>2e3&&(_e=_e.slice(-2e3)),W?this.emitEvent({type:"file_stream",filePath:q,content:_e,language:ne[Pe]||Pe,description:m.trim()||"Generating code...",timestamp:Date.now()}):this.emitEvent({type:"status",status:"tool_call",message:`Writing ${q} (${le.length} lines)...`});}}}catch{f.error("MK","\u4E0D\u5B8C\u6574\u7684json \u5904\u7406");}}}break;case "tool_call_done":{if(_.name&&_.arguments)try{let E=_.arguments.trim(),A=fu(_.name,E);if(A.isTruncated){process.env.CLI_DEBUG_CONSOLE==="1"&&f.log("MK",`[AgentHost] \u26A0\uFE0F Truncation detected: ${A.reason}`);let _e=gu(E);if(_e)process.env.CLI_DEBUG_CONSOLE==="1"&&console.log("[AgentHost] \u2705 JSON repaired successfully"),E=_e;else throw new Error(`Tool arguments truncated: ${A.reason}`)}let F=E?JSON.parse(E):{};process.env.CLI_DEBUG_CONSOLE==="1"&&f.debug("TOOL",`\u2705 Tool call parsed: ${_.name}`,{argsLength:E.length});let H=Hs(_.name,F),M=this.descriptionExtractor.extractFromAssistantMessage(m,_.name);M||(M=mu(_.name,F));let ee=this.commandGenerator.generateEquivalentCommand(_.name,F),P=`tool-${++this.toolCallIdCounter}-${Math.floor(Date.now())}`,q=Date.now(),B=this.batchDetector.detectBatch(P,_.name,H||"",F,q);this.recentToolCalls.set(_.name,{toolId:P,batchId:B.batchId,targetPath:H,args:F});let j={targetPath:H,argsPreview:JSON.stringify(F).substring(0,200)};_.name==="search"&&F.pattern?j.pattern=F.pattern.substring(0,80):(_.name==="readfile"||_.name==="edit_file")&&F.path&&(j.file=F.path),f.info("TOOL",`\u{1F916} [AGENT] Call: ${_.name}`,j),this.emitEvent({type:"tool_call_start",name:_.name,args:F,targetPath:H,description:M,equivalentCommand:ee,timestamp:q+Math.random()*.1,toolId:P,isBatch:B.type==="batch",batchId:B.batchId});let Y=_.name==="write_file"||_.name==="Write",ae=F.file_path||F.filePath||F.path;Y&&ae&&F.content&&(await this.emitFileStreamEvent(ae,F.content,m.trim()||void 0),m="");}catch(E){console.error("[AgentHost] \u274C Failed to parse tool arguments for:",_.name),console.error("[AgentHost] Error:",E.message),console.error("[AgentHost] Arguments length:",_.arguments?.length||0),process.env.CLI_DEBUG_CONSOLE==="1"&&(console.error("[AgentHost] First 200 chars:",_.arguments?.substring(0,200)||""),console.error("[AgentHost] Last 200 chars:",_.arguments?.substring(Math.max(0,(_.arguments?.length||0)-200))||""));let A=yu(_.name,_.arguments||"",E),F=A.category==="tool_truncated"?`\u274C Tool ${_.name}: content truncated during streaming`:`\u274C Tool ${_.name}: ${A.code}`;this.emitEvent({type:"status",status:"error",message:F}),this.emitEvent({type:"tool_call_start",name:_.name,args:{_raw:_.arguments?.substring(0,500)||"",_error:A.code,_errorCategory:A.category,_errorMessage:A.message,_suggestion:A.suggestion,_retryable:A.retryable},timestamp:Date.now()});let H=_.id||this.recentToolCalls.get(_.name)?.toolId;this.emitEvent({type:"tool_output",name:_.name,output:JSON.stringify(A),success:!1,toolId:H});}break}case "tool_output":if(_.name&&_.output!==void 0){let E=typeof _.output=="string"?_.output:JSON.stringify(_.output),A=E.length,F=_.success??!0,H=E.slice(0,wu),M=E.length>wu;f.info("TOOL",`\u{1F916} [AGENT] Result: ${_.name} ${F?"\u2713":"\u2717"}`,{success:F,resultLength:A,outputString:E});let ee=_.id,P=this.recentToolCalls.get(_.name),{toolId:q,batchId:B,targetPath:j,args:Y}=P||{},ae=ee||q,_e=j||(Y&&typeof Y.directory=="string"?Y.directory:void 0),Pe=_.name==="show_tree"?`show_tree: ${_e||"."} (${A} chars)`:void 0;if(F&&_e&&this.batchDetector.recordCompletion(_.name,_e),this.emitEvent({type:"tool_call_end",name:_.name,success:F,resultLength:A,timestamp:Date.now(),toolId:ae,batchId:B,targetPath:_e,summary:Pe,output:H,outputTruncated:M,args:Y}),_.name==="write_file"&&_.success&&Y?.file_path&&Y?.content){try{let ne=Y.file_path,le=Y.content,be=ne.split(".").pop()?.toLowerCase()||"",W={ts:"typescript",tsx:"tsx",js:"javascript",jsx:"jsx",py:"python",rb:"ruby",go:"go",rs:"rust",java:"java",kt:"kotlin",swift:"swift",c:"c",cpp:"cpp",h:"c",hpp:"cpp",css:"css",scss:"scss",less:"less",html:"html",vue:"vue",svelte:"svelte",json:"json",yaml:"yaml",yml:"yaml",md:"markdown",sql:"sql",sh:"bash"};this.emitEvent({type:"write_file_stream",filePath:ne,content:le,isComplete:!0,language:W[be]||be,timestamp:Date.now()});}catch(ne){f.error("TOOL","write_file_stream \u53D1\u9001\u5931\u8D25",ne);}await this.handleWriteFile(Y.file_path,Y.content,void 0);}if(_.name==="edit_file"&&_.success&&this.sessionSync&&this.sessionEnabled)try{let ne=JSON.parse(E),le=ne.metadata?.edit_info||ne.edit_info,be=ne.metadata?.hunks;if(f.info("TOOL","edit file\u7684\u7ED3\u679C "+ne),f.info("TOOL","edit file\u7684editInfo "+le),ne.status==="success"&&le){let W=[];if(Array.isArray(be)&&be.length>0)for(let ie of be)W.push({type:"file_edit_snapshot",data:{filePath:ne.file_path,oldString:ie.old_string,newString:ie.new_string,startLine:ie.start_line,oldLineCount:ie.old_line_count,newLineCount:ie.new_line_count,replaceAll:!1,replacementCount:1}});else W.push({type:"file_edit_snapshot",data:{filePath:ne.file_path,oldString:le.old_string,newString:le.new_string,startLine:le.start_line,oldLineCount:le.old_line_count,newLineCount:le.new_line_count,replaceAll:(ne.metadata?.replacements||ne.replacements)>1,replacementCount:ne.metadata?.replacements||ne.replacements}});await this.sessionSync.getSession().addItems(W);}}catch{f.error("TOOL","session\u7684edit file \u4FDD\u5B58\u5931\u8D25 ");}if(_.name==="edit_file"&&_.success)try{let ne=JSON.parse(E),le=ne.metadata?.edit_info||ne.edit_info;if(ne.status==="success"&&le){let be=Array.isArray(ne.metadata?.hunks)?ne.metadata.hunks.map(Q=>({oldString:Q.old_string,newString:Q.new_string,startLine:Q.start_line})):void 0,W=ne.file_path.split(".").pop()?.toLowerCase()||"",ie={ts:"typescript",tsx:"tsx",js:"javascript",jsx:"jsx",py:"python",rb:"ruby",go:"go",rs:"rust",java:"java",kt:"kotlin",swift:"swift",c:"c",cpp:"cpp",h:"c",hpp:"cpp",css:"css",scss:"scss",less:"less",html:"html",vue:"vue",svelte:"svelte",json:"json",yaml:"yaml",yml:"yaml",md:"markdown",sql:"sql",sh:"bash"};this.emitEvent({type:"edit_file_stream",filePath:ne.file_path,oldString:le.old_string,newString:le.new_string,startLine:le.start_line,hunks:be,isComplete:!0,language:ie[W]||W,timestamp:Date.now()});}}catch{f.error("TOOL","edit file \u4FDD\u5B58\u5931\u8D25 ");}this.emitEvent({type:"tool_output",name:_.name,output:_.output,success:F,toolId:ae});}break;case "token_usage":if(_.usage){d=_.usage.total_tokens;let E=_.usage.prompt_tokens||0,A=_.usage.completion_tokens||0,F=_.usage.prompt_tokens_details?.cached_tokens||0,H=_.usage.cache_read_input_tokens||0,M=_.usage.cache_creation_input_tokens||0,ee=F||H||_.usage.cached_tokens||0,P=E+H+M+F;if(f.debug("CACHE","\u{1F525} Cache token calculation:"),f.debug("CACHE",` actualInputTokens=${E}`),f.debug("CACHE",` anthropicCacheReadTokens=${H}`),f.debug("CACHE",` anthropicCacheCreationTokens=${M}`),f.debug("CACHE",` openaiCachedTokens=${F}`),f.debug("CACHE",` fullContextInputTokens=${P}`),f.debug("CACHE",` formula: ${E} + ${H} + ${M} + ${F} = ${P}`),this.sessionTotalInputTokens+=P,this.sessionTotalOutputTokens+=A,process.env.CLI_DEBUG&&(f.debug("CONTEXT","token_usage event received:"),f.debug("CONTEXT",` actualInputTokens=${E}, actualOutputTokens=${A}`),f.debug("CONTEXT",` anthropicCacheReadTokens=${H}, openaiCachedTokens=${F}`),f.debug("CONTEXT",` anthropicCacheCreationTokens=${M}`),f.debug("CONTEXT",` fullContextInputTokens=${P}`),f.debug("CONTEXT",` sessionTotalInput=${this.sessionTotalInputTokens}, sessionTotalOutput=${this.sessionTotalOutputTokens}`),f.debug("CONTEXT",` memoryPressure initialized: ${!!this.memoryPressure}`)),this.memoryPressure){let q=this.memory.getMessagesForLLM(),B=this.memoryPressure.estimateMessagesForDisplay(q);this.memoryPressure.recordCalibration(B,E,H);let j=this.memoryPressure.recordActualUsage(P,A,q.length);f.debug("SNAPSHOT","\u{1F525} Snapshot values:"),f.debug("SNAPSHOT",` fullContextInputTokens (passed to recordActualUsage)=${P}`),f.debug("SNAPSHOT",` snapshot.promptTokens (returned)=${j.promptTokens}`),f.debug("SNAPSHOT",` snapshot.tokensUsed=${j.tokensUsed}`),f.debug("SNAPSHOT",` snapshot.pressure=${j.pressure}`),process.env.CLI_DEBUG&&(f.debug("CONTEXT","recordActualUsage snapshot:"),f.debug("CONTEXT",` tokensUsed=${j.tokensUsed}, promptTokens=${j.promptTokens}`),f.debug("CONTEXT",` completionTokens=${j.completionTokens}, contextWindow=${j.profile.contextWindow}`),f.debug("CONTEXT",` pressure=${j.pressure}, state=${j.state}`)),await this.handleMemorySnapshot(j);}b=0,this.emitEvent({type:"token_usage",promptTokens:P,completionTokens:A,totalTokens:P+A,cachedTokens:ee>0?ee:void 0,openaiCachedTokens:F>0?F:void 0,anthropicCacheReadTokens:H>0?H:void 0,anthropicCacheCreationTokens:M>0?M:void 0,sessionPromptTokens:this.sessionTotalInputTokens,sessionCompletionTokens:this.sessionTotalOutputTokens});}break;case "context_compaction":this.emitEvent({type:"context_compaction",status:_.status,originalMessages:_.originalMessages,keptMessages:_.keptMessages,droppedMessages:_.droppedMessages,compressedMessages:_.compressedMessages,originalTokens:_.originalTokens,finalTokens:_.finalTokens,budgetTokens:_.budgetTokens,useLLM:_.useLLM,timestamp:_.timestamp??Date.now()});break;case "raw_response_event":if(_.event_type==="input_guardrails.check_start")this.emitEvent({type:"status",status:"thinking",message:"Checking input guardrails..."});else if(_.event_type==="output_guardrails.check_start")this.emitEvent({type:"status",status:"thinking",message:"Checking output guardrails..."});else if(_.event_type==="structured_output.retry"){this.emitEvent({type:"text_complete"}),c="";let E=Array.isArray(_.data?.errors)&&_.data.errors.length>0?_.data.errors.join("; "):_.data?.message;this.emitLog("warn","Structured output validation failed",E),this.emitEvent({type:"status",status:"error",message:"Structured output invalid, retrying..."});}else if(_.event_type==="structured_output.accepted")typeof _.data?.normalized_text=="string"&&(c=_.data.normalized_text),this.emitLog("info","Structured output ready",_.data?.schema?`Schema: ${_.data.schema}`:void 0);else if(_.event_type==="error.classified"){let E=_.data;this.emitEvent({type:"error_classified",category:E.category||"INTERNAL",code:E.code||"UNKNOWN_ERROR",message:E.message||"An unknown error occurred",suggestion:E.suggestion,retryable:E.retryable??!1});}else if(_.event_type==="context_compaction"){let E=_.data;if(this.memoryPressure&&E.finalTokens!==void 0){let H=this.memoryPressure.setPromptEstimateFromMessages(this.memory.getMessagesForLLM());this.handleMemorySnapshot(H,!0);}let A=E.droppedMessages||0,F=E.compressedMessages||0;if(A>0||F>0){let H=(E.originalTokens||0)-(E.finalTokens||0),M=E.useLLM?"\u667A\u80FD\u538B\u7F29":"\u88C1\u526A";this.emitLog("info",`\u25B8 \u4E0A\u4E0B\u6587${M}`,`\u79FB\u9664 ${A} \u6761\u6D88\u606F${F>0?`\uFF0C\u538B\u7F29 ${F} \u6761`:""}\uFF0C\u8282\u7701\u7EA6 ${H.toLocaleString()} tokens`),this.emitEvent({type:"status",status:"compacting",message:`Context compacted: -${A} messages`});}}else _.event_type==="response.completed"&&(process.env.CLI_DEBUG_CONSOLE==="1"&&f.debug("EVENTS","\u{1F4E4} Forwarding response.completed"),this.emitEvent({type:"raw_response_event",data:_.data,event_type:_.event_type}));break;case "run_done":break;case "error":f.error("AGENT",`Error: ${_.error||"Unknown error"}`),this.emitEvent({type:"error",message:_.error||"Unknown error"}),this.emitEvent({type:"status",status:"error",message:`Error: ${_.error||"Unknown error"}`});break;case "stream_retry":let k=_;this.emitEvent({type:"stream_retry",error:k.error,errorCode:k.errorCode||"STREAM_ERROR",attempt:k.attempt,maxRetries:k.maxRetries,delayMs:k.delayMs});break;case "stream_recovered":let D=_;this.emitEvent({type:"stream_recovered",attempt:D.attempt,maxRetries:D.maxRetries});break;case "plan_update":let N=_;f.info("RUNTIME_HOST","\u{1F525} Forwarding plan_update event",{hasExplanation:!!N.explanation,planSteps:N.plan?.length}),this.emitEvent({type:"plan_update",explanation:N.explanation,plan:N.plan,timestamp:N.timestamp||Date.now()});break}}process.env.CLI_DEBUG==="1"&&(f.debug("TASK","=== runner.run loop COMPLETED ==="),f.debug("TASK",` Total events: ${S}`),f.debug("TASK",` stdin.isPaused: ${process.stdin.isPaused?.()}`)),this.emitEvent({type:"text_complete"});let $=Date.now()-l,G=c;if(this.shouldInterrupt)this.emitEvent({type:"status",status:"error",message:"Task interrupted"});else if(this.emitEvent({type:"status",status:"complete",message:"Complete!"}),this.emitLog("info","Task complete",`${u} iterations, ${p} tool calls, ${d} tokens, ${($/1e3).toFixed(2)}s`),this.sessionSync&&this.sessionEnabled&&G)try{await this.sessionSync.saveTurn({role:"user",content:o},{role:"assistant",content:G});}catch{}let U={output:G,totalTokens:d,durationMs:$,iterations:u,toolCalls:p,interrupted:this.shouldInterrupt};return this.emitEvent({type:"run_result",output:G,totalTokens:d,iterations:u,toolCalls:p,durationMs:$}),U}catch(w){if(w?.code==="ERR_CANCELED"||w?.name==="CanceledError"||w?.name==="AbortError"||w?.category==="canceled"||this.shouldInterrupt){this.emitEvent({type:"text_complete"}),this.emitEvent({type:"status",status:"error",message:"Task interrupted"}),this.emitLog("info","Task interrupted by user");let R=Date.now()-l;return {output:c,totalTokens:d,durationMs:R,iterations:u,toolCalls:p,interrupted:true}}let x=w?.message||String(w)||"Unknown error";throw this.emitEvent({type:"text_complete"}),this.emitEvent({type:"status",status:"error",message:`Error: ${x}`}),this.emitLog("error",`Error: ${x}`),w}finally{process.env.CLI_DEBUG&&(f.debug("TASK","=== runTask finally block START ==="),f.debug("TASK",` isRunning was: ${this.isRunning}`)),i&&this.runner.setMode(n),this.isRunning=false,this.abortController=null,this.clearInterruptPromise(),process.env.CLI_DEBUG&&f.debug("TASK","=== runTask finally block END ===");}}syncWorkspaceEnv(){this.workDir&&(process.env.NEOX_WORKDIR=this.workDir);}async listSessions(){return this.sessionManager.listSessions()}getCurrentSessionId(){return this.session?.sessionId}async getSessionInfo(){if(!this.sessionSync)throw new Error("Session is not ready");return this.sessionSync.getSessionInfo()}async emitFileStreamEvent(e,t,s){let n=e.split(".").pop()||"",o={js:"javascript",ts:"typescript",tsx:"typescript",py:"python",html:"html",css:"css",json:"json",md:"markdown"}[n]||n,a=Date.now();this.emitEvent({type:"file_stream",filePath:e,content:t,isComplete:false,language:o,description:s,timestamp:a});}async handleWriteFile(e,t,s){let n=e.split(".").pop()||"",o={js:"javascript",ts:"typescript",tsx:"typescript",py:"python",html:"html",css:"css",json:"json",md:"markdown"}[n]||n,a=Date.now();try{let l=await import('fs'),c=await import('path'),u=c.isAbsolute(e)?c.resolve(e):c.resolve(this.workDir,e);if(this.sessionSync&&this.sessionEnabled)try{let p=null,d="create";l.existsSync(u)&&(d="modify",p=null);let m={type:"file_snapshot",data:{filePath:e,originalContent:p,operation:d,newContent:t}};await this.sessionSync.getSession().addItems([m]);}catch(p){console.debug("Failed to capture file snapshot",p);}this.emitEvent({type:"file_stream",filePath:e,content:t,isComplete:!0,language:o,description:s,timestamp:a}),this.emitLog("info",`\u2713 Saved ${e}`,`${t.split(`
|
|
1832
1832
|
`).length} lines written to disk`);}catch(l){this.emitEvent({type:"file_stream",filePath:e,content:t,isComplete:true,language:o,description:s,timestamp:a}),this.emitLog("error",`Error handling file write: ${l.message}`);}}async switchSession(e){let t=await this.sessionManager.getSession(e);if(!t)throw new Error(`Session ${e} not found`);return this.session=t,this.session}async createSession(e){let t=await this.sessionManager.createSession({model:e||this.model});return this.session=t,t}async saveTurn(e,t){!this.sessionSync||!this.sessionEnabled||await this.sessionSync.saveTurn({role:"user",content:e},{role:"assistant",content:t});}async undoTurns(e=1){if(!this.sessionSync)throw new Error("Session is not ready");return this.sessionSync.undo(e)}async createCheckpoint(e){if(!this.sessionSync)throw new Error("Session is not ready");let t=await this.sessionSync.createCheckpoint(e);return this.emitEvent({type:"checkpoint",id:t}),t}async listCheckpoints(){if(!this.sessionSync)throw new Error("Session is not ready");return await this.sessionSync.getSession().getCheckpoints()}async rollbackTo(e){if(!this.sessionSync)throw new Error("Session is not ready");return this.sessionSync.rollback(e)}async clearSession(){this.sessionSync&&await this.sessionSync.clearSession(),this.memory.clear();}async compactSession(){if(!this.sessionSync||!this.compatProfile)throw new Error("Compaction is not available");let e=this.sessionSync.getSession(),t=this.memory.getAll(),s=cs(t),n=s.totalTokens,i=s.systemTokens,o=s.userTokens+s.assistantTokens+s.toolCallTokens+s.toolResultTokens,l=this.memoryPressure?.getSnapshot()?.profile?.contextWindow||2e5,c=n/l,u=Math.round(c*100),d=(await e.getTimeline()).filter(g=>g.item.type==="message");process.env.CLI_DEBUG==="1"&&f.debug("COMPACT","Compaction status",{llmProvider:!!this.llmProvider,totalContextTokens:n,systemPromptTokens:i,dialogTokens:o,breakdown:s,messageCount:d.length,memoryMessageCount:t.length,contextWindow:l,pressure:c});let m=`\u603B Context: ${n.toLocaleString()} tokens (${u}% \u4F7F\u7528)
|
|
1833
1833
|
\u7CFB\u7EDF\u63D0\u793A\u8BCD: ${i.toLocaleString()} tokens
|
|
1834
1834
|
\u5BF9\u8BDD\u5386\u53F2: ${o.toLocaleString()} tokens (Memory: ${t.length-1} \u6761, Session: ${d.length} \u6761)`;this.emitCompacting("\u25A0 \u538B\u7F29\u524D\u72B6\u6001",m),this.emitCompacting("\u25C7 \u538B\u7F29\u65B9\u5F0F",`\u4F7F\u7528 LLM \u667A\u80FD\u538B\u7F29
|
|
1835
1835
|
\u5BF9\u8BDD\u5386\u53F2: ${(o/1e3).toFixed(1)}K tokens (${d.length} \u6761\u6D88\u606F)
|
|
1836
|
-
\u7CFB\u7EDF\u63D0\u793A\u8BCD: ${(i/1e3).toFixed(1)}K tokens (\u4E0D\u538B\u7F29)`);let h;if(!this.llmProvider){let g="LLM Provider \u672A\u521D\u59CB\u5316\uFF0C\u65E0\u6CD5\u8FDB\u884C\u667A\u80FD\u538B\u7F29\u3002\u8BF7\u786E\u4FDD\u5DF2\u914D\u7F6E provider\u3002";throw this.emitLog("error","\u274C \u538B\u7F29\u5931\u8D25",g),new Error(g)}try{if(h=await
|
|
1836
|
+
\u7CFB\u7EDF\u63D0\u793A\u8BCD: ${(i/1e3).toFixed(1)}K tokens (\u4E0D\u538B\u7F29)`);let h;if(!this.llmProvider){let g="LLM Provider \u672A\u521D\u59CB\u5316\uFF0C\u65E0\u6CD5\u8FDB\u884C\u667A\u80FD\u538B\u7F29\u3002\u8BF7\u786E\u4FDD\u5DF2\u914D\u7F6E provider\u3002";throw this.emitLog("error","\u274C \u538B\u7F29\u5931\u8D25",g),new Error(g)}try{if(h=await ia({session:e,profile:this.compatProfile,llmProvider:this.llmProvider,model:this.model,onProgress:(g,y)=>{let b={analyzing:"\u25C6 \u5206\u6790\u4E2D",summarizing:"\u26A1 \u751F\u6210\u6458\u8981",saving:"\u25B8 \u4FDD\u5B58\u4E2D"};this.emitCompacting(b[g],y||"");}}),h){await this.sessionSync.loadHistory();let y=(await e.getTimeline()).filter($=>$.item.type==="message"),b=cs(this.memory.getAll()),w=h.llmTokensUsed!==void 0;this.emitEvent({type:"context_compaction",status:"completed",originalMessages:d.length,keptMessages:y.length,droppedMessages:w?0:h.removedMessages,compressedMessages:w?h.removedMessages:0,originalTokens:n,finalTokens:b.totalTokens,budgetTokens:l,useLLM:w,timestamp:Date.now()});let S=(h.estimatedTokensSaved/1e3).toFixed(1),x=h.llmTokensUsed?` (\u6D88\u8017 ${h.llmTokensUsed} tokens)`:"",R=`\u79FB\u9664 ${h.removedMessages} \u6761\u5386\u53F2\uFF0C\u4FDD\u7559 ${h.keptMessages} \u6761\u8FD1\u671F\u6D88\u606F\uFF0C\u8282\u7701\u7EA6 ${S}K tokens${x}`;if(h.detailedStats){let{before:$,after:G,saved:U}=h.detailedStats,T=C=>(C/1e3).toFixed(1)+"K";R+=`
|
|
1837
1837
|
|
|
1838
1838
|
\u25A0 \u8BE6\u7EC6\u7EDF\u8BA1\uFF1A`,R+=`
|
|
1839
1839
|
\u250C\u2500 \u538B\u7F29\u524D\uFF1A`,R+=`
|
|
1840
|
-
\u2502 User: ${
|
|
1841
|
-
\u2502 \u603B\u8BA1: ${
|
|
1840
|
+
\u2502 User: ${T($.userTokens)} \u2022 Assistant: ${T($.assistantTokens)} \u2022 Tool: ${T($.toolTokens)}`,R+=`
|
|
1841
|
+
\u2502 \u603B\u8BA1: ${T($.totalTokens)}`,R+=`
|
|
1842
1842
|
\u251C\u2500 \u538B\u7F29\u540E\uFF1A`,R+=`
|
|
1843
|
-
\u2502 User: ${
|
|
1844
|
-
\u2502 Summary: ${
|
|
1845
|
-
\u2502 \u603B\u8BA1: ${
|
|
1843
|
+
\u2502 User: ${T(G.userTokens)} \u2022 Assistant: ${T(G.assistantTokens)} \u2022 Tool: ${T(G.toolTokens)}`,R+=`
|
|
1844
|
+
\u2502 Summary: ${T(G.summaryTokens)}`,R+=`
|
|
1845
|
+
\u2502 \u603B\u8BA1: ${T(G.totalTokens)}`,R+=`
|
|
1846
1846
|
\u2514\u2500 \u8282\u7701\uFF1A`,R+=`
|
|
1847
|
-
User: ${
|
|
1848
|
-
\u51C0\u8282\u7701: ${v(U.totalTokens)}`;}this.emitCompacting("\u2713 LLM \u538B\u7F29\u5B8C\u6210",R);}else this.emitCompacting("\u2139 \u65E0\u9700\u538B\u7F29","Context \u4F7F\u7528\u91CF\u5728\u9884\u7B97\u8303\u56F4\u5185");}catch(g){throw this.emitLog("error","\u274C LLM \u538B\u7F29\u5931\u8D25",g?.message||String(g)),g}}setSandboxMode(e){this.sandboxSetter?.(e);}setApprovalHandler(e){this.runner.setApprovalHandler(e);}setMode(e){this.runner.setMode(e);}setConversationHistory(e){this.memory.clear(),this.systemPrompt&&this.memory.add({role:"system",content:this.systemPrompt});for(let t of e)!t||!t.content||this.memory.add({role:t.role,content:t.content,name:t.name,tool_calls:t.tool_calls});}dispose(){this.isRunning&&this.interrupt(),this.abortController&&(this.abortController.abort(),this.abortController=null),this.eventEmitter.removeAllListeners(),this.memory.clear(),this.recentToolCalls.clear(),this.batchDetector.reset(),console.log("[AgentRuntimeHost] Disposed");}};var Rf="ark.cn-beijing.volces.com";function Ef(r){return r.includes("opus-4-6")||r.includes("opus-4.6")||r.includes("opus-4-5")||r.includes("opus-4.5")||r.endsWith("-thinking")}function na(r){return r.includes("doubao-seed")}function ra(r){return !!r&&r.includes(Rf)}function If(r){let e=r?.getProvider?.();return e instanceof It?e:void 0}function Mf(r){let e=r?.getProvider?.();return e instanceof js?e:void 0}function Af(r){let e=r?.getProvider?.();return e instanceof Gs?e:void 0}function Pf(r){let{model:e,baseUrl:t,openaiProvider:s,anthropicProvider:n,doubaoProvider:i,geminiProvider:o}=r,a={openai:s,anthropic:n,doubao:i,gemini:o},l=!!s&&ra(t)&&na(e);return (n||i||l)&&(a.setThinkingMode=u=>{if(i&&i.setThinking({type:u}),l&&s&&s.setDoubaoThinking({type:u}),n){let p=u==="auto"?"enabled":u;n.setThinking({type:p});}}),a}function hu(r){let{provider:e,model:t,sessionId:s}=r,n=e.protocol,i=e.models?.find(m=>m.name===t),o=e.baseUrl||void 0,a,l,c,u,p;if(n==="openai"||n==="openai-responses"||n==="kimi"){let m={...e,defaultModel:t,lastSelectedModel:t,apiEndpoint:e.urlSuffix,sessionId:s,modelConfig:i,doubaoThinking:ra(o)&&na(t)?{type:"enabled"}:void 0},h=Bs.createAdapter(n,m);a=h,l=If(h),l&&ra(o)&&na(t)&&l.setDoubaoThinking({type:"enabled"});}else if(n==="anthropic"){let m={...e,defaultModel:t,lastSelectedModel:t},h=Bs.createAdapter(n,m);a=h,c=Mf(h),c&&Ef(t)&&c.setThinking({type:"enabled"});}else if(n==="anthropic-openai"){let m=e.urlSuffix||"/v1/messages",h={apiKey:e.apiKey,baseUrl:o,defaultModel:t,apiEndpoint:m,streamFormat:"anthropic",sessionId:s,retry:e.retry,modelConfig:i};l=new It(h),a=l;}else if(n==="doubao")u=new li({apiKey:e.apiKey,baseUrl:o,defaultModel:t,thinking:{type:"enabled"},retry:e.retry}),a=u;else if(n==="gemini"){let m={...e,defaultModel:t,lastSelectedModel:t},h=Bs.createAdapter(n,m);a=h,p=Af(h);}else throw new Error(`Unsupported provider protocol: ${n}`);let d=Pf({model:t,baseUrl:o,openaiProvider:l,anthropicProvider:c,doubaoProvider:u,geminiProvider:p});return {llmProvider:a,controls:d}}function gu(r){return new Xr({llmProvider:r.llmProvider,model:r.model,tools:r.tools,memory:r.memory,config:r.config,agentName:r.agentName,agentDescription:r.agentDescription,instructions:r.instructions,contextInjection:r.contextInjection,plannerMode:r.plannerMode,structuredOutput:r.structuredOutput,providerName:r.providerName,contextWindow:r.contextWindow,tailTokenBudget:r.tailTokenBudget,maxInputTokensOverride:r.maxInputTokensOverride,toolInputGuardrails:r.toolInputGuardrails??Hc,toolOutputGuardrails:r.toolOutputGuardrails??zc,compressionMode:r.compressionMode,workspacePath:r.workspacePath,permissionManager:r.permissionManager,disableSystemPrompt:r.disableSystemPrompt})}function fu(r){return new mi({runner:r.runner,memory:r.memory,sessionManager:r.sessionManager||new At,sessionEnabled:r.sessionEnabled??false,workDir:r.workDir,model:r.model,memoryPressure:r.memoryPressure,compatProfile:r.compatProfile,systemPrompt:r.systemPrompt,setSandboxMode:r.setSandboxMode,llmProvider:r.llmProvider})}function yu(r){return new Ks(r)}de();async function ia(r){let{sessionId:e,provider:t,llmConfig:s,workspacePath:n,workDir:i,instructions:o,systemPrompt:a,agentName:l,agentDescription:c,permissionManager:u,tools:p,memory:d,memorySize:m,agentConfig:h,contextInjection:g,plannerMode:y,structuredOutput:b,toolInputGuardrails:w,toolOutputGuardrails:S,compressionMode:x,platformServices:R,sessionManager:L,sessionEnabled:H,disableSystemPrompt:U}=r,v=d??yu(m??50),T=typeof o=="string"?o:"[Function]";f.info("HOST_FACTORY",`Creating host with instructions length: ${T.length}`),f.info("HOST_FACTORY",`instructions contains \u534F\u4F5C\u6A21\u5F0F: ${T.includes("\u534F\u4F5C\u6A21\u5F0F")}`),f.info("HOST_FACTORY",`instructions contains delegate_task: ${T.includes("delegate_task")}`),f.debug("HOST_FACTORY",`instructions preview: ${T.substring(0,300)}`);let{llmProvider:_,controls:k}=hu({provider:t,model:s.model,sessionId:e}),M=s.compatProfile??null,W=M?new Yn(M):void 0,E=p??await Fo(n,R),D=h??{maxIterations:0,temperature:.7},N=gu({llmProvider:_,model:s.model,tools:E,memory:v,config:D,agentName:l,agentDescription:c,instructions:o,contextInjection:g,plannerMode:y,structuredOutput:b,providerName:s.providerName,contextWindow:M?.contextWindow,tailTokenBudget:M?.tailTokenBudget,maxInputTokensOverride:s.maxInputTokens,toolInputGuardrails:w,toolOutputGuardrails:S,compressionMode:x,workspacePath:n,permissionManager:u,disableSystemPrompt:U});return {host:fu({runner:N,memory:v,sessionManager:L??new At,sessionEnabled:H??false,workDir:i,model:s.model,memoryPressure:W,compatProfile:M,systemPrompt:a??(typeof o=="string"?o:""),llmProvider:_}),controls:k,llmProvider:_,runner:N,memory:v}}var oa=class{hostController;platformServices;constructor(e){this.platformServices=e.platformServices,this.hostController=e.hostController??new Kn;}setWorkspace(e){this.hostController.setWorkspace(e);}getHost(e){return this.hostController.getHost(e)}hasHost(e){return this.hostController.hasHost(e)}clearHost(e){this.hostController.clearHost(e);}clearAll(){this.hostController.clearAll();}forEachHost(e){this.hostController.forEachHost(e);}async getOrCreateHost(e){let{sessionId:t,configKey:s,provider:n,llmConfig:i,workspacePath:o,workDir:a,instructions:l,systemPrompt:c,agentName:u,agentDescription:p,permissionManager:d,tools:m,memory:h,memorySize:g,agentConfig:y,contextInjection:b,plannerMode:w,structuredOutput:S,toolInputGuardrails:x,toolOutputGuardrails:R,compressionMode:L,sessionManager:H,sessionEnabled:U,disableSystemPrompt:v,onHostCreated:T}=e;return this.hostController.getOrCreateHost({sessionId:t,configKey:s,createHost:async()=>{let{host:_,controls:k,llmProvider:M,runner:W,memory:E}=await ia({sessionId:t,provider:n,llmConfig:i,workspacePath:o,workDir:a,instructions:l,systemPrompt:c,agentName:u,agentDescription:p,permissionManager:d,tools:m,memory:h,memorySize:g,agentConfig:y,contextInjection:b,plannerMode:w,structuredOutput:S,toolInputGuardrails:x,toolOutputGuardrails:R,compressionMode:L,platformServices:this.platformServices,sessionManager:H,sessionEnabled:U,disableSystemPrompt:v});return T?.({host:_,controls:k,llmProvider:M,runner:W,memory:E}),_}})}async runTask(e){let{prompt:t,metadata:s,abortSignal:n,onHostReady:i,onEvent:o,...a}=e,l=await this.getOrCreateHost(a);i?.(l);let c=o?l.on(o):void 0;try{return await l.runTask(t,{metadata:s,abortSignal:n})}finally{c&&c();}}};async function bu(r){let e=r.initialProviderId,t=r.initialModelName,s=r.routeConfig,n=0,i=null,o=s?s.routes.filter(a=>a.enabled).length:r.resolvedRoute?.fallbackChain.length??1;for(;;)try{return await r.runAttempt({providerId:e,modelName:t,routeConfig:s,attempt:n,isRetry:n>0,previousError:i})}catch(a){let l=a instanceof Error?a:new Error(String(a));if(i=l,r.modelRouter&&e&&r.modelRouter.recordFailure(e,l),!!!(r.autoFailover&&r.resolvedRoute&&r.fallbackDecider&&r.modelAlias&&e))throw l;let u=r.fallbackDecider.shouldFallback(r.modelAlias,e,l,r.resolvedRoute.fallbackChain);if(u.shouldFallback&&u.targetProvider&&u.event){if(r.fallbackDecider.executeFallback(u),n+=1,e=u.targetProvider.providerId,t=u.targetProvider.modelName,s&&(s={...s,routes:s.routes.filter(p=>p.providerId!==u.event.fromProviderId)}),r.onRetry?.({providerId:e,modelName:t,attempt:n,decision:u}),n>=o)throw r.onExhausted?.("All providers have failed. Please try again later."),l;continue}throw u.exhausted&&r.onExhausted?.(u.reason),l}}var qn=240,hi=2e3;function dt(r,e){return r?r.length<=e?r:r.slice(0,e).trimEnd()+"...":""}var gi=class extends Error{code;constructor(e){super(e),this.code="missing_provider";}},aa=class{hostService;checkpointService;resolveProvider;actionLog;constructor(e){this.hostService=e.hostService,this.checkpointService=e.checkpointService,this.resolveProvider=e.resolveProvider,this.actionLog=e.actionLog;}async runSession(e){let{sessionId:t,prompt:s,metadata:n,startedAt:i=Date.now(),isAutoRouted:o,routeConfig:a,modelRouter:l,fallbackDecider:c,eventHub:u,abortSignal:p,buildHostConfig:d,onHostReady:m,onRuntimeEvent:h,onStatus:g,onRouteResolved:y,onRetry:b}=e,w=e.providerId,S=e.modelName,x=null,R=this.actionLog?.createRunId();if(this.actionLog){let U=dt(s,qn);this.actionLog.record({type:"run_start",sessionId:t,runId:R,actor:"user",summary:U?`User: ${U}`:"User: (empty prompt)",data:{prompt:dt(s,hi),promptLength:s.length,attachments:n?.attachments?.map(v=>({type:v.type,name:v.name,path:v.path}))}});}o&&a&&l&&(x=l.resolveProvider(a.modelAlias),x&&(w=x.providerId,S=x.modelName,y?.(x),x.degraded&&g?.("warning",`Using degraded provider: ${w}`)));let L=n;if(this.checkpointService)try{await this.checkpointService.startMessage(t);}catch{g?.("warning","Checkpoint start failed");}let H=false;try{let U=await bu({modelAlias:a?.modelAlias,initialProviderId:w,initialModelName:S,routeConfig:a,resolvedRoute:x,fallbackDecider:c,modelRouter:l??void 0,autoFailover:a?.autoFailover===!0,onRetry:({decision:v})=>{this.actionLog&&this.actionLog.record({type:"status",sessionId:t,runId:R,actor:"system",summary:v?.event?`Fallback: ${v.event.fromProviderId} -> ${v.event.toProviderId}`:"Fallback: switching provider",data:{from:v?.event?.fromProviderId,to:v?.event?.toProviderId,reason:v?.reason}}),b?.(v);},onExhausted:v=>{g?.("error",`All providers exhausted: ${v}`),this.actionLog&&this.actionLog.record({type:"run_error",sessionId:t,runId:R,actor:"system",summary:`All providers exhausted: ${dt(v,qn)}`,data:{reason:v}});},runAttempt:async v=>{let T=this.resolveProvider(v.providerId,v.modelName);if(!T.provider||!T.llmConfig)throw new gi("No provider configured. Please add an API provider first.");g?.("info",`Connecting to ${T.llmConfig.model}...`),this.actionLog&&this.actionLog.record({type:"run_attempt",sessionId:t,runId:R,actor:"system",summary:v.isRetry?`Retry ${v.attempt}: ${T.llmConfig.model}`:`Run: ${T.llmConfig.model}`,data:{providerId:T.provider.id,providerName:T.llmConfig.providerName,model:T.llmConfig.model,attempt:v.attempt,isRetry:v.isRetry,previousError:v.previousError?.message}});let _=d(T.provider,T.llmConfig),k={contextUsed:0,startTime:Date.now(),provider:T.llmConfig.providerName||T.provider.id||"unknown",model:T.llmConfig.model};return {summary:await this.hostService.runTask({..._,prompt:s,metadata:L,abortSignal:p,onHostReady:m,onEvent:W=>{if(this.actionLog){let E=this.buildActionLogEntry(W,t,R);E&&this.actionLog.record(E);}u?.emit(t,W,k),h?.(W,k);}}),contextUsed:k.contextUsed,providerId:T.provider.id}}});if(x&&U.providerId&&l){let v=Date.now()-i;l.recordSuccess(U.providerId,v),c&&c.recordSuccess(U.providerId);}if(this.checkpointService)try{await this.checkpointService.finishMessage(t,"Message completed"),H=!0;}catch{g?.("warning","Checkpoint save failed");}return {summary:U.summary,contextUsed:U.contextUsed,providerId:U.providerId}}catch(U){if(this.actionLog){let v=U instanceof Error?U.message:String(U);this.actionLog.record({type:"run_error",sessionId:t,runId:R,actor:"system",summary:`Run error: ${dt(v,qn)}`,data:{message:v}});}throw U}finally{if(this.checkpointService&&!H)try{await this.checkpointService.stopWatching();}catch{g?.("warning","Checkpoint cleanup failed");}}}buildActionLogEntry(e,t,s){if(!this.actionLog)return null;let n=i=>this.actionLog?.formatFilePath(i)??i;switch(e.type){case "tool_call_start":{let i=e.targetPath?n(e.targetPath):void 0,o=i?`Tool start: ${e.name} (${i})`:`Tool start: ${e.name}`,a=e.args?dt(JSON.stringify(e.args),hi):void 0;return {type:"tool_call_start",sessionId:t,runId:s,actor:"tool",summary:o,files:i?[i]:void 0,data:{name:e.name,toolId:e.toolId,batchId:e.batchId,targetPath:i,description:e.description,equivalentCommand:e.equivalentCommand,argsPreview:a}}}case "tool_call_end":{let i=e.targetPath?n(e.targetPath):void 0,o=i?`Tool ${e.success?"done":"failed"}: ${e.name} (${i})`:`Tool ${e.success?"done":"failed"}: ${e.name}`,a=e.output?dt(e.output,hi):void 0;return {type:"tool_call_end",sessionId:t,runId:s,actor:"tool",summary:o,files:i?[i]:void 0,data:{name:e.name,success:e.success,duration:e.duration,resultLength:e.resultLength,summary:e.summary,outputPreview:a,outputTruncated:e.outputTruncated,toolId:e.toolId,batchId:e.batchId,targetPath:i}}}case "file_stream":{if(!e.isComplete)return null;let i=n(e.filePath),o=e.additions||e.removals?`File updated: ${i} (+${e.additions??0}/-${e.removals??0})`:`File updated: ${i}`;return {type:"file_change",sessionId:t,runId:s,actor:"tool",summary:o,files:[i],data:{filePath:i,additions:e.additions,removals:e.removals,description:e.description,contentLength:e.content?.length??0}}}case "edit_file_stream":{if(!e.isComplete)return null;let i=n(e.filePath),o=`File edited: ${i}`;return {type:"file_change",sessionId:t,runId:s,actor:"tool",summary:o,files:[i],data:{filePath:i,startLine:e.startLine,hunks:e.hunks?.length??0,oldPreview:dt(e.oldString,200),newPreview:dt(e.newString,200),description:e.description}}}case "write_file_stream":{if(!e.isComplete)return null;let i=n(e.filePath),o=`File written: ${i}`;return {type:"file_change",sessionId:t,runId:s,actor:"tool",summary:o,files:[i],data:{filePath:i,contentLength:e.content?.length??0,description:e.description}}}case "checkpoint":return {type:"checkpoint",sessionId:t,runId:s,actor:"system",summary:`Checkpoint saved: ${e.id}`,data:{id:e.id,auto:e.auto}};case "plan_update":{let i=e.plan.length,o=e.plan.filter(c=>c.status==="completed").length,a=e.plan.filter(c=>c.status==="in_progress").length,l=i-o-a;return {type:"plan_update",sessionId:t,runId:s,actor:"assistant",summary:`Plan update: ${o} done, ${a} active, ${l} pending`,data:{explanation:e.explanation,plan:e.plan}}}case "context_compaction":return {type:"context_compaction",sessionId:t,runId:s,actor:"system",summary:`Context compacted: ${e.originalTokens} -> ${e.finalTokens} tokens`,data:{originalMessages:e.originalMessages,keptMessages:e.keptMessages,droppedMessages:e.droppedMessages,compressedMessages:e.compressedMessages,originalTokens:e.originalTokens,finalTokens:e.finalTokens,budgetTokens:e.budgetTokens,useLLM:e.useLLM}};case "stream_retry":return {type:"stream_retry",sessionId:t,runId:s,actor:"system",summary:`Stream retry ${e.attempt}/${e.maxRetries}: ${e.errorCode}`,data:{error:e.error,errorCode:e.errorCode,attempt:e.attempt,maxRetries:e.maxRetries,delayMs:e.delayMs}};case "stream_recovered":return {type:"stream_recovered",sessionId:t,runId:s,actor:"system",summary:`Stream recovered (attempt ${e.attempt})`,data:{attempt:e.attempt,maxRetries:e.maxRetries}};case "run_result":return {type:"run_result",sessionId:t,runId:s,actor:"assistant",summary:`Run completed in ${e.durationMs}ms, tokens ${e.totalTokens}`,data:{outputPreview:dt(e.output,hi),totalTokens:e.totalTokens,iterations:e.iterations,toolCalls:e.toolCalls,durationMs:e.durationMs}};case "error":return {type:"run_error",sessionId:t,runId:s,actor:"system",summary:`Runtime error: ${dt(e.message,qn)}`,data:{message:e.message}};case "error_classified":return {type:"run_error",sessionId:t,runId:s,actor:"system",summary:`Error ${e.code}: ${dt(e.message,qn)}`,data:{category:e.category,code:e.code,message:e.message,suggestion:e.suggestion,retryable:e.retryable}};default:return null}}};var Of=[".png",".jpg",".jpeg",".gif",".bmp",".ico",".webp",".svg",".tiff",".tif",".mp3",".mp4",".avi",".mov",".wmv",".flv",".wav",".ogg",".webm",".zip",".tar",".gz",".bz2",".7z",".rar",".xz",".exe",".dll",".so",".dylib",".bin",".app",".pdf",".doc",".docx",".xls",".xlsx",".ppt",".pptx",".db",".sqlite",".sqlite3",".ttf",".otf",".woff",".woff2",".eot",".jar",".war",".class",".pyc",".pyo",".o",".a",".lib",".node",".wasm",".asar"],wu={ignoredPatterns:["**/.git/**","**/.cdundo/**","**/.svn/**","**/.hg/**","**/.DS_Store","**/Thumbs.db","**/desktop.ini","**/*.log","**/*.tmp","**/*.temp","**/*.swp","**/*.swo","**/*~","**/node_modules/**","**/bower_components/**","**/.npm/**","**/.yarn/**","**/.pnpm-store/**","**/package-lock.json","**/yarn.lock","**/pnpm-lock.yaml","**/dist/**","**/build/**","**/out/**","**/output/**","**/.output/**","**/target/**","**/bin/**","**/obj/**","**/*.bundle.js","**/*.bundle.css","**/*.min.js","**/*.min.css","**/.next/**","**/.nuxt/**","**/.svelte-kit/**","**/.astro/**","**/.vercel/**","**/.netlify/**","**/.turbo/**","**/.cache/**","**/.parcel-cache/**","**/.webpack/**","**/.vite/**","**/coverage/**","**/.nyc_output/**","**/jest_cache/**","**/.jest/**","**/__pycache__/**","**/*.pyc","**/*.pyo","**/*.pyd","**/.venv/**","**/venv/**","**/env/**","**/.env/**","**/virtualenv/**","**/.Python","**/pip-wheel-metadata/**","**/*.egg-info/**","**/.eggs/**","**/site-packages/**","**/target/**","**/.gradle/**","**/gradle/**","**/.m2/**","**/*.class","**/*.jar","**/*.war","**/*.ear","**/target/**","**/*.rlib","**/Cargo.lock","**/vendor/**","**/go.sum","**/bin/**","**/obj/**","**/packages/**","**/.nuget/**","**/*.dll","**/*.exe","**/*.pdb","**/vendor/bundle/**","**/.bundle/**","**/Gemfile.lock","**/vendor/**","**/composer.lock","**/.idea/**","**/.vscode/**","**/*.sublime-*","**/.project","**/.classpath","**/.settings/**","**/*.iml","**/.env.local","**/.env.*.local","**/.env.development","**/.env.production","**/*.sqlite","**/*.sqlite3","**/*.db","**/npm-debug.log*","**/yarn-debug.log*","**/yarn-error.log*","**/.pnpm-debug.log*"],maxCheckpoints:50,checkpointTTL:864e5,enabled:true,largeFileThreshold:1048576,veryLargeFileThreshold:10485760,binaryExtensions:Of};var fi=class{workspacePath;shadowDir;shadowGitDir;git;watcher=null;changeBuffer=[];isWatching=false;currentSessionId=null;currentMessageIndex=0;config;changeCallbacks=new Set;initialized=false;debounceMap=new Map;DEBOUNCE_MS=100;gitOperationLock=Promise.resolve();GIT_RETRY_ATTEMPTS=3;GIT_RETRY_DELAY_MS=500;constructor(e={}){this.config={...wu,...e},this.workspacePath="",this.shadowDir="",this.shadowGitDir="",this.git=_u();}async init(e){if(this.initialized&&this.workspacePath===e){console.log("[ShadowGit] Already initialized for:",e);return}this.workspacePath=e,this.shadowDir=Y.join(e,".cdundo"),this.shadowGitDir=Y.join(this.shadowDir,".git"),console.log("[ShadowGit] Initializing for workspace:",e),await Q.mkdir(this.shadowDir,{recursive:true}),await this.addToGitignore();let t=xe.existsSync(this.shadowGitDir);this.git=_u(this.shadowDir),t?console.log("[ShadowGit] Using existing shadow git repository"):(await this.git.init(),await this.git.addConfig("user.email","checkpoint@neox.local"),await this.git.addConfig("user.name","Neox Checkpoint"),console.log("[ShadowGit] Created new shadow git repository")),await this.syncWorkspaceToShadow(),await this.withGitLock(async()=>{if((await this.git.status()).files.length>0||!t){await this.git.add(".");try{await this.git.commit("Initial checkpoint - workspace sync"),console.log("[ShadowGit] Created initial checkpoint");}catch{console.log("[ShadowGit] No changes to commit for initial checkpoint");}}}),this.initialized=true,console.log("[ShadowGit] Initialization complete");}beforeCheckpointId=null;async startWatching(e,t=0){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized. Call init() first.");if(this.isWatching)return console.log("[ShadowGit] Already watching, updating session info"),console.log("[ShadowGit] Clearing changeBuffer (was:",this.changeBuffer.length,"items)"),this.currentSessionId=e,this.currentMessageIndex=t,this.changeBuffer=[],this.beforeCheckpointId;console.log("[ShadowGit] Starting new watch, clearing changeBuffer (was:",this.changeBuffer.length,"items)"),this.currentSessionId=e,this.currentMessageIndex=t,this.changeBuffer=[];try{await this.withGitLock(async()=>{await this.syncWorkspaceToShadow(),await this.git.add("."),(await this.git.status()).files.length>0&&await this.git.commit(`Before session ${e} - auto checkpoint`);let i=await this.git.log({maxCount:1});this.beforeCheckpointId=i.latest?.hash||null,console.log("[ShadowGit] Created before-checkpoint:",this.beforeCheckpointId);});}catch(n){console.error("[ShadowGit] Failed to create before-checkpoint:",n);try{let i=await this.git.log({maxCount:1});this.beforeCheckpointId=i.latest?.hash||null;}catch{this.beforeCheckpointId=null;}}console.log("[ShadowGit] Starting file watcher for session:",e);let s=n=>!!(n.includes(".cdundo")||n.includes("/.cdundo/")||n.includes("node_modules")||n.includes("/node_modules/")||n.includes("/.git/")||n.endsWith("/.git")||n.includes("/dist/")||n.includes("/build/")||n.includes("/.next/")||n.includes(".DS_Store")||n.includes(".swp")||n.includes(".swo")||n.endsWith("package-lock.json")||n.endsWith("yarn.lock")||n.endsWith("pnpm-lock.yaml"));return this.watcher=Su.watch(this.workspacePath,{ignored:s,persistent:true,ignoreInitial:true,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},followSymlinks:false}),this.watcher.on("add",n=>this.handleChange("create",n)).on("change",n=>this.handleChange("modify",n)).on("unlink",n=>this.handleChange("delete",n)).on("addDir",n=>this.handleChange("mkdir",n)).on("unlinkDir",n=>this.handleChange("rmdir",n)).on("error",n=>console.error("[ShadowGit] Watcher error:",n)),this.isWatching=true,console.log("[ShadowGit] File watcher started"),this.beforeCheckpointId}getBeforeCheckpointId(){return this.beforeCheckpointId}async stopWatching(){this.watcher&&(await this.watcher.close(),this.watcher=null),this.isWatching=false,this.currentSessionId=null;for(let e of this.debounceMap.values())clearTimeout(e);this.debounceMap.clear(),this.changeBuffer=[],console.log("[ShadowGit] File watcher stopped");}handleChange(e,t){if(!this.isWatching)return;let s=Y.relative(this.workspacePath,t);if(this.shouldIgnorePath(s))return;let n=`${e}:${s}`,i=this.debounceMap.get(n);i&&clearTimeout(i),this.debounceMap.set(n,setTimeout(()=>{this.recordChange(e,s,t),this.debounceMap.delete(n);},this.DEBOUNCE_MS));}isBinaryFile(e){let t=Y.extname(e).toLowerCase();return this.config.binaryExtensions.includes(t)}async detectBinaryContent(e){try{let t=await Q.open(e,"r"),s=Buffer.alloc(8192),{bytesRead:n}=await t.read(s,0,8192,0);await t.close();for(let i=0;i<n;i++)if(s[i]===0)return !0;return !1}catch{return false}}async recordChange(e,t,s){let n={type:e,path:t,timestamp:Date.now()},i=this.isBinaryFile(t);n.isBinary=i;let o=0,a=false,l=false;if(e==="create"||e==="modify")try{let p=await Q.stat(s);if(p.isFile()&&(o=p.size,n.size=o,a=o>this.config.veryLargeFileThreshold,l=o>this.config.largeFileThreshold,n.isLargeFile=l,!i&&!l)){let d=await this.detectBinaryContent(s);n.isBinary=d;}}catch{}if((e==="delete"||e==="modify")&&!n.isBinary&&!l){let p=Y.join(this.shadowDir,t);try{let d=await Q.stat(p);d.isFile()&&d.size<this.config.largeFileThreshold&&(n.previousContent=await Q.readFile(p,"utf-8"));}catch{}}if((e==="create"||e==="modify")&&!n.isBinary&&!l)try{n.newContent=await Q.readFile(s,"utf-8");}catch{}this.changeBuffer.push(n),a?console.log(`[ShadowGit] Skipping very large file (${(o/1024/1024).toFixed(1)}MB): ${t}`):await this.syncFileToShadow(t,e,s);for(let p of this.changeCallbacks)try{p(n);}catch(d){console.error("[ShadowGit] Callback error:",d);}let c=o?` (${this.formatFileSize(o)})`:"",u=n.isBinary?" [binary]":"";console.log(`[ShadowGit] Recorded ${e}: ${t}${c}${u}`);}formatFileSize(e){return e<1024?`${e}B`:e<1024*1024?`${(e/1024).toFixed(1)}KB`:`${(e/1024/1024).toFixed(1)}MB`}async syncFileToShadow(e,t,s){let n=Y.join(this.shadowDir,e),i=Y.dirname(n);try{switch(t){case "create":case "modify":await Q.mkdir(i,{recursive:!0}),await Q.copyFile(s,n);break;case "delete":await Q.unlink(n).catch(()=>{});break;case "mkdir":await Q.mkdir(n,{recursive:!0});break;case "rmdir":await Q.rm(n,{recursive:!0,force:!0}).catch(()=>{});break}}catch(o){console.error(`[ShadowGit] Failed to sync ${e}:`,o);}}async syncWorkspaceToShadow(){console.log("[ShadowGit] Syncing workspace to shadow...");let e=0,t=0,s=0,n=async(i,o)=>{let a;try{a=await Q.readdir(i,{withFileTypes:!0});}catch{return}for(let l of a){let c=Y.join(i,l.name),u=Y.join(o,l.name),p=Y.relative(this.workspacePath,c);if(!this.shouldIgnore(p)){if(l.isDirectory())await Q.mkdir(u,{recursive:true}),await n(c,u);else if(l.isFile())try{let d=await Q.stat(c);if(d.size>this.config.veryLargeFileThreshold){t++,console.log(`[ShadowGit] Skipping very large file: ${p} (${this.formatFileSize(d.size)})`);continue}await Q.mkdir(Y.dirname(u),{recursive:!0}),await Q.copyFile(c,u),e++,s+=d.size;}catch{console.warn(`[ShadowGit] Failed to sync file: ${p}`);}}}};await n(this.workspacePath,this.shadowDir),console.log(`[ShadowGit] Workspace sync complete: ${e} files (${this.formatFileSize(s)}), ${t} large files skipped`);}shouldIgnorePath(e){return !!(e.startsWith(".cdundo")||e.includes("/.cdundo/")||e.includes("node_modules/")||e.startsWith("node_modules")||e.startsWith(".git")||e.includes("/.git/")||e.startsWith("dist/")||e.includes("/dist/")||e.startsWith("build/")||e.includes("/build/")||e.startsWith(".next/")||e.includes("/.next/")||e.includes(".DS_Store")||e.endsWith(".swp")||e.endsWith(".swo")||e.endsWith("package-lock.json")||e.endsWith("yarn.lock")||e.endsWith("pnpm-lock.yaml"))}shouldIgnore(e){if(this.shouldIgnorePath(e))return true;for(let t of this.config.ignoredPatterns)if(this.matchPattern(e,t))return true;return false}matchPattern(e,t){let s=t.replace(/\*\*/g,"<<<GLOBSTAR>>>").replace(/\*/g,"[^/]*").replace(/<<<GLOBSTAR>>>/g,".*").replace(/\?/g,".");return new RegExp(`^${s}$`).test(e)}async createCheckpoint(e){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized");return console.log("[ShadowGit] Creating checkpoint:",e),await this.withGitLock(async()=>{if(await this.git.add("."),(await this.git.status()).files.length===0&&this.changeBuffer.length===0)return console.log("[ShadowGit] No changes to checkpoint"),{id:(await this.git.log({maxCount:1})).latest?.hash||"no-changes",label:e,timestamp:Date.now(),sessionId:this.currentSessionId||"",messageIndex:this.currentMessageIndex,changes:[],stats:{created:0,modified:0,deleted:0,directories:0,total:0}};let s=this.calculateStats(),n=this.formatCommitMessage(e,s),i=await this.git.commit(n),o={id:i.commit,label:e,timestamp:Date.now(),sessionId:this.currentSessionId||"",messageIndex:this.currentMessageIndex,changes:[...this.changeBuffer],stats:s};return this.changeBuffer=[],this.currentMessageIndex++,console.log(`[ShadowGit] Checkpoint created: ${i.commit} (${s.total} changes)`),await this.cleanupOldCheckpoints(),o})}lastRollbackFromId=null;getLastRollbackFromId(){return this.lastRollbackFromId}async rollbackTo(e){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized");console.log("[ShadowGit] Rolling back to checkpoint:",e);let t=[],s=[],n;try{return await this.withGitLock(async()=>{await this.git.add(".");let i=await this.git.status();if(console.log("[ShadowGit] Current git status before rollback:",i.files.length,"files"),i.files.length>0)try{await this.git.commit("Changes before rollback (for reapply)"),console.log("[ShadowGit] Created commit for rollback comparison");}catch{console.log("[ShadowGit] No changes to commit (might be already committed)");}n=(await this.git.log({maxCount:1})).latest?.hash,this.lastRollbackFromId=n||null,console.log("[ShadowGit] Saved reapply checkpoint:",n);let a=await this.git.diff([e,"HEAD","--name-status"]),l=a.trim().split(`
|
|
1849
|
-
`).filter(c=>c.trim());console.log("[ShadowGit] Diff output:",a),console.log("[ShadowGit] Files to rollback:",l.length);for(let c of l){let[u,...p]=c.split(" "),d=p.join(" ");if(!d)continue;let m=
|
|
1847
|
+
User: ${T(U.userTokens)} \u2022 Assistant: ${T(U.assistantTokens)} \u2022 Tool: ${T(U.toolTokens)}`,R+=`
|
|
1848
|
+
\u51C0\u8282\u7701: ${T(U.totalTokens)}`;}this.emitCompacting("\u2713 LLM \u538B\u7F29\u5B8C\u6210",R);}else this.emitCompacting("\u2139 \u65E0\u9700\u538B\u7F29","Context \u4F7F\u7528\u91CF\u5728\u9884\u7B97\u8303\u56F4\u5185");}catch(g){throw this.emitLog("error","\u274C LLM \u538B\u7F29\u5931\u8D25",g?.message||String(g)),g}}setSandboxMode(e){this.sandboxSetter?.(e);}setApprovalHandler(e){this.runner.setApprovalHandler(e);}setMode(e){this.runner.setMode(e);}setConversationHistory(e){this.memory.clear(),this.systemPrompt&&this.memory.add({role:"system",content:this.systemPrompt});for(let t of e)!t||!t.content||this.memory.add({role:t.role,content:t.content,name:t.name,tool_calls:t.tool_calls});}dispose(){this.isRunning&&this.interrupt(),this.abortController&&(this.abortController.abort(),this.abortController=null),this.eventEmitter.removeAllListeners(),this.memory.clear(),this.recentToolCalls.clear(),this.batchDetector.reset(),console.log("[AgentRuntimeHost] Disposed");}};var $f="ark.cn-beijing.volces.com";function Nf(r){return r.includes("opus-4-6")||r.includes("opus-4.6")||r.includes("opus-4-5")||r.includes("opus-4.5")||r.endsWith("-thinking")}function oa(r){return r.includes("doubao-seed")}function aa(r){return !!r&&r.includes($f)}function Ff(r){let e=r?.getProvider?.();return e instanceof It?e:void 0}function Uf(r){let e=r?.getProvider?.();return e instanceof Gs?e:void 0}function jf(r){let e=r?.getProvider?.();return e instanceof Bs?e:void 0}function Gf(r){let{model:e,baseUrl:t,openaiProvider:s,anthropicProvider:n,doubaoProvider:i,geminiProvider:o}=r,a={openai:s,anthropic:n,doubao:i,gemini:o},l=!!s&&aa(t)&&oa(e);return (n||i||l)&&(a.setThinkingMode=u=>{if(i&&i.setThinking({type:u}),l&&s&&s.setDoubaoThinking({type:u}),n){let p=u==="auto"?"enabled":u;n.setThinking({type:p});}}),a}function _u(r){let{provider:e,model:t,sessionId:s}=r,n=e.protocol,i=e.models?.find(m=>m.name===t),o=e.baseUrl||void 0,a,l,c,u,p;if(n==="openai"||n==="openai-responses"||n==="kimi"){let m={...e,defaultModel:t,lastSelectedModel:t,apiEndpoint:e.urlSuffix,sessionId:s,modelConfig:i,doubaoThinking:aa(o)&&oa(t)?{type:"enabled"}:void 0},h=Ws.createAdapter(n,m);a=h,l=Ff(h),l&&aa(o)&&oa(t)&&l.setDoubaoThinking({type:"enabled"});}else if(n==="anthropic"){let m={...e,defaultModel:t,lastSelectedModel:t},h=Ws.createAdapter(n,m);a=h,c=Uf(h),c&&Nf(t)&&c.setThinking({type:"enabled"});}else if(n==="anthropic-openai"){let m=e.urlSuffix||"/v1/messages",h={apiKey:e.apiKey,baseUrl:o,defaultModel:t,apiEndpoint:m,streamFormat:"anthropic",sessionId:s,retry:e.retry,modelConfig:i};l=new It(h),a=l;}else if(n==="doubao")u=new pi({apiKey:e.apiKey,baseUrl:o,defaultModel:t,thinking:{type:"enabled"},retry:e.retry}),a=u;else if(n==="gemini"){let m={...e,defaultModel:t,lastSelectedModel:t},h=Ws.createAdapter(n,m);a=h,p=jf(h);}else throw new Error(`Unsupported provider protocol: ${n}`);let d=Gf({model:t,baseUrl:o,openaiProvider:l,anthropicProvider:c,doubaoProvider:u,geminiProvider:p});return {llmProvider:a,controls:d}}function Su(r){return new ei({llmProvider:r.llmProvider,model:r.model,tools:r.tools,memory:r.memory,config:r.config,agentName:r.agentName,agentDescription:r.agentDescription,instructions:r.instructions,contextInjection:r.contextInjection,plannerMode:r.plannerMode,structuredOutput:r.structuredOutput,providerName:r.providerName,contextWindow:r.contextWindow,tailTokenBudget:r.tailTokenBudget,maxInputTokensOverride:r.maxInputTokensOverride,toolInputGuardrails:r.toolInputGuardrails??Yc,toolOutputGuardrails:r.toolOutputGuardrails??Xc,compressionMode:r.compressionMode,workspacePath:r.workspacePath,permissionManager:r.permissionManager,disableSystemPrompt:r.disableSystemPrompt})}function ku(r){return new yi({runner:r.runner,memory:r.memory,sessionManager:r.sessionManager||new At,sessionEnabled:r.sessionEnabled??false,workDir:r.workDir,model:r.model,memoryPressure:r.memoryPressure,compatProfile:r.compatProfile,systemPrompt:r.systemPrompt,setSandboxMode:r.setSandboxMode,llmProvider:r.llmProvider})}function vu(r){return new Vs(r)}me();async function la(r){let{sessionId:e,provider:t,llmConfig:s,workspacePath:n,workDir:i,instructions:o,systemPrompt:a,agentName:l,agentDescription:c,permissionManager:u,tools:p,memory:d,memorySize:m,agentConfig:h,contextInjection:g,plannerMode:y,structuredOutput:b,toolInputGuardrails:w,toolOutputGuardrails:S,compressionMode:x,platformServices:R,sessionManager:$,sessionEnabled:G,disableSystemPrompt:U}=r,T=d??vu(m??50),C=typeof o=="string"?o:"[Function]";f.info("HOST_FACTORY",`Creating host with instructions length: ${C.length}`),f.info("HOST_FACTORY",`instructions contains \u534F\u4F5C\u6A21\u5F0F: ${C.includes("\u534F\u4F5C\u6A21\u5F0F")}`),f.info("HOST_FACTORY",`instructions contains delegate_task: ${C.includes("delegate_task")}`),f.debug("HOST_FACTORY",`instructions preview: ${C.substring(0,300)}`);let{llmProvider:_,controls:k}=_u({provider:t,model:s.model,sessionId:e}),D=s.compatProfile??null,N=D?new Xn(D):void 0,E=p??await Go(n,R),A=h??{maxIterations:0,temperature:.7},F=Su({llmProvider:_,model:s.model,tools:E,memory:T,config:A,agentName:l,agentDescription:c,instructions:o,contextInjection:g,plannerMode:y,structuredOutput:b,providerName:s.providerName,contextWindow:D?.contextWindow,tailTokenBudget:D?.tailTokenBudget,maxInputTokensOverride:s.maxInputTokens,toolInputGuardrails:w,toolOutputGuardrails:S,compressionMode:x,workspacePath:n,permissionManager:u,disableSystemPrompt:U});return {host:ku({runner:F,memory:T,sessionManager:$??new At,sessionEnabled:G??false,workDir:i,model:s.model,memoryPressure:N,compatProfile:D,systemPrompt:a??(typeof o=="string"?o:""),llmProvider:_}),controls:k,llmProvider:_,runner:F,memory:T}}var ca=class{hostController;platformServices;constructor(e){this.platformServices=e.platformServices,this.hostController=e.hostController??new Vn;}setWorkspace(e){this.hostController.setWorkspace(e);}getHost(e){return this.hostController.getHost(e)}hasHost(e){return this.hostController.hasHost(e)}clearHost(e){this.hostController.clearHost(e);}clearAll(){this.hostController.clearAll();}forEachHost(e){this.hostController.forEachHost(e);}async getOrCreateHost(e){let{sessionId:t,configKey:s,provider:n,llmConfig:i,workspacePath:o,workDir:a,instructions:l,systemPrompt:c,agentName:u,agentDescription:p,permissionManager:d,tools:m,memory:h,memorySize:g,agentConfig:y,contextInjection:b,plannerMode:w,structuredOutput:S,toolInputGuardrails:x,toolOutputGuardrails:R,compressionMode:$,sessionManager:G,sessionEnabled:U,disableSystemPrompt:T,onHostCreated:C}=e;return this.hostController.getOrCreateHost({sessionId:t,configKey:s,createHost:async()=>{let{host:_,controls:k,llmProvider:D,runner:N,memory:E}=await la({sessionId:t,provider:n,llmConfig:i,workspacePath:o,workDir:a,instructions:l,systemPrompt:c,agentName:u,agentDescription:p,permissionManager:d,tools:m,memory:h,memorySize:g,agentConfig:y,contextInjection:b,plannerMode:w,structuredOutput:S,toolInputGuardrails:x,toolOutputGuardrails:R,compressionMode:$,platformServices:this.platformServices,sessionManager:G,sessionEnabled:U,disableSystemPrompt:T});return C?.({host:_,controls:k,llmProvider:D,runner:N,memory:E}),_}})}async runTask(e){let{prompt:t,metadata:s,abortSignal:n,onHostReady:i,onEvent:o,...a}=e,l=await this.getOrCreateHost(a);i?.(l);let c=o?l.on(o):void 0;try{return await l.runTask(t,{metadata:s,abortSignal:n})}finally{c&&c();}}};async function Tu(r){let e=r.initialProviderId,t=r.initialModelName,s=r.routeConfig,n=0,i=null,o=s?s.routes.filter(a=>a.enabled).length:r.resolvedRoute?.fallbackChain.length??1;for(;;)try{return await r.runAttempt({providerId:e,modelName:t,routeConfig:s,attempt:n,isRetry:n>0,previousError:i})}catch(a){let l=a instanceof Error?a:new Error(String(a));if(i=l,r.modelRouter&&e&&r.modelRouter.recordFailure(e,l),!!!(r.autoFailover&&r.resolvedRoute&&r.fallbackDecider&&r.modelAlias&&e))throw l;let u=r.fallbackDecider.shouldFallback(r.modelAlias,e,l,r.resolvedRoute.fallbackChain);if(u.shouldFallback&&u.targetProvider&&u.event){if(r.fallbackDecider.executeFallback(u),n+=1,e=u.targetProvider.providerId,t=u.targetProvider.modelName,s&&(s={...s,routes:s.routes.filter(p=>p.providerId!==u.event.fromProviderId)}),r.onRetry?.({providerId:e,modelName:t,attempt:n,decision:u}),n>=o)throw r.onExhausted?.("All providers have failed. Please try again later."),l;continue}throw u.exhausted&&r.onExhausted?.(u.reason),l}}var Jn=240,bi=2e3;function dt(r,e){return r?r.length<=e?r:r.slice(0,e).trimEnd()+"...":""}var wi=class extends Error{code;constructor(e){super(e),this.code="missing_provider";}},ua=class{hostService;checkpointService;resolveProvider;actionLog;constructor(e){this.hostService=e.hostService,this.checkpointService=e.checkpointService,this.resolveProvider=e.resolveProvider,this.actionLog=e.actionLog;}async runSession(e){let{sessionId:t,prompt:s,metadata:n,startedAt:i=Date.now(),isAutoRouted:o,routeConfig:a,modelRouter:l,fallbackDecider:c,eventHub:u,abortSignal:p,buildHostConfig:d,onHostReady:m,onRuntimeEvent:h,onStatus:g,onRouteResolved:y,onRetry:b}=e,w=e.providerId,S=e.modelName,x=null,R=this.actionLog?.createRunId();if(this.actionLog){let U=dt(s,Jn);this.actionLog.record({type:"run_start",sessionId:t,runId:R,actor:"user",summary:U?`User: ${U}`:"User: (empty prompt)",data:{prompt:dt(s,bi),promptLength:s.length,attachments:n?.attachments?.map(T=>({type:T.type,name:T.name,path:T.path}))}});}o&&a&&l&&(x=l.resolveProvider(a.modelAlias),x&&(w=x.providerId,S=x.modelName,y?.(x),x.degraded&&g?.("warning",`Using degraded provider: ${w}`)));let $=n;if(this.checkpointService)try{await this.checkpointService.startMessage(t);}catch{g?.("warning","Checkpoint start failed");}let G=false;try{let U=await Tu({modelAlias:a?.modelAlias,initialProviderId:w,initialModelName:S,routeConfig:a,resolvedRoute:x,fallbackDecider:c,modelRouter:l??void 0,autoFailover:a?.autoFailover===!0,onRetry:({decision:T})=>{this.actionLog&&this.actionLog.record({type:"status",sessionId:t,runId:R,actor:"system",summary:T?.event?`Fallback: ${T.event.fromProviderId} -> ${T.event.toProviderId}`:"Fallback: switching provider",data:{from:T?.event?.fromProviderId,to:T?.event?.toProviderId,reason:T?.reason}}),b?.(T);},onExhausted:T=>{g?.("error",`All providers exhausted: ${T}`),this.actionLog&&this.actionLog.record({type:"run_error",sessionId:t,runId:R,actor:"system",summary:`All providers exhausted: ${dt(T,Jn)}`,data:{reason:T}});},runAttempt:async T=>{let C=this.resolveProvider(T.providerId,T.modelName);if(!C.provider||!C.llmConfig)throw new wi("No provider configured. Please add an API provider first.");g?.("info",`Connecting to ${C.llmConfig.model}...`),this.actionLog&&this.actionLog.record({type:"run_attempt",sessionId:t,runId:R,actor:"system",summary:T.isRetry?`Retry ${T.attempt}: ${C.llmConfig.model}`:`Run: ${C.llmConfig.model}`,data:{providerId:C.provider.id,providerName:C.llmConfig.providerName,model:C.llmConfig.model,attempt:T.attempt,isRetry:T.isRetry,previousError:T.previousError?.message}});let _=d(C.provider,C.llmConfig),k={contextUsed:0,startTime:Date.now(),provider:C.llmConfig.providerName||C.provider.id||"unknown",model:C.llmConfig.model};return {summary:await this.hostService.runTask({..._,prompt:s,metadata:$,abortSignal:p,onHostReady:m,onEvent:N=>{if(this.actionLog){let E=this.buildActionLogEntry(N,t,R);E&&this.actionLog.record(E);}u?.emit(t,N,k),h?.(N,k);}}),contextUsed:k.contextUsed,providerId:C.provider.id}}});if(x&&U.providerId&&l){let T=Date.now()-i;l.recordSuccess(U.providerId,T),c&&c.recordSuccess(U.providerId);}if(this.checkpointService)try{await this.checkpointService.finishMessage(t,"Message completed"),G=!0;}catch{g?.("warning","Checkpoint save failed");}return {summary:U.summary,contextUsed:U.contextUsed,providerId:U.providerId}}catch(U){if(this.actionLog){let T=U instanceof Error?U.message:String(U);this.actionLog.record({type:"run_error",sessionId:t,runId:R,actor:"system",summary:`Run error: ${dt(T,Jn)}`,data:{message:T}});}throw U}finally{if(this.checkpointService&&!G)try{await this.checkpointService.stopWatching();}catch{g?.("warning","Checkpoint cleanup failed");}}}buildActionLogEntry(e,t,s){if(!this.actionLog)return null;let n=i=>this.actionLog?.formatFilePath(i)??i;switch(e.type){case "tool_call_start":{let i=e.targetPath?n(e.targetPath):void 0,o=i?`Tool start: ${e.name} (${i})`:`Tool start: ${e.name}`,a=e.args?dt(JSON.stringify(e.args),bi):void 0;return {type:"tool_call_start",sessionId:t,runId:s,actor:"tool",summary:o,files:i?[i]:void 0,data:{name:e.name,toolId:e.toolId,batchId:e.batchId,targetPath:i,description:e.description,equivalentCommand:e.equivalentCommand,argsPreview:a}}}case "tool_call_end":{let i=e.targetPath?n(e.targetPath):void 0,o=i?`Tool ${e.success?"done":"failed"}: ${e.name} (${i})`:`Tool ${e.success?"done":"failed"}: ${e.name}`,a=e.output?dt(e.output,bi):void 0;return {type:"tool_call_end",sessionId:t,runId:s,actor:"tool",summary:o,files:i?[i]:void 0,data:{name:e.name,success:e.success,duration:e.duration,resultLength:e.resultLength,summary:e.summary,outputPreview:a,outputTruncated:e.outputTruncated,toolId:e.toolId,batchId:e.batchId,targetPath:i}}}case "file_stream":{if(!e.isComplete)return null;let i=n(e.filePath),o=e.additions||e.removals?`File updated: ${i} (+${e.additions??0}/-${e.removals??0})`:`File updated: ${i}`;return {type:"file_change",sessionId:t,runId:s,actor:"tool",summary:o,files:[i],data:{filePath:i,additions:e.additions,removals:e.removals,description:e.description,contentLength:e.content?.length??0}}}case "edit_file_stream":{if(!e.isComplete)return null;let i=n(e.filePath),o=`File edited: ${i}`;return {type:"file_change",sessionId:t,runId:s,actor:"tool",summary:o,files:[i],data:{filePath:i,startLine:e.startLine,hunks:e.hunks?.length??0,oldPreview:dt(e.oldString,200),newPreview:dt(e.newString,200),description:e.description}}}case "write_file_stream":{if(!e.isComplete)return null;let i=n(e.filePath),o=`File written: ${i}`;return {type:"file_change",sessionId:t,runId:s,actor:"tool",summary:o,files:[i],data:{filePath:i,contentLength:e.content?.length??0,description:e.description}}}case "checkpoint":return {type:"checkpoint",sessionId:t,runId:s,actor:"system",summary:`Checkpoint saved: ${e.id}`,data:{id:e.id,auto:e.auto}};case "plan_update":{let i=e.plan.length,o=e.plan.filter(c=>c.status==="completed").length,a=e.plan.filter(c=>c.status==="in_progress").length,l=i-o-a;return {type:"plan_update",sessionId:t,runId:s,actor:"assistant",summary:`Plan update: ${o} done, ${a} active, ${l} pending`,data:{explanation:e.explanation,plan:e.plan}}}case "context_compaction":return {type:"context_compaction",sessionId:t,runId:s,actor:"system",summary:`Context compacted: ${e.originalTokens} -> ${e.finalTokens} tokens`,data:{originalMessages:e.originalMessages,keptMessages:e.keptMessages,droppedMessages:e.droppedMessages,compressedMessages:e.compressedMessages,originalTokens:e.originalTokens,finalTokens:e.finalTokens,budgetTokens:e.budgetTokens,useLLM:e.useLLM}};case "stream_retry":return {type:"stream_retry",sessionId:t,runId:s,actor:"system",summary:`Stream retry ${e.attempt}/${e.maxRetries}: ${e.errorCode}`,data:{error:e.error,errorCode:e.errorCode,attempt:e.attempt,maxRetries:e.maxRetries,delayMs:e.delayMs}};case "stream_recovered":return {type:"stream_recovered",sessionId:t,runId:s,actor:"system",summary:`Stream recovered (attempt ${e.attempt})`,data:{attempt:e.attempt,maxRetries:e.maxRetries}};case "run_result":return {type:"run_result",sessionId:t,runId:s,actor:"assistant",summary:`Run completed in ${e.durationMs}ms, tokens ${e.totalTokens}`,data:{outputPreview:dt(e.output,bi),totalTokens:e.totalTokens,iterations:e.iterations,toolCalls:e.toolCalls,durationMs:e.durationMs}};case "error":return {type:"run_error",sessionId:t,runId:s,actor:"system",summary:`Runtime error: ${dt(e.message,Jn)}`,data:{message:e.message}};case "error_classified":return {type:"run_error",sessionId:t,runId:s,actor:"system",summary:`Error ${e.code}: ${dt(e.message,Jn)}`,data:{category:e.category,code:e.code,message:e.message,suggestion:e.suggestion,retryable:e.retryable}};default:return null}}};var Bf=[".png",".jpg",".jpeg",".gif",".bmp",".ico",".webp",".svg",".tiff",".tif",".mp3",".mp4",".avi",".mov",".wmv",".flv",".wav",".ogg",".webm",".zip",".tar",".gz",".bz2",".7z",".rar",".xz",".exe",".dll",".so",".dylib",".bin",".app",".pdf",".doc",".docx",".xls",".xlsx",".ppt",".pptx",".db",".sqlite",".sqlite3",".ttf",".otf",".woff",".woff2",".eot",".jar",".war",".class",".pyc",".pyo",".o",".a",".lib",".node",".wasm",".asar"],xu={ignoredPatterns:["**/.git/**","**/.cdundo/**","**/.svn/**","**/.hg/**","**/.DS_Store","**/Thumbs.db","**/desktop.ini","**/*.log","**/*.tmp","**/*.temp","**/*.swp","**/*.swo","**/*~","**/node_modules/**","**/bower_components/**","**/.npm/**","**/.yarn/**","**/.pnpm-store/**","**/package-lock.json","**/yarn.lock","**/pnpm-lock.yaml","**/dist/**","**/build/**","**/out/**","**/output/**","**/.output/**","**/target/**","**/bin/**","**/obj/**","**/*.bundle.js","**/*.bundle.css","**/*.min.js","**/*.min.css","**/.next/**","**/.nuxt/**","**/.svelte-kit/**","**/.astro/**","**/.vercel/**","**/.netlify/**","**/.turbo/**","**/.cache/**","**/.parcel-cache/**","**/.webpack/**","**/.vite/**","**/coverage/**","**/.nyc_output/**","**/jest_cache/**","**/.jest/**","**/__pycache__/**","**/*.pyc","**/*.pyo","**/*.pyd","**/.venv/**","**/venv/**","**/env/**","**/.env/**","**/virtualenv/**","**/.Python","**/pip-wheel-metadata/**","**/*.egg-info/**","**/.eggs/**","**/site-packages/**","**/target/**","**/.gradle/**","**/gradle/**","**/.m2/**","**/*.class","**/*.jar","**/*.war","**/*.ear","**/target/**","**/*.rlib","**/Cargo.lock","**/vendor/**","**/go.sum","**/bin/**","**/obj/**","**/packages/**","**/.nuget/**","**/*.dll","**/*.exe","**/*.pdb","**/vendor/bundle/**","**/.bundle/**","**/Gemfile.lock","**/vendor/**","**/composer.lock","**/.idea/**","**/.vscode/**","**/*.sublime-*","**/.project","**/.classpath","**/.settings/**","**/*.iml","**/.env.local","**/.env.*.local","**/.env.development","**/.env.production","**/*.sqlite","**/*.sqlite3","**/*.db","**/npm-debug.log*","**/yarn-debug.log*","**/yarn-error.log*","**/.pnpm-debug.log*"],maxCheckpoints:50,checkpointTTL:864e5,enabled:true,largeFileThreshold:1048576,veryLargeFileThreshold:10485760,binaryExtensions:Bf};var _i=class{workspacePath;shadowDir;shadowGitDir;git;watcher=null;changeBuffer=[];isWatching=false;currentSessionId=null;currentMessageIndex=0;config;changeCallbacks=new Set;initialized=false;debounceMap=new Map;DEBOUNCE_MS=100;gitOperationLock=Promise.resolve();GIT_RETRY_ATTEMPTS=3;GIT_RETRY_DELAY_MS=500;constructor(e={}){this.config={...xu,...e},this.workspacePath="",this.shadowDir="",this.shadowGitDir="",this.git=Cu();}async init(e){if(this.initialized&&this.workspacePath===e){console.log("[ShadowGit] Already initialized for:",e);return}this.workspacePath=e,this.shadowDir=X.join(e,".cdundo"),this.shadowGitDir=X.join(this.shadowDir,".git"),console.log("[ShadowGit] Initializing for workspace:",e),await Z.mkdir(this.shadowDir,{recursive:true}),await this.addToGitignore();let t=Ce.existsSync(this.shadowGitDir);this.git=Cu(this.shadowDir),t?console.log("[ShadowGit] Using existing shadow git repository"):(await this.git.init(),await this.git.addConfig("user.email","checkpoint@neox.local"),await this.git.addConfig("user.name","Neox Checkpoint"),console.log("[ShadowGit] Created new shadow git repository")),await this.syncWorkspaceToShadow(),await this.withGitLock(async()=>{if((await this.git.status()).files.length>0||!t){await this.git.add(".");try{await this.git.commit("Initial checkpoint - workspace sync"),console.log("[ShadowGit] Created initial checkpoint");}catch{console.log("[ShadowGit] No changes to commit for initial checkpoint");}}}),this.initialized=true,console.log("[ShadowGit] Initialization complete");}beforeCheckpointId=null;async startWatching(e,t=0){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized. Call init() first.");if(this.isWatching)return console.log("[ShadowGit] Already watching, updating session info"),console.log("[ShadowGit] Clearing changeBuffer (was:",this.changeBuffer.length,"items)"),this.currentSessionId=e,this.currentMessageIndex=t,this.changeBuffer=[],this.beforeCheckpointId;console.log("[ShadowGit] Starting new watch, clearing changeBuffer (was:",this.changeBuffer.length,"items)"),this.currentSessionId=e,this.currentMessageIndex=t,this.changeBuffer=[];try{await this.withGitLock(async()=>{await this.syncWorkspaceToShadow(),await this.git.add("."),(await this.git.status()).files.length>0&&await this.git.commit(`Before session ${e} - auto checkpoint`);let i=await this.git.log({maxCount:1});this.beforeCheckpointId=i.latest?.hash||null,console.log("[ShadowGit] Created before-checkpoint:",this.beforeCheckpointId);});}catch(n){console.error("[ShadowGit] Failed to create before-checkpoint:",n);try{let i=await this.git.log({maxCount:1});this.beforeCheckpointId=i.latest?.hash||null;}catch{this.beforeCheckpointId=null;}}console.log("[ShadowGit] Starting file watcher for session:",e);let s=n=>!!(n.includes(".cdundo")||n.includes("/.cdundo/")||n.includes("node_modules")||n.includes("/node_modules/")||n.includes("/.git/")||n.endsWith("/.git")||n.includes("/dist/")||n.includes("/build/")||n.includes("/.next/")||n.includes(".DS_Store")||n.includes(".swp")||n.includes(".swo")||n.endsWith("package-lock.json")||n.endsWith("yarn.lock")||n.endsWith("pnpm-lock.yaml"));return this.watcher=Ru.watch(this.workspacePath,{ignored:s,persistent:true,ignoreInitial:true,awaitWriteFinish:{stabilityThreshold:100,pollInterval:50},followSymlinks:false}),this.watcher.on("add",n=>this.handleChange("create",n)).on("change",n=>this.handleChange("modify",n)).on("unlink",n=>this.handleChange("delete",n)).on("addDir",n=>this.handleChange("mkdir",n)).on("unlinkDir",n=>this.handleChange("rmdir",n)).on("error",n=>console.error("[ShadowGit] Watcher error:",n)),this.isWatching=true,console.log("[ShadowGit] File watcher started"),this.beforeCheckpointId}getBeforeCheckpointId(){return this.beforeCheckpointId}async stopWatching(){this.watcher&&(await this.watcher.close(),this.watcher=null),this.isWatching=false,this.currentSessionId=null;for(let e of this.debounceMap.values())clearTimeout(e);this.debounceMap.clear(),this.changeBuffer=[],console.log("[ShadowGit] File watcher stopped");}handleChange(e,t){if(!this.isWatching)return;let s=X.relative(this.workspacePath,t);if(this.shouldIgnorePath(s))return;let n=`${e}:${s}`,i=this.debounceMap.get(n);i&&clearTimeout(i),this.debounceMap.set(n,setTimeout(()=>{this.recordChange(e,s,t),this.debounceMap.delete(n);},this.DEBOUNCE_MS));}isBinaryFile(e){let t=X.extname(e).toLowerCase();return this.config.binaryExtensions.includes(t)}async detectBinaryContent(e){try{let t=await Z.open(e,"r"),s=Buffer.alloc(8192),{bytesRead:n}=await t.read(s,0,8192,0);await t.close();for(let i=0;i<n;i++)if(s[i]===0)return !0;return !1}catch{return false}}async recordChange(e,t,s){let n={type:e,path:t,timestamp:Date.now()},i=this.isBinaryFile(t);n.isBinary=i;let o=0,a=false,l=false;if(e==="create"||e==="modify")try{let p=await Z.stat(s);if(p.isFile()&&(o=p.size,n.size=o,a=o>this.config.veryLargeFileThreshold,l=o>this.config.largeFileThreshold,n.isLargeFile=l,!i&&!l)){let d=await this.detectBinaryContent(s);n.isBinary=d;}}catch{}if((e==="delete"||e==="modify")&&!n.isBinary&&!l){let p=X.join(this.shadowDir,t);try{let d=await Z.stat(p);d.isFile()&&d.size<this.config.largeFileThreshold&&(n.previousContent=await Z.readFile(p,"utf-8"));}catch{}}if((e==="create"||e==="modify")&&!n.isBinary&&!l)try{n.newContent=await Z.readFile(s,"utf-8");}catch{}this.changeBuffer.push(n),a?console.log(`[ShadowGit] Skipping very large file (${(o/1024/1024).toFixed(1)}MB): ${t}`):await this.syncFileToShadow(t,e,s);for(let p of this.changeCallbacks)try{p(n);}catch(d){console.error("[ShadowGit] Callback error:",d);}let c=o?` (${this.formatFileSize(o)})`:"",u=n.isBinary?" [binary]":"";console.log(`[ShadowGit] Recorded ${e}: ${t}${c}${u}`);}formatFileSize(e){return e<1024?`${e}B`:e<1024*1024?`${(e/1024).toFixed(1)}KB`:`${(e/1024/1024).toFixed(1)}MB`}async syncFileToShadow(e,t,s){let n=X.join(this.shadowDir,e),i=X.dirname(n);try{switch(t){case "create":case "modify":await Z.mkdir(i,{recursive:!0}),await Z.copyFile(s,n);break;case "delete":await Z.unlink(n).catch(()=>{});break;case "mkdir":await Z.mkdir(n,{recursive:!0});break;case "rmdir":await Z.rm(n,{recursive:!0,force:!0}).catch(()=>{});break}}catch(o){console.error(`[ShadowGit] Failed to sync ${e}:`,o);}}async syncWorkspaceToShadow(){console.log("[ShadowGit] Syncing workspace to shadow...");let e=0,t=0,s=0,n=async(i,o)=>{let a;try{a=await Z.readdir(i,{withFileTypes:!0});}catch{return}for(let l of a){let c=X.join(i,l.name),u=X.join(o,l.name),p=X.relative(this.workspacePath,c);if(!this.shouldIgnore(p)){if(l.isDirectory())await Z.mkdir(u,{recursive:true}),await n(c,u);else if(l.isFile())try{let d=await Z.stat(c);if(d.size>this.config.veryLargeFileThreshold){t++,console.log(`[ShadowGit] Skipping very large file: ${p} (${this.formatFileSize(d.size)})`);continue}await Z.mkdir(X.dirname(u),{recursive:!0}),await Z.copyFile(c,u),e++,s+=d.size;}catch{console.warn(`[ShadowGit] Failed to sync file: ${p}`);}}}};await n(this.workspacePath,this.shadowDir),console.log(`[ShadowGit] Workspace sync complete: ${e} files (${this.formatFileSize(s)}), ${t} large files skipped`);}shouldIgnorePath(e){return !!(e.startsWith(".cdundo")||e.includes("/.cdundo/")||e.includes("node_modules/")||e.startsWith("node_modules")||e.startsWith(".git")||e.includes("/.git/")||e.startsWith("dist/")||e.includes("/dist/")||e.startsWith("build/")||e.includes("/build/")||e.startsWith(".next/")||e.includes("/.next/")||e.includes(".DS_Store")||e.endsWith(".swp")||e.endsWith(".swo")||e.endsWith("package-lock.json")||e.endsWith("yarn.lock")||e.endsWith("pnpm-lock.yaml"))}shouldIgnore(e){if(this.shouldIgnorePath(e))return true;for(let t of this.config.ignoredPatterns)if(this.matchPattern(e,t))return true;return false}matchPattern(e,t){let s=t.replace(/\*\*/g,"<<<GLOBSTAR>>>").replace(/\*/g,"[^/]*").replace(/<<<GLOBSTAR>>>/g,".*").replace(/\?/g,".");return new RegExp(`^${s}$`).test(e)}async createCheckpoint(e){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized");return console.log("[ShadowGit] Creating checkpoint:",e),await this.withGitLock(async()=>{if(await this.git.add("."),(await this.git.status()).files.length===0&&this.changeBuffer.length===0)return console.log("[ShadowGit] No changes to checkpoint"),{id:(await this.git.log({maxCount:1})).latest?.hash||"no-changes",label:e,timestamp:Date.now(),sessionId:this.currentSessionId||"",messageIndex:this.currentMessageIndex,changes:[],stats:{created:0,modified:0,deleted:0,directories:0,total:0}};let s=this.calculateStats(),n=this.formatCommitMessage(e,s),i=await this.git.commit(n),o={id:i.commit,label:e,timestamp:Date.now(),sessionId:this.currentSessionId||"",messageIndex:this.currentMessageIndex,changes:[...this.changeBuffer],stats:s};return this.changeBuffer=[],this.currentMessageIndex++,console.log(`[ShadowGit] Checkpoint created: ${i.commit} (${s.total} changes)`),await this.cleanupOldCheckpoints(),o})}lastRollbackFromId=null;getLastRollbackFromId(){return this.lastRollbackFromId}async rollbackTo(e){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized");console.log("[ShadowGit] Rolling back to checkpoint:",e);let t=[],s=[],n;try{return await this.withGitLock(async()=>{await this.git.add(".");let i=await this.git.status();if(console.log("[ShadowGit] Current git status before rollback:",i.files.length,"files"),i.files.length>0)try{await this.git.commit("Changes before rollback (for reapply)"),console.log("[ShadowGit] Created commit for rollback comparison");}catch{console.log("[ShadowGit] No changes to commit (might be already committed)");}n=(await this.git.log({maxCount:1})).latest?.hash,this.lastRollbackFromId=n||null,console.log("[ShadowGit] Saved reapply checkpoint:",n);let a=await this.git.diff([e,"HEAD","--name-status"]),l=a.trim().split(`
|
|
1849
|
+
`).filter(c=>c.trim());console.log("[ShadowGit] Diff output:",a),console.log("[ShadowGit] Files to rollback:",l.length);for(let c of l){let[u,...p]=c.split(" "),d=p.join(" ");if(!d)continue;let m=X.join(this.workspacePath,d),h=X.join(this.shadowDir,d);console.log(`[ShadowGit] Processing: status=${u}, file=${d}`);try{switch(u){case "A":console.log(`[ShadowGit] Deleting added file: ${m}`),await Z.unlink(m).catch(g=>{console.log(`[ShadowGit] Failed to delete workspace file: ${g}`);}),await Z.unlink(h).catch(()=>{}),t.push(`deleted: ${d}`);break;case "M":console.log(`[ShadowGit] Restoring modified file: ${d}`),await this.git.checkout([e,"--",d]),await Z.mkdir(X.dirname(m),{recursive:!0}),await Z.copyFile(h,m),t.push(`restored: ${d}`);break;case "D":console.log(`[ShadowGit] Recovering deleted file: ${d}`),await this.git.checkout([e,"--",d]),await Z.mkdir(X.dirname(m),{recursive:!0}),await Z.copyFile(h,m),t.push(`recovered: ${d}`);break;default:console.log(`[ShadowGit] Unhandled status ${u} for ${d}`);}}catch(g){console.error(`[ShadowGit] Error processing ${d}:`,g),s.push(`${d}: ${g}`);}}await this.git.reset(["--hard",e]),this.changeBuffer=[],console.log(`[ShadowGit] Rollback complete: ${t.length} restored, ${s.length} errors`);}),{success:s.length===0,restored:t,errors:s,reapplyCheckpointId:n}}catch(i){return console.error("[ShadowGit] Rollback failed:",i),{success:false,restored:t,errors:[String(i)],reapplyCheckpointId:n}}}async rollbackSingleFile(e){if(!this.initialized)return {success:false,error:"ShadowGitCheckpoint not initialized"};console.log("[ShadowGit] Rolling back single file:",e);let t=this.beforeCheckpointId;if(!t)return {success:false,error:"No before checkpoint available. Make sure startWatching() was called before this message."};let s=X.join(this.workspacePath,e),n=X.join(this.shadowDir,e);try{return await this.withGitLock(async()=>{let i=await this.git.diff([t,"HEAD","--name-status","--",e]);if(console.log("[ShadowGit] File diff status:",i.trim()),!i.trim())return console.log("[ShadowGit] File has no changes since before checkpoint"),{success:!0};let[o]=i.trim().split(" ");switch(o){case "A":console.log("[ShadowGit] File was added after checkpoint, deleting:",e);try{return await Z.unlink(s),await Z.unlink(n).catch(()=>{}),{success:!0}}catch(a){return {success:!1,error:`Failed to delete file: ${a}`}}case "M":case "D":console.log("[ShadowGit] Restoring file from before checkpoint:",e);try{return await this.git.checkout([t,"--",e]),await Z.mkdir(X.dirname(s),{recursive:!0}),await Z.copyFile(n,s),console.log("[ShadowGit] Successfully rolled back file:",e),{success:!0}}catch(a){return {success:!1,error:`Failed to restore file: ${a}`}}default:return console.log("[ShadowGit] Unhandled status:",o),{success:!1,error:`Unhandled file status: ${o}`}}})}catch(i){return console.error("[ShadowGit] Failed to rollback single file:",i),{success:false,error:String(i)}}}async reapplySingleFile(e){if(!this.initialized)return {success:false,error:"ShadowGitCheckpoint not initialized"};console.log("[ShadowGit] Reapplying single file:",e);try{return await this.withGitLock(async()=>{let t=X.join(this.workspacePath,e),s=X.join(this.shadowDir,e);try{return await this.git.checkout(["HEAD","--",e]),await Z.mkdir(X.dirname(t),{recursive:!0}),await Z.copyFile(s,t),console.log("[ShadowGit] Successfully reapplied file:",e),{success:!0}}catch(n){return {success:!1,error:`File not found in HEAD: ${n}`}}})}catch(t){return console.error("[ShadowGit] Failed to reapply single file:",t),{success:false,error:String(t)}}}async getCheckpoints(e=50,t){if(!this.initialized)return [];try{let s=t?e*3:e,i=(await this.git.log({maxCount:s})).all.map(o=>{let a=this.parseCommitMessage(o.message);return {id:o.hash,label:a.label,timestamp:new Date(o.date).getTime(),sessionId:a.sessionId,messageIndex:a.messageIndex,stats:a.stats}});return t&&(i=i.filter(o=>o.sessionId===t)),i.slice(0,e)}catch(s){return console.error("[ShadowGit] Failed to get checkpoints:",s),[]}}async getDiff(e,t="HEAD"){if(!this.initialized)throw new Error("ShadowGitCheckpoint not initialized");await this.git.diff([e,t,"--stat","--numstat"]);let n=await this.git.diffSummary([e,t]),i=n.files.map(o=>{let a="insertions"in o&&"deletions"in o;return {path:o.file,status:this.getFileStatus(o),additions:a?o.insertions:0,deletions:a?o.deletions:0,lines:[]}});return {checkpointId:e,files:i,stats:{filesChanged:n.changed,additions:n.insertions,deletions:n.deletions}}}getChangeBuffer(){return this.isWatching?[...this.changeBuffer]:(console.log("[ShadowGit] getChangeBuffer called but not watching, returning empty array"),[])}getCurrentStats(){if(!this.isWatching)return console.log("[ShadowGit] getCurrentStats called but not watching, returning empty stats"),{created:0,modified:0,deleted:0,directories:0,total:0};let e=this.calculateStats();return console.log("[ShadowGit] getCurrentStats called, changeBuffer length:",this.changeBuffer.length),this.changeBuffer.length>0&&console.log("[ShadowGit] changeBuffer contents:",this.changeBuffer.map(t=>`${t.type}: ${t.path}`)),e}onFileChange(e){return this.changeCallbacks.add(e),()=>this.changeCallbacks.delete(e)}isInitialized(){return this.initialized}isActive(){return this.isWatching}getShadowDir(){return this.shadowDir}calculateStats(){let e={created:0,modified:0,deleted:0,directories:0,total:0};for(let t of this.changeBuffer)switch(t.type){case "create":e.created++;break;case "modify":e.modified++;break;case "delete":e.deleted++;break;case "mkdir":case "rmdir":e.directories++;break}return e.total=e.created+e.modified+e.deleted+e.directories,e}formatCommitMessage(e,t){let s=this.currentSessionId?`
|
|
1850
1850
|
|
|
1851
1851
|
Session: ${this.currentSessionId}
|
|
1852
1852
|
Message: ${this.currentMessageIndex}`:"";return `${e}
|
|
1853
1853
|
|
|
1854
1854
|
Stats: +${t.created} ~${t.modified} -${t.deleted} d${t.directories}${s}`}parseCommitMessage(e){let t=e.split(`
|
|
1855
|
-
`),s=t[0]||"Unknown",n="",i=0,o={created:0,modified:0,deleted:0,directories:0,total:0};for(let a of t)if(a.startsWith("Session:"))n=a.replace("Session:","").trim();else if(a.startsWith("Message:"))i=parseInt(a.replace("Message:","").trim())||0;else if(a.startsWith("Stats:")){let l=a.match(/\+(\d+)\s+~(\d+)\s+-(\d+)\s+d(\d+)/);l&&(o.created=parseInt(l[1]),o.modified=parseInt(l[2]),o.deleted=parseInt(l[3]),o.directories=parseInt(l[4]),o.total=o.created+o.modified+o.deleted+o.directories);}return {label:s,sessionId:n,messageIndex:i,stats:o}}getFileStatus(e){let t=e.insertions??0,s=e.deletions??0;return t>0&&s===0?"A":s>0&&t===0?"D":"M"}async addToGitignore(){let e=
|
|
1855
|
+
`),s=t[0]||"Unknown",n="",i=0,o={created:0,modified:0,deleted:0,directories:0,total:0};for(let a of t)if(a.startsWith("Session:"))n=a.replace("Session:","").trim();else if(a.startsWith("Message:"))i=parseInt(a.replace("Message:","").trim())||0;else if(a.startsWith("Stats:")){let l=a.match(/\+(\d+)\s+~(\d+)\s+-(\d+)\s+d(\d+)/);l&&(o.created=parseInt(l[1]),o.modified=parseInt(l[2]),o.deleted=parseInt(l[3]),o.directories=parseInt(l[4]),o.total=o.created+o.modified+o.deleted+o.directories);}return {label:s,sessionId:n,messageIndex:i,stats:o}}getFileStatus(e){let t=e.insertions??0,s=e.deletions??0;return t>0&&s===0?"A":s>0&&t===0?"D":"M"}async addToGitignore(){let e=X.join(this.workspacePath,".gitignore");try{let t="";try{t=await Z.readFile(e,"utf-8");}catch{}if(!t.includes(".cdundo")){let s=t.trim()?`${t.trim()}
|
|
1856
1856
|
|
|
1857
1857
|
# Neox checkpoint directory
|
|
1858
1858
|
.cdundo/
|
|
1859
1859
|
`:`# Neox checkpoint directory
|
|
1860
1860
|
.cdundo/
|
|
1861
|
-
`;await
|
|
1861
|
+
`;await Z.writeFile(e,s),console.log("[ShadowGit] Added .cdundo to .gitignore");}}catch(t){console.error("[ShadowGit] Failed to update .gitignore:",t);}}async cleanupOldCheckpoints(){try{let e=await this.getCheckpoints(this.config.maxCheckpoints+10);e.length>this.config.maxCheckpoints&&(console.log(`[ShadowGit] Cleaning up old checkpoints (${e.length} > ${this.config.maxCheckpoints})`),await this.compressRepository());}catch(e){console.error("[ShadowGit] Failed to cleanup checkpoints:",e);}}async compressRepository(){if(!this.initialized)return {success:false};try{let e=await this.getRepositorySize();console.log("[ShadowGit] Compressing repository..."),await this.git.raw(["reflog","expire","--expire=now","--all"]),await this.git.raw(["gc","--aggressive","--prune=now"]),await this.git.raw(["repack","-a","-d","--depth=250","--window=250"]);let t=await this.getRepositorySize(),s=e-t;return console.log(`[ShadowGit] Repository compressed: ${this.formatFileSize(e)} \u2192 ${this.formatFileSize(t)} (saved ${this.formatFileSize(s)})`),{success:!0,savedBytes:s}}catch(e){return console.error("[ShadowGit] Failed to compress repository:",e),{success:false}}}async getRepositorySize(){let e=0,t=async s=>{try{let n=await Z.readdir(s,{withFileTypes:!0});for(let i of n){let o=X.join(s,i.name);if(i.isDirectory())await t(o);else if(i.isFile()){let a=await Z.stat(o);e+=a.size;}}}catch{}};return await t(this.shadowGitDir),e}async getStorageStats(){let e=await this.getRepositorySize(),t=0,s=async i=>{try{let o=await Z.readdir(i,{withFileTypes:!0});for(let a of o){let l=X.join(i,a.name);if(a.isDirectory()&&a.name!==".git")await s(l);else if(a.isFile()){let c=await Z.stat(l);t+=c.size;}}}catch{}};await s(this.shadowDir);let n=await this.getCheckpoints(1e3);return {repositorySize:e,shadowDirSize:t,checkpointCount:n.length,oldestCheckpoint:n.length>0?{id:n[n.length-1].id,timestamp:n[n.length-1].timestamp}:void 0,newestCheckpoint:n.length>0?{id:n[0].id,timestamp:n[0].timestamp}:void 0}}async cleanStaleLocks(){let e=X.join(this.shadowGitDir,"index.lock");try{if(Ce.existsSync(e)){let s=await Z.stat(e);Date.now()-s.mtimeMs>1e4&&(await Z.unlink(e),console.log("[ShadowGit] Cleaned stale lock file"));}}catch{}}async withGitLock(e){let t=this.gitOperationLock,s=()=>{};this.gitOperationLock=new Promise(n=>{s=n;});try{await t;let n;for(let i=1;i<=this.GIT_RETRY_ATTEMPTS;i++)try{return i>1&&(await this.cleanStaleLocks(),await new Promise(a=>setTimeout(a,this.GIT_RETRY_DELAY_MS))),await e()}catch(o){if(n=o,!(o.message&&(o.message.includes("index.lock")||o.message.includes("File exists")))||i===this.GIT_RETRY_ATTEMPTS)throw o;console.warn(`[ShadowGit] Git operation failed (attempt ${i}/${this.GIT_RETRY_ATTEMPTS}), retrying...`);}throw n}finally{s();}}async destroy(){await this.stopWatching(),this.initialized=false,this.changeCallbacks.clear(),console.log("[ShadowGit] Instance destroyed");}};var Kn=class r{static instance=null;instances=new Map;config;constructor(e={}){this.config=e;}static getInstance(e){return r.instance||(r.instance=new r(e)),r.instance}async getCheckpoint(e){let t=X.normalize(e);if(!this.instances.has(t)){let s=new _i(this.config);await s.init(t),this.instances.set(t,s);}return this.instances.get(t)}async startWatching(e,t,s=0){return (await this.getCheckpoint(e)).startWatching(t,s)}getBeforeCheckpointId(e){let t=X.normalize(e);return this.instances.get(t)?.getBeforeCheckpointId()??null}async stopWatching(e){let t=X.normalize(e),s=this.instances.get(t);s&&await s.stopWatching();}async createCheckpoint(e,t){return (await this.getCheckpoint(e)).createCheckpoint(t)}async rollbackTo(e,t){return (await this.getCheckpoint(e)).rollbackTo(t)}async rollbackSingleFile(e,t){return (await this.getCheckpoint(e)).rollbackSingleFile(t)}async reapplySingleFile(e,t){return (await this.getCheckpoint(e)).reapplySingleFile(t)}async getCheckpoints(e,t,s){return (await this.getCheckpoint(e)).getCheckpoints(t,s)}async getDiff(e,t,s){return (await this.getCheckpoint(e)).getDiff(t,s)}async getChangeBuffer(e){return (await this.getCheckpoint(e)).getChangeBuffer()}async getCurrentStats(e){return (await this.getCheckpoint(e)).getCurrentStats()}async onFileChange(e,t){return (await this.getCheckpoint(e)).onFileChange(t)}isWatching(e){let t=X.normalize(e);return this.instances.get(t)?.isActive()??false}async cleanup(e){let t=X.normalize(e),s=this.instances.get(t);s&&(await s.destroy(),this.instances.delete(t));let n=X.join(t,".cdundo");try{await Z.rm(n,{recursive:!0,force:!0}),console.log("[CheckpointManager] Cleaned up:",n);}catch(i){console.error("[CheckpointManager] Failed to cleanup:",i);}}async destroyAll(){for(let[e,t]of this.instances)await t.destroy();this.instances.clear(),console.log("[CheckpointManager] All instances destroyed");}getActiveWorkspaces(){return Array.from(this.instances.keys()).filter(e=>this.instances.get(e)?.isActive())}getStats(){return {totalInstances:this.instances.size,activeInstances:this.getActiveWorkspaces().length,workspaces:Array.from(this.instances.keys())}}};Kn.getInstance();var da=class{checkpointManager;workspacePath=null;enabled=true;sessionMessageCounts=new Map;constructor(e){this.checkpointManager=e??Kn.getInstance();}setWorkspace(e){this.workspacePath=e;}setEnabled(e){this.enabled=e;}isEnabled(){return this.enabled}async startMessage(e){if(!this.enabled||!this.workspacePath)return null;let t=this.sessionMessageCounts.get(e)||0;return this.checkpointManager.startWatching(this.workspacePath,e,t)}async finishMessage(e,t){if(!this.enabled||!this.workspacePath)return null;let s=await this.createCheckpoint(e,t);return await this.checkpointManager.stopWatching(this.workspacePath),s}async stopWatching(){this.workspacePath&&await this.checkpointManager.stopWatching(this.workspacePath);}async createCheckpoint(e,t){if(!this.enabled||!this.workspacePath)return null;let s=this.sessionMessageCounts.get(e)||0,n=t||`Message #${s+1}`,i=await this.checkpointManager.createCheckpoint(this.workspacePath,n);return this.sessionMessageCounts.set(e,s+1),i}async rollbackToCheckpoint(e){return this.workspacePath?this.checkpointManager.rollbackTo(this.workspacePath,e):{success:false,restored:[],errors:["No workspace set"]}}async rollbackSingleFile(e){return this.workspacePath?this.checkpointManager.rollbackSingleFile(this.workspacePath,e):{success:false,error:"No workspace set"}}async reapplySingleFile(e){return this.workspacePath?this.checkpointManager.reapplySingleFile(this.workspacePath,e):{success:false,error:"No workspace set"}}async getCheckpoints(e,t){return this.workspacePath?this.checkpointManager.getCheckpoints(this.workspacePath,e,t):[]}async getCurrentStats(){return this.workspacePath?this.checkpointManager.getCurrentStats(this.workspacePath):null}async getChangeBuffer(){return this.workspacePath?this.checkpointManager.getChangeBuffer(this.workspacePath):[]}async cleanup(){this.workspacePath&&await this.checkpointManager.cleanup(this.workspacePath);}};function Wf(r,e,t){if(e?.setThinkingMode)return e.setThinkingMode(r),true;let s=t;return s?.setThinking?(s.setThinking({type:r==="auto"?"enabled":r}),true):s?.setDoubaoThinking?(s.setDoubaoThinking({type:r}),true):false}function Hf(){return {...En(),capabilities:Mo}}export{da as RuntimeCheckpointService,ca as RuntimeHostService,ua as RuntimeOrchestrator,wi as RuntimeOrchestratorError,Wf as applyThinkingMode,Yo as buildInstructions,la as createAgentRuntimeHost,Hf as createElectronServices,En as createNodeServices,Mo as electronToolCapabilities,Go as getTools,Ur as nodeToolCapabilities,Ih as preloadShellEnv,vc as setToolServices};
|