@a-company/paradigm 5.37.8 → 5.38.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/dist/{accept-orchestration-SBZVK3H4.js → accept-orchestration-OATWIRHP.js} +1 -1
  2. package/dist/{aggregate-W66DM3GA.js → aggregate-A5S5MTCC.js} +1 -1
  3. package/dist/{beacon-5QVYV5DF.js → beacon-QVUD3MGP.js} +1 -1
  4. package/dist/{chunk-SI6SV76D.js → chunk-3DZK54RU.js} +72 -19
  5. package/dist/{chunk-KFNHCQ4R.js → chunk-4L7665QV.js} +1 -1
  6. package/dist/chunk-4VKSEOXZ.js +6 -0
  7. package/dist/{chunk-CHVQNRRT.js → chunk-5QOCKWK5.js} +1 -1
  8. package/dist/chunk-HOBHJPTL.js +24 -0
  9. package/dist/{chunk-T6IDXUUA.js → chunk-LWAIVOSF.js} +1 -1
  10. package/dist/chunk-NQ47TA6C.js +111 -0
  11. package/dist/{chunk-G7XFK2GI.js → chunk-RBLK34IA.js} +1 -1
  12. package/dist/chunk-RN4VE6P3.js +521 -0
  13. package/dist/{chunk-SUU6M4JH.js → chunk-TOYQ2QCB.js} +1 -1
  14. package/dist/{chunk-LBQBWIEX.js → chunk-Y4P4SGZV.js} +1 -1
  15. package/dist/chunk-ZJQY5PPP.js +7 -0
  16. package/dist/{commands-LMUD5L6R.js → commands-ANRJNG2W.js} +1 -1
  17. package/dist/compliance-D7GD6ZYC.js +6 -0
  18. package/dist/{constellation-CG7C4WFE.js → constellation-NWLXYATA.js} +1 -1
  19. package/dist/{cost-IDNVMAEV.js → cost-24UZSS2P.js} +1 -1
  20. package/dist/{diff-JVEYCXUC.js → diff-YGHBIJY5.js} +1 -1
  21. package/dist/dist-JZZJLVMR.js +2 -0
  22. package/dist/{dist-3ZCH25SG.js → dist-OG6MM4VY.js} +1 -1
  23. package/dist/dist-SE67SOXB.js +2 -0
  24. package/dist/doctor-WMVULMQD.js +2 -0
  25. package/dist/{flow-POQP27WA.js → flow-FVZR3YJ4.js} +1 -1
  26. package/dist/{hooks-IG2GOAHP.js → hooks-TFMMMB2H.js} +1 -1
  27. package/dist/index.js +5 -5
  28. package/dist/init-XYB62Q3X.js +2 -0
  29. package/dist/{integrity-UYDOOJDP.js → integrity-ROO3G43N.js} +1 -1
  30. package/dist/mcp.js +18 -10
  31. package/dist/{migrate-IBDE7VK4.js → migrate-Z5UQN57G.js} +1 -1
  32. package/dist/{orchestrate-RCAMBOIB.js → orchestrate-M5PBZBJQ.js} +1 -1
  33. package/dist/portal-check-ZMLVBIGW.js +8 -0
  34. package/dist/portal-compliance-6YR27IQU.js +2 -0
  35. package/dist/{probe-B22G2JKF.js → probe-3FTG6LYO.js} +1 -1
  36. package/dist/{reindex-FO5VMZVQ.js → reindex-I6LPAKCC.js} +1 -1
  37. package/dist/{review-6UAH6V3R.js → review-VMSX2PKI.js} +1 -1
  38. package/dist/{ripple-ZGDITCGB.js → ripple-FNZI47SH.js} +1 -1
  39. package/dist/sentinel.js +1 -1
  40. package/dist/{setup-3F5IK7MO.js → setup-FEWSYS3Y.js} +2 -2
  41. package/dist/{shift-CZMQWZWP.js → shift-PC6C7NUX.js} +4 -4
  42. package/dist/{snapshot-L2G56RPL.js → snapshot-3IYB67D4.js} +1 -1
  43. package/dist/{status-77M3SDIF.js → status-DB3KNLW3.js} +1 -1
  44. package/dist/{summary-LXLHFRN7.js → summary-PYTEIJ4U.js} +1 -1
  45. package/dist/{team-NSP6PMPS.js → team-PDK64JXI.js} +1 -1
  46. package/dist/{test-BQJMS4Y2.js → test-WLEPZQFC.js} +1 -1
  47. package/dist/{tools-BZUAEUSQ.js → tools-5ITPEPSV.js} +1 -1
  48. package/dist/{validate-VZXTJHGO.js → validate-BB6LRWIY.js} +1 -1
  49. package/dist/workspace-VMSPYIBV.js +2 -0
  50. package/package.json +2 -1
  51. package/templates/paradigm/specs/symbols.md +4 -2
  52. package/dist/chunk-3TR6LLXP.js +0 -111
  53. package/dist/chunk-3VF3CMCF.js +0 -521
  54. package/dist/chunk-J6KWGCHN.js +0 -24
  55. package/dist/chunk-QT2LKB3P.js +0 -7
  56. package/dist/chunk-SHD27BQX.js +0 -6
  57. package/dist/compliance-WJINB5DM.js +0 -6
  58. package/dist/dist-R3RWD35F.js +0 -2
  59. package/dist/dist-VXCZWVVJ.js +0 -2
  60. package/dist/doctor-QJ47XAUP.js +0 -2
  61. package/dist/init-HIBRSVUB.js +0 -2
  62. package/dist/portal-check-Z3OCQEQR.js +0 -8
  63. package/dist/portal-compliance-4MG5F2GI.js +0 -2
  64. package/dist/workspace-MKSQN7B2.js +0 -2
@@ -0,0 +1,111 @@
1
+ #!/usr/bin/env node
2
+ import {a as a$1,b as b$4,c as c$2}from'./chunk-M4UMM6DC.js';import {j,b as b$3,a as a$3}from'./chunk-ODVKPZZ4.js';import {j as j$1,a,c as c$1,b as b$2,k as k$1}from'./chunk-MQIG6SMF.js';import {b as b$1,a as a$2}from'./chunk-EK4ZRIFJ.js';import {c,b,d}from'./chunk-5TAVYPOV.js';import*as S from'fs';import*as k from'path';import*as Q from'crypto';import {execSync}from'child_process';import*as D from'js-yaml';import {z}from'zod';import {glob}from'glob';import*as be from'os';import Ts from'sql.js';var Ht={};c(Ht,{contentSearch:()=>Es,detectFileRename:()=>Ut,generateFingerprint:()=>Nt,levenshteinDistance:()=>Mt,levenshteinSimilarity:()=>Me,searchSiblingFiles:()=>zt,slidingWindowSearch:()=>xe});function Nt(t){let e=t.split(`
3
+ `).filter(s=>s.trim()!=="");return {firstLine:Se(e[0]||""),lastLine:Se(e[e.length-1]||""),lineCount:e.length,structuralHash:Dt(e)}}function Dt(t){let e=t.map(s=>s.trim()).filter(s=>Ot.test(s)).map(s=>{let n=s.match(Ot);return n?n[1].trim():""}).join("|");return Q.createHash("sha256").update(e).digest("hex").slice(0,16)}function Se(t){return t.trim().replace(/\s+/g," ").toLowerCase()}function Mt(t,e){if(t===e)return 0;if(t.length===0)return e.length;if(e.length===0)return t.length;t.length>e.length&&([t,e]=[e,t]);let s=t.length,n=e.length;if(s>5e3||n>5e3)return Math.abs(s-n);let o=new Array(s+1),r=new Array(s+1);for(let i=0;i<=s;i++)o[i]=i;for(let i=1;i<=n;i++){r[0]=i;for(let a=1;a<=s;a++){let c=t[a-1]===e[i-1]?0:1;r[a]=Math.min(o[a]+1,r[a-1]+1,o[a-1]+c);}[o,r]=[r,o];}return o[s]}function Me(t,e){if(t.length===0&&e.length===0)return 1;let s=Math.max(t.length,e.length);return 1-Mt(t,e)/s}function xe(t,e,s,n=3){let{lineCount:o}=e,r=Math.max(1,Math.floor(o*.8)),i=Math.ceil(o*1.2),a=[],c=De(s);for(let d of [o,r,i])if(!(d>t.length))for(let u=0;u<=t.length-d;u++){let p=t.slice(u,u+d),m=vs(p,e,c);if(m>=.5){let g=p.join(`
4
+ `);a.push({windowStart:u+1,windowEnd:u+d,similarity:Me(De(g),c),score:m});}}let l=new Map;for(let d of a){let u=l.get(d.windowStart);(!u||d.score>u.score)&&l.set(d.windowStart,d);}return Array.from(l.values()).sort((d,u)=>u.score-d.score).slice(0,n)}function vs(t,e,s){let n=t.filter(p=>p.trim()!=="");if(n.length===0)return 0;let o=0,r=Se(n[0]),i=Se(n[n.length-1]),a=0;r===e.firstLine&&(a+=.5),i===e.lastLine&&(a+=.5),o+=a*ws,Dt(n)===e.structuralHash&&(o+=bs);let l=n.join(`
5
+ `),d=Me(De(l),s);d>=.8&&(o+=(d-.8)/.2*Ss);let u=n.length/e.lineCount;if(u>=.8&&u<=1.2){let p=1-Math.abs(1-u)/.2;o+=p*xs;}return o}function De(t){return t.split(`
6
+ `).map(e=>e.trim()).filter(e=>e!=="").join(`
7
+ `)}function Ut(t,e){try{let s=execSync(`git log --follow --diff-filter=R --name-status --format="" -- "${e}"`,{cwd:t,encoding:"utf8",timeout:5e3}).trim();if(!s)return null;let n=s.split(`
8
+ `);for(let o of n){let r=o.split(" ");if(r.length>=3&&r[0].startsWith("R"))return r[2]}return null}catch{return null}}function zt(t,e,s,n,o=10){let r=k.isAbsolute(e)?e:k.join(t,e);if(!S.existsSync(r))return [];let i=[];try{let a=S.readdirSync(r).filter(c=>!c.startsWith(".")&&S.statSync(k.join(r,c)).isFile()).slice(0,o);for(let c of a)try{let d=S.readFileSync(k.join(r,c),"utf8").split(`
9
+ `),u=xe(d,s,n,1);if(u.length>0&&u[0].score>=.7){let p=k.relative(t,k.join(r,c));i.push({file:p,score:u[0].score,start:u[0].windowStart,end:u[0].windowEnd});}}catch{}}catch{return []}return i.sort((a,c)=>c.score-a.score)}function Es(t,e,s,n=true){let o=Nt(s),r=k.isAbsolute(e)?e:k.join(t,e);if(S.existsSync(r)){let d=S.readFileSync(r,"utf8").split(`
10
+ `),u=xe(d,o,s);if(u.length>0){let p=u[0];return {found:p.score>=.7,score:p.score,suggestedStart:p.windowStart,suggestedEnd:p.windowEnd,similarity:p.similarity}}}let i=Ut(t,e);if(i){let l=k.join(t,i);if(S.existsSync(l)){let u=S.readFileSync(l,"utf8").split(`
11
+ `),p=xe(u,o,s);if(p.length>0&&p[0].score>=.7)return {found:true,score:p[0].score,suggestedStart:p[0].windowStart,suggestedEnd:p[0].windowEnd,suggestedPath:i,similarity:p[0].similarity}}}let a=k.dirname(e),c=zt(t,a,o,s);if(c.length>0&&c[0].score>=.7){let l=c[0];return {found:true,score:l.score,suggestedStart:l.start,suggestedEnd:l.end,suggestedPath:l.file!==e?l.file:void 0,similarity:l.score}}return {found:false,score:0}}var Ot,ws,bs,Ss,xs,Wt=b(()=>{Ot=/^\s*(function |class |if |else |for |while |switch |case |return |export |import |const |let |var |async |await |try |catch |throw |struct |enum |protocol |guard |def |fn )/;ws=.4,bs=.3,Ss=.2,xs=.1;});var Ce=z.object({description:z.string(),type:z.string().optional(),parent:z.string().optional(),anchors:z.array(z.string()).optional(),tags:z.array(z.string()).optional(),endpoints:z.array(z.string()).optional(),tests:z.array(z.string()).optional(),rules:z.record(z.unknown()).optional(),aspects:z.array(z.string()).optional(),flows:z.array(z.string()).optional(),gates:z.array(z.string()).optional(),signals:z.array(z.string()).optional(),states:z.array(z.string()).optional(),components:z.array(z.string()).optional(),location:z.string().optional(),locations:z.array(z.string()).optional(),uses:z.array(z.string()).optional(),"used-by":z.array(z.string()).optional(),"used-for":z.array(z.string()).optional(),exports:z.array(z.string()).optional(),status:z.string().optional(),properties:z.record(z.unknown()).optional(),handles:z.array(z.string()).optional()}).passthrough(),it=Ce.extend({id:z.string()}),xn=z.object({description:z.string().optional(),category:z.string().optional(),severity:z.enum(["info","warn","error"]).optional(),emitters:z.array(z.string()).optional(),related:z.array(z.string()).optional(),data:z.record(z.unknown()).optional()}),vn=z.union([xn,z.string().transform(t=>({description:t}))]),En=z.object({from:z.string(),to:z.string(),type:z.string(),description:z.string().optional()}),Tn=z.union([En,z.string()]),_n=z.object({component:z.string(),action:z.string(),description:z.string().optional()}),dt=z.union([_n,z.string()]),$n=z.object({name:z.string(),description:z.string().optional(),steps:z.array(dt)}),Rn=z.object({description:z.string().optional(),gates:z.array(z.string()).optional(),signals:z.array(z.string()).optional(),components:z.array(z.string()).optional(),steps:z.array(dt).optional()}),kn=z.object({description:z.string().optional(),requires:z.array(z.string()).optional(),keys:z.array(z.string()).optional(),signals:z.array(z.string()).optional()}),In=z.object({description:z.string().optional(),default:z.unknown().optional(),type:z.string().optional()}),Cn=z.object({description:z.string().optional(),tags:z.array(z.string()).optional(),anchors:z.array(z.string()).optional(),"applies-to":z.array(z.string()).optional(),enforcement:z.string().optional()}),Pn=z.object({target:z.string(),type:z.string(),path:z.string()}),An=z.object({version:z.string().optional(),description:z.string().optional(),apiSpec:z.string().optional(),context:z.array(z.string()).optional(),rules:z.record(z.unknown()).optional(),features:z.union([z.array(it),z.record(Ce)]).optional(),components:z.union([z.array(it),z.record(Ce)]).optional(),gates:z.record(kn).optional(),states:z.record(In).optional(),signals:z.record(vn).optional(),aspects:z.record(Cn).optional(),relationships:z.array(Tn).optional(),flows:z.union([z.array($n),z.record(Rn)]).optional(),references:z.array(Pn).optional()});function Pe(t){let e=jn(t);return {data:e.data,errors:e.errors}}function jn(t){let e=[],s=[],n;try{n=S.readFileSync(t,"utf8");}catch(a){let c=`Cannot read file: ${a.message}`;return e.push(c),s.push({message:c,type:"file"}),{data:null,errors:e,detailedErrors:s,rawContent:void 0,isYamlValid:false}}let o=n.replace(/^([#~!$^][\w-]+):/gm,'"$1":').replace(/^(\s*-\s+)([!#][\w-]+)$/gm,'$1"$2"'),r=null;try{r=D.load(o);}catch(a){let c=a,l=c.mark?.line?c.mark.line+1:void 0,d=`YAML syntax error: ${c.reason||a.message}`;return e.push(`${d}${l?` (line ${l})`:""}`),s.push({message:d,line:l,type:"yaml"}),{data:null,errors:e,detailedErrors:s,rawContent:n,isYamlValid:false}}if(r==null)return {data:{},errors:[],detailedErrors:[],rawContent:n,isYamlValid:true};if(typeof r=="object"&&r!==null){let a=r,c={"#":"components",$:"flows","^":"gates","!":"signals","~":"aspects"};for(let l of Object.keys(a)){let d=l[0],u=c[d];if(!u||l.length<2)continue;let p=l.slice(1),m=a[l];if(typeof m!="object"||m===null)continue;let g=a[u]||{};u in a||(a[u]=g),p in g||(g[p]=m),delete a[l];}}let i=An.safeParse(r);if(!i.success){for(let a of i.error.issues){let c=a.path.join("."),l=a.message;e.push(`Schema error at ${c||"/"}: ${l}`),s.push({message:l,path:c||"/",type:"schema"});}return {data:r,errors:e,detailedErrors:s,rawContent:n,isYamlValid:true}}return {data:i.data,errors:[],detailedErrors:[],rawContent:n,isYamlValid:true}}function _o(t){return D.dump(t,{indent:2,lineWidth:-1,noRefs:true,sortKeys:false})}function ge(t){return t?Array.isArray(t)?t.map(e=>[e.id,e]):Object.entries(t):[]}async function On(t){let e=k.resolve(t);return (await glob("**/.purpose",{cwd:e,absolute:true,ignore:["**/node_modules/**","**/dist/**","**/.git/**"]})).sort((n,o)=>{let r=n.split(k.sep).length,i=o.split(k.sep).length;return r-i})}async function ut(t){let e=await On(t),s=[];for(let n of e){let{data:o,errors:r}=Pe(n);o&&(s.push({filePath:n,data:o}),r.length>0&&console.warn(`Warnings parsing ${n}:`,r));}return s}function pt(t){let e=new Map;for(let{filePath:s,data:n}of t){let o=ge(n.features);for(let[r,i]of o)e.set(r,{item:i,filePath:s});}return e}function ft(t){let e=new Map;for(let{filePath:s,data:n}of t){let o=ge(n.components);for(let[r,i]of o)e.set(r,{item:i,filePath:s});}return e}function gt(t){let e=new Map;for(let{filePath:s,data:n}of t)if(n.gates)for(let[o,r]of Object.entries(n.gates))e.set(o,{item:r,filePath:s});return e}function mt(t){let e=new Map;for(let{filePath:s,data:n}of t)if(n.states)for(let[o,r]of Object.entries(n.states))e.set(o,{item:r,filePath:s});return e}function ht(t){let e=new Map;for(let{filePath:s,data:n}of t)if(n.flows)if(Array.isArray(n.flows))for(let o of n.flows)e.set(o.name,{item:{id:o.name,description:o.description,steps:o.steps},filePath:s});else for(let[o,r]of Object.entries(n.flows))e.set(o,{item:{id:o,description:r.description,gates:r.gates,signals:r.signals,components:r.components,steps:r.steps},filePath:s});return e}function yt(t){let e=new Map;for(let{filePath:s,data:n}of t)if(n.signals)for(let[o,r]of Object.entries(n.signals))e.set(o,{item:r,filePath:s});return e}function wt(t){let e=new Map;for(let{filePath:s,data:n}of t)if(n.aspects)for(let[o,r]of Object.entries(n.aspects))e.set(o,{item:r,filePath:s});return e}function bt(t){let e=[],s=new Set;for(let{filePath:n,data:o}of t){let r=ge(o.features);for(let[a,c]of r)at(`#${a}`,c,n,e,s);let i=ge(o.components);for(let[a,c]of i)at(`#${a}`,c,n,e,s);}return e}function at(t,e,s,n,o){if(e.flows)for(let r of e.flows){let i=r.startsWith("$")?r:`$${r}`;o.has(i)||(o.add(i),n.push({symbol:i,type:"flow",sourceSymbol:t,filePath:s}));}if(e.gates)for(let r of e.gates){let i=r.startsWith("^")?r:`^${r}`;o.has(i)||(o.add(i),n.push({symbol:i,type:"gate",sourceSymbol:t,filePath:s}));}if(e.signals)for(let r of e.signals){let i=r.startsWith("!")?r:`!${r}`;o.has(i)||(o.add(i),n.push({symbol:i,type:"signal",sourceSymbol:t,filePath:s}));}if(e.states)for(let r of e.states){let i=r.startsWith("#")?r:r.startsWith("%")?`#${r.slice(1)}`:`#${r}`;o.has(i)||(o.add(i),n.push({symbol:i,type:"component",sourceSymbol:t,filePath:s}));}if(e.components)for(let r of e.components){let i=r.startsWith("#")?r:`#${r}`;o.has(i)||(o.add(i),n.push({symbol:i,type:"component",sourceSymbol:t,filePath:s}));}if(e.aspects)for(let r of e.aspects){let i=r.startsWith("~")?r:`~${r}`;o.has(i)||(o.add(i),n.push({symbol:i,type:"aspect",sourceSymbol:t,filePath:s}));}if(e.description){let r=Nn(e.description);for(let{symbol:i,type:a}of r)o.has(i)||(o.add(i),n.push({symbol:i,type:a,sourceSymbol:t,filePath:s}));}}var Fn=new Set(["$lib","$env","$app","$service-worker","$virtual","$schema","$ref","$id","$type"]);function Nn(t){let e=[],s=/([$^!#~%])([a-zA-Z][a-zA-Z0-9._-]*)/g,n;for(;(n=s.exec(t))!==null;){let o=n[1],r=n[2],i,a;switch(o){case "#":a="component",i=`#${r}`;break;case "$":a="flow",i=`$${r}`;break;case "^":a="gate",i=`^${r}`;break;case "!":a="signal",i=`!${r}`;break;case "~":a="aspect",i=`~${r}`;break;case "%":a="component",i=`#${r}`;break;default:continue}Fn.has(i)||e.push({symbol:i,type:a});}return e}function ie(t){return t?Array.isArray(t)?t.map(e=>[e.id,e]):Object.entries(t):[]}function Ie(t){return t?Array.isArray(t)?t.map(e=>e.id):Object.keys(t):[]}function Ro(t,e){let s=[],n=e?`${e}: `:"",o=ie(t.features);for(let[i,a]of o)ct(i,a,"feature",n,s);let r=ie(t.components);for(let[i,a]of r)ct(i,a,"component",n,s);if(t.relationships){let i=new Set([...Ie(t.features),...Ie(t.components)]);for(let a of t.relationships){if(typeof a=="string"||!a||!a.from||!a.to)continue;let c=a.from.replace(/^[@#$%~^!?]/,"");!i.has(c)&&!a.from.includes(".")&&s.push({type:"warning",message:`${n}Relationship references unknown source: "${a.from}"`,path:"relationships"});let l=a.to.replace(/^[@#$%~^!?]/,"");!i.has(l)&&!a.to.includes(".")&&s.push({type:"warning",message:`${n}Relationship references unknown target: "${a.to}"`,path:"relationships"});}}if(t.flows){let i=new Set(Ie(t.components));if(Array.isArray(t.flows)){for(let a of t.flows)if(!(!a||typeof a!="object")&&(a.name||s.push({type:"error",message:`${n}Flow missing required "name" field`,path:"flows"}),a.steps&&Array.isArray(a.steps)))for(let c of a.steps){if(typeof c=="string"||!c||!c.component)continue;let l=c.component.replace(/^#/,"");i.has(l)||s.push({type:"warning",message:`${n}Flow "${a.name}" references unknown component: "${c.component}"`,path:`flows.${a.name}`});}}else for(let[a,c]of Object.entries(t.flows))if(!(!c||typeof c!="object")&&c.steps&&Array.isArray(c.steps))for(let l of c.steps){if(typeof l=="string"||!l||!l.component)continue;let d=l.component.replace(/^#/,"");i.has(d)||s.push({type:"warning",message:`${n}Flow "${a}" references unknown component: "${l.component}"`,path:`flows.${a}`});}}return {valid:s.filter(i=>i.type==="error").length===0,issues:s}}function ct(t,e,s,n,o){let r=`${s}s.${t}`;if(/^[a-zA-Z][a-zA-Z0-9-]*$/.test(t)||o.push({type:"warning",message:`${n}${s} ID "${t}" should use alphanumeric characters and hyphens`,path:r}),(!e.description||e.description.trim()==="")&&o.push({type:"warning",message:`${n}${s} "${t}" has no description`,path:r}),e.endpoints)for(let i of e.endpoints)/^(GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS)\s+\//.test(i)||o.push({type:"warning",message:`${n}Endpoint "${i}" in ${s} "${t}" may not be in standard format (e.g., "GET /api/users")`,path:`${r}.endpoints`});}function St(t){let e=[],s=new Set;for(let{data:n}of t){let o=ie(n.components);for(let[i]of o)s.add(`#${i}`),s.add(i);let r=ie(n.features);for(let[i]of r)s.add(`#${i}`),s.add(i);if(n.gates)for(let i of Object.keys(n.gates))s.add(`^${i}`),s.add(i);if(n.signals)for(let i of Object.keys(n.signals))s.add(`!${i}`),s.add(i);if(n.flows)if(Array.isArray(n.flows))for(let i of n.flows)i?.name&&(s.add(`$${i.name}`),s.add(i.name));else for(let i of Object.keys(n.flows))s.add(`$${i}`),s.add(i);if(n.aspects)for(let i of Object.keys(n.aspects))s.add(`~${i}`),s.add(i);if(n.states)for(let i of Object.keys(n.states))s.add(`#${i}`),s.add(i);}for(let{filePath:n,data:o}of t){let r=n?`${n}: `:"",i=[...ie(o.components),...ie(o.features)];for(let[a,c]of i){if(c.parent){let d=c.parent.replace(/^["']|["']$/g,""),u=d.replace(/^[#$^!~@%?&]/,"");!s.has(d)&&!s.has(u)&&e.push({type:"warning",message:`${r}Component "${a}" references parent "${d}" which is not defined in any .purpose file`,path:`components.${a}.parent`});}let l=[{field:"gates",refs:c.gates},{field:"signals",refs:c.signals},{field:"flows",refs:c.flows},{field:"components",refs:c.components},{field:"aspects",refs:c.aspects}];for(let{field:d,refs:u}of l)if(u)for(let p of u){let m=p.replace(/^[#$^!~@%?&]/,"");!s.has(p)&&!s.has(m)&&e.push({type:"warning",message:`${r}Symbol "${a}" references ${d} "${p}" which is not defined`,path:`components.${a}.${d}`});}}if(o.flows){if(Array.isArray(o.flows)){for(let a of o.flows)if(a?.steps)for(let c of a.steps){if(typeof c=="string"||!c?.component)continue;let l=c.component.replace(/^#/,"");!s.has(c.component)&&!s.has(l)&&e.push({type:"warning",message:`${r}Flow "${a.name}" step references "${c.component}" which is not defined`,path:`flows.${a.name}.steps`});}}else for(let[a,c]of Object.entries(o.flows))if(c?.steps)for(let l of c.steps){if(typeof l=="string"||!l?.component)continue;let d=l.component.replace(/^#/,"");!s.has(l.component)&&!s.has(d)&&e.push({type:"warning",message:`${r}Flow "${a}" step references "${l.component}" which is not defined`,path:`flows.${a}.steps`});}}}return {valid:e.filter(n=>n.type==="error").length===0,issues:e}}var Dn={visualizerPort:42195,watcherPort:42196,autoConnect:true};async function ye(t){let e=k.resolve(t),s=k.dirname(e);if(!S.existsSync(e))throw new Error(`Gate config not found: ${e}`);let n=S.readFileSync(e,"utf8"),o=D.load(n);if(!o.version)throw new Error('Gate config missing required "version" field');let r=[],i=o,a=o.gates||i.portals;if(a)for(let[l,d]of Object.entries(a)){let u=l.startsWith("^")?l.slice(1):l;r.push(Ae(u,d));}if(o.include)for(let l of o.include){let d=k.join(s,l),u=await glob(d.replace(/\\/g,"/"));for(let p of u){let m=await Mn(p);r.push(...m);}}let c=[];if(o.flows)for(let[l,d]of Object.entries(o.flows))c.push(Hn(l,d));return {version:o.version,gates:r,flows:c,settings:{dev:{...Dn,...o.settings?.dev}}}}async function Mn(t){let e=S.readFileSync(t,"utf8"),s=D.load(e);if(s.id){let n=s.id,o=n.startsWith("^")?n.slice(1):n;return [Ae(o,s)]}if(s.gates){let n=[];for(let[o,r]of Object.entries(s.gates)){let i=o.startsWith("^")?o.slice(1):o;n.push(Ae(i,r));}return n}return []}function Ae(t,e){let s=[];if(e.locks)for(let o of e.locks)s.push(Un(o));let n=[];if(e.prizes)for(let o of e.prizes)n.push(zn(o));return {id:t,description:e.description,locks:s,prizes:n,position:e.position}}function Un(t){let e=t,s=[];if(e.keys){for(let n of e.keys)if(typeof n=="string")s.push({expression:n});else if(n.expression){let o=n;s.push({expression:o.expression,description:o.description});}}return {id:e.id,description:e.description,keys:s,mode:e.mode||"all"}}function zn(t){let e=t;return {id:e.id,oneTime:e.oneTime??false,metadata:e.metadata}}function Hn(t,e){return {id:t,description:e.description,gates:e.gates||[],forkable:e.forkable}}async function vt(t){let e=k.resolve(t);return await glob("**/portal.yaml",{cwd:e,absolute:true,ignore:["**/node_modules/**","**/dist/**","**/.git/**"]})}function Co(t){if(t instanceof D.YAMLException){let e=(t.reason||"").toLowerCase();return e.includes("duplicated mapping key")||e.includes("duplicate mapping key")?{errorClass:"duplicate-key",detail:"duplicate mapping key"}:["unexpected","expected","bad indentation","mapping values","cannot read a block mapping entry","end of the stream","while scanning","while parsing"].some(n=>e.includes(n))?{errorClass:"syntax",detail:"yaml syntax error"}:{errorClass:"other",detail:"yaml parse error"}}return {errorClass:"other",detail:"yaml parse error"}}var Wn=z.object({x:z.number(),y:z.number()}),Gn=z.object({x:z.number(),y:z.number(),zoom:z.number()}),Tt=z.object({path:z.string(),include:z.array(z.string()).optional(),exclude:z.array(z.string()).optional()}),$t=z.object({id:z.string(),symbol:z.string(),type:z.enum(["feature","component","flow","state","aspect","gate","signal","idea"]),content:z.string().optional(),position:Wn,tags:z.array(z.string()).optional(),created:z.string(),modified:z.string().optional()}),Rt=z.object({from:z.string(),to:z.string(),label:z.string().optional(),type:z.string().optional()}),Bn=z.object({id:z.string(),name:z.string(),nodes:z.array(z.string()),color:z.string().optional()}),kt=z.object({viewport:Gn,groups:z.array(Bn).optional()}),Xn=z.object({nodes:z.array($t),connections:z.array(Rt),layout:kt}),qn=z.object({id:z.string(),name:z.string(),timestamp:z.string(),description:z.string().optional(),state:Xn});z.object({version:z.string(),metadata:z.object({name:z.string(),created:z.string(),modified:z.string()}),sources:z.object({purpose:z.array(Tt).optional(),portal:z.array(Tt).optional()}),nodes:z.array($t),connections:z.array(Rt),layout:kt,snapshots:z.array(qn).optional()});async function Vn(t,e){let s=[],n=[],o=[],r=[];if(t.sources.purpose)for(let c of t.sources.purpose){let l=k.resolve(e,c.path);try{let d=await ut(l);o.push(...d.map(w=>w.filePath));let u=pt(d);for(let[w,{item:b,filePath:C}]of u){let O=["feature",...b.tags||[]];s.push(U({id:`purpose-feature-${w}`,symbol:`#${w}`,type:"component",source:"purpose",filePath:C,data:b,description:b.description,tags:O,componentType:b.type,parentSymbol:b.parent,anchors:b.anchors?.map(v=>je(v))}));}let p=ft(d);for(let[w,{item:b,filePath:C}]of p)s.push(U({id:`purpose-component-${w}`,symbol:`#${w}`,type:"component",source:"purpose",filePath:C,data:b,description:b.description,tags:b.tags,componentType:b.type,parentSymbol:b.parent,anchors:b.anchors?.map(O=>je(O))}));let m=gt(d);for(let[w,{item:b,filePath:C}]of m)s.push(U({id:`purpose-gate-${w}`,symbol:`^${w}`,type:"gate",source:"purpose",filePath:C,data:b,description:b.description}));let g=mt(d);for(let[w,{item:b,filePath:C}]of g)s.push(U({id:`purpose-state-${w}`,symbol:`#${w}`,type:"component",source:"purpose",filePath:C,data:b,description:b.description,tags:["state"]}));let h=ht(d);for(let[w,{item:b,filePath:C}]of h)s.push(U({id:`purpose-flow-${w}`,symbol:`$${w}`,type:"flow",source:"purpose",filePath:C,data:b,description:b.description}));let x=yt(d);for(let[w,{item:b,filePath:C}]of x)s.push(U({id:`purpose-signal-${w}`,symbol:`!${w}`,type:"signal",source:"purpose",filePath:C,data:b,description:b.description}));let T=wt(d);for(let[w,{item:b,filePath:C}]of T)s.push(U({id:`purpose-aspect-${w}`,symbol:`~${w}`,type:"aspect",source:"purpose",filePath:C,data:b,description:b.description,anchors:b.anchors?.map(O=>je(O)),appliesTo:b["applies-to"],tags:b.tags,enforcement:b.enforcement}));let E=bt(d),_=new Set(s.map(w=>w.symbol));for(let w of E)_.has(w.symbol)||(_.add(w.symbol),s.push(U({id:`purpose-ref-${w.type}-${w.symbol.slice(1)}`,symbol:w.symbol,type:w.type,source:"purpose",filePath:w.filePath,data:{referencedFrom:w.sourceSymbol},description:`Referenced from ${w.sourceSymbol}`})));}catch(d){n.push({source:"purpose",filePath:l,message:d.message});}}if(t.sources.portal)for(let c of t.sources.portal){let l=k.resolve(e,c.path);try{let d;if(l.endsWith(".yaml")||l.endsWith(".yml"))d=await ye(l),r.push(l);else {let u=await vt(l);if(r.push(...u),u.length>0){d=await ye(u[0]);for(let p=1;p<u.length;p++){let m=await ye(u[p]);d.gates.push(...m.gates),d.flows.push(...m.flows);}}else continue}for(let u of d.gates){s.push(Yn(u,l));for(let p of u.prizes)s.push(U({id:`gate-signal-${u.id}-${p.id}`,symbol:`!${p.id}`,type:"signal",source:"portal",filePath:l,data:p,description:`Signal from gate ${u.id}`}));}for(let u of d.flows)s.push(Jn(u,l));}catch(d){n.push({source:"portal",filePath:l,message:d.message});}}for(let c of t.nodes){let l=c.tags?.includes("idea");if(!c.content&&!l){let d=s.find(u=>u.symbol===c.symbol);if(d){d.position=c.position,d.tags=c.tags;continue}}s.push(U({id:c.id,symbol:c.symbol,type:c.type,source:"premise",filePath:".premise",data:c,description:c.content,position:c.position,tags:c.tags,created:c.created,modified:c.modified}));}Qn(s);let i=new Map;for(let c of s){let l=i.get(c.symbol)||[];l.includes(c.filePath)||l.push(c.filePath),i.set(c.symbol,l);}let a=[];for(let[c,l]of i)l.length>1&&a.push({symbol:c,files:l});return {symbols:s,purposeFiles:o,portalFiles:r,errors:n,timestamp:Date.now(),...a.length>0?{duplicateSymbols:a}:{}}}function U(t){return {...t,data:t.data??null,references:t.references??[],referencedBy:t.referencedBy??[]}}function Yn(t,e){let s=t.id.startsWith("^")?t.id.slice(1):t.id;return U({id:`gate-${s}`,symbol:`^${s}`,type:"gate",source:"portal",filePath:e,data:t,description:t.description,position:t.position})}function Jn(t,e){return U({id:`gate-flow-${t.id}`,symbol:`$${t.id}`,type:"flow",source:"portal",filePath:e,data:t,description:t.description})}function je(t){let e=t.lastIndexOf(":");if(e===-1||e===t.length-1)return {path:t,lines:0,raw:t};let s=t.slice(e+1),n=t.slice(0,e);if(!/^[\d,\- ]+$/.test(s))return {path:t,lines:0,raw:t};if(s.includes("-")){let[o,r]=s.split("-").map(Number);return {path:n,lines:[o,r],raw:t}}else if(s.includes(",")){let o=s.split(",").map(Number);return {path:n,lines:o,raw:t}}else return {path:n,lines:Number(s),raw:t}}var Kn=new Set(["$lib","$env","$app","$service-worker","$virtual","$schema","$ref","$id","$type"]);function Qn(t){let e=new Map(t.map(s=>[s.symbol,s]));for(let s of t){let n=JSON.stringify(s.data),o=/(?:\?[@#$%~^!]|[@#$%~^!?])[a-zA-Z][\w-]*/g,r=(n.match(o)||[]).filter(i=>!Kn.has(i));for(let i of r)if(i!==s.symbol&&e.has(i)){s.references.includes(i)||s.references.push(i);let a=e.get(i);a&&!a.referencedBy.includes(s.symbol)&&a.referencedBy.push(s.symbol);}}}async function It(t){let e={metadata:{name:k.basename(t),created:new Date().toISOString(),modified:new Date().toISOString()},sources:{purpose:[{path:"./"}],portal:[{path:"./"}]},nodes:[]};return Vn(e,t)}function Zn(){return {entries:new Map,byType:new Map,bySource:new Map,timestamp:0}}function Fo(t){let e=Zn();e.timestamp=t.timestamp;for(let s of t.symbols)e.entries.set(s.id,s),e.byType.has(s.type)||e.byType.set(s.type,[]),e.byType.get(s.type).push(s),e.bySource.has(s.source)||e.bySource.set(s.source,[]),e.bySource.get(s.source).push(s);return e}function we(t,e){for(let s of t.entries.values())if(s.symbol===e)return s}function No(t,e){return t.byType.get(e)||[]}function Do(t,e){let s=e.toLowerCase(),n=[];for(let o of t.entries.values()){if(o.symbol.toLowerCase().includes(s)){n.push(o);continue}if(o.description?.toLowerCase().includes(s)){n.push(o);continue}if(o.tags?.some(r=>r.toLowerCase().includes(s))){n.push(o);continue}if(o.componentType?.toLowerCase().includes(s)){n.push(o);continue}}return n}function Mo(t,e){let s=we(t,e);return s?s.referencedBy.map(n=>we(t,n)).filter(n=>n!==void 0):[]}function Uo(t,e){let s=we(t,e);return s?s.references.map(n=>we(t,n)).filter(n=>n!==void 0):[]}function zo(t){let e={component:0,flow:0,gate:0,signal:0,aspect:0};for(let[s,n]of t.byType)s in e&&(e[s]=n.length);return e}function Ho(t){return Array.from(t.entries.values())}var es="0.1.0",ts="1.0.0";function Le(t,e){let s={$meta:ns(e.projectName,t),components:{},features:{},flows:{},state:{},gates:{},signals:{},aspects:{},screens:{},symbolMap:{}};for(let o of t.symbols)ss(o,s,e);if(e.screenDefinitions)for(let[o,r]of Object.entries(e.screenDefinitions))s.screens[o]||(s.screens[o]={id:o,name:J(o),route:r.route,path:"",components:r.components,features:r.features});let n={};for(let o of Object.values(s.components))o.componentType&&(n[o.componentType]=(n[o.componentType]||0)+1);for(let o of Object.values(s.features))o.componentType&&(n[o.componentType]=(n[o.componentType]||0)+1);return Object.keys(n).length>0&&(s.$meta.componentTypes=n),us(s),s}function ns(t,e){return {version:ts,project:t,generatedAt:new Date().toISOString(),paradigmVersion:es,sources:{purposeFiles:e.purposeFiles.length,portalFiles:e.portalFiles.length,premiseFiles:e.symbols.filter(s=>s.source==="premise").length>0?1:0}}}function ss(t,e,s){let{type:n}=t;switch(n){case "component":os(t,e,s);break;case "feature":rs(t,e,s);break;case "flow":is(t,e);break;case "state":as(t,e);break;case "gate":cs(t,e);break;case "signal":ls(t,e);break;case "aspect":ds(t,e);break;}}function os(t,e,s){let n=ne(t.symbol),o=Ct(n,t.data,s.visualTagMappings),r={id:n,name:J(n),symbol:t.symbol,category:"components",path:t.filePath,description:t.description,visualTags:o,related:t.references,componentType:t.componentType,parent:t.parentSymbol};e.components[n]=r,e.symbolMap[t.symbol]={category:"components",id:n};}function rs(t,e,s){let n=ne(t.symbol),o=Ct(n,t.data,s.visualTagMappings),r={id:n,name:J(n),symbol:t.symbol,category:"features",path:t.filePath,description:t.description,visualTags:o,related:t.references,componentType:t.componentType,parent:t.parentSymbol};e.features[n]=r,e.symbolMap[t.symbol]={category:"features",id:n};}function is(t,e){let s=ne(t.symbol),n=t.data,o=[];if(n?.steps)for(let i=0;i<n.steps.length;i++){let a=n.steps[i];o.push({id:`${s}-step-${i}`,name:a.action||`Step ${i+1}`,target:a.component,description:a.description,order:i});}let r={id:s,name:J(s),symbol:t.symbol,path:t.filePath,description:t.description,steps:o};e.flows[s]=r,e.symbolMap[t.symbol]={category:"flows",id:s};}function as(t,e){let s=ne(t.symbol),n={id:s,name:J(s),symbol:t.symbol,path:t.filePath,description:t.description,consumers:t.referencedBy};e.state[s]=n,e.symbolMap[t.symbol]={category:"state",id:s};}function cs(t,e){let s=ne(t.symbol),n={id:s,name:J(s),symbol:t.symbol,category:"gates",path:t.filePath,description:t.description,related:t.references};e.gates[s]=n,e.symbolMap[t.symbol]={category:"gates",id:s};}function ls(t,e){let s=ne(t.symbol),n={id:s,name:J(s),symbol:t.symbol,category:"signals",path:t.filePath,description:t.description,related:t.references};e.signals[s]=n,e.symbolMap[t.symbol]={category:"signals",id:s};}function ds(t,e){let s=ne(t.symbol),n={id:s,name:J(s),symbol:t.symbol,category:"aspects",path:t.filePath,description:t.description,related:t.references};e.aspects[s]=n,e.symbolMap[t.symbol]={category:"aspects",id:s};}function us(t){for(let e of Object.values(t.screens))if(e.components)for(let s of e.components){let n=t.components[s];n&&(n.screens=n.screens||[],n.screens.includes(e.id)||n.screens.push(e.id));}}function ne(t){return t.slice(1)}function J(t){return t.split("-").map(e=>e.charAt(0).toUpperCase()+e.slice(1)).join(" ")}function Ct(t,e,s){let n=[];if(s?.[t])return s[t];let o=[[/button/i,"button"],[/btn/i,"button"],[/form/i,"form"],[/input/i,"input"],[/field/i,"input"],[/select/i,"input"],[/card/i,"card"],[/list/i,"list"],[/table/i,"list"],[/modal/i,"modal"],[/dialog/i,"modal"],[/drawer/i,"modal"],[/nav/i,"nav"],[/menu/i,"menu"],[/dropdown/i,"menu"],[/header/i,"header"],[/footer/i,"footer"],[/sidebar/i,"sidebar"],[/hero/i,"hero"],[/grid/i,"grid"],[/chart/i,"chart"],[/graph/i,"chart"],[/icon/i,"icon"],[/image/i,"image"],[/avatar/i,"avatar"],[/badge/i,"badge"],[/tag/i,"badge"],[/tab/i,"tab"],[/accordion/i,"accordion"],[/toast/i,"toast"],[/notification/i,"toast"],[/alert/i,"toast"],[/spinner/i,"spinner"],[/loader/i,"spinner"],[/loading/i,"spinner"],[/skeleton/i,"skeleton"]];for(let[r,i]of o)r.test(t)&&n.push(i);return n}function Oe(t){return JSON.stringify(t,null,2)}function Fe(t,e="unknown"){j$1().trackToolCall(e,t);}function Zo(t,e="paradigm://unknown"){j$1().trackResourceRead(e,t);}function ps(){k$1();}function fs(t,e){switch(t){case "paradigm_search":return {summary:`Searched for "${e.query}"${e.type?` (type: ${e.type})`:""}`,symbol:e.query};case "paradigm_ripple":return {summary:`Ripple analysis on ${e.symbol}${e.depth?` (depth: ${e.depth})`:""}`,symbol:e.symbol};case "paradigm_related":return {summary:`Checked relations for ${e.symbol}`,symbol:e.symbol};case "paradigm_status":return {summary:"Checked project status"};case "paradigm_navigate":{let s=e.intent,n=e.target,o=e.task;return s==="context"&&o?{summary:`Navigate context: "${o}"`}:n?{summary:`Navigate ${s||"find"}: ${n}`,symbol:n}:{summary:`Navigate (${s||"unknown"})`}}case "paradigm_gates_for_route":return {summary:`Gate suggestions for ${e.method||"GET"} ${e.route}`};case "paradigm_wisdom_context":return {summary:`Checked wisdom for ${Array.isArray(e.symbols)?e.symbols.join(", "):"symbols"}`,symbol:Array.isArray(e.symbols)?e.symbols[0]:void 0};case "paradigm_history_context":return {summary:`Checked history for ${Array.isArray(e.symbols)?e.symbols.join(", "):"symbols"}`,symbol:Array.isArray(e.symbols)?e.symbols[0]:void 0};case "paradigm_history_record":return {summary:`Recorded ${e.type}: ${(e.description||"").slice(0,60)}`,symbol:Array.isArray(e.symbols)?e.symbols[0]:void 0};case "paradigm_history_fragility":return {summary:`Checked fragility for ${Array.isArray(e.symbols)?e.symbols.join(", "):"symbols"}`,symbol:Array.isArray(e.symbols)?e.symbols[0]:void 0};case "paradigm_flows_affected":return {summary:`Checked flows affected by ${e.symbol}`,symbol:e.symbol};case "paradigm_reindex":return {summary:"Rebuilt static index files"};case "paradigm_session_checkpoint":return {summary:`Checkpoint: phase=${e.phase}, ${(e.context||"").slice(0,60)}`};case "paradigm_task_create":return {summary:`Created task: "${(e.blurb||"").slice(0,60)}"`};case "paradigm_task_done":return {summary:`Completed task ${e.id}`};case "paradigm_task_shelve":return {summary:`Shelved task ${e.id}`};case "paradigm_task_list":return {summary:`Listed tasks (status: ${e.status||"open"})`};case "paradigm_task_update":return {summary:`Updated task ${e.id}`};case "paradigm_assessment_record":return {summary:`Assessment: ${(e.title||"").slice(0,60)} \u2192 ${e.arc_id}`,symbol:Array.isArray(e.symbols)?e.symbols[0]:void 0};case "paradigm_assessment_list":return {summary:e.arc_id?`Listed entries in ${e.arc_id}`:"Listed assessment arcs"};case "paradigm_assessment_search":return {summary:`Searched assessments${e.symbol?` for ${e.symbol}`:""}`,symbol:e.symbol};case "paradigm_assessment_arc_create":return {summary:`Created arc: ${e.id}`};case "paradigm_assessment_arc_close":return {summary:`Closed arc: ${e.arc_id}`};default:{let s=t.replace(/^paradigm_/,""),n=Object.values(e).find(o=>typeof o=="string"&&o.length>0);return {summary:n?`${s}: ${n.slice(0,60)}`:s,symbol:e.symbol||void 0}}}}function er(t,e){let s=j$1(),{summary:n,symbol:o}=fs(t,e);s.addBreadcrumb("tool-call",n,{tool:t,symbol:o});}function tr(){return [{name:"paradigm_session_health",description:"Check if context handoff is recommended based on session activity. Call this periodically during long sessions. Returns usage percentage and recommendation (continue, consider-handoff, handoff-recommended, handoff-urgent). ~100 tokens.",inputSchema:{type:"object",properties:{estimatedTotalTokens:{type:"number",description:"Optional: Your estimate of total conversation tokens (if available)"},contextWindowSize:{type:"number",description:"Context window size in tokens (default: 200000)"}}},annotations:{readOnlyHint:true,destructiveHint:false}},{name:"paradigm_context_check",description:"DEPRECATED: renamed to paradigm_session_health. This alias will be removed in a future version.",inputSchema:{type:"object",properties:{}},annotations:{readOnlyHint:true,destructiveHint:false}},{name:"paradigm_handoff_prepare",description:"Prepare a handoff summary. Generates a structured handoff file with markdown summary and recovery instructions. Returns structured markdown with summary, modified files, and next steps. ~300 tokens.",inputSchema:{type:"object",properties:{summary:{type:"string",description:"Brief summary of work done in this session"},nextSteps:{type:"array",items:{type:"string"},description:"List of next steps for the continuing session"},agent:{type:"string",description:'Target agent role (e.g., "builder", "architect")'},modifiedFiles:{type:"array",items:{type:"string"},description:"List of files modified in this session"},symbolsTouched:{type:"array",items:{type:"string"},description:"List of symbols (@feature, #component, etc.) touched"},openQuestions:{type:"array",items:{type:"string"},description:"Unresolved questions or decisions needed"}},required:["summary"]},annotations:{readOnlyHint:false,destructiveHint:false}},{name:"paradigm_session_stats",description:"Get current session statistics (MCP interactions, estimated tokens). Returns tool call count, estimated tokens used, and cost breakdown. ~100 tokens.",inputSchema:{type:"object",properties:{}},annotations:{readOnlyHint:true,destructiveHint:false}},{name:"paradigm_session_recover",description:"Load previous session breadcrumbs for continuity. Call this at the start of a new session to understand what was done before. Returns symbols modified, files explored, recent actions, and suggestions for continuity. ~200 tokens. NOTE: Recovery data is automatically surfaced as a preamble on the first tool call of each session \u2014 explicit calls are retained for direct inspection or forcing a second recovery pass.",inputSchema:{type:"object",properties:{}},annotations:{readOnlyHint:true,destructiveHint:false},aliases:["resume","pick up","continue","what was I doing","last session","recover"]},{name:"paradigm_session_checkpoint",description:"Save a cognitive-transition checkpoint for crash recovery. Call when transitioning between phases (planning \u2192 implementing \u2192 validating \u2192 complete). ~100 tokens.",inputSchema:{type:"object",properties:{phase:{type:"string",enum:["planning","implementing","validating","complete"],description:"Current workflow phase"},context:{type:"string",description:"What's top-of-mind right now (1-3 sentences)"},externalId:{type:"string",description:'Optional: deterministic ID from external source for automatic session recovery (e.g. "linear:PROJ-123", "github:owner/repo#42")'},plan:{type:"string",description:"Optional: the current plan or approach"},modifiedFiles:{type:"array",items:{type:"string"},description:"Optional: files modified so far"},symbolsTouched:{type:"array",items:{type:"string"},description:"Optional: symbols touched so far"},decisions:{type:"array",items:{type:"string"},description:"Optional: key decisions made so far"}},required:["phase","context"]},annotations:{readOnlyHint:false,destructiveHint:false}}]}async function nr(t,e,s){let n=j$1();if(t==="paradigm_session_health"||t==="paradigm_context_check"){let o=e.contextWindowSize||2e5,r=e.estimatedTotalTokens,i=n.getStats(),{recommendation:a,message:c,usagePercent:l,signals:d}=n.getHandoffRecommendation(o,r),u=n.getDurationMinutes();return {handled:true,text:JSON.stringify({recommendation:a,message:c,stats:{sessionDurationMinutes:u,mcpToolCalls:i.totals.toolCallCount,mcpResourceReads:i.totals.resourceReadCount,estimatedMcpTokens:i.totals.totalTokens,estimatedTotalTokens:r||Math.round(i.totals.totalTokens*5),contextWindowSize:o,usagePercent:l},signals:d,action:a==="continue"?null:"Call paradigm_handoff_prepare to create handoff file"},null,2)}}if(t==="paradigm_handoff_prepare"){let o=e.summary,r=e.nextSteps||[],i=e.agent||"builder",a$1=e.modifiedFiles||[],c=e.symbolsTouched||[],l=e.openQuestions||[],d=n.getStats(),u=n.getCostBreakdown(),p=`h${Date.now().toString(36)}`,m=new Date().toISOString(),g={id:p,timestamp:m,from:"current-session",to:i,summary:o,nextSteps:r,modifiedFiles:a$1,symbolsTouched:c,openQuestions:l,sessionStats:{duration:n.getDurationMinutes(),mcpCalls:d.totals.toolCallCount+d.totals.resourceReadCount,estimatedTokens:d.totals.totalTokens,estimatedCostUsd:u.total.costUsd,model:u.model},status:"pending"},h=false;try{a(s.rootDir,g),h=!0;}catch{}let x=`# Handoff: ${m}
12
+
13
+ ## Session Summary
14
+ ${o}
15
+
16
+ ## Next Steps
17
+ ${r.map((T,E)=>`${E+1}. ${T}`).join(`
18
+ `)||"(none specified)"}
19
+
20
+ ## Key Context
21
+ - Modified files: ${a$1.length>0?a$1.join(", "):"(not specified)"}
22
+ - Symbols touched: ${c.length>0?c.join(", "):"(not specified)"}
23
+ - Open questions: ${l.length>0?l.join(", "):"(none)"}
24
+ `;return ps(),{handled:true,text:JSON.stringify({handoff:g,markdownSummary:x,persisted:h,recovery:"The next session will automatically receive this handoff via paradigm_session_recover."},null,2)}}if(t==="paradigm_session_stats"){let o=n.getStats(),r=n.getCostBreakdown(),i=n.getDurationMinutes();return {handled:true,text:JSON.stringify({session:{startTime:new Date(o.startTime).toISOString(),durationMinutes:i,lastActivity:new Date(o.lastActivity).toISOString()},model:{name:r.model,id:r.modelId,pricing:{inputPerMillion:`$${r.pricing.input.toFixed(2)}`,outputPerMillion:`$${r.pricing.output.toFixed(2)}`}},interactions:{toolCalls:o.totals.toolCallCount,resourceReads:o.totals.resourceReadCount,totalInteractions:o.totals.toolCallCount+o.totals.resourceReadCount},tokens:{total:o.totals.totalTokens,byCategory:{resources:r.resources.tokens,tools:r.tools.tokens}},cost:{totalUsd:`$${r.total.costUsd.toFixed(4)}`,breakdown:{resources:`$${r.resources.costUsd.toFixed(4)}`,tools:`$${r.tools.costUsd.toFixed(4)}`},note:"Cost is for MCP output tokens only (responses sent to model)"},details:{resourcesByType:r.resources.byType,toolsByName:r.tools.byName}},null,2)}}if(t==="paradigm_session_recover"){let{checkpoint:o,pendingHandoffs:r,previousSession:i}=Pt(s.rootDir);if(!i&&r.length===0&&!o)return {handled:true,text:JSON.stringify({found:false,message:"No previous session breadcrumbs, checkpoints, or pending handoffs found.",tip:"Breadcrumbs persist to ~/.paradigm/sessions/ and handoffs persist via paradigm_handoff_prepare. Checkpoints persist via paradigm_session_checkpoint."},null,2)};let a={found:true};if(o){let l=Date.now()-o.timestamp,d=Math.round(l/6e4),u=Math.round(l/36e5);a.checkpoint={phase:o.phase,context:o.context,age:u>1?`${u} hours ago`:`${d} minutes ago`,timestamp:new Date(o.timestamp).toISOString(),sessionId:o.sessionId,plan:o.plan,modifiedFiles:o.modifiedFiles,symbolsTouched:o.symbolsTouched,decisions:o.decisions,recentBreadcrumbs:o.recentBreadcrumbs?.map(p=>({time:new Date(p.timestamp).toISOString(),action:p.action,tool:p.tool,symbol:p.symbol,summary:p.summary}))};}if(i){let l=Date.now()-i.lastActivity,d=Math.round(l/6e4),u=Math.round(l/36e5),m=i.breadcrumbs.slice(-10).map(g=>({time:new Date(g.timestamp).toISOString(),action:g.action,tool:g.tool,symbol:g.symbol,summary:g.summary}));a.previousSession={sessionId:i.sessionId,startTime:new Date(i.startTime).toISOString(),lastActivity:new Date(i.lastActivity).toISOString(),age:u>1?`${u} hours ago`:`${d} minutes ago`},a.context={symbolsModified:i.symbolsModified,filesExplored:i.filesExplored},a.recentActions=m;}if(r.length>0){a.pendingHandoffs=r.map(l=>({id:l.id,timestamp:l.timestamp,from:l.from,to:l.to,summary:l.summary,nextSteps:l.nextSteps,modifiedFiles:l.modifiedFiles,symbolsTouched:l.symbolsTouched,openQuestions:l.openQuestions}));for(let l of r)try{c$1(s.rootDir,l.id);}catch{}}let c="Continue where the previous session left off.";if(o)c=`Previous session was in "${o.phase}" phase: ${o.context}`,o.decisions?.length&&(c+=` Key decisions: ${o.decisions.slice(0,2).join("; ")}`);else if(r.length>0){let l=r[r.length-1];c=`Handoff received: "${l.summary}". `,l.nextSteps.length>0&&(c+=`Start with: ${l.nextSteps[0]}`);}else if(i){let l=i.breadcrumbs.slice(-10);if(l.length>0){let d=l[l.length-1];d.symbol&&(c=`Last work involved ${d.symbol}. Consider checking its current state with paradigm_ripple.`);}}return a.suggestion=c,a.agentInstruction="Present a brief summary of the previous session, then ask the user what they would like to do: (1) Continue \u2014 pick up where the last session left off, (2) Discard \u2014 ignore the previous session and start fresh, or (3) let them describe what they want to work on instead. Do NOT automatically continue without asking.",n.markRecovered(),{handled:true,text:JSON.stringify(a,null,2)}}if(t==="paradigm_session_checkpoint"){n.setRootDir(s.rootDir);let o=e.phase,r=e.context,i=e.externalId,a=e.plan,c=e.modifiedFiles,l=e.symbolsTouched,d=e.decisions,{checkpoint:u,persisted:p}=n.saveCheckpoint({phase:o,context:r,externalId:i,plan:a,modifiedFiles:c,symbolsTouched:l,decisions:d}),m=p.local||p.global;return {handled:true,text:JSON.stringify({saved:m,persisted:p,checkpoint:{phase:u.phase,context:u.context,sessionId:u.sessionId,...u.externalId?{externalId:u.externalId}:{},timestamp:new Date(u.timestamp).toISOString(),modifiedFiles:u.modifiedFiles?.length||0,symbolsTouched:u.symbolsTouched?.length||0,decisions:u.decisions?.length||0,recentBreadcrumbs:u.recentBreadcrumbs?.length||0},...m?{note:"Checkpoint saved. Recovery data will be auto-surfaced on the first tool call of the next session."}:{warning:"Checkpoint was NOT persisted to disk. Both local and global writes failed. Check MCP server stderr for details."}},null,2)}}return {handled:false,text:""}}function Pt(t){let e=j$1();e.setRootDir(t);let s=e.loadCheckpoint(),n=e.loadPreviousSession(),o=[];try{o=b$2(t);}catch{}return {checkpoint:s,pendingHandoffs:o,previousSession:n}}async function sr(t){let{checkpoint:e,pendingHandoffs:s}=Pt(t);if(!e&&s.length===0)return null;let n=[];if(n.push("--- SESSION RECOVERY ---"),e){let o=Date.now()-e.timestamp,r=Math.round(o/6e4),i=Math.round(o/36e5),a=i>1?`${i}h ago`:`${r}m ago`;n.push(`Previous session was in "${e.phase}" phase (${a}): ${e.context}`),e.modifiedFiles?.length&&n.push(`Modified files: ${e.modifiedFiles.join(", ")}`),e.symbolsTouched?.length&&n.push(`Symbols: ${e.symbolsTouched.join(", ")}`),e.decisions?.length&&n.push(`Decisions: ${e.decisions.join("; ")}`),e.plan&&n.push(`Plan: ${e.plan.slice(0,200)}`);}if(s.length>0){let o=s[s.length-1];n.push(`Pending handoff: "${o.summary}"`),o.nextSteps.length>0&&n.push(`Next steps: ${o.nextSteps.slice(0,3).join(", ")}`);}try{let{loadTasks:o}=await import('./task-loader-NZFDTUQ5.js'),r=await o(t,{status:"open",limit:5});if(r.length>0){n.push(""),n.push("Open tasks:");for(let i of r){let a=i.tags.length>0?` [${i.tags.join(", ")}]`:"";n.push(` [${i.priority}] ${i.id}: ${i.blurb}${a}`);}}}catch{}try{let{loadLoreEntries:o}=await import('./lore-loader-RVQI5GXL.js'),i=(await o(t,{limit:10})).filter(a=>a.tags?.some(c=>c.startsWith("arc:")));if(i.length>0){let a=new Map;for(let d of i){let u=d.tags?.find(p=>p.startsWith("arc:"))||"";a.set(u,(a.get(u)||0)+1);}let c=e?.symbolsTouched||[];if((c.length>0?i.filter(d=>d.symbols_touched?.some(u=>c.includes(u))):i.slice(0,3)).length>0||a.size>0){n.push(""),n.push("Active lore arcs:");for(let[d,u]of a)n.push(` ${d} (${u} entries)`);}}}catch{}try{let{loadNominations:o}=await import('./nomination-engine-EALA5MGI.js'),r=o(t,{pending_only:!0}).filter(i=>i.urgency==="critical"||i.urgency==="high");if(r.length>0){n.push(""),n.push("Ambient nominations (urgent):");for(let i of r.slice(0,5))n.push(` [${i.urgency}] ${i.brief}`);r.length>5&&n.push(` ... and ${r.length-5} more. Use paradigm_ambient_nominations to see all.`);}}catch{}return n.push(""),n.push("IMPORTANT: Present a brief summary of this recovery data to the user, then ask what they would like to do: (1) Continue \u2014 pick up where the last session left off, (2) Discard \u2014 ignore the previous session and start fresh, or (3) let them describe what they want to work on instead. Do NOT automatically continue without asking."),n.push("---"),n.join(`
25
+ `)}var Ne=class{cache=new Map;ttlMs;constructor(e=3e4){this.ttlMs=e;}async getOrCompute(e,s){let n=this.cache.get(e);if(n&&Date.now()-n.createdAt<this.ttlMs)return n.data;let o=await s();return this.cache.set(e,{data:o,createdAt:Date.now()}),o}invalidate(e){this.cache.delete(e);}invalidatePrefix(e){for(let s of this.cache.keys())s.startsWith(e)&&this.cache.delete(s);}clear(){this.cache.clear();}stats(){return {size:this.cache.size,ttlMs:this.ttlMs}}},At=new Ne(3e4);var gs=300*1e3,de=null;function Lt(){de=null;}function X(t,e){return S.existsSync(k.join(t,e))}function K(t,e){return S.existsSync(k.join(t,e))}function ms(t,e,s){let n=t;try{if(!S.existsSync(n))return !1;let o=S.readdirSync(n,{withFileTypes:!0});for(let r of o){if(r.isFile()&&r.name.endsWith(e))return !0;if(r.isDirectory())try{if(S.readdirSync(k.join(n,r.name)).some(a=>a.endsWith(e)))return !0}catch{}}}catch{}return false}var hs={wisdom:t=>X(t,".paradigm/wisdom"),history:t=>X(t,".paradigm/history"),lore:t=>X(t,".paradigm/lore"),habits:t=>K(t,".paradigm/habits.yaml"),sentinel:t=>{try{let e=k.join(t,".paradigm","config.yaml");return S.existsSync(e)?S.readFileSync(e,"utf-8").includes("sentinel"):!1}catch{return false}},flows:t=>K(t,".paradigm/flow-index.json")||K(t,".paradigm/flows.yaml"),fixtures:t=>K(t,".paradigm/fixtures.yaml"),orchestration:t=>K(t,".paradigm/agents.yaml"),tasks:t=>X(t,".paradigm/tasks"),assessment:t=>X(t,".paradigm/lore"),personas:t=>ms(t,".persona"),protocols:t=>X(t,".paradigm/protocols"),symphony:()=>{let t=k.join(be.homedir(),".paradigm","score");return S.existsSync(t)},university:t=>X(t,".paradigm/university"),agents:t=>{let e=k.join(be.homedir(),".paradigm","agents");return X(t,".paradigm/agents")||S.existsSync(e)},"aspect-graph":t=>K(t,".paradigm/aspect-graph.db"),pan:t=>K(t,".pan")||K(t,"nevr.yaml"),notebooks:t=>{let e=k.join(be.homedir(),".paradigm","notebooks");return X(t,".paradigm/notebooks")||S.existsSync(e)}},jt=class{modules=new Map;activatedAdvanced=new Set;rootDir;constructor(e){this.rootDir=e;}register(e){this.modules.set(e.key,e);}registerAll(e){for(let s of e)this.register(s);}detectActiveFeatures(){if(de&&Date.now()-de.timestamp<gs)return de.features;let e=new Set;for(let[s,n]of this.modules){if(n.tier==="core"){e.add(s);continue}if(n.tier==="advanced"){this.activatedAdvanced.has(s)&&e.add(s);continue}let o=n.detect||hs[s];if(o)try{o(this.rootDir)&&e.add(s);}catch{}else e.add(s);}return de={features:e,timestamp:Date.now()},e}getActiveTools(){let e=this.detectActiveFeatures(),s=[];for(let[n,o]of this.modules)e.has(n)&&s.push(...o.getToolsList());return s}activateAdvanced(e){let s=this.modules.get(e);return !s||s.tier!=="advanced"?null:(this.activatedAdvanced.add(e),s.getToolsList())}getAvailableAdvanced(){let e=[];for(let[s,n]of this.modules)n.tier==="advanced"&&!this.activatedAdvanced.has(s)&&e.push({key:s,toolCount:n.getToolsList().length});return e}async dispatch(e,s,n,o){let r=this.detectActiveFeatures();for(let[i,a]of this.modules)if(r.has(i))try{let c=await a.handleTool(e,s,n,o);if(c.handled)return c}catch(c){return {handled:true,text:JSON.stringify({error:`Tool handler error in module "${i}"`,message:c.message},null,2)}}return null}get size(){return this.modules.size}getRegistryInfo(){let e=this.detectActiveFeatures(),s={core:0,feature:0,advanced:0};for(let n of this.modules.values())s[n.tier]++;return {total:this.modules.size,byTier:s,activeFeatures:[...e],availableAdvanced:[...this.modules.entries()].filter(([n,o])=>o.tier==="advanced"&&!this.activatedAdvanced.has(n)).map(([n])=>n)}}};var Ue=null;async function _s(){return Ue||(Ue=await Ts()),Ue}var $s=[`CREATE TABLE IF NOT EXISTS aspects (
26
+ id TEXT PRIMARY KEY,
27
+ description TEXT NOT NULL,
28
+ category TEXT DEFAULT 'rule',
29
+ severity TEXT DEFAULT 'medium',
30
+ value TEXT,
31
+ enforcement TEXT,
32
+ defined_in TEXT NOT NULL,
33
+ tags TEXT,
34
+ created_at TEXT NOT NULL,
35
+ updated_at TEXT NOT NULL
36
+ )`,`CREATE TABLE IF NOT EXISTS anchors (
37
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
38
+ aspect_id TEXT NOT NULL REFERENCES aspects(id) ON DELETE CASCADE,
39
+ file_path TEXT NOT NULL,
40
+ start_line INTEGER NOT NULL,
41
+ end_line INTEGER NOT NULL,
42
+ content_hash TEXT,
43
+ normalized_hash TEXT,
44
+ materialized_at_commit TEXT,
45
+ last_verified TEXT,
46
+ drifted INTEGER DEFAULT 0
47
+ )`,"CREATE INDEX IF NOT EXISTS idx_anchors_file ON anchors(file_path)","CREATE INDEX IF NOT EXISTS idx_anchors_aspect ON anchors(aspect_id)",`CREATE TABLE IF NOT EXISTS edges (
48
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
49
+ source TEXT NOT NULL,
50
+ target TEXT NOT NULL,
51
+ relation TEXT NOT NULL,
52
+ weight REAL DEFAULT 1.0,
53
+ origin TEXT DEFAULT 'explicit',
54
+ created_at TEXT NOT NULL
55
+ )`,"CREATE INDEX IF NOT EXISTS idx_edges_source ON edges(source)","CREATE INDEX IF NOT EXISTS idx_edges_target ON edges(target)",`CREATE TABLE IF NOT EXISTS lore_links (
56
+ aspect_id TEXT NOT NULL,
57
+ lore_id TEXT NOT NULL,
58
+ PRIMARY KEY (aspect_id, lore_id)
59
+ )`,`CREATE TABLE IF NOT EXISTS search_log (
60
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
61
+ query TEXT NOT NULL,
62
+ results_returned TEXT NOT NULL,
63
+ selected_result TEXT,
64
+ timestamp TEXT NOT NULL
65
+ )`,"CREATE INDEX IF NOT EXISTS idx_search_query ON search_log(query)",`CREATE TABLE IF NOT EXISTS search_weights (
66
+ query_normalized TEXT NOT NULL,
67
+ aspect_id TEXT NOT NULL,
68
+ weight REAL DEFAULT 1.0,
69
+ hit_count INTEGER DEFAULT 1,
70
+ last_hit TEXT NOT NULL,
71
+ PRIMARY KEY (query_normalized, aspect_id)
72
+ )`,`CREATE TABLE IF NOT EXISTS heatmap (
73
+ aspect_id TEXT NOT NULL,
74
+ access_type TEXT NOT NULL,
75
+ count INTEGER DEFAULT 0,
76
+ last_accessed TEXT NOT NULL,
77
+ PRIMARY KEY (aspect_id, access_type)
78
+ )`],Rs=["ALTER TABLE anchors ADD COLUMN original_content TEXT",`CREATE TABLE IF NOT EXISTS anchor_history (
79
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
80
+ anchor_id INTEGER NOT NULL,
81
+ action TEXT NOT NULL,
82
+ old_start INTEGER,
83
+ old_end INTEGER,
84
+ new_start INTEGER,
85
+ new_end INTEGER,
86
+ old_path TEXT,
87
+ new_path TEXT,
88
+ confidence REAL,
89
+ commit_hash TEXT,
90
+ healed_at TEXT NOT NULL
91
+ )`],ks="CREATE VIRTUAL TABLE IF NOT EXISTS aspects_fts USING fts5(id, description, enforcement, tags)";function W(t,e,s){let n=t.prepare(e);s&&s.length>0&&n.bind(s);let o=[];for(;n.step();)o.push(n.getAsObject());return n.free(),o}function Is(t,e,s){let n=t.prepare(e);s&&s.length>0&&n.bind(s);let o=null;return n.step()&&(o=n.getAsObject()),n.free(),o}async function Bt(t){let e=await _s(),s=k.join(t,".paradigm"),n=k.join(s,"aspect-graph.db"),o;if(S.existsSync(n)){let r=S.readFileSync(n);o=new e.Database(r);}else S.existsSync(s)||S.mkdirSync(s,{recursive:true}),o=new e.Database;for(let r of $s)o.run(r);try{o.run(ks);}catch{}for(let r of Rs)try{o.run(r);}catch{}return o}function Xt(t,e){if(e){let s=k.join(e,".paradigm");S.existsSync(s)||S.mkdirSync(s,{recursive:true});let n=k.join(s,"aspect-graph.db"),o=t.export();S.writeFileSync(n,Buffer.from(o));}t.close();}function qt(t,e,s){let n=e.filter(i=>i.type==="aspect"),o=new Date().toISOString(),r=null;try{r=execSync("git rev-parse HEAD",{cwd:s,encoding:"utf8"}).trim();}catch{}t.run("DELETE FROM anchors"),t.run("DELETE FROM edges"),t.run("DELETE FROM aspects");try{t.run("DELETE FROM aspects_fts");}catch{}for(let i of n){let a=i.data??{},c=js(a,i),l=Ls(a,i),d=a.value!=null?String(a.value):null,u=i.enforcement??(a.enforcement!=null?String(a.enforcement):null),p=i.tags?JSON.stringify(i.tags):null;if(t.run(`INSERT INTO aspects (id, description, category, severity, value, enforcement, defined_in, tags, created_at, updated_at)
92
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,[i.symbol,i.description??"",c,l,d,u,i.filePath,p,i.created??o,i.modified??o]),i.anchors)for(let g of i.anchors){let{startLine:h,endLine:x}=Vt(g),T=As();t.run(`INSERT INTO anchors (aspect_id, file_path, start_line, end_line, content_hash, normalized_hash, materialized_at_commit, last_verified, original_content)
93
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,[i.symbol,g.path,h,x,T.exact,T.normalized,r,o,T.normalizedContent]);}let m=a.edges;if(Array.isArray(m))for(let g of m)t.run(`INSERT INTO edges (source, target, relation, weight, origin, created_at)
94
+ VALUES (?, ?, ?, ?, ?, ?)`,[g.source??i.symbol,g.target??"",g.relation??"related-to",g.weight??1,g.origin??"explicit",o]);if(i.appliesTo)for(let g of i.appliesTo)t.run(`INSERT INTO edges (source, target, relation, weight, origin, created_at)
95
+ VALUES (?, ?, ?, ?, ?, ?)`,[i.symbol,g,"related-to",.5,"inferred",o]);try{t.run(`INSERT INTO aspects_fts (id, description, enforcement, tags)
96
+ VALUES (?, ?, ?, ?)`,[i.symbol,i.description??"",u??"",p??""]);}catch{}}}function dr(t,e){return Is(t,"SELECT * FROM aspects WHERE id = ?",[e])}function ur(t,e){return W(t,"SELECT * FROM anchors WHERE aspect_id = ?",[e])}function pr(t,e){return W(t,"SELECT * FROM edges WHERE source = ?",[e])}function fr(t,e){return W(t,"SELECT * FROM edges WHERE target = ?",[e])}function gr(t,e){return W(t,"SELECT * FROM edges WHERE source = ? OR target = ?",[e,e])}function mr(t,e,s){let n=new Date().toISOString();t.run(`INSERT INTO heatmap (aspect_id, access_type, count, last_accessed)
97
+ VALUES (?, ?, 1, ?)
98
+ ON CONFLICT(aspect_id, access_type)
99
+ DO UPDATE SET count = count + 1, last_accessed = ?`,[e,s,n,n]);}function hr(t,e=20,s){return s?W(t,"SELECT * FROM heatmap WHERE access_type = ? ORDER BY count DESC LIMIT ?",[s,e]):W(t,"SELECT * FROM heatmap ORDER BY count DESC LIMIT ?",[e])}function yr(t,e,s,n=true,o=.7,r=.85){let i=s?W(t,"SELECT * FROM anchors WHERE aspect_id = ?",[s]):W(t,"SELECT * FROM anchors"),a=[];for(let c of i){let l=k.isAbsolute(c.file_path)?c.file_path:k.join(e,c.file_path);if(!S.existsSync(l)){a.push({aspectId:c.aspect_id,path:c.file_path,startLine:c.start_line,endLine:c.end_line,status:"missing",resolvedBy:"none",exists:false,drifted:true});continue}try{let u=S.readFileSync(l,"utf8").split(`
100
+ `),p=Math.max(0,c.start_line-1),m=Math.min(u.length,c.end_line),g=u.slice(p,m).join(`
101
+ `),h=Q.createHash("sha256").update(g).digest("hex");if(c.content_hash!=null&&h===c.content_hash){a.push({aspectId:c.aspect_id,path:c.file_path,startLine:c.start_line,endLine:c.end_line,status:"clean",resolvedBy:"exact-hash",exists:!0,drifted:!1}),c.drifted===1&&t.run("UPDATE anchors SET drifted = 0 WHERE id = ?",[c.id]);continue}let x=Q.createHash("sha256").update(He(g)).digest("hex");if(c.normalized_hash!=null&&x===c.normalized_hash){t.run("UPDATE anchors SET content_hash = ?, drifted = 0 WHERE id = ?",[h,c.id]),a.push({aspectId:c.aspect_id,path:c.file_path,startLine:c.start_line,endLine:c.end_line,status:"cosmetic",resolvedBy:"normalized-hash",exists:!0,drifted:!1});continue}if(c.content_hash==null&&c.normalized_hash==null){t.run("UPDATE anchors SET content_hash = ?, normalized_hash = ?, drifted = 0 WHERE id = ?",[h,x,c.id]),a.push({aspectId:c.aspect_id,path:c.file_path,startLine:c.start_line,endLine:c.end_line,status:"clean",resolvedBy:"exact-hash",exists:!0,drifted:!1});continue}let T=!1;if(c.materialized_at_commit){let E=Ps(e,c.file_path,c.materialized_at_commit,c.start_line,c.end_line);if(E){let _=Math.max(0,E.currentStart-1),w=Math.min(u.length,E.currentEnd),b=u.slice(_,w).join(`
102
+ `),C=Q.createHash("sha256").update(b).digest("hex");if(c.content_hash!=null&&C===c.content_hash){let O=n;if(O){t.run("UPDATE anchors SET start_line = ?, end_line = ?, drifted = 0 WHERE id = ?",[E.currentStart,E.currentEnd,c.id]);let v=W(t,"SELECT defined_in FROM aspects WHERE id = ?",[c.aspect_id]);v.length>0&&ze(e,v[0].defined_in,c.file_path,c.start_line,c.end_line,E.currentStart,E.currentEnd);}a.push({aspectId:c.aspect_id,path:c.file_path,startLine:O?E.currentStart:c.start_line,endLine:O?E.currentEnd:c.end_line,status:"shifted",resolvedBy:"git-line-mapping",exists:!0,drifted:!1,suggestedStart:E.currentStart,suggestedEnd:E.currentEnd,autoHealed:O}),T=!0;}else {let O=Q.createHash("sha256").update(He(b)).digest("hex");if(c.normalized_hash!=null&&O===c.normalized_hash){if(n){let v=Q.createHash("sha256").update(b).digest("hex");t.run("UPDATE anchors SET start_line = ?, end_line = ?, content_hash = ?, drifted = 0 WHERE id = ?",[E.currentStart,E.currentEnd,v,c.id]);let F=W(t,"SELECT defined_in FROM aspects WHERE id = ?",[c.aspect_id]);F.length>0&&ze(e,F[0].defined_in,c.file_path,c.start_line,c.end_line,E.currentStart,E.currentEnd);}a.push({aspectId:c.aspect_id,path:c.file_path,startLine:n?E.currentStart:c.start_line,endLine:n?E.currentEnd:c.end_line,status:"shifted",resolvedBy:"git-line-mapping",exists:!0,drifted:!1,suggestedStart:E.currentStart,suggestedEnd:E.currentEnd,autoHealed:n}),T=!0;}}}}if(T)continue;if(c.original_content){let{contentSearch:E}=(Wt(),d(Ht)),_=E(e,c.file_path,c.original_content,n);if(_.found&&_.score>=o){if(n&&_.score>=r&&!_.suggestedPath&&_.suggestedStart&&_.suggestedEnd){t.run("UPDATE anchors SET start_line = ?, end_line = ?, drifted = 0 WHERE id = ?",[_.suggestedStart,_.suggestedEnd,c.id]);try{t.run(`INSERT INTO anchor_history (anchor_id, action, old_start, old_end, new_start, new_end, confidence, healed_at)
103
+ VALUES (?, 'relocated', ?, ?, ?, ?, ?, ?)`,[c.id,c.start_line,c.end_line,_.suggestedStart,_.suggestedEnd,_.score,new Date().toISOString()]);}catch{}let b=W(t,"SELECT defined_in FROM aspects WHERE id = ?",[c.aspect_id]);b.length>0&&ze(e,b[0].defined_in,c.file_path,c.start_line,c.end_line,_.suggestedStart,_.suggestedEnd),a.push({aspectId:c.aspect_id,path:c.file_path,startLine:_.suggestedStart,endLine:_.suggestedEnd,status:"relocated",resolvedBy:"content-search",exists:!0,similarity:_.similarity,suggestedStart:_.suggestedStart,suggestedEnd:_.suggestedEnd,autoHealed:!0,drifted:!1});continue}a.push({aspectId:c.aspect_id,path:_.suggestedPath||c.file_path,startLine:c.start_line,endLine:c.end_line,status:"relocated",resolvedBy:"content-search",exists:!0,similarity:_.similarity,suggestedStart:_.suggestedStart,suggestedEnd:_.suggestedEnd,autoHealed:!1,drifted:!0});continue}}t.run("UPDATE anchors SET drifted = 1 WHERE id = ?",[c.id]),a.push({aspectId:c.aspect_id,path:c.file_path,startLine:c.start_line,endLine:c.end_line,status:"modified",resolvedBy:"none",exists:!0,currentContent:g,drifted:!0});}catch{a.push({aspectId:c.aspect_id,path:c.file_path,startLine:c.start_line,endLine:c.end_line,status:"modified",resolvedBy:"none",exists:true,drifted:true});}}return a}function Vt(t){let{lines:e}=t;return typeof e=="number"?{startLine:e,endLine:e}:Array.isArray(e)?e.length===2?{startLine:e[0],endLine:e[1]}:{startLine:Math.min(...e),endLine:Math.max(...e)}:{startLine:1,endLine:1}}function Cs(t){let e=[],s=/^@@ -(\d+)(?:,(\d+))? \+(\d+)(?:,(\d+))? @@/gm,n;for(;(n=s.exec(t))!==null;)e.push({oldStart:parseInt(n[1],10),oldCount:n[2]!==void 0?parseInt(n[2],10):1,newStart:parseInt(n[3],10),newCount:n[4]!==void 0?parseInt(n[4],10):1});return e}function Ps(t,e,s,n,o){let r;try{r=execSync(`git diff ${s}..HEAD --unified=0 -- "${e}"`,{cwd:t,encoding:"utf8",timeout:5e3});}catch{return null}if(!r.trim())return {originalStart:n,originalEnd:o,currentStart:n,currentEnd:o};let i=Cs(r),a=0;for(let c of i){if(c.oldStart+c.oldCount<=n){a+=c.newCount-c.oldCount;continue}if(c.oldStart<o)return null;break}return a===0?null:{originalStart:n,originalEnd:o,currentStart:n+a,currentEnd:o+a}}function ze(t,e,s,n,o,r,i){let a=k.isAbsolute(e)?e:k.join(t,e);if(!S.existsSync(a))return false;try{let c=S.readFileSync(a,"utf8"),l=n===o?`${s}:${n}`:`${s}:${n}-${o}`,d=r===i?`${s}:${r}`:`${s}:${r}-${i}`;if(!c.includes(l))return !1;let u=c.replace(l,d);return S.writeFileSync(a,u,"utf8"),!0}catch{return false}}function He(t){return t.split(`
104
+ `).map(e=>e.trimEnd()).filter(e=>e.trim()!=="").map(e=>e.replace(/\s+/g," ")).join(`
105
+ `)}function As(t,e){return {exact:null,normalized:null,normalizedContent:null};}function js(t,e){if(typeof t.category=="string")return t.category;let s=(e.description??"").toLowerCase();return /\b(must|require|always)\b/.test(s)?"rule":/\b(decided|chose)\b/.test(s)?"decision":/\b(limit|cannot)\b/.test(s)?"constraint":/\b(set to|configured|value)\b/.test(s)?"configuration":"rule"}function Ls(t,e){if(typeof t.severity=="string")return t.severity;let s=e.tags??[];return s.includes("critical")?"critical":s.includes("security")||s.includes("compliance")?"high":"medium"}j();var Os=/L-\d{4}-\d{2}-\d{2}-\d{3}/g;async function Yt(t,e){t.run("DELETE FROM lore_links");let s=await a$3(e);if(s.length===0)return 0;let n=Fs(s),o=new Map;for(let l of s)o.set(l.id,l);let r=new Set,i=t.exec("SELECT id, enforcement FROM aspects");if(i.length>0){let{columns:l,values:d}=i[0],u=l.indexOf("id"),p=l.indexOf("enforcement");for(let m of d){let g=String(m[u]),h=m[p];if(h&&typeof h=="string"){let x=h.match(Os);if(x)for(let T of x)o.has(T)&&r.add(`${g}\0${T}`);}}}let a=t.exec("SELECT source, target FROM edges");if(a.length>0&&i.length>0){let l=Ns(t,a);for(let[d,u]of l)for(let p of u){let m=n.get(p);if(m)for(let g of m)r.add(`${d}\0${g}`);}}if(r.size===0)return 0;let c=t.prepare("INSERT OR IGNORE INTO lore_links (aspect_id, lore_id) VALUES (?, ?)");try{for(let l of r){let[d,u]=l.split("\0");c.bind([d,u]),c.step(),c.reset();}}finally{c.free();}return r.size}async function Sr(t,e,s){let n=t.exec("SELECT lore_id FROM lore_links WHERE aspect_id = ?",[s]);if(n.length===0||n[0].values.length===0)return [];let o=n[0].values.map(r=>String(r[0]));return Ds(e,o)}async function Jt(t,e){let s=await a$3(e);if(s.length===0)return 0;let n=t.exec("SELECT id FROM aspects"),o=new Set;if(n.length>0)for(let c of n[0].values)o.add(String(c[0]));if(o.size<2)return 0;let r=new Date().toISOString(),i=0,a=t.prepare(`INSERT OR IGNORE INTO edges (source, target, relation, weight, origin, created_at)
106
+ VALUES (?, ?, 'related-to', 0.3, 'learned', ?)`);try{for(let c of s){if(!c.symbols_touched||c.symbols_touched.length<2)continue;let l=[];for(let d of c.symbols_touched){let u=d.startsWith("~")?d.slice(1):d;o.has(u)&&l.push(u);}for(let d=0;d<l.length;d++)for(let u=d+1;u<l.length;u++){let[p,m]=l[d]<l[u]?[l[d],l[u]]:[l[u],l[d]];a.bind([p,m,r]),a.step(),a.reset(),i++;}}}finally{a.free();}return i}function Fs(t){let e=new Map;for(let s of t)if(s.symbols_touched)for(let n of s.symbols_touched){let o=e.get(n);o||(o=new Set,e.set(n,o)),o.add(s.id);}return e}function Ns(t,e){let s=t.exec("SELECT id FROM aspects"),n=new Set;if(s.length>0)for(let l of s[0].values)n.add(String(l[0]));let o=new Map;if(e.length===0)return o;let{columns:r,values:i}=e[0],a=r.indexOf("source"),c=r.indexOf("target");for(let l of i){let d=String(l[a]),u=String(l[c]);if(n.has(d)){let p=o.get(d);p||(p=new Set,o.set(d,p)),p.add(u),p.add(`~${d}`);}if(n.has(u)){let p=o.get(u);p||(p=new Set,o.set(u,p)),p.add(d),p.add(`~${u}`);}}return o}async function Ds(t,e){let s=new Set,n=[];for(let o of e){if(s.has(o))continue;s.add(o);let r=await b$3(t,o);r&&n.push(Ms(r));}return n}function Ms(t){return {id:t.id,title:t.title,summary:t.summary,timestamp:t.timestamp,symbolsTouched:t.symbols_touched}}var ae=".paradigm/personas",Us="index.yaml";async function ue(t,e){let s=k.join(t,ae);if(!S.existsSync(s))return [];let n=S.readdirSync(s).filter(r=>r.endsWith(".persona")),o=[];for(let r of n)try{let i=S.readFileSync(k.join(s,r),"utf8"),a=D.load(i);a&&a.id&&o.push(a);}catch{}return zs(o,e)}async function pe(t,e){let s=k.join(t,ae,`${e}.persona`);if(!S.existsSync(s))return null;try{return D.load(S.readFileSync(s,"utf8"))}catch{return null}}function zs(t,e){if(!e)return t;let s=t;return e.tag&&(s=s.filter(n=>n.tags?.includes(e.tag))),e.trigger_type&&(s=s.filter(n=>n.trigger.type===e.trigger_type)),e.gate&&(s=s.filter(n=>n.journey.some(o=>o.gates.includes(e.gate)))),e.flow&&(s=s.filter(n=>n.journey.some(o=>o.flow===e.flow))),e.limit&&(s=s.slice(0,e.limit)),s}async function vr(t,e){let s=k.join(t,ae);S.mkdirSync(s,{recursive:true});let n=k.join(s,`${e.id}.persona`);if(S.existsSync(n))throw new Error(`Persona ${e.id} already exists`);let o=new Date().toISOString(),r={version:"1.0",id:e.id,name:e.name,description:e.description,traits:e.traits,trigger:e.trigger,fixtures:e.fixtures,tags:e.tags||[],journey:e.journey||[],created:o,updated:o};return S.writeFileSync(n,D.dump(r,{indent:2,lineWidth:120,noRefs:true,sortKeys:false})),await fe(t),e.id}async function Kt(t,e,s){let n=await pe(t,e);if(!n)return false;let o=k.join(t,ae,`${e}.persona`),r={...n,...s,id:n.id,version:n.version,created:n.created,updated:new Date().toISOString()};return S.writeFileSync(o,D.dump(r,{indent:2,lineWidth:120,noRefs:true,sortKeys:false})),await fe(t),true}async function Er(t,e){let s=k.join(t,ae,`${e}.persona`);if(!S.existsSync(s))return {deleted:false,warnings:[]};let n=[],o=await ue(t);for(let r of o)if(r.id!==e){r.trigger.spawned_by?.startsWith(e+".")&&n.push(`Persona ${r.id} is spawned by ${e} \u2014 it will become orphaned`);for(let i of r.journey)i.spawns?.some(a=>a.persona===e)&&n.push(`Persona ${r.id} step ${i.id} spawns ${e} \u2014 spawn will break`);}return S.unlinkSync(s),await fe(t),{deleted:true,warnings:n}}async function Tr(t,e,s,n){let o=await pe(t,e);if(!o)return false;if(o.journey.some(r=>r.id===s.id))throw new Error(`Step ${s.id} already exists in persona ${e}`);if(n){let r=o.journey.findIndex(i=>i.id===n);if(r===-1)throw new Error(`Step ${n} not found in persona ${e}`);o.journey.splice(r+1,0,s);}else o.journey.push(s);return Kt(t,e,{journey:o.journey})}async function _r(t,e,s){let n=await pe(t,e);if(!n)return {removed:false,warnings:[]};let o=n.journey.findIndex(a=>a.id===s);if(o===-1)return {removed:false,warnings:[]};let r=n.journey[o],i=[];if(r.produces)for(let a of Object.keys(r.produces)){let c=`{{produces.${a}}}`;for(let l=o+1;l<n.journey.length;l++){let d=n.journey[l];JSON.stringify(d).includes(c)&&i.push(`Step ${d.id} consumes {{produces.${a}}} from this step`);}}if(r.spawns&&r.spawns.length>0)for(let a of r.spawns)i.push(`Step spawns persona ${a.persona} \u2014 spawn chain will break`);return n.journey.splice(o,1),await Kt(t,e,{journey:n.journey}),{removed:true,warnings:i}}var Hs=/^[a-z][a-z0-9-]*$/,Ws=/^[a-z][a-z0-9-]*$/,Gs=/^(GET|POST|PUT|PATCH|DELETE)\s+\//;async function $r(t,e,s=false){let n=[],o=[];Hs.test(e.id)||n.push({type:"invalid-id",detail:`ID "${e.id}" must match /^[a-z][a-z0-9-]*$/`}),(!e.name||e.name.trim()==="")&&n.push({type:"missing-name",detail:"Name is required"}),(!e.trigger||!e.trigger.type)&&n.push({type:"missing-trigger",detail:"Trigger with type is required"}),e.trigger.type!=="root"&&!e.trigger.spawned_by&&n.push({type:"missing-spawned-by",detail:`Non-root trigger type "${e.trigger.type}" requires spawned_by`}),(!e.journey||e.journey.length===0)&&n.push({type:"empty-journey",detail:"Journey must have at least one step"});let r=new Set,i=new Set;for(let a of e.journey){Ws.test(a.id)||n.push({type:"invalid-step-id",step:a.id,detail:"Step ID must match /^[a-z][a-z0-9-]*$/"}),r.has(a.id)&&n.push({type:"duplicate-step-id",step:a.id,detail:`Duplicate step ID "${a.id}"`}),r.add(a.id),Gs.test(a.route)||n.push({type:"invalid-route",step:a.id,route:a.route,detail:'Route must match "METHOD /path" (e.g., "POST /api/auth/signup")'}),(!a.gates||a.gates.length===0)&&n.push({type:"missing-gates",step:a.id,detail:"Step must have at least one gate"}),(!a.expect||a.expect.status===void 0)&&n.push({type:"missing-expect",step:a.id,detail:"Step must have expect with status"});let l=JSON.stringify(a).match(/\{\{produces\.([^}]+)\}\}/g)||[];for(let d of l){let u=d.replace("{{produces.","").replace("}}","");i.has(u)||n.push({type:"unresolved-produces",step:a.id,key:u,detail:`{{produces.${u}}} used but not produced by a prior step`});}if(a.produces)for(let d of Object.keys(a.produces))i.add(d);}if(s){let a=k.join(t,"portal.yaml"),c=[],l=[];if(S.existsSync(a))try{let u=D.load(S.readFileSync(a,"utf8"));u.gates&&typeof u.gates=="object"&&(c=Object.keys(u.gates)),u.routes&&typeof u.routes=="object"&&(l=Object.keys(u.routes));}catch{}for(let u of e.journey)for(let p of u.gates)c.length>0&&!c.includes(p)&&n.push({type:"gate-not-found",step:u.id,gate:p,detail:`Gate ${p} not defined in portal.yaml`});for(let u of e.journey)if(l.length>0){let p=u.route;l.some(g=>We(g,p))||o.push({type:"route-not-in-portal",detail:`Route "${p}" (step ${u.id}) not found in portal.yaml`});}for(let u of e.journey)if(u.spawns)for(let p of u.spawns)await pe(t,p.persona)||n.push({type:"spawn-target-missing",step:u.id,detail:`Spawn target persona "${p.persona}" does not exist`});let d=await Bs(t,e.id);if(d&&n.push({type:"spawn-cycle",detail:`Circular spawn dependency: ${d.join(" \u2192 ")}`}),l.length>0||c.length>0){let u=await ue(t),p=new Set,m=new Set;for(let T of u)for(let E of T.journey){for(let _ of E.gates)p.add(_);m.add(E.route);}let g=[],h=k.join(t,".paradigm","flow-index.json");if(S.existsSync(h))try{let T=JSON.parse(S.readFileSync(h,"utf8"));g=Object.keys(T.flows||{});}catch{}let x=new Set;for(let T of u)for(let E of T.journey)E.flow&&x.add(E.flow);return {persona:e.id,valid:n.length===0,errors:n,warnings:o,coverage:{routes:{covered:m.size,total:l.length,uncovered:l.filter(T=>!m.has(T))},gates:{covered:p.size,total:c.length,uncovered:c.filter(T=>!p.has(T))},flows:{covered:x.size,total:g.length,uncovered:g.filter(T=>!x.has(T))}}}}}return {persona:e.id,valid:n.length===0,errors:n,warnings:o}}function We(t,e){let s=n=>n.replace(/:[a-zA-Z_]+/g,":param").replace(/\{\{[^}]+\}\}/g,":param");return s(t)===s(e)}async function Bs(t,e){let s=new Set,n=[];async function o(r){if(s.has(r)){let a=n.indexOf(r);return a!==-1?[...n.slice(a),r]:null}s.add(r),n.push(r);let i=await pe(t,r);if(i){for(let a of i.journey)if(a.spawns)for(let c of a.spawns){let l=await o(c.persona);if(l)return l}}return n.pop(),null}return o(e)}async function fe(t){let e=k.join(t,ae);S.mkdirSync(e,{recursive:true});let s=await ue(t),n={},o={},r={};for(let u of s){let p=new Set,m=new Set,g=[],h=new Set;for(let x of u.journey){for(let T of x.gates)p.add(T);if(x.flow&&m.add(x.flow),g.push(x.route),x.spawns)for(let T of x.spawns)h.add(T.persona);}n[u.id]={name:u.name,trigger:u.trigger.type,spawned_by:u.trigger.spawned_by,steps:u.journey.length,gates:[...p],flows:[...m],routes:g,spawns:[...h],tags:u.tags||[]};for(let x of p)o[x]||(o[x]=[]),o[x].push(u.id);for(let x of g)r[x]||(r[x]=[]),r[x].push(u.id);}let i=[],a=k.join(t,"portal.yaml");if(S.existsSync(a))try{let u=D.load(S.readFileSync(a,"utf8"));u.routes&&typeof u.routes=="object"&&(i=Object.keys(u.routes).filter(m=>!Object.keys(r).some(g=>We(m,g))));}catch{}let c={},l=k.join(e,"chains");if(S.existsSync(l)){let u=S.readdirSync(l).filter(p=>p.endsWith(".yaml"));for(let p of u)try{let m=S.readFileSync(k.join(l,p),"utf8"),g=D.load(m);if(g&&g.id){let h=g.order.map(E=>E.persona),x=0,T=new Set;for(let E of h){let _=n[E];if(_){x+=_.steps;for(let w of _.gates)T.add(w);}}c[g.id]={description:g.description||"",order:h,total_steps:x,total_gates:T.size};}}catch{}}let d={version:"1.0",generated:new Date().toISOString(),personas:n,chains:c,gate_coverage:o,route_coverage:r,uncovered_routes:i};return S.writeFileSync(k.join(e,Us),D.dump(d,{indent:2,lineWidth:120,noRefs:true,sortKeys:false})),d}async function Rr(t){let e=await ue(t),s=new Set,n=new Set,o=new Set;for(let d of e)for(let u of d.journey){for(let p of u.gates)s.add(p);n.add(u.route),u.flow&&o.add(u.flow);}let r=[],i=[],a=k.join(t,"portal.yaml");if(S.existsSync(a))try{let d=D.load(S.readFileSync(a,"utf8"));d.gates&&typeof d.gates=="object"&&(r=Object.keys(d.gates)),d.routes&&typeof d.routes=="object"&&(i=Object.keys(d.routes));}catch{}let c=[],l=k.join(t,".paradigm","flow-index.json");if(S.existsSync(l))try{let d=JSON.parse(S.readFileSync(l,"utf8"));c=Object.keys(d.flows||{});}catch{}return {routes:{covered:n.size,total:i.length,uncovered:i.filter(d=>!Array.from(n).some(u=>We(d,u)))},gates:{covered:s.size,total:r.length,uncovered:r.filter(d=>!s.has(d))},flows:{covered:o.size,total:c.length,uncovered:c.filter(d=>!o.has(d))},personas:e.length}}async function kr(t,e){let s=await ue(t),n=[];for(let o of s){let r=[],i=[];for(let a of o.journey)if((a.gates.includes(e)||a.flow===e||a.route===e||a.signals?.includes(e))&&(r.push(a.id),a.spawns))for(let l of a.spawns)i.push(l.persona);r.length>0&&n.push({persona:o.id,steps:r,spawns_blocked:i});}return n}function Xs(t,e){let s=e.split(/[.\[\]]+/).filter(Boolean),n=t;for(let o of s){if(n==null||typeof n!="object")return;n=n[o];}return n}function qs(t,e){let s=[];if(e.status!==t.expect.status&&s.push({type:"status",field:"status",expected:t.expect.status,actual:e.status,message:`Step ${t.id}: status is ${e.status}, expected ${t.expect.status}`}),t.expect.body?.has){let n=e.body;for(let o of t.expect.body.has)(!n||typeof n!="object"||!(o in n))&&s.push({type:"body.has",field:o,expected:true,actual:false,message:`Step ${t.id}: body missing key '${o}'`});}if(t.expect.body?.match){let n=e.body;for(let[o,r]of Object.entries(t.expect.body.match)){let i=n?Xs(n,o):void 0;JSON.stringify(i)!==JSON.stringify(r)&&s.push({type:"body.match",field:o,expected:r,actual:i??null,message:`Step ${t.id}: '${o}' is ${JSON.stringify(i??null)}, expected ${JSON.stringify(r)}`});}}if(t.signals&&t.signals.length>0){let n=e.signals_fired||[];for(let o of t.signals)n.includes(o)||s.push({type:"signal",field:"signals_fired",expected:o,actual:n,message:`Step ${t.id}: signal '${o}' was not fired`});}if(t.gates.length>0&&e.gates_traversed)for(let n of t.gates)e.gates_traversed.includes(n)||s.push({type:"gate",field:"gates_traversed",expected:n,actual:e.gates_traversed,message:`Step ${t.id}: gate '${n}' was not traversed`});return s}async function Ir(t,e={}){let s=[];try{let{SentinelStorage:a}=await import('./dist-W3XCATBJ.js'),c=new a,d=(c.queryEvents?.({schemaId:"paradigm-personas",eventType:"persona.step.complete",scopeValue:t.id,limit:500})||[]).filter(g=>{let h=JSON.parse(g.data_json||"{}");return !(e.run_id&&h.run_id!==e.run_id||e.chain_id&&h.chain_id!==e.chain_id||e.environment&&h.environment!==e.environment)}),p=(c.queryEvents?.({schemaId:"paradigm-personas",eventType:"persona.step.fail",scopeValue:t.id,limit:500})||[]).filter(g=>{let h=JSON.parse(g.data_json||"{}");return !(e.run_id&&h.run_id!==e.run_id||e.chain_id&&h.chain_id!==e.chain_id||e.environment&&h.environment!==e.environment)}),m=new Map;for(let g of [...d,...p]){let h=JSON.parse(g.data_json||"{}");h.step_id&&m.set(h.step_id,h);}for(let g of t.journey){let h=m.get(g.id);if(!h){s.push({step_id:g.id,matched:!1,assertions:[],message:`No Sentinel event found for step '${g.id}' \u2014 step was never exercised`});continue}let x=qs(g,{status:h.status,body:h.body,gates_traversed:h.gates_traversed,signals_fired:h.signals_fired});s.push({step_id:g.id,matched:!0,passed:x.length===0,assertions:x});}}catch{for(let a of t.journey)s.push({step_id:a.id,matched:false,assertions:[],message:"Sentinel unavailable \u2014 cannot validate events"});}let n=s.filter(a=>a.matched).length,o=s.filter(a=>a.passed).length,r=s.filter(a=>a.matched&&!a.passed).length,i=s.reduce((a,c)=>a+c.assertions.length,0);return {run_id:e.run_id,environment:e.environment,steps:s,summary:{total_steps:t.journey.length,matched:n,unmatched:t.journey.length-n,passed:o,failed:r,assertion_failures:i}}}var se=".paradigm/protocols",Qt="index.yaml";async function Ge(t){let e=k.join(t,se);if(!S.existsSync(e))return [];let s=S.readdirSync(e).filter(o=>o.endsWith(".protocol")).sort(),n=[];for(let o of s)try{let r=S.readFileSync(k.join(e,o),"utf8"),i=D.load(r);i?.id&&i?.name&&n.push(i);}catch{}return n}async function Vs(t,e){let s=e.replace(/^P-/,""),n=k.join(t,se,`${s}.protocol`);if(S.existsSync(n))try{let r=S.readFileSync(n,"utf8");return D.load(r)}catch{return null}return (await Ge(t)).find(r=>r.id===e)||null}async function Pr(t){let e=k.join(t,se,Qt);if(!S.existsSync(e))return null;try{let s=S.readFileSync(e,"utf8");return D.load(s)}catch{return null}}async function Ar(t,e,s=3){let n=await Ge(t);if(n.length===0)return [];let o=Js(e);if(o.length===0)return [];let r=[];for(let i of n){let a=0;for(let d of i.trigger){let u=d.toLowerCase();for(let p of o)u.includes(p)&&(a+=3);}for(let d of i.tags){let u=d.toLowerCase();for(let p of o)(u.includes(p)||p.includes(u))&&(a+=2);}let c=i.name.toLowerCase(),l=i.description.toLowerCase();for(let d of o)c.includes(d)&&(a+=1),l.includes(d)&&(a+=1);for(let d of i.steps)if(d.notes){let u=d.notes.toLowerCase();for(let p of o)u.includes(p)&&(a+=.5);}a>0&&r.push({protocol:i,score:a});}return r.sort((i,a)=>a.score-i.score),r.slice(0,s)}async function jr(t,e){let s=k.join(t,se);S.existsSync(s)||S.mkdirSync(s,{recursive:true});let n=Qs(e.name),o=`P-${n}`,r=new Date().toISOString(),i={id:o,name:e.name,description:e.description,trigger:e.trigger,tags:e.tags,symbols:e.symbols||[],exemplar:e.exemplar,steps:e.steps,recorded_from:e.recorded_from,recorded_at:r,last_verified:r,verified_by:e.verified_by||"claude-opus-4-6",status:"current"},a=k.join(s,`${n}.protocol`);return S.writeFileSync(a,D.dump(i,{lineWidth:-1,noRefs:true}),"utf8"),o}async function Lr(t,e,s,n=false){let o=await Vs(t,e);if(!o)return false;s.name!==void 0&&(o.name=s.name),s.description!==void 0&&(o.description=s.description),s.trigger!==void 0&&(o.trigger=s.trigger),s.tags!==void 0&&(o.tags=s.tags),s.symbols!==void 0&&(o.symbols=s.symbols),s.exemplar!==void 0&&(o.exemplar=s.exemplar),s.steps!==void 0&&(o.steps=s.steps),s.status!==void 0&&(o.status=s.status),s.verified_by!==void 0&&(o.verified_by=s.verified_by),n&&(o.last_verified=new Date().toISOString(),o.verified_by=s.verified_by||"claude-opus-4-6");let r=e.replace(/^P-/,""),i=k.join(t,se,`${r}.protocol`);return S.writeFileSync(i,D.dump(o,{lineWidth:-1,noRefs:true}),"utf8"),true}function Ys(t,e){let s=[],n="current";if(e.exemplar){let o=k.join(t,e.exemplar);S.existsSync(o)?S.statSync(o).mtime.toISOString()>e.last_verified&&(s.push(`Exemplar modified since last verified: ${e.exemplar}`),n!=="broken"&&(n="stale")):(s.push(`Exemplar missing: ${e.exemplar}`),n="broken");}for(let o of e.steps){if(o.template_from){let r=k.join(t,o.template_from);S.existsSync(r)||(s.push(`Template file missing: ${o.template_from}`),n="broken");}if(o.action==="modify"&&o.target){let r=k.join(t,o.target);!o.target.includes("{")&&!S.existsSync(r)&&(s.push(`Modify target missing: ${o.target}`),n="broken");}}return {status:n,issues:s}}async function Zt(t){let e=await Ge(t),s=[],n=0,o=0,r=0;for(let c of e){let l=Ys(t,c);if(c.status!==l.status){c.status=l.status;let d=c.id.replace(/^P-/,""),u=k.join(t,se,`${d}.protocol`);S.existsSync(u)&&S.writeFileSync(u,D.dump(c,{lineWidth:-1,noRefs:true}),"utf8");}switch(l.status){case "current":n++;break;case "stale":o++;break;case "broken":r++;break}s.push({id:c.id,name:c.name,status:l.status,last_verified:c.last_verified,trigger:c.trigger,tags:c.tags});}let i={version:"1.0",generated:new Date().toISOString(),protocols:s,health:{total:e.length,current:n,stale:o,broken:r}},a=k.join(t,se);if(e.length>0){S.existsSync(a)||S.mkdirSync(a,{recursive:true});let c=k.join(a,Qt);S.writeFileSync(c,D.dump(i,{lineWidth:-1,noRefs:true}),"utf8");}return i}function Or(t,e,s){if(!e||e.length<2)return null;let n={};for(let o of e){let r=k.dirname(o);n[r]||(n[r]=[]),n[r].push(o);}for(let[o,r]of Object.entries(n)){if(r.length<2)continue;let i=k.join(t,o);if(!S.existsSync(i))continue;let c=S.readdirSync(i).filter(l=>{let d=k.extname(l);return [".ts",".tsx",".js",".jsx",".rs",".py"].includes(d)}).filter(l=>!r.some(d=>k.basename(d)===l));if(c.length>0){let l=k.join(o,c[0]),d=[...r.map(u=>({action:"create",target:u})),...s.map(u=>({action:"modify",target:u}))];return {hint:`This session created ${r.length} new files in ${o}/ following existing patterns. Consider recording a protocol.`,draft:{name:`Add a ${k.basename(o).replace(/s$/,"")}`,exemplar:l,steps:d}}}}return null}function Js(t){return t.toLowerCase().replace(/[^a-z0-9\s-]/g," ").split(/\s+/).filter(e=>e.length>1).filter(e=>!Ks.has(e))}var Ks=new Set(["a","an","the","is","are","was","were","be","been","to","of","in","for","on","with","at","by","from","it","this","that","and","or","but","if","then","so","as","do","does","did","will","would","can","could","should","may","might","must","shall","i","me","my","we","our","you","your","he","she","how","what","when","where","which","who","whom"]);function Qs(t){return t.toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-|-$/g,"")}var ee=".paradigm/university",Z="content",Xe="notes",ve="policies",Ee="quizzes",Te="paths",en="diplomas",tn="index.yaml",Zs="config.yaml",nn={name:"Project University",tagline:"Learn the codebase",institution:"Paradigm"},sn={primary:"#6366f1",secondary:"#8b5cf6",accent:"#f59e0b",background:"#0f172a",surface:"#1e293b",text:"#f8fafc",textMuted:"#94a3b8",success:"#22c55e",error:"#ef4444",font:"Inter, system-ui, sans-serif"},Be={branding:nn,theme:sn,content:{categories:[],defaultDifficulty:"beginner",requireApproval:false},diplomas:{includeGlobalPLSAT:true,customCertStyle:null}};function qe(t){let e=k.join(t,ee,Zs);if(!S.existsSync(e))return {...Be};try{let s=S.readFileSync(e,"utf8"),n=D.load(s);return n?{branding:{...nn,...n.branding||{}},theme:{...sn,...n.theme||{}},content:{categories:n.content?.categories||[],defaultDifficulty:n.content?.defaultDifficulty||"beginner",requireApproval:n.content?.requireApproval??!1,defaultCategory:n.content?.defaultCategory},diplomas:{includeGlobalPLSAT:n.diplomas?.includeGlobalPLSAT??!0,customCertStyle:n.diplomas?.customCertStyle??null}}:{...Be}}catch{return {...Be}}}function _e(t){let e=k.join(t,ee,tn);if(!S.existsSync(e))return null;try{let s=S.readFileSync(e,"utf8");return D.load(s)}catch{return null}}function on(t){let e=t.match(/^---\n([\s\S]*?)\n---\n([\s\S]*)$/);if(!e)return null;try{return {frontmatter:D.load(e[1]),body:e[2].trim()}}catch{return null}}function eo(t,e){return `---
107
+ ${D.dump(t,{lineWidth:-1,noRefs:true,sortKeys:false})}---
108
+
109
+ ${e}
110
+ `}function Nr(t,e){let s=Ye(t,e,".md");if(!s)return null;try{let n=S.readFileSync(s,"utf8"),o=on(n);if(!o)return null;let r=o.frontmatter;return {frontmatter:oo(r),body:o.body}}catch{return null}}function Dr(t,e,s){let n=e.type==="policy"?ve:Xe,o=k.join(t,ee,Z,n);S.mkdirSync(o,{recursive:true});let r=k.join(o,`${e.id}.md`),i=eo(e,s);return S.writeFileSync(r,i,"utf8"),r}function to(t,e){let s=Ye(t,e,".yaml");if(!s)return null;try{let n=S.readFileSync(s,"utf8"),o=D.load(n);return !o||!o.id?null:ro(o)}catch{return null}}function Mr(t,e){let s=k.join(t,ee,Z,Ee);S.mkdirSync(s,{recursive:true});let n=k.join(s,`${e.id}.yaml`);return S.writeFileSync(n,D.dump(e,{lineWidth:-1,noRefs:true}),"utf8"),n}function rn(t,e){let s=Ye(t,e,".yaml");if(!s)return null;try{let n=S.readFileSync(s,"utf8"),o=D.load(n);return !o||!o.id?null:o}catch{return null}}function Ur(t,e){let s=k.join(t,ee,Z,Te);S.mkdirSync(s,{recursive:true});let n=k.join(s,`${e.id}.yaml`);return S.writeFileSync(n,D.dump(e,{lineWidth:-1,noRefs:true}),"utf8"),n}function an(t,e){let s=k.join(t,ee,en);if(!S.existsSync(s))return [];let n=[];try{let o=S.readdirSync(s).filter(r=>r.endsWith(".yaml"));for(let r of o)try{let i=S.readFileSync(k.join(s,r),"utf8"),a=D.load(i);if(!a||!a.id||e?.student&&a.student!==e.student||e?.type&&a.type!==e.type)continue;n.push(a);}catch{}}catch{}return n.sort((o,r)=>r.earnedAt.localeCompare(o.earnedAt))}function zr(t,e){let s=_e(t);if(!s)return [];let n=[...s.entries];if(e.type&&(n=n.filter(r=>r.type===e.type)),e.tag&&(n=n.filter(r=>r.tags.some(i=>i.startsWith(e.tag)))),e.difficulty&&(n=n.filter(r=>r.difficulty===e.difficulty)),e.symbol&&(n=n.filter(r=>r.symbols.some(i=>i===e.symbol))),e.author&&(n=n.filter(r=>r.author===e.author)),e.query){let r=e.query.toLowerCase();n=n.filter(i=>i.title.toLowerCase().includes(r)||i.id.toLowerCase().includes(r)||i.tags.some(a=>a.toLowerCase().includes(r)));}if(e.category&&(n=n.filter(r=>r.category===e.category)),e.track){let r=qe(t),i=new Map;for(let a of r.content.categories)i.set(a.id,a.track||"core");n=n.filter(a=>(a.category&&i.get(a.category)||"core")===e.track);}let o=e.limit||20;return n.slice(0,o)}function Ve(t){let e=k.join(t,ee),s=k.join(e,Z),n=[];for(let d of [Xe,ve]){let u=k.join(s,d);if(S.existsSync(u))try{for(let p of S.readdirSync(u).filter(m=>m.endsWith(".md")))try{let m=S.readFileSync(k.join(u,p),"utf8"),g=on(m);if(!g)continue;let h=g.frontmatter;n.push({id:h.id||p.replace(".md",""),title:h.title||p,type:h.type||(d===ve?"policy":"note"),author:h.author||"unknown",created:h.created||"",updated:h.updated||"",tags:Array.isArray(h.tags)?h.tags:[],symbols:Array.isArray(h.symbols)?h.symbols:[],difficulty:h.difficulty||"beginner",file:`${Z}/${d}/${p}`,...h.category?{category:h.category}:{}});}catch{}}catch{}}let o=k.join(s,Ee);if(S.existsSync(o))try{for(let d of S.readdirSync(o).filter(u=>u.endsWith(".yaml")))try{let u=S.readFileSync(k.join(o,d),"utf8"),p=D.load(u);if(!p||!p.id)continue;n.push({id:p.id,title:p.title||d,type:"quiz",author:p.author||"unknown",created:p.created||"",updated:p.updated||"",tags:p.tags||[],symbols:p.symbols||[],difficulty:p.difficulty||"beginner",file:`${Z}/${Ee}/${d}`,...p.category?{category:p.category}:{}});}catch{}}catch{}let r=k.join(s,Te);if(S.existsSync(r))try{for(let d of S.readdirSync(r).filter(u=>u.endsWith(".yaml")))try{let u=S.readFileSync(k.join(r,d),"utf8"),p=D.load(u);if(!p||!p.id)continue;n.push({id:p.id,title:p.title||d,type:"path",author:p.author||"unknown",created:p.created||"",updated:p.updated||"",tags:p.tags||[],symbols:[],file:`${Z}/${Te}/${d}`,...p.category?{category:p.category}:{}});}catch{}}catch{}let i=0,a=k.join(e,en);if(S.existsSync(a))try{i=S.readdirSync(a).filter(d=>d.endsWith(".yaml")).length;}catch{}let c={version:"1.0",generatedAt:new Date().toISOString(),totalContent:n.length,entries:n,diplomaCount:i};S.mkdirSync(e,{recursive:true});let l=k.join(e,tn);return S.writeFileSync(l,D.dump(c,{lineWidth:-1,noRefs:true}),"utf8"),c}function Hr(t,e){let s=_e(t)||Ve(t),n=[],o=s.entries;e?.id&&(o=o.filter(l=>l.id===e.id));let r=null;e?.deep&&(r=cn(t));let i=new Set(s.entries.map(l=>l.id));for(let l of o){if(l.title||n.push({contentId:l.id,severity:"error",check:"missing-title",message:"Content is missing a title",fix:"Add a title field to the content frontmatter"}),l.type==="quiz"&&no(t,l.id,n),l.type==="path"&&so(t,l.id,i,n),r&&l.symbols.length>0){qe(t).content.categories.find(m=>m.id===l.category)?.validationStrictness==="relaxed";for(let m of l.symbols)r.has(m)||n.push({contentId:l.id,severity:"warning",check:"broken-symbol-ref",message:`Symbol "${m}" not found in scan-index`,fix:`Remove or update the symbol reference in ${l.id}`});}e?.deep&&l.symbols.length>0&&l.updated&&ao(t,l,n);}let a=an(t);for(let l of a)if(l.total>0&&l.percentage!==Math.round(l.score/l.total*1e4)/100){let d=Math.round(l.score/l.total*1e4)/100;Math.abs(l.percentage-d)>.1&&n.push({contentId:l.id,severity:"warning",check:"diploma-score-mismatch",message:`Diploma percentage ${l.percentage} doesn't match score ${l.score}/${l.total} (expected ${d})`});}let c=io(t,s);return {status:n.some(l=>l.severity==="error")?"errors":n.length>0?"warnings":"healthy",totalContent:s.totalContent,checked:o.length,issues:n,symbolCoverage:c}}function no(t,e,s){let n=to(t,e);if(!n){s.push({contentId:e,severity:"error",check:"unreadable-quiz",message:"Quiz file could not be parsed"});return}(!n.passThreshold||n.passThreshold<0||n.passThreshold>1)&&s.push({contentId:e,severity:"warning",check:"invalid-pass-threshold",message:`passThreshold should be between 0 and 1, got ${n.passThreshold}`,fix:"Set passThreshold to a value between 0.0 and 1.0"});for(let o of n.questions){if(!o.choices||typeof o.choices!="object"){s.push({contentId:e,severity:"error",check:"invalid-quiz-choices",message:`Question ${o.id} has no choices defined`});continue}(!o.correct||!(o.correct in o.choices))&&s.push({contentId:e,severity:"error",check:"invalid-quiz-answer",message:`Question ${o.id}: correct answer "${o.correct}" not found in choices [${Object.keys(o.choices).join(", ")}]`,fix:`Set correct to one of: ${Object.keys(o.choices).join(", ")}`});}}function so(t,e,s,n){let o=rn(t,e);if(!o){n.push({contentId:e,severity:"error",check:"unreadable-path",message:"Learning path file could not be parsed"});return}for(let r of o.steps)r.content.startsWith("plsat:")||s.has(r.content)||n.push({contentId:e,severity:"error",check:"broken-path-step",message:`Learning path step references "${r.content}" which doesn't exist`,fix:`Create content with id "${r.content}" or remove this step`});}function Wr(t,e){let s=_e(t);if(!s)return [];let n=[];for(let o of s.entries)if(o.symbols.includes(e)){let r=ln(t,o,e);n.push({id:o.id,title:o.title,type:o.type,stale:r});}return n}function Gr(t,e){let s=_e(t);if(!s)return {paths:[],suggestedContent:[],extracurricular:[],diplomaCount:0,totalContent:0};let n=qe(t),o=new Set;for(let p of n.content.categories)p.excludeFromOnboarding&&o.add(p.id);let r=s.entries.filter(p=>!p.category||!o.has(p.category)),i=s.entries.filter(p=>p.category&&o.has(p.category)),a=r.filter(p=>p.type==="path"),c=e?an(t,{student:e}):[],l=new Set(c.map(p=>p.source)),d=a.map(p=>{let m=rn(t,p.id);return {id:p.id,title:p.title,steps:m?.steps.length||0,completed:l.has(p.id)}}),u=r.filter(p=>p.type!=="path"&&(p.difficulty==="beginner"||p.tags.includes("onboarding"))).slice(0,10);return {paths:d,suggestedContent:u,extracurricular:i,diplomaCount:c.length,totalContent:s.totalContent}}function Ye(t,e,s){let n=k.join(t,ee,Z);for(let o of [Xe,ve,Ee,Te]){let r=k.join(n,o,`${e}${s}`);if(S.existsSync(r))return r}return null}function oo(t){return {id:t.id||"",title:t.title||"",type:t.type||"note",author:t.author||"unknown",created:t.created||"",updated:t.updated||"",tags:Array.isArray(t.tags)?t.tags:[],symbols:Array.isArray(t.symbols)?t.symbols:[],difficulty:t.difficulty||"beginner",estimatedMinutes:t.estimatedMinutes,prerequisites:Array.isArray(t.prerequisites)?t.prerequisites:[],...t.category?{category:t.category}:{}}}function ro(t){return {...t,tags:t.tags||[],symbols:t.symbols||[],difficulty:t.difficulty||"beginner",passThreshold:t.passThreshold??.7,questions:t.questions||[]}}function cn(t){let e=new Set,s=k.join(t,".paradigm","scan-index.json");if(!S.existsSync(s))return e;try{let n=S.readFileSync(s,"utf8"),o=JSON.parse(n);if(o.symbols&&Array.isArray(o.symbols))for(let r of o.symbols)r.symbol&&e.add(r.symbol);}catch{}return e}function io(t,e){let s=cn(t),n=new Set;for(let r of e.entries)for(let i of r.symbols)s.has(i)&&n.add(i);let o=s.size;return {totalSymbols:o,coveredByContent:n.size,percentage:o>0?Math.round(n.size/o*100):0}}function ln(t,e,s){if(!e.updated)return false;let n=new Date(e.updated).getTime();if(isNaN(n))return false;let o=k.join(t,".paradigm","scan-index.json");if(!S.existsSync(o))return false;try{let r=S.readFileSync(o,"utf8"),i=JSON.parse(r);if(i.symbols&&Array.isArray(i.symbols)){for(let a of i.symbols)if(a.symbol===s&&a.filePath){let c=k.join(t,a.filePath);if(S.existsSync(c)&&S.statSync(c).mtime.getTime()>n)return !0}}}catch{}return false}function ao(t,e,s){for(let n of e.symbols)if(ln(t,e,n)){s.push({contentId:e.id,severity:"warning",check:"stale-content",message:`Content may be stale: symbol "${n}" was updated after content was last modified`,fix:`Review and update ${e.id} to reflect changes to ${n}`});break}}var co="PARADIGM_STRICT";function $e(){let t=process.env[co];if(t===void 0||t==="")return false;let e=t.toLowerCase();return e==="1"||e==="true"||e==="yes"||e==="on"}var dn=new Set(["duplicate-key-detected"]);function lo(t){let e=t.trim();if(e.includes("/")||e.includes("\\")){let s=e.split(/[/\\]/);e=s[s.length-1]||"unknown";}return e.length>40&&(e=e.slice(0,40)),e||"unknown"}var Re=class{transforms=new Map;record(e,s,n=1){let o=lo(s),r=`${e}::${o}`,i=this.transforms.get(r);i?i.count+=n:this.transforms.set(r,{kind:e,surface:o,count:n});}report(){let e=Array.from(this.transforms.values()).sort((n,o)=>n.kind!==o.kind?n.kind.localeCompare(o.kind):n.surface.localeCompare(o.surface)),s=e.filter(n=>dn.has(n.kind)).reduce((n,o)=>n+o.count,0);return {reindex_ts:new Date().toISOString(),transformations:e,lossy_count:s,strict_mode:$e()}}hasLossy(){for(let e of this.transforms.values())if(dn.has(e.kind))return true;return false}totalCount(){let e=0;for(let s of this.transforms.values())e+=s.count;return e}};b$1();var uo={"@":{category:"features",prefix:"@"},"#":{category:"components",prefix:"#"},"^":{category:"gates",prefix:"^"},$:{category:"flows",prefix:"$"},"&":{category:"integrations",prefix:"&"},"!":{category:"signals",prefix:"!"},"%":{category:"state",prefix:"%"}},po={features:["src/features/","features/","app/","src/app/","src/modules/","modules/"],components:["src/components/","components/","src/lib/","lib/","src/ui/","ui/"],gates:["middleware/","src/middleware/","auth/","src/auth/","guards/","src/guards/"],flows:["flows/","src/flows/","workflows/","src/workflows/","sagas/","src/sagas/"],integrations:["integrations/","src/integrations/","external/","src/external/","vendors/"],signals:["events/","src/events/","handlers/","src/handlers/"],state:["stores/","src/stores/","state/","src/state/","reducers/","src/reducers/"]},fo={config:[".paradigm/config.yaml","package.json","tsconfig.json",".env.example"],entry:["src/index.ts","src/index.tsx","src/main.ts","src/main.tsx","index.ts","main.ts","src/app.ts","src/app.tsx"],types:["src/types/","types/","src/types.ts","types.ts"]},Je={always:["node_modules/","dist/","build/",".git/",".next/",".nuxt/",".cache/","*.lock","*.log"],unless_testing:["**/*.test.ts","**/*.test.tsx","**/*.spec.ts","**/*.spec.tsx","__tests__/","test/","tests/"],unless_docs:["docs/","*.md","README*","CHANGELOG*"]};function di(){return [{name:"paradigm_reindex",description:"Rebuild scan-index.json, navigator.yaml, and flow-index.json from .purpose files. Call after modifying paradigm files or at the end of a work session to ensure static index files are fresh. Returns counts of indexed symbols, files processed, and any errors. ~150 tokens.",inputSchema:{type:"object",properties:{}},annotations:{readOnlyHint:false,destructiveHint:true},aliases:["rebuild","refresh","rescan","regenerate index","update index"]}]}async function ui(t,e,s,n){if(t!=="paradigm_reindex")return {handled:false,text:""};try{let o=await go(s.rootDir,s);await n(),At.clear(),Lt();let r=(o.integrityReport?.brokenReferences?.length||0)+(o.integrityReport?.duplicateSymbols?.length||0)+(o.componentAnchorIssues||0)+(o.crossFileIssues||0),i={success:!0,symbolCount:o.symbolCount,breakdown:o.breakdown,flowCount:o.flowCount,filesWritten:o.filesWritten.length,...o.aspectGraphStats?{aspects:o.aspectGraphStats.aspects,loreLinks:o.aspectGraphStats.loreLinks}:{},...o.protocolHealth?{protocols:o.protocolHealth.total,staleProtocols:o.protocolHealth.stale}:{},...r>0?{issues:r}:{}};o.consistency&&(i.consistency=o.consistency);let a=JSON.stringify(i,null,2);return Fe(a.length,t),{handled:!0,text:a}}catch(o){let r=JSON.stringify({error:o.message},null,2);return Fe(r.length,t),{handled:true,text:r}}}async function go(t,e){let s=[],n=new Re,o;e?o=e.aggregation:o=await It(t);let r=e?.projectName||k.basename(t),i=k.join(t,".paradigm");S.existsSync(i)||S.mkdirSync(i,{recursive:true}),mo(t,n),ho(o.purposeFiles,n);let a=Le({symbols:o.symbols,purposeFiles:o.purposeFiles,portalFiles:o.portalFiles},{projectName:r}),c=k.join(i,"scan-index.json");S.writeFileSync(c,Oe(a),"utf8"),s.push(".paradigm/scan-index.json");let l=yo(t,o),d=k.join(i,"navigator.yaml");S.writeFileSync(d,D.dump(l,{indent:2,lineWidth:120,noRefs:true,sortKeys:false}),"utf8"),s.push(".paradigm/navigator.yaml");let u=Eo(t,o.purposeFiles),p=0;if(u&&Object.keys(u.flows).length>0){let v=k.join(i,"flow-index.json");S.writeFileSync(v,JSON.stringify(u,null,2),"utf8"),s.push(".paradigm/flow-index.json"),p=Object.keys(u.flows).length;}let m;try{let v=await Bt(t);qt(v,o.symbols,t);let F=await Yt(v,t),oe=await Jt(v,t),fn=v.exec("SELECT COUNT(*) FROM aspects")[0]?.values[0]?.[0]??0,gn=v.exec("SELECT COUNT(*) FROM anchors")[0]?.values[0]?.[0]??0,mn=v.exec("SELECT COUNT(*) FROM edges")[0]?.values[0]?.[0]??0;Xt(v,t),s.push(".paradigm/aspect-graph.db"),m={aspects:fn,anchors:gn,edges:mn,loreLinks:F};}catch{}let g=0;try{let v=await fe(t);g=Object.keys(v.personas).length,g>0&&s.push(".paradigm/personas/index.yaml");}catch{}let h;try{let v=await Zt(t);v.health.total>0&&(h=v.health,s.push(".paradigm/protocols/index.yaml"));}catch{}let x;try{let v=k.join(t,".paradigm","university");if(S.existsSync(v)){let F=Ve(t);(F.totalContent>0||F.diplomaCount>0)&&(x={totalContent:F.totalContent,diplomaCount:F.diplomaCount},s.push(".paradigm/university/index.yaml"));}}catch{}let T;try{T=a$1(o,t);}catch{}let E;try{let v=b$4(o.symbols,t),F=v.missing+v.outOfBounds;F>0&&(E=F);}catch{}let _;try{_=c$2(o.purposeFiles,t);}catch{}let w;try{let v=[];for(let F of o.purposeFiles){let oe=Pe(F);oe.data&&v.push({filePath:F,data:oe.data});}if(v.length>0){let oe=St(v).issues.length;oe>0&&(w=oe);}}catch{}let b={};for(let v of o.symbols)b[v.type]=(b[v.type]||0)+1;let C={};for(let v of o.symbols)v.type==="component"&&v.componentType&&(C[v.componentType]=(C[v.componentType]||0)+1);let O=n.report();try{let v=k.join(i,"manifest.consistency.json");S.writeFileSync(v,JSON.stringify(O,null,2),"utf-8"),s.push(".paradigm/manifest.consistency.json");}catch{a$2.component("#reindex").warn("failed to write consistency manifest",{stage:"manifest-write"});}if($e()&&n.hasLossy())throw new Error(`reindex aborted: ${O.lossy_count} lossy transformation(s) detected under PARADIGM_STRICT=1. See .paradigm/manifest.consistency.json.`);return {action:"reindex",filesWritten:s,symbolCount:o.symbols.length,breakdown:b,flowCount:p,aspectGraphStats:m,personaCount:g,protocolHealth:h,consistency:O,...Object.keys(C).length>0?{componentTypeBreakdown:C}:{},...x?{universityStats:x}:{},...T?{integrityReport:T}:{},...E!==void 0?{componentAnchorIssues:E}:{},..._?{purposeHealth:_}:{},...w!==void 0?{crossFileIssues:w}:{}}}function mo(t,e){let s=k.join(t,"portal.yaml");if(!S.existsSync(s))return;let n;try{n=S.readFileSync(s,"utf-8");}catch{return}try{D.load(n);}catch(c){(c?.reason?.toLowerCase()||"").includes("duplicate")&&e.record("duplicate-key-detected","portal.yaml");return}let o;try{o=D.load(n,{schema:D.FAILSAFE_SCHEMA});}catch{return}if(!o||typeof o!="object")return;let r=o,i=r.gates;if(i&&typeof i=="object"&&!Array.isArray(i)){let c=0;for(let l of Object.keys(i))l.startsWith("^")&&c++;c>0&&e.record("prefix-stripped","portal.yaml",c);}else Array.isArray(i)&&i.length>0&&e.record("array-coerced","portal.yaml");let a=r.routes;Array.isArray(a)&&a.length>0&&e.record("array-coerced","portal.yaml"),r.version||e.record("default-applied","portal.yaml");}function ho(t,e){for(let s of t){let n;try{n=S.readFileSync(s,"utf-8");}catch{continue}try{D.load(n);}catch(d){(d?.reason?.toLowerCase()||"").includes("duplicate")&&e.record("duplicate-key-detected","purpose.yaml");continue}let o;try{o=D.load(n,{schema:D.FAILSAFE_SCHEMA});}catch{continue}if(!o||typeof o!="object")continue;let r=o,i=["components","features","gates","signals","aspects","states"],a=0;for(let d of i)Array.isArray(r[d])&&a++;a>0&&e.record("array-coerced","purpose.yaml",a);let c=(d,u)=>{if(!d||typeof d!="object"||Array.isArray(d))return 0;let p=0;for(let m of Object.keys(d))m.startsWith(u)&&p++;return p},l=c(r.gates,"^")+c(r.signals,"!")+c(r.aspects,"~")+c(r.components,"#")+c(r.features,"#");l>0&&e.record("prefix-stripped","purpose.yaml",l);}}function yo(t,e){let s={};for(let n of e.symbols)if(n.type==="component"&&n.componentType){let o=n.componentType;s[o]||(s[o]=[]),s[o].push(n.symbol);}return {version:"1.0",generated:new Date().toISOString(),structure:wo(t),key_files:bo(t),skip_patterns:So(t),symbols:vo(e.symbols,e.purposeFiles),...Object.keys(s).length>0?{symbolsByComponentType:s}:{}}}function wo(t){let e={};for(let[s,n]of Object.entries(po)){let o=n.filter(r=>S.existsSync(k.join(t,r)));if(o.length>0){let r=Object.values(uo).find(i=>i.category===s);e[s]={paths:o,symbol:r?.prefix||"@"};}}return e}function bo(t){let e={};for(let[s,n]of Object.entries(fo)){let o=n.filter(r=>S.existsSync(k.join(t,r)));o.length>0&&(e[s]=o);}return e.config||(e.config=[]),e.entry||(e.entry=[]),e.types||(e.types=[]),e}function So(t){let e={always:[...Je.always],unless_testing:[...Je.unless_testing],unless_docs:[...Je.unless_docs]},s=k.join(t,".gitignore");if(S.existsSync(s))try{let o=S.readFileSync(s,"utf8").split(`
111
+ `).map(r=>r.trim()).filter(r=>r&&!r.startsWith("#")).filter(r=>r.endsWith("/")||r.includes("*")||["node_modules","dist","build",".cache"].some(i=>r.includes(i))).slice(0,20);for(let r of o)e.always.includes(r)||e.always.push(r);}catch{}return e}function xo(t){switch(t){case "feature":return "@";case "component":return "#";case "gate":return "^";case "flow":return "$";case "integration":return "&";case "signal":return "!";case "state":return "%";case "idea":return "?";case "deprecated":return "~";case "aspect":return "~";default:return "@"}}function vo(t,e,s){let n={};for(let o of t){let i=`${xo(o.type)}${o.id}`;if(o.filePath)n[i]=o.filePath;else {let a=e.find(c=>k.dirname(c).toLowerCase().includes(o.id.toLowerCase()));a&&(n[i]=k.dirname(a)+"/");}}return n}function Eo(t,e){let s={},n={};for(let o of e)try{let r=S.readFileSync(o,"utf8"),i=D.load(r);if(!i?.flows)continue;if(Array.isArray(i.flows))for(let a of i.flows){let c=a;if(!c.name)continue;let l=`$${c.name}`,d=un(c.steps);d.length>0&&(s[l]={id:l,description:c.description||"",steps:d,definedIn:k.relative(t,o)},pn(l,d,n));}else for(let[a,c]of Object.entries(i.flows)){let l=a.startsWith("$")?a:`$${a}`,d=un(c.steps);d.length>0&&(s[l]={id:l,description:c.description||"",trigger:c.trigger,steps:d,validation:c.validation,definedIn:k.relative(t,o)},pn(l,d,n));}}catch{}return Object.keys(s).length===0?null:{version:"1.0",generatedAt:new Date().toISOString(),flows:s,symbolToFlows:n}}function un(t){if(!t||!Array.isArray(t))return [];let e=[];for(let s=0;s<t.length;s++){let n=t[s];if(typeof n=="object"&&n!==null){let o=n,r=o.action||o.description||o.component||"";r&&e.push({id:o.id||`step-${s+1}`,action:r,symbol:o.symbol||o.component,expect:o.expect});}}return e}function pn(t,e,s){for(let n of e)n.symbol&&(s[n.symbol]||(s[n.symbol]=[]),s[n.symbol].includes(t)||s[n.symbol].push(t));}export{Or as $,Kt as A,Er as B,Tr as C,_r as D,$r as E,Rr as F,kr as G,Ir as H,qe as I,Nr as J,Dr as K,to as L,Mr as M,rn as N,Ur as O,zr as P,Ve as Q,Hr as R,Wr as S,Gr as T,Ge as U,Vs as V,Pr as W,Ar as X,jr as Y,Lr as Z,Ys as _,jn as a,$e as aa,_o as b,Bt as ba,On as c,Xt as ca,Ro as d,dr as da,ye as e,ur as ea,Co as f,pr as fa,It as g,fr as ga,Fo as h,gr as ha,we as i,mr as ia,No as j,hr as ja,Do as k,yr as ka,Mo as l,Sr as la,Uo as m,di as ma,zo as n,ui as na,Ho as o,go as oa,Fe as p,Zo as q,er as r,tr as s,nr as t,sr as u,jt as v,At as w,ue as x,pe as y,vr as z};
@@ -3,7 +3,7 @@ import {c,a as a$1}from'./chunk-DOCDDDTD.js';import {e as e$1}from'./chunk-JQKKV
3
3
  \u{1FA7A} Paradigm Doctor
4
4
  `)),console.log(N?l.gray(`Running context audit checks...
5
5
  `):l.gray(`Checking Paradigm setup...
6
- `)));let I=a.command("doctor").start("Running health checks");if(!N){let E=function(t){let a=[];try{let n=e.readdirSync(t,{withFileTypes:!0});for(let r of n){if(r.name==="node_modules"||r.name==="dist"||r.name===".git")continue;let f=i.join(t,r.name);r.isDirectory()?a.push(...E(f)):r.name===".purpose"&&a.push(f);}}catch{}return a};let o=i.join(p,".paradigm");if(e.existsSync(o))if(e.statSync(o).isFile())s.push({name:".paradigm",status:"warn",message:"Legacy file format (should be directory)",fix:"paradigm upgrade --all"});else {s.push({name:".paradigm/",status:"ok",message:"Directory exists"});let a=i.join(o,"config.yaml");if(e.existsSync(a))try{let g=e.readFileSync(a,"utf8");e$1(g),s.push({name:".paradigm/config.yaml",status:"ok",message:"Valid YAML"});}catch(g){s.push({name:".paradigm/config.yaml",status:"error",message:`Invalid YAML: ${g.message}`,fix:"Check YAML syntax"});}else s.push({name:".paradigm/config.yaml",status:"missing",message:"Config file not found",fix:"paradigm init --force"});let n=["logger.md","scan.md","symbols.md"],r=i.join(o,"specs");if(e.existsSync(r))for(let g of n){let x=i.join(r,g);e.existsSync(x)?s.push({name:`.paradigm/specs/${g}`,status:"ok",message:"Present"}):s.push({name:`.paradigm/specs/${g}`,status:"missing",message:"Spec file not found",fix:"paradigm upgrade --all"});}else s.push({name:".paradigm/specs/",status:"missing",message:"Specs directory not found",fix:"paradigm upgrade --all"});let f=i.join(o,"docs");e.existsSync(f)?s.push({name:".paradigm/docs/",status:"ok",message:"Directory exists"}):s.push({name:".paradigm/docs/",status:"missing",message:"Docs directory not found",fix:"paradigm upgrade --all"});let h=i.join(o,"prompts");e.existsSync(h)?s.push({name:".paradigm/prompts/",status:"ok",message:"Directory exists"}):s.push({name:".paradigm/prompts/",status:"missing",message:"Prompts directory not found",fix:"paradigm upgrade --all"});let u=["specs","implementation-guides","prompts","decisions"],d=[];for(let g of u){let x=i.join(o,g);if(e.existsSync(x)&&e.statSync(x).isDirectory()){let k=i.join(x,".index.yaml");e.existsSync(k)||d.push(`.paradigm/${g}/`);}}d.length>0?s.push({name:"Docs-class indexes",status:"warn",message:`${d.length} director${d.length===1?"y":"ies"} missing .index.yaml: ${d.join(", ")}`,fix:"paradigm docs scaffold"}):s.push({name:"Docs-class indexes",status:"ok",message:"All docs-class directories have .index.yaml"});let y=i.join(o,"scan-index.json"),F=i.join(p,".paradigm-scan-index.json");if(e.existsSync(y)){let g=e.statSync(y),x=Date.now()-g.mtime.getTime(),k=Math.floor(x/(1e3*60*60));k>24?s.push({name:".paradigm/scan-index.json",status:"warn",message:`Stale (${k} hours old)`,fix:"paradigm index"}):s.push({name:".paradigm/scan-index.json",status:"ok",message:k>0?`${k} hours old`:"Fresh"});}else e.existsSync(F)?s.push({name:"scan-index",status:"warn",message:"Using legacy location",fix:"paradigm index"}):s.push({name:".paradigm/scan-index.json",status:"missing",message:"Not generated",fix:"paradigm index"});}else s.push({name:".paradigm/",status:"missing",message:"Not initialized",fix:"paradigm init"});let m=c(p);if(m.detected){let t=a$1(m.detected);if(t){let a=i.join(p,t.outputPath);e.existsSync(a)?s.push({name:t.outputPath,status:"ok",message:`Present (${m.detected})`}):s.push({name:t.outputPath,status:"missing",message:`Not generated for ${m.detected}`,fix:"paradigm sync"});}}let c$1=i.join(p,".premise");e.existsSync(c$1)?s.push({name:".premise",status:"ok",message:"Present"}):s.push({name:".premise",status:"missing",message:"Not found (optional)"});let v=i.join(p,".purpose");e.existsSync(v)?s.push({name:".purpose",status:"ok",message:"Present"}):s.push({name:".purpose",status:"warn",message:"Root .purpose not found",fix:"paradigm init"});let A=i.join(p,".paradigm","config.yaml");if(e.existsSync(A))try{let t=e.readFileSync(A,"utf8"),n=S.load(t)?.["purpose-required"];if(n&&Array.isArray(n)){let r=[];for(let f of n){if(!f.pattern)continue;let{glob:h}=await import('glob'),u=await h(f.pattern,{cwd:p,nodir:!1});for(let d of u){let y=i.join(p,d);try{e.statSync(y).isDirectory()&&!e.existsSync(i.join(y,".purpose"))&&r.push(d);}catch{}}}r.length>0?s.push({name:"Purpose-required",status:"warn",message:`${r.length} director${r.length===1?"y":"ies"} missing .purpose: ${r.join(", ")}`,fix:"Create .purpose files with paradigm_purpose_init + paradigm_purpose_add_component"}):s.push({name:"Purpose-required",status:"ok",message:"All required directories have .purpose files"});}}catch{}let q=/\[NEEDS CLARIFICATION:\s*[^\]]+\]/gi,R=0,Y=E(p);for(let t of Y)try{let n=e.readFileSync(t,"utf8").match(q);n&&(R+=n.length);}catch{}R>0?s.push({name:"Clarification markers",status:"warn",message:`${R} [NEEDS CLARIFICATION] marker${R>1?"s":""} found in .purpose files`,fix:"Resolve open clarification markers before shipping"}):Y.length>0&&s.push({name:"Clarification markers",status:"ok",message:"No unresolved markers"});let L=i.join(p,"portal.yaml");if(e.existsSync(L))try{let t=e.readFileSync(L,"utf8"),a=S.load(t);if(a?.version&&a?.gates){let n=Object.keys(a.gates||{}).length,r=Object.keys(a.routes||{}).length;s.push({name:"portal.yaml",status:"ok",message:`Valid (${n} gates, ${r} routes)`});}else s.push({name:"portal.yaml",status:"warn",message:"Missing version or gates section",fix:'Add version: "1.0" and gates: {} to portal.yaml'});}catch(t){s.push({name:"portal.yaml",status:"error",message:`Invalid YAML: ${t.message}`,fix:"Check YAML syntax in portal.yaml"});}if(e.existsSync(L))try{let{checkPortalCompliance:t,getComplianceSummary:a}=await import('./portal-compliance-4MG5F2GI.js'),n=await t(p),r=a(n);s.push({name:"Portal compliance",status:r.status,message:r.message,fix:r.status!=="ok"?"paradigm portal check":void 0});}catch{}let U=i.join(p,".paradigm","flows.yaml");if(e.existsSync(U))try{let t=e.readFileSync(U,"utf8"),a=S.load(t);if(a?.version&&a?.flows){let n=Object.keys(a.flows||{}).length,r=Object.entries(a.flows||{}).filter(([,f])=>!f?.steps||(f.steps?.length??0)===0);r.length>0?s.push({name:".paradigm/flows.yaml",status:"warn",message:`${n} flows defined, ${r.length} have no steps`,fix:"Add steps to empty flow definitions"}):s.push({name:".paradigm/flows.yaml",status:"ok",message:`Valid (${n} flows)`});}else s.push({name:".paradigm/flows.yaml",status:"warn",message:"Missing version or flows section",fix:'Ensure flows.yaml has version: "1.0" and flows: {}'});}catch(t){s.push({name:".paradigm/flows.yaml",status:"error",message:`Invalid YAML: ${t.message}`,fix:"Check YAML syntax in flows.yaml"});}let H=i.join(p,".paradigm","lore");if(e.existsSync(H))try{let t=e.readdirSync(H).filter(a=>a.endsWith(".yaml"));t.length===0?s.push({name:"Lore entries",status:"warn",message:"Lore directory exists but no entries found",fix:"Record a lore entry: paradigm lore record"}):s.push({name:"Lore entries",status:"ok",message:`${t.length} lore file${t.length>1?"s":""}`});}catch{s.push({name:"Lore entries",status:"warn",message:"Could not read lore directory"});}let G=i.join(p,".paradigm","university");if(e.existsSync(G))try{let t=i.join(G,"content"),a=0,n=0;if(e.existsSync(t))for(let r of ["notes","policies","quizzes","paths"]){let f=i.join(t,r);e.existsSync(f)&&(a+=e.readdirSync(f).filter(h=>h.endsWith(".md")||h.endsWith(".yaml")).length);}if(a===0)s.push({name:"University content",status:"warn",message:"University directory exists but no content found",fix:'Add content: paradigm university add note --title "Getting Started"'});else {let r=i.join(t,"quizzes");if(e.existsSync(r))for(let h of e.readdirSync(r).filter(u=>u.endsWith(".yaml")))try{let u=S.load(e.readFileSync(i.join(r,h),"utf8"));if(u?.questions)for(let d of u.questions)d.choices&&d.correct&&!(d.correct in d.choices)&&n++;}catch{}let f=i.join(t,"paths");if(e.existsSync(f))for(let h of e.readdirSync(f).filter(u=>u.endsWith(".yaml")))try{let u=S.load(e.readFileSync(i.join(f,h),"utf8"));if(u?.steps){for(let d of u.steps)if(d.content&&!d.content.startsWith("plsat:")){let y=!1;for(let F of ["notes","policies","quizzes","paths"]){let g=i.join(t,F);if(e.existsSync(g)&&e.readdirSync(g).some(k=>k.startsWith(d.content))){y=!0;break}}y||n++;}}}catch{}n>0?s.push({name:"University content",status:"warn",message:`${a} items, ${n} issue${n>1?"s":""}`,fix:"Run: paradigm university validate --deep"}):s.push({name:"University content",status:"ok",message:`${a} content item${a>1?"s":""}`});}}catch{s.push({name:"University content",status:"warn",message:"Could not read university directory"});}let _=i.join(p,".claude","hooks.json"),ss=i.join(p,"plugins","paradigm","hooks.json");if(e.existsSync(_)){let t=e.statSync(_),a=Date.now()-t.mtime.getTime(),n=Math.floor(a/(1e3*60*60*24));n>30?s.push({name:"Claude Code hooks",status:"warn",message:`Hooks are ${n} days old \u2014 may be outdated`,fix:"paradigm hooks install"}):s.push({name:"Claude Code hooks",status:"ok",message:n>0?`${n} days old`:"Fresh"});}else e.existsSync(ss)?s.push({name:"Claude Code hooks",status:"ok",message:"Using plugin hooks"}):s.push({name:"Claude Code hooks",status:"missing",message:"No hooks installed",fix:"paradigm hooks install"});let V=i.join(p,".paradigm","habits.yaml");if(e.existsSync(V))try{let t=e.readFileSync(V,"utf8"),a=S.load(t);if(a?.version&&Array.isArray(a?.habits)){let n=a.habits.filter(r=>r.enabled!==!1).length;s.push({name:"Habits config",status:"ok",message:`Valid (${n}/${a.habits.length} enabled)`});}else s.push({name:"Habits config",status:"warn",message:"Missing version or habits array",fix:"Regenerate habits.yaml with paradigm habits init"});}catch(t){s.push({name:"Habits config",status:"error",message:`Invalid YAML: ${t.message}`,fix:"Check YAML syntax in habits.yaml"});}let J=i.join(p,"AGENTS.md");if(e.existsSync(J)){let t=e.statSync(J),a=Date.now()-t.mtime.getTime(),n=Math.floor(a/(1e3*60*60*24));n>60?s.push({name:"AGENTS.md",status:"warn",message:`${n} days since last update \u2014 may be stale`,fix:"paradigm sync"}):s.push({name:"AGENTS.md",status:"ok",message:n>0?`Updated ${n} days ago`:"Fresh"});}}let T=0,W=0,$=0;for(let o of s){let m,c;switch(o.status){case "ok":m="\u2713",c=l.green;break;case "warn":m="\u26A0",c=l.yellow,W++;break;case "error":m="\u2717",c=l.red,T++;break;case "missing":m="\u25CB",c=l.gray,$++;break}if(!w){let v=o.name.padEnd(30);console.log(` ${c(m)} ${v} ${c(o.message)}`),o.fix&&console.log(l.gray(` \u2514\u2500 Fix: ${o.fix}`));}}let{runContextAudit:Z}=await import('./context-audit-XRPT3OU2.js'),M=await Z(p,{quiet:w}),z=0,O=0,b=0;!w&&M.length>0&&(console.log(""),console.log(l.blue(" Context Audit")),console.log(l.gray(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500")));for(let o of M){let m,c;switch(o.status){case "ok":m="\u2713",c=l.green;break;case "warn":m="\u26A0",c=l.yellow,O++;break;case "error":m="\u2717",c=l.red,z++;break;case "advisory":m="\u2139",c=l.cyan,b++;break}if(!w){let v=o.check.padEnd(30);if(console.log(` ${c(m)} ${v} ${c(o.message)}`),o.details&&o.details.length>0){let A=o.details.slice(0,5);for(let q of A)console.log(l.gray(` \u2502 ${q}`));o.details.length>5&&console.log(l.gray(` \u2502 ... and ${o.details.length-5} more`));}o.fix&&console.log(l.gray(` \u2514\u2500 Fix: ${o.fix}`));}}let C=T+z,j=W+O,D=C+j+$===0;if(!w)if(console.log(""),D)console.log(l.green(`\u2728 All checks passed!
6
+ `)));let I=a.command("doctor").start("Running health checks");if(!N){let E=function(t){let a=[];try{let n=e.readdirSync(t,{withFileTypes:!0});for(let r of n){if(r.name==="node_modules"||r.name==="dist"||r.name===".git")continue;let f=i.join(t,r.name);r.isDirectory()?a.push(...E(f)):r.name===".purpose"&&a.push(f);}}catch{}return a};let o=i.join(p,".paradigm");if(e.existsSync(o))if(e.statSync(o).isFile())s.push({name:".paradigm",status:"warn",message:"Legacy file format (should be directory)",fix:"paradigm upgrade --all"});else {s.push({name:".paradigm/",status:"ok",message:"Directory exists"});let a=i.join(o,"config.yaml");if(e.existsSync(a))try{let g=e.readFileSync(a,"utf8");e$1(g),s.push({name:".paradigm/config.yaml",status:"ok",message:"Valid YAML"});}catch(g){s.push({name:".paradigm/config.yaml",status:"error",message:`Invalid YAML: ${g.message}`,fix:"Check YAML syntax"});}else s.push({name:".paradigm/config.yaml",status:"missing",message:"Config file not found",fix:"paradigm init --force"});let n=["logger.md","scan.md","symbols.md"],r=i.join(o,"specs");if(e.existsSync(r))for(let g of n){let x=i.join(r,g);e.existsSync(x)?s.push({name:`.paradigm/specs/${g}`,status:"ok",message:"Present"}):s.push({name:`.paradigm/specs/${g}`,status:"missing",message:"Spec file not found",fix:"paradigm upgrade --all"});}else s.push({name:".paradigm/specs/",status:"missing",message:"Specs directory not found",fix:"paradigm upgrade --all"});let f=i.join(o,"docs");e.existsSync(f)?s.push({name:".paradigm/docs/",status:"ok",message:"Directory exists"}):s.push({name:".paradigm/docs/",status:"missing",message:"Docs directory not found",fix:"paradigm upgrade --all"});let h=i.join(o,"prompts");e.existsSync(h)?s.push({name:".paradigm/prompts/",status:"ok",message:"Directory exists"}):s.push({name:".paradigm/prompts/",status:"missing",message:"Prompts directory not found",fix:"paradigm upgrade --all"});let u=["specs","implementation-guides","prompts","decisions"],d=[];for(let g of u){let x=i.join(o,g);if(e.existsSync(x)&&e.statSync(x).isDirectory()){let k=i.join(x,".index.yaml");e.existsSync(k)||d.push(`.paradigm/${g}/`);}}d.length>0?s.push({name:"Docs-class indexes",status:"warn",message:`${d.length} director${d.length===1?"y":"ies"} missing .index.yaml: ${d.join(", ")}`,fix:"paradigm docs scaffold"}):s.push({name:"Docs-class indexes",status:"ok",message:"All docs-class directories have .index.yaml"});let y=i.join(o,"scan-index.json"),F=i.join(p,".paradigm-scan-index.json");if(e.existsSync(y)){let g=e.statSync(y),x=Date.now()-g.mtime.getTime(),k=Math.floor(x/(1e3*60*60));k>24?s.push({name:".paradigm/scan-index.json",status:"warn",message:`Stale (${k} hours old)`,fix:"paradigm index"}):s.push({name:".paradigm/scan-index.json",status:"ok",message:k>0?`${k} hours old`:"Fresh"});}else e.existsSync(F)?s.push({name:"scan-index",status:"warn",message:"Using legacy location",fix:"paradigm index"}):s.push({name:".paradigm/scan-index.json",status:"missing",message:"Not generated",fix:"paradigm index"});}else s.push({name:".paradigm/",status:"missing",message:"Not initialized",fix:"paradigm init"});let m=c(p);if(m.detected){let t=a$1(m.detected);if(t){let a=i.join(p,t.outputPath);e.existsSync(a)?s.push({name:t.outputPath,status:"ok",message:`Present (${m.detected})`}):s.push({name:t.outputPath,status:"missing",message:`Not generated for ${m.detected}`,fix:"paradigm sync"});}}let c$1=i.join(p,".premise");e.existsSync(c$1)?s.push({name:".premise",status:"ok",message:"Present"}):s.push({name:".premise",status:"missing",message:"Not found (optional)"});let v=i.join(p,".purpose");e.existsSync(v)?s.push({name:".purpose",status:"ok",message:"Present"}):s.push({name:".purpose",status:"warn",message:"Root .purpose not found",fix:"paradigm init"});let A=i.join(p,".paradigm","config.yaml");if(e.existsSync(A))try{let t=e.readFileSync(A,"utf8"),n=S.load(t)?.["purpose-required"];if(n&&Array.isArray(n)){let r=[];for(let f of n){if(!f.pattern)continue;let{glob:h}=await import('glob'),u=await h(f.pattern,{cwd:p,nodir:!1});for(let d of u){let y=i.join(p,d);try{e.statSync(y).isDirectory()&&!e.existsSync(i.join(y,".purpose"))&&r.push(d);}catch{}}}r.length>0?s.push({name:"Purpose-required",status:"warn",message:`${r.length} director${r.length===1?"y":"ies"} missing .purpose: ${r.join(", ")}`,fix:"Create .purpose files with paradigm_purpose_init + paradigm_purpose_add_component"}):s.push({name:"Purpose-required",status:"ok",message:"All required directories have .purpose files"});}}catch{}let q=/\[NEEDS CLARIFICATION:\s*[^\]]+\]/gi,R=0,Y=E(p);for(let t of Y)try{let n=e.readFileSync(t,"utf8").match(q);n&&(R+=n.length);}catch{}R>0?s.push({name:"Clarification markers",status:"warn",message:`${R} [NEEDS CLARIFICATION] marker${R>1?"s":""} found in .purpose files`,fix:"Resolve open clarification markers before shipping"}):Y.length>0&&s.push({name:"Clarification markers",status:"ok",message:"No unresolved markers"});let L=i.join(p,"portal.yaml");if(e.existsSync(L))try{let t=e.readFileSync(L,"utf8"),a=S.load(t);if(a?.version&&a?.gates){let n=Object.keys(a.gates||{}).length,r=Object.keys(a.routes||{}).length;s.push({name:"portal.yaml",status:"ok",message:`Valid (${n} gates, ${r} routes)`});}else s.push({name:"portal.yaml",status:"warn",message:"Missing version or gates section",fix:'Add version: "1.0" and gates: {} to portal.yaml'});}catch(t){s.push({name:"portal.yaml",status:"error",message:`Invalid YAML: ${t.message}`,fix:"Check YAML syntax in portal.yaml"});}if(e.existsSync(L))try{let{checkPortalCompliance:t,getComplianceSummary:a}=await import('./portal-compliance-6YR27IQU.js'),n=await t(p),r=a(n);s.push({name:"Portal compliance",status:r.status,message:r.message,fix:r.status!=="ok"?"paradigm portal check":void 0});}catch{}let U=i.join(p,".paradigm","flows.yaml");if(e.existsSync(U))try{let t=e.readFileSync(U,"utf8"),a=S.load(t);if(a?.version&&a?.flows){let n=Object.keys(a.flows||{}).length,r=Object.entries(a.flows||{}).filter(([,f])=>!f?.steps||(f.steps?.length??0)===0);r.length>0?s.push({name:".paradigm/flows.yaml",status:"warn",message:`${n} flows defined, ${r.length} have no steps`,fix:"Add steps to empty flow definitions"}):s.push({name:".paradigm/flows.yaml",status:"ok",message:`Valid (${n} flows)`});}else s.push({name:".paradigm/flows.yaml",status:"warn",message:"Missing version or flows section",fix:'Ensure flows.yaml has version: "1.0" and flows: {}'});}catch(t){s.push({name:".paradigm/flows.yaml",status:"error",message:`Invalid YAML: ${t.message}`,fix:"Check YAML syntax in flows.yaml"});}let H=i.join(p,".paradigm","lore");if(e.existsSync(H))try{let t=e.readdirSync(H).filter(a=>a.endsWith(".yaml"));t.length===0?s.push({name:"Lore entries",status:"warn",message:"Lore directory exists but no entries found",fix:"Record a lore entry: paradigm lore record"}):s.push({name:"Lore entries",status:"ok",message:`${t.length} lore file${t.length>1?"s":""}`});}catch{s.push({name:"Lore entries",status:"warn",message:"Could not read lore directory"});}let G=i.join(p,".paradigm","university");if(e.existsSync(G))try{let t=i.join(G,"content"),a=0,n=0;if(e.existsSync(t))for(let r of ["notes","policies","quizzes","paths"]){let f=i.join(t,r);e.existsSync(f)&&(a+=e.readdirSync(f).filter(h=>h.endsWith(".md")||h.endsWith(".yaml")).length);}if(a===0)s.push({name:"University content",status:"warn",message:"University directory exists but no content found",fix:'Add content: paradigm university add note --title "Getting Started"'});else {let r=i.join(t,"quizzes");if(e.existsSync(r))for(let h of e.readdirSync(r).filter(u=>u.endsWith(".yaml")))try{let u=S.load(e.readFileSync(i.join(r,h),"utf8"));if(u?.questions)for(let d of u.questions)d.choices&&d.correct&&!(d.correct in d.choices)&&n++;}catch{}let f=i.join(t,"paths");if(e.existsSync(f))for(let h of e.readdirSync(f).filter(u=>u.endsWith(".yaml")))try{let u=S.load(e.readFileSync(i.join(f,h),"utf8"));if(u?.steps){for(let d of u.steps)if(d.content&&!d.content.startsWith("plsat:")){let y=!1;for(let F of ["notes","policies","quizzes","paths"]){let g=i.join(t,F);if(e.existsSync(g)&&e.readdirSync(g).some(k=>k.startsWith(d.content))){y=!0;break}}y||n++;}}}catch{}n>0?s.push({name:"University content",status:"warn",message:`${a} items, ${n} issue${n>1?"s":""}`,fix:"Run: paradigm university validate --deep"}):s.push({name:"University content",status:"ok",message:`${a} content item${a>1?"s":""}`});}}catch{s.push({name:"University content",status:"warn",message:"Could not read university directory"});}let _=i.join(p,".claude","hooks.json"),ss=i.join(p,"plugins","paradigm","hooks.json");if(e.existsSync(_)){let t=e.statSync(_),a=Date.now()-t.mtime.getTime(),n=Math.floor(a/(1e3*60*60*24));n>30?s.push({name:"Claude Code hooks",status:"warn",message:`Hooks are ${n} days old \u2014 may be outdated`,fix:"paradigm hooks install"}):s.push({name:"Claude Code hooks",status:"ok",message:n>0?`${n} days old`:"Fresh"});}else e.existsSync(ss)?s.push({name:"Claude Code hooks",status:"ok",message:"Using plugin hooks"}):s.push({name:"Claude Code hooks",status:"missing",message:"No hooks installed",fix:"paradigm hooks install"});let V=i.join(p,".paradigm","habits.yaml");if(e.existsSync(V))try{let t=e.readFileSync(V,"utf8"),a=S.load(t);if(a?.version&&Array.isArray(a?.habits)){let n=a.habits.filter(r=>r.enabled!==!1).length;s.push({name:"Habits config",status:"ok",message:`Valid (${n}/${a.habits.length} enabled)`});}else s.push({name:"Habits config",status:"warn",message:"Missing version or habits array",fix:"Regenerate habits.yaml with paradigm habits init"});}catch(t){s.push({name:"Habits config",status:"error",message:`Invalid YAML: ${t.message}`,fix:"Check YAML syntax in habits.yaml"});}let J=i.join(p,"AGENTS.md");if(e.existsSync(J)){let t=e.statSync(J),a=Date.now()-t.mtime.getTime(),n=Math.floor(a/(1e3*60*60*24));n>60?s.push({name:"AGENTS.md",status:"warn",message:`${n} days since last update \u2014 may be stale`,fix:"paradigm sync"}):s.push({name:"AGENTS.md",status:"ok",message:n>0?`Updated ${n} days ago`:"Fresh"});}}let T=0,W=0,$=0;for(let o of s){let m,c;switch(o.status){case "ok":m="\u2713",c=l.green;break;case "warn":m="\u26A0",c=l.yellow,W++;break;case "error":m="\u2717",c=l.red,T++;break;case "missing":m="\u25CB",c=l.gray,$++;break}if(!w){let v=o.name.padEnd(30);console.log(` ${c(m)} ${v} ${c(o.message)}`),o.fix&&console.log(l.gray(` \u2514\u2500 Fix: ${o.fix}`));}}let{runContextAudit:Z}=await import('./context-audit-XRPT3OU2.js'),M=await Z(p,{quiet:w}),z=0,O=0,b=0;!w&&M.length>0&&(console.log(""),console.log(l.blue(" Context Audit")),console.log(l.gray(" \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500")));for(let o of M){let m,c;switch(o.status){case "ok":m="\u2713",c=l.green;break;case "warn":m="\u26A0",c=l.yellow,O++;break;case "error":m="\u2717",c=l.red,z++;break;case "advisory":m="\u2139",c=l.cyan,b++;break}if(!w){let v=o.check.padEnd(30);if(console.log(` ${c(m)} ${v} ${c(o.message)}`),o.details&&o.details.length>0){let A=o.details.slice(0,5);for(let q of A)console.log(l.gray(` \u2502 ${q}`));o.details.length>5&&console.log(l.gray(` \u2502 ... and ${o.details.length-5} more`));}o.fix&&console.log(l.gray(` \u2514\u2500 Fix: ${o.fix}`));}}let C=T+z,j=W+O,D=C+j+$===0;if(!w)if(console.log(""),D)console.log(l.green(`\u2728 All checks passed!
7
7
  `));else {let o=[];C>0&&o.push(l.red(`${C} error${C>1?"s":""}`)),j>0&&o.push(l.yellow(`${j} warning${j>1?"s":""}`)),$>0&&o.push(l.gray(`${$} missing`)),b>0&&o.push(l.cyan(`${b} advisor${b>1?"ies":"y"}`)),console.log(`${o.join(", ")} found.
8
8
  `),console.log(l.gray("Run the suggested commands to fix issues.")),console.log(l.gray(`Troubleshooting guide: .paradigm/docs/troubleshooting.md
9
9
  `));}if(!w&&P.explain&&!D)try{let{narrateAllGaps:o}=await import('./gap-narrator-NTXLUI7I.js'),m=[];for(let c of s)c.status!=="ok"&&(c.name===".purpose"||c.name.startsWith("Purpose-required")?m.push({type:"missing-purpose",target:c.name,severity:"improvement"}):c.name===".paradigm/scan-index.json"&&c.status==="warn"?m.push({type:"index-stale",target:c.name,severity:"improvement"}):c.name==="Portal compliance"?m.push({type:"portal-mismatch",target:c.name,severity:c.status==="error"?"blocking":"improvement"}):c.name==="Clarification markers"&&m.push({type:"missing-description",target:c.name,severity:"improvement"}));if(m.length>0){let c=o(m);console.log(l.blue(`