qlogicagent 2.10.12 → 2.10.13

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.
Files changed (66) hide show
  1. package/dist/agent.js +14 -14
  2. package/dist/cli.js +344 -363
  3. package/dist/index.js +343 -362
  4. package/dist/orchestration.js +6 -6
  5. package/dist/protocol.js +1 -1
  6. package/dist/types/agent/agent.d.ts +1 -1
  7. package/dist/types/agent/tool-loop.d.ts +1 -1
  8. package/dist/types/agent/types.d.ts +1 -1
  9. package/dist/types/cli/handlers/memory-handler.d.ts +1 -0
  10. package/dist/types/cli/handlers/turn-handler.d.ts +1 -1
  11. package/dist/types/cli/tool-bootstrap.d.ts +3 -3
  12. package/dist/types/index.d.ts +2 -2
  13. package/dist/types/llm/index.d.ts +1 -1
  14. package/dist/types/orchestration/tool-cascade.d.ts +2 -2
  15. package/dist/types/protocol/wire/gateway-rpc.d.ts +14 -0
  16. package/dist/types/runtime/execution/dream-agent.d.ts +1 -1
  17. package/dist/types/runtime/execution/forked-agent.d.ts +1 -1
  18. package/dist/types/runtime/hooks/context-compression.d.ts +1 -1
  19. package/dist/types/runtime/session/session-persistence.d.ts +1 -1
  20. package/package.json +3 -2
  21. package/dist/types/provider-core/adapters/aliyun-oss-file-upload-adapter.d.ts +0 -44
  22. package/dist/types/provider-core/adapters/gemini-file-upload-adapter.d.ts +0 -26
  23. package/dist/types/provider-core/adapters/hub-oss-file-upload-adapter.d.ts +0 -29
  24. package/dist/types/provider-core/adapters/index.d.ts +0 -10
  25. package/dist/types/provider-core/adapters/openai-file-upload-adapter.d.ts +0 -38
  26. package/dist/types/provider-core/adapters/volcengine-file-upload-adapter.d.ts +0 -24
  27. package/dist/types/provider-core/builtin-providers.d.ts +0 -8
  28. package/dist/types/provider-core/constants.d.ts +0 -1
  29. package/dist/types/provider-core/credentials.d.ts +0 -1
  30. package/dist/types/provider-core/debug-transport.d.ts +0 -12
  31. package/dist/types/provider-core/errors.d.ts +0 -11
  32. package/dist/types/provider-core/events.d.ts +0 -48
  33. package/dist/types/provider-core/file-upload-service.d.ts +0 -68
  34. package/dist/types/provider-core/gemini-schema-utils.d.ts +0 -17
  35. package/dist/types/provider-core/index.d.ts +0 -37
  36. package/dist/types/provider-core/llm-client.d.ts +0 -43
  37. package/dist/types/provider-core/media-client.d.ts +0 -42
  38. package/dist/types/provider-core/media-transport.d.ts +0 -176
  39. package/dist/types/provider-core/media.d.ts +0 -2
  40. package/dist/types/provider-core/model-detection.d.ts +0 -22
  41. package/dist/types/provider-core/paths.d.ts +0 -2
  42. package/dist/types/provider-core/provider-def.d.ts +0 -220
  43. package/dist/types/provider-core/provider-registry.d.ts +0 -50
  44. package/dist/types/provider-core/provider-tool-api.d.ts +0 -44
  45. package/dist/types/provider-core/provider-variant-resolver.d.ts +0 -35
  46. package/dist/types/provider-core/retry.d.ts +0 -37
  47. package/dist/types/provider-core/transport.d.ts +0 -281
  48. package/dist/types/provider-core/transports/anthropic-messages.d.ts +0 -65
  49. package/dist/types/provider-core/transports/gemini-cache-api.d.ts +0 -86
  50. package/dist/types/provider-core/transports/gemini-file-api.d.ts +0 -90
  51. package/dist/types/provider-core/transports/gemini-generatecontent.d.ts +0 -56
  52. package/dist/types/provider-core/transports/gemini-lyria-realtime.d.ts +0 -117
  53. package/dist/types/provider-core/transports/gemini-media.d.ts +0 -53
  54. package/dist/types/provider-core/transports/media-resolve.d.ts +0 -50
  55. package/dist/types/provider-core/transports/minimax-media.d.ts +0 -56
  56. package/dist/types/provider-core/transports/openai-chat.d.ts +0 -81
  57. package/dist/types/provider-core/transports/openai-media.d.ts +0 -24
  58. package/dist/types/provider-core/transports/openai-responses.d.ts +0 -63
  59. package/dist/types/provider-core/transports/qwen-media.d.ts +0 -59
  60. package/dist/types/provider-core/transports/realtime-transport.d.ts +0 -183
  61. package/dist/types/provider-core/transports/volcengine-grounding.d.ts +0 -58
  62. package/dist/types/provider-core/transports/volcengine-media.d.ts +0 -94
  63. package/dist/types/provider-core/transports/volcengine-responses.d.ts +0 -64
  64. package/dist/types/provider-core/transports/zhipu-media.d.ts +0 -82
  65. package/dist/types/provider-core/transports/zhipu-tool-api.d.ts +0 -35
  66. package/dist/types/provider-core/wire-types.d.ts +0 -51
package/dist/agent.js CHANGED
@@ -1,23 +1,23 @@
1
- var qo=Object.defineProperty;var en=(t,e)=>()=>(t&&(e=t(t=0)),e);var tn=(t,e)=>{for(var o in e)qo(t,o,{get:e[o],enumerable:!0})};var Bo={};tn(Bo,{resolveToolEligibility:()=>ms});function us(t,e){if(cs.some(o=>o.test(t)))return!0;if(e)for(let o of e)try{if(new RegExp(o,"i").test(t))return!0}catch{}return!1}function ds(t,e){let o=t.function.name,n=t.meta,i=[];return e.blockedToolNames?.includes(o)?(i.push("policy_blocked"),{level:5,reasons:i}):n?.isReadOnly?(i.push("always_allowed"),{level:1,reasons:i}):n?.requiresApproval?(i.push("approval_required"),{level:4,reasons:i}):n?.isDangerous||us(o,e.dangerousPatterns)?(i.push("dangerous_tool"),{level:3,reasons:i}):{level:2,reasons:i}}function ps(t){switch(t){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 ms(t,e={}){let o=new Map,n=[],i=[],s=[];for(let l of t){let r=l.function.name,{level:d,reasons:h}=ds(l,e),m=ps(d),g={toolName:r,status:m,permissionLevel:d,approvalRequired:d===4,reasonCodes:h};o.set(r,g),d===5?i.push(g):(n.push(l),d===4&&s.push(g))}return{eligibleTools:n,blockedTools:i,approvalRequiredTools:s,eligibilityByName:o}}var cs,Wo=en(()=>{"use strict";cs=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});function We(t,e,o,n){return{role:"assistant",content:e||null,tool_calls:t,...o&&o.length>0?{thinkingBlocks:o}:{},...n?{reasoning_content:n}:{}}}function j(t,e){let o=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:o,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}var nn=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,K={rateLimit:[/rate[_ ]limit|too many requests|429/,"model_cooldown","exceeded your current quota","resource has been exhausted","quota exceeded","resource_exhausted","usage limit",/\btpm\b/i,"tokens per minute","tokens per day"],overloaded:[/overloaded_error|"type"\s*:\s*"overloaded_error"/i,"overloaded",/service[_ ]unavailable.*(?:overload|capacity|high[_ ]demand)|(?:overload|capacity|high[_ ]demand).*service[_ ]unavailable/i,"high demand"],timeout:["timeout","timed out","service unavailable","deadline exceeded","context deadline exceeded","connection error","network error","network request failed","fetch failed","socket hang up",/\beconn(?:refused|reset|aborted)\b/i,/\benotfound\b/i,/\beai_again\b/i,/without sending (?:any )?chunks?/i,/\bstop reason:\s*(?:abort|error|network_error)\b/i,/\breason:\s*(?:abort|error|network_error)\b/i,/\bunhandled stop reason:\s*(?:abort|error|network_error)\b/i],billing:[/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment/i,"payment required","insufficient credits",/insufficient[_ ]quota/i,"credit balance","plans & billing","insufficient balance"],authPermanent:[/api[_ ]?key[_ ]?(?:revoked|invalid|deactivated|deleted)/i,"invalid_api_key","key has been disabled","key has been revoked","account has been deactivated",/could not (?:authenticate|validate).*(?:api[_ ]?key|credentials)/i,"permission_error","not allowed for this organization"],auth:[/invalid[_ ]?api[_ ]?key/,"incorrect api key","invalid token","authentication","re-authenticate","oauth token refresh failed","unauthorized","forbidden","access denied","insufficient permissions","insufficient permission",/missing scopes?:/i,"expired","token has expired",/\b401\b/,/\b403\b/,"no credentials found","no api key found"],format:["string should match pattern","tool_use.id","tool_use_id","messages.1.content.1.tool_use.id","invalid request format",/tool call id was.*must be/i]},sn=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,rn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,an=512,ln=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var cn=new Set([500,502,503,504,521,522,523,524,529]),un=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],dn=["upgrade your plan","upgrade plan","current plan","subscription"],pn=["daily","weekly","monthly"],mn=["try again","retry","temporary","cooldown"],fn=["usage limit","rate limit","organization usage"],gn=["organization","workspace"],hn=["billing period","exceeded","reached","exhausted"],yn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment required\b/i,bn=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function V(t,e){if(!t)return!1;let o=t.toLowerCase();return e.some(n=>n instanceof RegExp?n.test(o):o.includes(n))}function Tn(t){return V(t,K.format)}function $t(t){return V(t,K.rateLimit)}function _n(t){return V(t,K.timeout)}function xn(t){return nn.test(t)}function Ge(t){let e=t.toLowerCase();return e?t.length>an?rn.test(e):V(e,K.billing)?!0:sn.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function Dt(t){return V(t,K.authPermanent)}function kn(t){return V(t,K.auth)}function Nt(t){return V(t,K.overloaded)}function H(t,e){return e.some(o=>t.includes(o))}function wn(t){return H(t,un)||H(t,dn)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function Cn(t){let e=H(t,pn),o=t.includes("spend limit")||t.includes("spending limit"),n=H(t,gn);return H(t,mn)&&H(t,fn)||e&&(t.includes("usage limit")||o)||e&&t.includes("limit")&&t.includes("reset")||n&&t.includes("limit")&&(o||H(t,hn))}function vn(t){return t.trim().toLowerCase().replace(bn,"").trim()}function Ft(t){let e=vn(t);return!e||wn(e)?"billing":$t(e)||Cn(e)?"rate_limit":"billing"}function Sn(t){return yn.test(t)?Ft(t):null}function Bt(t){let e=t.match(ln);if(!e)return null;let o=Number(e[1]);return Number.isFinite(o)?{code:o,rest:(e[2]??"").trim()}:null}function Mn(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function Rn(t){let e=t.trim();if(!e)return!1;let o=Bt(e);return o?cn.has(o.code):!1}function Wt(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?Ft(e):"billing":t===429?"rate_limit":t===401||t===403?e&&Dt(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&Nt(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&Ge(e)?"billing":"format":null}function En(t){if(!t)return!1;let e=t.toLowerCase();return!!(e.includes("unknown model")||e.includes("model not found")||e.includes("model_not_found")||e.includes("not_found_error")||e.includes("does not exist")&&e.includes("model")||e.includes("invalid model")&&!e.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(t)||/\b404\b/.test(t)&&/not[-_ ]?found/i.test(t))}function An(t){if(!t)return!1;let e=t.toLowerCase();return e.includes("session not found")||e.includes("session does not exist")||e.includes("session expired")||e.includes("session invalid")||e.includes("conversation not found")||e.includes("conversation does not exist")||e.includes("conversation expired")||e.includes("conversation invalid")||e.includes("no such session")||e.includes("invalid session")||e.includes("session id not found")||e.includes("conversation id not found")}function Gt(t){if(An(t))return"session_expired";if(En(t))return"model_not_found";let e=Sn(t);return e||(xn(t)?Ge(t)?"billing":"rate_limit":$t(t)?"rate_limit":Nt(t)?"overloaded":Rn(t)?Bt(t.trim())?.code===529?"overloaded":"timeout":Mn(t)?"timeout":Tn(t)?"format":Ge(t)?"billing":_n(t)?"timeout":Dt(t)?"auth_permanent":kn(t)?"auth":null)}var In={timeout:"RETRYABLE_TRANSIENT",overloaded:"RETRYABLE_TRANSIENT",rate_limit:"RETRYABLE_DEGRADED",auth:"NON_RETRYABLE_AUTH",auth_permanent:"NON_RETRYABLE_AUTH",billing:"NON_RETRYABLE_QUOTA",format:"NON_RETRYABLE_CONTENT",model_not_found:"NON_RETRYABLE_CONTENT",session_expired:"NON_RETRYABLE_CONTENT",unknown:"RETRYABLE_TRANSIENT"},On=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function Y(t,e){let o=Wt(t,e)??(e?Gt(e):null);return o?In[o]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function je(t){return On.has(t)}var jt=4,oe=class{constructor(e){this.estimateTokens=e}estimateTokens;compress(e,o){let n=[],i=[];for(let m of e)m.role==="system"?n.push(m):i.push(m);let s=o;for(let m of n)s-=this.estimateTokens(m);let l;for(let m of i)if(m.role==="user"){l=m;break}if(l&&(s-=this.estimateTokens(l)),s<=0)return{messages:l?[...n,l]:n,droppedCount:i.length-(l?1:0),strategy:"sliding-window"};let r=[],d=0;for(let m=i.length-1;m>=0;m--){let g=i[m];if(g===l)continue;let M=this.estimateTokens(g);if(s-M<0&&d>=jt)break;if(s-M<0&&d<jt){r.unshift(g),d++;continue}s-=M,r.unshift(g),d++}let h=[...n];return l&&!r.includes(l)&&h.push(l),h.push(...r),{messages:h,droppedCount:i.length-(r.length+(l&&!r.includes(l)?1:0)),strategy:"sliding-window"}}};var ne=class{constructor(e=8e3){this.maxToolResultChars=e}maxToolResultChars;compress(e,o){let n=0;return{messages:e.map(s=>s.role!=="tool"||typeof s.content!="string"||s.content.length<=this.maxToolResultChars?s:(n++,{...s,content:Un(s.content,this.maxToolResultChars)})),droppedCount:n,strategy:"tool-result-trim"}}};function Un(t,e){if(t.length<=e)return t;let o=t.slice(0,e);if(t.trimStart().startsWith("{")||t.trimStart().startsWith("[")){let s=Math.max(o.lastIndexOf("},"),o.lastIndexOf("],"),o.lastIndexOf(`}
1
+ var Dn=Object.defineProperty;var Un=(t,e)=>()=>(t&&(e=t(t=0)),e);var Fn=(t,e)=>{for(var o in e)Dn(t,o,{get:e[o],enumerable:!0})};var _n={};Fn(_n,{resolveToolEligibility:()=>Er});function xr(t,e){if(vr.some(o=>o.test(t)))return!0;if(e)for(let o of e)try{if(new RegExp(o,"i").test(t))return!0}catch{}return!1}function Mr(t,e){let o=t.function.name,n=t.meta,r=[];return e.blockedToolNames?.includes(o)?(r.push("policy_blocked"),{level:5,reasons:r}):n?.isReadOnly?(r.push("always_allowed"),{level:1,reasons:r}):n?.requiresApproval?(r.push("approval_required"),{level:4,reasons:r}):n?.isDangerous||xr(o,e.dangerousPatterns)?(r.push("dangerous_tool"),{level:3,reasons:r}):{level:2,reasons:r}}function Ar(t){switch(t){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 Er(t,e={}){let o=new Map,n=[],r=[],s=[];for(let c of t){let i=c.function.name,{level:p,reasons:y}=Mr(c,e),g=Ar(p),f={toolName:i,status:g,permissionLevel:p,approvalRequired:p===4,reasonCodes:y};o.set(i,f),p===5?r.push(f):(n.push(c),p===4&&s.push(f))}return{eligibleTools:n,blockedTools:r,approvalRequiredTools:s,eligibilityByName:o}}var vr,Sn=Un(()=>{"use strict";vr=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});import{cleanSchemaForGemini as Jr}from"@xiaozhiclaw/provider-core/gemini-schema-utils";function Pe(t,e,o,n){return{role:"assistant",content:e||null,tool_calls:t,...o&&o.length>0?{thinkingBlocks:o}:{},...n?{reasoning_content:n}:{}}}function G(t,e){let o=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:o,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}var Bn=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,q={rateLimit:[/rate[_ ]limit|too many requests|429/,"model_cooldown","exceeded your current quota","resource has been exhausted","quota exceeded","resource_exhausted","usage limit",/\btpm\b/i,"tokens per minute","tokens per day"],overloaded:[/overloaded_error|"type"\s*:\s*"overloaded_error"/i,"overloaded",/service[_ ]unavailable.*(?:overload|capacity|high[_ ]demand)|(?:overload|capacity|high[_ ]demand).*service[_ ]unavailable/i,"high demand"],timeout:["timeout","timed out","service unavailable","deadline exceeded","context deadline exceeded","connection error","network error","network request failed","fetch failed","socket hang up",/\beconn(?:refused|reset|aborted)\b/i,/\benotfound\b/i,/\beai_again\b/i,/without sending (?:any )?chunks?/i,/\bstop reason:\s*(?:abort|error|network_error)\b/i,/\breason:\s*(?:abort|error|network_error)\b/i,/\bunhandled stop reason:\s*(?:abort|error|network_error)\b/i],billing:[/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment/i,"payment required","insufficient credits",/insufficient[_ ]quota/i,"credit balance","plans & billing","insufficient balance"],authPermanent:[/api[_ ]?key[_ ]?(?:revoked|invalid|deactivated|deleted)/i,"invalid_api_key","key has been disabled","key has been revoked","account has been deactivated",/could not (?:authenticate|validate).*(?:api[_ ]?key|credentials)/i,"permission_error","not allowed for this organization"],auth:[/invalid[_ ]?api[_ ]?key/,"incorrect api key","invalid token","authentication","re-authenticate","oauth token refresh failed","unauthorized","forbidden","access denied","insufficient permissions","insufficient permission",/missing scopes?:/i,"expired","token has expired",/\b401\b/,/\b403\b/,"no credentials found","no api key found"],format:["string should match pattern","tool_use.id","tool_use_id","messages.1.content.1.tool_use.id","invalid request format",/tool call id was.*must be/i]},$n=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,jn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,Kn=512,Gn=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var Hn=new Set([500,502,503,504,521,522,523,524,529]),zn=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],qn=["upgrade your plan","upgrade plan","current plan","subscription"],Wn=["daily","weekly","monthly"],Xn=["try again","retry","temporary","cooldown"],Vn=["usage limit","rate limit","organization usage"],Yn=["organization","workspace"],Jn=["billing period","exceeded","reached","exhausted"],Qn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment required\b/i,Zn=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function W(t,e){if(!t)return!1;let o=t.toLowerCase();return e.some(n=>n instanceof RegExp?n.test(o):o.includes(n))}function eo(t){return W(t,q.format)}function Rt(t){return W(t,q.rateLimit)}function to(t){return W(t,q.timeout)}function no(t){return Bn.test(t)}function Le(t){let e=t.toLowerCase();return e?t.length>Kn?jn.test(e):W(e,q.billing)?!0:$n.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function _t(t){return W(t,q.authPermanent)}function oo(t){return W(t,q.auth)}function St(t){return W(t,q.overloaded)}function z(t,e){return e.some(o=>t.includes(o))}function ro(t){return z(t,zn)||z(t,qn)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function so(t){let e=z(t,Wn),o=t.includes("spend limit")||t.includes("spending limit"),n=z(t,Yn);return z(t,Xn)&&z(t,Vn)||e&&(t.includes("usage limit")||o)||e&&t.includes("limit")&&t.includes("reset")||n&&t.includes("limit")&&(o||z(t,Jn))}function io(t){return t.trim().toLowerCase().replace(Zn,"").trim()}function vt(t){let e=io(t);return!e||ro(e)?"billing":Rt(e)||so(e)?"rate_limit":"billing"}function ao(t){return Qn.test(t)?vt(t):null}function xt(t){let e=t.match(Gn);if(!e)return null;let o=Number(e[1]);return Number.isFinite(o)?{code:o,rest:(e[2]??"").trim()}:null}function lo(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function co(t){let e=t.trim();if(!e)return!1;let o=xt(e);return o?Hn.has(o.code):!1}function Mt(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?vt(e):"billing":t===429?"rate_limit":t===401||t===403?e&&_t(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&St(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&Le(e)?"billing":"format":null}function uo(t){if(!t)return!1;let e=t.toLowerCase();return!!(e.includes("unknown model")||e.includes("model not found")||e.includes("model_not_found")||e.includes("not_found_error")||e.includes("does not exist")&&e.includes("model")||e.includes("invalid model")&&!e.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(t)||/\b404\b/.test(t)&&/not[-_ ]?found/i.test(t))}function po(t){if(!t)return!1;let e=t.toLowerCase();return e.includes("session not found")||e.includes("session does not exist")||e.includes("session expired")||e.includes("session invalid")||e.includes("conversation not found")||e.includes("conversation does not exist")||e.includes("conversation expired")||e.includes("conversation invalid")||e.includes("no such session")||e.includes("invalid session")||e.includes("session id not found")||e.includes("conversation id not found")}function At(t){if(po(t))return"session_expired";if(uo(t))return"model_not_found";let e=ao(t);return e||(no(t)?Le(t)?"billing":"rate_limit":Rt(t)?"rate_limit":St(t)?"overloaded":co(t)?xt(t.trim())?.code===529?"overloaded":"timeout":lo(t)?"timeout":eo(t)?"format":Le(t)?"billing":to(t)?"timeout":_t(t)?"auth_permanent":oo(t)?"auth":null)}var go={timeout:"RETRYABLE_TRANSIENT",overloaded:"RETRYABLE_TRANSIENT",rate_limit:"RETRYABLE_DEGRADED",auth:"NON_RETRYABLE_AUTH",auth_permanent:"NON_RETRYABLE_AUTH",billing:"NON_RETRYABLE_QUOTA",format:"NON_RETRYABLE_CONTENT",model_not_found:"NON_RETRYABLE_CONTENT",session_expired:"NON_RETRYABLE_CONTENT",unknown:"RETRYABLE_TRANSIENT"},mo=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function V(t,e){let o=Mt(t,e)??(e?At(e):null);return o?go[o]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function Oe(t){return mo.has(t)}var Et=4,ne=class{constructor(e){this.estimateTokens=e}estimateTokens;compress(e,o){let n=[],r=[];for(let g of e)g.role==="system"?n.push(g):r.push(g);let s=o;for(let g of n)s-=this.estimateTokens(g);let c;for(let g of r)if(g.role==="user"){c=g;break}if(c&&(s-=this.estimateTokens(c)),s<=0)return{messages:c?[...n,c]:n,droppedCount:r.length-(c?1:0),strategy:"sliding-window"};let i=[],p=0;for(let g=r.length-1;g>=0;g--){let f=r[g];if(f===c)continue;let A=this.estimateTokens(f);if(s-A<0&&p>=Et)break;if(s-A<0&&p<Et){i.unshift(f),p++;continue}s-=A,i.unshift(f),p++}let y=[...n];return c&&!i.includes(c)&&y.push(c),y.push(...i),{messages:y,droppedCount:r.length-(i.length+(c&&!i.includes(c)?1:0)),strategy:"sliding-window"}}};var oe=class{constructor(e=8e3){this.maxToolResultChars=e}maxToolResultChars;compress(e,o){let n=0;return{messages:e.map(s=>s.role!=="tool"||typeof s.content!="string"||s.content.length<=this.maxToolResultChars?s:(n++,{...s,content:fo(s.content,this.maxToolResultChars)})),droppedCount:n,strategy:"tool-result-trim"}}};function fo(t,e){if(t.length<=e)return t;let o=t.slice(0,e);if(t.trimStart().startsWith("{")||t.trimStart().startsWith("[")){let s=Math.max(o.lastIndexOf("},"),o.lastIndexOf("],"),o.lastIndexOf(`}
2
2
  `),o.lastIndexOf(`]
3
3
  `));if(s>e*.5)return o.slice(0,s+1)+`
4
- [...truncated: ${t.length-s-1} chars omitted]`}let i=o.lastIndexOf(`
5
- `);return i>e*.7?o.slice(0,i)+`
6
- [...truncated: ${t.length-i} chars omitted]`:o+`
7
- [...truncated: ${t.length-e} chars omitted]`}function ze(...t){return{compress(e,o){let n=e,i=0,s=[];for(let l of t){let r=l.compress(n,o);n=r.messages,i+=r.droppedCount,r.droppedCount>0&&s.push(r.strategy)}return{messages:n,droppedCount:i,strategy:s.length>0?s.join("+"):"none"}}}}var zt={modelContextWindow:128e3,targetUsageRatio:.75,minBudget:16e3,maxBudget:12e4};function He(t={}){let e={...zt,...t},o=Math.floor(e.modelContextWindow*e.targetUsageRatio);return Math.max(e.minBudget,Math.min(o,e.maxBudget))}function Ke(t,e){let o=t/e;return o<=.8?"none":o<=1?"trim-only":o<=1.5?"sliding-window":"llm-summarize"}var ie=class{events=[];maxEvents;constructor(e=100){this.maxEvents=e}record(e){this.events.push(e),this.events.length>this.maxEvents&&this.events.shift()}snapshot(){let e=this.events.length;if(e===0)return{totalCompressions:0,totalLlmCalls:0,totalCacheInvalidations:0,averageCompressionRatio:1,averageLatencyMs:0,totalTokensSaved:0,recentEvents:[]};let o=0,n=0,i=0,s=0,l=0;for(let r of this.events)o+=r.tokensBefore>0?r.tokensAfter/r.tokensBefore:1,n+=r.latencyMs,i+=Math.max(0,r.tokensBefore-r.tokensAfter),r.usedLlm&&s++,r.cacheInvalidated&&l++;return{totalCompressions:e,totalLlmCalls:s,totalCacheInvalidations:l,averageCompressionRatio:o/e,averageLatencyMs:n/e,totalTokensSaved:i,recentEvents:this.events.slice(-10)}}reset(){this.events.length=0}},se=class{engines=new Map;activeId;register(e){this.engines.set(e.id,e)}activate(e){return this.engines.has(e)?(this.activeId=e,!0):!1}getActive(){return this.activeId?this.engines.get(this.activeId):void 0}listEngines(){return Array.from(this.engines.values()).map(e=>({id:e.id,label:e.label,active:e.id===this.activeId}))}};function Ht(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}var Pn=new Set(["file_read","read","Read","bash","shell","Bash","grep","search","Grep","grep_search","glob","Glob","file_search","web_search","WebSearch","web_fetch","WebFetch","file_edit","edit","Edit","file_write","write","Write"]),X=class{constructor(e=20,o=Ht){this.preserveRecentCount=e;this.estimateTokens=o}preserveRecentCount;estimateTokens;compress(e,o){if(e.length<=this.preserveRecentCount)return{messages:e,droppedCount:0,strategy:"micro-compact"};let n=e.length-this.preserveRecentCount,i=0,s=0;return{messages:e.map((r,d)=>{if(d>=n||r.role!=="tool"||typeof r.content!="string"||!r.name||!Pn.has(r.name)||r.content.length<=200)return r;let h=this.estimateTokens(r);return s+=h,i++,{...r,content:`[result cleared \u2014 ${r.content.length} chars]`}}),droppedCount:i,strategy:"micro-compact",metrics:i>0?{tokensBefore:0,tokensAfter:0,compressionRatio:0,latencyMs:0,usedLlm:!1,cacheInvalidated:!1}:void 0}}};function Ve(t,e,o=Ht){if(e.size===0)return{messages:t,tokensFreed:0,removedCount:0};let n=0,i=0,s=[];for(let r of t){let d=r.tool_call_id??"";if(d&&e.has(d)){n+=o(r),i++,e.delete(d);continue}s.push(r)}let l=i>0?{role:"system",content:`[${i} messages removed by snip]`}:void 0;return{messages:s,tokensFreed:n,removedCount:i,boundaryMessage:l}}function Xe(){return{stages:[]}}function Ye(t,e,o){let n=o?.thresholdMessages??40;if(t.filter(r=>r.role!=="system").length<=n)return{messages:t,stagedCount:0};let s=Kt(t,e),l=Ln(s,e,n);if(l.length===0)return{messages:s,stagedCount:0};for(let r of l)e.stages.push(r);return s=Kt(t,e),{messages:s,stagedCount:l.length}}function Je(t,e){let o=0;for(let n of e.stages)n.committed||(n.committed=!0,o++);return o===0?{messages:t,committed:0}:{messages:Vt(t,e),committed:o}}function Kt(t,e){return e.stages.filter(n=>n.committed).length===0?t:Vt(t,e)}function Vt(t,e){let o=e.stages.filter(i=>i.committed).sort((i,s)=>s.range[0]-i.range[0]),n=[...t];for(let i of o){let[s,l]=i.range;if(s>=n.length)continue;let r=Math.min(l,n.length),d={role:"system",content:i.summary};n.splice(s,r-s,d)}return n}function Ln(t,e,o){let n=Math.max(0,t.length-Math.floor(o/2)),i=[],s=new Set(e.stages.map(d=>`${d.range[0]}-${d.range[1]}`)),l=-1,r=0;for(let d=0;d<n;d++){let h=t[d];if(h.role==="tool"||h.role==="assistant"&&typeof h.content=="string"&&h.content==="")l<0&&(l=d),r++;else{if(r>=3){let g=`${l}-${l+r}`;s.has(g)||i.push({id:`collapse_${l}_${l+r}`,range:[l,l+r],summary:`[${r} tool results collapsed]`,committed:!1})}l=-1,r=0}}if(r>=3){let d=`${l}-${l+r}`;s.has(d)||i.push({id:`collapse_${l}_${l+r}`,range:[l,l+r],summary:`[${r} tool results collapsed]`,committed:!1})}return i}import{existsSync as qe,readFileSync as ho,writeFileSync as $n,readdirSync as yo,mkdirSync as Dn}from"node:fs";import{join as et,dirname as Nn}from"node:path";var Xt=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),Yt=3,Jt=2,_e=2,Qt=128e3,Zt=13e3,qt=16384,eo=65536,to=3,oo=65536,Qe=500,no=3,io=5e4,so=2e5,Ze=2e3,ro=3e4,ao=3,re=2;var lo=20;var co=3,uo=2,po=300*1e3,mo=3,fo=720*60*60*1e3;var Ws=300*1e3;var Gs=3600*1e3;var js=50*1024,zs=500*1024,Hs=500*1024*1024,Ks=50*1024*1024;var Vs=60*1024;var bo=0;var Fn="skill-patterns.json";function To(t){return et(t,".qlogicagent",Fn)}function Bn(t){let e=To(t);try{return JSON.parse(ho(e,"utf8"))}catch{return{version:1,patterns:{}}}}function go(t,e){let o=To(t);Dn(Nn(o),{recursive:!0}),$n(o,JSON.stringify(e,null,2),"utf8")}function Wn(t){let e=Date.now()-fo;for(let[o,n]of Object.entries(t.patterns))new Date(n.lastSeen).getTime()<e&&delete t.patterns[o]}function _o(t,e){if(e.length===0)return!1;let o=xe(e),n=Bn(t);Wn(n);let i=new Date().toISOString(),s=n.patterns[o];if(s||(s={signature:o,count:0,firstSeen:i,lastSeen:i,promoted:!1},n.patterns[o]=s),s.promoted)return go(t,n),!1;s.count++,s.lastSeen=i;let l=s.count>=mo;return l&&(s.promoted=!0),go(t,n),l}function xe(t){return[...t].sort().join("+")}function Gn(t,e){if(!qe(e))return null;let o=xe(t);try{let n=yo(e,{withFileTypes:!0});for(let i of n){if(!i.isDirectory())continue;let s=et(e,i.name,"SKILL.md");try{let r=ho(s,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(r){let d=r[1].split(`
8
- `).map(h=>h.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(xe(d)===o)return i.name}}catch{}}}catch{}return null}function jn(t){if(!qe(t))return 0;try{return yo(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&qe(et(t,e.name,"SKILL.md"))).length}catch{return 0}}function zn(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<co||t.distinctToolCount<uo||Date.now()-bo<po||e?.projectSkillsDir&&(jn(e.projectSkillsDir)>=lo||e.tools.length>0&&Gn(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!_o(e.projectRoot,e.tools))}function Hn(t){return t.existingSkillName?t.feedback==="negative":!1}function ke(t,e){return Hn(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:zn(t,e)?(bo=Date.now(),{type:"skill.create",suggestedName:e.suggestedName??`auto-skill-${e.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${e.tools.join(", ")}`,tools:e.tools,stepCount:t.toolCallCount}):null}function xo(t){return t.function&&typeof t.function=="object"&&typeof t.function.name=="string"?t.function.name.trim():typeof t.name=="string"?t.name.trim():""}function Kn(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Vn(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function Xn(t){if(!t.eligibility?.length)return[...t.tools];let e=Vn(t.eligibility);return t.tools.filter(o=>{let n=xo(o);if(!n)return!1;let i=e.get(n);return!i||Kn(i.status)})}function Yn(t){let e=[],o=t.compatibility??{},n=t.toolChoice;if(t.thinkingEnabled&&o.requireAutoWhenThinking){let i=typeof n=="object"&&n&&!Array.isArray(n)?String(n.type??""):n;i&&i!=="auto"&&i!=="none"&&(e.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),n="auto")}if(n==="required"&&o.allowRequiredToolChoice===!1){let i=o.requiredFallback??"auto";e.push(`tool_choice=required is not supported by this provider; downgraded to ${i}.`),n=i}if(n&&typeof n=="object"&&!Array.isArray(n)&&n.type==="function"&&o.allowNamedToolChoice===!1){let i=o.namedFallback??"required";e.push(`named tool_choice is not supported by this provider; downgraded to ${i}.`),n=i}return{normalizedToolChoice:n,warnings:e}}function tt(t){let e=Yn({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),o=e.normalizedToolChoice,n=[...e.warnings],i=Xn({tools:t.tools,eligibility:t.eligibility});if(!o||o==="auto")return{tools:i,normalizedToolChoice:o,warnings:n};if(o==="none")return{tools:[],normalizedToolChoice:"none",warnings:n};if(o==="required"){if(i.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:i,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:n}}if(typeof o=="object"&&!Array.isArray(o)&&o.type==="function"){let s=o.function??void 0,l=typeof s?.name=="string"?s.name.trim():"";if(!l)throw new Error("tool_choice.function.name is required");let r=i.filter(d=>xo(d)===l);if(r.length===0)throw new Error(`tool_choice requested unknown tool: ${l}`);return{tools:r,normalizedToolChoice:{type:"function",function:{name:l}},extraSystemPrompt:`You must call the ${l} tool before responding.`,warnings:n}}return{tools:i,normalizedToolChoice:o,warnings:n}}var Jn=["stop","aborted","timeout","cancelled","interrupted","error"],Qn=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function ko(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function Zn(t,e){return{...t,content:[...ko(t.content),...ko(e.content)]}}function qn(t){if(!t||typeof t!="object")return!1;if(t.function&&typeof t.function=="object"){let e=t.function.name;if(typeof e=="string"&&e.length>0)return!0}return typeof t.name=="string"&&t.name.length>0}function ei(t){return new Set((t??Jn).map(e=>e.trim().toLowerCase()))}function ti(t,e){return t?ei(e).has(t.trim().toLowerCase()):!1}function ot(t){if(!Array.isArray(t)||t.length===0)return[...t];let e=t.map(r=>{if(r.role==="assistant"&&Array.isArray(r.tool_calls)){let d=r.tool_calls.filter(h=>qn(h));return{...r,...d.length>0?{tool_calls:d}:{tool_calls:void 0}}}return{...r}}),o=new Set;for(let r of e)if(!(r.role!=="assistant"||!Array.isArray(r.tool_calls)))for(let d of r.tool_calls)typeof d.id=="string"&&d.id&&o.add(d.id);let n=e.filter(r=>r.role!=="tool"?!0:!!(r.tool_call_id&&o.has(r.tool_call_id))),i=new Set;for(let r of n)r.role==="tool"&&typeof r.tool_call_id=="string"&&r.tool_call_id&&i.add(r.tool_call_id);let s=[];for(let r of n){if(r.role==="assistant"&&Array.isArray(r.tool_calls)&&r.tool_calls.length>0){let d=r.tool_calls.filter(h=>typeof h.id=="string"&&i.has(h.id));if(d.length===0){let{tool_calls:h,...m}=r;m.content!=null&&m.content!==""&&s.push(m);continue}if(d.length<r.tool_calls.length){s.push({...r,tool_calls:d});continue}}s.push(r)}let l=[];for(let r of s){let d=l.length>0?l[l.length-1]:void 0;if(r.role==="user"&&d?.role==="user"){l[l.length-1]=Zn(d,r);continue}l.push(r)}return l}function nt(t,e){return ti(e?.stopReason,e?.forcedStopReasons)?t.map(o=>{if(o.role!=="assistant")return{...o};let n={...o};for(let i of Qn)delete n[i];return n}):[...t]}function it(t,e){let o=e?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",n=new Set;for(let s of t)s.role==="tool"&&typeof s.tool_call_id=="string"&&s.tool_call_id&&n.add(s.tool_call_id);let i=[];for(let s of t)if(i.push({...s}),!(s.role!=="assistant"||!Array.isArray(s.tool_calls)||s.tool_calls.length===0))for(let l of s.tool_calls)typeof l.id!="string"||!l.id||n.has(l.id)||(n.add(l.id),i.push({role:"tool",tool_call_id:l.id,content:o}));return i}function st(t,e){let o=ot(t),n=nt(o,e);return it(n,e)}function oi(t){let e=new Set,o=new Set;for(let n of t){if(n.role==="assistant"&&Array.isArray(n.tool_calls))for(let i of n.tool_calls)typeof i.id=="string"&&i.id&&e.add(i.id);n.role==="tool"&&typeof n.tool_call_id=="string"&&n.tool_call_id&&o.add(n.tool_call_id)}return[...e].filter(n=>!o.has(n))}function ni(t){let e=new Set;for(let o of t)o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&e.add(o.tool_call_id);return[...e]}function ii(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function rt(t,e){return{round:t.round+1,maxRounds:t.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??t.pendingToolCallIds],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function we(t,e){return{round:t.round,maxRounds:t.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Ce(t){let e=[],o=ot(t.replayMessages);o.length!==t.replayMessages.length&&e.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let n=nt(o,t.options);n.some((s,l)=>s!==o[l])&&e.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let i=it(n,t.options);return i.length>n.length&&e.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:ii({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:i,pendingToolCallIds:oi(i),completedToolCallIds:ni(i)}),recoveryActions:e}}var si=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function at(t){return t?si.has(t):!0}function lt(t){return t===429||t===529}function ve(t,e=500,o=32e3){let n=Math.min(e*Math.pow(2,t-1),o);return n+Math.floor(Math.random()*n*.25)}var sr={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Se(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ae=class extends Error{constructor(o,n){super(`Model fallback triggered: ${o} -> ${n}`);this.originalModel=o;this.fallbackModel=n;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function ct(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function ut(t,e){if(t.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let o=e.contextWindowTokens-e.responseBufferTokens-t.currentMaxOutputTokens,n=o>0?t.promptTokens/o*100:100;return t.promptTokens>=o?t.hasAttemptedReactiveCompact||!e.reactiveCompactEnabled?{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:n>=85?{level:"warning",usagePercent:n,remainingTokens:o-t.promptTokens}:{level:"ok"}}function dt(t,e,o){let n=t.message?.toLowerCase()??"",i=t.status??0;return i===413||n.includes("prompt_too_long")||n.includes("context_length_exceeded")?!e.hasAttemptedReactiveCompact&&o.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:i>=500&&i<600?{action:"retry",reason:`server_error_${i}`}:i===429?{action:"retry",reason:"rate_limited"}:i===401||i===403?{action:"abort",reason:"auth_error"}:i===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:n||"unknown_error"}}function pt(t,e,o){if(!e.outputEscalationEnabled)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};if(t.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};let n=Math.min(t.currentMaxOutputTokens*2,o);return n<=t.currentMaxOutputTokens?{shouldEscalate:!1,newMax:t.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:n}}function mt(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var ai={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function ft(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function J(t,e=ai){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}function gt(t,e){let o=t.get(e.index);o||(o={id:"",name:"",arguments:""},t.set(e.index,o)),e.id&&(o.id=e.id),e.name&&(o.name+=e.name),o.arguments+=e.arguments}import{writeFileSync as na,mkdirSync as ia}from"node:fs";import{join as ra}from"node:path";import{randomUUID as la}from"node:crypto";import{join as wo}from"node:path";import{homedir as fi,tmpdir as gi}from"node:os";function hi(){return process.env.QLOGICAGENT_HOME??wo(fi()||gi(),".qlogicagent")}function Co(){return process.env.QLOGICAGENT_DEBUG_LOG_DIR??wo(hi(),"debug-logs")}import{writeFileSync as ka,mkdirSync as wa}from"node:fs";import{join as va}from"node:path";import{randomUUID as Ma}from"node:crypto";import{writeFileSync as ma,mkdirSync as fa}from"node:fs";import{join as ha}from"node:path";import{randomUUID as ba}from"node:crypto";import{writeFileSync as Ua,mkdirSync as Pa}from"node:fs";import{join as $a}from"node:path";import{randomUUID as Na}from"node:crypto";var yt=[{id:"deepseek",name:"DeepSeek",transport:"anthropic-messages",baseUrl:"https://api.deepseek.com/anthropic",apiKeyEnvVars:["DEEPSEEK_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"deepseek-v4-flash",quirks:{useEffortInsteadOfBudget:!0,filterImageBlocks:!0,maxReasoningEffort:"max",supportsPrefixCompletion:!0,supportsThinkingParam:!0,disableThinkingByDefault:!0},models:[{id:"deepseek-v4-flash",name:"DeepSeek V4 Flash",contextWindow:1e6,maxOutput:384e3,toolCall:!0,reasoning:!0,vision:!1,costInput:.14,costOutput:.28,costCacheRead:.0028},{id:"deepseek-v4-pro",name:"DeepSeek V4 Pro",contextWindow:1e6,maxOutput:384e3,toolCall:!0,reasoning:!0,vision:!1,costInput:1.74,costOutput:3.48,costCacheRead:.0145}]},{id:"qwen",name:"Alibaba Qwen (DashScope)",transport:"anthropic-messages",baseUrl:"https://dashscope.aliyuncs.com/apps/anthropic",apiKeyEnvVars:["DASHSCOPE_API_KEY","QWEN_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"qwen3.6-plus",quirks:{supportsThinkingParam:!0,disableThinkingByDefault:!0},models:[{id:"qwen3.6-max-preview",name:"Qwen3.6 Max (Preview)",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:2,costOutput:8,costCacheRead:.2,costCacheWrite:2.5},{id:"qwen3.6-plus",name:"Qwen3.6 Plus",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:3,costCacheRead:.05,costCacheWrite:.625},{id:"qwen3.6-flash",name:"Qwen3.6 Flash",contextWindow:1e6,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.1,costOutput:.5,costCacheRead:.01,costCacheWrite:.125},{id:"qwq-plus",name:"QwQ Plus",contextWindow:131072,maxOutput:65536,toolCall:!0,reasoning:!0,reasoningRequired:!0,streamRequired:!0,vision:!1,costInput:.5,costOutput:3,costCacheRead:.05,costCacheWrite:.625},{id:"qwen-max",name:"Qwen Max",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:2,costOutput:6,costCacheRead:.2,costCacheWrite:2.5},{id:"qwen-plus",name:"Qwen Plus",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:.85,costCacheRead:.03,costCacheWrite:.375},{id:"qwen-flash",name:"Qwen Flash",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1},{id:"qwen-turbo",name:"Qwen Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!1},{id:"qwen-vl-max",name:"Qwen VL Max",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:3,costOutput:8.5},{id:"qwen3.5-omni-plus",name:"Qwen3.5 Omni Plus",contextWindow:131072,maxOutput:16384,toolCall:!1,reasoning:!1,streamRequired:!0,vision:!0},{id:"qwen3.5-omni-plus-realtime",name:"Qwen3.5 Omni Plus Realtime",contextWindow:131072,maxOutput:16384,toolCall:!1,reasoning:!1,streamRequired:!0,vision:!0,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"qwen-vl-ocr",name:"Qwen VL OCR",contextWindow:131072,maxOutput:4096,toolCall:!1,reasoning:!1,vision:!0,mediaType:"document_parsing",mediaCapabilities:{type:"document_parsing",supportedFormats:["jpg","jpeg","png","bmp","tiff","pdf"],maxFileSizeMB:10}},{id:"qwen3-tts-flash",name:"Qwen3 TTS Flash",contextWindow:32768,maxOutput:16384,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],maxCharacters:32768,formats:["mp3","wav"]}},{id:"cosyvoice-v2",name:"CosyVoice V2",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],maxCharacters:1e4,formats:["mp3","wav","pcm"]}},{id:"wan2.7-image-pro",name:"Wan 2.7 Image Pro",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","1280x720","720x1280","2048x2048","3840x2160"]}},{id:"wanx2.1-t2i-turbo",name:"Wan 2.1 Text-to-Image Turbo",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","720x1280","1280x720"]}},{id:"wan2.7-t2v-plus",name:"Wan 2.7 Text/Image-to-Video Plus",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:15,resolutions:["720P","1080P"]}},{id:"wanx2.1-t2v-turbo",name:"Wan 2.1 Text/Image-to-Video Turbo",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:5,resolutions:["480P","720P"]}},{id:"text-embedding-v4",name:"Text Embedding V4",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:1024,maxTokens:8192}},{id:"sensevoice-v1",name:"SenseVoice V1",contextWindow:0,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"stt",mediaCapabilities:{type:"stt",languages:["zh","en","ja","ko","yue"],formats:["wav","mp3","m4a","flac","aac"]}},{id:"wanx-background-generation-v2",name:"Wan Background Generation V2",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["inpainting"],sizes:["1024x1024","1280x720","720x1280"]}},{id:"qwen3-rerank",name:"Qwen3 Rerank",contextWindow:32768,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"rerank",mediaCapabilities:{type:"rerank",maxDocuments:100}}]},{id:"zhipu",name:"Zhipu GLM",group:"zhipu",transport:"anthropic-messages",baseUrl:"https://open.bigmodel.cn/api/anthropic",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"glm-5.1",quirks:{filterThinkingBlocks:!0},models:[{id:"glm-5.1",name:"GLM-5.1",contextWindow:2e5,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:6,costOutput:24,costCacheRead:1.3},{id:"glm-5",name:"GLM-5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-5-turbo",name:"GLM-5 Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1,costCacheRead:.1},{id:"glm-4.7",name:"GLM-4.7",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.6",name:"GLM-4.6",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.5-air",name:"GLM-4.5 Air",contextWindow:131072,maxOutput:98304,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1.5,costCacheRead:.1},{id:"glm-4-long",name:"GLM-4 Long",contextWindow:1e6,maxOutput:4096,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.1},{id:"glm-4.7-flash",name:"GLM-4.7 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-4.5-flash",name:"GLM-4.5 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-5v-turbo",name:"GLM-5V Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:1},{id:"glm-4.6v",name:"GLM-4.6V",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:3.2},{id:"glm-4.6v-flash",name:"GLM-4.6V Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:0,costOutput:0},{id:"cogview-4-250304",name:"CogView-4",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","768x1344","864x1152","1344x768","1152x864","1440x720","720x1440"]}},{id:"cogview-3-flash",name:"CogView-3 Flash (Free)",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024","768x1344","864x1152","1344x768","1152x864","1440x720","720x1440"]}},{id:"glm-image",name:"GLM-Image",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1280x1280","1568x1056","1056x1568","1472x1088","1088x1472","1728x960","960x1728"]}},{id:"cogvideox-3",name:"CogVideoX-3",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["1080p"]}},{id:"cogvideox-flash",name:"CogVideoX Flash (Free)",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:6}},{id:"glm-tts",name:"GLM-TTS",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech"],voices:["tongtong","chuichui","xiaochen","jam","kazi","douji","luodo"],maxCharacters:1024,formats:["wav","pcm"]}},{id:"glm-tts-clone",name:"GLM-TTS Clone",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"voice_clone",mediaCapabilities:{type:"voice_clone",maxSampleDurationSeconds:30,maxSampleSizeMB:10,formats:["wav","mp3"]}},{id:"glm-asr-2512",name:"GLM-ASR-2512",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"stt",mediaCapabilities:{type:"stt",languages:["zh","en"],maxDurationSeconds:30,formats:["wav","mp3"]}},{id:"glm-4-voice",name:"GLM-4-Voice",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"glm-realtime-flash",name:"GLM Realtime Flash",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!0,mediaType:"realtime_video",mediaCapabilities:{type:"realtime_video",modalities:["text","audio","video"],vad:!0,toolCalling:!1}},{id:"glm-realtime-air",name:"GLM Realtime Air",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!0,mediaType:"realtime_video",mediaCapabilities:{type:"realtime_video",modalities:["text","audio","video"],vad:!0,toolCalling:!1}},{id:"embedding-3",name:"Embedding-3",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:2048,maxTokens:3072}},{id:"embedding-2",name:"Embedding-2",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:1024,maxTokens:512}},{id:"rerank",name:"GLM Rerank",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"rerank",mediaCapabilities:{type:"rerank",maxDocuments:128,maxQueryLength:4096,maxDocumentLength:4096}},{id:"glm-ocr",name:"GLM-OCR",contextWindow:0,maxOutput:0,toolCall:!1,reasoning:!1,vision:!1,mediaType:"document_parsing",mediaCapabilities:{type:"document_parsing",supportedFormats:["pdf","jpg","png"],maxPageCount:100,maxFileSizeMB:50}}]},{id:"zhipu-openai",name:"Zhipu GLM OpenAI",group:"zhipu",transport:"openai-chat",baseUrl:"https://open.bigmodel.cn/api/paas/v4",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"glm-5.1",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,supportsToolStream:!0,builtinWebSearch:!0,builtinCodeInterpreter:!0},models:[{id:"glm-5.1",name:"GLM-5.1",contextWindow:2e5,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:6,costOutput:24,costCacheRead:1.3},{id:"glm-5",name:"GLM-5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-5-turbo",name:"GLM-5 Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1,costCacheRead:.1},{id:"glm-4.7",name:"GLM-4.7",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.6",name:"GLM-4.6",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:1,costOutput:3.2,costCacheRead:.2},{id:"glm-4.5-air",name:"GLM-4.5 Air",contextWindow:131072,maxOutput:98304,toolCall:!0,reasoning:!0,vision:!1,costInput:.5,costOutput:1.5,costCacheRead:.1},{id:"glm-4-long",name:"GLM-4 Long",contextWindow:1e6,maxOutput:4096,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.1},{id:"glm-4.7-flash",name:"GLM-4.7 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-4.5-flash",name:"GLM-4.5 Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:0,costOutput:0},{id:"glm-5v-turbo",name:"GLM-5V Turbo",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:1},{id:"glm-4.6v",name:"GLM-4.6V",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:3.2},{id:"glm-4.6v-flash",name:"GLM-4.6V Flash (Free)",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!1,vision:!0,costInput:0,costOutput:0}]},{id:"zhipu-coding",name:"Zhipu GLM Coding",group:"zhipu",transport:"openai-chat",baseUrl:"https://open.bigmodel.cn/api/coding/paas/v4",apiKeyEnvVars:["ZHIPU_API_KEY","GLM_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"codegeex-4",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,supportsToolStream:!0},models:[{id:"codegeex-4",name:"CodeGeeX-4",contextWindow:131072,maxOutput:16384,toolCall:!0,reasoning:!0,vision:!1,costInput:.1,costOutput:.1}]},{id:"minimax",name:"MiniMax",group:"minimax",transport:"anthropic-messages",baseUrl:"https://api.minimaxi.com/anthropic",apiKeyEnvVars:["MINIMAX_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"MiniMax-M2.7",omitZeroTemperature:!0,quirks:{filterImageBlocks:!0},models:[{id:"MiniMax-M2.7",name:"MiniMax M2.7",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2,costCacheRead:.06,costCacheWrite:.375},{id:"MiniMax-M2.7-highspeed",name:"MiniMax M2.7 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2,costCacheRead:.06,costCacheWrite:.375},{id:"MiniMax-M2.5",name:"MiniMax M2.5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6,costCacheRead:.03,costCacheWrite:.19},{id:"MiniMax-M2.5-highspeed",name:"MiniMax M2.5 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6,costCacheRead:.03,costCacheWrite:.19},{id:"MiniMax-M2.1",name:"MiniMax M2.1 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1-highspeed",name:"MiniMax M2.1 Highspeed (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2",name:"MiniMax M2 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.1,costOutput:.4},{id:"music-2.6",name:"MiniMax Music 2.6",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:300,formats:["mp3","wav"]}},{id:"music-cover",name:"MiniMax Music Cover",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"music",mediaCapabilities:{type:"music",operations:["cover"],maxDurationSeconds:300,formats:["mp3","wav"]}},{id:"MiniMax-Hailuo-2.3",name:"Hailuo 2.3",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["768P","1080P"]}},{id:"MiniMax-Hailuo-2.3-Fast",name:"Hailuo 2.3 Fast",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["768P","1080P"]}},{id:"MiniMax-Hailuo-02",name:"Hailuo 02",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:10,resolutions:["512P","768P","1080P"]}},{id:"image-01",name:"MiniMax Image 01",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["512x512","1024x1024","2048x2048"]}},{id:"image-01-live",name:"MiniMax Image 01 Live",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image"],sizes:["1024x1024"]}},{id:"speech-2.8-hd",name:"MiniMax Speech 2.8 HD",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],formats:["mp3","pcm","flac","wav","opus"]}},{id:"speech-2.8-turbo",name:"MiniMax Speech 2.8 Turbo",contextWindow:1e4,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech","voice_clone"],formats:["mp3","pcm","flac","wav","opus"]}},{id:"voice-clone",aliases:["minimax-voice-clone"],name:"MiniMax Voice Clone",contextWindow:0,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:0,costOutput:0,mediaType:"voice_clone",mediaCapabilities:{type:"voice_clone",maxSampleDurationSeconds:30,maxSampleSizeMB:20,formats:["mp3","wav","m4a"]}}]},{id:"minimax-openai",name:"MiniMax (OpenAI)",group:"minimax",transport:"openai-chat",baseUrl:"https://api.minimaxi.com/v1",apiKeyEnvVars:["MINIMAX_API_KEY"],authType:"bearer",isAggregator:!1,omitZeroTemperature:!0,defaultModel:"MiniMax-M2.7",quirks:{supportsReasoningSplit:!0},models:[{id:"MiniMax-M2.7",aliases:["minimax-m2.7"],name:"MiniMax M2.7",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2},{id:"MiniMax-M2.7-highspeed",name:"MiniMax M2.7 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.3,costOutput:1.2},{id:"MiniMax-M2.5",name:"MiniMax M2.5",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.5-highspeed",name:"MiniMax M2.5 Highspeed",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1",name:"MiniMax M2.1 (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6},{id:"MiniMax-M2.1-highspeed",name:"MiniMax M2.1 Highspeed (legacy)",contextWindow:204800,maxOutput:131072,toolCall:!0,reasoning:!1,vision:!1,costInput:.15,costOutput:.6}]},{id:"moonshot",name:"Moonshot (Kimi)",transport:"openai-chat",baseUrl:"https://api.moonshot.cn",apiKeyEnvVars:["MOONSHOT_API_KEY"],authType:"bearer",isAggregator:!1,omitZeroTemperature:!0,defaultModel:"kimi-k2.6",quirks:{supportsReasoningEffort:!0,supportsThinkingParam:!0,disableThinkingByDefault:!0,builtinWebSearch:!0},models:[{id:"kimi-k2.6",name:"Kimi K2.6",contextWindow:262144,maxOutput:262144,toolCall:!0,reasoning:!0,vision:!0,costInput:.95,costOutput:4,costCacheRead:.16},{id:"kimi-k2.5",name:"Kimi K2.5",contextWindow:262144,maxOutput:262144,toolCall:!0,reasoning:!0,vision:!0,costInput:.8,costOutput:4,costCacheRead:.2},{id:"moonshot-v1-128k",name:"Moonshot V1 128K",contextWindow:131072,maxOutput:8192,toolCall:!0,reasoning:!1,vision:!1,costInput:.84,costOutput:.84}]},{id:"volcengine",name:"Doubao / Volcengine",transport:"volcengine-responses",baseUrl:"https://ark.cn-beijing.volces.com/api",apiKeyEnvVars:["ARK_API_KEY","DOUBAO_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"doubao-seed-2-0-lite-260428",models:[{id:"doubao-seed-2-0-pro-260215",aliases:["doubao-seed-2-0-pro"],name:"Doubao Seed 2.0 Pro",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-lite-260428",aliases:["doubao-seed-2-0-lite"],name:"Doubao Seed 2.0 Lite",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-mini-260428",aliases:["doubao-seed-2-0-mini"],name:"Doubao Seed 2.0 Mini",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-2-0-code-preview-260215",aliases:["doubao-seed-2-0-code-preview"],name:"Doubao Seed 2.0 Code Preview",contextWindow:262144,maxOutput:131072,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-seed-1-8-251228",name:"Doubao Seed 1.8",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:0,costOutput:0},{id:"doubao-embedding-vision-251215",name:"Doubao Embedding Vision",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:2048,maxTokens:8192}},{id:"doubao-seedance-2-0-260128",aliases:["doubao-seedance-2-0"],name:"Doubao Seedance 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video","video2video","edit","merge","upscale"],maxDurationSeconds:15,resolutions:["480p","720p","1080p"],aspectRatios:["16:9","9:16","1:1"],fps:[24]}},{id:"doubao-seedance-2-0-fast-260128",aliases:["doubao-seedance-2-0-fast"],name:"Doubao Seedance 2.0 Fast",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video","video2video","edit","merge","upscale"],maxDurationSeconds:15,resolutions:["480p","720p"],aspectRatios:["16:9","9:16","1:1"],fps:[24]}},{id:"doubao-seedream-5-0-260128",aliases:["doubao-seedream-5-0"],name:"Doubao Seedream 5.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["2K"]}},{id:"doubao-seedream-4-5-251128",aliases:["doubao-seedream-4-5"],name:"Doubao Seedream 4.5",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["2K"]}},{id:"doubao-seed3d-2-0-260328",aliases:["doubao-seed3d-2-0"],name:"Doubao Seed3D 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["img2_3d"],outputFormats:["glb","obj","usd","usdz"]}},{id:"hyper3d-gen2-260112",aliases:["hyper3d-gen2"],name:"Hyper3D Gen2",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["text2_3d","img2_3d"],outputFormats:["glb","obj"]}},{id:"hitem3d-2-0-251223",aliases:["hitem3d-2-0"],name:"HiTem3D 2.0",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"3d",mediaCapabilities:{type:"3d",operations:["img2_3d"],outputFormats:["glb","obj","usd"]}}]},{id:"openai",name:"OpenAI",transport:"openai-responses",baseUrl:"https://api.openai.com",apiKeyEnvVars:["OPENAI_API_KEY"],authType:"bearer",isAggregator:!1,defaultModel:"gpt-5.5",quirks:{builtinWebSearch:!0,builtinCodeInterpreter:!0,builtinFileSearch:!0},models:[{id:"gpt-5.5",name:"GPT-5.5",contextWindow:105e4,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:30,costCacheRead:.5},{id:"gpt-5.4",name:"GPT-5.4",contextWindow:105e4,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:2.5,costOutput:15,costCacheRead:.25},{id:"gpt-5.4-mini",name:"GPT-5.4 Mini",contextWindow:4e5,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:.75,costOutput:4.5,costCacheRead:.075},{id:"gpt-5.4-nano",name:"GPT-5.4 Nano",contextWindow:4e5,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:.2,costOutput:1.25,costCacheRead:.02},{id:"gpt-image-2",name:"GPT Image 2",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img","inpainting"],sizes:["1024x1024","1536x1024","1024x1536","auto"],transparentBackground:!0}},{id:"gpt-realtime-2",name:"GPT Realtime 2",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!0,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}},{id:"gpt-realtime-translate",name:"GPT Realtime Translate",contextWindow:128e3,maxOutput:16e3,toolCall:!1,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!1}},{id:"gpt-realtime-1.5",name:"GPT Realtime 1.5",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}},{id:"gpt-realtime-mini",name:"GPT Realtime Mini",contextWindow:128e3,maxOutput:16e3,toolCall:!0,reasoning:!1,vision:!1,mediaType:"realtime_audio",mediaCapabilities:{type:"realtime_audio",voices:["alloy","ash","ballad","coral","echo","fable","onyx","nova","sage","shimmer"],modalities:["text","audio"],vad:!0,toolCalling:!0}}]},{id:"anthropic",name:"Anthropic",transport:"anthropic-messages",baseUrl:"https://api.anthropic.com",apiKeyEnvVars:["ANTHROPIC_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"claude-opus-4-7",quirks:{supportsDocumentVision:!0},models:[{id:"claude-opus-4-7",name:"Claude Opus 4.7",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5,costCacheWrite:6.25},{id:"claude-opus-4-6",name:"Claude Opus 4.6",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5,costCacheWrite:6.25},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6",contextWindow:1e6,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:3,costOutput:15,costCacheRead:.3,costCacheWrite:3.75},{id:"claude-sonnet-4-5",name:"Claude Sonnet 4.5",contextWindow:2e5,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:3,costOutput:15,costCacheRead:.3,costCacheWrite:3.75},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5",contextWindow:2e5,maxOutput:64e3,toolCall:!0,reasoning:!0,vision:!0,costInput:1,costOutput:5,costCacheRead:.1,costCacheWrite:1.25}]},{id:"google",name:"Google Gemini",transport:"gemini-generatecontent",baseUrl:"https://generativelanguage.googleapis.com/v1beta",apiKeyEnvVars:["GOOGLE_API_KEY","GEMINI_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"gemini-3-flash-preview",quirks:{builtinWebSearch:!0,builtinCodeInterpreter:!0,builtinUrlContext:!0,builtinMapsGrounding:!0,builtinFileSearch:!0,supportsDocumentVision:!0},models:[{id:"gemini-3.1-pro-preview",name:"Gemini 3.1 Pro",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,reasoningRequired:!0,vision:!0,costInput:2,costOutput:12},{id:"gemini-3-flash-preview",name:"Gemini 3 Flash",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.5,costOutput:3},{id:"gemini-3.1-flash-lite",name:"Gemini 3.1 Flash-Lite",contextWindow:1048576,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!0,costInput:.25,costOutput:1.5},{id:"gemini-3.1-flash-image-preview",name:"Gemini 3.1 Flash Image (Nano Banana 2)",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["1024x1024"]}},{id:"gemini-3-pro-image-preview",name:"Gemini 3 Pro Image (Nano Banana Pro)",contextWindow:4096,maxOutput:1,toolCall:!1,reasoning:!1,vision:!0,costInput:0,costOutput:0,mediaType:"image",mediaCapabilities:{type:"image",operations:["text2image","img2img"],sizes:["1024x1024"]}},{id:"veo-3.1-generate-preview",name:"Veo 3.1 Standard",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P","4K"]}},{id:"veo-3.1-fast-generate-preview",name:"Veo 3.1 Fast",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P","4K"]}},{id:"veo-3.1-lite-generate-preview",name:"Veo 3.1 Lite",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"video",mediaCapabilities:{type:"video",operations:["text2video","img2video"],maxDurationSeconds:8,resolutions:["720P","1080P"]}},{id:"lyria-3-pro-preview",name:"Lyria 3 Pro",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:300,formats:["mp3"]}},{id:"lyria-3-clip-preview",name:"Lyria 3 Clip",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music",mediaCapabilities:{type:"music",operations:["text2music"],maxDurationSeconds:30,formats:["mp3"]}},{id:"lyria-realtime-exp",name:"Lyria RealTime (Experimental)",contextWindow:2e3,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,mediaType:"music_realtime",mediaCapabilities:{type:"music",operations:["realtime"],formats:["wav"]}},{id:"gemini-3.1-flash-tts-preview",name:"Gemini 3.1 Flash TTS",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:1,costOutput:20,mediaType:"tts",mediaCapabilities:{type:"tts",operations:["text2speech"],maxCharacters:8e3,formats:["mp3","wav"]}},{id:"gemini-embedding-2",name:"Gemini Embedding 2 (Multimodal)",contextWindow:8192,maxOutput:1,toolCall:!1,reasoning:!1,vision:!1,costInput:.2,costOutput:0,mediaType:"embedding",mediaCapabilities:{type:"embedding",dimensions:3072,maxTokens:8192}}]},{id:"openrouter",name:"OpenRouter",transport:"openai-chat",baseUrl:"https://openrouter.ai/api",apiKeyEnvVars:["OPENROUTER_API_KEY"],authType:"bearer",isAggregator:!0,defaultModel:"anthropic/claude-opus-4.7",extraHeaders:{"HTTP-Referer":"https://claw.bot","X-Title":"XiaozhiClaw"},models:[{id:"anthropic/claude-opus-4.7",name:"Claude Opus 4.7 (via OpenRouter)",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5},{id:"anthropic/claude-opus-4.6",name:"Claude Opus 4.6 (via OpenRouter)",contextWindow:1e6,maxOutput:128e3,toolCall:!0,reasoning:!0,vision:!0,costInput:5,costOutput:25,costCacheRead:.5},{id:"deepseek/deepseek-v4-flash",name:"DeepSeek V4 Flash (via OpenRouter)",contextWindow:1048576,maxOutput:393216,toolCall:!0,reasoning:!0,vision:!1,costInput:.14,costOutput:.28,costCacheRead:.028}]},{id:"qwen-coding",name:"Alibaba Qwen (Coding Plan)",transport:"anthropic-messages",baseUrl:"https://coding.dashscope.aliyuncs.com/apps/anthropic",apiKeyEnvVars:["DASHSCOPE_API_KEY","QWEN_API_KEY"],authType:"x-api-key",isAggregator:!1,defaultModel:"qwen3-coder-plus",models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus (Coding Plan)",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!1},{id:"qwen3-coder-flash",name:"Qwen3 Coder Flash (Coding Plan)",contextWindow:262144,maxOutput:65536,toolCall:!0,reasoning:!0,vision:!1}]}];var ki={claude:"anthropic",gemini:"google",doubao:"volcengine"},le=class{builtins=new Map;overrides=new Map;constructor(){for(let e of yt)this.builtins.set(e.id,e)}applyOverride(e,o){this.overrides.set(e,{...this.overrides.get(e),...o})}getProvider(e){let o=ki[e]??e,n=this.builtins.get(o),i=this.overrides.get(o);if(!(!n&&!i))return!n&&i?!i.id||!i.transport||!i.baseUrl?void 0:{id:i.id,name:i.name??i.id,transport:i.transport,baseUrl:i.baseUrl,apiKeyEnvVars:i.apiKeyEnvVars??[],authType:i.authType??"bearer",isAggregator:i.isAggregator??!1,defaultModel:i.defaultModel,models:i.models}:n&&!i?n:{...n,...i,models:i.models??n.models}}listProviders(){let e=new Map;for(let[o,n]of this.builtins)e.set(o,n);for(let[o]of this.overrides){let n=this.getProvider(o);n&&e.set(o,n)}return[...e.values()]}listModels(e){return this.getProvider(e)?.models??[]}getModelInfo(e,o){return this.listModels(e).find(n=>n.id===o)}resolveApiKey(e,o){if(o)return o;let n=this.getProvider(e);if(n)for(let i of n.apiKeyEnvVars){let s=process.env[i];if(s?.trim())return s.trim()}}};var ce=class{registry;constructor(e){this.registry=e}resolve(e){let o=e.publicModel.trim();if(!o)return[];let n=e.userPreference?.providerIds?new Set(e.userPreference.providerIds):void 0,i=wi(e.requestedProtocol),s=e.capabilities??[],l=[];for(let r of this.registry.listProviders())if(!(n&&!n.has(r.id))&&!(i&&r.transport!==i))for(let d of this.registry.listModels(r.id)){let h=Ci(d,o);if(!h)continue;let m=Mi(r,d);if(s.some(x=>!m.includes(x)))continue;let g=vi(r,d),M=r.billingChannelKind??Si(g),T=Ei({matchKind:h,requestedTransport:i,requiredCapabilities:s,preferProviderId:e.userPreference?.preferProviderId,preferVariantKind:e.userPreference?.preferVariantKind,purpose:e.purpose,provider:r,variantKind:g,capabilities:m}),v=Ri({matchKind:h,requestedTransport:i,requiredCapabilities:s,preferProviderId:e.userPreference?.preferProviderId,preferVariantKind:e.userPreference?.preferVariantKind,purpose:e.purpose,provider:r,variantKind:g,capabilities:m});l.push({provider:r.id,group:r.group??r.id,publicModel:o,nativeModelId:d.id,displayName:d.name,transport:r.transport,variantKind:g,billingChannelKind:M,capabilities:m,score:v,reasons:T,providerDef:r,modelInfo:d})}return l.sort((r,d)=>d.score!==r.score?d.score-r.score:r.group!==d.group?r.group.localeCompare(d.group):r.provider.localeCompare(d.provider))}resolveBest(e){return this.resolve(e)[0]}};function wi(t){if(t)return t==="openai"?"openai-chat":t==="anthropic"?"anthropic-messages":t}function Ci(t,e){return vo(t.id,e)?"exact":(t.aliases??[]).some(o=>vo(o,e))?"alias":void 0}function vo(t,e){return t.trim().toLowerCase()===e.trim().toLowerCase()}function vi(t,e){return t.variantKind?t.variantKind:e.mediaType==="realtime_audio"||e.mediaType==="realtime_video"?"realtime":e.mediaType?"media-plan":t.id.includes("coding")||e.id.toLowerCase().includes("coder")||e.id.toLowerCase().includes("codegeex")?"coding-plan":t.transport==="openai-chat"||t.transport==="openai-responses"||t.transport==="volcengine-responses"?"openai-compatible":t.transport==="anthropic-messages"?"anthropic-compatible":"standard"}function Si(t){return t==="coding-plan"||t==="media-plan"?"plan":"paygo"}function Mi(t,e){let o=new Set(t.capabilities??[]);return e.reasoning&&o.add("thinking"),e.vision&&o.add("vision"),e.mediaType&&o.add("media"),(e.mediaType==="realtime_audio"||e.mediaType==="realtime_video")&&o.add("realtime"),e.toolCall&&t.quirks?.supportsToolStream&&o.add("tool_stream"),t.quirks?.supportsReasoningSplit&&o.add("reasoning_split"),(t.quirks?.builtinWebSearch||t.quirks?.builtinCodeInterpreter||t.quirks?.builtinUrlContext)&&o.add("builtin_tools"),(t.id.includes("coding")||e.id.toLowerCase().includes("coder")||e.id.toLowerCase().includes("codegeex"))&&o.add("coding"),[...o].sort()}function Ri(t){let e=100;return e+=t.matchKind==="exact"?25:15,t.requestedTransport&&t.provider.transport===t.requestedTransport&&(e+=20),e+=t.requiredCapabilities.length*15,t.preferProviderId&&t.provider.id===t.preferProviderId&&(e+=50),t.preferVariantKind&&t.variantKind===t.preferVariantKind&&(e+=35),t.purpose==="textGeneration"&&!t.capabilities.includes("media")&&(e+=5),t.purpose==="imageGeneration"&&t.capabilities.includes("media")&&(e+=10),t.purpose==="videoGeneration"&&t.capabilities.includes("media")&&(e+=10),t.capabilities.includes("tool_stream")&&(e+=8),t.capabilities.includes("reasoning_split")&&(e+=8),t.variantKind==="coding-plan"&&(e+=t.provider.id.includes("coding")?12:5),e}function Ei(t){let e=[t.matchKind==="exact"?"model id matched":"public alias matched"];t.requestedTransport&&e.push(`protocol ${t.requestedTransport} matched`);for(let o of t.requiredCapabilities)e.push(`capability ${o} matched`);return t.preferProviderId&&t.provider.id===t.preferProviderId&&e.push("preferred provider matched"),t.preferVariantKind&&t.variantKind===t.preferVariantKind&&e.push("preferred variant matched"),e}var il=20*1024*1024;import{createHmac as Nl,randomUUID as Fl}from"node:crypto";import{join as cc}from"node:path";import{mkdirSync as dc,appendFileSync as pc}from"node:fs";var fc=Co();import{mkdir as $i,writeFile as Di}from"fs/promises";import{join as So}from"path";import{tmpdir as Ni}from"os";var Fi="tool-results",Mo="<persisted-output>",Bi="</persisted-output>";function Ro(){return{seenIds:new Set,replacements:new Map}}function Eo(t){return So(Ni(),"qlogicagent-sessions",t,Fi)}async function Wi(t){try{await $i(Eo(t),{recursive:!0})}catch{}}function Gi(t,e){let o=e.replace(/[^a-zA-Z0-9_-]/g,"_");return So(Eo(t),`${o}.txt`)}function ji(t,e){if(t.length<=e)return{preview:t,hasMore:!1};let n=t.slice(0,e).lastIndexOf(`
9
- `),i=n>e*.5?n:e;return{preview:t.slice(0,i),hasMore:!0}}function Ao(t){return t.includes(Mo)}async function Io(t,e,o){await Wi(o);let n=Gi(o,e);try{await Di(n,t,{encoding:"utf-8",flag:"wx"})}catch(l){if(l.code!=="EEXIST")return null}let{preview:i,hasMore:s}=ji(t,Ze);return{filepath:n,originalSize:t.length,preview:i,hasMore:s}}function Oo(t){let e=`${Mo}
4
+ [...truncated: ${t.length-s-1} chars omitted]`}let r=o.lastIndexOf(`
5
+ `);return r>e*.7?o.slice(0,r)+`
6
+ [...truncated: ${t.length-r} chars omitted]`:o+`
7
+ [...truncated: ${t.length-e} chars omitted]`}function Ne(...t){return{compress(e,o){let n=e,r=0,s=[];for(let c of t){let i=c.compress(n,o);n=i.messages,r+=i.droppedCount,i.droppedCount>0&&s.push(i.strategy)}return{messages:n,droppedCount:r,strategy:s.length>0?s.join("+"):"none"}}}}var wt={modelContextWindow:128e3,targetUsageRatio:.75,minBudget:16e3,maxBudget:12e4};function De(t={}){let e={...wt,...t},o=Math.floor(e.modelContextWindow*e.targetUsageRatio);return Math.max(e.minBudget,Math.min(o,e.maxBudget))}function Ue(t,e){let o=t/e;return o<=.8?"none":o<=1?"trim-only":o<=1.5?"sliding-window":"llm-summarize"}var re=class{events=[];maxEvents;constructor(e=100){this.maxEvents=e}record(e){this.events.push(e),this.events.length>this.maxEvents&&this.events.shift()}snapshot(){let e=this.events.length;if(e===0)return{totalCompressions:0,totalLlmCalls:0,totalCacheInvalidations:0,averageCompressionRatio:1,averageLatencyMs:0,totalTokensSaved:0,recentEvents:[]};let o=0,n=0,r=0,s=0,c=0;for(let i of this.events)o+=i.tokensBefore>0?i.tokensAfter/i.tokensBefore:1,n+=i.latencyMs,r+=Math.max(0,i.tokensBefore-i.tokensAfter),i.usedLlm&&s++,i.cacheInvalidated&&c++;return{totalCompressions:e,totalLlmCalls:s,totalCacheInvalidations:c,averageCompressionRatio:o/e,averageLatencyMs:n/e,totalTokensSaved:r,recentEvents:this.events.slice(-10)}}reset(){this.events.length=0}},se=class{engines=new Map;activeId;register(e){this.engines.set(e.id,e)}activate(e){return this.engines.has(e)?(this.activeId=e,!0):!1}getActive(){return this.activeId?this.engines.get(this.activeId):void 0}listEngines(){return Array.from(this.engines.values()).map(e=>({id:e.id,label:e.label,active:e.id===this.activeId}))}};function It(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}var ho=new Set(["file_read","read","Read","bash","shell","Bash","grep","search","Grep","grep_search","glob","Glob","file_search","web_search","WebSearch","web_fetch","WebFetch","file_edit","edit","Edit","file_write","write","Write"]),X=class{constructor(e=20,o=It){this.preserveRecentCount=e;this.estimateTokens=o}preserveRecentCount;estimateTokens;compress(e,o){if(e.length<=this.preserveRecentCount)return{messages:e,droppedCount:0,strategy:"micro-compact"};let n=e.length-this.preserveRecentCount,r=0,s=0;return{messages:e.map((i,p)=>{if(p>=n||i.role!=="tool"||typeof i.content!="string"||!i.name||!ho.has(i.name)||i.content.length<=200)return i;let y=this.estimateTokens(i);return s+=y,r++,{...i,content:`[result cleared \u2014 ${i.content.length} chars]`}}),droppedCount:r,strategy:"micro-compact",metrics:r>0?{tokensBefore:0,tokensAfter:0,compressionRatio:0,latencyMs:0,usedLlm:!1,cacheInvalidated:!1}:void 0}}};function Fe(t,e,o=It){if(e.size===0)return{messages:t,tokensFreed:0,removedCount:0};let n=0,r=0,s=[];for(let i of t){let p=i.tool_call_id??"";if(p&&e.has(p)){n+=o(i),r++,e.delete(p);continue}s.push(i)}let c=r>0?{role:"system",content:`[${r} messages removed by snip]`}:void 0;return{messages:s,tokensFreed:n,removedCount:r,boundaryMessage:c}}function Be(){return{stages:[]}}function $e(t,e,o){let n=o?.thresholdMessages??40;if(t.filter(i=>i.role!=="system").length<=n)return{messages:t,stagedCount:0};let s=Pt(t,e),c=yo(s,e,n);if(c.length===0)return{messages:s,stagedCount:0};for(let i of c)e.stages.push(i);return s=Pt(t,e),{messages:s,stagedCount:c.length}}function je(t,e){let o=0;for(let n of e.stages)n.committed||(n.committed=!0,o++);return o===0?{messages:t,committed:0}:{messages:Lt(t,e),committed:o}}function Pt(t,e){return e.stages.filter(n=>n.committed).length===0?t:Lt(t,e)}function Lt(t,e){let o=e.stages.filter(r=>r.committed).sort((r,s)=>s.range[0]-r.range[0]),n=[...t];for(let r of o){let[s,c]=r.range;if(s>=n.length)continue;let i=Math.min(c,n.length),p={role:"system",content:r.summary};n.splice(s,i-s,p)}return n}function yo(t,e,o){let n=Math.max(0,t.length-Math.floor(o/2)),r=[],s=new Set(e.stages.map(p=>`${p.range[0]}-${p.range[1]}`)),c=-1,i=0;for(let p=0;p<n;p++){let y=t[p];if(y.role==="tool"||y.role==="assistant"&&typeof y.content=="string"&&y.content==="")c<0&&(c=p),i++;else{if(i>=3){let f=`${c}-${c+i}`;s.has(f)||r.push({id:`collapse_${c}_${c+i}`,range:[c,c+i],summary:`[${i} tool results collapsed]`,committed:!1})}c=-1,i=0}}if(i>=3){let p=`${c}-${c+i}`;s.has(p)||r.push({id:`collapse_${c}_${c+i}`,range:[c,c+i],summary:`[${i} tool results collapsed]`,committed:!1})}return r}import{existsSync as He,readFileSync as tn,writeFileSync as To,readdirSync as nn,mkdirSync as bo}from"node:fs";import{join as ze,dirname as Co}from"node:path";var Ot=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),Nt=3,Dt=2,Te=2,Ut=128e3,Ft=13e3,Bt=16384,$t=65536,jt=3,Kt=65536,Ke=500,Gt=3,Ht=5e4,zt=2e5,Ge=2e3,qt=3e4,Wt=3,ie=2;var Xt=20;var Vt=3,Yt=2,Jt=300*1e3,Qt=3,Zt=720*60*60*1e3;var rs=300*1e3;var ss=3600*1e3;var is=50*1024,as=500*1024,ls=500*1024*1024,cs=50*1024*1024;var us=60*1024;var on=0;var ko="skill-patterns.json";function rn(t){return ze(t,".qlogicagent",ko)}function Ro(t){let e=rn(t);try{return JSON.parse(tn(e,"utf8"))}catch{return{version:1,patterns:{}}}}function en(t,e){let o=rn(t);bo(Co(o),{recursive:!0}),To(o,JSON.stringify(e,null,2),"utf8")}function _o(t){let e=Date.now()-Zt;for(let[o,n]of Object.entries(t.patterns))new Date(n.lastSeen).getTime()<e&&delete t.patterns[o]}function sn(t,e){if(e.length===0)return!1;let o=be(e),n=Ro(t);_o(n);let r=new Date().toISOString(),s=n.patterns[o];if(s||(s={signature:o,count:0,firstSeen:r,lastSeen:r,promoted:!1},n.patterns[o]=s),s.promoted)return en(t,n),!1;s.count++,s.lastSeen=r;let c=s.count>=Qt;return c&&(s.promoted=!0),en(t,n),c}function be(t){return[...t].sort().join("+")}function So(t,e){if(!He(e))return null;let o=be(t);try{let n=nn(e,{withFileTypes:!0});for(let r of n){if(!r.isDirectory())continue;let s=ze(e,r.name,"SKILL.md");try{let i=tn(s,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(i){let p=i[1].split(`
8
+ `).map(y=>y.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(be(p)===o)return r.name}}catch{}}}catch{}return null}function vo(t){if(!He(t))return 0;try{return nn(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&He(ze(t,e.name,"SKILL.md"))).length}catch{return 0}}function xo(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<Vt||t.distinctToolCount<Yt||Date.now()-on<Jt||e?.projectSkillsDir&&(vo(e.projectSkillsDir)>=Xt||e.tools.length>0&&So(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!sn(e.projectRoot,e.tools))}function Mo(t){return t.existingSkillName?t.feedback==="negative":!1}function Ce(t,e){return Mo(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:xo(t,e)?(on=Date.now(),{type:"skill.create",suggestedName:e.suggestedName??`auto-skill-${e.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${e.tools.join(", ")}`,tools:e.tools,stepCount:t.toolCallCount}):null}function an(t){return t.function&&typeof t.function=="object"&&typeof t.function.name=="string"?t.function.name.trim():typeof t.name=="string"?t.name.trim():""}function Ao(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Eo(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function wo(t){if(!t.eligibility?.length)return[...t.tools];let e=Eo(t.eligibility);return t.tools.filter(o=>{let n=an(o);if(!n)return!1;let r=e.get(n);return!r||Ao(r.status)})}function Io(t){let e=[],o=t.compatibility??{},n=t.toolChoice;if(t.thinkingEnabled&&o.requireAutoWhenThinking){let r=typeof n=="object"&&n&&!Array.isArray(n)?String(n.type??""):n;r&&r!=="auto"&&r!=="none"&&(e.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),n="auto")}if(n==="required"&&o.allowRequiredToolChoice===!1){let r=o.requiredFallback??"auto";e.push(`tool_choice=required is not supported by this provider; downgraded to ${r}.`),n=r}if(n&&typeof n=="object"&&!Array.isArray(n)&&n.type==="function"&&o.allowNamedToolChoice===!1){let r=o.namedFallback??"required";e.push(`named tool_choice is not supported by this provider; downgraded to ${r}.`),n=r}return{normalizedToolChoice:n,warnings:e}}function qe(t){let e=Io({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),o=e.normalizedToolChoice,n=[...e.warnings],r=wo({tools:t.tools,eligibility:t.eligibility});if(!o||o==="auto")return{tools:r,normalizedToolChoice:o,warnings:n};if(o==="none")return{tools:[],normalizedToolChoice:"none",warnings:n};if(o==="required"){if(r.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:r,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:n}}if(typeof o=="object"&&!Array.isArray(o)&&o.type==="function"){let s=o.function??void 0,c=typeof s?.name=="string"?s.name.trim():"";if(!c)throw new Error("tool_choice.function.name is required");let i=r.filter(p=>an(p)===c);if(i.length===0)throw new Error(`tool_choice requested unknown tool: ${c}`);return{tools:i,normalizedToolChoice:{type:"function",function:{name:c}},extraSystemPrompt:`You must call the ${c} tool before responding.`,warnings:n}}return{tools:r,normalizedToolChoice:o,warnings:n}}var Po=["stop","aborted","timeout","cancelled","interrupted","error"],Lo=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function ln(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function Oo(t,e){return{...t,content:[...ln(t.content),...ln(e.content)]}}function No(t){if(!t||typeof t!="object")return!1;if(t.function&&typeof t.function=="object"){let e=t.function.name;if(typeof e=="string"&&e.length>0)return!0}return typeof t.name=="string"&&t.name.length>0}function Do(t){return new Set((t??Po).map(e=>e.trim().toLowerCase()))}function Uo(t,e){return t?Do(e).has(t.trim().toLowerCase()):!1}function We(t){if(!Array.isArray(t)||t.length===0)return[...t];let e=t.map(i=>{if(i.role==="assistant"&&Array.isArray(i.tool_calls)){let p=i.tool_calls.filter(y=>No(y));return{...i,...p.length>0?{tool_calls:p}:{tool_calls:void 0}}}return{...i}}),o=new Set;for(let i of e)if(!(i.role!=="assistant"||!Array.isArray(i.tool_calls)))for(let p of i.tool_calls)typeof p.id=="string"&&p.id&&o.add(p.id);let n=e.filter(i=>i.role!=="tool"?!0:!!(i.tool_call_id&&o.has(i.tool_call_id))),r=new Set;for(let i of n)i.role==="tool"&&typeof i.tool_call_id=="string"&&i.tool_call_id&&r.add(i.tool_call_id);let s=[];for(let i of n){if(i.role==="assistant"&&Array.isArray(i.tool_calls)&&i.tool_calls.length>0){let p=i.tool_calls.filter(y=>typeof y.id=="string"&&r.has(y.id));if(p.length===0){let{tool_calls:y,...g}=i;g.content!=null&&g.content!==""&&s.push(g);continue}if(p.length<i.tool_calls.length){s.push({...i,tool_calls:p});continue}}s.push(i)}let c=[];for(let i of s){let p=c.length>0?c[c.length-1]:void 0;if(i.role==="user"&&p?.role==="user"){c[c.length-1]=Oo(p,i);continue}c.push(i)}return c}function Xe(t,e){return Uo(e?.stopReason,e?.forcedStopReasons)?t.map(o=>{if(o.role!=="assistant")return{...o};let n={...o};for(let r of Lo)delete n[r];return n}):[...t]}function Ve(t,e){let o=e?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",n=new Set;for(let s of t)s.role==="tool"&&typeof s.tool_call_id=="string"&&s.tool_call_id&&n.add(s.tool_call_id);let r=[];for(let s of t)if(r.push({...s}),!(s.role!=="assistant"||!Array.isArray(s.tool_calls)||s.tool_calls.length===0))for(let c of s.tool_calls)typeof c.id!="string"||!c.id||n.has(c.id)||(n.add(c.id),r.push({role:"tool",tool_call_id:c.id,content:o}));return r}function Ye(t,e){let o=We(t),n=Xe(o,e);return Ve(n,e)}function Fo(t){let e=new Set,o=new Set;for(let n of t){if(n.role==="assistant"&&Array.isArray(n.tool_calls))for(let r of n.tool_calls)typeof r.id=="string"&&r.id&&e.add(r.id);n.role==="tool"&&typeof n.tool_call_id=="string"&&n.tool_call_id&&o.add(n.tool_call_id)}return[...e].filter(n=>!o.has(n))}function Bo(t){let e=new Set;for(let o of t)o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&e.add(o.tool_call_id);return[...e]}function $o(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function Je(t,e){return{round:t.round+1,maxRounds:t.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??t.pendingToolCallIds],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function ke(t,e){return{round:t.round,maxRounds:t.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Re(t){let e=[],o=We(t.replayMessages);o.length!==t.replayMessages.length&&e.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let n=Xe(o,t.options);n.some((s,c)=>s!==o[c])&&e.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let r=Ve(n,t.options);return r.length>n.length&&e.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:$o({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:r,pendingToolCallIds:Fo(r),completedToolCallIds:Bo(r)}),recoveryActions:e}}var jo=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function Qe(t){return t?jo.has(t):!0}function Ze(t){return t===429||t===529}function _e(t,e=500,o=32e3){let n=Math.min(e*Math.pow(2,t-1),o);return n+Math.floor(Math.random()*n*.25)}var Rs={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Se(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ae=class extends Error{constructor(o,n){super(`Model fallback triggered: ${o} -> ${n}`);this.originalModel=o;this.fallbackModel=n;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function et(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function tt(t,e){if(t.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let o=e.contextWindowTokens-e.responseBufferTokens-t.currentMaxOutputTokens,n=o>0?t.promptTokens/o*100:100;return t.promptTokens>=o?t.hasAttemptedReactiveCompact||!e.reactiveCompactEnabled?{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:n>=85?{level:"warning",usagePercent:n,remainingTokens:o-t.promptTokens}:{level:"ok"}}function nt(t,e,o){let n=t.message?.toLowerCase()??"",r=t.status??0;return r===413||n.includes("prompt_too_long")||n.includes("context_length_exceeded")?!e.hasAttemptedReactiveCompact&&o.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:r>=500&&r<600?{action:"retry",reason:`server_error_${r}`}:r===429?{action:"retry",reason:"rate_limited"}:r===401||r===403?{action:"abort",reason:"auth_error"}:r===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:n||"unknown_error"}}function ot(t,e,o){if(!e.outputEscalationEnabled)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};if(t.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};let n=Math.min(t.currentMaxOutputTokens*2,o);return n<=t.currentMaxOutputTokens?{shouldEscalate:!1,newMax:t.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:n}}function rt(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var Go={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function st(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function Y(t,e=Go){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}import{accumulateToolCalls as Pr}from"@xiaozhiclaw/provider-core";import{mkdir as Yo,writeFile as Jo}from"fs/promises";import{join as cn}from"path";import{tmpdir as Qo}from"os";var Zo="tool-results",un="<persisted-output>",er="</persisted-output>";function dn(){return{seenIds:new Set,replacements:new Map}}function pn(t){return cn(Qo(),"qlogicagent-sessions",t,Zo)}async function tr(t){try{await Yo(pn(t),{recursive:!0})}catch{}}function nr(t,e){let o=e.replace(/[^a-zA-Z0-9_-]/g,"_");return cn(pn(t),`${o}.txt`)}function or(t,e){if(t.length<=e)return{preview:t,hasMore:!1};let n=t.slice(0,e).lastIndexOf(`
9
+ `),r=n>e*.5?n:e;return{preview:t.slice(0,r),hasMore:!0}}function gn(t){return t.includes(un)}async function mn(t,e,o){await tr(o);let n=nr(o,e);try{await Jo(n,t,{encoding:"utf-8",flag:"wx"})}catch(c){if(c.code!=="EEXIST")return null}let{preview:r,hasMore:s}=or(t,Ge);return{filepath:n,originalSize:t.length,preview:r,hasMore:s}}function fn(t){let e=`${un}
10
10
  `;return e+=`Output too large (${t.originalSize} chars). Full output saved to: ${t.filepath}
11
11
 
12
- `,e+=`Preview (first ${Ze} bytes):
12
+ `,e+=`Preview (first ${Ge} bytes):
13
13
  `,e+=t.preview,e+=t.hasMore?`
14
14
  ...
15
15
  `:`
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,m=this.getProviderBaseUrl(s),g=this.getProviderBaseUrl(h);return{provider:s,model:l,apiKey:d.apiKey,baseUrl:m??(n.provider===s?n.baseUrl:void 0)??g,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+=`
16
+ `,e+=er,e}async function hn(t,e,o,n=Ht){if(t.length<=n||gn(t))return t;let r=await mn(t,e,o);return r?fn(r):t.slice(0,n)+`
17
+ ...[truncated ${t.length-n} chars]`}function rr(t){let e=[],o=[];for(let n of t)n.role==="tool"&&typeof n.content=="string"&&n.tool_call_id?gn(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 sr(t,e){let o=[],n=[],r=[];for(let s of t){let c=e.replacements.get(s.toolCallId);c!==void 0?o.push({...s,replacement:c}):e.seenIds.has(s.toolCallId)?n.push(s):r.push(s)}return{mustReapply:o,frozen:n,fresh:r}}function ir(t,e,o){let n=[...t].sort((c,i)=>i.size-c.size),r=[],s=e+t.reduce((c,i)=>c+i.size,0);for(let c of n){if(s<=o)break;r.push(c),s-=c.size}return r}async function yn(t,e,o,n=zt){let r=rr(t);if(r.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,c=[];for(let g of r){let{mustReapply:f,frozen:A,fresh:C}=sr(g,e);for(let _ of f)s.set(_.toolCallId,_.replacement);if(C.length===0){for(let _ of g)e.seenIds.add(_.toolCallId);continue}let x=A.reduce((_,w)=>_+w.size,0),R=C.reduce((_,w)=>_+w.size,0),S=x+R>n?ir(C,x,n):[],N=new Set(S.map(_=>_.toolCallId));for(let _ of g)N.has(_.toolCallId)||e.seenIds.add(_.toolCallId);S.length>0&&c.push(...S)}if(s.size===0&&c.length===0)return{messages:t,newlyReplacedCount:0};let i=await Promise.all(c.map(async g=>{let f=await mn(g.content,g.toolCallId,o);return{candidate:g,result:f}})),p=0;for(let{candidate:g,result:f}of i){if(e.seenIds.add(g.toolCallId),!f)continue;let A=fn(f);s.set(g.toolCallId,A),e.replacements.set(g.toolCallId,A),p++}return s.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(g=>{if(g.role!=="tool"||!g.tool_call_id)return g;let f=s.get(g.tool_call_id);return f===void 0?g:{...g,content:f}}),newlyReplacedCount:p}}var ar=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),lr=new Set(["bash","execute_command","Bash","shell"]),ve=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??ar,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(r=>r.status==="executing"),n=this.config.maxConcurrentTools;return n&&n>0&&o.length>=n?!1:o.length===0||e&&o.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 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 r=n.length>40?n.slice(0,40)+"\u2026":n;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,o){let n=this.erroredToolDescription,r=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:r,message:G(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let n=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:c,sessionId:i,turnId:p,log:y}=this.config,g=e.toolCall.function.name,f=!1,A=e.toolCall.function.arguments;if(c)try{let _=await c.invoke("tool.before_invoke",{sessionId:i,turnId:p,callId:e.id,toolName:g,arguments:cr(A)});if(_.action==="abort"){let w=_.reason??"blocked by policy";y.info(`tool ${g} blocked: ${w}`),e.results.push({callId:e.id,toolName:g,ok:!1,error:w,blocked:!0,blockReason:w,message:G(e.id,{ok:!1,error:w})}),e.status="completed";return}_.action==="continue"&&_.context?.arguments&&(A=JSON.stringify(_.context.arguments))}catch{}let C=await s.invoke(p,g,A,this.siblingAbortController.signal),x=this.getAbortReason();if(x&&!f){e.results.push(this.createSyntheticError(e,x)),e.status="completed";return}let R=!C.error,S=C.result;R&&S&&S.length>5e4&&(S=await hn(S,e.id,i));let N=G(e.id,{ok:R,payload:S,error:C.error,toolReferences:C.toolReferences,imageUrls:C.imageUrls});R||(f=!0,lr.has(g)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),c?.invoke(R?"tool.after_invoke":"tool.invoke_failed",{sessionId:i,turnId:p,callId:e.id,toolName:g,ok:R,...C.error?{error:C.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:g,ok:R,error:C.error,message:N}),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 cr(t){try{return JSON.parse(t)}catch{return}}import{readFile as Ii}from"node:fs/promises";import*as U from"node:fs";import{ProviderRegistry as gr,ProviderVariantResolver as mr}from"@xiaozhiclaw/provider-core";import{homedir as ur}from"node:os";import{join as Tn}from"node:path";import{existsSync as Ri}from"node:fs";var dr=".qlogicagent";function pr(){return process.env.QLOGICAGENT_HOME||Tn(ur(),dr)}function bn(){return Tn(pr(),"settings.json")}var xe=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(),r=this.getHealthyCandidates(o,n);if(r.length===0)return null;let s=this.selectByStrategy(r,o.strategy,n);if(!s)return null;let c=this.runtimeStates.get(s.id);return c.inFlight++,c.totalRequests++,c.lastUsedAt=n,c.requestTimestamps.push(n),{keyId:s.id,apiKey:s.key,providerId:e,release:i=>this.releaseKey(s.id,i)}}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 r=o.retryAfter?o.retryAfter*1e3:3e4;n.cooldownUntil=Date.now()+r,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 r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=n?.id??crypto.randomUUID(),c={id:s,key:o,label:n?.label,weight:n?.weight??1,enabled:n?.enabled??!0};return r.keys.push(c),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let o of this.pools.values()){let n=o.keys.findIndex(r=>r.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 r=n.keys.find(s=>s.id===e);if(r){if(o.label!==void 0&&(r.label=o.label),o.weight!==void 0&&(r.weight=o.weight),o.enabled!==void 0){r.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 r of n.keys)o.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let n of[...this.pools.keys()])e.some(r=>r.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 r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.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((i,p)=>i+p,0)>=e.rateLimit.tpm*.9)||n.push(r))}}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((r,s)=>r+s.weight,0),n=Math.random()*o;for(let r of e)if(n-=r.weight,n<=0)return r;return e[e.length-1]}leastBusy(e){let o=1/0,n=e[0];for(let r of e){let c=this.runtimeStates.get(r.id)?.inFlight??0;(c<o||c===o&&r.weight>n.weight)&&(o=c,n=r)}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 fr=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],it=class{keyPool;coreProviderRegistry=new gr;providerVariantResolver=new mr(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=bn(),this.keyPool=new xe(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 r=this.resolveTechnicalVariant(n,e),s=r?.provider??n.provider,c=r?.nativeModelId??n.nativeModelId??n.model,i=this.acquireKeyForProviderVariant(s);if(!i)return null;let{keyHandle:p,keyProviderId:y}=i,g=this.getProviderBaseUrl(s),f=this.getProviderBaseUrl(y);return{provider:s,model:c,apiKey:p.apiKey,baseUrl:g??(n.provider===s?n.baseUrl:void 0)??f,keyHandle:p}}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 r=this.keyPool.addKey(e,o,n);return this.emitChange(),r}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,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[n];this.emitChange()}migrateModelIds(e){for(let[o,n]of e){let r=this.modelEnabledOverrides.get(o);r!==void 0&&!this.modelEnabledOverrides.has(n)&&this.modelEnabledOverrides.set(n,r),this.modelEnabledOverrides.delete(o);for(let[s,c]of Object.entries(this.bindings))c===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 fr){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{U.existsSync(this.settingsPath)&&(e=JSON.parse(U.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(/[/\\][^/\\]+$/,"");U.existsSync(n)||U.mkdirSync(n,{recursive:!0}),U.writeFileSync(this.settingsPath,JSON.stringify(o,null,2),"utf-8")}load(){try{if(!U.existsSync(this.settingsPath))return!1;let e=U.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(!U.existsSync(this.settingsPath))return;let o=U.readFileSync(this.settingsPath,"utf-8");return JSON.parse(o).tunables?.[e]}catch{return}}getModelInfo(e,o){let n=this.listModels({provider:e}).find(r=>r.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(r=>r.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 r=n.apiKey;return n.release({success:!0}),r}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 r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:yr(o,e.transport),capabilities:Tr(o),purpose:o,userPreference:{providerIds:n}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let o=[e],n=this.coreProviderRegistry.getProvider(e),r=n?.group??n?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&o.push(s.id);return r!==e&&o.push(r),[...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{}}},Me=null;function at(){return Me||(Me=new it,Me.load()),Me}function hr(t){switch(t){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return t;default:return}}function yr(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 hr(e)}}function Tr(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 ut(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function lt(t){let e=0;for(let o of t)e+=ut(o);return e}var ct={"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 br(t){if(!t)return 128e3;if(t in ct)return ct[t];let e=t.toLowerCase();for(let[o,n]of Object.entries(ct))if(e.startsWith(o.toLowerCase()))return n;return 128e3}var Cr=8e3;var kr=new re(200);var Rr=new se;function Cn(){return Rr}function _r(){return Ne(new oe(Cr),new X(20,ut),new ne(ut))}var Sr=null;function kn(t,e){let o=e?.budget??De({modelContextWindow:br(e?.model)}),r=(e?.pipeline??_r()).compress(t,o);if(r.droppedCount>0){let s=lt(t),c=lt(r.messages);kr.record({timestamp:Date.now(),strategy:r.strategy,tokensBefore:s,tokensAfter:c,droppedCount:r.droppedCount,latencyMs:r.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:r.metrics?.cacheInvalidated??!1,tier:Ue(s,o)})}return r.droppedCount>0&&Sr?.(r.droppedCount,lt(r.messages)),r}function Rn(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 Lr=new Set(["write","edit","patch","apply_patch"]);function Or(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 Nr(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 Dr=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,Ur=new Set(["search","grep","glob","find","list","read","exec"]);function Fr(t){if(!Ur.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&Dr.test(e)}function vn(t,e){for(let o=t.length-1;o>=0;o--){let n=t[o];if(!n||n.role!=="tool")continue;let r=typeof n.content=="string"?n.content:"";if(r.startsWith("Error: "))return r.slice(7).trim()}}function Br(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):Ot}function xn(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 $r(t){return t==="length"||t==="max_tokens"}function Mn(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 jr(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 Kr(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 r=n-o-1e3;return r>=3e3?r:null}function Gr(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*An(t,e,o,n){let{turnId:r,sessionId:s,messages:c,tools:i,model:p,apiKey:y,temperature:g=0,hooks:f,signal:A}=t,C={sessionId:s,turnId:r},x=t.maxTurns??0,R=t.querySource,{resolveToolEligibility:S}=await Promise.resolve().then(()=>(Sn(),_n)),N=S(i,t.toolEligibilityContext),_=N.eligibleTools;for(let b of N.blockedTools)yield{type:"tool_blocked",turnId:r,callId:"",name:b.toolName,reason:"blocked-by-policy"};if(!_.length){yield*Hr(r,p,c,y,g,A,e,n);return}let w=Br(t.maxRounds),D={contextWindowTokens:t.contextWindowTokens??Ut,responseBufferTokens:Ft,maxOutputTokens:t.maxOutputTokens??Bt,abortSignal:A,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},M=new Set,I=0,ce=_,ue,a={messages:[...c],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:et(D),reactiveCompactState:st(),toolLoopState:Re({maxRounds:w,replayMessages:[...c]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Be(),currentModel:p,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:dn(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},dt=Math.max(x*5,200),pt=0;for(;;){if(pt++,pt>dt){n.info(`hard iteration cap reached (${dt}), forcing completion`);let l=a.finalText||le(a.messages,n);yield{type:"end",turnId:r,content:l,usage:a.totalUsage,model:a.currentModel};return}let{messages:b,maxOutputTokensRecoveryCount:J,hasAttemptedReactiveCompact:Xr,maxOutputTokensOverride:gt,turnCount:Q,guardState:P,reactiveCompactState:j,collapseStore:Ae}=a,{toolLoopState:F}=a;if(ue){try{let l=await ue;l&&(yield{type:"tool_use_summary",turnId:r,summary:l})}catch{}ue=void 0}if(t.refreshTools&&Q>1){let l=t.refreshTools();l!==ce&&(ce=l,n.debug(`tools refreshed: ${l.length} tools`))}if(rt(P,D)){n.info(`turn aborted by guard at turn ${Q}`),yield{type:"error",turnId:r,error:"Turn aborted",code:"ABORTED",usage:a.totalUsage};return}let H=tt(P,D);if(H.level==="blocking"){H.reason==="prompt_too_long"&&Y(j)&&(j.attemptedThisTurn=!0,P.hasAttemptedReactiveCompact=!0,n.info(`token budget blocking (${H.reason}), reactive compact needed`),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"token budget pre-check"}),n.info(`token budget blocking (${H.reason}), ending tool loop`);break}H.level==="warning"&&n.info(`token budget warning: ${H.usagePercent}% used, ${H.remainingTokens} remaining`);let L;{let l=await yn(b,a.contentReplacementState,s);L=l.messages,l.newlyReplacedCount>0&&(n.info(`tool-result-budget: persisted ${l.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:r,action:"tool_result_budget",detail:`${l.newlyReplacedCount} persisted`})}{let l=Fe(L,a.snipRemovedIds);L=l.messages,l.removedCount>0&&(n.info(`snip: removed ${l.removedCount} messages, freed ~${l.tokensFreed} tokens`),yield{type:"recovery",turnId:r,action:"snip",detail:`${l.removedCount} messages`})}{let u=new X().compress(L,0);u.droppedCount>0&&(L=u.messages,n.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(L=$e(L,Ae).messages,P.promptTokens>0){let l=D.contextWindowTokens*.75,u=Cn().getActive(),d;u?d=await u.compressAsync(L,l,{model:a.currentModel,sessionId:s}):d=kn(L,{budget:l,model:a.currentModel}),d.droppedCount>0&&(L=d.messages,n.info(`autocompact: ${d.strategy}, dropped ${d.droppedCount}`),yield{type:"recovery",turnId:r,action:"autocompact",detail:`${d.strategy}: ${d.droppedCount} dropped`},a.hasAttemptedReactiveCompact=!1,f?.invoke("context.after_compact",{...C,removedCount:d.droppedCount}).catch(()=>{}))}L=Gr(L);let de=qe({tools:ce,toolChoice:t.toolChoice??"auto"}),Z=Re({maxRounds:w,replayMessages:L,lastStopReason:F.lastStopReason,options:{stopReason:F.lastStopReason}}),mt=de.extraSystemPrompt?[{role:"system",content:de.extraSystemPrompt},...Z.state.replayMessages]:Z.state.replayMessages;F=Z.state,Z.recoveryActions.length>0&&n.debug(`tool loop recovery: ${Z.recoveryActions.map(l=>l.detail??l.kind).join("; ")}`),n.debug(`turn ${Q}, messages: ${mt.length}`),f?.invoke("turn.before_inference",{...C,model:a.currentModel}).catch(()=>{});let pe=!1,ft=[],ht=new Map,yt="stop",B,k=null,ge=!1,ee=[],O=[];try{for await(let l of e.stream({model:a.currentModel,messages:mt,tools:de.tools,toolChoice:de.normalizedToolChoice??"auto",temperature:g,maxTokens:(gt??P.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},y,A))switch(l.type){case"delta":ft.push(l.text),pe||(yield{type:"delta",turnId:r,text:l.text});break;case"tool_call_delta":pe=!0,Pr(ht,l);break;case"reasoning_delta":ee.push(l.text);break;case"reasoning_block_complete":l.signature&&O.push({thinking:ee.join(""),signature:l.signature}),ee.length=0;break;case"usage":B={inputTokens:l.promptTokens,outputTokens:l.completionTokens,reasoningTokens:l.reasoningTokens,cacheRead:l.cacheReadTokens,cacheWrite:l.cacheCreationTokens};break;case"response_id":a.lastResponseId=l.id;break;case"annotations":yield{type:"annotations",turnId:r,annotations:l.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:r,message:`${l.toolType}: ${l.event}`};break;case"done":yt=l.finishReason;break}if(pe||f?.invoke("turn.after_inference",{...C,model:a.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let l=a.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...L],model:l,sessionId:s})}catch{}}}catch(l){if(l instanceof ae&&t.fallbackModel){n.info(`model fallback triggered: ${l.originalModel} \u2192 ${l.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`${l.originalModel} \u2192 ${l.fallbackModel}`},a={...a,currentModel:l.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=l instanceof Error?l.message:String(l),d=typeof l?.status=="number"?l.status:void 0;if(!d&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let T=(a.consecutiveApiRetries??0)+1;if(T>ie){n.info(`stale connection retry limit reached (${ie}), aborting`),yield{type:"error",turnId:r,error:u,code:"RETRIES_EXHAUSTED",usage:a.totalUsage};return}n.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:r,action:"stale_connection_retry",detail:u.slice(0,80)},a={...a,consecutiveApiRetries:T,transition:void 0};continue}let m=Kr({status:d,message:u});if(m!==null){n.info(`max_tokens overflow: adjusting to ${m}`),P.currentMaxOutputTokens=m,a={...a,maxOutputTokensOverride:m,transition:void 0};continue}if(Ze(d)){a.consecutive529Errors++;let T=2,E=t.fallbackModel&&a.currentModel!==t.fallbackModel;if(a.consecutive529Errors>T&&!E&&!Se()){n.info(`transient ${d} \xD7 ${a.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:r,error:`API unavailable after ${a.consecutive529Errors} consecutive ${d} errors`,code:"API_ERROR",usage:a.totalUsage};return}if(a.consecutive529Errors>=Wt&&t.fallbackModel&&a.currentModel!==t.fallbackModel){n.info(`529 \xD7 ${a.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`529 \xD7 ${a.consecutive529Errors}`},a={...a,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Se()){let h=_e(a.consecutive529Errors);n.info(`persistent retry: waiting ${h}ms (attempt ${a.consecutive529Errors})`);let v=h;for(;v>0;){if(A?.aborted){yield{type:"error",turnId:r,error:"Aborted during retry wait",code:"ABORTED",usage:a.totalUsage};return}yield{type:"heartbeat",turnId:r,message:`Retrying in ${Math.ceil(v/1e3)}s (${d})`};let $=Math.min(v,qt);await new Promise(Ie=>setTimeout(Ie,$)),v-=$}a={...a,transition:void 0};continue}if(Qe(R)){let v=jr({status:d,message:u})??_e(a.consecutive529Errors);n.info(`transient ${d}: retry in ${v}ms`),yield{type:"recovery",turnId:r,action:"retry",detail:`${d} retry in ${v}ms`},await new Promise($=>setTimeout($,v)),a={...a,transition:void 0};continue}n.info(`background source ${R}: not retrying ${d}`)}k={status:d,message:u}}if(k&&f?.invoke("turn.after_inference",{...C,model:a.currentModel,response:{error:k.message}}).catch(()=>{}),k)if(xn(k))ge=!0,n.info(`withheld prompt_too_long error (status=${k.status})`);else if(Mn(k))ge=!0,n.info(`withheld media_size error (status=${k.status})`);else{let l=nt({status:k.status??500,message:k.message},P,D);if(l.action==="reactive_compact"&&Y(j)&&(j.attemptedThisTurn=!0,P.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:r,action:"reactive_compact",detail:`API ${k.status??500}: ${k.message}`}),l.action==="retry"){let d=(a.consecutiveApiRetries??0)+1;if(d>ie){n.info(`API retry limit reached (${ie}), aborting`);let m=V(k.status,k.message);yield{type:"error",turnId:r,error:k.message,code:m,usage:a.totalUsage};return}yield{type:"recovery",turnId:r,action:"retry",detail:l.reason},a={...a,consecutiveApiRetries:d,transition:void 0};continue}let u=V(k.status,k.message);f?.invoke("stop.failure",{sessionId:s,reason:u,error:k.message}).catch(()=>{}),yield{type:"error",turnId:r,error:k.message,code:u,usage:a.totalUsage};return}B&&(a.totalUsage.inputTokens+=B.inputTokens,a.totalUsage.outputTokens+=B.outputTokens,B.reasoningTokens&&(a.totalUsage.reasoningTokens=(a.totalUsage.reasoningTokens??0)+B.reasoningTokens),B.cacheRead&&(a.totalUsage.cacheRead=(a.totalUsage.cacheRead??0)+B.cacheRead),B.cacheWrite&&(a.totalUsage.cacheWrite=(a.totalUsage.cacheWrite??0)+B.cacheWrite)),B?.inputTokens&&(P.promptTokens=B.inputTokens);let Tt=ft.join("");Tt&&(a.finalText=Tt);let K=[...ht.values()].map(l=>({id:l.id||`tc_${r}_${Q}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:l.name,arguments:l.arguments}}));if(K.length===0&&!pe){if(ge&&k&&xn(k)){if(a.transition?.reason!=="collapse_drain_retry"){let d=je(L,Ae);if(d.committed>0){n.info(`collapse drain: committed ${d.committed} stages`),yield{type:"recovery",turnId:r,action:"collapse_drain",detail:`${d.committed} stages committed`},a={...a,messages:d.messages,transition:{reason:"collapse_drain_retry",committed:d.committed}};continue}}if(Y(j)){j.attemptedThisTurn=!0,P.hasAttemptedReactiveCompact=!0,n.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:r,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"),f?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:k.message}).catch(()=>{}),yield{type:"error",turnId:r,error:k.message,code:"PROMPT_TOO_LONG",usage:a.totalUsage};return}if(ge&&k&&Mn(k)){if(Y(j)){j.attemptedThisTurn=!0,P.hasAttemptedReactiveCompact=!0,n.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:r,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"),f?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:k.message}).catch(()=>{}),yield{type:"error",turnId:r,error:k.message,code:"IMAGE_ERROR",usage:a.totalUsage};return}if($r(yt)){P.consecutiveTruncations+=1;let d=t.modelMaxOutputTokens??$t,m=ot(P,D,d);if(m.shouldEscalate&&gt===void 0){P.currentMaxOutputTokens=m.newMax,n.info(`max_output_tokens escalate: ${m.newMax} tokens`),yield{type:"recovery",turnId:r,action:"output_escalation",detail:`${m.newMax} tokens`},a={...a,maxOutputTokensOverride:Kt,transition:{reason:"max_output_tokens_escalate"}};continue}if(J<jt){let T={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 #${J+1}`),yield{type:"recovery",turnId:r,action:"max_output_tokens_recovery",detail:`attempt ${J+1}`},a={...a,messages:[...L,T],maxOutputTokensRecoveryCount:J+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:J+1}};continue}n.info("max_output_tokens recovery exhausted, completing with partial content")}else P.consecutiveTruncations=0;if(F=ke(F,{replayMessages:b,lastStopReason:"completed"}),f){let d=await f.invoke("stop",{sessionId:s,reason:"completed"});if(d.action==="prevent"){n.info(`stop hook prevented continuation: ${d.reason??"no reason"}`),yield{type:"end",turnId:r,content:a.finalText,usage:a.totalUsage,model:a.currentModel};return}if(d.action==="abort"){let m=d.reason??"Stop hook requested continuation";n.info(`stop hook blocking: ${m}`);let T={role:"user",content:m},E={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,E,T],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&a.budgetContinuationCount<5){let d=a.totalUsage.inputTokens+a.totalUsage.outputTokens+(a.totalUsage.reasoningTokens??0),m=d/t.tokenBudget*100,T=d-a.lastBudgetGlobalTokens,E=a.budgetContinuationCount>=Gt&&T<Ke&&a.lastBudgetDeltaTokens<Ke;if(E&&n.info(`token budget early stop: diminishing returns at ${Math.round(m)}% (delta=${T})`),!E&&m<90){let h=a.budgetContinuationCount+1,v={role:"user",content:Rn(m,d,t.tokenBudget)};n.info(`token budget continuation #${h}: ${Math.round(m)}% used`),yield{type:"recovery",turnId:r,action:"budget_continuation",detail:`${Math.round(m)}% used (#${h})`};let $={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,$,v],budgetContinuationCount:h,lastBudgetDeltaTokens:T,lastBudgetGlobalTokens:d,transition:{reason:"token_budget_continuation"}};continue}}if(!a.stopHookActive){let d=c.find(h=>h.role==="user"),m=typeof d?.content=="string"?d.content:"",T=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(m),E=M.has("write")||M.has("edit");if(T&&!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(Ie=>Ie.role==="tool");$&&typeof $.content=="string"&&($.content+=`
18
18
 
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(`
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 h={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."},v={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,v,h],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!a.stopHookActive&&I>=3&&M.has("write")){let d=0;for(let m of b){let T=m,E=T.is_error===!0||typeof T.content=="string"&&T.content.startsWith("Error:");T.role==="tool"&&typeof T.content=="string"&&!E&&d++}if(d>=3){n.info("AP3 verification nudge: 3+ files created, injecting completeness check");let m={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."},T={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,T,m],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(I>0){let d={ok:!0,toolCallCount:I,distinctToolCount:M.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},m=Ce(d,{tools:[...M],projectRoot:t.projectRoot});m&&(yield{type:"skill_instruction",turnId:r,instruction:m})}let u=a.finalText||le(b,n);yield{type:"end",turnId:r,content:u,usage:a.totalUsage,model:a.currentModel};return}let Pn=O.length===0&&ee.length>0?ee.join(""):void 0;b.push(Pe(K,a.finalText||void 0,O.length>0?O:void 0,Pn)),F=Je(F,{replayMessages:b,pendingToolCallIds:K.map(l=>l.id),completedToolCallIds:F.completedToolCallIds,lastStopReason:"tool_calls"});let me=a.identicalCallCounts,bt=[],fe=[],Ct=!1;for(let l of K){let u=`${l.function.name}::${l.function.arguments}`,d=me.get(u)??0;me.set(u,d+1),d+1>Dt?(fe.push(l),Ct||(Ct=!0,n.info(`AP4 blocked: ${l.function.name} repeated ${d+1}x`))):bt.push(l)}let he=[];for(let l of fe){let u=me.get(`${l.function.name}::${l.function.arguments}`),d=vn(b,l.function.name),m=d?`This exact tool call has been attempted ${u} times. Last error: ${d}. 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.`,T=G(l.id,{ok:!1,error:m});b.push(T),he.push(l.id),M.add(l.function.name),I++,yield{type:"tool_result",turnId:r,callId:l.id,name:l.function.name,ok:!1,error:m}}if(fe.length>0){let l=vn(b,fe[0].function.name),u={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(l?`The error was: "${l}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};b.push(u)}let ye=[],Ee=[];for(let l of bt)(a.toolFailureCounts.get(l.function.name)??0)>=Te?Ee.push(l):ye.push(l);if(Ee.length>0){for(let u of Ee){let d=a.toolFailureCounts.get(u.function.name),m=`Tool "${u.function.name}" has failed ${d} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,T=G(u.id,{ok:!1,error:m});b.push(T),he.push(u.id),M.add(u.function.name),I++,yield{type:"tool_result",turnId:r,callId:u.id,name:u.function.name,ok:!1,error:m},n.info(`AP4-variant blocked: ${u.function.name} failed ${d}x with different args`)}let l={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."};b.push(l)}for(let l of ye){let u=l.function.arguments,d=ce.find(m=>m.function.name===l.function.name);if(d?.backfillObservableInput)try{let m=JSON.parse(l.function.arguments),T={...m};d.backfillObservableInput(T),Object.keys(T).some(h=>!(h in m))&&(u=JSON.stringify(T))}catch{}yield{type:"tool_call",turnId:r,callId:l.id,name:l.function.name,arguments:u}}let Ln=new Map(a.toolFailureCounts);try{let l=new ve({toolInvoker:o,hooks:f,sessionId:s,turnId:r,log:n,signal:A,maxConcurrentTools:t?.maxConcurrentTools});for(let u of ye)l.addTool(u);for await(let u of l.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:r,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),b.push(u.message),he.push(u.callId),M.add(u.toolName),I++;let d=u.ok&&Fr(u);if(!u.ok||d){let h=(a.toolFailureCounts.get(u.toolName)??0)+1;a.toolFailureCounts.set(u.toolName,h)}if(u.ok&&u.toolName==="read"){let E=ye.find(h=>h.id===u.callId);if(E)try{let h=JSON.parse(E.function.arguments),v=h.file_path??h.path??h.filePath??"";if(v){let $=a.fileReadCounts.get(v)??0;a.fileReadCounts.set(v,$+1)}}catch{}}let m=typeof u.message?.content=="string"?u.message.content:"",T=u.ok&&m?m.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:r,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:T},u.ok){let E=K.find(h=>h.id===u.callId);if(E){if(u.toolName==="plan_mode")try{let h=JSON.parse(E.function.arguments);h.action==="exit"&&typeof h.plan=="string"&&h.plan.length>0&&(yield{type:"plan_update",turnId:r,slug:"approved-plan",content:h.plan})}catch{}if(Lr.has(u.toolName))try{let h=JSON.parse(E.function.arguments),v=typeof h.file_path=="string"?h.file_path:typeof h.filePath=="string"?h.filePath:typeof h.path=="string"?h.path:void 0;v&&(yield{type:"artifact",turnId:r,artifactId:`artifact-${u.callId}`,artifactType:Or(v),title:v.split(/[\\/]/).pop()||v,filePath:v,language:Nr(v)})}catch{}}}}}catch(l){let u=l instanceof Error?l.message:String(l);yield{type:"error",turnId:r,error:u,code:"TOOL_EXECUTION_ERROR",usage:a.totalUsage};return}for(let[l,u]of a.toolFailureCounts)u>=Te&&(Ln.get(l)??0)<Te&&b.push({role:"user",content:`Tool "${l}" has now failed/returned empty results ${u} times with different arguments. The target clearly does not exist. Do NOT call "${l}" again. Report the result to the user immediately.`});if(F=ke(F,{replayMessages:b,completedToolCallIds:[...F.completedToolCallIds,...he],lastStopReason:"tool_calls"}),t.generateToolUseSummary&&K.length>0){let l=K.map(u=>({name:u.function.name,arguments:u.function.arguments}));ue=t.generateToolUseSummary(l).catch(()=>null)}let On=K.length>0&&K.every(l=>{let u=b.find(m=>m?.role==="tool"&&m?.tool_call_id===l.id);if(!u)return!0;let d=u.content;return typeof d=="string"&&d.startsWith("Error: ")}),te=a.consecutiveFailedRounds;if(On){if(te+=1,te>=Nt){let l=a.finalText||le(b,n);n.info(`early exit: ${te} consecutive failed rounds, returning ${a.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:r,content:l,usage:a.totalUsage,model:a.currentModel};return}}else te=0;let Nn=3,kt=[...a.fileReadCounts.entries()].filter(([,l])=>l>=Nn);if(kt.length>0){let l=kt.map(([d])=>d).join(", ");n.info(`AP5: file read cycle detected on ${l}, injecting nudge`);let u={role:"user",content:`You are reading the same files repeatedly (${l}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};b.push(u),a.fileReadCounts.clear()}let we=Q+1;if(x>0&&we>x){if(n.info(`max turns reached (${x}), completing`),f){let u=await f.invoke("stop",{sessionId:s,reason:"max_turns"});if(u.action==="abort"){let d=u.reason??"Stop hook requested continuation after max_turns",m={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,m,{role:"user",content:d}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let l=a.finalText||le(b,n);yield{type:"end",turnId:r,content:l,usage:a.totalUsage,model:a.currentModel};return}if(we>w){if(n.info(`tool loop budget exhausted (${w} rounds), returning`),I>0){let u={ok:!0,toolCallCount:I,distinctToolCount:M.size,multiStep:I>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},d=Ce(u,{tools:[...M],projectRoot:t.projectRoot});d&&(yield{type:"skill_instruction",turnId:r,instruction:d})}let l=a.finalText||le(b,n);yield{type:"end",turnId:r,content:l,usage:a.totalUsage,model:a.currentModel};return}a={messages:b,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:we,transition:{reason:"next_turn"},guardState:P,reactiveCompactState:j,toolLoopState:F,consecutiveFailedRounds:te,finalText:a.finalText,totalUsage:a.totalUsage,collapseStore:Ae,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:me,toolFailureCounts:a.toolFailureCounts,fileReadCounts:a.fileReadCounts}}}function le(t,e){let o=[];for(let n=t.length-1;n>=0;n--){let r=t[n];if(r.role==="tool"&&typeof r.content=="string")o.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 o.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${o.length} tool result(s)`),o.join(`
20
20
 
21
- `)):""}async function*Ms(t,e,o,n,i,s,l,r){let d=[],h;r.debug(`single LLM round, messages: ${o.length}`);for await(let m of l.stream({model:e,messages:o,temperature:i},n,s))switch(m.type){case"delta":d.push(m.text),yield{type:"delta",turnId:t,text:m.text};break;case"usage":h={inputTokens:m.promptTokens,outputTokens:m.completionTokens,reasoningTokens:m.reasoningTokens,cacheRead:m.cacheReadTokens,cacheWrite:m.cacheCreationTokens};break;case"done":break}yield{type:"end",turnId:t,content:d.join(""),usage:h??{inputTokens:0,outputTokens:0},model:e}}var Rs={coding:[/(?:bug|error|fix|debug|报错|修复|编译|compile|build|lint)/i,/(?:implement|refactor|重构|实现|代码|code|function|method|class)/i,/(?:test|测试|vitest|jest|断言|assert)/i,/(?:type(?:script)?|接口|interface|generic|泛型)/i,/(?:import|export|module|依赖|package|npm|pnpm)/i,/(?:git|commit|branch|merge|rebase|PR|MR)/i],config:[/(?:deploy|部署|运维|docker|container|kubernetes|k8s)/i,/(?:port|端口|config|配置|env|环境变量|.env)/i,/(?:server|service|daemon|进程|systemd|nginx|redis)/i,/(?:版本|version|upgrade|migrate|迁移)/i,/(?:domain|域名|ssl|cert|证书|DNS)/i],conversation:[/(?:你好|hi|hello|hey|请问|问一下)/i,/(?:我(?:喜欢|偏好|习惯|想)|prefer|I (?:like|want|need))/i,/(?:帮我|help me|能不能|可以吗|would you)/i,/(?:style|风格|format|格式|命名|naming)/i],learning:[/(?:best practice|最佳实践|pattern|模式|惯例|convention)/i,/(?:怎么做|how to|how do|what's the|推荐|recommend)/i,/(?:为什么|why|原因|reason|explain|解释)/i,/(?:lesson|经验|教训|gotcha|pitfall|坑)/i],decision:[/(?:should|应该|选择|choose|decision|决定|trade-?off|权衡)/i,/(?:vs|versus|对比|compare|区别|difference)/i,/(?:architecture|架构|方案|approach|strategy)/i,/(?:pros|cons|优缺点|利弊|好处|坏处)/i],general:[]},Es={coding:{preferred:["lesson","pattern","fact"],deprioritized:["preference"]},config:{preferred:["fact","decision","lesson"],deprioritized:["preference","skill-learning"]},conversation:{preferred:["preference","fact"],deprioritized:["pattern","skill-learning"]},learning:{preferred:["lesson","pattern","skill-learning"],deprioritized:["preference"]},decision:{preferred:["decision","fact","lesson"],deprioritized:["skill-learning","preference"]},general:{preferred:[],deprioritized:[]}};function Ko(t){if(!t||t.length<5)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};let e=[];for(let[i,s]of Object.entries(Rs)){if(i==="general")continue;let l=s.filter(r=>r.test(t)).length;if(l>0){let r=Math.min(1,l/2);e.push({scenario:i,score:r})}}if(e.length===0)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};e.sort((i,s)=>s.score-i.score);let o=e[0];if(o.score<.5)return{scenario:"general",preferred:[],deprioritized:[],confidence:o.score};let n=Es[o.scenario];return{scenario:o.scenario,preferred:n.preferred,deprioritized:n.deprioritized,confidence:o.score}}var Xo=class{transport;apiKey;toolInvoker;log;hooks;maxRounds;projectRoot;constructor(e){this.transport=e.llmTransport,this.apiKey=e.apiKey,this.toolInvoker=e.toolInvoker,this.log=e.log,this.hooks=e.hooks,this.projectRoot=e.projectRoot,this.maxRounds=Math.min(e.maxRounds??25,100)}async*run(e,o){let{turnId:n,messages:i,tools:s,systemPrompt:l,config:r}=e,d={sessionId:e.sessionId,turnId:n};yield{type:"start",turnId:n},this.hooks?.invoke("turn.submitted",{...d,prompt:i[i.length-1]?.content??void 0}).catch(()=>{});let h=st(i),m=[];if(l&&m.push({role:"system",content:l}),m.push(...h),this.hooks){let T=h.filter(x=>x.role==="user").pop(),v=typeof T?.content=="string"?T.content.slice(0,500):void 0;if(v)try{let x=Ko(v),C=await this.hooks.invoke("memory.before_recall",{sessionId:e.sessionId,turnId:n,query:v,preferredCategories:x.preferred.length>0?x.preferred:void 0,deprioritizedCategories:x.deprioritized.length>0?x.deprioritized:void 0}),L=C?.context?.recalledMemories;if(L&&L.length>0){let A=0,$=[];for(let R of L){let I=(R.text?.length??0)*2;if(A+I>8192)break;$.push(R),A+=I}if($.length>0){let R=$.map(I=>`- ${I.text}`).join(`
22
- `);m.splice(l?1:0,0,{role:"system",content:`[Recalled memories \u2014 context priority: project-specific facts override general user preferences when they conflict]
23
- ${R}`})}}this.hooks.invoke("memory.after_recall",{sessionId:e.sessionId,turnId:n,blockCount:C?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let g=r?.model??"",M=Math.min(r?.maxRounds??this.maxRounds,100);try{let T=async C=>{let L=xt().resolveModelForPurpose("smallModel");if(!L)return null;try{let w=C.map(R=>`${R.name}(${R.arguments.slice(0,200)})`).join(", "),A=this.transport.stream({model:L,messages:[{role:"system",content:"Summarize the tool usage in ~30 chars, git-commit-subject style. Reply with ONLY the summary, nothing else."},{role:"user",content:w}],tools:[],maxTokens:60},r?.apiKey??this.apiKey),$="";for await(let R of A)R.type==="delta"&&($+=R.text);return $.trim()||null}catch{return null}},v={turnId:n,sessionId:e.sessionId,messages:m,tools:s,model:g,apiKey:r?.apiKey??this.apiKey,temperature:r?.temperature,maxRounds:M,contextWindowTokens:r?.contextWindowTokens,maxOutputTokens:r?.maxOutputTokens,modelMaxOutputTokens:r?.modelMaxOutputTokens,toolChoice:r?.toolChoice,parentDepth:r?.parentDepth,hooks:this.hooks,fallbackModel:r?.fallbackModel,maxTurns:r?.maxTurns,tokenBudget:r?.tokenBudget,maxConcurrentTools:r?.maxConcurrentTools,streamRequired:r?.streamRequired,reasoning:r?.reasoning,promptCacheKey:r?.promptCacheKey,promptCacheRetention:r?.promptCacheRetention,serviceTier:r?.serviceTier,openaiBuiltinTools:r?.openaiBuiltinTools,maxToolCalls:r?.maxToolCalls,parallelToolCalls:r?.parallelToolCalls,textVerbosity:r?.textVerbosity,projectRoot:this.projectRoot,generateToolUseSummary:T,signal:o},x;for await(let C of Ho(v,this.transport,this.toolInvoker,this.log))x=C,yield C;x?.type==="end"?this.hooks?.invoke("turn.completed",{...d}).catch(()=>{}):x?.type==="error"&&this.hooks?.invoke("turn.failed",{...d,code:x.code,error:x.error}).catch(()=>{})}catch(T){if(o?.aborted)this.hooks?.invoke("turn.failed",{...d,code:"ABORTED",error:"Turn aborted"}).catch(()=>{}),yield{type:"error",turnId:n,error:"Turn aborted",code:"ABORTED"};else{let v=T instanceof Error?T.message:String(T),x=typeof T?.status=="number"?T.status:void 0,C=Y(x,v);this.log.error(`turn ${n} error [${C}, retryable=${je(C)}]: ${v}`),this.hooks?.invoke("turn.failed",{...d,code:C,error:v}).catch(()=>{}),yield{type:"error",turnId:n,error:v,code:C}}}}};export{Xo as Agent};
21
+ `)):""}async function*Hr(t,e,o,n,r,s,c,i){let p=[],y;i.debug(`single LLM round, messages: ${o.length}`);for await(let g of c.stream({model:e,messages:o,temperature:r},n,s))switch(g.type){case"delta":p.push(g.text),yield{type:"delta",turnId:t,text:g.text};break;case"usage":y={inputTokens:g.promptTokens,outputTokens:g.completionTokens,reasoningTokens:g.reasoningTokens,cacheRead:g.cacheReadTokens,cacheWrite:g.cacheCreationTokens};break;case"done":break}yield{type:"end",turnId:t,content:p.join(""),usage:y??{inputTokens:0,outputTokens:0},model:e}}var zr={coding:[/(?:bug|error|fix|debug|报错|修复|编译|compile|build|lint)/i,/(?:implement|refactor|重构|实现|代码|code|function|method|class)/i,/(?:test|测试|vitest|jest|断言|assert)/i,/(?:type(?:script)?|接口|interface|generic|泛型)/i,/(?:import|export|module|依赖|package|npm|pnpm)/i,/(?:git|commit|branch|merge|rebase|PR|MR)/i],config:[/(?:deploy|部署|运维|docker|container|kubernetes|k8s)/i,/(?:port|端口|config|配置|env|环境变量|.env)/i,/(?:server|service|daemon|进程|systemd|nginx|redis)/i,/(?:版本|version|upgrade|migrate|迁移)/i,/(?:domain|域名|ssl|cert|证书|DNS)/i],conversation:[/(?:你好|hi|hello|hey|请问|问一下)/i,/(?:我(?:喜欢|偏好|习惯|想)|prefer|I (?:like|want|need))/i,/(?:帮我|help me|能不能|可以吗|would you)/i,/(?:style|风格|format|格式|命名|naming)/i],learning:[/(?:best practice|最佳实践|pattern|模式|惯例|convention)/i,/(?:怎么做|how to|how do|what's the|推荐|recommend)/i,/(?:为什么|why|原因|reason|explain|解释)/i,/(?:lesson|经验|教训|gotcha|pitfall|坑)/i],decision:[/(?:should|应该|选择|choose|decision|决定|trade-?off|权衡)/i,/(?:vs|versus|对比|compare|区别|difference)/i,/(?:architecture|架构|方案|approach|strategy)/i,/(?:pros|cons|优缺点|利弊|好处|坏处)/i],general:[]},qr={coding:{preferred:["lesson","pattern","fact"],deprioritized:["preference"]},config:{preferred:["fact","decision","lesson"],deprioritized:["preference","skill-learning"]},conversation:{preferred:["preference","fact"],deprioritized:["pattern","skill-learning"]},learning:{preferred:["lesson","pattern","skill-learning"],deprioritized:["preference"]},decision:{preferred:["decision","fact","lesson"],deprioritized:["skill-learning","preference"]},general:{preferred:[],deprioritized:[]}};function En(t){if(!t||t.length<5)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};let e=[];for(let[r,s]of Object.entries(zr)){if(r==="general")continue;let c=s.filter(i=>i.test(t)).length;if(c>0){let i=Math.min(1,c/2);e.push({scenario:r,score:i})}}if(e.length===0)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};e.sort((r,s)=>s.score-r.score);let o=e[0];if(o.score<.5)return{scenario:"general",preferred:[],deprioritized:[],confidence:o.score};let n=qr[o.scenario];return{scenario:o.scenario,preferred:n.preferred,deprioritized:n.deprioritized,confidence:o.score}}var In=class{transport;apiKey;toolInvoker;log;hooks;maxRounds;projectRoot;constructor(e){this.transport=e.llmTransport,this.apiKey=e.apiKey,this.toolInvoker=e.toolInvoker,this.log=e.log,this.hooks=e.hooks,this.projectRoot=e.projectRoot,this.maxRounds=Math.min(e.maxRounds??25,100)}async*run(e,o){let{turnId:n,messages:r,tools:s,systemPrompt:c,config:i}=e,p={sessionId:e.sessionId,turnId:n};yield{type:"start",turnId:n},this.hooks?.invoke("turn.submitted",{...p,prompt:r[r.length-1]?.content??void 0}).catch(()=>{});let y=Ye(r),g=[];if(c&&g.push({role:"system",content:c}),g.push(...y),this.hooks){let C=y.filter(R=>R.role==="user").pop(),x=typeof C?.content=="string"?C.content.slice(0,500):void 0;if(x)try{let R=En(x),S=await this.hooks.invoke("memory.before_recall",{sessionId:e.sessionId,turnId:n,query:x,preferredCategories:R.preferred.length>0?R.preferred:void 0,deprioritizedCategories:R.deprioritized.length>0?R.deprioritized:void 0}),N=S?.context?.recalledMemories;if(N&&N.length>0){let w=0,D=[];for(let M of N){let I=(M.text?.length??0)*2;if(w+I>8192)break;D.push(M),w+=I}if(D.length>0){let M=D.map(I=>`- ${I.text}`).join(`
22
+ `);g.splice(c?1:0,0,{role:"system",content:`[Recalled memories \u2014 context priority: project-specific facts override general user preferences when they conflict]
23
+ ${M}`})}}this.hooks.invoke("memory.after_recall",{sessionId:e.sessionId,turnId:n,blockCount:S?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let f=i?.model??"",A=Math.min(i?.maxRounds??this.maxRounds,100);try{let C=async S=>{let N=at().resolveModelForPurpose("smallModel");if(!N)return null;try{let _=S.map(M=>`${M.name}(${M.arguments.slice(0,200)})`).join(", "),w=this.transport.stream({model:N,messages:[{role:"system",content:"Summarize the tool usage in ~30 chars, git-commit-subject style. Reply with ONLY the summary, nothing else."},{role:"user",content:_}],tools:[],maxTokens:60},i?.apiKey??this.apiKey),D="";for await(let M of w)M.type==="delta"&&(D+=M.text);return D.trim()||null}catch{return null}},x={turnId:n,sessionId:e.sessionId,messages:g,tools:s,model:f,apiKey:i?.apiKey??this.apiKey,temperature:i?.temperature,maxRounds:A,contextWindowTokens:i?.contextWindowTokens,maxOutputTokens:i?.maxOutputTokens,modelMaxOutputTokens:i?.modelMaxOutputTokens,toolChoice:i?.toolChoice,parentDepth:i?.parentDepth,hooks:this.hooks,fallbackModel:i?.fallbackModel,maxTurns:i?.maxTurns,tokenBudget:i?.tokenBudget,maxConcurrentTools:i?.maxConcurrentTools,streamRequired:i?.streamRequired,reasoning:i?.reasoning,promptCacheKey:i?.promptCacheKey,promptCacheRetention:i?.promptCacheRetention,serviceTier:i?.serviceTier,openaiBuiltinTools:i?.openaiBuiltinTools,maxToolCalls:i?.maxToolCalls,parallelToolCalls:i?.parallelToolCalls,textVerbosity:i?.textVerbosity,projectRoot:this.projectRoot,generateToolUseSummary:C,signal:o},R;for await(let S of An(x,this.transport,this.toolInvoker,this.log))R=S,yield S;R?.type==="end"?this.hooks?.invoke("turn.completed",{...p}).catch(()=>{}):R?.type==="error"&&this.hooks?.invoke("turn.failed",{...p,code:R.code,error:R.error}).catch(()=>{})}catch(C){if(o?.aborted)this.hooks?.invoke("turn.failed",{...p,code:"ABORTED",error:"Turn aborted"}).catch(()=>{}),yield{type:"error",turnId:n,error:"Turn aborted",code:"ABORTED"};else{let x=C instanceof Error?C.message:String(C),R=typeof C?.status=="number"?C.status:void 0,S=V(R,x);this.log.error(`turn ${n} error [${S}, retryable=${Oe(S)}]: ${x}`),this.hooks?.invoke("turn.failed",{...p,code:S,error:x}).catch(()=>{}),yield{type:"error",turnId:n,error:x,code:S}}}}};export{In as Agent};