qlogicagent 2.10.10 → 2.10.11
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/agent.js
CHANGED
|
@@ -14,7 +14,7 @@ var qo=Object.defineProperty;var en=(t,e)=>()=>(t&&(e=t(t=0)),e);var tn=(t,e)=>{
|
|
|
14
14
|
...
|
|
15
15
|
`:`
|
|
16
16
|
`,e+=Bi,e}async function Uo(t,e,o,n=io){if(t.length<=n||Ao(t))return t;let i=await Io(t,e,o);return i?Oo(i):t.slice(0,n)+`
|
|
17
|
-
...[truncated ${t.length-n} chars]`}function zi(t){let e=[],o=[];for(let n of t)n.role==="tool"&&typeof n.content=="string"&&n.tool_call_id?Ao(n.content)||o.push({toolCallId:n.tool_call_id,content:n.content,size:n.content.length}):n.role==="assistant"&&o.length>0&&(e.push(o),o=[]);return o.length>0&&e.push(o),e}function Hi(t,e){let o=[],n=[],i=[];for(let s of t){let l=e.replacements.get(s.toolCallId);l!==void 0?o.push({...s,replacement:l}):e.seenIds.has(s.toolCallId)?n.push(s):i.push(s)}return{mustReapply:o,frozen:n,fresh:i}}function Ki(t,e,o){let n=[...t].sort((l,r)=>r.size-l.size),i=[],s=e+t.reduce((l,r)=>l+r.size,0);for(let l of n){if(s<=o)break;i.push(l),s-=l.size}return i}async function Po(t,e,o,n=so){let i=zi(t);if(i.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,l=[];for(let m of i){let{mustReapply:g,frozen:M,fresh:T}=Hi(m,e);for(let w of g)s.set(w.toolCallId,w.replacement);if(T.length===0){for(let w of m)e.seenIds.add(w.toolCallId);continue}let v=M.reduce((w,A)=>w+A.size,0),x=T.reduce((w,A)=>w+A.size,0),C=v+x>n?Ki(T,v,n):[],L=new Set(C.map(w=>w.toolCallId));for(let w of m)L.has(w.toolCallId)||e.seenIds.add(w.toolCallId);C.length>0&&l.push(...C)}if(s.size===0&&l.length===0)return{messages:t,newlyReplacedCount:0};let r=await Promise.all(l.map(async m=>{let g=await Io(m.content,m.toolCallId,o);return{candidate:m,result:g}})),d=0;for(let{candidate:m,result:g}of r){if(e.seenIds.add(m.toolCallId),!g)continue;let M=Oo(g);s.set(m.toolCallId,M),e.replacements.set(m.toolCallId,M),d++}return s.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(m=>{if(m.role!=="tool"||!m.tool_call_id)return m;let g=s.get(m.tool_call_id);return g===void 0?m:{...m,content:g}}),newlyReplacedCount:d}}var Vi=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),Xi=new Set(["bash","execute_command","Bash","shell"]),Pe=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??Vi,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let o=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:o,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let o=this.tools.filter(i=>i.status==="executing"),n=this.config.maxConcurrentTools;return n&&n>0&&o.length>=n?!1:o.length===0||e&&o.every(i=>i.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let o;try{o=JSON.parse(e.toolCall.function.arguments)}catch{}let n=o?.command??o?.file_path??o?.pattern??"";if(typeof n=="string"&&n.length>0){let i=n.length>40?n.slice(0,40)+"\u2026":n;return`${e.toolCall.function.name}(${i})`}return e.toolCall.function.name}createSyntheticError(e,o){let n=this.erroredToolDescription,i=o==="user_interrupted"?"User rejected tool use":o==="discarded"?"Streaming fallback - tool execution discarded":n?`Cancelled: parallel tool call ${n} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:i,message:j(e.id,{ok:!1,error:i})}}async executeTool(e){e.status="executing";let n=(async()=>{let i=this.getAbortReason();if(i){e.results.push(this.createSyntheticError(e,i)),e.status="completed";return}let{toolInvoker:s,hooks:l,sessionId:r,turnId:d,log:h}=this.config,m=e.toolCall.function.name,g=!1,M=e.toolCall.function.arguments;if(l)try{let w=await l.invoke("tool.before_invoke",{sessionId:r,turnId:d,callId:e.id,toolName:m,arguments:Yi(M)});if(w.action==="abort"){let A=w.reason??"blocked by policy";h.info(`tool ${m} blocked: ${A}`),e.results.push({callId:e.id,toolName:m,ok:!1,error:A,blocked:!0,blockReason:A,message:j(e.id,{ok:!1,error:A})}),e.status="completed";return}w.action==="continue"&&w.context?.arguments&&(M=JSON.stringify(w.context.arguments))}catch{}let T=await s.invoke(d,m,M,this.siblingAbortController.signal),v=this.getAbortReason();if(v&&!g){e.results.push(this.createSyntheticError(e,v)),e.status="completed";return}let x=!T.error,C=T.result;x&&C&&C.length>5e4&&(C=await Uo(C,e.id,r));let L=j(e.id,{ok:x,payload:C,error:T.error,toolReferences:T.toolReferences,imageUrls:T.imageUrls});x||(g=!0,Xi.has(m)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),l?.invoke(x?"tool.after_invoke":"tool.invoke_failed",{sessionId:r,turnId:d,callId:e.id,toolName:m,ok:x,...T.error?{error:T.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:m,ok:x,error:T.error,message:L}),e.status="completed"})();e.promise=n,n.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let o of e.results)yield o}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(n=>n.status==="executing"&&n.promise).map(n=>n.promise),o=new Promise(n=>{this.progressResolve=n});e.length>0&&await Promise.race([...e,o])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}};function Yi(t){try{return JSON.parse(t)}catch{return}}import{readFile as gu}from"node:fs/promises";import*as D from"node:fs";import{homedir as Ji}from"node:os";import{join as Lo}from"node:path";import{existsSync as ru}from"node:fs";var Qi=".qlogicagent";function Zi(){return process.env.QLOGICAGENT_HOME||Lo(Ji(),Qi)}function $o(){return Lo(Zi(),"settings.json")}var Le=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let o of e){this.pools.set(o.providerId,o);for(let n of o.keys)this.runtimeStates.set(n.id,this.createInitialState())}}acquireKey(e){let o=this.pools.get(e);if(!o||o.keys.length===0)return null;let n=Date.now(),i=this.getHealthyCandidates(o,n);if(i.length===0)return null;let s=this.selectByStrategy(i,o.strategy,n);if(!s)return null;let l=this.runtimeStates.get(s.id);return l.inFlight++,l.totalRequests++,l.lastUsedAt=n,l.requestTimestamps.push(n),{keyId:s.id,apiKey:s.key,providerId:e,release:r=>this.releaseKey(s.id,r)}}releaseKey(e,o){let n=this.runtimeStates.get(e);if(n)if(n.inFlight=Math.max(0,n.inFlight-1),o.success)n.consecutiveErrors=0,n.healthStatus="healthy",o.tokens&&(n.totalTokens+=o.tokens,n.tokenCounts.push(o.tokens));else if(n.consecutiveErrors++,n.lastErrorAt=Date.now(),o.errorCode===429){let i=o.retryAfter?o.retryAfter*1e3:3e4;n.cooldownUntil=Date.now()+i,n.healthStatus="cooldown"}else n.consecutiveErrors>=5?(n.cooldownUntil=Date.now()+6e4,n.healthStatus="cooldown"):n.consecutiveErrors>=3&&(n.healthStatus="degraded")}addProvider(e,o){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:o?.baseUrl,strategy:o?.strategy??"weighted-round-robin",keys:[],rateLimit:o?.rateLimit})}removeProvider(e){let o=this.pools.get(e);if(o){for(let n of o.keys)this.runtimeStates.delete(n.id);this.pools.delete(e)}}addKey(e,o,n){let i=this.pools.get(e);i||(i={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,i));let s=n?.id??crypto.randomUUID(),l={id:s,key:o,label:n?.label,weight:n?.weight??1,enabled:n?.enabled??!0};return i.keys.push(l),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let o of this.pools.values()){let n=o.keys.findIndex(i=>i.id===e);if(n!==-1){o.keys.splice(n,1),this.runtimeStates.delete(e);return}}}updateKey(e,o){for(let n of this.pools.values()){let i=n.keys.find(s=>s.id===e);if(i){if(o.label!==void 0&&(i.label=o.label),o.weight!==void 0&&(i.weight=o.weight),o.enabled!==void 0){i.enabled=o.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=o.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,o){let n=this.runtimeStates.get(e);n&&(n.healthStatus=o)}setStrategy(e,o){let n=this.pools.get(e);n&&(n.strategy=o)}setRateLimit(e,o){let n=this.pools.get(e);n&&(n.rateLimit=o)}getPoolStatus(e){let o=this.pools.get(e);return o?this.buildPoolStatus(o):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let o=this.pools.get(e);return o?this.getHealthyCandidates(o,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let o=new Set;for(let n of e){this.pools.set(n.providerId,n);for(let i of n.keys)o.add(i.id),this.runtimeStates.has(i.id)||this.runtimeStates.set(i.id,this.createInitialState())}for(let n of[...this.pools.keys()])e.some(i=>i.providerId===n)||this.pools.delete(n);for(let n of[...this.runtimeStates.keys()])o.has(n)||this.runtimeStates.delete(n)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,o){let n=[];for(let i of e.keys){if(!i.enabled)continue;let s=this.runtimeStates.get(i.id);if(s){if(s.healthStatus==="cooldown")if(o>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,o),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,o),s.tokenCounts.reduce((r,d)=>r+d,0)>=e.rateLimit.tpm*.9)||n.push(i))}}return n}selectByStrategy(e,o,n){if(e.length===0)return null;if(e.length===1)return e[0];switch(o){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let o=e.reduce((i,s)=>i+s.weight,0),n=Math.random()*o;for(let i of e)if(n-=i.weight,n<=0)return i;return e[e.length-1]}leastBusy(e){let o=1/0,n=e[0];for(let i of e){let l=this.runtimeStates.get(i.id)?.inFlight??0;(l<o||l===o&&i.weight>n.weight)&&(o=l,n=i)}return n}pruneWindow(e,o){let n=o-6e4;for(;e.length>0&&e[0]<n;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(o=>{let n=this.runtimeStates.get(o.id)??this.createInitialState();return{...o,inFlight:n.inFlight,totalRequests:n.totalRequests,totalTokens:n.totalTokens,lastUsedAt:n.lastUsedAt,lastErrorAt:n.lastErrorAt,consecutiveErrors:n.consecutiveErrors,cooldownUntil:n.cooldownUntil,healthStatus:o.enabled?n.healthStatus:"disabled"}})}}};var qi=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],_t=class{keyPool;coreProviderRegistry=new le;providerVariantResolver=new ce(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=$o(),this.keyPool=new Le(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let o=this.bindings[e];if(!o)return null;let n=this.models.get(o);if(!n||!n.enabled)return null;let i=this.resolveTechnicalVariant(n,e),s=i?.provider??n.provider,l=i?.nativeModelId??n.nativeModelId??n.model,r=this.acquireKeyForProviderVariant(s);if(!r)return null;let{keyHandle:d,keyProviderId:h}=r;return{provider:s,model:l,apiKey:d.apiKey,baseUrl:n.provider===s?n.baseUrl??this.getProviderBaseUrl(s)??this.getProviderBaseUrl(h):this.getProviderBaseUrl(s),keyHandle:d}}peekActiveModel(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}isAvailable(e){let o=this.peekActiveModel(e);return!!o?.enabled&&this.hasAvailableKeyForProviderVariant(o.provider)}resolveModelForPurpose(e){let o=this.peekActiveModel(e);return o?o.model:null}addProvider(e,o){this.keyPool.addProvider(e,o),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[o,n]of this.models)n.provider===e&&this.removeModel(o);this.emitChange()}addKey(e,o,n){let i=this.keyPool.addKey(e,o,n);return this.emitChange(),i}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,o){this.keyPool.updateKey(e,o),this.emitChange()}setKeyHealth(e,o){this.keyPool.setKeyHealth(e,o),this.emitChange()}setStrategy(e,o){this.keyPool.setStrategy(e,o),this.emitChange()}addModel(e){let o=e.id??`${e.provider}:${e.model}`;return this.models.set(o,{...e,id:o,enabled:this.modelEnabledOverrides.get(o)??e.enabled}),this.emitChange(),o}replaceCatalogModels(e){let o=new Map;for(let n of e)o.set(n.id,{...n,enabled:this.modelEnabledOverrides.get(n.id)??n.enabled});for(let n of this.modelEnabledOverrides.keys())o.has(n)||this.modelEnabledOverrides.delete(n);this.models=o;for(let[n,i]of Object.entries(this.bindings))i&&!this.models.has(i)&&delete this.bindings[n];this.emitChange()}migrateModelIds(e){for(let[o,n]of e){let i=this.modelEnabledOverrides.get(o);i!==void 0&&!this.modelEnabledOverrides.has(n)&&this.modelEnabledOverrides.set(n,i),this.modelEnabledOverrides.delete(o);for(let[s,l]of Object.entries(this.bindings))l===o&&(this.bindings[s]=n)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[o,n]of Object.entries(this.bindings))n===e&&delete this.bindings[o];this.emitChange()}enableModel(e){let o=this.models.get(e);o&&(o.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let o=this.models.get(e);o&&(o.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let o=[...this.models.values()];return e?.purpose&&(o=o.filter(n=>n.purposes.includes(e.purpose))),e?.provider&&(o=o.filter(n=>n.provider===e.provider)),e?.enabledOnly&&(o=o.filter(n=>n.enabled)),o}getModel(e){return this.models.get(e)??null}setBinding(e,o){let n=this.models.get(o);if(!n)throw new Error(`Model "${o}" not found in pool.`);if(!n.purposes.includes(e))throw new Error(`Model "${o}" does not support purpose "${e}".`);this.bindings[e]=o,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}getAllBindings(){let e={};for(let o of qi){let n=this.bindings[o];e[o]=n?this.models.get(n)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{D.existsSync(this.settingsPath)&&(e=JSON.parse(D.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let o={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},n=this.settingsPath.replace(/[/\\][^/\\]+$/,"");D.existsSync(n)||D.mkdirSync(n,{recursive:!0}),D.writeFileSync(this.settingsPath,JSON.stringify(o,null,2),"utf-8")}load(){try{if(!D.existsSync(this.settingsPath))return!1;let e=D.readFileSync(this.settingsPath,"utf-8"),o=JSON.parse(e);return o.providers&&this.keyPool.reloadConfig(o.providers),this.models.clear(),this.modelEnabledOverrides.clear(),o.models&&this.loadModelState(o.models),this.bindings=o.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!D.existsSync(this.settingsPath))return;let o=D.readFileSync(this.settingsPath,"utf-8");return JSON.parse(o).tunables?.[e]}catch{return}}getModelInfo(e,o){let n=this.listModels({provider:e}).find(i=>i.model===o);if(n)return{id:n.model,name:n.displayName,contextWindow:n.contextWindow,maxOutput:n.maxOutput,streamRequired:n.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>!!this.keyPool.getPoolStatus(o)?.keys.some(i=>i.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>this.keyPool.hasAvailableKey(o))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(o=>({id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let o=this.changeListeners.indexOf(e);o>=0&&this.changeListeners.splice(o,1)}}getKeyForProvider(e){let n=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!n)return null;let i=n.apiKey;return n.release({success:!0}),i}snapshotProviderKeys(){let e={};for(let o of this.keyPool.getAllStatus()){let n=this.getKeyForProvider(o.providerId);n&&(e[o.providerId]=n)}return e}getProviderBaseUrl(e){return this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let o of this.providerVariantKeyCandidates(e)){let n=this.keyPool.acquireKey(o);if(n)return{keyHandle:n,keyProviderId:o}}return null}resolveTechnicalVariant(e,o){let n=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(n.length===0)return;let i=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:ts(o,e.transport),capabilities:os(o),purpose:o,userPreference:{providerIds:n}});if(i)return{provider:i.provider,nativeModelId:i.nativeModelId}}providerVariantKeyCandidates(e){let o=[e],n=this.coreProviderRegistry.getProvider(e),i=n?.group??n?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===i&&o.push(s.id);return i!==e&&o.push(i),[...new Set(o)]}loadModelState(e){for(let o of e)typeof o.id!="string"||!o.id||typeof o.enabled=="boolean"&&this.modelEnabledOverrides.set(o.id,o.enabled)}exportModelState(){let e=new Map;for(let[o,n]of this.modelEnabledOverrides)e.set(o,n);for(let o of this.models.values())e.set(o.id,o.enabled);return[...e.entries()].map(([o,n])=>({id:o,enabled:n}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},$e=null;function xt(){return $e||($e=new _t,$e.load()),$e}function es(t){switch(t){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return t;default:return}}function ts(t,e){switch(t){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return es(e)}}function os(t){switch(t){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}function Ct(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function kt(t){let e=0;for(let o of t)e+=Ct(o);return e}var wt={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};function ns(t){if(!t)return 128e3;if(t in wt)return wt[t];let e=t.toLowerCase();for(let[o,n]of Object.entries(wt))if(e.startsWith(o.toLowerCase()))return n;return 128e3}var is=8e3;var ss=new ie(200);var rs=new se;function Do(){return rs}function as(){return ze(new ne(is),new X(20,Ct),new oe(Ct))}var ls=null;function No(t,e){let o=e?.budget??He({modelContextWindow:ns(e?.model)}),i=(e?.pipeline??as()).compress(t,o);if(i.droppedCount>0){let s=kt(t),l=kt(i.messages);ss.record({timestamp:Date.now(),strategy:i.strategy,tokensBefore:s,tokensAfter:l,droppedCount:i.droppedCount,latencyMs:i.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:i.metrics?.cacheInvalidated??!1,tier:Ke(s,o)})}return i.droppedCount>0&&ls?.(i.droppedCount,kt(i.messages)),i}function Fo(t,e,o){let n=o-e;return`[Budget] ${Math.round(t)}% used (${e.toLocaleString()} / ${o.toLocaleString()} tokens). ${n.toLocaleString()} tokens remaining. `+(t>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var hs=new Set(["write","edit","patch","apply_patch"]);function ys(t){let e=t.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function bs(t){let e=t.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}var Ts=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,_s=new Set(["search","grep","glob","find","list","read","exec"]);function xs(t){if(!_s.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&Ts.test(e)}function Go(t,e){for(let o=t.length-1;o>=0;o--){let n=t[o];if(!n||n.role!=="tool")continue;let i=typeof n.content=="string"?n.content:"";if(i.startsWith("Error: "))return i.slice(7).trim()}}function ks(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):Xt}function jo(t){let e=t.message.toLowerCase();return t.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function ws(t){return t==="length"||t==="max_tokens"}function zo(t){let e=t.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(t.status===413||e.includes("too large")||e.includes("size"))}function Cs(t){let e=t.headers;if(!e)return null;let o=e["retry-after"]??e["Retry-After"];if(!o)return null;let n=parseInt(o,10);return!isNaN(n)&&n>0?n*1e3:null}function vs(t){if(t.status!==400)return null;let e=t.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let o=parseInt(e[1],10),n=parseInt(e[3],10);if(isNaN(o)||isNaN(n))return null;let i=n-o-1e3;return i>=3e3?i:null}function Ss(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Ho(t,e,o,n){let{turnId:i,sessionId:s,messages:l,tools:r,model:d,apiKey:h,temperature:m=0,hooks:g,signal:M}=t,T={sessionId:s,turnId:i},v=t.maxTurns??0,x=t.querySource,{resolveToolEligibility:C}=await Promise.resolve().then(()=>(Wo(),Bo)),L=C(r,t.toolEligibilityContext),w=L.eligibleTools;for(let _ of L.blockedTools)yield{type:"tool_blocked",turnId:i,callId:"",name:_.toolName,reason:"blocked-by-policy"};if(!w.length){yield*Ms(i,d,l,h,m,M,e,n);return}let A=ks(t.maxRounds),$={contextWindowTokens:t.contextWindowTokens??Qt,responseBufferTokens:Zt,maxOutputTokens:t.maxOutputTokens??qt,abortSignal:M,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},R=new Set,I=0,de=w,pe,a={messages:[...l],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:ct($),reactiveCompactState:ft(),toolLoopState:Ce({maxRounds:A,replayMessages:[...l]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Xe(),currentModel:d,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Ro(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},vt=Math.max(v*5,200),St=0;for(;;){if(St++,St>vt){n.info(`hard iteration cap reached (${vt}), forcing completion`);let c=a.finalText||ue(a.messages,n);yield{type:"end",turnId:i,content:c,usage:a.totalUsage,model:a.currentModel};return}let{messages:_,maxOutputTokensRecoveryCount:Q,hasAttemptedReactiveCompact:Is,maxOutputTokensOverride:Mt,turnCount:Z,guardState:O,reactiveCompactState:W,collapseStore:De}=a,{toolLoopState:N}=a;if(pe){try{let c=await pe;c&&(yield{type:"tool_use_summary",turnId:i,summary:c})}catch{}pe=void 0}if(t.refreshTools&&Z>1){let c=t.refreshTools();c!==de&&(de=c,n.debug(`tools refreshed: ${c.length} tools`))}if(mt(O,$)){n.info(`turn aborted by guard at turn ${Z}`),yield{type:"error",turnId:i,error:"Turn aborted",code:"ABORTED",usage:a.totalUsage};return}let z=ut(O,$);if(z.level==="blocking"){z.reason==="prompt_too_long"&&J(W)&&(W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,n.info(`token budget blocking (${z.reason}), reactive compact needed`),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"token budget pre-check"}),n.info(`token budget blocking (${z.reason}), ending tool loop`);break}z.level==="warning"&&n.info(`token budget warning: ${z.usagePercent}% used, ${z.remainingTokens} remaining`);let U;{let c=await Po(_,a.contentReplacementState,s);U=c.messages,c.newlyReplacedCount>0&&(n.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:i,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Ve(U,a.snipRemovedIds);U=c.messages,c.removedCount>0&&(n.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:i,action:"snip",detail:`${c.removedCount} messages`})}{let u=new X().compress(U,0);u.droppedCount>0&&(U=u.messages,n.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(U=Ye(U,De).messages,O.promptTokens>0){let c=$.contextWindowTokens*.75,u=Do().getActive(),p;u?p=await u.compressAsync(U,c,{model:a.currentModel,sessionId:s}):p=No(U,{budget:c,model:a.currentModel}),p.droppedCount>0&&(U=p.messages,n.info(`autocompact: ${p.strategy}, dropped ${p.droppedCount}`),yield{type:"recovery",turnId:i,action:"autocompact",detail:`${p.strategy}: ${p.droppedCount} dropped`},a.hasAttemptedReactiveCompact=!1,g?.invoke("context.after_compact",{...T,removedCount:p.droppedCount}).catch(()=>{}))}U=Ss(U);let me=tt({tools:de,toolChoice:t.toolChoice??"auto"}),q=Ce({maxRounds:A,replayMessages:U,lastStopReason:N.lastStopReason,options:{stopReason:N.lastStopReason}}),Rt=me.extraSystemPrompt?[{role:"system",content:me.extraSystemPrompt},...q.state.replayMessages]:q.state.replayMessages;N=q.state,q.recoveryActions.length>0&&n.debug(`tool loop recovery: ${q.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),n.debug(`turn ${Z}, messages: ${Rt.length}`),g?.invoke("turn.before_inference",{...T,model:a.currentModel}).catch(()=>{});let fe=!1,Et=[],At=new Map,It="stop",F,k=null,ge=!1,ee=[],P=[];try{for await(let c of e.stream({model:a.currentModel,messages:Rt,tools:me.tools,toolChoice:me.normalizedToolChoice??"auto",temperature:m,maxTokens:(Mt??O.currentMaxOutputTokens)||void 0,streamRequired:t.streamRequired,previousResponseId:a.lastResponseId,reasoning:t.reasoning,promptCacheKey:t.promptCacheKey,promptCacheRetention:t.promptCacheRetention,serviceTier:t.serviceTier,openaiBuiltinTools:t.openaiBuiltinTools,maxToolCalls:t.maxToolCalls,parallelToolCalls:t.parallelToolCalls,textVerbosity:t.textVerbosity},h,M))switch(c.type){case"delta":Et.push(c.text),fe||(yield{type:"delta",turnId:i,text:c.text});break;case"tool_call_delta":fe=!0,gt(At,c);break;case"reasoning_delta":ee.push(c.text);break;case"reasoning_block_complete":c.signature&&P.push({thinking:ee.join(""),signature:c.signature}),ee.length=0;break;case"usage":F={inputTokens:c.promptTokens,outputTokens:c.completionTokens,reasoningTokens:c.reasoningTokens,cacheRead:c.cacheReadTokens,cacheWrite:c.cacheCreationTokens};break;case"response_id":a.lastResponseId=c.id;break;case"annotations":yield{type:"annotations",turnId:i,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:i,message:`${c.toolType}: ${c.event}`};break;case"done":It=c.finishReason;break}if(fe||g?.invoke("turn.after_inference",{...T,model:a.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=a.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...U],model:c,sessionId:s})}catch{}}}catch(c){if(c instanceof ae&&t.fallbackModel){n.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:i,action:"model_fallback",detail:`${c.originalModel} \u2192 ${c.fallbackModel}`},a={...a,currentModel:c.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=c instanceof Error?c.message:String(c),p=typeof c?.status=="number"?c.status:void 0;if(!p&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let b=(a.consecutiveApiRetries??0)+1;if(b>re){n.info(`stale connection retry limit reached (${re}), aborting`),yield{type:"error",turnId:i,error:u,code:"RETRIES_EXHAUSTED",usage:a.totalUsage};return}n.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:i,action:"stale_connection_retry",detail:u.slice(0,80)},a={...a,consecutiveApiRetries:b,transition:void 0};continue}let f=vs({status:p,message:u});if(f!==null){n.info(`max_tokens overflow: adjusting to ${f}`),O.currentMaxOutputTokens=f,a={...a,maxOutputTokensOverride:f,transition:void 0};continue}if(lt(p)){a.consecutive529Errors++;let b=2,E=t.fallbackModel&&a.currentModel!==t.fallbackModel;if(a.consecutive529Errors>b&&!E&&!Se()){n.info(`transient ${p} \xD7 ${a.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:i,error:`API unavailable after ${a.consecutive529Errors} consecutive ${p} errors`,code:"API_ERROR",usage:a.totalUsage};return}if(a.consecutive529Errors>=ao&&t.fallbackModel&&a.currentModel!==t.fallbackModel){n.info(`529 \xD7 ${a.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:i,action:"model_fallback",detail:`529 \xD7 ${a.consecutive529Errors}`},a={...a,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Se()){let y=ve(a.consecutive529Errors);n.info(`persistent retry: waiting ${y}ms (attempt ${a.consecutive529Errors})`);let S=y;for(;S>0;){if(M?.aborted){yield{type:"error",turnId:i,error:"Aborted during retry wait",code:"ABORTED",usage:a.totalUsage};return}yield{type:"heartbeat",turnId:i,message:`Retrying in ${Math.ceil(S/1e3)}s (${p})`};let B=Math.min(S,ro);await new Promise(Be=>setTimeout(Be,B)),S-=B}a={...a,transition:void 0};continue}if(at(x)){let S=Cs({status:p,message:u})??ve(a.consecutive529Errors);n.info(`transient ${p}: retry in ${S}ms`),yield{type:"recovery",turnId:i,action:"retry",detail:`${p} retry in ${S}ms`},await new Promise(B=>setTimeout(B,S)),a={...a,transition:void 0};continue}n.info(`background source ${x}: not retrying ${p}`)}k={status:p,message:u}}if(k&&g?.invoke("turn.after_inference",{...T,model:a.currentModel,response:{error:k.message}}).catch(()=>{}),k)if(jo(k))ge=!0,n.info(`withheld prompt_too_long error (status=${k.status})`);else if(zo(k))ge=!0,n.info(`withheld media_size error (status=${k.status})`);else{let c=dt({status:k.status??500,message:k.message},O,$);if(c.action==="reactive_compact"&&J(W)&&(W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:i,action:"reactive_compact",detail:`API ${k.status??500}: ${k.message}`}),c.action==="retry"){let p=(a.consecutiveApiRetries??0)+1;if(p>re){n.info(`API retry limit reached (${re}), aborting`);let f=Y(k.status,k.message);yield{type:"error",turnId:i,error:k.message,code:f,usage:a.totalUsage};return}yield{type:"recovery",turnId:i,action:"retry",detail:c.reason},a={...a,consecutiveApiRetries:p,transition:void 0};continue}let u=Y(k.status,k.message);g?.invoke("stop.failure",{sessionId:s,reason:u,error:k.message}).catch(()=>{}),yield{type:"error",turnId:i,error:k.message,code:u,usage:a.totalUsage};return}F&&(a.totalUsage.inputTokens+=F.inputTokens,a.totalUsage.outputTokens+=F.outputTokens,F.reasoningTokens&&(a.totalUsage.reasoningTokens=(a.totalUsage.reasoningTokens??0)+F.reasoningTokens),F.cacheRead&&(a.totalUsage.cacheRead=(a.totalUsage.cacheRead??0)+F.cacheRead),F.cacheWrite&&(a.totalUsage.cacheWrite=(a.totalUsage.cacheWrite??0)+F.cacheWrite)),F?.inputTokens&&(O.promptTokens=F.inputTokens);let Ot=Et.join("");Ot&&(a.finalText=Ot);let G=[...At.values()].map(c=>({id:c.id||`tc_${i}_${Z}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(G.length===0&&!fe){if(ge&&k&&jo(k)){if(a.transition?.reason!=="collapse_drain_retry"){let p=Je(U,De);if(p.committed>0){n.info(`collapse drain: committed ${p.committed} stages`),yield{type:"recovery",turnId:i,action:"collapse_drain",detail:`${p.committed} stages committed`},a={...a,messages:p.messages,transition:{reason:"collapse_drain_retry",committed:p.committed}};continue}}if(J(W)){W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,n.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"withheld prompt_too_long"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld 413: recovery exhausted, surfacing error"),g?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:k.message}).catch(()=>{}),yield{type:"error",turnId:i,error:k.message,code:"PROMPT_TOO_LONG",usage:a.totalUsage};return}if(ge&&k&&zo(k)){if(J(W)){W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,n.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"media error strip-retry"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld media error: recovery exhausted"),g?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:k.message}).catch(()=>{}),yield{type:"error",turnId:i,error:k.message,code:"IMAGE_ERROR",usage:a.totalUsage};return}if(ws(It)){O.consecutiveTruncations+=1;let p=t.modelMaxOutputTokens??eo,f=pt(O,$,p);if(f.shouldEscalate&&Mt===void 0){O.currentMaxOutputTokens=f.newMax,n.info(`max_output_tokens escalate: ${f.newMax} tokens`),yield{type:"recovery",turnId:i,action:"output_escalation",detail:`${f.newMax} tokens`},a={...a,maxOutputTokensOverride:oo,transition:{reason:"max_output_tokens_escalate"}};continue}if(Q<to){let b={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};n.info(`max_output_tokens recovery #${Q+1}`),yield{type:"recovery",turnId:i,action:"max_output_tokens_recovery",detail:`attempt ${Q+1}`},a={...a,messages:[...U,b],maxOutputTokensRecoveryCount:Q+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:Q+1}};continue}n.info("max_output_tokens recovery exhausted, completing with partial content")}else O.consecutiveTruncations=0;if(N=we(N,{replayMessages:_,lastStopReason:"completed"}),g){let p=await g.invoke("stop",{sessionId:s,reason:"completed"});if(p.action==="prevent"){n.info(`stop hook prevented continuation: ${p.reason??"no reason"}`),yield{type:"end",turnId:i,content:a.finalText,usage:a.totalUsage,model:a.currentModel};return}if(p.action==="abort"){let f=p.reason??"Stop hook requested continuation";n.info(`stop hook blocking: ${f}`);let b={role:"user",content:f},E={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,E,b],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&a.budgetContinuationCount<5){let p=a.totalUsage.inputTokens+a.totalUsage.outputTokens+(a.totalUsage.reasoningTokens??0),f=p/t.tokenBudget*100,b=p-a.lastBudgetGlobalTokens,E=a.budgetContinuationCount>=no&&b<Qe&&a.lastBudgetDeltaTokens<Qe;if(E&&n.info(`token budget early stop: diminishing returns at ${Math.round(f)}% (delta=${b})`),!E&&f<90){let y=a.budgetContinuationCount+1,S={role:"user",content:Fo(f,p,t.tokenBudget)};n.info(`token budget continuation #${y}: ${Math.round(f)}% used`),yield{type:"recovery",turnId:i,action:"budget_continuation",detail:`${Math.round(f)}% used (#${y})`};let B={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,B,S],budgetContinuationCount:y,lastBudgetDeltaTokens:b,lastBudgetGlobalTokens:p,transition:{reason:"token_budget_continuation"}};continue}}if(!a.stopHookActive){let p=l.find(y=>y.role==="user"),f=typeof p?.content=="string"?p.content:"",b=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(f),E=R.has("write")||R.has("edit");if(b&&!E){if(n.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),I>0){let B=[..._].reverse().find(Be=>Be.role==="tool");B&&typeof B.content=="string"&&(B.content+=`
|
|
17
|
+
...[truncated ${t.length-n} chars]`}function zi(t){let e=[],o=[];for(let n of t)n.role==="tool"&&typeof n.content=="string"&&n.tool_call_id?Ao(n.content)||o.push({toolCallId:n.tool_call_id,content:n.content,size:n.content.length}):n.role==="assistant"&&o.length>0&&(e.push(o),o=[]);return o.length>0&&e.push(o),e}function Hi(t,e){let o=[],n=[],i=[];for(let s of t){let l=e.replacements.get(s.toolCallId);l!==void 0?o.push({...s,replacement:l}):e.seenIds.has(s.toolCallId)?n.push(s):i.push(s)}return{mustReapply:o,frozen:n,fresh:i}}function Ki(t,e,o){let n=[...t].sort((l,r)=>r.size-l.size),i=[],s=e+t.reduce((l,r)=>l+r.size,0);for(let l of n){if(s<=o)break;i.push(l),s-=l.size}return i}async function Po(t,e,o,n=so){let i=zi(t);if(i.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,l=[];for(let m of i){let{mustReapply:g,frozen:M,fresh:T}=Hi(m,e);for(let w of g)s.set(w.toolCallId,w.replacement);if(T.length===0){for(let w of m)e.seenIds.add(w.toolCallId);continue}let v=M.reduce((w,A)=>w+A.size,0),x=T.reduce((w,A)=>w+A.size,0),C=v+x>n?Ki(T,v,n):[],L=new Set(C.map(w=>w.toolCallId));for(let w of m)L.has(w.toolCallId)||e.seenIds.add(w.toolCallId);C.length>0&&l.push(...C)}if(s.size===0&&l.length===0)return{messages:t,newlyReplacedCount:0};let r=await Promise.all(l.map(async m=>{let g=await Io(m.content,m.toolCallId,o);return{candidate:m,result:g}})),d=0;for(let{candidate:m,result:g}of r){if(e.seenIds.add(m.toolCallId),!g)continue;let M=Oo(g);s.set(m.toolCallId,M),e.replacements.set(m.toolCallId,M),d++}return s.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(m=>{if(m.role!=="tool"||!m.tool_call_id)return m;let g=s.get(m.tool_call_id);return g===void 0?m:{...m,content:g}}),newlyReplacedCount:d}}var Vi=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),Xi=new Set(["bash","execute_command","Bash","shell"]),Pe=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??Vi,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let o=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:o,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let o=this.tools.filter(i=>i.status==="executing"),n=this.config.maxConcurrentTools;return n&&n>0&&o.length>=n?!1:o.length===0||e&&o.every(i=>i.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let o;try{o=JSON.parse(e.toolCall.function.arguments)}catch{}let n=o?.command??o?.file_path??o?.pattern??"";if(typeof n=="string"&&n.length>0){let i=n.length>40?n.slice(0,40)+"\u2026":n;return`${e.toolCall.function.name}(${i})`}return e.toolCall.function.name}createSyntheticError(e,o){let n=this.erroredToolDescription,i=o==="user_interrupted"?"User rejected tool use":o==="discarded"?"Streaming fallback - tool execution discarded":n?`Cancelled: parallel tool call ${n} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:i,message:j(e.id,{ok:!1,error:i})}}async executeTool(e){e.status="executing";let n=(async()=>{let i=this.getAbortReason();if(i){e.results.push(this.createSyntheticError(e,i)),e.status="completed";return}let{toolInvoker:s,hooks:l,sessionId:r,turnId:d,log:h}=this.config,m=e.toolCall.function.name,g=!1,M=e.toolCall.function.arguments;if(l)try{let w=await l.invoke("tool.before_invoke",{sessionId:r,turnId:d,callId:e.id,toolName:m,arguments:Yi(M)});if(w.action==="abort"){let A=w.reason??"blocked by policy";h.info(`tool ${m} blocked: ${A}`),e.results.push({callId:e.id,toolName:m,ok:!1,error:A,blocked:!0,blockReason:A,message:j(e.id,{ok:!1,error:A})}),e.status="completed";return}w.action==="continue"&&w.context?.arguments&&(M=JSON.stringify(w.context.arguments))}catch{}let T=await s.invoke(d,m,M,this.siblingAbortController.signal),v=this.getAbortReason();if(v&&!g){e.results.push(this.createSyntheticError(e,v)),e.status="completed";return}let x=!T.error,C=T.result;x&&C&&C.length>5e4&&(C=await Uo(C,e.id,r));let L=j(e.id,{ok:x,payload:C,error:T.error,toolReferences:T.toolReferences,imageUrls:T.imageUrls});x||(g=!0,Xi.has(m)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),l?.invoke(x?"tool.after_invoke":"tool.invoke_failed",{sessionId:r,turnId:d,callId:e.id,toolName:m,ok:x,...T.error?{error:T.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:m,ok:x,error:T.error,message:L}),e.status="completed"})();e.promise=n,n.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let o of e.results)yield o}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(n=>n.status==="executing"&&n.promise).map(n=>n.promise),o=new Promise(n=>{this.progressResolve=n});e.length>0&&await Promise.race([...e,o])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}};function Yi(t){try{return JSON.parse(t)}catch{return}}import{readFile as gu}from"node:fs/promises";import*as D from"node:fs";import{homedir as Ji}from"node:os";import{join as Lo}from"node:path";import{existsSync as ru}from"node:fs";var Qi=".qlogicagent";function Zi(){return process.env.QLOGICAGENT_HOME||Lo(Ji(),Qi)}function $o(){return Lo(Zi(),"settings.json")}var Le=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let o of e){this.pools.set(o.providerId,o);for(let n of o.keys)this.runtimeStates.set(n.id,this.createInitialState())}}acquireKey(e){let o=this.pools.get(e);if(!o||o.keys.length===0)return null;let n=Date.now(),i=this.getHealthyCandidates(o,n);if(i.length===0)return null;let s=this.selectByStrategy(i,o.strategy,n);if(!s)return null;let l=this.runtimeStates.get(s.id);return l.inFlight++,l.totalRequests++,l.lastUsedAt=n,l.requestTimestamps.push(n),{keyId:s.id,apiKey:s.key,providerId:e,release:r=>this.releaseKey(s.id,r)}}releaseKey(e,o){let n=this.runtimeStates.get(e);if(n)if(n.inFlight=Math.max(0,n.inFlight-1),o.success)n.consecutiveErrors=0,n.healthStatus="healthy",o.tokens&&(n.totalTokens+=o.tokens,n.tokenCounts.push(o.tokens));else if(n.consecutiveErrors++,n.lastErrorAt=Date.now(),o.errorCode===429){let i=o.retryAfter?o.retryAfter*1e3:3e4;n.cooldownUntil=Date.now()+i,n.healthStatus="cooldown"}else n.consecutiveErrors>=5?(n.cooldownUntil=Date.now()+6e4,n.healthStatus="cooldown"):n.consecutiveErrors>=3&&(n.healthStatus="degraded")}addProvider(e,o){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:o?.baseUrl,strategy:o?.strategy??"weighted-round-robin",keys:[],rateLimit:o?.rateLimit})}removeProvider(e){let o=this.pools.get(e);if(o){for(let n of o.keys)this.runtimeStates.delete(n.id);this.pools.delete(e)}}addKey(e,o,n){let i=this.pools.get(e);i||(i={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,i));let s=n?.id??crypto.randomUUID(),l={id:s,key:o,label:n?.label,weight:n?.weight??1,enabled:n?.enabled??!0};return i.keys.push(l),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let o of this.pools.values()){let n=o.keys.findIndex(i=>i.id===e);if(n!==-1){o.keys.splice(n,1),this.runtimeStates.delete(e);return}}}updateKey(e,o){for(let n of this.pools.values()){let i=n.keys.find(s=>s.id===e);if(i){if(o.label!==void 0&&(i.label=o.label),o.weight!==void 0&&(i.weight=o.weight),o.enabled!==void 0){i.enabled=o.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=o.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,o){let n=this.runtimeStates.get(e);n&&(n.healthStatus=o)}setStrategy(e,o){let n=this.pools.get(e);n&&(n.strategy=o)}setRateLimit(e,o){let n=this.pools.get(e);n&&(n.rateLimit=o)}getPoolStatus(e){let o=this.pools.get(e);return o?this.buildPoolStatus(o):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let o=this.pools.get(e);return o?this.getHealthyCandidates(o,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let o=new Set;for(let n of e){this.pools.set(n.providerId,n);for(let i of n.keys)o.add(i.id),this.runtimeStates.has(i.id)||this.runtimeStates.set(i.id,this.createInitialState())}for(let n of[...this.pools.keys()])e.some(i=>i.providerId===n)||this.pools.delete(n);for(let n of[...this.runtimeStates.keys()])o.has(n)||this.runtimeStates.delete(n)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,o){let n=[];for(let i of e.keys){if(!i.enabled)continue;let s=this.runtimeStates.get(i.id);if(s){if(s.healthStatus==="cooldown")if(o>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,o),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,o),s.tokenCounts.reduce((r,d)=>r+d,0)>=e.rateLimit.tpm*.9)||n.push(i))}}return n}selectByStrategy(e,o,n){if(e.length===0)return null;if(e.length===1)return e[0];switch(o){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let o=e.reduce((i,s)=>i+s.weight,0),n=Math.random()*o;for(let i of e)if(n-=i.weight,n<=0)return i;return e[e.length-1]}leastBusy(e){let o=1/0,n=e[0];for(let i of e){let l=this.runtimeStates.get(i.id)?.inFlight??0;(l<o||l===o&&i.weight>n.weight)&&(o=l,n=i)}return n}pruneWindow(e,o){let n=o-6e4;for(;e.length>0&&e[0]<n;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(o=>{let n=this.runtimeStates.get(o.id)??this.createInitialState();return{...o,inFlight:n.inFlight,totalRequests:n.totalRequests,totalTokens:n.totalTokens,lastUsedAt:n.lastUsedAt,lastErrorAt:n.lastErrorAt,consecutiveErrors:n.consecutiveErrors,cooldownUntil:n.cooldownUntil,healthStatus:o.enabled?n.healthStatus:"disabled"}})}}};var qi=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],_t=class{keyPool;coreProviderRegistry=new le;providerVariantResolver=new ce(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=$o(),this.keyPool=new Le(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let o=this.bindings[e];if(!o)return null;let n=this.models.get(o);if(!n||!n.enabled)return null;let i=this.resolveTechnicalVariant(n,e),s=i?.provider??n.provider,l=i?.nativeModelId??n.nativeModelId??n.model,r=this.acquireKeyForProviderVariant(s);if(!r)return null;let{keyHandle:d,keyProviderId:h}=r;return{provider:s,model:l,apiKey:d.apiKey,baseUrl:n.provider===s?n.baseUrl??this.getProviderBaseUrl(s)??this.getProviderBaseUrl(h):this.getProviderBaseUrl(s),keyHandle:d}}peekActiveModel(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}isAvailable(e){let o=this.peekActiveModel(e);return!!o?.enabled&&this.hasAvailableKeyForProviderVariant(o.provider)}resolveModelForPurpose(e){let o=this.peekActiveModel(e);return o?o.model:null}addProvider(e,o){this.keyPool.addProvider(e,o),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[o,n]of this.models)n.provider===e&&this.removeModel(o);this.emitChange()}addKey(e,o,n){let i=this.keyPool.addKey(e,o,n);return this.emitChange(),i}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,o){this.keyPool.updateKey(e,o),this.emitChange()}setKeyHealth(e,o){this.keyPool.setKeyHealth(e,o),this.emitChange()}setStrategy(e,o){this.keyPool.setStrategy(e,o),this.emitChange()}addModel(e){let o=e.id??`${e.provider}:${e.model}`;return this.models.set(o,{...e,id:o,enabled:this.modelEnabledOverrides.get(o)??e.enabled}),this.emitChange(),o}replaceCatalogModels(e){let o=new Map;for(let n of e)o.set(n.id,{...n,enabled:this.modelEnabledOverrides.get(n.id)??n.enabled});for(let n of this.modelEnabledOverrides.keys())o.has(n)||this.modelEnabledOverrides.delete(n);this.models=o;for(let[n,i]of Object.entries(this.bindings))i&&!this.models.has(i)&&delete this.bindings[n];this.emitChange()}migrateModelIds(e){for(let[o,n]of e){let i=this.modelEnabledOverrides.get(o);i!==void 0&&!this.modelEnabledOverrides.has(n)&&this.modelEnabledOverrides.set(n,i),this.modelEnabledOverrides.delete(o);for(let[s,l]of Object.entries(this.bindings))l===o&&(this.bindings[s]=n)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[o,n]of Object.entries(this.bindings))n===e&&delete this.bindings[o];this.emitChange()}enableModel(e){let o=this.models.get(e);o&&(o.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let o=this.models.get(e);o&&(o.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let o=[...this.models.values()];return e?.purpose&&(o=o.filter(n=>n.purposes.includes(e.purpose))),e?.provider&&(o=o.filter(n=>n.provider===e.provider)),e?.enabledOnly&&(o=o.filter(n=>n.enabled)),o}getModel(e){return this.models.get(e)??null}setBinding(e,o){let n=this.models.get(o);if(!n)throw new Error(`Model "${o}" not found in pool.`);if(!n.purposes.includes(e))throw new Error(`Model "${o}" does not support purpose "${e}".`);this.bindings[e]=o,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}getAllBindings(){let e={};for(let o of qi){let n=this.bindings[o];e[o]=n?this.models.get(n)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{D.existsSync(this.settingsPath)&&(e=JSON.parse(D.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let o={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},n=this.settingsPath.replace(/[/\\][^/\\]+$/,"");D.existsSync(n)||D.mkdirSync(n,{recursive:!0}),D.writeFileSync(this.settingsPath,JSON.stringify(o,null,2),"utf-8")}load(){try{if(!D.existsSync(this.settingsPath))return!1;let e=D.readFileSync(this.settingsPath,"utf-8"),o=JSON.parse(e);return o.providers&&this.keyPool.reloadConfig(o.providers),this.models.clear(),this.modelEnabledOverrides.clear(),o.models&&this.loadModelState(o.models),this.bindings=o.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!D.existsSync(this.settingsPath))return;let o=D.readFileSync(this.settingsPath,"utf-8");return JSON.parse(o).tunables?.[e]}catch{return}}getModelInfo(e,o){let n=this.listModels({provider:e}).find(i=>i.model===o);if(n)return{id:n.model,name:n.displayName,contextWindow:n.contextWindow,maxOutput:n.maxOutput,streamRequired:n.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>!!this.keyPool.getPoolStatus(o)?.keys.some(i=>i.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>this.keyPool.hasAvailableKey(o))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(o=>({id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let o=this.changeListeners.indexOf(e);o>=0&&this.changeListeners.splice(o,1)}}getKeyForProvider(e){let n=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!n)return null;let i=n.apiKey;return n.release({success:!0}),i}snapshotProviderKeys(){let e={};for(let o of this.keyPool.getAllStatus()){let n=this.getKeyForProvider(o.providerId);n&&(e[o.providerId]=n)}return e}getProviderBaseUrl(e){return this.coreProviderRegistry.getProvider(e)?.baseUrl??this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let o of this.providerVariantKeyCandidates(e)){let n=this.keyPool.acquireKey(o);if(n)return{keyHandle:n,keyProviderId:o}}return null}resolveTechnicalVariant(e,o){let n=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(n.length===0)return;let i=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:ts(o,e.transport),capabilities:os(o),purpose:o,userPreference:{providerIds:n}});if(i)return{provider:i.provider,nativeModelId:i.nativeModelId}}providerVariantKeyCandidates(e){let o=[e],n=this.coreProviderRegistry.getProvider(e),i=n?.group??n?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===i&&o.push(s.id);return i!==e&&o.push(i),[...new Set(o)]}loadModelState(e){for(let o of e)typeof o.id!="string"||!o.id||typeof o.enabled=="boolean"&&this.modelEnabledOverrides.set(o.id,o.enabled)}exportModelState(){let e=new Map;for(let[o,n]of this.modelEnabledOverrides)e.set(o,n);for(let o of this.models.values())e.set(o.id,o.enabled);return[...e.entries()].map(([o,n])=>({id:o,enabled:n}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},$e=null;function xt(){return $e||($e=new _t,$e.load()),$e}function es(t){switch(t){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return t;default:return}}function ts(t,e){switch(t){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return es(e)}}function os(t){switch(t){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}function Ct(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function kt(t){let e=0;for(let o of t)e+=Ct(o);return e}var wt={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};function ns(t){if(!t)return 128e3;if(t in wt)return wt[t];let e=t.toLowerCase();for(let[o,n]of Object.entries(wt))if(e.startsWith(o.toLowerCase()))return n;return 128e3}var is=8e3;var ss=new ie(200);var rs=new se;function Do(){return rs}function as(){return ze(new ne(is),new X(20,Ct),new oe(Ct))}var ls=null;function No(t,e){let o=e?.budget??He({modelContextWindow:ns(e?.model)}),i=(e?.pipeline??as()).compress(t,o);if(i.droppedCount>0){let s=kt(t),l=kt(i.messages);ss.record({timestamp:Date.now(),strategy:i.strategy,tokensBefore:s,tokensAfter:l,droppedCount:i.droppedCount,latencyMs:i.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:i.metrics?.cacheInvalidated??!1,tier:Ke(s,o)})}return i.droppedCount>0&&ls?.(i.droppedCount,kt(i.messages)),i}function Fo(t,e,o){let n=o-e;return`[Budget] ${Math.round(t)}% used (${e.toLocaleString()} / ${o.toLocaleString()} tokens). ${n.toLocaleString()} tokens remaining. `+(t>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var hs=new Set(["write","edit","patch","apply_patch"]);function ys(t){let e=t.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function bs(t){let e=t.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}var Ts=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,_s=new Set(["search","grep","glob","find","list","read","exec"]);function xs(t){if(!_s.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&Ts.test(e)}function Go(t,e){for(let o=t.length-1;o>=0;o--){let n=t[o];if(!n||n.role!=="tool")continue;let i=typeof n.content=="string"?n.content:"";if(i.startsWith("Error: "))return i.slice(7).trim()}}function ks(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):Xt}function jo(t){let e=t.message.toLowerCase();return t.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function ws(t){return t==="length"||t==="max_tokens"}function zo(t){let e=t.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(t.status===413||e.includes("too large")||e.includes("size"))}function Cs(t){let e=t.headers;if(!e)return null;let o=e["retry-after"]??e["Retry-After"];if(!o)return null;let n=parseInt(o,10);return!isNaN(n)&&n>0?n*1e3:null}function vs(t){if(t.status!==400)return null;let e=t.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let o=parseInt(e[1],10),n=parseInt(e[3],10);if(isNaN(o)||isNaN(n))return null;let i=n-o-1e3;return i>=3e3?i:null}function Ss(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Ho(t,e,o,n){let{turnId:i,sessionId:s,messages:l,tools:r,model:d,apiKey:h,temperature:m=0,hooks:g,signal:M}=t,T={sessionId:s,turnId:i},v=t.maxTurns??0,x=t.querySource,{resolveToolEligibility:C}=await Promise.resolve().then(()=>(Wo(),Bo)),L=C(r,t.toolEligibilityContext),w=L.eligibleTools;for(let _ of L.blockedTools)yield{type:"tool_blocked",turnId:i,callId:"",name:_.toolName,reason:"blocked-by-policy"};if(!w.length){yield*Ms(i,d,l,h,m,M,e,n);return}let A=ks(t.maxRounds),$={contextWindowTokens:t.contextWindowTokens??Qt,responseBufferTokens:Zt,maxOutputTokens:t.maxOutputTokens??qt,abortSignal:M,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},R=new Set,I=0,de=w,pe,a={messages:[...l],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:ct($),reactiveCompactState:ft(),toolLoopState:Ce({maxRounds:A,replayMessages:[...l]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Xe(),currentModel:d,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Ro(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},vt=Math.max(v*5,200),St=0;for(;;){if(St++,St>vt){n.info(`hard iteration cap reached (${vt}), forcing completion`);let c=a.finalText||ue(a.messages,n);yield{type:"end",turnId:i,content:c,usage:a.totalUsage,model:a.currentModel};return}let{messages:_,maxOutputTokensRecoveryCount:Q,hasAttemptedReactiveCompact:Is,maxOutputTokensOverride:Mt,turnCount:Z,guardState:O,reactiveCompactState:W,collapseStore:De}=a,{toolLoopState:N}=a;if(pe){try{let c=await pe;c&&(yield{type:"tool_use_summary",turnId:i,summary:c})}catch{}pe=void 0}if(t.refreshTools&&Z>1){let c=t.refreshTools();c!==de&&(de=c,n.debug(`tools refreshed: ${c.length} tools`))}if(mt(O,$)){n.info(`turn aborted by guard at turn ${Z}`),yield{type:"error",turnId:i,error:"Turn aborted",code:"ABORTED",usage:a.totalUsage};return}let z=ut(O,$);if(z.level==="blocking"){z.reason==="prompt_too_long"&&J(W)&&(W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,n.info(`token budget blocking (${z.reason}), reactive compact needed`),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"token budget pre-check"}),n.info(`token budget blocking (${z.reason}), ending tool loop`);break}z.level==="warning"&&n.info(`token budget warning: ${z.usagePercent}% used, ${z.remainingTokens} remaining`);let U;{let c=await Po(_,a.contentReplacementState,s);U=c.messages,c.newlyReplacedCount>0&&(n.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:i,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Ve(U,a.snipRemovedIds);U=c.messages,c.removedCount>0&&(n.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:i,action:"snip",detail:`${c.removedCount} messages`})}{let u=new X().compress(U,0);u.droppedCount>0&&(U=u.messages,n.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(U=Ye(U,De).messages,O.promptTokens>0){let c=$.contextWindowTokens*.75,u=Do().getActive(),p;u?p=await u.compressAsync(U,c,{model:a.currentModel,sessionId:s}):p=No(U,{budget:c,model:a.currentModel}),p.droppedCount>0&&(U=p.messages,n.info(`autocompact: ${p.strategy}, dropped ${p.droppedCount}`),yield{type:"recovery",turnId:i,action:"autocompact",detail:`${p.strategy}: ${p.droppedCount} dropped`},a.hasAttemptedReactiveCompact=!1,g?.invoke("context.after_compact",{...T,removedCount:p.droppedCount}).catch(()=>{}))}U=Ss(U);let me=tt({tools:de,toolChoice:t.toolChoice??"auto"}),q=Ce({maxRounds:A,replayMessages:U,lastStopReason:N.lastStopReason,options:{stopReason:N.lastStopReason}}),Rt=me.extraSystemPrompt?[{role:"system",content:me.extraSystemPrompt},...q.state.replayMessages]:q.state.replayMessages;N=q.state,q.recoveryActions.length>0&&n.debug(`tool loop recovery: ${q.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),n.debug(`turn ${Z}, messages: ${Rt.length}`),g?.invoke("turn.before_inference",{...T,model:a.currentModel}).catch(()=>{});let fe=!1,Et=[],At=new Map,It="stop",F,k=null,ge=!1,ee=[],P=[];try{for await(let c of e.stream({model:a.currentModel,messages:Rt,tools:me.tools,toolChoice:me.normalizedToolChoice??"auto",temperature:m,maxTokens:(Mt??O.currentMaxOutputTokens)||void 0,streamRequired:t.streamRequired,previousResponseId:a.lastResponseId,reasoning:t.reasoning,promptCacheKey:t.promptCacheKey,promptCacheRetention:t.promptCacheRetention,serviceTier:t.serviceTier,openaiBuiltinTools:t.openaiBuiltinTools,maxToolCalls:t.maxToolCalls,parallelToolCalls:t.parallelToolCalls,textVerbosity:t.textVerbosity},h,M))switch(c.type){case"delta":Et.push(c.text),fe||(yield{type:"delta",turnId:i,text:c.text});break;case"tool_call_delta":fe=!0,gt(At,c);break;case"reasoning_delta":ee.push(c.text);break;case"reasoning_block_complete":c.signature&&P.push({thinking:ee.join(""),signature:c.signature}),ee.length=0;break;case"usage":F={inputTokens:c.promptTokens,outputTokens:c.completionTokens,reasoningTokens:c.reasoningTokens,cacheRead:c.cacheReadTokens,cacheWrite:c.cacheCreationTokens};break;case"response_id":a.lastResponseId=c.id;break;case"annotations":yield{type:"annotations",turnId:i,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:i,message:`${c.toolType}: ${c.event}`};break;case"done":It=c.finishReason;break}if(fe||g?.invoke("turn.after_inference",{...T,model:a.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=a.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...U],model:c,sessionId:s})}catch{}}}catch(c){if(c instanceof ae&&t.fallbackModel){n.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:i,action:"model_fallback",detail:`${c.originalModel} \u2192 ${c.fallbackModel}`},a={...a,currentModel:c.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=c instanceof Error?c.message:String(c),p=typeof c?.status=="number"?c.status:void 0;if(!p&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let b=(a.consecutiveApiRetries??0)+1;if(b>re){n.info(`stale connection retry limit reached (${re}), aborting`),yield{type:"error",turnId:i,error:u,code:"RETRIES_EXHAUSTED",usage:a.totalUsage};return}n.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:i,action:"stale_connection_retry",detail:u.slice(0,80)},a={...a,consecutiveApiRetries:b,transition:void 0};continue}let f=vs({status:p,message:u});if(f!==null){n.info(`max_tokens overflow: adjusting to ${f}`),O.currentMaxOutputTokens=f,a={...a,maxOutputTokensOverride:f,transition:void 0};continue}if(lt(p)){a.consecutive529Errors++;let b=2,E=t.fallbackModel&&a.currentModel!==t.fallbackModel;if(a.consecutive529Errors>b&&!E&&!Se()){n.info(`transient ${p} \xD7 ${a.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:i,error:`API unavailable after ${a.consecutive529Errors} consecutive ${p} errors`,code:"API_ERROR",usage:a.totalUsage};return}if(a.consecutive529Errors>=ao&&t.fallbackModel&&a.currentModel!==t.fallbackModel){n.info(`529 \xD7 ${a.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:i,action:"model_fallback",detail:`529 \xD7 ${a.consecutive529Errors}`},a={...a,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Se()){let y=ve(a.consecutive529Errors);n.info(`persistent retry: waiting ${y}ms (attempt ${a.consecutive529Errors})`);let S=y;for(;S>0;){if(M?.aborted){yield{type:"error",turnId:i,error:"Aborted during retry wait",code:"ABORTED",usage:a.totalUsage};return}yield{type:"heartbeat",turnId:i,message:`Retrying in ${Math.ceil(S/1e3)}s (${p})`};let B=Math.min(S,ro);await new Promise(Be=>setTimeout(Be,B)),S-=B}a={...a,transition:void 0};continue}if(at(x)){let S=Cs({status:p,message:u})??ve(a.consecutive529Errors);n.info(`transient ${p}: retry in ${S}ms`),yield{type:"recovery",turnId:i,action:"retry",detail:`${p} retry in ${S}ms`},await new Promise(B=>setTimeout(B,S)),a={...a,transition:void 0};continue}n.info(`background source ${x}: not retrying ${p}`)}k={status:p,message:u}}if(k&&g?.invoke("turn.after_inference",{...T,model:a.currentModel,response:{error:k.message}}).catch(()=>{}),k)if(jo(k))ge=!0,n.info(`withheld prompt_too_long error (status=${k.status})`);else if(zo(k))ge=!0,n.info(`withheld media_size error (status=${k.status})`);else{let c=dt({status:k.status??500,message:k.message},O,$);if(c.action==="reactive_compact"&&J(W)&&(W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:i,action:"reactive_compact",detail:`API ${k.status??500}: ${k.message}`}),c.action==="retry"){let p=(a.consecutiveApiRetries??0)+1;if(p>re){n.info(`API retry limit reached (${re}), aborting`);let f=Y(k.status,k.message);yield{type:"error",turnId:i,error:k.message,code:f,usage:a.totalUsage};return}yield{type:"recovery",turnId:i,action:"retry",detail:c.reason},a={...a,consecutiveApiRetries:p,transition:void 0};continue}let u=Y(k.status,k.message);g?.invoke("stop.failure",{sessionId:s,reason:u,error:k.message}).catch(()=>{}),yield{type:"error",turnId:i,error:k.message,code:u,usage:a.totalUsage};return}F&&(a.totalUsage.inputTokens+=F.inputTokens,a.totalUsage.outputTokens+=F.outputTokens,F.reasoningTokens&&(a.totalUsage.reasoningTokens=(a.totalUsage.reasoningTokens??0)+F.reasoningTokens),F.cacheRead&&(a.totalUsage.cacheRead=(a.totalUsage.cacheRead??0)+F.cacheRead),F.cacheWrite&&(a.totalUsage.cacheWrite=(a.totalUsage.cacheWrite??0)+F.cacheWrite)),F?.inputTokens&&(O.promptTokens=F.inputTokens);let Ot=Et.join("");Ot&&(a.finalText=Ot);let G=[...At.values()].map(c=>({id:c.id||`tc_${i}_${Z}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(G.length===0&&!fe){if(ge&&k&&jo(k)){if(a.transition?.reason!=="collapse_drain_retry"){let p=Je(U,De);if(p.committed>0){n.info(`collapse drain: committed ${p.committed} stages`),yield{type:"recovery",turnId:i,action:"collapse_drain",detail:`${p.committed} stages committed`},a={...a,messages:p.messages,transition:{reason:"collapse_drain_retry",committed:p.committed}};continue}}if(J(W)){W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,n.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"withheld prompt_too_long"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld 413: recovery exhausted, surfacing error"),g?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:k.message}).catch(()=>{}),yield{type:"error",turnId:i,error:k.message,code:"PROMPT_TOO_LONG",usage:a.totalUsage};return}if(ge&&k&&zo(k)){if(J(W)){W.attemptedThisTurn=!0,O.hasAttemptedReactiveCompact=!0,n.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:i,action:"reactive_compact",detail:"media error strip-retry"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld media error: recovery exhausted"),g?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:k.message}).catch(()=>{}),yield{type:"error",turnId:i,error:k.message,code:"IMAGE_ERROR",usage:a.totalUsage};return}if(ws(It)){O.consecutiveTruncations+=1;let p=t.modelMaxOutputTokens??eo,f=pt(O,$,p);if(f.shouldEscalate&&Mt===void 0){O.currentMaxOutputTokens=f.newMax,n.info(`max_output_tokens escalate: ${f.newMax} tokens`),yield{type:"recovery",turnId:i,action:"output_escalation",detail:`${f.newMax} tokens`},a={...a,maxOutputTokensOverride:oo,transition:{reason:"max_output_tokens_escalate"}};continue}if(Q<to){let b={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};n.info(`max_output_tokens recovery #${Q+1}`),yield{type:"recovery",turnId:i,action:"max_output_tokens_recovery",detail:`attempt ${Q+1}`},a={...a,messages:[...U,b],maxOutputTokensRecoveryCount:Q+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:Q+1}};continue}n.info("max_output_tokens recovery exhausted, completing with partial content")}else O.consecutiveTruncations=0;if(N=we(N,{replayMessages:_,lastStopReason:"completed"}),g){let p=await g.invoke("stop",{sessionId:s,reason:"completed"});if(p.action==="prevent"){n.info(`stop hook prevented continuation: ${p.reason??"no reason"}`),yield{type:"end",turnId:i,content:a.finalText,usage:a.totalUsage,model:a.currentModel};return}if(p.action==="abort"){let f=p.reason??"Stop hook requested continuation";n.info(`stop hook blocking: ${f}`);let b={role:"user",content:f},E={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,E,b],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&a.budgetContinuationCount<5){let p=a.totalUsage.inputTokens+a.totalUsage.outputTokens+(a.totalUsage.reasoningTokens??0),f=p/t.tokenBudget*100,b=p-a.lastBudgetGlobalTokens,E=a.budgetContinuationCount>=no&&b<Qe&&a.lastBudgetDeltaTokens<Qe;if(E&&n.info(`token budget early stop: diminishing returns at ${Math.round(f)}% (delta=${b})`),!E&&f<90){let y=a.budgetContinuationCount+1,S={role:"user",content:Fo(f,p,t.tokenBudget)};n.info(`token budget continuation #${y}: ${Math.round(f)}% used`),yield{type:"recovery",turnId:i,action:"budget_continuation",detail:`${Math.round(f)}% used (#${y})`};let B={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,B,S],budgetContinuationCount:y,lastBudgetDeltaTokens:b,lastBudgetGlobalTokens:p,transition:{reason:"token_budget_continuation"}};continue}}if(!a.stopHookActive){let p=l.find(y=>y.role==="user"),f=typeof p?.content=="string"?p.content:"",b=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(f),E=R.has("write")||R.has("edit");if(b&&!E){if(n.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),I>0){let B=[..._].reverse().find(Be=>Be.role==="tool");B&&typeof B.content=="string"&&(B.content+=`
|
|
18
18
|
|
|
19
19
|
\u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let y={role:"user",content:I===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},S={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,S,y],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!a.stopHookActive&&I>=3&&R.has("write")){let p=0;for(let f of _){let b=f,E=b.is_error===!0||typeof b.content=="string"&&b.content.startsWith("Error:");b.role==="tool"&&typeof b.content=="string"&&!E&&p++}if(p>=3){n.info("AP3 verification nudge: 3+ files created, injecting completeness check");let f={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},b={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,b,f],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(I>0){let p={ok:!0,toolCallCount:I,distinctToolCount:R.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},f=ke(p,{tools:[...R],projectRoot:t.projectRoot});f&&(yield{type:"skill_instruction",turnId:i,instruction:f})}let u=a.finalText||ue(_,n);yield{type:"end",turnId:i,content:u,usage:a.totalUsage,model:a.currentModel};return}let Yo=P.length===0&&ee.length>0?ee.join(""):void 0;_.push(We(G,a.finalText||void 0,P.length>0?P:void 0,Yo)),N=rt(N,{replayMessages:_,pendingToolCallIds:G.map(c=>c.id),completedToolCallIds:N.completedToolCallIds,lastStopReason:"tool_calls"});let he=a.identicalCallCounts,Ut=[],ye=[],Pt=!1;for(let c of G){let u=`${c.function.name}::${c.function.arguments}`,p=he.get(u)??0;he.set(u,p+1),p+1>Jt?(ye.push(c),Pt||(Pt=!0,n.info(`AP4 blocked: ${c.function.name} repeated ${p+1}x`))):Ut.push(c)}let be=[];for(let c of ye){let u=he.get(`${c.function.name}::${c.function.arguments}`),p=Go(_,c.function.name),f=p?`This exact tool call has been attempted ${u} times. Last error: ${p}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${u} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,b=j(c.id,{ok:!1,error:f});_.push(b),be.push(c.id),R.add(c.function.name),I++,yield{type:"tool_result",turnId:i,callId:c.id,name:c.function.name,ok:!1,error:f}}if(ye.length>0){let c=Go(_,ye[0].function.name),u={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(c?`The error was: "${c}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};_.push(u)}let Te=[],Ne=[];for(let c of Ut)(a.toolFailureCounts.get(c.function.name)??0)>=_e?Ne.push(c):Te.push(c);if(Ne.length>0){for(let u of Ne){let p=a.toolFailureCounts.get(u.function.name),f=`Tool "${u.function.name}" has failed ${p} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,b=j(u.id,{ok:!1,error:f});_.push(b),be.push(u.id),R.add(u.function.name),I++,yield{type:"tool_result",turnId:i,callId:u.id,name:u.function.name,ok:!1,error:f},n.info(`AP4-variant blocked: ${u.function.name} failed ${p}x with different args`)}let c={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};_.push(c)}for(let c of Te){let u=c.function.arguments,p=de.find(f=>f.function.name===c.function.name);if(p?.backfillObservableInput)try{let f=JSON.parse(c.function.arguments),b={...f};p.backfillObservableInput(b),Object.keys(b).some(y=>!(y in f))&&(u=JSON.stringify(b))}catch{}yield{type:"tool_call",turnId:i,callId:c.id,name:c.function.name,arguments:u}}let Jo=new Map(a.toolFailureCounts);try{let c=new Pe({toolInvoker:o,hooks:g,sessionId:s,turnId:i,log:n,signal:M,maxConcurrentTools:t?.maxConcurrentTools});for(let u of Te)c.addTool(u);for await(let u of c.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:i,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),_.push(u.message),be.push(u.callId),R.add(u.toolName),I++;let p=u.ok&&xs(u);if(!u.ok||p){let y=(a.toolFailureCounts.get(u.toolName)??0)+1;a.toolFailureCounts.set(u.toolName,y)}if(u.ok&&u.toolName==="read"){let E=Te.find(y=>y.id===u.callId);if(E)try{let y=JSON.parse(E.function.arguments),S=y.file_path??y.path??y.filePath??"";if(S){let B=a.fileReadCounts.get(S)??0;a.fileReadCounts.set(S,B+1)}}catch{}}let f=typeof u.message?.content=="string"?u.message.content:"",b=u.ok&&f?f.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:i,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:b},u.ok){let E=G.find(y=>y.id===u.callId);if(E){if(u.toolName==="plan_mode")try{let y=JSON.parse(E.function.arguments);y.action==="exit"&&typeof y.plan=="string"&&y.plan.length>0&&(yield{type:"plan_update",turnId:i,slug:"approved-plan",content:y.plan})}catch{}if(hs.has(u.toolName))try{let y=JSON.parse(E.function.arguments),S=typeof y.file_path=="string"?y.file_path:typeof y.filePath=="string"?y.filePath:typeof y.path=="string"?y.path:void 0;S&&(yield{type:"artifact",turnId:i,artifactId:`artifact-${u.callId}`,artifactType:ys(S),title:S.split(/[\\/]/).pop()||S,filePath:S,language:bs(S)})}catch{}}}}}catch(c){let u=c instanceof Error?c.message:String(c);yield{type:"error",turnId:i,error:u,code:"TOOL_EXECUTION_ERROR",usage:a.totalUsage};return}for(let[c,u]of a.toolFailureCounts)u>=_e&&(Jo.get(c)??0)<_e&&_.push({role:"user",content:`Tool "${c}" has now failed/returned empty results ${u} times with different arguments. The target clearly does not exist. Do NOT call "${c}" again. Report the result to the user immediately.`});if(N=we(N,{replayMessages:_,completedToolCallIds:[...N.completedToolCallIds,...be],lastStopReason:"tool_calls"}),t.generateToolUseSummary&&G.length>0){let c=G.map(u=>({name:u.function.name,arguments:u.function.arguments}));pe=t.generateToolUseSummary(c).catch(()=>null)}let Qo=G.length>0&&G.every(c=>{let u=_.find(f=>f?.role==="tool"&&f?.tool_call_id===c.id);if(!u)return!0;let p=u.content;return typeof p=="string"&&p.startsWith("Error: ")}),te=a.consecutiveFailedRounds;if(Qo){if(te+=1,te>=Yt){let c=a.finalText||ue(_,n);n.info(`early exit: ${te} consecutive failed rounds, returning ${a.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:i,content:c,usage:a.totalUsage,model:a.currentModel};return}}else te=0;let Zo=3,Lt=[...a.fileReadCounts.entries()].filter(([,c])=>c>=Zo);if(Lt.length>0){let c=Lt.map(([p])=>p).join(", ");n.info(`AP5: file read cycle detected on ${c}, injecting nudge`);let u={role:"user",content:`You are reading the same files repeatedly (${c}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};_.push(u),a.fileReadCounts.clear()}let Fe=Z+1;if(v>0&&Fe>v){if(n.info(`max turns reached (${v}), completing`),g){let u=await g.invoke("stop",{sessionId:s,reason:"max_turns"});if(u.action==="abort"){let p=u.reason??"Stop hook requested continuation after max_turns",f={role:"assistant",content:a.finalText,...P.length>0&&{thinkingBlocks:[...P]}};a={...a,messages:[..._,f,{role:"user",content:p}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let c=a.finalText||ue(_,n);yield{type:"end",turnId:i,content:c,usage:a.totalUsage,model:a.currentModel};return}if(Fe>A){if(n.info(`tool loop budget exhausted (${A} rounds), returning`),I>0){let u={ok:!0,toolCallCount:I,distinctToolCount:R.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},p=ke(u,{tools:[...R],projectRoot:t.projectRoot});p&&(yield{type:"skill_instruction",turnId:i,instruction:p})}let c=a.finalText||ue(_,n);yield{type:"end",turnId:i,content:c,usage:a.totalUsage,model:a.currentModel};return}a={messages:_,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:Fe,transition:{reason:"next_turn"},guardState:O,reactiveCompactState:W,toolLoopState:N,consecutiveFailedRounds:te,finalText:a.finalText,totalUsage:a.totalUsage,collapseStore:De,currentModel:a.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:a.stopHookActive,lastResponseId:a.lastResponseId,snipRemovedIds:a.snipRemovedIds,contentReplacementState:a.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:he,toolFailureCounts:a.toolFailureCounts,fileReadCounts:a.fileReadCounts}}}function ue(t,e){let o=[];for(let n=t.length-1;n>=0;n--){let i=t[n];if(i.role==="tool"&&typeof i.content=="string")o.unshift(i.content.slice(0,500));else if(i.role==="assistant"){if(typeof i.content=="string"&&i.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),i.content;break}else break}return o.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${o.length} tool result(s)`),o.join(`
|
|
20
20
|
|
package/dist/cli.js
CHANGED
|
@@ -40,7 +40,7 @@ ${s.executableCode.code}
|
|
|
40
40
|
...
|
|
41
41
|
`:`
|
|
42
42
|
`,e+=iw,e}async function ep(n,e,t,o=Bi){if(n.length<=o||Ju(n))return n;let r=await Qu(n,e,t);return r?Zu(r):n.slice(0,o)+`
|
|
43
|
-
...[truncated ${n.length-o} chars]`}function dw(n){let e=[],t=[];for(let o of n)o.role==="tool"&&typeof o.content=="string"&&o.tool_call_id?Ju(o.content)||t.push({toolCallId:o.tool_call_id,content:o.content,size:o.content.length}):o.role==="assistant"&&t.length>0&&(e.push(t),t=[]);return t.length>0&&e.push(t),e}function uw(n,e){let t=[],o=[],r=[];for(let s of n){let i=e.replacements.get(s.toolCallId);i!==void 0?t.push({...s,replacement:i}):e.seenIds.has(s.toolCallId)?o.push(s):r.push(s)}return{mustReapply:t,frozen:o,fresh:r}}function pw(n,e,t){let o=[...n].sort((i,a)=>a.size-i.size),r=[],s=e+n.reduce((i,a)=>i+a.size,0);for(let i of o){if(s<=t)break;r.push(i),s-=i.size}return r}async function tp(n,e,t,o=Wi){let r=dw(n);if(r.length===0)return{messages:n,newlyReplacedCount:0};let s=new Map,i=[];for(let d of r){let{mustReapply:u,frozen:p,fresh:m}=uw(d,e);for(let k of u)s.set(k.toolCallId,k.replacement);if(m.length===0){for(let k of d)e.seenIds.add(k.toolCallId);continue}let h=p.reduce((k,x)=>k+x.size,0),f=m.reduce((k,x)=>k+x.size,0),y=h+f>o?pw(m,h,o):[],b=new Set(y.map(k=>k.toolCallId));for(let k of d)b.has(k.toolCallId)||e.seenIds.add(k.toolCallId);y.length>0&&i.push(...y)}if(s.size===0&&i.length===0)return{messages:n,newlyReplacedCount:0};let a=await Promise.all(i.map(async d=>{let u=await Qu(d.content,d.toolCallId,t);return{candidate:d,result:u}})),l=0;for(let{candidate:d,result:u}of a){if(e.seenIds.add(d.toolCallId),!u)continue;let p=Zu(u);s.set(d.toolCallId,p),e.replacements.set(d.toolCallId,p),l++}return s.size===0?{messages:n,newlyReplacedCount:0}:{messages:n.map(d=>{if(d.role!=="tool"||!d.tool_call_id)return d;let u=s.get(d.tool_call_id);return u===void 0?d:{...d,content:u}}),newlyReplacedCount:l}}var sw,qu,iw,ol=N(()=>{"use strict";je();sw="tool-results",qu="<persisted-output>",iw="</persisted-output>"});function gw(n){try{return JSON.parse(n)}catch{return}}var mw,fw,zr,np=N(()=>{"use strict";So();ol();mw=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),fw=new Set(["bash","execute_command","Bash","shell"]),zr=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??mw,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let t=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:t,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let t=this.tools.filter(r=>r.status==="executing"),o=this.config.maxConcurrentTools;return o&&o>0&&t.length>=o?!1:t.length===0||e&&t.every(r=>r.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let t;try{t=JSON.parse(e.toolCall.function.arguments)}catch{}let o=t?.command??t?.file_path??t?.pattern??"";if(typeof o=="string"&&o.length>0){let r=o.length>40?o.slice(0,40)+"\u2026":o;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,t){let o=this.erroredToolDescription,r=t==="user_interrupted"?"User rejected tool use":t==="discarded"?"Streaming fallback - tool execution discarded":o?`Cancelled: parallel tool call ${o} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:r,message:on(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let o=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:i,sessionId:a,turnId:l,log:c}=this.config,d=e.toolCall.function.name,u=!1,p=e.toolCall.function.arguments;if(i)try{let k=await i.invoke("tool.before_invoke",{sessionId:a,turnId:l,callId:e.id,toolName:d,arguments:gw(p)});if(k.action==="abort"){let x=k.reason??"blocked by policy";c.info(`tool ${d} blocked: ${x}`),e.results.push({callId:e.id,toolName:d,ok:!1,error:x,blocked:!0,blockReason:x,message:on(e.id,{ok:!1,error:x})}),e.status="completed";return}k.action==="continue"&&k.context?.arguments&&(p=JSON.stringify(k.context.arguments))}catch{}let m=await s.invoke(l,d,p,this.siblingAbortController.signal),h=this.getAbortReason();if(h&&!u){e.results.push(this.createSyntheticError(e,h)),e.status="completed";return}let f=!m.error,y=m.result;f&&y&&y.length>5e4&&(y=await ep(y,e.id,a));let b=on(e.id,{ok:f,payload:y,error:m.error,toolReferences:m.toolReferences,imageUrls:m.imageUrls});f||(u=!0,fw.has(d)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),i?.invoke(f?"tool.after_invoke":"tool.invoke_failed",{sessionId:a,turnId:l,callId:e.id,toolName:d,ok:f,...m.error?{error:m.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:d,ok:f,error:m.error,message:b}),e.status="completed"})();e.promise=o,o.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let t of e.results)yield t}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(o=>o.status==="executing"&&o.promise).map(o=>o.promise),t=new Promise(o=>{this.progressResolve=o});e.length>0&&await Promise.race([...e,t])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}}});import{homedir as hw}from"node:os";import{join as Ae}from"node:path";import{existsSync as yw}from"node:fs";function H(){return process.env.QLOGICAGENT_HOME||Ae(hw(),He)}function op(){return Ae(H(),"plugins")}function Vt(){return Ae(H(),"skills")}function mt(){return Ae(H(),"settings.json")}function rp(){return Ae(H(),"plugin-cache")}function sp(){return Ae(H(),"mcp.json")}function ip(){return Ae(H(),"marketplace.json")}function ap(){return Ae(H(),"workflows")}function lp(){return Ae(H(),"rules")}function Oe(n){if(!n)throw new Error("getProjectAgentDir: cwd is required (must not fall back to process.cwd())");return Ae(n,He)}function cp(n){return Ae(Oe(n),"workflows")}function Ct(n){return Ae(Oe(n),"skills")}function Mo(n){return Ae(Oe(n),"INSTRUCTIONS.md")}function Hn(n){return Ae(Oe(n),"rules")}function Kt(n){return Ae(Oe(n),"sessions")}function dp(n,e){let t=Ae(Oe(n),"checkpoints");return e?Ae(t,e):t}function up(n){return Ae(n,He,"hooks")}function pp(n,e){return n.filter(t=>t!==e&&yw(Ae(t,He,"skills")))}var He,le=N(()=>{"use strict";He=".qlogicagent"});var qr,mp=N(()=>{"use strict";qr=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let t of e){this.pools.set(t.providerId,t);for(let o of t.keys)this.runtimeStates.set(o.id,this.createInitialState())}}acquireKey(e){let t=this.pools.get(e);if(!t||t.keys.length===0)return null;let o=Date.now(),r=this.getHealthyCandidates(t,o);if(r.length===0)return null;let s=this.selectByStrategy(r,t.strategy,o);if(!s)return null;let i=this.runtimeStates.get(s.id);return i.inFlight++,i.totalRequests++,i.lastUsedAt=o,i.requestTimestamps.push(o),{keyId:s.id,apiKey:s.key,providerId:e,release:a=>this.releaseKey(s.id,a)}}releaseKey(e,t){let o=this.runtimeStates.get(e);if(o)if(o.inFlight=Math.max(0,o.inFlight-1),t.success)o.consecutiveErrors=0,o.healthStatus="healthy",t.tokens&&(o.totalTokens+=t.tokens,o.tokenCounts.push(t.tokens));else if(o.consecutiveErrors++,o.lastErrorAt=Date.now(),t.errorCode===429){let r=t.retryAfter?t.retryAfter*1e3:3e4;o.cooldownUntil=Date.now()+r,o.healthStatus="cooldown"}else o.consecutiveErrors>=5?(o.cooldownUntil=Date.now()+6e4,o.healthStatus="cooldown"):o.consecutiveErrors>=3&&(o.healthStatus="degraded")}addProvider(e,t){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:t?.baseUrl,strategy:t?.strategy??"weighted-round-robin",keys:[],rateLimit:t?.rateLimit})}removeProvider(e){let t=this.pools.get(e);if(t){for(let o of t.keys)this.runtimeStates.delete(o.id);this.pools.delete(e)}}addKey(e,t,o){let r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=o?.id??crypto.randomUUID(),i={id:s,key:t,label:o?.label,weight:o?.weight??1,enabled:o?.enabled??!0};return r.keys.push(i),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let t of this.pools.values()){let o=t.keys.findIndex(r=>r.id===e);if(o!==-1){t.keys.splice(o,1),this.runtimeStates.delete(e);return}}}updateKey(e,t){for(let o of this.pools.values()){let r=o.keys.find(s=>s.id===e);if(r){if(t.label!==void 0&&(r.label=t.label),t.weight!==void 0&&(r.weight=t.weight),t.enabled!==void 0){r.enabled=t.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=t.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,t){let o=this.runtimeStates.get(e);o&&(o.healthStatus=t)}setStrategy(e,t){let o=this.pools.get(e);o&&(o.strategy=t)}setRateLimit(e,t){let o=this.pools.get(e);o&&(o.rateLimit=t)}getPoolStatus(e){let t=this.pools.get(e);return t?this.buildPoolStatus(t):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let t=this.pools.get(e);return t?this.getHealthyCandidates(t,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let t=new Set;for(let o of e){this.pools.set(o.providerId,o);for(let r of o.keys)t.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let o of[...this.pools.keys()])e.some(r=>r.providerId===o)||this.pools.delete(o);for(let o of[...this.runtimeStates.keys()])t.has(o)||this.runtimeStates.delete(o)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,t){let o=[];for(let r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.id);if(s){if(s.healthStatus==="cooldown")if(t>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,t),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,t),s.tokenCounts.reduce((a,l)=>a+l,0)>=e.rateLimit.tpm*.9)||o.push(r))}}return o}selectByStrategy(e,t,o){if(e.length===0)return null;if(e.length===1)return e[0];switch(t){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let t=e.reduce((r,s)=>r+s.weight,0),o=Math.random()*t;for(let r of e)if(o-=r.weight,o<=0)return r;return e[e.length-1]}leastBusy(e){let t=1/0,o=e[0];for(let r of e){let i=this.runtimeStates.get(r.id)?.inFlight??0;(i<t||i===t&&r.weight>o.weight)&&(t=i,o=r)}return o}pruneWindow(e,t){let o=t-6e4;for(;e.length>0&&e[0]<o;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(t=>{let o=this.runtimeStates.get(t.id)??this.createInitialState();return{...t,inFlight:o.inFlight,totalRequests:o.totalRequests,totalTokens:o.totalTokens,lastUsedAt:o.lastUsedAt,lastErrorAt:o.lastErrorAt,consecutiveErrors:o.consecutiveErrors,cooldownUntil:o.cooldownUntil,healthStatus:t.enabled?o.healthStatus:"disabled"}})}}}});var fp={};mn(fp,{ALL_PURPOSES:()=>Do,ModelRegistry:()=>Yr,deriveModelPurposes:()=>kw,getModelRegistry:()=>X,resetModelRegistry:()=>bw});import*as tt from"node:fs";function X(){return Oo||(Oo=new Yr,Oo.load()),Oo}function bw(){Oo=null}function kw(n){let e=[];switch((!n.mediaType||n.mediaType==="image_understanding"||n.mediaType==="video_understanding")&&e.push("textGeneration"),(n.vision||n.mediaType==="image_understanding")&&e.push("imageUnderstanding"),n.mediaType==="video_understanding"&&e.push("videoUnderstanding"),n.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function vw(n){switch(n){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return n;default:return}}function Sw(n,e){switch(n){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return vw(e)}}function Tw(n){switch(n){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}var Do,Yr,Oo,ft=N(()=>{"use strict";Sn();le();mp();Do=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],Yr=class{keyPool;coreProviderRegistry=new kn;providerVariantResolver=new _o(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=mt(),this.keyPool=new qr(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let t=this.bindings[e];if(!t)return null;let o=this.models.get(t);if(!o||!o.enabled)return null;let r=this.resolveTechnicalVariant(o,e),s=r?.provider??o.provider,i=r?.nativeModelId??o.nativeModelId??o.model,a=this.acquireKeyForProviderVariant(s);if(!a)return null;let{keyHandle:l,keyProviderId:c}=a;return{provider:s,model:i,apiKey:l.apiKey,baseUrl:o.provider===s?o.baseUrl??this.getProviderBaseUrl(s)??this.getProviderBaseUrl(c):this.getProviderBaseUrl(s),keyHandle:l}}peekActiveModel(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}isAvailable(e){let t=this.peekActiveModel(e);return!!t?.enabled&&this.hasAvailableKeyForProviderVariant(t.provider)}resolveModelForPurpose(e){let t=this.peekActiveModel(e);return t?t.model:null}addProvider(e,t){this.keyPool.addProvider(e,t),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[t,o]of this.models)o.provider===e&&this.removeModel(t);this.emitChange()}addKey(e,t,o){let r=this.keyPool.addKey(e,t,o);return this.emitChange(),r}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,t){this.keyPool.updateKey(e,t),this.emitChange()}setKeyHealth(e,t){this.keyPool.setKeyHealth(e,t),this.emitChange()}setStrategy(e,t){this.keyPool.setStrategy(e,t),this.emitChange()}addModel(e){let t=e.id??`${e.provider}:${e.model}`;return this.models.set(t,{...e,id:t,enabled:this.modelEnabledOverrides.get(t)??e.enabled}),this.emitChange(),t}replaceCatalogModels(e){let t=new Map;for(let o of e)t.set(o.id,{...o,enabled:this.modelEnabledOverrides.get(o.id)??o.enabled});for(let o of this.modelEnabledOverrides.keys())t.has(o)||this.modelEnabledOverrides.delete(o);this.models=t;for(let[o,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[o];this.emitChange()}migrateModelIds(e){for(let[t,o]of e){let r=this.modelEnabledOverrides.get(t);r!==void 0&&!this.modelEnabledOverrides.has(o)&&this.modelEnabledOverrides.set(o,r),this.modelEnabledOverrides.delete(t);for(let[s,i]of Object.entries(this.bindings))i===t&&(this.bindings[s]=o)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[t,o]of Object.entries(this.bindings))o===e&&delete this.bindings[t];this.emitChange()}enableModel(e){let t=this.models.get(e);t&&(t.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let t=this.models.get(e);t&&(t.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let t=[...this.models.values()];return e?.purpose&&(t=t.filter(o=>o.purposes.includes(e.purpose))),e?.provider&&(t=t.filter(o=>o.provider===e.provider)),e?.enabledOnly&&(t=t.filter(o=>o.enabled)),t}getModel(e){return this.models.get(e)??null}setBinding(e,t){let o=this.models.get(t);if(!o)throw new Error(`Model "${t}" not found in pool.`);if(!o.purposes.includes(e))throw new Error(`Model "${t}" does not support purpose "${e}".`);this.bindings[e]=t,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}getAllBindings(){let e={};for(let t of Do){let o=this.bindings[t];e[t]=o?this.models.get(o)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{tt.existsSync(this.settingsPath)&&(e=JSON.parse(tt.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let t={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},o=this.settingsPath.replace(/[/\\][^/\\]+$/,"");tt.existsSync(o)||tt.mkdirSync(o,{recursive:!0}),tt.writeFileSync(this.settingsPath,JSON.stringify(t,null,2),"utf-8")}load(){try{if(!tt.existsSync(this.settingsPath))return!1;let e=tt.readFileSync(this.settingsPath,"utf-8"),t=JSON.parse(e);return t.providers&&this.keyPool.reloadConfig(t.providers),this.models.clear(),this.modelEnabledOverrides.clear(),t.models&&this.loadModelState(t.models),this.bindings=t.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!tt.existsSync(this.settingsPath))return;let t=tt.readFileSync(this.settingsPath,"utf-8");return JSON.parse(t).tunables?.[e]}catch{return}}getModelInfo(e,t){let o=this.listModels({provider:e}).find(r=>r.model===t);if(o)return{id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>!!this.keyPool.getPoolStatus(t)?.keys.some(r=>r.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>this.keyPool.hasAvailableKey(t))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(t=>({id:t.model,name:t.displayName,contextWindow:t.contextWindow,maxOutput:t.maxOutput,streamRequired:t.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let t=this.changeListeners.indexOf(e);t>=0&&this.changeListeners.splice(t,1)}}getKeyForProvider(e){let o=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!o)return null;let r=o.apiKey;return o.release({success:!0}),r}snapshotProviderKeys(){let e={};for(let t of this.keyPool.getAllStatus()){let o=this.getKeyForProvider(t.providerId);o&&(e[t.providerId]=o)}return e}getProviderBaseUrl(e){return this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let t of this.providerVariantKeyCandidates(e)){let o=this.keyPool.acquireKey(t);if(o)return{keyHandle:o,keyProviderId:t}}return null}resolveTechnicalVariant(e,t){let o=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(o.length===0)return;let r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:Sw(t,e.transport),capabilities:Tw(t),purpose:t,userPreference:{providerIds:o}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let t=[e],o=this.coreProviderRegistry.getProvider(e),r=o?.group??o?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&t.push(s.id);return r!==e&&t.push(r),[...new Set(t)]}loadModelState(e){for(let t of e)typeof t.id!="string"||!t.id||typeof t.enabled=="boolean"&&this.modelEnabledOverrides.set(t.id,t.enabled)}exportModelState(){let e=new Map;for(let[t,o]of this.modelEnabledOverrides)e.set(t,o);for(let t of this.models.values())e.set(t.id,t.enabled);return[...e.entries()].map(([t,o])=>({id:t,enabled:o}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},Oo=null});import{readFile as ww}from"node:fs/promises";function Tn(n){let e=typeof n.content=="string"?n.content:n.content!=null?JSON.stringify(n.content):"";return Math.ceil(e.length/4)}function wn(n){let e=0;for(let t of n)e+=Tn(t);return e}function hp(n){if(!n)return 128e3;if(n in rl)return rl[n];let e=n.toLowerCase();for(let[t,o]of Object.entries(rl))if(e.startsWith(t.toLowerCase()))return o;return 128e3}function Rw(){return X().resolveModelForPurpose("textGeneration")??xw}function bp(){return il}function _w(n,e){return async(t,o)=>{let r=e?.transport,s=e?.apiKey;if(!r||!s)return n.debug("[context-compression] no LLM transport for summarization \u2014 using sync fallback"),sl(t);try{let i="",a=e?.model??Rw();for await(let l of r.stream({model:a,messages:[{role:"system",content:"You are a precise conversation summarizer."},{role:"user",content:o}],maxTokens:2e3,temperature:.3},s,AbortSignal.timeout(3e4)))l.type==="delta"&&(i+=l.text);return i||(n.warn("[context-compression] empty summary response"),sl(t))}catch(i){return n.warn({err:i.message},"[context-compression] summarize call error \u2014 using fallback"),sl(t)}}}function sl(n){let e=[],t=n.filter(s=>s.role==="user"),o=t.slice(0,20).map(s=>{let i=typeof s.content=="string"?s.content:JSON.stringify(s.content??"");return`- [user]: ${i.slice(0,300)}${i.length>300?"...":""}`});e.push(`## User Requests (${t.length} messages)`),e.push(...o);let r=n.filter(s=>s.role==="assistant");if(r.length>0){let s=r.slice(0,10).map(i=>{let a=typeof i.content=="string"?i.content:JSON.stringify(i.content??"");return`- [assistant]: ${a.slice(0,150)}${a.length>150?"...":""}`});e.push("",`## Assistant Responses (${r.length} total)`),e.push(...s)}return e.join(`
|
|
43
|
+
...[truncated ${n.length-o} chars]`}function dw(n){let e=[],t=[];for(let o of n)o.role==="tool"&&typeof o.content=="string"&&o.tool_call_id?Ju(o.content)||t.push({toolCallId:o.tool_call_id,content:o.content,size:o.content.length}):o.role==="assistant"&&t.length>0&&(e.push(t),t=[]);return t.length>0&&e.push(t),e}function uw(n,e){let t=[],o=[],r=[];for(let s of n){let i=e.replacements.get(s.toolCallId);i!==void 0?t.push({...s,replacement:i}):e.seenIds.has(s.toolCallId)?o.push(s):r.push(s)}return{mustReapply:t,frozen:o,fresh:r}}function pw(n,e,t){let o=[...n].sort((i,a)=>a.size-i.size),r=[],s=e+n.reduce((i,a)=>i+a.size,0);for(let i of o){if(s<=t)break;r.push(i),s-=i.size}return r}async function tp(n,e,t,o=Wi){let r=dw(n);if(r.length===0)return{messages:n,newlyReplacedCount:0};let s=new Map,i=[];for(let d of r){let{mustReapply:u,frozen:p,fresh:m}=uw(d,e);for(let k of u)s.set(k.toolCallId,k.replacement);if(m.length===0){for(let k of d)e.seenIds.add(k.toolCallId);continue}let h=p.reduce((k,x)=>k+x.size,0),f=m.reduce((k,x)=>k+x.size,0),y=h+f>o?pw(m,h,o):[],b=new Set(y.map(k=>k.toolCallId));for(let k of d)b.has(k.toolCallId)||e.seenIds.add(k.toolCallId);y.length>0&&i.push(...y)}if(s.size===0&&i.length===0)return{messages:n,newlyReplacedCount:0};let a=await Promise.all(i.map(async d=>{let u=await Qu(d.content,d.toolCallId,t);return{candidate:d,result:u}})),l=0;for(let{candidate:d,result:u}of a){if(e.seenIds.add(d.toolCallId),!u)continue;let p=Zu(u);s.set(d.toolCallId,p),e.replacements.set(d.toolCallId,p),l++}return s.size===0?{messages:n,newlyReplacedCount:0}:{messages:n.map(d=>{if(d.role!=="tool"||!d.tool_call_id)return d;let u=s.get(d.tool_call_id);return u===void 0?d:{...d,content:u}}),newlyReplacedCount:l}}var sw,qu,iw,ol=N(()=>{"use strict";je();sw="tool-results",qu="<persisted-output>",iw="</persisted-output>"});function gw(n){try{return JSON.parse(n)}catch{return}}var mw,fw,zr,np=N(()=>{"use strict";So();ol();mw=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),fw=new Set(["bash","execute_command","Bash","shell"]),zr=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??mw,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let t=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:t,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let t=this.tools.filter(r=>r.status==="executing"),o=this.config.maxConcurrentTools;return o&&o>0&&t.length>=o?!1:t.length===0||e&&t.every(r=>r.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let t;try{t=JSON.parse(e.toolCall.function.arguments)}catch{}let o=t?.command??t?.file_path??t?.pattern??"";if(typeof o=="string"&&o.length>0){let r=o.length>40?o.slice(0,40)+"\u2026":o;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,t){let o=this.erroredToolDescription,r=t==="user_interrupted"?"User rejected tool use":t==="discarded"?"Streaming fallback - tool execution discarded":o?`Cancelled: parallel tool call ${o} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:r,message:on(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let o=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:i,sessionId:a,turnId:l,log:c}=this.config,d=e.toolCall.function.name,u=!1,p=e.toolCall.function.arguments;if(i)try{let k=await i.invoke("tool.before_invoke",{sessionId:a,turnId:l,callId:e.id,toolName:d,arguments:gw(p)});if(k.action==="abort"){let x=k.reason??"blocked by policy";c.info(`tool ${d} blocked: ${x}`),e.results.push({callId:e.id,toolName:d,ok:!1,error:x,blocked:!0,blockReason:x,message:on(e.id,{ok:!1,error:x})}),e.status="completed";return}k.action==="continue"&&k.context?.arguments&&(p=JSON.stringify(k.context.arguments))}catch{}let m=await s.invoke(l,d,p,this.siblingAbortController.signal),h=this.getAbortReason();if(h&&!u){e.results.push(this.createSyntheticError(e,h)),e.status="completed";return}let f=!m.error,y=m.result;f&&y&&y.length>5e4&&(y=await ep(y,e.id,a));let b=on(e.id,{ok:f,payload:y,error:m.error,toolReferences:m.toolReferences,imageUrls:m.imageUrls});f||(u=!0,fw.has(d)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),i?.invoke(f?"tool.after_invoke":"tool.invoke_failed",{sessionId:a,turnId:l,callId:e.id,toolName:d,ok:f,...m.error?{error:m.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:d,ok:f,error:m.error,message:b}),e.status="completed"})();e.promise=o,o.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let t of e.results)yield t}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(o=>o.status==="executing"&&o.promise).map(o=>o.promise),t=new Promise(o=>{this.progressResolve=o});e.length>0&&await Promise.race([...e,t])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}}});import{homedir as hw}from"node:os";import{join as Ae}from"node:path";import{existsSync as yw}from"node:fs";function H(){return process.env.QLOGICAGENT_HOME||Ae(hw(),He)}function op(){return Ae(H(),"plugins")}function Vt(){return Ae(H(),"skills")}function mt(){return Ae(H(),"settings.json")}function rp(){return Ae(H(),"plugin-cache")}function sp(){return Ae(H(),"mcp.json")}function ip(){return Ae(H(),"marketplace.json")}function ap(){return Ae(H(),"workflows")}function lp(){return Ae(H(),"rules")}function Oe(n){if(!n)throw new Error("getProjectAgentDir: cwd is required (must not fall back to process.cwd())");return Ae(n,He)}function cp(n){return Ae(Oe(n),"workflows")}function Ct(n){return Ae(Oe(n),"skills")}function Mo(n){return Ae(Oe(n),"INSTRUCTIONS.md")}function Hn(n){return Ae(Oe(n),"rules")}function Kt(n){return Ae(Oe(n),"sessions")}function dp(n,e){let t=Ae(Oe(n),"checkpoints");return e?Ae(t,e):t}function up(n){return Ae(n,He,"hooks")}function pp(n,e){return n.filter(t=>t!==e&&yw(Ae(t,He,"skills")))}var He,le=N(()=>{"use strict";He=".qlogicagent"});var qr,mp=N(()=>{"use strict";qr=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let t of e){this.pools.set(t.providerId,t);for(let o of t.keys)this.runtimeStates.set(o.id,this.createInitialState())}}acquireKey(e){let t=this.pools.get(e);if(!t||t.keys.length===0)return null;let o=Date.now(),r=this.getHealthyCandidates(t,o);if(r.length===0)return null;let s=this.selectByStrategy(r,t.strategy,o);if(!s)return null;let i=this.runtimeStates.get(s.id);return i.inFlight++,i.totalRequests++,i.lastUsedAt=o,i.requestTimestamps.push(o),{keyId:s.id,apiKey:s.key,providerId:e,release:a=>this.releaseKey(s.id,a)}}releaseKey(e,t){let o=this.runtimeStates.get(e);if(o)if(o.inFlight=Math.max(0,o.inFlight-1),t.success)o.consecutiveErrors=0,o.healthStatus="healthy",t.tokens&&(o.totalTokens+=t.tokens,o.tokenCounts.push(t.tokens));else if(o.consecutiveErrors++,o.lastErrorAt=Date.now(),t.errorCode===429){let r=t.retryAfter?t.retryAfter*1e3:3e4;o.cooldownUntil=Date.now()+r,o.healthStatus="cooldown"}else o.consecutiveErrors>=5?(o.cooldownUntil=Date.now()+6e4,o.healthStatus="cooldown"):o.consecutiveErrors>=3&&(o.healthStatus="degraded")}addProvider(e,t){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:t?.baseUrl,strategy:t?.strategy??"weighted-round-robin",keys:[],rateLimit:t?.rateLimit})}removeProvider(e){let t=this.pools.get(e);if(t){for(let o of t.keys)this.runtimeStates.delete(o.id);this.pools.delete(e)}}addKey(e,t,o){let r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=o?.id??crypto.randomUUID(),i={id:s,key:t,label:o?.label,weight:o?.weight??1,enabled:o?.enabled??!0};return r.keys.push(i),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let t of this.pools.values()){let o=t.keys.findIndex(r=>r.id===e);if(o!==-1){t.keys.splice(o,1),this.runtimeStates.delete(e);return}}}updateKey(e,t){for(let o of this.pools.values()){let r=o.keys.find(s=>s.id===e);if(r){if(t.label!==void 0&&(r.label=t.label),t.weight!==void 0&&(r.weight=t.weight),t.enabled!==void 0){r.enabled=t.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=t.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,t){let o=this.runtimeStates.get(e);o&&(o.healthStatus=t)}setStrategy(e,t){let o=this.pools.get(e);o&&(o.strategy=t)}setRateLimit(e,t){let o=this.pools.get(e);o&&(o.rateLimit=t)}getPoolStatus(e){let t=this.pools.get(e);return t?this.buildPoolStatus(t):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let t=this.pools.get(e);return t?this.getHealthyCandidates(t,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let t=new Set;for(let o of e){this.pools.set(o.providerId,o);for(let r of o.keys)t.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let o of[...this.pools.keys()])e.some(r=>r.providerId===o)||this.pools.delete(o);for(let o of[...this.runtimeStates.keys()])t.has(o)||this.runtimeStates.delete(o)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,t){let o=[];for(let r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.id);if(s){if(s.healthStatus==="cooldown")if(t>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,t),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,t),s.tokenCounts.reduce((a,l)=>a+l,0)>=e.rateLimit.tpm*.9)||o.push(r))}}return o}selectByStrategy(e,t,o){if(e.length===0)return null;if(e.length===1)return e[0];switch(t){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let t=e.reduce((r,s)=>r+s.weight,0),o=Math.random()*t;for(let r of e)if(o-=r.weight,o<=0)return r;return e[e.length-1]}leastBusy(e){let t=1/0,o=e[0];for(let r of e){let i=this.runtimeStates.get(r.id)?.inFlight??0;(i<t||i===t&&r.weight>o.weight)&&(t=i,o=r)}return o}pruneWindow(e,t){let o=t-6e4;for(;e.length>0&&e[0]<o;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(t=>{let o=this.runtimeStates.get(t.id)??this.createInitialState();return{...t,inFlight:o.inFlight,totalRequests:o.totalRequests,totalTokens:o.totalTokens,lastUsedAt:o.lastUsedAt,lastErrorAt:o.lastErrorAt,consecutiveErrors:o.consecutiveErrors,cooldownUntil:o.cooldownUntil,healthStatus:t.enabled?o.healthStatus:"disabled"}})}}}});var fp={};mn(fp,{ALL_PURPOSES:()=>Do,ModelRegistry:()=>Yr,deriveModelPurposes:()=>kw,getModelRegistry:()=>X,resetModelRegistry:()=>bw});import*as tt from"node:fs";function X(){return Oo||(Oo=new Yr,Oo.load()),Oo}function bw(){Oo=null}function kw(n){let e=[];switch((!n.mediaType||n.mediaType==="image_understanding"||n.mediaType==="video_understanding")&&e.push("textGeneration"),(n.vision||n.mediaType==="image_understanding")&&e.push("imageUnderstanding"),n.mediaType==="video_understanding"&&e.push("videoUnderstanding"),n.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function vw(n){switch(n){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return n;default:return}}function Sw(n,e){switch(n){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return vw(e)}}function Tw(n){switch(n){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}var Do,Yr,Oo,ft=N(()=>{"use strict";Sn();le();mp();Do=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],Yr=class{keyPool;coreProviderRegistry=new kn;providerVariantResolver=new _o(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=mt(),this.keyPool=new qr(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let t=this.bindings[e];if(!t)return null;let o=this.models.get(t);if(!o||!o.enabled)return null;let r=this.resolveTechnicalVariant(o,e),s=r?.provider??o.provider,i=r?.nativeModelId??o.nativeModelId??o.model,a=this.acquireKeyForProviderVariant(s);if(!a)return null;let{keyHandle:l,keyProviderId:c}=a;return{provider:s,model:i,apiKey:l.apiKey,baseUrl:o.provider===s?o.baseUrl??this.getProviderBaseUrl(s)??this.getProviderBaseUrl(c):this.getProviderBaseUrl(s),keyHandle:l}}peekActiveModel(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}isAvailable(e){let t=this.peekActiveModel(e);return!!t?.enabled&&this.hasAvailableKeyForProviderVariant(t.provider)}resolveModelForPurpose(e){let t=this.peekActiveModel(e);return t?t.model:null}addProvider(e,t){this.keyPool.addProvider(e,t),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[t,o]of this.models)o.provider===e&&this.removeModel(t);this.emitChange()}addKey(e,t,o){let r=this.keyPool.addKey(e,t,o);return this.emitChange(),r}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,t){this.keyPool.updateKey(e,t),this.emitChange()}setKeyHealth(e,t){this.keyPool.setKeyHealth(e,t),this.emitChange()}setStrategy(e,t){this.keyPool.setStrategy(e,t),this.emitChange()}addModel(e){let t=e.id??`${e.provider}:${e.model}`;return this.models.set(t,{...e,id:t,enabled:this.modelEnabledOverrides.get(t)??e.enabled}),this.emitChange(),t}replaceCatalogModels(e){let t=new Map;for(let o of e)t.set(o.id,{...o,enabled:this.modelEnabledOverrides.get(o.id)??o.enabled});for(let o of this.modelEnabledOverrides.keys())t.has(o)||this.modelEnabledOverrides.delete(o);this.models=t;for(let[o,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[o];this.emitChange()}migrateModelIds(e){for(let[t,o]of e){let r=this.modelEnabledOverrides.get(t);r!==void 0&&!this.modelEnabledOverrides.has(o)&&this.modelEnabledOverrides.set(o,r),this.modelEnabledOverrides.delete(t);for(let[s,i]of Object.entries(this.bindings))i===t&&(this.bindings[s]=o)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[t,o]of Object.entries(this.bindings))o===e&&delete this.bindings[t];this.emitChange()}enableModel(e){let t=this.models.get(e);t&&(t.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let t=this.models.get(e);t&&(t.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let t=[...this.models.values()];return e?.purpose&&(t=t.filter(o=>o.purposes.includes(e.purpose))),e?.provider&&(t=t.filter(o=>o.provider===e.provider)),e?.enabledOnly&&(t=t.filter(o=>o.enabled)),t}getModel(e){return this.models.get(e)??null}setBinding(e,t){let o=this.models.get(t);if(!o)throw new Error(`Model "${t}" not found in pool.`);if(!o.purposes.includes(e))throw new Error(`Model "${t}" does not support purpose "${e}".`);this.bindings[e]=t,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}getAllBindings(){let e={};for(let t of Do){let o=this.bindings[t];e[t]=o?this.models.get(o)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{tt.existsSync(this.settingsPath)&&(e=JSON.parse(tt.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let t={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},o=this.settingsPath.replace(/[/\\][^/\\]+$/,"");tt.existsSync(o)||tt.mkdirSync(o,{recursive:!0}),tt.writeFileSync(this.settingsPath,JSON.stringify(t,null,2),"utf-8")}load(){try{if(!tt.existsSync(this.settingsPath))return!1;let e=tt.readFileSync(this.settingsPath,"utf-8"),t=JSON.parse(e);return t.providers&&this.keyPool.reloadConfig(t.providers),this.models.clear(),this.modelEnabledOverrides.clear(),t.models&&this.loadModelState(t.models),this.bindings=t.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!tt.existsSync(this.settingsPath))return;let t=tt.readFileSync(this.settingsPath,"utf-8");return JSON.parse(t).tunables?.[e]}catch{return}}getModelInfo(e,t){let o=this.listModels({provider:e}).find(r=>r.model===t);if(o)return{id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>!!this.keyPool.getPoolStatus(t)?.keys.some(r=>r.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>this.keyPool.hasAvailableKey(t))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(t=>({id:t.model,name:t.displayName,contextWindow:t.contextWindow,maxOutput:t.maxOutput,streamRequired:t.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let t=this.changeListeners.indexOf(e);t>=0&&this.changeListeners.splice(t,1)}}getKeyForProvider(e){let o=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!o)return null;let r=o.apiKey;return o.release({success:!0}),r}snapshotProviderKeys(){let e={};for(let t of this.keyPool.getAllStatus()){let o=this.getKeyForProvider(t.providerId);o&&(e[t.providerId]=o)}return e}getProviderBaseUrl(e){return this.coreProviderRegistry.getProvider(e)?.baseUrl??this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let t of this.providerVariantKeyCandidates(e)){let o=this.keyPool.acquireKey(t);if(o)return{keyHandle:o,keyProviderId:t}}return null}resolveTechnicalVariant(e,t){let o=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(o.length===0)return;let r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:Sw(t,e.transport),capabilities:Tw(t),purpose:t,userPreference:{providerIds:o}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let t=[e],o=this.coreProviderRegistry.getProvider(e),r=o?.group??o?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&t.push(s.id);return r!==e&&t.push(r),[...new Set(t)]}loadModelState(e){for(let t of e)typeof t.id!="string"||!t.id||typeof t.enabled=="boolean"&&this.modelEnabledOverrides.set(t.id,t.enabled)}exportModelState(){let e=new Map;for(let[t,o]of this.modelEnabledOverrides)e.set(t,o);for(let t of this.models.values())e.set(t.id,t.enabled);return[...e.entries()].map(([t,o])=>({id:t,enabled:o}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},Oo=null});import{readFile as ww}from"node:fs/promises";function Tn(n){let e=typeof n.content=="string"?n.content:n.content!=null?JSON.stringify(n.content):"";return Math.ceil(e.length/4)}function wn(n){let e=0;for(let t of n)e+=Tn(t);return e}function hp(n){if(!n)return 128e3;if(n in rl)return rl[n];let e=n.toLowerCase();for(let[t,o]of Object.entries(rl))if(e.startsWith(t.toLowerCase()))return o;return 128e3}function Rw(){return X().resolveModelForPurpose("textGeneration")??xw}function bp(){return il}function _w(n,e){return async(t,o)=>{let r=e?.transport,s=e?.apiKey;if(!r||!s)return n.debug("[context-compression] no LLM transport for summarization \u2014 using sync fallback"),sl(t);try{let i="",a=e?.model??Rw();for await(let l of r.stream({model:a,messages:[{role:"system",content:"You are a precise conversation summarizer."},{role:"user",content:o}],maxTokens:2e3,temperature:.3},s,AbortSignal.timeout(3e4)))l.type==="delta"&&(i+=l.text);return i||(n.warn("[context-compression] empty summary response"),sl(t))}catch(i){return n.warn({err:i.message},"[context-compression] summarize call error \u2014 using fallback"),sl(t)}}}function sl(n){let e=[],t=n.filter(s=>s.role==="user"),o=t.slice(0,20).map(s=>{let i=typeof s.content=="string"?s.content:JSON.stringify(s.content??"");return`- [user]: ${i.slice(0,300)}${i.length>300?"...":""}`});e.push(`## User Requests (${t.length} messages)`),e.push(...o);let r=n.filter(s=>s.role==="assistant");if(r.length>0){let s=r.slice(0,10).map(i=>{let a=typeof i.content=="string"?i.content:JSON.stringify(i.content??"");return`- [assistant]: ${a.slice(0,150)}${a.length>150?"...":""}`});e.push("",`## Assistant Responses (${r.length} total)`),e.push(...s)}return e.join(`
|
|
44
44
|
`)}function Aw(){return Ti(new yn(al),new rn(20,Tn),new Nn(Tn))}function gp(n,e){let t=wi(new yn(al),new rn(20,Tn),new fo({protectedHeadExchanges:1,protectedTailMessages:8,summarize:n,estimateTokens:Tn}),new Nn(Tn));return new go({inner:t,estimateTokens:Tn,onCacheInvalidated:e?.onCacheInvalidated})}function kp(n,e){let t=e?.budget??vr({modelContextWindow:hp(e?.model)}),r=(e?.pipeline??Aw()).compress(n,t);if(r.droppedCount>0){let s=wn(n),i=wn(r.messages);yp.record({timestamp:Date.now(),strategy:r.strategy,tokensBefore:s,tokensAfter:i,droppedCount:r.droppedCount,latencyMs:r.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:r.metrics?.cacheInvalidated??!1,tier:ko(s,t)})}return r.droppedCount>0&&ll?.(r.droppedCount,wn(r.messages)),r}async function Pw(n,e,t){let o=t??vr({modelContextWindow:hp(e.model)}),r=wn(n),s=ko(r,o),i;switch(s){case"none":i={messages:n,droppedCount:0,strategy:"none"};break;case"trim-only":i=new yn(al).compress(n,o);break;case"sliding-window":{i=await gp(e.summarize).compressAsync(n,o);break}case"llm-summarize":{let a=e.pipeline??gp(e.summarize);i=bo(a)?await a.compressAsync(n,o):a.compress(n,o);break}}return i.droppedCount>0&&(i={...i,messages:await Ri(i.messages,n,{maxFiles:5,maxTokenBudget:5e4,readFile:async a=>{try{return await ww(a,"utf-8")}catch{return null}}})}),Iw(n,i,o),i}function Iw(n,e,t){if(e.droppedCount>0||e.metrics?.usedLlm){let o=e.metrics?.tokensBefore||wn(n),r=e.metrics?.tokensAfter||wn(e.messages);yp.record({timestamp:Date.now(),strategy:e.strategy,tokensBefore:o,tokensAfter:r,droppedCount:e.droppedCount,latencyMs:e.metrics?.latencyMs??0,usedLlm:e.metrics?.usedLlm??!1,cacheInvalidated:e.metrics?.cacheInvalidated??!1,tier:ko(o,t)})}if(e.droppedCount>0){let o=e.metrics?.tokensAfter||wn(e.messages);ll?.(e.droppedCount,o)}}function Cw(n,e){let t=_w(n,e),o={id:"builtin-compressor",label:"4-Layer Compression Funnel (built-in)",async compressAsync(r,s,i){return Pw(r,{budget:s,model:i?.model,sessionId:i?.sessionId,summarize:t},s)}};il.register(o),il.activate(o.id),n.info(`[context-compression] registered context engine: ${o.id}`)}function vp(n,e,t){Cw(e,t),n.register({point:"context.before_compact",priority:50,label:"context-compression-bridge",handler:(o,r)=>{let s=r.messageCount;return s&&s>0&&e.debug(`[context-compression] before_compact: ${s} messages entering compression`),{action:"continue"}}}),ll=(o,r)=>{e.debug(`[context-compression] after_compact: removed ${o}, ${r} tokens remaining`),n.invoke("context.after_compact",{sessionId:"",turnId:"",removedCount:o,tokenCount:r}).catch(()=>{})}}var rl,al,xw,yp,il,ll,cl=N(()=>{"use strict";So();ft();rl={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};al=8e3,xw="deepseek-v4-flash";yp=new ho(200),il=new yo;ll=null});function Sp(n,e,t){let o=t-e;return`[Budget] ${Math.round(n)}% used (${e.toLocaleString()} / ${t.toLocaleString()} tokens). ${o.toLocaleString()} tokens remaining. `+(n>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var Tp=N(()=>{"use strict"});var wp={};mn(wp,{resolveToolEligibility:()=>Lw});function Mw(n,e){if(Ew.some(t=>t.test(n)))return!0;if(e)for(let t of e)try{if(new RegExp(t,"i").test(n))return!0}catch{}return!1}function Ow(n,e){let t=n.function.name,o=n.meta,r=[];return e.blockedToolNames?.includes(t)?(r.push("policy_blocked"),{level:5,reasons:r}):o?.isReadOnly?(r.push("always_allowed"),{level:1,reasons:r}):o?.requiresApproval?(r.push("approval_required"),{level:4,reasons:r}):o?.isDangerous||Mw(t,e.dangerousPatterns)?(r.push("dangerous_tool"),{level:3,reasons:r}):{level:2,reasons:r}}function Dw(n){switch(n){case 1:return"eligible";case 2:return"eligible";case 3:return"dangerous-notify";case 4:return"approval-required";case 5:return"blocked-by-policy"}}function Lw(n,e={}){let t=new Map,o=[],r=[],s=[];for(let i of n){let a=i.function.name,{level:l,reasons:c}=Ow(i,e),d=Dw(l),u={toolName:a,status:d,permissionLevel:l,approvalRequired:l===4,reasonCodes:c};t.set(a,u),l===5?r.push(u):(o.push(i),l===4&&s.push(u))}return{eligibleTools:o,blockedTools:r,approvalRequiredTools:s,eligibilityByName:t}}var Ew,xp=N(()=>{"use strict";Ew=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});function jw(n){let e=n.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function Fw(n){let e=n.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}function Gw(n){if(!Ww.has(n.toolName))return!1;let e=typeof n.message?.content=="string"?n.message.content.trim():"";return e.length>0&&e.length<200&&Bw.test(e)}function Rp(n,e){for(let t=n.length-1;t>=0;t--){let o=n[t];if(!o||o.role!=="tool")continue;let r=typeof o.content=="string"?o.content:"";if(r.startsWith("Error: "))return r.slice(7).trim()}}function Hw(n){return typeof n=="number"&&Number.isFinite(n)&&n>=1?Math.min(Math.round(n),100):Ei}function _p(n){let e=n.message.toLowerCase();return n.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function Vw(n){return n==="length"||n==="max_tokens"}function Ap(n){let e=n.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(n.status===413||e.includes("too large")||e.includes("size"))}function Kw(n){let e=n.headers;if(!e)return null;let t=e["retry-after"]??e["Retry-After"];if(!t)return null;let o=parseInt(t,10);return!isNaN(o)&&o>0?o*1e3:null}function zw(n){if(n.status!==400)return null;let e=n.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let t=parseInt(e[1],10),o=parseInt(e[3],10);if(isNaN(t)||isNaN(o))return null;let r=o-t-1e3;return r>=3e3?r:null}function qw(n){return n.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Pp(n,e,t,o){let{turnId:r,sessionId:s,messages:i,tools:a,model:l,apiKey:c,temperature:d=0,hooks:u,signal:p}=n,m={sessionId:s,turnId:r},h=n.maxTurns??0,f=n.querySource,{resolveToolEligibility:y}=await Promise.resolve().then(()=>(xp(),wp)),b=y(a,n.toolEligibilityContext),k=b.eligibleTools;for(let j of b.blockedTools)yield{type:"tool_blocked",turnId:r,callId:"",name:j.toolName,reason:"blocked-by-policy"};if(!k.length){yield*Yw(r,l,i,c,d,p,e,o);return}let x=Hw(n.maxRounds),I={contextWindowTokens:n.contextWindowTokens??Di,responseBufferTokens:Li,maxOutputTokens:n.maxOutputTokens??Ni,abortSignal:p,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},P=new Set,O=0,$=k,W,S={messages:[...i],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:Ea(I),reactiveCompactState:Na(),toolLoopState:Ar({maxRounds:x,replayMessages:[...i]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Pi(),currentModel:l,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Yu(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},ce=Math.max(h*5,200),de=0;for(;;){if(de++,de>ce){o.info(`hard iteration cap reached (${ce}), forcing completion`);let A=S.finalText||Lo(S.messages,o);yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}let{messages:j,maxOutputTokensRecoveryCount:ve,hasAttemptedReactiveCompact:ie,maxOutputTokensOverride:Ue,turnCount:ne,guardState:Q,reactiveCompactState:T,collapseStore:F}=S,{toolLoopState:B}=S;if(W){try{let A=await W;A&&(yield{type:"tool_use_summary",turnId:r,summary:A})}catch{}W=void 0}if(n.refreshTools&&ne>1){let A=n.refreshTools();A!==$&&($=A,o.debug(`tools refreshed: ${A.length} tools`))}if(La(Q,I)){o.info(`turn aborted by guard at turn ${ne}`),yield{type:"error",turnId:r,error:"Turn aborted",code:"ABORTED",usage:S.totalUsage};return}let Re=Ma(Q,I);if(Re.level==="blocking"){Re.reason==="prompt_too_long"&&Un(T)&&(T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,o.info(`token budget blocking (${Re.reason}), reactive compact needed`),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"token budget pre-check"}),o.info(`token budget blocking (${Re.reason}), ending tool loop`);break}Re.level==="warning"&&o.info(`token budget warning: ${Re.usagePercent}% used, ${Re.remainingTokens} remaining`);let he;{let A=await tp(j,S.contentReplacementState,s);he=A.messages,A.newlyReplacedCount>0&&(o.info(`tool-result-budget: persisted ${A.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:r,action:"tool_result_budget",detail:`${A.newlyReplacedCount} persisted`})}{let A=_i(he,S.snipRemovedIds);he=A.messages,A.removedCount>0&&(o.info(`snip: removed ${A.removedCount} messages, freed ~${A.tokensFreed} tokens`),yield{type:"recovery",turnId:r,action:"snip",detail:`${A.removedCount} messages`})}{let E=new rn().compress(he,0);E.droppedCount>0&&(he=E.messages,o.info(`microcompact: cleared ${E.droppedCount} old tool results`))}if(he=Ii(he,F).messages,Q.promptTokens>0){let A=I.contextWindowTokens*.75,E=bp().getActive(),L;E?L=await E.compressAsync(he,A,{model:S.currentModel,sessionId:s}):L=kp(he,{budget:A,model:S.currentModel}),L.droppedCount>0&&(he=L.messages,o.info(`autocompact: ${L.strategy}, dropped ${L.droppedCount}`),yield{type:"recovery",turnId:r,action:"autocompact",detail:`${L.strategy}: ${L.droppedCount} dropped`},S.hasAttemptedReactiveCompact=!1,u?.invoke("context.after_compact",{...m,removedCount:L.droppedCount}).catch(()=>{}))}he=qw(he);let jt=ba({tools:$,toolChoice:n.toolChoice??"auto"}),g=Ar({maxRounds:x,replayMessages:he,lastStopReason:B.lastStopReason,options:{stopReason:B.lastStopReason}}),v=jt.extraSystemPrompt?[{role:"system",content:jt.extraSystemPrompt},...g.state.replayMessages]:g.state.replayMessages;B=g.state,g.recoveryActions.length>0&&o.debug(`tool loop recovery: ${g.recoveryActions.map(A=>A.detail??A.kind).join("; ")}`),o.debug(`turn ${ne}, messages: ${v.length}`),u?.invoke("turn.before_inference",{...m,model:S.currentModel}).catch(()=>{});let _=!1,C=[],R=new Map,U="stop",D,M=null,V=!1,ae=[],ee=[];try{for await(let A of e.stream({model:S.currentModel,messages:v,tools:jt.tools,toolChoice:jt.normalizedToolChoice??"auto",temperature:d,maxTokens:(Ue??Q.currentMaxOutputTokens)||void 0,streamRequired:n.streamRequired,previousResponseId:S.lastResponseId,reasoning:n.reasoning,promptCacheKey:n.promptCacheKey,promptCacheRetention:n.promptCacheRetention,serviceTier:n.serviceTier,openaiBuiltinTools:n.openaiBuiltinTools,maxToolCalls:n.maxToolCalls,parallelToolCalls:n.parallelToolCalls,textVerbosity:n.textVerbosity},c,p))switch(A.type){case"delta":C.push(A.text),_||(yield{type:"delta",turnId:r,text:A.text});break;case"tool_call_delta":_=!0,$a(R,A);break;case"reasoning_delta":ae.push(A.text);break;case"reasoning_block_complete":A.signature&&ee.push({thinking:ae.join(""),signature:A.signature}),ae.length=0;break;case"usage":D={inputTokens:A.promptTokens,outputTokens:A.completionTokens,reasoningTokens:A.reasoningTokens,cacheRead:A.cacheReadTokens,cacheWrite:A.cacheCreationTokens};break;case"response_id":S.lastResponseId=A.id;break;case"annotations":yield{type:"annotations",turnId:r,annotations:A.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:r,message:`${A.toolType}: ${A.event}`};break;case"done":U=A.finishReason;break}if(_||u?.invoke("turn.after_inference",{...m,model:S.currentModel}).catch(()=>{}),n.postSamplingHooks&&n.postSamplingHooks.length>0){let A=S.currentModel;for(let E of n.postSamplingHooks)try{E({messages:[...he],model:A,sessionId:s})}catch{}}}catch(A){if(A instanceof vo&&n.fallbackModel){o.info(`model fallback triggered: ${A.originalModel} \u2192 ${A.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`${A.originalModel} \u2192 ${A.fallbackModel}`},S={...S,currentModel:A.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let E=A instanceof Error?A.message:String(A),L=typeof A?.status=="number"?A.status:void 0;if(!L&&E&&(E.includes("ECONNRESET")||E.includes("EPIPE"))){let re=(S.consecutiveApiRetries??0)+1;if(re>$n){o.info(`stale connection retry limit reached (${$n}), aborting`),yield{type:"error",turnId:r,error:E,code:"RETRIES_EXHAUSTED",usage:S.totalUsage};return}o.info(`stale connection (${E.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:r,action:"stale_connection_retry",detail:E.slice(0,80)},S={...S,consecutiveApiRetries:re,transition:void 0};continue}let G=zw({status:L,message:E});if(G!==null){o.info(`max_tokens overflow: adjusting to ${G}`),Q.currentMaxOutputTokens=G,S={...S,maxOutputTokensOverride:G,transition:void 0};continue}if(_a(L)){S.consecutive529Errors++;let re=2,_e=n.fallbackModel&&S.currentModel!==n.fallbackModel;if(S.consecutive529Errors>re&&!_e&&!Ir()){o.info(`transient ${L} \xD7 ${S.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:r,error:`API unavailable after ${S.consecutive529Errors} consecutive ${L} errors`,code:"API_ERROR",usage:S.totalUsage};return}if(S.consecutive529Errors>=Hi&&n.fallbackModel&&S.currentModel!==n.fallbackModel){o.info(`529 \xD7 ${S.consecutive529Errors}: triggering fallback to ${n.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`529 \xD7 ${S.consecutive529Errors}`},S={...S,currentModel:n.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Ir()){let Z=Pr(S.consecutive529Errors);o.info(`persistent retry: waiting ${Z}ms (attempt ${S.consecutive529Errors})`);let ye=Z;for(;ye>0;){if(p?.aborted){yield{type:"error",turnId:r,error:"Aborted during retry wait",code:"ABORTED",usage:S.totalUsage};return}yield{type:"heartbeat",turnId:r,message:`Retrying in ${Math.ceil(ye/1e3)}s (${L})`};let at=Math.min(ye,Gi);await new Promise(hi=>setTimeout(hi,at)),ye-=at}S={...S,transition:void 0};continue}if(Ra(f)){let ye=Kw({status:L,message:E})??Pr(S.consecutive529Errors);o.info(`transient ${L}: retry in ${ye}ms`),yield{type:"recovery",turnId:r,action:"retry",detail:`${L} retry in ${ye}ms`},await new Promise(at=>setTimeout(at,ye)),S={...S,transition:void 0};continue}o.info(`background source ${f}: not retrying ${L}`)}M={status:L,message:E}}if(M&&u?.invoke("turn.after_inference",{...m,model:S.currentModel,response:{error:M.message}}).catch(()=>{}),M)if(_p(M))V=!0,o.info(`withheld prompt_too_long error (status=${M.status})`);else if(Ap(M))V=!0,o.info(`withheld media_size error (status=${M.status})`);else{let A=Oa({status:M.status??500,message:M.message},Q,I);if(A.action==="reactive_compact"&&Un(T)&&(T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:r,action:"reactive_compact",detail:`API ${M.status??500}: ${M.message}`}),A.action==="retry"){let L=(S.consecutiveApiRetries??0)+1;if(L>$n){o.info(`API retry limit reached (${$n}), aborting`);let G=Ln(M.status,M.message);yield{type:"error",turnId:r,error:M.message,code:G,usage:S.totalUsage};return}yield{type:"recovery",turnId:r,action:"retry",detail:A.reason},S={...S,consecutiveApiRetries:L,transition:void 0};continue}let E=Ln(M.status,M.message);u?.invoke("stop.failure",{sessionId:s,reason:E,error:M.message}).catch(()=>{}),yield{type:"error",turnId:r,error:M.message,code:E,usage:S.totalUsage};return}D&&(S.totalUsage.inputTokens+=D.inputTokens,S.totalUsage.outputTokens+=D.outputTokens,D.reasoningTokens&&(S.totalUsage.reasoningTokens=(S.totalUsage.reasoningTokens??0)+D.reasoningTokens),D.cacheRead&&(S.totalUsage.cacheRead=(S.totalUsage.cacheRead??0)+D.cacheRead),D.cacheWrite&&(S.totalUsage.cacheWrite=(S.totalUsage.cacheWrite??0)+D.cacheWrite)),D?.inputTokens&&(Q.promptTokens=D.inputTokens);let oe=C.join("");oe&&(S.finalText=oe);let me=[...R.values()].map(A=>({id:A.id||`tc_${r}_${ne}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:A.name,arguments:A.arguments}}));if(me.length===0&&!_){if(V&&M&&_p(M)){if(S.transition?.reason!=="collapse_drain_retry"){let L=Ci(he,F);if(L.committed>0){o.info(`collapse drain: committed ${L.committed} stages`),yield{type:"recovery",turnId:r,action:"collapse_drain",detail:`${L.committed} stages committed`},S={...S,messages:L.messages,transition:{reason:"collapse_drain_retry",committed:L.committed}};continue}}if(Un(T)){T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,o.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"withheld prompt_too_long"},S={...S,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld 413: recovery exhausted, surfacing error"),u?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:M.message}).catch(()=>{}),yield{type:"error",turnId:r,error:M.message,code:"PROMPT_TOO_LONG",usage:S.totalUsage};return}if(V&&M&&Ap(M)){if(Un(T)){T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,o.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"media error strip-retry"},S={...S,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld media error: recovery exhausted"),u?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:M.message}).catch(()=>{}),yield{type:"error",turnId:r,error:M.message,code:"IMAGE_ERROR",usage:S.totalUsage};return}if(Vw(U)){Q.consecutiveTruncations+=1;let L=n.modelMaxOutputTokens??$i,G=Da(Q,I,L);if(G.shouldEscalate&&Ue===void 0){Q.currentMaxOutputTokens=G.newMax,o.info(`max_output_tokens escalate: ${G.newMax} tokens`),yield{type:"recovery",turnId:r,action:"output_escalation",detail:`${G.newMax} tokens`},S={...S,maxOutputTokensOverride:ji,transition:{reason:"max_output_tokens_escalate"}};continue}if(ve<Ui){let re={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};o.info(`max_output_tokens recovery #${ve+1}`),yield{type:"recovery",turnId:r,action:"max_output_tokens_recovery",detail:`attempt ${ve+1}`},S={...S,messages:[...he,re],maxOutputTokensRecoveryCount:ve+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:ve+1}};continue}o.info("max_output_tokens recovery exhausted, completing with partial content")}else Q.consecutiveTruncations=0;if(B=_r(B,{replayMessages:j,lastStopReason:"completed"}),u){let L=await u.invoke("stop",{sessionId:s,reason:"completed"});if(L.action==="prevent"){o.info(`stop hook prevented continuation: ${L.reason??"no reason"}`),yield{type:"end",turnId:r,content:S.finalText,usage:S.totalUsage,model:S.currentModel};return}if(L.action==="abort"){let G=L.reason??"Stop hook requested continuation";o.info(`stop hook blocking: ${G}`);let re={role:"user",content:G},_e={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,_e,re],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(n.tokenBudget&&n.tokenBudget>0&&S.budgetContinuationCount<5){let L=S.totalUsage.inputTokens+S.totalUsage.outputTokens+(S.totalUsage.reasoningTokens??0),G=L/n.tokenBudget*100,re=L-S.lastBudgetGlobalTokens,_e=S.budgetContinuationCount>=Fi&&re<Tr&&S.lastBudgetDeltaTokens<Tr;if(_e&&o.info(`token budget early stop: diminishing returns at ${Math.round(G)}% (delta=${re})`),!_e&&G<90){let Z=S.budgetContinuationCount+1,ye={role:"user",content:Sp(G,L,n.tokenBudget)};o.info(`token budget continuation #${Z}: ${Math.round(G)}% used`),yield{type:"recovery",turnId:r,action:"budget_continuation",detail:`${Math.round(G)}% used (#${Z})`};let at={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,at,ye],budgetContinuationCount:Z,lastBudgetDeltaTokens:re,lastBudgetGlobalTokens:L,transition:{reason:"token_budget_continuation"}};continue}}if(!S.stopHookActive){let L=i.find(Z=>Z.role==="user"),G=typeof L?.content=="string"?L.content:"",re=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(G),_e=P.has("write")||P.has("edit");if(re&&!_e){if(o.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),O>0){let at=[...j].reverse().find(hi=>hi.role==="tool");at&&typeof at.content=="string"&&(at.content+=`
|
|
45
45
|
|
|
46
46
|
\u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let Z={role:"user",content:O===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},ye={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,ye,Z],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!S.stopHookActive&&O>=3&&P.has("write")){let L=0;for(let G of j){let re=G,_e=re.is_error===!0||typeof re.content=="string"&&re.content.startsWith("Error:");re.role==="tool"&&typeof re.content=="string"&&!_e&&L++}if(L>=3){o.info("AP3 verification nudge: 3+ files created, injecting completeness check");let G={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},re={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,re,G],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(O>0){let L={ok:!0,toolCallCount:O,distinctToolCount:P.size,multiStep:O>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},G=Rr(L,{tools:[...P],projectRoot:n.projectRoot});G&&(yield{type:"skill_instruction",turnId:r,instruction:G})}let E=S.finalText||Lo(j,o);yield{type:"end",turnId:r,content:E,usage:S.totalUsage,model:S.currentModel};return}let Ge=ee.length===0&&ae.length>0?ae.join(""):void 0;j.push(ki(me,S.finalText||void 0,ee.length>0?ee:void 0,Ge)),B=xa(B,{replayMessages:j,pendingToolCallIds:me.map(A=>A.id),completedToolCallIds:B.completedToolCallIds,lastStopReason:"tool_calls"});let Me=S.identicalCallCounts,nn=[],ge=[],Ft=!1;for(let A of me){let E=`${A.function.name}::${A.function.arguments}`,L=Me.get(E)??0;Me.set(E,L+1),L+1>Oi?(ge.push(A),Ft||(Ft=!0,o.info(`AP4 blocked: ${A.function.name} repeated ${L+1}x`))):nn.push(A)}let Rt=[];for(let A of ge){let E=Me.get(`${A.function.name}::${A.function.arguments}`),L=Rp(j,A.function.name),G=L?`This exact tool call has been attempted ${E} times. Last error: ${L}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${E} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,re=on(A.id,{ok:!1,error:G});j.push(re),Rt.push(A.id),P.add(A.function.name),O++,yield{type:"tool_result",turnId:r,callId:A.id,name:A.function.name,ok:!1,error:G}}if(ge.length>0){let A=Rp(j,ge[0].function.name),E={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(A?`The error was: "${A}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};j.push(E)}let Ke=[],fi=[];for(let A of nn)(S.toolFailureCounts.get(A.function.name)??0)>=Sr?fi.push(A):Ke.push(A);if(fi.length>0){for(let E of fi){let L=S.toolFailureCounts.get(E.function.name),G=`Tool "${E.function.name}" has failed ${L} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,re=on(E.id,{ok:!1,error:G});j.push(re),Rt.push(E.id),P.add(E.function.name),O++,yield{type:"tool_result",turnId:r,callId:E.id,name:E.function.name,ok:!1,error:G},o.info(`AP4-variant blocked: ${E.function.name} failed ${L}x with different args`)}let A={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};j.push(A)}for(let A of Ke){let E=A.function.arguments,L=$.find(G=>G.function.name===A.function.name);if(L?.backfillObservableInput)try{let G=JSON.parse(A.function.arguments),re={...G};L.backfillObservableInput(re),Object.keys(re).some(Z=>!(Z in G))&&(E=JSON.stringify(re))}catch{}yield{type:"tool_call",turnId:r,callId:A.id,name:A.function.name,arguments:E}}let Hk=new Map(S.toolFailureCounts);try{let A=new zr({toolInvoker:t,hooks:u,sessionId:s,turnId:r,log:o,signal:p,maxConcurrentTools:n?.maxConcurrentTools});for(let E of Ke)A.addTool(E);for await(let E of A.getRemainingResults()){E.blocked&&(yield{type:"tool_blocked",turnId:r,callId:E.callId,name:E.toolName,reason:E.blockReason??"blocked"}),j.push(E.message),Rt.push(E.callId),P.add(E.toolName),O++;let L=E.ok&&Gw(E);if(!E.ok||L){let Z=(S.toolFailureCounts.get(E.toolName)??0)+1;S.toolFailureCounts.set(E.toolName,Z)}if(E.ok&&E.toolName==="read"){let _e=Ke.find(Z=>Z.id===E.callId);if(_e)try{let Z=JSON.parse(_e.function.arguments),ye=Z.file_path??Z.path??Z.filePath??"";if(ye){let at=S.fileReadCounts.get(ye)??0;S.fileReadCounts.set(ye,at+1)}}catch{}}let G=typeof E.message?.content=="string"?E.message.content:"",re=E.ok&&G?G.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:r,callId:E.callId,name:E.toolName,ok:E.ok,error:E.error,outputPreview:re},E.ok){let _e=me.find(Z=>Z.id===E.callId);if(_e){if(E.toolName==="plan_mode")try{let Z=JSON.parse(_e.function.arguments);Z.action==="exit"&&typeof Z.plan=="string"&&Z.plan.length>0&&(yield{type:"plan_update",turnId:r,slug:"approved-plan",content:Z.plan})}catch{}if(Uw.has(E.toolName))try{let Z=JSON.parse(_e.function.arguments),ye=typeof Z.file_path=="string"?Z.file_path:typeof Z.filePath=="string"?Z.filePath:typeof Z.path=="string"?Z.path:void 0;ye&&(yield{type:"artifact",turnId:r,artifactId:`artifact-${E.callId}`,artifactType:jw(ye),title:ye.split(/[\\/]/).pop()||ye,filePath:ye,language:Fw(ye)})}catch{}}}}}catch(A){let E=A instanceof Error?A.message:String(A);yield{type:"error",turnId:r,error:E,code:"TOOL_EXECUTION_ERROR",usage:S.totalUsage};return}for(let[A,E]of S.toolFailureCounts)E>=Sr&&(Hk.get(A)??0)<Sr&&j.push({role:"user",content:`Tool "${A}" has now failed/returned empty results ${E} times with different arguments. The target clearly does not exist. Do NOT call "${A}" again. Report the result to the user immediately.`});if(B=_r(B,{replayMessages:j,completedToolCallIds:[...B.completedToolCallIds,...Rt],lastStopReason:"tool_calls"}),n.generateToolUseSummary&&me.length>0){let A=me.map(E=>({name:E.function.name,arguments:E.function.arguments}));W=n.generateToolUseSummary(A).catch(()=>null)}let Vk=me.length>0&&me.every(A=>{let E=j.find(G=>G?.role==="tool"&&G?.tool_call_id===A.id);if(!E)return!0;let L=E.content;return typeof L=="string"&&L.startsWith("Error: ")}),mo=S.consecutiveFailedRounds;if(Vk){if(mo+=1,mo>=Mi){let A=S.finalText||Lo(j,o);o.info(`early exit: ${mo} consecutive failed rounds, returning ${S.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}}else mo=0;let Kk=3,Ad=[...S.fileReadCounts.entries()].filter(([,A])=>A>=Kk);if(Ad.length>0){let A=Ad.map(([L])=>L).join(", ");o.info(`AP5: file read cycle detected on ${A}, injecting nudge`);let E={role:"user",content:`You are reading the same files repeatedly (${A}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};j.push(E),S.fileReadCounts.clear()}let gi=ne+1;if(h>0&&gi>h){if(o.info(`max turns reached (${h}), completing`),u){let E=await u.invoke("stop",{sessionId:s,reason:"max_turns"});if(E.action==="abort"){let L=E.reason??"Stop hook requested continuation after max_turns",G={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,G,{role:"user",content:L}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let A=S.finalText||Lo(j,o);yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}if(gi>x){if(o.info(`tool loop budget exhausted (${x} rounds), returning`),O>0){let E={ok:!0,toolCallCount:O,distinctToolCount:P.size,multiStep:O>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},L=Rr(E,{tools:[...P],projectRoot:n.projectRoot});L&&(yield{type:"skill_instruction",turnId:r,instruction:L})}let A=S.finalText||Lo(j,o);yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}S={messages:j,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:gi,transition:{reason:"next_turn"},guardState:Q,reactiveCompactState:T,toolLoopState:B,consecutiveFailedRounds:mo,finalText:S.finalText,totalUsage:S.totalUsage,collapseStore:F,currentModel:S.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:S.stopHookActive,lastResponseId:S.lastResponseId,snipRemovedIds:S.snipRemovedIds,contentReplacementState:S.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:Me,toolFailureCounts:S.toolFailureCounts,fileReadCounts:S.fileReadCounts}}}function Lo(n,e){let t=[];for(let o=n.length-1;o>=0;o--){let r=n[o];if(r.role==="tool"&&typeof r.content=="string")t.unshift(r.content.slice(0,500));else if(r.role==="assistant"){if(typeof r.content=="string"&&r.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),r.content;break}else break}return t.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${t.length} tool result(s)`),t.join(`
|
package/dist/index.js
CHANGED
|
@@ -39,7 +39,7 @@ ${s.executableCode.code}
|
|
|
39
39
|
...
|
|
40
40
|
`:`
|
|
41
41
|
`,e+=XT,e}async function Ju(n,e,t,o=ji){if(n.length<=o||qu(n))return n;let r=await Yu(n,e,t);return r?Xu(r):n.slice(0,o)+`
|
|
42
|
-
...[truncated ${n.length-o} chars]`}function ew(n){let e=[],t=[];for(let o of n)o.role==="tool"&&typeof o.content=="string"&&o.tool_call_id?qu(o.content)||t.push({toolCallId:o.tool_call_id,content:o.content,size:o.content.length}):o.role==="assistant"&&t.length>0&&(e.push(t),t=[]);return t.length>0&&e.push(t),e}function tw(n,e){let t=[],o=[],r=[];for(let s of n){let i=e.replacements.get(s.toolCallId);i!==void 0?t.push({...s,replacement:i}):e.seenIds.has(s.toolCallId)?o.push(s):r.push(s)}return{mustReapply:t,frozen:o,fresh:r}}function nw(n,e,t){let o=[...n].sort((i,a)=>a.size-i.size),r=[],s=e+n.reduce((i,a)=>i+a.size,0);for(let i of o){if(s<=t)break;r.push(i),s-=i.size}return r}async function Qu(n,e,t,o=Fi){let r=ew(n);if(r.length===0)return{messages:n,newlyReplacedCount:0};let s=new Map,i=[];for(let d of r){let{mustReapply:u,frozen:p,fresh:m}=tw(d,e);for(let k of u)s.set(k.toolCallId,k.replacement);if(m.length===0){for(let k of d)e.seenIds.add(k.toolCallId);continue}let h=p.reduce((k,x)=>k+x.size,0),f=m.reduce((k,x)=>k+x.size,0),y=h+f>o?nw(m,h,o):[],b=new Set(y.map(k=>k.toolCallId));for(let k of d)b.has(k.toolCallId)||e.seenIds.add(k.toolCallId);y.length>0&&i.push(...y)}if(s.size===0&&i.length===0)return{messages:n,newlyReplacedCount:0};let a=await Promise.all(i.map(async d=>{let u=await Yu(d.content,d.toolCallId,t);return{candidate:d,result:u}})),l=0;for(let{candidate:d,result:u}of a){if(e.seenIds.add(d.toolCallId),!u)continue;let p=Xu(u);s.set(d.toolCallId,p),e.replacements.set(d.toolCallId,p),l++}return s.size===0?{messages:n,newlyReplacedCount:0}:{messages:n.map(d=>{if(d.role!=="tool"||!d.tool_call_id)return d;let u=s.get(d.tool_call_id);return u===void 0?d:{...d,content:u}}),newlyReplacedCount:l}}var YT,Vu,XT,tl=N(()=>{"use strict";je();YT="tool-results",Vu="<persisted-output>",XT="</persisted-output>"});function sw(n){try{return JSON.parse(n)}catch{return}}var ow,rw,Kr,Zu=N(()=>{"use strict";$n();tl();ow=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),rw=new Set(["bash","execute_command","Bash","shell"]),Kr=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??ow,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let t=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:t,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let t=this.tools.filter(r=>r.status==="executing"),o=this.config.maxConcurrentTools;return o&&o>0&&t.length>=o?!1:t.length===0||e&&t.every(r=>r.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let t;try{t=JSON.parse(e.toolCall.function.arguments)}catch{}let o=t?.command??t?.file_path??t?.pattern??"";if(typeof o=="string"&&o.length>0){let r=o.length>40?o.slice(0,40)+"\u2026":o;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,t){let o=this.erroredToolDescription,r=t==="user_interrupted"?"User rejected tool use":t==="discarded"?"Streaming fallback - tool execution discarded":o?`Cancelled: parallel tool call ${o} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:r,message:nn(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let o=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:i,sessionId:a,turnId:l,log:c}=this.config,d=e.toolCall.function.name,u=!1,p=e.toolCall.function.arguments;if(i)try{let k=await i.invoke("tool.before_invoke",{sessionId:a,turnId:l,callId:e.id,toolName:d,arguments:sw(p)});if(k.action==="abort"){let x=k.reason??"blocked by policy";c.info(`tool ${d} blocked: ${x}`),e.results.push({callId:e.id,toolName:d,ok:!1,error:x,blocked:!0,blockReason:x,message:nn(e.id,{ok:!1,error:x})}),e.status="completed";return}k.action==="continue"&&k.context?.arguments&&(p=JSON.stringify(k.context.arguments))}catch{}let m=await s.invoke(l,d,p,this.siblingAbortController.signal),h=this.getAbortReason();if(h&&!u){e.results.push(this.createSyntheticError(e,h)),e.status="completed";return}let f=!m.error,y=m.result;f&&y&&y.length>5e4&&(y=await Ju(y,e.id,a));let b=nn(e.id,{ok:f,payload:y,error:m.error,toolReferences:m.toolReferences,imageUrls:m.imageUrls});f||(u=!0,rw.has(d)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),i?.invoke(f?"tool.after_invoke":"tool.invoke_failed",{sessionId:a,turnId:l,callId:e.id,toolName:d,ok:f,...m.error?{error:m.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:d,ok:f,error:m.error,message:b}),e.status="completed"})();e.promise=o,o.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let t of e.results)yield t}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(o=>o.status==="executing"&&o.promise).map(o=>o.promise),t=new Promise(o=>{this.progressResolve=o});e.length>0&&await Promise.race([...e,t])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}}});import{homedir as iw}from"node:os";import{join as Ae}from"node:path";import{existsSync as aw}from"node:fs";function H(){return process.env.QLOGICAGENT_HOME||Ae(iw(),He)}function ep(){return Ae(H(),"plugins")}function Ht(){return Ae(H(),"skills")}function pt(){return Ae(H(),"settings.json")}function tp(){return Ae(H(),"plugin-cache")}function np(){return Ae(H(),"mcp.json")}function op(){return Ae(H(),"marketplace.json")}function rp(){return Ae(H(),"workflows")}function sp(){return Ae(H(),"rules")}function Oe(n){if(!n)throw new Error("getProjectAgentDir: cwd is required (must not fall back to process.cwd())");return Ae(n,He)}function ip(n){return Ae(Oe(n),"workflows")}function It(n){return Ae(Oe(n),"skills")}function Oo(n){return Ae(Oe(n),"INSTRUCTIONS.md")}function Gn(n){return Ae(Oe(n),"rules")}function Vt(n){return Ae(Oe(n),"sessions")}function ap(n,e){let t=Ae(Oe(n),"checkpoints");return e?Ae(t,e):t}function lp(n){return Ae(n,He,"hooks")}function cp(n,e){return n.filter(t=>t!==e&&aw(Ae(t,He,"skills")))}var He,le=N(()=>{"use strict";He=".qlogicagent"});var zr,dp=N(()=>{"use strict";zr=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let t of e){this.pools.set(t.providerId,t);for(let o of t.keys)this.runtimeStates.set(o.id,this.createInitialState())}}acquireKey(e){let t=this.pools.get(e);if(!t||t.keys.length===0)return null;let o=Date.now(),r=this.getHealthyCandidates(t,o);if(r.length===0)return null;let s=this.selectByStrategy(r,t.strategy,o);if(!s)return null;let i=this.runtimeStates.get(s.id);return i.inFlight++,i.totalRequests++,i.lastUsedAt=o,i.requestTimestamps.push(o),{keyId:s.id,apiKey:s.key,providerId:e,release:a=>this.releaseKey(s.id,a)}}releaseKey(e,t){let o=this.runtimeStates.get(e);if(o)if(o.inFlight=Math.max(0,o.inFlight-1),t.success)o.consecutiveErrors=0,o.healthStatus="healthy",t.tokens&&(o.totalTokens+=t.tokens,o.tokenCounts.push(t.tokens));else if(o.consecutiveErrors++,o.lastErrorAt=Date.now(),t.errorCode===429){let r=t.retryAfter?t.retryAfter*1e3:3e4;o.cooldownUntil=Date.now()+r,o.healthStatus="cooldown"}else o.consecutiveErrors>=5?(o.cooldownUntil=Date.now()+6e4,o.healthStatus="cooldown"):o.consecutiveErrors>=3&&(o.healthStatus="degraded")}addProvider(e,t){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:t?.baseUrl,strategy:t?.strategy??"weighted-round-robin",keys:[],rateLimit:t?.rateLimit})}removeProvider(e){let t=this.pools.get(e);if(t){for(let o of t.keys)this.runtimeStates.delete(o.id);this.pools.delete(e)}}addKey(e,t,o){let r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=o?.id??crypto.randomUUID(),i={id:s,key:t,label:o?.label,weight:o?.weight??1,enabled:o?.enabled??!0};return r.keys.push(i),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let t of this.pools.values()){let o=t.keys.findIndex(r=>r.id===e);if(o!==-1){t.keys.splice(o,1),this.runtimeStates.delete(e);return}}}updateKey(e,t){for(let o of this.pools.values()){let r=o.keys.find(s=>s.id===e);if(r){if(t.label!==void 0&&(r.label=t.label),t.weight!==void 0&&(r.weight=t.weight),t.enabled!==void 0){r.enabled=t.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=t.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,t){let o=this.runtimeStates.get(e);o&&(o.healthStatus=t)}setStrategy(e,t){let o=this.pools.get(e);o&&(o.strategy=t)}setRateLimit(e,t){let o=this.pools.get(e);o&&(o.rateLimit=t)}getPoolStatus(e){let t=this.pools.get(e);return t?this.buildPoolStatus(t):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let t=this.pools.get(e);return t?this.getHealthyCandidates(t,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let t=new Set;for(let o of e){this.pools.set(o.providerId,o);for(let r of o.keys)t.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let o of[...this.pools.keys()])e.some(r=>r.providerId===o)||this.pools.delete(o);for(let o of[...this.runtimeStates.keys()])t.has(o)||this.runtimeStates.delete(o)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,t){let o=[];for(let r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.id);if(s){if(s.healthStatus==="cooldown")if(t>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,t),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,t),s.tokenCounts.reduce((a,l)=>a+l,0)>=e.rateLimit.tpm*.9)||o.push(r))}}return o}selectByStrategy(e,t,o){if(e.length===0)return null;if(e.length===1)return e[0];switch(t){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let t=e.reduce((r,s)=>r+s.weight,0),o=Math.random()*t;for(let r of e)if(o-=r.weight,o<=0)return r;return e[e.length-1]}leastBusy(e){let t=1/0,o=e[0];for(let r of e){let i=this.runtimeStates.get(r.id)?.inFlight??0;(i<t||i===t&&r.weight>o.weight)&&(t=i,o=r)}return o}pruneWindow(e,t){let o=t-6e4;for(;e.length>0&&e[0]<o;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(t=>{let o=this.runtimeStates.get(t.id)??this.createInitialState();return{...t,inFlight:o.inFlight,totalRequests:o.totalRequests,totalTokens:o.totalTokens,lastUsedAt:o.lastUsedAt,lastErrorAt:o.lastErrorAt,consecutiveErrors:o.consecutiveErrors,cooldownUntil:o.cooldownUntil,healthStatus:t.enabled?o.healthStatus:"disabled"}})}}}});var up={};fn(up,{ALL_PURPOSES:()=>Lo,ModelRegistry:()=>qr,deriveModelPurposes:()=>cw,getModelRegistry:()=>X,resetModelRegistry:()=>lw});import*as et from"node:fs";function X(){return Do||(Do=new qr,Do.load()),Do}function lw(){Do=null}function cw(n){let e=[];switch((!n.mediaType||n.mediaType==="image_understanding"||n.mediaType==="video_understanding")&&e.push("textGeneration"),(n.vision||n.mediaType==="image_understanding")&&e.push("imageUnderstanding"),n.mediaType==="video_understanding"&&e.push("videoUnderstanding"),n.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function dw(n){switch(n){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return n;default:return}}function uw(n,e){switch(n){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return dw(e)}}function pw(n){switch(n){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}var Lo,qr,Do,mt=N(()=>{"use strict";an();le();dp();Lo=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],qr=class{keyPool;coreProviderRegistry=new sn;providerVariantResolver=new _o(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=pt(),this.keyPool=new zr(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let t=this.bindings[e];if(!t)return null;let o=this.models.get(t);if(!o||!o.enabled)return null;let r=this.resolveTechnicalVariant(o,e),s=r?.provider??o.provider,i=r?.nativeModelId??o.nativeModelId??o.model,a=this.acquireKeyForProviderVariant(s);if(!a)return null;let{keyHandle:l,keyProviderId:c}=a;return{provider:s,model:i,apiKey:l.apiKey,baseUrl:o.provider===s?o.baseUrl??this.getProviderBaseUrl(s)??this.getProviderBaseUrl(c):this.getProviderBaseUrl(s),keyHandle:l}}peekActiveModel(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}isAvailable(e){let t=this.peekActiveModel(e);return!!t?.enabled&&this.hasAvailableKeyForProviderVariant(t.provider)}resolveModelForPurpose(e){let t=this.peekActiveModel(e);return t?t.model:null}addProvider(e,t){this.keyPool.addProvider(e,t),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[t,o]of this.models)o.provider===e&&this.removeModel(t);this.emitChange()}addKey(e,t,o){let r=this.keyPool.addKey(e,t,o);return this.emitChange(),r}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,t){this.keyPool.updateKey(e,t),this.emitChange()}setKeyHealth(e,t){this.keyPool.setKeyHealth(e,t),this.emitChange()}setStrategy(e,t){this.keyPool.setStrategy(e,t),this.emitChange()}addModel(e){let t=e.id??`${e.provider}:${e.model}`;return this.models.set(t,{...e,id:t,enabled:this.modelEnabledOverrides.get(t)??e.enabled}),this.emitChange(),t}replaceCatalogModels(e){let t=new Map;for(let o of e)t.set(o.id,{...o,enabled:this.modelEnabledOverrides.get(o.id)??o.enabled});for(let o of this.modelEnabledOverrides.keys())t.has(o)||this.modelEnabledOverrides.delete(o);this.models=t;for(let[o,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[o];this.emitChange()}migrateModelIds(e){for(let[t,o]of e){let r=this.modelEnabledOverrides.get(t);r!==void 0&&!this.modelEnabledOverrides.has(o)&&this.modelEnabledOverrides.set(o,r),this.modelEnabledOverrides.delete(t);for(let[s,i]of Object.entries(this.bindings))i===t&&(this.bindings[s]=o)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[t,o]of Object.entries(this.bindings))o===e&&delete this.bindings[t];this.emitChange()}enableModel(e){let t=this.models.get(e);t&&(t.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let t=this.models.get(e);t&&(t.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let t=[...this.models.values()];return e?.purpose&&(t=t.filter(o=>o.purposes.includes(e.purpose))),e?.provider&&(t=t.filter(o=>o.provider===e.provider)),e?.enabledOnly&&(t=t.filter(o=>o.enabled)),t}getModel(e){return this.models.get(e)??null}setBinding(e,t){let o=this.models.get(t);if(!o)throw new Error(`Model "${t}" not found in pool.`);if(!o.purposes.includes(e))throw new Error(`Model "${t}" does not support purpose "${e}".`);this.bindings[e]=t,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}getAllBindings(){let e={};for(let t of Lo){let o=this.bindings[t];e[t]=o?this.models.get(o)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{et.existsSync(this.settingsPath)&&(e=JSON.parse(et.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let t={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},o=this.settingsPath.replace(/[/\\][^/\\]+$/,"");et.existsSync(o)||et.mkdirSync(o,{recursive:!0}),et.writeFileSync(this.settingsPath,JSON.stringify(t,null,2),"utf-8")}load(){try{if(!et.existsSync(this.settingsPath))return!1;let e=et.readFileSync(this.settingsPath,"utf-8"),t=JSON.parse(e);return t.providers&&this.keyPool.reloadConfig(t.providers),this.models.clear(),this.modelEnabledOverrides.clear(),t.models&&this.loadModelState(t.models),this.bindings=t.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!et.existsSync(this.settingsPath))return;let t=et.readFileSync(this.settingsPath,"utf-8");return JSON.parse(t).tunables?.[e]}catch{return}}getModelInfo(e,t){let o=this.listModels({provider:e}).find(r=>r.model===t);if(o)return{id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>!!this.keyPool.getPoolStatus(t)?.keys.some(r=>r.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>this.keyPool.hasAvailableKey(t))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(t=>({id:t.model,name:t.displayName,contextWindow:t.contextWindow,maxOutput:t.maxOutput,streamRequired:t.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let t=this.changeListeners.indexOf(e);t>=0&&this.changeListeners.splice(t,1)}}getKeyForProvider(e){let o=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!o)return null;let r=o.apiKey;return o.release({success:!0}),r}snapshotProviderKeys(){let e={};for(let t of this.keyPool.getAllStatus()){let o=this.getKeyForProvider(t.providerId);o&&(e[t.providerId]=o)}return e}getProviderBaseUrl(e){return this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let t of this.providerVariantKeyCandidates(e)){let o=this.keyPool.acquireKey(t);if(o)return{keyHandle:o,keyProviderId:t}}return null}resolveTechnicalVariant(e,t){let o=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(o.length===0)return;let r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:uw(t,e.transport),capabilities:pw(t),purpose:t,userPreference:{providerIds:o}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let t=[e],o=this.coreProviderRegistry.getProvider(e),r=o?.group??o?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&t.push(s.id);return r!==e&&t.push(r),[...new Set(t)]}loadModelState(e){for(let t of e)typeof t.id!="string"||!t.id||typeof t.enabled=="boolean"&&this.modelEnabledOverrides.set(t.id,t.enabled)}exportModelState(){let e=new Map;for(let[t,o]of this.modelEnabledOverrides)e.set(t,o);for(let t of this.models.values())e.set(t.id,t.enabled);return[...e.entries()].map(([t,o])=>({id:t,enabled:o}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},Do=null});import{readFile as mw}from"node:fs/promises";function Sn(n){let e=typeof n.content=="string"?n.content:n.content!=null?JSON.stringify(n.content):"";return Math.ceil(e.length/4)}function Tn(n){let e=0;for(let t of n)e+=Sn(t);return e}function mp(n){if(!n)return 128e3;if(n in nl)return nl[n];let e=n.toLowerCase();for(let[t,o]of Object.entries(nl))if(e.startsWith(t.toLowerCase()))return o;return 128e3}function gw(){return X().resolveModelForPurpose("textGeneration")??fw}function gp(){return rl}function hw(n,e){return async(t,o)=>{let r=e?.transport,s=e?.apiKey;if(!r||!s)return n.debug("[context-compression] no LLM transport for summarization \u2014 using sync fallback"),ol(t);try{let i="",a=e?.model??gw();for await(let l of r.stream({model:a,messages:[{role:"system",content:"You are a precise conversation summarizer."},{role:"user",content:o}],maxTokens:2e3,temperature:.3},s,AbortSignal.timeout(3e4)))l.type==="delta"&&(i+=l.text);return i||(n.warn("[context-compression] empty summary response"),ol(t))}catch(i){return n.warn({err:i.message},"[context-compression] summarize call error \u2014 using fallback"),ol(t)}}}function ol(n){let e=[],t=n.filter(s=>s.role==="user"),o=t.slice(0,20).map(s=>{let i=typeof s.content=="string"?s.content:JSON.stringify(s.content??"");return`- [user]: ${i.slice(0,300)}${i.length>300?"...":""}`});e.push(`## User Requests (${t.length} messages)`),e.push(...o);let r=n.filter(s=>s.role==="assistant");if(r.length>0){let s=r.slice(0,10).map(i=>{let a=typeof i.content=="string"?i.content:JSON.stringify(i.content??"");return`- [assistant]: ${a.slice(0,150)}${a.length>150?"...":""}`});e.push("",`## Assistant Responses (${r.length} total)`),e.push(...s)}return e.join(`
|
|
42
|
+
...[truncated ${n.length-o} chars]`}function ew(n){let e=[],t=[];for(let o of n)o.role==="tool"&&typeof o.content=="string"&&o.tool_call_id?qu(o.content)||t.push({toolCallId:o.tool_call_id,content:o.content,size:o.content.length}):o.role==="assistant"&&t.length>0&&(e.push(t),t=[]);return t.length>0&&e.push(t),e}function tw(n,e){let t=[],o=[],r=[];for(let s of n){let i=e.replacements.get(s.toolCallId);i!==void 0?t.push({...s,replacement:i}):e.seenIds.has(s.toolCallId)?o.push(s):r.push(s)}return{mustReapply:t,frozen:o,fresh:r}}function nw(n,e,t){let o=[...n].sort((i,a)=>a.size-i.size),r=[],s=e+n.reduce((i,a)=>i+a.size,0);for(let i of o){if(s<=t)break;r.push(i),s-=i.size}return r}async function Qu(n,e,t,o=Fi){let r=ew(n);if(r.length===0)return{messages:n,newlyReplacedCount:0};let s=new Map,i=[];for(let d of r){let{mustReapply:u,frozen:p,fresh:m}=tw(d,e);for(let k of u)s.set(k.toolCallId,k.replacement);if(m.length===0){for(let k of d)e.seenIds.add(k.toolCallId);continue}let h=p.reduce((k,x)=>k+x.size,0),f=m.reduce((k,x)=>k+x.size,0),y=h+f>o?nw(m,h,o):[],b=new Set(y.map(k=>k.toolCallId));for(let k of d)b.has(k.toolCallId)||e.seenIds.add(k.toolCallId);y.length>0&&i.push(...y)}if(s.size===0&&i.length===0)return{messages:n,newlyReplacedCount:0};let a=await Promise.all(i.map(async d=>{let u=await Yu(d.content,d.toolCallId,t);return{candidate:d,result:u}})),l=0;for(let{candidate:d,result:u}of a){if(e.seenIds.add(d.toolCallId),!u)continue;let p=Xu(u);s.set(d.toolCallId,p),e.replacements.set(d.toolCallId,p),l++}return s.size===0?{messages:n,newlyReplacedCount:0}:{messages:n.map(d=>{if(d.role!=="tool"||!d.tool_call_id)return d;let u=s.get(d.tool_call_id);return u===void 0?d:{...d,content:u}}),newlyReplacedCount:l}}var YT,Vu,XT,tl=N(()=>{"use strict";je();YT="tool-results",Vu="<persisted-output>",XT="</persisted-output>"});function sw(n){try{return JSON.parse(n)}catch{return}}var ow,rw,Kr,Zu=N(()=>{"use strict";$n();tl();ow=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),rw=new Set(["bash","execute_command","Bash","shell"]),Kr=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??ow,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let t=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:t,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let t=this.tools.filter(r=>r.status==="executing"),o=this.config.maxConcurrentTools;return o&&o>0&&t.length>=o?!1:t.length===0||e&&t.every(r=>r.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let t;try{t=JSON.parse(e.toolCall.function.arguments)}catch{}let o=t?.command??t?.file_path??t?.pattern??"";if(typeof o=="string"&&o.length>0){let r=o.length>40?o.slice(0,40)+"\u2026":o;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,t){let o=this.erroredToolDescription,r=t==="user_interrupted"?"User rejected tool use":t==="discarded"?"Streaming fallback - tool execution discarded":o?`Cancelled: parallel tool call ${o} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:r,message:nn(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let o=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:i,sessionId:a,turnId:l,log:c}=this.config,d=e.toolCall.function.name,u=!1,p=e.toolCall.function.arguments;if(i)try{let k=await i.invoke("tool.before_invoke",{sessionId:a,turnId:l,callId:e.id,toolName:d,arguments:sw(p)});if(k.action==="abort"){let x=k.reason??"blocked by policy";c.info(`tool ${d} blocked: ${x}`),e.results.push({callId:e.id,toolName:d,ok:!1,error:x,blocked:!0,blockReason:x,message:nn(e.id,{ok:!1,error:x})}),e.status="completed";return}k.action==="continue"&&k.context?.arguments&&(p=JSON.stringify(k.context.arguments))}catch{}let m=await s.invoke(l,d,p,this.siblingAbortController.signal),h=this.getAbortReason();if(h&&!u){e.results.push(this.createSyntheticError(e,h)),e.status="completed";return}let f=!m.error,y=m.result;f&&y&&y.length>5e4&&(y=await Ju(y,e.id,a));let b=nn(e.id,{ok:f,payload:y,error:m.error,toolReferences:m.toolReferences,imageUrls:m.imageUrls});f||(u=!0,rw.has(d)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),i?.invoke(f?"tool.after_invoke":"tool.invoke_failed",{sessionId:a,turnId:l,callId:e.id,toolName:d,ok:f,...m.error?{error:m.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:d,ok:f,error:m.error,message:b}),e.status="completed"})();e.promise=o,o.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let t of e.results)yield t}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(o=>o.status==="executing"&&o.promise).map(o=>o.promise),t=new Promise(o=>{this.progressResolve=o});e.length>0&&await Promise.race([...e,t])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}}});import{homedir as iw}from"node:os";import{join as Ae}from"node:path";import{existsSync as aw}from"node:fs";function H(){return process.env.QLOGICAGENT_HOME||Ae(iw(),He)}function ep(){return Ae(H(),"plugins")}function Ht(){return Ae(H(),"skills")}function pt(){return Ae(H(),"settings.json")}function tp(){return Ae(H(),"plugin-cache")}function np(){return Ae(H(),"mcp.json")}function op(){return Ae(H(),"marketplace.json")}function rp(){return Ae(H(),"workflows")}function sp(){return Ae(H(),"rules")}function Oe(n){if(!n)throw new Error("getProjectAgentDir: cwd is required (must not fall back to process.cwd())");return Ae(n,He)}function ip(n){return Ae(Oe(n),"workflows")}function It(n){return Ae(Oe(n),"skills")}function Oo(n){return Ae(Oe(n),"INSTRUCTIONS.md")}function Gn(n){return Ae(Oe(n),"rules")}function Vt(n){return Ae(Oe(n),"sessions")}function ap(n,e){let t=Ae(Oe(n),"checkpoints");return e?Ae(t,e):t}function lp(n){return Ae(n,He,"hooks")}function cp(n,e){return n.filter(t=>t!==e&&aw(Ae(t,He,"skills")))}var He,le=N(()=>{"use strict";He=".qlogicagent"});var zr,dp=N(()=>{"use strict";zr=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let t of e){this.pools.set(t.providerId,t);for(let o of t.keys)this.runtimeStates.set(o.id,this.createInitialState())}}acquireKey(e){let t=this.pools.get(e);if(!t||t.keys.length===0)return null;let o=Date.now(),r=this.getHealthyCandidates(t,o);if(r.length===0)return null;let s=this.selectByStrategy(r,t.strategy,o);if(!s)return null;let i=this.runtimeStates.get(s.id);return i.inFlight++,i.totalRequests++,i.lastUsedAt=o,i.requestTimestamps.push(o),{keyId:s.id,apiKey:s.key,providerId:e,release:a=>this.releaseKey(s.id,a)}}releaseKey(e,t){let o=this.runtimeStates.get(e);if(o)if(o.inFlight=Math.max(0,o.inFlight-1),t.success)o.consecutiveErrors=0,o.healthStatus="healthy",t.tokens&&(o.totalTokens+=t.tokens,o.tokenCounts.push(t.tokens));else if(o.consecutiveErrors++,o.lastErrorAt=Date.now(),t.errorCode===429){let r=t.retryAfter?t.retryAfter*1e3:3e4;o.cooldownUntil=Date.now()+r,o.healthStatus="cooldown"}else o.consecutiveErrors>=5?(o.cooldownUntil=Date.now()+6e4,o.healthStatus="cooldown"):o.consecutiveErrors>=3&&(o.healthStatus="degraded")}addProvider(e,t){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:t?.baseUrl,strategy:t?.strategy??"weighted-round-robin",keys:[],rateLimit:t?.rateLimit})}removeProvider(e){let t=this.pools.get(e);if(t){for(let o of t.keys)this.runtimeStates.delete(o.id);this.pools.delete(e)}}addKey(e,t,o){let r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=o?.id??crypto.randomUUID(),i={id:s,key:t,label:o?.label,weight:o?.weight??1,enabled:o?.enabled??!0};return r.keys.push(i),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let t of this.pools.values()){let o=t.keys.findIndex(r=>r.id===e);if(o!==-1){t.keys.splice(o,1),this.runtimeStates.delete(e);return}}}updateKey(e,t){for(let o of this.pools.values()){let r=o.keys.find(s=>s.id===e);if(r){if(t.label!==void 0&&(r.label=t.label),t.weight!==void 0&&(r.weight=t.weight),t.enabled!==void 0){r.enabled=t.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=t.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,t){let o=this.runtimeStates.get(e);o&&(o.healthStatus=t)}setStrategy(e,t){let o=this.pools.get(e);o&&(o.strategy=t)}setRateLimit(e,t){let o=this.pools.get(e);o&&(o.rateLimit=t)}getPoolStatus(e){let t=this.pools.get(e);return t?this.buildPoolStatus(t):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let t=this.pools.get(e);return t?this.getHealthyCandidates(t,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let t=new Set;for(let o of e){this.pools.set(o.providerId,o);for(let r of o.keys)t.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let o of[...this.pools.keys()])e.some(r=>r.providerId===o)||this.pools.delete(o);for(let o of[...this.runtimeStates.keys()])t.has(o)||this.runtimeStates.delete(o)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,t){let o=[];for(let r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.id);if(s){if(s.healthStatus==="cooldown")if(t>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,t),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,t),s.tokenCounts.reduce((a,l)=>a+l,0)>=e.rateLimit.tpm*.9)||o.push(r))}}return o}selectByStrategy(e,t,o){if(e.length===0)return null;if(e.length===1)return e[0];switch(t){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let t=e.reduce((r,s)=>r+s.weight,0),o=Math.random()*t;for(let r of e)if(o-=r.weight,o<=0)return r;return e[e.length-1]}leastBusy(e){let t=1/0,o=e[0];for(let r of e){let i=this.runtimeStates.get(r.id)?.inFlight??0;(i<t||i===t&&r.weight>o.weight)&&(t=i,o=r)}return o}pruneWindow(e,t){let o=t-6e4;for(;e.length>0&&e[0]<o;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(t=>{let o=this.runtimeStates.get(t.id)??this.createInitialState();return{...t,inFlight:o.inFlight,totalRequests:o.totalRequests,totalTokens:o.totalTokens,lastUsedAt:o.lastUsedAt,lastErrorAt:o.lastErrorAt,consecutiveErrors:o.consecutiveErrors,cooldownUntil:o.cooldownUntil,healthStatus:t.enabled?o.healthStatus:"disabled"}})}}}});var up={};fn(up,{ALL_PURPOSES:()=>Lo,ModelRegistry:()=>qr,deriveModelPurposes:()=>cw,getModelRegistry:()=>X,resetModelRegistry:()=>lw});import*as et from"node:fs";function X(){return Do||(Do=new qr,Do.load()),Do}function lw(){Do=null}function cw(n){let e=[];switch((!n.mediaType||n.mediaType==="image_understanding"||n.mediaType==="video_understanding")&&e.push("textGeneration"),(n.vision||n.mediaType==="image_understanding")&&e.push("imageUnderstanding"),n.mediaType==="video_understanding"&&e.push("videoUnderstanding"),n.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function dw(n){switch(n){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return n;default:return}}function uw(n,e){switch(n){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return dw(e)}}function pw(n){switch(n){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}var Lo,qr,Do,mt=N(()=>{"use strict";an();le();dp();Lo=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],qr=class{keyPool;coreProviderRegistry=new sn;providerVariantResolver=new _o(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=pt(),this.keyPool=new zr(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings})}getActiveModel(e){let t=this.bindings[e];if(!t)return null;let o=this.models.get(t);if(!o||!o.enabled)return null;let r=this.resolveTechnicalVariant(o,e),s=r?.provider??o.provider,i=r?.nativeModelId??o.nativeModelId??o.model,a=this.acquireKeyForProviderVariant(s);if(!a)return null;let{keyHandle:l,keyProviderId:c}=a;return{provider:s,model:i,apiKey:l.apiKey,baseUrl:o.provider===s?o.baseUrl??this.getProviderBaseUrl(s)??this.getProviderBaseUrl(c):this.getProviderBaseUrl(s),keyHandle:l}}peekActiveModel(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}isAvailable(e){let t=this.peekActiveModel(e);return!!t?.enabled&&this.hasAvailableKeyForProviderVariant(t.provider)}resolveModelForPurpose(e){let t=this.peekActiveModel(e);return t?t.model:null}addProvider(e,t){this.keyPool.addProvider(e,t),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[t,o]of this.models)o.provider===e&&this.removeModel(t);this.emitChange()}addKey(e,t,o){let r=this.keyPool.addKey(e,t,o);return this.emitChange(),r}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,t){this.keyPool.updateKey(e,t),this.emitChange()}setKeyHealth(e,t){this.keyPool.setKeyHealth(e,t),this.emitChange()}setStrategy(e,t){this.keyPool.setStrategy(e,t),this.emitChange()}addModel(e){let t=e.id??`${e.provider}:${e.model}`;return this.models.set(t,{...e,id:t,enabled:this.modelEnabledOverrides.get(t)??e.enabled}),this.emitChange(),t}replaceCatalogModels(e){let t=new Map;for(let o of e)t.set(o.id,{...o,enabled:this.modelEnabledOverrides.get(o.id)??o.enabled});for(let o of this.modelEnabledOverrides.keys())t.has(o)||this.modelEnabledOverrides.delete(o);this.models=t;for(let[o,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[o];this.emitChange()}migrateModelIds(e){for(let[t,o]of e){let r=this.modelEnabledOverrides.get(t);r!==void 0&&!this.modelEnabledOverrides.has(o)&&this.modelEnabledOverrides.set(o,r),this.modelEnabledOverrides.delete(t);for(let[s,i]of Object.entries(this.bindings))i===t&&(this.bindings[s]=o)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[t,o]of Object.entries(this.bindings))o===e&&delete this.bindings[t];this.emitChange()}enableModel(e){let t=this.models.get(e);t&&(t.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let t=this.models.get(e);t&&(t.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let t=[...this.models.values()];return e?.purpose&&(t=t.filter(o=>o.purposes.includes(e.purpose))),e?.provider&&(t=t.filter(o=>o.provider===e.provider)),e?.enabledOnly&&(t=t.filter(o=>o.enabled)),t}getModel(e){return this.models.get(e)??null}setBinding(e,t){let o=this.models.get(t);if(!o)throw new Error(`Model "${t}" not found in pool.`);if(!o.purposes.includes(e))throw new Error(`Model "${t}" does not support purpose "${e}".`);this.bindings[e]=t,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let t=this.bindings[e];return t?this.models.get(t)??null:null}getAllBindings(){let e={};for(let t of Lo){let o=this.bindings[t];e[t]=o?this.models.get(o)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{et.existsSync(this.settingsPath)&&(e=JSON.parse(et.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let t={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},o=this.settingsPath.replace(/[/\\][^/\\]+$/,"");et.existsSync(o)||et.mkdirSync(o,{recursive:!0}),et.writeFileSync(this.settingsPath,JSON.stringify(t,null,2),"utf-8")}load(){try{if(!et.existsSync(this.settingsPath))return!1;let e=et.readFileSync(this.settingsPath,"utf-8"),t=JSON.parse(e);return t.providers&&this.keyPool.reloadConfig(t.providers),this.models.clear(),this.modelEnabledOverrides.clear(),t.models&&this.loadModelState(t.models),this.bindings=t.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!et.existsSync(this.settingsPath))return;let t=et.readFileSync(this.settingsPath,"utf-8");return JSON.parse(t).tunables?.[e]}catch{return}}getModelInfo(e,t){let o=this.listModels({provider:e}).find(r=>r.model===t);if(o)return{id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>!!this.keyPool.getPoolStatus(t)?.keys.some(r=>r.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(t=>this.keyPool.hasAvailableKey(t))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(t=>({id:t.model,name:t.displayName,contextWindow:t.contextWindow,maxOutput:t.maxOutput,streamRequired:t.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let t=this.changeListeners.indexOf(e);t>=0&&this.changeListeners.splice(t,1)}}getKeyForProvider(e){let o=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!o)return null;let r=o.apiKey;return o.release({success:!0}),r}snapshotProviderKeys(){let e={};for(let t of this.keyPool.getAllStatus()){let o=this.getKeyForProvider(t.providerId);o&&(e[t.providerId]=o)}return e}getProviderBaseUrl(e){return this.coreProviderRegistry.getProvider(e)?.baseUrl??this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let t of this.providerVariantKeyCandidates(e)){let o=this.keyPool.acquireKey(t);if(o)return{keyHandle:o,keyProviderId:t}}return null}resolveTechnicalVariant(e,t){let o=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(o.length===0)return;let r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:uw(t,e.transport),capabilities:pw(t),purpose:t,userPreference:{providerIds:o}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let t=[e],o=this.coreProviderRegistry.getProvider(e),r=o?.group??o?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&t.push(s.id);return r!==e&&t.push(r),[...new Set(t)]}loadModelState(e){for(let t of e)typeof t.id!="string"||!t.id||typeof t.enabled=="boolean"&&this.modelEnabledOverrides.set(t.id,t.enabled)}exportModelState(){let e=new Map;for(let[t,o]of this.modelEnabledOverrides)e.set(t,o);for(let t of this.models.values())e.set(t.id,t.enabled);return[...e.entries()].map(([t,o])=>({id:t,enabled:o}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},Do=null});import{readFile as mw}from"node:fs/promises";function Sn(n){let e=typeof n.content=="string"?n.content:n.content!=null?JSON.stringify(n.content):"";return Math.ceil(e.length/4)}function Tn(n){let e=0;for(let t of n)e+=Sn(t);return e}function mp(n){if(!n)return 128e3;if(n in nl)return nl[n];let e=n.toLowerCase();for(let[t,o]of Object.entries(nl))if(e.startsWith(t.toLowerCase()))return o;return 128e3}function gw(){return X().resolveModelForPurpose("textGeneration")??fw}function gp(){return rl}function hw(n,e){return async(t,o)=>{let r=e?.transport,s=e?.apiKey;if(!r||!s)return n.debug("[context-compression] no LLM transport for summarization \u2014 using sync fallback"),ol(t);try{let i="",a=e?.model??gw();for await(let l of r.stream({model:a,messages:[{role:"system",content:"You are a precise conversation summarizer."},{role:"user",content:o}],maxTokens:2e3,temperature:.3},s,AbortSignal.timeout(3e4)))l.type==="delta"&&(i+=l.text);return i||(n.warn("[context-compression] empty summary response"),ol(t))}catch(i){return n.warn({err:i.message},"[context-compression] summarize call error \u2014 using fallback"),ol(t)}}}function ol(n){let e=[],t=n.filter(s=>s.role==="user"),o=t.slice(0,20).map(s=>{let i=typeof s.content=="string"?s.content:JSON.stringify(s.content??"");return`- [user]: ${i.slice(0,300)}${i.length>300?"...":""}`});e.push(`## User Requests (${t.length} messages)`),e.push(...o);let r=n.filter(s=>s.role==="assistant");if(r.length>0){let s=r.slice(0,10).map(i=>{let a=typeof i.content=="string"?i.content:JSON.stringify(i.content??"");return`- [assistant]: ${a.slice(0,150)}${a.length>150?"...":""}`});e.push("",`## Assistant Responses (${r.length} total)`),e.push(...s)}return e.join(`
|
|
43
43
|
`)}function yw(){return vi(new bn(sl),new on(20,Sn),new Dn(Sn))}function pp(n,e){let t=Si(new bn(sl),new on(20,Sn),new fo({protectedHeadExchanges:1,protectedTailMessages:8,summarize:n,estimateTokens:Sn}),new Dn(Sn));return new go({inner:t,estimateTokens:Sn,onCacheInvalidated:e?.onCacheInvalidated})}function hp(n,e){let t=e?.budget??Sr({modelContextWindow:mp(e?.model)}),r=(e?.pipeline??yw()).compress(n,t);if(r.droppedCount>0){let s=Tn(n),i=Tn(r.messages);fp.record({timestamp:Date.now(),strategy:r.strategy,tokensBefore:s,tokensAfter:i,droppedCount:r.droppedCount,latencyMs:r.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:r.metrics?.cacheInvalidated??!1,tier:ko(s,t)})}return r.droppedCount>0&&il?.(r.droppedCount,Tn(r.messages)),r}async function bw(n,e,t){let o=t??Sr({modelContextWindow:mp(e.model)}),r=Tn(n),s=ko(r,o),i;switch(s){case"none":i={messages:n,droppedCount:0,strategy:"none"};break;case"trim-only":i=new bn(sl).compress(n,o);break;case"sliding-window":{i=await pp(e.summarize).compressAsync(n,o);break}case"llm-summarize":{let a=e.pipeline??pp(e.summarize);i=bo(a)?await a.compressAsync(n,o):a.compress(n,o);break}}return i.droppedCount>0&&(i={...i,messages:await wi(i.messages,n,{maxFiles:5,maxTokenBudget:5e4,readFile:async a=>{try{return await mw(a,"utf-8")}catch{return null}}})}),kw(n,i,o),i}function kw(n,e,t){if(e.droppedCount>0||e.metrics?.usedLlm){let o=e.metrics?.tokensBefore||Tn(n),r=e.metrics?.tokensAfter||Tn(e.messages);fp.record({timestamp:Date.now(),strategy:e.strategy,tokensBefore:o,tokensAfter:r,droppedCount:e.droppedCount,latencyMs:e.metrics?.latencyMs??0,usedLlm:e.metrics?.usedLlm??!1,cacheInvalidated:e.metrics?.cacheInvalidated??!1,tier:ko(o,t)})}if(e.droppedCount>0){let o=e.metrics?.tokensAfter||Tn(e.messages);il?.(e.droppedCount,o)}}function vw(n,e){let t=hw(n,e),o={id:"builtin-compressor",label:"4-Layer Compression Funnel (built-in)",async compressAsync(r,s,i){return bw(r,{budget:s,model:i?.model,sessionId:i?.sessionId,summarize:t},s)}};rl.register(o),rl.activate(o.id),n.info(`[context-compression] registered context engine: ${o.id}`)}function yp(n,e,t){vw(e,t),n.register({point:"context.before_compact",priority:50,label:"context-compression-bridge",handler:(o,r)=>{let s=r.messageCount;return s&&s>0&&e.debug(`[context-compression] before_compact: ${s} messages entering compression`),{action:"continue"}}}),il=(o,r)=>{e.debug(`[context-compression] after_compact: removed ${o}, ${r} tokens remaining`),n.invoke("context.after_compact",{sessionId:"",turnId:"",removedCount:o,tokenCount:r}).catch(()=>{})}}var nl,sl,fw,fp,rl,il,al=N(()=>{"use strict";$n();mt();nl={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};sl=8e3,fw="deepseek-v4-flash";fp=new ho(200),rl=new yo;il=null});function bp(n,e,t){let o=t-e;return`[Budget] ${Math.round(n)}% used (${e.toLocaleString()} / ${t.toLocaleString()} tokens). ${o.toLocaleString()} tokens remaining. `+(n>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var kp=N(()=>{"use strict"});var vp={};fn(vp,{resolveToolEligibility:()=>Rw});function Tw(n,e){if(Sw.some(t=>t.test(n)))return!0;if(e)for(let t of e)try{if(new RegExp(t,"i").test(n))return!0}catch{}return!1}function ww(n,e){let t=n.function.name,o=n.meta,r=[];return e.blockedToolNames?.includes(t)?(r.push("policy_blocked"),{level:5,reasons:r}):o?.isReadOnly?(r.push("always_allowed"),{level:1,reasons:r}):o?.requiresApproval?(r.push("approval_required"),{level:4,reasons:r}):o?.isDangerous||Tw(t,e.dangerousPatterns)?(r.push("dangerous_tool"),{level:3,reasons:r}):{level:2,reasons:r}}function xw(n){switch(n){case 1:return"eligible";case 2:return"eligible";case 3:return"dangerous-notify";case 4:return"approval-required";case 5:return"blocked-by-policy"}}function Rw(n,e={}){let t=new Map,o=[],r=[],s=[];for(let i of n){let a=i.function.name,{level:l,reasons:c}=ww(i,e),d=xw(l),u={toolName:a,status:d,permissionLevel:l,approvalRequired:l===4,reasonCodes:c};t.set(a,u),l===5?r.push(u):(o.push(i),l===4&&s.push(u))}return{eligibleTools:o,blockedTools:r,approvalRequiredTools:s,eligibilityByName:t}}var Sw,Sp=N(()=>{"use strict";Sw=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});function Iw(n){let e=n.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function Cw(n){let e=n.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}function Ow(n){if(!Mw.has(n.toolName))return!1;let e=typeof n.message?.content=="string"?n.message.content.trim():"";return e.length>0&&e.length<200&&Ew.test(e)}function Tp(n,e){for(let t=n.length-1;t>=0;t--){let o=n[t];if(!o||o.role!=="tool")continue;let r=typeof o.content=="string"?o.content:"";if(r.startsWith("Error: "))return r.slice(7).trim()}}function Dw(n){return typeof n=="number"&&Number.isFinite(n)&&n>=1?Math.min(Math.round(n),100):Ii}function wp(n){let e=n.message.toLowerCase();return n.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function Lw(n){return n==="length"||n==="max_tokens"}function xp(n){let e=n.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(n.status===413||e.includes("too large")||e.includes("size"))}function Nw(n){let e=n.headers;if(!e)return null;let t=e["retry-after"]??e["Retry-After"];if(!t)return null;let o=parseInt(t,10);return!isNaN(o)&&o>0?o*1e3:null}function $w(n){if(n.status!==400)return null;let e=n.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let t=parseInt(e[1],10),o=parseInt(e[3],10);if(isNaN(t)||isNaN(o))return null;let r=o-t-1e3;return r>=3e3?r:null}function Uw(n){return n.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Rp(n,e,t,o){let{turnId:r,sessionId:s,messages:i,tools:a,model:l,apiKey:c,temperature:d=0,hooks:u,signal:p}=n,m={sessionId:s,turnId:r},h=n.maxTurns??0,f=n.querySource,{resolveToolEligibility:y}=await Promise.resolve().then(()=>(Sp(),vp)),b=y(a,n.toolEligibilityContext),k=b.eligibleTools;for(let j of b.blockedTools)yield{type:"tool_blocked",turnId:r,callId:"",name:j.toolName,reason:"blocked-by-policy"};if(!k.length){yield*jw(r,l,i,c,d,p,e,o);return}let x=Dw(n.maxRounds),I={contextWindowTokens:n.contextWindowTokens??Mi,responseBufferTokens:Oi,maxOutputTokens:n.maxOutputTokens??Di,abortSignal:p,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},P=new Set,O=0,$=k,W,S={messages:[...i],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:Ia(I),reactiveCompactState:Da(),toolLoopState:Ar({maxRounds:x,replayMessages:[...i]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:_i(),currentModel:l,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Ku(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},ce=Math.max(h*5,200),de=0;for(;;){if(de++,de>ce){o.info(`hard iteration cap reached (${ce}), forcing completion`);let A=S.finalText||No(S.messages,o);yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}let{messages:j,maxOutputTokensRecoveryCount:ve,hasAttemptedReactiveCompact:ie,maxOutputTokensOverride:Ue,turnCount:ne,guardState:Q,reactiveCompactState:T,collapseStore:F}=S,{toolLoopState:B}=S;if(W){try{let A=await W;A&&(yield{type:"tool_use_summary",turnId:r,summary:A})}catch{}W=void 0}if(n.refreshTools&&ne>1){let A=n.refreshTools();A!==$&&($=A,o.debug(`tools refreshed: ${A.length} tools`))}if(Oa(Q,I)){o.info(`turn aborted by guard at turn ${ne}`),yield{type:"error",turnId:r,error:"Turn aborted",code:"ABORTED",usage:S.totalUsage};return}let Re=Ca(Q,I);if(Re.level==="blocking"){Re.reason==="prompt_too_long"&&Nn(T)&&(T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,o.info(`token budget blocking (${Re.reason}), reactive compact needed`),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"token budget pre-check"}),o.info(`token budget blocking (${Re.reason}), ending tool loop`);break}Re.level==="warning"&&o.info(`token budget warning: ${Re.usagePercent}% used, ${Re.remainingTokens} remaining`);let he;{let A=await Qu(j,S.contentReplacementState,s);he=A.messages,A.newlyReplacedCount>0&&(o.info(`tool-result-budget: persisted ${A.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:r,action:"tool_result_budget",detail:`${A.newlyReplacedCount} persisted`})}{let A=xi(he,S.snipRemovedIds);he=A.messages,A.removedCount>0&&(o.info(`snip: removed ${A.removedCount} messages, freed ~${A.tokensFreed} tokens`),yield{type:"recovery",turnId:r,action:"snip",detail:`${A.removedCount} messages`})}{let E=new on().compress(he,0);E.droppedCount>0&&(he=E.messages,o.info(`microcompact: cleared ${E.droppedCount} old tool results`))}if(he=Ai(he,F).messages,Q.promptTokens>0){let A=I.contextWindowTokens*.75,E=gp().getActive(),L;E?L=await E.compressAsync(he,A,{model:S.currentModel,sessionId:s}):L=hp(he,{budget:A,model:S.currentModel}),L.droppedCount>0&&(he=L.messages,o.info(`autocompact: ${L.strategy}, dropped ${L.droppedCount}`),yield{type:"recovery",turnId:r,action:"autocompact",detail:`${L.strategy}: ${L.droppedCount} dropped`},S.hasAttemptedReactiveCompact=!1,u?.invoke("context.after_compact",{...m,removedCount:L.droppedCount}).catch(()=>{}))}he=Uw(he);let Ut=ha({tools:$,toolChoice:n.toolChoice??"auto"}),g=Ar({maxRounds:x,replayMessages:he,lastStopReason:B.lastStopReason,options:{stopReason:B.lastStopReason}}),v=Ut.extraSystemPrompt?[{role:"system",content:Ut.extraSystemPrompt},...g.state.replayMessages]:g.state.replayMessages;B=g.state,g.recoveryActions.length>0&&o.debug(`tool loop recovery: ${g.recoveryActions.map(A=>A.detail??A.kind).join("; ")}`),o.debug(`turn ${ne}, messages: ${v.length}`),u?.invoke("turn.before_inference",{...m,model:S.currentModel}).catch(()=>{});let _=!1,C=[],R=new Map,U="stop",D,M=null,V=!1,ae=[],ee=[];try{for await(let A of e.stream({model:S.currentModel,messages:v,tools:Ut.tools,toolChoice:Ut.normalizedToolChoice??"auto",temperature:d,maxTokens:(Ue??Q.currentMaxOutputTokens)||void 0,streamRequired:n.streamRequired,previousResponseId:S.lastResponseId,reasoning:n.reasoning,promptCacheKey:n.promptCacheKey,promptCacheRetention:n.promptCacheRetention,serviceTier:n.serviceTier,openaiBuiltinTools:n.openaiBuiltinTools,maxToolCalls:n.maxToolCalls,parallelToolCalls:n.parallelToolCalls,textVerbosity:n.textVerbosity},c,p))switch(A.type){case"delta":C.push(A.text),_||(yield{type:"delta",turnId:r,text:A.text});break;case"tool_call_delta":_=!0,La(R,A);break;case"reasoning_delta":ae.push(A.text);break;case"reasoning_block_complete":A.signature&&ee.push({thinking:ae.join(""),signature:A.signature}),ae.length=0;break;case"usage":D={inputTokens:A.promptTokens,outputTokens:A.completionTokens,reasoningTokens:A.reasoningTokens,cacheRead:A.cacheReadTokens,cacheWrite:A.cacheCreationTokens};break;case"response_id":S.lastResponseId=A.id;break;case"annotations":yield{type:"annotations",turnId:r,annotations:A.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:r,message:`${A.toolType}: ${A.event}`};break;case"done":U=A.finishReason;break}if(_||u?.invoke("turn.after_inference",{...m,model:S.currentModel}).catch(()=>{}),n.postSamplingHooks&&n.postSamplingHooks.length>0){let A=S.currentModel;for(let E of n.postSamplingHooks)try{E({messages:[...he],model:A,sessionId:s})}catch{}}}catch(A){if(A instanceof So&&n.fallbackModel){o.info(`model fallback triggered: ${A.originalModel} \u2192 ${A.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`${A.originalModel} \u2192 ${A.fallbackModel}`},S={...S,currentModel:A.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let E=A instanceof Error?A.message:String(A),L=typeof A?.status=="number"?A.status:void 0;if(!L&&E&&(E.includes("ECONNRESET")||E.includes("EPIPE"))){let re=(S.consecutiveApiRetries??0)+1;if(re>Ln){o.info(`stale connection retry limit reached (${Ln}), aborting`),yield{type:"error",turnId:r,error:E,code:"RETRIES_EXHAUSTED",usage:S.totalUsage};return}o.info(`stale connection (${E.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:r,action:"stale_connection_retry",detail:E.slice(0,80)},S={...S,consecutiveApiRetries:re,transition:void 0};continue}let G=$w({status:L,message:E});if(G!==null){o.info(`max_tokens overflow: adjusting to ${G}`),Q.currentMaxOutputTokens=G,S={...S,maxOutputTokensOverride:G,transition:void 0};continue}if(xa(L)){S.consecutive529Errors++;let re=2,_e=n.fallbackModel&&S.currentModel!==n.fallbackModel;if(S.consecutive529Errors>re&&!_e&&!Ir()){o.info(`transient ${L} \xD7 ${S.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:r,error:`API unavailable after ${S.consecutive529Errors} consecutive ${L} errors`,code:"API_ERROR",usage:S.totalUsage};return}if(S.consecutive529Errors>=Wi&&n.fallbackModel&&S.currentModel!==n.fallbackModel){o.info(`529 \xD7 ${S.consecutive529Errors}: triggering fallback to ${n.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`529 \xD7 ${S.consecutive529Errors}`},S={...S,currentModel:n.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Ir()){let Z=Pr(S.consecutive529Errors);o.info(`persistent retry: waiting ${Z}ms (attempt ${S.consecutive529Errors})`);let ye=Z;for(;ye>0;){if(p?.aborted){yield{type:"error",turnId:r,error:"Aborted during retry wait",code:"ABORTED",usage:S.totalUsage};return}yield{type:"heartbeat",turnId:r,message:`Retrying in ${Math.ceil(ye/1e3)}s (${L})`};let it=Math.min(ye,Bi);await new Promise(fi=>setTimeout(fi,it)),ye-=it}S={...S,transition:void 0};continue}if(wa(f)){let ye=Nw({status:L,message:E})??Pr(S.consecutive529Errors);o.info(`transient ${L}: retry in ${ye}ms`),yield{type:"recovery",turnId:r,action:"retry",detail:`${L} retry in ${ye}ms`},await new Promise(it=>setTimeout(it,ye)),S={...S,transition:void 0};continue}o.info(`background source ${f}: not retrying ${L}`)}M={status:L,message:E}}if(M&&u?.invoke("turn.after_inference",{...m,model:S.currentModel,response:{error:M.message}}).catch(()=>{}),M)if(wp(M))V=!0,o.info(`withheld prompt_too_long error (status=${M.status})`);else if(xp(M))V=!0,o.info(`withheld media_size error (status=${M.status})`);else{let A=Ea({status:M.status??500,message:M.message},Q,I);if(A.action==="reactive_compact"&&Nn(T)&&(T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:r,action:"reactive_compact",detail:`API ${M.status??500}: ${M.message}`}),A.action==="retry"){let L=(S.consecutiveApiRetries??0)+1;if(L>Ln){o.info(`API retry limit reached (${Ln}), aborting`);let G=On(M.status,M.message);yield{type:"error",turnId:r,error:M.message,code:G,usage:S.totalUsage};return}yield{type:"recovery",turnId:r,action:"retry",detail:A.reason},S={...S,consecutiveApiRetries:L,transition:void 0};continue}let E=On(M.status,M.message);u?.invoke("stop.failure",{sessionId:s,reason:E,error:M.message}).catch(()=>{}),yield{type:"error",turnId:r,error:M.message,code:E,usage:S.totalUsage};return}D&&(S.totalUsage.inputTokens+=D.inputTokens,S.totalUsage.outputTokens+=D.outputTokens,D.reasoningTokens&&(S.totalUsage.reasoningTokens=(S.totalUsage.reasoningTokens??0)+D.reasoningTokens),D.cacheRead&&(S.totalUsage.cacheRead=(S.totalUsage.cacheRead??0)+D.cacheRead),D.cacheWrite&&(S.totalUsage.cacheWrite=(S.totalUsage.cacheWrite??0)+D.cacheWrite)),D?.inputTokens&&(Q.promptTokens=D.inputTokens);let oe=C.join("");oe&&(S.finalText=oe);let me=[...R.values()].map(A=>({id:A.id||`tc_${r}_${ne}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:A.name,arguments:A.arguments}}));if(me.length===0&&!_){if(V&&M&&wp(M)){if(S.transition?.reason!=="collapse_drain_retry"){let L=Pi(he,F);if(L.committed>0){o.info(`collapse drain: committed ${L.committed} stages`),yield{type:"recovery",turnId:r,action:"collapse_drain",detail:`${L.committed} stages committed`},S={...S,messages:L.messages,transition:{reason:"collapse_drain_retry",committed:L.committed}};continue}}if(Nn(T)){T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,o.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"withheld prompt_too_long"},S={...S,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld 413: recovery exhausted, surfacing error"),u?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:M.message}).catch(()=>{}),yield{type:"error",turnId:r,error:M.message,code:"PROMPT_TOO_LONG",usage:S.totalUsage};return}if(V&&M&&xp(M)){if(Nn(T)){T.attemptedThisTurn=!0,Q.hasAttemptedReactiveCompact=!0,o.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"media error strip-retry"},S={...S,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld media error: recovery exhausted"),u?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:M.message}).catch(()=>{}),yield{type:"error",turnId:r,error:M.message,code:"IMAGE_ERROR",usage:S.totalUsage};return}if(Lw(U)){Q.consecutiveTruncations+=1;let L=n.modelMaxOutputTokens??Li,G=Ma(Q,I,L);if(G.shouldEscalate&&Ue===void 0){Q.currentMaxOutputTokens=G.newMax,o.info(`max_output_tokens escalate: ${G.newMax} tokens`),yield{type:"recovery",turnId:r,action:"output_escalation",detail:`${G.newMax} tokens`},S={...S,maxOutputTokensOverride:$i,transition:{reason:"max_output_tokens_escalate"}};continue}if(ve<Ni){let re={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};o.info(`max_output_tokens recovery #${ve+1}`),yield{type:"recovery",turnId:r,action:"max_output_tokens_recovery",detail:`attempt ${ve+1}`},S={...S,messages:[...he,re],maxOutputTokensRecoveryCount:ve+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:ve+1}};continue}o.info("max_output_tokens recovery exhausted, completing with partial content")}else Q.consecutiveTruncations=0;if(B=_r(B,{replayMessages:j,lastStopReason:"completed"}),u){let L=await u.invoke("stop",{sessionId:s,reason:"completed"});if(L.action==="prevent"){o.info(`stop hook prevented continuation: ${L.reason??"no reason"}`),yield{type:"end",turnId:r,content:S.finalText,usage:S.totalUsage,model:S.currentModel};return}if(L.action==="abort"){let G=L.reason??"Stop hook requested continuation";o.info(`stop hook blocking: ${G}`);let re={role:"user",content:G},_e={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,_e,re],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(n.tokenBudget&&n.tokenBudget>0&&S.budgetContinuationCount<5){let L=S.totalUsage.inputTokens+S.totalUsage.outputTokens+(S.totalUsage.reasoningTokens??0),G=L/n.tokenBudget*100,re=L-S.lastBudgetGlobalTokens,_e=S.budgetContinuationCount>=Ui&&re<wr&&S.lastBudgetDeltaTokens<wr;if(_e&&o.info(`token budget early stop: diminishing returns at ${Math.round(G)}% (delta=${re})`),!_e&&G<90){let Z=S.budgetContinuationCount+1,ye={role:"user",content:bp(G,L,n.tokenBudget)};o.info(`token budget continuation #${Z}: ${Math.round(G)}% used`),yield{type:"recovery",turnId:r,action:"budget_continuation",detail:`${Math.round(G)}% used (#${Z})`};let it={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,it,ye],budgetContinuationCount:Z,lastBudgetDeltaTokens:re,lastBudgetGlobalTokens:L,transition:{reason:"token_budget_continuation"}};continue}}if(!S.stopHookActive){let L=i.find(Z=>Z.role==="user"),G=typeof L?.content=="string"?L.content:"",re=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(G),_e=P.has("write")||P.has("edit");if(re&&!_e){if(o.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),O>0){let it=[...j].reverse().find(fi=>fi.role==="tool");it&&typeof it.content=="string"&&(it.content+=`
|
|
44
44
|
|
|
45
45
|
\u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let Z={role:"user",content:O===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},ye={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,ye,Z],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!S.stopHookActive&&O>=3&&P.has("write")){let L=0;for(let G of j){let re=G,_e=re.is_error===!0||typeof re.content=="string"&&re.content.startsWith("Error:");re.role==="tool"&&typeof re.content=="string"&&!_e&&L++}if(L>=3){o.info("AP3 verification nudge: 3+ files created, injecting completeness check");let G={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},re={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,re,G],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(O>0){let L={ok:!0,toolCallCount:O,distinctToolCount:P.size,multiStep:O>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},G=vo(L,{tools:[...P],projectRoot:n.projectRoot});G&&(yield{type:"skill_instruction",turnId:r,instruction:G})}let E=S.finalText||No(j,o);yield{type:"end",turnId:r,content:E,usage:S.totalUsage,model:S.currentModel};return}let Ge=ee.length===0&&ae.length>0?ae.join(""):void 0;j.push(yi(me,S.finalText||void 0,ee.length>0?ee:void 0,Ge)),B=Ta(B,{replayMessages:j,pendingToolCallIds:me.map(A=>A.id),completedToolCallIds:B.completedToolCallIds,lastStopReason:"tool_calls"});let Me=S.identicalCallCounts,tn=[],ge=[],jt=!1;for(let A of me){let E=`${A.function.name}::${A.function.arguments}`,L=Me.get(E)??0;Me.set(E,L+1),L+1>Ei?(ge.push(A),jt||(jt=!0,o.info(`AP4 blocked: ${A.function.name} repeated ${L+1}x`))):tn.push(A)}let xt=[];for(let A of ge){let E=Me.get(`${A.function.name}::${A.function.arguments}`),L=Tp(j,A.function.name),G=L?`This exact tool call has been attempted ${E} times. Last error: ${L}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${E} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,re=nn(A.id,{ok:!1,error:G});j.push(re),xt.push(A.id),P.add(A.function.name),O++,yield{type:"tool_result",turnId:r,callId:A.id,name:A.function.name,ok:!1,error:G}}if(ge.length>0){let A=Tp(j,ge[0].function.name),E={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(A?`The error was: "${A}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};j.push(E)}let Ke=[],pi=[];for(let A of tn)(S.toolFailureCounts.get(A.function.name)??0)>=Tr?pi.push(A):Ke.push(A);if(pi.length>0){for(let E of pi){let L=S.toolFailureCounts.get(E.function.name),G=`Tool "${E.function.name}" has failed ${L} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,re=nn(E.id,{ok:!1,error:G});j.push(re),xt.push(E.id),P.add(E.function.name),O++,yield{type:"tool_result",turnId:r,callId:E.id,name:E.function.name,ok:!1,error:G},o.info(`AP4-variant blocked: ${E.function.name} failed ${L}x with different args`)}let A={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};j.push(A)}for(let A of Ke){let E=A.function.arguments,L=$.find(G=>G.function.name===A.function.name);if(L?.backfillObservableInput)try{let G=JSON.parse(A.function.arguments),re={...G};L.backfillObservableInput(re),Object.keys(re).some(Z=>!(Z in G))&&(E=JSON.stringify(re))}catch{}yield{type:"tool_call",turnId:r,callId:A.id,name:A.function.name,arguments:E}}let Lk=new Map(S.toolFailureCounts);try{let A=new Kr({toolInvoker:t,hooks:u,sessionId:s,turnId:r,log:o,signal:p,maxConcurrentTools:n?.maxConcurrentTools});for(let E of Ke)A.addTool(E);for await(let E of A.getRemainingResults()){E.blocked&&(yield{type:"tool_blocked",turnId:r,callId:E.callId,name:E.toolName,reason:E.blockReason??"blocked"}),j.push(E.message),xt.push(E.callId),P.add(E.toolName),O++;let L=E.ok&&Ow(E);if(!E.ok||L){let Z=(S.toolFailureCounts.get(E.toolName)??0)+1;S.toolFailureCounts.set(E.toolName,Z)}if(E.ok&&E.toolName==="read"){let _e=Ke.find(Z=>Z.id===E.callId);if(_e)try{let Z=JSON.parse(_e.function.arguments),ye=Z.file_path??Z.path??Z.filePath??"";if(ye){let it=S.fileReadCounts.get(ye)??0;S.fileReadCounts.set(ye,it+1)}}catch{}}let G=typeof E.message?.content=="string"?E.message.content:"",re=E.ok&&G?G.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:r,callId:E.callId,name:E.toolName,ok:E.ok,error:E.error,outputPreview:re},E.ok){let _e=me.find(Z=>Z.id===E.callId);if(_e){if(E.toolName==="plan_mode")try{let Z=JSON.parse(_e.function.arguments);Z.action==="exit"&&typeof Z.plan=="string"&&Z.plan.length>0&&(yield{type:"plan_update",turnId:r,slug:"approved-plan",content:Z.plan})}catch{}if(Pw.has(E.toolName))try{let Z=JSON.parse(_e.function.arguments),ye=typeof Z.file_path=="string"?Z.file_path:typeof Z.filePath=="string"?Z.filePath:typeof Z.path=="string"?Z.path:void 0;ye&&(yield{type:"artifact",turnId:r,artifactId:`artifact-${E.callId}`,artifactType:Iw(ye),title:ye.split(/[\\/]/).pop()||ye,filePath:ye,language:Cw(ye)})}catch{}}}}}catch(A){let E=A instanceof Error?A.message:String(A);yield{type:"error",turnId:r,error:E,code:"TOOL_EXECUTION_ERROR",usage:S.totalUsage};return}for(let[A,E]of S.toolFailureCounts)E>=Tr&&(Lk.get(A)??0)<Tr&&j.push({role:"user",content:`Tool "${A}" has now failed/returned empty results ${E} times with different arguments. The target clearly does not exist. Do NOT call "${A}" again. Report the result to the user immediately.`});if(B=_r(B,{replayMessages:j,completedToolCallIds:[...B.completedToolCallIds,...xt],lastStopReason:"tool_calls"}),n.generateToolUseSummary&&me.length>0){let A=me.map(E=>({name:E.function.name,arguments:E.function.arguments}));W=n.generateToolUseSummary(A).catch(()=>null)}let Nk=me.length>0&&me.every(A=>{let E=j.find(G=>G?.role==="tool"&&G?.tool_call_id===A.id);if(!E)return!0;let L=E.content;return typeof L=="string"&&L.startsWith("Error: ")}),mo=S.consecutiveFailedRounds;if(Nk){if(mo+=1,mo>=Ci){let A=S.finalText||No(j,o);o.info(`early exit: ${mo} consecutive failed rounds, returning ${S.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}}else mo=0;let $k=3,xd=[...S.fileReadCounts.entries()].filter(([,A])=>A>=$k);if(xd.length>0){let A=xd.map(([L])=>L).join(", ");o.info(`AP5: file read cycle detected on ${A}, injecting nudge`);let E={role:"user",content:`You are reading the same files repeatedly (${A}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};j.push(E),S.fileReadCounts.clear()}let mi=ne+1;if(h>0&&mi>h){if(o.info(`max turns reached (${h}), completing`),u){let E=await u.invoke("stop",{sessionId:s,reason:"max_turns"});if(E.action==="abort"){let L=E.reason??"Stop hook requested continuation after max_turns",G={role:"assistant",content:S.finalText,...ee.length>0&&{thinkingBlocks:[...ee]}};S={...S,messages:[...j,G,{role:"user",content:L}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let A=S.finalText||No(j,o);yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}if(mi>x){if(o.info(`tool loop budget exhausted (${x} rounds), returning`),O>0){let E={ok:!0,toolCallCount:O,distinctToolCount:P.size,multiStep:O>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},L=vo(E,{tools:[...P],projectRoot:n.projectRoot});L&&(yield{type:"skill_instruction",turnId:r,instruction:L})}let A=S.finalText||No(j,o);yield{type:"end",turnId:r,content:A,usage:S.totalUsage,model:S.currentModel};return}S={messages:j,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:mi,transition:{reason:"next_turn"},guardState:Q,reactiveCompactState:T,toolLoopState:B,consecutiveFailedRounds:mo,finalText:S.finalText,totalUsage:S.totalUsage,collapseStore:F,currentModel:S.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:S.stopHookActive,lastResponseId:S.lastResponseId,snipRemovedIds:S.snipRemovedIds,contentReplacementState:S.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:Me,toolFailureCounts:S.toolFailureCounts,fileReadCounts:S.fileReadCounts}}}function No(n,e){let t=[];for(let o=n.length-1;o>=0;o--){let r=n[o];if(r.role==="tool"&&typeof r.content=="string")t.unshift(r.content.slice(0,500));else if(r.role==="assistant"){if(typeof r.content=="string"&&r.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),r.content;break}else break}return t.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${t.length} tool result(s)`),t.join(`
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|