@vpxa/aikit 0.1.283 → 0.1.285

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.
@@ -1,7 +1,7 @@
1
- import{n as e,t}from"./curated-manager-C5uOPept.js";import{a as n,i as r,n as i,o as a,r as o,s}from"./retention-B4ITAs7F.js";import{a as c,c as l,d as u,f as d,h as f,i as p,l as m,m as h,n as g,o as _,p as v,r as y,s as b,u as x}from"./supersession-CWEne3av.js";import{n as S,r as C}from"./resolve-sibling-1oDoO-Re.js";import{n as w,r as T}from"./evolution-BX_zTSdj.js";import{a as E,i as D,n as O,r as k,s as ee,t as te}from"./promotion-D9anNXv8.js";import{autoUpgradeScaffold as ne,getCurrentVersion as re,getUpgradeState as ie}from"./version-check-DAQdKLy7.js";import{createRequire as ae}from"node:module";import{createHash as A,randomBytes as oe,randomUUID as se,timingSafeEqual as ce}from"node:crypto";import{existsSync as j,mkdirSync as M,readFileSync as N,readdirSync as le,renameSync as ue,rmSync as de,statSync as fe,unlinkSync as pe,writeFileSync as me}from"node:fs";import{basename as he,dirname as ge,isAbsolute as _e,join as P,relative as ve,resolve as F,sep as ye}from"node:path";import{fileURLToPath as be}from"node:url";import{promisify as xe}from"node:util";import{AIKIT_PATHS as Se,CONTENT_TYPES as Ce,CircuitBreaker as we,EMBEDDING_DEFAULTS as Te,HealthBus as Ee,KNOWLEDGE_ORIGINS as De,SOURCE_TYPES as Oe,TOKEN_BUDGETS as ke,addLogListener as Ae,computePartitionKey as je,createLogger as I,getGlobalDataDir as Me,getPartitionDir as Ne,isUserInstalled as Pe,listWorkspaces as Fe,serializeError as L}from"../../core/dist/index.js";import{FileCache as Ie,acquireLease as Le,addToWorkset as Re,audit as ze,bookendReorder as Be,changelog as Ve,check as He,checkpointDiff as Ue,checkpointGC as We,checkpointHistory as Ge,checkpointLatest as Ke,checkpointList as qe,checkpointLoad as Je,checkpointSave as Ye,codemod as Xe,compact as Ze,compressTerminalOutput as Qe,createRestorePoint as $e,createSearchSuccessResponse as et,dataTransform as tt,delegate as nt,delegateListModels as rt,deleteWorkset as it,diffParse as at,digest as ot,encode as st,ensureLegacyStashImported as ct,envInfo as lt,evaluate as ut,evidenceMap as dt,fileSummary as ft,find as pt,findDeadSymbols as mt,findExamples as ht,forgeClassify as gt,forgeGround as _t,getWorkset as vt,gitContext as yt,graphAugmentSearch as bt,graphQuery as xt,guide as St,health as Ct,httpRequest as wt,laneCreate as Tt,laneDiff as Et,laneDiscard as Dt,laneList as Ot,laneMerge as kt,laneStatus as At,listActiveLeases as jt,listRestorePoints as Mt,listWorksets as Nt,measure as Pt,onboard as Ft,parseOutput as It,processList as Lt,processLogs as Rt,processStart as zt,processStatus as Bt,processStop as Vt,queueClear as Ht,queueCreate as Ut,queueDag as Wt,queueDelete as Gt,queueDone as Kt,queueFail as qt,queueGet as Jt,queueList as Yt,queueNext as Xt,queuePush as Zt,regexTest as Qt,releaseLease as $t,removeFromWorkset as en,rename as tn,replayAppend as nn,replayClear as rn,replayList as an,replayTrim as on,restoreFromPoint as sn,saveWorkset as cn,schemaValidate as ln,scopeMap as un,scoreCompliance as dn,sessionDigest as fn,sessionDigestSampling as pn,stashClear as mn,stashDelete as hn,stashGet as gn,stashList as _n,stashSet as vn,storeReversibleContext as yn,stratumCard as bn,summarizeCheckResult as xn,symbol as Sn,testRun as Cn,timeUtils as wn,trace as Tn,truncateToTokenBudget as R,watchList as En,watchStart as Dn,watchStop as On,webFetch as kn,webSearch as An}from"../../tools/dist/index.js";import{mkdir as jn,readFile as Mn,readdir as Nn,rm as Pn,stat as Fn,unlink as In,writeFile as Ln}from"node:fs/promises";import{execFile as Rn,execSync as zn}from"node:child_process";import{homedir as Bn,tmpdir as Vn}from"node:os";import{McpServer as Hn,ResourceTemplate as Un}from"@modelcontextprotocol/sdk/server/mcp.js";import{buildFormSchema as Wn,field as Gn,normalizeResponse as Kn}from"../../elicitation/dist/index.js";import{completable as qn}from"@modelcontextprotocol/sdk/server/completable.js";import{z}from"zod";import{getEngine as Jn,registerBrowserTools as Yn}from"../../browser/dist/index.js";import{BlastRadiusAnalyzer as Xn,DependencyAnalyzer as Zn,DiagramGenerator as Qn,EntryPointAnalyzer as $n,KnowledgeProducer as er,PatternAnalyzer as tr,StructureAnalyzer as nr,SymbolAnalyzer as rr}from"../../analyzers/dist/index.js";import{WasmDiagnostics as ir,WasmRuntime as ar,initializeWasm as or}from"../../chunker/dist/index.js";import{ERCache as sr,ERClient as cr,EvolutionCollector as lr,PolicyStore as ur,PushAdapter as dr,mergeResults as fr}from"../../enterprise-bridge/dist/index.js";import"../../tool-routing/dist/index.mjs";import{RESOURCE_MIME_TYPE as pr,getUiCapability as mr,registerAppResource as hr,registerAppTool as gr}from"@modelcontextprotocol/ext-apps/server";import{SqliteGraphStore as _r,allMigrations as vr,createSqliteAdapter as yr,createStateStore as br,createStore as xr,runMigrations as Sr}from"../../store/dist/index.js";import{TemplateRegistry as Cr,buildShell as wr,dashboardTemplateDefinition as Tr,defaultRegistry as Er,flameGraphTemplateDefinition as Dr,isError as Or,isResult as kr,kanbanTemplateDefinition as Ar,listSortTemplateDefinition as jr,renderSurface as Mr}from"../../blocks-core/dist/index.mjs";import{createServer as Nr}from"node:http";import{EmbedderProxy as Pr}from"../../embeddings/dist/index.js";import{FileHashCache as Fr,IncrementalIndexer as Ir}from"../../indexer/dist/index.js";function Lr(e){function t(){return!!e.server?.getClientCapabilities?.()?.elicitation}async function n(n,r){if(t())try{let t=await e.server.elicitInput({message:n,requestedSchema:r});return Kn(t?{action:t.action,content:t.content}:void 0)}catch{return}}return{get available(){return t()},async ask(e){return await n(e.message,e.schema)||{action:`decline`}},async confirm(e){let t=await n(e,Wn({confirmed:Gn.confirm(e)}));return t?.action===`accept`&&t.content?.confirmed===!0},async selectOne(e,t){let r=await n(e,Wn({selection:Gn.select(`Choose one`,t)}));if(r?.action!==`accept`)return null;let i=r.content?.selection;return typeof i==`string`?i:null},async selectMany(e,t){let r=await n(e,Wn({selections:Gn.multi(`Choose one or more`,t)}));if(r?.action!==`accept`)return[];let i=r.content?.selections;return Array.isArray(i)?i:[]},async promptText(e,t){let r=await n(e,Wn({text:Gn.text(e,{description:t})}));if(r?.action!==`accept`)return null;let i=r.content?.text;return typeof i==`string`?i:null}}}const Rr={debug:`debug`,info:`info`,warn:`warning`,error:`error`};function zr(e){return Ae(({level:t,component:n,message:r,data:i})=>{try{Promise.resolve(e.sendLoggingMessage({level:Rr[t],logger:n,data:i?{message:r,...i}:r})).catch(()=>{})}catch{}})}const Br=3e4,Vr=new Map;function Hr(e,t,n){let r=Vr.get(e);if(r&&Date.now()<r.expires)return Promise.resolve(r.data);let i=n();return Promise.resolve(i).then(n=>(Vr.set(e,{data:n,expires:Date.now()+t}),n))}function Ur(){Vr.clear()}function Wr(e,t){return Hr(`curated-paths`,Br,async()=>(await e.list()).map(e=>e.path)).then(e=>e.filter(e=>e.toLowerCase().includes(t.toLowerCase())).slice(0,20))}function Gr(e,t){return Hr(`file-paths`,Br,()=>e.listSourcePaths()).then(e=>e.filter(e=>e.toLowerCase().includes(t.toLowerCase())).slice(0,20))}function Kr(e,t){return Hr(`symbol-names`,Br,async()=>(await e.findNodes({type:`symbol`,limit:500})).map(e=>e.name)).then(e=>e.filter(e=>e.toLowerCase().includes(t.toLowerCase())).slice(0,20))}function qr(e,t){return t?_n(t).map(e=>e.key).filter(t=>t.toLowerCase().includes(e.toLowerCase())).slice(0,20):[]}function Jr(e){return Nt().map(e=>e.name).filter(t=>t.toLowerCase().includes(e.toLowerCase())).slice(0,20)}function Yr(e,t){return t?qe(t).map(e=>e.label).filter(t=>t.toLowerCase().includes(e.toLowerCase())).slice(0,20):[]}function Xr(e,t,n){if(e.registerPrompt(`ready`,{title:`AI Kit Ready`,description:`AI Kit is ready — quick-start guide for search, onboard, and workflows`},async()=>({messages:[{role:`user`,content:{type:`text`,text:[`AI Kit is ready. Quick start:`,``,'• **New project?** → `onboard({ path: "." })` for full codebase analysis','• **Returning?** → `status({})` then `search({ query: "SESSION CHECKPOINT", origin: "curated" })`','• **Exploring?** → `guide({ goal: "your task" })` for workflow recommendations','• **Quick lookup?** → `search({ query: "your question" })`'].join(`
1
+ import{n as e,t}from"./curated-manager-C5uOPept.js";import{a as n,i as r,n as i,o as a,r as o,s}from"./retention-B4ITAs7F.js";import{a as c,c as l,d as u,f as d,h as f,i as p,l as m,m as h,n as g,o as _,p as v,r as y,s as b,u as x}from"./supersession-CWEne3av.js";import{n as S,r as C}from"./resolve-sibling-1oDoO-Re.js";import{n as w,r as T}from"./evolution-BX_zTSdj.js";import{a as E,i as D,n as O,r as k,s as ee,t as te}from"./promotion-D9anNXv8.js";import{autoUpgradeScaffold as ne,getCurrentVersion as re,getUpgradeState as ie}from"./version-check-yzdUDXHC.js";import{createRequire as ae}from"node:module";import{createHash as A,randomBytes as oe,randomUUID as se,timingSafeEqual as ce}from"node:crypto";import{existsSync as j,mkdirSync as M,readFileSync as N,readdirSync as le,renameSync as ue,rmSync as de,statSync as fe,unlinkSync as pe,writeFileSync as me}from"node:fs";import{basename as he,dirname as ge,isAbsolute as _e,join as P,relative as ve,resolve as F,sep as ye}from"node:path";import{fileURLToPath as be}from"node:url";import{promisify as xe}from"node:util";import{AIKIT_PATHS as Se,CONTENT_TYPES as Ce,CircuitBreaker as we,EMBEDDING_DEFAULTS as Te,HealthBus as Ee,KNOWLEDGE_ORIGINS as De,SOURCE_TYPES as Oe,TOKEN_BUDGETS as ke,addLogListener as Ae,computePartitionKey as je,createLogger as I,getGlobalDataDir as Me,getPartitionDir as Ne,isUserInstalled as Pe,listWorkspaces as Fe,serializeError as L}from"../../core/dist/index.js";import{FileCache as Ie,acquireLease as Le,addToWorkset as Re,audit as ze,bookendReorder as Be,changelog as Ve,check as He,checkpointDiff as Ue,checkpointGC as We,checkpointHistory as Ge,checkpointLatest as Ke,checkpointList as qe,checkpointLoad as Je,checkpointSave as Ye,codemod as Xe,compact as Ze,compressTerminalOutput as Qe,createRestorePoint as $e,createSearchSuccessResponse as et,dataTransform as tt,delegate as nt,delegateListModels as rt,deleteWorkset as it,diffParse as at,digest as ot,encode as st,ensureLegacyStashImported as ct,envInfo as lt,evaluate as ut,evidenceMap as dt,fileSummary as ft,find as pt,findDeadSymbols as mt,findExamples as ht,forgeClassify as gt,forgeGround as _t,getWorkset as vt,gitContext as yt,graphAugmentSearch as bt,graphQuery as xt,guide as St,health as Ct,httpRequest as wt,laneCreate as Tt,laneDiff as Et,laneDiscard as Dt,laneList as Ot,laneMerge as kt,laneStatus as At,listActiveLeases as jt,listRestorePoints as Mt,listWorksets as Nt,measure as Pt,onboard as Ft,parseOutput as It,processList as Lt,processLogs as Rt,processStart as zt,processStatus as Bt,processStop as Vt,queueClear as Ht,queueCreate as Ut,queueDag as Wt,queueDelete as Gt,queueDone as Kt,queueFail as qt,queueGet as Jt,queueList as Yt,queueNext as Xt,queuePush as Zt,regexTest as Qt,releaseLease as $t,removeFromWorkset as en,rename as tn,replayAppend as nn,replayClear as rn,replayList as an,replayTrim as on,restoreFromPoint as sn,saveWorkset as cn,schemaValidate as ln,scopeMap as un,scoreCompliance as dn,sessionDigest as fn,sessionDigestSampling as pn,stashClear as mn,stashDelete as hn,stashGet as gn,stashList as _n,stashSet as vn,storeReversibleContext as yn,stratumCard as bn,summarizeCheckResult as xn,symbol as Sn,testRun as Cn,timeUtils as wn,trace as Tn,truncateToTokenBudget as R,watchList as En,watchStart as Dn,watchStop as On,webFetch as kn,webSearch as An}from"../../tools/dist/index.js";import{mkdir as jn,readFile as Mn,readdir as Nn,rm as Pn,stat as Fn,unlink as In,writeFile as Ln}from"node:fs/promises";import{execFile as Rn,execSync as zn}from"node:child_process";import{homedir as Bn,tmpdir as Vn}from"node:os";import{McpServer as Hn,ResourceTemplate as Un}from"@modelcontextprotocol/sdk/server/mcp.js";import{buildFormSchema as Wn,field as Gn,normalizeResponse as Kn}from"../../elicitation/dist/index.js";import{completable as qn}from"@modelcontextprotocol/sdk/server/completable.js";import{z}from"zod";import{getEngine as Jn,registerBrowserTools as Yn}from"../../browser/dist/index.js";import{BlastRadiusAnalyzer as Xn,DependencyAnalyzer as Zn,DiagramGenerator as Qn,EntryPointAnalyzer as $n,KnowledgeProducer as er,PatternAnalyzer as tr,StructureAnalyzer as nr,SymbolAnalyzer as rr}from"../../analyzers/dist/index.js";import{WasmDiagnostics as ir,WasmRuntime as ar,initializeWasm as or}from"../../chunker/dist/index.js";import{ERCache as sr,ERClient as cr,EvolutionCollector as lr,PolicyStore as ur,PushAdapter as dr,mergeResults as fr}from"../../enterprise-bridge/dist/index.js";import"../../tool-routing/dist/index.mjs";import{RESOURCE_MIME_TYPE as pr,getUiCapability as mr,registerAppResource as hr,registerAppTool as gr}from"@modelcontextprotocol/ext-apps/server";import{SqliteGraphStore as _r,allMigrations as vr,createSqliteAdapter as yr,createStateStore as br,createStore as xr,runMigrations as Sr}from"../../store/dist/index.js";import{TemplateRegistry as Cr,buildShell as wr,dashboardTemplateDefinition as Tr,defaultRegistry as Er,flameGraphTemplateDefinition as Dr,isError as Or,isResult as kr,kanbanTemplateDefinition as Ar,listSortTemplateDefinition as jr,renderSurface as Mr}from"../../blocks-core/dist/index.mjs";import{createServer as Nr}from"node:http";import{EmbedderProxy as Pr}from"../../embeddings/dist/index.js";import{FileHashCache as Fr,IncrementalIndexer as Ir}from"../../indexer/dist/index.js";function Lr(e){function t(){return!!e.server?.getClientCapabilities?.()?.elicitation}async function n(n,r){if(t())try{let t=await e.server.elicitInput({message:n,requestedSchema:r});return Kn(t?{action:t.action,content:t.content}:void 0)}catch{return}}return{get available(){return t()},async ask(e){return await n(e.message,e.schema)||{action:`decline`}},async confirm(e){let t=await n(e,Wn({confirmed:Gn.confirm(e)}));return t?.action===`accept`&&t.content?.confirmed===!0},async selectOne(e,t){let r=await n(e,Wn({selection:Gn.select(`Choose one`,t)}));if(r?.action!==`accept`)return null;let i=r.content?.selection;return typeof i==`string`?i:null},async selectMany(e,t){let r=await n(e,Wn({selections:Gn.multi(`Choose one or more`,t)}));if(r?.action!==`accept`)return[];let i=r.content?.selections;return Array.isArray(i)?i:[]},async promptText(e,t){let r=await n(e,Wn({text:Gn.text(e,{description:t})}));if(r?.action!==`accept`)return null;let i=r.content?.text;return typeof i==`string`?i:null}}}const Rr={debug:`debug`,info:`info`,warn:`warning`,error:`error`};function zr(e){return Ae(({level:t,component:n,message:r,data:i})=>{try{Promise.resolve(e.sendLoggingMessage({level:Rr[t],logger:n,data:i?{message:r,...i}:r})).catch(()=>{})}catch{}})}const Br=3e4,Vr=new Map;function Hr(e,t,n){let r=Vr.get(e);if(r&&Date.now()<r.expires)return Promise.resolve(r.data);let i=n();return Promise.resolve(i).then(n=>(Vr.set(e,{data:n,expires:Date.now()+t}),n))}function Ur(){Vr.clear()}function Wr(e,t){return Hr(`curated-paths`,Br,async()=>(await e.list()).map(e=>e.path)).then(e=>e.filter(e=>e.toLowerCase().includes(t.toLowerCase())).slice(0,20))}function Gr(e,t){return Hr(`file-paths`,Br,()=>e.listSourcePaths()).then(e=>e.filter(e=>e.toLowerCase().includes(t.toLowerCase())).slice(0,20))}function Kr(e,t){return Hr(`symbol-names`,Br,async()=>(await e.findNodes({type:`symbol`,limit:500})).map(e=>e.name)).then(e=>e.filter(e=>e.toLowerCase().includes(t.toLowerCase())).slice(0,20))}function qr(e,t){return t?_n(t).map(e=>e.key).filter(t=>t.toLowerCase().includes(e.toLowerCase())).slice(0,20):[]}function Jr(e){return Nt().map(e=>e.name).filter(t=>t.toLowerCase().includes(e.toLowerCase())).slice(0,20)}function Yr(e,t){return t?qe(t).map(e=>e.label).filter(t=>t.toLowerCase().includes(e.toLowerCase())).slice(0,20):[]}function Xr(e,t,n){if(e.registerPrompt(`ready`,{title:`AI Kit Ready`,description:`AI Kit is ready — quick-start guide for search, onboard, and workflows`},async()=>({messages:[{role:`user`,content:{type:`text`,text:[`AI Kit is ready. Quick start:`,``,'• **New project?** → `onboard({ path: "." })` for full codebase analysis','• **Returning?** → `status({})` then `search({ query: "SESSION CHECKPOINT", origin: "curated" })`','• **Exploring?** → `guide({ goal: "your task" })` for workflow recommendations','• **Quick lookup?** → `search({ query: "your question" })`'].join(`
2
2
  `)}}]})),e.registerPrompt(`onboard`,{title:`Onboard Codebase`,description:`Analyze the codebase for first-time onboarding — runs all analyzers and produces a knowledge summary`,argsSchema:{path:z.string().optional().describe(`Path to analyze (default: workspace root)`)}},async({path:e})=>({messages:[{role:`user`,content:{type:`text`,text:[`Run the full onboarding workflow for "${e??`.`}"`,``,`1. \`onboard({ path: "${e??`.`}" })\` — full codebase analysis`,`2. \`produce_knowledge({ path: "${e??`.`}" })\` — generate synthesis`,'3. `knowledge({ action: "remember", ... })` for key curated entries',"4. `status` to verify index health"].join(`
3
3
  `)}}]})),e.registerPrompt(`sessionStart`,{title:`Start AI Kit Session`,description:`Initialize an AI Kit session — check status, list knowledge, and resume from last checkpoint`},async()=>({messages:[{role:`user`,content:{type:`text`,text:[`Run the session start protocol:`,``,"1. `status({})` — check AI Kit health and onboard state",'2. `knowledge({ action: "list" })` — see stored knowledge entries','3. `search({ query: "SESSION CHECKPOINT", origin: "curated" })` — resume prior work'].join(`
4
- `)}}]})),e.registerPrompt(`sessionEnd`,{title:`End AI Kit Session`,description:`Persist decisions and create a session checkpoint before ending`,argsSchema:{summary:z.string().describe(`Brief summary of decisions made, blockers encountered, and next steps`)}},async({summary:e})=>({messages:[{role:`user`,content:{type:`text`,text:[`Run the session end protocol:`,``,'1. `knowledge({ action: "remember", title: "Session checkpoint: '+e.slice(0,60)+`...", content: "`+e.replace(/"/g,`\\"`)+'", category: "conventions" })` — persist findings',n===`smart`?`2. Smart indexing is active — index refreshes automatically`:"2. `reindex({})` — refresh search index if files changed",`3. Confirm session data saved`].join(`
4
+ `)}}]})),e.registerPrompt(`sessionEnd`,{title:`End AI Kit Session`,description:`Persist decisions and create a session checkpoint before ending`,argsSchema:{summary:z.string().describe(`Brief summary of decisions made, blockers encountered, and next steps`)}},async({summary:e})=>({messages:[{role:`user`,content:{type:`text`,text:[`Run the session end protocol:`,``,'1. `knowledge({ action: "remember", title: "Session checkpoint: '+e.slice(0,60)+`...", content: "`+e.replace(/"/g,`\\"`)+'", category: "session" })` — persist findings',n===`smart`?`2. Smart indexing is active — index refreshes automatically`:"2. `reindex({})` — refresh search index if files changed",`3. Confirm session data saved`].join(`
5
5
  `)}}]})),e.registerPrompt(`search`,{title:`Search AI Kit`,description:`Search AI Kit with hybrid semantic + keyword search`,argsSchema:{query:z.string().describe(`Search query`)}},async({query:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Search AI Kit for: "${e}"\n\nUse \`search({ query: "${e.replace(/"/g,`\\"`)}" })\` to find relevant code, documentation, and curated knowledge.`}}]})),e.registerPrompt(`remember`,{title:`Remember Knowledge`,description:`Store a decision, convention, or finding as curated knowledge`,argsSchema:{title:z.string().describe(`Title of the knowledge entry`),content:z.string().describe(`Content to remember`),category:z.enum([`conventions`,`decisions`,`patterns`,`blockers`,`tasks`]).optional().describe(`Category (default: conventions)`)}},async({title:e,content:t,category:n})=>({messages:[{role:`user`,content:{type:`text`,text:`Store this knowledge:\n\n\`knowledge({ action: "remember", title: "${e.replace(/"/g,`\\"`)}", content: "${t.replace(/"/g,`\\"`).slice(0,200)}...", category: "${n??`conventions`}" })\``}}]})),e.registerPrompt(`planTask`,{title:`Plan a Task`,description:`Generate a reading plan and scope map for a development task`,argsSchema:{task:z.string().describe(`Description of the task to plan`)}},async({task:e})=>({messages:[{role:`user`,content:{type:`text`,text:[`Plan implementation for: "${e}"`,``,'1. `search({ query: "'+e.replace(/"/g,`\\"`)+'" })` — find related code and prior decisions','2. `scope_map({ task: "'+e.replace(/"/g,`\\"`)+'" })` — generate a reading plan',"3. For each recommended file, use `file_summary` then `compact` for detail","4. `blast_radius` on planned changes to assess impact"].join(`
6
6
  `)}}]})),e.registerPrompt(`investigate`,{title:`Investigate Bug`,description:`Bug investigation workflow — parse error, find symbols, trace data flow, assess impact`,argsSchema:{error:z.string().describe(`Error message, stack trace, or bug description`)}},async({error:e})=>({messages:[{role:`user`,content:{type:`text`,text:[`Investigate this error:`,"```",e,"```",``,`Follow the bug investigation workflow:`,"1. `parse_output({ text: <error> })` — extract structured data from the error","2. `symbol({ name: <relevant symbol> })` — find definition and references",'3. `trace({ symbol: <symbol>, direction: "backward" })` — trace data flow to find root cause',"4. `blast_radius({ changed_files: [<affected files>] })` — assess fix impact"].join(`
7
7
  `)}}]})),!t)return;let{curated:r,store:i,graphStore:a}=t;e.registerPrompt(`read_knowledge`,{title:`Read Knowledge`,description:`Read a curated knowledge entry by path — with autocomplete`,argsSchema:{path:qn(z.string().describe(`Path of the curated entry (e.g. conventions/naming.md)`),async e=>Wr(r,e))}},async({path:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Read the curated knowledge entry: \`knowledge({ action: "read", path: "${e}" })\``}}]})),e.registerPrompt(`update_knowledge`,{title:`Update Knowledge`,description:`Update an existing curated knowledge entry — with autocomplete`,argsSchema:{path:qn(z.string().describe(`Path of the curated entry to update`),async e=>Wr(r,e)),content:z.string().describe(`New content for the entry`)}},async({path:e,content:t})=>({messages:[{role:`user`,content:{type:`text`,text:`Update the curated entry at "${e}":\n\n\`knowledge({ action: "update", path: "${e}", content: "${t.replace(/"/g,`\\"`).slice(0,200)}..." })\``}}]})),e.registerPrompt(`forget_knowledge`,{title:`Forget Knowledge`,description:`Delete a curated knowledge entry — with autocomplete`,argsSchema:{path:qn(z.string().describe(`Path of the curated entry to delete`),async e=>Wr(r,e))}},async({path:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Delete the curated entry: \`knowledge({ action: "forget", path: "${e}" })\``}}]})),e.registerPrompt(`lookup_file`,{title:`Lookup File`,description:`Look up an indexed file — with autocomplete`,argsSchema:{path:qn(z.string().describe(`Source file path`),async e=>Gr(i,e))}},async({path:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Look up the indexed file: \`file_summary({ path: "${e}" })\``}}]})),e.registerPrompt(`find_symbol`,{title:`Find Symbol`,description:`Find a symbol definition and references — with autocomplete`,argsSchema:{name:qn(z.string().describe(`Symbol name`),async e=>Kr(a,e))}},async({name:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Find symbol: \`symbol({ name: "${e}" })\``}}]})),e.registerPrompt(`get_stash`,{title:`Get Stash`,description:`Retrieve a stashed value by key — with autocomplete`,argsSchema:{key:qn(z.string().describe(`Stash key`),e=>qr(e,t?.stateStore))}},async({key:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Get stashed value: \`stash({ action: "get", key: "${e}" })\``}}]})),e.registerPrompt(`get_workset`,{title:`Get Workset`,description:`Load a saved workset by name — with autocomplete`,argsSchema:{name:qn(z.string().describe(`Workset name`),e=>Jr(e))}},async({name:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Load workset: \`workset({ action: "load", name: "${e}" })\``}}]})),e.registerPrompt(`load_checkpoint`,{title:`Load Checkpoint`,description:`Restore a saved checkpoint by name — with autocomplete`,argsSchema:{name:qn(z.string().describe(`Checkpoint name`),e=>Yr(e,t?.stateStore))}},async({name:e})=>({messages:[{role:`user`,content:{type:`text`,text:`Load checkpoint: \`checkpoint({ action: "load", name: "${e}" })\``}}]})),e.registerPrompt(`audit_workflow`,{title:`Audit Workflow`,description:`Run a full project quality audit: check → test_run → audit → produce recommendations`},async()=>({messages:[{role:`user`,content:{type:`text`,text:[`## Audit Workflow`,``,`Execute the following tools in sequence:`,``,"1. `check({})` — Run typecheck + lint","2. `test_run({})` — Run all tests","3. `audit({})` — Full project audit","4. Review findings and `remember` important patterns",``,`Report: pass/fail status, error counts, audit recommendations, and suggested next steps.`].join(`
@@ -17,14 +17,14 @@ import{n as e,t}from"./curated-manager-C5uOPept.js";import{a as n,i as r,n as i,
17
17
  `)})})}function wi(e,t=ei){if(!t.enabled||e.length===0)return[];let n=new Set(t.excludeTools.map(e=>e.toLowerCase())),r=e.filter(e=>!n.has(li(e.tool)));return hi([...xi(r),...Si(r),...Ci(r)].map(e=>({...e,confidence:t.initialConfidence,tags:ui([`auto-observed`,`detector:${e.detector}`,...e.tags])}))).slice(0,t.maxCandidatesPerSession)}function Ti(e){return e.split(`
18
18
  `).filter(Boolean).map(e=>{try{return JSON.parse(e)}catch{return null}}).filter(mi).map(e=>({...e,output:e.output??``}))}var Ei=class{name=`behavioral`;tools=[];buffer=[];eventCounter=0;lastDetectionTs=0;extract(e){if(this.push(yi(e)),this.eventCounter+=1,this.eventCounter%50!=0)return[];let t=Date.now();if(t-this.lastDetectionTs<3e5)return[];let n=wi(this.buffer).map(bi);return this.eventCounter=0,this.lastDetectionTs=t,n}push(e){this.buffer.push(e),this.buffer.length>100&&this.buffer.splice(0,this.buffer.length-100)}};function Di(){return new Ei}Di();const Oi={name:`build-commands`,tools:[`check`,`test_run`],extract(e){if(e.isError)return[];let t=Qr(e.result);if(!t)return[];let n=[];if(e.toolName===`check`){let r=[];if(/typecheck.*(?:pass|success|0 error)/i.test(t)&&r.push(`typecheck`),/lint.*(?:pass|success|no (?:warning|error))/i.test(t)&&r.push(`lint`),/biome.*(?:checked|no fixes)/i.test(t)&&r.push(`biome`),r.length>0){let t=[...r].sort();n.push({title:`Verified checks: ${t.join(`, `)}`,content:`The following checks passed successfully: ${t.join(`, `)}.\nRun with the \`check\` tool to verify code quality.`,category:`conventions`,tags:[`build`,`verified`,...t],hash:B(`build-checks-${t.join(`,`)}`),quality:.8,source:e.toolName})}}if(e.toolName===`test_run`){let r=t.match(/(\d+)\s*(?:tests?\s+)?pass/i),i=t.match(/(\d+)\s*(?:total|tests)/i),a=t.match(/(\d+)\s*(?:test\s+)?files?/i);if(r){let t=r[1],o=i?.[1]??t,s=a?.[1]??`unknown`;n.push({title:`Test suite summary`,content:`Test results: ${t}/${o} tests passed across ${s} test files.\nUse \`test_run\` tool to execute the test suite.`,category:`context`,tags:[`testing`,`verified`,`test-summary`],hash:B(`test-summary-${t}-${o}`),quality:.7,source:e.toolName,ttlMs:72e5})}let o=t.match(/(?:running|command|exec):\s*(.+?)$/im);if(o?.[1]){let t=o[1].trim();n.push({title:`Test command: ${t.slice(0,60)}`,content:`Verified test command: \`${t}\`\nThis command successfully ran the project's test suite.`,category:`conventions`,tags:[`testing`,`build-command`,`verified`],hash:B(`test-cmd-${t}`),quality:.9,source:e.toolName})}}return n}},ki={name:`codebase-insights`,tools:[`analyze`,`scope_map`,`blast_radius`,`onboard`],extract(e){let t=Qr(e.result);if(!t||t.length<50||e.isError)return[];let n=[];if(e.toolName===`analyze`&&e.args.aspect===`structure`){let r=typeof e.args.path==`string`?e.args.path:`.`,i=t.slice(0,600);n.push({title:`Structure: ${r}`,content:`Project structure analysis for ${r}:\n${i}`,category:`context`,tags:[`architecture`,`structure`,`analysis`],hash:B(`structure-${r}`),identityKey:`analyze:structure:${r}`,quality:Math.min(.9,$r(i)+.2),source:e.toolName})}if(e.toolName===`analyze`&&e.args.aspect===`dependencies`){let r=typeof e.args.path==`string`?e.args.path:`.`,i=t.split(/\r?\n/).filter(e=>/(?:depends on|imports?|requires?|from)\s/i.test(e)).slice(0,10);if(i.length>0){let t=`Dependency analysis for ${r}:\n${i.join(`
19
19
  `)}`;n.push({title:`Dependencies: ${r}`,content:t,category:`context`,tags:[`architecture`,`dependencies`,`analysis`],hash:B(`deps-${r}`),identityKey:`analyze:dependencies:${r}`,quality:.7,source:e.toolName})}}if(e.toolName===`blast_radius`){let r=e.args.changed_files,i=Array.isArray(r)?r.map(String).join(`, `):String(r??``);if(i&&t.length>50){let r=t.slice(0,400);n.push({title:`Blast radius: ${i.slice(0,60)}`,content:`Impact analysis for changes to ${i}:\n${r}`,category:`context`,tags:[`architecture`,`blast-radius`,`impact`],hash:B(`blast-${i}`),identityKey:`blast-radius:${i}`,quality:.6,source:e.toolName,ttlMs:36e5})}}if(e.toolName===`analyze`&&e.args.aspect===`entry_points`){let r=t.split(/\r?\n/).filter(e=>/(?:entry|export|main|bin)\b/i.test(e)).slice(0,10);r.length>0&&n.push({title:`Project entry points`,content:`Detected entry points:\n${r.join(`
20
- `)}`,category:`context`,tags:[`architecture`,`entry-points`],hash:B(`entry-points`),identityKey:`analyze:entry-points`,quality:.7,source:e.toolName})}if(e.toolName===`scope_map`){let r=typeof e.args.task==`string`?e.args.task:``;r&&t.length>100&&n.push({title:`Scope map: ${r.slice(0,60)}`,content:`Scope analysis for "${r}":\n${t.slice(0,500)}`,category:`context`,tags:[`planning`,`scope-map`],hash:B(`scope-${r}`),identityKey:`scope-map:${r}`,quality:.6,source:e.toolName,ttlMs:72e5})}return e.toolName===`onboard`&&t.length>200&&n.push({title:`Onboard analysis summary`,content:`Codebase onboarding analysis:\n${t.slice(0,800)}`,category:`context`,tags:[`onboarding`,`analysis`,`structure`],hash:B(`onboard-summary`),identityKey:`onboard:summary`,quality:.9,source:e.toolName}),n}};function Ai(e,t,n,r,i,a,o,s){return{title:e,content:t,category:`context`,tags:s,hash:B(n),identityKey:r,quality:i,ttlMs:a,source:o}}const ji={name:`context-reads`,tools:[`compact`,`file_summary`,`digest`,`lookup`,`stratum_card`],extract(e){if(e.isError)return[];let t=Qr(e.result);if(!t)return[];if(e.toolName===`compact`){let n=typeof e.args.path==`string`?e.args.path:void 0,r=typeof e.args.query==`string`?e.args.query:void 0;return!n||!r||t.length<100?[]:[Ai(`Context: ${n} (${r.slice(0,40)})`,t.slice(0,800),`compact-${n}-${r}`,`compact:${n}:${r}`,.7,72e5,e.toolName,[`context`,`compact`,`file-read`])]}if(e.toolName===`file_summary`){let n=typeof e.args.path==`string`?e.args.path:void 0;return!n||t.length<50?[]:[Ai(`Structure: ${n}`,t,`file-summary-${n}`,`file-summary:${n}`,.65,144e5,e.toolName,[`context`,`file-summary`,`structure`])]}if(e.toolName===`digest`){let n=typeof e.args.query==`string`?e.args.query:void 0;if(!n||t.length<150)return[];let r=Array.isArray(e.args.sources)?e.args.sources.map(e=>{if(!e||typeof e!=`object`)return``;let t=e.id;return typeof t==`string`?t:``}).join(`,`):``;return[Ai(`Digest: ${n.slice(0,60)}`,t.slice(0,1e3),`digest-${n}-${r}`,`digest:${n}:${r}`,.75,72e5,e.toolName,[`context`,`digest`,`compression`])]}if(e.toolName===`lookup`){let n=typeof e.args.path==`string`?e.args.path:void 0;return!n||t.length<100?[]:[Ai(`Indexed: ${n}`,t.slice(0,600),`lookup-${n}`,`lookup:${n}`,.5,72e5,e.toolName,[`context`,`lookup`,`file-content`])]}if(e.toolName===`stratum_card`){let n=Array.isArray(e.args.files)?e.args.files.filter(e=>typeof e==`string`):[],r=typeof e.args.query==`string`?e.args.query:``,i=typeof e.args.tier==`string`?e.args.tier:void 0;if(n.length===0||!i||t.length<50)return[];let a=n.join(`,`),o=i===`T2`?`stratum-${a}-${i}-${r}`:`stratum-${a}-${i}`;return[Ai(`Card [${i}]: ${n[0]} (+${n.length-1})`,t.slice(0,600),o,`stratum:${i}:${a}:${r}`,i===`T2`?.7:.55,72e5,e.toolName,[`context`,`stratum-card`,i])]}return[]}};function Mi(e,t){let n=[],r=e.toLowerCase();r.includes(`biome`)?n.push({title:`Linter: Biome`,content:`This project uses Biome for linting and formatting.`,category:`conventions`,tags:[`tooling`,`linter`,`biome`],hash:B(`convention-linter-biome`),quality:.8,source:t}):r.includes(`eslint`)&&n.push({title:`Linter: ESLint`,content:`This project uses ESLint for linting.`,category:`conventions`,tags:[`tooling`,`linter`,`eslint`],hash:B(`convention-linter-eslint`),quality:.8,source:t}),r.includes(`prettier`)&&n.push({title:`Formatter: Prettier`,content:`This project uses Prettier for code formatting.`,category:`conventions`,tags:[`tooling`,`formatter`,`prettier`],hash:B(`convention-formatter-prettier`),quality:.8,source:t}),(/strict\s*(?:mode)?.*(?:enabled|true)/i.test(e)||/"strict"\s*:\s*true/.test(e))&&n.push({title:`TypeScript strict mode enabled`,content:`This project has TypeScript strict mode enabled. Ensure all types are explicit.`,category:`conventions`,tags:[`typescript`,`strict`,`config`],hash:B(`convention-ts-strict`),quality:.8,source:t});for(let e of[`pnpm`,`yarn`,`npm`,`bun`])if(r.includes(e)&&(r.includes(`lockfile`)||r.includes(`workspace`)||r.includes(`${e} run`))){n.push({title:`Package manager: ${e}`,content:`This project uses ${e} as its package manager.`,category:`conventions`,tags:[`tooling`,`package-manager`,e],hash:B(`convention-pm-${e}`),quality:.7,source:t});break}return(r.includes(`monorepo`)||r.includes(`workspaces`)||/packages\/\w+/.test(e))&&n.push({title:`Monorepo structure detected`,content:`This project uses a monorepo structure with multiple packages.`,category:`conventions`,tags:[`architecture`,`monorepo`],hash:B(`convention-monorepo`),quality:.7,source:t}),n}function Ni(e,t){let n=[],r=e.matchAll(/(?:pattern|convention):\s*(.+?)(?:\n|$)/gi);for(let e of r){let r=e[1]?.trim();r&&r.length>20&&r.length<200&&n.push({title:`Pattern: ${r.slice(0,80)}`,content:r,category:`patterns`,tags:[`detected-pattern`],hash:B(`pattern-${r}`),quality:.6,source:t})}return n}const Pi={name:`convention-detection`,tools:[`check`,`analyze`,`onboard`],extract(e){let t=Qr(e.result);if(!t||e.isError)return[];let n=[];return n.push(...Mi(t,e.toolName)),e.toolName===`analyze`&&e.args.aspect===`patterns`&&n.push(...Ni(t,e.toolName)),n}};function Fi(e,t){return e.match(t)?.[1]?.trim()||null}function Ii(e,t,n,r,i,a){return{title:e,content:t,category:`context`,tags:n,hash:B(r),quality:i,source:a}}const Li={name:`environment-facts`,tools:[`env`,`config`,`status`],extract(e){let t=Qr(e.result);if(!t)return[];let n=[],r=Fi(t,/node(?:\.js)?\s*[:=]\s*([^\r\n]+)/i);r&&n.push(Ii(`Node.js version`,`Detected Node.js version: ${r}`,[`environment`,`node`],`node-version-${r}`,.4,e.toolName));let i=Fi(t,/(?:^|\n)os\s*[:=]\s*([^\r\n]+)/i);i&&n.push(Ii(`Operating system`,`Detected OS: ${i}`,[`environment`,`os`],`os-${i}`,.4,e.toolName));let a=Fi(t,/workspace(?: path)?\s*[:=]\s*([^\r\n]+)/i);a&&n.push(Ii(`Workspace path`,`Primary workspace path: ${a}`,[`environment`,`workspace`],`workspace-${a}`,.4,e.toolName));let o=Fi(t,/store(?: backend)?\s*[:=]\s*([^\r\n]+)/i);o&&n.push(Ii(`Store backend`,`Configured store backend: ${o}`,[`environment`,`storage`],`store-${o}`,.6,e.toolName));let s=Fi(t,/embedding(?: model)?\s*[:=]\s*([^\r\n]+)/i);return s&&n.push(Ii(`Embedding model`,`Configured embedding model: ${s}`,[`environment`,`embedding`],`embedding-${s}`,.6,e.toolName)),n}},Ri={"search-result":800,"file-card":2e3,analysis:1500,"step-summary":3e3},zi=[`search`,`file_summary`,`stratum_card`,`compact`,`blast_radius`,`scope_map`],Bi={search:`search-result`,file_summary:`file-card`,stratum_card:`file-card`,compact:`analysis`,blast_radius:`analysis`,scope_map:`step-summary`},Vi={"search-result":72e5,"file-card":144e5,analysis:144e5,"step-summary":288e5};function Hi(e){return e.replace(/\s+/g,` `).trim()}function Ui(e){return Math.max(.6,Math.min(.8,$r(e)))}function V(e,t=500){let n=Hi(e);return n.length<=t?n:`${n.slice(0,Math.max(0,t-3)).trimEnd()}...`}function Wi(e){return typeof e==`object`&&!!e}function Gi(e){try{return JSON.parse(e)}catch{return null}}function H(e){return typeof e==`string`?Hi(e):typeof e==`number`||typeof e==`boolean`?String(e):``}function Ki(e,t=5){if(!Array.isArray(e))return[];let n=[];for(let r of e){if(n.length>=t)break;if(typeof r==`string`){let e=Hi(r);e&&n.push(e);continue}if(Wi(r)){let e=H(r.path)||H(r.sourcePath)||H(r.title)||H(r.name)||H(r.label);e&&n.push(e)}}return n}function U(e,...t){for(let n of t){let t=H(e[n]);if(t)return t}return``}function qi(e){let t=[e.file,e.path,e.files,e.changed_files,e.changedFiles].flatMap(e=>typeof e==`string`?[Hi(e)]:Ki(e,6));return[...new Set(t.filter(Boolean))].slice(0,6)}function Ji(e,t=6){let n=e.match(/(?:[A-Za-z]:[\\/]|\.\/?|\.\.[\\/]|[A-Za-z0-9_.-]+\/)[^\s,:;]+\.[A-Za-z0-9]+/g)??[];return[...new Set(n.map(e=>Hi(e)))].slice(0,t)}function Yi(e,t){return e.length===0?``:`${t}: ${e.join(`, `)}`}function Xi(e,t=3){return e.split(/\r?\n/).map(e=>Hi(e)).filter(e=>e.length>=12).slice(0,t)}function Zi(e){if(!Wi(e))return``;let t=H(e.title)||H(e.path)||H(e.sourcePath)||H(e.file),n=H(e.snippet)||H(e.preview)||H(e.content)||H(e.summary);return Hi([t,n&&`- ${n}`].filter(Boolean).join(` `))}function Qi(e,t){let n=U(e,`query`),r=Gi(t);if(Wi(r)&&Array.isArray(r.results)){let e=r.results.map(e=>Zi(e)).filter(Boolean).slice(0,3);if(e.length>0)return V(`Query: ${n||`unknown`}. Top hits: ${e.join(` | `)}`,Ri[`search-result`])}let i=Xi(t,3);return V(`Query: ${n||`unknown`}. Top hits: ${i.join(` | `)}`,Ri[`search-result`])}function $i(e,t){let n=U(e,`path`,`file`),r=Gi(t);if(Wi(r)){let e=H(r.path)||n||`unknown file`,t=Ki(r.imports,4),i=Ki(r.exports,5),a=Ki(r.functions,4),o=[`File: ${e}`,Yi(i,`Exports`),Yi(t,`Imports`),Yi(a,`Functions`)].filter(Boolean);if(o.length>1)return V(o.join(`. `),Ri[`file-card`])}let i=Xi(t,4);return V(`File: ${n||`unknown file`}. Structure: ${i.join(` | `)}`,Ri[`file-card`])}function ea(e,t){let n=qi(e),r=U(e,`tier`)||`T1`,i=Gi(t);if(Wi(i)){let e=(Array.isArray(i.cards)?i.cards:[]).map(e=>Zi(e)).filter(Boolean).slice(0,3);if(e.length>0)return V(`Tier: ${r}. Files: ${n.join(`, `)||`unknown`}. Cards: ${e.join(` | `)}`,Ri[`file-card`])}let a=Xi(t,3);return V(`Tier: ${r}. Files: ${n.join(`, `)||`unknown`}. Highlights: ${a.join(` | `)}`,Ri[`file-card`])}function ta(e,t){let n=U(e,`path`,`file`),r=U(e,`query`);return V(`Path: ${n||`unknown`}. Focus: ${r||`general`}. Summary: ${t}`,Ri.analysis)}function na(e,t){let n=qi(e),r=Gi(t),i=Wi(r)?[...Ki(r.affectedFiles,8),...Ki(r.tests,4),...Ki(r.importers,4)]:[],a=[...new Set([...i,...Ji(t,8)])].slice(0,8),o=[`Changed: ${n.join(`, `)||`unknown`}`,Yi(a,`Affected`)].filter(Boolean);return o.length>1?V(o.join(`. `),Ri.analysis):V(`Changed: ${n.join(`, `)||`unknown`}. Summary: ${t}`,Ri.analysis)}function ra(e,t){let n=U(e,`task`),r=Gi(t);if(Wi(r)){let e=Ki(r.files,6),t=typeof r.totalFiles==`number`?r.totalFiles:e.length;if(e.length>0)return V(`Task: ${n||`unknown`}. Reading plan (${t} files): ${e.join(`, `)}`,Ri[`step-summary`])}let i=Ji(t,6);return V(`Task: ${n||`unknown`}. Reading plan: ${i.join(`, `)||Xi(t,3).join(` | `)}`,Ri[`step-summary`])}function ia(e,t){switch(e.toolName){case`search`:return Qi(e.args,t);case`file_summary`:return $i(e.args,t);case`stratum_card`:return ea(e.args,t);case`compact`:return ta(e.args,t);case`blast_radius`:return na(e.args,t);case`scope_map`:return ra(e.args,t);default:return``}}function aa(e){switch(e.toolName){case`search`:return V(`Search: ${U(e.args,`query`)||`unknown query`}`,120);case`file_summary`:return V(`File summary: ${U(e.args,`path`,`file`)||`unknown file`}`,120);case`stratum_card`:return V(`Stratum card: ${qi(e.args).join(`, `)||`unknown files`}${U(e.args,`tier`)?` (${U(e.args,`tier`)})`:``}`,120);case`compact`:return V(`Compact: ${U(e.args,`path`,`file`)||`unknown path`}${U(e.args,`query`)?` - ${U(e.args,`query`)}`:``}`,120);case`blast_radius`:return V(`Blast radius: ${qi(e.args).join(`, `)||`unknown changes`}`,120);case`scope_map`:return V(`Scope map: ${U(e.args,`task`)||`unknown task`}`,120);default:return V(`Flow context: ${e.toolName}`,120)}}function oa(e){switch(e.toolName){case`search`:return`search:${U(e.args,`query`)||`unknown-query`}`;case`file_summary`:return`file-summary:${U(e.args,`path`,`file`)||`unknown-file`}`;case`stratum_card`:{let t=qi(e.args).join(`,`),n=U(e.args,`tier`)||`unknown-tier`,r=U(e.args,`query`);return`stratum:${n}:${t}${r?`:${r}`:``}`}case`compact`:{let t=U(e.args,`path`,`file`)||`unknown-path`,n=U(e.args,`query`);return`compact:${t}${n?`:${n}`:``}`}case`blast_radius`:return`blast-radius:${qi(e.args).join(`,`)||`unknown-changes`}`;case`scope_map`:return`scope-map:${U(e.args,`task`)||`unknown-task`}`;default:return`${e.toolName}:generic`}}function sa(e){return{name:`flow-context`,tools:[...zi],extract(t){if(t.isError)return[];let n=e();if(!n?.active||!n.slug||!(t.toolName in Bi))return[];let r=Qr(t.result).trim();if(r.length<50)return[];let i=Bi[t.toolName],a=ia(t,r);if(a.length<50)return[];let o=aa(t);return[{title:o,content:a,category:`flow-context`,tags:[`flow-context`,`flow:${n.slug}`,i,`tool:${t.toolName}`],hash:B(`${n.slug}|${t.toolName}|${o}|${a}`),identityKey:oa(t),quality:Ui(a),ttlMs:Vi[i],source:t.toolName}]}}}const ca={name:`research-results`,tools:[`web_search`,`web_fetch`,`search`,`find`],extract(e){let t=Qr(e.result);if(!t||t.length<100||e.isError)return[];let n=[];if(e.toolName===`web_search`){let r=typeof e.args.query==`string`?e.args.query:``;if(r&&t.length>200){let i=t.slice(0,800);n.push({title:`Web research: ${r.slice(0,80)}`,content:`Research query: "${r}"\n\nKey findings:\n${i}`,category:`context`,tags:[`research`,`web-search`],hash:B(`web-search-${r}`),quality:Math.min(.8,$r(i)+.2),source:e.toolName,ttlMs:864e5})}}if(e.toolName===`web_fetch`){let r=e.args.urls,i=Array.isArray(r)?String(r[0]??``):typeof e.args.url==`string`?e.args.url:``;if(i&&t.length>200){let r=t.split(/\r?\n/).find(e=>e.trim().length>10)?.trim()??i,a=t.slice(0,600);n.push({title:`Fetched: ${r.slice(0,80)}`,content:`Source: ${i}\n\n${a}`,category:`context`,tags:[`research`,`web-fetch`],hash:B(`web-fetch-${i}`),quality:$r(a),source:e.toolName,ttlMs:864e5})}}if(e.toolName===`search`){let r=typeof e.args.query==`string`?e.args.query:``,i=typeof e.args.origin==`string`?e.args.origin:``,a=typeof e.args.search_mode==`string`?e.args.search_mode:`hybrid`;i===`curated`&&r&&t.length>100&&n.push({title:`Curated search: ${r.slice(0,80)}`,content:`Searched curated knowledge for: "${r}"\n\nResults:\n${t.slice(0,500)}`,category:`context`,tags:[`research`,`curated-search`],hash:B(`curated-search-${r}`),quality:.5,source:e.toolName,ttlMs:36e5}),i!==`curated`&&r&&t.length>150&&n.push({title:`Search: ${r.slice(0,80)}`,content:t.slice(0,500),category:`context`,tags:[`research`,`search`,i||`hybrid`,a],hash:B(`search-${r}-${i||`hybrid`}-${a}`),quality:.5,source:e.toolName,ttlMs:36e5})}if(e.toolName===`find`){let r=typeof e.args.query==`string`?e.args.query:``,i=typeof e.args.pattern==`string`?e.args.pattern:``,a=typeof e.args.glob==`string`?e.args.glob:``,o=typeof e.args.mode==`string`?e.args.mode:``,s=r||i||a||``;s&&t.length>100&&n.push({title:o?`Find (${o}): ${s.slice(0,60)}`:`Find: ${s.slice(0,60)}`,content:t.slice(0,600),category:`context`,tags:[`research`,`find`,o||`search`],hash:B(`find-${r}-${i}-${a}-${o}`),quality:.55,source:e.toolName,ttlMs:36e5})}return n}},la=new Set([`neighbors`,`traverse`,`find_nodes`,`symbol360`]),ua=144e5;function da(e,t){return e.slice(0,t).trim()}function fa(e,t){let n=da(t,800);return n.length<80?[]:[{title:`Symbol: ${e}`,content:n,category:`patterns`,tags:[`architecture`,`symbol`,`definition`],hash:B(`symbol-${e}`),quality:.7,ttlMs:ua,source:`symbol`}]}function pa(e,t,n){let r=da(n,800);return r.length<100?[]:[{title:`Trace ${t}: ${e}`,content:r,category:`patterns`,tags:[`architecture`,`trace`,`data-flow`,t],hash:B(`trace-${e}-${t}`),quality:.75,ttlMs:ua,source:`trace`}]}function ma(e,t){return e===`find_nodes`?`Graph nodes: ${t}`:e===`neighbors`?`Graph neighbors: ${t}`:e===`traverse`?`Graph traverse: ${t}`:`Symbol360: ${t}`}function ha(e,t,n,r,i){let a=da(i,600);return a.length<50?[]:[{title:ma(e,t),content:a,category:`patterns`,tags:[`architecture`,`graph`,e],hash:B(`graph-${e}-${t}-${n}-${r}`),quality:.6,ttlMs:ua,source:`graph`}]}const ga={name:`symbol-analysis`,tools:[`symbol`,`trace`,`graph`],extract(e){let t=Qr(e.result);if(!t||e.isError)return[];if(e.toolName===`symbol`){let n=typeof e.args.name==`string`?e.args.name:``;return n?fa(n,t):[]}if(e.toolName===`trace`){let n=typeof e.args.start==`string`?e.args.start:``,r=typeof e.args.direction==`string`?e.args.direction:``;return!n||!r?[]:pa(n,r,t)}if(e.toolName===`graph`){let n=typeof e.args.action==`string`?e.args.action:``;if(!la.has(n))return[];let r=typeof e.args.node_id==`string`?e.args.node_id:``,i=typeof e.args.name_pattern==`string`?e.args.name_pattern:``;if(n===`find_nodes`&&!i||(n===`neighbors`||n===`traverse`||n===`symbol360`)&&!r)return[];let a=typeof e.args.direction==`string`?e.args.direction:`both`,o=typeof e.args.max_depth==`number`?String(e.args.max_depth):``;return ha(n,n===`find_nodes`?i:r,a,o,t)}return[]}};function _a(e){let t=e.toLowerCase();return t.includes(`vitest`)?`vitest`:t.includes(`jest`)?`jest`:t.includes(`mocha`)?`mocha`:t.includes(`playwright`)?`playwright`:t.includes(`cypress`)?`cypress`:null}function va(e){let t=[/(\S+\.test\.\w+)/,/(\S+\.spec\.\w+)/,/(\S+_test\.\w+)/,/__tests__\/\S+/],n=new Set;for(let r of t){let t=e.matchAll(new RegExp(r.source,`g`));for(let e of t){let t=e[0].match(/\.(test|spec)\.\w+$/);t&&n.add(t[0])}}return n.size>0?[...n].join(`, `):null}const ya={name:`test-results`,tools:[`check`,`test_run`],extract(e){let t=Qr(e.result);if(!t)return[];let n=[],r=_a(t);r&&n.push({title:`Test framework: ${r}`,content:`This project uses ${r} for testing. Detected from ${e.toolName} output.`,category:`context`,tags:[`testing`,`environment`,r],hash:B(`test-framework-${r}`),quality:.7,source:e.toolName});let i=va(t);return i&&n.push({title:`Test file pattern: ${i}`,content:`Test files use the naming pattern: ${i}. Follow this convention when creating new tests.`,category:`conventions`,tags:[`testing`,`naming-convention`],hash:B(`test-pattern-${i}`),quality:.7,source:e.toolName}),n}};function ba(e){let t=e.toLowerCase();return/enoent|no such file|not found/i.test(e)?{type:`missing-file`,actionable:!1}:/econnreset|econnrefused|etimedout|fetch failed/i.test(e)?{type:`network`,actionable:!1}:/permission denied|eacces/i.test(e)?{type:`permission`,actionable:!0}:/type\s*error|cannot.*property|is not a function/i.test(e)?{type:`type-error`,actionable:!0}:/syntax\s*error|unexpected token|parsing error/i.test(e)?{type:`syntax`,actionable:!0}:/out of memory|heap|allocation/i.test(e)?{type:`memory`,actionable:!0}:/timeout|timed out/i.test(e)?{type:`timeout`,actionable:t.includes(`increase`)||t.includes(`config`)}:/import|require|module not found|cannot find module/i.test(e)?{type:`module-resolution`,actionable:!0}:{type:`unknown`,actionable:e.length>100}}const xa={name:`tool-failure-patterns`,tools:[],extract(e){if(!e.isError)return[];let t=Qr(e.result);if(!t||t.length<30)return[];let{type:n,actionable:r}=ba(t);if(!r)return[];let i=t.slice(0,500),a=$r(i);return a<.2?[]:[{title:`${n} error in ${e.toolName}`,content:`Tool \`${e.toolName}\` failed with a ${n} error.\n\nArgs: ${JSON.stringify(e.args,null,2).slice(0,200)}\n\nError:\n${i}`,category:`context`,tags:[`errors`,n,e.toolName],hash:B(`smart-error-${n}-${e.toolName}-${t.slice(0,80)}`),quality:Math.min(.7,a+.1),source:e.toolName,ttlMs:72e5}]}};var Sa=class{extractors=[];register(e){this.extractors.push(e)}getExtractors(e){return this.extractors.filter(t=>t.tools.length===0||t.tools.includes(e))}extractAll(e){return this.getExtractors(e.toolName).flatMap(t=>t.extract(e))}};function Ca(e){return{content:[{type:`text`,text:(e instanceof Error,String(e))}],isError:!0}}function wa(e,t){try{e.push(t)}catch{}}function Ta(e){return async(t,n)=>{let r=Date.now();try{let i=await n();return wa(e,{toolName:t.toolName,args:t.args,result:i,durationMs:Date.now()-r,isError:i.isError===!0,timestamp:new Date().toISOString()}),i}catch(n){throw wa(e,{toolName:t.toolName,args:t.args,result:Ca(n),durationMs:Date.now()-r,isError:!0,timestamp:new Date().toISOString()}),n}}}const W=I(`auto-knowledge`);var Ea=class{registry;curated;flowContextAdapter;queue=[];timer=null;seenHashes=new Map;failedBuffer=[];maxBufferSize=50;storedCount=0;droppedCount=0;dedupedCount=0;bufferDropCount=0;recoveryListenerRegistered=!1;config;existingCuratedEntries=null;recoveryListener=null;constructor(e,t,n={},r){this.registry=e,this.curated=t,this.flowContextAdapter=r,this.config={...Zr,...n}}push(e){if(!(!this.config.enabled||!this.curated&&!this.flowContextAdapter)&&!(this.storedCount>=this.config.maxFactsPerSession)){if(this.queue.push(e),this.queue.length>=this.config.batchSize){this.flush().catch(e=>{W.warn(`Auto-knowledge flush error`,{error:String(e)})});return}this.scheduleBatch()}}async flush(){this.timer&&=(clearTimeout(this.timer),null);let e=this.queue.splice(0);if(e.length===0||!this.curated&&!this.flowContextAdapter)return;this.existingCuratedEntries===null&&(this.existingCuratedEntries=await this.loadExistingCuratedEntries());let t=new Map;for(let n of e)for(let e of this.registry.extractAll(n)){if(e.quality<this.config.minQuality){this.droppedCount++;continue}if(this.isSeenRecently(e)){this.dedupedCount++;continue}let n=this.buildFactIdentity(e),r=t.get(n);if(r){t.set(n,this.choosePreferredFact(r,e)),this.dedupedCount++;continue}t.set(n,e)}for(let e of t.values()){if(this.storedCount>=this.config.maxFactsPerSession)break;if(Ee.instance().isDegraded(`embedder`)){W.debug?.(`Auto-knowledge embedder degraded — buffering fact`),this.bufferFact(e);continue}try{await this.storeFact(e)}catch(t){W.warn(`Auto-knowledge store failed — buffered for retry`,{title:e.title,error:String(t)}),this.bufferFact(e)}}}reset(){this.queue=[],this.seenHashes.clear(),this.failedBuffer.length=0,this.storedCount=0,this.droppedCount=0,this.dedupedCount=0,this.bufferDropCount=0,this.existingCuratedEntries=null,this.removeRecoveryListener(),this.timer&&=(clearTimeout(this.timer),null)}getStats(){return{queued:this.queue.length,stored:this.storedCount,seen:this.seenHashes.size,dropped:this.droppedCount,deduped:this.dedupedCount,bufferSize:this.failedBuffer.length,bufferDropped:this.bufferDropCount}}bufferFact(e){this.failedBuffer.length>=this.maxBufferSize&&(this.failedBuffer.shift(),this.bufferDropCount++),this.failedBuffer.push(e),this.ensureRecoveryListener()}ensureRecoveryListener(){if(this.recoveryListenerRegistered)return;let e=Ee.instance(),t=n=>{n.subsystem===`embedder`&&(e.removeListener(`healthy`,t),this.recoveryListener=null,this.recoveryListenerRegistered=!1,this.flushBuffer().catch(e=>{W.warn(`Buffer flush failed`,{error:String(e)})}))};this.recoveryListener=t,this.recoveryListenerRegistered=!0,e.on(`healthy`,t)}removeRecoveryListener(){if(!this.recoveryListener){this.recoveryListenerRegistered=!1;return}Ee.instance().removeListener(`healthy`,this.recoveryListener),this.recoveryListener=null,this.recoveryListenerRegistered=!1}async flushBuffer(){if(this.failedBuffer.length===0||!this.curated&&!this.flowContextAdapter)return;this.existingCuratedEntries===null&&(this.existingCuratedEntries=await this.loadExistingCuratedEntries()),W.info(`Flushing ${this.failedBuffer.length} buffered auto-knowledge facts`);let e=this.failedBuffer.splice(0);for(let t=0;t<e.length;t++){let n=e[t];if(n){if(this.storedCount>=this.config.maxFactsPerSession){this.failedBuffer.unshift(...e.slice(t));break}if(Ee.instance().isDegraded(`embedder`)){this.failedBuffer.unshift(...e.slice(t)),this.ensureRecoveryListener();break}try{let e=await this.storeFact(n);(e===`created`||e===`updated`)&&W.info(`Buffered fact stored on recovery`,{title:n.title,status:e})}catch(r){W.warn(`Auto-knowledge store failed — buffered for retry`,{title:n.title,error:String(r)}),this.failedBuffer.unshift(n,...e.slice(t+1)),this.ensureRecoveryListener();break}}}}isSeenRecently(e){let t=this.seenHashes.get(e.hash);return t==null?!1:e.ttlMs==null?!0:Date.now()-t<e.ttlMs}normalizeTitle(e){return e.toLowerCase().trim()}buildFactIdentity(e){let t=e.identityKey?`key:${e.identityKey}`:`hash:${e.hash||this.normalizeTitle(e.title)}`;return`${e.category}:${t}`}choosePreferredFact(e,t){return t.quality===e.quality?e:t.quality>e.quality?t:e}slugify(e){return e.toLowerCase().replace(/[^a-z0-9]+/g,`-`).replace(/^-|-$/g,``).slice(0,80)||`untitled`}resolveCuratedRelativePath(e){let t=`${e.category}/auto-${this.slugify(e.identityKey??e.title)}.md`,n=this.existingCuratedEntries??[],r=n.find(e=>e.path===t);if(r)return r.path;let i=this.normalizeTitle(e.title),a=n.filter(t=>t.category===e.category&&this.normalizeTitle(t.title)===i);return a.length===0?t:(a.sort((t,n)=>{let r=this.tagOverlapScore(n.tags,e.tags),i=this.tagOverlapScore(t.tags,e.tags);return r===i?t.path.localeCompare(n.path):r-i}),a[0]?.path??t)}resolveFlowContextRelativePath(e){return`${e.tags.find(e=>!e.startsWith(`flow:`)&&!e.startsWith(`tool:`)&&e!==`flow-context`)||`analysis`}/${this.slugify(e.identityKey??e.title)}.md`}tagOverlapScore(e,t){let n=new Set(e),r=0;for(let e of t)n.has(e)&&(r+=1);return r}markFactSeen(e){this.seenHashes.set(e.hash,Date.now())}rememberExistingCuratedFact(e,t){let n=this.existingCuratedEntries;if(!n)return;let r=n.find(t=>t.path===e);if(r){r.title=t.title,r.category=t.category,r.tags=[...t.tags];return}n.push({path:e,title:t.title,category:t.category,tags:[...t.tags]})}async storeFact(e){if(e.tags.includes(`flow-context`)&&this.flowContextAdapter){let t=this.resolveFlowContextRelativePath(e),n=`# ${e.title}\n\n${e.content}`,r=await this.flowContextAdapter.read(t);if(r===n)return this.markFactSeen(e),this.dedupedCount++,`unchanged`;await this.flowContextAdapter.write(t,n);let i=r==null?`created`:`updated`;return this.markFactSeen(e),this.storedCount++,W.info(i===`created`?`Auto-knowledge stored`:`Auto-knowledge refreshed`,{title:e.title,category:e.category,quality:e.quality,source:e.source,status:i}),i}else if(this.curated){let t=this.resolveCuratedRelativePath(e),n=`Auto-knowledge refresh from ${e.source}`,r=this.curated;if(typeof r.upsertAutoKnowledge==`function`){let i=await r.upsertAutoKnowledge(t,e.title,e.content,e.category,e.tags,n);return this.markFactSeen(e),this.rememberExistingCuratedFact(i.path,e),i.status===`unchanged`?(this.dedupedCount++,`unchanged`):(this.storedCount++,W.info(i.status===`created`?`Auto-knowledge stored`:`Auto-knowledge refreshed`,{title:e.title,category:e.category,quality:e.quality,source:e.source,status:i.status}),i.status)}await this.curated.remember(e.title,e.content,e.category,e.tags)}else return`skipped`;return this.markFactSeen(e),this.storedCount++,this.curated&&this.rememberExistingCuratedFact(this.resolveCuratedRelativePath(e),e),W.info(`Auto-knowledge stored`,{title:e.title,category:e.category,quality:e.quality,source:e.source}),`created`}async loadExistingCuratedEntries(){let e=this.curated;if(!e)return[];try{return(await e.list()).map(e=>({path:e.path,title:e.title,category:e.category,tags:[...e.tags]}))}catch{W.warn(`Failed to load existing curated entries for dedup`,{})}return[]}scheduleBatch(){this.timer||=setTimeout(()=>{this.timer=null,this.flush().catch(e=>{W.warn(`Auto-knowledge flush error`,{error:String(e)})})},this.config.debounceMs)}};const Da=/```/,Oa=/^\s*(?:import|export|function|class|interface|type|const|let|var|return|if|for|while|switch|try|catch|throw|await|async)\b/,ka=/=>|;\s*$|{\s*$|}\s*$|:\s*(?:string|number|boolean|unknown|void|any|Record|Array|Set|Map|Promise|ReadonlyArray)\b/;function Aa(e){if(e.includes("```")||Da.test(e))return!0;let t=e.split(/\r?\n/u).filter(e=>e.trim().length>0);if(t.length<3)return!1;let n=0;for(let e of t)(Oa.test(e)||ka.test(e))&&(n+=1);return n/t.length>=.25}function ja(e){let t=e.meta?.compression?.preserve??`balanced`;if(t===`exact`||Aa(e.text))return{profile:`exact`,shouldCompress:!1,mode:`structural`,threshold:e.threshold,tokenBudget:e.tokenBudget,reason:t===`exact`?`tool-specific preservation profile`:`code-like output preserved verbatim`};if(t===`dense`){let t=Math.max(1,Math.floor(e.threshold*.65)),n=Math.max(1,Math.floor(e.tokenBudget*.6));return{profile:`dense`,shouldCompress:e.text.length>=t,mode:`aggressive`,threshold:t,tokenBudget:n,reason:`dense tool profile`}}return{profile:`balanced`,shouldCompress:e.text.length>=e.threshold,mode:`structural`,threshold:e.threshold,tokenBudget:e.tokenBudget,reason:`balanced tool profile`}}const Ma={search:{title:`Hybrid Search`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`dense`}},find:{title:`Federated Find`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`dense`}},symbol:{title:`Symbol Resolver — Cross-Module Definitions & References`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},trace:{title:`Data Flow Tracer — Cross-Module Call & Import Chains`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},scope_map:{title:`Task Scope Map`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},lookup:{title:`Chunk Lookup`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},dead_symbols:{title:`Dead Symbol Finder`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},file_summary:{title:`File Summary`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`,selfManaged:!0}},analyze:{title:`Analyze`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`analysis`],compression:{preserve:`exact`}},blast_radius:{title:`Blast Radius`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`analysis`,`search`],compression:{preserve:`exact`}},knowledge:{title:`Knowledge`,annotations:{readOnlyHint:!1},category:[`knowledge`],compression:{preserve:`balanced`}},memory_explain:{title:`Memory Explain`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`knowledge`,`search`],compression:{preserve:`exact`}},produce_knowledge:{title:`Produce Knowledge`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`knowledge`],compression:{preserve:`exact`}},compact:{title:`Semantic Compactor`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`compression`],compression:{preserve:`balanced`}},digest:{title:`Multi-Source Digest`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`compression`],compression:{preserve:`balanced`}},stratum_card:{title:`Stratum Card`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`compression`],compression:{preserve:`balanced`}},forge_ground:{title:`FORGE Ground`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`forge`],compression:{preserve:`exact`}},forge_classify:{title:`FORGE Classify`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`forge`],compression:{preserve:`exact`}},evidence_map:{title:`Evidence Map`,annotations:{readOnlyHint:!1},category:[`forge`],compression:{preserve:`exact`}},present:{title:`Rich Content Presenter`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`presentation`],compression:{preserve:`balanced`}},check:{title:`Typecheck & Lint`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`execution`],compression:{preserve:`dense`,selfManaged:!0}},test_run:{title:`Run Tests`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`execution`],compression:{preserve:`dense`}},eval:{title:`Evaluate Code`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`execution`],compression:{preserve:`dense`}},audit:{title:`Project Audit`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`execution`],compression:{preserve:`dense`,selfManaged:!0}},browser:{title:`Browser Automation`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`}},rename:{title:`Rename Symbol`,annotations:{readOnlyHint:!1,destructiveHint:!0},category:[`manipulation`],compression:{preserve:`dense`}},restore:{title:`Restore`,annotations:{readOnlyHint:!1},category:[`manipulation`],compression:{preserve:`dense`}},codemod:{title:`Codemod`,annotations:{readOnlyHint:!1,destructiveHint:!0},category:[`manipulation`],compression:{preserve:`dense`}},data_transform:{title:`Data Transform`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`manipulation`],compression:{preserve:`exact`}},stash:{title:`Stash Values`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`}},signal:{title:`Inter-Agent Signaling`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`}},checkpoint:{title:`Session Checkpoint`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`}},session_digest:{title:`Session Digest`,annotations:{readOnlyHint:!0,idempotentHint:!1},category:[`session`],compression:{preserve:`balanced`}},compliance_score:{title:`Compliance Score`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`session`],compression:{preserve:`exact`}},workset:{title:`Workset Manager`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`}},lane:{title:`Exploration Lane`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`}},git_context:{title:`Git Context`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`git`],compression:{preserve:`exact`}},diff_parse:{title:`Diff Parser`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`git`],compression:{preserve:`exact`}},parse_output:{title:`Parse Build Output`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`git`],compression:{preserve:`exact`}},process:{title:`Process Manager`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`process`],compression:{preserve:`dense`}},watch:{title:`File Watcher`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`process`],compression:{preserve:`dense`}},delegate:{title:`Delegate Task`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`process`],compression:{preserve:`dense`}},config:{title:`Configuration Manager`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`exact`}},status:{title:`AI Kit Status`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},health:{title:`Health Check`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},reindex:{title:`Reindex`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`dense`}},onboard:{title:`Onboard Codebase`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`dense`}},graph:{title:`Code Knowledge Graph — Module & Symbol Relationships`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`}},guide:{title:`Tool Guide`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},replay:{title:`Replay History`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`dense`}},list_tools:{title:`List Available Tools`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`meta`],compression:{preserve:`exact`}},describe_tool:{title:`Describe Tool`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`meta`],compression:{preserve:`exact`}},search_tools:{title:`Search Tools`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`meta`],compression:{preserve:`exact`}},changelog:{title:`Generate Changelog`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`balanced`}},regex_test:{title:`Regex Tester`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`}},encode:{title:`Encode / Decode`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`}},measure:{title:`Code Metrics`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`dense`}},schema_validate:{title:`Schema Validator`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`}},env:{title:`Environment Info`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`}},time:{title:`Date & Time`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`}},web_fetch:{title:`Web Fetch`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`}},web_search:{title:`Web Search`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`}},http:{title:`HTTP Request`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`}},queue:{title:`Operation Queue`,annotations:{readOnlyHint:!1},category:[`queue`],compression:{preserve:`dense`}},bridge_push:{title:`Bridge Push`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`}},bridge_pull:{title:`Bridge Pull`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},bridge_sync:{title:`Bridge Sync Status`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},er_push:{title:`Enterprise Push`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`}},er_pull:{title:`Enterprise Pull`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},er_sync_status:{title:`Enterprise Sync Status`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},er_update_policy:{title:`Enterprise Update Policy`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`}},er_evolve_review:{title:`Enterprise Evolution Review`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},evolution_state:{title:`Evolution State`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`}},policy_check:{title:`Policy Check`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`}},flow:{title:`Flow`,annotations:{readOnlyHint:!1},category:[`flow`],compression:{preserve:`balanced`}}};function G(e){return Ma[e]??{title:e,annotations:{readOnlyHint:!1},category:[]}}function Na(e){switch(e){case`efficient`:return{threshold:2e3,tokenBudget:1e3};case`full`:return{threshold:1/0};default:return{threshold:4e3,tokenBudget:2e3}}}function Pa(e){let t=e?.threshold??4e3,n=e?.tokenBudget??2e3;return async(e,r)=>{if(G(e.toolName).compression?.selfManaged)return r();let i=await r();if(!Array.isArray(i.content))return i;let a={profile:`balanced`,applied:!1,reason:`below threshold`,mode:`structural`,threshold:t,tokenBudget:n,originalChars:0,compressedChars:0,savedChars:0,compressedItems:0,preservedItems:0},o=i.content.map(r=>{if(r.type!==`text`||typeof r.text!=`string`)return r;a.originalChars+=r.text.length;let i=ja({meta:e.meta,text:r.text,threshold:t,tokenBudget:n});if(a.profile=i.profile,a.mode=i.mode,a.threshold=i.threshold,a.tokenBudget=i.tokenBudget,a.reason=i.reason,!i.shouldCompress||r.text.length<i.threshold)return a.preservedItems+=1,a.compressedChars+=r.text.length,r;let o=Qe({text:r.text,tool:e.toolName,tokenBudget:i.tokenBudget,mode:i.mode});return a.applied=!0,a.compressedItems+=1,a.compressedChars+=o.text.length,o.text===r.text?r:{...r,text:o.text}});return a.originalChars===0?i:(a.savedChars=a.originalChars-a.compressedChars,{...i,content:o,_meta:{...i._meta??{},compression:a}})}}var Fa=class{baseDir;getActiveSlug;constructor(e,t){this.baseDir=e,this.getActiveSlug=t}async initialize(){await jn(this.baseDir,{recursive:!0})}async read(e){let t=this.resolveScopedPath(e);if(t==null)return null;try{return await Mn(t,`utf-8`)}catch(e){if(this.isMissingError(e))return null;throw e}}async write(e,t,n){let r=this.resolveScopedPath(e);r!=null&&(await jn(ge(r),{recursive:!0}),await Ln(r,t,{encoding:`utf-8`,flag:n?.exclusive?`wx`:`w`}))}async delete(e){let t=this.resolveScopedPath(e);if(t==null)return!1;try{return await In(t),!0}catch(e){if(this.isMissingError(e))return!1;throw e}}async list(e){let t=this.getActiveSlugDir();if(t==null)return[];let n=e?this.resolveScopedPath(e):t;return n==null?[]:this.collectFiles(n,e??``)}async exists(e){let t=this.resolveScopedPath(e);if(t==null)return!1;try{return await Fn(t),!0}catch(e){if(this.isMissingError(e))return!1;throw e}}async listDirectories(){let e=this.getActiveSlugDir();if(e==null)return[];try{return(await Nn(e,{withFileTypes:!0})).filter(e=>e.isDirectory()&&/^[a-z][a-z0-9-]*$/.test(e.name)).map(e=>e.name).sort()}catch(e){if(this.isMissingError(e))return[];throw e}}async flushAll(){let e=this.getActiveSlugDir();if(e==null)return 0;let t=await this.countFiles(e);return t===0?0:(await Pn(e,{recursive:!0,force:!0}),t)}async close(){}getActiveSlugDir(){let e=this.getActiveSlug();return e?P(this.baseDir,e):null}resolveScopedPath(e){let t=this.getActiveSlugDir();if(t==null)return null;let n=F(t),r=F(n,e),i=ve(n,r);if(i===``||i===`..`||i.startsWith(`..${ye}`)||_e(i))throw Error(`Path escapes active flow context scope: ${e}`);return r}async collectFiles(e,t){let n;try{n=await Nn(e,{withFileTypes:!0})}catch(e){if(this.isMissingError(e))return[];throw e}let r=[];for(let i of n){let n=t?`${t}/${i.name}`:i.name,a=P(e,i.name);if(i.isDirectory()){r.push(...await this.collectFiles(a,n));continue}if(!(!i.isFile()||!i.name.endsWith(`.md`)))try{let e=await Fn(a);r.push({path:n,size:e.size,mtimeMs:e.mtimeMs})}catch(e){if(!this.isMissingError(e))throw e}}return r.sort((e,t)=>e.path.localeCompare(t.path))}async countFiles(e){let t;try{t=await Nn(e,{withFileTypes:!0})}catch(e){if(this.isMissingError(e))return 0;throw e}let n=0;for(let r of t){let t=P(e,r.name);if(r.isDirectory()){n+=await this.countFiles(t);continue}r.isFile()&&(n+=1)}return n}isMissingError(e){return typeof e==`object`&&!!e&&`code`in e&&(e.code===`ENOENT`||e.code===`ENOTDIR`)}};const Ia=I(`observation-capture`),La=[`check`,`test_run`,`search`,`trace`],Ra=[/\bAuthorization\s*:\s*Bearer\s+[A-Za-z0-9\-._~+/]+=*/gi,/\bBearer\s+[A-Za-z0-9\-._~+/]+=*/g,/\b(?:sk|ghp|gho|glpat|xoxb|xoxp)-[A-Za-z0-9\-._]{20,}\b/g,/\b(?:token|key|secret|password|auth(?:orization)?)\s*[=:]\s*['"]?[^\s'"&]{8,}/gi,/\b(?:token|key|secret|password|auth(?:orization)?)=[^\s&]+/gi,/\b[A-Z][A-Z0-9_]*(?:PASSWORD|SECRET|TOKEN|AUTH)[A-Z0-9_]*\b\s*[=:]\s*['"]?[^\s'"]+/g,/\b[A-Z][A-Z0-9_]*KEY[A-Z0-9_]*\b\s*[=:]\s*['"]?[^\s'"]{8,}/g,/-----BEGIN [\w\s]+-----[\s\S]*?-----END [\w\s]+-----/g],za=new Set([`env`,`auth`,`config`]),Ba=2e3,Va={enabled:!0,rateLimit:10,captureFrom:[...La],minContentLength:50};var Ha=class{maxPerMinute;timestamps=[];constructor(e){this.maxPerMinute=e}canCapture(e=Date.now()){return this.prune(e),this.timestamps.length<this.maxPerMinute}record(e=Date.now()){this.prune(e),this.timestamps.push(e)}setLimit(e){this.maxPerMinute=e,this.prune(Date.now())}prune(e){let t=e-6e4;this.timestamps=this.timestamps.filter(e=>e>t)}};function Ua(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function Wa(e){return typeof e==`string`?e:Ua(e)?[Array.isArray(e.content)?e.content.filter(e=>Ua(e)).map(e=>typeof e.text==`string`?e.text:``).filter(e=>e.length>0).join(`
20
+ `)}`,category:`context`,tags:[`architecture`,`entry-points`],hash:B(`entry-points`),identityKey:`analyze:entry-points`,quality:.7,source:e.toolName})}if(e.toolName===`scope_map`){let r=typeof e.args.task==`string`?e.args.task:``;r&&t.length>100&&n.push({title:`Scope map: ${r.slice(0,60)}`,content:`Scope analysis for "${r}":\n${t.slice(0,500)}`,category:`context`,tags:[`planning`,`scope-map`],hash:B(`scope-${r}`),identityKey:`scope-map:${r}`,quality:.6,source:e.toolName,ttlMs:72e5})}return e.toolName===`onboard`&&t.length>200&&n.push({title:`Onboard analysis summary`,content:`Codebase onboarding analysis:\n${t.slice(0,800)}`,category:`context`,tags:[`onboarding`,`analysis`,`structure`],hash:B(`onboard-summary`),identityKey:`onboard:summary`,quality:.9,source:e.toolName}),n}};function Ai(e,t,n,r,i,a,o,s){return{title:e,content:t,category:`context`,tags:s,hash:B(n),identityKey:r,quality:i,ttlMs:a,source:o}}const ji={name:`context-reads`,tools:[`compact`,`file_summary`,`digest`,`lookup`,`stratum_card`],extract(e){if(e.isError)return[];let t=Qr(e.result);if(!t)return[];if(e.toolName===`compact`){let n=typeof e.args.path==`string`?e.args.path:void 0,r=typeof e.args.query==`string`?e.args.query:void 0;return!n||!r||t.length<100?[]:[Ai(`Context: ${n} (${r.slice(0,40)})`,t.slice(0,800),`compact-${n}-${r}`,`compact:${n}:${r}`,.7,72e5,e.toolName,[`context`,`compact`,`file-read`])]}if(e.toolName===`file_summary`){let n=typeof e.args.path==`string`?e.args.path:void 0;return!n||t.length<50?[]:[Ai(`Structure: ${n}`,t,`file-summary-${n}`,`file-summary:${n}`,.65,144e5,e.toolName,[`context`,`file-summary`,`structure`])]}if(e.toolName===`digest`){let n=typeof e.args.query==`string`?e.args.query:void 0;if(!n||t.length<150)return[];let r=Array.isArray(e.args.sources)?e.args.sources.map(e=>{if(!e||typeof e!=`object`)return``;let t=e.id;return typeof t==`string`?t:``}).join(`,`):``;return[Ai(`Digest: ${n.slice(0,60)}`,t.slice(0,1e3),`digest-${n}-${r}`,`digest:${n}:${r}`,.75,72e5,e.toolName,[`context`,`digest`,`compression`])]}if(e.toolName===`lookup`){let n=typeof e.args.path==`string`?e.args.path:void 0;return!n||t.length<100?[]:[Ai(`Indexed: ${n}`,t.slice(0,600),`lookup-${n}`,`lookup:${n}`,.5,72e5,e.toolName,[`context`,`lookup`,`file-content`])]}if(e.toolName===`stratum_card`){let n=Array.isArray(e.args.files)?e.args.files.filter(e=>typeof e==`string`):[],r=typeof e.args.query==`string`?e.args.query:``,i=typeof e.args.tier==`string`?e.args.tier:void 0;if(n.length===0||!i||t.length<50)return[];let a=n.join(`,`),o=i===`T2`?`stratum-${a}-${i}-${r}`:`stratum-${a}-${i}`;return[Ai(`Card [${i}]: ${n[0]} (+${n.length-1})`,t.slice(0,600),o,`stratum:${i}:${a}:${r}`,i===`T2`?.7:.55,72e5,e.toolName,[`context`,`stratum-card`,i])]}return[]}};function Mi(e,t){let n=[],r=e.toLowerCase();r.includes(`biome`)?n.push({title:`Linter: Biome`,content:`This project uses Biome for linting and formatting.`,category:`conventions`,tags:[`tooling`,`linter`,`biome`],hash:B(`convention-linter-biome`),quality:.8,source:t}):r.includes(`eslint`)&&n.push({title:`Linter: ESLint`,content:`This project uses ESLint for linting.`,category:`conventions`,tags:[`tooling`,`linter`,`eslint`],hash:B(`convention-linter-eslint`),quality:.8,source:t}),r.includes(`prettier`)&&n.push({title:`Formatter: Prettier`,content:`This project uses Prettier for code formatting.`,category:`conventions`,tags:[`tooling`,`formatter`,`prettier`],hash:B(`convention-formatter-prettier`),quality:.8,source:t}),(/strict\s*(?:mode)?.*(?:enabled|true)/i.test(e)||/"strict"\s*:\s*true/.test(e))&&n.push({title:`TypeScript strict mode enabled`,content:`This project has TypeScript strict mode enabled. Ensure all types are explicit.`,category:`conventions`,tags:[`typescript`,`strict`,`config`],hash:B(`convention-ts-strict`),quality:.8,source:t});for(let e of[`pnpm`,`yarn`,`npm`,`bun`])if(r.includes(e)&&(r.includes(`lockfile`)||r.includes(`workspace`)||r.includes(`${e} run`))){n.push({title:`Package manager: ${e}`,content:`This project uses ${e} as its package manager.`,category:`conventions`,tags:[`tooling`,`package-manager`,e],hash:B(`convention-pm-${e}`),quality:.7,source:t});break}return(r.includes(`monorepo`)||r.includes(`workspaces`)||/packages\/\w+/.test(e))&&n.push({title:`Monorepo structure detected`,content:`This project uses a monorepo structure with multiple packages.`,category:`conventions`,tags:[`architecture`,`monorepo`],hash:B(`convention-monorepo`),quality:.7,source:t}),n}function Ni(e,t){let n=[],r=e.matchAll(/(?:pattern|convention):\s*(.+?)(?:\n|$)/gi);for(let e of r){let r=e[1]?.trim();r&&r.length>20&&r.length<200&&n.push({title:`Pattern: ${r.slice(0,80)}`,content:r,category:`patterns`,tags:[`detected-pattern`],hash:B(`pattern-${r}`),quality:.6,source:t})}return n}const Pi={name:`convention-detection`,tools:[`check`,`analyze`,`onboard`],extract(e){let t=Qr(e.result);if(!t||e.isError)return[];let n=[];return n.push(...Mi(t,e.toolName)),e.toolName===`analyze`&&e.args.aspect===`patterns`&&n.push(...Ni(t,e.toolName)),n}};function Fi(e,t){return e.match(t)?.[1]?.trim()||null}function Ii(e,t,n,r,i,a){return{title:e,content:t,category:`context`,tags:n,hash:B(r),quality:i,source:a}}const Li={name:`environment-facts`,tools:[`env`,`config`,`status`],extract(e){let t=Qr(e.result);if(!t)return[];let n=[],r=Fi(t,/node(?:\.js)?\s*[:=]\s*([^\r\n]+)/i);r&&n.push(Ii(`Node.js version`,`Detected Node.js version: ${r}`,[`environment`,`node`],`node-version-${r}`,.4,e.toolName));let i=Fi(t,/(?:^|\n)os\s*[:=]\s*([^\r\n]+)/i);i&&n.push(Ii(`Operating system`,`Detected OS: ${i}`,[`environment`,`os`],`os-${i}`,.4,e.toolName));let a=Fi(t,/workspace(?: path)?\s*[:=]\s*([^\r\n]+)/i);a&&n.push(Ii(`Workspace path`,`Primary workspace path: ${a}`,[`environment`,`workspace`],`workspace-${a}`,.4,e.toolName));let o=Fi(t,/store(?: backend)?\s*[:=]\s*([^\r\n]+)/i);o&&n.push(Ii(`Store backend`,`Configured store backend: ${o}`,[`environment`,`storage`],`store-${o}`,.6,e.toolName));let s=Fi(t,/embedding(?: model)?\s*[:=]\s*([^\r\n]+)/i);return s&&n.push(Ii(`Embedding model`,`Configured embedding model: ${s}`,[`environment`,`embedding`],`embedding-${s}`,.6,e.toolName)),n}},Ri={"search-result":800,"file-card":2e3,analysis:1500,"step-summary":3e3},zi=[`search`,`file_summary`,`stratum_card`,`compact`,`blast_radius`,`scope_map`],Bi={search:`search-result`,file_summary:`file-card`,stratum_card:`file-card`,compact:`analysis`,blast_radius:`analysis`,scope_map:`step-summary`},Vi={"search-result":72e5,"file-card":144e5,analysis:144e5,"step-summary":288e5};function Hi(e){return e.replace(/\s+/g,` `).trim()}function Ui(e){return Math.max(.6,Math.min(.8,$r(e)))}function V(e,t=500){let n=Hi(e);return n.length<=t?n:`${n.slice(0,Math.max(0,t-3)).trimEnd()}...`}function Wi(e){return typeof e==`object`&&!!e}function Gi(e){try{return JSON.parse(e)}catch{return null}}function H(e){return typeof e==`string`?Hi(e):typeof e==`number`||typeof e==`boolean`?String(e):``}function Ki(e,t=5){if(!Array.isArray(e))return[];let n=[];for(let r of e){if(n.length>=t)break;if(typeof r==`string`){let e=Hi(r);e&&n.push(e);continue}if(Wi(r)){let e=H(r.path)||H(r.sourcePath)||H(r.title)||H(r.name)||H(r.label);e&&n.push(e)}}return n}function U(e,...t){for(let n of t){let t=H(e[n]);if(t)return t}return``}function qi(e){let t=[e.file,e.path,e.files,e.changed_files,e.changedFiles].flatMap(e=>typeof e==`string`?[Hi(e)]:Ki(e,6));return[...new Set(t.filter(Boolean))].slice(0,6)}function Ji(e,t=6){let n=e.match(/(?:[A-Za-z]:[\\/]|\.\/?|\.\.[\\/]|[A-Za-z0-9_.-]+\/)[^\s,:;]+\.[A-Za-z0-9]+/g)??[];return[...new Set(n.map(e=>Hi(e)))].slice(0,t)}function Yi(e,t){return e.length===0?``:`${t}: ${e.join(`, `)}`}function Xi(e,t=3){return e.split(/\r?\n/).map(e=>Hi(e)).filter(e=>e.length>=12).slice(0,t)}function Zi(e){if(!Wi(e))return``;let t=H(e.title)||H(e.path)||H(e.sourcePath)||H(e.file),n=H(e.snippet)||H(e.preview)||H(e.content)||H(e.summary);return Hi([t,n&&`- ${n}`].filter(Boolean).join(` `))}function Qi(e,t){let n=U(e,`query`),r=Gi(t);if(Wi(r)&&Array.isArray(r.results)){let e=r.results.map(e=>Zi(e)).filter(Boolean).slice(0,3);if(e.length>0)return V(`Query: ${n||`unknown`}. Top hits: ${e.join(` | `)}`,Ri[`search-result`])}let i=Xi(t,3);return V(`Query: ${n||`unknown`}. Top hits: ${i.join(` | `)}`,Ri[`search-result`])}function $i(e,t){let n=U(e,`path`,`file`),r=Gi(t);if(Wi(r)){let e=H(r.path)||n||`unknown file`,t=Ki(r.imports,4),i=Ki(r.exports,5),a=Ki(r.functions,4),o=[`File: ${e}`,Yi(i,`Exports`),Yi(t,`Imports`),Yi(a,`Functions`)].filter(Boolean);if(o.length>1)return V(o.join(`. `),Ri[`file-card`])}let i=Xi(t,4);return V(`File: ${n||`unknown file`}. Structure: ${i.join(` | `)}`,Ri[`file-card`])}function ea(e,t){let n=qi(e),r=U(e,`tier`)||`T1`,i=Gi(t);if(Wi(i)){let e=(Array.isArray(i.cards)?i.cards:[]).map(e=>Zi(e)).filter(Boolean).slice(0,3);if(e.length>0)return V(`Tier: ${r}. Files: ${n.join(`, `)||`unknown`}. Cards: ${e.join(` | `)}`,Ri[`file-card`])}let a=Xi(t,3);return V(`Tier: ${r}. Files: ${n.join(`, `)||`unknown`}. Highlights: ${a.join(` | `)}`,Ri[`file-card`])}function ta(e,t){let n=U(e,`path`,`file`),r=U(e,`query`);return V(`Path: ${n||`unknown`}. Focus: ${r||`general`}. Summary: ${t}`,Ri.analysis)}function na(e,t){let n=qi(e),r=Gi(t),i=Wi(r)?[...Ki(r.affectedFiles,8),...Ki(r.tests,4),...Ki(r.importers,4)]:[],a=[...new Set([...i,...Ji(t,8)])].slice(0,8),o=[`Changed: ${n.join(`, `)||`unknown`}`,Yi(a,`Affected`)].filter(Boolean);return o.length>1?V(o.join(`. `),Ri.analysis):V(`Changed: ${n.join(`, `)||`unknown`}. Summary: ${t}`,Ri.analysis)}function ra(e,t){let n=U(e,`task`),r=Gi(t);if(Wi(r)){let e=Ki(r.files,6),t=typeof r.totalFiles==`number`?r.totalFiles:e.length;if(e.length>0)return V(`Task: ${n||`unknown`}. Reading plan (${t} files): ${e.join(`, `)}`,Ri[`step-summary`])}let i=Ji(t,6);return V(`Task: ${n||`unknown`}. Reading plan: ${i.join(`, `)||Xi(t,3).join(` | `)}`,Ri[`step-summary`])}function ia(e,t){switch(e.toolName){case`search`:return Qi(e.args,t);case`file_summary`:return $i(e.args,t);case`stratum_card`:return ea(e.args,t);case`compact`:return ta(e.args,t);case`blast_radius`:return na(e.args,t);case`scope_map`:return ra(e.args,t);default:return``}}function aa(e){switch(e.toolName){case`search`:return V(`Search: ${U(e.args,`query`)||`unknown query`}`,120);case`file_summary`:return V(`File summary: ${U(e.args,`path`,`file`)||`unknown file`}`,120);case`stratum_card`:return V(`Stratum card: ${qi(e.args).join(`, `)||`unknown files`}${U(e.args,`tier`)?` (${U(e.args,`tier`)})`:``}`,120);case`compact`:return V(`Compact: ${U(e.args,`path`,`file`)||`unknown path`}${U(e.args,`query`)?` - ${U(e.args,`query`)}`:``}`,120);case`blast_radius`:return V(`Blast radius: ${qi(e.args).join(`, `)||`unknown changes`}`,120);case`scope_map`:return V(`Scope map: ${U(e.args,`task`)||`unknown task`}`,120);default:return V(`Flow context: ${e.toolName}`,120)}}function oa(e){switch(e.toolName){case`search`:return`search:${U(e.args,`query`)||`unknown-query`}`;case`file_summary`:return`file-summary:${U(e.args,`path`,`file`)||`unknown-file`}`;case`stratum_card`:{let t=qi(e.args).join(`,`),n=U(e.args,`tier`)||`unknown-tier`,r=U(e.args,`query`);return`stratum:${n}:${t}${r?`:${r}`:``}`}case`compact`:{let t=U(e.args,`path`,`file`)||`unknown-path`,n=U(e.args,`query`);return`compact:${t}${n?`:${n}`:``}`}case`blast_radius`:return`blast-radius:${qi(e.args).join(`,`)||`unknown-changes`}`;case`scope_map`:return`scope-map:${U(e.args,`task`)||`unknown-task`}`;default:return`${e.toolName}:generic`}}function sa(e){return{name:`flow-context`,tools:[...zi],extract(t){if(t.isError)return[];let n=e();if(!n?.active||!n.slug||!(t.toolName in Bi))return[];let r=Qr(t.result).trim();if(r.length<50)return[];let i=Bi[t.toolName],a=ia(t,r);if(a.length<50)return[];let o=aa(t);return[{title:o,content:a,category:`flow-context`,tags:[`flow-context`,`flow:${n.slug}`,i,`tool:${t.toolName}`],hash:B(`${n.slug}|${t.toolName}|${o}|${a}`),identityKey:oa(t),quality:Ui(a),ttlMs:Vi[i],source:t.toolName}]}}}const ca={name:`research-results`,tools:[`web_search`,`web_fetch`,`search`,`find`],extract(e){let t=Qr(e.result);if(!t||t.length<100||e.isError)return[];let n=[];if(e.toolName===`web_search`){let r=typeof e.args.query==`string`?e.args.query:``;if(r&&t.length>200){let i=t.slice(0,800);n.push({title:`Web research: ${r.slice(0,80)}`,content:`Research query: "${r}"\n\nKey findings:\n${i}`,category:`context`,tags:[`research`,`web-search`],hash:B(`web-search-${r}`),quality:Math.min(.8,$r(i)+.2),source:e.toolName,ttlMs:864e5})}}if(e.toolName===`web_fetch`){let r=e.args.urls,i=Array.isArray(r)?String(r[0]??``):typeof e.args.url==`string`?e.args.url:``;if(i&&t.length>200){let r=t.split(/\r?\n/).find(e=>e.trim().length>10)?.trim()??i,a=t.slice(0,600);n.push({title:`Fetched: ${r.slice(0,80)}`,content:`Source: ${i}\n\n${a}`,category:`context`,tags:[`research`,`web-fetch`],hash:B(`web-fetch-${i}`),quality:$r(a),source:e.toolName,ttlMs:864e5})}}if(e.toolName===`search`){let r=typeof e.args.query==`string`?e.args.query:``,i=typeof e.args.origin==`string`?e.args.origin:``,a=typeof e.args.search_mode==`string`?e.args.search_mode:`hybrid`;i===`curated`&&r&&t.length>100&&n.push({title:`Curated search: ${r.slice(0,80)}`,content:`Searched curated knowledge for: "${r}"\n\nResults:\n${t.slice(0,500)}`,category:`context`,tags:[`research`,`curated-search`],hash:B(`curated-search-${r}`),quality:.5,source:e.toolName,ttlMs:36e5}),i!==`curated`&&r&&t.length>150&&n.push({title:`Search: ${r.slice(0,80)}`,content:t.slice(0,500),category:`context`,tags:[`research`,`search`,i||`hybrid`,a],hash:B(`search-${r}-${i||`hybrid`}-${a}`),quality:.5,source:e.toolName,ttlMs:36e5})}if(e.toolName===`find`){let r=typeof e.args.query==`string`?e.args.query:``,i=typeof e.args.pattern==`string`?e.args.pattern:``,a=typeof e.args.glob==`string`?e.args.glob:``,o=typeof e.args.mode==`string`?e.args.mode:``,s=r||i||a||``;s&&t.length>100&&n.push({title:o?`Find (${o}): ${s.slice(0,60)}`:`Find: ${s.slice(0,60)}`,content:t.slice(0,600),category:`context`,tags:[`research`,`find`,o||`search`],hash:B(`find-${r}-${i}-${a}-${o}`),quality:.55,source:e.toolName,ttlMs:36e5})}return n}},la=new Set([`neighbors`,`traverse`,`find_nodes`,`symbol360`]),ua=144e5;function da(e,t){return e.slice(0,t).trim()}function fa(e,t){let n=da(t,800);return n.length<80?[]:[{title:`Symbol: ${e}`,content:n,category:`patterns`,tags:[`architecture`,`symbol`,`definition`],hash:B(`symbol-${e}`),quality:.7,ttlMs:ua,source:`symbol`}]}function pa(e,t,n){let r=da(n,800);return r.length<100?[]:[{title:`Trace ${t}: ${e}`,content:r,category:`patterns`,tags:[`architecture`,`trace`,`data-flow`,t],hash:B(`trace-${e}-${t}`),quality:.75,ttlMs:ua,source:`trace`}]}function ma(e,t){return e===`find_nodes`?`Graph nodes: ${t}`:e===`neighbors`?`Graph neighbors: ${t}`:e===`traverse`?`Graph traverse: ${t}`:`Symbol360: ${t}`}function ha(e,t,n,r,i){let a=da(i,600);return a.length<50?[]:[{title:ma(e,t),content:a,category:`patterns`,tags:[`architecture`,`graph`,e],hash:B(`graph-${e}-${t}-${n}-${r}`),quality:.6,ttlMs:ua,source:`graph`}]}const ga={name:`symbol-analysis`,tools:[`symbol`,`trace`,`graph`],extract(e){let t=Qr(e.result);if(!t||e.isError)return[];if(e.toolName===`symbol`){let n=typeof e.args.name==`string`?e.args.name:``;return n?fa(n,t):[]}if(e.toolName===`trace`){let n=typeof e.args.start==`string`?e.args.start:``,r=typeof e.args.direction==`string`?e.args.direction:``;return!n||!r?[]:pa(n,r,t)}if(e.toolName===`graph`){let n=typeof e.args.action==`string`?e.args.action:``;if(!la.has(n))return[];let r=typeof e.args.node_id==`string`?e.args.node_id:``,i=typeof e.args.name_pattern==`string`?e.args.name_pattern:``;if(n===`find_nodes`&&!i||(n===`neighbors`||n===`traverse`||n===`symbol360`)&&!r)return[];let a=typeof e.args.direction==`string`?e.args.direction:`both`,o=typeof e.args.max_depth==`number`?String(e.args.max_depth):``;return ha(n,n===`find_nodes`?i:r,a,o,t)}return[]}};function _a(e){let t=e.toLowerCase();return t.includes(`vitest`)?`vitest`:t.includes(`jest`)?`jest`:t.includes(`mocha`)?`mocha`:t.includes(`playwright`)?`playwright`:t.includes(`cypress`)?`cypress`:null}function va(e){let t=[/(\S+\.test\.\w+)/,/(\S+\.spec\.\w+)/,/(\S+_test\.\w+)/,/__tests__\/\S+/],n=new Set;for(let r of t){let t=e.matchAll(new RegExp(r.source,`g`));for(let e of t){let t=e[0].match(/\.(test|spec)\.\w+$/);t&&n.add(t[0])}}return n.size>0?[...n].join(`, `):null}const ya={name:`test-results`,tools:[`check`,`test_run`],extract(e){let t=Qr(e.result);if(!t)return[];let n=[],r=_a(t);r&&n.push({title:`Test framework: ${r}`,content:`This project uses ${r} for testing. Detected from ${e.toolName} output.`,category:`context`,tags:[`testing`,`environment`,r],hash:B(`test-framework-${r}`),quality:.7,source:e.toolName});let i=va(t);return i&&n.push({title:`Test file pattern: ${i}`,content:`Test files use the naming pattern: ${i}. Follow this convention when creating new tests.`,category:`conventions`,tags:[`testing`,`naming-convention`],hash:B(`test-pattern-${i}`),quality:.7,source:e.toolName}),n}};function ba(e){let t=e.toLowerCase();return/enoent|no such file|not found/i.test(e)?{type:`missing-file`,actionable:!1}:/econnreset|econnrefused|etimedout|fetch failed/i.test(e)?{type:`network`,actionable:!1}:/permission denied|eacces/i.test(e)?{type:`permission`,actionable:!0}:/type\s*error|cannot.*property|is not a function/i.test(e)?{type:`type-error`,actionable:!0}:/syntax\s*error|unexpected token|parsing error/i.test(e)?{type:`syntax`,actionable:!0}:/out of memory|heap|allocation/i.test(e)?{type:`memory`,actionable:!0}:/timeout|timed out/i.test(e)?{type:`timeout`,actionable:t.includes(`increase`)||t.includes(`config`)}:/import|require|module not found|cannot find module/i.test(e)?{type:`module-resolution`,actionable:!0}:{type:`unknown`,actionable:e.length>100}}const xa={name:`tool-failure-patterns`,tools:[],extract(e){if(!e.isError)return[];let t=Qr(e.result);if(!t||t.length<30)return[];let{type:n,actionable:r}=ba(t);if(!r)return[];let i=t.slice(0,500),a=$r(i);return a<.2?[]:[{title:`${n} error in ${e.toolName}`,content:`Tool \`${e.toolName}\` failed with a ${n} error.\n\nArgs: ${JSON.stringify(e.args,null,2).slice(0,200)}\n\nError:\n${i}`,category:`context`,tags:[`errors`,n,e.toolName],hash:B(`smart-error-${n}-${e.toolName}-${t.slice(0,80)}`),quality:Math.min(.7,a+.1),source:e.toolName,ttlMs:72e5}]}};var Sa=class{extractors=[];register(e){this.extractors.push(e)}getExtractors(e){return this.extractors.filter(t=>t.tools.length===0||t.tools.includes(e))}extractAll(e){return this.getExtractors(e.toolName).flatMap(t=>t.extract(e))}};function Ca(e){return{content:[{type:`text`,text:(e instanceof Error,String(e))}],isError:!0}}function wa(e,t){try{e.push(t)}catch{}}function Ta(e){return async(t,n)=>{let r=Date.now();try{let i=await n();return wa(e,{toolName:t.toolName,args:t.args,result:i,durationMs:Date.now()-r,isError:i.isError===!0,timestamp:new Date().toISOString()}),i}catch(n){throw wa(e,{toolName:t.toolName,args:t.args,result:Ca(n),durationMs:Date.now()-r,isError:!0,timestamp:new Date().toISOString()}),n}}}const Ea=I(`auto-knowledge`);var Da=class{registry;curated;flowContextAdapter;queue=[];timer=null;seenHashes=new Map;failedBuffer=[];maxBufferSize=50;storedCount=0;droppedCount=0;dedupedCount=0;bufferDropCount=0;recoveryListenerRegistered=!1;config;existingCuratedEntries=null;recoveryListener=null;constructor(e,t,n={},r){this.registry=e,this.curated=t,this.flowContextAdapter=r,this.config={...Zr,...n}}push(e){if(!(!this.config.enabled||!this.curated&&!this.flowContextAdapter)&&!(this.storedCount>=this.config.maxFactsPerSession)){if(this.queue.push(e),this.queue.length>=this.config.batchSize){this.flush().catch(e=>{Ea.warn(`Auto-knowledge flush error`,{error:String(e)})});return}this.scheduleBatch()}}async flush(){this.timer&&=(clearTimeout(this.timer),null);let e=this.queue.splice(0);if(e.length===0||!this.curated&&!this.flowContextAdapter)return;this.existingCuratedEntries===null&&(this.existingCuratedEntries=await this.loadExistingCuratedEntries());let t=new Map;for(let n of e)for(let e of this.registry.extractAll(n)){if(e.quality<this.config.minQuality){this.droppedCount++;continue}if(this.isSeenRecently(e)){this.dedupedCount++;continue}let n=this.buildFactIdentity(e),r=t.get(n);if(r){t.set(n,this.choosePreferredFact(r,e)),this.dedupedCount++;continue}t.set(n,e)}for(let e of t.values()){if(this.storedCount>=this.config.maxFactsPerSession)break;if(Ee.instance().isDegraded(`embedder`)){Ea.debug?.(`Auto-knowledge embedder degraded — buffering fact`),this.bufferFact(e);continue}try{await this.storeFact(e)}catch(t){Ea.warn(`Auto-knowledge store failed — buffered for retry`,{title:e.title,error:String(t)}),this.bufferFact(e)}}}reset(){this.queue=[],this.seenHashes.clear(),this.failedBuffer.length=0,this.storedCount=0,this.droppedCount=0,this.dedupedCount=0,this.bufferDropCount=0,this.existingCuratedEntries=null,this.removeRecoveryListener(),this.timer&&=(clearTimeout(this.timer),null)}getStats(){return{queued:this.queue.length,stored:this.storedCount,seen:this.seenHashes.size,dropped:this.droppedCount,deduped:this.dedupedCount,bufferSize:this.failedBuffer.length,bufferDropped:this.bufferDropCount}}bufferFact(e){this.failedBuffer.length>=this.maxBufferSize&&(this.failedBuffer.shift(),this.bufferDropCount++),this.failedBuffer.push(e),this.ensureRecoveryListener()}ensureRecoveryListener(){if(this.recoveryListenerRegistered)return;let e=Ee.instance(),t=n=>{n.subsystem===`embedder`&&(e.removeListener(`healthy`,t),this.recoveryListener=null,this.recoveryListenerRegistered=!1,this.flushBuffer().catch(e=>{Ea.warn(`Buffer flush failed`,{error:String(e)})}))};this.recoveryListener=t,this.recoveryListenerRegistered=!0,e.on(`healthy`,t)}removeRecoveryListener(){if(!this.recoveryListener){this.recoveryListenerRegistered=!1;return}Ee.instance().removeListener(`healthy`,this.recoveryListener),this.recoveryListener=null,this.recoveryListenerRegistered=!1}async flushBuffer(){if(this.failedBuffer.length===0||!this.curated&&!this.flowContextAdapter)return;this.existingCuratedEntries===null&&(this.existingCuratedEntries=await this.loadExistingCuratedEntries()),Ea.info(`Flushing ${this.failedBuffer.length} buffered auto-knowledge facts`);let e=this.failedBuffer.splice(0);for(let t=0;t<e.length;t++){let n=e[t];if(n){if(this.storedCount>=this.config.maxFactsPerSession){this.failedBuffer.unshift(...e.slice(t));break}if(Ee.instance().isDegraded(`embedder`)){this.failedBuffer.unshift(...e.slice(t)),this.ensureRecoveryListener();break}try{let e=await this.storeFact(n);(e===`created`||e===`updated`)&&Ea.info(`Buffered fact stored on recovery`,{title:n.title,status:e})}catch(r){Ea.warn(`Auto-knowledge store failed — buffered for retry`,{title:n.title,error:String(r)}),this.failedBuffer.unshift(n,...e.slice(t+1)),this.ensureRecoveryListener();break}}}}isSeenRecently(e){let t=this.seenHashes.get(e.hash);return t==null?!1:e.ttlMs==null?!0:Date.now()-t<e.ttlMs}normalizeTitle(e){return e.toLowerCase().trim()}buildFactIdentity(e){let t=e.identityKey?`key:${e.identityKey}`:`hash:${e.hash||this.normalizeTitle(e.title)}`;return`${e.category}:${t}`}choosePreferredFact(e,t){return t.quality===e.quality?e:t.quality>e.quality?t:e}slugify(e){return e.toLowerCase().replace(/[^a-z0-9]+/g,`-`).replace(/^-|-$/g,``).slice(0,80)||`untitled`}resolveCuratedRelativePath(e){let t=`${e.category}/auto-${this.slugify(e.identityKey??e.title)}.md`,n=this.existingCuratedEntries??[],r=n.find(e=>e.path===t);if(r)return r.path;let i=this.normalizeTitle(e.title),a=n.filter(t=>t.category===e.category&&this.normalizeTitle(t.title)===i);return a.length===0?t:(a.sort((t,n)=>{let r=this.tagOverlapScore(n.tags,e.tags),i=this.tagOverlapScore(t.tags,e.tags);return r===i?t.path.localeCompare(n.path):r-i}),a[0]?.path??t)}resolveFlowContextRelativePath(e){return`${e.tags.find(e=>!e.startsWith(`flow:`)&&!e.startsWith(`tool:`)&&e!==`flow-context`)||`analysis`}/${this.slugify(e.identityKey??e.title)}.md`}tagOverlapScore(e,t){let n=new Set(e),r=0;for(let e of t)n.has(e)&&(r+=1);return r}markFactSeen(e){this.seenHashes.set(e.hash,Date.now())}rememberExistingCuratedFact(e,t){let n=this.existingCuratedEntries;if(!n)return;let r=n.find(t=>t.path===e);if(r){r.title=t.title,r.category=t.category,r.tags=[...t.tags];return}n.push({path:e,title:t.title,category:t.category,tags:[...t.tags]})}async storeFact(e){if(e.tags.includes(`flow-context`)&&this.flowContextAdapter){let t=this.resolveFlowContextRelativePath(e),n=`# ${e.title}\n\n${e.content}`,r=await this.flowContextAdapter.read(t);if(r===n)return this.markFactSeen(e),this.dedupedCount++,`unchanged`;await this.flowContextAdapter.write(t,n);let i=r==null?`created`:`updated`;return this.markFactSeen(e),this.storedCount++,Ea.info(i===`created`?`Auto-knowledge stored`:`Auto-knowledge refreshed`,{title:e.title,category:e.category,quality:e.quality,source:e.source,status:i}),i}else if(this.curated){let t=this.resolveCuratedRelativePath(e),n=`Auto-knowledge refresh from ${e.source}`,r=this.curated;if(typeof r.upsertAutoKnowledge==`function`){let i=await r.upsertAutoKnowledge(t,e.title,e.content,e.category,e.tags,n);return this.markFactSeen(e),this.rememberExistingCuratedFact(i.path,e),i.status===`unchanged`?(this.dedupedCount++,`unchanged`):(this.storedCount++,Ea.info(i.status===`created`?`Auto-knowledge stored`:`Auto-knowledge refreshed`,{title:e.title,category:e.category,quality:e.quality,source:e.source,status:i.status}),i.status)}await this.curated.remember(e.title,e.content,e.category,e.tags)}else return`skipped`;return this.markFactSeen(e),this.storedCount++,this.curated&&this.rememberExistingCuratedFact(this.resolveCuratedRelativePath(e),e),Ea.info(`Auto-knowledge stored`,{title:e.title,category:e.category,quality:e.quality,source:e.source}),`created`}async loadExistingCuratedEntries(){let e=this.curated;if(!e)return[];try{return(await e.list()).map(e=>({path:e.path,title:e.title,category:e.category,tags:[...e.tags]}))}catch{Ea.warn(`Failed to load existing curated entries for dedup`,{})}return[]}scheduleBatch(){this.timer||=setTimeout(()=>{this.timer=null,this.flush().catch(e=>{Ea.warn(`Auto-knowledge flush error`,{error:String(e)})})},this.config.debounceMs)}};const Oa=/```/,ka=/^\s*(?:import|export|function|class|interface|type|const|let|var|return|if|for|while|switch|try|catch|throw|await|async)\b/,Aa=/=>|;\s*$|{\s*$|}\s*$|:\s*(?:string|number|boolean|unknown|void|any|Record|Array|Set|Map|Promise|ReadonlyArray)\b/;function ja(e){let t=e.trimStart();if(t.length===0)return!1;let n=t.charAt(0);return n!==`{`&&n!==`[`?!1:n===`{`?!(!t.includes(`"`)||!t.includes(`:`)):t.length>2}function Ma(e){if(ja(e)||e.includes("```")||Oa.test(e))return!0;let t=e.split(/\r?\n/u).filter(e=>e.trim().length>0);if(t.length<3)return!1;let n=0;for(let e of t)(ka.test(e)||Aa.test(e))&&(n+=1);return n/t.length>=.25}function Na(e){let t=e.meta?.compression?.preserve??`balanced`;if(t===`exact`||Ma(e.text))return{profile:`exact`,shouldCompress:!1,mode:`structural`,threshold:e.threshold,tokenBudget:e.tokenBudget,reason:t===`exact`?`tool-specific preservation profile`:`code-like output preserved verbatim`};if(t===`dense`){let t=Math.max(1,Math.floor(e.threshold*.65)),n=Math.max(1,Math.floor(e.tokenBudget*.6));return{profile:`dense`,shouldCompress:e.text.length>=t,mode:`aggressive`,threshold:t,tokenBudget:n,reason:`dense tool profile`}}return{profile:`balanced`,shouldCompress:e.text.length>=e.threshold,mode:`structural`,threshold:e.threshold,tokenBudget:e.tokenBudget,reason:`balanced tool profile`}}const W={search:{title:`Hybrid Search`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`dense`}},find:{title:`Federated Find`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`dense`}},symbol:{title:`Symbol Resolver — Cross-Module Definitions & References`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},trace:{title:`Data Flow Tracer — Cross-Module Call & Import Chains`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},scope_map:{title:`Task Scope Map`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`},capabilities:{indexIndependent:!0}},lookup:{title:`Chunk Lookup`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},dead_symbols:{title:`Dead Symbol Finder`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`}},file_summary:{title:`File Summary`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`search`],compression:{preserve:`exact`,selfManaged:!0},capabilities:{indexIndependent:!0}},analyze:{title:`Analyze`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`analysis`],compression:{preserve:`exact`}},blast_radius:{title:`Blast Radius`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`analysis`,`search`],compression:{preserve:`exact`}},knowledge:{title:`Knowledge`,annotations:{readOnlyHint:!1},category:[`knowledge`],compression:{preserve:`balanced`},capabilities:{indexIndependent:!0}},memory_explain:{title:`Memory Explain`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`knowledge`,`search`],compression:{preserve:`exact`}},produce_knowledge:{title:`Produce Knowledge`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`knowledge`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},compact:{title:`Semantic Compactor`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`compression`],compression:{preserve:`balanced`},capabilities:{indexIndependent:!0}},digest:{title:`Multi-Source Digest`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`compression`],compression:{preserve:`balanced`},capabilities:{indexIndependent:!0}},stratum_card:{title:`Stratum Card`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`compression`],compression:{preserve:`balanced`},capabilities:{indexIndependent:!0}},forge_ground:{title:`FORGE Ground`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`forge`],compression:{preserve:`exact`}},forge_classify:{title:`FORGE Classify`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`forge`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},evidence_map:{title:`Evidence Map`,annotations:{readOnlyHint:!1},category:[`forge`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},present:{title:`Rich Content Presenter`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`presentation`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},check:{title:`Typecheck & Lint`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`execution`],compression:{preserve:`dense`,selfManaged:!0},capabilities:{zeroDep:!0,indexIndependent:!0}},test_run:{title:`Run Tests`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`execution`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},eval:{title:`Evaluate Code`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`execution`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},audit:{title:`Project Audit`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`execution`],compression:{preserve:`dense`,selfManaged:!0}},browser:{title:`Browser Automation`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},rename:{title:`Rename Symbol`,annotations:{readOnlyHint:!1,destructiveHint:!0},category:[`manipulation`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},restore:{title:`Restore`,annotations:{readOnlyHint:!1},category:[`manipulation`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},codemod:{title:`Codemod`,annotations:{readOnlyHint:!1,destructiveHint:!0},category:[`manipulation`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},data_transform:{title:`Data Transform`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`manipulation`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},stash:{title:`Stash Values`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`},capabilities:{indexIndependent:!0}},signal:{title:`Inter-Agent Signaling`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`},capabilities:{indexIndependent:!0}},checkpoint:{title:`Session Checkpoint`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},session_digest:{title:`Session Digest`,annotations:{readOnlyHint:!0,idempotentHint:!1},category:[`session`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},compliance_score:{title:`Compliance Score`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`session`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},workset:{title:`Workset Manager`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},lane:{title:`Exploration Lane`,annotations:{readOnlyHint:!1},category:[`session`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},git_context:{title:`Git Context`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`git`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},diff_parse:{title:`Diff Parser`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`git`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},parse_output:{title:`Parse Build Output`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`git`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},process:{title:`Process Manager`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`process`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},watch:{title:`File Watcher`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`process`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},delegate:{title:`Delegate Task`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`process`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},config:{title:`Configuration Manager`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`exact`},capabilities:{indexIndependent:!0}},status:{title:`AI Kit Status`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},health:{title:`Health Check`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},reindex:{title:`Reindex`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`dense`},capabilities:{indexIndependent:!0}},onboard:{title:`Onboard Codebase`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`dense`},capabilities:{indexIndependent:!0}},graph:{title:`Code Knowledge Graph — Module & Symbol Relationships`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`},capabilities:{indexIndependent:!0}},guide:{title:`Tool Guide`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},replay:{title:`Replay History`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},list_tools:{title:`List Available Tools`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`meta`],compression:{preserve:`exact`},capabilities:{zeroDep:!0}},describe_tool:{title:`Describe Tool`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`meta`],compression:{preserve:`exact`},capabilities:{zeroDep:!0}},search_tools:{title:`Search Tools`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`meta`],compression:{preserve:`exact`},capabilities:{zeroDep:!0}},changelog:{title:`Generate Changelog`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},regex_test:{title:`Regex Tester`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},encode:{title:`Encode / Decode`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},measure:{title:`Code Metrics`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},schema_validate:{title:`Schema Validator`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},env:{title:`Environment Info`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},time:{title:`Date & Time`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`utilities`],compression:{preserve:`exact`},capabilities:{zeroDep:!0,indexIndependent:!0}},web_fetch:{title:`Web Fetch`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},web_search:{title:`Web Search`,annotations:{readOnlyHint:!0,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},http:{title:`HTTP Request`,annotations:{readOnlyHint:!1,openWorldHint:!0},category:[`web`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0,indexIndependent:!0}},queue:{title:`Operation Queue`,annotations:{readOnlyHint:!1},category:[`queue`],compression:{preserve:`dense`},capabilities:{zeroDep:!0,indexIndependent:!0}},bridge_push:{title:`Bridge Push`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},bridge_pull:{title:`Bridge Pull`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},bridge_sync:{title:`Bridge Sync Status`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},er_push:{title:`Enterprise Push`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},er_pull:{title:`Enterprise Pull`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},er_sync_status:{title:`Enterprise Sync Status`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},er_update_policy:{title:`Enterprise Update Policy`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},er_evolve_review:{title:`Enterprise Evolution Review`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},evolution_state:{title:`Evolution State`,annotations:{readOnlyHint:!1},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},policy_check:{title:`Policy Check`,annotations:{readOnlyHint:!0,idempotentHint:!0},category:[`system`],compression:{preserve:`balanced`},capabilities:{conditional:!0}},flow:{title:`Flow`,annotations:{readOnlyHint:!1},category:[`flow`],compression:{preserve:`balanced`},capabilities:{zeroDep:!0}}},Pa=Object.keys(W).filter(e=>!W[e]?.capabilities?.conditional),Fa=new Set(Object.entries(W).filter(([e,t])=>t.capabilities?.zeroDep).map(([e])=>e)),Ia=new Set(Object.entries(W).filter(([e,t])=>t.capabilities?.indexIndependent).map(([e])=>e));function G(e){return W[e]??{title:e,annotations:{readOnlyHint:!1},category:[]}}function La(e){switch(e){case`efficient`:return{threshold:2e3,tokenBudget:1e3};case`full`:return{threshold:1/0};default:return{threshold:4e3,tokenBudget:2e3}}}function Ra(e){let t=e?.threshold??4e3,n=e?.tokenBudget??2e3;return async(e,r)=>{if(G(e.toolName).compression?.selfManaged)return r();let i=await r();if(!Array.isArray(i.content))return i;let a={profile:`balanced`,applied:!1,reason:`below threshold`,mode:`structural`,threshold:t,tokenBudget:n,originalChars:0,compressedChars:0,savedChars:0,compressedItems:0,preservedItems:0},o=i.content.map(r=>{if(r.type!==`text`||typeof r.text!=`string`)return r;a.originalChars+=r.text.length;let i=Na({meta:e.meta,text:r.text,threshold:t,tokenBudget:n});if(a.profile=i.profile,a.mode=i.mode,a.threshold=i.threshold,a.tokenBudget=i.tokenBudget,a.reason=i.reason,!i.shouldCompress||r.text.length<i.threshold)return a.preservedItems+=1,a.compressedChars+=r.text.length,r;let o=Qe({text:r.text,tool:e.toolName,tokenBudget:i.tokenBudget,mode:i.mode});return a.applied=!0,a.compressedItems+=1,a.compressedChars+=o.text.length,o.text===r.text?r:{...r,text:o.text}});return a.originalChars===0?i:(a.savedChars=a.originalChars-a.compressedChars,{...i,content:o,_meta:{...i._meta??{},compression:a}})}}var za=class{baseDir;getActiveSlug;constructor(e,t){this.baseDir=e,this.getActiveSlug=t}async initialize(){await jn(this.baseDir,{recursive:!0})}async read(e){let t=this.resolveScopedPath(e);if(t==null)return null;try{return await Mn(t,`utf-8`)}catch(e){if(this.isMissingError(e))return null;throw e}}async write(e,t,n){let r=this.resolveScopedPath(e);r!=null&&(await jn(ge(r),{recursive:!0}),await Ln(r,t,{encoding:`utf-8`,flag:n?.exclusive?`wx`:`w`}))}async delete(e){let t=this.resolveScopedPath(e);if(t==null)return!1;try{return await In(t),!0}catch(e){if(this.isMissingError(e))return!1;throw e}}async list(e){let t=this.getActiveSlugDir();if(t==null)return[];let n=e?this.resolveScopedPath(e):t;return n==null?[]:this.collectFiles(n,e??``)}async exists(e){let t=this.resolveScopedPath(e);if(t==null)return!1;try{return await Fn(t),!0}catch(e){if(this.isMissingError(e))return!1;throw e}}async listDirectories(){let e=this.getActiveSlugDir();if(e==null)return[];try{return(await Nn(e,{withFileTypes:!0})).filter(e=>e.isDirectory()&&/^[a-z][a-z0-9-]*$/.test(e.name)).map(e=>e.name).sort()}catch(e){if(this.isMissingError(e))return[];throw e}}async flushAll(){let e=this.getActiveSlugDir();if(e==null)return 0;let t=await this.countFiles(e);return t===0?0:(await Pn(e,{recursive:!0,force:!0}),t)}async close(){}getActiveSlugDir(){let e=this.getActiveSlug();return e?P(this.baseDir,e):null}resolveScopedPath(e){let t=this.getActiveSlugDir();if(t==null)return null;let n=F(t),r=F(n,e),i=ve(n,r);if(i===``||i===`..`||i.startsWith(`..${ye}`)||_e(i))throw Error(`Path escapes active flow context scope: ${e}`);return r}async collectFiles(e,t){let n;try{n=await Nn(e,{withFileTypes:!0})}catch(e){if(this.isMissingError(e))return[];throw e}let r=[];for(let i of n){let n=t?`${t}/${i.name}`:i.name,a=P(e,i.name);if(i.isDirectory()){r.push(...await this.collectFiles(a,n));continue}if(!(!i.isFile()||!i.name.endsWith(`.md`)))try{let e=await Fn(a);r.push({path:n,size:e.size,mtimeMs:e.mtimeMs})}catch(e){if(!this.isMissingError(e))throw e}}return r.sort((e,t)=>e.path.localeCompare(t.path))}async countFiles(e){let t;try{t=await Nn(e,{withFileTypes:!0})}catch(e){if(this.isMissingError(e))return 0;throw e}let n=0;for(let r of t){let t=P(e,r.name);if(r.isDirectory()){n+=await this.countFiles(t);continue}r.isFile()&&(n+=1)}return n}isMissingError(e){return typeof e==`object`&&!!e&&`code`in e&&(e.code===`ENOENT`||e.code===`ENOTDIR`)}};const Ba=I(`observation-capture`),Va=[`check`,`test_run`,`search`,`trace`],Ha=[/\bAuthorization\s*:\s*Bearer\s+[A-Za-z0-9\-._~+/]+=*/gi,/\bBearer\s+[A-Za-z0-9\-._~+/]+=*/g,/\b(?:sk|ghp|gho|glpat|xoxb|xoxp)-[A-Za-z0-9\-._]{20,}\b/g,/\b(?:token|key|secret|password|auth(?:orization)?)\s*[=:]\s*['"]?[^\s'"&]{8,}/gi,/\b(?:token|key|secret|password|auth(?:orization)?)=[^\s&]+/gi,/\b[A-Z][A-Z0-9_]*(?:PASSWORD|SECRET|TOKEN|AUTH)[A-Z0-9_]*\b\s*[=:]\s*['"]?[^\s'"]+/g,/\b[A-Z][A-Z0-9_]*KEY[A-Z0-9_]*\b\s*[=:]\s*['"]?[^\s'"]{8,}/g,/-----BEGIN [\w\s]+-----[\s\S]*?-----END [\w\s]+-----/g],Ua=new Set([`env`,`auth`,`config`]),Wa=2e3,Ga={enabled:!0,rateLimit:10,captureFrom:[...Va],minContentLength:50};var Ka=class{maxPerMinute;timestamps=[];constructor(e){this.maxPerMinute=e}canCapture(e=Date.now()){return this.prune(e),this.timestamps.length<this.maxPerMinute}record(e=Date.now()){this.prune(e),this.timestamps.push(e)}setLimit(e){this.maxPerMinute=e,this.prune(Date.now())}prune(e){let t=e-6e4;this.timestamps=this.timestamps.filter(e=>e>t)}};function qa(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function Ja(e){return typeof e==`string`?e:qa(e)?[Array.isArray(e.content)?e.content.filter(e=>qa(e)).map(e=>typeof e.text==`string`?e.text:``).filter(e=>e.length>0).join(`
21
21
  `):``,e.structuredContent==null?``:JSON.stringify(e.structuredContent,null,2)].filter(e=>e.length>0).join(`
22
22
 
23
- `):JSON.stringify(e)}function Ga(e,t=500){return e.length<=t?e:e.slice(0,t)}function Ka(e){let t=e.toLowerCase();return[...za].some(e=>t===e||t.includes(e))}function qa(e){let t=e;for(let e of Ra)t=t.replace(e,`[REDACTED]`);return t.length>Ba&&(t=`${t.slice(0,Ba)}\n...[truncated]`),t}function Ja(e,t){let n=t?.args??{},r=[];switch(t?.workspace&&r.push(`workspace=${t.workspace}`),e){case`check`:typeof n.cwd==`string`&&r.push(`cwd=${n.cwd}`),Array.isArray(n.files)&&n.files.length>0&&r.push(`files=${n.files.join(`, `)}`);break;case`test_run`:typeof n.cwd==`string`&&r.push(`cwd=${n.cwd}`),typeof n.grep==`string`&&r.push(`grep=${n.grep}`),Array.isArray(n.files)&&n.files.length>0&&r.push(`files=${n.files.join(`, `)}`);break;case`search`:typeof n.query==`string`&&r.push(`query=${n.query}`);break;case`trace`:typeof n.start==`string`&&r.push(`start=${n.start}`),typeof n.direction==`string`&&r.push(`direction=${n.direction}`);break;default:break}return r.length>0?r.join(` | `):void 0}var Ya=class{stateStore;curatedStore;rateLimiter;config;constructor(e,t,n){this.stateStore=e,this.curatedStore=t,this.config={...Va,...n,captureFrom:n?.captureFrom?[...n.captureFrom]:[...La]},this.rateLimiter=new Ha(this.config.rateLimit)}getConfig(){return{...this.config,captureFrom:[...this.config.captureFrom]}}updateConfig(e){this.config={...this.config,...e,captureFrom:e.captureFrom?[...e.captureFrom]:[...this.config.captureFrom]},e.rateLimit!==void 0&&this.rateLimiter.setLimit(e.rateLimit)}enable(){this.config.enabled=!0}disable(){this.config.enabled=!1}registerTool(e){this.config.captureFrom.includes(e)||this.config.captureFrom.push(e)}unregisterTool(e){this.config.captureFrom=this.config.captureFrom.filter(t=>t!==e)}async processToolResult(e,t,n){if(!this.config.enabled||Ka(e)||!this.config.captureFrom.includes(e)||!this.rateLimiter.canCapture())return null;let r=this.extractObservation(e,t,n);if(!r)return null;let i=qa(r.content).trim();if(i.length<this.config.minContentLength)return null;let a={...r,content:Ga(i).trim()},o={...a,content:i};this.rateLimiter.record();try{await this.storeObservation(o)}catch(t){Ia.warn(`Failed to store observation`,{toolName:e,error:t instanceof Error?t.message:String(t)})}return a}extractObservation(e,t,n){let r=Wa(t);if(r.trim().length===0)return null;switch(e){case`check`:return this.extractFromCheck(t,r,n);case`test_run`:return this.extractFromTestRun(t,r,n);case`search`:return this.extractFromSearch(r,n);case`trace`:return this.extractFromTrace(r,n);default:return null}}extractFromCheck(e,t,n){return Ua(e)&&e.isError===!0||/\berror\b/i.test(t)||/failed/i.test(t)?this.buildObservation(`check`,`error`,t,n):null}extractFromTestRun(e,t,n){let r=Ua(e)&&Ua(e.structuredContent)?e.structuredContent:void 0,i=typeof r?.failedTests==`number`?r.failedTests:void 0;return Ua(e)&&e.isError===!0||typeof i==`number`&&i>0||/\bFAIL\b/.test(t)||/failed/i.test(t)?this.buildObservation(`test_run`,`test_failure`,t,n):null}extractFromSearch(e,t){if(!/\b(convention|pattern)\b/i.test(e))return null;let n=/\bconvention\b/i.test(e)?`convention`:`pattern`;return this.buildObservation(`search`,n,e,t)}extractFromTrace(e,t){return this.buildObservation(`trace`,`insight`,e,t)}buildObservation(e,t,n,r){return{id:se(),source:e,type:t,content:n,context:Ja(e,r),timestamp:new Date().toISOString()}}async storeObservation(e){let t=`Observation ${e.source} ${e.type} ${e.timestamp}`,n=[`Source: ${e.source}`,`Type: ${e.type}`,`Captured: ${e.timestamp}`,e.context?`Context: ${e.context}`:null,``,e.content].filter(e=>e!==null).join(`
24
- `),r=await this.curatedStore.remember(t,n,`context`,[`observation`,`source-${e.source}`,`type-${e.type}`]);this.stateStore.memoryMetaCreate(r.path,`working`)}};function Xa(e){let t=[e.cwd,e.workspace,e.root_path,e.path];for(let e of t)if(typeof e==`string`&&e.length>0)return e}function Za(e){return async(t,n)=>{let r=await n();try{await e.processToolResult(t.toolName,r,{workspace:Xa(t.args),args:t.args})}catch(e){Ia.warn(`Observation capture failed`,{toolName:t.toolName,requestId:t.requestId,error:e instanceof Error?e.message:String(e)})}return r}}const Qa=I(`procedural-memory`),$a=`Use when these user-facing tools are run in this order within a single session.`,eo={minSequenceLength:3,minRepetitions:3,maxSequenceLength:10,confidenceIncrement:10,confidenceDecrement:20},to=new Set([`status`,`guide`,`health`,`onboard`,`reindex`,`replay`,`session_digest`,`process`,`watch`,`produce_knowledge`,`list_tools`,`describe_tool`,`search_tools`]);function no(e){return e.join(`→`)}function ro(e){return{...e,steps:[...e.steps]}}function io(e){return e.every(e=>e.success)}var ao=class{config;history=[];sequences=new Map;procedures=new Map;pendingProcedures=new Map;constructor(e=eo){this.config=e}record(e,t){let n=new Date().toISOString();this.history.push({toolName:e,timestamp:n,success:t}),this.history.length>100&&(this.history=this.history.slice(-100));let r=this.detectSequences(n);this.updateMatchedProcedures(n,r)}getExtractableSequences(){return[...this.sequences.entries()].filter(([,e])=>e.count>=this.config.minRepetitions).map(([e,t])=>({steps:e.split(`→`),count:t.count,lastSeen:t.lastSeen})).sort((e,t)=>t.count===e.count?t.steps.length-e.steps.length:t.count-e.count)}listProcedures(){return[...this.procedures.values()].map(e=>ro(e)).sort((e,t)=>t.occurrences===e.occurrences?t.steps.length-e.steps.length:t.occurrences-e.occurrences)}drainNewProcedures(){let e=[...this.pendingProcedures.values()].map(e=>ro(e));return this.pendingProcedures.clear(),e}requeueProcedures(e){for(let t of e)this.pendingProcedures.set(no(t.steps),ro(t))}extractProcedure(e,t){return{id:se(),steps:[...e],occurrences:t,confidence:Math.min(50+(t-this.config.minRepetitions)*this.config.confidenceIncrement,100),lastSeen:new Date().toISOString(),conditions:$a}}adjustConfidence(e,t){return e.confidence=t?Math.min(100,e.confidence+this.config.confidenceIncrement):Math.max(0,e.confidence-this.config.confidenceDecrement),e.confidence}getHistoryLength(){return this.history.length}clear(){this.history=[],this.sequences.clear(),this.procedures.clear(),this.pendingProcedures.clear()}detectSequences(e){let t=this.history.map(e=>e.toolName),n=Math.min(this.config.maxSequenceLength,t.length),r=new Set,i=Math.max(1,Math.min(2,this.config.minRepetitions));for(let a=this.config.minSequenceLength;a<=n;a+=1){let n=t.slice(-a),o=no(n),s=0;for(let e=0;e<=t.length-a;e+=1)no(t.slice(e,e+a))===o&&(s+=1);if(!(s<i)&&(this.sequences.set(o,{count:s,lastSeen:e}),s>=this.config.minRepetitions&&!this.procedures.has(o))){let t=this.extractProcedure(n,s);t.lastSeen=e,this.procedures.set(o,t),this.pendingProcedures.set(o,ro(t)),r.add(o)}}return r}updateMatchedProcedures(e,t){for(let[n,r]of this.procedures.entries()){if(t.has(n))continue;let i=n.split(`→`);if(this.history.length<i.length)continue;let a=this.history.slice(-i.length);no(a.map(e=>e.toolName))===n&&(r.occurrences+=1,r.lastSeen=e,this.adjustConfidence(r,io(a)))}}};async function oo(e,t,n){let r=await t.remember(`Procedure: ${n.steps.join(` → `)}`,so(n),`patterns`,[`procedure`,`auto-extracted`]);return e.memoryMetaCreate(r.path,`procedural`),r.path}function so(e){return[`## Procedure: ${e.steps.join(` → `)}`,``,`**Confidence:** ${e.confidence}/100`,`**Occurrences:** ${e.occurrences}`,`**Last Seen:** ${e.lastSeen}`,``,`### Steps`,...e.steps.map((e,t)=>`${t+1}. \`${e}\``),``,`### When to Use`,e.conditions??$a].join(`
25
- `)}function co(e,t,n={}){return async(r,i)=>{if(!lo(r.toolName,n))return i();try{let n=await i();return e.record(r.toolName,n.isError!==!0),await uo(e,t,r.toolName),n}catch(n){throw e.record(r.toolName,!1),await uo(e,t,r.toolName),n}}}function lo(e,t){return t.trackedTools&&!t.trackedTools.has(e)?!1:!(t.ignoredTools??to).has(e)}async function uo(e,t,n){if(Ee.instance().isDegraded(`embedder`)){Qa.debug?.(`Skipping procedural memory persist — embedder degraded`);return}let r=e.drainNewProcedures();if(r.length===0)return;let i=[];for(let e of r)try{await oo(t.stateStore,t.curatedStore,e)}catch(t){let r=t instanceof Error?t.message:String(t),a=/circuit breaker|timed out|worker.*killed|respawn/i.test(r);Qa.warn(`Failed to store procedural memory`,{toolName:n,sequence:e.steps.join(` -> `),error:r}),a||i.push(e)}i.length>0&&e.requeueProcedures(i)}const fo=I(`tool-pipeline`);function po(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function mo(e,t){return e.tools?(Array.isArray(e.tools)?e.tools:[e.tools]).includes(t):!0}function ho(e){return e.middleware.critical===!0}var go=class{entries=[];use(e,t){this.entries.push({middleware:e,order:t?.order??100,tools:t?.tools,name:t?.name??e.name??`anonymous`})}useFor(e,t,n){this.use(t,{order:n?.order,tools:e,name:n?.name})}wrap(e,t,n,r){let i=this.entries.filter(t=>mo(t,e)).sort((e,t)=>e.order-t.order);return async(a,o)=>{let s={toolName:e,args:po(a)?a:{},requestId:se(),meta:r,extra:o,toolConfig:n},c=async n=>{let r=i[n];if(!r)return await t(s.args,o);let a=!1,l=!1,u,d=async()=>{a=!0;let e=await c(n+1);return l=!0,u=e,e};try{return await r.middleware(s,d)}catch(t){if(ho(r))throw t;if(fo.warn(`Middleware failed for tool`,{middleware:r.name,tool:e,error:String(t)}),a){if(l&&u)return u;throw t}return c(n+1)}};return c(0)}}getMiddlewareNames(){return this.entries.map(e=>e.name)}};const _o=I(`auto-gc`);let vo=`warming`,yo=null,bo=0;function xo(){let e=[...Fo()];if(e.length<10)return 0;e.sort((e,t)=>e-t);let t=Math.floor(e.length*.95);return e[Math.min(t,e.length-1)]}function So(e){let t=xo();if(t===0){vo=`warming`;return}if(t>500){vo=`degraded`;let n=Date.now();if(yo&&n-yo<36e5){_o.debug(`GC cooldown active — skipping`,{lastGcAgoMs:n-yo});return}yo=n,bo++,_o.warn(`p95 latency exceeds threshold, triggering GC`,{p95:t,cycle:bo}),e&&e().catch(e=>_o.error(`GC callback failed`,{err:String(e)}))}else t<200&&(vo=`healthy`)}function Co(){return{state:vo,p95:xo(),lastGcAt:yo,gcCount:bo,bufferSize:Fo().length}}const wo=/key|token|secret|auth|password|bearer/i,To=new Set([`eval`,`env`]);function Eo(e){if(typeof e==`string`)return/^(Bearer |sk-|ghp_|glpat-|ghu_|ghs_|github_pat_)/i.test(e)?`[REDACTED]`:e;if(Array.isArray(e))return e.map(Eo);if(e&&typeof e==`object`){let t={};for(let[n,r]of Object.entries(e))/(?:token|secret|password|passphrase|key|auth|credential|api.?key)/i.test(n)?t[n]=`[REDACTED]`:t[n]=Eo(r);return t}return e}function Do(e,t){if(To.has(e))return JSON.stringify({_redacted:!0,tool:e});let n=Eo(t);if(e===`http`&&n.headers&&typeof n.headers==`object`){let e={};for(let[t,r]of Object.entries(n.headers))e[t]=wo.test(t)?`[REDACTED]`:r;return n.headers=e,JSON.stringify(n).slice(0,2e3)}return JSON.stringify(n).slice(0,2e3)}let Oo={totalInputChars:0,totalOutputChars:0,callCount:0,startTime:new Date().toISOString()};function ko(e,t){Oo.totalInputChars+=e,Oo.totalOutputChars+=t,Oo.callCount++}function Ao(){return{...Oo}}const jo=new Map,Mo=[];function No(e,t,n,r,i){let a=jo.get(e);a||(a={callCount:0,totalDurationMs:0,totalInputChars:0,totalOutputChars:0,errorCount:0},jo.set(e,a)),a.callCount++,a.totalDurationMs+=t,a.totalInputChars+=n,a.totalOutputChars+=r,i&&a.errorCount++,Mo.push(t),Mo.length>100&&Mo.shift(),Mo.length>=10&&Mo.length%20==0&&So()}function Po(){return Array.from(jo.entries()).map(([e,t])=>({tool:e,...t}))}function Fo(){return Mo}function Io(){return async(e,t)=>{let n=Date.now(),r=JSON.stringify(e.args??{}).length;try{let i=await t(),a=Date.now()-n,o=JSON.stringify(i);return nn({ts:new Date().toISOString(),source:`mcp`,tool:e.toolName,input:Do(e.toolName,e.args),durationMs:a,status:`ok`,output:o,traceId:e.requestId,outputChars:o.length,inputChars:r}),No(e.toolName,a,r,o.length,!1),ko(r,o.length),i}catch(t){let i=Date.now()-n,a=t instanceof Error?t.message:String(t);throw nn({ts:new Date().toISOString(),source:`mcp`,tool:e.toolName,input:Do(e.toolName,e.args),durationMs:i,status:`error`,output:a,traceId:e.requestId,outputChars:0,inputChars:r}),No(e.toolName,i,r,0,!0),ko(r,a.length),t}}}function Lo(e,t){e.registerResource(`aikit-curated-index`,`aikit://curated`,{description:`Index of all curated knowledge entries`,mimeType:`text/markdown`},async()=>{let e=(await t.list()).map(e=>`- [${e.title}](aikit://curated/${e.path}) — ${e.category}`);return{contents:[{uri:`aikit://curated`,text:`# Curated Knowledge Index\n\n${e.length>0?e.join(`
26
- `):`_No curated entries yet._`}`,mimeType:`text/markdown`}]}});let n=new Un(`aikit://curated/{+path}`,{list:async()=>({resources:(await t.list()).map(e=>({uri:`aikit://curated/${e.path}`,name:e.title,description:`[${e.category}] ${e.contentPreview?.slice(0,80)??``}`,mimeType:`text/markdown`}))})});e.registerResource(`aikit-curated-entry`,n,{description:`A curated knowledge entry`,mimeType:`text/markdown`},async(e,n)=>{let r=n.path;if(!r)throw Error(`Missing path variable in curated resource URI`);let i=await t.read(r);return{contents:[{uri:e.toString(),text:`---\ntitle: ${i.title}\ncategory: ${i.category}\ntags: ${i.tags?.join(`, `)??``}\nversion: ${i.version??1}\n---\n\n${i.content??i.contentPreview??``}`,mimeType:`text/markdown`}]}})}const Ro=`aikit://schemas/channel-surface`,zo=new URL(`../../../blocks-core/schemas/channel-surface.schema.json`,import.meta.url);let Bo;function Vo(){return Bo??=Mn(zo,`utf8`),Bo}function Ho(e,t,n){e.registerResource(`aikit-status`,`aikit://status`,{description:`Current AI Kit status and statistics`,mimeType:`text/plain`},async()=>{let e=await t.getStats();return{contents:[{uri:`aikit://status`,text:`AI Kit: ${e.totalRecords} records from ${e.totalFiles} files. Last indexed: ${e.lastIndexedAt??`Never`}`,mimeType:`text/plain`}]}}),e.registerResource(`aikit-file-tree`,`aikit://file-tree`,{description:`List of all indexed source files`,mimeType:`text/plain`},async()=>({contents:[{uri:`aikit://file-tree`,text:(await t.listSourcePaths()).sort().join(`
27
- `),mimeType:`text/plain`}]})),e.registerResource(`aikit-channel-surface-schema`,Ro,{description:`JSON Schema for the ChannelSurface communication contract`,mimeType:`application/schema+json`},async()=>({contents:[{uri:Ro,text:await Vo(),mimeType:`application/schema+json`}]})),Lo(e,n)}const Uo=[`er_push`,`er_pull`,`er_sync_status`],Wo=[...Uo,`er_update_policy`,`er_evolve_review`],Go=new Set(Wo);function Ko(e){return e.toolProfiles}const qo=new Set(`browser.changelog.check.compliance_score.checkpoint.codemod.compact.config.data_transform.delegate.diff_parse.digest.encode.env.eval.evidence_map.file_summary.forge_classify.git_context.graph.guide.health.http.knowledge.lane.measure.onboard.parse_output.present.process.produce_knowledge.queue.regex_test.reindex.rename.replay.restore.schema_validate.session_digest.scope_map.stash.status.stratum_card.signal.test_run.time.watch.web_fetch.web_search.workset`.split(`.`)),Jo=5e3,Yo=new Set(`browser.changelog.check.compliance_score.checkpoint.codemod.data_transform.delegate.diff_parse.encode.env.eval.evidence_map.flow.describe_tool.list_tools.search_tools.forge_classify.git_context.guide.present.health.http.lane.measure.parse_output.process.produce_knowledge.queue.regex_test.rename.replay.restore.schema_validate.session_digest.status.test_run.time.watch.web_fetch.web_search.workset`.split(`.`)),Xo=`analyze.audit.blast_radius.browser.changelog.check.compliance_score.checkpoint.codemod.compact.config.data_transform.dead_symbols.delegate.diff_parse.digest.encode.env.eval.evidence_map.file_summary.find.flow.forge_classify.forge_ground.git_context.graph.guide.health.http.knowledge.memory_explain.lane.describe_tool.list_tools.lookup.measure.onboard.parse_output.present.process.produce_knowledge.queue.regex_test.reindex.rename.replay.restore.schema_validate.scope_map.search.search_tools.signal.session_digest.stash.status.stratum_card.symbol.test_run.time.trace.watch.web_fetch.web_search.workset`.split(`.`),Zo=I(`structured-content-guard`);function Qo(){let e=(async(e,t)=>{let n;try{n=await t()}catch(e){n={content:[{type:`text`,text:`[ERROR:INTERNAL] ${e instanceof Error?e.message:String(e)}`}],isError:!0}}let r=(e.toolConfig??{}).outputSchema;if(r==null)return n;let i=null;if(n.structuredContent==null){let t=$o(r);n.structuredContent=t,i=`synthesize`,n.structuredContent??(n.structuredContent={},i=`synthesize-null-fallback`,Zo.error(`synthesizeStructuredContent returned null/undefined — using empty fallback`,{tool:e.toolName}))}let a=es(r,n.structuredContent);if(a.action!=null&&(n.structuredContent=a.structuredContent,i=a.action),ns(n.structuredContent)||(n.isError=!0,n.structuredContent={},i=`fallback-error`),ts(r,n.structuredContent)===!1){let e=$o(r);n.structuredContent=e??{},ts(r,n.structuredContent)===!1?(n.structuredContent=ns(n.structuredContent)?n.structuredContent:{},i=`final-validation-failed`):i??=`final-heal`}return ns(n.structuredContent)||(n.isError=!0,n.structuredContent={},i=`fallback-error`),i!=null&&(i===`synthesize`||i===`final-heal`?Zo.debug:Zo.warn)(`Structured content guard activated`,{tool:e.toolName,action:i}),n});return e.critical=!0,e}function $o(e){try{return rs(e)??{}}catch{return{}}}function es(e,t){if(ts(e,t)!==!1)return{structuredContent:t,action:null};try{let n=$o(e);if(ns(n)&&ns(t)){let r={...n,...t};if(ts(e,r)!==!1)return{structuredContent:r,action:`heal`}}return{structuredContent:n,action:`fallback-zero-value`}}catch{return{structuredContent:t,action:null}}}function ts(e,t){let n=e.safeParse;if(typeof n==`function`)try{return n(t).success}catch{return}}function ns(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function rs(e){if(!e)return{};if(e.anyOf){let t=e.anyOf.find(e=>e.type!==`null`);return t?rs(t):null}let t=e._def?.typeName;if(t&&!e.type)switch(t){case`ZodObject`:{let t={},n=null;try{n=e.shape??(typeof e._def?.shape==`function`?e._def.shape():e._def?.shape)}catch{n=null}if(n)for(let[e,r]of Object.entries(n))try{t[e]=rs(r)}catch{t[e]=null}return t}case`ZodArray`:return[];case`ZodString`:return``;case`ZodNumber`:return 0;case`ZodBoolean`:return!1;case`ZodNullable`:return null;case`ZodOptional`:return;case`ZodRecord`:return{};case`ZodEnum`:return e._def?.values?.[0]??``;default:return{}}switch(e.type){case`object`:{let t={},n=e.properties??e.shape;if(n)for(let[e,r]of Object.entries(n))t[e]=rs(r);return t}case`array`:return[];case`string`:return``;case`number`:case`integer`:return 0;case`boolean`:return!1;case`nullable`:return null;case`optional`:return;case`record`:return{};case`enum`:return e.options?.[0]??Object.values(e.enum??e._def?.entries??{})[0]??``;default:return{}}}function is(e){if(!e)return{};try{let t=rs(e);return ns(t)?t:{}}catch{return{}}}const as=Symbol(`toolPipelineState`);function os(e){return e[as]}function ss(e,t){e[as]=t}function cs(e,t){return t?async(...n)=>{let r=await e(...n);if(!r||typeof r!=`object`)return r;let i=r;return!(`content`in i)||i.structuredContent!=null&&typeof i.structuredContent==`object`?r:(i.structuredContent=is(t),i.structuredContent??={},r)}:e}function ls(e,t,n=``){let r=os(e);if(r){r.pipeline=t,r.prefix=n;return}ss(e,{originalRegisterTool:e.registerTool.bind(e),pipeline:t,prefix:n}),e.registerTool=(n,r,i)=>{let a=os(e),o=a?.prefix?`${a.prefix}${n}`:n;if(!i)return a?.originalRegisterTool(o,r);let s=r?.outputSchema;if((a?.pipeline??t).getMiddlewareNames().length===0){let e=cs(i,s);return a?.originalRegisterTool(o,r,e)}let c=G(n),l=cs((a?.pipeline??t).wrap(n,i,r,c),s);return a?.originalRegisterTool(o,r,l)}}const us={analyze:1,audit:1,blast_radius:1,changelog:1,check:2,checkpoint:2,codemod:2,compact:1,config:0,data_transform:1,dead_symbols:1,delegate:3,describe_tool:1,diff_parse:1,digest:1,encode:1,env:0,eval:2,evidence_map:2,file_summary:1,find:1,flow:3,forge_classify:1,forge_ground:2,git_context:1,graph:1,guide:0,health:0,http:1,lane:2,list_tools:1,lookup:1,measure:1,onboard:3,parse_output:1,present:1,process:3,produce_knowledge:3,queue:3,regex_test:1,reindex:3,rename:2,replay:1,restore:2,schema_validate:1,scope_map:1,search:1,search_tools:1,signal:2,session_digest:2,stash:2,status:0,stratum_card:1,symbol:1,test_run:2,time:0,trace:1,watch:3,web_fetch:1,web_search:1,workset:2};function ds(e,t){return e.filter(e=>(us[e]??0)<=t)}const fs=new Set([`status`,`config`,`guide`,`health`]),ps={full:{description:`All tools enabled (default)`,includeCategories:[]},safe:{description:`Read-only tools — no file/state modifications`,includeCategories:[`search`,`analysis`,`compression`,`utilities`,`system`,`git`,`flow`],excludeTools:[`reindex`,`onboard`]},research:{description:`Search, analysis, knowledge, and web access`,includeCategories:[`search`,`analysis`,`knowledge`,`compression`,`web`,`system`,`flow`]},minimal:{description:`Essential tools only — search, status, basic operations`,includeCategories:[`search`,`system`],includeTools:[`compact`,`file_summary`,`check`,`test_run`]},discovery:{description:`Full toolset plus discovery-oriented meta-tools for guided tool exploration`,includeCategories:[],includeTools:[`list_tools`,`describe_tool`,`search_tools`]}};function ms(e,t){let n=ps[e];if(n)return n;let r=t?.[e];if(r)return r;throw Error(`Unknown tool profile: ${e}`)}function hs(e,t,n){return t.includes(`*`)?!0:(n[e]?.category??[]).some(e=>t.includes(e))}function gs(e,t,n,r){if(t.includes(`*`)){for(let t of n)e.add(t);return}for(let i of n)hs(i,t,r)&&e.add(i)}function _s(e,t,n){if(t.includes(`*`)){e.clear();return}for(let r of[...e])hs(r,t,n)&&e.delete(r)}function vs(e,t,n){if(!e||e.length===0||e.includes(`*`))return new Set(t);let r=new Set;return gs(r,e,t,n),r}function ys(e,t){return e===void 0?t:t===void 0?e:Math.min(e,t)}function bs(e,t){for(let n of[...e])t[n]?.annotations?.readOnlyHint===!1&&e.delete(n)}function xs(e,t,n=0,r=[]){if(n>10)throw Error(`Tool profile inheritance exceeded max depth 10: ${[...r,e].join(` -> `)}`);if(r.includes(e))throw Error(`Tool profile inheritance cycle detected: ${[...r,e].join(` -> `)}`);let i=ms(e,t);return ys(i.extends?xs(i.extends,t,n+1,[...r,e]):void 0,i.maxTier)}function Ss(e,t,n,r){let i=(e,a,o)=>{if(a>10)throw Error(`Tool profile inheritance exceeded max depth 10: ${[...o,e].join(` -> `)}`);if(o.includes(e))throw Error(`Tool profile inheritance cycle detected: ${[...o,e].join(` -> `)}`);let s=ms(e,r),c=[...o,e],l=s.extends?i(s.extends,a+1,c):vs(s.includeCategories,t,n);s.extends&&s.includeCategories?.length&&gs(l,s.includeCategories,t,n),s.excludeCategories?.length&&_s(l,s.excludeCategories,n);for(let e of s.includeTools??[])l.add(e);for(let e of s.excludeTools??[])l.delete(e);return l},a=i(e,0,[]),o=xs(e,r);if(o!==void 0){let e=ds([...a],o);a.clear();for(let t of e)a.add(t)}for(let e of fs)a.add(e);return e===`safe`&&bs(a,n),a}const Cs=new Set([`search`,`analysis`,`knowledge`,`compression`,`forge`,`presentation`,`execution`,`manipulation`,`session`,`git`,`process`,`system`,`meta`,`utilities`,`web`,`queue`,`flow`]);function ws(e,t,n,r){let i=process.env.AIKIT_TOOLSET||e.toolProfile||`full`,a=Ss(i,t,n,r);if(e.features&&e.features.length>0){let i=e.features.filter(e=>!Cs.has(e));if(i.length>0)throw Error(`Unknown feature group(s): ${i.join(`, `)}. Valid categories: ${[...Cs].join(`, `)}`);let o={description:`Synthetic profile from features config`,includeCategories:e.features},s=Ss(`_features`,t,n,{...r,_features:o});for(let e of a)!s.has(e)&&!fs.has(e)&&a.delete(e)}if(e.readOnly)for(let e of[...a])n[e]?.annotations?.readOnlyHint===!1&&!fs.has(e)&&a.delete(e);for(let e of fs)a.add(e);return i===`safe`&&bs(a,n),a}const Ts=z.object({mode:z.enum([`wasm`,`regex`,`unknown`]),reason:z.string(),pathsChecked:z.array(z.object({path:z.string(),exists:z.boolean()})),os:z.string(),arch:z.string(),nodeVersion:z.string(),webTreeSitterImportable:z.boolean(),healAttempted:z.boolean(),healSuccess:z.boolean(),healError:z.string().nullable(),initError:z.string().nullable(),wasmDir:z.string().nullable(),grammarCount:z.number()}),Es=z.object({kind:z.enum([`onboard`,`reindex`,`handoff`,`proceed`]),reason:z.string()}),Ds=z.object({title:z.string(),insight:z.string(),confidence:z.number()}),Os=z.object({lessons:z.array(Ds),conventions:z.array(z.object({title:z.string(),preview:z.string()})),checkpoint:z.string().nullable()}),ks=z.object({totalRecords:z.number(),totalFiles:z.number(),lastIndexedAt:z.string().nullable(),onboarded:z.boolean(),onboardDir:z.string(),contentTypes:z.record(z.string(),z.number()),wasmAvailable:z.boolean(),wasmDiagnostics:Ts,graphStats:z.object({nodes:z.number(),edges:z.number()}).nullable(),curatedCount:z.number(),serverVersion:z.string(),scaffoldVersion:z.string().nullable(),workspaceScaffoldVersion:z.string().nullable(),upgradeAvailable:z.boolean(),sessionTokens:z.object({callCount:z.number(),totalInputChars:z.number(),totalOutputChars:z.number(),estInputTokens:z.number(),estTotalTokens:z.number(),startTime:z.string()}).optional(),storeBackend:z.string().optional(),storeDiagnostics:z.object({adapterType:z.string(),vectorSearchEnabled:z.boolean(),ftsEnabled:z.boolean(),degradedMode:z.boolean(),dbPath:z.string(),dbSizeBytes:z.number().nullable(),embeddingDim:z.number(),vectorDtype:z.string()}).nullable().optional(),contextPressure:z.number().min(0).max(100).describe(`0–100 score indicating AI Kit saturation`),nextAction:Es,prelude:Os.nullable().optional()});z.object({entries:z.array(z.object({path:z.string(),title:z.string(),category:z.string(),tags:z.array(z.string()),version:z.number(),preview:z.string()})),totalCount:z.number()});const As=z.object({ok:z.boolean(),checks:z.array(z.object({name:z.string(),ok:z.boolean(),message:z.string().optional()}))}),js=z.object({summary:z.object({totalFiles:z.number(),totalLines:z.number(),totalCodeLines:z.number(),totalFunctions:z.number(),avgComplexity:z.number(),maxComplexity:z.object({value:z.number(),file:z.string()})}),files:z.array(z.object({path:z.string(),lines:z.number(),code:z.number(),complexity:z.number(),functions:z.number()}))}),Ms=z.object({platform:z.string(),arch:z.string(),nodeVersion:z.string(),cwd:z.string(),cpus:z.number(),memoryFreeGb:z.number(),memoryTotalGb:z.number()}),Ns=z.object({iso:z.string(),unix:z.number(),timezone:z.string(),formatted:z.string()}),Ps=z.object({passed:z.boolean(),errorCount:z.number(),warningCount:z.number(),topErrors:z.array(z.string())}),Fs=z.object({passed:z.boolean(),tsc:Ps,biome:Ps}),Is=z.object({name:z.string(),definedIn:z.object({path:z.string(),line:z.number(),kind:z.string(),signature:z.string().optional()}).nullable(),importedBy:z.array(z.object({path:z.string(),line:z.number(),importStatement:z.string()})),referencedIn:z.array(z.object({path:z.string(),line:z.number(),context:z.string(),scope:z.string().optional()})),graphContext:z.object({definingModule:z.string().optional(),importedByModules:z.array(z.string()),siblingSymbols:z.array(z.string())}).nullable()}),Ls=z.object({sourcePath:z.string(),contentType:z.string(),score:z.number(),headingPath:z.string().optional(),startLine:z.number().optional(),endLine:z.number().optional(),origin:z.string().optional(),category:z.string().optional(),tags:z.array(z.string()).optional()}),Rs=z.object({results:z.array(Ls),totalResults:z.number(),searchMode:z.string(),query:z.string(),ref:z.string().optional().describe(`Reusable cache reference for later compact(ref, query)`)}),zs=z.object({path:z.string(),line:z.number().optional(),matchType:z.string(),preview:z.string()}),Bs=z.object({matches:z.array(zs),totalMatches:z.number(),pattern:z.string(),truncated:z.boolean(),ref:z.string().optional().describe(`Reusable cache reference for later compact(ref, query)`)}),Vs=z.object({path:z.string(),relevance:z.number(),estimatedTokens:z.number(),focusLines:z.array(z.string()).optional()}),Hs=z.object({files:z.array(Vs),totalFiles:z.number(),totalEstimatedTokens:z.number(),task:z.string()}),Us=z.object({path:z.string(),impact:z.string(),reason:z.string()}),Ws=z.object({changedFiles:z.array(z.string()),affectedFiles:z.array(Us),totalAffected:z.number(),riskLevel:z.string()}),Gs=z.object({name:z.string(),passed:z.boolean(),message:z.string().optional(),severity:z.string().optional()}),Ks=z.object({passed:z.boolean(),score:z.number(),checks:z.array(Gs),summary:z.string()}),qs=z.object({id:z.string(),name:z.string(),type:z.string(),sourcePath:z.string().optional()}),Js=z.object({fromId:z.string(),toId:z.string(),type:z.string()}),Ys=z.object({nodes:z.array(qs),edges:z.array(Js),totalNodes:z.number(),totalEdges:z.number(),query:z.string()}),Xs=z.object({symbols:z.array(z.object({name:z.string(),path:z.string(),line:z.number().optional(),kind:z.string()})),totalDead:z.number()});z.object({files:z.number(),packages:z.number(),languages:z.record(z.string(),z.number()),tree:z.string()});const Zs=z.object({path:z.string(),language:z.string(),lines:z.number(),imports:z.number(),exports:z.number(),functions:z.number(),classes:z.number()}),Qs=z.object({gitRoot:z.string(),branch:z.string(),commitCount:z.number(),hasUncommitted:z.boolean(),recentCommits:z.array(z.object({hash:z.string(),message:z.string(),author:z.string(),date:z.string()}))}),$s=z.object({text:z.string().describe(`The compressed text output`),ref:z.string().optional().describe(`Reusable cache reference`),originalChars:z.number(),compressedChars:z.number(),ratio:z.number(),segmentsKept:z.number(),segmentsTotal:z.number()}),ec=z.object({sourceId:z.string(),value:z.string()}),tc=z.object({id:z.string(),originalChars:z.number(),keptChars:z.number(),segmentsKept:z.number(),segmentsTotal:z.number()}),nc=z.object({text:z.string().describe(`The compressed digest text output`),ref:z.string().optional().describe(`Reusable cache reference`),fields:z.record(z.string(),z.array(ec)),sourceStats:z.array(tc),totalOriginalChars:z.number(),totalCompressedChars:z.number(),ratio:z.number()}),rc=z.object({passed:z.boolean(),totalTests:z.number(),passedTests:z.number(),failedTests:z.number(),skippedTests:z.number(),duration:z.number().describe(`Duration in milliseconds`),failures:z.array(z.object({name:z.string(),message:z.string(),file:z.string().optional()}))}),ic=I(`utils:enrich`);async function K(e,t){let n={curated:[],graph:[]},r=t.limit??3,[i,a]=await Promise.allSettled([ac(e,t.query,r),oc(e,t.filePath)]);return i.status===`fulfilled`?n.curated=i.value:ic.debug(`Curated enrichment failed`,{error:i.reason}),a.status===`fulfilled`?n.graph=a.value:ic.debug(`Graph enrichment failed`,{error:a.reason}),n}async function ac(e,t,n){if(!e.store||!t)return[];try{let r=await e.store.ftsSearch(t,{origin:`curated`,limit:n});if(r.length>0)return r.map(e=>sc(e.record));if(e.embedder){let r=await e.embedder.embedQuery(t);return(await e.store.search(r,{origin:`curated`,limit:n,minScore:.3})).map(e=>sc(e.record))}return[]}catch(e){return ic.debug(`Curated enrichment failed`,{error:e}),[]}}async function oc(e,t){if(!e.graphStore||!t)return[];try{let n=await e.graphStore.findNodes({sourcePath:t,limit:1});if(n.length===0){let r=t.split(/[/\\]/).pop()?.replace(/\.\w+$/,``)||``;if(!r)return[];let i=await e.graphStore.findNodes({namePattern:r,type:`module`,limit:1});if(i.length===0)return[];n.push(i[0])}let r=n[0],i=await e.graphStore.getNeighbors(r.id,{direction:`both`,limit:10}),a=[];for(let e of i.edges){let t=e.fromId===r.id?e.toId:e.fromId,n=i.nodes.find(e=>e.id===t);if(!n)continue;let o=e.fromId===r.id?`->`:`<-`;a.push(`${o} ${e.type}: ${n.name} (${n.type})`)}return a}catch(e){return ic.debug(`Graph enrichment failed`,{error:e}),[]}}function q(e){let t=[];if(e.curated.length>0){t.push(`**Curated Knowledge:**`);for(let n of e.curated)t.push(`- ${n}`)}if(e.graph.length>0){t.push(`**Graph Context:**`);for(let n of e.graph)t.push(`- ${n}`)}return t.length===0?``:`\n\n---\n### Enrichment\n${t.join(`
23
+ `):JSON.stringify(e)}function Ya(e,t=500){return e.length<=t?e:e.slice(0,t)}function Xa(e){let t=e.toLowerCase();return[...Ua].some(e=>t===e||t.includes(e))}function Za(e){let t=e;for(let e of Ha)t=t.replace(e,`[REDACTED]`);return t.length>Wa&&(t=`${t.slice(0,Wa)}\n...[truncated]`),t}function Qa(e,t){let n=t?.args??{},r=[];switch(t?.workspace&&r.push(`workspace=${t.workspace}`),e){case`check`:typeof n.cwd==`string`&&r.push(`cwd=${n.cwd}`),Array.isArray(n.files)&&n.files.length>0&&r.push(`files=${n.files.join(`, `)}`);break;case`test_run`:typeof n.cwd==`string`&&r.push(`cwd=${n.cwd}`),typeof n.grep==`string`&&r.push(`grep=${n.grep}`),Array.isArray(n.files)&&n.files.length>0&&r.push(`files=${n.files.join(`, `)}`);break;case`search`:typeof n.query==`string`&&r.push(`query=${n.query}`);break;case`trace`:typeof n.start==`string`&&r.push(`start=${n.start}`),typeof n.direction==`string`&&r.push(`direction=${n.direction}`);break;default:break}return r.length>0?r.join(` | `):void 0}var $a=class{stateStore;curatedStore;rateLimiter;config;constructor(e,t,n){this.stateStore=e,this.curatedStore=t,this.config={...Ga,...n,captureFrom:n?.captureFrom?[...n.captureFrom]:[...Va]},this.rateLimiter=new Ka(this.config.rateLimit)}getConfig(){return{...this.config,captureFrom:[...this.config.captureFrom]}}updateConfig(e){this.config={...this.config,...e,captureFrom:e.captureFrom?[...e.captureFrom]:[...this.config.captureFrom]},e.rateLimit!==void 0&&this.rateLimiter.setLimit(e.rateLimit)}enable(){this.config.enabled=!0}disable(){this.config.enabled=!1}registerTool(e){this.config.captureFrom.includes(e)||this.config.captureFrom.push(e)}unregisterTool(e){this.config.captureFrom=this.config.captureFrom.filter(t=>t!==e)}async processToolResult(e,t,n){if(!this.config.enabled||Xa(e)||!this.config.captureFrom.includes(e)||!this.rateLimiter.canCapture())return null;let r=this.extractObservation(e,t,n);if(!r)return null;let i=Za(r.content).trim();if(i.length<this.config.minContentLength)return null;let a={...r,content:Ya(i).trim()},o={...a,content:i};this.rateLimiter.record();try{await this.storeObservation(o)}catch(t){Ba.warn(`Failed to store observation`,{toolName:e,error:t instanceof Error?t.message:String(t)})}return a}extractObservation(e,t,n){let r=Ja(t);if(r.trim().length===0)return null;switch(e){case`check`:return this.extractFromCheck(t,r,n);case`test_run`:return this.extractFromTestRun(t,r,n);case`search`:return this.extractFromSearch(r,n);case`trace`:return this.extractFromTrace(r,n);default:return null}}extractFromCheck(e,t,n){return qa(e)&&e.isError===!0||/\berror\b/i.test(t)||/failed/i.test(t)?this.buildObservation(`check`,`error`,t,n):null}extractFromTestRun(e,t,n){let r=qa(e)&&qa(e.structuredContent)?e.structuredContent:void 0,i=typeof r?.failedTests==`number`?r.failedTests:void 0;return qa(e)&&e.isError===!0||typeof i==`number`&&i>0||/\bFAIL\b/.test(t)||/failed/i.test(t)?this.buildObservation(`test_run`,`test_failure`,t,n):null}extractFromSearch(e,t){if(!/\b(convention|pattern)\b/i.test(e))return null;let n=/\bconvention\b/i.test(e)?`convention`:`pattern`;return this.buildObservation(`search`,n,e,t)}extractFromTrace(e,t){return this.buildObservation(`trace`,`insight`,e,t)}buildObservation(e,t,n,r){return{id:se(),source:e,type:t,content:n,context:Qa(e,r),timestamp:new Date().toISOString()}}async storeObservation(e){let t=`Observation ${e.source} ${e.type} ${e.timestamp}`,n=[`Source: ${e.source}`,`Type: ${e.type}`,`Captured: ${e.timestamp}`,e.context?`Context: ${e.context}`:null,``,e.content].filter(e=>e!==null).join(`
24
+ `),r=await this.curatedStore.remember(t,n,`context`,[`observation`,`source-${e.source}`,`type-${e.type}`]);this.stateStore.memoryMetaCreate(r.path,`working`)}};function eo(e){let t=[e.cwd,e.workspace,e.root_path,e.path];for(let e of t)if(typeof e==`string`&&e.length>0)return e}function to(e){return async(t,n)=>{let r=await n();try{await e.processToolResult(t.toolName,r,{workspace:eo(t.args),args:t.args})}catch(e){Ba.warn(`Observation capture failed`,{toolName:t.toolName,requestId:t.requestId,error:e instanceof Error?e.message:String(e)})}return r}}const no=I(`procedural-memory`),ro=`Use when these user-facing tools are run in this order within a single session.`,io={minSequenceLength:3,minRepetitions:3,maxSequenceLength:10,confidenceIncrement:10,confidenceDecrement:20},ao=new Set([`status`,`guide`,`health`,`onboard`,`reindex`,`replay`,`session_digest`,`process`,`watch`,`produce_knowledge`,`list_tools`,`describe_tool`,`search_tools`]);function oo(e){return e.join(`→`)}function so(e){return{...e,steps:[...e.steps]}}function co(e){return e.every(e=>e.success)}var lo=class{config;history=[];sequences=new Map;procedures=new Map;pendingProcedures=new Map;constructor(e=io){this.config=e}record(e,t){let n=new Date().toISOString();this.history.push({toolName:e,timestamp:n,success:t}),this.history.length>100&&(this.history=this.history.slice(-100));let r=this.detectSequences(n);this.updateMatchedProcedures(n,r)}getExtractableSequences(){return[...this.sequences.entries()].filter(([,e])=>e.count>=this.config.minRepetitions).map(([e,t])=>({steps:e.split(`→`),count:t.count,lastSeen:t.lastSeen})).sort((e,t)=>t.count===e.count?t.steps.length-e.steps.length:t.count-e.count)}listProcedures(){return[...this.procedures.values()].map(e=>so(e)).sort((e,t)=>t.occurrences===e.occurrences?t.steps.length-e.steps.length:t.occurrences-e.occurrences)}drainNewProcedures(){let e=[...this.pendingProcedures.values()].map(e=>so(e));return this.pendingProcedures.clear(),e}requeueProcedures(e){for(let t of e)this.pendingProcedures.set(oo(t.steps),so(t))}extractProcedure(e,t){return{id:se(),steps:[...e],occurrences:t,confidence:Math.min(50+(t-this.config.minRepetitions)*this.config.confidenceIncrement,100),lastSeen:new Date().toISOString(),conditions:ro}}adjustConfidence(e,t){return e.confidence=t?Math.min(100,e.confidence+this.config.confidenceIncrement):Math.max(0,e.confidence-this.config.confidenceDecrement),e.confidence}getHistoryLength(){return this.history.length}clear(){this.history=[],this.sequences.clear(),this.procedures.clear(),this.pendingProcedures.clear()}detectSequences(e){let t=this.history.map(e=>e.toolName),n=Math.min(this.config.maxSequenceLength,t.length),r=new Set,i=Math.max(1,Math.min(2,this.config.minRepetitions));for(let a=this.config.minSequenceLength;a<=n;a+=1){let n=t.slice(-a),o=oo(n),s=0;for(let e=0;e<=t.length-a;e+=1)oo(t.slice(e,e+a))===o&&(s+=1);if(!(s<i)&&(this.sequences.set(o,{count:s,lastSeen:e}),s>=this.config.minRepetitions&&!this.procedures.has(o))){let t=this.extractProcedure(n,s);t.lastSeen=e,this.procedures.set(o,t),this.pendingProcedures.set(o,so(t)),r.add(o)}}return r}updateMatchedProcedures(e,t){for(let[n,r]of this.procedures.entries()){if(t.has(n))continue;let i=n.split(`→`);if(this.history.length<i.length)continue;let a=this.history.slice(-i.length);oo(a.map(e=>e.toolName))===n&&(r.occurrences+=1,r.lastSeen=e,this.adjustConfidence(r,co(a)))}}};async function uo(e,t,n){let r=await t.remember(`Procedure: ${n.steps.join(` → `)}`,fo(n),`patterns`,[`procedure`,`auto-extracted`]);return e.memoryMetaCreate(r.path,`procedural`),r.path}function fo(e){return[`## Procedure: ${e.steps.join(` → `)}`,``,`**Confidence:** ${e.confidence}/100`,`**Occurrences:** ${e.occurrences}`,`**Last Seen:** ${e.lastSeen}`,``,`### Steps`,...e.steps.map((e,t)=>`${t+1}. \`${e}\``),``,`### When to Use`,e.conditions??ro].join(`
25
+ `)}function po(e,t,n={}){return async(r,i)=>{if(!mo(r.toolName,n))return i();try{let n=await i();return e.record(r.toolName,n.isError!==!0),await ho(e,t,r.toolName),n}catch(n){throw e.record(r.toolName,!1),await ho(e,t,r.toolName),n}}}function mo(e,t){return t.trackedTools&&!t.trackedTools.has(e)?!1:!(t.ignoredTools??ao).has(e)}async function ho(e,t,n){if(Ee.instance().isDegraded(`embedder`)){no.debug?.(`Skipping procedural memory persist — embedder degraded`);return}let r=e.drainNewProcedures();if(r.length===0)return;let i=[];for(let e of r)try{await uo(t.stateStore,t.curatedStore,e)}catch(t){let r=t instanceof Error?t.message:String(t),a=/circuit breaker|timed out|worker.*killed|respawn/i.test(r);no.warn(`Failed to store procedural memory`,{toolName:n,sequence:e.steps.join(` -> `),error:r}),a||i.push(e)}i.length>0&&e.requeueProcedures(i)}const go=I(`tool-pipeline`);function _o(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function vo(e,t){return e.tools?(Array.isArray(e.tools)?e.tools:[e.tools]).includes(t):!0}function yo(e){return e.middleware.critical===!0}var bo=class{entries=[];use(e,t){this.entries.push({middleware:e,order:t?.order??100,tools:t?.tools,name:t?.name??e.name??`anonymous`})}useFor(e,t,n){this.use(t,{order:n?.order,tools:e,name:n?.name})}wrap(e,t,n,r){let i=this.entries.filter(t=>vo(t,e)).sort((e,t)=>e.order-t.order);return async(a,o)=>{let s={toolName:e,args:_o(a)?a:{},requestId:se(),meta:r,extra:o,toolConfig:n},c=async n=>{let r=i[n];if(!r)return await t(s.args,o);let a=!1,l=!1,u,d=async()=>{a=!0;let e=await c(n+1);return l=!0,u=e,e};try{return await r.middleware(s,d)}catch(t){if(yo(r))throw t;if(go.warn(`Middleware failed for tool`,{middleware:r.name,tool:e,error:String(t)}),a){if(l&&u)return u;throw t}return c(n+1)}};return c(0)}}getMiddlewareNames(){return this.entries.map(e=>e.name)}};const xo=I(`auto-gc`);let So=`warming`,Co=null,wo=0;function To(){let e=[...zo()];if(e.length<10)return 0;e.sort((e,t)=>e-t);let t=Math.floor(e.length*.95);return e[Math.min(t,e.length-1)]}function Eo(e){let t=To();if(t===0){So=`warming`;return}if(t>500){So=`degraded`;let n=Date.now();if(Co&&n-Co<36e5){xo.debug(`GC cooldown active — skipping`,{lastGcAgoMs:n-Co});return}Co=n,wo++,xo.warn(`p95 latency exceeds threshold, triggering GC`,{p95:t,cycle:wo}),e&&e().catch(e=>xo.error(`GC callback failed`,{err:String(e)}))}else t<200&&(So=`healthy`)}function Do(){return{state:So,p95:To(),lastGcAt:Co,gcCount:wo,bufferSize:zo().length}}const Oo=/key|token|secret|auth|password|bearer/i,ko=new Set([`eval`,`env`]);function Ao(e){if(typeof e==`string`)return/^(Bearer |sk-|ghp_|glpat-|ghu_|ghs_|github_pat_)/i.test(e)?`[REDACTED]`:e;if(Array.isArray(e))return e.map(Ao);if(e&&typeof e==`object`){let t={};for(let[n,r]of Object.entries(e))/(?:token|secret|password|passphrase|key|auth|credential|api.?key)/i.test(n)?t[n]=`[REDACTED]`:t[n]=Ao(r);return t}return e}function jo(e,t){if(ko.has(e))return JSON.stringify({_redacted:!0,tool:e});let n=Ao(t);if(e===`http`&&n.headers&&typeof n.headers==`object`){let e={};for(let[t,r]of Object.entries(n.headers))e[t]=Oo.test(t)?`[REDACTED]`:r;return n.headers=e,JSON.stringify(n).slice(0,2e3)}return JSON.stringify(n).slice(0,2e3)}let Mo={totalInputChars:0,totalOutputChars:0,callCount:0,startTime:new Date().toISOString()};function No(e,t){Mo.totalInputChars+=e,Mo.totalOutputChars+=t,Mo.callCount++}function Po(){return{...Mo}}const Fo=new Map,Io=[];function Lo(e,t,n,r,i){let a=Fo.get(e);a||(a={callCount:0,totalDurationMs:0,totalInputChars:0,totalOutputChars:0,errorCount:0},Fo.set(e,a)),a.callCount++,a.totalDurationMs+=t,a.totalInputChars+=n,a.totalOutputChars+=r,i&&a.errorCount++,Io.push(t),Io.length>100&&Io.shift(),Io.length>=10&&Io.length%20==0&&Eo()}function Ro(){return Array.from(Fo.entries()).map(([e,t])=>({tool:e,...t}))}function zo(){return Io}function Bo(){return async(e,t)=>{let n=Date.now(),r=JSON.stringify(e.args??{}).length;try{let i=await t(),a=Date.now()-n,o=JSON.stringify(i);return nn({ts:new Date().toISOString(),source:`mcp`,tool:e.toolName,input:jo(e.toolName,e.args),durationMs:a,status:`ok`,output:o,traceId:e.requestId,outputChars:o.length,inputChars:r}),Lo(e.toolName,a,r,o.length,!1),No(r,o.length),i}catch(t){let i=Date.now()-n,a=t instanceof Error?t.message:String(t);throw nn({ts:new Date().toISOString(),source:`mcp`,tool:e.toolName,input:jo(e.toolName,e.args),durationMs:i,status:`error`,output:a,traceId:e.requestId,outputChars:0,inputChars:r}),Lo(e.toolName,i,r,0,!0),No(r,a.length),t}}}function Vo(e,t){e.registerResource(`aikit-curated-index`,`aikit://curated`,{description:`Index of all curated knowledge entries`,mimeType:`text/markdown`},async()=>{let e=(await t.list()).map(e=>`- [${e.title}](aikit://curated/${e.path}) — ${e.category}`);return{contents:[{uri:`aikit://curated`,text:`# Curated Knowledge Index\n\n${e.length>0?e.join(`
26
+ `):`_No curated entries yet._`}`,mimeType:`text/markdown`}]}});let n=new Un(`aikit://curated/{+path}`,{list:async()=>({resources:(await t.list()).map(e=>({uri:`aikit://curated/${e.path}`,name:e.title,description:`[${e.category}] ${e.contentPreview?.slice(0,80)??``}`,mimeType:`text/markdown`}))})});e.registerResource(`aikit-curated-entry`,n,{description:`A curated knowledge entry`,mimeType:`text/markdown`},async(e,n)=>{let r=n.path;if(!r)throw Error(`Missing path variable in curated resource URI`);let i=await t.read(r);return{contents:[{uri:e.toString(),text:`---\ntitle: ${i.title}\ncategory: ${i.category}\ntags: ${i.tags?.join(`, `)??``}\nversion: ${i.version??1}\n---\n\n${i.content??i.contentPreview??``}`,mimeType:`text/markdown`}]}})}const Ho=`aikit://schemas/channel-surface`,Uo=new URL(`../../../blocks-core/schemas/channel-surface.schema.json`,import.meta.url);let Wo;function Go(){return Wo??=Mn(Uo,`utf8`),Wo}function Ko(e,t,n){e.registerResource(`aikit-status`,`aikit://status`,{description:`Current AI Kit status and statistics`,mimeType:`text/plain`},async()=>{let e=await t.getStats();return{contents:[{uri:`aikit://status`,text:`AI Kit: ${e.totalRecords} records from ${e.totalFiles} files. Last indexed: ${e.lastIndexedAt??`Never`}`,mimeType:`text/plain`}]}}),e.registerResource(`aikit-file-tree`,`aikit://file-tree`,{description:`List of all indexed source files`,mimeType:`text/plain`},async()=>({contents:[{uri:`aikit://file-tree`,text:(await t.listSourcePaths()).sort().join(`
27
+ `),mimeType:`text/plain`}]})),e.registerResource(`aikit-channel-surface-schema`,Ho,{description:`JSON Schema for the ChannelSurface communication contract`,mimeType:`application/schema+json`},async()=>({contents:[{uri:Ho,text:await Go(),mimeType:`application/schema+json`}]})),Vo(e,n)}const qo=[`er_push`,`er_pull`,`er_sync_status`],Jo=[...qo,`er_update_policy`,`er_evolve_review`],Yo=new Set(Jo);function Xo(e){return e.toolProfiles}const Zo=5e3,Qo=I(`structured-content-guard`);function $o(){let e=(async(e,t)=>{let n;try{n=await t()}catch(e){n={content:[{type:`text`,text:`[ERROR:INTERNAL] ${e instanceof Error?e.message:String(e)}`}],isError:!0}}let r=(e.toolConfig??{}).outputSchema;if(r==null)return n;let i=null;if(n.structuredContent==null){let t=es(r);n.structuredContent=t,i=`synthesize`,n.structuredContent??(n.structuredContent={},i=`synthesize-null-fallback`,Qo.error(`synthesizeStructuredContent returned null/undefined — using empty fallback`,{tool:e.toolName}))}let a=ts(r,n.structuredContent);if(a.action!=null&&(n.structuredContent=a.structuredContent,i=a.action),rs(n.structuredContent)||(n.isError=!0,n.structuredContent={},i=`fallback-error`),ns(r,n.structuredContent)===!1){let e=es(r);n.structuredContent=e??{},ns(r,n.structuredContent)===!1?(n.structuredContent=rs(n.structuredContent)?n.structuredContent:{},i=`final-validation-failed`):i??=`final-heal`}return n});return e.critical=!0,e}function es(e){try{return is(e)??{}}catch{return{}}}function ts(e,t){if(ns(e,t)!==!1)return{structuredContent:t,action:null};try{let n=es(e);if(rs(n)&&rs(t)){let r={...n,...t};if(ns(e,r)!==!1)return{structuredContent:r,action:`heal`}}return{structuredContent:n,action:`fallback-zero-value`}}catch{return{structuredContent:t,action:null}}}function ns(e,t){let n=e.safeParse;if(typeof n==`function`)try{return n(t).success}catch{return}}function rs(e){return typeof e==`object`&&!!e&&!Array.isArray(e)}function is(e){if(!e)return{};if(e.anyOf){let t=e.anyOf.find(e=>e.type!==`null`);return t?is(t):null}let t=e._def?.typeName;if(t&&!e.type)switch(t){case`ZodObject`:{let t={},n=null;try{n=e.shape??(typeof e._def?.shape==`function`?e._def.shape():e._def?.shape)}catch{n=null}if(n)for(let[e,r]of Object.entries(n))try{t[e]=is(r)}catch{t[e]=null}return t}case`ZodArray`:return[];case`ZodString`:return``;case`ZodNumber`:return 0;case`ZodBoolean`:return!1;case`ZodNullable`:return null;case`ZodOptional`:return;case`ZodRecord`:return{};case`ZodEnum`:return e._def?.values?.[0]??``;default:return{}}switch(e.type){case`object`:{let t={},n=e.properties??e.shape;if(n)for(let[e,r]of Object.entries(n))t[e]=is(r);return t}case`array`:return[];case`string`:return``;case`number`:case`integer`:return 0;case`boolean`:return!1;case`nullable`:return null;case`optional`:return;case`record`:return{};case`enum`:return e.options?.[0]??Object.values(e.enum??e._def?.entries??{})[0]??``;default:return{}}}function as(e){if(!e)return{};try{let t=is(e);return rs(t)?t:{}}catch{return{}}}const os=Symbol(`toolPipelineState`);function ss(e){return e[os]}function cs(e,t){e[os]=t}function ls(e,t){return t?async(...n)=>{let r=await e(...n);if(!r||typeof r!=`object`)return r;let i=r;return!(`content`in i)||i.structuredContent!=null&&typeof i.structuredContent==`object`?r:(i.structuredContent=as(t),i.structuredContent??={},r)}:e}function us(e,t,n=``){let r=ss(e);if(r){r.pipeline=t,r.prefix=n;return}cs(e,{originalRegisterTool:e.registerTool.bind(e),pipeline:t,prefix:n}),e.registerTool=(n,r,i)=>{let a=ss(e),o=a?.prefix?`${a.prefix}${n}`:n;if(!i)return a?.originalRegisterTool(o,r);let s=r?.outputSchema;if((a?.pipeline??t).getMiddlewareNames().length===0){let e=ls(i,s);return a?.originalRegisterTool(o,r,e)}let c=G(n),l=ls((a?.pipeline??t).wrap(n,i,r,c),s);return a?.originalRegisterTool(o,r,l)}}const ds={analyze:1,audit:1,blast_radius:1,changelog:1,check:2,checkpoint:2,codemod:2,compact:1,config:0,data_transform:1,dead_symbols:1,delegate:3,describe_tool:1,diff_parse:1,digest:1,encode:1,env:0,eval:2,evidence_map:2,file_summary:1,find:1,flow:3,forge_classify:1,forge_ground:2,git_context:1,graph:1,guide:0,health:0,http:1,lane:2,list_tools:1,lookup:1,measure:1,onboard:3,parse_output:1,present:1,process:3,produce_knowledge:3,queue:3,regex_test:1,reindex:3,rename:2,replay:1,restore:2,schema_validate:1,scope_map:1,search:1,search_tools:1,signal:2,session_digest:2,stash:2,status:0,stratum_card:1,symbol:1,test_run:2,time:0,trace:1,watch:3,web_fetch:1,web_search:1,workset:2};function fs(e,t){return e.filter(e=>(ds[e]??0)<=t)}const ps=new Set([`status`,`config`,`guide`,`health`]),ms={full:{description:`All tools enabled (default)`,includeCategories:[]},safe:{description:`Read-only tools — no file/state modifications`,includeCategories:[`search`,`analysis`,`compression`,`utilities`,`system`,`git`,`flow`],excludeTools:[`reindex`,`onboard`]},research:{description:`Search, analysis, knowledge, and web access`,includeCategories:[`search`,`analysis`,`knowledge`,`compression`,`web`,`system`,`flow`]},minimal:{description:`Essential tools only — search, status, basic operations`,includeCategories:[`search`,`system`],includeTools:[`compact`,`file_summary`,`check`,`test_run`]},discovery:{description:`Full toolset plus discovery-oriented meta-tools for guided tool exploration`,includeCategories:[],includeTools:[`list_tools`,`describe_tool`,`search_tools`]}};function hs(e,t){let n=ms[e];if(n)return n;let r=t?.[e];if(r)return r;throw Error(`Unknown tool profile: ${e}`)}function gs(e,t,n){return t.includes(`*`)?!0:(n[e]?.category??[]).some(e=>t.includes(e))}function _s(e,t,n,r){if(t.includes(`*`)){for(let t of n)e.add(t);return}for(let i of n)gs(i,t,r)&&e.add(i)}function vs(e,t,n){if(t.includes(`*`)){e.clear();return}for(let r of[...e])gs(r,t,n)&&e.delete(r)}function ys(e,t,n){if(!e||e.length===0||e.includes(`*`))return new Set(t);let r=new Set;return _s(r,e,t,n),r}function bs(e,t){return e===void 0?t:t===void 0?e:Math.min(e,t)}function xs(e,t){for(let n of[...e])t[n]?.annotations?.readOnlyHint===!1&&e.delete(n)}function Ss(e,t,n=0,r=[]){if(n>10)throw Error(`Tool profile inheritance exceeded max depth 10: ${[...r,e].join(` -> `)}`);if(r.includes(e))throw Error(`Tool profile inheritance cycle detected: ${[...r,e].join(` -> `)}`);let i=hs(e,t);return bs(i.extends?Ss(i.extends,t,n+1,[...r,e]):void 0,i.maxTier)}function Cs(e,t,n,r){let i=(e,a,o)=>{if(a>10)throw Error(`Tool profile inheritance exceeded max depth 10: ${[...o,e].join(` -> `)}`);if(o.includes(e))throw Error(`Tool profile inheritance cycle detected: ${[...o,e].join(` -> `)}`);let s=hs(e,r),c=[...o,e],l=s.extends?i(s.extends,a+1,c):ys(s.includeCategories,t,n);s.extends&&s.includeCategories?.length&&_s(l,s.includeCategories,t,n),s.excludeCategories?.length&&vs(l,s.excludeCategories,n);for(let e of s.includeTools??[])l.add(e);for(let e of s.excludeTools??[])l.delete(e);return l},a=i(e,0,[]),o=Ss(e,r);if(o!==void 0){let e=fs([...a],o);a.clear();for(let t of e)a.add(t)}for(let e of ps)a.add(e);return e===`safe`&&xs(a,n),a}const ws=new Set([`search`,`analysis`,`knowledge`,`compression`,`forge`,`presentation`,`execution`,`manipulation`,`session`,`git`,`process`,`system`,`meta`,`utilities`,`web`,`queue`,`flow`]);function Ts(e,t,n,r){let i=process.env.AIKIT_TOOLSET||e.toolProfile||`full`,a=Cs(i,t,n,r);if(e.features&&e.features.length>0){let i=e.features.filter(e=>!ws.has(e));if(i.length>0)throw Error(`Unknown feature group(s): ${i.join(`, `)}. Valid categories: ${[...ws].join(`, `)}`);let o={description:`Synthetic profile from features config`,includeCategories:e.features},s=Cs(`_features`,t,n,{...r,_features:o});for(let e of a)!s.has(e)&&!ps.has(e)&&a.delete(e)}if(e.readOnly)for(let e of[...a])n[e]?.annotations?.readOnlyHint===!1&&!ps.has(e)&&a.delete(e);for(let e of ps)a.add(e);return i===`safe`&&xs(a,n),a}const Es=z.object({mode:z.enum([`wasm`,`regex`,`unknown`]),reason:z.string(),pathsChecked:z.array(z.object({path:z.string(),exists:z.boolean()})),os:z.string(),arch:z.string(),nodeVersion:z.string(),webTreeSitterImportable:z.boolean(),healAttempted:z.boolean(),healSuccess:z.boolean(),healError:z.string().nullable(),initError:z.string().nullable(),wasmDir:z.string().nullable(),grammarCount:z.number()}),Ds=z.object({kind:z.enum([`onboard`,`reindex`,`handoff`,`proceed`]),reason:z.string()}),Os=z.object({title:z.string(),insight:z.string(),confidence:z.number()}),ks=z.object({lessons:z.array(Os),conventions:z.array(z.object({title:z.string(),preview:z.string()})),checkpoint:z.string().nullable()});z.object({totalRecords:z.number(),totalFiles:z.number(),lastIndexedAt:z.string().nullable(),onboarded:z.boolean(),onboardDir:z.string(),contentTypes:z.record(z.string(),z.number()),wasmAvailable:z.boolean(),wasmDiagnostics:Es,graphStats:z.object({nodes:z.number(),edges:z.number()}).nullable(),curatedCount:z.number(),serverVersion:z.string(),scaffoldVersion:z.string().nullable(),workspaceScaffoldVersion:z.string().nullable(),upgradeAvailable:z.boolean(),sessionTokens:z.object({callCount:z.number(),totalInputChars:z.number(),totalOutputChars:z.number(),estInputTokens:z.number(),estTotalTokens:z.number(),startTime:z.string()}).optional(),storeBackend:z.string().optional(),storeDiagnostics:z.object({adapterType:z.string(),vectorSearchEnabled:z.boolean(),ftsEnabled:z.boolean(),degradedMode:z.boolean(),dbPath:z.string(),dbSizeBytes:z.number().nullable(),embeddingDim:z.number(),vectorDtype:z.string()}).nullable().optional(),contextPressure:z.number().min(0).max(100).describe(`0–100 score indicating AI Kit saturation`),nextAction:Ds,prelude:ks.nullable().optional()}).catchall(z.any()),z.object({entries:z.array(z.object({path:z.string(),title:z.string(),category:z.string(),tags:z.array(z.string()),version:z.number(),preview:z.string()})),totalCount:z.number()});const As=z.object({ok:z.boolean(),checks:z.array(z.object({name:z.string(),ok:z.boolean(),message:z.string().optional()}))}),js=z.object({summary:z.object({totalFiles:z.number(),totalLines:z.number(),totalCodeLines:z.number(),totalFunctions:z.number(),avgComplexity:z.number(),maxComplexity:z.object({value:z.number(),file:z.string()})}),files:z.array(z.object({path:z.string(),lines:z.number(),code:z.number(),complexity:z.number(),functions:z.number()}))}),Ms=z.object({platform:z.string(),arch:z.string(),nodeVersion:z.string(),cwd:z.string(),cpus:z.number(),memoryFreeGb:z.number(),memoryTotalGb:z.number()}),Ns=z.object({iso:z.string(),unix:z.number(),timezone:z.string(),formatted:z.string()}),Ps=z.object({passed:z.boolean(),errorCount:z.number(),warningCount:z.number(),topErrors:z.array(z.string())}),Fs=z.object({passed:z.boolean(),tsc:Ps,biome:Ps}),Is=z.object({name:z.string(),definedIn:z.object({path:z.string(),line:z.number(),kind:z.string(),signature:z.string().optional()}).nullable(),importedBy:z.array(z.object({path:z.string(),line:z.number(),importStatement:z.string()})),referencedIn:z.array(z.object({path:z.string(),line:z.number(),context:z.string(),scope:z.string().optional()})),graphContext:z.object({definingModule:z.string().optional(),importedByModules:z.array(z.string()),siblingSymbols:z.array(z.string())}).nullable()}),Ls=z.object({sourcePath:z.string(),contentType:z.string(),score:z.number(),headingPath:z.string().optional(),startLine:z.number().optional(),endLine:z.number().optional(),origin:z.string().optional(),category:z.string().optional(),tags:z.array(z.string()).optional()}),Rs=z.object({results:z.array(Ls),totalResults:z.number(),searchMode:z.string(),query:z.string(),ref:z.string().optional().describe(`Reusable cache reference for later compact(ref, query)`)}),zs=z.object({path:z.string(),line:z.number().optional(),matchType:z.string(),preview:z.string()}),Bs=z.object({matches:z.array(zs),totalMatches:z.number(),pattern:z.string(),truncated:z.boolean(),ref:z.string().optional().describe(`Reusable cache reference for later compact(ref, query)`)}),Vs=z.object({path:z.string(),relevance:z.number(),estimatedTokens:z.number(),focusLines:z.array(z.string()).optional()}),Hs=z.object({files:z.array(Vs),totalFiles:z.number(),totalEstimatedTokens:z.number(),task:z.string()}),Us=z.object({path:z.string(),impact:z.string(),reason:z.string()}),Ws=z.object({changedFiles:z.array(z.string()),affectedFiles:z.array(Us),totalAffected:z.number(),riskLevel:z.string()}),Gs=z.object({name:z.string(),passed:z.boolean(),message:z.string().optional(),severity:z.string().optional()}),Ks=z.object({passed:z.boolean(),score:z.number(),checks:z.array(Gs),summary:z.string()}),qs=z.object({id:z.string(),name:z.string(),type:z.string(),sourcePath:z.string().optional()}),Js=z.object({fromId:z.string(),toId:z.string(),type:z.string()}),Ys=z.object({nodes:z.array(qs),edges:z.array(Js),totalNodes:z.number(),totalEdges:z.number(),query:z.string()}),Xs=z.object({symbols:z.array(z.object({name:z.string(),path:z.string(),line:z.number().optional(),kind:z.string()})),totalDead:z.number()});z.object({files:z.number(),packages:z.number(),languages:z.record(z.string(),z.number()),tree:z.string()});const Zs=z.object({path:z.string(),language:z.string(),lines:z.number(),imports:z.number(),exports:z.number(),functions:z.number(),classes:z.number()}),Qs=z.object({gitRoot:z.string(),branch:z.string(),commitCount:z.number(),hasUncommitted:z.boolean(),recentCommits:z.array(z.object({hash:z.string(),message:z.string(),author:z.string(),date:z.string()}))}),$s=z.object({text:z.string().describe(`The compressed text output`),ref:z.string().optional().describe(`Reusable cache reference`),originalChars:z.number(),compressedChars:z.number(),ratio:z.number(),segmentsKept:z.number(),segmentsTotal:z.number()}),ec=z.object({sourceId:z.string(),value:z.string()}),tc=z.object({id:z.string(),originalChars:z.number(),keptChars:z.number(),segmentsKept:z.number(),segmentsTotal:z.number()}),nc=z.object({text:z.string().describe(`The compressed digest text output`),ref:z.string().optional().describe(`Reusable cache reference`),fields:z.record(z.string(),z.array(ec)),sourceStats:z.array(tc),totalOriginalChars:z.number(),totalCompressedChars:z.number(),ratio:z.number()}),rc=z.object({passed:z.boolean(),totalTests:z.number(),passedTests:z.number(),failedTests:z.number(),skippedTests:z.number(),duration:z.number().describe(`Duration in milliseconds`),failures:z.array(z.object({name:z.string(),message:z.string(),file:z.string().optional()}))}),ic=I(`utils:enrich`);async function K(e,t){let n={curated:[],graph:[]},r=t.limit??3,[i,a]=await Promise.allSettled([ac(e,t.query,r),oc(e,t.filePath)]);return i.status===`fulfilled`?n.curated=i.value:ic.debug(`Curated enrichment failed`,{error:i.reason}),a.status===`fulfilled`?n.graph=a.value:ic.debug(`Graph enrichment failed`,{error:a.reason}),n}async function ac(e,t,n){if(!e.store||!t)return[];try{let r=await e.store.ftsSearch(t,{origin:`curated`,limit:n});if(r.length>0)return r.map(e=>sc(e.record));if(e.embedder){let r=await e.embedder.embedQuery(t);return(await e.store.search(r,{origin:`curated`,limit:n,minScore:.3})).map(e=>sc(e.record))}return[]}catch(e){return ic.debug(`Curated enrichment failed`,{error:e}),[]}}async function oc(e,t){if(!e.graphStore||!t)return[];try{let n=await e.graphStore.findNodes({sourcePath:t,limit:1});if(n.length===0){let r=t.split(/[/\\]/).pop()?.replace(/\.\w+$/,``)||``;if(!r)return[];let i=await e.graphStore.findNodes({namePattern:r,type:`module`,limit:1});if(i.length===0)return[];n.push(i[0])}let r=n[0],i=await e.graphStore.getNeighbors(r.id,{direction:`both`,limit:10}),a=[];for(let e of i.edges){let t=e.fromId===r.id?e.toId:e.fromId,n=i.nodes.find(e=>e.id===t);if(!n)continue;let o=e.fromId===r.id?`->`:`<-`;a.push(`${o} ${e.type}: ${n.name} (${n.type})`)}return a}catch(e){return ic.debug(`Graph enrichment failed`,{error:e}),[]}}function q(e){let t=[];if(e.curated.length>0){t.push(`**Curated Knowledge:**`);for(let n of e.curated)t.push(`- ${n}`)}if(e.graph.length>0){t.push(`**Graph Context:**`);for(let n of e.graph)t.push(`- ${n}`)}return t.length===0?``:`\n\n---\n### Enrichment\n${t.join(`
28
28
  `)}`}function sc(e){let t=cc(e.metadata,`title`)||e.sourcePath||`Untitled`;return`[${cc(e.metadata,`category`)}] ${t}: ${e.content.slice(0,200)}`}function cc(e,t){let n=e?.[t];return typeof n==`string`?n:``}function J(e,t,n){return{content:[{type:`text`,text:`[ERROR:${e}] ${t}`}],isError:!0,...n==null?{}:{structuredContent:n}}}function Y(e,t){return async(n,r)=>{let i=Date.now(),a=await t(n,r),o=Date.now()-i;return a._meta={...a._meta??{},durationMs:o,toolName:e},a}}const lc=I(`tools`),uc=z.number().min(100).max(5e4).optional().describe(`Maximum token budget for the response. When set, output is truncated to fit.`);function dc(e,t){return t?R(e,t):e}function fc(){let e=[];return ar.get()||e.push(`Tree-sitter unavailable — using regex fallback, symbol/pattern confidence reduced`),e.length===0?``:`\n\n> **⚠ Caveats:** ${e.join(`; `)}`}function pc(e){return(e??[]).map(e=>{if(typeof e==`string`)return e;if(e&&typeof e==`object`&&`path`in e)return typeof e.path==`string`?e.path:void 0}).filter(e=>!!e)}function mc(e){let t=[],n=e.filter(e=>/\.(ts|tsx|js|jsx)$/.test(e)&&/(service|store|model|schema|migration)/i.test(e)),r=e.filter(e=>/\.(ts|tsx|js|jsx)$/.test(e)&&!n.includes(e)),i=e.filter(e=>!/\.(ts|tsx|js|jsx)$/.test(e));return(n.length>0||r.length>0||i.length>0)&&(t.push(`
29
29
 
30
30
  ### Risk Assessment`),n.length>0&&t.push(`- 🔴 **High risk** (${n.length}): ${n.slice(0,5).map(e=>`\`${e}\``).join(`, `)}`),r.length>0&&t.push(`- 🟡 **Medium risk** (${r.length}): source files`),i.length>0&&t.push(`- 🟢 **Low risk** (${i.length}): non-source files`)),t.join(`
@@ -259,8 +259,8 @@ None.`:`### Stale Lessons\n${l.map(e=>`- **${e.title}** (\`${e.path}\`) — effe
259
259
  `),s=Wd(e),c=s?Hd(s):void 0,l=`${a}\n${o}\n\n---\n_Next: Use \`search\` to find related content, or \`analyze({ aspect: "dependencies", path: "${e}" })\` to see what this file imports._`;if(r&&n){let t=await K(n,{query:e});l+=q(t)}return{content:[{type:`text`,text:l},...c?[c]:[]]}}catch(e){return ip.error(`Lookup failed`,L(e)),J(`INTERNAL`,`Lookup failed: ${e instanceof Error?e.message:String(e)}`)}}))}const op=I(`tools:manipulation`);function sp(e){return e.sources[0]?.path??process.cwd()}function cp(e,t){let n=F(t,e),r=ve(t,n);if(r.startsWith(`..`)||_e(r))throw Error(`Path "${e}" escapes workspace root: ${t}`);return n}function lp(e){let t=G(`git_context`);e.registerTool(`git_context`,{title:t.title,description:`Summarize the current Git branch, working tree state, recent commits, and optional diff statistics for the repository.`,inputSchema:{cwd:z.string().optional().describe(`Repository root or working directory`),commit_count:z.number().min(1).max(50).default(5).optional().describe(`How many recent commits to include`),include_diff:z.boolean().default(!1).optional().describe(`Include diff stat for working tree changes`)},annotations:t.annotations,outputSchema:Qs},async({cwd:e,commit_count:t,include_diff:n})=>{try{let r=await yt({cwd:e,commitCount:t,includeDiff:n});return{content:[{type:`text`,text:mp(r)}],structuredContent:{gitRoot:r.gitRoot,branch:r.branch,commitCount:r.recentCommits.length,hasUncommitted:r.status.staged.length>0||r.status.modified.length>0||r.status.untracked.length>0,recentCommits:r.recentCommits.map(e=>({hash:e.hash,message:e.message,author:e.author,date:e.date}))}}}catch(e){return op.error(`Git context failed`,L(e)),J(`INTERNAL`,`Git context failed: ${e instanceof Error?e.message:String(e)}`)}})}function up(e){let t=G(`diff_parse`);e.registerTool(`diff_parse`,{title:t.title,description:`Parse raw unified diff text into file-level and hunk-level structural changes.`,inputSchema:{diff:z.string().max(1e6).describe(`Raw unified diff text`)},annotations:t.annotations},async({diff:e})=>{try{return{content:[{type:`text`,text:hp(at({diff:e.replace(/\\n/g,`
260
260
  `).replace(/\\t/g,` `)}))}]}}catch(e){return op.error(`Diff parse failed`,L(e)),J(`INTERNAL`,`Diff parse failed: ${e instanceof Error?e.message:String(e)}`)}})}function dp(e,t){let n=G(`rename`),r=sp(t);e.registerTool(`rename`,{title:n.title,description:`Rename a symbol across files using whole-word regex matching for exports, imports, and general usage references.`,inputSchema:{old_name:z.string().describe(`Existing symbol name to replace`),new_name:z.string().describe(`New symbol name to use`),root_path:z.string().describe(`Root directory to search within`),extensions:z.array(z.string()).optional().describe(`Optional file extensions to include, such as .ts,.tsx,.js,.jsx`),dry_run:z.boolean().default(!0).describe(`Preview changes without writing files`)},annotations:n.annotations},Y(`rename`,async({old_name:e,new_name:t,root_path:n,extensions:i,dry_run:a},o)=>{let s;try{s=Vc(o).createTask(`Rename Symbol`,2),s.progress(0,`Scanning for references`);let c=cp(n,r);s.progress(1,`Applying renames`);let l=await tn({oldName:e,newName:t,rootPath:c,extensions:i,dryRun:a});return s.complete(`Rename complete`),{content:[{type:`text`,text:JSON.stringify(l)}]}}catch(e){return s?.fail?.(`Rename failed`),op.error(`Rename failed`,L(e)),J(`INTERNAL`,`Rename failed: ${e instanceof Error?e.message:String(e)}`)}}))}function fp(e,t){let n=G(`codemod`),r=sp(t);e.registerTool(`codemod`,{title:n.title,description:`Apply regex-based codemod rules across files and return structured before/after changes for each affected line.`,inputSchema:{root_path:z.string().describe(`Root directory to transform within`),rules:z.array(z.object({description:z.string().describe(`What the codemod rule does`),pattern:z.string().describe(`Regex pattern in string form`),replacement:z.string().describe(`Replacement string with optional capture groups`)})).min(1).describe(`Codemod rules to apply`),dry_run:z.boolean().default(!0).describe(`Preview changes without writing files`)},annotations:n.annotations},Y(`codemod`,async({root_path:e,rules:t,dry_run:n},i)=>{let a;try{a=Vc(i).createTask(`Codemod`,2),a.progress(0,`Scanning files`);let o=cp(e,r);a.progress(1,`Applying transforms`);let s=await Xe({rootPath:o,rules:t,dryRun:n});return a.complete(`Codemod complete`),{content:[{type:`text`,text:JSON.stringify(s)}]}}catch(e){return a?.fail?.(`Codemod failed`),op.error(`Codemod failed`,L(e)),J(`INTERNAL`,`Codemod failed: ${e instanceof Error?e.message:String(e)}`)}}))}function pp(e){let t=G(`data_transform`);e.registerTool(`data_transform`,{title:t.title,description:`Apply small jq-like transforms to JSON input for filtering, projection, grouping, and path extraction.`,inputSchema:{input:z.string().max(5e5).describe(`Input JSON string`),expression:z.string().max(1e4).describe(`Transform expression to apply`)},annotations:t.annotations},async({input:e,expression:t})=>{try{return{content:[{type:`text`,text:tt({input:e,expression:t}).outputString}]}}catch(e){return op.error(`Data transform failed`,L(e)),J(`INTERNAL`,`Data transform failed: ${e instanceof Error?e.message:String(e)}`)}})}function mp(e){let t=[`Git root: ${e.gitRoot}`,`Branch: ${e.branch}`,`Staged: ${e.status.staged.length}`,...e.status.staged.map(e=>` - ${e}`),`Modified: ${e.status.modified.length}`,...e.status.modified.map(e=>` - ${e}`),`Untracked: ${e.status.untracked.length}`,...e.status.untracked.map(e=>` - ${e}`),``,`Recent commits:`];if(e.recentCommits.length===0)t.push(` none`);else for(let n of e.recentCommits)t.push(` - ${n.hash} ${n.message}`),t.push(` ${n.author} @ ${n.date}`);return e.diff&&t.push(``,`Diff stat:`,e.diff),t.join(`
261
261
  `)}function hp(e){if(e.length===0)return`No diff files found.`;let t=[];for(let n of e){let e=n.oldPath?` (from ${n.oldPath})`:``;t.push(`${n.path}${e} [${n.status}] +${n.additions} -${n.deletions} (${n.hunks.length} hunks)`);for(let e of n.hunks){let n=e.header?` ${e.header}`:``;t.push(` @@ -${e.oldStart},${e.oldLines} +${e.newStart},${e.newLines} @@${n}`)}}return t.join(`
262
- `)}function gp(e,t){return t?e.length<=500?e:`${e.slice(0,497)}...`:``}function _p(e,t){let n=[];return e.keywordRank!==void 0&&n.push(`keyword match rank ${e.keywordRank+1}`),e.vectorRank!==void 0&&n.push(`semantic match rank ${e.vectorRank+1}`),e.result.record.origin===`curated`&&n.push(`curated memory`),e.result.record.category&&n.push(`category:${e.result.record.category}`),e.result.record.tags.length>0&&n.push(`tags:${e.result.record.tags.join(`,`)}`),{id:e.result.record.id,score:e.result.score,content:gp(e.result.record.content,t),sourcePath:e.result.record.sourcePath,origin:e.result.record.origin,category:e.result.record.category,tags:e.result.record.tags,reason:n.join(`; `)||`store result`}}function vp(e,t){let n=new Map;return e.forEach((e,t)=>{n.set(e.record.id,{result:e,vectorRank:t})}),t.forEach((e,t)=>{let r=n.get(e.record.id);if(r){n.set(e.record.id,{result:{record:e.record,score:Math.max(r.result.score,e.score)},vectorRank:r.vectorRank,keywordRank:t});return}n.set(e.record.id,{result:e,keywordRank:t})}),[...n.values()].sort((e,t)=>{let n=Math.min(e.vectorRank??1/0,e.keywordRank??1/0),r=Math.min(t.vectorRank??1/0,t.keywordRank??1/0);return n===r?t.result.score-e.result.score:n-r})}async function yp(e,t,n={}){let r=n.limit??5,i=n.candidateLimit??Math.max(r*3,10),a=n.searchMode??`hybrid`,o={limit:i,origin:n.origin??`curated`,category:n.category,tags:n.tags?[...n.tags]:void 0},[s,c]=await Promise.all([a===`keyword`?Promise.resolve([]):t.embedder.embedQuery(e).then(e=>t.store.search(e,o)).catch(()=>[]),a===`semantic`?Promise.resolve([]):t.store.ftsSearch(e,o).catch(()=>[])]),l=vp(s,c).map(e=>_p(e,n.includeContent??!0)),u=l.slice(0,r),d=l.slice(r).map(e=>({...e,ignoredReason:`lower ranked candidate outside selection limit`})),f=c.length,p=s.length;return{query:e,searchMode:a,retrieved:l,selected:u,ignored:d,finalReasoning:u.length===0?`No active matching memory was found. Deleted memories are not visible after store cleanup.`:`Selected ${u.length} of ${l.length} active candidate(s). Keyword candidates: ${f}; semantic candidates: ${p}.`}}function bp(e,t,n){let r=G(`memory_explain`);e.registerTool(`memory_explain`,{title:r.title,description:`Explain why AI Kit memory search returns, selects, or ignores memories for a query. Debugs curated and auto-knowledge quality without invoking an LLM.`,inputSchema:{query:z.string().min(1).max(5e3).describe(`Memory query to explain`),limit:z.number().int().min(1).max(20).default(5),candidate_limit:z.number().int().min(1).max(100).optional(),search_mode:z.enum([`hybrid`,`semantic`,`keyword`]).default(`hybrid`),origin:z.enum(De).default(`curated`),category:z.string().optional(),tags:z.array(z.string()).optional(),include_content:z.boolean().default(!0)},annotations:r.annotations},async({query:e,limit:r,candidate_limit:i,search_mode:a,origin:o,category:s,tags:c,include_content:l})=>{try{let u=await yp(e,{embedder:t,store:n},{limit:r,candidateLimit:i,searchMode:a,origin:o,category:s,tags:c,includeContent:l}),d=JSON.stringify(u,null,2),f=Ol(d);return{content:[{type:`text`,text:kl(d,f)}],structuredContent:{...u,ref:f}}}catch(e){return J(`INTERNAL`,`memory_explain failed: ${L(e).message}`)}})}const xp=[`list_tools`,`describe_tool`,`search_tools`];function Sp(e,t,n){let r=[...new Set(n)].sort();e.registerTool(`list_tools`,{title:G(`list_tools`).title,description:`List the available AI Kit tools with names, titles, and categories. Use this before describe_tool when you need to discover the active toolset.`,inputSchema:{category:z.string().optional().describe(`Optional category filter`)},annotations:G(`list_tools`).annotations},Y(`list_tools`,async({category:e})=>{let t=e?.trim().toLowerCase();return{content:[{type:`text`,text:r.filter(e=>t?(Ma[e]?.category??[]).some(e=>e.toLowerCase()===t):!0).map(e=>{let t=Ma[e]??{title:e,category:[]},n=t.category?.join(`, `)||`uncategorized`;return`${e}: ${t.title} [${n}]`}).join(`
263
- `)||`No tools matched the filter.`}]}})),e.registerTool(`describe_tool`,{title:G(`describe_tool`).title,description:`Describe a specific active AI Kit tool using centralized metadata. Use this after list_tools when you need a tool title, categories, and annotations before calling it directly.`,inputSchema:{tool_name:z.string().describe(`The active tool name to describe`)},annotations:G(`describe_tool`).annotations},Y(`describe_tool`,async({tool_name:e})=>{if(!r.includes(e))return J(`VALIDATION`,`Unknown or inactive tool: ${e}`);let t=Ma[e],n={name:e,title:t?.title??e,categories:t?.category??[],annotations:t?.annotations??{},note:`Call the tool directly after discovery. AI Kit does not expose an execute_tool proxy.`};return{content:[{type:`text`,text:JSON.stringify(n,null,2)}]}})),e.registerTool(`search_tools`,{title:G(`search_tools`).title,description:`Search active AI Kit tools by keyword across tool names, titles, and categories.`,inputSchema:{query:z.string().min(1).describe(`Keyword query to match against active tools`)},annotations:G(`search_tools`).annotations},Y(`search_tools`,async({query:e})=>{let t=e.trim().toLowerCase(),n=r.filter(e=>{let n=Ma[e];return e.toLowerCase().includes(t)||n?.title.toLowerCase().includes(t)||(n?.category??[]).some(e=>e.toLowerCase().includes(t))}).map(e=>{let t=Ma[e]??{title:e,category:[]},n=t.category?.join(`, `)||`uncategorized`;return`${e}: ${t.title} [${n}]`});return{content:[{type:`text`,text:n.length>0?n.join(`
262
+ `)}function gp(e,t){return t?e.length<=500?e:`${e.slice(0,497)}...`:``}function _p(e,t){let n=[];return e.keywordRank!==void 0&&n.push(`keyword match rank ${e.keywordRank+1}`),e.vectorRank!==void 0&&n.push(`semantic match rank ${e.vectorRank+1}`),e.result.record.origin===`curated`&&n.push(`curated memory`),e.result.record.category&&n.push(`category:${e.result.record.category}`),e.result.record.tags.length>0&&n.push(`tags:${e.result.record.tags.join(`,`)}`),{id:e.result.record.id,score:e.result.score,content:gp(e.result.record.content,t),sourcePath:e.result.record.sourcePath,origin:e.result.record.origin,category:e.result.record.category,tags:e.result.record.tags,reason:n.join(`; `)||`store result`}}function vp(e,t){let n=new Map;return e.forEach((e,t)=>{n.set(e.record.id,{result:e,vectorRank:t})}),t.forEach((e,t)=>{let r=n.get(e.record.id);if(r){n.set(e.record.id,{result:{record:e.record,score:Math.max(r.result.score,e.score)},vectorRank:r.vectorRank,keywordRank:t});return}n.set(e.record.id,{result:e,keywordRank:t})}),[...n.values()].sort((e,t)=>{let n=Math.min(e.vectorRank??1/0,e.keywordRank??1/0),r=Math.min(t.vectorRank??1/0,t.keywordRank??1/0);return n===r?t.result.score-e.result.score:n-r})}async function yp(e,t,n={}){let r=n.limit??5,i=n.candidateLimit??Math.max(r*3,10),a=n.searchMode??`hybrid`,o={limit:i,origin:n.origin??`curated`,category:n.category,tags:n.tags?[...n.tags]:void 0},[s,c]=await Promise.all([a===`keyword`?Promise.resolve([]):t.embedder.embedQuery(e).then(e=>t.store.search(e,o)).catch(()=>[]),a===`semantic`?Promise.resolve([]):t.store.ftsSearch(e,o).catch(()=>[])]),l=vp(s,c).map(e=>_p(e,n.includeContent??!0)),u=l.slice(0,r),d=l.slice(r).map(e=>({...e,ignoredReason:`lower ranked candidate outside selection limit`})),f=c.length,p=s.length;return{query:e,searchMode:a,retrieved:l,selected:u,ignored:d,finalReasoning:u.length===0?`No active matching memory was found. Deleted memories are not visible after store cleanup.`:`Selected ${u.length} of ${l.length} active candidate(s). Keyword candidates: ${f}; semantic candidates: ${p}.`}}function bp(e,t,n){let r=G(`memory_explain`);e.registerTool(`memory_explain`,{title:r.title,description:`Explain why AI Kit memory search returns, selects, or ignores memories for a query. Debugs curated and auto-knowledge quality without invoking an LLM.`,inputSchema:{query:z.string().min(1).max(5e3).describe(`Memory query to explain`),limit:z.number().int().min(1).max(20).default(5),candidate_limit:z.number().int().min(1).max(100).optional(),search_mode:z.enum([`hybrid`,`semantic`,`keyword`]).default(`hybrid`),origin:z.enum(De).default(`curated`),category:z.string().optional(),tags:z.array(z.string()).optional(),include_content:z.boolean().default(!0)},annotations:r.annotations},async({query:e,limit:r,candidate_limit:i,search_mode:a,origin:o,category:s,tags:c,include_content:l})=>{try{let u=await yp(e,{embedder:t,store:n},{limit:r,candidateLimit:i,searchMode:a,origin:o,category:s,tags:c,includeContent:l}),d=JSON.stringify(u,null,2),f=Ol(d);return{content:[{type:`text`,text:kl(d,f)}],structuredContent:{...u,ref:f}}}catch(e){return J(`INTERNAL`,`memory_explain failed: ${L(e).message}`)}})}const xp=[`list_tools`,`describe_tool`,`search_tools`];function Sp(e,t,n){let r=[...new Set(n)].sort();e.registerTool(`list_tools`,{title:G(`list_tools`).title,description:`List the available AI Kit tools with names, titles, and categories. Use this before describe_tool when you need to discover the active toolset.`,inputSchema:{category:z.string().optional().describe(`Optional category filter`)},annotations:G(`list_tools`).annotations},Y(`list_tools`,async({category:e})=>{let t=e?.trim().toLowerCase();return{content:[{type:`text`,text:r.filter(e=>t?(W[e]?.category??[]).some(e=>e.toLowerCase()===t):!0).map(e=>{let t=W[e]??{title:e,category:[]},n=t.category?.join(`, `)||`uncategorized`;return`${e}: ${t.title} [${n}]`}).join(`
263
+ `)||`No tools matched the filter.`}]}})),e.registerTool(`describe_tool`,{title:G(`describe_tool`).title,description:`Describe a specific active AI Kit tool using centralized metadata. Use this after list_tools when you need a tool title, categories, and annotations before calling it directly.`,inputSchema:{tool_name:z.string().describe(`The active tool name to describe`)},annotations:G(`describe_tool`).annotations},Y(`describe_tool`,async({tool_name:e})=>{if(!r.includes(e))return J(`VALIDATION`,`Unknown or inactive tool: ${e}`);let t=W[e],n={name:e,title:t?.title??e,categories:t?.category??[],annotations:t?.annotations??{},note:`Call the tool directly after discovery. AI Kit does not expose an execute_tool proxy.`};return{content:[{type:`text`,text:JSON.stringify(n,null,2)}]}})),e.registerTool(`search_tools`,{title:G(`search_tools`).title,description:`Search active AI Kit tools by keyword across tool names, titles, and categories.`,inputSchema:{query:z.string().min(1).describe(`Keyword query to match against active tools`)},annotations:G(`search_tools`).annotations},Y(`search_tools`,async({query:e})=>{let t=e.trim().toLowerCase(),n=r.filter(e=>{let n=W[e];return e.toLowerCase().includes(t)||n?.title.toLowerCase().includes(t)||(n?.category??[]).some(e=>e.toLowerCase().includes(t))}).map(e=>{let t=W[e]??{title:e,category:[]},n=t.category?.join(`, `)||`uncategorized`;return`${e}: ${t.title} [${n}]`});return{content:[{type:`text`,text:n.length>0?n.join(`
264
264
  `):`No tools found matching "${e}"`}]}}))}const Cp=I(`server`),wp=xe(Rn),Tp={"@huggingface/transformers":`4.2.0`,"onnxruntime-common":`1.24.3`,"onnxruntime-node":`1.24.3`};function Ep(e){return e.replace(/\\/g,`/`)}function Dp(e){return process.platform===`win32`?e.replace(/\//g,ye):e}function Op(){return F(ge(be(import.meta.url)),`..`,`..`,`..`)}function kp(e){return Ep(e).includes(`/_npx/`)}function Ap(e){return/^(1|true)$/i.test(process.env.AIKIT_DISABLE_DEP_REPAIR??``)?!1:/^(1|true)$/i.test(process.env.AIKIT_ALLOW_DEP_REPAIR??``)?!0:kp(e)}function jp(e,t){let n=Ep(e),r=`/node_modules/${t}/`,i=n.lastIndexOf(r);if(i<0)return null;let a=i+r.length-1,o=n.slice(0,a),s=o.search(/[A-Za-z]:\/|\//);return s<0?null:Dp(o.slice(s))}function Mp(e,t){if(!e)return Tp[t]??`latest`;try{return JSON.parse(N(P(e,`package.json`),`utf8`)).version??Tp[t]??`latest`}catch{return Tp[t]??`latest`}}function Np(e){let t=Ep(e).toLowerCase();return/(cannot find module|cannot find package|module not found|err_module_not_found)/i.test(e)?t.includes(`@huggingface/transformers`)||t.includes(`transformers.node`)||t.includes(`onnxruntime-common`)||t.includes(`onnxruntime-node`):!1}function Pp(e){if(!Np(e))return[];let t=Ep(e).toLowerCase(),n=new Map;if(t.includes(`@huggingface/transformers`)){let t=jp(e,`@huggingface/transformers`);n.set(`@huggingface/transformers`,`@huggingface/transformers@${Mp(t,`@huggingface/transformers`)}`)}if(t.includes(`onnxruntime-common`)){let t=jp(e,`onnxruntime-common`);n.set(`onnxruntime-common`,`onnxruntime-common@${Mp(t,`onnxruntime-common`)}`)}if(t.includes(`onnxruntime-node`)){let t=jp(e,`onnxruntime-node`);n.set(`onnxruntime-node`,`onnxruntime-node@${Mp(t,`onnxruntime-node`)}`)}return Array.from(n.values())}function Fp(e){if(!/index\.js/i.test(e)||!Ep(e).includes(`@huggingface`))return!1;let t=jp(e,`@huggingface/transformers`);if(!t)return!1;let n=P(t,`index.js`),r=P(t,`dist`,`transformers.node.mjs`);return j(n)||!j(r)?!1:(me(n,[`// Auto-generated by AI Kit runtime dependency repair.`,`export * from './dist/transformers.node.mjs';`,`export { default } from './dist/transformers.node.mjs';`,``].join(`
265
265
  `),`utf8`),Cp.info(`Auto-heal: created @huggingface/transformers index.js shim`,{path:n}),!0)}async function Ip(e,t={}){let n=Pp(e),r=t.packageRoot??Op(),i=Fp(e);if(n.length===0)return{attempted:i,repaired:i,packages:n,reason:i?`created transformer index shim`:`no missing runtime dependency detected`};if(!Ap(r))return{attempted:i,repaired:i,packages:n,reason:`runtime dependency auto-install disabled outside npx cache; set AIKIT_ALLOW_DEP_REPAIR=1 to enable`};let a=process.platform===`win32`?`npm.cmd`:`npm`,o=[`install`,`--no-save`,`--package-lock=false`,`--no-audit`,`--no-fund`,`--omit=dev`,`--prefer-online`,`--ignore-scripts`,...n];Cp.warn(`Auto-heal: repairing missing runtime dependencies`,{packages:n,packageRoot:r});try{return await wp(a,o,{cwd:r,timeout:t.timeoutMs??6e4,windowsHide:!0}),Cp.info(`Auto-heal: runtime dependency repair completed`,{packages:n,packageRoot:r}),{attempted:!0,repaired:!0,packages:n,reason:`npm install repair completed`}}catch(e){let t=e instanceof Error?e.message:String(e);return Cp.warn(`Auto-heal: runtime dependency repair failed`,{packages:n,packageRoot:r,...L(e)}),{attempted:!0,repaired:i,packages:n,reason:i?`created transformer shim but npm repair failed`:`npm repair failed`,error:t}}}const Lp=I(`tools`);let Rp=!1;function zp(e){let t=e instanceof Error?e.message:String(e);return Np(t)||/embedder worker|embedding worker|circuit breaker|timed out|killed|respawn|ipc_channel|epipe|econnreset/i.test(t)}async function Bp(e,t,n){try{return await e.embedBatch(t,n)}catch(r){if((await Ip(r instanceof Error?r.message:String(r))).repaired)return e.embedBatch(t,n);throw r}}async function Vp(e,t,n){for(let r of n.steps)if(!(r.status!==`success`||!r.output))try{let i=A(`sha256`).update(n.path).digest(`hex`).slice(0,12),a=`produced/onboard/${r.name}/${i}.md`,o=A(`sha256`).update(r.output).digest(`hex`).slice(0,16),s=new Date().toISOString(),c=r.output.length>2e3?r.output.split(/(?=^## )/m).filter(e=>e.trim().length>0):[r.output],l=c.map((e,t)=>({id:A(`sha256`).update(`${a}::${t}`).digest(`hex`).slice(0,16),content:e.trim(),sourcePath:a,contentType:`produced-knowledge`,chunkIndex:t,totalChunks:c.length,startLine:0,endLine:0,fileHash:o,indexedAt:s,origin:`produced`,tags:[`onboard`,r.name],category:`analysis`,version:1})),u=await Bp(t,l.map(e=>e.content));await e.upsert(l,u)}catch(e){if(zp(e)){let t=e instanceof Error?e.message:String(e);Ee.instance().reportDegraded(`embedder`,t),Lp.warn(`Auto-persist onboard disabled — embedder unavailable`,{stepName:r.name,...L(e)});return}Lp.warn(`Auto-persist onboard step failed`,{stepName:r.name,...L(e)})}}async function Hp(e,t,n){if(n.autoRemember?.length)for(let r of n.autoRemember)try{let n=A(`sha256`).update(`onboard-remember::${r.title}`).digest(`hex`).slice(0,16),i=new Date().toISOString(),a={id:n,content:`# ${r.title}\n\n${r.content}`,sourcePath:`curated/onboard/${r.category}/${n}.md`,contentType:`curated`,chunkIndex:0,totalChunks:1,startLine:0,endLine:0,fileHash:A(`sha256`).update(r.content).digest(`hex`).slice(0,16),indexedAt:i,origin:`curated`,tags:r.tags,category:r.category,version:1},[o]=await Bp(t,[a.content]);await e.upsert([a],[o])}catch(e){if(zp(e)){let t=e instanceof Error?e.message:String(e);Ee.instance().reportDegraded(`embedder`,t),Lp.warn(`Auto-persist remember disabled — embedder unavailable`,{title:r.title,...L(e)});return}Lp.warn(`Auto-persist remember entry failed`,{title:r.title,...L(e)})}}function Up(e,t,n,r,i,a){let o=G(`onboard`);e.registerTool(`onboard`,{title:o.title,description:`First-time codebase onboarding: runs all analysis tools (structure, dependencies, entry-points, symbols, patterns, diagram) in one command. Results are auto-persisted to AI Kit memory. Use mode=generate to also write structured output to .ai/context/ directory.`,inputSchema:{path:z.string().describe(`Root path of the codebase to onboard`),mode:z.enum([`memory`,`generate`]).default(`generate`).describe(`Output mode: generate (default) = persist to AI Kit + write .ai/context/ files; memory = AI Kit vector store only`),out_dir:z.string().optional().describe(`Custom output directory for generate mode (default: <path>/.ai/context)`),enrich:z.boolean().default(!0).describe(`Append curated knowledge and graph context to output. Adds ~150-250 tokens. Default true for planning tools — set false to save tokens when enrichment is not needed.`)},annotations:o.annotations},Y(`onboard`,async({path:e,mode:o,out_dir:s,enrich:c},l)=>{try{if(Rp)return{content:[{type:`text`,text:`Onboard is already running. Please wait for it to complete before starting another.`}]};Rp=!0,Lp.info(`Starting onboard`,{path:e,mode:o});let u=await Ft({path:e,mode:o,outDir:s??r?.onboardDir}),d=Vc(l).createTask(`Onboard`,u.steps.length);for(let e=0;e<u.steps.length;e++){let t=u.steps[e];d.progress(e,`${t.name}: ${t.status}`)}d.complete(`Onboard complete: ${u.steps.filter(e=>e.status===`success`).length}/${u.steps.length} steps succeeded`),Vp(t,n,u),u.autoRemember?.length&&Hp(t,n,u).catch(e=>{Lp.warn(`Auto-persist autoRemember failed`,L(e))}),i&&(i.onboardComplete=!0,i.onboardTimestamp=new Date().toISOString());let f=[`## Onboard Complete`,``,`**Path:** \`${u.path}\``,`**Mode:** ${u.mode}`,`**Duration:** ${u.totalDurationMs}ms`,``];u.outDir&&(f.push(`**Output directory:** \`${u.outDir}\``),f.push(``)),f.push(`### Analysis Results`,``);let p=[],m=[];for(let e of u.steps)e.status===`success`?p.push(`- ✓ **${e.name}** (${e.durationMs}ms) — ${e.output.length} chars`):m.push(`- ✗ **${e.name}** — ${e.error}`);f.push(...p),m.length>0&&f.push(``,`### Failed`,``,...m),f.push(``,`---`,``);for(let e of u.steps)e.status===`success`&&f.push(`### ${e.name}`,``,e.output,``,`---`,``);f.push(`_All results auto-saved to AI Kit memory._`,u.mode===`generate`?` Files written to \`${u.outDir}\`.`:``,' Next: Use `search` to query the knowledge, or `knowledge({ action: "remember", ... })` to add custom insights.');let h=f.join(`
266
266
  `);if(c&&a){let e=await K(a,{query:`onboard codebase conventions`});h+=q(e)}return{content:[{type:`text`,text:h}]}}catch(e){return Lp.error(`Onboard failed`,L(e)),J(`INTERNAL`,`Onboard failed: ${e instanceof Error?e.message:String(e)}`)}finally{Rp=!1}}))}const Wp=I(`tools:persistence`);function Gp(e){let t=G(`workset`);e.registerTool(`workset`,{title:t.title,description:`Manage named file sets (worksets). Save, load, list, add/remove files. Worksets persist across sessions in the AI Kit state directory.`,inputSchema:{action:z.enum([`save`,`get`,`list`,`delete`,`add`,`remove`]).describe(`Operation to perform`),name:z.string().optional().describe(`Workset name (required for all except list)`),files:z.array(z.string()).optional().describe(`File paths (required for save, add, remove)`),description:z.string().optional().describe(`Description (for save)`)},annotations:t.annotations},Y(`workset`,async({action:e,name:t,files:n,description:r})=>{try{switch(e){case`save`:{if(!t||!n)throw Error(`name and files required for save`);let e=cn(t,n,{description:r});return{content:[{type:`text`,text:`Saved workset "${e.name}" with ${e.files.length} files.`}]}}case`get`:{if(!t)throw Error(`name required for get`);let e=vt(t);return e?{content:[{type:`text`,text:JSON.stringify(e)}]}:{content:[{type:`text`,text:`Workset "${t}" not found.`}]}}case`list`:{let e=Nt();return e.length===0?{content:[{type:`text`,text:`No worksets.`}]}:{content:[{type:`text`,text:e.map(e=>`- **${e.name}** (${e.files.length} files) — ${e.description??`no description`}`).join(`
@@ -2996,8 +2996,8 @@ Use \`status({})\` to check smart indexing queue status.`}]};let l=Vc(c).createT
2996
2996
 
2997
2997
  `),se=(f===`hybrid`?`hybrid (vector + keyword RRF)`:f===`keyword`?`keyword (FTS)`:`semantic (vector)`)+te,ce=Mg(T,e),j=ce.length>0?`\n_Distinctive terms: ${ce.map(e=>`\`${e}\``).join(`, `)}_`:``,M=await Pg(n,T),N=[];if(T.length===0)N.push("`reindex` — no results found, index may be stale"),N.push("`find` — try federated search with glob/regex");else{let e=T[0]?.record.sourcePath;e&&N.push(`\`lookup\` — see all chunks from \`${e}\``),N.push("`symbol` — resolve a specific symbol from the results"),N.push("`compact` — compress a result file for focused reading")}let le=[re?`${re}\n\n`:``,M?`${M}\n\n`:``,oe,`\n\n---\n_Search mode: ${se} | ${T.length} results_${j}`,`\n_Next: ${N.join(` | `)}_`],ue=O+le.join(``),de=!1;if(b){let e=R(ue,b);de=e!==ue,ue=e}de||=A;let fe=T.map(e=>({sourcePath:e.record.sourcePath,contentType:e.record.contentType,score:e.score,...e.record.headingPath?{headingPath:e.record.headingPath}:{},...e.record.startLine?{startLine:e.record.startLine}:{},...e.record.endLine?{endLine:e.record.endLine}:{},...e.record.origin===`indexed`?{}:{origin:e.record.origin},...e.record.category?{category:e.record.category}:{},...e.record.tags?.length?{tags:e.record.tags}:{}})),pe=[re,M].filter(e=>!!e),me=et({text:ue,query:e,searchMode:f,limit:d,results:fe,durationMs:Date.now()-C,truncated:de,caveats:pe}),he=Ol(me.summary),ge=new Set,_e=[];for(let e of T){if(e.record.origin!==`curated`||e.record.sourcePath.startsWith(`[`))continue;let t=Wd(e.record.sourcePath);if(!t)continue;let n=Hd(t,e.record.headingPath??t);n&&!ge.has(n.uri)&&(ge.add(n.uri),_e.push(n))}return{content:[{type:`text`,text:kl(me.summary,he)},..._e],isError:!me.ok,structuredContent:{...me.data??{results:[],totalResults:0,searchMode:f,query:e},ref:he}}}catch(t){xg.error(`Search failed`,L(t));let n=et({text:`Search failed: ${t instanceof Error?t.message:String(t)}`,query:e??``,searchMode:f??`hybrid`,limit:d,results:[],durationMs:Date.now()-C}),r=Ol(n.summary);return{content:[{type:`text`,text:kl(n.summary,r)}],structuredContent:{...n.data??{results:[],totalResults:0,searchMode:f??`hybrid`,query:e??``},ref:r}}}})}const Ig=I(`tools`);function Lg(e,t,n){let r=G(`session_digest`);e.registerTool(`session_digest`,{title:r.title,description:`Compress the current session's tool trajectory into a focused digest. Aggregates replay log, stash state, and checkpoints. Supports deterministic and LLM-assisted (sampling) modes with configurable token budget.`,inputSchema:{scope:z.enum([`tools`,`stash`,`all`]).default(`all`).describe(`What to include: tools (replay only), stash (stash + checkpoints only), or all`),since:z.string().optional().describe(`ISO timestamp — only include activity after this time`),last:z.number().min(1).max(500).optional().describe(`Max replay entries to consider (default: 50)`),focus:z.string().optional().describe(`Focus query — prioritize entries matching this topic`),mode:z.enum([`deterministic`,`sampling`]).default(`deterministic`).describe(`Summary mode: deterministic (fast, template-based) or sampling (LLM-assisted, richer)`),token_budget:z.number().min(100).max(8e3).default(2e3).describe(`Target token budget for the digest output`),persist:z.boolean().default(!0).describe(`Auto-save digest to stash for crash recovery`)},annotations:r.annotations},Y(`session_digest`,async({scope:e,since:r,last:i,focus:a,mode:o,token_budget:s,persist:c})=>{try{let l={scope:e,since:r,last:i,focus:a,mode:o,tokenBudget:s,persist:c},u=t?{stateStore:t}:void 0;return{content:[{type:`text`,text:(o===`sampling`&&n?.available?await pn(l,async(e,t,r)=>(await n.createMessage({prompt:e,systemPrompt:t,maxTokens:r})).text,u):fn(l,u)).digest}]}}catch(e){return Ig.error(`Session digest failed`,L(e)),J(`INTERNAL`,`Session digest failed: ${e instanceof Error?e.message:String(e)}`)}}))}const Rg=1e4,zg={defaultTtlSeconds:300,defaultLeaseTtlMinutes:10,globalEnabled:!1};function Bg(e){return e??zg}function Vg(e,t){let n=e.trim();if(!n)throw Error(`${t} is required`);return n}function Hg(e,t,n){let r=Vg(e,t);if(r.length>n)throw Error(`${t} exceeds max length of ${n}`);return r}function Ug(e,t){if(!Number.isFinite(e)||e<=0)throw Error(`${t} must be greater than 0`);return Math.trunc(e)}function Wg(e,t=!1,n){Vg(e,`workspace`);let r=Bg(n);if(!t)return e;if(!r.globalEnabled)throw Error(`Global signal scope is disabled`);return`__global__`}function Gg(e,t,n){let r=Bg(n),i=Wg(t.workspace,t.global??!1,r),a=Hg(t.key,`key`,500),o=Hg(t.value,`value`,Rg),s=t.agent?Hg(t.agent,`agent`,500):void 0,c=Ug(t.ttlSeconds??r.defaultTtlSeconds,`ttlSeconds`);return e.signalPost(i,a,o,s,c)}function Kg(e,t,n){let r=Vg(t,`workspace`),i=Hg(n,`key`,500);return e.signalGet(r,i)}function qg(e,t){let n=Vg(t,`workspace`);return e.signalList(n)}function Jg(e,t,n){let r=Vg(t,`workspace`),i=n===void 0?void 0:Hg(n,`key`,500);return e.signalClear(r,i)}function Yg(e,t,n){let r=Bg(n),i=Hg(t.resource,`resource`,500),a=Hg(t.holder,`holder`,500),o=Vg(t.workspace,`workspace`),s=t.intent?Hg(t.intent,`intent`,Rg):void 0,c=Ug(t.ttlMinutes??r.defaultLeaseTtlMinutes,`ttlMinutes`);if(c>60)throw Error(`ttlMinutes exceeds max of 60`);let l=e.leaseAcquire(i,a,o,s,c),u=e.leaseGet(i,o);return u?{acquired:l,holder:u.holder,expiresAt:u.expiresAt}:{acquired:l}}function Xg(e,t,n,r){let i=Vg(t,`workspace`),a=Hg(n,`resource`,500),o=Hg(r,`holder`,500);return e.leaseRelease(a,o,i)}function Zg(e,t){let n=Vg(t,`workspace`);return e.leaseList(n)}const Qg=I(`tools:signal`);function $g(e){return JSON.stringify(e,null,2)}function e_(e,t,n){let r=G(`signal`),i={...zg,...n};e.registerTool(`signal`,{title:r.title,description:`Inter-agent signaling and lease coordination`,inputSchema:{action:z.enum([`post`,`get`,`list`,`clear`,`lease`,`unlease`,`leases`]).describe(`Signal action to perform`),workspace:z.string().describe(`Workspace identifier (required)`),key:z.string().optional().describe(`Signal key (for post/get/clear)`),value:z.string().optional().describe(`Signal value (for post)`),agent:z.string().optional().describe(`Agent identifier`),resource:z.string().optional().describe(`Resource path (for lease/unlease)`),holder:z.string().optional().describe(`Lease holder ID (for lease/unlease)`),intent:z.string().optional().describe(`What the holder plans to do`),ttl:z.number().optional().describe(`TTL (seconds for signals, minutes for leases)`),global:z.boolean().optional().describe(`Use global scope (default: false)`)},annotations:r.annotations},Y(`signal`,async({action:e,workspace:n,key:r,value:a,agent:o,resource:s,holder:c,intent:l,ttl:u,global:d})=>{try{switch(e){case`post`:{if(!r||a===void 0)throw Error(`key and value are required for post`);let e=Gg(t,{workspace:n,key:r,value:a,agent:o,ttlSeconds:u,global:d},i);return{content:[{type:`text`,text:$g({id:e})}],structuredContent:{id:e}}}case`get`:{if(!r)throw Error(`key is required for get`);let e=Kg(t,Wg(n,d??!1,i),r);return{content:[{type:`text`,text:e.length===0?`[]`:$g(e)}],structuredContent:{signals:e}}}case`list`:{let e=qg(t,Wg(n,d??!1,i));return{content:[{type:`text`,text:e.length===0?`[]`:$g(e)}],structuredContent:{signals:e}}}case`clear`:{let e=Jg(t,Wg(n,d??!1,i),r);return{content:[{type:`text`,text:$g({cleared:e})}],structuredContent:{cleared:e}}}case`lease`:{if(!s||!c)throw Error(`resource and holder are required for lease`);let e=Yg(t,{resource:s,holder:c,workspace:n,intent:l,ttlMinutes:u},i);return{content:[{type:`text`,text:$g(e)}],structuredContent:e}}case`unlease`:{if(!s||!c)throw Error(`resource and holder are required for unlease`);let e=Xg(t,n,s,c);return{content:[{type:`text`,text:$g({released:e})}],structuredContent:{released:e}}}case`leases`:{let e=Zg(t,n);return{content:[{type:`text`,text:e.length===0?`[]`:$g(e)}],structuredContent:{leases:e}}}}}catch(e){return Qg.error(`Signal operation failed`,L(e)),J(`INTERNAL`,`Signal operation failed: ${e instanceof Error?e.message:String(e)}`)}}))}function t_(e,t){return e.length<=t?e:e.slice(0,t)}function n_(e){if(!e)return 0;let t=Date.parse(e);return Number.isNaN(t)?0:t}async function r_(e,t,n=_){if(!e||!t)return null;try{let[r,i,a]=await Promise.all([e.list({category:`lessons`}),e.list({category:`conventions`}),e.list({category:`session`})]),o=r.filter(e=>e.tags.includes(`lesson`)).map(e=>{let r=t.memoryMetaGet(e.path);return!r||r.supersededBy!=null?null:{entry:e,confidence:m(r.confidence,r.lastAccessedAt,r.createdAt,n)}}).filter(e=>e!==null).sort((e,t)=>t.confidence-e.confidence).slice(0,3);return{lessons:await Promise.all(o.map(async({entry:t,confidence:n})=>{let r=d((await e.read(t.path)).content);return{title:t.title,insight:t_(r.insight??``,150),confidence:n}})),conventions:i.map(e=>({entry:e,lastAccessedAt:t.memoryMetaGet(e.path)?.lastAccessedAt??null})).sort((e,t)=>n_(t.lastAccessedAt)-n_(e.lastAccessedAt)).slice(0,2).map(({entry:e})=>({title:e.title,preview:e.contentPreview})),checkpoint:a.map(e=>({entry:e,lastAccessedAt:t.memoryMetaGet(e.path)?.lastAccessedAt??null})).sort((e,t)=>n_(t.lastAccessedAt)-n_(e.lastAccessedAt)).map(({entry:e})=>t_(e.contentPreview,200))[0]??null}}catch{return null}}const i_=I(`tools`),a_=14400*1e3,o_={includePrelude:z.boolean().default(!1).describe(`Include session prelude with top lessons, conventions, and last checkpoint`)};function s_(e,t,n,r=15e3){let i,a=new Promise(e=>{i=setTimeout(()=>{i_.warn(`Status sub-operation "${n}" timed out after ${r}ms`),e({value:t,timedOut:!0})},r)});return Promise.race([e.then(e=>(clearTimeout(i),{value:e,timedOut:!1}),e=>(clearTimeout(i),i_.warn(`Status sub-operation "${n}" failed: ${e instanceof Error?e.message:String(e)}`),{value:t,timedOut:!1})),a])}function c_(e){return e.onboarded?e.indexStale?{kind:`reindex`,reason:`Index stale. Run reindex() to update.`}:e.contextPressure>70?{kind:`handoff`,reason:`Context pressure high. Consider session handoff.`}:{kind:`proceed`,reason:`Ready to work.`}:{kind:`onboard`,reason:`Index not initialized. Run onboard({ path: "." }) first.`}}function l_(){let e=ar.get(),t=ir.get();if(e)return`- **Tree-sitter (WASM)**: ✅ Available (${t.grammarCount} grammars, dir: ${t.wasmDir})`;let n=t.pathsChecked.length?t.pathsChecked.map(e=>` ${e.exists?`✓`:`✗`} ${e.path}`).join(`
2998
2998
  `):` none`,r=t.healAttempted?` Auto-heal: ${t.healSuccess?`✓ succeeded`:`✗ failed (${t.healError??`unknown`})`}`:` Auto-heal: not attempted`;return[`- **Tree-sitter (WASM)**: ⚠ Unavailable (regex fallback)`,` Reason: ${t.reason||`unknown`}`,` Paths checked:`,n,r,` OS: ${t.os} ${t.arch} | Node: ${t.nodeVersion}`,` Fix: Reinstall package or run vendor:wasm script`].join(`
2999
- `)}const u_=5*6e4;let d_=null,f_=null;function p_(e,t,n,r){let i=Math.min(e/2e4,1),a=Math.min((t+n)/5e4,1),o=Math.min(r/200,1);return Math.round(i*40+a*35+o*25)}function m_(){let e=Date.now();if(d_&&e-d_.ts<u_)return d_.value;try{let t=F(Bn(),`.copilot`,`.aikit-scaffold.json`);if(!j(t))return d_={value:null,ts:e},null;let n=JSON.parse(N(t,`utf-8`)).version??null;return d_={value:n,ts:e},n}catch{return d_={value:null,ts:e},null}}function h_(){let e=Date.now();if(f_&&e-f_.ts<u_)return f_.value;try{let t=F(process.cwd(),`.github`,`.aikit-scaffold.json`);if(!j(t))return f_={value:null,ts:e},null;let n=JSON.parse(N(t,`utf-8`)).version??null;return f_={value:n,ts:e},n}catch{return f_={value:null,ts:e},null}}function g_(e){let t=G(`status`);e.registerTool(`status`,{title:t.title,description:`Get the current status and statistics of the AI Kit index.`,inputSchema:o_,outputSchema:ks,annotations:t.annotations},Y(`status`,async()=>{let e=re(),t=m_(),n=h_(),r=t!=null&&t!==e,i=n!=null&&n!==e,a=[`## AI Kit Status`,``,`⏳ **AI Kit is initializing** — index stats will be available shortly.`,``,`### Runtime`,`- **Tree-sitter (WASM)**: ${ar.get()?`✅ Available (AST analysis)`:`⚠ Unavailable (regex fallback)`}`,``,`### Version`,`- **Server**: ${e}`,`- **Scaffold (user)**: ${t??`not installed`}`,`- **Scaffold (workspace)**: ${n??`not installed`}`];if(r||i){let o=ie(),s=[];r&&s.push(`user scaffold v${t}`),i&&s.push(`workspace scaffold v${n}`);let c=s.join(`, `);o.state===`success`?a.push(``,`### ✅ Upgrade Applied`,`- Server v${e} — ${c} auto-upgraded successfully.`,`- _Restart the MCP server to use the updated version._`):o.state===`pending`?a.push(``,`### ⏳ Upgrade In Progress`,`- Server v${e} ≠ ${c}`,`- Auto-upgrade is running in the background…`):o.state===`failed`?(ne(),a.push(``,`### ⬆ Upgrade Available (auto-upgrade failed, retrying)`,`- Server v${e} ≠ ${c}`,`- Error: ${o.error??`unknown`}`)):(ne(),a.push(``,`### ⬆ Upgrade Available`,`- Server v${e} ≠ ${c}`,`- Auto-upgrade triggered — check again shortly.`))}let o={totalRecords:0,totalFiles:0,lastIndexedAt:null,onboarded:!1,onboardDir:``,contentTypes:{},wasmAvailable:!!ar.get(),wasmDiagnostics:ir.get(),graphStats:null,curatedCount:0,serverVersion:e,scaffoldVersion:t??null,workspaceScaffoldVersion:n??null,upgradeAvailable:r||i,contextPressure:0,nextAction:c_({onboarded:!1,indexStale:!1,contextPressure:0})};return{content:[{type:`text`,text:a.join(`
3000
- `)}],structuredContent:o}}))}function __(e,t,n,r,i,a,o,s,c){let l=G(`status`);e.registerTool(`status`,{title:l.title,description:`Get the current status and statistics of the AI Kit index.`,inputSchema:o_,outputSchema:ks,annotations:l.annotations},Y(`status`,async({includePrelude:e=!1})=>{let l=[];try{let[u,d]=await Promise.all([s_(t.getStats(),{totalRecords:0,totalFiles:0,lastIndexedAt:null,contentTypeBreakdown:{}},`store.getStats`),s_(t.listSourcePaths(),[],`store.listSourcePaths`)]),f=u.value;u.timedOut&&l.push(`⚠ Index stats timed out — values may be incomplete`);let p=d.value;d.timedOut&&l.push(`⚠ File listing timed out`);let m=null,h=0,g=[`## AI Kit Status`,``,`- **Total Records**: ${f.totalRecords}`,`- **Total Files**: ${f.totalFiles}`,`- **Last Indexed**: ${f.lastIndexedAt??`Never`}`,``,`### Content Types`,...Object.entries(f.contentTypeBreakdown).map(([e,t])=>`- ${e}: ${t}`),``,`### Indexed Files`,...p.slice(0,50).map(e=>`- ${e}`),p.length>50?`\n... and ${p.length-50} more files`:``];if(n)try{let e=await s_(n.getStats(),{nodeCount:0,edgeCount:0,nodeTypes:{},edgeTypes:{}},`graphStore.getStats`);if(e.timedOut)l.push(`⚠ Graph stats timed out`),g.push(``,`### Knowledge Graph`,`- Graph stats timed out`);else{let t=e.value;m={nodes:t.nodeCount,edges:t.edgeCount},g.push(``,`### Knowledge Graph`,`- **Nodes**: ${t.nodeCount}`,`- **Edges**: ${t.edgeCount}`,...Object.entries(t.nodeTypes).map(([e,t])=>` - ${e}: ${t}`));try{let e=await s_(n.validate(),{valid:!0,danglingEdges:[],orphanNodes:[],stats:{nodeCount:0,edgeCount:0,nodeTypes:{},edgeTypes:{}}},`graphStore.validate`);if(!e.timedOut){let t=e.value;t.valid||g.push(`- **⚠ Integrity Issues**: ${t.danglingEdges.length} dangling edges`),t.orphanNodes.length>0&&g.push(`- **Orphan nodes**: ${t.orphanNodes.length}`)}}catch{}}}catch{g.push(``,`### Knowledge Graph`,`- Graph store unavailable`)}let _=a?.onboardDir??``,v=j(_),y=i?.onboardComplete||v;if(g.push(``,`### Onboard Status`,y?`- ✅ Complete${i?.onboardTimestamp?` (last: ${i.onboardTimestamp})`:``}`:'- ❌ Not run — call `onboard({ path: "." })` to analyze the codebase',`- **Onboard Directory**: \`${_}\``),r)try{let e=await s_(r.list(),[],`curated.list`);if(e.timedOut)l.push(`⚠ Curated knowledge listing timed out`),g.push(``,`### Curated Knowledge`,`- Listing timed out`);else{let t=e.value;h=t.length,g.push(``,`### Curated Knowledge`,t.length>0?`- ${t.length} entries`:'- Empty — use `knowledge({ action: "remember", ... })` to persist decisions')}}catch{g.push(``,`### Curated Knowledge`,`- Unable to read curated entries`)}let b=p_(f.totalRecords,m?.nodes??0,m?.edges??0,h),x=f.lastIndexedAt?new Date(f.lastIndexedAt).getTime():0,S=x>0?Date.now()-x:1/0,C=c_({onboarded:y,indexStale:y&&S>1440*60*1e3,contextPressure:b});g.push(``),g.push(`## 📊 Context Pressure: ${b}/100`),b>=80?g.push(`⚠️ High pressure — consider pruning stale entries or compacting context.`):b>=50?g.push(`ℹ️ Moderate pressure — AI Kit memory is well-populated.`):g.push(`✅ Low pressure — plenty of headroom for more content.`);let w=0;if(f.lastIndexedAt){w=new Date(f.lastIndexedAt).getTime();let e=(Date.now()-w)/(1e3*60*60);g.push(``,`### Index Freshness`,e>24?o===`smart`?`- ⚠ Last indexed ${Math.floor(e)}h ago — smart indexing will refresh automatically`:`- ⚠ Last indexed ${Math.floor(e)}h ago — may be stale. Run \`reindex({})\``:`- ✅ Last indexed ${e<1?`less than 1h`:`${Math.floor(e)}h`} ago`)}g.push(``,`### Next Action`,`- **${C.kind}**: ${C.reason}`);let T=null,E=t;if(typeof E.getDiagnostics==`function`)try{let e=E.getDiagnostics();T={adapterType:e.adapterType,vectorSearchEnabled:e.vectorSearchEnabled,ftsEnabled:e.ftsEnabled,degradedMode:e.degradedMode,dbPath:e.dbPath,dbSizeBytes:e.dbSizeBytes,embeddingDim:e.embeddingDim,vectorDtype:e.vectorDtype},g.push(``,`### Storage`,`- **Backend**: ${a?.store?.backend??`unknown`}`,`- **Adapter**: ${T.adapterType}`,`- **Vector search**: ${T.vectorSearchEnabled?`✅ enabled`:`⚠ disabled (FTS-only fallback)`}`,T.dbPath?`- **DB**: ${T.dbPath}`:``,T.dbSizeBytes==null?``:`- **DB size**: ${(T.dbSizeBytes/1024/1024).toFixed(2)} MB`,`- **Embedding dim**: ${T.embeddingDim}`,`- **Vector dtype**: ${T.vectorDtype}`)}catch{}if(o===`smart`)if(g.push(``,`### Smart Indexing`),s){let e=s();e?g.push(`- **Mode**: Smart (trickle)`,`- **Status**: ${e.running?`✅ Running`:`⏸ Stopped`}`,`- **Queue**: ${e.queueSize} files pending`,`- **Changed files**: ${e.changedFilesSize} detected`,`- **Interval**: ${Math.round(e.intervalMs/1e3)}s per batch of ${e.batchSize}`):g.push(`- **Mode**: Smart (trickle)`,`- **Status**: scheduler state unavailable (init may have failed)`)}else g.push(`- **Mode**: Smart (trickle) — scheduler state unavailable`);let D=0;{try{let e=a?.stateDir?P(a.stateDir,`stash`):null;if(e&&j(e)){let t=fe(e).mtimeMs;t>w&&(w=t)}}catch{}let e=[];if(r)try{let t=h>0?await r.list():[];for(let e of t){let t=new Date(e.updated||e.created).getTime();t>w&&(w=t)}e.push(...t.sort((e,t)=>new Date(t.updated).getTime()-new Date(e.updated).getTime()).slice(0,5))}catch{}if(D=w>0?Date.now()-w:0,D>=a_){let t=Math.floor(D/36e5);if(g.push(``,`### 🌅 Session Briefing`,`_${t}+ hours since last activity — here's what to pick up:_`,``),e.length>0){g.push(`**Recent decisions/notes:**`);for(let t of e)g.push(`- **${t.title}** (${t.category??`note`}) — ${(t.contentPreview??``).slice(0,80)}…`)}g.push(``,`**Suggested next steps:**`,'- `search({ query: "SESSION CHECKPOINT", origin: "curated" })` — find your last checkpoint',"- `restore({})` — resume from a saved checkpoint",'- `knowledge({ action: "list" })` — browse all stored knowledge')}}g.push(``,`### Runtime`,l_());let O=Ee.instance().getAll(),k=O.filter(e=>e.status!==`healthy`);if(k.length>0){g.push(``,`### ⚠️ Subsystem Health`);for(let e of k){let t=Math.round((Date.now()-e.since)/1e3);g.push(`- **${e.name}**: ${e.status} (${t}s ago${e.reason?` — ${e.reason}`:``})`)}}else O.length>0&&g.push(``,`### ✅ Subsystem Health`,`- All ${O.length} subsystems healthy`);let ee=we.getAll();if(ee.size>0){g.push(``,`### 🔌 Circuit Breakers`);for(let[e,t]of ee){let n=t.getState(),r=`- **${e}**: ${n===`closed`?`🟢`:n===`open`?`🔴`:`🟡`} ${n}`;if(n===`open`){let e=t.remainingCooldownMs();r+=` (recovery in ${Math.ceil(e/1e3)}s)`}g.push(r)}}let te=m_(),ae=h_(),A=re(),oe=te!=null&&te!==A,se=ae!=null&&ae!==A;if(oe||se){let e=ie(),t=[];oe&&t.push(`user scaffold v${te}`),se&&t.push(`workspace scaffold v${ae}`);let n=t.join(`, `);e.state===`success`?g.push(``,`### ✅ Upgrade Applied`,`- Server v${A} — ${n} auto-upgraded successfully.`,`- _Restart the MCP server to use the updated version._`):e.state===`pending`?g.push(``,`### ⏳ Upgrade In Progress`,`- Server v${A} ≠ ${n}`,`- Auto-upgrade is running in the background…`):e.state===`failed`?(ne(),g.push(``,`### ⬆ Upgrade Available (auto-upgrade failed, retrying)`,`- Server v${A} ≠ ${n}`,`- Error: ${e.error??`unknown`}`)):(ne(),g.push(``,`### ⬆ Upgrade Available`,`- Server v${A} ≠ ${n}`,`- Auto-upgrade triggered — check again shortly.`))}l.length>0&&g.push(``,`### ⚠ Warnings`,...l.map(e=>`- ${e}`));let ce=Po();if(ce.length>0){let e=ce.sort((e,t)=>t.callCount-e.callCount);g.push(``,`### Tool Usage This Session`,``),g.push(`| Tool | Calls | Tokens In | Tokens Out | Errors | Avg Latency |`),g.push(`|------|-------|-----------|------------|--------|-------------|`);for(let t of e.slice(0,15)){let e=Math.round(t.totalInputChars/4),n=Math.round(t.totalOutputChars/4),r=Math.round(t.totalDurationMs/t.callCount);g.push(`| ${t.tool} | ${t.callCount} | ${e.toLocaleString()} | ${n.toLocaleString()} | ${t.errorCount} | ${r}ms |`)}}let M=Ao();M.callCount>0&&(g.push(``),g.push(`### Session Token Usage`),g.push(`- Tool calls: ${M.callCount}`),g.push(`- Input chars: ${M.totalInputChars.toLocaleString()}`),g.push(`- Output chars: ${M.totalOutputChars.toLocaleString()}`),g.push(`- Est. input tokens: ${Math.round(M.totalInputChars/4).toLocaleString()}`),g.push(`- Est. total tokens: ${Math.round((M.totalInputChars+M.totalOutputChars)/4).toLocaleString()}`));let N=Co();if(N.bufferSize>=10){let e=N.state===`healthy`?`🟢`:N.state===`degraded`?`🔴`:`🟡`;g.push(``,`### Auto-GC: ${e} ${N.state}`),g.push(`- p95 latency: ${N.p95}ms | buffer: ${N.bufferSize} samples`),N.gcCount>0&&g.push(`- GC cycles triggered: ${N.gcCount}`)}let le=g.join(`
2999
+ `)}const u_=5*6e4;let d_=null,f_=null;function p_(e,t,n,r){let i=Math.min(e/2e4,1),a=Math.min((t+n)/5e4,1),o=Math.min(r/200,1);return Math.round(i*40+a*35+o*25)}function m_(){let e=Date.now();if(d_&&e-d_.ts<u_)return d_.value;try{let t=F(Bn(),`.copilot`,`.aikit-scaffold.json`);if(!j(t))return d_={value:null,ts:e},null;let n=JSON.parse(N(t,`utf-8`)).version??null;return d_={value:n,ts:e},n}catch{return d_={value:null,ts:e},null}}function h_(){let e=Date.now();if(f_&&e-f_.ts<u_)return f_.value;try{let t=F(process.cwd(),`.github`,`.aikit-scaffold.json`);if(!j(t))return f_={value:null,ts:e},null;let n=JSON.parse(N(t,`utf-8`)).version??null;return f_={value:n,ts:e},n}catch{return f_={value:null,ts:e},null}}function g_(e){let t=G(`status`);e.registerTool(`status`,{title:t.title,description:`Get the current status and statistics of the AI Kit index.`,inputSchema:o_,annotations:t.annotations},Y(`status`,async()=>{let e=re(),t=m_(),n=h_(),r=t!=null&&t!==e,i=n!=null&&n!==e,a=[`## AI Kit Status`,``,`⏳ **AI Kit is initializing** — index stats will be available shortly.`,``,`### Runtime`,`- **Tree-sitter (WASM)**: ${ar.get()?`✅ Available (AST analysis)`:`⚠ Unavailable (regex fallback)`}`,``,`### Version`,`- **Server**: ${e}`,`- **Scaffold (user)**: ${t??`not installed`}`,`- **Scaffold (workspace)**: ${n??`not installed`}`];if(r||i){let o=ie(),s=[];r&&s.push(`user scaffold v${t}`),i&&s.push(`workspace scaffold v${n}`);let c=s.join(`, `);o.state===`success`?a.push(``,`### ✅ Upgrade Applied`,`- Server v${e} — ${c} auto-upgraded successfully.`,`- _Restart the MCP server to use the updated version._`):o.state===`pending`?a.push(``,`### ⏳ Upgrade In Progress`,`- Server v${e} ≠ ${c}`,`- Auto-upgrade is running in the background…`):o.state===`failed`?(ne(),a.push(``,`### ⬆ Upgrade Available (auto-upgrade failed, retrying)`,`- Server v${e} ≠ ${c}`,`- Error: ${o.error??`unknown`}`)):(ne(),a.push(``,`### ⬆ Upgrade Available`,`- Server v${e} ≠ ${c}`,`- Auto-upgrade triggered — check again shortly.`))}let o={totalRecords:0,totalFiles:0,lastIndexedAt:null,onboarded:!1,onboardDir:``,contentTypes:{},wasmAvailable:!!ar.get(),wasmDiagnostics:ir.get(),graphStats:null,curatedCount:0,serverVersion:e,scaffoldVersion:t??null,workspaceScaffoldVersion:n??null,upgradeAvailable:r||i,contextPressure:0,nextAction:c_({onboarded:!1,indexStale:!1,contextPressure:0})};return{content:[{type:`text`,text:a.join(`
3000
+ `)}],structuredContent:o}}))}function __(e,t,n,r,i,a,o,s,c){let l=G(`status`);e.registerTool(`status`,{title:l.title,description:`Get the current status and statistics of the AI Kit index.`,inputSchema:o_,annotations:l.annotations},Y(`status`,async({includePrelude:e=!1})=>{let l=[];try{let[u,d]=await Promise.all([s_(t.getStats(),{totalRecords:0,totalFiles:0,lastIndexedAt:null,contentTypeBreakdown:{}},`store.getStats`),s_(t.listSourcePaths(),[],`store.listSourcePaths`)]),f=u.value;u.timedOut&&l.push(`⚠ Index stats timed out — values may be incomplete`);let p=d.value;d.timedOut&&l.push(`⚠ File listing timed out`);let m=null,h=0,g=[`## AI Kit Status`,``,`- **Total Records**: ${f.totalRecords}`,`- **Total Files**: ${f.totalFiles}`,`- **Last Indexed**: ${f.lastIndexedAt??`Never`}`,``,`### Content Types`,...Object.entries(f.contentTypeBreakdown).map(([e,t])=>`- ${e}: ${t}`),``,`### Indexed Files`,...p.slice(0,50).map(e=>`- ${e}`),p.length>50?`\n... and ${p.length-50} more files`:``];if(n)try{let e=await s_(n.getStats(),{nodeCount:0,edgeCount:0,nodeTypes:{},edgeTypes:{}},`graphStore.getStats`);if(e.timedOut)l.push(`⚠ Graph stats timed out`),g.push(``,`### Knowledge Graph`,`- Graph stats timed out`);else{let t=e.value;m={nodes:t.nodeCount,edges:t.edgeCount},g.push(``,`### Knowledge Graph`,`- **Nodes**: ${t.nodeCount}`,`- **Edges**: ${t.edgeCount}`,...Object.entries(t.nodeTypes).map(([e,t])=>` - ${e}: ${t}`));try{let e=await s_(n.validate(),{valid:!0,danglingEdges:[],orphanNodes:[],stats:{nodeCount:0,edgeCount:0,nodeTypes:{},edgeTypes:{}}},`graphStore.validate`);if(!e.timedOut){let t=e.value;t.valid||g.push(`- **⚠ Integrity Issues**: ${t.danglingEdges.length} dangling edges`),t.orphanNodes.length>0&&g.push(`- **Orphan nodes**: ${t.orphanNodes.length}`)}}catch{}}}catch{g.push(``,`### Knowledge Graph`,`- Graph store unavailable`)}let _=a?.onboardDir??``,v=j(_),y=i?.onboardComplete||v;if(g.push(``,`### Onboard Status`,y?`- ✅ Complete${i?.onboardTimestamp?` (last: ${i.onboardTimestamp})`:``}`:'- ❌ Not run — call `onboard({ path: "." })` to analyze the codebase',`- **Onboard Directory**: \`${_}\``),r)try{let e=await s_(r.list(),[],`curated.list`);if(e.timedOut)l.push(`⚠ Curated knowledge listing timed out`),g.push(``,`### Curated Knowledge`,`- Listing timed out`);else{let t=e.value;h=t.length,g.push(``,`### Curated Knowledge`,t.length>0?`- ${t.length} entries`:'- Empty — use `knowledge({ action: "remember", ... })` to persist decisions')}}catch{g.push(``,`### Curated Knowledge`,`- Unable to read curated entries`)}let b=p_(f.totalRecords,m?.nodes??0,m?.edges??0,h),x=f.lastIndexedAt?new Date(f.lastIndexedAt).getTime():0,S=x>0?Date.now()-x:1/0,C=c_({onboarded:y,indexStale:y&&S>1440*60*1e3,contextPressure:b});g.push(``),g.push(`## 📊 Context Pressure: ${b}/100`),b>=80?g.push(`⚠️ High pressure — consider pruning stale entries or compacting context.`):b>=50?g.push(`ℹ️ Moderate pressure — AI Kit memory is well-populated.`):g.push(`✅ Low pressure — plenty of headroom for more content.`);let w=0;if(f.lastIndexedAt){w=new Date(f.lastIndexedAt).getTime();let e=(Date.now()-w)/(1e3*60*60);g.push(``,`### Index Freshness`,e>24?o===`smart`?`- ⚠ Last indexed ${Math.floor(e)}h ago — smart indexing will refresh automatically`:`- ⚠ Last indexed ${Math.floor(e)}h ago — may be stale. Run \`reindex({})\``:`- ✅ Last indexed ${e<1?`less than 1h`:`${Math.floor(e)}h`} ago`)}g.push(``,`### Next Action`,`- **${C.kind}**: ${C.reason}`);let T=null,E=t;if(typeof E.getDiagnostics==`function`)try{let e=E.getDiagnostics();T={adapterType:e.adapterType,vectorSearchEnabled:e.vectorSearchEnabled,ftsEnabled:e.ftsEnabled,degradedMode:e.degradedMode,dbPath:e.dbPath,dbSizeBytes:e.dbSizeBytes,embeddingDim:e.embeddingDim,vectorDtype:e.vectorDtype},g.push(``,`### Storage`,`- **Backend**: ${a?.store?.backend??`unknown`}`,`- **Adapter**: ${T.adapterType}`,`- **Vector search**: ${T.vectorSearchEnabled?`✅ enabled`:`⚠ disabled (FTS-only fallback)`}`,T.dbPath?`- **DB**: ${T.dbPath}`:``,T.dbSizeBytes==null?``:`- **DB size**: ${(T.dbSizeBytes/1024/1024).toFixed(2)} MB`,`- **Embedding dim**: ${T.embeddingDim}`,`- **Vector dtype**: ${T.vectorDtype}`)}catch{}if(o===`smart`)if(g.push(``,`### Smart Indexing`),s){let e=s();e?g.push(`- **Mode**: Smart (trickle)`,`- **Status**: ${e.running?`✅ Running`:`⏸ Stopped`}`,`- **Queue**: ${e.queueSize} files pending`,`- **Changed files**: ${e.changedFilesSize} detected`,`- **Interval**: ${Math.round(e.intervalMs/1e3)}s per batch of ${e.batchSize}`):g.push(`- **Mode**: Smart (trickle)`,`- **Status**: scheduler state unavailable (init may have failed)`)}else g.push(`- **Mode**: Smart (trickle) — scheduler state unavailable`);let D=0;{try{let e=a?.stateDir?P(a.stateDir,`stash`):null;if(e&&j(e)){let t=fe(e).mtimeMs;t>w&&(w=t)}}catch{}let e=[];if(r)try{let t=h>0?await r.list():[];for(let e of t){let t=new Date(e.updated||e.created).getTime();t>w&&(w=t)}e.push(...t.sort((e,t)=>new Date(t.updated).getTime()-new Date(e.updated).getTime()).slice(0,5))}catch{}if(D=w>0?Date.now()-w:0,D>=a_){let t=Math.floor(D/36e5);if(g.push(``,`### 🌅 Session Briefing`,`_${t}+ hours since last activity — here's what to pick up:_`,``),e.length>0){g.push(`**Recent decisions/notes:**`);for(let t of e)g.push(`- **${t.title}** (${t.category??`note`}) — ${(t.contentPreview??``).slice(0,80)}…`)}g.push(``,`**Suggested next steps:**`,'- `search({ query: "SESSION CHECKPOINT", origin: "curated" })` — find your last checkpoint',"- `restore({})` — resume from a saved checkpoint",'- `knowledge({ action: "list" })` — browse all stored knowledge')}}g.push(``,`### Runtime`,l_());let O=Ee.instance().getAll(),k=O.filter(e=>e.status!==`healthy`);if(k.length>0){g.push(``,`### ⚠️ Subsystem Health`);for(let e of k){let t=Math.round((Date.now()-e.since)/1e3);g.push(`- **${e.name}**: ${e.status} (${t}s ago${e.reason?` — ${e.reason}`:``})`)}}else O.length>0&&g.push(``,`### ✅ Subsystem Health`,`- All ${O.length} subsystems healthy`);let ee=we.getAll();if(ee.size>0){g.push(``,`### 🔌 Circuit Breakers`);for(let[e,t]of ee){let n=t.getState(),r=`- **${e}**: ${n===`closed`?`🟢`:n===`open`?`🔴`:`🟡`} ${n}`;if(n===`open`){let e=t.remainingCooldownMs();r+=` (recovery in ${Math.ceil(e/1e3)}s)`}g.push(r)}}let te=m_(),ae=h_(),A=re(),oe=te!=null&&te!==A,se=ae!=null&&ae!==A;if(oe||se){let e=ie(),t=[];oe&&t.push(`user scaffold v${te}`),se&&t.push(`workspace scaffold v${ae}`);let n=t.join(`, `);e.state===`success`?g.push(``,`### ✅ Upgrade Applied`,`- Server v${A} — ${n} auto-upgraded successfully.`,`- _Restart the MCP server to use the updated version._`):e.state===`pending`?g.push(``,`### ⏳ Upgrade In Progress`,`- Server v${A} ≠ ${n}`,`- Auto-upgrade is running in the background…`):e.state===`failed`?(ne(),g.push(``,`### ⬆ Upgrade Available (auto-upgrade failed, retrying)`,`- Server v${A} ≠ ${n}`,`- Error: ${e.error??`unknown`}`)):(ne(),g.push(``,`### ⬆ Upgrade Available`,`- Server v${A} ≠ ${n}`,`- Auto-upgrade triggered — check again shortly.`))}l.length>0&&g.push(``,`### ⚠ Warnings`,...l.map(e=>`- ${e}`));let ce=Ro();if(ce.length>0){let e=ce.sort((e,t)=>t.callCount-e.callCount);g.push(``,`### Tool Usage This Session`,``),g.push(`| Tool | Calls | Tokens In | Tokens Out | Errors | Avg Latency |`),g.push(`|------|-------|-----------|------------|--------|-------------|`);for(let t of e.slice(0,15)){let e=Math.round(t.totalInputChars/4),n=Math.round(t.totalOutputChars/4),r=Math.round(t.totalDurationMs/t.callCount);g.push(`| ${t.tool} | ${t.callCount} | ${e.toLocaleString()} | ${n.toLocaleString()} | ${t.errorCount} | ${r}ms |`)}}let M=Po();M.callCount>0&&(g.push(``),g.push(`### Session Token Usage`),g.push(`- Tool calls: ${M.callCount}`),g.push(`- Input chars: ${M.totalInputChars.toLocaleString()}`),g.push(`- Output chars: ${M.totalOutputChars.toLocaleString()}`),g.push(`- Est. input tokens: ${Math.round(M.totalInputChars/4).toLocaleString()}`),g.push(`- Est. total tokens: ${Math.round((M.totalInputChars+M.totalOutputChars)/4).toLocaleString()}`));let N=Do();if(N.bufferSize>=10){let e=N.state===`healthy`?`🟢`:N.state===`degraded`?`🔴`:`🟡`;g.push(``,`### Auto-GC: ${e} ${N.state}`),g.push(`- p95 latency: ${N.p95}ms | buffer: ${N.bufferSize} samples`),N.gcCount>0&&g.push(`- GC cycles triggered: ${N.gcCount}`)}let le=g.join(`
3001
3001
  `),ue=e||D>=a_?await r_(r,c):void 0,de={totalRecords:f.totalRecords,totalFiles:f.totalFiles,lastIndexedAt:f.lastIndexedAt??null,onboarded:y,onboardDir:_,contentTypes:f.contentTypeBreakdown,wasmAvailable:!!ar.get(),wasmDiagnostics:ir.get(),graphStats:m,curatedCount:h,serverVersion:A,scaffoldVersion:te??null,workspaceScaffoldVersion:ae??null,upgradeAvailable:oe||se,storeBackend:a?.store?.backend,storeDiagnostics:T??null,contextPressure:b,nextAction:C,sessionTokens:{callCount:M.callCount,totalInputChars:M.totalInputChars,totalOutputChars:M.totalOutputChars,estInputTokens:Math.round(M.totalInputChars/4),estTotalTokens:Math.round((M.totalInputChars+M.totalOutputChars)/4),startTime:M.startTime},...ue===void 0?{}:{prelude:ue}};return{content:[{type:`text`,text:le+(o===`smart`?"\n\n---\n_Next: Use `search` to query indexed content or `graph({action:'find_nodes', name_pattern:'<top-level-module>'})` → then `graph({action:'neighbors', node_id})` for relationships. Smart indexing handles updates automatically._":"\n\n---\n_Next: Use `search` to query indexed content, `graph({action:'find_nodes', name_pattern:'<top-level-module>'})` → then `graph({action:'neighbors', node_id})` for relationships, or `reindex` to refresh the index._")}],structuredContent:de}}catch(e){return i_.error(`Status failed`,L(e)),J(`INTERNAL`,`Status check failed: ${e instanceof Error?e.message:String(e)}`)}}))}const v_=I(`tools`);function y_(e){return e instanceof Error?(`code`in e?e.code:void 0)===`ENOENT`||e.message.startsWith(`File not found:`)||e.message.startsWith(`Path not found:`):!1}function b_(e){let t=G(`web_search`);e.registerTool(`web_search`,{title:t.title,description:`PREFERRED web search — fans out to multiple keyless providers (DuckDuckGo + Bing-HTML + Mojeek) by default, returning a deduplicated, consensus-ranked union within a 10s deadline. Optional providers (SearXNG, Google, Brave, Bing API) join the fan-out automatically when their env vars are set. Pass one query or multiple for parallel searching.`,inputSchema:{queries:z.array(z.string().max(2e3)).min(1).max(5).describe('Search queries (1–5). Single: `["react hooks"]`. Multiple searched in parallel.'),limit:z.number().min(1).max(20).default(5).describe(`Max results per query`),site:z.string().optional().describe(`Restrict to domain (e.g., "docs.aws.amazon.com")`),provider:z.enum([`multi`,`duckduckgo`,`bing-html`,`mojeek`,`searxng`,`google`,`brave`,`bing`]).optional().describe("Search provider. Defaults to env AIKIT_SEARCH_PROVIDER, then `multi` (fan-out). Single keyless: `duckduckgo`, `bing-html`, `mojeek`. Self-hosted: `searxng` (requires SEARXNG_URL). Keyed APIs: `google` (GOOGLE_API_KEY+GOOGLE_CSE_ID), `brave` (BRAVE_API_KEY), `bing` (BING_API_KEY). Missing keys auto-fall back to duckduckgo.")},annotations:t.annotations},Y(`web_search`,async({queries:e,limit:t,site:n,provider:r})=>{let i=e,a=async e=>{let i=await An({query:e,limit:t,site:n,provider:r}),a=[`## Search: ${i.query} _(via ${i.provider})_`,``];if(i.results.length===0)a.push(`No results found.`);else for(let e of i.results)a.push(`### [${e.title}](${e.url})`,e.snippet,``);return a.join(`
3002
3002
  `)};if(i.length===1)try{return{content:[{type:`text`,text:`${await a(i[0])}\n---\n_Next: Use \`web_fetch\` to read any of these pages in full._`}]}}catch(e){return v_.error(`Web search failed`,L(e)),J(`INTERNAL`,`Web search failed: ${e instanceof Error?e.message:String(e)}`)}let o=await Promise.allSettled(i.map(e=>a(e))),s=[],c=0;for(let e=0;e<o.length;e++){let t=o[e];if(t.status===`fulfilled`)s.push(t.value);else{c++;let n=t.reason instanceof Error?t.reason.message:String(t.reason);v_.error(`Web search failed`,{query:i[e],error:n}),s.push(`## ❌ Search failed: ${i[e]}\n\n${n}`)}}let l=`_Searched ${o.length-c}/${o.length} queries successfully._`;s.push(``,`---`,l,"_Next: Use `web_fetch` to read any of these pages in full._");let u=s.join(`
3003
3003
 
@@ -3010,7 +3010,7 @@ Use \`status({})\` to check smart indexing queue status.`}]};let l=Vc(c).createT
3010
3010
  Data matches the schema.`}]};let r=[`## Validation: FAILED`,``,`**${n.errors.length} error(s):**`,``];for(let e of n.errors){let t=e.expected?` (expected: ${e.expected}, got: ${e.received})`:``;r.push(`- \`${e.path}\`: ${e.message}${t}`)}return{content:[{type:`text`,text:r.join(`
3011
3011
  `)}]}}catch(e){return v_.error(`Schema validation failed`,L(e)),J(`INTERNAL`,`Schema validation failed: ${e instanceof Error?e.message:String(e)}`)}}))}function D_(e){let t=G(`env`);e.registerTool(`env`,{title:t.title,description:`Get system and runtime environment info. Sensitive env vars are redacted by default.`,outputSchema:Ms,inputSchema:{include_env:z.boolean().default(!1).describe(`Include environment variables`),filter_env:z.string().optional().describe(`Filter env vars by name substring`),show_sensitive:z.boolean().default(!1).describe(`Show sensitive values (keys, tokens, etc.) — redacted by default`)},annotations:t.annotations},Y(`env`,async({include_env:e,filter_env:t,show_sensitive:n})=>{let r=lt({includeEnv:e,filterEnv:t,showSensitive:n}),i=[`## Environment`,``,`**Platform:** ${r.system.platform} ${r.system.arch}`,`**OS:** ${r.system.type} ${r.system.release}`,`**Host:** ${r.system.hostname}`,`**CPUs:** ${r.system.cpus}`,`**Memory:** ${r.system.memoryFreeGb}GB free / ${r.system.memoryTotalGb}GB total`,``,`**Node:** ${r.runtime.node}`,`**V8:** ${r.runtime.v8}`,`**CWD:** ${r.cwd}`];if(r.env){i.push(``,`### Environment Variables`,``);for(let[e,t]of Object.entries(r.env))i.push(`- \`${e}\`: ${t}`)}let a={platform:r.system.platform,arch:r.system.arch,nodeVersion:r.runtime.node,cwd:r.cwd,cpus:r.system.cpus,memoryFreeGb:r.system.memoryFreeGb,memoryTotalGb:r.system.memoryTotalGb};return{content:[{type:`text`,text:i.join(`
3012
3012
  `)}],structuredContent:a}}))}function O_(e){let t=G(`time`);e.registerTool(`time`,{title:t.title,description:`Parse dates, convert timezones, calculate durations, add time. Supports ISO 8601, unix timestamps, and human-readable formats.`,outputSchema:Ns,inputSchema:{operation:z.enum([`now`,`parse`,`convert`,`diff`,`add`]).describe(`now: current time | parse: parse a date string | convert: timezone conversion | diff: duration between two dates | add: add duration to date`),input:z.string().optional().describe(`Date input (ISO, unix timestamp, or parseable string). For diff: two comma-separated dates`),timezone:z.string().optional().describe(`Target timezone (e.g., "America/New_York", "Asia/Tokyo")`),duration:z.string().optional().describe(`Duration to add (e.g., "2h30m", "1d", "30s") — for add operation`)},annotations:t.annotations},Y(`time`,async({operation:e,input:t,timezone:n,duration:r})=>{try{let i=wn({operation:e,input:t,timezone:n,duration:r}),a=[`**${i.output}**`,``,`ISO: ${i.iso}`,`Unix: ${i.unix}`];i.details&&a.push(``,"```json",JSON.stringify(i.details),"```");let o={iso:i.iso,unix:i.unix,timezone:n??Intl.DateTimeFormat().resolvedOptions().timeZone,formatted:i.output};return{content:[{type:`text`,text:a.join(`
3013
- `)}],structuredContent:o}}catch(e){return v_.error(`Time failed`,L(e)),J(`INTERNAL`,`Time failed: ${e instanceof Error?e.message:String(e)}`)}}))}function k_(e){try{let t=P(e,`.flows`);if(!j(t))return null;let n=le(t,{withFileTypes:!0});for(let e of n){if(!e.isDirectory())continue;let n=P(t,e.name,`meta.json`);if(j(n)&&JSON.parse(N(n,`utf-8`)).status===`active`)return e.name}}catch{return null}return null}function A_(e,t,n,r,i,a,o,s,c,l){let u=new go,d=n.sources[0]?.path??process.cwd(),f=je(d),p={activeSlug:null};p.activeSlug=k_(d);let m=new Fa(P(n.stateDir??``,`flow-context`),()=>p.activeSlug),h=new Sa;h.register(Di()),h.register(ya),h.register(Li),h.register(ca),h.register(Pi),h.register(Oi),h.register(ki),h.register(ga),h.register(ji),h.register(xa),h.register(sa(()=>p.activeSlug?{active:!0,slug:p.activeSlug}:null));let g=new Ea(h,t.curated,{},m),_=l??ws(n,[...Xo,...Wo],Ma,Ko(n)),v=e=>_.has(e),y=new Set([..._].filter(e=>!xp.includes(e)&&!to.has(e))),b=new ao;u.use(Ta(g),{order:5,name:`auto-knowledge`}),u.use(Io(),{order:10,name:`replay`}),u.use(co(b,{stateStore:t.stateStore,curatedStore:t.curated},{trackedTools:y}),{order:94,name:`procedural-memory`}),u.use(Za(new Ya(t.stateStore,t.curated)),{order:95,name:`observation-capture`}),u.use(Qo(),{order:1,name:`structured-content-guard`}),u.use(Pa(Na(n.tokenBudget)),{order:90,name:`compression`}),ls(e,u,n.toolPrefix??``);let x=[..._].filter(e=>Go.has(e)?Uo.includes(e)?!!t.bridge:e===`er_update_policy`?!!t.policyStore:e===`er_evolve_review`?!!t.evolutionCollector:!1:!0);v(`search`)&&Fg(e,t.embedder,t.store,t.graphStore,t.bridge,t.evolutionCollector,a,t.stateStore,n.memory?.retention,n.memory?.consolidation,f);let S={store:t.store,graphStore:t.graphStore,embedder:t.embedder},C=c?e=>{c()?.prioritize(e)}:void 0;v(`lookup`)&&ap(e,t.store,S);let w={onboardComplete:t.onboardComplete,onboardTimestamp:t.onboardTimestamp};v(`status`)&&__(e,t.store,t.graphStore,t.curated,w,n,o,s,t.stateStore),v(`config`)&&yl(e,n),v(`reindex`)&&pg(e,t.indexer,n,t.curated,t.store,i,o),v(`knowledge`)&&rp(e,t.curated,t.policyStore,t.evolutionCollector,i,m,t.stateStore,n.memory?.retention,n.memory?.supersession,n.memory?.consolidation,n.memory?.lessons,S),v(`memory_explain`)&&bp(e,t.embedder,t.store),v(`analyze`)&&Lc(e,t.store,t.embedder,S),v(`blast_radius`)&&Rc(e,t.store,t.embedder,t.graphStore,S),v(`produce_knowledge`)&&dg(e,n),v(`onboard`)&&Up(e,t.store,t.embedder,n,w,S),v(`graph`)&&ud(e,t.graphStore,S),v(`audit`)&&Uc(e,t.store,t.embedder,n.tokenBudget),v(`compact`)&&Ll(e,t.embedder,t.fileCache,d,n.allRoots,S,C),v(`scope_map`)&&Rl(e,t.embedder,t.store,S),v(`find`)&&zl(e,t.embedder,t.store,d,S,f),v(`parse_output`)&&$l(e),v(`workset`)&&Gp(e),v(`check`)&&Xl(e,S,n.tokenBudget),v(`symbol`)&&Bl(e,t.embedder,t.store,t.graphStore,S,f),v(`eval`)&&Zl(e),v(`test_run`)&&Ql(e,S),v(`stash`)&&Kp(e,t.stateStore),v(`signal`)&&e_(e,t.stateStore),v(`git_context`)&&lp(e),v(`diff_parse`)&&up(e),v(`rename`)&&dp(e,n),v(`codemod`)&&fp(e,n),v(`restore`)&&_g(e),v(`file_summary`)&&Vl(e,t.fileCache,d,n.allRoots,S,C),v(`checkpoint`)&&qp(e,t.stateStore),v(`data_transform`)&&pp(e),v(`trace`)&&Hl(e,t.embedder,t.store,t.graphStore,S),v(`process`)&&fd(e),v(`watch`)&&pd(e),v(`dead_symbols`)&&Ul(e,t.embedder,t.store,d,n.allRoots,S),v(`delegate`)&&eu(e,a),v(`health`)&&md(e),v(`lane`)&&Jp(e),v(`queue`)&&Yp(e),v(`web_fetch`)&&hd(e),v(`guide`)&&gd(e,o),xp.some(e=>v(e))&&Sp(e,n,x),v(`evidence_map`)&&nd(e),v(`digest`)&&rd(e,t.embedder),v(`forge_classify`)&&id(e,S),v(`stratum_card`)&&ad(e,t.embedder,t.fileCache),v(`forge_ground`)&&od(e,t.embedder,t.store),v(`present`)&&lg(e,r),v(`browser`)&&Yn(e,n),v(`web_search`)&&b_(e),v(`http`)&&x_(e),v(`regex_test`)&&S_(e),v(`encode`)&&C_(e),v(`measure`)&&w_(e),v(`changelog`)&&T_(e),v(`schema_validate`)&&E_(e),v(`env`)&&D_(e),v(`time`)&&O_(e),v(`flow`)&&ed(e,n,{store:t.store?{search:async(e,n)=>(await t.store.ftsSearch(e,n)).map(e=>({content:e.record.content}))}:null,graphStore:t.graphStore,embedder:t.embedder},e=>{p.activeSlug=e}),t.bridge&&Uo.some(e=>v(e))&&(qc(e,t.bridge,t.evolutionCollector),Jc(e,t.bridge),Yc(e,t.bridge)),t.policyStore&&v(`er_update_policy`)&&tm(e,t.policyStore),t.evolutionCollector&&v(`er_evolve_review`)&&Jl(e,t.evolutionCollector),Ho(e,t.store,t.curated),v(`compliance_score`)&&Qc(e),v(`replay`)&&hg(e),v(`session_digest`)&&Lg(e,t.stateStore,a)}function j_(e,t,n){let r=e=>!n||n.has(e);r(`check`)&&Xl(e,void 0,t.tokenBudget),r(`eval`)&&Zl(e),r(`test_run`)&&Ql(e),r(`parse_output`)&&$l(e),r(`delegate`)&&eu(e),r(`git_context`)&&lp(e),r(`diff_parse`)&&up(e),r(`rename`)&&dp(e,t),r(`codemod`)&&fp(e,t),r(`data_transform`)&&pp(e),r(`workset`)&&Gp(e),r(`restore`)&&_g(e),r(`lane`)&&Jp(e),r(`queue`)&&Yp(e),r(`session_digest`)&&Lg(e),r(`health`)&&md(e),r(`process`)&&fd(e),r(`watch`)&&pd(e),r(`web_fetch`)&&hd(e),r(`guide`)&&gd(e),xp.some(e=>r(e))&&Sp(e,t,[...n??new Set(Xo)]),r(`evidence_map`)&&nd(e),r(`forge_classify`)&&id(e),r(`present`)&&lg(e),r(`browser`)&&Yn(e,t),r(`produce_knowledge`)&&dg(e),r(`compliance_score`)&&Qc(e),r(`replay`)&&hg(e),r(`status`)&&g_(e),r(`flow`)&&ed(e,t),r(`web_search`)&&b_(e),r(`http`)&&x_(e),r(`regex_test`)&&S_(e),r(`encode`)&&C_(e),r(`measure`)&&w_(e),r(`changelog`)&&T_(e),r(`schema_validate`)&&E_(e),r(`env`)&&D_(e),r(`time`)&&O_(e)}const M_=I(`resource-notifier`);var N_=class{mcpServer;constructor(e){this.mcpServer=e}async notifyStatusChanged(){await this.sendUpdate(`aikit://status`)}async notifyFileTreeChanged(){await this.sendUpdate(`aikit://file-tree`)}async notifyCuratedIndexChanged(){await this.sendUpdate(`aikit://curated`)}async notifyCuratedEntryChanged(e){await this.sendUpdate(`aikit://curated/${e}`)}async notifyResourceListChanged(){try{await this.mcpServer.server.sendResourceListChanged()}catch(e){M_.debug(`sendResourceListChanged failed`,{error:String(e)})}}async notifyAfterReindex(){await Promise.allSettled([this.notifyStatusChanged(),this.notifyFileTreeChanged()])}async notifyAfterCuratedWrite(e){let t=[this.notifyStatusChanged(),this.notifyCuratedIndexChanged()];e&&t.push(this.notifyCuratedEntryChanged(e)),await Promise.allSettled(t)}async sendUpdate(e){try{await this.mcpServer.server.sendResourceUpdated({uri:e})}catch(t){M_.debug(`sendResourceUpdated failed`,{uri:e,error:String(t)})}}};const Q=I(`server`);function P_(e){let t=e?.trim().toLowerCase();return t===`1`||t===`true`||t===`yes`||t===`on`}async function F_(n){Q.info(`Initializing AI Kit components`);let r=n.store.backend,i=n.embedding,a={model:i.model,nativeDim:i.nativeDim??Te.nativeDim,dimensions:i.dimensions,queryPrefix:i.queryPrefix??Te.queryPrefix},o=n.store.path,s=P_(process.env.AIKIT_SPLIT_STATE),c=P(o,`aikit.db`),l={splitEnabled:s,contentDbPath:c,controlDbPath:s?P(o,`aikit-control.db`):c},u=null;if(r===`sqlite-vec`){let e=l.contentDbPath;j(o)||M(o,{recursive:!0}),u=await yr(e),Q.debug(`SQLite adapter ready`,{type:u.type,vectorCapable:u.vectorCapable,dbPath:e}),u.vectorCapable||Q.warn(`┌──────────────────────────────────────────────────────────────────┐
3013
+ `)}],structuredContent:o}}catch(e){return v_.error(`Time failed`,L(e)),J(`INTERNAL`,`Time failed: ${e instanceof Error?e.message:String(e)}`)}}))}function k_(e){try{let t=P(e,`.flows`);if(!j(t))return null;let n=le(t,{withFileTypes:!0});for(let e of n){if(!e.isDirectory())continue;let n=P(t,e.name,`meta.json`);if(j(n)&&JSON.parse(N(n,`utf-8`)).status===`active`)return e.name}}catch{return null}return null}function A_(e){let{server:t,aikit:n,config:r,elicitor:i,resourceNotifier:a,samplingClient:o,indexMode:s,getSmartState:c,getSmartScheduler:l,precomputedActiveTools:u}=e,d=new bo,f=r.sources[0]?.path??process.cwd(),p=je(f),m={activeSlug:null};m.activeSlug=k_(f);let h=new za(P(r.stateDir??``,`flow-context`),()=>m.activeSlug),g=new Sa;g.register(Di()),g.register(ya),g.register(Li),g.register(ca),g.register(Pi),g.register(Oi),g.register(ki),g.register(ga),g.register(ji),g.register(xa),g.register(sa(()=>m.activeSlug?{active:!0,slug:m.activeSlug}:null));let _=new Da(g,n.curated,{},h),v=u??Ts(r,[...Pa,...Jo],W,Xo(r)),y=e=>v.has(e),b=new Set([...v].filter(e=>!xp.includes(e)&&!ao.has(e))),x=new lo;d.use(Ta(_),{order:5,name:`auto-knowledge`}),d.use(Bo(),{order:10,name:`replay`}),d.use(po(x,{stateStore:n.stateStore,curatedStore:n.curated},{trackedTools:b}),{order:94,name:`procedural-memory`}),d.use(to(new $a(n.stateStore,n.curated)),{order:95,name:`observation-capture`}),d.use($o(),{order:1,name:`structured-content-guard`}),d.use(Ra(La(r.tokenBudget)),{order:90,name:`compression`}),us(t,d,r.toolPrefix??``);let S=[...v].filter(e=>Yo.has(e)?qo.includes(e)?!!n.bridge:e===`er_update_policy`?!!n.policyStore:e===`er_evolve_review`?!!n.evolutionCollector:!1:!0);y(`search`)&&Fg(t,n.embedder,n.store,n.graphStore,n.bridge,n.evolutionCollector,o,n.stateStore,r.memory?.retention,r.memory?.consolidation,p);let C={store:n.store,graphStore:n.graphStore,embedder:n.embedder},w=l?e=>{l()?.prioritize(e)}:void 0;y(`lookup`)&&ap(t,n.store,C);let T={onboardComplete:n.onboardComplete,onboardTimestamp:n.onboardTimestamp};y(`status`)&&__(t,n.store,n.graphStore,n.curated,T,r,s,c,n.stateStore),y(`config`)&&yl(t,r),y(`reindex`)&&pg(t,n.indexer,r,n.curated,n.store,a,s),y(`knowledge`)&&rp(t,n.curated,n.policyStore,n.evolutionCollector,a,h,n.stateStore,r.memory?.retention,r.memory?.supersession,r.memory?.consolidation,r.memory?.lessons,C),y(`memory_explain`)&&bp(t,n.embedder,n.store),y(`analyze`)&&Lc(t,n.store,n.embedder,C),y(`blast_radius`)&&Rc(t,n.store,n.embedder,n.graphStore,C),y(`produce_knowledge`)&&dg(t,r),y(`onboard`)&&Up(t,n.store,n.embedder,r,T,C),y(`graph`)&&ud(t,n.graphStore,C),y(`audit`)&&Uc(t,n.store,n.embedder,r.tokenBudget),y(`compact`)&&Ll(t,n.embedder,n.fileCache,f,r.allRoots,C,w),y(`scope_map`)&&Rl(t,n.embedder,n.store,C),y(`find`)&&zl(t,n.embedder,n.store,f,C,p),y(`parse_output`)&&$l(t),y(`workset`)&&Gp(t),y(`check`)&&Xl(t,C,r.tokenBudget),y(`symbol`)&&Bl(t,n.embedder,n.store,n.graphStore,C,p),y(`eval`)&&Zl(t),y(`test_run`)&&Ql(t,C),y(`stash`)&&Kp(t,n.stateStore),y(`signal`)&&e_(t,n.stateStore),y(`git_context`)&&lp(t),y(`diff_parse`)&&up(t),y(`rename`)&&dp(t,r),y(`codemod`)&&fp(t,r),y(`restore`)&&_g(t),y(`file_summary`)&&Vl(t,n.fileCache,f,r.allRoots,C,w),y(`checkpoint`)&&qp(t,n.stateStore),y(`data_transform`)&&pp(t),y(`trace`)&&Hl(t,n.embedder,n.store,n.graphStore,C),y(`process`)&&fd(t),y(`watch`)&&pd(t),y(`dead_symbols`)&&Ul(t,n.embedder,n.store,f,r.allRoots,C),y(`delegate`)&&eu(t,o),y(`health`)&&md(t),y(`lane`)&&Jp(t),y(`queue`)&&Yp(t),y(`web_fetch`)&&hd(t),y(`guide`)&&gd(t,s),xp.some(e=>y(e))&&Sp(t,r,S),y(`evidence_map`)&&nd(t),y(`digest`)&&rd(t,n.embedder),y(`forge_classify`)&&id(t,C),y(`stratum_card`)&&ad(t,n.embedder,n.fileCache),y(`forge_ground`)&&od(t,n.embedder,n.store),y(`present`)&&lg(t,i),y(`browser`)&&Yn(t,r),y(`web_search`)&&b_(t),y(`http`)&&x_(t),y(`regex_test`)&&S_(t),y(`encode`)&&C_(t),y(`measure`)&&w_(t),y(`changelog`)&&T_(t),y(`schema_validate`)&&E_(t),y(`env`)&&D_(t),y(`time`)&&O_(t),y(`flow`)&&ed(t,r,{store:n.store?{search:async(e,t)=>(await n.store.ftsSearch(e,t)).map(e=>({content:e.record.content}))}:null,graphStore:n.graphStore,embedder:n.embedder},e=>{m.activeSlug=e}),n.bridge&&qo.some(e=>y(e))&&(qc(t,n.bridge,n.evolutionCollector),Jc(t,n.bridge),Yc(t,n.bridge)),n.policyStore&&y(`er_update_policy`)&&tm(t,n.policyStore),n.evolutionCollector&&y(`er_evolve_review`)&&Jl(t,n.evolutionCollector),Ko(t,n.store,n.curated),y(`compliance_score`)&&Qc(t),y(`replay`)&&hg(t),y(`session_digest`)&&Lg(t,n.stateStore,o)}function j_(e,t,n){let r=e=>!n||n.has(e);r(`check`)&&Xl(e,void 0,t.tokenBudget),r(`eval`)&&Zl(e),r(`test_run`)&&Ql(e),r(`parse_output`)&&$l(e),r(`delegate`)&&eu(e),r(`git_context`)&&lp(e),r(`diff_parse`)&&up(e),r(`rename`)&&dp(e,t),r(`codemod`)&&fp(e,t),r(`data_transform`)&&pp(e),r(`workset`)&&Gp(e),r(`restore`)&&_g(e),r(`lane`)&&Jp(e),r(`queue`)&&Yp(e),r(`session_digest`)&&Lg(e),r(`health`)&&md(e),r(`process`)&&fd(e),r(`watch`)&&pd(e),r(`web_fetch`)&&hd(e),r(`guide`)&&gd(e),xp.some(e=>r(e))&&Sp(e,t,[...n??new Set(Pa)]),r(`evidence_map`)&&nd(e),r(`forge_classify`)&&id(e),r(`present`)&&lg(e),r(`browser`)&&Yn(e,t),r(`produce_knowledge`)&&dg(e),r(`compliance_score`)&&Qc(e),r(`replay`)&&hg(e),r(`status`)&&g_(e),r(`flow`)&&ed(e,t),r(`web_search`)&&b_(e),r(`http`)&&x_(e),r(`regex_test`)&&S_(e),r(`encode`)&&C_(e),r(`measure`)&&w_(e),r(`changelog`)&&T_(e),r(`schema_validate`)&&E_(e),r(`env`)&&D_(e),r(`time`)&&O_(e)}const M_=I(`resource-notifier`);var N_=class{mcpServer;constructor(e){this.mcpServer=e}async notifyStatusChanged(){await this.sendUpdate(`aikit://status`)}async notifyFileTreeChanged(){await this.sendUpdate(`aikit://file-tree`)}async notifyCuratedIndexChanged(){await this.sendUpdate(`aikit://curated`)}async notifyCuratedEntryChanged(e){await this.sendUpdate(`aikit://curated/${e}`)}async notifyResourceListChanged(){try{await this.mcpServer.server.sendResourceListChanged()}catch(e){M_.debug(`sendResourceListChanged failed`,{error:String(e)})}}async notifyAfterReindex(){await Promise.allSettled([this.notifyStatusChanged(),this.notifyFileTreeChanged()])}async notifyAfterCuratedWrite(e){let t=[this.notifyStatusChanged(),this.notifyCuratedIndexChanged()];e&&t.push(this.notifyCuratedEntryChanged(e)),await Promise.allSettled(t)}async sendUpdate(e){try{await this.mcpServer.server.sendResourceUpdated({uri:e})}catch(t){M_.debug(`sendResourceUpdated failed`,{uri:e,error:String(t)})}}};const Q=I(`server`);function P_(e){let t=e?.trim().toLowerCase();return t===`1`||t===`true`||t===`yes`||t===`on`}async function F_(n){Q.info(`Initializing AI Kit components`);let r=n.store.backend,i=n.embedding,a={model:i.model,nativeDim:i.nativeDim??Te.nativeDim,dimensions:i.dimensions,queryPrefix:i.queryPrefix??Te.queryPrefix},o=n.store.path,s=P_(process.env.AIKIT_SPLIT_STATE),c=P(o,`aikit.db`),l={splitEnabled:s,contentDbPath:c,controlDbPath:s?P(o,`aikit-control.db`):c},u=null;if(r===`sqlite-vec`){let e=l.contentDbPath;j(o)||M(o,{recursive:!0}),u=await yr(e),Q.debug(`SQLite adapter ready`,{type:u.type,vectorCapable:u.vectorCapable,dbPath:e}),u.vectorCapable||Q.warn(`┌──────────────────────────────────────────────────────────────────┐
3014
3014
  │ ⚠ SQLite vector extension unavailable — DEGRADED MODE │
3015
3015
  │ Vector search is disabled. Hybrid search returns FTS only. │
3016
3016
  │ To enable: install/rebuild better-sqlite3 (native module). │
@@ -3018,6 +3018,6 @@ Data matches the schema.`}]};let r=[`## Validation: FAILED`,``,`**${n.errors.len
3018
3018
  `)}const L_=I(`background-task`);var R_=class{queue=[];running=null;get isRunning(){return this.running!==null}get currentTask(){return this.running}get pendingCount(){return this.queue.length}schedule(e){return new Promise((t,n)=>{this.queue.push({...e,resolve:t,reject:n}),this.running||this.processQueue()})}async processQueue(){for(;this.queue.length>0;){let e=this.queue.shift();if(!e)break;this.running=e.name,L_.info(`Background task started`,{task:e.name,pending:this.queue.length});let t=Date.now();try{await e.fn();let n=Date.now()-t;L_.info(`Background task completed`,{task:e.name,durationMs:n}),e.resolve()}catch(n){let r=Date.now()-t;L_.error(`Background task failed`,{task:e.name,durationMs:r,err:n}),e.reject(n instanceof Error?n:Error(String(n)))}}this.running=null}};const z_=I(`idle-timer`);var B_=class{timer=null;cleanupFns=[];idleMs;disposed=!1;sessionActive=!1;_busy=!1;constructor(e){this.idleMs=e?.idleMs??3e5}setBusy(e){this._busy=e,e?this.cancel():this.touch()}onIdle(e){this.cleanupFns.push(e)}markSessionActive(){this.sessionActive=!0}touch(){this.disposed||this._busy||(this.cancel(),this.timer=setTimeout(()=>{this.runCleanup()},this.idleMs),this.timer.unref&&this.timer.unref())}cancel(){this.timer&&=(clearTimeout(this.timer),null)}dispose(){this.cancel(),this.cleanupFns.length=0,this.disposed=!0}async runCleanup(){if(!this.sessionActive){z_.info(`Idle timeout reached with no active session — skipping cleanup (waiting for first tool call)`);return}if(this._busy){z_.info(`Skipping idle cleanup — background work in progress`);return}z_.info(`Idle for ${this.idleMs/1e3}s — running cleanup`);let e=await Promise.allSettled(this.cleanupFns.map(e=>e()));for(let t of e)t.status===`rejected`&&z_.warn(`Idle cleanup callback failed`,{error:String(t.reason)})}};const V_=I(`memory-monitor`);var H_=class{timer=null;warningBytes;criticalBytes;intervalMs;pressureFns=[];memoryPressureFns=[];lastLevel=`normal`;constructor(e){this.warningBytes=e?.warningBytes??4294967296,this.criticalBytes=e?.criticalBytes??8589934592,this.intervalMs=e?.intervalMs??6e4}onPressure(e){this.pressureFns.push(e)}registerMemoryPressureCallback(e){this.memoryPressureFns.push(e)}start(){this.timer||(this.timer=setInterval(()=>this.check(),this.intervalMs),this.timer.unref&&this.timer.unref(),V_.debug(`Memory monitor started`,{warningMB:Math.round(this.warningBytes/1024/1024),criticalMB:Math.round(this.criticalBytes/1024/1024),intervalSec:Math.round(this.intervalMs/1e3)}))}stop(){this.timer&&=(clearInterval(this.timer),null)}getRssBytes(){return process.memoryUsage.rss()}check(){let e=this.getRssBytes(),t=`normal`;if(e>=this.criticalBytes?t=`critical`:e>=this.warningBytes&&(t=`warning`),t!==this.lastLevel||t===`critical`){let n=Math.round(e/1024/1024);t===`critical`?V_.warn(`Memory CRITICAL: ${n}MB RSS — consider restarting the server`):t===`warning`?V_.warn(`Memory WARNING: ${n}MB RSS`):this.lastLevel!==`normal`&&V_.info(`Memory returned to normal: ${n}MB RSS`),this.lastLevel=t}if(t!==`normal`)for(let n of this.pressureFns)try{n(t,e)}catch{}if(t===`critical`)for(let e of this.memoryPressureFns)try{let t=e();t&&typeof t.catch==`function`&&t.catch(()=>{})}catch{}return t===`critical`&&typeof globalThis.gc==`function`&&globalThis.gc(),t}};const U_=I(`tool-timeout`),W_=new Set([`onboard`,`reindex`,`produce_knowledge`,`analyze`,`codemod`,`audit`]);var G_=class extends Error{toolName;timeoutMs;constructor(e,t){super(`Tool "${e}" timed out after ${t}ms`),this.toolName=e,this.timeoutMs=t,this.name=`ToolTimeoutError`}};function K_(e){return W_.has(e)?6e5:12e4}function q_(e,t,n){return new Promise((r,i)=>{let a=!1,o=setTimeout(()=>{if(!a){a=!0;let e=new G_(n,t);U_.warn(e.message),i(e)}},t);o.unref&&o.unref(),e().then(e=>{a||(a=!0,clearTimeout(o),r(e))},e=>{a||(a=!0,clearTimeout(o),i(e))})})}const $=I(`server`),J_=new Set([`status`,`list_tools`,`describe_tool`,`config`,`env`,`present`]);function Y_(e,t=28){let n=e.replace(/\s+/g,` `).trim();return n.length<=t?n:`${n.slice(0,t-3)}...`}function X_(e){let t=[`query`,`path`,`task`,`name`,`start`,`symbol`,`file`,`pattern`],n=[];for(let r of t){let t=e[r];typeof t==`string`&&t.length>0&&t.length<200&&n.push(t)}return n.join(` `).slice(0,200)}async function Z_(e,t,n){let r=[];try{t.statePath&&ct(e.stateStore,{stateDir:t.statePath});let i=e.stateStore.stashList().map(e=>e.key);if(i.length>0){let e=n.toLowerCase().split(/\s+/).filter(e=>e.length>2);if(e.length===0)r.push(`stash: ${i.length} entries available`);else{let t=i.filter(t=>e.some(e=>t.toLowerCase().includes(e))).slice(0,3);t.length>0?r.push(`stash: ${t.map(e=>`"${Y_(e)}"`).join(`, `)}${i.length>t.length?` (${i.length} total)`:``}`):r.push(`stash: ${i.length} entries available`)}}}catch{}try{if(n){let t=await Promise.race([e.store.ftsSearch(n,{limit:3}),new Promise(e=>setTimeout(()=>e(null),50))]);if(Array.isArray(t)&&t.length>0){let e=t.filter(e=>e&&typeof e==`object`&&`record`in e&&(e.record.origin===`produced`||e.record.origin===`curated`));if(e.length>0){let t=e.slice(0,2).map(e=>{let t=e.record;return`"${Y_(t.headingPath||t.sourcePath||`knowledge`)}"`});r.push(`knowledge: ${t.join(`, `)}`)}}}}catch{}return r.length===0?null:`\n---\nContext available: ${r.join(` | `)}\nPull with: stash({action:'get', key:'...'}) or search({query:'...', origin:'produced'})\n---`}function Q_(e,t,n){let r=3;for(let[i,a]of Object.entries(e)){let e=a.handler;a.handler=async(...a)=>{let o=await e(...a);if(!o||typeof o!=`object`||r<=0||o.isError||J_.has(i))return o;try{r--;let e=a[0],i=await Z_(t,n,X_(e&&typeof e==`object`?e:{}));i&&(o.content=Array.isArray(o.content)?o.content:[],o.content.push({type:`text`,text:i}))}catch{}return o}}}function $_(e){let t=e.toLowerCase();return[`protobuf`,`invalid model`,`invalid onnx`,`unexpected end`,`unexpected token`,`failed to load`,`failed to initialize embedding`,`checksum`,`corrupt`,`malformed`,`could not load`,`onnx`,`database disk image is malformed`,`file is not a database`,`lance`,`cannot find module`,`cannot find package`,`module not found`].some(e=>t.includes(e))}function ev(e){return Np(e)?[`Auto-heal tried to repair missing runtime dependency files in the npx install.`,`If this persists, clear the broken npx cache and restart:`,` npm cache clean --force`,` npx -y @vpxa/aikit@latest serve`].join(`
3019
3019
  `):[`To fix embedding errors, try deleting the cached model:`,` rm -rf ~/.cache/huggingface/transformers-js/mixedbread-ai/`,`Then restart the server to re-download a fresh copy.`].join(`
3020
3020
  `)}async function tv(e,t){let n=t.toLowerCase(),r;try{({rm:r}=await import(`node:fs/promises`))}catch{return}if(n.includes(`transformers.node.mjs`)&&n.includes(`cannot find module`)){let e=t.match(/Cannot find module '([^']+transformers\.node\.mjs)'/);if(e){let t=e[1],n=t.replace(/\.mjs$/,`.cjs`);try{let{existsSync:e,writeFileSync:r}=await import(`node:fs`);e(n)&&!e(t)&&(r(t,[`// Auto-generated ESM shim — published package missing this file`,`import { createRequire } from 'node:module';`,`const require = createRequire(import.meta.url);`,`const mod = require('./transformers.node.cjs');`,`export default mod;`,``].join(`
3021
- `),`utf8`),$.info(`Auto-heal: created ESM shim for @huggingface/transformers (.mjs wrapper → .cjs)`,{path:t}))}catch(e){$.warn(`Auto-heal: failed to create ESM shim`,{error:e instanceof Error?e.message:String(e),path:t})}}}if(n.includes(`embedding`)||n.includes(`onnx`)||n.includes(`protobuf`)||n.includes(`model`)){let t=e.embedding?.model;if(t){let e=P(Bn(),`.cache`,`huggingface`,`transformers-js`,t);try{await r(e,{recursive:!0,force:!0}),$.info(`Auto-heal: cleared embedding model cache`,{path:e})}catch{}}}if(n.includes(`lance`)||n.includes(`database`)||n.includes(`store`)){let t=P(e.store.path,`lance`);try{await r(t,{recursive:!0,force:!0}),$.info(`Auto-heal: cleared LanceDB store`,{path:t})}catch{}}if(n.includes(`sqlite`)||n.includes(`database disk image`)||n.includes(`graph`)){let t=P(e.store.path,`graph.db`);try{await r(t,{force:!0}),$.info(`Auto-heal: cleared graph database`,{path:t})}catch{}let n=P(e.store.path,`aikit.db`);try{await r(n,{force:!0}),await r(`${n}-wal`,{force:!0}).catch(()=>{}),await r(`${n}-shm`,{force:!0}).catch(()=>{}),$.info(`Auto-heal: cleared corrupted aikit database`,{path:n})}catch{}}if(Np(t)){let e=await Ip(t);e.repaired||$.warn(`Auto-heal: missing runtime dependency repair did not complete`,{packages:e.packages,reason:e.reason,error:e.error,hint:`Run: npm cache clean --force && npx -y @vpxa/aikit@latest serve`})}else n.includes(`cannot find module`)&&!n.includes(`.cache`)&&$.warn(`Auto-heal: missing module detected during initialization cleanup`,{hint:`Run: npm cache clean --force && npx -y @vpxa/aikit@latest serve`})}function nv(e,t){let n=ws(e,Xo,Ma,Ko(e)),r=I_(e,n,Ma),i=new Hn({name:e.serverName??`aikit`,version:re()},{capabilities:{logging:{},completions:{},prompts:{}},instructions:r}),a=`initializing`,o=``,s=!1,c=null,l=null,u=null;function d(e){if(!e||typeof e!=`object`)return[];let t=e,n=[];for(let e of[`path`,`file`,`source_path`,`sourcePath`,`filePath`]){let r=t[e];typeof r==`string`&&r&&n.push(r)}for(let e of[`changed_files`,`paths`,`files`]){let r=t[e];if(Array.isArray(r))for(let e of r){if(typeof e==`string`){n.push(e);continue}e&&typeof e==`object`&&typeof e.path==`string`&&n.push(e.path)}}if(Array.isArray(t.sources))for(let e of t.sources)e&&typeof e==`object`&&typeof e.path==`string`&&n.push(e.path);return n}let f=()=>a===`failed`?[`❌ AI Kit initialization failed — this tool is unavailable.`,``,o?`Error: ${o}`:``,``,`**${Yo.size} tools are still available** and fully functional:`,`check, eval, test_run, git_context, health, measure, web_fetch, web_search,`,`flow, regex_test, encode,`,`stash, checkpoint, lane, process, time, env, and more.`,``,ev(o),``,`Try restarting the MCP server to retry initialization.`].filter(Boolean).join(`
3022
- `):[`AI Kit is still initializing (loading embeddings model & store).`,``,`**${Yo.size} tools are already available** while initialization completes — including:`,`check, eval, test_run, git_context, health, measure, web_fetch, web_search,`,`flow, regex_test, encode,`,`stash, checkpoint, lane, process, time, env, and more.`,``,`This tool requires the AI Kit index. Please retry in a few seconds,`,`or use one of the available tools above in the meantime.`].join(`
3023
- `);zr(i);let p=new go;p.use(Qo(),{order:1,name:`structured-content-guard`}),ls(i,p,e.toolPrefix??``);let m=i.sendToolListChanged.bind(i);i.sendToolListChanged=()=>{};let h=[];for(let e of Xo){if(!n.has(e))continue;let t=G(e),r=i.registerTool(e,{title:t.title,description:`${t.title} — initializing, available shortly`,inputSchema:{},annotations:t.annotations},async()=>({content:[{type:`text`,text:f()}]}));Yo.has(e)?r.remove():h.push(r)}j_(i,e,n),i.sendToolListChanged=m;let g=i.registerResource(`aikit-status`,`aikit://status`,{description:`AI Kit status (initializing...)`,mimeType:`text/plain`},async()=>({contents:[{uri:`aikit://status`,text:`AI Kit is initializing...`,mimeType:`text/plain`}]})),_=i.registerPrompt(`_init`,{description:`Initializing AI Kit…`,argsSchema:{_dummy:qn(z.string(),()=>[])}},async()=>({messages:[]})),v,y,b=new Promise((e,t)=>{v=e,y=t}),x,S=new Promise(e=>{x=e}),C=()=>x?.(),w=(async()=>{await S;try{let{createRequire:e}=await import(`node:module`),{readFileSync:t,existsSync:n}=await import(`node:fs`),{fileURLToPath:r}=await import(`node:url`),{resolve:i,dirname:a}=await import(`node:path`),o=e(import.meta.url),s=a(r(import.meta.url)),c=i(s,`..`,`package.json`),l=i(s,`..`,`..`),u=JSON.parse(t(c,`utf8`)),d=Object.keys(u.dependencies??{}),f=[`@mixmark-io/domino`],p=[...d,...f.filter(e=>!d.includes(e))],m=p.filter(e=>!e.startsWith(`@aikit/`)),h=p.filter(e=>e.startsWith(`@aikit/`)),g=[];for(let e of m)try{o.resolve(e)}catch{try{o.resolve(`${e}/package.json`)}catch{g.push(e)}}g.length>0&&$.warn(`Dependencies not resolvable — server may operate in degraded mode`,{missing:g,hint:`Run: npm cache clean --force && npx -y @vpxa/aikit@latest serve`});let _=[];if(h.length>0){for(let e of h)n(i(l,e.slice(7),`dist`))||_.push(e);_.length>0&&$.warn(`Workspace sibling packages missing dist — server may have degraded features`,{missing:_,hint:`Reinstall: npm cache clean --force && npx -y @vpxa/aikit@latest serve`})}}catch{}let n;try{n=await F_(e)}catch(t){let r=t instanceof Error?t.message:String(t);if($_(r)){$.warn(`AI Kit initialization failed with recoverable error — attempting auto-heal retry`,{error:r}),await tv(e,r);try{n=await F_(e),$.info(`AI Kit auto-heal successful — initialization recovered after retry`)}catch(e){a=`failed`,o=e instanceof Error?e.message:String(e),$.error(`AI Kit initialization failed after auto-heal attempt — server continuing with zero-dep tools only`,{error:o,originalError:r}),y?.(e instanceof Error?e:Error(o));return}}else{a=`failed`,o=r,$.error(`AI Kit initialization failed — server continuing with zero-dep tools only`,{error:o}),y?.(t instanceof Error?t:Error(o));return}}let r=i.sendToolListChanged.bind(i);i.sendToolListChanged=()=>{};let f=i.sendPromptListChanged.bind(i);i.sendPromptListChanged=()=>{};let p=i.sendResourceListChanged.bind(i);i.sendResourceListChanged=()=>{};for(let e of h)e.remove();g.remove(),_.remove();let m=i._registeredTools??{};for(let e of Yo)m[e]?.remove();let b=new N_(i),x=au(i);A_(i,n,e,Lr(i),b,x,t,t===`smart`?(()=>{let e=u;return e?.getState?e.getState():null}):null,t===`smart`?()=>{let e=u;return e?{prioritize:e.prioritize.bind(e)}:null}:null),Xr(i,{curated:n.curated,store:n.store,graphStore:n.graphStore,stateStore:n.stateStore},t),i.sendToolListChanged=r,i.sendPromptListChanged=f,i.sendResourceListChanged=p,Promise.resolve(i.sendToolListChanged()).catch(()=>{}),Promise.resolve(i.sendPromptListChanged()).catch(()=>{}),Promise.resolve(i.sendResourceListChanged()).catch(()=>{});let C=i._registeredTools??{};for(let[e,t]of Object.entries(C)){if(qo.has(e))continue;let r=t.handler;t.handler=async(...i)=>{if(!n.indexer.isIndexing)return r(...i);let a=s?`re-indexing`:`running initial index`,o=new Promise(n=>setTimeout(()=>n({content:[{type:`text`,text:`⏳ AI Kit is ${a}. The tool "${e}" timed out waiting for index data (${Jo/1e3}s).\n\nThe existing index may be temporarily locked. Please retry shortly — indexing will complete automatically.`}],...t.config?.outputSchema?{structuredContent:is(t.config.outputSchema)}:{}}),Jo));return Promise.race([r(...i),o])}}for(let[e,t]of Object.entries(C)){let n=t.handler,r=K_(e);t.handler=async(...i)=>{try{return await q_(()=>n(...i),r,e)}catch(n){if(n instanceof G_)return{content:[{type:`text`,text:`⏳ Tool "${e}" timed out after ${r/1e3}s. This may indicate a long-running operation. Please retry or break the task into smaller steps.`}],...t.config?.outputSchema?{structuredContent:is(t.config.outputSchema)}:{}};throw n}}}let w=Object.keys(C).length;w<Xo.length&&$.warn(`ALL_TOOL_NAMES count mismatch`,{expectedToolCount:Xo.length,registeredToolCount:w}),$.debug(`MCP server configured`,{toolCount:Xo.length,resourceCount:4});let T=new H_;T.onPressure((e,t)=>{e===`warning`&&Ur(),e===`critical`&&($.warn(`Memory pressure critical — consider restarting`,{rssMB:Math.round(t/1024/1024)}),Ur())}),T.registerMemoryPressureCallback(()=>n.embedder.shutdown?.()),T.start();let D=new B_;l=D,D.onIdle(async()=>{if(E.isRunning||n.indexer.isIndexing){$.info(`Idle cleanup deferred — background tasks still running`),D.touch();return}$.info(`Idle cleanup: releasing cached memory (connections stay open)`);try{n.store.releaseMemory?.(),n.graphStore.releaseMemory?.()}catch{}}),D.touch();let O=!1;for(let e of Object.values(C)){let t=e.handler;e.handler=async(...e)=>{if(O||(O=!0,D.markSessionActive()),D.touch(),u){let t=d(e[0]);t.length>0&&u.prioritize(...t)}return t(...e)}}Q_(C,n,{statePath:e.stateDir??``});for(let[,e]of Object.entries(C)){let t=e.config?.outputSchema;if(!t)continue;let n=e.handler;e.handler=async(...e)=>{let r=await n(...e);if(!r||typeof r!=`object`)return r;let i=r;return!(`content`in i)||i.isError||i.structuredContent!=null&&typeof i.structuredContent==`object`?r:(i.structuredContent=is(t),i.structuredContent??={},r)}}process.stdin.on(`end`,()=>($.info(`stdin closed — MCP client disconnected. Shutting down.`),process.exit(0))),process.stdin.on(`error`,()=>($.info(`stdin error — MCP client disconnected. Shutting down.`),process.exit(0))),c=n,v?.(n)})(),T=async()=>{let t;try{t=await b}catch{$.warn(`Skipping initial index — AI Kit initialization failed`);return}l?.setBusy(!0);try{let n=e.sources.map(e=>e.path).join(`, `);$.info(`Running initial index`,{sourcePaths:n});let r=await t.indexer.index(e,e=>{e.phase===`crawling`||e.phase===`done`||(e.phase===`chunking`&&e.currentFile&&$.debug(`Indexing file`,{current:e.filesProcessed+1,total:e.filesTotal,file:e.currentFile}),e.phase===`cleanup`&&$.debug(`Index cleanup`,{staleEntries:e.filesTotal-e.filesProcessed}))});s=!0,$.info(`Initial index complete`,{filesProcessed:r.filesProcessed,filesSkipped:r.filesSkipped,chunksCreated:r.chunksCreated,durationMs:r.durationMs});try{await t.store.createFtsIndex()}catch(e){$.warn(`FTS index creation failed`,L(e))}try{let e=await t.curated.reindexAll();$.info(`Curated re-index complete`,{indexed:e.indexed})}catch(e){$.error(`Curated re-index failed`,L(e))}}catch(e){$.error(`Initial index failed; will retry on aikit_reindex`,L(e))}finally{l?.setBusy(!1)}},E=new R_,D=()=>E.schedule({name:`initial-index`,fn:T}),O=process.ppid,k=setInterval(()=>{try{process.kill(O,0)}catch{$.info(`Parent process died; shutting down`,{parentPid:O}),clearInterval(k),u?.stop&&u.stop(),import(`../../tools/dist/index.js`).then(({processStopAll:e})=>e()).catch(()=>{}),b.then(async e=>{await Promise.all([e.embedder.shutdown?.().catch(()=>{})??Promise.resolve(),e.graphStore.close().catch(()=>{}),e.closeStateStore?.().catch(()=>{})??Promise.resolve(),e.store.close().catch(()=>{})])}).catch(()=>{}).finally(()=>process.exit(0))}},5e3);return k.unref(),{server:i,startInit:C,ready:w,runInitialIndex:D,get aikit(){return c},scheduler:E,setSmartScheduler(e){u=e}}}const rv=I(`server`);function iv(e,t){let n=ws(t,[...Xo,...Wo],Ma,Ko(t)),r=I_(t,n,Ma),i=new Hn({name:t.serverName??`aikit`,version:re()},{capabilities:{logging:{},completions:{},prompts:{}},instructions:r});return zr(i),A_(i,e,t,Lr(i),new N_(i),au(i),void 0,null,null,n),Xr(i,{curated:e.curated,store:e.store,graphStore:e.graphStore,stateStore:e.stateStore},t.indexMode),i}async function av(e){let t=await F_(e),n=iv(t,e);rv.debug(`MCP server configured`,{toolCount:Xo.length,resourceCount:2});let r=async()=>{try{let n=e.sources.map(e=>e.path).join(`, `);rv.info(`Running initial index`,{sourcePaths:n});let r=await t.indexer.index(e,e=>{e.phase===`crawling`||e.phase===`done`||(e.phase===`chunking`&&e.currentFile&&rv.debug(`Indexing file`,{current:e.filesProcessed+1,total:e.filesTotal,file:e.currentFile}),e.phase===`cleanup`&&rv.debug(`Index cleanup`,{staleEntries:e.filesTotal-e.filesProcessed}))});rv.info(`Initial index complete`,{filesProcessed:r.filesProcessed,filesSkipped:r.filesSkipped,chunksCreated:r.chunksCreated,durationMs:r.durationMs});try{await t.store.createFtsIndex()}catch(e){rv.warn(`FTS index creation failed`,L(e))}try{let e=await t.curated.reindexAll();rv.info(`Curated re-index complete`,{indexed:e.indexed})}catch(e){rv.error(`Curated re-index failed`,L(e))}}catch(e){rv.error(`Initial index failed; will retry on aikit_reindex`,L(e))}},i=async()=>{rv.info(`Shutting down`),await Promise.all([t.embedder.shutdown?.().catch(()=>{})??Promise.resolve(),t.graphStore.close().catch(()=>{}),t.closeStateStore?.().catch(()=>{})??Promise.resolve(),t.store.close().catch(()=>{})]),process.exit(0)};process.on(`SIGINT`,i),process.on(`SIGTERM`,i);let a=process.ppid,o=setInterval(()=>{try{process.kill(a,0)}catch{rv.info(`Parent process died; shutting down`,{parentPid:a}),clearInterval(o),i()}},5e3);return o.unref(),{server:n,runInitialIndex:r,shutdown:i}}export{Xo as ALL_TOOL_NAMES,nv as createLazyServer,iv as createMcpServer,av as createServer,F_ as initializeAikit,A_ as registerMcpTools};
3021
+ `),`utf8`),$.info(`Auto-heal: created ESM shim for @huggingface/transformers (.mjs wrapper → .cjs)`,{path:t}))}catch(e){$.warn(`Auto-heal: failed to create ESM shim`,{error:e instanceof Error?e.message:String(e),path:t})}}}if(n.includes(`embedding`)||n.includes(`onnx`)||n.includes(`protobuf`)||n.includes(`model`)){let t=e.embedding?.model;if(t){let e=P(Bn(),`.cache`,`huggingface`,`transformers-js`,t);try{await r(e,{recursive:!0,force:!0}),$.info(`Auto-heal: cleared embedding model cache`,{path:e})}catch{}}}if(n.includes(`lance`)||n.includes(`database`)||n.includes(`store`)){let t=P(e.store.path,`lance`);try{await r(t,{recursive:!0,force:!0}),$.info(`Auto-heal: cleared LanceDB store`,{path:t})}catch{}}if(n.includes(`sqlite`)||n.includes(`database disk image`)||n.includes(`graph`)){let t=P(e.store.path,`graph.db`);try{await r(t,{force:!0}),$.info(`Auto-heal: cleared graph database`,{path:t})}catch{}let n=P(e.store.path,`aikit.db`);try{await r(n,{force:!0}),await r(`${n}-wal`,{force:!0}).catch(()=>{}),await r(`${n}-shm`,{force:!0}).catch(()=>{}),$.info(`Auto-heal: cleared corrupted aikit database`,{path:n})}catch{}}if(Np(t)){let e=await Ip(t);e.repaired||$.warn(`Auto-heal: missing runtime dependency repair did not complete`,{packages:e.packages,reason:e.reason,error:e.error,hint:`Run: npm cache clean --force && npx -y @vpxa/aikit@latest serve`})}else n.includes(`cannot find module`)&&!n.includes(`.cache`)&&$.warn(`Auto-heal: missing module detected during initialization cleanup`,{hint:`Run: npm cache clean --force && npx -y @vpxa/aikit@latest serve`})}function nv(e,t){let n=Ts(e,Pa,W,Xo(e)),r=I_(e,n,W),i=new Hn({name:e.serverName??`aikit`,version:re()},{capabilities:{logging:{},completions:{},prompts:{}},instructions:r}),a=`initializing`,o=``,s=!1,c=null,l=null,u=null;function d(e){if(!e||typeof e!=`object`)return[];let t=e,n=[];for(let e of[`path`,`file`,`source_path`,`sourcePath`,`filePath`]){let r=t[e];typeof r==`string`&&r&&n.push(r)}for(let e of[`changed_files`,`paths`,`files`]){let r=t[e];if(Array.isArray(r))for(let e of r){if(typeof e==`string`){n.push(e);continue}e&&typeof e==`object`&&typeof e.path==`string`&&n.push(e.path)}}if(Array.isArray(t.sources))for(let e of t.sources)e&&typeof e==`object`&&typeof e.path==`string`&&n.push(e.path);return n}let f=()=>a===`failed`?[`❌ AI Kit initialization failed — this tool is unavailable.`,``,o?`Error: ${o}`:``,``,`**${Fa.size} tools are still available** and fully functional:`,`check, eval, test_run, git_context, health, measure, web_fetch, web_search,`,`flow, regex_test, encode,`,`stash, checkpoint, lane, process, time, env, and more.`,``,ev(o),``,`Try restarting the MCP server to retry initialization.`].filter(Boolean).join(`
3022
+ `):[`AI Kit is still initializing (loading embeddings model & store).`,``,`**${Fa.size} tools are already available** while initialization completes — including:`,`check, eval, test_run, git_context, health, measure, web_fetch, web_search,`,`flow, regex_test, encode,`,`stash, checkpoint, lane, process, time, env, and more.`,``,`This tool requires the AI Kit index. Please retry in a few seconds,`,`or use one of the available tools above in the meantime.`].join(`
3023
+ `);zr(i);let p=new bo;p.use($o(),{order:1,name:`structured-content-guard`}),us(i,p,e.toolPrefix??``);let m=i.sendToolListChanged.bind(i);i.sendToolListChanged=()=>{};let h=[];for(let e of Pa){if(!n.has(e))continue;let t=G(e),r=i.registerTool(e,{title:t.title,description:`${t.title} — initializing, available shortly`,inputSchema:{},annotations:t.annotations},async()=>({content:[{type:`text`,text:f()}]}));Fa.has(e)?r.remove():h.push(r)}j_(i,e,n),i.sendToolListChanged=m;let g=i.registerResource(`aikit-status`,`aikit://status`,{description:`AI Kit status (initializing...)`,mimeType:`text/plain`},async()=>({contents:[{uri:`aikit://status`,text:`AI Kit is initializing...`,mimeType:`text/plain`}]})),_=i.registerPrompt(`_init`,{description:`Initializing AI Kit…`,argsSchema:{_dummy:qn(z.string(),()=>[])}},async()=>({messages:[]})),v,y,b=new Promise((e,t)=>{v=e,y=t}),x,S=new Promise(e=>{x=e}),C=()=>x?.(),w=(async()=>{await S;try{let{createRequire:e}=await import(`node:module`),{readFileSync:t,existsSync:n}=await import(`node:fs`),{fileURLToPath:r}=await import(`node:url`),{resolve:i,dirname:a}=await import(`node:path`),o=e(import.meta.url),s=a(r(import.meta.url)),c=i(s,`..`,`package.json`),l=i(s,`..`,`..`),u=JSON.parse(t(c,`utf8`)),d=Object.keys(u.dependencies??{}),f=[`@mixmark-io/domino`],p=[...d,...f.filter(e=>!d.includes(e))],m=p.filter(e=>!e.startsWith(`@aikit/`)),h=p.filter(e=>e.startsWith(`@aikit/`)),g=[];for(let e of m)try{o.resolve(e)}catch{try{o.resolve(`${e}/package.json`)}catch{g.push(e)}}g.length>0&&$.warn(`Dependencies not resolvable — server may operate in degraded mode`,{missing:g,hint:`Run: npm cache clean --force && npx -y @vpxa/aikit@latest serve`});let _=[];if(h.length>0){for(let e of h)n(i(l,e.slice(7),`dist`))||_.push(e);_.length>0&&$.warn(`Workspace sibling packages missing dist — server may have degraded features`,{missing:_,hint:`Reinstall: npm cache clean --force && npx -y @vpxa/aikit@latest serve`})}}catch{}let n;try{n=await F_(e)}catch(t){let r=t instanceof Error?t.message:String(t);if($_(r)){$.warn(`AI Kit initialization failed with recoverable error — attempting auto-heal retry`,{error:r}),await tv(e,r);try{n=await F_(e),$.info(`AI Kit auto-heal successful — initialization recovered after retry`)}catch(e){a=`failed`,o=e instanceof Error?e.message:String(e),$.error(`AI Kit initialization failed after auto-heal attempt — server continuing with zero-dep tools only`,{error:o,originalError:r}),y?.(e instanceof Error?e:Error(o));return}}else{a=`failed`,o=r,$.error(`AI Kit initialization failed — server continuing with zero-dep tools only`,{error:o}),y?.(t instanceof Error?t:Error(o));return}}let r=i.sendToolListChanged.bind(i);i.sendToolListChanged=()=>{};let f=i.sendPromptListChanged.bind(i);i.sendPromptListChanged=()=>{};let p=i.sendResourceListChanged.bind(i);i.sendResourceListChanged=()=>{};for(let e of h)e.remove();g.remove(),_.remove();let m=i._registeredTools??{};for(let e of Fa)m[e]?.remove();let b=new N_(i),x=au(i);A_({server:i,aikit:n,config:e,elicitor:Lr(i),resourceNotifier:b,samplingClient:x,indexMode:t,getSmartState:t===`smart`?(()=>{let e=u;return e?.getState?e.getState():null}):null,getSmartScheduler:t===`smart`?()=>{let e=u;return e?{prioritize:e.prioritize.bind(e)}:null}:null}),Xr(i,{curated:n.curated,store:n.store,graphStore:n.graphStore,stateStore:n.stateStore},t),i.sendToolListChanged=r,i.sendPromptListChanged=f,i.sendResourceListChanged=p,Promise.resolve(i.sendToolListChanged()).catch(()=>{}),Promise.resolve(i.sendPromptListChanged()).catch(()=>{}),Promise.resolve(i.sendResourceListChanged()).catch(()=>{});let C=i._registeredTools??{};for(let[e,t]of Object.entries(C)){if(Ia.has(e))continue;let r=t.handler;t.handler=async(...i)=>{if(!n.indexer.isIndexing)return r(...i);let a=s?`re-indexing`:`running initial index`,o=new Promise(n=>setTimeout(()=>n({content:[{type:`text`,text:`⏳ AI Kit is ${a}. The tool "${e}" timed out waiting for index data (${Zo/1e3}s).\n\nThe existing index may be temporarily locked. Please retry shortly — indexing will complete automatically.`}],...t.config?.outputSchema?{structuredContent:as(t.config.outputSchema)}:{}}),Zo));return Promise.race([r(...i),o])}}for(let[e,t]of Object.entries(C)){let n=t.handler,r=K_(e);t.handler=async(...i)=>{try{return await q_(()=>n(...i),r,e)}catch(n){if(n instanceof G_)return{content:[{type:`text`,text:`⏳ Tool "${e}" timed out after ${r/1e3}s. This may indicate a long-running operation. Please retry or break the task into smaller steps.`}],...t.config?.outputSchema?{structuredContent:as(t.config.outputSchema)}:{}};throw n}}}let w=Object.keys(C).length;w<Pa.length&&$.warn(`ALL_TOOL_NAMES count mismatch`,{expectedToolCount:Pa.length,registeredToolCount:w}),$.debug(`MCP server configured`,{toolCount:Pa.length,resourceCount:4});let T=new H_;T.onPressure((e,t)=>{e===`warning`&&Ur(),e===`critical`&&($.warn(`Memory pressure critical — consider restarting`,{rssMB:Math.round(t/1024/1024)}),Ur())}),T.registerMemoryPressureCallback(()=>n.embedder.shutdown?.()),T.start();let D=new B_;l=D,D.onIdle(async()=>{if(E.isRunning||n.indexer.isIndexing){$.info(`Idle cleanup deferred — background tasks still running`),D.touch();return}$.info(`Idle cleanup: releasing cached memory (connections stay open)`);try{n.store.releaseMemory?.(),n.graphStore.releaseMemory?.()}catch{}}),D.touch();let O=!1;for(let e of Object.values(C)){let t=e.handler;e.handler=async(...e)=>{if(O||(O=!0,D.markSessionActive()),D.touch(),u){let t=d(e[0]);t.length>0&&u.prioritize(...t)}return t(...e)}}Q_(C,n,{statePath:e.stateDir??``});for(let[,e]of Object.entries(C)){let t=e.config?.outputSchema;if(!t)continue;let n=e.handler;e.handler=async(...e)=>{let r=await n(...e);if(!r||typeof r!=`object`)return r;let i=r;return!(`content`in i)||i.isError||i.structuredContent!=null&&typeof i.structuredContent==`object`?r:(i.structuredContent=as(t),i.structuredContent??={},r)}}process.stdin.on(`end`,()=>($.info(`stdin closed — MCP client disconnected. Shutting down.`),process.exit(0))),process.stdin.on(`error`,()=>($.info(`stdin error — MCP client disconnected. Shutting down.`),process.exit(0))),c=n,v?.(n)})(),T=async()=>{let t;try{t=await b}catch{$.warn(`Skipping initial index — AI Kit initialization failed`);return}l?.setBusy(!0);try{let n=e.sources.map(e=>e.path).join(`, `);$.info(`Running initial index`,{sourcePaths:n});let r=await t.indexer.index(e,e=>{e.phase===`crawling`||e.phase===`done`||(e.phase===`chunking`&&e.currentFile&&$.debug(`Indexing file`,{current:e.filesProcessed+1,total:e.filesTotal,file:e.currentFile}),e.phase===`cleanup`&&$.debug(`Index cleanup`,{staleEntries:e.filesTotal-e.filesProcessed}))});s=!0,$.info(`Initial index complete`,{filesProcessed:r.filesProcessed,filesSkipped:r.filesSkipped,chunksCreated:r.chunksCreated,durationMs:r.durationMs});try{await t.store.createFtsIndex()}catch(e){$.warn(`FTS index creation failed`,L(e))}try{let e=await t.curated.reindexAll();$.info(`Curated re-index complete`,{indexed:e.indexed})}catch(e){$.error(`Curated re-index failed`,L(e))}}catch(e){$.error(`Initial index failed; will retry on aikit_reindex`,L(e))}finally{l?.setBusy(!1)}},E=new R_,D=()=>E.schedule({name:`initial-index`,fn:T}),O=process.ppid,k=setInterval(()=>{try{process.kill(O,0)}catch{$.info(`Parent process died; shutting down`,{parentPid:O}),clearInterval(k),u?.stop&&u.stop(),import(`../../tools/dist/index.js`).then(({processStopAll:e})=>e()).catch(()=>{}),b.then(async e=>{await Promise.all([e.embedder.shutdown?.().catch(()=>{})??Promise.resolve(),e.graphStore.close().catch(()=>{}),e.closeStateStore?.().catch(()=>{})??Promise.resolve(),e.store.close().catch(()=>{})])}).catch(()=>{}).finally(()=>process.exit(0))}},5e3);return k.unref(),{server:i,startInit:C,ready:w,runInitialIndex:D,get aikit(){return c},scheduler:E,setSmartScheduler(e){u=e}}}const rv=I(`server`);function iv(e,t){let n=Ts(t,[...Pa,...Jo],W,Xo(t)),r=I_(t,n,W),i=new Hn({name:t.serverName??`aikit`,version:re()},{capabilities:{logging:{},completions:{},prompts:{}},instructions:r});return zr(i),A_({server:i,aikit:e,config:t,elicitor:Lr(i),resourceNotifier:new N_(i),samplingClient:au(i),precomputedActiveTools:n}),Xr(i,{curated:e.curated,store:e.store,graphStore:e.graphStore,stateStore:e.stateStore},t.indexMode),i}async function av(e){let t=await F_(e),n=iv(t,e);rv.debug(`MCP server configured`,{toolCount:Pa.length,resourceCount:2});let r=async()=>{try{let n=e.sources.map(e=>e.path).join(`, `);rv.info(`Running initial index`,{sourcePaths:n});let r=await t.indexer.index(e,e=>{e.phase===`crawling`||e.phase===`done`||(e.phase===`chunking`&&e.currentFile&&rv.debug(`Indexing file`,{current:e.filesProcessed+1,total:e.filesTotal,file:e.currentFile}),e.phase===`cleanup`&&rv.debug(`Index cleanup`,{staleEntries:e.filesTotal-e.filesProcessed}))});rv.info(`Initial index complete`,{filesProcessed:r.filesProcessed,filesSkipped:r.filesSkipped,chunksCreated:r.chunksCreated,durationMs:r.durationMs});try{await t.store.createFtsIndex()}catch(e){rv.warn(`FTS index creation failed`,L(e))}try{let e=await t.curated.reindexAll();rv.info(`Curated re-index complete`,{indexed:e.indexed})}catch(e){rv.error(`Curated re-index failed`,L(e))}}catch(e){rv.error(`Initial index failed; will retry on aikit_reindex`,L(e))}},i=async()=>{rv.info(`Shutting down`),await Promise.all([t.embedder.shutdown?.().catch(()=>{})??Promise.resolve(),t.graphStore.close().catch(()=>{}),t.closeStateStore?.().catch(()=>{})??Promise.resolve(),t.store.close().catch(()=>{})]),process.exit(0)};process.on(`SIGINT`,i),process.on(`SIGTERM`,i);let a=process.ppid,o=setInterval(()=>{try{process.kill(a,0)}catch{rv.info(`Parent process died; shutting down`,{parentPid:a}),clearInterval(o),i()}},5e3);return o.unref(),{server:n,runInitialIndex:r,shutdown:i}}export{Pa as ALL_TOOL_NAMES,nv as createLazyServer,iv as createMcpServer,av as createServer,F_ as initializeAikit,A_ as registerMcpTools};