qlogicagent 2.10.33 → 2.10.34
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent.js +6 -21
- package/dist/cli.js +386 -387
- package/dist/index.js +388 -389
- package/dist/orchestration.js +8 -8
- package/dist/permissions.js +1 -1
- package/dist/protocol.js +1 -1
- package/dist/types/agent/agent.d.ts +4 -2
- package/dist/types/agent/tool-loop/artifact-events.d.ts +17 -0
- package/dist/types/agent/tool-loop/loop-helpers.d.ts +15 -0
- package/dist/types/agent/tool-loop/recovery-helpers.d.ts +18 -0
- package/dist/types/agent/tool-loop/single-round.d.ts +2 -0
- package/dist/types/agent/tool-loop/tool-result-events.d.ts +7 -0
- package/dist/types/agent/tool-loop.d.ts +12 -11
- package/dist/types/agent/types.d.ts +3 -1
- package/dist/types/cli/acp-session-handlers.d.ts +2 -0
- package/dist/types/cli/agent-runtime-bootstrap.d.ts +2 -1
- package/dist/types/cli/agent-runtime-ports-adapter.d.ts +2 -0
- package/dist/types/cli/agent-runtime-session-state.d.ts +24 -0
- package/dist/types/cli/base-tool-bootstrap.d.ts +2 -0
- package/dist/types/cli/core-tool-coordinator.d.ts +3 -0
- package/dist/types/cli/core-tools/agent-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/core-tools/agent-tool-service.d.ts +3 -1
- package/dist/types/cli/core-tools/checkpoint-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/core-tools/config-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/core-tools/cron-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/core-tools/monitor-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/core-tools/team-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/core-tools/utility-tool-bootstrap.d.ts +3 -1
- package/dist/types/cli/dev-tool-bootstrap.d.ts +4 -0
- package/dist/types/cli/dev-tools/dev-tool-bootstrap-service.d.ts +6 -0
- package/dist/types/cli/dev-tools/dev-tool-registry.d.ts +7 -0
- package/dist/types/cli/dream-host-adapter.d.ts +1 -0
- package/dist/types/cli/handlers/community-handler.d.ts +2 -1
- package/dist/types/cli/handlers/config-handler.d.ts +2 -0
- package/dist/types/cli/handlers/dream-handler.d.ts +2 -0
- package/dist/types/cli/handlers/pet-handler.d.ts +1 -0
- package/dist/types/cli/handlers/product-handler.d.ts +18 -40
- package/dist/types/cli/handlers/project-handler.d.ts +1 -1
- package/dist/types/cli/handlers/turn-handler.d.ts +3 -1
- package/dist/types/cli/handlers/workflow-handler.d.ts +2 -0
- package/dist/types/cli/mcp-bootstrap.d.ts +20 -0
- package/dist/types/cli/mcp-plugin-bootstrap.d.ts +2 -27
- package/dist/types/cli/media-runtime-facade.d.ts +20 -0
- package/dist/types/cli/memory-candidate-service.d.ts +74 -0
- package/dist/types/cli/memory-coordinator.d.ts +3 -3
- package/dist/types/cli/permission-approval-bridge.d.ts +15 -0
- package/dist/types/cli/permission-bootstrap.d.ts +6 -6
- package/dist/types/cli/permission-runtime-service.d.ts +9 -0
- package/dist/types/cli/pet-confirm-coordinator.d.ts +2 -2
- package/dist/types/cli/plugin-bootstrap.d.ts +14 -0
- package/dist/types/cli/product-coordinator.d.ts +25 -0
- package/dist/types/cli/project-command-service.d.ts +26 -0
- package/dist/types/cli/provider-core-facade.d.ts +1 -0
- package/dist/types/cli/runtime-hook-bootstrap.d.ts +2 -1
- package/dist/types/cli/runtime-watcher-bootstrap.d.ts +2 -2
- package/dist/types/cli/session-coordinator.d.ts +5 -3
- package/dist/types/cli/session-query-service.d.ts +23 -0
- package/dist/types/cli/skill-meta-subturn-service.d.ts +22 -0
- package/dist/types/cli/skill-meta-tool-bootstrap.d.ts +9 -7
- package/dist/types/cli/skills-query-service.d.ts +26 -0
- package/dist/types/cli/stdio-agent-session-bootstrap.d.ts +78 -0
- package/dist/types/cli/stdio-runtime-bootstrap.d.ts +16 -0
- package/dist/types/cli/stdio-runtime-services.d.ts +36 -0
- package/dist/types/cli/stdio-server.d.ts +19 -18
- package/dist/types/cli/test-support/tool-catalog-fixture.d.ts +3 -0
- package/dist/types/cli/tool-bootstrap-providers.d.ts +3 -0
- package/dist/types/cli/tool-bootstrap.d.ts +7 -20
- package/dist/types/cli/tool-catalog.d.ts +4 -2
- package/dist/types/cli/tool-invoker-factory.d.ts +2 -0
- package/dist/types/cli/tool-registration-modules.contract.test.d.ts +1 -0
- package/dist/types/cli/tool-registry-adapter.d.ts +5 -0
- package/dist/types/contracts/hooks.d.ts +1 -1
- package/dist/types/index.d.ts +1 -2
- package/dist/types/orchestration/product-persistence.d.ts +7 -3
- package/dist/types/orchestration/solo-persistence.d.ts +8 -4
- package/dist/types/orchestration/subagent/agent-registry.d.ts +3 -3
- package/dist/types/orchestration/tool-cascade.d.ts +12 -3
- package/dist/types/orchestration/tool-loop/tool-schema.d.ts +4 -1
- package/dist/types/orchestration/workflow/qla-executor-host.d.ts +3 -3
- package/dist/types/protocol/methods.d.ts +27 -1
- package/dist/types/protocol/wire/acp-protocol.d.ts +0 -2
- package/dist/types/protocol/wire/agent-rpc.d.ts +4 -4
- package/dist/types/protocol/wire/capability-manifest.d.ts +2 -1
- package/dist/types/protocol/wire/capability-transport.d.ts +2 -2
- package/dist/types/protocol/wire/chat-types.d.ts +4 -0
- package/dist/types/protocol/wire/index.d.ts +1 -1
- package/dist/types/protocol/wire/notification-payloads.d.ts +2 -1
- package/dist/types/protocol/wire/web-capability.d.ts +3 -0
- package/dist/types/runtime/community/community-consent-client.d.ts +21 -1
- package/dist/types/runtime/execution/dream-agent.d.ts +1 -1
- package/dist/types/runtime/execution/forked-agent.d.ts +1 -1
- package/dist/types/runtime/execution/tool-eligibility.d.ts +14 -37
- package/dist/types/runtime/execution/tool-eligibility.test.d.ts +1 -0
- package/dist/types/runtime/hooks/context-compression.d.ts +1 -1
- package/dist/types/runtime/infra/agent-paths.d.ts +0 -4
- package/dist/types/runtime/infra/default-path-service.d.ts +32 -0
- package/dist/types/runtime/infra/llmrouter-catalog.d.ts +6 -5
- package/dist/types/runtime/infra/model-registry.d.ts +1 -2
- package/dist/types/runtime/infra/process-config-port.d.ts +2 -0
- package/dist/types/runtime/infra/provider-catalog-adapter.d.ts +48 -0
- package/dist/types/runtime/infra/token-budget.d.ts +1 -1
- package/dist/types/runtime/ports/agent-runtime-ports.d.ts +76 -0
- package/dist/types/runtime/ports/config-port.d.ts +4 -0
- package/dist/types/runtime/ports/index.d.ts +8 -2
- package/dist/types/runtime/ports/model-transport-contracts.d.ts +125 -0
- package/dist/types/runtime/ports/path-service.d.ts +18 -0
- package/dist/types/runtime/ports/permission-contracts.d.ts +8 -3
- package/dist/types/runtime/ports/tool-contracts.d.ts +63 -2
- package/dist/types/runtime/session/session-persistence.d.ts +1 -1
- package/dist/types/runtime/tasks/task-types.d.ts +2 -1
- package/dist/types/skills/index.d.ts +1 -109
- package/dist/types/skills/mcp/mcp-manager.d.ts +13 -0
- package/dist/types/skills/memory/local-memory-provider.d.ts +0 -4
- package/dist/types/skills/memory/local-store-records.d.ts +184 -0
- package/dist/types/skills/memory/local-store.d.ts +9 -14
- package/dist/types/skills/memory/memory-db-path.d.ts +7 -0
- package/dist/types/skills/memory/memory-embedding-config.d.ts +31 -0
- package/dist/types/skills/memory/memory-provider-factory.d.ts +3 -14
- package/dist/types/skills/memory/memory-vector-utils.d.ts +2 -0
- package/dist/types/skills/memory/sqlite-memory-mappers.d.ts +6 -0
- package/dist/types/skills/memory/sqlite-memory-schema.d.ts +3 -0
- package/dist/types/skills/permissions/hook-runner.d.ts +1 -1
- package/dist/types/skills/permissions/rule-engine.d.ts +2 -5
- package/dist/types/skills/permissions/settings-watcher.d.ts +6 -35
- package/dist/types/skills/permissions/types.d.ts +1 -1
- package/dist/types/skills/plugins/plugin-loader.d.ts +10 -0
- package/dist/types/skills/portable-tool.d.ts +10 -0
- package/dist/types/skills/tools/cron-tool.d.ts +0 -20
- package/dist/types/skills/tools.d.ts +24 -59
- package/dist/types/transport/acp-server.d.ts +7 -7
- package/package.json +2 -1
- /package/dist/types/{cli/rpc-registry.community.test.d.ts → agent/tool-loop.contract.test.d.ts} +0 -0
package/dist/agent.js
CHANGED
|
@@ -1,23 +1,8 @@
|
|
|
1
|
-
var Jn=Object.defineProperty;var Qn=(t,e)=>()=>(t&&(e=t(t=0)),e);var Zn=(t,e)=>{for(var o in e)Jn(t,o,{get:e[o],enumerable:!0})};var Ln={};Zn(Ln,{resolveToolEligibility:()=>Vr});function zr(t,e){if(qr.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 Wr(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||zr(o,e.dangerousPatterns)?(r.push("dangerous_tool"),{level:3,reasons:r}):{level:2,reasons:r}}function Xr(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 Vr(t,e={}){let o=new Map,n=[],r=[],s=[];for(let l of t){let i=l.function.name,{level:p,reasons:h}=Wr(l,e),g=Xr(p),f={toolName:i,status:g,permissionLevel:p,approvalRequired:p===4,reasonCodes:h};o.set(i,f),p===5?r.push(f):(n.push(l),p===4&&s.push(f))}return{eligibleTools:n,blockedTools:r,approvalRequiredTools:s,eligibilityByName:o}}var qr,On=Qn(()=>{"use strict";qr=[/^(?: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 xs}from"@xiaozhiclaw/provider-core/gemini-schema-utils";function Ue(t,e,o,n){return{role:"assistant",content:e||null,tool_calls:t,...o&&o.length>0?{thinkingBlocks:o}:{},...n?{reasoning_content:n}:{}}}function ke(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 eo=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,X={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]},to=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,no=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,oo=512,ro=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var so=new Set([500,502,503,504,521,522,523,524,529]),io=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],ao=["upgrade your plan","upgrade plan","current plan","subscription"],lo=["daily","weekly","monthly"],co=["try again","retry","temporary","cooldown"],uo=["usage limit","rate limit","organization usage"],po=["organization","workspace"],go=["billing period","exceeded","reached","exhausted"],mo=/["']?(?: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,fo=/^(?: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 ho(t){return V(t,X.format)}function Et(t){return V(t,X.rateLimit)}function yo(t){return V(t,X.timeout)}function To(t){return eo.test(t)}function Fe(t){let e=t.toLowerCase();return e?t.length>oo?no.test(e):V(e,X.billing)?!0:to.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function wt(t){return V(t,X.authPermanent)}function bo(t){return V(t,X.auth)}function It(t){return V(t,X.overloaded)}function W(t,e){return e.some(o=>t.includes(o))}function Co(t){return W(t,io)||W(t,ao)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function ko(t){let e=W(t,lo),o=t.includes("spend limit")||t.includes("spending limit"),n=W(t,po);return W(t,co)&&W(t,uo)||e&&(t.includes("usage limit")||o)||e&&t.includes("limit")&&t.includes("reset")||n&&t.includes("limit")&&(o||W(t,go))}function Ro(t){return t.trim().toLowerCase().replace(fo,"").trim()}function Pt(t){let e=Ro(t);return!e||Co(e)?"billing":Et(e)||ko(e)?"rate_limit":"billing"}function _o(t){return mo.test(t)?Pt(t):null}function Lt(t){let e=t.match(ro);if(!e)return null;let o=Number(e[1]);return Number.isFinite(o)?{code:o,rest:(e[2]??"").trim()}:null}function So(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function xo(t){let e=t.trim();if(!e)return!1;let o=Lt(e);return o?so.has(o.code):!1}function Ot(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?Pt(e):"billing":t===429?"rate_limit":t===401||t===403?e&&wt(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&It(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&Fe(e)?"billing":"format":null}function vo(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 Mo(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 Nt(t){if(Mo(t))return"session_expired";if(vo(t))return"model_not_found";let e=_o(t);return e||(To(t)?Fe(t)?"billing":"rate_limit":Et(t)?"rate_limit":It(t)?"overloaded":xo(t)?Lt(t.trim())?.code===529?"overloaded":"timeout":So(t)?"timeout":ho(t)?"format":Fe(t)?"billing":yo(t)?"timeout":wt(t)?"auth_permanent":bo(t)?"auth":null)}var Ao={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"},Eo=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function Q(t,e){let o=Ot(t,e)??(e?Nt(e):null);return o?Ao[o]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function Be(t){return Eo.has(t)}var Dt=4,se=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 l;for(let g of r)if(g.role==="user"){l=g;break}if(l&&(s-=this.estimateTokens(l)),s<=0)return{messages:l?[...n,l]:n,droppedCount:r.length-(l?1:0),strategy:"sliding-window"};let i=[],p=0;for(let g=r.length-1;g>=0;g--){let f=r[g];if(f===l)continue;let M=this.estimateTokens(f);if(s-M<0&&p>=Dt)break;if(s-M<0&&p<Dt){i.unshift(f),p++;continue}s-=M,i.unshift(f),p++}let h=[...n];return l&&!i.includes(l)&&h.push(l),h.push(...i),{messages:h,droppedCount:r.length-(i.length+(l&&!i.includes(l)?1:0)),strategy:"sliding-window"}}};var ie=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:wo(s.content,this.maxToolResultChars)})),droppedCount:n,strategy:"tool-result-trim"}}};function wo(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
|
-
`),o.lastIndexOf(`]
|
|
3
|
-
`));if(s>e*.5)return o.slice(0,s+1)+`
|
|
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 $e(...t){return{compress(e,o){let n=e,r=0,s=[];for(let l of t){let i=l.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 Ut={modelContextWindow:128e3,targetUsageRatio:.75,minBudget:16e3,maxBudget:12e4};function je(t={}){let e={...Ut,...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 ae=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,l=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&&l++;return{totalCompressions:e,totalLlmCalls:s,totalCacheInvalidations:l,averageCompressionRatio:o/e,averageLatencyMs:n/e,totalTokensSaved:r,recentEvents:this.events.slice(-10)}}reset(){this.events.length=0}},le=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 Ft(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}var Io=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"]),Y=class{constructor(e=20,o=Ft){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||!Io.has(i.name)||i.content.length<=200)return i;let h=this.estimateTokens(i);return s+=h,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 Ge(t,e,o=Ft){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 l=r>0?{role:"system",content:`[${r} messages removed by snip]`}:void 0;return{messages:s,tokensFreed:n,removedCount:r,boundaryMessage:l}}function He(){return{stages:[]}}function qe(t,e,o){let n=o?.thresholdMessages??40;if(t.filter(i=>i.role!=="system").length<=n)return{messages:t,stagedCount:0};let s=Bt(t,e),l=Po(s,e,n);if(l.length===0)return{messages:s,stagedCount:0};for(let i of l)e.stages.push(i);return s=Bt(t,e),{messages:s,stagedCount:l.length}}function ze(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:$t(t,e),committed:o}}function Bt(t,e){return e.stages.filter(n=>n.committed).length===0?t:$t(t,e)}function $t(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,l]=r.range;if(s>=n.length)continue;let i=Math.min(l,n.length),p={role:"system",content:r.summary};n.splice(s,i-s,p)}return n}function Po(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]}`)),l=-1,i=0;for(let p=0;p<n;p++){let h=t[p];if(h.role==="tool"||h.role==="assistant"&&typeof h.content=="string"&&h.content==="")l<0&&(l=p),i++;else{if(i>=3){let f=`${l}-${l+i}`;s.has(f)||r.push({id:`collapse_${l}_${l+i}`,range:[l,l+i],summary:`[${i} tool results collapsed]`,committed:!1})}l=-1,i=0}}if(i>=3){let p=`${l}-${l+i}`;s.has(p)||r.push({id:`collapse_${l}_${l+i}`,range:[l,l+i],summary:`[${i} tool results collapsed]`,committed:!1})}return r}import{existsSync as Ve,readFileSync as cn,writeFileSync as Lo,readdirSync as un,mkdirSync as Oo}from"node:fs";import{join as Ye,dirname as No}from"node:path";var jt=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),Kt=3,Gt=2,Re=2,Ht=128e3,qt=13e3,zt=16384,Wt=65536,Xt=3,Vt=65536,We=500,Yt=3,Jt=5e4,Qt=2e5,Xe=2e3,Zt=3e4,en=3,ce=2;var tn=20;var nn=3,on=2,rn=300*1e3,sn=3,an=720*60*60*1e3;var Ps=300*1e3;var Ls=3600*1e3;var Os=50*1024,Ns=500*1024,Ds=500*1024*1024,Us=50*1024*1024;var Fs=60*1024;var dn=0;var Do="skill-patterns.json";function pn(t){return Ye(t,".qlogicagent",Do)}function Uo(t){let e=pn(t);try{return JSON.parse(cn(e,"utf8"))}catch{return{version:1,patterns:{}}}}function ln(t,e){let o=pn(t);Oo(No(o),{recursive:!0}),Lo(o,JSON.stringify(e,null,2),"utf8")}function Fo(t){let e=Date.now()-an;for(let[o,n]of Object.entries(t.patterns))new Date(n.lastSeen).getTime()<e&&delete t.patterns[o]}function gn(t,e){if(e.length===0)return!1;let o=_e(e),n=Uo(t);Fo(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 ln(t,n),!1;s.count++,s.lastSeen=r;let l=s.count>=sn;return l&&(s.promoted=!0),ln(t,n),l}function _e(t){return[...t].sort().join("+")}function Bo(t,e){if(!Ve(e))return null;let o=_e(t);try{let n=un(e,{withFileTypes:!0});for(let r of n){if(!r.isDirectory())continue;let s=Ye(e,r.name,"SKILL.md");try{let i=cn(s,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(i){let p=i[1].split(`
|
|
8
|
-
`).map(h=>h.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(_e(p)===o)return r.name}}catch{}}}catch{}return null}function $o(t){if(!Ve(t))return 0;try{return un(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&Ve(Ye(t,e.name,"SKILL.md"))).length}catch{return 0}}function jo(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<nn||t.distinctToolCount<on||Date.now()-dn<rn||e?.projectSkillsDir&&($o(e.projectSkillsDir)>=tn||e.tools.length>0&&Bo(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!gn(e.projectRoot,e.tools))}function Ko(t){return t.existingSkillName?t.feedback==="negative":!1}function Se(t,e){return Ko(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:jo(t,e)?(dn=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 mn(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 Go(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Ho(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function qo(t){if(!t.eligibility?.length)return[...t.tools];let e=Ho(t.eligibility);return t.tools.filter(o=>{let n=mn(o);if(!n)return!1;let r=e.get(n);return!r||Go(r.status)})}function zo(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 Je(t){let e=zo({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),o=e.normalizedToolChoice,n=[...e.warnings],r=qo({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,l=typeof s?.name=="string"?s.name.trim():"";if(!l)throw new Error("tool_choice.function.name is required");let i=r.filter(p=>mn(p)===l);if(i.length===0)throw new Error(`tool_choice requested unknown tool: ${l}`);return{tools:i,normalizedToolChoice:{type:"function",function:{name:l}},extraSystemPrompt:`You must call the ${l} tool before responding.`,warnings:n}}return{tools:r,normalizedToolChoice:o,warnings:n}}var Wo=["stop","aborted","timeout","cancelled","interrupted","error"],Xo=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function fn(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function Vo(t,e){return{...t,content:[...fn(t.content),...fn(e.content)]}}function Yo(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 Jo(t){return new Set((t??Wo).map(e=>e.trim().toLowerCase()))}function Qo(t,e){return t?Jo(e).has(t.trim().toLowerCase()):!1}function Qe(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(h=>Yo(h));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(h=>typeof h.id=="string"&&r.has(h.id));if(p.length===0){let{tool_calls:h,...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 l=[];for(let i of s){let p=l.length>0?l[l.length-1]:void 0;if(i.role==="user"&&p?.role==="user"){l[l.length-1]=Vo(p,i);continue}l.push(i)}return l}function Ze(t,e){return Qo(e?.stopReason,e?.forcedStopReasons)?t.map(o=>{if(o.role!=="assistant")return{...o};let n={...o};for(let r of Xo)delete n[r];return n}):[...t]}function et(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 l of s.tool_calls)typeof l.id!="string"||!l.id||n.has(l.id)||(n.add(l.id),r.push({role:"tool",tool_call_id:l.id,content:o}));return r}function tt(t,e){let o=Qe(t),n=Ze(o,e);return et(n,e)}function Zo(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 er(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 tr(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function nt(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 xe(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 ve(t){let e=[],o=Qe(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=Ze(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 r=et(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:tr({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:r,pendingToolCallIds:Zo(r),completedToolCallIds:er(r)}),recoveryActions:e}}var nr=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function ot(t){return t?nr.has(t):!0}function rt(t){return t===429||t===529}function Me(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 Ys={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Ae(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ue=class extends Error{constructor(o,n){super(`Model fallback triggered: ${o} -> ${n}`);this.originalModel=o;this.fallbackModel=n;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function st(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function it(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 at(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 lt(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 ct(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var rr={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function ut(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function Z(t,e=rr){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}import{accumulateToolCalls as Qr}from"@xiaozhiclaw/provider-core";function Ee(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}:{}}}import{mkdir as dr,writeFile as pr}from"fs/promises";import{join as hn}from"path";import{tmpdir as gr}from"os";var mr="tool-results",yn="<persisted-output>",fr="</persisted-output>";function Tn(){return{seenIds:new Set,replacements:new Map}}function bn(t){return hn(gr(),"qlogicagent-sessions",t,mr)}async function hr(t){try{await dr(bn(t),{recursive:!0})}catch{}}function yr(t,e){let o=e.replace(/[^a-zA-Z0-9_-]/g,"_");return hn(bn(t),`${o}.txt`)}function Tr(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 Cn(t){return t.includes(yn)}async function kn(t,e,o){await hr(o);let n=yr(o,e);try{await pr(n,t,{encoding:"utf-8",flag:"wx"})}catch(l){if(l.code!=="EEXIST")return null}let{preview:r,hasMore:s}=Tr(t,Xe);return{filepath:n,originalSize:t.length,preview:r,hasMore:s}}function Rn(t){let e=`${yn}
|
|
10
|
-
`;return e+=`Output too large (${t.originalSize} chars). Full output saved to: ${t.filepath}
|
|
1
|
+
function xe(e,t,r,o){return{role:"assistant",content:t||null,tool_calls:e,...r&&r.length>0?{thinkingBlocks:r}:{},...o?{reasoning_content:o}:{}}}function pe(e,t){let r=t.ok?typeof t.payload=="string"?t.payload:JSON.stringify(t.payload??""):`Error: ${t.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:e,content:r,...!t.ok&&{is_error:!0},...t.toolReferences?.length?{toolReferences:t.toolReferences}:{},...t.imageUrls?.length?{imageUrls:t.imageUrls}:{}}}var go=/\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]},fo=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,yo=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,To=512,ho=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var Co=new Set([500,502,503,504,521,522,523,524,529]),ko=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],Ro=["upgrade your plan","upgrade plan","current plan","subscription"],bo=["daily","weekly","monthly"],_o=["try again","retry","temporary","cooldown"],xo=["usage limit","rate limit","organization usage"],So=["organization","workspace"],Mo=["billing period","exceeded","reached","exhausted"],Ao=/["']?(?: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,vo=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function z(e,t){if(!e)return!1;let r=e.toLowerCase();return t.some(o=>o instanceof RegExp?o.test(r):r.includes(o))}function Eo(e){return z(e,q.format)}function ut(e){return z(e,q.rateLimit)}function Io(e){return z(e,q.timeout)}function wo(e){return go.test(e)}function Se(e){let t=e.toLowerCase();return t?e.length>To?yo.test(t):z(t,q.billing)?!0:fo.test(e)?t.includes("upgrade")||t.includes("credits")||t.includes("payment")||t.includes("plan"):!1:!1}function dt(e){return z(e,q.authPermanent)}function Lo(e){return z(e,q.auth)}function pt(e){return z(e,q.overloaded)}function H(e,t){return t.some(r=>e.includes(r))}function Po(e){return H(e,ko)||H(e,Ro)&&e.includes("limit")||e.includes("billing hard limit")||e.includes("hard limit reached")||e.includes("maximum allowed")&&e.includes("limit")}function Oo(e){let t=H(e,bo),r=e.includes("spend limit")||e.includes("spending limit"),o=H(e,So);return H(e,_o)&&H(e,xo)||t&&(e.includes("usage limit")||r)||t&&e.includes("limit")&&e.includes("reset")||o&&e.includes("limit")&&(r||H(e,Mo))}function No(e){return e.trim().toLowerCase().replace(vo,"").trim()}function mt(e){let t=No(e);return!t||Po(t)?"billing":ut(t)||Oo(t)?"rate_limit":"billing"}function Do(e){return Ao.test(e)?mt(e):null}function gt(e){let t=e.match(ho);if(!t)return null;let r=Number(t[1]);return Number.isFinite(r)?{code:r,rest:(t[2]??"").trim()}:null}function Fo(e){if(!e)return!1;let t=e.toLowerCase();return t.includes('"type":"api_error"')&&t.includes("internal server error")}function Bo(e){let t=e.trim();if(!t)return!1;let r=gt(t);return r?Co.has(r.code):!1}function ft(e,t){return typeof e!="number"||!Number.isFinite(e)?null:e===402?t?mt(t):"billing":e===429?"rate_limit":e===401||e===403?t&&dt(t)?"auth_permanent":"auth":e===408?"timeout":e===503?t&&pt(t)?"overloaded":"timeout":e===502||e===504?"timeout":e===529?"overloaded":e===400?t&&Se(t)?"billing":"format":null}function Uo(e){if(!e)return!1;let t=e.toLowerCase();return!!(t.includes("unknown model")||t.includes("model not found")||t.includes("model_not_found")||t.includes("not_found_error")||t.includes("does not exist")&&t.includes("model")||t.includes("invalid model")&&!t.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(e)||/\b404\b/.test(e)&&/not[-_ ]?found/i.test(e))}function $o(e){if(!e)return!1;let t=e.toLowerCase();return t.includes("session not found")||t.includes("session does not exist")||t.includes("session expired")||t.includes("session invalid")||t.includes("conversation not found")||t.includes("conversation does not exist")||t.includes("conversation expired")||t.includes("conversation invalid")||t.includes("no such session")||t.includes("invalid session")||t.includes("session id not found")||t.includes("conversation id not found")}function yt(e){if($o(e))return"session_expired";if(Uo(e))return"model_not_found";let t=Do(e);return t||(wo(e)?Se(e)?"billing":"rate_limit":ut(e)?"rate_limit":pt(e)?"overloaded":Bo(e)?gt(e.trim())?.code===529?"overloaded":"timeout":Fo(e)?"timeout":Eo(e)?"format":Se(e)?"billing":Io(e)?"timeout":dt(e)?"auth_permanent":Lo(e)?"auth":null)}var jo={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"},Go=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function K(e,t){let r=ft(e,t)??(t?yt(t):null);return r?jo[r]:typeof e=="number"&&e>=400&&e<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function Me(e){return Go.has(e)}function Tt(e){let t=typeof e.content=="string"?e.content:e.content!=null?JSON.stringify(e.content):"";return Math.ceil(t.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"]),ee=class{constructor(t=20,r=Tt){this.preserveRecentCount=t;this.estimateTokens=r}preserveRecentCount;estimateTokens;compress(t,r){if(t.length<=this.preserveRecentCount)return{messages:t,droppedCount:0,strategy:"micro-compact"};let o=t.length-this.preserveRecentCount,n=0,l=0;return{messages:t.map((a,m)=>{if(m>=o||a.role!=="tool"||typeof a.content!="string"||!a.name||!Ho.has(a.name)||a.content.length<=200)return a;let T=this.estimateTokens(a);return l+=T,n++,{...a,content:`[result cleared \u2014 ${a.content.length} chars]`}}),droppedCount:n,strategy:"micro-compact",metrics:n>0?{tokensBefore:0,tokensAfter:0,compressionRatio:0,latencyMs:0,usedLlm:!1,cacheInvalidated:!1}:void 0}}};function Ae(e,t,r=Tt){if(t.size===0)return{messages:e,tokensFreed:0,removedCount:0};let o=0,n=0,l=[];for(let a of e){let m=a.tool_call_id??"";if(m&&t.has(m)){o+=r(a),n++,t.delete(m);continue}l.push(a)}let d=n>0?{role:"system",content:`[${n} messages removed by snip]`}:void 0;return{messages:l,tokensFreed:o,removedCount:n,boundaryMessage:d}}function ve(){return{stages:[]}}function Ee(e,t,r){let o=r?.thresholdMessages??40;if(e.filter(a=>a.role!=="system").length<=o)return{messages:e,stagedCount:0};let l=ht(e,t),d=qo(l,t,o);if(d.length===0)return{messages:l,stagedCount:0};for(let a of d)t.stages.push(a);return l=ht(e,t),{messages:l,stagedCount:d.length}}function Ie(e,t){let r=0;for(let o of t.stages)o.committed||(o.committed=!0,r++);return r===0?{messages:e,committed:0}:{messages:Ct(e,t),committed:r}}function ht(e,t){return t.stages.filter(o=>o.committed).length===0?e:Ct(e,t)}function Ct(e,t){let r=t.stages.filter(n=>n.committed).sort((n,l)=>l.range[0]-n.range[0]),o=[...e];for(let n of r){let[l,d]=n.range;if(l>=o.length)continue;let a=Math.min(d,o.length),m={role:"system",content:n.summary};o.splice(l,a-l,m)}return o}function qo(e,t,r){let o=Math.max(0,e.length-Math.floor(r/2)),n=[],l=new Set(t.stages.map(m=>`${m.range[0]}-${m.range[1]}`)),d=-1,a=0;for(let m=0;m<o;m++){let T=e[m];if(T.role==="tool"||T.role==="assistant"&&typeof T.content=="string"&&T.content==="")d<0&&(d=m),a++;else{if(a>=3){let b=`${d}-${d+a}`;l.has(b)||n.push({id:`collapse_${d}_${d+a}`,range:[d,d+a],summary:`[${a} tool results collapsed]`,committed:!1})}d=-1,a=0}}if(a>=3){let m=`${d}-${d+a}`;l.has(m)||n.push({id:`collapse_${d}_${d+a}`,range:[d,d+a],summary:`[${a} tool results collapsed]`,committed:!1})}return n}import{existsSync as Le,readFileSync as Ut,writeFileSync as zo,readdirSync as $t,mkdirSync as Ko}from"node:fs";import{join as Pe,dirname as Wo}from"node:path";var kt=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),Rt=3,bt=2,me=2,_t=128e3,xt=13e3,St=16384,Mt=65536,At=3,vt=65536,we=500,Et=3;var It=3e4,wt=3,te=2;var Lt=20;var Pt=3,Ot=2,Nt=300*1e3,Dt=3,Ft=720*60*60*1e3;var Gn=300*1e3;var Hn=3600*1e3;var qn=50*1024,zn=500*1024,Kn=500*1024*1024,Wn=50*1024*1024;var Xn=60*1024;var jt=0;var Xo="skill-patterns.json";function Gt(e){return Pe(e,".qlogicagent",Xo)}function Yo(e){let t=Gt(e);try{return JSON.parse(Ut(t,"utf8"))}catch{return{version:1,patterns:{}}}}function Bt(e,t){let r=Gt(e);Ko(Wo(r),{recursive:!0}),zo(r,JSON.stringify(t,null,2),"utf8")}function Vo(e){let t=Date.now()-Ft;for(let[r,o]of Object.entries(e.patterns))new Date(o.lastSeen).getTime()<t&&delete e.patterns[r]}function Ht(e,t){if(t.length===0)return!1;let r=ge(t),o=Yo(e);Vo(o);let n=new Date().toISOString(),l=o.patterns[r];if(l||(l={signature:r,count:0,firstSeen:n,lastSeen:n,promoted:!1},o.patterns[r]=l),l.promoted)return Bt(e,o),!1;l.count++,l.lastSeen=n;let d=l.count>=Dt;return d&&(l.promoted=!0),Bt(e,o),d}function ge(e){return[...e].sort().join("+")}function Jo(e,t){if(!Le(t))return null;let r=ge(e);try{let o=$t(t,{withFileTypes:!0});for(let n of o){if(!n.isDirectory())continue;let l=Pe(t,n.name,"SKILL.md");try{let a=Ut(l,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(a){let m=a[1].split(`
|
|
2
|
+
`).map(T=>T.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(ge(m)===r)return n.name}}catch{}}}catch{}return null}function Zo(e){if(!Le(e))return 0;try{return $t(e,{withFileTypes:!0}).filter(t=>t.isDirectory()&&Le(Pe(e,t.name,"SKILL.md"))).length}catch{return 0}}function Qo(e,t){return!(!e.ok||e.existingSkillName||!e.multiStep||e.toolCallCount<Pt||e.distinctToolCount<Ot||Date.now()-jt<Nt||t?.projectSkillsDir&&(Zo(t.projectSkillsDir)>=Lt||t.tools.length>0&&Jo(t.tools,t.projectSkillsDir))||t?.projectRoot&&t.tools.length>0&&!Ht(t.projectRoot,t.tools))}function en(e){return e.existingSkillName?e.feedback==="negative":!1}function fe(e,t){return en(e)?{type:"skill.improve",skillName:e.existingSkillName,reason:"negative user feedback on existing skill execution"}:Qo(e,t)?(jt=Date.now(),{type:"skill.create",suggestedName:t.suggestedName??`auto-skill-${t.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${t.tools.join(", ")}`,tools:t.tools,stepCount:e.toolCallCount}):null}function qt(e){return e.function&&typeof e.function=="object"&&typeof e.function.name=="string"?e.function.name.trim():typeof e.name=="string"?e.name.trim():""}function tn(e){return e==="enabled-eligible"||e==="installed-awaiting-approval"}function on(e){return new Map((e??[]).map(t=>[t.toolName,t]))}function nn(e){if(!e.eligibility?.length)return[...e.tools];let t=on(e.eligibility);return e.tools.filter(r=>{let o=qt(r);if(!o)return!1;let n=t.get(o);return!n||tn(n.status)})}function rn(e){let t=[],r=e.compatibility??{},o=e.toolChoice;if(e.thinkingEnabled&&r.requireAutoWhenThinking){let n=typeof o=="object"&&o&&!Array.isArray(o)?String(o.type??""):o;n&&n!=="auto"&&n!=="none"&&(t.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),o="auto")}if(o==="required"&&r.allowRequiredToolChoice===!1){let n=r.requiredFallback??"auto";t.push(`tool_choice=required is not supported by this provider; downgraded to ${n}.`),o=n}if(o&&typeof o=="object"&&!Array.isArray(o)&&o.type==="function"&&r.allowNamedToolChoice===!1){let n=r.namedFallback??"required";t.push(`named tool_choice is not supported by this provider; downgraded to ${n}.`),o=n}return{normalizedToolChoice:o,warnings:t}}function Oe(e){let t=rn({toolChoice:e.toolChoice,thinkingEnabled:e.thinkingEnabled,compatibility:e.compatibility}),r=t.normalizedToolChoice,o=[...t.warnings],n=nn({tools:e.tools,eligibility:e.eligibility});if(!r||r==="auto")return{tools:n,normalizedToolChoice:r,warnings:o};if(r==="none")return{tools:[],normalizedToolChoice:"none",warnings:o};if(r==="required"){if(n.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:n,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:o}}if(typeof r=="object"&&!Array.isArray(r)&&r.type==="function"){let l=r.function??void 0,d=typeof l?.name=="string"?l.name.trim():"";if(!d)throw new Error("tool_choice.function.name is required");let a=n.filter(m=>qt(m)===d);if(a.length===0)throw new Error(`tool_choice requested unknown tool: ${d}`);return{tools:a,normalizedToolChoice:{type:"function",function:{name:d}},extraSystemPrompt:`You must call the ${d} tool before responding.`,warnings:o}}return{tools:n,normalizedToolChoice:r,warnings:o}}var sn=["stop","aborted","timeout","cancelled","interrupted","error"],an=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function zt(e){return e==null?[]:typeof e=="string"?e.length>0?[{type:"text",text:e}]:[]:Array.isArray(e)?e:[{type:"text",text:String(e)}]}function ln(e,t){return{...e,content:[...zt(e.content),...zt(t.content)]}}function cn(e){if(!e||typeof e!="object")return!1;if(e.function&&typeof e.function=="object"){let t=e.function.name;if(typeof t=="string"&&t.length>0)return!0}return typeof e.name=="string"&&e.name.length>0}function un(e){return new Set((e??sn).map(t=>t.trim().toLowerCase()))}function dn(e,t){return e?un(t).has(e.trim().toLowerCase()):!1}function Ne(e){if(!Array.isArray(e)||e.length===0)return[...e];let t=e.map(a=>{if(a.role==="assistant"&&Array.isArray(a.tool_calls)){let m=a.tool_calls.filter(T=>cn(T));return{...a,...m.length>0?{tool_calls:m}:{tool_calls:void 0}}}return{...a}}),r=new Set;for(let a of t)if(!(a.role!=="assistant"||!Array.isArray(a.tool_calls)))for(let m of a.tool_calls)typeof m.id=="string"&&m.id&&r.add(m.id);let o=t.filter(a=>a.role!=="tool"?!0:!!(a.tool_call_id&&r.has(a.tool_call_id))),n=new Set;for(let a of o)a.role==="tool"&&typeof a.tool_call_id=="string"&&a.tool_call_id&&n.add(a.tool_call_id);let l=[];for(let a of o){if(a.role==="assistant"&&Array.isArray(a.tool_calls)&&a.tool_calls.length>0){let m=a.tool_calls.filter(T=>typeof T.id=="string"&&n.has(T.id));if(m.length===0){let{tool_calls:T,...C}=a;C.content!=null&&C.content!==""&&l.push(C);continue}if(m.length<a.tool_calls.length){l.push({...a,tool_calls:m});continue}}l.push(a)}let d=[];for(let a of l){let m=d.length>0?d[d.length-1]:void 0;if(a.role==="user"&&m?.role==="user"){d[d.length-1]=ln(m,a);continue}d.push(a)}return d}function De(e,t){return dn(t?.stopReason,t?.forcedStopReasons)?e.map(r=>{if(r.role!=="assistant")return{...r};let o={...r};for(let n of an)delete o[n];return o}):[...e]}function Fe(e,t){let r=t?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",o=new Set;for(let l of e)l.role==="tool"&&typeof l.tool_call_id=="string"&&l.tool_call_id&&o.add(l.tool_call_id);let n=[];for(let l of e)if(n.push({...l}),!(l.role!=="assistant"||!Array.isArray(l.tool_calls)||l.tool_calls.length===0))for(let d of l.tool_calls)typeof d.id!="string"||!d.id||o.has(d.id)||(o.add(d.id),n.push({role:"tool",tool_call_id:d.id,content:r}));return n}function Be(e,t){let r=Ne(e),o=De(r,t);return Fe(o,t)}function pn(e){let t=new Set,r=new Set;for(let o of e){if(o.role==="assistant"&&Array.isArray(o.tool_calls))for(let n of o.tool_calls)typeof n.id=="string"&&n.id&&t.add(n.id);o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&r.add(o.tool_call_id)}return[...t].filter(o=>!r.has(o))}function mn(e){let t=new Set;for(let r of e)r.role==="tool"&&typeof r.tool_call_id=="string"&&r.tool_call_id&&t.add(r.tool_call_id);return[...t]}function gn(e){return{round:e.round??0,maxRounds:e.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??[]],completedToolCallIds:[...e.completedToolCallIds??[]],lastStopReason:e.lastStopReason,replayMessages:[...e.replayMessages??[]]}}function Ue(e,t){return{round:e.round+1,maxRounds:e.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??e.pendingToolCallIds],completedToolCallIds:[...t.completedToolCallIds??e.completedToolCallIds],lastStopReason:t.lastStopReason??e.lastStopReason,replayMessages:[...t.replayMessages??e.replayMessages]}}function ye(e,t){return{round:e.round,maxRounds:e.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...t.completedToolCallIds??e.completedToolCallIds],lastStopReason:t.lastStopReason??e.lastStopReason,replayMessages:[...t.replayMessages??e.replayMessages]}}function Te(e){let t=[],r=Ne(e.replayMessages);r.length!==e.replayMessages.length&&t.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let o=De(r,e.options);o.some((l,d)=>l!==r[d])&&t.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let n=Fe(o,e.options);return n.length>o.length&&t.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:gn({maxRounds:e.maxRounds,round:e.round,lastStopReason:e.lastStopReason,replayMessages:n,pendingToolCallIds:pn(n),completedToolCallIds:mn(n)}),recoveryActions:t}}var fn=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function $e(e){return e?fn.has(e):!0}function je(e){return e===429||e===529}function he(e,t=500,r=32e3){let o=Math.min(t*Math.pow(2,e-1),r);return o+Math.floor(Math.random()*o*.25)}var ir={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Ce(){let e=process.env.QLOGICAGENT_PERSISTENT_RETRY;return e==="1"||e==="true"}var oe=class extends Error{constructor(r,o){super(`Model fallback triggered: ${r} -> ${o}`);this.originalModel=r;this.fallbackModel=o;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function Ge(e){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:e.maxOutputTokens,consecutiveTruncations:0,aborted:e.abortSignal?.aborted??!1}}function He(e,t){if(e.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let r=t.contextWindowTokens-t.responseBufferTokens-e.currentMaxOutputTokens,o=r>0?e.promptTokens/r*100:100;return e.promptTokens>=r?e.hasAttemptedReactiveCompact||!t.reactiveCompactEnabled?{level:"blocking",usagePercent:o,reason:"prompt_too_long"}:{level:"blocking",usagePercent:o,reason:"prompt_too_long"}:o>=85?{level:"warning",usagePercent:o,remainingTokens:r-e.promptTokens}:{level:"ok"}}function qe(e,t,r){let o=e.message?.toLowerCase()??"",n=e.status??0;return n===413||o.includes("prompt_too_long")||o.includes("context_length_exceeded")?!t.hasAttemptedReactiveCompact&&r.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:n>=500&&n<600?{action:"retry",reason:`server_error_${n}`}:n===429?{action:"retry",reason:"rate_limited"}:n===401||n===403?{action:"abort",reason:"auth_error"}:n===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:o||"unknown_error"}}function ze(e,t,r){if(!t.outputEscalationEnabled)return{shouldEscalate:!1,newMax:e.currentMaxOutputTokens};if(e.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:e.currentMaxOutputTokens};let o=Math.min(e.currentMaxOutputTokens*2,r);return o<=e.currentMaxOutputTokens?{shouldEscalate:!1,newMax:e.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:o}}function Ke(e,t){return e.aborted?!0:t.abortSignal?.aborted?(e.aborted=!0,!0):!1}var Tn={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function We(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function W(e,t=Tn){return!(e.attemptedThisTurn||e.consecutiveFailures>=t.maxConsecutiveFailures)}function Xe(e,t){let r=e.get(t.index)??{id:"",name:"",arguments:""};t.id&&(r.id=t.id),t.name&&(r.name=t.name),r.arguments+=t.arguments??"",e.set(t.index,r)}function Kt(e,t){let r=typeof t.message?.content=="string"?t.message.content:"",o=r?r.slice(0,2e3):void 0,n=t.details,l=typeof n?.stdout=="string"?n.stdout.slice(0,8e3):void 0,d=typeof n?.stderr=="string"?n.stderr.slice(0,4e3):void 0,a=typeof n?.exitCode=="number"?n.exitCode:void 0;return{type:"tool_result",turnId:e,callId:t.callId,name:t.toolName,ok:t.ok,error:t.error,outputPreview:o,durationMs:t.durationMs,exitCode:a,stdout:l,stderr:d,details:n}}var hn=new Set(["write","edit","patch","apply_patch"]);function Wt(e){let{turnId:t,result:r,toolCalls:o}=e;if(!r.ok)return[];let n=o.find(a=>a.id===r.callId);if(!n)return[];let l=[],d=Cn(n.function.arguments);if(!d)return l;if(r.toolName==="plan_mode"&&d.action==="exit"&&typeof d.plan=="string"&&d.plan.length>0&&l.push({type:"plan_update",turnId:t,slug:"approved-plan",content:d.plan}),hn.has(r.toolName)){let a=kn(d);a&&l.push({type:"artifact",turnId:t,artifactId:`artifact-${r.callId}`,artifactType:Rn(a),title:a.split(/[\\/]/).pop()||a,filePath:a,language:bn(a)})}return l}function Cn(e){try{return JSON.parse(e)}catch{return null}}function kn(e){return typeof e.file_path=="string"?e.file_path:typeof e.filePath=="string"?e.filePath:typeof e.path=="string"?e.path:void 0}function Rn(e){let t=e.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(t)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(t)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(t)?"diagram":["csv","tsv","xlsx","xls"].includes(t)?"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(t)?"code":"file"}function bn(e){let t=e.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"}[t]}var xn=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,Sn=new Set(["search","grep","glob","find","list","read","exec"]);function Xt(e){if(!Sn.has(e.toolName))return!1;let t=typeof e.message?.content=="string"?e.message.content.trim():"";return t.length>0&&t.length<200&&xn.test(t)}function Ye(e,t){for(let r=e.length-1;r>=0;r--){let o=e[r];if(!o||o.role!=="tool")continue;let n=typeof o.content=="string"?o.content:"";if(n.startsWith("Error: "))return n.slice(7).trim()}}function Yt(e){return typeof e=="number"&&Number.isFinite(e)&&e>=1?Math.min(Math.round(e),100):kt}function Vt(e){return e.filter(t=>t.role!=="assistant"?!0:!(typeof t.content=="string"&&t.content.trim()===""))}function X(e,t){let r=[];for(let o=e.length-1;o>=0;o--){let n=e[o];if(n.role==="tool"&&typeof n.content=="string")r.unshift(n.content.slice(0,500));else if(n.role==="assistant"){if(typeof n.content=="string"&&n.content.trim())return t.info("synthesizeFallbackContent: found assistant text, using it"),n.content;break}else break}return r.length>0?(t.info(`synthesizeFallbackContent: synthesized from ${r.length} tool result(s)`),r.join(`
|
|
11
3
|
|
|
12
|
-
`,e+=`Preview (first ${Xe} bytes):
|
|
13
|
-
`,e+=t.preview,e+=t.hasMore?`
|
|
14
|
-
...
|
|
15
|
-
`:`
|
|
16
|
-
`,e+=fr,e}async function _n(t,e,o,n=Jt){if(t.length<=n||Cn(t))return t;let r=await kn(t,e,o);return r?Rn(r):t.slice(0,n)+`
|
|
17
|
-
...[truncated ${t.length-n} chars]`}function br(t){let e=[],o=[];for(let n of t)n.role==="tool"&&typeof n.content=="string"&&n.tool_call_id?Cn(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 Cr(t,e){let o=[],n=[],r=[];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):r.push(s)}return{mustReapply:o,frozen:n,fresh:r}}function kr(t,e,o){let n=[...t].sort((l,i)=>i.size-l.size),r=[],s=e+t.reduce((l,i)=>l+i.size,0);for(let l of n){if(s<=o)break;r.push(l),s-=l.size}return r}async function Sn(t,e,o,n=Qt){let r=br(t);if(r.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,l=[];for(let g of r){let{mustReapply:f,frozen:M,fresh:_}=Cr(g,e);for(let R of f)s.set(R.toolCallId,R.replacement);if(_.length===0){for(let R of g)e.seenIds.add(R.toolCallId);continue}let b=M.reduce((R,O)=>R+O.size,0),S=_.reduce((R,O)=>R+O.size,0),x=b+S>n?kr(_,b,n):[],w=new Set(x.map(R=>R.toolCallId));for(let R of g)w.has(R.toolCallId)||e.seenIds.add(R.toolCallId);x.length>0&&l.push(...x)}if(s.size===0&&l.length===0)return{messages:t,newlyReplacedCount:0};let i=await Promise.all(l.map(async g=>{let f=await kn(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 M=Rn(f);s.set(g.toolCallId,M),e.replacements.set(g.toolCallId,M),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 Rr=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),_r=new Set(["bash","execute_command","Bash","shell"]),we=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??Rr,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:Ee(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:l,sessionId:i,turnId:p,log:h}=this.config,g=e.toolCall.function.name,f=!1,M=e.toolCall.function.arguments;if(l)try{let A=await l.invoke("tool.before_invoke",{sessionId:i,turnId:p,callId:e.id,toolName:g,arguments:Sr(M)});if(A.action==="abort"){let k=A.reason??"blocked by policy";h.info(`tool ${g} blocked: ${k}`),e.results.push({callId:e.id,toolName:g,ok:!1,error:k,blocked:!0,blockReason:k,message:Ee(e.id,{ok:!1,error:k})}),e.status="completed";return}A.action==="continue"&&A.context?.arguments&&(M=JSON.stringify(A.context.arguments))}catch{}let _=Date.now(),b=await s.invoke(p,g,M,this.siblingAbortController.signal),S=Math.max(0,Date.now()-_),x=this.getAbortReason();if(x&&!f){e.results.push(this.createSyntheticError(e,x)),e.status="completed";return}let w=!b.error,R=b.result;w&&R&&R.length>5e4&&(R=await _n(R,e.id,i));let O=Ee(e.id,{ok:w,payload:R,error:b.error,toolReferences:b.toolReferences,imageUrls:b.imageUrls});w||(f=!0,_r.has(g)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),l?.invoke(w?"tool.after_invoke":"tool.invoke_failed",{sessionId:i,turnId:p,callId:e.id,toolName:g,ok:w,...b.error?{error:b.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:g,ok:w,error:b.error,durationMs:S,details:b.details,message:O}),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 Sr(t){try{return JSON.parse(t)}catch{return}}import{readFile as la}from"node:fs/promises";import*as I from"node:fs";import{ProviderRegistry as wr,ProviderVariantResolver as Ir}from"@xiaozhiclaw/provider-core";import{homedir as xr}from"node:os";import{join as Ie}from"node:path";import{existsSync as Zi}from"node:fs";var vr=".qlogicagent";function xn(){return process.env.QLOGICAGENT_HOME||Ie(xr(),vr)}function vn(){return Ie(xn(),"settings.json")}function Mr(){let t=process.env.QLOGIC_LLMROUTER_USER_ID?.trim();if(t)return t;let e=process.env.QLOGIC_IMPLICIT_OWNER_ID?.trim();if(e)return e;let o=process.env.QLOGIC_DEVICE_ID?.trim();return o?`oc_${o}`:"oc_local"}function Ar(t){let e=t.trim();if(!e)throw new Error("ownerUserId is required for profile-scoped storage");return encodeURIComponent(e).replace(/\./g,"%2E")}function Er(t=Mr()){return Ie(xn(),"profiles",Ar(t))}function Mn(){return Ie(Er(),"settings.json")}var Pe=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 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: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(),l={id:s,key:o,label:n?.label,weight:n?.weight??1,enabled:n?.enabled??!0};return r.keys.push(l),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 l=this.runtimeStates.get(r.id)?.inFlight??0;(l<o||l===o&&r.weight>n.weight)&&(o=l,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 Pr=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],dt=class{keyPool;coreProviderRegistry=new wr;providerVariantResolver=new Ir(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=Mn(),this.keyPool=new Pe(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings}),this.hydrateCatalogModels()}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,l=r?.nativeModelId??n.nativeModelId??n.model,i=this.acquireKeyForProviderVariant(s);if(!i)return null;let{keyHandle:p,keyProviderId:h}=i,g=this.getProviderBaseUrl(s),f=this.getProviderBaseUrl(h);return{provider:s,model:l,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()}replaceProviderModels(e,o){let n=new Map;for(let[s,l]of this.models)l.provider!==e&&n.set(s,l);for(let s of o)s.provider===e&&n.set(s.id,{...s,enabled:this.modelEnabledOverrides.get(s.id)??s.enabled});let r=`${e}:`;for(let s of this.modelEnabledOverrides.keys())s.startsWith(r)&&!n.has(s)&&this.modelEnabledOverrides.delete(s);this.models=n;for(let[s,l]of Object.entries(this.bindings))l&&!this.models.has(l)&&delete this.bindings[s];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,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 Pr){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{I.existsSync(this.settingsPath)&&(e=JSON.parse(I.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(/[/\\][^/\\]+$/,"");I.existsSync(n)||I.mkdirSync(n,{recursive:!0}),I.writeFileSync(this.settingsPath,JSON.stringify(o,null,2),"utf-8")}load(){try{if(Lr(this.settingsPath),!I.existsSync(this.settingsPath))return!1;let e=I.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.hydrateCatalogModels(),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(!I.existsSync(this.settingsPath))return;let o=I.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}))}))}getKnownProviderDef(e){let o=this.coreProviderRegistry.getProvider(e);return o?{id:o.id,name:o.name,transport:o.transport,baseUrl:o.baseUrl,defaultModel:o.defaultModel,group:o.group,models:this.coreProviderRegistry.listModels(o.id).map(n=>({id:n.aliases?.[0]??n.id,name:n.name,contextWindow:n.contextWindow,maxOutput:n.maxOutput,streamRequired:n.streamRequired,vision:n.vision,mediaType:n.mediaType}))}:null}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:Ur(o,e.transport),capabilities:Fr(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)}hydrateCatalogModels(){let e=[];for(let n of this.coreProviderRegistry.listProviders())for(let r of this.coreProviderRegistry.listModels(n.id)){let s=r.aliases?.[0]??r.id,l=`${n.id}:${s}`;e.push({id:l,provider:n.id,model:s,displayName:r.name,purposes:Nr(r),baseUrl:n.baseUrl,enabled:this.modelEnabledOverrides.get(l)??!1,nativeModelId:r.id,transport:n.transport,contextWindow:r.contextWindow,maxOutput:r.maxOutput,streamRequired:r.streamRequired,capabilities:[...r.toolCall?["toolCall"]:[],...r.reasoning?["reasoning"]:[],...r.vision?["vision"]:[],...r.mediaType?[r.mediaType]:[]],pricing:{inputPer1M:r.costInput,outputPer1M:r.costOutput,cacheReadPer1M:r.costCacheRead,cacheWritePer1M:r.costCacheWrite}})}let o=new Map;for(let n of e)o.set(n.id,n);this.models=o}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{}}},Le=null;function gt(){return Le||(Le=new dt,Le.load()),Le}function Lr(t){let e=vn();if(t===e||!I.existsSync(e))return;let o=An(e);if(!En(o))return;let n=An(t);if(En(n))return;let r={...o,...n,providers:o.providers,models:o.models??n.models,bindings:Or(n)?n.bindings:o.bindings,migrations:{...pt(o.migrations)?o.migrations:{},...pt(n.migrations)?n.migrations:{},legacyGlobalSettingsImportedAt:new Date().toISOString()}},s=t.replace(/[/\\][^/\\]+$/,"");I.existsSync(s)||I.mkdirSync(s,{recursive:!0}),I.writeFileSync(t,JSON.stringify(r,null,2),"utf-8")}function An(t){try{return JSON.parse(I.readFileSync(t,"utf-8"))}catch{return{}}}function En(t){return Array.isArray(t.providers)&&t.providers.length>0}function Or(t){return pt(t.bindings)&&Object.keys(t.bindings).length>0}function pt(t){return!!t&&typeof t=="object"&&!Array.isArray(t)}function Nr(t){let e=[];switch((!t.mediaType||t.mediaType==="image_understanding"||t.mediaType==="video_understanding")&&e.push("textGeneration"),(t.vision||t.mediaType==="image_understanding")&&e.push("imageUnderstanding"),t.mediaType==="video_understanding"&&e.push("videoUnderstanding"),t.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function Dr(t){switch(t){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return t;default:return}}function Ur(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 Dr(e)}}function Fr(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 ht(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function mt(t){let e=0;for(let o of t)e+=ht(o);return e}var ft={"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 ft)return ft[t];let e=t.toLowerCase();for(let[o,n]of Object.entries(ft))if(e.startsWith(o.toLowerCase()))return n;return 128e3}var $r=8e3;var jr=new ae(200);var Kr=new le;function wn(){return Kr}function Gr(){return $e(new ie($r),new Y(20,ht),new se(ht))}var Hr=null;function In(t,e){let o=e?.budget??je({modelContextWindow:Br(e?.model)}),r=(e?.pipeline??Gr()).compress(t,o);if(r.droppedCount>0){let s=mt(t),l=mt(r.messages);jr.record({timestamp:Date.now(),strategy:r.strategy,tokensBefore:s,tokensAfter:l,droppedCount:r.droppedCount,latencyMs:r.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:r.metrics?.cacheInvalidated??!1,tier:Ke(s,o)})}return r.droppedCount>0&&Hr?.(r.droppedCount,mt(r.messages)),r}function Pn(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 Zr=new Set(["write","edit","patch","apply_patch"]);function es(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 ts(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 ns=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,os=new Set(["search","grep","glob","find","list","read","exec"]);function rs(t){if(!os.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&ns.test(e)}function Nn(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 ss(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):jt}function Dn(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 is(t){return t==="length"||t==="max_tokens"}function Un(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 as(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 ls(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 cs(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Fn(t,e,o,n){let{turnId:r,sessionId:s,messages:l,tools:i,model:p,apiKey:h,temperature:g=0,hooks:f,signal:M}=t,_={sessionId:s,turnId:r},b=t.maxTurns??0,S=t.querySource,{resolveToolEligibility:x}=await Promise.resolve().then(()=>(On(),Ln)),w=x(i,t.toolEligibilityContext),R=w.eligibleTools;for(let T of w.blockedTools)yield{type:"tool_blocked",turnId:r,callId:"",name:T.toolName,reason:"blocked-by-policy"};if(!R.length){yield*ds(r,p,l,h,g,M,e,n);return}let O=ss(t.maxRounds),A={contextWindowTokens:t.contextWindowTokens??Ht,responseBufferTokens:qt,maxOutputTokens:t.maxOutputTokens??zt,abortSignal:M,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},k=new Set,N=0,J=R,pe,ge=!1,yt=0,a={messages:[...l],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:st(A),reactiveCompactState:ut(),toolLoopState:ve({maxRounds:O,replayMessages:[...l]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:He(),currentModel:p,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:Tn(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},Tt=Math.max(b*5,200),bt=0;for(;;){if(bt++,bt>Tt){n.info(`hard iteration cap reached (${Tt}), forcing completion`);let c=a.finalText||de(a.messages,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}let{messages:T,maxOutputTokensRecoveryCount:ee,hasAttemptedReactiveCompact:Rs,maxOutputTokensOverride:Ct,turnCount:te,guardState:P,reactiveCompactState:q,collapseStore:Oe}=a,{toolLoopState:B}=a;if(pe){try{let c=await pe;c&&(yield{type:"tool_use_summary",turnId:r,summary:c})}catch{}pe=void 0}if(t.refreshTools&&te>1){let c=t.refreshTools();c!==J&&(J=c,n.debug(`tools refreshed: ${c.length} tools`))}if(ct(P,A)){n.info(`turn aborted by guard at turn ${te}`),yield{type:"error",turnId:r,error:"Turn aborted",code:"ABORTED",usage:a.totalUsage};return}let z=it(P,A);if(z.level==="blocking"){z.reason==="prompt_too_long"&&Z(q)&&(q.attemptedThisTurn=!0,P.hasAttemptedReactiveCompact=!0,n.info(`token budget blocking (${z.reason}), reactive compact needed`),yield{type:"recovery",turnId:r,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 L;{let c=await Sn(T,a.contentReplacementState,s);L=c.messages,c.newlyReplacedCount>0&&(n.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:r,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Ge(L,a.snipRemovedIds);L=c.messages,c.removedCount>0&&(n.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:r,action:"snip",detail:`${c.removedCount} messages`})}{let u=new Y().compress(L,0);u.droppedCount>0&&(L=u.messages,n.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(L=qe(L,Oe).messages,P.promptTokens>0){let c=A.contextWindowTokens*.75,u=wn().getActive(),d;u?d=await u.compressAsync(L,c,{model:a.currentModel,sessionId:s}):d=In(L,{budget:c,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",{..._,removedCount:d.droppedCount}).catch(()=>{}))}L=cs(L);let qn=t.toolChoice==="required"&&ge?"auto":t.toolChoice??"auto",me=Je({tools:J,toolChoice:qn}),ne=ve({maxRounds:O,replayMessages:L,lastStopReason:B.lastStopReason,options:{stopReason:B.lastStopReason}}),kt=me.extraSystemPrompt?[{role:"system",content:me.extraSystemPrompt},...ne.state.replayMessages]:ne.state.replayMessages;B=ne.state,ne.recoveryActions.length>0&&n.debug(`tool loop recovery: ${ne.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),n.debug(`turn ${te}, messages: ${kt.length}`),f?.invoke("turn.before_inference",{..._,model:a.currentModel}).catch(()=>{});let fe=!1,Rt=[],_t=new Map,St="stop",$,C=null,he=!1,oe=[],U=[];try{for await(let c of e.stream({model:a.currentModel,messages:kt,tools:me.tools,toolChoice:me.normalizedToolChoice??"auto",temperature:g,maxTokens:(Ct??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},h,M))switch(c.type){case"delta":Rt.push(c.text),!fe&&!(t.toolChoice==="required"&&!ge)&&(yield{type:"delta",turnId:r,text:c.text});break;case"tool_call_delta":fe=!0,Qr(_t,c);break;case"reasoning_delta":oe.push(c.text);break;case"reasoning_block_complete":c.signature&&U.push({thinking:oe.join(""),signature:c.signature}),oe.length=0;break;case"usage":$={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:r,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:r,message:`${c.toolType}: ${c.event}`};break;case"done":St=c.finishReason;break}if(fe||f?.invoke("turn.after_inference",{..._,model:a.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=a.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...L],model:c,sessionId:s})}catch{}}}catch(c){if(c instanceof ue&&t.fallbackModel){n.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:r,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),d=typeof c?.status=="number"?c.status:void 0;if(!d&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let y=(a.consecutiveApiRetries??0)+1;if(y>ce){n.info(`stale connection retry limit reached (${ce}), 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:y,transition:void 0};continue}let m=ls({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(rt(d)){a.consecutive529Errors++;let y=2,E=t.fallbackModel&&a.currentModel!==t.fallbackModel;if(a.consecutive529Errors>y&&!E&&!Ae()){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>=en&&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(Ae()){let D=Me(a.consecutive529Errors);n.info(`persistent retry: waiting ${D}ms (attempt ${a.consecutive529Errors})`);let F=D;for(;F>0;){if(M?.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(F/1e3)}s (${d})`};let j=Math.min(F,Zt);await new Promise(K=>setTimeout(K,j)),F-=j}a={...a,transition:void 0};continue}if(ot(S)){let F=as({status:d,message:u})??Me(a.consecutive529Errors);n.info(`transient ${d}: retry in ${F}ms`),yield{type:"recovery",turnId:r,action:"retry",detail:`${d} retry in ${F}ms`},await new Promise(j=>setTimeout(j,F)),a={...a,transition:void 0};continue}n.info(`background source ${S}: not retrying ${d}`)}C={status:d,message:u}}if(C&&f?.invoke("turn.after_inference",{..._,model:a.currentModel,response:{error:C.message}}).catch(()=>{}),C)if(Dn(C))he=!0,n.info(`withheld prompt_too_long error (status=${C.status})`);else if(Un(C))he=!0,n.info(`withheld media_size error (status=${C.status})`);else{let c=at({status:C.status??500,message:C.message},P,A);if(c.action==="reactive_compact"&&Z(q)&&(q.attemptedThisTurn=!0,P.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:r,action:"reactive_compact",detail:`API ${C.status??500}: ${C.message}`}),c.action==="retry"){let d=(a.consecutiveApiRetries??0)+1;if(d>ce){n.info(`API retry limit reached (${ce}), aborting`);let m=Q(C.status,C.message);yield{type:"error",turnId:r,error:C.message,code:m,usage:a.totalUsage};return}yield{type:"recovery",turnId:r,action:"retry",detail:c.reason},a={...a,consecutiveApiRetries:d,transition:void 0};continue}let u=Q(C.status,C.message);f?.invoke("stop.failure",{sessionId:s,reason:u,error:C.message}).catch(()=>{}),yield{type:"error",turnId:r,error:C.message,code:u,usage:a.totalUsage};return}$&&(a.totalUsage.inputTokens+=$.inputTokens,a.totalUsage.outputTokens+=$.outputTokens,$.reasoningTokens&&(a.totalUsage.reasoningTokens=(a.totalUsage.reasoningTokens??0)+$.reasoningTokens),$.cacheRead&&(a.totalUsage.cacheRead=(a.totalUsage.cacheRead??0)+$.cacheRead),$.cacheWrite&&(a.totalUsage.cacheWrite=(a.totalUsage.cacheWrite??0)+$.cacheWrite)),$?.inputTokens&&(P.promptTokens=$.inputTokens);let xt=Rt.join("");xt&&(a.finalText=xt);let G=[..._t.values()].map(c=>({id:c.id||`tc_${r}_${te}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(G.length===0&&!fe){if(t.toolChoice==="required"&&!ge&&J.length>0&&yt<2){yt++;let d=J.map(m=>m.function.name).filter(Boolean).slice(0,8).join(", ");a={...a,messages:[...T,{role:"user",content:`You must call one available tool before answering. Available tools for this request: ${d}. Do not answer from memory, prior context, or guesses.`}],finalText:"",transition:{reason:"next_turn"}};continue}if(he&&C&&Dn(C)){if(a.transition?.reason!=="collapse_drain_retry"){let d=ze(L,Oe);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(Z(q)){q.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:C.message}).catch(()=>{}),yield{type:"error",turnId:r,error:C.message,code:"PROMPT_TOO_LONG",usage:a.totalUsage};return}if(he&&C&&Un(C)){if(Z(q)){q.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:C.message}).catch(()=>{}),yield{type:"error",turnId:r,error:C.message,code:"IMAGE_ERROR",usage:a.totalUsage};return}if(is(St)){P.consecutiveTruncations+=1;let d=t.modelMaxOutputTokens??Wt,m=lt(P,A,d);if(m.shouldEscalate&&Ct===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:Vt,transition:{reason:"max_output_tokens_escalate"}};continue}if(ee<Xt){let y={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 #${ee+1}`),yield{type:"recovery",turnId:r,action:"max_output_tokens_recovery",detail:`attempt ${ee+1}`},a={...a,messages:[...L,y],maxOutputTokensRecoveryCount:ee+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:ee+1}};continue}n.info("max_output_tokens recovery exhausted, completing with partial content")}else P.consecutiveTruncations=0;if(B=xe(B,{replayMessages:T,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 y={role:"user",content:m},E={role:"assistant",content:a.finalText,...U.length>0&&{thinkingBlocks:[...U]}};a={...a,messages:[...T,E,y],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,y=d-a.lastBudgetGlobalTokens,E=a.budgetContinuationCount>=Yt&&y<We&&a.lastBudgetDeltaTokens<We;if(E&&n.info(`token budget early stop: diminishing returns at ${Math.round(m)}% (delta=${y})`),!E&&m<90){let D=a.budgetContinuationCount+1,F={role:"user",content:Pn(m,d,t.tokenBudget)};n.info(`token budget continuation #${D}: ${Math.round(m)}% used`),yield{type:"recovery",turnId:r,action:"budget_continuation",detail:`${Math.round(m)}% used (#${D})`};let j={role:"assistant",content:a.finalText,...U.length>0&&{thinkingBlocks:[...U]}};a={...a,messages:[...T,j,F],budgetContinuationCount:D,lastBudgetDeltaTokens:y,lastBudgetGlobalTokens:d,transition:{reason:"token_budget_continuation"}};continue}}if(!a.stopHookActive){let d=l.find(D=>D.role==="user"),m=typeof d?.content=="string"?d.content:"",y=/创建(?:文件)?|生成文件|写入|写一个|建一个|新建|重写|改写|修改|改成|把.*改|修复|实现|create\s+(?:a\s+)?file|write\s+(?:a\s+)?file|make\s+(?:a\s+)?file|fix|implement|文件名叫/i.test(m),E=k.has("write")||k.has("edit");if(y&&!E){if(n.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),N>0){let j=[...T].reverse().find(K=>K.role==="tool");j&&typeof j.content=="string"&&(j.content+=`
|
|
4
|
+
`)):""}function Jt(e){try{let t=JSON.parse(e),o=[t.description,t.command,t.query,t.url,t.path,t.file_path,t.filePath,t.pattern,t.model].find(l=>typeof l=="string"&&l.trim().length>0);if(typeof o=="string")return o.trim().slice(0,240);let n=Object.keys(t);return n.length>0?n.slice(0,5).join(" / "):void 0}catch{return}}function Ve(e){let t=e.message.toLowerCase();return e.status===413||t.includes("prompt_too_long")||t.includes("context_length_exceeded")||t.includes("maximum context length")}function Zt(e){return e==="length"||e==="max_tokens"}function Je(e){let t=e.message.toLowerCase();return(t.includes("image")||t.includes("media")||t.includes("file too large")||t.includes("payload too large"))&&(e.status===413||t.includes("too large")||t.includes("size"))}function Qt(e){let t=e.headers;if(!t)return null;let r=t["retry-after"]??t["Retry-After"];if(!r)return null;let o=parseInt(r,10);return!isNaN(o)&&o>0?o*1e3:null}function eo(e){if(e.status!==400)return null;let t=e.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!t?.[1]||!t?.[3])return null;let r=parseInt(t[1],10),o=parseInt(t[3],10);if(isNaN(r)||isNaN(o))return null;let n=o-r-1e3;return n>=3e3?n:null}async function*to(e,t,r,o,n,l,d,a){let m=[],T;a.debug(`single LLM round, messages: ${r.length}`);for await(let C of d.stream({model:t,messages:r,temperature:n},o,l))switch(C.type){case"delta":m.push(C.text),yield{type:"delta",turnId:e,text:C.text};break;case"usage":T={inputTokens:C.promptTokens,outputTokens:C.completionTokens,reasoningTokens:C.reasoningTokens,cacheRead:C.cacheReadTokens,cacheWrite:C.cacheCreationTokens};break;case"done":break}yield{type:"end",turnId:e,content:m.join(""),usage:T??{inputTokens:0,outputTokens:0},model:t}}async function*oo(e,t,r,o){let{turnId:n,sessionId:l,messages:d,tools:a,model:m,apiKey:T,temperature:C=0,hooks:b,signal:$}=e,S={sessionId:l,turnId:n},M=e.maxTurns??0,k=e.querySource,A=e.runtimePorts.resolveToolEligibility(a,e.toolEligibilityContext),F=A.eligibleTools;for(let f of A.blockedTools)yield{type:"tool_blocked",turnId:n,callId:"",name:f.toolName,reason:"blocked-by-policy"};if(!F.length){yield*to(n,m,d,T,C,$,t,o);return}let j=Yt(e.maxRounds),O={contextWindowTokens:e.contextWindowTokens??_t,responseBufferTokens:xt,maxOutputTokens:e.maxOutputTokens??St,abortSignal:$,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},R=new Set,h=0,B=F,ne,re=!1,Ze=0,s={messages:[...d],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:Ge(O),reactiveCompactState:We(),toolLoopState:Te({maxRounds:j,replayMessages:[...d]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:ve(),currentModel:m,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:e.runtimePorts.createContentReplacementState(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},Qe=Math.max(M*5,200),et=0;for(;;){if(et++,et>Qe){o.info(`hard iteration cap reached (${Qe}), forcing completion`);let i=s.finalText||X(s.messages,o);yield{type:"end",turnId:n,content:i,usage:s.totalUsage,model:s.currentModel};return}let{messages:f,maxOutputTokensRecoveryCount:Y,hasAttemptedReactiveCompact:Nn,maxOutputTokensOverride:tt,turnCount:V,guardState:_,reactiveCompactState:U,collapseStore:ke}=s,{toolLoopState:w}=s;if(ne){try{let i=await ne;i&&(yield{type:"tool_use_summary",turnId:n,summary:i})}catch{}ne=void 0}if(e.refreshTools&&V>1){let i=e.refreshTools();i!==B&&(B=i,o.debug(`tools refreshed: ${i.length} tools`))}if(Ke(_,O)){o.info(`turn aborted by guard at turn ${V}`),yield{type:"error",turnId:n,error:"Turn aborted",code:"ABORTED",usage:s.totalUsage};return}let G=He(_,O);if(G.level==="blocking"){G.reason==="prompt_too_long"&&W(U)&&(U.attemptedThisTurn=!0,_.hasAttemptedReactiveCompact=!0,o.info(`token budget blocking (${G.reason}), reactive compact needed`),yield{type:"recovery",turnId:n,action:"reactive_compact",detail:"token budget pre-check"}),o.info(`token budget blocking (${G.reason}), ending tool loop`);break}G.level==="warning"&&o.info(`token budget warning: ${G.usagePercent}% used, ${G.remainingTokens} remaining`);let x;{let i=await e.runtimePorts.enforceToolResultBudget(f,s.contentReplacementState,l);x=i.messages,i.newlyReplacedCount>0&&(o.info(`tool-result-budget: persisted ${i.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:n,action:"tool_result_budget",detail:`${i.newlyReplacedCount} persisted`})}{let i=Ae(x,s.snipRemovedIds);x=i.messages,i.removedCount>0&&(o.info(`snip: removed ${i.removedCount} messages, freed ~${i.tokensFreed} tokens`),yield{type:"recovery",turnId:n,action:"snip",detail:`${i.removedCount} messages`})}{let c=new ee().compress(x,0);c.droppedCount>0&&(x=c.messages,o.info(`microcompact: cleared ${c.droppedCount} old tool results`))}if(x=Ee(x,ke).messages,_.promptTokens>0){let i=O.contextWindowTokens*.75,c=e.runtimePorts.getActiveContextCompressionEngine(),u;c?u=await c.compressAsync(x,i,{model:s.currentModel,sessionId:l}):u=e.runtimePorts.compressMessages(x,{budget:i,model:s.currentModel}),u.droppedCount>0&&(x=u.messages,o.info(`autocompact: ${u.strategy}, dropped ${u.droppedCount}`),yield{type:"recovery",turnId:n,action:"autocompact",detail:`${u.strategy}: ${u.droppedCount} dropped`},s.hasAttemptedReactiveCompact=!1,b?.invoke("context.after_compact",{...S,removedCount:u.droppedCount}).catch(()=>{}))}x=Vt(x);let lo=e.toolChoice==="required"&&re?"auto":e.toolChoice??"auto",se=Oe({tools:B,toolChoice:lo}),J=Te({maxRounds:j,replayMessages:x,lastStopReason:w.lastStopReason,options:{stopReason:w.lastStopReason}}),ot=se.extraSystemPrompt?[{role:"system",content:se.extraSystemPrompt},...J.state.replayMessages]:J.state.replayMessages;w=J.state,J.recoveryActions.length>0&&o.debug(`tool loop recovery: ${J.recoveryActions.map(i=>i.detail??i.kind).join("; ")}`),o.debug(`turn ${V}, messages: ${ot.length}`),b?.invoke("turn.before_inference",{...S,model:s.currentModel}).catch(()=>{});let ie=!1,nt=[],rt=new Map,st="stop",L,y=null,ae=!1,Z=[],I=[];try{for await(let i of t.stream({model:s.currentModel,messages:ot,tools:se.tools,toolChoice:se.normalizedToolChoice??"auto",temperature:C,maxTokens:(tt??_.currentMaxOutputTokens)||void 0,streamRequired:e.streamRequired,previousResponseId:s.lastResponseId,reasoning:e.reasoning,promptCacheKey:e.promptCacheKey,promptCacheRetention:e.promptCacheRetention,serviceTier:e.serviceTier,openaiBuiltinTools:e.openaiBuiltinTools,maxToolCalls:e.maxToolCalls,parallelToolCalls:e.parallelToolCalls,textVerbosity:e.textVerbosity},T,$))switch(i.type){case"delta":nt.push(i.text),!ie&&!(e.toolChoice==="required"&&!re)&&(yield{type:"delta",turnId:n,text:i.text});break;case"tool_call_delta":ie=!0,Xe(rt,i);break;case"reasoning_delta":Z.push(i.text);break;case"reasoning_block_complete":i.signature&&I.push({thinking:Z.join(""),signature:i.signature}),Z.length=0;break;case"usage":L={inputTokens:i.promptTokens,outputTokens:i.completionTokens,reasoningTokens:i.reasoningTokens,cacheRead:i.cacheReadTokens,cacheWrite:i.cacheCreationTokens};break;case"response_id":s.lastResponseId=i.id;break;case"annotations":yield{type:"annotations",turnId:n,annotations:i.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:n,message:`${i.toolType}: ${i.event}`};break;case"done":st=i.finishReason;break}if(ie||b?.invoke("turn.after_inference",{...S,model:s.currentModel}).catch(()=>{}),e.postSamplingHooks&&e.postSamplingHooks.length>0){let i=s.currentModel;for(let c of e.postSamplingHooks)try{c({messages:[...x],model:i,sessionId:l})}catch{}}}catch(i){if(i instanceof oe&&e.fallbackModel){o.info(`model fallback triggered: ${i.originalModel} -> ${i.fallbackModel}`),yield{type:"recovery",turnId:n,action:"model_fallback",detail:`${i.originalModel} -> ${i.fallbackModel}`},s={...s,currentModel:i.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let c=i instanceof Error?i.message:String(i),u=typeof i?.status=="number"?i.status:void 0;if(!u&&c&&(c.includes("ECONNRESET")||c.includes("EPIPE"))){let g=(s.consecutiveApiRetries??0)+1;if(g>te){o.info(`stale connection retry limit reached (${te}), aborting`),yield{type:"error",turnId:n,error:c,code:"RETRIES_EXHAUSTED",usage:s.totalUsage};return}o.info(`stale connection (${c.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:n,action:"stale_connection_retry",detail:c.slice(0,80)},s={...s,consecutiveApiRetries:g,transition:void 0};continue}let p=eo({status:u,message:c});if(p!==null){o.info(`max_tokens overflow: adjusting to ${p}`),_.currentMaxOutputTokens=p,s={...s,maxOutputTokensOverride:p,transition:void 0};continue}if(je(u)){s.consecutive529Errors++;let g=2,v=e.fallbackModel&&s.currentModel!==e.fallbackModel;if(s.consecutive529Errors>g&&!v&&!Ce()){o.info(`transient ${u} \u8133 ${s.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:n,error:`API unavailable after ${s.consecutive529Errors} consecutive ${u} errors`,code:"API_ERROR",usage:s.totalUsage};return}if(s.consecutive529Errors>=wt&&e.fallbackModel&&s.currentModel!==e.fallbackModel){o.info(`529 \u8133 ${s.consecutive529Errors}: triggering fallback to ${e.fallbackModel}`),yield{type:"recovery",turnId:n,action:"model_fallback",detail:`529 \u8133 ${s.consecutive529Errors}`},s={...s,currentModel:e.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Ce()){let E=he(s.consecutive529Errors);o.info(`persistent retry: waiting ${E}ms (attempt ${s.consecutive529Errors})`);let P=E;for(;P>0;){if($?.aborted){yield{type:"error",turnId:n,error:"Aborted during retry wait",code:"ABORTED",usage:s.totalUsage};return}yield{type:"heartbeat",turnId:n,message:`Retrying in ${Math.ceil(P/1e3)}s (${u})`};let D=Math.min(P,It);await new Promise(_e=>setTimeout(_e,D)),P-=D}s={...s,transition:void 0};continue}if($e(k)){let P=Qt({status:u,message:c})??he(s.consecutive529Errors);o.info(`transient ${u}: retry in ${P}ms`),yield{type:"recovery",turnId:n,action:"retry",detail:`${u} retry in ${P}ms`},await new Promise(D=>setTimeout(D,P)),s={...s,transition:void 0};continue}o.info(`background source ${k}: not retrying ${u}`)}y={status:u,message:c}}if(y&&b?.invoke("turn.after_inference",{...S,model:s.currentModel,response:{error:y.message}}).catch(()=>{}),y)if(Ve(y))ae=!0,o.info(`withheld prompt_too_long error (status=${y.status})`);else if(Je(y))ae=!0,o.info(`withheld media_size error (status=${y.status})`);else{let i=qe({status:y.status??500,message:y.message},_,O);if(i.action==="reactive_compact"&&W(U)&&(U.attemptedThisTurn=!0,_.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:n,action:"reactive_compact",detail:`API ${y.status??500}: ${y.message}`}),i.action==="retry"){let u=(s.consecutiveApiRetries??0)+1;if(u>te){o.info(`API retry limit reached (${te}), aborting`);let p=K(y.status,y.message);yield{type:"error",turnId:n,error:y.message,code:p,usage:s.totalUsage};return}yield{type:"recovery",turnId:n,action:"retry",detail:i.reason},s={...s,consecutiveApiRetries:u,transition:void 0};continue}let c=K(y.status,y.message);b?.invoke("stop.failure",{sessionId:l,reason:c,error:y.message}).catch(()=>{}),yield{type:"error",turnId:n,error:y.message,code:c,usage:s.totalUsage};return}L&&(s.totalUsage.inputTokens+=L.inputTokens,s.totalUsage.outputTokens+=L.outputTokens,L.reasoningTokens&&(s.totalUsage.reasoningTokens=(s.totalUsage.reasoningTokens??0)+L.reasoningTokens),L.cacheRead&&(s.totalUsage.cacheRead=(s.totalUsage.cacheRead??0)+L.cacheRead),L.cacheWrite&&(s.totalUsage.cacheWrite=(s.totalUsage.cacheWrite??0)+L.cacheWrite)),L?.inputTokens&&(_.promptTokens=L.inputTokens);let it=nt.join("");it&&(s.finalText=it);let N=[...rt.values()].map(i=>({id:i.id||`tc_${n}_${V}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:i.name,arguments:i.arguments}}));if(N.length===0&&!ie){if(e.toolChoice==="required"&&!re&&B.length>0&&Ze<2){Ze++;let u=B.map(p=>p.function.name).filter(Boolean).slice(0,8).join(", ");s={...s,messages:[...f,{role:"user",content:`You must call one available tool before answering. Available tools for this request: ${u}. Do not answer from memory, prior context, or guesses.`}],finalText:"",transition:{reason:"next_turn"}};continue}if(ae&&y&&Ve(y)){if(s.transition?.reason!=="collapse_drain_retry"){let u=Ie(x,ke);if(u.committed>0){o.info(`collapse drain: committed ${u.committed} stages`),yield{type:"recovery",turnId:n,action:"collapse_drain",detail:`${u.committed} stages committed`},s={...s,messages:u.messages,transition:{reason:"collapse_drain_retry",committed:u.committed}};continue}}if(W(U)){U.attemptedThisTurn=!0,_.hasAttemptedReactiveCompact=!0,o.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:n,action:"reactive_compact",detail:"withheld prompt_too_long"},s={...s,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld 413: recovery exhausted, surfacing error"),b?.invoke("stop.failure",{sessionId:l,reason:"prompt_too_long",error:y.message}).catch(()=>{}),yield{type:"error",turnId:n,error:y.message,code:"PROMPT_TOO_LONG",usage:s.totalUsage};return}if(ae&&y&&Je(y)){if(W(U)){U.attemptedThisTurn=!0,_.hasAttemptedReactiveCompact=!0,o.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:n,action:"reactive_compact",detail:"media error strip-retry"},s={...s,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}o.info("withheld media error: recovery exhausted"),b?.invoke("stop.failure",{sessionId:l,reason:"media_error",error:y.message}).catch(()=>{}),yield{type:"error",turnId:n,error:y.message,code:"IMAGE_ERROR",usage:s.totalUsage};return}if(Zt(st)){_.consecutiveTruncations+=1;let u=e.modelMaxOutputTokens??Mt,p=ze(_,O,u);if(p.shouldEscalate&&tt===void 0){_.currentMaxOutputTokens=p.newMax,o.info(`max_output_tokens escalate: ${p.newMax} tokens`),yield{type:"recovery",turnId:n,action:"output_escalation",detail:`${p.newMax} tokens`},s={...s,maxOutputTokensOverride:vt,transition:{reason:"max_output_tokens_escalate"}};continue}if(Y<At){let g={role:"user",content:"Output token limit hit. Resume directly - no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};o.info(`max_output_tokens recovery #${Y+1}`),yield{type:"recovery",turnId:n,action:"max_output_tokens_recovery",detail:`attempt ${Y+1}`},s={...s,messages:[...x,g],maxOutputTokensRecoveryCount:Y+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:Y+1}};continue}o.info("max_output_tokens recovery exhausted, completing with partial content")}else _.consecutiveTruncations=0;if(w=ye(w,{replayMessages:f,lastStopReason:"completed"}),b){let u=await b.invoke("stop",{sessionId:l,reason:"completed"});if(u.action==="prevent"){o.info(`stop hook prevented continuation: ${u.reason??"no reason"}`),yield{type:"end",turnId:n,content:s.finalText,usage:s.totalUsage,model:s.currentModel};return}if(u.action==="abort"){let p=u.reason??"Stop hook requested continuation";o.info(`stop hook blocking: ${p}`);let g={role:"user",content:p},v={role:"assistant",content:s.finalText,...I.length>0&&{thinkingBlocks:[...I]}};s={...s,messages:[...f,v,g],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(e.tokenBudget&&e.tokenBudget>0&&s.budgetContinuationCount<5){let u=s.totalUsage.inputTokens+s.totalUsage.outputTokens+(s.totalUsage.reasoningTokens??0),p=u/e.tokenBudget*100,g=u-s.lastBudgetGlobalTokens,v=s.budgetContinuationCount>=Et&&g<we&&s.lastBudgetDeltaTokens<we;if(v&&o.info(`token budget early stop: diminishing returns at ${Math.round(p)}% (delta=${g})`),!v&&p<90){let E=s.budgetContinuationCount+1,P={role:"user",content:e.runtimePorts.getBudgetContinuationMessage(p,u,e.tokenBudget)};o.info(`token budget continuation #${E}: ${Math.round(p)}% used`),yield{type:"recovery",turnId:n,action:"budget_continuation",detail:`${Math.round(p)}% used (#${E})`};let D={role:"assistant",content:s.finalText,...I.length>0&&{thinkingBlocks:[...I]}};s={...s,messages:[...f,D,P],budgetContinuationCount:E,lastBudgetDeltaTokens:g,lastBudgetGlobalTokens:u,transition:{reason:"token_budget_continuation"}};continue}}if(!s.stopHookActive){let u=d.find(E=>E.role==="user"),p=typeof u?.content=="string"?u.content:"",g=/create\s+(?:a\s+)?file|write\s+(?:a\s+)?file|make\s+(?:a\s+)?file|fix|implement|modify|update|repair|generate\s+(?:a\s+)?file|new\s+file/i.test(p),v=R.has("write")||R.has("edit");if(g&&!v){if(o.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),h>0){let D=[...f].reverse().find(_e=>_e.role==="tool");D&&typeof D.content=="string"&&(D.content+=`
|
|
18
5
|
|
|
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 D={role:"user",content:N===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."},F={role:"assistant",content:a.finalText,...U.length>0&&{thinkingBlocks:[...U]}};a={...a,messages:[...T,F,D],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!a.stopHookActive&&N>=3&&k.has("write")){let d=0;for(let m of T){let y=m,E=y.is_error===!0||typeof y.content=="string"&&y.content.startsWith("Error:");y.role==="tool"&&typeof y.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."},y={role:"assistant",content:a.finalText,...U.length>0&&{thinkingBlocks:[...U]}};a={...a,messages:[...T,y,m],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(N>0){let d={ok:!0,toolCallCount:N,distinctToolCount:k.size,multiStep:N>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},m=Se(d,{tools:[...k],projectRoot:t.projectRoot});m&&(yield{type:"skill_instruction",turnId:r,instruction:m})}let u=a.finalText||de(T,n);yield{type:"end",turnId:r,content:u,usage:a.totalUsage,model:a.currentModel};return}let zn=U.length===0&&oe.length>0?oe.join(""):void 0;T.push(Ue(G,a.finalText||void 0,U.length>0?U:void 0,zn)),B=nt(B,{replayMessages:T,pendingToolCallIds:G.map(c=>c.id),completedToolCallIds:B.completedToolCallIds,lastStopReason:"tool_calls"});let ye=a.identicalCallCounts,vt=[],Te=[],Mt=!1;for(let c of G){let u=`${c.function.name}::${c.function.arguments}`,d=ye.get(u)??0;ye.set(u,d+1),d+1>Gt?(Te.push(c),Mt||(Mt=!0,n.info(`AP4 blocked: ${c.function.name} repeated ${d+1}x`))):vt.push(c)}let be=[];for(let c of Te){let u=ye.get(`${c.function.name}::${c.function.arguments}`),d=Nn(T,c.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.`,y=ke(c.id,{ok:!1,error:m});T.push(y),be.push(c.id),k.add(c.function.name),N++,yield{type:"tool_result",turnId:r,callId:c.id,name:c.function.name,ok:!1,error:m}}if(Te.length>0){let c=Nn(T,Te[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."};T.push(u)}let Ce=[],Ne=[];for(let c of vt)(a.toolFailureCounts.get(c.function.name)??0)>=Re?Ne.push(c):Ce.push(c);if(Ne.length>0){for(let u of Ne){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.`,y=ke(u.id,{ok:!1,error:m});T.push(y),be.push(u.id),k.add(u.function.name),N++,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 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."};T.push(c)}for(let c of Ce){let u=c.function.arguments,d=J.find(m=>m.function.name===c.function.name);if(d?.backfillObservableInput)try{let m=JSON.parse(c.function.arguments),y={...m};d.backfillObservableInput(y),Object.keys(y).some(D=>!(D in m))&&(u=JSON.stringify(y))}catch{}yield{type:"tool_call",turnId:r,callId:c.id,name:c.function.name,arguments:u,inputSummary:us(u)}}let Wn=new Map(a.toolFailureCounts);try{let c=new we({toolInvoker:o,hooks:f,sessionId:s,turnId:r,log:n,signal:M,maxConcurrentTools:t?.maxConcurrentTools});for(let u of Ce)c.addTool(u);for await(let u of c.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:r,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),T.push(u.message),be.push(u.callId),k.add(u.toolName),N++;let d=u.ok&&rs(u);if(!u.ok||d){let v=(a.toolFailureCounts.get(u.toolName)??0)+1;a.toolFailureCounts.set(u.toolName,v)}if(u.ok&&u.toolName==="read"){let K=Ce.find(v=>v.id===u.callId);if(K)try{let v=JSON.parse(K.function.arguments),H=v.file_path??v.path??v.filePath??"";if(H){let Yn=a.fileReadCounts.get(H)??0;a.fileReadCounts.set(H,Yn+1)}}catch{}}let m=typeof u.message?.content=="string"?u.message.content:"",y=m?m.slice(0,2e3):void 0,E=u.details,D=typeof E?.stdout=="string"?E.stdout.slice(0,8e3):void 0,F=typeof E?.stderr=="string"?E.stderr.slice(0,4e3):void 0,j=typeof E?.exitCode=="number"?E.exitCode:void 0;if(yield{type:"tool_result",turnId:r,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:y,durationMs:u.durationMs,exitCode:j,stdout:D,stderr:F,details:E},u.ok){let K=G.find(v=>v.id===u.callId);if(K){if(u.toolName==="plan_mode")try{let v=JSON.parse(K.function.arguments);v.action==="exit"&&typeof v.plan=="string"&&v.plan.length>0&&(yield{type:"plan_update",turnId:r,slug:"approved-plan",content:v.plan})}catch{}if(Zr.has(u.toolName))try{let v=JSON.parse(K.function.arguments),H=typeof v.file_path=="string"?v.file_path:typeof v.filePath=="string"?v.filePath:typeof v.path=="string"?v.path:void 0;H&&(yield{type:"artifact",turnId:r,artifactId:`artifact-${u.callId}`,artifactType:es(H),title:H.split(/[\\/]/).pop()||H,filePath:H,language:ts(H)})}catch{}}}}}catch(c){let u=c instanceof Error?c.message:String(c);yield{type:"error",turnId:r,error:u,code:"TOOL_EXECUTION_ERROR",usage:a.totalUsage};return}for(let[c,u]of a.toolFailureCounts)u>=Re&&(Wn.get(c)??0)<Re&&T.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(B=xe(B,{replayMessages:T,completedToolCallIds:[...B.completedToolCallIds,...be],lastStopReason:"tool_calls"}),t.toolChoice==="required"&&G.length>0&&(ge=!0),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 Xn=G.length>0&&G.every(c=>{let u=T.find(m=>m?.role==="tool"&&m?.tool_call_id===c.id);if(!u)return!0;let d=u.content;return typeof d=="string"&&d.startsWith("Error: ")}),re=a.consecutiveFailedRounds;if(Xn){if(re+=1,re>=Kt){let c=a.finalText||de(T,n);n.info(`early exit: ${re} consecutive failed rounds, returning ${a.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}}else re=0;let Vn=3,At=[...a.fileReadCounts.entries()].filter(([,c])=>c>=Vn);if(At.length>0){let c=At.map(([d])=>d).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.`};T.push(u),a.fileReadCounts.clear()}let De=te+1;if(b>0&&De>b){if(n.info(`max turns reached (${b}), 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,...U.length>0&&{thinkingBlocks:[...U]}};a={...a,messages:[...T,m,{role:"user",content:d}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let c=a.finalText||de(T,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}if(De>O){if(n.info(`tool loop budget exhausted (${O} rounds), returning`),N>0){let u={ok:!0,toolCallCount:N,distinctToolCount:k.size,multiStep:N>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},d=Se(u,{tools:[...k],projectRoot:t.projectRoot});d&&(yield{type:"skill_instruction",turnId:r,instruction:d})}let c=a.finalText||de(T,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}a={messages:T,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:De,transition:{reason:"next_turn"},guardState:P,reactiveCompactState:q,toolLoopState:B,consecutiveFailedRounds:re,finalText:a.finalText,totalUsage:a.totalUsage,collapseStore:Oe,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:ye,toolFailureCounts:a.toolFailureCounts,fileReadCounts:a.fileReadCounts}}}function de(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
|
-
|
|
21
|
-
`)
|
|
22
|
-
`)}function fs(t){let e=t.filter(r=>r.source==="l1-project-md").flatMap(r=>$n(r.text)),o=t.filter(r=>r.source==="l2-long-term").flatMap(r=>$n(r.text)),n=[];for(let r of e)for(let s of o)r.entity===s.entity&&r.predicate===s.predicate&&r.amount!==s.amount&&n.push({entity:r.entity,predicate:r.predicate,l1Amount:r.amount,l2Amount:s.amount,l1Text:r.text,l2Text:s.text});return bs(n)}function $n(t){let e=[];for(let o of t.split(/\r?\n/)){let n=o.trim();if(n)for(let r of ms){if(r==="\u91D1\u989D"&&/(接单金额|合同金额)/u.test(n))continue;let s=new RegExp(`${Cs(r)}[^0-9.\u4E07kK,]{0,12}([0-9][0-9.,]*\\s*(?:\u4E07|k|K)?)`,"gi");for(let l of n.matchAll(s)){let i=ys(l[1]);i!==null&&e.push({entity:hs(n,r),predicate:r,amount:i,text:n})}}}return e}function hs(t,e){if(/Galaxy\s+Tech/i.test(t))return"Galaxy Tech";if(t.includes("\u7528\u6237"))return"\u7528\u6237";let o=t.toLowerCase().indexOf(e.toLowerCase()),r=(o>=0?t.slice(0,o):"").replace(/[#*`:\-,。;;,.]/g," ").trim().split(/\s+/).filter(Boolean);return r[r.length-1]??"unknown"}function ys(t){let e=t.replace(/,/g,"").replace(/\s+/g,"").trim(),o=e.endsWith("\u4E07")?1e4:/k$/i.test(e)?1e3:1,n=Number(e.replace(/[万kK]$/u,""));return Number.isFinite(n)?n*o:null}function Ts(t){if(t.label)return t.label;switch(t.source){case"l1-project-md":return"L1 project MD";case"l2-long-term":return"L2 long-term";case"skill":return"Skill";case"system":return"System";default:return"Memory"}}function jn(t){return Number.isInteger(t)?String(t):String(Number(t.toFixed(4)))}function bs(t){let e=new Set;return t.filter(o=>{let n=`${o.entity}\0${o.predicate}\0${o.l1Amount}\0${o.l2Amount}`;return e.has(n)?!1:(e.add(n),!0)})}function Cs(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var Hn=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:l,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 h=tt(r),g=[];if(l&&g.push({role:"system",content:l}),g.push(...h),this.hooks){let _=h.filter(S=>S.role==="user").pop(),b=typeof _?.content=="string"?_.content.slice(0,500):void 0;if(b)try{let S=Bn(b),x=await this.hooks.invoke("memory.before_recall",{sessionId:e.sessionId,turnId:n,query:b,preferredCategories:S.preferred.length>0?S.preferred:void 0,deprioritizedCategories:S.deprioritized.length>0?S.deprioritized:void 0}),w=x?.context?.recalledMemories;if(w&&w.length>0){let O=0,A=[];for(let k of w){let N=(k.text?.length??0)*2;if(O+N>8192)break;A.push(k),O+=N}if(A.length>0){let k=Kn(A);g.splice(l?1:0,0,{role:"system",content:`[Recalled memories \u2014 context priority: project-specific facts override general user preferences when they conflict]
|
|
23
|
-
${k}`})}}this.hooks.invoke("memory.after_recall",{sessionId:e.sessionId,turnId:n,blockCount:x?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let f=i?.model??"",M=Math.min(i?.maxRounds??this.maxRounds,100);try{let _=async x=>{let w=gt().resolveModelForPurpose("smallModel");if(!w)return null;try{let R=x.map(k=>`${k.name}(${k.arguments.slice(0,200)})`).join(", "),O=this.transport.stream({model:w,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:R}],tools:[],maxTokens:60},i?.apiKey??this.apiKey),A="";for await(let k of O)k.type==="delta"&&(A+=k.text);return A.trim()||null}catch{return null}},b={turnId:n,sessionId:e.sessionId,messages:g,tools:s,model:f,apiKey:i?.apiKey??this.apiKey,temperature:i?.temperature,maxRounds:M,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:_,signal:o},S;for await(let x of Fn(b,this.transport,this.toolInvoker,this.log))S=x,yield x;S?.type==="end"?this.hooks?.invoke("turn.completed",{...p}).catch(()=>{}):S?.type==="error"&&this.hooks?.invoke("turn.failed",{...p,code:S.code,error:S.error}).catch(()=>{})}catch(_){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 b=_ instanceof Error?_.message:String(_),S=typeof _?.status=="number"?_.status:void 0,x=Q(S,b);this.log.error(`turn ${n} error [${x}, retryable=${Be(x)}]: ${b}`),this.hooks?.invoke("turn.failed",{...p,code:x,error:b}).catch(()=>{}),yield{type:"error",turnId:n,error:b,code:x}}}}};export{Hn as Agent};
|
|
6
|
+
\u923F\u72C5\u7B0D 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 E={role:"user",content:h===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 - 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."},P={role:"assistant",content:s.finalText,...I.length>0&&{thinkingBlocks:[...I]}};s={...s,messages:[...f,P,E],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!s.stopHookActive&&h>=3&&R.has("write")){let u=0;for(let p of f){let g=p,v=g.is_error===!0||typeof g.content=="string"&&g.content.startsWith("Error:");g.role==="tool"&&typeof g.content=="string"&&!v&&u++}if(u>=3){o.info("AP3 verification nudge: 3+ files created, injecting completeness check");let p={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."},g={role:"assistant",content:s.finalText,...I.length>0&&{thinkingBlocks:[...I]}};s={...s,messages:[...f,g,p],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(h>0){let u={ok:!0,toolCallCount:h,distinctToolCount:R.size,multiStep:h>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},p=fe(u,{tools:[...R],projectRoot:e.projectRoot});p&&(yield{type:"skill_instruction",turnId:n,instruction:p})}let c=s.finalText||X(f,o);yield{type:"end",turnId:n,content:c,usage:s.totalUsage,model:s.currentModel};return}let co=I.length===0&&Z.length>0?Z.join(""):void 0;f.push(xe(N,s.finalText||void 0,I.length>0?I:void 0,co)),w=Ue(w,{replayMessages:f,pendingToolCallIds:N.map(i=>i.id),completedToolCallIds:w.completedToolCallIds,lastStopReason:"tool_calls"});let le=s.identicalCallCounts,at=[],ce=[],lt=!1;for(let i of N){let c=`${i.function.name}::${i.function.arguments}`,u=le.get(c)??0;le.set(c,u+1),u+1>bt?(ce.push(i),lt||(lt=!0,o.info(`AP4 blocked: ${i.function.name} repeated ${u+1}x`))):at.push(i)}let ue=[];for(let i of ce){let c=le.get(`${i.function.name}::${i.function.arguments}`),u=Ye(f,i.function.name),p=u?`This exact tool call has been attempted ${c} times. Last error: ${u}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${c} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,g=pe(i.id,{ok:!1,error:p});f.push(g),ue.push(i.id),R.add(i.function.name),h++,yield{type:"tool_result",turnId:n,callId:i.id,name:i.function.name,ok:!1,error:p}}if(ce.length>0){let i=Ye(f,ce[0].function.name),c={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(i?`The error was: "${i}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};f.push(c)}let de=[],Re=[];for(let i of at)(s.toolFailureCounts.get(i.function.name)??0)>=me?Re.push(i):de.push(i);if(Re.length>0){for(let c of Re){let u=s.toolFailureCounts.get(c.function.name),p=`Tool "${c.function.name}" has failed ${u} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,g=pe(c.id,{ok:!1,error:p});f.push(g),ue.push(c.id),R.add(c.function.name),h++,yield{type:"tool_result",turnId:n,callId:c.id,name:c.function.name,ok:!1,error:p},o.info(`AP4-variant blocked: ${c.function.name} failed ${u}x with different args`)}let i={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."};f.push(i)}for(let i of de){let c=i.function.arguments,u=B.find(p=>p.function.name===i.function.name);if(u?.backfillObservableInput)try{let p=JSON.parse(i.function.arguments),g={...p};u.backfillObservableInput(g),Object.keys(g).some(E=>!(E in p))&&(c=JSON.stringify(g))}catch{}yield{type:"tool_call",turnId:n,callId:i.id,name:i.function.name,arguments:c,inputSummary:Jt(c)}}let uo=new Map(s.toolFailureCounts);try{let i=e.runtimePorts.createStreamingToolExecutor({toolInvoker:r,hooks:b,sessionId:l,turnId:n,log:o,signal:$,maxConcurrentTools:e?.maxConcurrentTools});for(let c of de)i.addTool(c);for await(let c of i.getRemainingResults()){c.blocked&&(yield{type:"tool_blocked",turnId:n,callId:c.callId,name:c.toolName,reason:c.blockReason??"blocked"}),f.push(c.message),ue.push(c.callId),R.add(c.toolName),h++;let u=c.ok&&Xt(c);if(!c.ok||u){let g=(s.toolFailureCounts.get(c.toolName)??0)+1;s.toolFailureCounts.set(c.toolName,g)}if(c.ok&&c.toolName==="read"){let p=de.find(g=>g.id===c.callId);if(p)try{let g=JSON.parse(p.function.arguments),v=g.file_path??g.path??g.filePath??"";if(v){let E=s.fileReadCounts.get(v)??0;s.fileReadCounts.set(v,E+1)}}catch{}}yield Kt(n,c);for(let p of Wt({turnId:n,result:c,toolCalls:N}))yield p}}catch(i){let c=i instanceof Error?i.message:String(i);yield{type:"error",turnId:n,error:c,code:"TOOL_EXECUTION_ERROR",usage:s.totalUsage};return}for(let[i,c]of s.toolFailureCounts)c>=me&&(uo.get(i)??0)<me&&f.push({role:"user",content:`Tool "${i}" has now failed/returned empty results ${c} times with different arguments. The target clearly does not exist. Do NOT call "${i}" again. Report the result to the user immediately.`});if(w=ye(w,{replayMessages:f,completedToolCallIds:[...w.completedToolCallIds,...ue],lastStopReason:"tool_calls"}),e.toolChoice==="required"&&N.length>0&&(re=!0),e.generateToolUseSummary&&N.length>0){let i=N.map(c=>({name:c.function.name,arguments:c.function.arguments}));ne=e.generateToolUseSummary(i).catch(()=>null)}let po=N.length>0&&N.every(i=>{let c=f.find(p=>p?.role==="tool"&&p?.tool_call_id===i.id);if(!c)return!0;let u=c.content;return typeof u=="string"&&u.startsWith("Error: ")}),Q=s.consecutiveFailedRounds;if(po){if(Q+=1,Q>=Rt){let i=s.finalText||X(f,o);o.info(`early exit: ${Q} consecutive failed rounds, returning ${s.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:n,content:i,usage:s.totalUsage,model:s.currentModel};return}}else Q=0;let mo=3,ct=[...s.fileReadCounts.entries()].filter(([,i])=>i>=mo);if(ct.length>0){let i=ct.map(([u])=>u).join(", ");o.info(`AP5: file read cycle detected on ${i}, injecting nudge`);let c={role:"user",content:`You are reading the same files repeatedly (${i}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};f.push(c),s.fileReadCounts.clear()}let be=V+1;if(M>0&&be>M){if(o.info(`max turns reached (${M}), completing`),b){let c=await b.invoke("stop",{sessionId:l,reason:"max_turns"});if(c.action==="abort"){let u=c.reason??"Stop hook requested continuation after max_turns",p={role:"assistant",content:s.finalText,...I.length>0&&{thinkingBlocks:[...I]}};s={...s,messages:[...f,p,{role:"user",content:u}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let i=s.finalText||X(f,o);yield{type:"end",turnId:n,content:i,usage:s.totalUsage,model:s.currentModel};return}if(be>j){if(o.info(`tool loop budget exhausted (${j} rounds), returning`),h>0){let c={ok:!0,toolCallCount:h,distinctToolCount:R.size,multiStep:h>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},u=fe(c,{tools:[...R],projectRoot:e.projectRoot});u&&(yield{type:"skill_instruction",turnId:n,instruction:u})}let i=s.finalText||X(f,o);yield{type:"end",turnId:n,content:i,usage:s.totalUsage,model:s.currentModel};return}s={messages:f,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:be,transition:{reason:"next_turn"},guardState:_,reactiveCompactState:U,toolLoopState:w,consecutiveFailedRounds:Q,finalText:s.finalText,totalUsage:s.totalUsage,collapseStore:ke,currentModel:s.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:s.stopHookActive,lastResponseId:s.lastResponseId,snipRemovedIds:s.snipRemovedIds,contentReplacementState:s.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:le,toolFailureCounts:s.toolFailureCounts,fileReadCounts:s.fileReadCounts}}}var An=["\u63A5\u5355\u91D1\u989D","\u5408\u540C\u91D1\u989D","\u62A5\u4EF7","\u9884\u7B97","\u91D1\u989D","price","amount","contract amount"];function so(e){let t=vn(e),r=["[Recalled memories]","- L1 project MD is project-scoped working memory.","- L2 long-term memory is cross-project canonical memory.","- If L1 and L2 conflict on the same entity/fact, do not silently merge or choose. Surface the conflict and ask the user to confirm. For current-project operational tasks, use L1 only as a project-scoped clue until confirmed into L2."];if(t.length>0){r.push("[Memory conflict detected]");for(let o of t)r.push(`- entity: ${o.entity}; fact: ${o.predicate}; L1 project MD says: ${ro(o.l1Amount)}; L2 long-term says: ${ro(o.l2Amount)}; action: ask the user which value is current before using it.`)}for(let o of e){let n=wn(o);r.push(`- [${n}] ${o.text}`)}return r.join(`
|
|
7
|
+
`)}function vn(e){let t=e.filter(n=>n.source==="l1-project-md").flatMap(n=>no(n.text)),r=e.filter(n=>n.source==="l2-long-term").flatMap(n=>no(n.text)),o=[];for(let n of t)for(let l of r)n.entity===l.entity&&n.predicate===l.predicate&&n.amount!==l.amount&&o.push({entity:n.entity,predicate:n.predicate,l1Amount:n.amount,l2Amount:l.amount,l1Text:n.text,l2Text:l.text});return Ln(o)}function no(e){let t=[];for(let r of e.split(/\r?\n/)){let o=r.trim();if(o)for(let n of An){if(n==="\u91D1\u989D"&&/(接单金额|合同金额)/u.test(o))continue;let l=new RegExp(`${Pn(n)}[^0-9.\u4E07kK,]{0,12}([0-9][0-9.,]*\\s*(?:\u4E07|k|K)?)`,"gi");for(let d of o.matchAll(l)){let a=In(d[1]);a!==null&&t.push({entity:En(o,n),predicate:n,amount:a,text:o})}}}return t}function En(e,t){if(/Galaxy\s+Tech/i.test(e))return"Galaxy Tech";if(e.includes("\u7528\u6237"))return"\u7528\u6237";let r=e.toLowerCase().indexOf(t.toLowerCase()),n=(r>=0?e.slice(0,r):"").replace(/[#*`:\-,。;;,.]/g," ").trim().split(/\s+/).filter(Boolean);return n[n.length-1]??"unknown"}function In(e){let t=e.replace(/,/g,"").replace(/\s+/g,"").trim(),r=t.endsWith("\u4E07")?1e4:/k$/i.test(t)?1e3:1,o=Number(t.replace(/[万kK]$/u,""));return Number.isFinite(o)?o*r:null}function wn(e){if(e.label)return e.label;switch(e.source){case"l1-project-md":return"L1 project MD";case"l2-long-term":return"L2 long-term";case"skill":return"Skill";case"system":return"System";default:return"Memory"}}function ro(e){return Number.isInteger(e)?String(e):String(Number(e.toFixed(4)))}function Ln(e){let t=new Set;return e.filter(r=>{let o=`${r.entity}\0${r.predicate}\0${r.l1Amount}\0${r.l2Amount}`;return t.has(o)?!1:(t.add(o),!0)})}function Pn(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var ao=class{transport;apiKey;toolInvoker;log;hooks;maxRounds;projectRoot;runtimePorts;constructor(t){this.transport=t.llmTransport,this.apiKey=t.apiKey,this.toolInvoker=t.toolInvoker,this.log=t.log,this.hooks=t.hooks,this.projectRoot=t.projectRoot,this.runtimePorts=t.runtimePorts,this.maxRounds=Math.min(t.maxRounds??25,100)}async*run(t,r){let{turnId:o,messages:n,tools:l,systemPrompt:d,config:a}=t,m={sessionId:t.sessionId,turnId:o};yield{type:"start",turnId:o},this.hooks?.invoke("turn.submitted",{...m,prompt:n[n.length-1]?.content??void 0}).catch(()=>{});let T=Be(n),C=[];if(d&&C.push({role:"system",content:d}),C.push(...T),this.hooks){let S=T.filter(k=>k.role==="user").pop(),M=typeof S?.content=="string"?S.content.slice(0,500):void 0;if(M)try{let k=this.runtimePorts.detectRecallCategories(M),A=await this.hooks.invoke("memory.before_recall",{sessionId:t.sessionId,turnId:o,query:M,preferredCategories:k.preferred.length>0?k.preferred:void 0,deprioritizedCategories:k.deprioritized.length>0?k.deprioritized:void 0}),F=A?.context?.recalledMemories;if(F&&F.length>0){let O=0,R=[];for(let h of F){let B=(h.text?.length??0)*2;if(O+B>8192)break;R.push(h),O+=B}if(R.length>0){let h=so(R);C.splice(d?1:0,0,{role:"system",content:`[Recalled memories \u2014 context priority: project-specific facts override general user preferences when they conflict]
|
|
8
|
+
${h}`})}}this.hooks.invoke("memory.after_recall",{sessionId:t.sessionId,turnId:o,blockCount:A?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let b=a?.model??"",$=Math.min(a?.maxRounds??this.maxRounds,100);try{let S=async A=>{let F=this.runtimePorts.resolveModelForPurpose("smallModel");if(!F)return null;try{let j=A.map(h=>`${h.name}(${h.arguments.slice(0,200)})`).join(", "),O=this.transport.stream({model:F,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:j}],tools:[],maxTokens:60},a?.apiKey??this.apiKey),R="";for await(let h of O)h.type==="delta"&&(R+=h.text);return R.trim()||null}catch{return null}},M={turnId:o,sessionId:t.sessionId,messages:C,tools:l,model:b,apiKey:a?.apiKey??this.apiKey,temperature:a?.temperature,maxRounds:$,contextWindowTokens:a?.contextWindowTokens,maxOutputTokens:a?.maxOutputTokens,modelMaxOutputTokens:a?.modelMaxOutputTokens,toolChoice:a?.toolChoice,parentDepth:a?.parentDepth,hooks:this.hooks,fallbackModel:a?.fallbackModel,maxTurns:a?.maxTurns,tokenBudget:a?.tokenBudget,maxConcurrentTools:a?.maxConcurrentTools,streamRequired:a?.streamRequired,reasoning:a?.reasoning,promptCacheKey:a?.promptCacheKey,promptCacheRetention:a?.promptCacheRetention,serviceTier:a?.serviceTier,openaiBuiltinTools:a?.openaiBuiltinTools,maxToolCalls:a?.maxToolCalls,parallelToolCalls:a?.parallelToolCalls,textVerbosity:a?.textVerbosity,projectRoot:this.projectRoot,generateToolUseSummary:S,runtimePorts:this.runtimePorts.toolLoop,signal:r},k;for await(let A of oo(M,this.transport,this.toolInvoker,this.log))k=A,yield A;k?.type==="end"?this.hooks?.invoke("turn.completed",{...m}).catch(()=>{}):k?.type==="error"&&this.hooks?.invoke("turn.failed",{...m,code:k.code,error:k.error}).catch(()=>{})}catch(S){if(r?.aborted)this.hooks?.invoke("turn.failed",{...m,code:"ABORTED",error:"Turn aborted"}).catch(()=>{}),yield{type:"error",turnId:o,error:"Turn aborted",code:"ABORTED"};else{let M=S instanceof Error?S.message:String(S),k=typeof S?.status=="number"?S.status:void 0,A=K(k,M);this.log.error(`turn ${o} error [${A}, retryable=${Me(A)}]: ${M}`),this.hooks?.invoke("turn.failed",{...m,code:A,error:M}).catch(()=>{}),yield{type:"error",turnId:o,error:M,code:A}}}}};export{ao as Agent};
|