@precisionutilityguild/liquid-shadow 1.0.7 → 1.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -3
- package/dist/data/migrations/000_baseline.sql +27 -0
- package/dist/data/migrations/013_file_claims.sql +18 -0
- package/dist/data/migrations/014_tribunal_state.sql +24 -0
- package/dist/data/migrations/015_repo_level_handoffs_nullable.sql +52 -0
- package/dist/data/migrations/016_repair_tribunal_artifact_fk.sql +58 -0
- package/dist/entry/cli/index.js +597 -495
- package/dist/entry/ember/index.js +109 -32
- package/dist/entry/mcp/server.js +443 -347
- package/dist/entry/tribunal/index.js +650 -0
- package/dist/index.js +441 -345
- package/dist/logic/parser/index.js +16 -14
- package/dist/skills/shadow_audit/SKILL.md +22 -30
- package/dist/skills/shadow_chronicle/SKILL.md +16 -29
- package/dist/skills/shadow_continue/SKILL.md +37 -53
- package/dist/skills/shadow_coordinate/SKILL.md +46 -0
- package/dist/skills/shadow_crystallize/SKILL.md +13 -27
- package/dist/skills/shadow_mission/SKILL.md +27 -41
- package/dist/skills/shadow_onboard/SKILL.md +26 -35
- package/dist/skills/shadow_research/SKILL.md +15 -23
- package/dist/skills/shadow_sync/SKILL.md +18 -9
- package/dist/skills/shadow_synthesize/SKILL.md +14 -36
- package/dist/skills/shadow_trace_impact/SKILL.md +30 -50
- package/dist/skills/shadow_understand/SKILL.md +37 -52
- package/dist/skills/shadow_workspace/SKILL.md +17 -17
- package/dist/web-manifest.json +16 -6
- package/package.json +1 -1
- package/skills/shadow_audit/SKILL.md +22 -30
- package/skills/shadow_chronicle/SKILL.md +16 -29
- package/skills/shadow_continue/SKILL.md +37 -53
- package/skills/shadow_coordinate/SKILL.md +46 -0
- package/skills/shadow_crystallize/SKILL.md +13 -27
- package/skills/shadow_mission/SKILL.md +27 -41
- package/skills/shadow_onboard/SKILL.md +26 -35
- package/skills/shadow_research/SKILL.md +15 -23
- package/skills/shadow_sync/SKILL.md +18 -9
- package/skills/shadow_synthesize/SKILL.md +14 -36
- package/skills/shadow_trace_impact/SKILL.md +30 -50
- package/skills/shadow_understand/SKILL.md +37 -52
- package/skills/shadow_workspace/SKILL.md +17 -17
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{for(var t in e)ot(s,t,{get:e[t],enumerable:!0})};import lt from"pino";var ct,ut,d,M=P(()=>{"use strict";ct={10:"TRACE",20:"DEBUG",30:"INFO",40:"WARN",50:"ERROR",60:"FATAL"},ut=lt({level:process.env.LOG_LEVEL||"warn",base:{service:"liquid-shadow"},formatters:{level(s,e){return{level:s,severity:ct[e]??"INFO"}}},transport:{target:"pino-pretty",options:{colorize:!0,translateTime:"HH:MM:ss",destination:2,levelKey:"severity",messageKey:"message"}}}),d=ut});import{fileURLToPath as At}from"node:url";import{dirname as ae,join as De,resolve as xt}from"node:path";import{existsSync as wt}from"node:fs";function vt(){let s=Ie;for(;s!==ae(s);){if(wt(De(s,"package.json")))return s;s=ae(s)}return xt(Ie,"..","..")}function Me(...s){return De(vt(),...s)}var kt,Ie,Ce=P(()=>{"use strict";kt=At(import.meta.url),Ie=ae(kt)});import{Worker as Ht}from"node:worker_threads";import{cpus as Wt}from"node:os";import{fileURLToPath as Ft}from"node:url";import{dirname as Ut,join as Ae}from"node:path";import{existsSync as xe}from"node:fs";function Bt(){if(ke.endsWith(".ts")){let e=Ae(we,"worker.ts");if(xe(e))return e}let s=Ae(we,"worker.js");return xe(s)?s:Me("dist/logic/domain/embeddings/worker.js")}function x(s){return A||(A=new H(s)),A}async function ve(){A&&(await A.shutdown(),A=null)}var ke,we,H,A,He=P(()=>{"use strict";M();Ce();ke=Ft(import.meta.url),we=Ut(ke);H=class{workers=[];taskQueue=[];pendingTasks=new Map;taskIdCounter=0;initialized=!1;initPromise;shutdownRequested=!1;numWorkers;cacheDir;initTimeout;constructor(e={}){this.numWorkers=e.numWorkers??Math.max(1,Math.min(2,Wt().length-1)),this.cacheDir=e.cacheDir??"./.cache",this.initTimeout=e.initTimeout??6e4}async initialize(){if(!this.initialized)return this.initPromise?this.initPromise:(this.initPromise=this._doInitialize(),this.initPromise)}async _doInitialize(){let e;try{d.info({numWorkers:this.numWorkers},"Initializing embedding worker pool");let t=new Promise((i,n)=>{e=setTimeout(()=>n(new Error(`Worker pool initialization timed out after ${this.initTimeout}ms`)),this.initTimeout)});if(await Promise.race([this._initializeWorkers(),t]),e&&clearTimeout(e),this.shutdownRequested){this.initialized=!1,this.initPromise=void 0,d.debug("Initialization completed but shutdown was requested");return}this.initialized=!0,d.info({numWorkers:this.workers.length},"Embedding worker pool ready")}catch(t){throw e&&clearTimeout(e),this.initPromise=void 0,this.initialized=!1,await this.shutdown(),t}}async _initializeWorkers(){let e=Bt();d.debug({workerPath:e},"Resolved worker path");let t=[];for(let i=0;i<this.numWorkers;i++)i>0&&await new Promise(n=>setTimeout(n,25)),t.push(this.createWorker(e,i));await Promise.all(t)}async createWorker(e,t){return new Promise((i,n)=>{let r=setTimeout(()=>{n(new Error(`Worker ${t} initialization timed out`))},this.initTimeout),c=new Ht(e,{workerData:{cacheDir:this.cacheDir},execArgv:process.execArgv}),l={worker:c,busy:!1,currentTaskId:null};c.on("message",a=>{if(a.type==="ready"){if(clearTimeout(r),this.shutdownRequested){d.debug({workerIndex:t},"Worker ready but shutdown requested, terminating"),c.terminate().catch(()=>{}),i();return}this.workers.push(l),d.debug({workerIndex:t},"Worker ready"),i()}else a.type==="result"&&a.id?this.handleTaskComplete(l,a.id,a.embeddings||[]):a.type==="error"&&a.id&&this.handleTaskError(l,a.id,new Error(a.error||"Unknown error"))}),c.on("error",a=>{if(clearTimeout(r),d.error({err:a,workerIndex:t},"Worker error"),l.currentTaskId&&this.handleTaskError(l,l.currentTaskId,a),!this.initialized){n(a);return}let o=this.workers.indexOf(l);o!==-1&&this.workers.splice(o,1),!this.shutdownRequested&&this.initialized&&this.createWorker(e,t).catch(u=>{d.error({err:u},"Failed to replace crashed worker")})}),c.on("exit",a=>{a!==0&&!this.shutdownRequested&&d.warn({workerIndex:t,code:a},"Worker exited unexpectedly")})})}handleTaskComplete(e,t,i){let n=this.pendingTasks.get(t);n&&(this.pendingTasks.delete(t),n.resolve(i)),e.busy=!1,e.currentTaskId=null,this.processQueue()}handleTaskError(e,t,i){let n=this.pendingTasks.get(t);n&&(this.pendingTasks.delete(t),n.reject(i)),e.busy=!1,e.currentTaskId=null,this.processQueue()}processQueue(){if(this.taskQueue.length===0)return;let e=this.workers.find(i=>!i.busy);if(!e)return;let t=this.taskQueue.shift();t&&(e.busy=!0,e.currentTaskId=t.id,this.pendingTasks.set(t.id,t),e.worker.postMessage({type:"embed",id:t.id,texts:t.texts}))}async generateEmbeddings(e,t=128,i){if(this.initialized||await this.initialize(),e.length===0)return[];let n=[];for(let o=0;o<e.length;o+=t)n.push(e.slice(o,o+t));let r=new Array(n.length),c=0,l=n.map((o,u)=>new Promise((p,m)=>{let f={id:`task_${++this.taskIdCounter}`,texts:o,resolve:T=>{if(r[u]=T,c++,i){let N=Math.min(c*t,e.length);i(N,e.length)}p()},reject:T=>{if(r[u]=new Array(o.length).fill(null),c++,d.warn({err:T,chunkIndex:u},"Chunk embedding failed"),i){let N=Math.min(c*t,e.length);i(N,e.length)}p()}};this.taskQueue.push(f),this.processQueue()}));await Promise.all(l);let a=[];for(let o of r)a.push(...o);return d.info({total:e.length,successful:a.filter(o=>o!==null).length,workers:this.workers.length},"Parallel embedding generation complete"),a}get workerCount(){return this.workers.length}get busyWorkers(){return this.workers.filter(e=>e.busy).length}get queueSize(){return this.taskQueue.length}get isInitialized(){return this.initialized}async shutdown(){if(this.shutdownRequested=!0,this.initPromise)try{await this.initPromise}catch{}if(!this.initialized&&this.workers.length===0){this.shutdownRequested=!1,this.initPromise=void 0;return}d.info({numWorkers:this.workers.length},"Shutting down embedding worker pool");let e=this.workers.map(t=>new Promise(i=>{t.worker.postMessage({type:"shutdown"}),t.worker.once("exit",()=>i()),setTimeout(()=>{t.worker.terminate().then(()=>i())},5e3)}));await Promise.all(e),this.workers=[],this.taskQueue=[],this.pendingTasks.clear(),this.initialized=!1,this.shutdownRequested=!1,d.info("Embedding worker pool shutdown complete")}},A=null});var I={};at(I,{EmbeddingPriorityQueue:()=>ce,EmbeddingWorkerPool:()=>H,cosineSimilarity:()=>qt,generateEmbedding:()=>Yt,generateEmbeddingsBatch:()=>Kt,getDefaultPool:()=>x,setUseWorkerThreads:()=>$t,shutdownDefaultPool:()=>ve});async function Pt(){return W||(W=await import("@xenova/transformers"),W.env.cacheDir="./.cache",W.env.allowLocalModels=!0),W}function $t(s){ue=s,d.info({useWorkerThreads:s},"Worker thread mode updated")}function We(s=!1){let e=(F||"").toLowerCase(),t={};return F&&(t.dtype=F),s?(t.quantized=!1,t):(e==="fp32"||e==="fp16"||e==="float32"||e==="float16"?t.quantized=!1:e.startsWith("q")&&(t.quantized=!0),t)}async function zt(){d.info({model:G,dtype:F},"Loading embedding model...");let{pipeline:s}=await Pt(),e=We(!1);try{return await s("feature-extraction",G,e)}catch(t){let i=t?.message||"";if(!(i.includes("/onnx/model_quantized.onnx")||i.includes("model_quantized.onnx")))throw t;return d.warn({model:G,dtype:F},"Quantized ONNX artifact missing, retrying with unquantized ONNX"),await s("feature-extraction",G,We(!0))}}async function Ue(){return le||(le=zt()),le}async function Yt(s){try{let t=await(await Ue())(s,{pooling:"mean",normalize:!0});return Array.from(t.data)}catch(e){return d.error({err:e},"Failed to generate embedding"),null}}async function Kt(s,e=Fe,t){return s.length===0?[]:ue?x().generateEmbeddings(s,e,t):Be(s,e,t)}async function Be(s,e,t){let i=new Array(s.length).fill(null),n=await Ue();for(let r=0;r<s.length;r+=e){let c=Math.min(r+e,s.length),l=s.slice(r,c);try{let a=await n(l,{pooling:"mean",normalize:!0}),[o,u]=a.dims;for(let p=0;p<o;p++){let m=p*u,y=m+u;i[r+p]=Array.from(a.data.slice(m,y))}}catch(a){d.error({err:a,batchStart:r,batchEnd:c},"Single-threaded batch embedding failed, falling back to sequential for this chunk");for(let o=0;o<l.length;o++)try{let u=l[o];if(!u||u.trim().length===0)continue;let p=await n(u,{pooling:"mean",normalize:!0});i[r+o]=Array.from(p.data)}catch{i[r+o]=null}}t&&t(c,s.length)}return d.debug({total:s.length,successful:i.filter(r=>r!==null).length},"Batch embedding complete"),i}function qt(s,e){let t=0,i=0,n=0;for(let r=0;r<s.length;r++)t+=s[r]*e[r],i+=s[r]*s[r],n+=e[r]*e[r];return t/(Math.sqrt(i)*Math.sqrt(n))}var G,F,W,Fe,ue,le,ce,S=P(()=>{"use strict";M();He();G=process.env.EMBEDDING_MODEL??"Xenova/all-MiniLM-L6-v2",F=process.env.EMBEDDING_DTYPE??"fp32",W=null;Fe=128,ue=!1;le=null;ce=class{queue=[];processing=!1;results=new Map;enqueue(e){this.queue.push(e),this.queue.sort((t,i)=>i.priority-t.priority)}enqueueMany(e){this.queue.push(...e),this.queue.sort((t,i)=>i.priority-t.priority)}get size(){return this.queue.length}get isProcessing(){return this.processing}getResult(e){return this.results.get(e)}async processQueue(e=Fe,t){if(this.processing)return d.warn("Queue processing already in progress"),this.results;this.processing=!0;let i=this.queue.length;try{ue?await this.processQueueParallel(e,i,t):await this.processQueueSequential(e,i,t)}finally{this.processing=!1}return this.results}async processQueueSequential(e,t,i){for(;this.queue.length>0;){let n=this.queue.splice(0,e),r=n.map(l=>l.text),c=await Be(r,r.length);if(n.forEach((l,a)=>{this.results.set(l.id,c[a])}),i){let l=t-this.queue.length;i(l,t)}}}async processQueueParallel(e,t,i){let n=this.queue.splice(0),r=n.map(a=>a.text),l=await x().generateEmbeddings(r,e,(a,o)=>{i&&i(a,o)});n.forEach((a,o)=>{this.results.set(a.id,l[o])})}clear(){this.queue=[],this.results.clear()}}});import de from"node:os";M();import yt from"better-sqlite3";import z from"path";import Te from"fs";import Tt from"crypto";M();import O from"fs";import $ from"path";import{fileURLToPath as dt}from"url";var R=d.child({module:"migrations"}),pt=dt(import.meta.url),mt=$.dirname(pt);function Et(){let s=mt;if(O.readdirSync(s).some(i=>i.match(/^\d{3}_.*\.sql$/)))return s;let t=$.resolve(s,"../../data/migrations");return O.existsSync(t)&&O.readdirSync(t).some(i=>i.match(/^\d{3}_.*\.sql$/))?t:s}function ht(s){s.exec(`
|
|
1
|
+
var at=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var lt=(s,e)=>{for(var t in e)at(s,t,{get:e[t],enumerable:!0})};import ct from"pino";var ut,dt,d,M=P(()=>{"use strict";ut={10:"TRACE",20:"DEBUG",30:"INFO",40:"WARN",50:"ERROR",60:"FATAL"},dt=ct({level:process.env.LOG_LEVEL||"warn",base:{service:"liquid-shadow"},formatters:{level(s,e){return{level:s,severity:ut[e]??"INFO"}}},transport:{target:"pino-pretty",options:{colorize:!0,translateTime:"HH:MM:ss",destination:2,levelKey:"severity",messageKey:"message"}}}),d=dt});import{fileURLToPath as xt}from"node:url";import{dirname as le,join as Me,resolve as wt}from"node:path";import{existsSync as kt}from"node:fs";function Wt(){let s=Ce;for(;s!==le(s);){if(kt(Me(s,"package.json")))return s;s=le(s)}return wt(Ce,"..","..")}function Ae(...s){return Me(Wt(),...s)}var Ft,Ce,De=P(()=>{"use strict";Ft=xt(import.meta.url),Ce=le(Ft)});import{Worker as vt}from"node:worker_threads";import{cpus as Ht}from"node:os";import{fileURLToPath as Bt}from"node:url";import{dirname as Ut,join as xe}from"node:path";import{existsSync as we}from"node:fs";function Pt(){if(Fe.endsWith(".ts")){let e=xe(ke,"worker.ts");if(we(e))return e}let s=xe(ke,"worker.js");return we(s)?s:Ae("dist/logic/domain/embeddings/worker.js")}function x(s){return D||(D=new W(s)),D}async function We(){D&&(await D.shutdown(),D=null)}var Fe,ke,W,D,ve=P(()=>{"use strict";M();De();Fe=Bt(import.meta.url),ke=Ut(Fe);W=class{workers=[];taskQueue=[];pendingTasks=new Map;taskIdCounter=0;initialized=!1;initPromise;shutdownRequested=!1;numWorkers;cacheDir;initTimeout;constructor(e={}){this.numWorkers=e.numWorkers??Math.max(1,Math.min(2,Ht().length-1)),this.cacheDir=e.cacheDir??"./.cache",this.initTimeout=e.initTimeout??6e4}async initialize(){if(!this.initialized)return this.initPromise?this.initPromise:(this.initPromise=this._doInitialize(),this.initPromise)}async _doInitialize(){let e;try{d.info({numWorkers:this.numWorkers},"Initializing embedding worker pool");let t=new Promise((i,n)=>{e=setTimeout(()=>n(new Error(`Worker pool initialization timed out after ${this.initTimeout}ms`)),this.initTimeout)});if(await Promise.race([this._initializeWorkers(),t]),e&&clearTimeout(e),this.shutdownRequested){this.initialized=!1,this.initPromise=void 0,d.debug("Initialization completed but shutdown was requested");return}this.initialized=!0,d.info({numWorkers:this.workers.length},"Embedding worker pool ready")}catch(t){throw e&&clearTimeout(e),this.initPromise=void 0,this.initialized=!1,await this.shutdown(),t}}async _initializeWorkers(){let e=Pt();d.debug({workerPath:e},"Resolved worker path");let t=[];for(let i=0;i<this.numWorkers;i++)i>0&&await new Promise(n=>setTimeout(n,25)),t.push(this.createWorker(e,i));await Promise.all(t)}async createWorker(e,t){return new Promise((i,n)=>{let r=setTimeout(()=>{n(new Error(`Worker ${t} initialization timed out`))},this.initTimeout),c=new vt(e,{workerData:{cacheDir:this.cacheDir},execArgv:process.execArgv}),l={worker:c,busy:!1,currentTaskId:null};c.on("message",a=>{if(a.type==="ready"){if(clearTimeout(r),this.shutdownRequested){d.debug({workerIndex:t},"Worker ready but shutdown requested, terminating"),c.terminate().catch(()=>{}),i();return}this.workers.push(l),d.debug({workerIndex:t},"Worker ready"),i()}else a.type==="result"&&a.id?this.handleTaskComplete(l,a.id,a.embeddings||[]):a.type==="error"&&a.id&&this.handleTaskError(l,a.id,new Error(a.error||"Unknown error"))}),c.on("error",a=>{if(clearTimeout(r),d.error({err:a,workerIndex:t},"Worker error"),l.currentTaskId&&this.handleTaskError(l,l.currentTaskId,a),!this.initialized){n(a);return}let o=this.workers.indexOf(l);o!==-1&&this.workers.splice(o,1),!this.shutdownRequested&&this.initialized&&this.createWorker(e,t).catch(u=>{d.error({err:u},"Failed to replace crashed worker")})}),c.on("exit",a=>{a!==0&&!this.shutdownRequested&&d.warn({workerIndex:t,code:a},"Worker exited unexpectedly")})})}handleTaskComplete(e,t,i){let n=this.pendingTasks.get(t);n&&(this.pendingTasks.delete(t),n.resolve(i)),e.busy=!1,e.currentTaskId=null,this.processQueue()}handleTaskError(e,t,i){let n=this.pendingTasks.get(t);n&&(this.pendingTasks.delete(t),n.reject(i)),e.busy=!1,e.currentTaskId=null,this.processQueue()}processQueue(){if(this.taskQueue.length===0)return;let e=this.workers.find(i=>!i.busy);if(!e)return;let t=this.taskQueue.shift();t&&(e.busy=!0,e.currentTaskId=t.id,this.pendingTasks.set(t.id,t),e.worker.postMessage({type:"embed",id:t.id,texts:t.texts}))}async generateEmbeddings(e,t=128,i){if(this.initialized||await this.initialize(),e.length===0)return[];let n=[];for(let o=0;o<e.length;o+=t)n.push(e.slice(o,o+t));let r=new Array(n.length),c=0,l=n.map((o,u)=>new Promise((m,p)=>{let g={id:`task_${++this.taskIdCounter}`,texts:o,resolve:T=>{if(r[u]=T,c++,i){let N=Math.min(c*t,e.length);i(N,e.length)}m()},reject:T=>{if(r[u]=new Array(o.length).fill(null),c++,d.warn({err:T,chunkIndex:u},"Chunk embedding failed"),i){let N=Math.min(c*t,e.length);i(N,e.length)}m()}};this.taskQueue.push(g),this.processQueue()}));await Promise.all(l);let a=[];for(let o of r)a.push(...o);return d.info({total:e.length,successful:a.filter(o=>o!==null).length,workers:this.workers.length},"Parallel embedding generation complete"),a}get workerCount(){return this.workers.length}get busyWorkers(){return this.workers.filter(e=>e.busy).length}get queueSize(){return this.taskQueue.length}get isInitialized(){return this.initialized}async shutdown(){if(this.shutdownRequested=!0,this.initPromise)try{await this.initPromise}catch{}if(!this.initialized&&this.workers.length===0){this.shutdownRequested=!1,this.initPromise=void 0;return}d.info({numWorkers:this.workers.length},"Shutting down embedding worker pool");let e=this.workers.map(t=>new Promise(i=>{t.worker.postMessage({type:"shutdown"}),t.worker.once("exit",()=>i()),setTimeout(()=>{t.worker.terminate().then(()=>i())},5e3)}));await Promise.all(e),this.workers=[],this.taskQueue=[],this.pendingTasks.clear(),this.initialized=!1,this.shutdownRequested=!1,d.info("Embedding worker pool shutdown complete")}},D=null});var O={};lt(O,{EmbeddingPriorityQueue:()=>ue,EmbeddingWorkerPool:()=>W,cosineSimilarity:()=>qt,generateEmbedding:()=>Yt,generateEmbeddingsBatch:()=>jt,getDefaultPool:()=>x,setUseWorkerThreads:()=>zt,shutdownDefaultPool:()=>We});async function $t(){return v||(v=await import("@xenova/transformers"),v.env.cacheDir="./.cache",v.env.allowLocalModels=!0),v}function zt(s){de=s,d.info({useWorkerThreads:s},"Worker thread mode updated")}function He(s=!1){let e=(H||"").toLowerCase(),t={};return H&&(t.dtype=H),s?(t.quantized=!1,t):(e==="fp32"||e==="fp16"||e==="float32"||e==="float16"?t.quantized=!1:e.startsWith("q")&&(t.quantized=!0),t)}async function Kt(){d.info({model:G,dtype:H},"Loading embedding model...");let{pipeline:s}=await $t(),e=He(!1);try{return await s("feature-extraction",G,e)}catch(t){let i=t?.message||"";if(!(i.includes("/onnx/model_quantized.onnx")||i.includes("model_quantized.onnx")))throw t;return d.warn({model:G,dtype:H},"Quantized ONNX artifact missing, retrying with unquantized ONNX"),await s("feature-extraction",G,He(!0))}}async function Ue(){return ce||(ce=Kt()),ce}async function Yt(s){try{let t=await(await Ue())(s,{pooling:"mean",normalize:!0});return Array.from(t.data)}catch(e){return d.error({err:e},"Failed to generate embedding"),null}}async function jt(s,e=Be,t){return s.length===0?[]:de?x().generateEmbeddings(s,e,t):Pe(s,e,t)}async function Pe(s,e,t){let i=new Array(s.length).fill(null),n=await Ue();for(let r=0;r<s.length;r+=e){let c=Math.min(r+e,s.length),l=s.slice(r,c);try{let a=await n(l,{pooling:"mean",normalize:!0}),[o,u]=a.dims;for(let m=0;m<o;m++){let p=m*u,y=p+u;i[r+m]=Array.from(a.data.slice(p,y))}}catch(a){d.error({err:a,batchStart:r,batchEnd:c},"Single-threaded batch embedding failed, falling back to sequential for this chunk");for(let o=0;o<l.length;o++)try{let u=l[o];if(!u||u.trim().length===0)continue;let m=await n(u,{pooling:"mean",normalize:!0});i[r+o]=Array.from(m.data)}catch{i[r+o]=null}}t&&t(c,s.length)}return d.debug({total:s.length,successful:i.filter(r=>r!==null).length},"Batch embedding complete"),i}function qt(s,e){let t=0,i=0,n=0;for(let r=0;r<s.length;r++)t+=s[r]*e[r],i+=s[r]*s[r],n+=e[r]*e[r];return t/(Math.sqrt(i)*Math.sqrt(n))}var G,H,v,Be,de,ce,ue,S=P(()=>{"use strict";M();ve();G=process.env.EMBEDDING_MODEL??"Xenova/all-MiniLM-L6-v2",H=process.env.EMBEDDING_DTYPE??"fp32",v=null;Be=128,de=!1;ce=null;ue=class{queue=[];processing=!1;results=new Map;enqueue(e){this.queue.push(e),this.queue.sort((t,i)=>i.priority-t.priority)}enqueueMany(e){this.queue.push(...e),this.queue.sort((t,i)=>i.priority-t.priority)}get size(){return this.queue.length}get isProcessing(){return this.processing}getResult(e){return this.results.get(e)}async processQueue(e=Be,t){if(this.processing)return d.warn("Queue processing already in progress"),this.results;this.processing=!0;let i=this.queue.length;try{de?await this.processQueueParallel(e,i,t):await this.processQueueSequential(e,i,t)}finally{this.processing=!1}return this.results}async processQueueSequential(e,t,i){for(;this.queue.length>0;){let n=this.queue.splice(0,e),r=n.map(l=>l.text),c=await Pe(r,r.length);if(n.forEach((l,a)=>{this.results.set(l.id,c[a])}),i){let l=t-this.queue.length;i(l,t)}}}async processQueueParallel(e,t,i){let n=this.queue.splice(0),r=n.map(a=>a.text),l=await x().generateEmbeddings(r,e,(a,o)=>{i&&i(a,o)});n.forEach((a,o)=>{this.results.set(a.id,l[o])})}clear(){this.queue=[],this.results.clear()}}});import me from"node:os";M();import Tt from"better-sqlite3";import z from"path";import Re from"fs";import Rt from"crypto";M();import I from"fs";import $ from"path";import{fileURLToPath as mt}from"url";var R=d.child({module:"migrations"}),pt=mt(import.meta.url),Et=$.dirname(pt);function ht(){let s=Et;if(I.readdirSync(s).some(i=>i.match(/^\d{3}_.*\.sql$/)))return s;let t=$.resolve(s,"../../data/migrations");return I.existsSync(t)&&I.readdirSync(t).some(i=>i.match(/^\d{3}_.*\.sql$/))?t:s}function ft(s){s.exec(`
|
|
2
2
|
CREATE TABLE IF NOT EXISTS schema_migrations (
|
|
3
3
|
version INTEGER PRIMARY KEY,
|
|
4
4
|
name TEXT NOT NULL,
|
|
5
5
|
applied_at REAL DEFAULT (unixepoch())
|
|
6
6
|
);
|
|
7
|
-
`)}function gt(s){
|
|
7
|
+
`)}function gt(s){ft(s);let e=s.prepare("SELECT version FROM schema_migrations ORDER BY version").all();return new Set(e.map(t=>t.version))}function _t(s){return I.readdirSync(s).filter(t=>t.match(/^\d{3}_.*\.sql$/)&&!t.startsWith("000_")).sort().map(t=>{let i=t.match(/^(\d{3})_(.+)\.sql$/),n=parseInt(i[1],10),r=i[2],l=I.readFileSync($.join(s,t),"utf-8").split(/^-- DOWN$/m);return{version:n,name:r,up:l[0].trim(),down:l[1]?.trim()}})}function bt(s,e){R.info({version:e.version,name:e.name},"Applying migration"),s.transaction(()=>{s.exec(e.up),s.prepare("INSERT INTO schema_migrations (version, name) VALUES (?, ?)").run(e.version,e.name)})(),R.info({version:e.version},"Migration applied successfully")}function yt(s,e,t){let i=$.join(e,"000_baseline.sql");if(!I.existsSync(i)){R.warn("000_baseline.sql not found \u2014 falling back to incremental migrations");return}R.info("Fresh database detected \u2014 applying consolidated baseline schema");let n=I.readFileSync(i,"utf-8");s.transaction(()=>{s.exec(n);let r=s.prepare("INSERT OR IGNORE INTO schema_migrations (version, name) VALUES (?, ?)");for(let c of t)r.run(c.version,c.name)})(),R.info({stamped:t.length},"Baseline applied \u2014 incremental migrations stamped")}function Te(s){let e=gt(s),t=ht(),i=_t(t);if(e.size===0){yt(s,t,i);return}let n=i.filter(r=>!e.has(r.version));if(n.length===0){R.debug("No pending migrations");return}R.info({count:n.length},"Running pending migrations");for(let r of n)bt(s,r);R.info("All migrations complete")}import Lt from"os";var A=d.child({module:"db"});function oe(s){let e=Lt.homedir(),t=z.join(e,".mcp-liquid-shadow"),i=z.join(t,"dbs");Re.existsSync(i)||Re.mkdirSync(i,{recursive:!0});let n=Rt.createHash("sha256").update(s).digest("hex").substring(0,12),c=`${z.basename(s).replace(/[^a-zA-Z0-9-_]/g,"_")}_${n}.db`;return z.join(i,c)}function St(s,e){let t=e||oe(s);A.debug({repoPath:s,dbPath:t},"Initializing database");let i=new Tt(t);return i.pragma("journal_mode = WAL"),i.pragma("busy_timeout = 5000"),Te(i),K.set(s,t),L.set(t,i),A.debug({repoPath:s,dbPath:t},"Database initialized successfully"),i}var L=new Map,K=new Map;function F(s){let e=K.get(s)||oe(s),t=L.get(e);if(t){if(t.open)return t;L.delete(e)}let i=St(s);return L.set(e,i),i}function Le(s){let e=K.get(s)||oe(s),t=L.get(e);t&&(t.open&&(A.debug({repoPath:s,dbPath:e},"Closing database connection"),t.close()),L.delete(e)),K.delete(s)}function Se(){for(let[s,e]of L.entries())try{e.open&&(A.debug({dbPath:s},"Closing database connection"),e.close())}catch(t){A.error({dbPath:s,err:t},"Error closing database execution")}L.clear()}process.on("exit",()=>Se());var Ne=s=>{A.debug({signal:s},"Received termination signal, closing databases"),Se(),process.exit(0)};process.on("SIGINT",()=>Ne("SIGINT"));process.on("SIGTERM",()=>Ne("SIGTERM"));import Dt from"path";var E=class{db;constructor(e){this.db=e}get database(){return this.db}all(e,...t){return this.db.prepare(e).all(...t)}get(e,...t){return this.db.prepare(e).get(...t)}run(e,...t){return this.db.prepare(e).run(...t).changes}insert(e,...t){return this.db.prepare(e).run(...t).lastInsertRowid}transaction(e){return this.db.transaction(e)()}};var Nt=new Set(["any","unknown","never","void","null","undefined","string","number","boolean","symbol","object","bigint","readonly","keyof","infer","extends","implements","class","interface","type","function","new"]);function It(s,e){if(!s)return!1;let t=s.trim();return!t||Nt.has(t.toLowerCase())||e.has(t)?!1:/^[A-Za-z_$][A-Za-z0-9_$.]*$/.test(t)}function Ot(s){return s.split(/[,|&]/).map(e=>e.trim()).filter(Boolean)}function Ct(s){let e=s.replace(/^[({\[]+/,"").replace(/[)}\]]+$/,"").replace(/^readonly\s+/,"").trim();return e&&e.match(/^([A-Za-z_$][A-Za-z0-9_$.]*)/)?.[1]||null}function Mt(s){let e=[],t=0,i="",n=!1;for(let r of s){if(r==="<"&&(t++,t===1)){n=!0,i="";continue}if(r===">"&&(t>0&&t--,t===0&&n)){n=!1,i.trim()&&e.push(i),i="";continue}n&&(i+=r)}return e}function At(s){let e=new Set;for(let t of s){let i=t.split(",").map(n=>n.trim());for(let n of i){let r=n.match(/^([A-Za-z_$][A-Za-z0-9_$]*)/);r?.[1]&&e.add(r[1])}}return e}function ae(s,e){let t=[];for(let i of Ot(s)){let n=Ct(i);n&&It(n,e)&&t.push(n)}return t}function Ie(s){if(!s)return[];let e=s.replace(/\s+/g," ").trim();if(!e)return[];let t=Mt(e),i=At(t),n=[],r=new Set,c=(o,u,m)=>{let p=`${o}:${u}`;r.has(p)||(r.add(p),n.push({relationship:o,targetName:u,...m?{metadata:m}:{}}))},l=e.match(/\bextends\s+(.+?)(?=\bimplements\b|\{|=|$)/);if(l?.[1]){let o=ae(l[1],i);for(let u of o)c("extends",u,l[1].trim())}let a=e.match(/\bimplements\s+(.+?)(?=\{|=|$)/);if(a?.[1]){let o=ae(a[1],i);for(let u of o)c("implements",u,a[1].trim())}for(let o of t){let u=/([A-Za-z_$][A-Za-z0-9_$]*)\s+extends\s+([^,>]+)/g,m=null;for(;(m=u.exec(o))!==null;){let p=m[2]?.trim();if(!p)continue;let y=ae(p,i);for(let g of y)c("constrained_by",g,p)}}return n}var Y=class extends E{findByPath(e){return this.get("SELECT * FROM files WHERE path = ?",e)}findAll(e){let t="SELECT * FROM files ORDER BY path ASC";return e&&(t+=` LIMIT ${e}`),this.all(t)}getAllPaths(){return this.all("SELECT path FROM files").map(t=>t.path)}findInSubPath(e,t){let i=Dt.resolve(e,t),n=i.endsWith("/")?i:i+"/";return this.all(`
|
|
8
8
|
SELECT * FROM files
|
|
9
9
|
WHERE (path LIKE ? OR path = ?)
|
|
10
10
|
ORDER BY path ASC
|
|
@@ -50,14 +50,14 @@ var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{f
|
|
|
50
50
|
OR m.id IN (${e.length>0?e.join(","):"-1"})
|
|
51
51
|
)
|
|
52
52
|
AND ws.file_path IS NOT NULL
|
|
53
|
-
`,r=[];t&&r.push(t);let c=this.all(n,...r);for(let o of c){i[o.file_path]||(i[o.file_path]={score:1,reasons:[]});let u=o.status==="in-progress"||o.status==="verifying"?1:.5;i[o.file_path].score+=u;let
|
|
53
|
+
`,r=[];t&&r.push(t);let c=this.all(n,...r);for(let o of c){i[o.file_path]||(i[o.file_path]={score:1,reasons:[]});let u=o.status==="in-progress"||o.status==="verifying"?1:.5;i[o.file_path].score+=u;let m=o.status==="in-progress"||o.status==="verifying"?"Working Set":"Lineage Bleed";i[o.file_path].reasons.push(`${m}: ${o.mission_name}`)}let l=Math.floor(Date.now()/1e3)-86400,a=this.all(`
|
|
54
54
|
SELECT file_path, type, mission_id
|
|
55
55
|
FROM intent_logs
|
|
56
56
|
WHERE (created_at > ? OR mission_id IN (${e.length>0?e.join(","):"-1"}))
|
|
57
57
|
AND file_path IS NOT NULL
|
|
58
58
|
ORDER BY created_at DESC
|
|
59
59
|
LIMIT 100
|
|
60
|
-
`,l);for(let o of a){i[o.file_path]||(i[o.file_path]={score:1,reasons:[]});let u=o.mission_id?e.includes(o.mission_id):!1,
|
|
60
|
+
`,l);for(let o of a){i[o.file_path]||(i[o.file_path]={score:1,reasons:[]});let u=o.mission_id?e.includes(o.mission_id):!1,m=u?.1:.2;i[o.file_path].score<5&&(i[o.file_path].score+=m);let p=u?`Lineage Intent: ${o.type}`:`Recent Intent: ${o.type}`;!i[o.file_path].reasons.includes(p)&&i[o.file_path].reasons.length<5&&i[o.file_path].reasons.push(p)}return i}getCount(){return this.get("SELECT COUNT(*) as count FROM files")?.count||0}getTopDirectories(e,t=8){return this.all(`
|
|
61
61
|
SELECT
|
|
62
62
|
SUBSTR(path, LENGTH(?) + 2,
|
|
63
63
|
INSTR(SUBSTR(path, LENGTH(?) + 2), '/') - 1
|
|
@@ -80,7 +80,7 @@ var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{f
|
|
|
80
80
|
SUBSTR(path, LENGTH(?) + 2) as relPath
|
|
81
81
|
FROM files
|
|
82
82
|
WHERE path LIKE ? || '/%/package.json'
|
|
83
|
-
`,e,e)}deletePaths(e){if(e.length===0)return;let t=this.db.prepare("DELETE FROM files WHERE path = ?");this.db.transaction(n=>{for(let r of n)t.run(r)})(e)}updateMtime(e,t){this.run("UPDATE files SET mtime = ? WHERE path = ?",t,e)}batchSaveIndexResults(e,t,i,n){let r=this.db.prepare("DELETE FROM exports WHERE file_path = ?"),c=this.db.prepare("DELETE FROM imports WHERE file_path = ?"),l=this.db.prepare("DELETE FROM configs WHERE file_path = ?"),a=this.db.prepare("DELETE FROM file_content WHERE file_path = ?"),o=this.db.prepare("DELETE FROM event_synapses WHERE file_path = ?"),u=this.db.prepare("DELETE FROM type_graph_edges WHERE file_path = ?"),
|
|
83
|
+
`,e,e)}deletePaths(e){if(e.length===0)return;let t=this.db.prepare("DELETE FROM files WHERE path = ?");this.db.transaction(n=>{for(let r of n)t.run(r)})(e)}updateMtime(e,t){this.run("UPDATE files SET mtime = ? WHERE path = ?",t,e)}batchSaveIndexResults(e,t,i,n){let r=this.db.prepare("DELETE FROM exports WHERE file_path = ?"),c=this.db.prepare("DELETE FROM imports WHERE file_path = ?"),l=this.db.prepare("DELETE FROM configs WHERE file_path = ?"),a=this.db.prepare("DELETE FROM file_content WHERE file_path = ?"),o=this.db.prepare("DELETE FROM event_synapses WHERE file_path = ?"),u=this.db.prepare("DELETE FROM type_graph_edges WHERE file_path = ?"),m=this.db.prepare("INSERT INTO exports (file_path, name, kind, signature, doc, start_line, end_line, classification, capabilities, parent_id, embedding) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)"),p=this.db.prepare("INSERT INTO imports (file_path, module_specifier, imported_symbols, resolved_path) VALUES (?, ?, ?, ?)"),y=this.db.prepare("INSERT INTO configs (file_path, key, value, kind) VALUES (?, ?, ?, ?)"),g=this.db.prepare("INSERT INTO file_content (file_path, content) VALUES (?, ?)"),T=this.db.prepare("INSERT INTO event_synapses (file_path, type, name, direction, line_number, code_snippet) VALUES (?, ?, ?, ?, ?, ?)"),N=this.db.prepare("INSERT INTO type_graph_edges (file_path, source_symbol_id, source_symbol_name, target_symbol_name, relationship, line_number, metadata) VALUES (?, ?, ?, ?, ?, ?, ?)"),Je=this.db.prepare(`
|
|
84
84
|
INSERT INTO files (path, mtime, last_scanned_at, classification, summary, embedding, content_hash)
|
|
85
85
|
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
86
86
|
ON CONFLICT(path) DO UPDATE SET
|
|
@@ -90,7 +90,7 @@ var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{f
|
|
|
90
90
|
summary=excluded.summary,
|
|
91
91
|
embedding=excluded.embedding,
|
|
92
92
|
content_hash=excluded.content_hash
|
|
93
|
-
`),
|
|
93
|
+
`),Qe=this.db.transaction(C=>{for(let Xe of C){let{meta:_,exports:Ee,imports:he,configs:fe,events:ge,content:B,classification:Ze,summary:et,embedding:_e,contentHash:tt}=Xe;r.run(_.path),c.run(_.path),l.run(_.path),a.run(_.path),o.run(_.path),u.run(_.path);let it=tt??(B&&i?i(B):null);if(Je.run(_.path,_.mtime,Date.now(),Ze||"Unknown",et||"",_e?JSON.stringify(_e):null,it),Ee){let h=(k,nt,st)=>{for(let f of nt){let rt=f.embedding?JSON.stringify(f.embedding):null,be=m.run(k,f.name,f.kind,f.signature,f.doc||"",f.line,f.endLine||f.line,f.classification||"Other",f.capabilities||"[]",st,rt),ye=Number(be.lastInsertRowid);if(Number.isFinite(ye)){let ot=Ie(f.signature);for(let U of ot)U.targetName!==f.name&&N.run(k,ye,f.name,U.targetName,U.relationship,f.line,U.metadata||null)}f.members&&f.members.length>0&&h(k,f.members,be.lastInsertRowid)}};h(_.path,Ee,null)}if(he)for(let h of he){let k=h.resolved_path!==void 0?h.resolved_path:n?.(h.module,_.path,t)??"";p.run(_.path,h.module,h.name,k)}if(fe)for(let h of fe)y.run(_.path,h.key,h.value,h.kind);if(B!==void 0&&g.run(_.path,B),ge)for(let h of ge)T.run(_.path,h.type,h.name,h.direction,h.line,h.snippet)}}),pe=500;for(let C=0;C<e.length;C+=pe)Qe(e.slice(C,C+pe))}getLatestScanTime(){return this.get("SELECT MAX(last_scanned_at) as t FROM files")?.t||null}buildContentFtsQuery(e){let t=e.replace(/([a-z0-9])([A-Z])/g,"$1 $2").toLowerCase().split(/[^a-z0-9_]+/).map(r=>r.trim()).filter(r=>r.length>=2).slice(0,12);if(t.length===0)return"";if(t.length===1)return`${t[0]}*`;let i=`"${t.join(" ")}"`,n=t.map(r=>`${r}*`).join(" OR ");return`${i} OR ${n}`}};var j=class s extends E{static HTTP_METHOD_EXPORTS=new Set(["GET","POST","PUT","PATCH","DELETE","HEAD","OPTIONS"]);findByNameAndFile(e,t){return this.all("SELECT * FROM exports WHERE file_path = ? AND name = ?",t,e)}findByNameGlobal(e){return this.all("SELECT * FROM exports WHERE name = ?",e)}findTopLevelByNameGlobal(e){return this.all("SELECT * FROM exports WHERE name = ? AND parent_id IS NULL",e)}findAtLine(e,t){return this.get(`
|
|
94
94
|
SELECT * FROM exports
|
|
95
95
|
WHERE file_path = ? AND start_line <= ? AND end_line >= ?
|
|
96
96
|
ORDER BY (end_line - start_line) ASC -- Get innermost symbol
|
|
@@ -187,7 +187,7 @@ var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{f
|
|
|
187
187
|
SELECT * FROM exports
|
|
188
188
|
WHERE lower(name) LIKE ?
|
|
189
189
|
LIMIT ?
|
|
190
|
-
`,`%${e.toLowerCase()}%`,t)}getAllNames(e=5e3){return this.all("SELECT DISTINCT name FROM exports WHERE parent_id IS NULL LIMIT ?",e).map(i=>i.name)}countByFile(e){return this.get("SELECT COUNT(*) as count FROM exports WHERE file_path = ?",e)?.count||0}findDeadExports(e={}){let{limit:t=50,includeTests:i=!1,includeMigrations:n=!1,includeFixtures:r=!1,excludePatterns:c=[],confidenceThreshold:l="all"}=e,a=[];i||(a.push("e.file_path NOT LIKE '%/test/%'"),a.push("e.file_path NOT LIKE '%/tests/%'"),a.push("e.file_path NOT LIKE '%/__tests__/%'"),a.push("e.file_path NOT LIKE '%.spec.%'"),a.push("e.file_path NOT LIKE '%.test.%'")),n||(a.push("e.file_path NOT LIKE '%/migrations/%'"),a.push("e.file_path NOT LIKE '%/migration/%'"),a.push("e.file_path NOT LIKE '%Migration.%'")),r||(a.push("e.file_path NOT LIKE '%/__fixtures__/%'"),a.push("e.file_path NOT LIKE '%/__mocks__/%'"),a.push("e.file_path NOT LIKE '%/fixtures/%'"),a.push("e.file_path NOT LIKE '%/mocks/%'"),a.push("e.file_path NOT LIKE '%.fixture.%'"),a.push("e.file_path NOT LIKE '%.mock.%'"));for(let
|
|
190
|
+
`,`%${e.toLowerCase()}%`,t)}getAllNames(e=5e3){return this.all("SELECT DISTINCT name FROM exports WHERE parent_id IS NULL LIMIT ?",e).map(i=>i.name)}countByFile(e){return this.get("SELECT COUNT(*) as count FROM exports WHERE file_path = ?",e)?.count||0}findDeadExports(e={}){let{limit:t=50,includeTests:i=!1,includeMigrations:n=!1,includeFixtures:r=!1,excludePatterns:c=[],confidenceThreshold:l="all"}=e,a=[];i||(a.push("e.file_path NOT LIKE '%/test/%'"),a.push("e.file_path NOT LIKE '%/tests/%'"),a.push("e.file_path NOT LIKE '%/__tests__/%'"),a.push("e.file_path NOT LIKE '%.spec.%'"),a.push("e.file_path NOT LIKE '%.test.%'")),n||(a.push("e.file_path NOT LIKE '%/migrations/%'"),a.push("e.file_path NOT LIKE '%/migration/%'"),a.push("e.file_path NOT LIKE '%Migration.%'")),r||(a.push("e.file_path NOT LIKE '%/__fixtures__/%'"),a.push("e.file_path NOT LIKE '%/__mocks__/%'"),a.push("e.file_path NOT LIKE '%/fixtures/%'"),a.push("e.file_path NOT LIKE '%/mocks/%'"),a.push("e.file_path NOT LIKE '%.fixture.%'"),a.push("e.file_path NOT LIKE '%.mock.%'")),a.push("e.file_path NOT LIKE '%/dist/%'"),a.push("e.file_path NOT LIKE '%/build/%'"),a.push("e.file_path NOT LIKE '%/.next/%'"),a.push("e.file_path NOT LIKE '%/.nuxt/%'"),a.push("e.file_path NOT LIKE '%/.cache/%'"),a.push("e.file_path NOT LIKE '%/coverage/%'"),a.push("e.file_path NOT LIKE '%/node_modules/%'"),a.push("e.file_path NOT LIKE '%/storage/runtime/%'"),a.push("e.file_path NOT LIKE '%/compiled_templates/%'"),a.push("e.file_path NOT LIKE '%/compiled_classes/%'"),a.push("e.file_path NOT LIKE '%.generated.%'"),a.push("e.file_path NOT LIKE '%.gen.%'");for(let g of c){let T=g.replace(/\*\*/g,"%").replace(/\*/g,"%").replace(/\?/g,"_");a.push(`e.file_path NOT LIKE '${T}'`)}let o=a.length>0?`AND ${a.join(" AND ")}`:"",p=this.all(`
|
|
191
191
|
SELECT e.name, e.kind, e.file_path, e.start_line
|
|
192
192
|
FROM exports e
|
|
193
193
|
WHERE e.kind IN (
|
|
@@ -208,7 +208,7 @@ var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{f
|
|
|
208
208
|
AND NOT EXISTS (SELECT 1 FROM imports i WHERE i.resolved_path = e.file_path AND i.imported_symbols LIKE '%*%')
|
|
209
209
|
ORDER BY e.file_path, e.start_line
|
|
210
210
|
LIMIT ?
|
|
211
|
-
`,t*2).filter(
|
|
211
|
+
`,t*2).filter(g=>!this.isFrameworkEntrypointExport(g)).map(g=>{let{confidence:T,reason:N}=this.scoreDeadExportConfidence(g);return{...g,confidence:T,reason:N}}),y=p;return l==="high"?y=p.filter(g=>g.confidence==="high"):l==="medium"&&(y=p.filter(g=>g.confidence==="high"||g.confidence==="medium")),y.slice(0,t)}scoreDeadExportConfidence(e){let t=e.file_path.toLowerCase(),i=e.name;return t.includes("/index.")||t.endsWith("index.ts")||t.endsWith("index.js")?{confidence:"low",reason:"Barrel/index file - likely re-export"}:e.kind==="TsInterfaceDeclaration"||e.kind==="TsTypeAliasDeclaration"?{confidence:"medium",reason:"Type definition - may be used externally"}:t.includes("/entry/")||t.includes("/bin/")||t.includes("main.")||t.includes("server.")||t.includes("cli.")?{confidence:"medium",reason:"Entry point - may be invoked externally"}:(t.includes("/components/")||t.endsWith(".tsx")||t.endsWith(".jsx"))&&/^[A-Z][A-Za-z0-9_]*$/.test(i)?{confidence:"medium",reason:"Component export - may be used by runtime composition"}:(t.includes("/contexts/")||t.includes("/context/"))&&(/Provider$/.test(i)||i.startsWith("use"))?{confidence:"medium",reason:"Context/provider export - may be wired dynamically"}:i.startsWith("create")||i.endsWith("Factory")||i.endsWith("Builder")?{confidence:"medium",reason:"Factory/builder pattern - may be used dynamically"}:i.startsWith("use")&&i.length>3?{confidence:"medium",reason:"Hook pattern - may be used in components"}:{confidence:"high",reason:"No detected usage"}}isFrameworkEntrypointExport(e){let i=e.file_path.toLowerCase().replace(/\\/g,"/"),n=e.name;return!!(/(^|\/)(src\/)?app\/.*\/route\.(t|j)sx?$/.test(i)&&s.HTTP_METHOD_EXPORTS.has(n)||/(^|\/)(src\/)?app\/.*\/(page|layout|loading|error|not-found|default|template)\.(t|j)sx?$/.test(i)||/(^|\/)(src\/)?middleware\.(t|j)sx?$/.test(i)||i.includes("/app/exceptions/handler.php")||i.includes("/app/http/middleware/")||i.includes("/app/providers/")||i.includes("/app/console/commands/")||i.includes("/database/seeds/")||i.includes("/config/")&&i.endsWith(".php")||i.includes("/routes/")&&["loader","action","meta","headers"].includes(n))}getGravityMap(e=[],t){let i={},n=`
|
|
212
212
|
SELECT ws.symbol_id, m.name as mission_name, m.status
|
|
213
213
|
FROM working_set ws
|
|
214
214
|
JOIN missions m ON ws.mission_id = m.id
|
|
@@ -217,14 +217,14 @@ var ot=Object.defineProperty;var P=(s,e)=>()=>(s&&(e=s(s=0)),e);var at=(s,e)=>{f
|
|
|
217
217
|
OR m.id IN (${e.length>0?e.join(","):"-1"})
|
|
218
218
|
)
|
|
219
219
|
AND ws.symbol_id IS NOT NULL
|
|
220
|
-
`,r=[];t&&r.push(t);let c=this.all(n,...r);for(let o of c){i[o.symbol_id]||(i[o.symbol_id]={score:1,reasons:[]});let u=o.status==="in-progress"||o.status==="verifying"?1:.5;i[o.symbol_id].score+=u;let
|
|
220
|
+
`,r=[];t&&r.push(t);let c=this.all(n,...r);for(let o of c){i[o.symbol_id]||(i[o.symbol_id]={score:1,reasons:[]});let u=o.status==="in-progress"||o.status==="verifying"?1:.5;i[o.symbol_id].score+=u;let m=o.status==="in-progress"||o.status==="verifying"?"Working Set":"Lineage Bleed";i[o.symbol_id].reasons.push(`${m}: ${o.mission_name}`)}let l=Math.floor(Date.now()/1e3)-86400,a=this.all(`
|
|
221
221
|
SELECT symbol_id, type, mission_id
|
|
222
222
|
FROM intent_logs
|
|
223
223
|
WHERE (created_at > ? OR mission_id IN (${e.length>0?e.join(","):"-1"}))
|
|
224
224
|
AND symbol_id IS NOT NULL
|
|
225
225
|
ORDER BY created_at DESC
|
|
226
226
|
LIMIT 200
|
|
227
|
-
`,l);for(let o of a){i[o.symbol_id]||(i[o.symbol_id]={score:1,reasons:[]});let u=o.mission_id?e.includes(o.mission_id):!1,
|
|
227
|
+
`,l);for(let o of a){i[o.symbol_id]||(i[o.symbol_id]={score:1,reasons:[]});let u=o.mission_id?e.includes(o.mission_id):!1,m=u?.1:.2;i[o.symbol_id].score<5&&(i[o.symbol_id].score+=m);let p=u?`Lineage Intent: ${o.type}`:`Recent Intent: ${o.type}`;!i[o.symbol_id].reasons.includes(p)&&i[o.symbol_id].reasons.length<5&&i[o.symbol_id].reasons.push(p)}return i}getCount(){return this.get("SELECT COUNT(*) as count FROM exports")?.count||0}getKindDistribution(e=5){return this.all(`
|
|
228
228
|
SELECT kind, COUNT(*) as c
|
|
229
229
|
FROM exports
|
|
230
230
|
WHERE kind IS NOT NULL AND kind != ''
|
|
@@ -314,7 +314,7 @@ SELECT DISTINCT
|
|
|
314
314
|
dc.imported_symbols
|
|
315
315
|
FROM dependency_chain dc
|
|
316
316
|
ORDER BY dc.depth, dc.consumer_path;
|
|
317
|
-
`;var
|
|
317
|
+
`;var q=class extends E{findByFile(e){return this.all("SELECT * FROM imports WHERE file_path = ?",e)}findByFiles(e){if(e.length===0)return[];let t=e.map(()=>"?").join(", ");return this.all(`SELECT * FROM imports WHERE file_path IN (${t}) ORDER BY file_path`,...e)}getAllResolved(){return this.all(`
|
|
318
318
|
SELECT * FROM imports
|
|
319
319
|
WHERE resolved_path IS NOT NULL AND resolved_path != ''
|
|
320
320
|
`)}findDependents(e){return this.all("SELECT * FROM imports WHERE resolved_path = ?",e)}countByFile(e){return this.get("SELECT COUNT(*) as count FROM imports WHERE file_path = ?",e)?.count||0}countDependents(e){return this.get("SELECT COUNT(*) as count FROM imports WHERE resolved_path = ?",e)?.count||0}getImportsForFile(e){return this.all("SELECT module_specifier, imported_symbols, resolved_path FROM imports WHERE file_path = ?",e)}findImportSource(e,t){return this.get(`
|
|
@@ -406,7 +406,7 @@ ORDER BY dc.depth, dc.consumer_path;
|
|
|
406
406
|
SELECT AVG(updated_at - created_at) AS avg_duration
|
|
407
407
|
FROM missions
|
|
408
408
|
WHERE status = 'completed' AND updated_at > created_at
|
|
409
|
-
`),n=i?.avg_duration!=null?Math.round(i.avg_duration):null,r=Math.floor(Date.now()/1e3)-168*3600,c=Math.floor(Date.now()/1e3)-720*3600,l=this.get("SELECT COUNT(*) AS n FROM missions WHERE status = 'completed' AND updated_at >= ?",r),a=this.get("SELECT COUNT(*) AS n FROM missions WHERE status = 'completed' AND updated_at >= ?",c),o=l?.n??0,u=a?.n??0,
|
|
409
|
+
`),n=i?.avg_duration!=null?Math.round(i.avg_duration):null,r=Math.floor(Date.now()/1e3)-168*3600,c=Math.floor(Date.now()/1e3)-720*3600,l=this.get("SELECT COUNT(*) AS n FROM missions WHERE status = 'completed' AND updated_at >= ?",r),a=this.get("SELECT COUNT(*) AS n FROM missions WHERE status = 'completed' AND updated_at >= ?",c),o=l?.n??0,u=a?.n??0,m=`${o} completed in last 7 days, ${u} in last 30 days.`;if(n!=null){let p=Math.round(n/60);m+=` Avg mission duration: ${p} min.`}return{completionRate:t,averageDurationSeconds:n,completedLast7Days:o,completedLast30Days:u,velocityNote:m}}suspendByBranch(e){return this.run(`UPDATE missions
|
|
410
410
|
SET status = 'suspended', updated_at = unixepoch()
|
|
411
411
|
WHERE git_branch = ? AND status IN ('in-progress', 'verifying')`,e)}resumeByBranch(e){return this.run(`UPDATE missions
|
|
412
412
|
SET status = 'in-progress', updated_at = unixepoch()
|
|
@@ -431,7 +431,7 @@ ORDER BY dc.depth, dc.consumer_path;
|
|
|
431
431
|
SELECT linked_repo_path, linked_mission_id, relationship, direction
|
|
432
432
|
FROM cross_repo_links
|
|
433
433
|
WHERE mission_id = ?
|
|
434
|
-
`,e)}catch{return[]}}findLastMission(){return this.get("SELECT * FROM missions ORDER BY updated_at DESC, id DESC LIMIT 1")}findActiveByPriority(){return this.get("SELECT * FROM missions WHERE status IN ('in-progress', 'active', 'verifying') ORDER BY CASE WHEN status = 'in-progress' THEN 0 ELSE 1 END, created_at ASC LIMIT 1")}addHandoff(e,t){let i=JSON.stringify(t),n=
|
|
434
|
+
`,e)}catch{return[]}}findLastMission(){return this.get("SELECT * FROM missions ORDER BY updated_at DESC, id DESC LIMIT 1")}findActiveByPriority(){return this.get("SELECT * FROM missions WHERE status IN ('in-progress', 'active', 'verifying') ORDER BY CASE WHEN status = 'in-progress' THEN 0 ELSE 1 END, created_at ASC LIMIT 1")}addHandoff(e,t){let i=JSON.stringify(t),n=this.insert("INSERT INTO mission_artifacts (mission_id, type, identifier, metadata) VALUES (?, ?, ?, ?)",e,"handoff",t.kind,i),r=[`[handoff:${t.kind}]`,...t.findings.map(c=>c.statement),...t.risks.map(c=>c.description),...t.gaps].filter(Boolean).join(" ");return Promise.resolve().then(()=>(S(),O)).then(({generateEmbedding:c})=>c(r)).then(c=>{c&&this.run("UPDATE mission_artifacts SET embedding = ? WHERE id = ?",JSON.stringify(c),n)}).catch(()=>{}),n}getHandoffs(e,t,i=20){let n=["type = 'handoff'"],r=[];e!==void 0&&(e===null?n.push("mission_id IS NULL"):(n.push("mission_id = ?"),r.push(e))),t&&(n.push("identifier = ?"),r.push(t));let c=`SELECT * FROM mission_artifacts WHERE ${n.join(" AND ")} ORDER BY created_at DESC LIMIT ?`;return r.push(i),this.all(c,...r)}async findSemanticHandoffs(e,t){let{cosineSimilarity:i}=await Promise.resolve().then(()=>(S(),O)),n=["type = 'handoff'","embedding IS NOT NULL"],r=[];t?.missionId!==void 0&&(t.missionId===null?n.push("mission_id IS NULL"):(n.push("mission_id = ?"),r.push(t.missionId))),t?.kind&&(n.push("identifier = ?"),r.push(t.kind));let c=this.all(`SELECT * FROM mission_artifacts WHERE ${n.join(" AND ")}`,...r),l=[];for(let a of c)try{let o=JSON.parse(a.embedding),u=i(e,o);u>.3&&l.push({...a,similarity:u})}catch{}return l.sort((a,o)=>o.similarity-a.similarity).slice(0,t?.limit??5)}};M();var J=class s extends E{findByMission(e,t=50){return this.all(`
|
|
435
435
|
SELECT
|
|
436
436
|
id, mission_id, symbol_id, file_path, type, content, confidence,
|
|
437
437
|
symbol_name, signature, commit_sha, is_crystallized, crystal_id,
|
|
@@ -452,7 +452,7 @@ ORDER BY dc.depth, dc.consumer_path;
|
|
|
452
452
|
`,e)}create(e){let t=this.insert(`
|
|
453
453
|
INSERT INTO intent_logs (mission_id, symbol_id, file_path, type, content, confidence, symbol_name, signature, commit_sha)
|
|
454
454
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
455
|
-
`,e.mission_id,e.symbol_id,e.file_path,e.type,e.content,e.confidence,e.symbol_name,e.signature,e.commit_sha);return s.EMBEDDABLE_TYPES.has(e.type)&&this.generateAndStoreEmbedding(Number(t),e).catch(i=>{d.debug({err:i,intentLogId:t},"Failed to generate intent log embedding")}),t}static EMBEDDABLE_TYPES=new Set(["decision","discovery","fix","blocker","note","heritage","crystal"]);static buildEmbeddingText(e){let t=[`[${e.type}]`];return e.symbol_name&&t.push(`symbol: ${e.symbol_name}`),e.file_path&&t.push(`file: ${e.file_path.split("/").pop()}`),t.push(e.content),t.join(" ")}async generateAndStoreEmbedding(e,t){let{generateEmbedding:i}=await Promise.resolve().then(()=>(S(),
|
|
455
|
+
`,e.mission_id,e.symbol_id,e.file_path,e.type,e.content,e.confidence,e.symbol_name,e.signature,e.commit_sha);return s.EMBEDDABLE_TYPES.has(e.type)&&this.generateAndStoreEmbedding(Number(t),e).catch(i=>{d.debug({err:i,intentLogId:t},"Failed to generate intent log embedding")}),t}static EMBEDDABLE_TYPES=new Set(["decision","discovery","fix","blocker","note","heritage","crystal"]);static buildEmbeddingText(e){let t=[`[${e.type}]`];return e.symbol_name&&t.push(`symbol: ${e.symbol_name}`),e.file_path&&t.push(`file: ${e.file_path.split("/").pop()}`),t.push(e.content),t.join(" ")}async generateAndStoreEmbedding(e,t){let{generateEmbedding:i}=await Promise.resolve().then(()=>(S(),O)),n=s.buildEmbeddingText(t),r=await i(n);r&&this.run("UPDATE intent_logs SET embedding = ? WHERE id = ?",JSON.stringify(r),e)}findWithEmbeddings(){return this.all("SELECT * FROM intent_logs WHERE embedding IS NOT NULL AND type NOT IN ('system', 'lapsed')")}async findSemanticMatches(e,t,i){let{cosineSimilarity:n}=await Promise.resolve().then(()=>(S(),O)),r=this.findWithEmbeddings();if(r.length>5e3)return d.warn({count:r.length},"Intent log count exceeds brute-force vector scan limit (5000). Skipping semantic recall."),[];let c=[];for(let l of r)if(!(i&&l.symbol_id===i))try{let a=JSON.parse(l.embedding),o=n(e,a);o>.25&&c.push({id:l.id,mission_id:l.mission_id,type:l.type,content:l.content,symbol_name:l.symbol_name,file_path:l.file_path,similarity:o,created_at:l.created_at})}catch{}return c.sort((l,a)=>a.similarity-l.similarity).slice(0,t)}delete(e){this.run("DELETE FROM intent_logs WHERE id = ?",e)}update(e,t){let i=Object.keys(t);if(i.length===0)return;let n=i.map(c=>`${c} = ?`).join(", "),r=Object.values(t);r.push(e),this.run(`UPDATE intent_logs SET ${n} WHERE id = ?`,...r)}findRepairableOrphans(){return this.all(`
|
|
456
456
|
SELECT id, file_path, symbol_name, signature
|
|
457
457
|
FROM intent_logs
|
|
458
458
|
WHERE symbol_id IS NULL AND symbol_name IS NOT NULL
|
|
@@ -484,24 +484,48 @@ ORDER BY dc.depth, dc.consumer_path;
|
|
|
484
484
|
FROM intent_logs
|
|
485
485
|
WHERE mission_id = ? AND is_crystallized = 0
|
|
486
486
|
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')
|
|
487
|
+
ORDER BY created_at ASC`,e)}findCrystallizableByMission(e){return this.all(`SELECT
|
|
488
|
+
id, mission_id, symbol_id, file_path, type, content, confidence,
|
|
489
|
+
symbol_name, signature, commit_sha, is_crystallized, crystal_id,
|
|
490
|
+
created_at
|
|
491
|
+
FROM intent_logs
|
|
492
|
+
WHERE mission_id = ?
|
|
493
|
+
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')
|
|
487
494
|
ORDER BY created_at ASC`,e)}findCrystalByMission(e){return this.get(`SELECT
|
|
488
495
|
id, mission_id, symbol_id, file_path, type, content, confidence,
|
|
489
496
|
symbol_name, signature, commit_sha, is_crystallized, crystal_id,
|
|
490
497
|
created_at
|
|
491
498
|
FROM intent_logs
|
|
492
499
|
WHERE mission_id = ? AND type = 'crystal'
|
|
493
|
-
ORDER BY created_at DESC LIMIT 1`,e)}
|
|
494
|
-
|
|
500
|
+
ORDER BY created_at DESC LIMIT 1`,e)}findCrystalBySymbol(e){return this.get(`SELECT
|
|
501
|
+
id, mission_id, symbol_id, file_path, type, content, confidence,
|
|
502
|
+
symbol_name, signature, commit_sha, is_crystallized, crystal_id,
|
|
503
|
+
created_at
|
|
504
|
+
FROM intent_logs
|
|
505
|
+
WHERE symbol_id = ? AND mission_id IS NULL AND type = 'crystal'
|
|
506
|
+
ORDER BY created_at DESC LIMIT 1`,e)}crystallize(e,t,i){return this.transaction(()=>{let n=i;return typeof n=="number"?this.run(`UPDATE intent_logs
|
|
507
|
+
SET content = ?, confidence = 1.0
|
|
508
|
+
WHERE id = ? AND mission_id = ? AND type = 'crystal'`,t,n,e):n=Number(this.insert(`INSERT INTO intent_logs (mission_id, type, content, confidence, is_crystallized, symbol_id, file_path, symbol_name, signature, commit_sha)
|
|
509
|
+
VALUES (?, 'crystal', ?, 1.0, 0, NULL, NULL, NULL, NULL, NULL)`,e,t)),this.run(`UPDATE intent_logs
|
|
495
510
|
SET is_crystallized = 1, crystal_id = ?
|
|
496
511
|
WHERE mission_id = ? AND is_crystallized = 0 AND id != ?
|
|
497
|
-
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')`,
|
|
512
|
+
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')`,n,e,n),this.generateAndStoreEmbedding(n,{type:"crystal",content:t}).catch(r=>{d.debug({err:r,intentLogId:n},"Failed to refresh crystal embedding")}),n})}findRawBySymbol(e){return this.all(`SELECT * FROM intent_logs
|
|
498
513
|
WHERE symbol_id = ? AND mission_id IS NULL AND is_crystallized = 0
|
|
499
514
|
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')
|
|
500
|
-
ORDER BY created_at ASC`,e)}
|
|
501
|
-
|
|
515
|
+
ORDER BY created_at ASC`,e)}findCrystallizableBySymbol(e){return this.all(`SELECT
|
|
516
|
+
id, mission_id, symbol_id, file_path, type, content, confidence,
|
|
517
|
+
symbol_name, signature, commit_sha, is_crystallized, crystal_id,
|
|
518
|
+
created_at
|
|
519
|
+
FROM intent_logs
|
|
520
|
+
WHERE symbol_id = ? AND mission_id IS NULL
|
|
521
|
+
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')
|
|
522
|
+
ORDER BY created_at ASC`,e)}crystallizeBySymbol(e,t,i){return this.transaction(()=>{let n=i;return typeof n=="number"?this.run(`UPDATE intent_logs
|
|
523
|
+
SET content = ?, confidence = 1.0
|
|
524
|
+
WHERE id = ? AND symbol_id = ? AND mission_id IS NULL AND type = 'crystal'`,t,n,e):n=Number(this.insert(`INSERT INTO intent_logs (mission_id, symbol_id, type, content, confidence, is_crystallized, file_path, symbol_name, signature, commit_sha)
|
|
525
|
+
VALUES (NULL, ?, 'crystal', ?, 1.0, 0, NULL, NULL, NULL, NULL)`,e,t)),this.run(`UPDATE intent_logs
|
|
502
526
|
SET is_crystallized = 1, crystal_id = ?
|
|
503
527
|
WHERE symbol_id = ? AND mission_id IS NULL AND is_crystallized = 0 AND id != ?
|
|
504
|
-
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')`,
|
|
528
|
+
AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')`,n,e,n),this.generateAndStoreEmbedding(n,{type:"crystal",content:t}).catch(r=>{d.debug({err:r,intentLogId:n},"Failed to refresh crystal embedding")}),n})}countByMissions(e){if(e.length===0)return{};let t=e.map(()=>"?").join(","),i=this.all(`SELECT mission_id, COUNT(*) as cnt
|
|
505
529
|
FROM intent_logs
|
|
506
530
|
WHERE mission_id IN (${t})
|
|
507
531
|
AND type NOT IN ('system', 'adr', 'lapsed')
|
|
@@ -515,8 +539,8 @@ ORDER BY dc.depth, dc.consumer_path;
|
|
|
515
539
|
FROM intent_logs
|
|
516
540
|
WHERE mission_id = ? AND is_crystallized = 0 AND type NOT IN ('adr', 'system', 'crystal', 'lapsed')
|
|
517
541
|
AND created_at > ?
|
|
518
|
-
ORDER BY created_at DESC LIMIT ?`,e,i.created_at,t-1);return[i,...n]}return this.findByMission(e,t)}async findSemanticTheme(e,t,i=200){let{cosineSimilarity:n}=await Promise.resolve().then(()=>(S(),
|
|
519
|
-
VALUES (NULL, 'crystal', ?, 1.0, 0, NULL, NULL, NULL, NULL, NULL)`,i);if(t.length>0){let r=t.map(()=>"?").join(",");this.run(`UPDATE intent_logs SET is_crystallized = 1, crystal_id = ? WHERE id IN (${r})`,n,...t)}return n})}async backfillEmbeddings(e=64,t){let{generateEmbeddingsBatch:i}=await Promise.resolve().then(()=>(S(),
|
|
542
|
+
ORDER BY created_at DESC LIMIT ?`,e,i.created_at,t-1);return[i,...n]}return this.findByMission(e,t)}async findSemanticTheme(e,t,i=200){let{cosineSimilarity:n}=await Promise.resolve().then(()=>(S(),O)),r=this.findWithEmbeddings(),c=[];for(let l of r)if(s.EMBEDDABLE_TYPES.has(l.type)&&l.type!=="crystal"&&l.mission_id!=null&&!(t&&!t.includes(l.mission_id)))try{let a=JSON.parse(l.embedding),o=n(e,a);o>.35&&c.push({...l,_similarity:o})}catch{}return c.sort((l,a)=>a._similarity-l._similarity).slice(0,i).map(({_similarity:l,...a})=>a)}crystallizeTheme(e,t,i){return this.transaction(()=>{let n=this.insert(`INSERT INTO intent_logs (mission_id, type, content, confidence, is_crystallized, symbol_id, file_path, symbol_name, signature, commit_sha)
|
|
543
|
+
VALUES (NULL, 'crystal', ?, 1.0, 0, NULL, NULL, NULL, NULL, NULL)`,i);if(t.length>0){let r=t.map(()=>"?").join(",");this.run(`UPDATE intent_logs SET is_crystallized = 1, crystal_id = ? WHERE id IN (${r})`,n,...t)}return n})}async backfillEmbeddings(e=64,t){let{generateEmbeddingsBatch:i}=await Promise.resolve().then(()=>(S(),O)),n=[...s.EMBEDDABLE_TYPES].map(u=>`'${u}'`).join(","),r=this.all(`SELECT * FROM intent_logs WHERE embedding IS NULL AND type IN (${n})`);if(r.length===0)return 0;let c=r.map(u=>s.buildEmbeddingText(u)),l=await i(c,e,t),a=this.db.prepare("UPDATE intent_logs SET embedding = ? WHERE id = ?"),o=0;return this.transaction(()=>{for(let u=0;u<r.length;u++)l[u]&&(a.run(JSON.stringify(l[u]),r[u].id),o++)}),d.info({total:r.length,embedded:o},"Intent log embedding backfill complete"),o}};var Q=class extends E{findByKey(e,t=20){return this.all(`
|
|
520
544
|
SELECT file_path, key, value, kind
|
|
521
545
|
FROM configs
|
|
522
546
|
WHERE key LIKE ? OR value LIKE ?
|
|
@@ -526,20 +550,73 @@ ORDER BY dc.depth, dc.consumer_path;
|
|
|
526
550
|
FROM content_fts
|
|
527
551
|
WHERE content_fts MATCH ?
|
|
528
552
|
LIMIT ?
|
|
529
|
-
`,e,t)}};var
|
|
530
|
-
WHERE query LIKE ? ORDER BY created_at DESC LIMIT ?`,`${e}%`,t):this.findRecent(t)}pruneIfNeeded(){(this.get("SELECT COUNT(*) as count FROM search_history")?.count??0)
|
|
553
|
+
`,e,t)}};var $e=500,Z=class extends E{record(e,t,i=null){this.run("INSERT INTO search_history (query, mode, branch) VALUES (?, ?, ?)",e,t,i),this.pruneIfNeeded()}findRecent(e=20){return this.all("SELECT id, query, mode, branch, created_at FROM search_history ORDER BY created_at DESC LIMIT ?",e)}findRecentByQueryPrefix(e,t=10){return e.trim()?this.all(`SELECT id, query, mode, branch, created_at FROM search_history
|
|
554
|
+
WHERE query LIKE ? ORDER BY created_at DESC LIMIT ?`,`${e}%`,t):this.findRecent(t)}pruneIfNeeded(){(this.get("SELECT COUNT(*) as count FROM search_history")?.count??0)<=$e||this.run(`DELETE FROM search_history WHERE id NOT IN (
|
|
531
555
|
SELECT id FROM search_history ORDER BY created_at DESC LIMIT ?
|
|
532
|
-
)
|
|
556
|
+
)`,$e)}};var ee=class extends E{getSection(e){return this.get("SELECT section, data, updated_at FROM hologram_snapshot WHERE section = ?",e)}getAllSections(){return this.all("SELECT section, data, updated_at FROM hologram_snapshot ORDER BY section")}upsertSection(e,t){this.run(`
|
|
533
557
|
INSERT INTO hologram_snapshot (section, data, updated_at)
|
|
534
558
|
VALUES (?, ?, unixepoch())
|
|
535
559
|
ON CONFLICT(section) DO UPDATE SET
|
|
536
560
|
data = excluded.data,
|
|
537
561
|
updated_at = excluded.updated_at
|
|
538
|
-
`,e,t)}deleteSection(e){this.run("DELETE FROM hologram_snapshot WHERE section = ?",e)}deleteAll(){this.run("DELETE FROM hologram_snapshot")}hasSection(e){return(this.get("SELECT COUNT(*) as count FROM hologram_snapshot WHERE section = ?",e)?.count??0)>0}};var te=class
|
|
539
|
-
|
|
540
|
-
|
|
562
|
+
`,e,t)}deleteSection(e){this.run("DELETE FROM hologram_snapshot WHERE section = ?",e)}deleteAll(){this.run("DELETE FROM hologram_snapshot")}hasSection(e){return(this.get("SELECT COUNT(*) as count FROM hologram_snapshot WHERE section = ?",e)?.count??0)>0}};var te=class extends E{claimFile(e,t){try{this.run(`
|
|
563
|
+
INSERT INTO file_claims (file_path, mission_id, claimed_at, updated_at)
|
|
564
|
+
VALUES (?, ?, unixepoch(), unixepoch())
|
|
565
|
+
`,e,t);let i=this.getClaim(e);if(!i)throw new Error(`Failed to hydrate claim after insert for file ${e}`);return{status:"claimed",claim:i}}catch{let i=this.getClaim(e);if(!i)throw new Error(`Failed to read existing claim for file ${e}`);return i.mission_id===t?(this.run("UPDATE file_claims SET updated_at = unixepoch() WHERE file_path = ?",e),{status:"already_claimed",claim:this.getClaim(e)??i}):{status:"conflict",claim:i}}}releaseFile(e,t){let i=this.getClaim(e);return i?t!==void 0&&i.mission_id!==t?{released:!1,reason:"not_owner",claim:i}:(this.run("DELETE FROM file_claims WHERE file_path = ?",e),{released:!0}):{released:!1,reason:"not_found"}}releaseAllForMission(e){return this.run("DELETE FROM file_claims WHERE mission_id = ?",e)}getClaim(e){return this.get(`
|
|
566
|
+
SELECT
|
|
567
|
+
fc.file_path,
|
|
568
|
+
fc.mission_id,
|
|
569
|
+
fc.claimed_at,
|
|
570
|
+
fc.updated_at,
|
|
571
|
+
m.name AS mission_name,
|
|
572
|
+
m.status AS mission_status,
|
|
573
|
+
m.git_branch AS mission_branch
|
|
574
|
+
FROM file_claims fc
|
|
575
|
+
LEFT JOIN missions m ON m.id = fc.mission_id
|
|
576
|
+
WHERE fc.file_path = ?
|
|
577
|
+
`,e)}getClaimsForMission(e){return this.all(`
|
|
578
|
+
SELECT
|
|
579
|
+
fc.file_path,
|
|
580
|
+
fc.mission_id,
|
|
581
|
+
fc.claimed_at,
|
|
582
|
+
fc.updated_at,
|
|
583
|
+
m.name AS mission_name,
|
|
584
|
+
m.status AS mission_status,
|
|
585
|
+
m.git_branch AS mission_branch
|
|
586
|
+
FROM file_claims fc
|
|
587
|
+
LEFT JOIN missions m ON m.id = fc.mission_id
|
|
588
|
+
WHERE fc.mission_id = ?
|
|
589
|
+
ORDER BY fc.file_path ASC
|
|
590
|
+
`,e)}listClaims(){return this.all(`
|
|
591
|
+
SELECT
|
|
592
|
+
fc.file_path,
|
|
593
|
+
fc.mission_id,
|
|
594
|
+
fc.claimed_at,
|
|
595
|
+
fc.updated_at,
|
|
596
|
+
m.name AS mission_name,
|
|
597
|
+
m.status AS mission_status,
|
|
598
|
+
m.git_branch AS mission_branch
|
|
599
|
+
FROM file_claims fc
|
|
600
|
+
LEFT JOIN missions m ON m.id = fc.mission_id
|
|
601
|
+
ORDER BY fc.updated_at DESC, fc.file_path ASC
|
|
602
|
+
`)}getClaimsByFiles(e){if(e.length===0)return[];let t=e.map(()=>"?").join(", ");return this.all(`
|
|
603
|
+
SELECT
|
|
604
|
+
fc.file_path,
|
|
605
|
+
fc.mission_id,
|
|
606
|
+
fc.claimed_at,
|
|
607
|
+
fc.updated_at,
|
|
608
|
+
m.name AS mission_name,
|
|
609
|
+
m.status AS mission_status,
|
|
610
|
+
m.git_branch AS mission_branch
|
|
611
|
+
FROM file_claims fc
|
|
612
|
+
LEFT JOIN missions m ON m.id = fc.mission_id
|
|
613
|
+
WHERE fc.file_path IN (${t})
|
|
614
|
+
ORDER BY fc.file_path ASC
|
|
615
|
+
`,...e)}};var ie=class{static repositoryCache=new Map;static getInstance(e){let t=this.repositoryCache.get(e);if(t){let r=F(e),c=t.files?.database,a=!t.intentLogs||!t.searchHistory||!t.missions||!t.hologram||!t.claims;if(c===r&&r.open&&!a)return t;this.repositoryCache.delete(e)}let i=F(e),n={files:new Y(i),exports:new j(i),imports:new q(i),missions:new V(i),intentLogs:new J(i),configs:new Q(i),content:new X(i),searchHistory:new Z(i),hologram:new ee(i),claims:new te(i)};return this.repositoryCache.set(e,n),n}static closeInstance(e){this.repositoryCache.delete(e),Le(e)}static clearCache(e){this.repositoryCache.delete(e)}};S();var ze=new Set(["FunctionDeclaration","ClassDeclaration","TsInterfaceDeclaration","TsTypeAliasDeclaration","TsEnumDeclaration","HTTP Route","Socket Event","Pub/Sub Topic","function","class","interface","type","enum"]),Ke={"HTTP Route":0,"Socket Event":0,"Pub/Sub Topic":0,TsInterfaceDeclaration:1,TsTypeAliasDeclaration:1,TsEnumDeclaration:1,interface:1,type:1,enum:1,FunctionDeclaration:2,function:2,ClassDeclaration:3,class:3};function Ye(s,e,t=[]){let i=t.length>0?`${t.join(" > ")} > ${e.name}`:String(e.name),n=[`Symbol: ${e.name}`,`Kind: ${e.kind??"Unknown"}`,`Scope: ${i}`,`File: ${s}`];return e.signature&&n.push(`Signature: ${String(e.signature)}`),e.doc&&n.push(`Doc: ${String(e.doc)}`),n.join(`
|
|
616
|
+
`)}function je(s){return s.map(()=>"?").join(",")}var Gt=me.constants.priority.PRIORITY_LOWEST??me.constants.priority.PRIORITY_LOW,ne=process.argv[2];ne||(process.stderr.write(`Ember: repoPath argument missing
|
|
617
|
+
`),process.exit(1));try{me.setPriority(Gt)}catch{}function w(s,e){s.transaction(()=>{let t=s.prepare("INSERT OR REPLACE INTO ember_state (key, value, updated_at) VALUES (?, ?, unixepoch())");for(let[i,n]of Object.entries(e))t.run(i,n??null)})()}var qe=100,re=[...ze],Ge=je(re),Vt=re.map(s=>`WHEN '${s.replace(/'/g,"''")}' THEN ${Ke[s]??2}`).join(" ").trim(),se=x({numWorkers:2}),b;async function Jt(){b=F(ne),w(b,{status:"running",pid:String(process.pid),started_at:String(Date.now()),repo_path:ne}),await se.initialize();let e=b.prepare(`SELECT COUNT(*) as c FROM exports WHERE embedding IS NULL AND kind IN (${Ge})`).get(...re).c,t=0;w(b,{progress:`0/${e}`});let i=b.prepare(`SELECT id, file_path, name, kind, signature, doc, start_line, end_line
|
|
541
618
|
FROM exports
|
|
542
|
-
WHERE embedding IS NULL AND kind IN (${
|
|
543
|
-
ORDER BY CASE kind ${
|
|
544
|
-
LIMIT ${qe}`),n=
|
|
545
|
-
`);try{
|
|
619
|
+
WHERE embedding IS NULL AND kind IN (${Ge})
|
|
620
|
+
ORDER BY CASE kind ${Vt} END
|
|
621
|
+
LIMIT ${qe}`),n=b.prepare("UPDATE exports SET embedding = ? WHERE id = ?");for(;;){let r=i.all(...re);if(r.length===0)break;let c=r.map(a=>Ye(a.file_path,a)),l=await se.generateEmbeddings(c,qe);b.transaction(()=>{for(let a=0;a<r.length;a++){let o=l[a];o&&n.run(JSON.stringify(o),r[a].id)}})(),t+=r.length,w(b,{progress:`${t}/${e}`})}try{await ie.getInstance(ne).intentLogs.backfillEmbeddings(64)}catch{}w(b,{status:"done",progress:`${t}/${e}`}),await se.shutdown(),process.exit(0)}async function Ve(){try{b&&w(b,{status:"idle"}),await se.shutdown()}catch{}process.exit(0)}process.on("SIGTERM",()=>{Ve()});process.on("SIGINT",()=>{Ve()});Jt().catch(s=>{process.stderr.write(`Ember error: ${s instanceof Error?s.message:String(s)}
|
|
622
|
+
`);try{b&&w(b,{status:"error"})}catch{}process.exit(1)});
|