@zipbul/gildash 0.28.0 → 0.30.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.
- package/README.md +3 -0
- package/dist/index.js +9 -9
- package/dist/src/gildash/context.d.ts +1 -1
- package/dist/src/gildash/index.d.ts +34 -1
- package/dist/src/gildash/semantic-api.d.ts +7 -1
- package/dist/src/index.d.ts +2 -1
- package/dist/src/semantic/ast-node-utils.d.ts +4 -3
- package/dist/src/semantic/index.d.ts +3 -1
- package/dist/src/semantic/reference-classifier.d.ts +59 -0
- package/dist/src/semantic/reference-resolver.d.ts +14 -1
- package/dist/src/semantic/types.d.ts +47 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -337,6 +337,7 @@ Requires `semantic: true` at open time.
|
|
|
337
337
|
|--------|---------|-------------|
|
|
338
338
|
| `getResolvedType(name, filePath)` | `ResolvedType \| null` | Resolved type via tsc TypeChecker |
|
|
339
339
|
| `getSemanticReferences(name, filePath)` | `SemanticReference[]` | All references to a symbol |
|
|
340
|
+
| `getEnrichedReferences(name, filePath)` | `EnrichedReference[]` | References enriched with `writeKind` / `isAmbient` / `enclosingScope` (dataflow) |
|
|
340
341
|
| `getImplementations(name, filePath)` | `Implementation[]` | Interface / abstract class implementations |
|
|
341
342
|
| `getSemanticModuleInterface(filePath)` | `SemanticModuleInterface` | Module exports with resolved types |
|
|
342
343
|
| `isTypeAssignableTo(opts)` | `boolean` | Whether one symbol's type is assignable to another's |
|
|
@@ -351,6 +352,8 @@ Requires `semantic: true` at open time.
|
|
|
351
352
|
| `getResolvedTypeAtPosition(filePath, position)` | `ResolvedType \| null` | Resolved type at a byte position |
|
|
352
353
|
| `getResolvedTypesAtPositions(filePath, positions)` | `Map<number, ResolvedType>` | Batch type lookup across positions |
|
|
353
354
|
| `getSemanticReferencesAtPosition(filePath, position)` | `SemanticReference[]` | References to the symbol at a position |
|
|
355
|
+
| `getEnrichedReferencesAtPosition(filePath, position)` | `EnrichedReference[]` | Enriched references to the symbol at a position |
|
|
356
|
+
| `getFileBindings(filePath)` | `FileBinding[]` | All bindings in a file (single pass), each with its in-file enriched references — `O(identifiers)` for dataflow |
|
|
354
357
|
| `getImplementationsAtPosition(filePath, position)` | `Implementation[]` | Implementations of the symbol at a position |
|
|
355
358
|
| `isTypeAssignableToAtPosition(opts)` | `boolean` | Assignability check between two byte positions |
|
|
356
359
|
| `isTypeAssignableToTypeAtPositions(opts)` | `boolean` | Assignability check from a position to an arbitrary type string |
|
package/dist/index.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
var j$=Object.defineProperty;var g$=(_)=>_;function k$(_,$){this[_]=g$.bind(null,$)}var E$=(_,$)=>{for(var J in $)j$(_,J,{get:$[J],enumerable:!0,configurable:!0,set:k$.bind($,J)})};var x0=import.meta.require;import{isErr as p_}from"@zipbul/result";import v_ from"path";import{existsSync as BQ}from"fs";import{err as h0,isErr as y$}from"@zipbul/result";import{Database as x$}from"bun:sqlite";import{mkdirSync as h$,unlinkSync as m0,existsSync as n0}from"fs";import{dirname as m$,join as d0}from"path";import{drizzle as n$}from"drizzle-orm/bun-sqlite";import{migrate as d$}from"drizzle-orm/bun-sqlite/migrator";class O extends Error{type;constructor(_,$,J){super($,J);this.type=_;this.name="GildashError"}}var D_=".gildash",l_="gildash.db";var U0={};E$(U0,{watcherOwner:()=>f$,symbols:()=>f,symbolChangelog:()=>t,relations:()=>k,files:()=>s,annotations:()=>z_});import{sql as u$}from"drizzle-orm";import{sqliteTable as G_,text as b,integer as a,real as v$,index as $_,primaryKey as b$,foreignKey as X0,check as P$}from"drizzle-orm/sqlite-core";var s=G_("files",{project:b("project").notNull(),filePath:b("file_path").notNull(),mtimeMs:v$("mtime_ms").notNull(),size:a("size").notNull(),contentHash:b("content_hash").notNull(),updatedAt:b("updated_at").notNull(),lineCount:a("line_count")},(_)=>[b$({columns:[_.project,_.filePath]})]),f=G_("symbols",{id:a("id").primaryKey({autoIncrement:!0}),project:b("project").notNull(),filePath:b("file_path").notNull(),kind:b("kind").notNull(),name:b("name").notNull(),startLine:a("start_line").notNull(),startColumn:a("start_column").notNull(),endLine:a("end_line").notNull(),endColumn:a("end_column").notNull(),isExported:a("is_exported").notNull().default(0),signature:b("signature"),fingerprint:b("fingerprint"),detailJson:b("detail_json"),contentHash:b("content_hash").notNull(),indexedAt:b("indexed_at").notNull(),resolvedType:b("resolved_type"),structuralFingerprint:b("structural_fingerprint")},(_)=>[$_("idx_symbols_project_file").on(_.project,_.filePath),$_("idx_symbols_project_kind").on(_.project,_.kind),$_("idx_symbols_project_name").on(_.project,_.name),$_("idx_symbols_fingerprint").on(_.project,_.fingerprint),X0({columns:[_.project,_.filePath],foreignColumns:[s.project,s.filePath]}).onDelete("cascade")]),k=G_("relations",{id:a("id").primaryKey({autoIncrement:!0}),project:b("project").notNull(),type:b("type").notNull(),srcFilePath:b("src_file_path").notNull(),srcSymbolName:b("src_symbol_name"),dstProject:b("dst_project"),dstFilePath:b("dst_file_path"),dstSymbolName:b("dst_symbol_name"),metaJson:b("meta_json"),specifier:b("specifier"),isExternal:a("is_external").notNull().default(0)},(_)=>[$_("idx_relations_src").on(_.project,_.srcFilePath),$_("idx_relations_dst").on(_.dstProject,_.dstFilePath),$_("idx_relations_type").on(_.project,_.type),$_("idx_relations_project_type_src").on(_.project,_.type,_.srcFilePath),$_("idx_relations_specifier").on(_.project,_.specifier),X0({columns:[_.project,_.srcFilePath],foreignColumns:[s.project,s.filePath]}).onDelete("cascade")]),z_=G_("annotations",{id:a("id").primaryKey({autoIncrement:!0}),project:b("project").notNull(),filePath:b("file_path").notNull(),tag:b("tag").notNull(),value:b("value").notNull().default(""),source:b("source").notNull(),symbolName:b("symbol_name"),startLine:a("start_line").notNull(),startColumn:a("start_column").notNull(),endLine:a("end_line").notNull(),endColumn:a("end_column").notNull(),indexedAt:b("indexed_at").notNull()},(_)=>[$_("idx_annotations_project_file").on(_.project,_.filePath),$_("idx_annotations_project_tag").on(_.project,_.tag),$_("idx_annotations_project_symbol").on(_.project,_.symbolName),X0({columns:[_.project,_.filePath],foreignColumns:[s.project,s.filePath]}).onDelete("cascade")]),t=G_("symbol_changelog",{id:a("id").primaryKey({autoIncrement:!0}),project:b("project").notNull(),changeType:b("change_type").notNull(),symbolName:b("symbol_name").notNull(),symbolKind:b("symbol_kind").notNull(),filePath:b("file_path").notNull(),oldName:b("old_name"),oldFilePath:b("old_file_path"),fingerprint:b("fingerprint"),changedAt:b("changed_at").notNull(),isFullIndex:a("is_full_index").notNull().default(0),indexRunId:b("index_run_id").notNull()},(_)=>[$_("idx_changelog_project_changed_at").on(_.project,_.changedAt),$_("idx_changelog_project_name").on(_.project,_.symbolName),$_("idx_changelog_project_run").on(_.project,_.indexRunId)]),f$=G_("watcher_owner",{id:a("id").primaryKey(),pid:a("pid").notNull(),startedAt:b("started_at").notNull(),heartbeatAt:b("heartbeat_at").notNull(),instanceId:b("instance_id")},(_)=>[P$("watcher_owner_singleton",u$`${_.id} = 1`)]);class V0{client=null;drizzle=null;dbPath;txDepth=0;constructor(_){this.dbPath=d0(_.projectRoot,D_,l_)}get drizzleDb(){if(!this.drizzle)throw Error("Database is not open. Call open() first.");return this.drizzle}open(){try{h$(m$(this.dbPath),{recursive:!0}),this.client=new x$(this.dbPath),this.client.run("PRAGMA journal_mode = WAL"),this.client.run("PRAGMA foreign_keys = OFF"),this.client.run("PRAGMA busy_timeout = 5000"),this.drizzle=n$(this.client,{schema:U0}),d$(this.drizzle,{migrationsFolder:d0(import.meta.dirname,"migrations")});let _=this.client.prepare("PRAGMA foreign_key_check").all();if(_.length>0)throw Error(`FK integrity violation after migration: ${JSON.stringify(_.slice(0,5))}`);this.client.run("PRAGMA foreign_keys = ON"),this.registerRegexpUdf(this.client)}catch(_){if(this.isCorruptionError(_)&&n0(this.dbPath)){this.closeClient(),m0(this.dbPath);for(let J of["-wal","-shm"]){let Q=this.dbPath+J;if(n0(Q))m0(Q)}let $=this.open();if(y$($))return h0(new O("store",`Failed to recover database at ${this.dbPath}`,{cause:$.data}));return $}return h0(new O("store",`Failed to open database at ${this.dbPath}`,{cause:_}))}}close(){this.closeClient(),this.drizzle=null}transaction(_){let $=this.requireClient();if(this.txDepth===0){this.txDepth++;try{return $.transaction(()=>_(this))()}finally{this.txDepth--}}let J=`sp_${this.txDepth++}`;$.run(`SAVEPOINT "${J}"`);try{let Q=_(this);return $.run(`RELEASE SAVEPOINT "${J}"`),Q}catch(Q){throw $.run(`ROLLBACK TO SAVEPOINT "${J}"`),$.run(`RELEASE SAVEPOINT "${J}"`),Q}finally{this.txDepth--}}immediateTransaction(_){let $=this.requireClient();this.txDepth++,$.run("BEGIN IMMEDIATE");try{let J=_();return $.run("COMMIT"),J}catch(J){throw $.run("ROLLBACK"),J}finally{this.txDepth--}}getTableNames(){return this.requireClient().query("SELECT name FROM sqlite_master WHERE type = 'table'").all().map(($)=>$.name)}selectOwner(){return this.requireClient().prepare("SELECT pid, heartbeat_at, instance_id FROM watcher_owner WHERE id = 1").get()??void 0}insertOwner(_,$){let J=new Date().toISOString();this.requireClient().prepare("INSERT INTO watcher_owner (id, pid, started_at, heartbeat_at, instance_id) VALUES (1, ?, ?, ?, ?)").run(_,J,J,$??null)}replaceOwner(_,$){let J=new Date().toISOString();this.requireClient().prepare("INSERT OR REPLACE INTO watcher_owner (id, pid, started_at, heartbeat_at, instance_id) VALUES (1, ?, ?, ?, ?)").run(_,J,J,$??null)}touchOwner(_){let $=new Date().toISOString();this.requireClient().prepare("UPDATE watcher_owner SET heartbeat_at = ? WHERE id = 1 AND pid = ?").run($,_)}deleteOwner(_){this.requireClient().prepare("DELETE FROM watcher_owner WHERE id = 1 AND pid = ?").run(_)}registerRegexpUdf(_){let $=_;if(typeof $.function!=="function")return;$.function.call(_,"regexp",(J,Q)=>{try{return new RegExp(J).test(Q)?1:0}catch{return 0}})}requireClient(){if(!this.client)throw Error("Database is not open. Call open() first.");return this.client}closeClient(){if(this.client)this.client.close(),this.client=null}isCorruptionError(_){if(!(_ instanceof Error))return!1;let $=_.message.toLowerCase();return $.includes("malformed")||$.includes("corrupt")||$.includes("not a database")||$.includes("disk i/o error")||$.includes("sqlite_corrupt")}}import{eq as b_,and as p0}from"drizzle-orm";class O0{db;constructor(_){this.db=_}getFile(_,$){return this.db.drizzleDb.select().from(s).where(p0(b_(s.project,_),b_(s.filePath,$))).get()??null}upsertFile(_){this.db.drizzleDb.insert(s).values({project:_.project,filePath:_.filePath,mtimeMs:_.mtimeMs,size:_.size,contentHash:_.contentHash,updatedAt:_.updatedAt,lineCount:_.lineCount??null}).onConflictDoUpdate({target:[s.project,s.filePath],set:{mtimeMs:_.mtimeMs,size:_.size,contentHash:_.contentHash,updatedAt:_.updatedAt,lineCount:_.lineCount??null}}).run()}getAllFiles(_){return this.db.drizzleDb.select().from(s).where(b_(s.project,_)).all()}getFilesMap(_){let $=this.getAllFiles(_),J=new Map;for(let Q of $)J.set(Q.filePath,Q);return J}deleteFile(_,$){this.db.drizzleDb.delete(s).where(p0(b_(s.project,_),b_(s.filePath,$))).run()}}import{eq as r,and as A_,sql as c_,count as p$}from"drizzle-orm";function F_(_){return _.replaceAll("\x00","").trim().split(/\s+/).map(($)=>$.trim()).filter(($)=>$.length>0).map(($)=>`"${$.replaceAll('"','""')}"*`).join(" ")}var i0=50;class H0{db;constructor(_){this.db=_}replaceFileSymbols(_,$,J,Q){if(this.db.drizzleDb.delete(f).where(A_(r(f.project,_),r(f.filePath,$))).run(),!Q.length)return;let W=new Date().toISOString(),z=Q.map((Z)=>({project:_,filePath:$,kind:Z.kind??"unknown",name:Z.name??"",startLine:Z.startLine??0,startColumn:Z.startColumn??0,endLine:Z.endLine??0,endColumn:Z.endColumn??0,isExported:Z.isExported??0,signature:Z.signature??null,fingerprint:Z.fingerprint??null,detailJson:Z.detailJson??null,contentHash:J,indexedAt:Z.indexedAt??W,resolvedType:Z.resolvedType??null,structuralFingerprint:Z.structuralFingerprint??null}));for(let Z=0;Z<z.length;Z+=i0)this.db.drizzleDb.insert(f).values(z.slice(Z,Z+i0)).run()}getFileSymbols(_,$){return this.db.drizzleDb.select().from(f).where(A_(r(f.project,_),r(f.filePath,$))).all()}searchByName(_,$,J={}){let Q=J.limit??50,W=F_($);if(!W)return[];return this.db.drizzleDb.select().from(f).where(A_(c_`${f.id} IN (SELECT rowid FROM symbols_fts WHERE symbols_fts MATCH ${W})`,r(f.project,_),J.kind?r(f.kind,J.kind):void 0)).orderBy(f.name).limit(Q).all()}searchByKind(_,$){return this.db.drizzleDb.select().from(f).where(A_(r(f.project,_),r(f.kind,$))).orderBy(f.name).all()}getStats(_){let $=this.db.drizzleDb.select({symbolCount:p$(),fileCount:c_`COUNT(DISTINCT ${f.filePath})`}).from(f).where(r(f.project,_)).get();return{symbolCount:$?.symbolCount??0,fileCount:$?.fileCount??0}}getByFingerprint(_,$){return this.db.drizzleDb.select().from(f).where(A_(r(f.project,_),r(f.fingerprint,$))).all()}deleteFileSymbols(_,$){this.db.drizzleDb.delete(f).where(A_(r(f.project,_),r(f.filePath,$))).run()}searchByQuery(_){let $=this.db.drizzleDb.select().from(f).where(A_(_.ftsQuery?c_`${f.id} IN (SELECT rowid FROM symbols_fts WHERE symbols_fts MATCH ${_.ftsQuery})`:void 0,_.exactName?r(f.name,_.exactName):void 0,_.project!==void 0?r(f.project,_.project):void 0,_.kind?r(f.kind,_.kind):void 0,_.filePath!==void 0?r(f.filePath,_.filePath):void 0,_.isExported!==void 0?r(f.isExported,_.isExported?1:0):void 0,_.decorator?c_`${f.id} IN (SELECT s.id FROM symbols s, json_each(s.detail_json, '$.decorators') je WHERE json_extract(je.value, '$.name') = ${_.decorator})`:void 0,_.resolvedType!==void 0?r(f.resolvedType,_.resolvedType):void 0)).orderBy(f.name);if(!_.regex)return(_.limit!==void 0?$.limit(_.limit):$).all();let J;try{J=new RegExp(_.regex)}catch{throw new O("validation",`Invalid regex pattern: ${_.regex}`)}if(_.limit===void 0)return $.all().filter((z)=>J.test(z.name));let Q=[];for(let W of[5,20,100]){let z=_.limit*W,Z=$.limit(z).all();if(Q=Z.filter((Y)=>J.test(Y.name)),Q.length>=_.limit||Z.length<z)return Q.slice(0,_.limit)}return Q.slice(0,_.limit)}}import{eq as h,and as H_,isNull as l0,or as i$}from"drizzle-orm";var P_={project:k.project,type:k.type,srcFilePath:k.srcFilePath,srcSymbolName:k.srcSymbolName,dstProject:k.dstProject,dstFilePath:k.dstFilePath,dstSymbolName:k.dstSymbolName,metaJson:k.metaJson,specifier:k.specifier,isExternal:k.isExternal};class M0{db;constructor(_){this.db=_}replaceFileRelations(_,$,J){this.db.transaction((Q)=>{if(Q.drizzleDb.delete(k).where(H_(h(k.project,_),h(k.srcFilePath,$))).run(),!J.length)return;for(let W of J)Q.drizzleDb.insert(k).values({project:_,type:W.type??"unknown",srcFilePath:W.srcFilePath??$,srcSymbolName:W.srcSymbolName??null,dstProject:W.dstProject??(W.dstFilePath!=null?_:null),dstFilePath:W.dstFilePath??null,dstSymbolName:W.dstSymbolName??null,metaJson:W.metaJson??null,specifier:W.specifier??null,isExternal:W.isExternal??0}).run()})}getOutgoing(_,$,J){if(J!==void 0)return this.db.drizzleDb.select(P_).from(k).where(H_(h(k.project,_),h(k.srcFilePath,$),i$(h(k.srcSymbolName,J),l0(k.srcSymbolName)))).all();return this.db.drizzleDb.select(P_).from(k).where(H_(h(k.project,_),h(k.srcFilePath,$))).all()}getIncoming(_){let{dstProject:$,dstFilePath:J}=_;return this.db.drizzleDb.select(P_).from(k).where(H_(h(k.dstProject,$),h(k.dstFilePath,J))).all()}getByType(_,$){return this.db.drizzleDb.select(P_).from(k).where(H_(h(k.project,_),h(k.type,$))).all()}deleteFileRelations(_,$){this.db.drizzleDb.delete(k).where(H_(h(k.project,_),h(k.srcFilePath,$))).run()}deleteIncomingRelations(_,$){this.db.drizzleDb.delete(k).where(H_(h(k.dstProject,_),h(k.dstFilePath,$))).run()}searchRelations(_){let $=this.db.drizzleDb.select(P_).from(k).where(H_(_.project!==void 0?h(k.project,_.project):void 0,_.srcFilePath!==void 0?h(k.srcFilePath,_.srcFilePath):void 0,_.srcSymbolName!==void 0?h(k.srcSymbolName,_.srcSymbolName):void 0,_.dstProject!==void 0?h(k.dstProject,_.dstProject):void 0,_.dstFilePath!==void 0?h(k.dstFilePath,_.dstFilePath):void 0,_.dstSymbolName!==void 0?h(k.dstSymbolName,_.dstSymbolName):void 0,_.type!==void 0?h(k.type,_.type):void 0,_.specifier!==void 0?h(k.specifier,_.specifier):void 0,_.isExternal!==void 0?h(k.isExternal,_.isExternal?1:0):void 0));return(_.limit!==void 0?$.limit(_.limit):$).all()}retargetRelations(_){let{dstProject:$,oldFile:J,oldSymbol:Q,newFile:W,newSymbol:z,newDstProject:Z}=_,Y=Q===null?H_(h(k.dstProject,$),h(k.dstFilePath,J),l0(k.dstSymbolName)):H_(h(k.dstProject,$),h(k.dstFilePath,J),h(k.dstSymbolName,Q)),X={dstFilePath:W,dstSymbolName:z};if(Z!==void 0)X.dstProject=Z;this.db.drizzleDb.update(k).set(X).where(Y).run()}}import{err as a0}from"@zipbul/result";import{subscribe as l$}from"@parcel/watcher";import K0 from"path";import c0 from"path";function J_(_){return _.replaceAll("\\","/")}function f_(_,$){return J_(c0.relative(_,$))}function j_(_,$){return J_(c0.resolve(_,$))}var c$=["**/.git/**",`**/${D_}/**`,"**/dist/**","**/node_modules/**"],a$=new Set(["package.json","tsconfig.json"]);function s$(_){if(_==="update")return"change";if(_==="create")return"create";return"delete"}class B0{#_;#$;#J;#Y;#W;#z;constructor(_,$=l$,J=console){this.#$=_.projectRoot,this.#J=[...c$,..._.ignorePatterns??[]],this.#Y=new Set((_.extensions??[".ts",".mts",".cts"]).map((Q)=>Q.toLowerCase())),this.#W=$,this.#z=J}async start(_){try{this.#_=await this.#W(this.#$,($,J)=>{if($){this.#z.error(new O("watcher","Callback error",{cause:$}));return}try{for(let Q of J){let W=J_(K0.relative(this.#$,Q.path));if(W.startsWith(".."))continue;let z=K0.basename(W),Z=K0.extname(W).toLowerCase();if(!a$.has(z)&&!this.#Y.has(Z))continue;if(W.endsWith(".d.ts"))continue;_({eventType:s$(Q.type),filePath:W})}}catch(Q){this.#z.error(new O("watcher","Callback error",{cause:Q}))}},{ignore:this.#J})}catch($){return a0(new O("watcher","Failed to subscribe watcher",{cause:$}))}}async close(){if(!this.#_)return;try{await this.#_.unsubscribe(),this.#_=void 0}catch(_){return a0(new O("watcher","Failed to close watcher",{cause:_}))}}}import L0 from"path";var r$=["**/node_modules/**","**/.git/**",`**/${D_}/**`,"**/dist/**"],o$=r$.map((_)=>new Bun.Glob(_));function t$(_){return new Bun.Glob("**/package.json").scan({cwd:_,followSymlinks:!1})}async function a_(_,$=t$){let J=[];for await(let Q of $(_)){let W=J_(Q);if(o$.some((K)=>K.match(W)))continue;let z=J_(L0.dirname(Q)),Z=L0.join(_,Q),Y=await Bun.file(Z).json(),X=typeof Y?.name==="string"&&Y.name.length>0?Y.name:L0.basename(z==="."?_:z);J.push({dir:z,project:X})}return J.sort((Q,W)=>W.dir.length-Q.dir.length),J}function l(_,$,J="default"){let Q=J_(_);for(let W of $){if(W.dir===".")return W.project;if(Q===W.dir||Q.startsWith(`${W.dir}/`))return W.project}return J}import y_ from"path";var C_=new Map;async function e$(_){let $=Bun.file(_);if(!await $.exists())return null;try{let J=await $.text(),Q=Bun.JSONC.parse(J);return typeof Q==="object"&&Q!==null?Q:null}catch{return null}}function _J(_,$){if($.startsWith(".")){let J=y_.resolve(_,$);return J.endsWith(".json")?J:J+".json"}return y_.resolve(_,"node_modules",$)}async function s0(_,$=5){if($<=0)return null;let J=await e$(_);if(!J)return null;let Q=J.extends;if(typeof Q!=="string"||!Q)return J;let W=_J(y_.dirname(_),Q),z=await s0(W,$-1);if(!z)return J;let Z=typeof z.compilerOptions==="object"&&z.compilerOptions!==null?z.compilerOptions:{},Y=typeof J.compilerOptions==="object"&&J.compilerOptions!==null?J.compilerOptions:{};return{...z,...J,compilerOptions:{...Z,...Y}}}async function x_(_){if(C_.has(_))return C_.get(_)??null;let $=y_.join(_,"tsconfig.json"),J=await s0($);if(!J)return C_.set(_,null),null;let Q=typeof J.compilerOptions==="object"&&J.compilerOptions!==null?J.compilerOptions:null;if(!Q)return C_.set(_,null),null;let W=typeof Q.baseUrl==="string"?Q.baseUrl:null,z=typeof Q.paths==="object"&&Q.paths!==null?Q.paths:null;if(!W&&!z)return C_.set(_,null),null;let Z=W?y_.resolve(_,W):_,Y=new Map;if(z)for(let[K,V]of Object.entries(z)){if(!Array.isArray(V))continue;let B=V.filter((C)=>typeof C==="string");Y.set(K,B)}let X={baseUrl:Z,paths:Y};return C_.set(_,X),X}function s_(_){if(_){C_.delete(_);return}C_.clear()}function V_(_){let $=Bun.hash.xxHash64(_);return BigInt.asUintN(64,BigInt($)).toString(16).padStart(16,"0")}import{isErr as Y1}from"@zipbul/result";import{err as $J}from"@zipbul/result";import{parseSync as JJ}from"oxc-parser";function g_(_,$,J,Q=JJ){try{let W={preserveParens:!1,...J},z=Q(_,$,W);return{filePath:_,program:z.program,errors:z.errors,comments:z.comments,sourceText:$,module:z.module}}catch(W){return $J(new O("parse",`Failed to parse file: ${_}`,{cause:W}))}}import{join as QJ}from"path";function WJ(_,$){let J=$.length===1?`**/*${$[0]}`:`**/*{${$.join(",")}}`;return new Bun.Glob(J).scan({cwd:_,followSymlinks:!1})}async function r0(_){let{projectRoot:$,extensions:J,ignorePatterns:Q,fileRepo:W,scanFilesFn:z=WJ}=_,Z=W.getFilesMap(),Y=new Set,X=[],K=[],V=Q.map((C)=>new Bun.Glob(C));for await(let C of z($,J)){let N=J_(C);if(!J.some((d)=>N.endsWith(d)))continue;if(N.startsWith("node_modules/")||N.includes("/node_modules/"))continue;if(V.some((d)=>d.match(N)))continue;Y.add(N);let w=QJ($,N),S=Bun.file(w),{size:F,lastModified:G}=S,u=Z.get(N);if(!u){let d=await S.text(),p=V_(d);X.push({filePath:N,contentHash:p,mtimeMs:G,size:F});continue}if(u.mtimeMs===G&&u.size===F){K.push({filePath:N,contentHash:u.contentHash,mtimeMs:G,size:F});continue}let E=await S.text(),y=V_(E);if(y===u.contentHash)K.push({filePath:N,contentHash:y,mtimeMs:G,size:F});else X.push({filePath:N,contentHash:y,mtimeMs:G,size:F})}let B=[];for(let C of Z.keys())if(!Y.has(C))B.push(C);return{changed:X,unchanged:K,deleted:B}}function h_(_){let $=[0];for(let J=0;J<_.length;J++)if(_[J]===`
|
|
3
|
-
`)$.push(J+1);return $}function U_(_,$){let J=0,Q=_.length-1;while(J<Q){let W=J+Q+1>>1;if(_[W]<=$)J=W;else Q=W-1}return{line:J+1,column:$-_[J]}}import{err as zJ}from"@zipbul/result";import{parse as YJ}from"comment-parser";function r_(_){try{let $=_.trim();if($.startsWith("/**"))$=$.slice(3);if($.endsWith("*/"))$=$.slice(0,-2);let Q=YJ(`/** ${$} */`)[0]??{description:"",tags:[]};return{description:(Q.description??"").trim(),tags:(Q.tags??[]).map((W)=>({tag:W.tag??"",name:W.name??"",type:W.type??"",description:W.description??"",optional:W.optional??!1,...W.default!==void 0?{default:W.default}:{}}))}}catch($){return zJ(new O("parse","Failed to parse JSDoc comment",{cause:$}))}}import{isErr as ZJ}from"@zipbul/result";function XJ(_){if("name"in _&&typeof _.name==="string")return _.name;if("value"in _){let $=_.value;if(typeof $==="string")return $;if(typeof $==="number"||typeof $==="bigint"||typeof $==="boolean")return String($)}return"unknown"}function k_(_){if(_.type==="Identifier")return[{name:_.name,start:_.start,end:_.end}];if(_.type==="ObjectPattern"){let $=[];for(let J of _.properties)if(J.type==="RestElement")$.push(...k_(J.argument));else $.push(...k_(J.value));return $}if(_.type==="ArrayPattern"){let $=[];for(let J of _.elements){if(!J)continue;if(J.type==="RestElement")$.push(...k_(J.argument));else $.push(...k_(J))}return $}if(_.type==="AssignmentPattern")return k_(_.left);return[]}function UJ(_){let $=new Map;for(let J of _.module.staticImports){let Q=J.moduleRequest.value;for(let W of J.entries){let z=W.localName.value,Z=W.importName.kind==="Name"?W.importName.name:void 0,Y={specifier:Q};if(Z&&Z!==z)Y.originalName=Z;$.set(z,Y)}}return $}function q_(_){let{program:$,sourceText:J,comments:Q}=_,W=h_(J),z=UJ(_),Z=Q.filter((D)=>D.type==="Block"&&D.value.startsWith("*")).sort((D,q)=>D.end-q.end),Y=$.body.map((D)=>D.start).sort((D,q)=>D-q);function X(D,q){return G(D,q)}function K(D,q,U){if(D.type==="PrivateIdentifier")return{kind:"private"};if(!q&&D.type==="Identifier")return;return X(D,U)}function V(D,q){if(q)return J.slice(D.start,D.end);if(D.type==="PrivateIdentifier")return`#${D.name}`;return XJ(D)}function B(D,q,U){let H=D;if(!q&&H.type==="Identifier")return{kind:"string",value:H.name};return X(D,U)}function C(D,q){return{start:U_(W,D),end:U_(W,q)}}function N(D){let q=0,U=Z.length-1,H=-1;while(q<=U){let L=q+U>>>1;if(Z[L].end<=D)H=L,q=L+1;else U=L-1}if(H<0)return;let M=Z[H];q=0,U=Y.length-1;while(q<=U){let L=q+U>>>1,A=Y[L];if(A<=M.end)q=L+1;else if(A>=D)U=L-1;else return}return`/*${M.value}*/`}function w(D){if(!D)return;let q="typeAnnotation"in D&&D.typeAnnotation?D.typeAnnotation:D;return J.slice(q.start,q.end)}let S=8;function F(D){if(D.type==="Identifier")return z.get(D.name);if(D.type==="MemberExpression"){let q=D.object;if(q.type==="Identifier")return z.get(q.name)}return}function G(D,q=0){let U=D;if(q>=S)return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)};let H=U.type;if(H==="Literal"){let M=U.value;if(typeof M==="bigint")return{kind:"bigint",value:typeof U.bigint==="string"?U.bigint:M.toString()};if(typeof U.regex==="object"&&U.regex!==null)return{kind:"regex",value:J.slice(U.start,U.end)};if(M===null)return{kind:"null",value:null};if(typeof M==="string")return{kind:"string",value:M};if(typeof M==="number")return{kind:"number",value:M};if(typeof M==="boolean")return{kind:"boolean",value:M};return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}if(H==="Identifier"){let M=U.name;if(M==="undefined")return{kind:"undefined",value:null};let L=z.get(M),A={kind:"identifier",name:M};if(L){if(A.importSource=L.specifier,L.originalName)A.originalName=L.originalName}return A}if(H==="MemberExpression"){if(U.computed){let j=U.property;if(j.type==="Literal"&&typeof j.value==="string"){let g=U.object,v=J.slice(g.start,g.end),n=g.type==="Identifier"?g.name:void 0,__=n?z.get(n):void 0,X_={kind:"member",object:v,property:j.value};if(__)X_.importSource=__.specifier;return X_}return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}let M=U.object,L=J.slice(M.start,M.end),A=U.property.name??J.slice(U.property.start,U.property.end),I=M.type==="Identifier"?M.name:void 0,T=I?z.get(I):void 0,R={kind:"member",object:L,property:A};if(T)R.importSource=T.specifier;return R}if(H==="CallExpression"){let M=U.callee,L=J.slice(M.start,M.end),I=(U.arguments??[]).map((j)=>G(j,q+1)),T=F(M),R={kind:"call",callee:L,arguments:I};if(T)R.importSource=T.specifier;return R}if(H==="NewExpression"){let M=U.callee,L=J.slice(M.start,M.end),I=(U.arguments??[]).map((j)=>G(j,q+1)),T=F(M),R={kind:"new",callee:L,arguments:I};if(T)R.importSource=T.specifier;return R}if(H==="ObjectExpression"){let M=U.properties??[],L=[];for(let A of M){if(A.type==="SpreadElement"){let n=A.argument;L.push({kind:"spread",argument:G(n,q+1)});continue}let I=A.key,T=A.computed===!0,R=A.value,j=A.shorthand||void 0,v={kind:"property",key:B(I,T,q+1),value:G(R,q+1)};if(j)v.shorthand=!0;L.push(v)}return{kind:"object",properties:L}}if(H==="ArrayExpression")return{kind:"array",elements:(U.elements??[]).map((A)=>{if(!A)return{kind:"undefined",value:null};return G(A,q+1)})};if(H==="SpreadElement"){let M=U.argument;return{kind:"spread",argument:G(M,q+1)}}if(H==="ArrowFunctionExpression"||H==="FunctionExpression"){let L=U.params.map(E),A={kind:"function",sourceText:J.slice(U.start,U.end)};if(L.length>0)A.parameters=L;return A}if(H==="TemplateLiteral"||H==="TaggedTemplateExpression")return{kind:"template",sourceText:J.slice(U.start,U.end)};if(H==="UnaryExpression"){let{operator:M,argument:L}=U;if(M==="-"&&L.type==="Literal"&&typeof L.value==="number")return{kind:"number",value:-L.value};if(M==="void")return{kind:"undefined",value:null};return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}if(H==="TSAsExpression"||H==="TSSatisfiesExpression"||H==="TSNonNullExpression"||H==="TSTypeAssertion"||H==="TSInstantiationExpression"||H==="ParenthesizedExpression"||H==="ChainExpression"){let M=U.expression;if(M)return G(M,q)}return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}function u(D){if(!D||D.length===0)return[];return D.map((q)=>{let U=q.expression;if(U.type==="CallExpression"){let H=U,M=H.callee,L="name"in M&&typeof M.name==="string"?M.name:("property"in M)&&M.property&&typeof M.property.name==="string"?M.property.name:"unknown",A=H.arguments.map((I)=>G(I));return{name:L,arguments:A.length>0?A:void 0}}if(U.type==="Identifier")return{name:U.name??"unknown"};return{name:J.slice(U.start,U.end)}})}function E(D){if(D.type==="TSParameterProperty"){let U=D;return d(U.parameter,U.decorators)}if(D.type==="RestElement"){let U=D,H=U.argument,L=`...${"name"in H&&typeof H.name==="string"?H.name:"unknown"}`,A=U.typeAnnotation,I=A?w(A):void 0,T={name:L,isOptional:!1};if(I)T.type=I;return T}let q=D;return d(q,q.decorators)}function y(D){if(!D)return;let q="typeAnnotation"in D&&D.typeAnnotation?D.typeAnnotation:null;if(!q)return;let H=q.typeName?.name;if(!H)return;return z.get(H)?.specifier}function d(D,q){if(D.type==="AssignmentPattern"){let{left:R,right:j}=D,g="name"in R&&typeof R.name==="string"?R.name:"unknown",v="typeAnnotation"in R?R.typeAnnotation:null,n=v?w(v):void 0,__=y(v),X_=J.slice(j.start,j.end),K_="decorators"in R&&Array.isArray(R.decorators)?R.decorators:[],Z0=u(K_),I_={name:g,isOptional:!0,defaultValue:X_};if(n)I_.type=n;if(__)I_.typeImportSource=__;if(Z0.length>0)I_.decorators=Z0;return I_}let U="name"in D&&typeof D.name==="string"?D.name:("pattern"in D)&&D.pattern&&typeof D.pattern.name==="string"?D.pattern.name:"unknown",H=!!(("optional"in D)&&D.optional),M="typeAnnotation"in D?D.typeAnnotation:null,L=M?w(M):void 0,A=y(M),I=u(q??[]),T={name:U,isOptional:H};if(L)T.type=L;if(A)T.typeImportSource=A;if(I.length>0)T.decorators=I;return T}function p(D,q){let U=[];if(q?.async)U.push("async");if(D.static)U.push("static");if(D.abstract)U.push("abstract");if(D.readonly)U.push("readonly");if(D.override)U.push("override");if(D.declare)U.push("declare");if(D.const)U.push("const");let H=D.accessibility;if(H==="private")U.push("private");else if(H==="protected")U.push("protected");else if(H==="public")U.push("public");return U}function Q_(D){if(!D)return;let q=D.params.flatMap((U)=>{let H=U.name.name;return H?[H]:[]});return q.length>0?q:void 0}function Y_(D){let q=[];if(D.superClass){let H=J.slice(D.superClass.start,D.superClass.end);q.push({kind:"extends",name:H})}let U=D.implements??[];for(let H of U){let M=H.expression,L=J.slice(M.start,M.end);q.push({kind:"implements",name:L})}return q}function O_(D){let q=[],U=D.extends;for(let H of U){let M=H.expression,L=J.slice(M.start,M.end);q.push({kind:"extends",name:L})}return q}function Z_(D){let q=[];for(let U of D)if(U.type==="MethodDefinition"||U.type==="TSAbstractMethodDefinition"){let H=U,M=V(H.key,H.computed),L=K(H.key,H.computed,0),A=H.value,I=H.kind,T=I==="constructor"?"constructor":I==="get"?"getter":I==="set"?"setter":"method",R=p(H,A);if(U.type==="TSAbstractMethodDefinition"&&!R.includes("abstract"))R.push("abstract");let j=A.params.map(E),g=w(A.returnType),v=u(H.decorators??[]),n={kind:"method",name:M,span:C(U.start,U.end),isExported:!1,methodKind:T,modifiers:R,parameters:j.length>0?j:void 0,returnType:g};if(L)n.key=L;if(v.length>0)n.decorators=v;q.push(n)}else if(U.type==="PropertyDefinition"||U.type==="TSAbstractPropertyDefinition"||U.type==="AccessorProperty"||U.type==="TSAbstractAccessorProperty"){let H=U,M=V(H.key,H.computed),L=K(H.key,H.computed,0),A=p(H);if(U.type==="TSAbstractPropertyDefinition"||U.type==="TSAbstractAccessorProperty"){if(!A.includes("abstract"))A.push("abstract")}if(U.type==="AccessorProperty"||U.type==="TSAbstractAccessorProperty")A.push("accessor");let I=w(H.typeAnnotation),T=H.value,R=T?G(T):void 0,j=u(H.decorators??[]),g={kind:"property",name:M,span:C(U.start,U.end),isExported:!1,modifiers:A,returnType:I,initializer:R};if(L)g.key=L;if(j.length>0)g.decorators=j;q.push(g)}return q}function W_(D){let q=[];for(let U of D)if(U.type==="TSMethodSignature"){let H=U,M=V(H.key,H.computed),L=K(H.key,H.computed,0),A=H.params.map(E),I=w(H.returnType),T={kind:"method",name:M,span:C(U.start,U.end),isExported:!1,modifiers:[],methodKind:"method",parameters:A.length>0?A:void 0,returnType:I};if(L)T.key=L;q.push(T)}else if(U.type==="TSPropertySignature"){let H=U,M=V(H.key,H.computed),L=K(H.key,H.computed,0),A=w(H.typeAnnotation),I={kind:"property",name:M,span:C(U.start,U.end),isExported:!1,modifiers:H.readonly?["readonly"]:[],returnType:A};if(L)I.key=L;q.push(I)}return q}function i(D,q){let U=D.type;if(U==="FunctionDeclaration"||U==="FunctionExpression"||U==="TSDeclareFunction"||U==="TSEmptyBodyFunctionExpression"){let H=D,M=H.id?.name??"default",L=H.params.map(E),A=w(H.returnType),I=p(H,H),T=u(H.decorators??[]),R=Q_(H.typeParameters),j={kind:"function",name:M,span:C(D.start,D.end),isExported:q,modifiers:I,parameters:L.length>0?L:void 0,returnType:A,decorators:T.length>0?T:void 0};if(R&&R.length>0)j.typeParameters=R;return j}if(U==="ClassDeclaration"||U==="ClassExpression"){let H=D,M=H.id?.name??"default",L=Y_(H),A=Z_(H.body.body),I=u(H.decorators),T=p(H),R=Q_(H.typeParameters),j={kind:"class",name:M,span:C(D.start,D.end),isExported:q,modifiers:T,heritage:L.length>0?L:void 0,members:A.length>0?A:void 0,decorators:I.length>0?I:void 0};if(R&&R.length>0)j.typeParameters=R;return j}if(U==="VariableDeclaration"){let H=D,M=[];for(let L of H.declarations){let{id:A,init:I}=L;if(A.type==="ObjectPattern"||A.type==="ArrayPattern"){let X_=k_(A);for(let K_ of X_)M.push({kind:"variable",name:K_.name,span:C(K_.start,K_.end),isExported:q,modifiers:[]});continue}let T="name"in A&&typeof A.name==="string"?A.name:"unknown",R="variable",j,g,v;if(I)if(I.type==="FunctionExpression"||I.type==="ArrowFunctionExpression"){R="function";let X_=I;j=X_.params.map(E),g=w(X_.returnType)}else v=G(I);let n=[],__={kind:R,name:T,span:C(L.start,L.end),isExported:q,modifiers:n,parameters:j,returnType:g};if(v)__.initializer=v;M.push(__)}if(M.length===0)return null;if(M.length===1)return M[0];return M}if(U==="TSTypeAliasDeclaration")return{kind:"type",name:D.id.name,span:C(D.start,D.end),isExported:q,modifiers:[]};if(U==="TSInterfaceDeclaration"){let H=D,M=H.id.name,L=O_(H),A=W_(H.body.body),I=Q_(H.typeParameters),T={kind:"interface",name:M,span:C(D.start,D.end),isExported:q,modifiers:[],heritage:L.length>0?L:void 0,members:A.length>0?A:void 0};if(I&&I.length>0)T.typeParameters=I;return T}if(U==="TSEnumDeclaration"){let H=D,M=H.id.name,L=p(H),I=H.body.members.map((T)=>{let R=T.id,j=R.type!=="Identifier",g="name"in R&&typeof R.name==="string"?R.name:("value"in R)&&typeof R.value==="string"?R.value:"unknown",v=T.initializer?G(T.initializer):void 0,n={kind:"property",name:g,span:C(T.start,T.end),isExported:!1,modifiers:[]};if(j)n.key=X(R,0);if(v)n.initializer=v;return n});return{kind:"enum",name:M,span:C(D.start,D.end),isExported:q,modifiers:L,members:I.length>0?I:void 0}}if(U==="TSModuleDeclaration"){let H=D,M=H.id.name??H.id.value??"unknown",L=p(H),A=[];if(H.body?.type==="TSModuleBlock")for(let I of H.body.body??[]){if(I.type!=="ExportNamedDeclaration")continue;let T=I.declaration;if(!T)continue;let R=i(T,!1);if(R)if(Array.isArray(R))A.push(...R);else A.push(R)}return{kind:"namespace",name:M,span:C(D.start,D.end),isExported:q,modifiers:L,members:A.length>0?A:void 0}}return null}let c=[],w_=new Set;for(let D of $.body){let q=null,U=D;if(U.type==="ExportNamedDeclaration"){let M=U;if(M.declaration){if(q=i(M.declaration,!0),q&&!Array.isArray(q))q.span=C(M.start,M.end)}else if(!M.source&&M.specifiers)for(let L of M.specifiers){let A=L.local,I="name"in A?A.name:A.value;if(I)w_.add(I)}}else if(U.type==="ExportDefaultDeclaration"){let M=U,L=M.declaration;if(L){if(q=i(L,!0),q&&!Array.isArray(q))q.name="id"in L&&L.id&&typeof L.id.name==="string"?L.id.name:"default",q.isExported=!0,q.span=C(M.start,M.end);else if(!q&&"type"in L&&L.type==="Identifier"){let A=L.name;if(A)w_.add(A)}}}else{let M=U.type;if(M==="FunctionDeclaration"||M==="TSDeclareFunction"||M==="ClassDeclaration"||M==="VariableDeclaration"||M==="TSTypeAliasDeclaration"||M==="TSInterfaceDeclaration"||M==="TSEnumDeclaration"||M==="TSModuleDeclaration")q=i(U,!1)}let H=Array.isArray(q)?q:q?[q]:[];for(let M of H){let L=D.start,A=N(L);if(A){let I=r_(A);if(!ZJ(I))M.jsDoc=I}c.push(M)}}if(w_.size>0){for(let D of c)if(!D.isExported&&w_.has(D.name))D.isExported=!0}return c}function o_(_){if(_===null||typeof _!=="object")return JSON.stringify(_);if(Array.isArray(_))return`[${_.map(o_).join(",")}]`;let $=_;return`{${Object.keys($).sort().map((Q)=>`${JSON.stringify(Q)}:${o_($[Q])}`).join(",")}}`}function VJ(_){if(_.kind==="function"||_.kind==="method"){let $=_.parameters?.length??0,J=_.modifiers.includes("async")?1:0;return`params:${$}|async:${J}`}return null}function OJ(_){let $={};if(_.jsDoc)$.jsDoc=_.jsDoc;if(_.kind==="function"||_.kind==="method"){if(_.parameters!==void 0)$.parameters=_.parameters;if(_.returnType!==void 0)$.returnType=_.returnType}if(_.heritage?.length)$.heritage=_.heritage;if(_.decorators?.length)$.decorators=_.decorators;if(_.typeParameters?.length)$.typeParameters=_.typeParameters;if(_.modifiers?.length)$.modifiers=_.modifiers;if(_.initializer)$.initializer=_.initializer;if(_.key)$.key=_.key;if(_.members?.length)$.members=_.members.map((J)=>{let Q=J.modifiers.find((z)=>z==="private"||z==="protected"||z==="public"),W={name:J.name,kind:J.methodKind??J.kind,type:J.returnType,visibility:Q,isStatic:J.modifiers.includes("static")||void 0,isReadonly:J.modifiers.includes("readonly")||void 0,isAccessor:J.modifiers.includes("accessor")||void 0};if(J.key)W.key=J.key;if(J.initializer)W.initializer=J.initializer;if(J.decorators?.length)W.decorators=J.decorators;return W});return Object.keys($).length>0?JSON.stringify($):null}function HJ(_){let $=[_.kind];if(_.modifiers.length)$.push(`mod:${[..._.modifiers].sort().join(",")}`);if(_.typeParameters?.length)$.push(`tp:${_.typeParameters.length}`);if(_.heritage?.length){let J=[..._.heritage].sort((Q,W)=>Q.name.localeCompare(W.name)).map((Q)=>`${Q.kind}:${Q.name}`).join(",");$.push(`her:${J}`)}if(_.decorators?.length)$.push(`dec:${[..._.decorators].map((J)=>J.name).sort().join(",")}`);if(_.methodKind)$.push(`mk:${_.methodKind}`);if(_.parameters)$.push(`p:${_.parameters.length}`);if(_.returnType)$.push(`rt:${_.returnType}`);if(_.key)$.push(`k:${o_(_.key)}`);if(_.members?.length){let J=_.members.map((Q)=>`${Q.kind}:${Q.modifiers.join(",")}:${Q.parameters?.length??""}:${Q.returnType??""}:${Q.key?o_(Q.key):""}`).sort().join(";");$.push(`mem:${_.members.length}:${V_(J)}`)}return V_($.join("|"))}function o0(_,$,J,Q,W){let z=VJ(_),Z=V_(`${$}|${_.kind}|${z??""}`),Y=HJ(_);return{project:J,filePath:Q,kind:_.kind,name:$,startLine:_.span.start.line,startColumn:_.span.start.column,endLine:_.span.end.line,endColumn:_.span.end.column,isExported:_.isExported?1:0,signature:z,fingerprint:Z,detailJson:OJ(_),contentHash:W,indexedAt:new Date().toISOString(),structuralFingerprint:Y}}function w0(_){let{parsed:$,project:J,filePath:Q,contentHash:W,symbolRepo:z}=_,Z=q_($),Y=[];for(let X of Z){Y.push(o0(X,X.name,J,Q,W));for(let K of X.members??[])Y.push(o0(K,`${X.name}.${K.name}`,J,Q,W))}z.replaceFileSymbols(J,Q,W,Y)}import{resolve as I0,dirname as MJ,extname as KJ}from"path";function N_(_,$,J){let Q=(W)=>{let z=KJ(W);if(z===".js")return[W.slice(0,-3)+".ts"];if(z===".mjs")return[W.slice(0,-4)+".mts"];if(z===".cjs")return[W.slice(0,-4)+".cts"];if(z===".ts"||z===".mts"||z===".cts"||z===".d.ts")return[W];return[W+".ts",W+".d.ts",W+"/index.ts",W+"/index.d.ts",W+".mts",W+"/index.mts",W+".cts",W+"/index.cts"]};if($.startsWith(".")){let W=J_(I0(MJ(_),$));return Q(W)}if(J)for(let[W,z]of J.paths){if(z.length===0)continue;let Z=W.indexOf("*");if(Z===-1){if($===W){let Y=[];for(let X of z)Y.push(...Q(J_(I0(J.baseUrl,X))));return Y}}else{let Y=W.slice(0,Z),X=W.slice(Z+1);if($.startsWith(Y)&&(X===""||$.endsWith(X))){let K=$.slice(Y.length,X===""?void 0:$.length-X.length),V=[];for(let B of z)V.push(...Q(J_(I0(J.baseUrl,B.replace("*",K)))));return V}}}return[]}function t0(_,$,J,Q=N_){let W=new Map,z=_.body??[];for(let Z of z){if(Z.type!=="ImportDeclaration")continue;let Y=Z.source?.value??"",X=Q($,Y,J);if(X.length===0)continue;let K=X[0],V=Z.specifiers??[];for(let B of V)switch(B.type){case"ImportSpecifier":W.set(B.local.name,{path:K,importedName:B.imported.name});break;case"ImportDefaultSpecifier":W.set(B.local.name,{path:K,importedName:"default"});break;case"ImportNamespaceSpecifier":W.set(B.local.name,{path:K,importedName:"*"});break}}return W}import{Visitor as BJ}from"oxc-parser";function t_(_){return"name"in _&&typeof _.name==="string"?_.name:("value"in _)&&typeof _.value==="string"?_.value:"unknown"}function LJ(_){return!_.startsWith(".")&&!_.startsWith("/")}function R_(_,$,J,Q){let W=Q(_,$,J),z=W.length>0?W[0]:null,Z=z===null&&LJ($);return{resolved:z,isExternal:Z}}function wJ(_,$,J,Q,W){for(let z of _.staticImports){let Z=z.moduleRequest.value,{resolved:Y,isExternal:X}=R_($,Z,J,Q),K={dstFilePath:Y,specifier:Z};if(z.entries.length===0){let V={};if(X)V.isExternal=!0;if(Y===null&&!X)V.isUnresolved=!0;W.push({type:"imports",srcFilePath:$,srcSymbolName:null,...K,dstSymbolName:null,...Object.keys(V).length>0?{metaJson:JSON.stringify(V)}:{}});continue}for(let V of z.entries){let B=V.isType,C={};if(B)C.isType=!0;if(X)C.isExternal=!0;if(Y===null&&!X)C.isUnresolved=!0;let N,w,S=V.importName.kind;if(S==="Default")N="default",w=V.localName.value;else if(S==="NamespaceObject")N="*",w=V.localName.value,C.importKind="namespace";else N=V.importName.name??"unknown",w=V.localName.value;W.push({type:B?"type-references":"imports",srcFilePath:$,srcSymbolName:w,...K,dstSymbolName:N,...Object.keys(C).length>0?{metaJson:JSON.stringify(C)}:{}})}}}function IJ(_,$,J,Q,W){let z=new Map;for(let Z of _.staticImports)for(let Y of Z.entries)z.set(Y.localName.value,Z.moduleRequest.value);for(let Z of _.staticExports)for(let Y of Z.entries){let X=null;if(Y.moduleRequest)X=Y.moduleRequest.value;else if(Y.localName.name)X=z.get(Y.localName.name)??null;if(!X)continue;let{resolved:K,isExternal:V}=R_($,X,J,Q),B=Y.exportName.name??"default",C=Y.exportName.kind,N=Y.localName.name??Y.importName.name??B,w=Y.isType,S={isReExport:!0};if(C==="None");else S.specifiers=[{local:N,exported:B}];if(w)S.isType=!0;if(V)S.isExternal=!0;if(K===null&&!V)S.isUnresolved=!0;let F=null,G=null,u=Y.importName.kind;if(u==="All"||u==="AllButDefault"){if(C==="Name"&&B)G=B,S.namespaceAlias=B}else G=N,F=B;W.push({type:w?"type-references":"re-exports",srcFilePath:$,srcSymbolName:F,dstFilePath:K,dstSymbolName:G,specifier:X,metaJson:JSON.stringify(S)})}}function DJ(_,$,J,Q,W){for(let z of _.body){let Z=z;if(Z.type==="ImportDeclaration"){let Y=Z,X=Y.source.value,{resolved:K,isExternal:V}=R_($,X,J,Q),B=Y.importKind==="type",C=Y.specifiers,N={dstFilePath:K,specifier:X};if(C.length===0){let w={};if(B)w.isType=!0;if(V)w.isExternal=!0;if(K===null&&!V)w.isUnresolved=!0;W.push({type:B?"type-references":"imports",srcFilePath:$,srcSymbolName:null,...N,dstSymbolName:null,...Object.keys(w).length>0?{metaJson:JSON.stringify(w)}:{}})}else for(let w of C){let S=w.type,F=B||S==="ImportSpecifier"&&w.importKind==="type",G={};if(F)G.isType=!0;if(V)G.isExternal=!0;if(K===null&&!V)G.isUnresolved=!0;let u,E;if(S==="ImportDefaultSpecifier")u="default",E=w.local.name;else if(S==="ImportNamespaceSpecifier")u="*",E=w.local.name,G.importKind="namespace";else u=t_(w.imported),E=w.local.name;W.push({type:F?"type-references":"imports",srcFilePath:$,srcSymbolName:E,...N,dstSymbolName:u,...Object.keys(G).length>0?{metaJson:JSON.stringify(G)}:{}})}continue}if(Z.type==="ExportAllDeclaration"){let Y=Z,X=Y.source.value,{resolved:K,isExternal:V}=R_($,X,J,Q),B=Y.exportKind==="type",C=Y.exported,N=C?t_(C):null,w={isReExport:!0};if(B)w.isType=!0;if(V)w.isExternal=!0;if(K===null&&!V)w.isUnresolved=!0;if(N)w.namespaceAlias=N;W.push({type:B?"type-references":"re-exports",srcFilePath:$,srcSymbolName:null,dstFilePath:K,dstSymbolName:N,specifier:X,metaJson:JSON.stringify(w)});continue}if(Z.type==="ExportNamedDeclaration"){let Y=Z;if(!Y.source)continue;let X=Y.source.value,{resolved:K,isExternal:V}=R_($,X,J,Q),B=Y.exportKind==="type",C=Y.specifiers??[];for(let N of C){let w=B||N.exportKind==="type",S=t_(N.local),F=t_(N.exported),G={isReExport:!0,specifiers:[{local:S,exported:F}]};if(w)G.isType=!0;if(V)G.isExternal=!0;if(K===null&&!V)G.isUnresolved=!0;W.push({type:w?"type-references":"re-exports",srcFilePath:$,srcSymbolName:F,dstFilePath:K,dstSymbolName:S,specifier:X,metaJson:JSON.stringify(G)})}}}}function CJ(_,$,J,Q,W){new BJ({ImportExpression(Z){let Y=Z.source;if(Y.type!=="Literal"||typeof Y.value!=="string")return;let X=Y.value,{resolved:K,isExternal:V}=R_($,X,J,Q),B={isDynamic:!0};if(V)B.isExternal=!0;if(K===null&&!V)B.isUnresolved=!0;W.push({type:"imports",srcFilePath:$,srcSymbolName:null,dstFilePath:K,dstSymbolName:null,specifier:X,metaJson:JSON.stringify(B)})},CallExpression(Z){let Y=Z.callee,X=!1;if(Y.type==="Identifier"&&Y.name==="require");else if(Y.type==="MemberExpression"&&!Y.computed){let S=Y,F=S.object,G=S.property;if(F.type==="Identifier"&&F.name==="require"&&G.name==="resolve")X=!0;else return}else return;let K=Z.arguments;if(K.length===0)return;let V=K[0];if(V.type!=="Literal"||typeof V.value!=="string")return;let B=V.value,{resolved:C,isExternal:N}=R_($,B,J,Q),w={isRequire:!0};if(X)w.isRequireResolve=!0;if(N)w.isExternal=!0;if(C===null&&!N)w.isUnresolved=!0;W.push({type:"imports",srcFilePath:$,srcSymbolName:null,dstFilePath:C,dstSymbolName:null,specifier:B,metaJson:JSON.stringify(w)})}}).visit(_)}function e0(_,$,J,Q=N_,W){let z=[];if(W)wJ(W,$,J,Q,z),IJ(W,$,J,Q,z);else DJ(_,$,J,Q,z);return CJ(_,$,J,Q,z),z}import{walk as EJ}from"oxc-walker";function AJ(_){return _.type==="FunctionDeclaration"||_.type==="FunctionExpression"||_.type==="ArrowFunctionExpression"}function qJ(_){return _.type==="ArrowFunctionExpression"}function NJ(_){return _.type==="AssignmentExpression"}function RJ(_){return _.type==="CallExpression"}function SJ(_){return _.type==="FunctionDeclaration"}function TJ(_){return _.type==="FunctionExpression"}function GJ(_){return _.type==="Identifier"}function FJ(_){return _.type==="MemberExpression"}function jJ(_){return _.type==="TSQualifiedName"}function gJ(_){return _.type==="VariableDeclaration"}var _1=new Map,kJ=new Proxy({},{get(_,$,J){if(typeof $!=="string")return Reflect.get(_,$,J);let Q=$.charCodeAt(0);if(Q<65||Q>90)return Reflect.get(_,$,J);let W=_1.get($);if(W===void 0)W=(z)=>z!==null&&z!==void 0&&z.type===$,_1.set($,W);return W}});function E_(_){if(!_||typeof _!=="object"||Array.isArray(_))return null;let $=_;if($.type==="Identifier"){let J=$.name;return{root:J,parts:[],full:J}}if($.type==="ThisExpression")return{root:"this",parts:[],full:"this"};if($.type==="Super")return{root:"super",parts:[],full:"super"};if($.type==="MemberExpression"){let J=[],Q=$;while(Q.type==="MemberExpression"){let Z=Q.property;if(!Z||typeof Z.name!=="string")return null;J.push(Z.name),Q=Q.object}let W;if(Q.type==="Identifier")W=Q.name;else if(Q.type==="ThisExpression")W="this";else if(Q.type==="Super")W="super";else return null;J.reverse();let z=[W,...J].join(".");return{root:W,parts:J,full:z}}return null}function $1(_,$,J){let Q=[],W=[],z=[];function Z(){if(W.length>0)return W[W.length-1]??null;return null}function Y(V){if(!V)return null;let B=J.get(V.root);if(V.parts.length===0){if(B)return{dstFilePath:B.path,dstSymbolName:B.importedName,resolution:"import"};return{dstFilePath:$,dstSymbolName:V.root,resolution:"local"}}else{if(B&&B.importedName==="*"){let C=V.parts[V.parts.length-1];return{dstFilePath:B.path,dstSymbolName:C,resolution:"namespace"}}return{dstFilePath:$,dstSymbolName:V.full,resolution:"local-member"}}}function X(V,B){let C=E_(V.callee),N=Y(C);if(N){let w=Z(),S={};if(B)S.isNew=!0;if(w===null)S.scope="module";Q.push({type:"calls",srcFilePath:$,srcSymbolName:w,dstFilePath:N.dstFilePath,dstSymbolName:N.dstSymbolName,...Object.keys(S).length>0?{metaJson:JSON.stringify(S)}:{}})}}function K(V,B){if(V.type==="FunctionDeclaration"){W.push(V.id?.name??"anonymous");return}if(V.type==="FunctionExpression"||V.type==="ArrowFunctionExpression"){if(B?.type==="VariableDeclarator"){let w=B.id,S=w.type==="Identifier"?w.name:"anonymous";W.push(S);return}if(B?.type==="MethodDefinition"||B?.type==="TSAbstractMethodDefinition"){let w=B.key,S=z[z.length-1]??"",F="name"in w?w.name:"anonymous",G=S?`${S}.${F}`:F;W.push(G);return}let C=Z(),N=C?`${C}.<anonymous>`:"<anonymous>";W.push(N)}}return EJ(_,{enter(V,B){if(V.type==="ClassDeclaration"||V.type==="ClassExpression"){z.push(V.id?.name??"AnonymousClass");return}if(V.type==="FunctionDeclaration"||V.type==="FunctionExpression"||V.type==="ArrowFunctionExpression"){K(V,B);return}if(V.type==="CallExpression"){X(V,!1);return}if(V.type==="NewExpression"){X(V,!0);return}},leave(V){if(V.type==="ClassDeclaration"||V.type==="ClassExpression"){z.pop();return}if(V.type==="FunctionDeclaration"||V.type==="FunctionExpression"||V.type==="ArrowFunctionExpression"){W.pop();return}}}),Q}import{Visitor as uJ}from"oxc-parser";function J1(_,$,J){let Q=[];function W(Z){let Y=Z.id?.name??"AnonymousClass";if(Z.superClass){let K=E_(Z.superClass);if(K){let V=D0(K,$,J);Q.push({type:"extends",srcFilePath:$,srcSymbolName:Y,...V})}}let X=Z.implements??[];for(let K of X){let V=E_(K.expression);if(!V)continue;let B=D0(V,$,J);Q.push({type:"implements",srcFilePath:$,srcSymbolName:Y,...B})}}return new uJ({TSInterfaceDeclaration(Z){let Y=Z.id.name??"AnonymousInterface",X=Z.extends;for(let K of X){let V=E_(K.expression);if(!V)continue;let B=D0(V,$,J);Q.push({type:"extends",srcFilePath:$,srcSymbolName:Y,...B})}},ClassDeclaration(Z){W(Z)},ClassExpression(Z){W(Z)}}).visit(_),Q}function D0(_,$,J){let Q=J.get(_.root);if(Q){if(Q.importedName==="*"){let W=_.parts[_.parts.length-1]??_.root;return{dstFilePath:Q.path,dstSymbolName:W,metaJson:JSON.stringify({isNamespaceImport:!0})}}return{dstFilePath:Q.path,dstSymbolName:_.parts.length>0?_.full:Q.importedName}}return{dstFilePath:$,dstSymbolName:_.full,metaJson:JSON.stringify({isLocal:!0})}}function m_(_,$,J,Q=N_,W){let z=t0(_,$,J,Q),Z=e0(_,$,J,Q,W),Y=$1(_,$,z),X=J1(_,$,z);return[...Z,...Y,...X]}function C0(_){let{ast:$,project:J,filePath:Q,relationRepo:W,projectRoot:z,tsconfigPaths:Z,knownFiles:Y,boundaries:X,module:K}=_,V=j_(z,Q),C=m_($,V,Z,Y?(w,S,F)=>{let G=N_(w,S,F);for(let u of G){let E=f_(z,u);if(X){let y=l(E,X);if(Y.has(`${y}::${E}`))return[u]}else if(Y.has(`${J}::${E}`))return[u]}return[]}:void 0,K),N=[];for(let w of C){if(w.dstFilePath===null){let u=f_(z,w.srcFilePath),E;if(w.metaJson)try{E=JSON.parse(w.metaJson)}catch{}let y=E?.isExternal===!0;N.push({project:J,type:w.type,srcFilePath:u,srcSymbolName:w.srcSymbolName??null,dstProject:null,dstFilePath:null,dstSymbolName:w.dstSymbolName??null,metaJson:w.metaJson??null,specifier:w.specifier??null,isExternal:y?1:0});continue}let S=f_(z,w.dstFilePath);if(S.startsWith(".."))continue;let F=f_(z,w.srcFilePath),G=X?l(S,X):J;N.push({project:J,type:w.type,srcFilePath:F,srcSymbolName:w.srcSymbolName??null,dstProject:G,dstFilePath:S,dstSymbolName:w.dstSymbolName??null,metaJson:w.metaJson??null,specifier:w.specifier??null,isExternal:0})}return W.replaceFileRelations(J,Q,N),N.length}import{isErr as vJ}from"@zipbul/result";var Q1=/(?:^|\s)@([a-zA-Z][\w-]*\w|[a-zA-Z])\s*(.*)$/m;function bJ(_){let $=q_(_),J=[];for(let Q of $){J.push({name:Q.name,startLine:Q.span.start.line});for(let W of Q.members??[])J.push({name:`${Q.name}.${W.name}`,startLine:W.span.start.line})}return J.sort((Q,W)=>Q.startLine-W.startLine),J}function A0(_,$,J){let Q=0,W=_.length-1;while(Q<=W){let z=Q+W>>1;if(_[z].startLine<=$)Q=z+1;else W=z-1}if(Q<_.length){let z=_[Q];if(z.startLine-$<=J)return z.name}return null}function e_(_,$,J){let Q=U_(_,$),W=U_(_,J);return{start:Q,end:W}}function W1(_){let{comments:$,sourceText:J}=_;if(!$.length)return[];let Q=h_(J),W=bJ(_),z=[],Z=[...$].sort((X,K)=>X.start-K.start),Y=null;for(let X of Z)if(X.type==="Block"&&X.value.startsWith("*")){Y=null;let K=`/*${X.value}*/`,V=r_(K);if(vJ(V))continue;let B=V;if(!B.tags?.length)continue;let C=U_(Q,X.end),N=A0(W,C.line,3),w=J.slice(X.start,X.end);for(let S of B.tags){let F=[S.name,S.description].filter(Boolean).join(" "),G=`@${S.tag}`,u=w.indexOf(G),E;if(u>=0){let y=X.start+u,d=J.indexOf(`
|
|
4
|
-
`,y),
|
|
5
|
-
`),V=0;for(let
|
|
6
|
-
`).length});let
|
|
7
|
-
`).length})}let I=new Set;for(let R of H)for(let[j]of Q.getFilesMap(R.project))I.add(`${R.project}::${j}`);let T=this.opts.parseSourceFn??g_;for(let R of L){let j=l(R.filePath,H),g=T(j_(U,R.filePath),R.text);if(Y1(g))throw g.data;let v=g;if(A.push({filePath:R.filePath,parsed:v}),w0({parsed:v,project:j,filePath:R.filePath,contentHash:R.contentHash,symbolRepo:W}),G)y+=q0({parsed:v,project:j,filePath:R.filePath,annotationRepo:G});Q_+=C0({ast:v.program,project:j,filePath:R.filePath,relationRepo:z,projectRoot:U,tsconfigPaths:K,knownFiles:I,boundaries:H,module:v.module}),p+=W.getFileSymbols(j,R.filePath).length}});for(let I of A)M.set(I.filePath,I.parsed)}else{E();let U=await d();p=U.symbols,Q_=U.relations,y=U.annotations,Y_=U.failedFiles}for(let U of Y){let H=l(U.filePath,this.opts.boundaries);for(let M of W.getFileSymbols(H,U.filePath))N.set(`${M.filePath}::${M.name}`,w(M))}let O_=new Map;for(let U of Y){let H=l(U.filePath,this.opts.boundaries);for(let M of z.getOutgoing(H,U.filePath))O_.set(S(M),M)}let Z_=(U)=>({type:U.type,srcFilePath:U.srcFilePath,dstFilePath:U.dstFilePath,srcSymbolName:U.srcSymbolName,dstSymbolName:U.dstSymbolName,dstProject:U.dstProject,metaJson:U.metaJson}),W_={added:[...O_.entries()].filter(([U])=>!F.has(U)).map(([,U])=>Z_(U)),removed:[...F.entries()].filter(([U])=>!O_.has(U)).map(([,U])=>Z_(U))},i={added:[],modified:[],removed:[]};for(let[U,H]of N){let M=C.get(U);if(!M)i.added.push({name:H.name,filePath:H.filePath,kind:H.kind,isExported:Boolean(H.isExported)});else{let L=M.fingerprint!==H.fingerprint,A=M.isExported!==H.isExported,I=M.structuralFingerprint!==null&&H.structuralFingerprint!==null&&M.structuralFingerprint!==H.structuralFingerprint;if(L||A||I)i.modified.push({name:H.name,filePath:H.filePath,kind:H.kind,isExported:Boolean(H.isExported)})}}for(let[U,H]of C)if(!N.has(U))i.removed.push({name:H.name,filePath:H.filePath,kind:H.kind,isExported:Boolean(H.isExported)});let c=z1(C,N),w_=new Set(c.renamed.map((U)=>`${U.filePath}::${U.oldName}`)),D=new Set(c.renamed.map((U)=>`${U.filePath}::${U.newName}`));i.added=i.added.filter((U)=>!D.has(`${U.filePath}::${U.name}`)),i.removed=i.removed.filter((U)=>!w_.has(`${U.filePath}::${U.name}`));let q=[];if(!$){for(let[H,M]of V)for(let L of M){if(!L.fingerprint)continue;let A=l(H,this.opts.boundaries),I=W.getByFingerprint(A,L.fingerprint);if(I.length===1){let T=I[0];z.retargetRelations({dstProject:A,oldFile:H,oldSymbol:L.name,newFile:T.filePath,newSymbol:T.name}),q.push({name:T.name,filePath:T.filePath,kind:T.kind,oldFilePath:H,isExported:T.isExported??0})}}let U=new Set(q.map((H)=>`${H.oldFilePath}::${H.name}`));for(let H of c.removed){if(U.has(`${H.filePath}::${H.name}`))continue;let L=C.get(`${H.filePath}::${H.name}`)?.fingerprint;if(!L)continue;let A=l(H.filePath,this.opts.boundaries),I=W.getByFingerprint(A,L);if(I.length===1){let T=I[0];if(T.filePath!==H.filePath||T.name!==H.name)z.retargetRelations({dstProject:A,oldFile:H.filePath,oldSymbol:H.name,newFile:T.filePath,newSymbol:T.name}),q.push({name:T.name,filePath:T.filePath,kind:T.kind,oldFilePath:H.filePath,isExported:T.isExported??0})}}}if(q.length){let U=new Set(q.map((M)=>`${M.filePath}::${M.name}`)),H=new Set(q.map((M)=>`${M.oldFilePath}::${M.name}`));i.added=i.added.filter((M)=>!U.has(`${M.filePath}::${M.name}`)),i.removed=i.removed.filter((M)=>!H.has(`${M.filePath}::${M.name}`))}if(u){let U=new Date().toISOString(),H=$?1:0,M=[];for(let L of i.added){let A=`${L.filePath}::${L.name}`,I=N.get(A),T=l(L.filePath,this.opts.boundaries);M.push({project:T,changeType:"added",symbolName:L.name,symbolKind:L.kind,filePath:L.filePath,oldName:null,oldFilePath:null,fingerprint:I?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:B})}for(let L of i.modified){let A=N.get(`${L.filePath}::${L.name}`),I=l(L.filePath,this.opts.boundaries);M.push({project:I,changeType:"modified",symbolName:L.name,symbolKind:L.kind,filePath:L.filePath,oldName:null,oldFilePath:null,fingerprint:A?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:B})}for(let L of i.removed){let A=`${L.filePath}::${L.name}`,I=C.get(A),T=l(L.filePath,this.opts.boundaries);M.push({project:T,changeType:"removed",symbolName:L.name,symbolKind:L.kind,filePath:L.filePath,oldName:null,oldFilePath:null,fingerprint:I?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:B})}for(let L of c.renamed){let A=N.get(`${L.filePath}::${L.newName}`),I=l(L.filePath,this.opts.boundaries);M.push({project:I,changeType:"renamed",symbolName:L.newName,symbolKind:L.kind,filePath:L.filePath,oldName:L.oldName,oldFilePath:null,fingerprint:A?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:B})}for(let L of q){let A=N.get(`${L.filePath}::${L.name}`),I=l(L.filePath,this.opts.boundaries);M.push({project:I,changeType:"moved",symbolName:L.name,symbolKind:L.kind,filePath:L.filePath,oldName:null,oldFilePath:L.oldFilePath,fingerprint:A?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:B})}if(M.length)try{Z.transaction(()=>{u.insertBatch(M)})}catch(L){this.logger.error("[IndexCoordinator] changelog insert failed:",L)}if(Date.now()-this.lastPruneAt>3600000){this.lastPruneAt=Date.now();let L=new Date(Date.now()-2592000000).toISOString();try{for(let A of this.opts.boundaries)u.pruneOlderThan(A.project,L)}catch(A){this.logger.error("[IndexCoordinator] changelog pruning failed:",A)}}}return{indexedFiles:Y.length,removedFiles:X.length,totalSymbols:p,totalRelations:Q_,totalAnnotations:y,durationMs:Date.now()-J,changedFiles:Y.map((U)=>U.filePath),deletedFiles:[...X],failedFiles:Y_,changedSymbols:i,renamedSymbols:c.renamed.map((U)=>({oldName:U.oldName,newName:U.newName,filePath:U.filePath,kind:U.kind,isExported:Boolean(N.get(`${U.filePath}::${U.newName}`)?.isExported)})),movedSymbols:q.map((U)=>({name:U.name,oldFilePath:U.oldFilePath,newFilePath:U.filePath,kind:U.kind,isExported:Boolean(U.isExported)})),changedRelations:W_}}fireCallbacks(_){for(let $ of this.callbacks)try{$(_)}catch(J){this.logger.error("[IndexCoordinator] onIndexed callback threw:",J)}}flushPending(){if(this.indexingLock)return;if(this.pendingEvents.length>0){let _=this.pendingEvents.splice(0);this.startIndex(_,!1).catch(($)=>this.logger.error("[IndexCoordinator] flushPending startIndex error:",$))}}}function fJ(_){try{return process.kill(_,0),!0}catch($){if(typeof $==="object"&&$&&"code"in $)return $.code!=="ESRCH";return!0}}function yJ(_){let $=new Date(_).getTime();return Number.isNaN($)?0:$}function X1(_,$,J={}){let Q=J.now??Date.now,W=J.isAlive??fJ,z=J.staleAfterSeconds??60,Z=J.instanceId;return _.immediateTransaction(()=>{let Y=_.selectOwner();if(!Y)return _.insertOwner($,Z),"owner";let X=Math.floor((Q()-yJ(Y.heartbeat_at))/1000),K=W(Y.pid);if(K&&Z&&Y.instance_id&&Y.instance_id!==Z&&Y.pid===$)return _.replaceOwner($,Z),"owner";if(K&&X<z)return"reader";return _.replaceOwner($,Z),"owner"})}function U1(_,$){_.deleteOwner($)}function V1(_,$){_.touchOwner($)}class n_{#_;#$=new Map;constructor(_){this.#_=Math.max(1,_)}get size(){return this.#$.size}has(_){return this.#$.has(_)}get(_){if(!this.#$.has(_))return;let $=this.#$.get(_);return this.#$.delete(_),this.#$.set(_,$),$}set(_,$){if(this.#$.has(_))this.#$.delete(_);if(this.#$.set(_,$),this.#$.size>this.#_){let J=this.#$.keys().next().value;if(J!==void 0)this.#$.delete(J)}}delete(_){return this.#$.delete(_)}clear(){this.#$.clear()}}class R0{lru;constructor(_=500){this.lru=new n_(_)}get(_){return this.lru.get(_)}set(_,$){this.lru.set(_,$)}invalidate(_){this.lru.delete(_)}invalidateAll(){this.lru.clear()}size(){return this.lru.size}}function S0(_){let{symbolRepo:$,project:J,query:Q}=_,W=Q.project??J,z={kind:Q.kind,filePath:Q.filePath,isExported:Q.isExported,project:W,limit:Q.limit,resolvedType:Q.resolvedType};if(Q.text)if(Q.exact)z.exactName=Q.text;else{let Y=F_(Q.text);if(Y)z.ftsQuery=Y}if(Q.decorator)z.decorator=Q.decorator;if(Q.regex)z.regex=Q.regex;return $.searchByQuery(z).map((Y)=>{let X=Y.name.indexOf(".");return{id:Y.id,filePath:Y.filePath,kind:Y.kind,name:Y.name,memberName:X>=0?Y.name.slice(X+1):null,span:{start:{line:Y.startLine,column:Y.startColumn},end:{line:Y.endLine,column:Y.endColumn}},isExported:Y.isExported===1,signature:Y.signature,fingerprint:Y.fingerprint,detail:Y.detailJson?(()=>{try{return JSON.parse(Y.detailJson)}catch{return{}}})():{}}})}function T0(_){let{relationRepo:$,project:J,query:Q}=_;if(Q.srcFilePath&&Q.srcFilePathPattern)throw new O("validation","srcFilePath and srcFilePathPattern are mutually exclusive");if(Q.dstFilePath&&Q.dstFilePathPattern)throw new O("validation","dstFilePath and dstFilePathPattern are mutually exclusive");let W=Q.project??J,z=Q.limit,Z=!!(Q.srcFilePathPattern||Q.dstFilePathPattern),Y=Z?void 0:z,K=$.searchRelations({srcFilePath:Q.srcFilePath,srcSymbolName:Q.srcSymbolName,dstFilePath:Q.dstFilePath,dstSymbolName:Q.dstSymbolName,dstProject:Q.dstProject,type:Q.type,project:W,specifier:Q.specifier,isExternal:Q.isExternal,limit:Y}).map((V)=>{let B;if(V.metaJson)try{B=JSON.parse(V.metaJson)}catch{}return{type:V.type,srcFilePath:V.srcFilePath,srcSymbolName:V.srcSymbolName,dstFilePath:V.dstFilePath,dstSymbolName:V.dstSymbolName,dstProject:V.dstProject,isExternal:V.isExternal===1,specifier:V.specifier,metaJson:V.metaJson??void 0,meta:B}});if(Q.srcFilePathPattern||Q.dstFilePathPattern){let V=Q.srcFilePathPattern?new Bun.Glob(Q.srcFilePathPattern):null,B=Q.dstFilePathPattern?new Bun.Glob(Q.dstFilePathPattern):null;K=K.filter((C)=>(!V||V.match(C.srcFilePath))&&(!B||C.dstFilePath===null||B.match(C.dstFilePath)))}if(Z&&z!==void 0&&K.length>z)K=K.slice(0,z);return K}import{findInFiles as xJ,Lang as hJ}from"@ast-grep/napi";function mJ(_){let $=new Set,J=/\${1,3}([A-Z_][A-Z_0-9]*)/g,Q;while((Q=J.exec(_))!==null)$.add(Q[0]);return[...$]}function nJ(_){return _.replace(/^\$+/,"")}function dJ(_,$){if($.length===0)return;let J={},Q=!1;for(let W of $){let z=nJ(W),Z=_.getMatch(z);if(Z){let X=Z.range();J[W]={text:Z.text(),startLine:X.start.line+1,endLine:X.end.line+1,startColumn:X.start.column,endColumn:X.end.column,startOffset:X.start.index,endOffset:X.end.index},Q=!0;continue}let Y=_.getMultipleMatches(z);if(Y.length>0){let X=Y[0].range(),K=Y[Y.length-1].range();J[W]={text:Y.map((V)=>V.text()).join(", "),startLine:X.start.line+1,endLine:K.end.line+1,startColumn:X.start.column,endColumn:K.end.column,startOffset:X.start.index,endOffset:K.end.index},Q=!0}}return Q?J:void 0}async function G0(_){if(_.filePaths.length===0)return[];let $=mJ(_.pattern),J=[];return await xJ(hJ.TypeScript,{paths:_.filePaths,matcher:{rule:{pattern:_.pattern}}},(Q,W)=>{if(Q){console.warn("[patternSearch] findInFiles callback error:",Q);return}for(let z of W){let Z=z.range(),Y={filePath:z.getRoot().filename(),startLine:Z.start.line+1,endLine:Z.end.line+1,startColumn:Z.start.column,endColumn:Z.end.column,startOffset:Z.start.index,endOffset:Z.end.index,matchedText:z.text()},X=dJ(z,$);if(X)Y.captures=X;J.push(Y)}}),J}import o from"typescript";import{isErr as QQ}from"@zipbul/result";import B_ from"typescript";import pJ from"path";import{err as F0}from"@zipbul/result";function iJ(_){try{return x0("fs").readFileSync(_,"utf-8")}catch{return}}function lJ(_){try{return x0("fs").readFileSync(_,"utf-8")}catch{return}}class _0{#_;#$;#J=!1;__testing__;constructor(_,$){this.#_=_,this.#$=$,this.__testing__={host:$}}static create(_,$={}){let J=$.readConfigFile??iJ,Q=$.resolveNonTrackedFile??lJ,W=pJ.dirname(_),z=J(_);if(z===void 0)return F0(new O("semantic",`tsconfig not found: ${_}`));let Z=B_.parseJsonText(_,z),Y=Z.parseDiagnostics;if(Y&&Y.length>0){let B=Y.map((C)=>B_.flattenDiagnosticMessageText(C.messageText,`
|
|
8
|
-
`)).join("; ");return
|
|
9
|
-
`)).join("; ");return F0(new O("semantic",`tsconfig compile error: ${C}`))}}let K=new O1(X.fileNames,X.options,W,Q),V=B_.createLanguageService(K);return new _0(V,K)}get isDisposed(){return this.#J}getProgram(){this.#Y();let _=this.#_.getProgram();if(!_)throw Error("TscProgram: LanguageService returned null Program");return _}getChecker(){return this.#Y(),this.getProgram().getTypeChecker()}getLanguageService(){return this.#Y(),this.#_}notifyFileChanged(_,$){if(this.#J)return;this.#$.updateFile(_,$)}removeFile(_){if(this.#J)return;this.#$.removeFile(_)}dispose(){if(this.#J)return;this.#J=!0,this.#_.dispose()}#Y(){if(this.#J)throw Error("TscProgram is disposed")}}class O1{#_;#$;#J;#Y;#W=new Map;#z=new Map;#Q=new Map;constructor(_,$,J,Q){this.#_=new Set(_),this.#$=$,this.#J=J,this.#Y=Q}updateFile(_,$){let J=this.#W.get(_);if(J)this.#z.delete(`${_}:${J.version}`),J.version+=1,J.content=$;else this.#W.set(_,{version:1,content:$})}removeFile(_){let $=this.#W.get(_);if($)this.#z.delete(`${_}:${$.version}`);this.#W.delete(_),this.#_.delete(_)}getScriptFileNames(){let _=[...this.#W.keys()];return[...[...this.#_].filter((J)=>!this.#W.has(J)),..._]}getScriptVersion(_){let $=this.#W.get(_);return $?String($.version):"0"}getScriptSnapshot(_){let $=this.#W.get(_);if($){let W=`${_}:${$.version}`,z=this.#z.get(W);if(!z)z=B_.ScriptSnapshot.fromString($.content),this.#z.set(W,z);return z}let J=this.#Q.get(_);if(J)return J;let Q=this.#Y(_);if(Q!==void 0)return J=B_.ScriptSnapshot.fromString(Q),this.#Q.set(_,J),J;return}getCurrentDirectory(){return this.#J}getCompilationSettings(){return this.#$}getDefaultLibFileName(_){return B_.getDefaultLibFilePath(_)}fileExists(_){if(this.#W.has(_))return!0;return this.#Y(_)!==void 0}readFile(_){let $=this.#W.get(_);if($)return $.content;return this.#Y(_)}}import m from"typescript";import cJ from"typescript";function e(_,$){if($<0||$>=_.getEnd())return;let J=cJ.getTokenAtPosition(_,$);if(J.getStart(_,!1)>$)return;return J}var $0=8;function aJ(_){return!!(_.flags&m.TypeFlags.Object)&&!!(_.objectFlags&m.ObjectFlags.Reference)}function M_(_,$,J=0,Q){if(Q){let w=Q.get($);if(w)return w}let W=_.typeToString($),z=$.flags,Z=!!(z&m.TypeFlags.Union),Y=!!(z&m.TypeFlags.Intersection),X;if(J<$0&&aJ($)){let w=_.getTypeArguments($);if(w.length>0)X=w}let K=!!(z&m.TypeFlags.TypeParameter)||X!==void 0&&X.length>0,V;if(Z&&J<$0)V=$.types.map((w)=>M_(_,w,J+1,Q));else if(Y&&J<$0)V=$.types.map((w)=>M_(_,w,J+1,Q));let B;if(X&&X.length>0)B=X.map((w)=>M_(_,w,J+1,Q));let C;if(J<$0&&!!(z&m.TypeFlags.Object)&&!Z&&!Y){let w=_.getPropertiesOfType($);if(w.length>0&&w.length<=50){let S=$.symbol?.declarations?.[0];C=[];for(let F of w){let G=F.declarations?.[0]??S;if(!G)continue;try{let u=_.getTypeOfSymbolAtLocation(F,G);C.push({name:F.getName(),type:M_(_,u,J+1,Q)})}catch{}}if(C.length===0)C=void 0}}let N={text:W,flags:z,isUnion:Z,isIntersection:Y,isGeneric:K,members:V,typeArguments:B,properties:C};if(Q)Q.set($,N);return N}function sJ(_){return m.isFunctionDeclaration(_)||m.isVariableDeclaration(_)||m.isClassDeclaration(_)||m.isInterfaceDeclaration(_)||m.isTypeAliasDeclaration(_)||m.isEnumDeclaration(_)||m.isMethodDeclaration(_)||m.isPropertyDeclaration(_)||m.isPropertySignature(_)||m.isMethodSignature(_)}var j0="/__gildash_type_probe__.ts";class g0{program;#_=null;constructor(_){this.program=_}#$(_){if(this.#_===_)return;this.program.notifyFileChanged(j0,`declare const __gildash_probe__: ${_};`),this.#_=_}#J(_,$){let J=_.getSourceFile(j0);if(!J)return null;let Q=J.statements[0];if(!Q||!m.isVariableStatement(Q))return null;let W=Q.declarationList.declarations[0];if(!W)return null;return $.getTypeAtLocation(W.name)}clearProbe(){if(this.#_!==null)this.program.removeFile(j0),this.#_=null}collectAt(_,$){let J=this.program.getProgram(),Q=J.getTypeChecker();if($<0)return null;let W=J.getSourceFile(_);if(!W)return null;if($>=W.getEnd())return null;let z=e(W,$);if(!z)return null;if(!m.isIdentifier(z)&&!m.isTypeNode(z))return null;try{let Z=Q.getTypeAtLocation(z);return M_(Q,Z,0,new Map)}catch{return null}}isAssignableTo(_,$,J,Q){let W=this.program.getProgram(),z=W.getTypeChecker(),Z=W.getSourceFile(_);if(!Z)return null;let Y=e(Z,$);if(!Y||!m.isIdentifier(Y))return null;let X=W.getSourceFile(J);if(!X)return null;let K=e(X,Q);if(!K||!m.isIdentifier(K))return null;try{let V=z.getTypeAtLocation(Y),B=z.getTypeAtLocation(K);return z.isTypeAssignableTo(V,B)}catch{return null}}isAssignableToType(_,$,J,Q){this.#$(J);let W=this.program.getProgram(),z=W.getTypeChecker(),Z=W.getSourceFile(_);if(!Z)return null;let Y=e(Z,$);if(!Y||!m.isIdentifier(Y)&&!m.isTypeNode(Y))return null;try{let X=this.#J(W,z);if(!X)return null;let K=z.getTypeAtLocation(Y);if(Q?.anyConstituent&&K.isUnion())return K.types.some((V)=>z.isTypeAssignableTo(V,X));return z.isTypeAssignableTo(K,X)}catch{return null}}isAssignableToTypeAtPositions(_,$,J,Q){let W=new Map;if($.length===0)return W;this.#$(J);let z=this.program.getProgram(),Z=z.getTypeChecker(),Y=z.getSourceFile(_);if(!Y)return W;try{let X=this.#J(z,Z);if(!X)return W;let K=Y.getEnd();for(let V of $){if(V<0||V>=K)continue;let B=e(Y,V);if(!B||!m.isIdentifier(B)&&!m.isTypeNode(B))continue;try{let C=Z.getTypeAtLocation(B);if(Q?.anyConstituent&&C.isUnion())W.set(V,C.types.some((N)=>Z.isTypeAssignableTo(N,X)));else W.set(V,Z.isTypeAssignableTo(C,X))}catch{}}}catch{}return W}collectAtPositions(_,$){let J=new Map;if($.length===0)return J;let Q=this.program.getProgram(),W=Q.getTypeChecker(),z=Q.getSourceFile(_);if(!z)return J;let Z=z.getEnd(),Y=new Map;for(let X of $){if(X<0||X>=Z)continue;let K=e(z,X);if(!K)continue;if(!m.isIdentifier(K)&&!m.isTypeNode(K))continue;try{let V=W.getTypeAtLocation(K);J.set(X,M_(W,V,0,Y))}catch{}}return J}collectFile(_){let $=new Map,J=this.program.getProgram(),Q=J.getTypeChecker(),W=J.getSourceFile(_);if(!W)return $;let z=new Map;function Z(Y){if(sJ(Y)&&Y.name&&m.isIdentifier(Y.name)){let X=Y.name;try{let K=Q.getTypeAtLocation(X),V=X.getStart(W);$.set(V,M_(Q,K,0,z))}catch{}}m.forEachChild(Y,Z)}return Z(W),$}}import L_ from"typescript";var rJ=1000,oJ=1;function tJ(_){let $=_.declarations?.[0],J=$?.getSourceFile(),Q=$?L_.getNameOfDeclaration($):void 0;return{name:_.getName(),filePath:J?.fileName??"",position:Q?.getStart(J,!1)??$?.getStart(J,!1)??0}}function J0(_,$=0,J){let Q=_.declarations?.[0],W=Q?.getSourceFile(),z=Q?L_.getNameOfDeclaration(Q):void 0,Z=W?.fileName??"",Y=z?.getStart(W,!1)??Q?.getStart(W,!1)??0,X={name:_.getName(),filePath:Z,position:Y},K=_;if(K.parent)X.parent=tJ(K.parent);let V=J&&!!(_.flags&L_.SymbolFlags.Alias)?J.getAliasedSymbol(_):_;if($<oJ){let B=V.flags,C=!!(B&L_.SymbolFlags.Enum),N=!!(B&(L_.SymbolFlags.NamespaceModule|L_.SymbolFlags.ValueModule)),w=!!(B&(L_.SymbolFlags.Class|L_.SymbolFlags.Interface));if(C&&V.exports&&V.exports.size>0){let S=[];V.exports.forEach((F)=>{S.push(J0(F,$+1,J))}),X.members=S}else if(w&&V.members&&V.members.size>0){let S=[];V.members.forEach((F)=>{S.push(J0(F,$+1,J))}),X.members=S}if(N&&V.exports&&V.exports.size>0){let S=[];V.exports.forEach((F)=>{S.push(J0(F,$+1,J))}),X.exports=S}}return X}class k0{#_;#$;#J=new Map;constructor(_,$=rJ){this.#_=_,this.#$=new n_($)}get(_,$){if(this.#_.isDisposed)return null;let J=`${_}:${$}`,Q=this.#$.get(J);if(Q!==void 0)return Q;let W=this.#_.getProgram(),z=W.getSourceFile(_);if(!z)return null;let Z=e(z,$);if(!Z||!L_.isIdentifier(Z))return null;let Y=W.getTypeChecker(),X=Y.getSymbolAtLocation(Z);if(!X)return null;let K=J0(X,0,Y);this.#$.set(J,K);let V=this.#J.get(_);if(!V)V=new Set,this.#J.set(_,V);return V.add(J),K}invalidate(_){let $=this.#J.get(_);if($){for(let J of $)this.#$.delete(J);this.#J.delete(_)}}clear(){this.#$.clear(),this.#J.clear()}}import eJ from"typescript";class E0{#_;constructor(_){this.#_=_}findAt(_,$){if(this.#_.isDisposed)return[];let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return[];let W=e(Q,$);if(!W||!eJ.isIdentifier(W))return[];let Z=this.#_.getLanguageService().findReferences(_,$);if(!Z||Z.length===0)return[];let Y=[];for(let X of Z)for(let K of X.references){let V=J.getSourceFile(K.fileName);if(!V)continue;let{line:B,character:C}=V.getLineAndCharacterOfPosition(K.textSpan.start);Y.push({filePath:K.fileName,position:K.textSpan.start,line:B+1,column:C,isDefinition:K.isDefinition??!1,isWrite:K.isWriteAccess??!1})}return Y}}import x from"typescript";function _Q(_,$){let J=e(_,$);if(!J)return;if(H1(J))return J;let Q=J.parent;for(let W=0;W<5&&Q;W++){if(H1(Q))return Q;Q=Q.parent}return J}function H1(_){return x.isClassDeclaration(_)||x.isClassExpression(_)||x.isFunctionDeclaration(_)||x.isFunctionExpression(_)||x.isArrowFunction(_)||x.isVariableDeclaration(_)||x.isObjectLiteralExpression(_)}function M1(_){if(x.isClassDeclaration(_)||x.isClassExpression(_))return"class";if(x.isFunctionDeclaration(_)||x.isFunctionExpression(_)||x.isArrowFunction(_))return"function";if(x.isObjectLiteralExpression(_))return"object";if(x.isVariableDeclaration(_)&&_.initializer)return M1(_.initializer);return"class"}function $Q(_,$){if(x.isClassDeclaration(_)||x.isFunctionDeclaration(_))return _.name?.getText($)??"";if(x.isClassExpression(_))return _.name?.getText($)??"";if(x.isVariableDeclaration(_)&&x.isIdentifier(_.name))return _.name.getText($);if(x.isFunctionExpression(_))return _.name?.getText($)??"";if(x.isArrowFunction(_)&&_.parent&&x.isVariableDeclaration(_.parent)){if(x.isIdentifier(_.parent.name))return _.parent.name.getText($)}if(x.isObjectLiteralExpression(_)&&_.parent&&x.isVariableDeclaration(_.parent)){if(x.isIdentifier(_.parent.name))return _.parent.name.getText($)}return""}function JQ(_){if(!x.isClassDeclaration(_)&&!x.isClassExpression(_))return!1;let $=_.heritageClauses;if(!$)return!1;return $.some((J)=>J.token===x.SyntaxKind.ImplementsKeyword)}class u0{#_;constructor(_){this.#_=_}findAt(_,$){if(this.#_.isDisposed)return[];let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return[];let W=e(Q,$);if(!W||!x.isIdentifier(W))return[];let Z=this.#_.getLanguageService().getImplementationAtPosition(_,$);if(!Z||Z.length===0)return[];let Y=[];for(let X of Z){if(X.kind===x.ScriptElementKind.interfaceElement||X.kind===x.ScriptElementKind.typeElement)continue;let K=J.getSourceFile(X.fileName);if(!K)continue;let V=_Q(K,X.textSpan.start);if(!V)continue;let B=M1(V),C=$Q(V,K),N=JQ(V);Y.push({filePath:X.fileName,symbolName:C,position:X.textSpan.start,kind:B,isExplicit:N})}return Y}}function WQ(_){if(o.isFunctionDeclaration(_))return"function";if(o.isClassDeclaration(_))return"class";if(o.isInterfaceDeclaration(_))return"interface";if(o.isTypeAliasDeclaration(_))return"type";if(o.isEnumDeclaration(_))return"enum";if(o.isVariableDeclaration(_))return"const";if(o.isVariableStatement(_))return"const";return"unknown"}function K1(_){if(_>=97&&_<=122)return!0;if(_>=65&&_<=90)return!0;if(_>=48&&_<=57)return!0;if(_===95||_===36)return!0;return!1}class Q0{#_;#$;#J;#Y;#W;#z=!1;constructor(_,$,J,Q,W){this.#_=_,this.#$=$,this.#J=J,this.#Y=Q,this.#W=W}static create(_,$={}){let J=_0.create(_,{readConfigFile:$.readConfigFile,resolveNonTrackedFile:$.resolveNonTrackedFile});if(QQ(J))return J;let Q=J,W=$.typeCollector??new g0(Q),z=$.symbolGraph??new k0(Q),Z=$.referenceResolver??new E0(Q),Y=$.implementationFinder??new u0(Q);return new Q0(Q,W,z,Z,Y)}get isDisposed(){return this.#z}collectTypeAt(_,$){return this.#Q(),this.#$.collectAt(_,$)}collectFileTypes(_){return this.#Q(),this.#$.collectFile(_)}collectTypesAtPositions(_,$){return this.#Q(),this.#$.collectAtPositions(_,$)}findReferences(_,$){return this.#Q(),this.#Y.findAt(_,$)}findImplementations(_,$){return this.#Q(),this.#W.findAt(_,$)}isTypeAssignableTo(_,$,J,Q){return this.#Q(),this.#$.isAssignableTo(_,$,J,Q)}isTypeAssignableToType(_,$,J,Q){return this.#Q(),this.#$.isAssignableToType(_,$,J,Q)}isTypeAssignableToTypeAtPositions(_,$,J,Q){return this.#Q(),this.#$.isAssignableToTypeAtPositions(_,$,J,Q)}getSymbolNode(_,$){return this.#Q(),this.#J.get(_,$)}getBaseTypes(_,$){this.#Q();let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return null;let W=e(Q,$);if(!W)return null;let z=J.getTypeChecker(),Z=z.getTypeAtLocation(W);if(!(Z.flags&o.TypeFlags.Object)||!(Z.objectFlags&o.ObjectFlags.ClassOrInterface))return null;let Y=z.getBaseTypes(Z);if(!Y||Y.length===0)return[];let X=new Map;return Y.map((K)=>M_(z,K,0,X))}getModuleInterface(_){this.#Q();let $=[],J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return{filePath:_,exports:$};let W=J.getTypeChecker(),z=W.getSymbolAtLocation(Q);if(z){let Z=W.getExportsOfModule(z),Y=new Map;for(let X of Z){let K=X.getName(),V=X.declarations?.[0],B="unknown";if(V){if(B=WQ(V),B==="unknown"&&o.isExportAssignment(V))B="const"}let C=null;try{let N=W.getTypeOfSymbolAtLocation(X,V??Q);C=M_(W,N,0,Y)}catch{}$.push({name:K,kind:B,resolvedType:C})}}return{filePath:_,exports:$}}notifyFileChanged(_,$){if(this.#z)return;this.#_.notifyFileChanged(_,$),this.#J.invalidate(_)}notifyFileDeleted(_){if(this.#z)return;this.#_.removeFile(_),this.#J.invalidate(_)}lineColumnToPosition(_,$,J){this.#Q();let Q=this.#_.getProgram().getSourceFile(_);if(!Q)return null;try{return o.getPositionOfLineAndCharacter(Q,$-1,J)}catch{return null}}findNamePosition(_,$,J){this.#Q();let Q=this.#_.getProgram().getSourceFile(_);if(!Q)return null;let W=Q.getFullText(),z=$;while(z<W.length){let Z=W.indexOf(J,z);if(Z<0)return null;let Y=Z>0?W.charCodeAt(Z-1):32,X=Z+J.length<W.length?W.charCodeAt(Z+J.length):32;if(!K1(Y)&&!K1(X))return Z;z=Z+1}return null}getDiagnostics(_,$){this.#Q();let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return[];let W={[o.DiagnosticCategory.Error]:"error",[o.DiagnosticCategory.Warning]:"warning",[o.DiagnosticCategory.Suggestion]:"suggestion",[o.DiagnosticCategory.Message]:"suggestion"};return(($?.preEmit)?o.getPreEmitDiagnostics(J,Q):J.getSemanticDiagnostics(Q)).map((Z)=>{let Y=1,X=0;if(Z.file&&Z.start!==void 0){let K=o.getLineAndCharacterOfPosition(Z.file,Z.start);Y=K.line+1,X=K.character}return{filePath:Z.file?.fileName??_,line:Y,column:X,message:o.flattenDiagnosticMessageText(Z.messageText,`
|
|
10
|
-
`),code:Z.code,category:W[Z.category]??"error"}})}dispose(){if(this.#z)return;this.#z=!0,this.#$.clearProbe(),this.#_.dispose(),this.#J.clear()}#Q(){if(this.#z)throw Error("SemanticLayer is disposed")}}import{eq as S_,and as B1,sql as zQ}from"drizzle-orm";var L1=80;class v0{db;constructor(_){this.db=_}insertBatch(_,$,J){if(!J.length)return;let Q=J.map((W)=>({project:_,filePath:$,tag:W.tag,value:W.value,source:W.source,symbolName:W.symbolName,startLine:W.startLine,startColumn:W.startColumn,endLine:W.endLine,endColumn:W.endColumn,indexedAt:W.indexedAt}));for(let W=0;W<Q.length;W+=L1)this.db.drizzleDb.insert(z_).values(Q.slice(W,W+L1)).run()}deleteFileAnnotations(_,$){this.db.drizzleDb.delete(z_).where(B1(S_(z_.project,_),S_(z_.filePath,$))).run()}search(_){let $=this.db.drizzleDb.select().from(z_).where(B1(_.project?S_(z_.project,_.project):void 0,_.tag?S_(z_.tag,_.tag):void 0,_.filePath?S_(z_.filePath,_.filePath):void 0,_.symbolName?S_(z_.symbolName,_.symbolName):void 0,_.source?S_(z_.source,_.source):void 0,_.ftsQuery?zQ`${z_.id} IN (SELECT rowid FROM annotations_fts WHERE annotations_fts MATCH ${_.ftsQuery})`:void 0));return(_.limit!==void 0?$.limit(_.limit):$).all()}}import{eq as u_,and as w1,sql as d_,gt as YQ,gte as ZQ}from"drizzle-orm";var I1=80;class b0{db;constructor(_){this.db=_}insertBatch(_){if(!_.length)return;let $=_.map((J)=>({project:J.project,changeType:J.changeType,symbolName:J.symbolName,symbolKind:J.symbolKind,filePath:J.filePath,oldName:J.oldName,oldFilePath:J.oldFilePath,fingerprint:J.fingerprint,changedAt:J.changedAt,isFullIndex:J.isFullIndex,indexRunId:J.indexRunId}));for(let J=0;J<$.length;J+=I1)this.db.drizzleDb.insert(t).values($.slice(J,J+I1)).run()}getSince(_){return this.db.drizzleDb.select().from(t).where(w1(u_(t.project,_.project),ZQ(t.changedAt,_.since),_.symbolName?u_(t.symbolName,_.symbolName):void 0,_.changeTypes?.length?d_`${t.changeType} IN (${d_.join(_.changeTypes.map(($)=>d_`${$}`),d_`, `)})`:void 0,_.filePath?u_(t.filePath,_.filePath):void 0,_.includeFullIndex?void 0:u_(t.isFullIndex,0),_.indexRunId?u_(t.indexRunId,_.indexRunId):void 0,_.afterId?YQ(t.id,_.afterId):void 0)).orderBy(t.id).limit(_.limit).all()}pruneOlderThan(_,$){return this.db.drizzleDb.delete(t).where(w1(u_(t.project,_),d_`${t.changedAt} < ${$}`)).run().changes}}function D1(_){let{annotationRepo:$,project:J,query:Q}=_,W=Q.project??J,z;if(Q.text){let Y=F_(Q.text);if(Y)z=Y}return $.search({project:W,tag:Q.tag,filePath:Q.filePath,symbolName:Q.symbolName,source:Q.source,ftsQuery:z,limit:Q.limit}).map((Y)=>({tag:Y.tag,value:Y.value,source:Y.source,filePath:Y.filePath,symbolName:Y.symbolName,span:{start:{line:Y.startLine,column:Y.startColumn},end:{line:Y.endLine,column:Y.endColumn}}}))}class W0{options;adjacencyList=new Map;reverseAdjacencyList=new Map;constructor(_){this.options=_}build(){this.adjacencyList=new Map,this.reverseAdjacencyList=new Map;let $=[this.options.project,...this.options.additionalProjects??[]].flatMap((J)=>[...this.options.relationRepo.getByType(J,"imports"),...this.options.relationRepo.getByType(J,"type-references"),...this.options.relationRepo.getByType(J,"re-exports")]);for(let J of $){let{srcFilePath:Q,dstFilePath:W}=J;if(W===null)continue;if(!this.adjacencyList.has(Q))this.adjacencyList.set(Q,new Set);if(this.adjacencyList.get(Q).add(W),!this.adjacencyList.has(W))this.adjacencyList.set(W,new Set);if(!this.reverseAdjacencyList.has(W))this.reverseAdjacencyList.set(W,new Set);this.reverseAdjacencyList.get(W).add(Q)}}patchFiles(_,$,J){let Q=new Set([..._,...$]);for(let W of Q){let z=this.adjacencyList.get(W);if(z){for(let Y of z)this.reverseAdjacencyList.get(Y)?.delete(W);z.clear()}let Z=this.reverseAdjacencyList.get(W);if(Z){for(let Y of Z)this.adjacencyList.get(Y)?.delete(W);Z.clear()}}for(let W of $)this.adjacencyList.delete(W),this.reverseAdjacencyList.delete(W);for(let W of _){let z=J(W);for(let Z of z){if(!this.adjacencyList.has(Z.srcFilePath))this.adjacencyList.set(Z.srcFilePath,new Set);if(this.adjacencyList.get(Z.srcFilePath).add(Z.dstFilePath),!this.adjacencyList.has(Z.dstFilePath))this.adjacencyList.set(Z.dstFilePath,new Set);if(!this.reverseAdjacencyList.has(Z.dstFilePath))this.reverseAdjacencyList.set(Z.dstFilePath,new Set);this.reverseAdjacencyList.get(Z.dstFilePath).add(Z.srcFilePath)}}}getDependencies(_){return Array.from(this.adjacencyList.get(_)??[])}getDependents(_){return Array.from(this.reverseAdjacencyList.get(_)??[])}getTransitiveDependents(_){let $=new Set,J=[_];while(J.length>0){let Q=J.shift();for(let W of this.reverseAdjacencyList.get(Q)??[])if(!$.has(W))$.add(W),J.push(W)}return Array.from($)}hasCycle(){let _=new Set,$=new Set;for(let J of this.adjacencyList.keys()){if(_.has(J))continue;let Q=[{node:J,entered:!1}];while(Q.length>0){let W=Q.pop();if(W.entered){$.delete(W.node);continue}if($.has(W.node))return!0;if(_.has(W.node))continue;_.add(W.node),$.add(W.node),Q.push({node:W.node,entered:!0});for(let z of this.adjacencyList.get(W.node)??[]){if($.has(z))return!0;if(!_.has(z))Q.push({node:z,entered:!1})}}}return!1}getAffectedByChange(_){let $=new Set;for(let J of _)for(let Q of this.getTransitiveDependents(J))$.add(Q);return Array.from($)}getAdjacencyList(){let _=new Map;for(let[$,J]of this.adjacencyList)_.set($,Array.from(J));return _}getTransitiveDependencies(_){let $=new Set,J=[_];while(J.length>0){let Q=J.shift();for(let W of this.adjacencyList.get(Q)??[])if(!$.has(W))$.add(W),J.push(W)}return Array.from($)}getCyclePaths(_){let $=_?.maxCycles??1/0;if($<=0)return[];let J=new Map;for(let[Q,W]of this.adjacencyList)J.set(Q,Array.from(W));return HQ(J,$)}}var XQ=(_,$)=>_.localeCompare($);function UQ(_){let $=_.length>1&&_[0]===_[_.length-1]?_.slice(0,-1):[..._];if($.length===0)return[];let J=$;for(let Q=1;Q<$.length;Q++){let W=$.slice(Q).concat($.slice(0,Q));if(W.join("::")<J.join("::"))J=W}return[...J]}function P0(_,$,J){let Q=UQ(J);if(Q.length===0)return!1;let W=Q.join("->");if(_.has(W))return!1;return _.add(W),$.push(Q),!0}function VQ(_){let $=0,J=[],Q=new Set,W=new Map,z=new Map,Z=[],Y=(X)=>{W.set(X,$),z.set(X,$),$+=1,J.push(X),Q.add(X);for(let K of _.get(X)??[])if(!W.has(K))Y(K),z.set(X,Math.min(z.get(X)??0,z.get(K)??0));else if(Q.has(K))z.set(X,Math.min(z.get(X)??0,W.get(K)??0));if(z.get(X)===W.get(X)){let K=[],V="";do V=J.pop()??"",Q.delete(V),K.push(V);while(V!==X&&J.length>0);Z.push(K)}};for(let X of _.keys())if(!W.has(X))Y(X);return{components:Z}}function OQ(_,$,J){let Q=[],W=new Set,z=[..._].sort(XQ),Z=(Y,X,K)=>{X.delete(Y);let V=K.get(Y);if(!V)return;for(let B of V)if(X.has(B))Z(B,X,K);V.clear()};for(let Y=0;Y<z.length&&Q.length<J;Y++){let X=z[Y]??"",K=new Set(z.slice(Y)),V=new Set,B=new Map,C=[],N=(S)=>($.get(S)??[]).filter((F)=>K.has(F)),w=(S)=>{if(Q.length>=J)return!0;let F=!1;C.push(S),V.add(S);for(let G of N(S)){if(Q.length>=J)break;if(G===X)P0(W,Q,C.concat(X)),F=!0;else if(!V.has(G)){if(w(G))F=!0}}if(F)Z(S,V,B);else for(let G of N(S)){let u=B.get(G)??new Set;u.add(S),B.set(G,u)}return C.pop(),F};w(X)}return Q}function HQ(_,$){let{components:J}=VQ(_),Q=[],W=new Set;for(let z of J){if(Q.length>=$)break;if(z.length===0)continue;if(z.length===1){let X=z[0]??"";if((_.get(X)??[]).includes(X))P0(W,Q,[X,X]);continue}let Z=$-Q.length,Y=OQ(z,_,Z);for(let X of Y){if(Q.length>=$)break;P0(W,Q,X)}}return Q}var MQ=15000;function z0(_){_.graphCache=null,_.graphCacheKey=null,_.graphCacheBuiltAt=null}function T_(_,$){let J=$??"__cross__";if(_.graphCache&&_.graphCacheBuiltAt!==null){if(Date.now()-_.graphCacheBuiltAt>MQ)_.graphCache=null,_.graphCacheKey=null,_.graphCacheBuiltAt=null}if(_.graphCache&&_.graphCacheKey===J)return _.graphCache;let Q=new W0({relationRepo:_.relationRepo,project:$??_.defaultProject,additionalProjects:$?void 0:_.boundaries?.map((W)=>W.project)});return Q.build(),_.graphCache=Q,_.graphCacheKey=J,_.graphCacheBuiltAt=Date.now(),Q}function C1(_,$,J,Q=1e4){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:J??_.defaultProject,query:{srcFilePath:$,type:"imports",project:J??_.defaultProject,limit:Q}}).filter((W)=>W.dstFilePath!==null).map((W)=>W.dstFilePath)}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getDependencies failed",{cause:W})}}function A1(_,$,J,Q=1e4){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:J??_.defaultProject,query:{dstFilePath:$,type:"imports",project:J??_.defaultProject,limit:Q}}).map((W)=>W.srcFilePath)}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getDependents failed",{cause:W})}}async function q1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return T_(_,J).getAffectedByChange($)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getAffected failed",{cause:Q})}}async function N1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return T_(_,$).hasCycle()}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: hasCycle failed",{cause:J})}}async function R1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return T_(_,$).getAdjacencyList()}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: getImportGraph failed",{cause:J})}}async function S1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return T_(_,J).getTransitiveDependencies($)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getTransitiveDependencies failed",{cause:Q})}}async function T1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return T_(_,J).getTransitiveDependents($)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getTransitiveDependents failed",{cause:Q})}}async function G1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return T_(_,$).getCyclePaths(J)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getCyclePaths failed",{cause:Q})}}async function F1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let Q=T_(_,J);return{filePath:$,fanIn:Q.getDependents($).length,fanOut:Q.getDependencies($).length}}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getFanMetrics failed",{cause:Q})}}var LQ=30000,j1=15000,wQ=10;function IQ(_,$){_.boundaries=$,_.defaultProject=$[0]?.project??v_.basename(_.projectRoot)}function DQ(_,$){return(J)=>{for(let Q of _.onFileChangedCallbacks)try{Q(J)}catch(W){_.logger.error("[Gildash] onFileChanged callback threw:",W)}if($.handleWatcherEvent?.(J),_.semanticLayer)if(J.eventType==="delete")try{_.semanticLayer.notifyFileDeleted(J.filePath)}catch(Q){_.logger.error("[Gildash] semanticLayer.notifyFileDeleted threw:",Q);for(let W of _.onErrorCallbacks)try{W(Q instanceof O?Q:new O("semantic","semantic notifyFileDeleted failed",{cause:Q}))}catch{}}else _.readFileFn(J.filePath).then((Q)=>{try{_.semanticLayer?.notifyFileChanged(J.filePath,Q)}catch(W){_.logger.error("[Gildash] semanticLayer.notifyFileChanged threw:",W);for(let z of _.onErrorCallbacks)try{z(W instanceof O?W:new O("semantic","semantic notifyFileChanged failed",{cause:W}))}catch{}}}).catch((Q)=>{_.logger.error("[Gildash] failed to read file for semantic layer",J.filePath,Q);try{_.semanticLayer?.notifyFileDeleted(J.filePath)}catch(W){_.logger.error("[Gildash] semanticLayer.notifyFileDeleted threw during read error recovery:",W)}})}}async function CQ(_){if(!_.semanticLayer)return;let $=_.fileRepo.getAllFiles(_.defaultProject);await Promise.all($.map(async(J)=>{try{let Q=v_.resolve(_.projectRoot,J.filePath),W=await _.readFileFn(Q);_.semanticLayer?.notifyFileChanged(Q,W)}catch{}}))}async function g1(_,$){let J=_.coordinatorFactory?_.coordinatorFactory():new N0({projectRoot:_.projectRoot,boundaries:_.boundaries,extensions:_.extensions,ignorePatterns:_.ignorePatterns,dbConnection:_.db,parseCache:_.parseCache,fileRepo:_.fileRepo,symbolRepo:_.symbolRepo,relationRepo:_.relationRepo,annotationRepo:_.annotationRepo??void 0,changelogRepo:_.changelogRepo??void 0,onBoundariesChanged:(Q)=>IQ(_,Q),logger:_.logger});_.coordinator=J;for(let Q of _.onIndexedCallbacks)J.onIndexed(Q);if(J.onIndexed((Q)=>{let W=Q.changedFiles.length+Q.deletedFiles.length;if(_.graphCache&&W>0&&W<100){let z=_.relationRepo;_.graphCache.patchFiles(Q.changedFiles,Q.deletedFiles,(Z)=>{return[_.defaultProject,..._.boundaries.map((X)=>X.project)].flatMap((X)=>z.getByType(X,"imports").concat(z.getByType(X,"type-references")).concat(z.getByType(X,"re-exports"))).filter((X)=>X.dstFilePath!==null&&(X.srcFilePath===Z||X.dstFilePath===Z)).map((X)=>({srcFilePath:X.srcFilePath,dstFilePath:X.dstFilePath}))}),_.graphCacheBuiltAt=Date.now()}else z0(_)}),$.isWatchMode){let Q=_.watcherFactory?_.watcherFactory():new B0({projectRoot:_.projectRoot,ignorePatterns:_.ignorePatterns,extensions:_.extensions},void 0,_.logger);await Q.start(DQ(_,J)).then((W)=>{if(p_(W))throw W.data}),_.watcher=Q,_.timer=setInterval(()=>{if(_.closed)return;_.updateHeartbeatFn(_.db,process.pid)},LQ)}await J.fullIndex(),await CQ(_)}function AQ(_,$){let J=["SIGTERM","SIGINT","beforeExit"];for(let Q of J){let W=()=>{$().catch((z)=>_.logger.error("[Gildash] close error during signal",Q,z))};if(Q==="beforeExit")process.on("beforeExit",W);else process.on(Q,W);_.signalHandlers.push([Q,W])}}async function k1(_){let{projectRoot:$,extensions:J=[".ts",".mts",".cts"],ignorePatterns:Q=["**/node_modules/**"],parseCacheCapacity:W=500,logger:z=console,existsSyncFn:Z=BQ,dbConnectionFactory:Y,watcherFactory:X,coordinatorFactory:K,repositoryFactory:V,acquireWatcherRoleFn:B=X1,releaseWatcherRoleFn:C=U1,updateHeartbeatFn:N=V1,discoverProjectsFn:w=a_,parseSourceFn:S=g_,extractSymbolsFn:F=q_,extractRelationsFn:G=m_,symbolSearchFn:u=S0,relationSearchFn:E=T0,patternSearchFn:y=G0,loadTsconfigPathsFn:d=x_,readFileFn:p=async(c)=>Bun.file(c).text(),unlinkFn:Q_=async(c)=>{await Bun.file(c).unlink()},watchMode:Y_,semantic:O_,semanticLayerFactory:Z_}=_;if(!v_.isAbsolute($))throw new O("validation",`Gildash: projectRoot must be an absolute path, got: "${$}"`);if(!Z($))throw new O("validation",`Gildash: projectRoot does not exist: "${$}"`);let W_=Y?Y():new V0({projectRoot:$}),i=W_.open();if(p_(i))throw i.data;try{let c=await w($),w_=c[0]?.project??v_.basename($),D=V?V():(()=>{let T=W_;return{fileRepo:new O0(T),symbolRepo:new H0(T),relationRepo:new M0(T),parseCache:new R0(W)}})(),q=V?null:W_,U=q?new v0(q):null,H=q?new b0(q):null,M=Y_??!0,L=crypto.randomUUID(),A;if(M)A=await Promise.resolve(B(W_,process.pid,{instanceId:L}));else A="owner";let I={projectRoot:$,extensions:J,ignorePatterns:Q,logger:z,defaultProject:w_,role:A,db:W_,symbolRepo:D.symbolRepo,relationRepo:D.relationRepo,fileRepo:D.fileRepo,parseCache:D.parseCache,annotationRepo:U,changelogRepo:H,annotationSearchFn:D1,releaseWatcherRoleFn:C,parseSourceFn:S,extractSymbolsFn:F,extractRelationsFn:G,symbolSearchFn:u,relationSearchFn:E,patternSearchFn:y,readFileFn:p,unlinkFn:Q_,existsSyncFn:Z,acquireWatcherRoleFn:B,updateHeartbeatFn:N,watcherFactory:X,coordinatorFactory:K,instanceId:L,closed:!1,coordinator:null,watcher:null,timer:null,signalHandlers:[],tsconfigPaths:null,boundaries:c,onIndexedCallbacks:new Set,onFileChangedCallbacks:new Set,onErrorCallbacks:new Set,onRoleChangedCallbacks:new Set,graphCache:null,graphCacheKey:null,graphCacheBuiltAt:null,semanticLayer:null};if(s_($),I.tsconfigPaths=await d($),O_){let T=v_.join($,"tsconfig.json");try{if(Z_)I.semanticLayer=Z_(T);else{let R=Q0.create(T);if(p_(R))throw R.data;I.semanticLayer=R}}catch(R){if(R instanceof O)throw R;throw new O("semantic","Gildash: semantic layer creation failed",{cause:R})}}if(A==="owner")await g1(I,{isWatchMode:M});else{let T=0,R=async()=>{try{let j=await Promise.resolve(I.acquireWatcherRoleFn(I.db,process.pid,{instanceId:I.instanceId}));if(T=0,j==="owner"){I.role="owner";for(let g of I.onRoleChangedCallbacks)try{g("owner")}catch(v){I.logger.error("[Gildash] onRoleChanged callback threw:",v)}clearInterval(I.timer),I.timer=null;try{await g1(I,{isWatchMode:!0})}catch(g){if(I.logger.error("[Gildash] owner promotion failed, reverting to reader",g),I.role="reader",I.timer!==null)clearInterval(I.timer),I.timer=null;if(I.watcher){let v=await I.watcher.close();if(p_(v))I.logger.error("[Gildash] watcher close error during promotion rollback",v.data);I.watcher=null}if(I.coordinator)await I.coordinator.shutdown().catch((v)=>I.logger.error("[Gildash] coordinator shutdown error during promotion rollback",v)),I.coordinator=null;try{I.releaseWatcherRoleFn(I.db,process.pid)}catch(v){I.logger.error("[Gildash] failed to release watcher role during promotion rollback",v)}I.timer=setInterval(R,j1)}}}catch(j){T++;let g=j instanceof O?j:new O("watcher","Gildash: healthcheck error",{cause:j});for(let v of I.onErrorCallbacks)try{v(g)}catch(n){I.logger.error("[Gildash] onError callback threw:",n)}if(I.logger.error("[Gildash] healthcheck error",j),T>=wQ)I.logger.error("[Gildash] healthcheck failed too many times, shutting down"),clearInterval(I.timer),I.timer=null,Y0(I).catch((v)=>I.logger.error("[Gildash] close error during healthcheck shutdown",v))}};I.timer=setInterval(R,j1)}if(M)AQ(I,()=>Y0(I));return I}catch(c){if(W_.close(),c instanceof O)throw c;throw new O("store","Gildash: initialization failed",{cause:c})}}async function Y0(_,$){if(_.closed)return;_.closed=!0;let J=[];for(let[Q,W]of _.signalHandlers)if(Q==="beforeExit")process.off("beforeExit",W);else process.off(Q,W);if(_.signalHandlers=[],_.semanticLayer){try{_.semanticLayer.dispose()}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}_.semanticLayer=null}if(_.coordinator)try{await _.coordinator.shutdown()}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}if(_.watcher){let Q=await _.watcher.close();if(p_(Q))J.push(Q.data)}if(_.timer!==null)clearInterval(_.timer),_.timer=null;try{_.releaseWatcherRoleFn(_.db,process.pid)}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}try{_.db.close()}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}if($?.cleanup)for(let Q of["","-wal","-shm"])try{await _.unlinkFn(v_.join(_.projectRoot,D_,l_+Q))}catch{}if(J.length>0)throw new O("close","Gildash: one or more errors occurred during close()",{cause:J})}import{isErr as E1}from"@zipbul/result";function u1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");let W=_.parseSourceFn($,J,Q);if(E1(W))throw W.data;return _.parseCache.set($,W),W}async function v1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");let Q=new Map,W=[];return await Promise.all($.map(async(z)=>{try{let Z=await _.readFileFn(z),Y=_.parseSourceFn(z,Z,J);if(!E1(Y))Q.set(z,Y);else W.push({filePath:z,error:Y.data})}catch(Z){W.push({filePath:z,error:Z instanceof Error?Z:Error(String(Z))})}})),{parsed:Q,failures:W}}function b1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");return _.parseCache.get($)}function P1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");return _.extractSymbolsFn($)}function f1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");return _.extractRelationsFn($.program,$.filePath,_.tsconfigPaths??void 0)}import y1 from"path";function x1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.symbolRepo.getStats($??_.defaultProject)}catch(J){if(J instanceof O)throw J;throw new O("store","Gildash: getStats failed",{cause:J})}}function f0(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.symbolSearchFn({symbolRepo:_.symbolRepo,project:_.defaultProject,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchSymbols failed",{cause:J})}}function h1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:_.defaultProject,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchRelations failed",{cause:J})}}function m1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.symbolSearchFn({symbolRepo:_.symbolRepo,project:void 0,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchAllSymbols failed",{cause:J})}}function n1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:void 0,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchAllRelations failed",{cause:J})}}function d1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.fileRepo.getAllFiles($??_.defaultProject)}catch(J){if(J instanceof O)throw J;throw new O("store","Gildash: listIndexedFiles failed",{cause:J})}}function p1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:J??_.defaultProject,query:{srcFilePath:$,dstFilePath:$,limit:1e4}})}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getInternalRelations failed",{cause:Q})}}function i1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let W=Q??_.defaultProject,z=_.symbolSearchFn({symbolRepo:_.symbolRepo,project:W,query:{text:$,exact:!0,filePath:J,limit:1}});if(z.length===0)return null;let Z=z[0],Y=Z.detail,X={...Z,members:Y.members,jsDoc:Y.jsDoc,parameters:Y.parameters,returnType:Y.returnType,heritage:Y.heritage,decorators:Y.decorators,typeParameters:Y.typeParameters,initializer:Y.initializer};if(_.semanticLayer)try{let K=y1.isAbsolute(J)?J:y1.resolve(_.projectRoot,J),V=_.semanticLayer.lineColumnToPosition(K,Z.span.start.line,Z.span.start.column);if(V!==null){let B=_.semanticLayer.findNamePosition(K,V,Z.name)??V,C=_.semanticLayer.collectTypeAt(K,B);if(C)X.resolvedType=C}}catch{}return X}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getFullSymbol failed",{cause:W})}}function l1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let Q=J??_.defaultProject,W=_.fileRepo.getFile(Q,$);if(!W)throw new O("search",`Gildash: file '${$}' is not in the index`);let z=_.symbolRepo.getFileSymbols(Q,$),Z=_.relationRepo.getOutgoing(Q,$);return{filePath:W.filePath,lineCount:W.lineCount??0,size:W.size,symbolCount:z.length,exportedSymbolCount:z.filter((Y)=>Y.isExported).length,relationCount:Z.length}}catch(Q){if(Q instanceof O)throw Q;throw new O("store","Gildash: getFileStats failed",{cause:Q})}}function c1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.fileRepo.getFile(J??_.defaultProject,$)}catch(Q){if(Q instanceof O)throw Q;throw new O("store","Gildash: getFileInfo failed",{cause:Q})}}function a1(_,$,J){return f0(_,{filePath:$,project:J??void 0,limit:1e4})}function s1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let W=_.symbolSearchFn({symbolRepo:_.symbolRepo,project:J??_.defaultProject,query:{filePath:$,isExported:!0}}).map((z)=>({name:z.name,kind:z.kind,parameters:z.detail.parameters?`(${z.detail.parameters.map((Z)=>`${Z.name}${Z.isOptional?"?":""}: ${Z.type??"unknown"}`).join(", ")})`:void 0,returnType:z.detail.returnType??void 0,jsDoc:z.detail.jsDoc?.description??void 0}));return{filePath:$,exports:W}}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getModuleInterface failed",{cause:Q})}}import P from"path";function i_(_,$,J,Q){let W=Q??_.defaultProject,z=P.isAbsolute(J)?P.relative(_.projectRoot,J):J,Z=_.symbolSearchFn({symbolRepo:_.symbolRepo,project:W,query:{text:$,exact:!0,filePath:z,limit:1}});if(Z.length===0)return null;let Y=Z[0],X=P.isAbsolute(J)?J:P.resolve(_.projectRoot,J),K=_.semanticLayer.lineColumnToPosition(X,Y.span.start.line,Y.span.start.column);if(K===null)return null;let V=_.semanticLayer.findNamePosition(X,K,Y.name)??K;return{sym:Y,position:V,absPath:X}}function r1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=i_(_,$,J,Q);if(!W)return null;return _.semanticLayer.collectTypeAt(W.absPath,W.position)}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getResolvedType failed",{cause:W})}}function o1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=i_(_,$,J,Q);if(!W)throw new O("search",`Gildash: symbol '${$}' not found in '${J}'`);return _.semanticLayer.findReferences(W.absPath,W.position)}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getSemanticReferences failed",{cause:W})}}function t1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=i_(_,$,J,Q);if(!W)throw new O("search",`Gildash: symbol '${$}' not found in '${J}'`);return _.semanticLayer.findImplementations(W.absPath,W.position)}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getImplementations failed",{cause:W})}}function e1(_,$,J,Q,W,z){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Z=i_(_,$,J,z);if(!Z)throw new O("search",`Gildash: source symbol '${$}' not found in '${J}'`);let Y=i_(_,Q,W,z);if(!Y)throw new O("search",`Gildash: target symbol '${Q}' not found in '${W}'`);return _.semanticLayer.isTypeAssignableTo(Z.absPath,Z.position,Y.absPath,Y.position)}catch(Z){if(Z instanceof O)throw Z;throw new O("semantic","Gildash: isTypeAssignableTo failed",{cause:Z})}}function _$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let J=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.collectFileTypes(J)}catch(J){if(J instanceof O)throw J;throw new O("semantic","Gildash: getFileTypes failed",{cause:J})}}function $$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=P.isAbsolute($)?$:P.resolve(_.projectRoot,$),z=_.semanticLayer.lineColumnToPosition(W,J,Q);if(z===null)return null;return _.semanticLayer.collectTypeAt(W,z)}catch(W){if(W instanceof O)throw W;throw new O("semantic","Gildash: getResolvedTypeAt failed",{cause:W})}}function J$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let J=P.isAbsolute($.source.filePath)?$.source.filePath:P.resolve(_.projectRoot,$.source.filePath),Q=P.isAbsolute($.target.filePath)?$.target.filePath:P.resolve(_.projectRoot,$.target.filePath),W=_.semanticLayer.lineColumnToPosition(J,$.source.line,$.source.column);if(W===null)return null;let z=_.semanticLayer.lineColumnToPosition(Q,$.target.line,$.target.column);if(z===null)return null;return _.semanticLayer.isTypeAssignableTo(J,W,Q,z)}catch(J){if(J instanceof O)throw J;throw new O("semantic","Gildash: isTypeAssignableToAt failed",{cause:J})}}function Q$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{return _.semanticLayer.getModuleInterface($)}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: getSemanticModuleInterface failed",{cause:J})}}function W$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.getBaseTypes(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getBaseTypes failed",{cause:Q})}}function z$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.collectTypesAtPositions(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getResolvedTypesAtPositions failed",{cause:Q})}}function Y$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.collectTypeAt(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getResolvedTypeAtPosition failed",{cause:Q})}}function Z$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.findReferences(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getSemanticReferencesAtPosition failed",{cause:Q})}}function X$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.findImplementations(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getImplementationsAtPosition failed",{cause:Q})}}function U$(_,$,J,Q,W){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=P.isAbsolute($)?$:P.resolve(_.projectRoot,$),Z=P.isAbsolute(Q)?Q:P.resolve(_.projectRoot,Q);return _.semanticLayer.isTypeAssignableTo(z,J,Z,W)}catch(z){if(z instanceof O)throw z;throw new O("semantic","Gildash: isTypeAssignableToAtPosition failed",{cause:z})}}function V$(_,$,J,Q,W){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.isTypeAssignableToType(z,J,Q,W)}catch(z){if(z instanceof O)throw z;throw new O("semantic","Gildash: isTypeAssignableToType failed",{cause:z})}}function O$(_,$,J,Q,W){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.isTypeAssignableToTypeAtPositions(z,J,Q,W)}catch(z){if(z instanceof O)throw z;throw new O("semantic","Gildash: isTypeAssignableToTypeAtPositions failed",{cause:z})}}function H$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.lineColumnToPosition(W,J,Q)}catch(W){if(W instanceof O)throw W;throw new O("semantic","Gildash: lineColumnToPosition failed",{cause:W})}}function M$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.findNamePosition(W,J,Q)}catch(W){if(W instanceof O)throw W;throw new O("semantic","Gildash: findNamePosition failed",{cause:W})}}function K$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.getSymbolNode(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getSymbolNode failed",{cause:Q})}}function B$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=P.isAbsolute($)?$:P.resolve(_.projectRoot,$);return _.semanticLayer.getDiagnostics(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getSemanticDiagnostics failed",{cause:Q})}}function L$(_,$){let J=new Map(_.map((Y)=>[`${Y.name}::${Y.filePath}`,Y])),Q=new Map($.map((Y)=>[`${Y.name}::${Y.filePath}`,Y])),W=[],z=[],Z=[];for(let[Y,X]of Q){let K=J.get(Y);if(!K)W.push(X);else if(K.fingerprint!==X.fingerprint)Z.push({before:K,after:X})}for(let[Y,X]of J)if(!Q.has(Y))z.push(X);return{added:W,removed:z,modified:Z}}function w$(_,$){if(_.onIndexedCallbacks.add($),!_.coordinator)return()=>{_.onIndexedCallbacks.delete($)};let J=_.coordinator.onIndexed($);return()=>{_.onIndexedCallbacks.delete($),J()}}async function I$(_){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.coordinator)throw new O("closed","Gildash: reindex() is not available for readers");try{let $=await _.coordinator.fullIndex();return z0(_),$}catch($){if($ instanceof O)throw $;throw new O("index","Gildash: reindex failed",{cause:$})}}function D$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");let W=Q??_.defaultProject,z=new Set,Z=[],Y=$,X=J;for(;;){let K=`${X}::${Y}`;if(z.has(K))return{originalName:Y,originalFilePath:X,reExportChain:Z,circular:!0};z.add(K);let V=_.relationSearchFn({relationRepo:_.relationRepo,project:W,query:{type:"re-exports",srcFilePath:X,limit:500}}),B,C;for(let N of V){let w;if(N.metaJson)try{let F=JSON.parse(N.metaJson);if(Array.isArray(F.specifiers))w=F.specifiers}catch{}if(!w)continue;let S=w.find((F)=>F.exported===Y);if(!S)continue;B=N.dstFilePath??void 0,C=S.local;break}if(!B||!C)return{originalName:Y,originalFilePath:X,reExportChain:Z,circular:!1};Z.push({filePath:X,exportedAs:Y}),X=B,Y=C}}function C$(_,$){return _.onFileChangedCallbacks.add($),()=>{_.onFileChangedCallbacks.delete($)}}function A$(_,$){return _.onErrorCallbacks.add($),()=>{_.onErrorCallbacks.delete($)}}function q$(_,$){return _.onRoleChangedCallbacks.add($),()=>{_.onRoleChangedCallbacks.delete($)}}async function N$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let Q=J?.project??_.defaultProject,W=J?.filePaths?J.filePaths:_.fileRepo.getAllFiles(Q).map((z)=>z.filePath);return await _.patternSearchFn({pattern:$,filePaths:W})}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: findPattern failed",{cause:Q})}}async function R$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let W=Q??_.defaultProject,z=new Set,Z=(Y,X,K)=>{let V=`${Y}::${X}`;if(z.has(V))return{symbolName:Y,filePath:X,kind:K,children:[]};z.add(V);let N=_.relationSearchFn({relationRepo:_.relationRepo,project:W,query:{srcFilePath:X,srcSymbolName:Y,limit:1000}}).filter((w)=>w.type==="extends"||w.type==="implements").filter((w)=>w.dstSymbolName!=null&&w.dstFilePath!=null).map((w)=>Z(w.dstSymbolName,w.dstFilePath,w.type));return{symbolName:Y,filePath:X,kind:K,children:N}};return Z($,J)}catch(W){if(W instanceof O)throw W;throw new O("search","Gildash: getHeritageChain failed",{cause:W})}}function S$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.annotationRepo||!_.annotationSearchFn)return[];return _.annotationSearchFn({annotationRepo:_.annotationRepo,project:$.project??_.defaultProject,query:$})}function T$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.changelogRepo)return[];let Q=$ instanceof Date?$.toISOString():$,W=J?.project??_.defaultProject,z=J?.limit??1000;return _.changelogRepo.getSince({project:W,since:Q,symbolName:J?.symbolName,changeTypes:J?.changeTypes,filePath:J?.filePath,includeFullIndex:J?.includeFullIndex,indexRunId:J?.indexRunId,afterId:J?.afterId,limit:z}).map((Y)=>({changeType:Y.changeType,symbolName:Y.symbolName,symbolKind:Y.symbolKind,filePath:Y.filePath,oldName:Y.oldName,oldFilePath:Y.oldFilePath,fingerprint:Y.fingerprint,changedAt:Y.changedAt,isFullIndex:Y.isFullIndex===1,indexRunId:Y.indexRunId}))}function G$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.changelogRepo)return 0;let J=$ instanceof Date?$.toISOString():$,Q=0,W=[_.defaultProject,..._.boundaries.map((Z)=>Z.project)],z=[...new Set(W)];for(let Z of z)Q+=_.changelogRepo.pruneOlderThan(Z,J);return Q}class y0{_ctx;get projectRoot(){return this._ctx.projectRoot}get role(){return this._ctx.role}get projects(){return[...this._ctx.boundaries]}constructor(_){this._ctx=_}static async open(_){let $=await k1(_);return new y0($)}async close(_){return Y0(this._ctx,_)}parseSource(_,$,J){return u1(this._ctx,_,$,J)}async batchParse(_,$){return v1(this._ctx,_,$)}getParsedAst(_){return b1(this._ctx,_)}extractSymbols(_){return P1(this._ctx,_)}extractRelations(_){return f1(this._ctx,_)}getStats(_){return x1(this._ctx,_)}searchSymbols(_){return f0(this._ctx,_)}searchRelations(_){return h1(this._ctx,_)}searchAllSymbols(_){return m1(this._ctx,_)}searchAllRelations(_){return n1(this._ctx,_)}listIndexedFiles(_){return d1(this._ctx,_)}getInternalRelations(_,$){return p1(this._ctx,_,$)}getFullSymbol(_,$,J){return i1(this._ctx,_,$,J)}getFileStats(_,$){return l1(this._ctx,_,$)}getFileInfo(_,$){return c1(this._ctx,_,$)}getSymbolsByFile(_,$){return a1(this._ctx,_,$)}getModuleInterface(_,$){return s1(this._ctx,_,$)}getDependencies(_,$,J=1e4){return C1(this._ctx,_,$,J)}getDependents(_,$,J=1e4){return A1(this._ctx,_,$,J)}async getAffected(_,$){return q1(this._ctx,_,$)}async hasCycle(_){return N1(this._ctx,_)}async getImportGraph(_){return R1(this._ctx,_)}async getTransitiveDependencies(_,$){return S1(this._ctx,_,$)}async getTransitiveDependents(_,$){return T1(this._ctx,_,$)}async getCyclePaths(_,$){return G1(this._ctx,_,$)}async getFanMetrics(_,$){return F1(this._ctx,_,$)}getResolvedType(_,$,J){return r1(this._ctx,_,$,J)}getSemanticReferences(_,$,J){return o1(this._ctx,_,$,J)}getImplementations(_,$,J){return t1(this._ctx,_,$,J)}isTypeAssignableTo(_,$,J,Q,W){return e1(this._ctx,_,$,J,Q,W)}getSemanticModuleInterface(_){return Q$(this._ctx,_)}getFileTypes(_){return _$(this._ctx,_)}getResolvedTypeAt(_,$,J){return $$(this._ctx,_,$,J)}isTypeAssignableToAt(_){return J$(this._ctx,_)}getResolvedTypeAtPosition(_,$){return Y$(this._ctx,_,$)}getResolvedTypesAtPositions(_,$){return z$(this._ctx,_,$)}getSemanticReferencesAtPosition(_,$){return Z$(this._ctx,_,$)}getImplementationsAtPosition(_,$){return X$(this._ctx,_,$)}isTypeAssignableToAtPosition(_,$,J,Q){return U$(this._ctx,_,$,J,Q)}isTypeAssignableToType(_,$,J,Q){return V$(this._ctx,_,$,J,Q)}isTypeAssignableToTypeAtPositions(_,$,J,Q){return O$(this._ctx,_,$,J,Q)}lineColumnToPosition(_,$,J){return H$(this._ctx,_,$,J)}findNamePosition(_,$,J){return M$(this._ctx,_,$,J)}getSymbolNode(_,$){return K$(this._ctx,_,$)}getBaseTypes(_,$){return W$(this._ctx,_,$)}getSemanticDiagnostics(_,$){return B$(this._ctx,_,$)}diffSymbols(_,$){return L$(_,$)}onIndexed(_){return w$(this._ctx,_)}async reindex(){return I$(this._ctx)}resolveSymbol(_,$,J){return D$(this._ctx,_,$,J)}async findPattern(_,$){return N$(this._ctx,_,$)}async getHeritageChain(_,$,J){return R$(this._ctx,_,$,J)}onFileChanged(_){return C$(this._ctx,_)}onError(_){return A$(this._ctx,_)}onRoleChanged(_){return q$(this._ctx,_)}searchAnnotations(_){return S$(this._ctx,_)}getSymbolChanges(_,$){return T$(this._ctx,_,$)}pruneChangelog(_){return G$(this._ctx,_)}}import{Visitor as N5,visitorKeys as R5}from"oxc-parser";import{walk as T5,parseAndWalk as G5,ScopeTracker as F5}from"oxc-walker";export{T5 as walk,R5 as visitorKeys,S0 as symbolSearch,T0 as relationSearch,G0 as patternSearch,g_ as parseSource,G5 as parseAndWalk,J_ as normalizePath,gJ as isVariableDeclaration,jJ as isTSQualifiedName,FJ as isMemberExpression,GJ as isIdentifier,AJ as isFunctionNode,TJ as isFunctionExpression,SJ as isFunctionDeclaration,RJ as isCallExpression,NJ as isAssignmentExpression,qJ as isArrowFunctionExpression,kJ as is,U_ as getLineColumn,q_ as extractSymbols,m_ as extractRelations,h_ as buildLineOffsets,N5 as Visitor,F5 as ScopeTracker,O as GildashError,y0 as Gildash,W0 as DependencyGraph};
|
|
2
|
+
var x$=Object.defineProperty;var h$=(_)=>_;function m$(_,$){this[_]=h$.bind(null,$)}var n$=(_,$)=>{for(var J in $)x$(_,J,{get:$[J],enumerable:!0,configurable:!0,set:m$.bind($,J)})};var d0=import.meta.require;import{isErr as c_}from"@zipbul/result";import P_ from"path";import{existsSync as jQ}from"fs";import{err as l0,isErr as a$}from"@zipbul/result";import{Database as s$}from"bun:sqlite";import{mkdirSync as r$,unlinkSync as i0,existsSync as c0}from"fs";import{dirname as o$,join as a0}from"path";import{drizzle as t$}from"drizzle-orm/bun-sqlite";import{migrate as e$}from"drizzle-orm/bun-sqlite/migrator";class O extends Error{type;constructor(_,$,J){super($,J);this.type=_;this.name="GildashError"}}var A_=".gildash",a_="gildash.db";var O0={};n$(O0,{watcherOwner:()=>c$,symbols:()=>x,symbolChangelog:()=>$_,relations:()=>v,files:()=>o,annotations:()=>Z_});import{sql as p$}from"drizzle-orm";import{sqliteTable as j_,text as P,integer as r,real as d$,index as Q_,primaryKey as l$,foreignKey as V0,check as i$}from"drizzle-orm/sqlite-core";var o=j_("files",{project:P("project").notNull(),filePath:P("file_path").notNull(),mtimeMs:d$("mtime_ms").notNull(),size:r("size").notNull(),contentHash:P("content_hash").notNull(),updatedAt:P("updated_at").notNull(),lineCount:r("line_count")},(_)=>[l$({columns:[_.project,_.filePath]})]),x=j_("symbols",{id:r("id").primaryKey({autoIncrement:!0}),project:P("project").notNull(),filePath:P("file_path").notNull(),kind:P("kind").notNull(),name:P("name").notNull(),startLine:r("start_line").notNull(),startColumn:r("start_column").notNull(),endLine:r("end_line").notNull(),endColumn:r("end_column").notNull(),isExported:r("is_exported").notNull().default(0),signature:P("signature"),fingerprint:P("fingerprint"),detailJson:P("detail_json"),contentHash:P("content_hash").notNull(),indexedAt:P("indexed_at").notNull(),resolvedType:P("resolved_type"),structuralFingerprint:P("structural_fingerprint")},(_)=>[Q_("idx_symbols_project_file").on(_.project,_.filePath),Q_("idx_symbols_project_kind").on(_.project,_.kind),Q_("idx_symbols_project_name").on(_.project,_.name),Q_("idx_symbols_fingerprint").on(_.project,_.fingerprint),V0({columns:[_.project,_.filePath],foreignColumns:[o.project,o.filePath]}).onDelete("cascade")]),v=j_("relations",{id:r("id").primaryKey({autoIncrement:!0}),project:P("project").notNull(),type:P("type").notNull(),srcFilePath:P("src_file_path").notNull(),srcSymbolName:P("src_symbol_name"),dstProject:P("dst_project"),dstFilePath:P("dst_file_path"),dstSymbolName:P("dst_symbol_name"),metaJson:P("meta_json"),specifier:P("specifier"),isExternal:r("is_external").notNull().default(0)},(_)=>[Q_("idx_relations_src").on(_.project,_.srcFilePath),Q_("idx_relations_dst").on(_.dstProject,_.dstFilePath),Q_("idx_relations_type").on(_.project,_.type),Q_("idx_relations_project_type_src").on(_.project,_.type,_.srcFilePath),Q_("idx_relations_specifier").on(_.project,_.specifier),V0({columns:[_.project,_.srcFilePath],foreignColumns:[o.project,o.filePath]}).onDelete("cascade")]),Z_=j_("annotations",{id:r("id").primaryKey({autoIncrement:!0}),project:P("project").notNull(),filePath:P("file_path").notNull(),tag:P("tag").notNull(),value:P("value").notNull().default(""),source:P("source").notNull(),symbolName:P("symbol_name"),startLine:r("start_line").notNull(),startColumn:r("start_column").notNull(),endLine:r("end_line").notNull(),endColumn:r("end_column").notNull(),indexedAt:P("indexed_at").notNull()},(_)=>[Q_("idx_annotations_project_file").on(_.project,_.filePath),Q_("idx_annotations_project_tag").on(_.project,_.tag),Q_("idx_annotations_project_symbol").on(_.project,_.symbolName),V0({columns:[_.project,_.filePath],foreignColumns:[o.project,o.filePath]}).onDelete("cascade")]),$_=j_("symbol_changelog",{id:r("id").primaryKey({autoIncrement:!0}),project:P("project").notNull(),changeType:P("change_type").notNull(),symbolName:P("symbol_name").notNull(),symbolKind:P("symbol_kind").notNull(),filePath:P("file_path").notNull(),oldName:P("old_name"),oldFilePath:P("old_file_path"),fingerprint:P("fingerprint"),changedAt:P("changed_at").notNull(),isFullIndex:r("is_full_index").notNull().default(0),indexRunId:P("index_run_id").notNull()},(_)=>[Q_("idx_changelog_project_changed_at").on(_.project,_.changedAt),Q_("idx_changelog_project_name").on(_.project,_.symbolName),Q_("idx_changelog_project_run").on(_.project,_.indexRunId)]),c$=j_("watcher_owner",{id:r("id").primaryKey(),pid:r("pid").notNull(),startedAt:P("started_at").notNull(),heartbeatAt:P("heartbeat_at").notNull(),instanceId:P("instance_id")},(_)=>[i$("watcher_owner_singleton",p$`${_.id} = 1`)]);class H0{client=null;drizzle=null;dbPath;txDepth=0;constructor(_){this.dbPath=a0(_.projectRoot,A_,a_)}get drizzleDb(){if(!this.drizzle)throw Error("Database is not open. Call open() first.");return this.drizzle}open(){try{r$(o$(this.dbPath),{recursive:!0}),this.client=new s$(this.dbPath),this.client.run("PRAGMA journal_mode = WAL"),this.client.run("PRAGMA foreign_keys = OFF"),this.client.run("PRAGMA busy_timeout = 5000"),this.drizzle=t$(this.client,{schema:O0}),e$(this.drizzle,{migrationsFolder:a0(import.meta.dirname,"migrations")});let _=this.client.prepare("PRAGMA foreign_key_check").all();if(_.length>0)throw Error(`FK integrity violation after migration: ${JSON.stringify(_.slice(0,5))}`);this.client.run("PRAGMA foreign_keys = ON"),this.registerRegexpUdf(this.client)}catch(_){if(this.isCorruptionError(_)&&c0(this.dbPath)){this.closeClient(),i0(this.dbPath);for(let J of["-wal","-shm"]){let Q=this.dbPath+J;if(c0(Q))i0(Q)}let $=this.open();if(a$($))return l0(new O("store",`Failed to recover database at ${this.dbPath}`,{cause:$.data}));return $}return l0(new O("store",`Failed to open database at ${this.dbPath}`,{cause:_}))}}close(){this.closeClient(),this.drizzle=null}transaction(_){let $=this.requireClient();if(this.txDepth===0){this.txDepth++;try{return $.transaction(()=>_(this))()}finally{this.txDepth--}}let J=`sp_${this.txDepth++}`;$.run(`SAVEPOINT "${J}"`);try{let Q=_(this);return $.run(`RELEASE SAVEPOINT "${J}"`),Q}catch(Q){throw $.run(`ROLLBACK TO SAVEPOINT "${J}"`),$.run(`RELEASE SAVEPOINT "${J}"`),Q}finally{this.txDepth--}}immediateTransaction(_){let $=this.requireClient();this.txDepth++,$.run("BEGIN IMMEDIATE");try{let J=_();return $.run("COMMIT"),J}catch(J){throw $.run("ROLLBACK"),J}finally{this.txDepth--}}getTableNames(){return this.requireClient().query("SELECT name FROM sqlite_master WHERE type = 'table'").all().map(($)=>$.name)}selectOwner(){return this.requireClient().prepare("SELECT pid, heartbeat_at, instance_id FROM watcher_owner WHERE id = 1").get()??void 0}insertOwner(_,$){let J=new Date().toISOString();this.requireClient().prepare("INSERT INTO watcher_owner (id, pid, started_at, heartbeat_at, instance_id) VALUES (1, ?, ?, ?, ?)").run(_,J,J,$??null)}replaceOwner(_,$){let J=new Date().toISOString();this.requireClient().prepare("INSERT OR REPLACE INTO watcher_owner (id, pid, started_at, heartbeat_at, instance_id) VALUES (1, ?, ?, ?, ?)").run(_,J,J,$??null)}touchOwner(_){let $=new Date().toISOString();this.requireClient().prepare("UPDATE watcher_owner SET heartbeat_at = ? WHERE id = 1 AND pid = ?").run($,_)}deleteOwner(_){this.requireClient().prepare("DELETE FROM watcher_owner WHERE id = 1 AND pid = ?").run(_)}registerRegexpUdf(_){let $=_;if(typeof $.function!=="function")return;$.function.call(_,"regexp",(J,Q)=>{try{return new RegExp(J).test(Q)?1:0}catch{return 0}})}requireClient(){if(!this.client)throw Error("Database is not open. Call open() first.");return this.client}closeClient(){if(this.client)this.client.close(),this.client=null}isCorruptionError(_){if(!(_ instanceof Error))return!1;let $=_.message.toLowerCase();return $.includes("malformed")||$.includes("corrupt")||$.includes("not a database")||$.includes("disk i/o error")||$.includes("sqlite_corrupt")}}import{eq as y_,and as s0}from"drizzle-orm";class M0{db;constructor(_){this.db=_}getFile(_,$){return this.db.drizzleDb.select().from(o).where(s0(y_(o.project,_),y_(o.filePath,$))).get()??null}upsertFile(_){this.db.drizzleDb.insert(o).values({project:_.project,filePath:_.filePath,mtimeMs:_.mtimeMs,size:_.size,contentHash:_.contentHash,updatedAt:_.updatedAt,lineCount:_.lineCount??null}).onConflictDoUpdate({target:[o.project,o.filePath],set:{mtimeMs:_.mtimeMs,size:_.size,contentHash:_.contentHash,updatedAt:_.updatedAt,lineCount:_.lineCount??null}}).run()}getAllFiles(_){return this.db.drizzleDb.select().from(o).where(y_(o.project,_)).all()}getFilesMap(_){let $=this.getAllFiles(_),J=new Map;for(let Q of $)J.set(Q.filePath,Q);return J}deleteFile(_,$){this.db.drizzleDb.delete(o).where(s0(y_(o.project,_),y_(o.filePath,$))).run()}}import{eq as t,and as N_,sql as s_,count as _J}from"drizzle-orm";function g_(_){return _.replaceAll("\x00","").trim().split(/\s+/).map(($)=>$.trim()).filter(($)=>$.length>0).map(($)=>`"${$.replaceAll('"','""')}"*`).join(" ")}var r0=50;class K0{db;constructor(_){this.db=_}replaceFileSymbols(_,$,J,Q){if(this.db.drizzleDb.delete(x).where(N_(t(x.project,_),t(x.filePath,$))).run(),!Q.length)return;let z=new Date().toISOString(),W=Q.map((Z)=>({project:_,filePath:$,kind:Z.kind??"unknown",name:Z.name??"",startLine:Z.startLine??0,startColumn:Z.startColumn??0,endLine:Z.endLine??0,endColumn:Z.endColumn??0,isExported:Z.isExported??0,signature:Z.signature??null,fingerprint:Z.fingerprint??null,detailJson:Z.detailJson??null,contentHash:J,indexedAt:Z.indexedAt??z,resolvedType:Z.resolvedType??null,structuralFingerprint:Z.structuralFingerprint??null}));for(let Z=0;Z<W.length;Z+=r0)this.db.drizzleDb.insert(x).values(W.slice(Z,Z+r0)).run()}getFileSymbols(_,$){return this.db.drizzleDb.select().from(x).where(N_(t(x.project,_),t(x.filePath,$))).all()}searchByName(_,$,J={}){let Q=J.limit??50,z=g_($);if(!z)return[];return this.db.drizzleDb.select().from(x).where(N_(s_`${x.id} IN (SELECT rowid FROM symbols_fts WHERE symbols_fts MATCH ${z})`,t(x.project,_),J.kind?t(x.kind,J.kind):void 0)).orderBy(x.name).limit(Q).all()}searchByKind(_,$){return this.db.drizzleDb.select().from(x).where(N_(t(x.project,_),t(x.kind,$))).orderBy(x.name).all()}getStats(_){let $=this.db.drizzleDb.select({symbolCount:_J(),fileCount:s_`COUNT(DISTINCT ${x.filePath})`}).from(x).where(t(x.project,_)).get();return{symbolCount:$?.symbolCount??0,fileCount:$?.fileCount??0}}getByFingerprint(_,$){return this.db.drizzleDb.select().from(x).where(N_(t(x.project,_),t(x.fingerprint,$))).all()}deleteFileSymbols(_,$){this.db.drizzleDb.delete(x).where(N_(t(x.project,_),t(x.filePath,$))).run()}searchByQuery(_){let $=this.db.drizzleDb.select().from(x).where(N_(_.ftsQuery?s_`${x.id} IN (SELECT rowid FROM symbols_fts WHERE symbols_fts MATCH ${_.ftsQuery})`:void 0,_.exactName?t(x.name,_.exactName):void 0,_.project!==void 0?t(x.project,_.project):void 0,_.kind?t(x.kind,_.kind):void 0,_.filePath!==void 0?t(x.filePath,_.filePath):void 0,_.isExported!==void 0?t(x.isExported,_.isExported?1:0):void 0,_.decorator?s_`${x.id} IN (SELECT s.id FROM symbols s, json_each(s.detail_json, '$.decorators') je WHERE json_extract(je.value, '$.name') = ${_.decorator})`:void 0,_.resolvedType!==void 0?t(x.resolvedType,_.resolvedType):void 0)).orderBy(x.name);if(!_.regex)return(_.limit!==void 0?$.limit(_.limit):$).all();let J;try{J=new RegExp(_.regex)}catch{throw new O("validation",`Invalid regex pattern: ${_.regex}`)}if(_.limit===void 0)return $.all().filter((W)=>J.test(W.name));let Q=[];for(let z of[5,20,100]){let W=_.limit*z,Z=$.limit(W).all();if(Q=Z.filter((Y)=>J.test(Y.name)),Q.length>=_.limit||Z.length<W)return Q.slice(0,_.limit)}return Q.slice(0,_.limit)}}import{eq as m,and as K_,isNull as o0,or as $J}from"drizzle-orm";var x_={project:v.project,type:v.type,srcFilePath:v.srcFilePath,srcSymbolName:v.srcSymbolName,dstProject:v.dstProject,dstFilePath:v.dstFilePath,dstSymbolName:v.dstSymbolName,metaJson:v.metaJson,specifier:v.specifier,isExternal:v.isExternal};class L0{db;constructor(_){this.db=_}replaceFileRelations(_,$,J){this.db.transaction((Q)=>{if(Q.drizzleDb.delete(v).where(K_(m(v.project,_),m(v.srcFilePath,$))).run(),!J.length)return;for(let z of J)Q.drizzleDb.insert(v).values({project:_,type:z.type??"unknown",srcFilePath:z.srcFilePath??$,srcSymbolName:z.srcSymbolName??null,dstProject:z.dstProject??(z.dstFilePath!=null?_:null),dstFilePath:z.dstFilePath??null,dstSymbolName:z.dstSymbolName??null,metaJson:z.metaJson??null,specifier:z.specifier??null,isExternal:z.isExternal??0}).run()})}getOutgoing(_,$,J){if(J!==void 0)return this.db.drizzleDb.select(x_).from(v).where(K_(m(v.project,_),m(v.srcFilePath,$),$J(m(v.srcSymbolName,J),o0(v.srcSymbolName)))).all();return this.db.drizzleDb.select(x_).from(v).where(K_(m(v.project,_),m(v.srcFilePath,$))).all()}getIncoming(_){let{dstProject:$,dstFilePath:J}=_;return this.db.drizzleDb.select(x_).from(v).where(K_(m(v.dstProject,$),m(v.dstFilePath,J))).all()}getByType(_,$){return this.db.drizzleDb.select(x_).from(v).where(K_(m(v.project,_),m(v.type,$))).all()}deleteFileRelations(_,$){this.db.drizzleDb.delete(v).where(K_(m(v.project,_),m(v.srcFilePath,$))).run()}deleteIncomingRelations(_,$){this.db.drizzleDb.delete(v).where(K_(m(v.dstProject,_),m(v.dstFilePath,$))).run()}searchRelations(_){let $=this.db.drizzleDb.select(x_).from(v).where(K_(_.project!==void 0?m(v.project,_.project):void 0,_.srcFilePath!==void 0?m(v.srcFilePath,_.srcFilePath):void 0,_.srcSymbolName!==void 0?m(v.srcSymbolName,_.srcSymbolName):void 0,_.dstProject!==void 0?m(v.dstProject,_.dstProject):void 0,_.dstFilePath!==void 0?m(v.dstFilePath,_.dstFilePath):void 0,_.dstSymbolName!==void 0?m(v.dstSymbolName,_.dstSymbolName):void 0,_.type!==void 0?m(v.type,_.type):void 0,_.specifier!==void 0?m(v.specifier,_.specifier):void 0,_.isExternal!==void 0?m(v.isExternal,_.isExternal?1:0):void 0));return(_.limit!==void 0?$.limit(_.limit):$).all()}retargetRelations(_){let{dstProject:$,oldFile:J,oldSymbol:Q,newFile:z,newSymbol:W,newDstProject:Z}=_,Y=Q===null?K_(m(v.dstProject,$),m(v.dstFilePath,J),o0(v.dstSymbolName)):K_(m(v.dstProject,$),m(v.dstFilePath,J),m(v.dstSymbolName,Q)),X={dstFilePath:z,dstSymbolName:W};if(Z!==void 0)X.dstProject=Z;this.db.drizzleDb.update(v).set(X).where(Y).run()}}import{err as e0}from"@zipbul/result";import{subscribe as JJ}from"@parcel/watcher";import B0 from"path";import t0 from"path";function z_(_){return _.replaceAll("\\","/")}function h_(_,$){return z_(t0.relative(_,$))}function k_(_,$){return z_(t0.resolve(_,$))}var QJ=["**/.git/**",`**/${A_}/**`,"**/dist/**","**/node_modules/**"],zJ=new Set(["package.json","tsconfig.json"]);function WJ(_){if(_==="update")return"change";if(_==="create")return"create";return"delete"}class w0{#_;#$;#J;#z;#W;#Y;constructor(_,$=JJ,J=console){this.#$=_.projectRoot,this.#J=[...QJ,..._.ignorePatterns??[]],this.#z=new Set((_.extensions??[".ts",".mts",".cts"]).map((Q)=>Q.toLowerCase())),this.#W=$,this.#Y=J}async start(_){try{this.#_=await this.#W(this.#$,($,J)=>{if($){this.#Y.error(new O("watcher","Callback error",{cause:$}));return}try{for(let Q of J){let z=z_(B0.relative(this.#$,Q.path));if(z.startsWith(".."))continue;let W=B0.basename(z),Z=B0.extname(z).toLowerCase();if(!zJ.has(W)&&!this.#z.has(Z))continue;if(z.endsWith(".d.ts"))continue;_({eventType:WJ(Q.type),filePath:z})}}catch(Q){this.#Y.error(new O("watcher","Callback error",{cause:Q}))}},{ignore:this.#J})}catch($){return e0(new O("watcher","Failed to subscribe watcher",{cause:$}))}}async close(){if(!this.#_)return;try{await this.#_.unsubscribe(),this.#_=void 0}catch(_){return e0(new O("watcher","Failed to close watcher",{cause:_}))}}}import I0 from"path";var YJ=["**/node_modules/**","**/.git/**",`**/${A_}/**`,"**/dist/**"],ZJ=YJ.map((_)=>new Bun.Glob(_));function XJ(_){return new Bun.Glob("**/package.json").scan({cwd:_,followSymlinks:!1})}async function r_(_,$=XJ){let J=[];for await(let Q of $(_)){let z=z_(Q);if(ZJ.some((K)=>K.match(z)))continue;let W=z_(I0.dirname(Q)),Z=I0.join(_,Q),Y=await Bun.file(Z).json(),X=typeof Y?.name==="string"&&Y.name.length>0?Y.name:I0.basename(W==="."?_:W);J.push({dir:W,project:X})}return J.sort((Q,z)=>z.dir.length-Q.dir.length),J}function a(_,$,J="default"){let Q=z_(_);for(let z of $){if(z.dir===".")return z.project;if(Q===z.dir||Q.startsWith(`${z.dir}/`))return z.project}return J}import m_ from"path";var q_=new Map;async function UJ(_){let $=Bun.file(_);if(!await $.exists())return null;try{let J=await $.text(),Q=Bun.JSONC.parse(J);return typeof Q==="object"&&Q!==null?Q:null}catch{return null}}function VJ(_,$){if($.startsWith(".")){let J=m_.resolve(_,$);return J.endsWith(".json")?J:J+".json"}return m_.resolve(_,"node_modules",$)}async function _1(_,$=5){if($<=0)return null;let J=await UJ(_);if(!J)return null;let Q=J.extends;if(typeof Q!=="string"||!Q)return J;let z=VJ(m_.dirname(_),Q),W=await _1(z,$-1);if(!W)return J;let Z=typeof W.compilerOptions==="object"&&W.compilerOptions!==null?W.compilerOptions:{},Y=typeof J.compilerOptions==="object"&&J.compilerOptions!==null?J.compilerOptions:{};return{...W,...J,compilerOptions:{...Z,...Y}}}async function n_(_){if(q_.has(_))return q_.get(_)??null;let $=m_.join(_,"tsconfig.json"),J=await _1($);if(!J)return q_.set(_,null),null;let Q=typeof J.compilerOptions==="object"&&J.compilerOptions!==null?J.compilerOptions:null;if(!Q)return q_.set(_,null),null;let z=typeof Q.baseUrl==="string"?Q.baseUrl:null,W=typeof Q.paths==="object"&&Q.paths!==null?Q.paths:null;if(!z&&!W)return q_.set(_,null),null;let Z=z?m_.resolve(_,z):_,Y=new Map;if(W)for(let[K,V]of Object.entries(W)){if(!Array.isArray(V))continue;let L=V.filter((D)=>typeof D==="string");Y.set(K,L)}let X={baseUrl:Z,paths:Y};return q_.set(_,X),X}function o_(_){if(_){q_.delete(_);return}q_.clear()}function H_(_){let $=Bun.hash.xxHash64(_);return BigInt.asUintN(64,BigInt($)).toString(16).padStart(16,"0")}import{isErr as O1}from"@zipbul/result";import{err as OJ}from"@zipbul/result";import{parseSync as HJ}from"oxc-parser";function E_(_,$,J,Q=HJ){try{let z={preserveParens:!1,...J},W=Q(_,$,z);return{filePath:_,program:W.program,errors:W.errors,comments:W.comments,sourceText:$,module:W.module}}catch(z){return OJ(new O("parse",`Failed to parse file: ${_}`,{cause:z}))}}import{join as MJ}from"path";function KJ(_,$){let J=$.length===1?`**/*${$[0]}`:`**/*{${$.join(",")}}`;return new Bun.Glob(J).scan({cwd:_,followSymlinks:!1})}async function $1(_){let{projectRoot:$,extensions:J,ignorePatterns:Q,fileRepo:z,scanFilesFn:W=KJ}=_,Z=z.getFilesMap(),Y=new Set,X=[],K=[],V=Q.map((D)=>new Bun.Glob(D));for await(let D of W($,J)){let N=z_(D);if(!J.some((l)=>N.endsWith(l)))continue;if(N.startsWith("node_modules/")||N.includes("/node_modules/"))continue;if(V.some((l)=>l.match(N)))continue;Y.add(N);let w=MJ($,N),R=Bun.file(w),{size:F,lastModified:S}=R,u=Z.get(N);if(!u){let l=await R.text(),i=H_(l);X.push({filePath:N,contentHash:i,mtimeMs:S,size:F});continue}if(u.mtimeMs===S&&u.size===F){K.push({filePath:N,contentHash:u.contentHash,mtimeMs:S,size:F});continue}let E=await R.text(),y=H_(E);if(y===u.contentHash)K.push({filePath:N,contentHash:y,mtimeMs:S,size:F});else X.push({filePath:N,contentHash:y,mtimeMs:S,size:F})}let L=[];for(let D of Z.keys())if(!Y.has(D))L.push(D);return{changed:X,unchanged:K,deleted:L}}function p_(_){let $=[0];for(let J=0;J<_.length;J++)if(_[J]===`
|
|
3
|
+
`)$.push(J+1);return $}function O_(_,$){let J=0,Q=_.length-1;while(J<Q){let z=J+Q+1>>1;if(_[z]<=$)J=z;else Q=z-1}return{line:J+1,column:$-_[J]}}import{err as LJ}from"@zipbul/result";import{parse as BJ}from"comment-parser";function t_(_){try{let $=_.trim();if($.startsWith("/**"))$=$.slice(3);if($.endsWith("*/"))$=$.slice(0,-2);let Q=BJ(`/** ${$} */`)[0]??{description:"",tags:[]};return{description:(Q.description??"").trim(),tags:(Q.tags??[]).map((z)=>({tag:z.tag??"",name:z.name??"",type:z.type??"",description:z.description??"",optional:z.optional??!1,...z.default!==void 0?{default:z.default}:{}}))}}catch($){return LJ(new O("parse","Failed to parse JSDoc comment",{cause:$}))}}import{isErr as wJ}from"@zipbul/result";function IJ(_){if("name"in _&&typeof _.name==="string")return _.name;if("value"in _){let $=_.value;if(typeof $==="string")return $;if(typeof $==="number"||typeof $==="bigint"||typeof $==="boolean")return String($)}return"unknown"}function v_(_){if(_.type==="Identifier")return[{name:_.name,start:_.start,end:_.end}];if(_.type==="ObjectPattern"){let $=[];for(let J of _.properties)if(J.type==="RestElement")$.push(...v_(J.argument));else $.push(...v_(J.value));return $}if(_.type==="ArrayPattern"){let $=[];for(let J of _.elements){if(!J)continue;if(J.type==="RestElement")$.push(...v_(J.argument));else $.push(...v_(J))}return $}if(_.type==="AssignmentPattern")return v_(_.left);return[]}function CJ(_){let $=new Map;for(let J of _.module.staticImports){let Q=J.moduleRequest.value;for(let z of J.entries){let W=z.localName.value,Z=z.importName.kind==="Name"?z.importName.name:void 0,Y={specifier:Q};if(Z&&Z!==W)Y.originalName=Z;$.set(W,Y)}}return $}function R_(_){let{program:$,sourceText:J,comments:Q}=_,z=p_(J),W=CJ(_),Z=Q.filter((C)=>C.type==="Block"&&C.value.startsWith("*")).sort((C,q)=>C.end-q.end),Y=$.body.map((C)=>C.start).sort((C,q)=>C-q);function X(C,q){return S(C,q)}function K(C,q,U){if(C.type==="PrivateIdentifier")return{kind:"private"};if(!q&&C.type==="Identifier")return;return X(C,U)}function V(C,q){if(q)return J.slice(C.start,C.end);if(C.type==="PrivateIdentifier")return`#${C.name}`;return IJ(C)}function L(C,q,U){let H=C;if(!q&&H.type==="Identifier")return{kind:"string",value:H.name};return X(C,U)}function D(C,q){return{start:O_(z,C),end:O_(z,q)}}function N(C){let q=0,U=Z.length-1,H=-1;while(q<=U){let B=q+U>>>1;if(Z[B].end<=C)H=B,q=B+1;else U=B-1}if(H<0)return;let M=Z[H];q=0,U=Y.length-1;while(q<=U){let B=q+U>>>1,A=Y[B];if(A<=M.end)q=B+1;else if(A>=C)U=B-1;else return}return`/*${M.value}*/`}function w(C){if(!C)return;let q="typeAnnotation"in C&&C.typeAnnotation?C.typeAnnotation:C;return J.slice(q.start,q.end)}let R=8;function F(C){if(C.type==="Identifier")return W.get(C.name);if(C.type==="MemberExpression"){let q=C.object;if(q.type==="Identifier")return W.get(q.name)}return}function S(C,q=0){let U=C;if(q>=R)return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)};let H=U.type;if(H==="Literal"){let M=U.value;if(typeof M==="bigint")return{kind:"bigint",value:typeof U.bigint==="string"?U.bigint:M.toString()};if(typeof U.regex==="object"&&U.regex!==null)return{kind:"regex",value:J.slice(U.start,U.end)};if(M===null)return{kind:"null",value:null};if(typeof M==="string")return{kind:"string",value:M};if(typeof M==="number")return{kind:"number",value:M};if(typeof M==="boolean")return{kind:"boolean",value:M};return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}if(H==="Identifier"){let M=U.name;if(M==="undefined")return{kind:"undefined",value:null};let B=W.get(M),A={kind:"identifier",name:M};if(B){if(A.importSource=B.specifier,B.originalName)A.originalName=B.originalName}return A}if(H==="MemberExpression"){if(U.computed){let j=U.property;if(j.type==="Literal"&&typeof j.value==="string"){let k=U.object,b=J.slice(k.start,k.end),d=k.type==="Identifier"?k.name:void 0,J_=d?W.get(d):void 0,V_={kind:"member",object:b,property:j.value};if(J_)V_.importSource=J_.specifier;return V_}return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}let M=U.object,B=J.slice(M.start,M.end),A=U.property.name??J.slice(U.property.start,U.property.end),I=M.type==="Identifier"?M.name:void 0,G=I?W.get(I):void 0,T={kind:"member",object:B,property:A};if(G)T.importSource=G.specifier;return T}if(H==="CallExpression"){let M=U.callee,B=J.slice(M.start,M.end),I=(U.arguments??[]).map((j)=>S(j,q+1)),G=F(M),T={kind:"call",callee:B,arguments:I};if(G)T.importSource=G.specifier;return T}if(H==="NewExpression"){let M=U.callee,B=J.slice(M.start,M.end),I=(U.arguments??[]).map((j)=>S(j,q+1)),G=F(M),T={kind:"new",callee:B,arguments:I};if(G)T.importSource=G.specifier;return T}if(H==="ObjectExpression"){let M=U.properties??[],B=[];for(let A of M){if(A.type==="SpreadElement"){let d=A.argument;B.push({kind:"spread",argument:S(d,q+1)});continue}let I=A.key,G=A.computed===!0,T=A.value,j=A.shorthand||void 0,b={kind:"property",key:L(I,G,q+1),value:S(T,q+1)};if(j)b.shorthand=!0;B.push(b)}return{kind:"object",properties:B}}if(H==="ArrayExpression")return{kind:"array",elements:(U.elements??[]).map((A)=>{if(!A)return{kind:"undefined",value:null};return S(A,q+1)})};if(H==="SpreadElement"){let M=U.argument;return{kind:"spread",argument:S(M,q+1)}}if(H==="ArrowFunctionExpression"||H==="FunctionExpression"){let B=U.params.map(E),A={kind:"function",sourceText:J.slice(U.start,U.end)};if(B.length>0)A.parameters=B;return A}if(H==="TemplateLiteral"||H==="TaggedTemplateExpression")return{kind:"template",sourceText:J.slice(U.start,U.end)};if(H==="UnaryExpression"){let{operator:M,argument:B}=U;if(M==="-"&&B.type==="Literal"&&typeof B.value==="number")return{kind:"number",value:-B.value};if(M==="void")return{kind:"undefined",value:null};return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}if(H==="TSAsExpression"||H==="TSSatisfiesExpression"||H==="TSNonNullExpression"||H==="TSTypeAssertion"||H==="TSInstantiationExpression"||H==="ParenthesizedExpression"||H==="ChainExpression"){let M=U.expression;if(M)return S(M,q)}return{kind:"unresolvable",sourceText:J.slice(U.start,U.end)}}function u(C){if(!C||C.length===0)return[];return C.map((q)=>{let U=q.expression;if(U.type==="CallExpression"){let H=U,M=H.callee,B="name"in M&&typeof M.name==="string"?M.name:("property"in M)&&M.property&&typeof M.property.name==="string"?M.property.name:"unknown",A=H.arguments.map((I)=>S(I));return{name:B,arguments:A.length>0?A:void 0}}if(U.type==="Identifier")return{name:U.name??"unknown"};return{name:J.slice(U.start,U.end)}})}function E(C){if(C.type==="TSParameterProperty"){let U=C;return l(U.parameter,U.decorators)}if(C.type==="RestElement"){let U=C,H=U.argument,B=`...${"name"in H&&typeof H.name==="string"?H.name:"unknown"}`,A=U.typeAnnotation,I=A?w(A):void 0,G={name:B,isOptional:!1};if(I)G.type=I;return G}let q=C;return l(q,q.decorators)}function y(C){if(!C)return;let q="typeAnnotation"in C&&C.typeAnnotation?C.typeAnnotation:null;if(!q)return;let H=q.typeName?.name;if(!H)return;return W.get(H)?.specifier}function l(C,q){if(C.type==="AssignmentPattern"){let{left:T,right:j}=C,k="name"in T&&typeof T.name==="string"?T.name:"unknown",b="typeAnnotation"in T?T.typeAnnotation:null,d=b?w(b):void 0,J_=y(b),V_=J.slice(j.start,j.end),B_="decorators"in T&&Array.isArray(T.decorators)?T.decorators:[],U0=u(B_),D_={name:k,isOptional:!0,defaultValue:V_};if(d)D_.type=d;if(J_)D_.typeImportSource=J_;if(U0.length>0)D_.decorators=U0;return D_}let U="name"in C&&typeof C.name==="string"?C.name:("pattern"in C)&&C.pattern&&typeof C.pattern.name==="string"?C.pattern.name:"unknown",H=!!(("optional"in C)&&C.optional),M="typeAnnotation"in C?C.typeAnnotation:null,B=M?w(M):void 0,A=y(M),I=u(q??[]),G={name:U,isOptional:H};if(B)G.type=B;if(A)G.typeImportSource=A;if(I.length>0)G.decorators=I;return G}function i(C,q){let U=[];if(q?.async)U.push("async");if(C.static)U.push("static");if(C.abstract)U.push("abstract");if(C.readonly)U.push("readonly");if(C.override)U.push("override");if(C.declare)U.push("declare");if(C.const)U.push("const");let H=C.accessibility;if(H==="private")U.push("private");else if(H==="protected")U.push("protected");else if(H==="public")U.push("public");return U}function W_(C){if(!C)return;let q=C.params.flatMap((U)=>{let H=U.name.name;return H?[H]:[]});return q.length>0?q:void 0}function X_(C){let q=[];if(C.superClass){let H=J.slice(C.superClass.start,C.superClass.end);q.push({kind:"extends",name:H})}let U=C.implements??[];for(let H of U){let M=H.expression,B=J.slice(M.start,M.end);q.push({kind:"implements",name:B})}return q}function M_(C){let q=[],U=C.extends;for(let H of U){let M=H.expression,B=J.slice(M.start,M.end);q.push({kind:"extends",name:B})}return q}function U_(C){let q=[];for(let U of C)if(U.type==="MethodDefinition"||U.type==="TSAbstractMethodDefinition"){let H=U,M=V(H.key,H.computed),B=K(H.key,H.computed,0),A=H.value,I=H.kind,G=I==="constructor"?"constructor":I==="get"?"getter":I==="set"?"setter":"method",T=i(H,A);if(U.type==="TSAbstractMethodDefinition"&&!T.includes("abstract"))T.push("abstract");let j=A.params.map(E),k=w(A.returnType),b=u(H.decorators??[]),d={kind:"method",name:M,span:D(U.start,U.end),isExported:!1,methodKind:G,modifiers:T,parameters:j.length>0?j:void 0,returnType:k};if(B)d.key=B;if(b.length>0)d.decorators=b;q.push(d)}else if(U.type==="PropertyDefinition"||U.type==="TSAbstractPropertyDefinition"||U.type==="AccessorProperty"||U.type==="TSAbstractAccessorProperty"){let H=U,M=V(H.key,H.computed),B=K(H.key,H.computed,0),A=i(H);if(U.type==="TSAbstractPropertyDefinition"||U.type==="TSAbstractAccessorProperty"){if(!A.includes("abstract"))A.push("abstract")}if(U.type==="AccessorProperty"||U.type==="TSAbstractAccessorProperty")A.push("accessor");let I=w(H.typeAnnotation),G=H.value,T=G?S(G):void 0,j=u(H.decorators??[]),k={kind:"property",name:M,span:D(U.start,U.end),isExported:!1,modifiers:A,returnType:I,initializer:T};if(B)k.key=B;if(j.length>0)k.decorators=j;q.push(k)}return q}function Y_(C){let q=[];for(let U of C)if(U.type==="TSMethodSignature"){let H=U,M=V(H.key,H.computed),B=K(H.key,H.computed,0),A=H.params.map(E),I=w(H.returnType),G={kind:"method",name:M,span:D(U.start,U.end),isExported:!1,modifiers:[],methodKind:"method",parameters:A.length>0?A:void 0,returnType:I};if(B)G.key=B;q.push(G)}else if(U.type==="TSPropertySignature"){let H=U,M=V(H.key,H.computed),B=K(H.key,H.computed,0),A=w(H.typeAnnotation),I={kind:"property",name:M,span:D(U.start,U.end),isExported:!1,modifiers:H.readonly?["readonly"]:[],returnType:A};if(B)I.key=B;q.push(I)}return q}function c(C,q){let U=C.type;if(U==="FunctionDeclaration"||U==="FunctionExpression"||U==="TSDeclareFunction"||U==="TSEmptyBodyFunctionExpression"){let H=C,M=H.id?.name??"default",B=H.params.map(E),A=w(H.returnType),I=i(H,H),G=u(H.decorators??[]),T=W_(H.typeParameters),j={kind:"function",name:M,span:D(C.start,C.end),isExported:q,modifiers:I,parameters:B.length>0?B:void 0,returnType:A,decorators:G.length>0?G:void 0};if(T&&T.length>0)j.typeParameters=T;return j}if(U==="ClassDeclaration"||U==="ClassExpression"){let H=C,M=H.id?.name??"default",B=X_(H),A=U_(H.body.body),I=u(H.decorators),G=i(H),T=W_(H.typeParameters),j={kind:"class",name:M,span:D(C.start,C.end),isExported:q,modifiers:G,heritage:B.length>0?B:void 0,members:A.length>0?A:void 0,decorators:I.length>0?I:void 0};if(T&&T.length>0)j.typeParameters=T;return j}if(U==="VariableDeclaration"){let H=C,M=[];for(let B of H.declarations){let{id:A,init:I}=B;if(A.type==="ObjectPattern"||A.type==="ArrayPattern"){let V_=v_(A);for(let B_ of V_)M.push({kind:"variable",name:B_.name,span:D(B_.start,B_.end),isExported:q,modifiers:[]});continue}let G="name"in A&&typeof A.name==="string"?A.name:"unknown",T="variable",j,k,b;if(I)if(I.type==="FunctionExpression"||I.type==="ArrowFunctionExpression"){T="function";let V_=I;j=V_.params.map(E),k=w(V_.returnType)}else b=S(I);let d=[],J_={kind:T,name:G,span:D(B.start,B.end),isExported:q,modifiers:d,parameters:j,returnType:k};if(b)J_.initializer=b;M.push(J_)}if(M.length===0)return null;if(M.length===1)return M[0];return M}if(U==="TSTypeAliasDeclaration")return{kind:"type",name:C.id.name,span:D(C.start,C.end),isExported:q,modifiers:[]};if(U==="TSInterfaceDeclaration"){let H=C,M=H.id.name,B=M_(H),A=Y_(H.body.body),I=W_(H.typeParameters),G={kind:"interface",name:M,span:D(C.start,C.end),isExported:q,modifiers:[],heritage:B.length>0?B:void 0,members:A.length>0?A:void 0};if(I&&I.length>0)G.typeParameters=I;return G}if(U==="TSEnumDeclaration"){let H=C,M=H.id.name,B=i(H),I=H.body.members.map((G)=>{let T=G.id,j=T.type!=="Identifier",k="name"in T&&typeof T.name==="string"?T.name:("value"in T)&&typeof T.value==="string"?T.value:"unknown",b=G.initializer?S(G.initializer):void 0,d={kind:"property",name:k,span:D(G.start,G.end),isExported:!1,modifiers:[]};if(j)d.key=X(T,0);if(b)d.initializer=b;return d});return{kind:"enum",name:M,span:D(C.start,C.end),isExported:q,modifiers:B,members:I.length>0?I:void 0}}if(U==="TSModuleDeclaration"){let H=C,M=H.id.name??H.id.value??"unknown",B=i(H),A=[];if(H.body?.type==="TSModuleBlock")for(let I of H.body.body??[]){if(I.type!=="ExportNamedDeclaration")continue;let G=I.declaration;if(!G)continue;let T=c(G,!1);if(T)if(Array.isArray(T))A.push(...T);else A.push(T)}return{kind:"namespace",name:M,span:D(C.start,C.end),isExported:q,modifiers:B,members:A.length>0?A:void 0}}return null}let s=[],C_=new Set;for(let C of $.body){let q=null,U=C;if(U.type==="ExportNamedDeclaration"){let M=U;if(M.declaration){if(q=c(M.declaration,!0),q&&!Array.isArray(q))q.span=D(M.start,M.end)}else if(!M.source&&M.specifiers)for(let B of M.specifiers){let A=B.local,I="name"in A?A.name:A.value;if(I)C_.add(I)}}else if(U.type==="ExportDefaultDeclaration"){let M=U,B=M.declaration;if(B){if(q=c(B,!0),q&&!Array.isArray(q))q.name="id"in B&&B.id&&typeof B.id.name==="string"?B.id.name:"default",q.isExported=!0,q.span=D(M.start,M.end);else if(!q&&"type"in B&&B.type==="Identifier"){let A=B.name;if(A)C_.add(A)}}}else{let M=U.type;if(M==="FunctionDeclaration"||M==="TSDeclareFunction"||M==="ClassDeclaration"||M==="VariableDeclaration"||M==="TSTypeAliasDeclaration"||M==="TSInterfaceDeclaration"||M==="TSEnumDeclaration"||M==="TSModuleDeclaration")q=c(U,!1)}let H=Array.isArray(q)?q:q?[q]:[];for(let M of H){let B=C.start,A=N(B);if(A){let I=t_(A);if(!wJ(I))M.jsDoc=I}s.push(M)}}if(C_.size>0){for(let C of s)if(!C.isExported&&C_.has(C.name))C.isExported=!0}return s}function e_(_){if(_===null||typeof _!=="object")return JSON.stringify(_);if(Array.isArray(_))return`[${_.map(e_).join(",")}]`;let $=_;return`{${Object.keys($).sort().map((Q)=>`${JSON.stringify(Q)}:${e_($[Q])}`).join(",")}}`}function DJ(_){if(_.kind==="function"||_.kind==="method"){let $=_.parameters?.length??0,J=_.modifiers.includes("async")?1:0;return`params:${$}|async:${J}`}return null}function AJ(_){let $={};if(_.jsDoc)$.jsDoc=_.jsDoc;if(_.kind==="function"||_.kind==="method"){if(_.parameters!==void 0)$.parameters=_.parameters;if(_.returnType!==void 0)$.returnType=_.returnType}if(_.heritage?.length)$.heritage=_.heritage;if(_.decorators?.length)$.decorators=_.decorators;if(_.typeParameters?.length)$.typeParameters=_.typeParameters;if(_.modifiers?.length)$.modifiers=_.modifiers;if(_.initializer)$.initializer=_.initializer;if(_.key)$.key=_.key;if(_.members?.length)$.members=_.members.map((J)=>{let Q=J.modifiers.find((W)=>W==="private"||W==="protected"||W==="public"),z={name:J.name,kind:J.methodKind??J.kind,type:J.returnType,visibility:Q,isStatic:J.modifiers.includes("static")||void 0,isReadonly:J.modifiers.includes("readonly")||void 0,isAccessor:J.modifiers.includes("accessor")||void 0};if(J.key)z.key=J.key;if(J.initializer)z.initializer=J.initializer;if(J.decorators?.length)z.decorators=J.decorators;return z});return Object.keys($).length>0?JSON.stringify($):null}function qJ(_){let $=[_.kind];if(_.modifiers.length)$.push(`mod:${[..._.modifiers].sort().join(",")}`);if(_.typeParameters?.length)$.push(`tp:${_.typeParameters.length}`);if(_.heritage?.length){let J=[..._.heritage].sort((Q,z)=>Q.name.localeCompare(z.name)).map((Q)=>`${Q.kind}:${Q.name}`).join(",");$.push(`her:${J}`)}if(_.decorators?.length)$.push(`dec:${[..._.decorators].map((J)=>J.name).sort().join(",")}`);if(_.methodKind)$.push(`mk:${_.methodKind}`);if(_.parameters)$.push(`p:${_.parameters.length}`);if(_.returnType)$.push(`rt:${_.returnType}`);if(_.key)$.push(`k:${e_(_.key)}`);if(_.members?.length){let J=_.members.map((Q)=>`${Q.kind}:${Q.modifiers.join(",")}:${Q.parameters?.length??""}:${Q.returnType??""}:${Q.key?e_(Q.key):""}`).sort().join(";");$.push(`mem:${_.members.length}:${H_(J)}`)}return H_($.join("|"))}function J1(_,$,J,Q,z){let W=DJ(_),Z=H_(`${$}|${_.kind}|${W??""}`),Y=qJ(_);return{project:J,filePath:Q,kind:_.kind,name:$,startLine:_.span.start.line,startColumn:_.span.start.column,endLine:_.span.end.line,endColumn:_.span.end.column,isExported:_.isExported?1:0,signature:W,fingerprint:Z,detailJson:AJ(_),contentHash:z,indexedAt:new Date().toISOString(),structuralFingerprint:Y}}function C0(_){let{parsed:$,project:J,filePath:Q,contentHash:z,symbolRepo:W}=_,Z=R_($),Y=[];for(let X of Z){Y.push(J1(X,X.name,J,Q,z));for(let K of X.members??[])Y.push(J1(K,`${X.name}.${K.name}`,J,Q,z))}W.replaceFileSymbols(J,Q,z,Y)}import{resolve as D0,dirname as NJ,extname as RJ}from"path";function T_(_,$,J){let Q=(z)=>{let W=RJ(z);if(W===".js")return[z.slice(0,-3)+".ts"];if(W===".mjs")return[z.slice(0,-4)+".mts"];if(W===".cjs")return[z.slice(0,-4)+".cts"];if(W===".ts"||W===".mts"||W===".cts"||W===".d.ts")return[z];return[z+".ts",z+".d.ts",z+"/index.ts",z+"/index.d.ts",z+".mts",z+"/index.mts",z+".cts",z+"/index.cts"]};if($.startsWith(".")){let z=z_(D0(NJ(_),$));return Q(z)}if(J)for(let[z,W]of J.paths){if(W.length===0)continue;let Z=z.indexOf("*");if(Z===-1){if($===z){let Y=[];for(let X of W)Y.push(...Q(z_(D0(J.baseUrl,X))));return Y}}else{let Y=z.slice(0,Z),X=z.slice(Z+1);if($.startsWith(Y)&&(X===""||$.endsWith(X))){let K=$.slice(Y.length,X===""?void 0:$.length-X.length),V=[];for(let L of W)V.push(...Q(z_(D0(J.baseUrl,L.replace("*",K)))));return V}}}return[]}function Q1(_,$,J,Q=T_){let z=new Map,W=_.body??[];for(let Z of W){if(Z.type!=="ImportDeclaration")continue;let Y=Z.source?.value??"",X=Q($,Y,J);if(X.length===0)continue;let K=X[0],V=Z.specifiers??[];for(let L of V)switch(L.type){case"ImportSpecifier":z.set(L.local.name,{path:K,importedName:L.imported.name});break;case"ImportDefaultSpecifier":z.set(L.local.name,{path:K,importedName:"default"});break;case"ImportNamespaceSpecifier":z.set(L.local.name,{path:K,importedName:"*"});break}}return z}import{Visitor as TJ}from"oxc-parser";function _0(_){return"name"in _&&typeof _.name==="string"?_.name:("value"in _)&&typeof _.value==="string"?_.value:"unknown"}function GJ(_){return!_.startsWith(".")&&!_.startsWith("/")}function G_(_,$,J,Q){let z=Q(_,$,J),W=z.length>0?z[0]:null,Z=W===null&&GJ($);return{resolved:W,isExternal:Z}}function SJ(_,$,J,Q,z){for(let W of _.staticImports){let Z=W.moduleRequest.value,{resolved:Y,isExternal:X}=G_($,Z,J,Q),K={dstFilePath:Y,specifier:Z};if(W.entries.length===0){let V={};if(X)V.isExternal=!0;if(Y===null&&!X)V.isUnresolved=!0;z.push({type:"imports",srcFilePath:$,srcSymbolName:null,...K,dstSymbolName:null,...Object.keys(V).length>0?{metaJson:JSON.stringify(V)}:{}});continue}for(let V of W.entries){let L=V.isType,D={};if(L)D.isType=!0;if(X)D.isExternal=!0;if(Y===null&&!X)D.isUnresolved=!0;let N,w,R=V.importName.kind;if(R==="Default")N="default",w=V.localName.value;else if(R==="NamespaceObject")N="*",w=V.localName.value,D.importKind="namespace";else N=V.importName.name??"unknown",w=V.localName.value;z.push({type:L?"type-references":"imports",srcFilePath:$,srcSymbolName:w,...K,dstSymbolName:N,...Object.keys(D).length>0?{metaJson:JSON.stringify(D)}:{}})}}}function FJ(_,$,J,Q,z){let W=new Map;for(let Z of _.staticImports)for(let Y of Z.entries)W.set(Y.localName.value,Z.moduleRequest.value);for(let Z of _.staticExports)for(let Y of Z.entries){let X=null;if(Y.moduleRequest)X=Y.moduleRequest.value;else if(Y.localName.name)X=W.get(Y.localName.name)??null;if(!X)continue;let{resolved:K,isExternal:V}=G_($,X,J,Q),L=Y.exportName.name??"default",D=Y.exportName.kind,N=Y.localName.name??Y.importName.name??L,w=Y.isType,R={isReExport:!0};if(D==="None");else R.specifiers=[{local:N,exported:L}];if(w)R.isType=!0;if(V)R.isExternal=!0;if(K===null&&!V)R.isUnresolved=!0;let F=null,S=null,u=Y.importName.kind;if(u==="All"||u==="AllButDefault"){if(D==="Name"&&L)S=L,R.namespaceAlias=L}else S=N,F=L;z.push({type:w?"type-references":"re-exports",srcFilePath:$,srcSymbolName:F,dstFilePath:K,dstSymbolName:S,specifier:X,metaJson:JSON.stringify(R)})}}function jJ(_,$,J,Q,z){for(let W of _.body){let Z=W;if(Z.type==="ImportDeclaration"){let Y=Z,X=Y.source.value,{resolved:K,isExternal:V}=G_($,X,J,Q),L=Y.importKind==="type",D=Y.specifiers,N={dstFilePath:K,specifier:X};if(D.length===0){let w={};if(L)w.isType=!0;if(V)w.isExternal=!0;if(K===null&&!V)w.isUnresolved=!0;z.push({type:L?"type-references":"imports",srcFilePath:$,srcSymbolName:null,...N,dstSymbolName:null,...Object.keys(w).length>0?{metaJson:JSON.stringify(w)}:{}})}else for(let w of D){let R=w.type,F=L||R==="ImportSpecifier"&&w.importKind==="type",S={};if(F)S.isType=!0;if(V)S.isExternal=!0;if(K===null&&!V)S.isUnresolved=!0;let u,E;if(R==="ImportDefaultSpecifier")u="default",E=w.local.name;else if(R==="ImportNamespaceSpecifier")u="*",E=w.local.name,S.importKind="namespace";else u=_0(w.imported),E=w.local.name;z.push({type:F?"type-references":"imports",srcFilePath:$,srcSymbolName:E,...N,dstSymbolName:u,...Object.keys(S).length>0?{metaJson:JSON.stringify(S)}:{}})}continue}if(Z.type==="ExportAllDeclaration"){let Y=Z,X=Y.source.value,{resolved:K,isExternal:V}=G_($,X,J,Q),L=Y.exportKind==="type",D=Y.exported,N=D?_0(D):null,w={isReExport:!0};if(L)w.isType=!0;if(V)w.isExternal=!0;if(K===null&&!V)w.isUnresolved=!0;if(N)w.namespaceAlias=N;z.push({type:L?"type-references":"re-exports",srcFilePath:$,srcSymbolName:null,dstFilePath:K,dstSymbolName:N,specifier:X,metaJson:JSON.stringify(w)});continue}if(Z.type==="ExportNamedDeclaration"){let Y=Z;if(!Y.source)continue;let X=Y.source.value,{resolved:K,isExternal:V}=G_($,X,J,Q),L=Y.exportKind==="type",D=Y.specifiers??[];for(let N of D){let w=L||N.exportKind==="type",R=_0(N.local),F=_0(N.exported),S={isReExport:!0,specifiers:[{local:R,exported:F}]};if(w)S.isType=!0;if(V)S.isExternal=!0;if(K===null&&!V)S.isUnresolved=!0;z.push({type:w?"type-references":"re-exports",srcFilePath:$,srcSymbolName:F,dstFilePath:K,dstSymbolName:R,specifier:X,metaJson:JSON.stringify(S)})}}}}function gJ(_,$,J,Q,z){new TJ({ImportExpression(Z){let Y=Z.source;if(Y.type!=="Literal"||typeof Y.value!=="string")return;let X=Y.value,{resolved:K,isExternal:V}=G_($,X,J,Q),L={isDynamic:!0};if(V)L.isExternal=!0;if(K===null&&!V)L.isUnresolved=!0;z.push({type:"imports",srcFilePath:$,srcSymbolName:null,dstFilePath:K,dstSymbolName:null,specifier:X,metaJson:JSON.stringify(L)})},CallExpression(Z){let Y=Z.callee,X=!1;if(Y.type==="Identifier"&&Y.name==="require");else if(Y.type==="MemberExpression"&&!Y.computed){let R=Y,F=R.object,S=R.property;if(F.type==="Identifier"&&F.name==="require"&&S.name==="resolve")X=!0;else return}else return;let K=Z.arguments;if(K.length===0)return;let V=K[0];if(V.type!=="Literal"||typeof V.value!=="string")return;let L=V.value,{resolved:D,isExternal:N}=G_($,L,J,Q),w={isRequire:!0};if(X)w.isRequireResolve=!0;if(N)w.isExternal=!0;if(D===null&&!N)w.isUnresolved=!0;z.push({type:"imports",srcFilePath:$,srcSymbolName:null,dstFilePath:D,dstSymbolName:null,specifier:L,metaJson:JSON.stringify(w)})}}).visit(_)}function z1(_,$,J,Q=T_,z){let W=[];if(z)SJ(z,$,J,Q,W),FJ(z,$,J,Q,W);else jJ(_,$,J,Q,W);return gJ(_,$,J,Q,W),W}import{walk as nJ}from"oxc-walker";function kJ(_){return _.type==="FunctionDeclaration"||_.type==="FunctionExpression"||_.type==="ArrowFunctionExpression"}function EJ(_){return _.type==="ArrowFunctionExpression"}function vJ(_){return _.type==="AssignmentExpression"}function uJ(_){return _.type==="CallExpression"}function bJ(_){return _.type==="FunctionDeclaration"}function PJ(_){return _.type==="FunctionExpression"}function fJ(_){return _.type==="Identifier"}function yJ(_){return _.type==="MemberExpression"}function xJ(_){return _.type==="TSQualifiedName"}function hJ(_){return _.type==="VariableDeclaration"}var W1=new Map,mJ=new Proxy({},{get(_,$,J){if(typeof $!=="string")return Reflect.get(_,$,J);let Q=$.charCodeAt(0);if(Q<65||Q>90)return Reflect.get(_,$,J);let z=W1.get($);if(z===void 0)z=(W)=>W!==null&&W!==void 0&&W.type===$,W1.set($,z);return z}});function u_(_){if(!_||typeof _!=="object"||Array.isArray(_))return null;let $=_;if($.type==="Identifier"){let J=$.name;return{root:J,parts:[],full:J}}if($.type==="ThisExpression")return{root:"this",parts:[],full:"this"};if($.type==="Super")return{root:"super",parts:[],full:"super"};if($.type==="MemberExpression"){let J=[],Q=$;while(Q.type==="MemberExpression"){let Z=Q.property;if(!Z||typeof Z.name!=="string")return null;J.push(Z.name),Q=Q.object}let z;if(Q.type==="Identifier")z=Q.name;else if(Q.type==="ThisExpression")z="this";else if(Q.type==="Super")z="super";else return null;J.reverse();let W=[z,...J].join(".");return{root:z,parts:J,full:W}}return null}function Y1(_,$,J){let Q=[],z=[],W=[];function Z(){if(z.length>0)return z[z.length-1]??null;return null}function Y(V){if(!V)return null;let L=J.get(V.root);if(V.parts.length===0){if(L)return{dstFilePath:L.path,dstSymbolName:L.importedName,resolution:"import"};return{dstFilePath:$,dstSymbolName:V.root,resolution:"local"}}else{if(L&&L.importedName==="*"){let D=V.parts[V.parts.length-1];return{dstFilePath:L.path,dstSymbolName:D,resolution:"namespace"}}return{dstFilePath:$,dstSymbolName:V.full,resolution:"local-member"}}}function X(V,L){let D=u_(V.callee),N=Y(D);if(N){let w=Z(),R={};if(L)R.isNew=!0;if(w===null)R.scope="module";Q.push({type:"calls",srcFilePath:$,srcSymbolName:w,dstFilePath:N.dstFilePath,dstSymbolName:N.dstSymbolName,...Object.keys(R).length>0?{metaJson:JSON.stringify(R)}:{}})}}function K(V,L){if(V.type==="FunctionDeclaration"){z.push(V.id?.name??"anonymous");return}if(V.type==="FunctionExpression"||V.type==="ArrowFunctionExpression"){if(L?.type==="VariableDeclarator"){let w=L.id,R=w.type==="Identifier"?w.name:"anonymous";z.push(R);return}if(L?.type==="MethodDefinition"||L?.type==="TSAbstractMethodDefinition"){let w=L.key,R=W[W.length-1]??"",F="name"in w?w.name:"anonymous",S=R?`${R}.${F}`:F;z.push(S);return}let D=Z(),N=D?`${D}.<anonymous>`:"<anonymous>";z.push(N)}}return nJ(_,{enter(V,L){if(V.type==="ClassDeclaration"||V.type==="ClassExpression"){W.push(V.id?.name??"AnonymousClass");return}if(V.type==="FunctionDeclaration"||V.type==="FunctionExpression"||V.type==="ArrowFunctionExpression"){K(V,L);return}if(V.type==="CallExpression"){X(V,!1);return}if(V.type==="NewExpression"){X(V,!0);return}},leave(V){if(V.type==="ClassDeclaration"||V.type==="ClassExpression"){W.pop();return}if(V.type==="FunctionDeclaration"||V.type==="FunctionExpression"||V.type==="ArrowFunctionExpression"){z.pop();return}}}),Q}import{Visitor as pJ}from"oxc-parser";function Z1(_,$,J){let Q=[];function z(Z){let Y=Z.id?.name??"AnonymousClass";if(Z.superClass){let K=u_(Z.superClass);if(K){let V=A0(K,$,J);Q.push({type:"extends",srcFilePath:$,srcSymbolName:Y,...V})}}let X=Z.implements??[];for(let K of X){let V=u_(K.expression);if(!V)continue;let L=A0(V,$,J);Q.push({type:"implements",srcFilePath:$,srcSymbolName:Y,...L})}}return new pJ({TSInterfaceDeclaration(Z){let Y=Z.id.name??"AnonymousInterface",X=Z.extends;for(let K of X){let V=u_(K.expression);if(!V)continue;let L=A0(V,$,J);Q.push({type:"extends",srcFilePath:$,srcSymbolName:Y,...L})}},ClassDeclaration(Z){z(Z)},ClassExpression(Z){z(Z)}}).visit(_),Q}function A0(_,$,J){let Q=J.get(_.root);if(Q){if(Q.importedName==="*"){let z=_.parts[_.parts.length-1]??_.root;return{dstFilePath:Q.path,dstSymbolName:z,metaJson:JSON.stringify({isNamespaceImport:!0})}}return{dstFilePath:Q.path,dstSymbolName:_.parts.length>0?_.full:Q.importedName}}return{dstFilePath:$,dstSymbolName:_.full,metaJson:JSON.stringify({isLocal:!0})}}function d_(_,$,J,Q=T_,z){let W=Q1(_,$,J,Q),Z=z1(_,$,J,Q,z),Y=Y1(_,$,W),X=Z1(_,$,W);return[...Z,...Y,...X]}function q0(_){let{ast:$,project:J,filePath:Q,relationRepo:z,projectRoot:W,tsconfigPaths:Z,knownFiles:Y,boundaries:X,module:K}=_,V=k_(W,Q),D=d_($,V,Z,Y?(w,R,F)=>{let S=T_(w,R,F);for(let u of S){let E=h_(W,u);if(X){let y=a(E,X);if(Y.has(`${y}::${E}`))return[u]}else if(Y.has(`${J}::${E}`))return[u]}return[]}:void 0,K),N=[];for(let w of D){if(w.dstFilePath===null){let u=h_(W,w.srcFilePath),E;if(w.metaJson)try{E=JSON.parse(w.metaJson)}catch{}let y=E?.isExternal===!0;N.push({project:J,type:w.type,srcFilePath:u,srcSymbolName:w.srcSymbolName??null,dstProject:null,dstFilePath:null,dstSymbolName:w.dstSymbolName??null,metaJson:w.metaJson??null,specifier:w.specifier??null,isExternal:y?1:0});continue}let R=h_(W,w.dstFilePath);if(R.startsWith(".."))continue;let F=h_(W,w.srcFilePath),S=X?a(R,X):J;N.push({project:J,type:w.type,srcFilePath:F,srcSymbolName:w.srcSymbolName??null,dstProject:S,dstFilePath:R,dstSymbolName:w.dstSymbolName??null,metaJson:w.metaJson??null,specifier:w.specifier??null,isExternal:0})}return z.replaceFileRelations(J,Q,N),N.length}import{isErr as dJ}from"@zipbul/result";var X1=/(?:^|\s)@([a-zA-Z][\w-]*\w|[a-zA-Z])\s*(.*)$/m;function lJ(_){let $=R_(_),J=[];for(let Q of $){J.push({name:Q.name,startLine:Q.span.start.line});for(let z of Q.members??[])J.push({name:`${Q.name}.${z.name}`,startLine:z.span.start.line})}return J.sort((Q,z)=>Q.startLine-z.startLine),J}function N0(_,$,J){let Q=0,z=_.length-1;while(Q<=z){let W=Q+z>>1;if(_[W].startLine<=$)Q=W+1;else z=W-1}if(Q<_.length){let W=_[Q];if(W.startLine-$<=J)return W.name}return null}function $0(_,$,J){let Q=O_(_,$),z=O_(_,J);return{start:Q,end:z}}function U1(_){let{comments:$,sourceText:J}=_;if(!$.length)return[];let Q=p_(J),z=lJ(_),W=[],Z=[...$].sort((X,K)=>X.start-K.start),Y=null;for(let X of Z)if(X.type==="Block"&&X.value.startsWith("*")){Y=null;let K=`/*${X.value}*/`,V=t_(K);if(dJ(V))continue;let L=V;if(!L.tags?.length)continue;let D=O_(Q,X.end),N=N0(z,D.line,3),w=J.slice(X.start,X.end);for(let R of L.tags){let F=[R.name,R.description].filter(Boolean).join(" "),S=`@${R.tag}`,u=w.indexOf(S),E;if(u>=0){let y=X.start+u,l=J.indexOf(`
|
|
4
|
+
`,y),i=l>=0?Math.min(l,X.end):X.end;E=$0(Q,y,i)}else E=$0(Q,X.start,X.end);W.push({tag:R.tag,value:F,source:"jsdoc",span:E,symbolName:N})}}else if(X.type==="Block"){Y=null;let K=X.value.split(`
|
|
5
|
+
`),V=0;for(let L of K){let D=L.replace(/^\s*\*?\s?/,""),N=X1.exec(D);if(N){let w=N[1],R=N[2]?.trim()??"",F=`@${w}`,S=L.indexOf(F),u=X.start+2+V+(S>=0?S:0),E=X.start+2+V+L.length,y=$0(Q,u,E),l=O_(Q,X.end),i=N0(z,l.line,3);W.push({tag:w,value:R,source:"block",span:y,symbolName:i})}V+=L.length+1}}else{let K=X.value,V=X1.exec(K),L=O_(Q,X.start),D=O_(Q,X.end);if(V){let N=V[1],w=V[2]?.trim()??"",R=`@${N}`,F=K.indexOf(R),S=X.start+2+(F>=0?F:0),u=$0(Q,S,X.end),E=N0(z,D.line,3),y={tag:N,value:w,source:"line",span:u,symbolName:E};W.push(y),Y={annotation:y,endLine:D.line}}else if(Y&&L.line===Y.endLine+1){let N=K.trim();if(N)Y.annotation.value+=" "+N,Y.annotation.span.end=O_(Q,X.end),Y.endLine=D.line}else Y=null}return W}function R0(_){let{parsed:$,project:J,filePath:Q,annotationRepo:z}=_,W=U1($);if(z.deleteFileAnnotations(J,Q),!W.length)return 0;let Z=new Date().toISOString(),Y=W.map((X)=>({project:J,filePath:Q,tag:X.tag,value:X.value,source:X.source,symbolName:X.symbolName,startLine:X.span.start.line,startColumn:X.span.start.column,endLine:X.span.end.line,endColumn:X.span.end.column,indexedAt:Z}));return z.insertBatch(J,Q,Y),W.length}function V1(_,$){let J=[],Q=[],z=[];for(let[V,L]of $)if(!_.has(V))J.push({name:L.name,filePath:L.filePath,kind:L.kind,fingerprint:L.fingerprint});for(let[V,L]of _)if(!$.has(V))Q.push({name:L.name,filePath:L.filePath,kind:L.kind,fingerprint:L.fingerprint});if(!J.length||!Q.length)return{renamed:z,added:J,removed:Q};let W=new Map,Z=new Map;for(let V of J){let L=W.get(V.filePath)??[];L.push(V),W.set(V.filePath,L)}for(let V of Q){let L=Z.get(V.filePath)??[];L.push(V),Z.set(V.filePath,L)}let Y=new Set,X=new Set;for(let[V,L]of W){let D=Z.get(V);if(!D)continue;for(let N of new Set(L.map((w)=>w.kind))){let w=L.filter((E)=>E.kind===N&&!Y.has(E)),R=D.filter((E)=>E.kind===N&&!X.has(E));if(!w.length||!R.length)continue;let F=(E,y)=>{return y.get(`${E.filePath}::${E.name}`)?.structuralFingerprint??null},S=(E,y)=>{return y.get(`${E.filePath}::${E.name}`)?.startLine??0},u=new Map;for(let E of R){let y=F(E,_);if(!y)continue;let l=u.get(y)??[];l.push(E),u.set(y,l)}for(let E of w){if(Y.has(E))continue;let y=F(E,$);if(!y)continue;let l=u.get(y);if(!l)continue;let i=l.filter((X_)=>!X.has(X_));if(!i.length)continue;let W_=i[0];if(i.length>1){let X_=S(E,$),M_=Math.abs(S(W_,_)-X_);for(let U_=1;U_<i.length;U_++){let Y_=Math.abs(S(i[U_],_)-X_);if(Y_<M_)M_=Y_,W_=i[U_]}}z.push({oldName:W_.name,newName:E.name,filePath:V,kind:N}),Y.add(E),X.add(W_)}}}let K=z.filter((V)=>!V.oldName.includes("."));for(let V of K){let L=`${V.oldName}.`,D=`${V.newName}.`,N=Q.filter((R)=>R.filePath===V.filePath&&R.name.startsWith(L)&&!X.has(R)),w=J.filter((R)=>R.filePath===V.filePath&&R.name.startsWith(D)&&!Y.has(R));for(let R of N){let F=R.name.slice(L.length),S=w.find((u)=>u.name.slice(D.length)===F);if(S)z.push({oldName:R.name,newName:S.name,filePath:V.filePath,kind:R.kind}),Y.add(S),X.add(R)}}return{renamed:z,added:J.filter((V)=>!Y.has(V)),removed:Q.filter((V)=>!X.has(V))}}var iJ=100,H1=50;class T0{opts;logger;callbacks=new Set;indexingLock=!1;pendingEvents=[];debounceTimer=null;currentIndexing=null;pendingFullIndex=!1;pendingFullIndexWaiters=[];tsconfigPathsRaw;boundariesRefresh=null;lastPruneAt=0;constructor(_){this.opts=_,this.logger=_.logger??console,this.tsconfigPathsRaw=n_(_.projectRoot)}get tsconfigPaths(){return this.tsconfigPathsRaw}fullIndex(){return this.startIndex(void 0,!0)}incrementalIndex(_){return this.startIndex(_,!1)}onIndexed(_){return this.callbacks.add(_),()=>this.callbacks.delete(_)}handleWatcherEvent(_){if(_.filePath.endsWith("tsconfig.json")){o_(this.opts.projectRoot),this.tsconfigPathsRaw=n_(this.opts.projectRoot),this.fullIndex().catch(($)=>{this.logger.error("[IndexCoordinator] fullIndex failed after tsconfig change:",$)});return}if(_.filePath.endsWith("package.json")){let $=this.opts.discoverProjectsFn??r_;this.boundariesRefresh=$(this.opts.projectRoot).then((J)=>{this.opts.boundaries=J,this.opts.onBoundariesChanged?.(J)}),this.fullIndex().catch((J)=>{this.logger.error("[IndexCoordinator] fullIndex failed after package.json change:",J)});return}if(this.pendingEvents.push(_),this.debounceTimer===null)this.debounceTimer=setTimeout(()=>{this.debounceTimer=null,this.flushPending()},iJ)}async shutdown(){if(this.debounceTimer!==null)clearTimeout(this.debounceTimer),this.debounceTimer=null;if(this.currentIndexing)await this.currentIndexing}startIndex(_,$){if(this.indexingLock){if($)return this.pendingFullIndex=!0,new Promise((Q,z)=>{this.pendingFullIndexWaiters.push({resolve:Q,reject:z})});return this.currentIndexing}this.indexingLock=!0;let J=this.doIndex(_,$).then((Q)=>{return this.fireCallbacks(Q),Q}).finally(()=>{if(this.indexingLock=!1,this.currentIndexing=null,this.pendingFullIndex){this.pendingFullIndex=!1;let Q=this.pendingFullIndexWaiters.splice(0);this.startIndex(void 0,!0).then((z)=>{for(let W of Q)W.resolve(z)}).catch((z)=>{for(let W of Q)W.reject(z)})}else if(this.pendingEvents.length>0){let Q=this.pendingEvents.splice(0);this.startIndex(Q,!1).catch((z)=>this.logger.error("[IndexCoordinator] incremental drain error",z))}});return this.currentIndexing=J,J}async doIndex(_,$){let J=Date.now(),{fileRepo:Q,symbolRepo:z,relationRepo:W,dbConnection:Z}=this.opts;if(this.boundariesRefresh)await this.boundariesRefresh,this.boundariesRefresh=null;let Y,X;if(_!==void 0)Y=_.filter((U)=>U.eventType==="create"||U.eventType==="change").map((U)=>({filePath:U.filePath,contentHash:"",mtimeMs:0,size:0})),X=_.filter((U)=>U.eventType==="delete").map((U)=>U.filePath);else{let U=new Map;for(let M of this.opts.boundaries)for(let[B,A]of Q.getFilesMap(M.project))U.set(B,A);let H=await $1({projectRoot:this.opts.projectRoot,extensions:this.opts.extensions,ignorePatterns:this.opts.ignorePatterns,fileRepo:{getFilesMap:()=>U}});Y=H.changed,X=H.deleted}let K=await this.tsconfigPathsRaw??void 0,V=new Map;for(let U of X){let H=a(U,this.opts.boundaries),M=z.getFileSymbols(H,U);V.set(U,M)}let L=crypto.randomUUID(),D=new Map,N=new Map,w=(U)=>({name:U.name,filePath:U.filePath,kind:U.kind,fingerprint:U.fingerprint,structuralFingerprint:U.structuralFingerprint??null,startLine:U.startLine,isExported:U.isExported??0});if($)for(let U of this.opts.boundaries)for(let H of Q.getAllFiles(U.project))for(let M of z.getFileSymbols(U.project,H.filePath))D.set(`${M.filePath}::${M.name}`,w(M));else{for(let U of Y){let H=a(U.filePath,this.opts.boundaries);for(let M of z.getFileSymbols(H,U.filePath))D.set(`${M.filePath}::${M.name}`,w(M))}for(let[,U]of V)for(let H of U)D.set(`${H.filePath}::${H.name}`,w(H))}let R=(U)=>`${U.type}|${U.srcFilePath}|${U.dstFilePath??""}|${U.srcSymbolName??""}|${U.dstSymbolName??""}|${H_(U.metaJson??"")}`,F=new Map;if($)for(let U of this.opts.boundaries)for(let H of Q.getAllFiles(U.project))for(let M of W.getOutgoing(U.project,H.filePath))F.set(R(M),M);else{for(let U of Y){let H=a(U.filePath,this.opts.boundaries);for(let M of W.getOutgoing(H,U.filePath))F.set(R(M),M)}for(let U of X){let H=a(U,this.opts.boundaries);for(let M of W.getOutgoing(H,U))F.set(R(M),M)}}let{annotationRepo:S,changelogRepo:u}=this.opts,E=()=>{for(let U of X){let H=a(U,this.opts.boundaries);if(z.deleteFileSymbols(H,U),W.deleteFileRelations(H,U),W.deleteIncomingRelations(H,U),S)S.deleteFileAnnotations(H,U);Q.deleteFile(H,U)}},y=0,l=async()=>{let{projectRoot:U,boundaries:H}=this.opts,{parseCache:M}=this.opts,B=0,A=0,I=0,G=[],T=[];for(let k of Y)try{let b=k_(U,k.filePath),d=Bun.file(b),J_=await d.text(),V_=k.contentHash||H_(J_),B_=a(k.filePath,H);Q.upsertFile({project:B_,filePath:k.filePath,mtimeMs:d.lastModified,size:d.size,contentHash:V_,updatedAt:new Date().toISOString(),lineCount:J_.split(`
|
|
6
|
+
`).length});let D_=(this.opts.parseSourceFn??E_)(b,J_);if(O1(D_))throw D_.data;let y$=D_;T.push({filePath:k.filePath,text:J_,contentHash:V_,parsed:y$,project:B_})}catch(b){this.logger.error(`[IndexCoordinator] Failed to prepare ${k.filePath}:`,b),G.push(k.filePath)}let j=new Set;for(let k of H)for(let[b]of Q.getFilesMap(k.project))j.add(`${k.project}::${b}`);return Z.transaction(()=>{for(let k of T){if(C0({parsed:k.parsed,project:k.project,filePath:k.filePath,contentHash:k.contentHash,symbolRepo:z}),A+=q0({ast:k.parsed.program,project:k.project,filePath:k.filePath,relationRepo:W,projectRoot:U,tsconfigPaths:K,knownFiles:j,boundaries:H,module:k.parsed.module}),S)I+=R0({parsed:k.parsed,project:k.project,filePath:k.filePath,annotationRepo:S});M.set(k.filePath,k.parsed),B+=z.getFileSymbols(k.project,k.filePath).length}}),{symbols:B,relations:A,annotations:I,failedFiles:G}},i=0,W_=0,X_=[];if($){let{projectRoot:U,boundaries:H}=this.opts,{parseCache:M}=this.opts,B=[];for(let I=0;I<Y.length;I+=H1){let G=Y.slice(I,I+H1),T=await Promise.allSettled(G.map(async(j)=>{let k=k_(U,j.filePath),b=Bun.file(k),d=await b.text(),J_=j.contentHash||H_(d);return{filePath:j.filePath,text:d,contentHash:J_,mtimeMs:b.lastModified,size:b.size}}));for(let j=0;j<T.length;j++){let k=T[j];if(k.status==="fulfilled")B.push(k.value);else this.logger.error("[IndexCoordinator] Failed to pre-read file:",k.reason),X_.push(G[j].filePath)}}let A=[];Z.transaction(()=>{for(let T of B){let j=a(T.filePath,H);Q.deleteFile(j,T.filePath)}for(let T of X){let j=a(T,H);if(z.deleteFileSymbols(j,T),W.deleteFileRelations(j,T),W.deleteIncomingRelations(j,T),S)S.deleteFileAnnotations(j,T);Q.deleteFile(j,T)}for(let T of B){let j=a(T.filePath,H);Q.upsertFile({project:j,filePath:T.filePath,mtimeMs:T.mtimeMs,size:T.size,contentHash:T.contentHash,updatedAt:new Date().toISOString(),lineCount:T.text.split(`
|
|
7
|
+
`).length})}let I=new Set;for(let T of H)for(let[j]of Q.getFilesMap(T.project))I.add(`${T.project}::${j}`);let G=this.opts.parseSourceFn??E_;for(let T of B){let j=a(T.filePath,H),k=G(k_(U,T.filePath),T.text);if(O1(k))throw k.data;let b=k;if(A.push({filePath:T.filePath,parsed:b}),C0({parsed:b,project:j,filePath:T.filePath,contentHash:T.contentHash,symbolRepo:z}),S)y+=R0({parsed:b,project:j,filePath:T.filePath,annotationRepo:S});W_+=q0({ast:b.program,project:j,filePath:T.filePath,relationRepo:W,projectRoot:U,tsconfigPaths:K,knownFiles:I,boundaries:H,module:b.module}),i+=z.getFileSymbols(j,T.filePath).length}});for(let I of A)M.set(I.filePath,I.parsed)}else{E();let U=await l();i=U.symbols,W_=U.relations,y=U.annotations,X_=U.failedFiles}for(let U of Y){let H=a(U.filePath,this.opts.boundaries);for(let M of z.getFileSymbols(H,U.filePath))N.set(`${M.filePath}::${M.name}`,w(M))}let M_=new Map;for(let U of Y){let H=a(U.filePath,this.opts.boundaries);for(let M of W.getOutgoing(H,U.filePath))M_.set(R(M),M)}let U_=(U)=>({type:U.type,srcFilePath:U.srcFilePath,dstFilePath:U.dstFilePath,srcSymbolName:U.srcSymbolName,dstSymbolName:U.dstSymbolName,dstProject:U.dstProject,metaJson:U.metaJson}),Y_={added:[...M_.entries()].filter(([U])=>!F.has(U)).map(([,U])=>U_(U)),removed:[...F.entries()].filter(([U])=>!M_.has(U)).map(([,U])=>U_(U))},c={added:[],modified:[],removed:[]};for(let[U,H]of N){let M=D.get(U);if(!M)c.added.push({name:H.name,filePath:H.filePath,kind:H.kind,isExported:Boolean(H.isExported)});else{let B=M.fingerprint!==H.fingerprint,A=M.isExported!==H.isExported,I=M.structuralFingerprint!==null&&H.structuralFingerprint!==null&&M.structuralFingerprint!==H.structuralFingerprint;if(B||A||I)c.modified.push({name:H.name,filePath:H.filePath,kind:H.kind,isExported:Boolean(H.isExported)})}}for(let[U,H]of D)if(!N.has(U))c.removed.push({name:H.name,filePath:H.filePath,kind:H.kind,isExported:Boolean(H.isExported)});let s=V1(D,N),C_=new Set(s.renamed.map((U)=>`${U.filePath}::${U.oldName}`)),C=new Set(s.renamed.map((U)=>`${U.filePath}::${U.newName}`));c.added=c.added.filter((U)=>!C.has(`${U.filePath}::${U.name}`)),c.removed=c.removed.filter((U)=>!C_.has(`${U.filePath}::${U.name}`));let q=[];if(!$){for(let[H,M]of V)for(let B of M){if(!B.fingerprint)continue;let A=a(H,this.opts.boundaries),I=z.getByFingerprint(A,B.fingerprint);if(I.length===1){let G=I[0];W.retargetRelations({dstProject:A,oldFile:H,oldSymbol:B.name,newFile:G.filePath,newSymbol:G.name}),q.push({name:G.name,filePath:G.filePath,kind:G.kind,oldFilePath:H,isExported:G.isExported??0})}}let U=new Set(q.map((H)=>`${H.oldFilePath}::${H.name}`));for(let H of s.removed){if(U.has(`${H.filePath}::${H.name}`))continue;let B=D.get(`${H.filePath}::${H.name}`)?.fingerprint;if(!B)continue;let A=a(H.filePath,this.opts.boundaries),I=z.getByFingerprint(A,B);if(I.length===1){let G=I[0];if(G.filePath!==H.filePath||G.name!==H.name)W.retargetRelations({dstProject:A,oldFile:H.filePath,oldSymbol:H.name,newFile:G.filePath,newSymbol:G.name}),q.push({name:G.name,filePath:G.filePath,kind:G.kind,oldFilePath:H.filePath,isExported:G.isExported??0})}}}if(q.length){let U=new Set(q.map((M)=>`${M.filePath}::${M.name}`)),H=new Set(q.map((M)=>`${M.oldFilePath}::${M.name}`));c.added=c.added.filter((M)=>!U.has(`${M.filePath}::${M.name}`)),c.removed=c.removed.filter((M)=>!H.has(`${M.filePath}::${M.name}`))}if(u){let U=new Date().toISOString(),H=$?1:0,M=[];for(let B of c.added){let A=`${B.filePath}::${B.name}`,I=N.get(A),G=a(B.filePath,this.opts.boundaries);M.push({project:G,changeType:"added",symbolName:B.name,symbolKind:B.kind,filePath:B.filePath,oldName:null,oldFilePath:null,fingerprint:I?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:L})}for(let B of c.modified){let A=N.get(`${B.filePath}::${B.name}`),I=a(B.filePath,this.opts.boundaries);M.push({project:I,changeType:"modified",symbolName:B.name,symbolKind:B.kind,filePath:B.filePath,oldName:null,oldFilePath:null,fingerprint:A?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:L})}for(let B of c.removed){let A=`${B.filePath}::${B.name}`,I=D.get(A),G=a(B.filePath,this.opts.boundaries);M.push({project:G,changeType:"removed",symbolName:B.name,symbolKind:B.kind,filePath:B.filePath,oldName:null,oldFilePath:null,fingerprint:I?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:L})}for(let B of s.renamed){let A=N.get(`${B.filePath}::${B.newName}`),I=a(B.filePath,this.opts.boundaries);M.push({project:I,changeType:"renamed",symbolName:B.newName,symbolKind:B.kind,filePath:B.filePath,oldName:B.oldName,oldFilePath:null,fingerprint:A?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:L})}for(let B of q){let A=N.get(`${B.filePath}::${B.name}`),I=a(B.filePath,this.opts.boundaries);M.push({project:I,changeType:"moved",symbolName:B.name,symbolKind:B.kind,filePath:B.filePath,oldName:null,oldFilePath:B.oldFilePath,fingerprint:A?.fingerprint??null,changedAt:U,isFullIndex:H,indexRunId:L})}if(M.length)try{Z.transaction(()=>{u.insertBatch(M)})}catch(B){this.logger.error("[IndexCoordinator] changelog insert failed:",B)}if(Date.now()-this.lastPruneAt>3600000){this.lastPruneAt=Date.now();let B=new Date(Date.now()-2592000000).toISOString();try{for(let A of this.opts.boundaries)u.pruneOlderThan(A.project,B)}catch(A){this.logger.error("[IndexCoordinator] changelog pruning failed:",A)}}}return{indexedFiles:Y.length,removedFiles:X.length,totalSymbols:i,totalRelations:W_,totalAnnotations:y,durationMs:Date.now()-J,changedFiles:Y.map((U)=>U.filePath),deletedFiles:[...X],failedFiles:X_,changedSymbols:c,renamedSymbols:s.renamed.map((U)=>({oldName:U.oldName,newName:U.newName,filePath:U.filePath,kind:U.kind,isExported:Boolean(N.get(`${U.filePath}::${U.newName}`)?.isExported)})),movedSymbols:q.map((U)=>({name:U.name,oldFilePath:U.oldFilePath,newFilePath:U.filePath,kind:U.kind,isExported:Boolean(U.isExported)})),changedRelations:Y_}}fireCallbacks(_){for(let $ of this.callbacks)try{$(_)}catch(J){this.logger.error("[IndexCoordinator] onIndexed callback threw:",J)}}flushPending(){if(this.indexingLock)return;if(this.pendingEvents.length>0){let _=this.pendingEvents.splice(0);this.startIndex(_,!1).catch(($)=>this.logger.error("[IndexCoordinator] flushPending startIndex error:",$))}}}function cJ(_){try{return process.kill(_,0),!0}catch($){if(typeof $==="object"&&$&&"code"in $)return $.code!=="ESRCH";return!0}}function aJ(_){let $=new Date(_).getTime();return Number.isNaN($)?0:$}function M1(_,$,J={}){let Q=J.now??Date.now,z=J.isAlive??cJ,W=J.staleAfterSeconds??60,Z=J.instanceId;return _.immediateTransaction(()=>{let Y=_.selectOwner();if(!Y)return _.insertOwner($,Z),"owner";let X=Math.floor((Q()-aJ(Y.heartbeat_at))/1000),K=z(Y.pid);if(K&&Z&&Y.instance_id&&Y.instance_id!==Z&&Y.pid===$)return _.replaceOwner($,Z),"owner";if(K&&X<W)return"reader";return _.replaceOwner($,Z),"owner"})}function K1(_,$){_.deleteOwner($)}function L1(_,$){_.touchOwner($)}class l_{#_;#$=new Map;constructor(_){this.#_=Math.max(1,_)}get size(){return this.#$.size}has(_){return this.#$.has(_)}get(_){if(!this.#$.has(_))return;let $=this.#$.get(_);return this.#$.delete(_),this.#$.set(_,$),$}set(_,$){if(this.#$.has(_))this.#$.delete(_);if(this.#$.set(_,$),this.#$.size>this.#_){let J=this.#$.keys().next().value;if(J!==void 0)this.#$.delete(J)}}delete(_){return this.#$.delete(_)}clear(){this.#$.clear()}}class G0{lru;constructor(_=500){this.lru=new l_(_)}get(_){return this.lru.get(_)}set(_,$){this.lru.set(_,$)}invalidate(_){this.lru.delete(_)}invalidateAll(){this.lru.clear()}size(){return this.lru.size}}function S0(_){let{symbolRepo:$,project:J,query:Q}=_,z=Q.project??J,W={kind:Q.kind,filePath:Q.filePath,isExported:Q.isExported,project:z,limit:Q.limit,resolvedType:Q.resolvedType};if(Q.text)if(Q.exact)W.exactName=Q.text;else{let Y=g_(Q.text);if(Y)W.ftsQuery=Y}if(Q.decorator)W.decorator=Q.decorator;if(Q.regex)W.regex=Q.regex;return $.searchByQuery(W).map((Y)=>{let X=Y.name.indexOf(".");return{id:Y.id,filePath:Y.filePath,kind:Y.kind,name:Y.name,memberName:X>=0?Y.name.slice(X+1):null,span:{start:{line:Y.startLine,column:Y.startColumn},end:{line:Y.endLine,column:Y.endColumn}},isExported:Y.isExported===1,signature:Y.signature,fingerprint:Y.fingerprint,detail:Y.detailJson?(()=>{try{return JSON.parse(Y.detailJson)}catch{return{}}})():{}}})}function F0(_){let{relationRepo:$,project:J,query:Q}=_;if(Q.srcFilePath&&Q.srcFilePathPattern)throw new O("validation","srcFilePath and srcFilePathPattern are mutually exclusive");if(Q.dstFilePath&&Q.dstFilePathPattern)throw new O("validation","dstFilePath and dstFilePathPattern are mutually exclusive");let z=Q.project??J,W=Q.limit,Z=!!(Q.srcFilePathPattern||Q.dstFilePathPattern),Y=Z?void 0:W,K=$.searchRelations({srcFilePath:Q.srcFilePath,srcSymbolName:Q.srcSymbolName,dstFilePath:Q.dstFilePath,dstSymbolName:Q.dstSymbolName,dstProject:Q.dstProject,type:Q.type,project:z,specifier:Q.specifier,isExternal:Q.isExternal,limit:Y}).map((V)=>{let L;if(V.metaJson)try{L=JSON.parse(V.metaJson)}catch{}return{type:V.type,srcFilePath:V.srcFilePath,srcSymbolName:V.srcSymbolName,dstFilePath:V.dstFilePath,dstSymbolName:V.dstSymbolName,dstProject:V.dstProject,isExternal:V.isExternal===1,specifier:V.specifier,metaJson:V.metaJson??void 0,meta:L}});if(Q.srcFilePathPattern||Q.dstFilePathPattern){let V=Q.srcFilePathPattern?new Bun.Glob(Q.srcFilePathPattern):null,L=Q.dstFilePathPattern?new Bun.Glob(Q.dstFilePathPattern):null;K=K.filter((D)=>(!V||V.match(D.srcFilePath))&&(!L||D.dstFilePath===null||L.match(D.dstFilePath)))}if(Z&&W!==void 0&&K.length>W)K=K.slice(0,W);return K}import{findInFiles as sJ,Lang as rJ}from"@ast-grep/napi";function oJ(_){let $=new Set,J=/\${1,3}([A-Z_][A-Z_0-9]*)/g,Q;while((Q=J.exec(_))!==null)$.add(Q[0]);return[...$]}function tJ(_){return _.replace(/^\$+/,"")}function eJ(_,$){if($.length===0)return;let J={},Q=!1;for(let z of $){let W=tJ(z),Z=_.getMatch(W);if(Z){let X=Z.range();J[z]={text:Z.text(),startLine:X.start.line+1,endLine:X.end.line+1,startColumn:X.start.column,endColumn:X.end.column,startOffset:X.start.index,endOffset:X.end.index},Q=!0;continue}let Y=_.getMultipleMatches(W);if(Y.length>0){let X=Y[0].range(),K=Y[Y.length-1].range();J[z]={text:Y.map((V)=>V.text()).join(", "),startLine:X.start.line+1,endLine:K.end.line+1,startColumn:X.start.column,endColumn:K.end.column,startOffset:X.start.index,endOffset:K.end.index},Q=!0}}return Q?J:void 0}async function j0(_){if(_.filePaths.length===0)return[];let $=oJ(_.pattern),J=[];return await sJ(rJ.TypeScript,{paths:_.filePaths,matcher:{rule:{pattern:_.pattern}}},(Q,z)=>{if(Q){console.warn("[patternSearch] findInFiles callback error:",Q);return}for(let W of z){let Z=W.range(),Y={filePath:W.getRoot().filename(),startLine:Z.start.line+1,endLine:Z.end.line+1,startColumn:Z.start.column,endColumn:Z.end.column,startOffset:Z.start.index,endOffset:Z.end.index,matchedText:W.text()},X=eJ(W,$);if(X)Y.captures=X;J.push(Y)}}),J}import __ from"typescript";import{isErr as wQ}from"@zipbul/result";import w_ from"typescript";import _Q from"path";import{err as g0}from"@zipbul/result";function $Q(_){try{return d0("fs").readFileSync(_,"utf-8")}catch{return}}function JQ(_){try{return d0("fs").readFileSync(_,"utf-8")}catch{return}}class J0{#_;#$;#J=!1;__testing__;constructor(_,$){this.#_=_,this.#$=$,this.__testing__={host:$}}static create(_,$={}){let J=$.readConfigFile??$Q,Q=$.resolveNonTrackedFile??JQ,z=_Q.dirname(_),W=J(_);if(W===void 0)return g0(new O("semantic",`tsconfig not found: ${_}`));let Z=w_.parseJsonText(_,W),Y=Z.parseDiagnostics;if(Y&&Y.length>0){let L=Y.map((D)=>w_.flattenDiagnosticMessageText(D.messageText,`
|
|
8
|
+
`)).join("; ");return g0(new O("semantic",`tsconfig parse error: ${L}`))}let X=w_.parseJsonSourceFileConfigFileContent(Z,{useCaseSensitiveFileNames:!0,readDirectory:()=>[],fileExists:(L)=>J(L)!==void 0||Q(L)!==void 0,readFile:(L)=>J(L)??Q(L)},z);if(X.errors.length>0){let L=X.errors.filter((D)=>D.category===w_.DiagnosticCategory.Error&&D.code!==18003);if(L.length>0){let D=L.map((N)=>w_.flattenDiagnosticMessageText(N.messageText,`
|
|
9
|
+
`)).join("; ");return g0(new O("semantic",`tsconfig compile error: ${D}`))}}let K=new B1(X.fileNames,X.options,z,Q),V=w_.createLanguageService(K);return new J0(V,K)}get isDisposed(){return this.#J}getProgram(){this.#z();let _=this.#_.getProgram();if(!_)throw Error("TscProgram: LanguageService returned null Program");return _}getChecker(){return this.#z(),this.getProgram().getTypeChecker()}getLanguageService(){return this.#z(),this.#_}notifyFileChanged(_,$){if(this.#J)return;this.#$.updateFile(_,$)}removeFile(_){if(this.#J)return;this.#$.removeFile(_)}dispose(){if(this.#J)return;this.#J=!0,this.#_.dispose()}#z(){if(this.#J)throw Error("TscProgram is disposed")}}class B1{#_;#$;#J;#z;#W=new Map;#Y=new Map;#Q=new Map;constructor(_,$,J,Q){this.#_=new Set(_),this.#$=$,this.#J=J,this.#z=Q}updateFile(_,$){let J=this.#W.get(_);if(J)this.#Y.delete(`${_}:${J.version}`),J.version+=1,J.content=$;else this.#W.set(_,{version:1,content:$})}removeFile(_){let $=this.#W.get(_);if($)this.#Y.delete(`${_}:${$.version}`);this.#W.delete(_),this.#_.delete(_)}getScriptFileNames(){let _=[...this.#W.keys()];return[...[...this.#_].filter((J)=>!this.#W.has(J)),..._]}getScriptVersion(_){let $=this.#W.get(_);return $?String($.version):"0"}getScriptSnapshot(_){let $=this.#W.get(_);if($){let z=`${_}:${$.version}`,W=this.#Y.get(z);if(!W)W=w_.ScriptSnapshot.fromString($.content),this.#Y.set(z,W);return W}let J=this.#Q.get(_);if(J)return J;let Q=this.#z(_);if(Q!==void 0)return J=w_.ScriptSnapshot.fromString(Q),this.#Q.set(_,J),J;return}getCurrentDirectory(){return this.#J}getCompilationSettings(){return this.#$}getDefaultLibFileName(_){return w_.getDefaultLibFilePath(_)}fileExists(_){if(this.#W.has(_))return!0;return this.#z(_)!==void 0}readFile(_){let $=this.#W.get(_);if($)return $.content;return this.#z(_)}}import n from"typescript";import w1 from"typescript";function e(_,$){if($<0||$>=_.getEnd())return;let J,Q=(z)=>{if($<z.getStart(_,!1)||$>=z.getEnd())return;J=z,w1.forEachChild(z,Q)};return w1.forEachChild(_,Q),J}var Q0=8;function QQ(_){return!!(_.flags&n.TypeFlags.Object)&&!!(_.objectFlags&n.ObjectFlags.Reference)}function L_(_,$,J=0,Q){if(Q){let w=Q.get($);if(w)return w}let z=_.typeToString($),W=$.flags,Z=!!(W&n.TypeFlags.Union),Y=!!(W&n.TypeFlags.Intersection),X;if(J<Q0&&QQ($)){let w=_.getTypeArguments($);if(w.length>0)X=w}let K=!!(W&n.TypeFlags.TypeParameter)||X!==void 0&&X.length>0,V;if(Z&&J<Q0)V=$.types.map((w)=>L_(_,w,J+1,Q));else if(Y&&J<Q0)V=$.types.map((w)=>L_(_,w,J+1,Q));let L;if(X&&X.length>0)L=X.map((w)=>L_(_,w,J+1,Q));let D;if(J<Q0&&!!(W&n.TypeFlags.Object)&&!Z&&!Y){let w=_.getPropertiesOfType($);if(w.length>0&&w.length<=50){let R=$.symbol?.declarations?.[0];D=[];for(let F of w){let S=F.declarations?.[0]??R;if(!S)continue;try{let u=_.getTypeOfSymbolAtLocation(F,S);D.push({name:F.getName(),type:L_(_,u,J+1,Q)})}catch{}}if(D.length===0)D=void 0}}let N={text:z,flags:W,isUnion:Z,isIntersection:Y,isGeneric:K,members:V,typeArguments:L,properties:D};if(Q)Q.set($,N);return N}function zQ(_){return n.isFunctionDeclaration(_)||n.isVariableDeclaration(_)||n.isClassDeclaration(_)||n.isInterfaceDeclaration(_)||n.isTypeAliasDeclaration(_)||n.isEnumDeclaration(_)||n.isMethodDeclaration(_)||n.isPropertyDeclaration(_)||n.isPropertySignature(_)||n.isMethodSignature(_)}var k0="/__gildash_type_probe__.ts";class E0{program;#_=null;constructor(_){this.program=_}#$(_){if(this.#_===_)return;this.program.notifyFileChanged(k0,`declare const __gildash_probe__: ${_};`),this.#_=_}#J(_,$){let J=_.getSourceFile(k0);if(!J)return null;let Q=J.statements[0];if(!Q||!n.isVariableStatement(Q))return null;let z=Q.declarationList.declarations[0];if(!z)return null;return $.getTypeAtLocation(z.name)}clearProbe(){if(this.#_!==null)this.program.removeFile(k0),this.#_=null}collectAt(_,$){let J=this.program.getProgram(),Q=J.getTypeChecker();if($<0)return null;let z=J.getSourceFile(_);if(!z)return null;if($>=z.getEnd())return null;let W=e(z,$);if(!W)return null;if(!n.isIdentifier(W)&&!n.isTypeNode(W))return null;try{let Z=Q.getTypeAtLocation(W);return L_(Q,Z,0,new Map)}catch{return null}}isAssignableTo(_,$,J,Q){let z=this.program.getProgram(),W=z.getTypeChecker(),Z=z.getSourceFile(_);if(!Z)return null;let Y=e(Z,$);if(!Y||!n.isIdentifier(Y))return null;let X=z.getSourceFile(J);if(!X)return null;let K=e(X,Q);if(!K||!n.isIdentifier(K))return null;try{let V=W.getTypeAtLocation(Y),L=W.getTypeAtLocation(K);return W.isTypeAssignableTo(V,L)}catch{return null}}isAssignableToType(_,$,J,Q){this.#$(J);let z=this.program.getProgram(),W=z.getTypeChecker(),Z=z.getSourceFile(_);if(!Z)return null;let Y=e(Z,$);if(!Y||!n.isIdentifier(Y)&&!n.isTypeNode(Y))return null;try{let X=this.#J(z,W);if(!X)return null;let K=W.getTypeAtLocation(Y);if(Q?.anyConstituent&&K.isUnion())return K.types.some((V)=>W.isTypeAssignableTo(V,X));return W.isTypeAssignableTo(K,X)}catch{return null}}isAssignableToTypeAtPositions(_,$,J,Q){let z=new Map;if($.length===0)return z;this.#$(J);let W=this.program.getProgram(),Z=W.getTypeChecker(),Y=W.getSourceFile(_);if(!Y)return z;try{let X=this.#J(W,Z);if(!X)return z;let K=Y.getEnd();for(let V of $){if(V<0||V>=K)continue;let L=e(Y,V);if(!L||!n.isIdentifier(L)&&!n.isTypeNode(L))continue;try{let D=Z.getTypeAtLocation(L);if(Q?.anyConstituent&&D.isUnion())z.set(V,D.types.some((N)=>Z.isTypeAssignableTo(N,X)));else z.set(V,Z.isTypeAssignableTo(D,X))}catch{}}}catch{}return z}collectAtPositions(_,$){let J=new Map;if($.length===0)return J;let Q=this.program.getProgram(),z=Q.getTypeChecker(),W=Q.getSourceFile(_);if(!W)return J;let Z=W.getEnd(),Y=new Map;for(let X of $){if(X<0||X>=Z)continue;let K=e(W,X);if(!K)continue;if(!n.isIdentifier(K)&&!n.isTypeNode(K))continue;try{let V=z.getTypeAtLocation(K);J.set(X,L_(z,V,0,Y))}catch{}}return J}collectFile(_){let $=new Map,J=this.program.getProgram(),Q=J.getTypeChecker(),z=J.getSourceFile(_);if(!z)return $;let W=new Map;function Z(Y){if(zQ(Y)&&Y.name&&n.isIdentifier(Y.name)){let X=Y.name;try{let K=Q.getTypeAtLocation(X),V=X.getStart(z);$.set(V,L_(Q,K,0,W))}catch{}}n.forEachChild(Y,Z)}return Z(z),$}}import I_ from"typescript";var WQ=1000,YQ=1;function ZQ(_){let $=_.declarations?.[0],J=$?.getSourceFile(),Q=$?I_.getNameOfDeclaration($):void 0;return{name:_.getName(),filePath:J?.fileName??"",position:Q?.getStart(J,!1)??$?.getStart(J,!1)??0}}function z0(_,$=0,J){let Q=_.declarations?.[0],z=Q?.getSourceFile(),W=Q?I_.getNameOfDeclaration(Q):void 0,Z=z?.fileName??"",Y=W?.getStart(z,!1)??Q?.getStart(z,!1)??0,X={name:_.getName(),filePath:Z,position:Y},K=_;if(K.parent)X.parent=ZQ(K.parent);let V=J&&!!(_.flags&I_.SymbolFlags.Alias)?J.getAliasedSymbol(_):_;if($<YQ){let L=V.flags,D=!!(L&I_.SymbolFlags.Enum),N=!!(L&(I_.SymbolFlags.NamespaceModule|I_.SymbolFlags.ValueModule)),w=!!(L&(I_.SymbolFlags.Class|I_.SymbolFlags.Interface));if(D&&V.exports&&V.exports.size>0){let R=[];V.exports.forEach((F)=>{R.push(z0(F,$+1,J))}),X.members=R}else if(w&&V.members&&V.members.size>0){let R=[];V.members.forEach((F)=>{R.push(z0(F,$+1,J))}),X.members=R}if(N&&V.exports&&V.exports.size>0){let R=[];V.exports.forEach((F)=>{R.push(z0(F,$+1,J))}),X.exports=R}}return X}class v0{#_;#$;#J=new Map;constructor(_,$=WQ){this.#_=_,this.#$=new l_($)}get(_,$){if(this.#_.isDisposed)return null;let J=`${_}:${$}`,Q=this.#$.get(J);if(Q!==void 0)return Q;let z=this.#_.getProgram(),W=z.getSourceFile(_);if(!W)return null;let Z=e(W,$);if(!Z||!I_.isIdentifier(Z))return null;let Y=z.getTypeChecker(),X=Y.getSymbolAtLocation(Z);if(!X)return null;let K=z0(X,0,Y);this.#$.set(J,K);let V=this.#J.get(_);if(!V)V=new Set,this.#J.set(_,V);return V.add(J),K}invalidate(_){let $=this.#J.get(_);if($){for(let J of $)this.#$.delete(J);this.#J.delete(_)}}clear(){this.#$.clear(),this.#J.clear()}}import p from"typescript";import g from"typescript";function u0(_){if(_.getSourceFile().isDeclarationFile)return!0;for(let $=_;$;$=$.parent)if(XQ($))return!0;return!1}function XQ(_){if(!g.canHaveModifiers(_))return!1;return g.getModifiers(_)?.some((J)=>J.kind===g.SyntaxKind.DeclareKeyword)??!1}function b0(_){let $=(Q,z)=>({kind:Q,pos:z.getStart(),end:z.getEnd()}),J=_.parent;while(J){if(g.isSourceFile(J)||g.isModuleDeclaration(J))return $("module",J);if(g.isFunctionLike(J))return $("function",J);if(g.isClassStaticBlockDeclaration(J))return $("function",J);if(g.isPropertyDeclaration(J))return $("function",J);if(g.isBlock(J)){let Q=J.parent;if(Q&&(g.isFunctionLike(Q)||g.isClassStaticBlockDeclaration(Q)))return $("function",Q);return $("block",J)}if(g.isForStatement(J)||g.isForInStatement(J)||g.isForOfStatement(J)||g.isCatchClause(J)||g.isCaseBlock(J)||g.isWithStatement(J))return $("block",J);J=J.parent}return $("module",_.getSourceFile())}function P0(_){let $=_.parent;if(!$)return;if(g.isVariableDeclaration($)&&$.name===_)return"declaration";if(g.isParameter($)&&$.name===_)return"declaration";if(g.isBindingElement($)&&$.name===_)return"declaration";if((g.isForOfStatement($)||g.isForInStatement($))&&$.initializer===_)return"assignment";if((g.isPrefixUnaryExpression($)||g.isPostfixUnaryExpression($))&&$.operand===_&&($.operator===g.SyntaxKind.PlusPlusToken||$.operator===g.SyntaxKind.MinusMinusToken))return"update";let J=_;while(J.parent&&g.isParenthesizedExpression(J.parent))J=J.parent;let Q=J.parent;if(Q&&g.isBinaryExpression(Q)&&Q.left===J)return UQ(Q.operatorToken.kind);if(VQ(_))return"assignment";return}function UQ(_){switch(_){case g.SyntaxKind.EqualsToken:return"assignment";case g.SyntaxKind.PlusEqualsToken:case g.SyntaxKind.MinusEqualsToken:case g.SyntaxKind.AsteriskEqualsToken:case g.SyntaxKind.AsteriskAsteriskEqualsToken:case g.SyntaxKind.SlashEqualsToken:case g.SyntaxKind.PercentEqualsToken:case g.SyntaxKind.LessThanLessThanEqualsToken:case g.SyntaxKind.GreaterThanGreaterThanEqualsToken:case g.SyntaxKind.GreaterThanGreaterThanGreaterThanEqualsToken:case g.SyntaxKind.AmpersandEqualsToken:case g.SyntaxKind.BarEqualsToken:case g.SyntaxKind.CaretEqualsToken:return"compound-assignment";case g.SyntaxKind.AmpersandAmpersandEqualsToken:case g.SyntaxKind.BarBarEqualsToken:case g.SyntaxKind.QuestionQuestionEqualsToken:return"logical-assignment";default:return}}function VQ(_){let $=_.parent;if(!$)return!1;if(!(g.isShorthandPropertyAssignment($)&&$.name===_||g.isPropertyAssignment($)&&$.initializer===_||g.isArrayLiteralExpression($)||g.isSpreadAssignment($)&&$.expression===_||g.isSpreadElement($)&&$.expression===_))return!1;let Q=$;while(Q.parent){let z=Q.parent;if(g.isBinaryExpression(z)&&z.left===Q&&z.operatorToken.kind===g.SyntaxKind.EqualsToken)return!0;if(g.isObjectLiteralExpression(z)||g.isArrayLiteralExpression(z)||g.isPropertyAssignment(z)||g.isShorthandPropertyAssignment(z)||g.isSpreadAssignment(z)||g.isSpreadElement(z)){Q=z;continue}return!1}return!1}class f0{#_;constructor(_){this.#_=_}findAt(_,$){let J=this.#$(_,$);if(!J)return[];let Q=this.#_.getProgram(),z=[];for(let W of J)for(let Z of W.references){let Y=Q.getSourceFile(Z.fileName);if(!Y)continue;z.push(I1(Z,Y))}return z}findEnrichedAt(_,$){let J=this.#$(_,$);if(!J)return[];let Q=this.#_.getProgram(),z=Q.getTypeChecker(),W=[];for(let Z of J){let Y=this.#J(Z,Q,z);for(let X of Z.references){let K=Q.getSourceFile(X.fileName);if(!K)continue;let V=e(K,X.textSpan.start),L=V&&p.isIdentifier(V)?V:void 0;W.push({...I1(X,K),writeKind:L?P0(L):void 0,isAmbient:Y,enclosingScope:b0(L??K)})}}return W}findFileBindings(_){if(this.#_.isDisposed)return[];let $=this.#_.getProgram(),J=$.getSourceFile(_);if(!J)return[];let Q=$.getTypeChecker(),z=new Map,W=(Y)=>{if(p.isIdentifier(Y)&&!OQ(Y)){let X=MQ(Y,Q);if(X){let K=z.get(X);if(K)K.push(Y);else z.set(X,[Y])}}p.forEachChild(Y,W)};p.forEachChild(J,W);let Z=[];for(let[Y,X]of z){let K=Y.declarations;if(!K||K.length===0)continue;if(K.every(HQ))continue;let V=K.every(u0),L=new Set(K.map((F)=>p.getNameOfDeclaration(F)).filter((F)=>F!==void 0)),D=K[0],N=p.getNameOfDeclaration(D)??D,w=D.getSourceFile(),R=X.map((F)=>{let S=F.getStart(J),{line:u,character:E}=J.getLineAndCharacterOfPosition(S),y=P0(F);return{filePath:J.fileName,position:S,line:u+1,column:E,isDefinition:L.has(F),isWrite:y!==void 0,writeKind:y,isAmbient:V,enclosingScope:b0(F)}});Z.push({declaration:{filePath:w.fileName,position:N.getStart(w),name:Y.getName(),isAmbient:V},references:R})}return Z}#$(_,$){if(this.#_.isDisposed)return null;let Q=this.#_.getProgram().getSourceFile(_);if(!Q)return null;let z=e(Q,$);if(!z||!p.isIdentifier(z))return null;let W=this.#_.getLanguageService().findReferences(_,$);if(!W||W.length===0)return null;return W}#J(_,$,J){let Q=_.definition,z=$.getSourceFile(Q.fileName);if(!z)return!1;let W=e(z,Q.textSpan.start);if(!W)return!1;let Y=J.getSymbolAtLocation(W)?.declarations;if(!Y||Y.length===0)return!1;return Y.every(u0)}}function OQ(_){let $=_.parent;return p.isPropertyAccessExpression($)&&$.name===_||p.isQualifiedName($)&&$.right===_||p.isPropertyAssignment($)&&$.name===_||p.isBindingElement($)&&$.propertyName===_||p.isJsxAttribute($)&&$.name===_||p.isImportSpecifier($)&&$.propertyName===_||p.isModuleDeclaration($)&&$.name===_&&($.flags&p.NodeFlags.GlobalAugmentation)!==0}function HQ(_){return p.isPropertyDeclaration(_)||p.isPropertySignature(_)||p.isMethodDeclaration(_)||p.isMethodSignature(_)||p.isGetAccessorDeclaration(_)||p.isSetAccessorDeclaration(_)||p.isEnumMember(_)||p.isParameter(_)&&p.isIndexSignatureDeclaration(_.parent)}function MQ(_,$){let J=_.parent;if(p.isShorthandPropertyAssignment(J))return $.getShorthandAssignmentValueSymbol(J);if(p.isExportSpecifier(J)){let Q=J.parent.parent;if(p.isExportDeclaration(Q)&&Q.moduleSpecifier)return;return(J.propertyName??J.name)===_?$.getExportSpecifierLocalTargetSymbol(J):void 0}return $.getSymbolAtLocation(_)}function I1(_,$){let{line:J,character:Q}=$.getLineAndCharacterOfPosition(_.textSpan.start);return{filePath:_.fileName,position:_.textSpan.start,line:J+1,column:Q,isDefinition:_.isDefinition??!1,isWrite:_.isWriteAccess??!1}}import h from"typescript";function KQ(_,$){let J=e(_,$);if(!J)return;if(C1(J))return J;let Q=J.parent;for(let z=0;z<5&&Q;z++){if(C1(Q))return Q;Q=Q.parent}return J}function C1(_){return h.isClassDeclaration(_)||h.isClassExpression(_)||h.isFunctionDeclaration(_)||h.isFunctionExpression(_)||h.isArrowFunction(_)||h.isVariableDeclaration(_)||h.isObjectLiteralExpression(_)}function D1(_){if(h.isClassDeclaration(_)||h.isClassExpression(_))return"class";if(h.isFunctionDeclaration(_)||h.isFunctionExpression(_)||h.isArrowFunction(_))return"function";if(h.isObjectLiteralExpression(_))return"object";if(h.isVariableDeclaration(_)&&_.initializer)return D1(_.initializer);return"class"}function LQ(_,$){if(h.isClassDeclaration(_)||h.isFunctionDeclaration(_))return _.name?.getText($)??"";if(h.isClassExpression(_))return _.name?.getText($)??"";if(h.isVariableDeclaration(_)&&h.isIdentifier(_.name))return _.name.getText($);if(h.isFunctionExpression(_))return _.name?.getText($)??"";if(h.isArrowFunction(_)&&_.parent&&h.isVariableDeclaration(_.parent)){if(h.isIdentifier(_.parent.name))return _.parent.name.getText($)}if(h.isObjectLiteralExpression(_)&&_.parent&&h.isVariableDeclaration(_.parent)){if(h.isIdentifier(_.parent.name))return _.parent.name.getText($)}return""}function BQ(_){if(!h.isClassDeclaration(_)&&!h.isClassExpression(_))return!1;let $=_.heritageClauses;if(!$)return!1;return $.some((J)=>J.token===h.SyntaxKind.ImplementsKeyword)}class y0{#_;constructor(_){this.#_=_}findAt(_,$){if(this.#_.isDisposed)return[];let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return[];let z=e(Q,$);if(!z||!h.isIdentifier(z))return[];let Z=this.#_.getLanguageService().getImplementationAtPosition(_,$);if(!Z||Z.length===0)return[];let Y=[];for(let X of Z){if(X.kind===h.ScriptElementKind.interfaceElement||X.kind===h.ScriptElementKind.typeElement)continue;let K=J.getSourceFile(X.fileName);if(!K)continue;let V=KQ(K,X.textSpan.start);if(!V)continue;let L=D1(V),D=LQ(V,K),N=BQ(V);Y.push({filePath:X.fileName,symbolName:D,position:X.textSpan.start,kind:L,isExplicit:N})}return Y}}function IQ(_){if(__.isFunctionDeclaration(_))return"function";if(__.isClassDeclaration(_))return"class";if(__.isInterfaceDeclaration(_))return"interface";if(__.isTypeAliasDeclaration(_))return"type";if(__.isEnumDeclaration(_))return"enum";if(__.isVariableDeclaration(_))return"const";if(__.isVariableStatement(_))return"const";return"unknown"}function A1(_){if(_>=97&&_<=122)return!0;if(_>=65&&_<=90)return!0;if(_>=48&&_<=57)return!0;if(_===95||_===36)return!0;return!1}class W0{#_;#$;#J;#z;#W;#Y=!1;constructor(_,$,J,Q,z){this.#_=_,this.#$=$,this.#J=J,this.#z=Q,this.#W=z}static create(_,$={}){let J=J0.create(_,{readConfigFile:$.readConfigFile,resolveNonTrackedFile:$.resolveNonTrackedFile});if(wQ(J))return J;let Q=J,z=$.typeCollector??new E0(Q),W=$.symbolGraph??new v0(Q),Z=$.referenceResolver??new f0(Q),Y=$.implementationFinder??new y0(Q);return new W0(Q,z,W,Z,Y)}get isDisposed(){return this.#Y}collectTypeAt(_,$){return this.#Q(),this.#$.collectAt(_,$)}collectFileTypes(_){return this.#Q(),this.#$.collectFile(_)}collectTypesAtPositions(_,$){return this.#Q(),this.#$.collectAtPositions(_,$)}findReferences(_,$){return this.#Q(),this.#z.findAt(_,$)}findEnrichedReferences(_,$){return this.#Q(),this.#z.findEnrichedAt(_,$)}getFileBindings(_){return this.#Q(),this.#z.findFileBindings(_)}findImplementations(_,$){return this.#Q(),this.#W.findAt(_,$)}isTypeAssignableTo(_,$,J,Q){return this.#Q(),this.#$.isAssignableTo(_,$,J,Q)}isTypeAssignableToType(_,$,J,Q){return this.#Q(),this.#$.isAssignableToType(_,$,J,Q)}isTypeAssignableToTypeAtPositions(_,$,J,Q){return this.#Q(),this.#$.isAssignableToTypeAtPositions(_,$,J,Q)}getSymbolNode(_,$){return this.#Q(),this.#J.get(_,$)}getBaseTypes(_,$){this.#Q();let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return null;let z=e(Q,$);if(!z)return null;let W=J.getTypeChecker(),Z=W.getTypeAtLocation(z);if(!(Z.flags&__.TypeFlags.Object)||!(Z.objectFlags&__.ObjectFlags.ClassOrInterface))return null;let Y=W.getBaseTypes(Z);if(!Y||Y.length===0)return[];let X=new Map;return Y.map((K)=>L_(W,K,0,X))}getModuleInterface(_){this.#Q();let $=[],J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return{filePath:_,exports:$};let z=J.getTypeChecker(),W=z.getSymbolAtLocation(Q);if(W){let Z=z.getExportsOfModule(W),Y=new Map;for(let X of Z){let K=X.getName(),V=X.declarations?.[0],L="unknown";if(V){if(L=IQ(V),L==="unknown"&&__.isExportAssignment(V))L="const"}let D=null;try{let N=z.getTypeOfSymbolAtLocation(X,V??Q);D=L_(z,N,0,Y)}catch{}$.push({name:K,kind:L,resolvedType:D})}}return{filePath:_,exports:$}}notifyFileChanged(_,$){if(this.#Y)return;this.#_.notifyFileChanged(_,$),this.#J.invalidate(_)}notifyFileDeleted(_){if(this.#Y)return;this.#_.removeFile(_),this.#J.invalidate(_)}lineColumnToPosition(_,$,J){this.#Q();let Q=this.#_.getProgram().getSourceFile(_);if(!Q)return null;try{return __.getPositionOfLineAndCharacter(Q,$-1,J)}catch{return null}}findNamePosition(_,$,J){this.#Q();let Q=this.#_.getProgram().getSourceFile(_);if(!Q)return null;let z=Q.getFullText(),W=$;while(W<z.length){let Z=z.indexOf(J,W);if(Z<0)return null;let Y=Z>0?z.charCodeAt(Z-1):32,X=Z+J.length<z.length?z.charCodeAt(Z+J.length):32;if(!A1(Y)&&!A1(X))return Z;W=Z+1}return null}getDiagnostics(_,$){this.#Q();let J=this.#_.getProgram(),Q=J.getSourceFile(_);if(!Q)return[];let z={[__.DiagnosticCategory.Error]:"error",[__.DiagnosticCategory.Warning]:"warning",[__.DiagnosticCategory.Suggestion]:"suggestion",[__.DiagnosticCategory.Message]:"suggestion"};return(($?.preEmit)?__.getPreEmitDiagnostics(J,Q):J.getSemanticDiagnostics(Q)).map((Z)=>{let Y=1,X=0;if(Z.file&&Z.start!==void 0){let K=__.getLineAndCharacterOfPosition(Z.file,Z.start);Y=K.line+1,X=K.character}return{filePath:Z.file?.fileName??_,line:Y,column:X,message:__.flattenDiagnosticMessageText(Z.messageText,`
|
|
10
|
+
`),code:Z.code,category:z[Z.category]??"error"}})}dispose(){if(this.#Y)return;this.#Y=!0,this.#$.clearProbe(),this.#_.dispose(),this.#J.clear()}#Q(){if(this.#Y)throw Error("SemanticLayer is disposed")}}import{eq as S_,and as q1,sql as CQ}from"drizzle-orm";var N1=80;class x0{db;constructor(_){this.db=_}insertBatch(_,$,J){if(!J.length)return;let Q=J.map((z)=>({project:_,filePath:$,tag:z.tag,value:z.value,source:z.source,symbolName:z.symbolName,startLine:z.startLine,startColumn:z.startColumn,endLine:z.endLine,endColumn:z.endColumn,indexedAt:z.indexedAt}));for(let z=0;z<Q.length;z+=N1)this.db.drizzleDb.insert(Z_).values(Q.slice(z,z+N1)).run()}deleteFileAnnotations(_,$){this.db.drizzleDb.delete(Z_).where(q1(S_(Z_.project,_),S_(Z_.filePath,$))).run()}search(_){let $=this.db.drizzleDb.select().from(Z_).where(q1(_.project?S_(Z_.project,_.project):void 0,_.tag?S_(Z_.tag,_.tag):void 0,_.filePath?S_(Z_.filePath,_.filePath):void 0,_.symbolName?S_(Z_.symbolName,_.symbolName):void 0,_.source?S_(Z_.source,_.source):void 0,_.ftsQuery?CQ`${Z_.id} IN (SELECT rowid FROM annotations_fts WHERE annotations_fts MATCH ${_.ftsQuery})`:void 0));return(_.limit!==void 0?$.limit(_.limit):$).all()}}import{eq as b_,and as R1,sql as i_,gt as DQ,gte as AQ}from"drizzle-orm";var T1=80;class h0{db;constructor(_){this.db=_}insertBatch(_){if(!_.length)return;let $=_.map((J)=>({project:J.project,changeType:J.changeType,symbolName:J.symbolName,symbolKind:J.symbolKind,filePath:J.filePath,oldName:J.oldName,oldFilePath:J.oldFilePath,fingerprint:J.fingerprint,changedAt:J.changedAt,isFullIndex:J.isFullIndex,indexRunId:J.indexRunId}));for(let J=0;J<$.length;J+=T1)this.db.drizzleDb.insert($_).values($.slice(J,J+T1)).run()}getSince(_){return this.db.drizzleDb.select().from($_).where(R1(b_($_.project,_.project),AQ($_.changedAt,_.since),_.symbolName?b_($_.symbolName,_.symbolName):void 0,_.changeTypes?.length?i_`${$_.changeType} IN (${i_.join(_.changeTypes.map(($)=>i_`${$}`),i_`, `)})`:void 0,_.filePath?b_($_.filePath,_.filePath):void 0,_.includeFullIndex?void 0:b_($_.isFullIndex,0),_.indexRunId?b_($_.indexRunId,_.indexRunId):void 0,_.afterId?DQ($_.id,_.afterId):void 0)).orderBy($_.id).limit(_.limit).all()}pruneOlderThan(_,$){return this.db.drizzleDb.delete($_).where(R1(b_($_.project,_),i_`${$_.changedAt} < ${$}`)).run().changes}}function G1(_){let{annotationRepo:$,project:J,query:Q}=_,z=Q.project??J,W;if(Q.text){let Y=g_(Q.text);if(Y)W=Y}return $.search({project:z,tag:Q.tag,filePath:Q.filePath,symbolName:Q.symbolName,source:Q.source,ftsQuery:W,limit:Q.limit}).map((Y)=>({tag:Y.tag,value:Y.value,source:Y.source,filePath:Y.filePath,symbolName:Y.symbolName,span:{start:{line:Y.startLine,column:Y.startColumn},end:{line:Y.endLine,column:Y.endColumn}}}))}class Y0{options;adjacencyList=new Map;reverseAdjacencyList=new Map;constructor(_){this.options=_}build(){this.adjacencyList=new Map,this.reverseAdjacencyList=new Map;let $=[this.options.project,...this.options.additionalProjects??[]].flatMap((J)=>[...this.options.relationRepo.getByType(J,"imports"),...this.options.relationRepo.getByType(J,"type-references"),...this.options.relationRepo.getByType(J,"re-exports")]);for(let J of $){let{srcFilePath:Q,dstFilePath:z}=J;if(z===null)continue;if(!this.adjacencyList.has(Q))this.adjacencyList.set(Q,new Set);if(this.adjacencyList.get(Q).add(z),!this.adjacencyList.has(z))this.adjacencyList.set(z,new Set);if(!this.reverseAdjacencyList.has(z))this.reverseAdjacencyList.set(z,new Set);this.reverseAdjacencyList.get(z).add(Q)}}patchFiles(_,$,J){let Q=new Set([..._,...$]);for(let z of Q){let W=this.adjacencyList.get(z);if(W){for(let Y of W)this.reverseAdjacencyList.get(Y)?.delete(z);W.clear()}let Z=this.reverseAdjacencyList.get(z);if(Z){for(let Y of Z)this.adjacencyList.get(Y)?.delete(z);Z.clear()}}for(let z of $)this.adjacencyList.delete(z),this.reverseAdjacencyList.delete(z);for(let z of _){let W=J(z);for(let Z of W){if(!this.adjacencyList.has(Z.srcFilePath))this.adjacencyList.set(Z.srcFilePath,new Set);if(this.adjacencyList.get(Z.srcFilePath).add(Z.dstFilePath),!this.adjacencyList.has(Z.dstFilePath))this.adjacencyList.set(Z.dstFilePath,new Set);if(!this.reverseAdjacencyList.has(Z.dstFilePath))this.reverseAdjacencyList.set(Z.dstFilePath,new Set);this.reverseAdjacencyList.get(Z.dstFilePath).add(Z.srcFilePath)}}}getDependencies(_){return Array.from(this.adjacencyList.get(_)??[])}getDependents(_){return Array.from(this.reverseAdjacencyList.get(_)??[])}getTransitiveDependents(_){let $=new Set,J=[_];while(J.length>0){let Q=J.shift();for(let z of this.reverseAdjacencyList.get(Q)??[])if(!$.has(z))$.add(z),J.push(z)}return Array.from($)}hasCycle(){let _=new Set,$=new Set;for(let J of this.adjacencyList.keys()){if(_.has(J))continue;let Q=[{node:J,entered:!1}];while(Q.length>0){let z=Q.pop();if(z.entered){$.delete(z.node);continue}if($.has(z.node))return!0;if(_.has(z.node))continue;_.add(z.node),$.add(z.node),Q.push({node:z.node,entered:!0});for(let W of this.adjacencyList.get(z.node)??[]){if($.has(W))return!0;if(!_.has(W))Q.push({node:W,entered:!1})}}}return!1}getAffectedByChange(_){let $=new Set;for(let J of _)for(let Q of this.getTransitiveDependents(J))$.add(Q);return Array.from($)}getAdjacencyList(){let _=new Map;for(let[$,J]of this.adjacencyList)_.set($,Array.from(J));return _}getTransitiveDependencies(_){let $=new Set,J=[_];while(J.length>0){let Q=J.shift();for(let z of this.adjacencyList.get(Q)??[])if(!$.has(z))$.add(z),J.push(z)}return Array.from($)}getCyclePaths(_){let $=_?.maxCycles??1/0;if($<=0)return[];let J=new Map;for(let[Q,z]of this.adjacencyList)J.set(Q,Array.from(z));return GQ(J,$)}}var qQ=(_,$)=>_.localeCompare($);function NQ(_){let $=_.length>1&&_[0]===_[_.length-1]?_.slice(0,-1):[..._];if($.length===0)return[];let J=$;for(let Q=1;Q<$.length;Q++){let z=$.slice(Q).concat($.slice(0,Q));if(z.join("::")<J.join("::"))J=z}return[...J]}function m0(_,$,J){let Q=NQ(J);if(Q.length===0)return!1;let z=Q.join("->");if(_.has(z))return!1;return _.add(z),$.push(Q),!0}function RQ(_){let $=0,J=[],Q=new Set,z=new Map,W=new Map,Z=[],Y=(X)=>{z.set(X,$),W.set(X,$),$+=1,J.push(X),Q.add(X);for(let K of _.get(X)??[])if(!z.has(K))Y(K),W.set(X,Math.min(W.get(X)??0,W.get(K)??0));else if(Q.has(K))W.set(X,Math.min(W.get(X)??0,z.get(K)??0));if(W.get(X)===z.get(X)){let K=[],V="";do V=J.pop()??"",Q.delete(V),K.push(V);while(V!==X&&J.length>0);Z.push(K)}};for(let X of _.keys())if(!z.has(X))Y(X);return{components:Z}}function TQ(_,$,J){let Q=[],z=new Set,W=[..._].sort(qQ),Z=(Y,X,K)=>{X.delete(Y);let V=K.get(Y);if(!V)return;for(let L of V)if(X.has(L))Z(L,X,K);V.clear()};for(let Y=0;Y<W.length&&Q.length<J;Y++){let X=W[Y]??"",K=new Set(W.slice(Y)),V=new Set,L=new Map,D=[],N=(R)=>($.get(R)??[]).filter((F)=>K.has(F)),w=(R)=>{if(Q.length>=J)return!0;let F=!1;D.push(R),V.add(R);for(let S of N(R)){if(Q.length>=J)break;if(S===X)m0(z,Q,D.concat(X)),F=!0;else if(!V.has(S)){if(w(S))F=!0}}if(F)Z(R,V,L);else for(let S of N(R)){let u=L.get(S)??new Set;u.add(R),L.set(S,u)}return D.pop(),F};w(X)}return Q}function GQ(_,$){let{components:J}=RQ(_),Q=[],z=new Set;for(let W of J){if(Q.length>=$)break;if(W.length===0)continue;if(W.length===1){let X=W[0]??"";if((_.get(X)??[]).includes(X))m0(z,Q,[X,X]);continue}let Z=$-Q.length,Y=TQ(W,_,Z);for(let X of Y){if(Q.length>=$)break;m0(z,Q,X)}}return Q}var SQ=15000;function Z0(_){_.graphCache=null,_.graphCacheKey=null,_.graphCacheBuiltAt=null}function F_(_,$){let J=$??"__cross__";if(_.graphCache&&_.graphCacheBuiltAt!==null){if(Date.now()-_.graphCacheBuiltAt>SQ)_.graphCache=null,_.graphCacheKey=null,_.graphCacheBuiltAt=null}if(_.graphCache&&_.graphCacheKey===J)return _.graphCache;let Q=new Y0({relationRepo:_.relationRepo,project:$??_.defaultProject,additionalProjects:$?void 0:_.boundaries?.map((z)=>z.project)});return Q.build(),_.graphCache=Q,_.graphCacheKey=J,_.graphCacheBuiltAt=Date.now(),Q}function S1(_,$,J,Q=1e4){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:J??_.defaultProject,query:{srcFilePath:$,type:"imports",project:J??_.defaultProject,limit:Q}}).filter((z)=>z.dstFilePath!==null).map((z)=>z.dstFilePath)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getDependencies failed",{cause:z})}}function F1(_,$,J,Q=1e4){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:J??_.defaultProject,query:{dstFilePath:$,type:"imports",project:J??_.defaultProject,limit:Q}}).map((z)=>z.srcFilePath)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getDependents failed",{cause:z})}}async function j1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return F_(_,J).getAffectedByChange($)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getAffected failed",{cause:Q})}}async function g1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return F_(_,$).hasCycle()}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: hasCycle failed",{cause:J})}}async function k1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return F_(_,$).getAdjacencyList()}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: getImportGraph failed",{cause:J})}}async function E1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return F_(_,J).getTransitiveDependencies($)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getTransitiveDependencies failed",{cause:Q})}}async function v1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return F_(_,J).getTransitiveDependents($)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getTransitiveDependents failed",{cause:Q})}}async function u1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return F_(_,$).getCyclePaths(J)}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getCyclePaths failed",{cause:Q})}}async function b1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let Q=F_(_,J);return{filePath:$,fanIn:Q.getDependents($).length,fanOut:Q.getDependencies($).length}}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getFanMetrics failed",{cause:Q})}}var gQ=30000,P1=15000,kQ=10;function EQ(_,$){_.boundaries=$,_.defaultProject=$[0]?.project??P_.basename(_.projectRoot)}function vQ(_,$){return(J)=>{for(let Q of _.onFileChangedCallbacks)try{Q(J)}catch(z){_.logger.error("[Gildash] onFileChanged callback threw:",z)}if($.handleWatcherEvent?.(J),_.semanticLayer)if(J.eventType==="delete")try{_.semanticLayer.notifyFileDeleted(J.filePath)}catch(Q){_.logger.error("[Gildash] semanticLayer.notifyFileDeleted threw:",Q);for(let z of _.onErrorCallbacks)try{z(Q instanceof O?Q:new O("semantic","semantic notifyFileDeleted failed",{cause:Q}))}catch{}}else _.readFileFn(J.filePath).then((Q)=>{try{_.semanticLayer?.notifyFileChanged(J.filePath,Q)}catch(z){_.logger.error("[Gildash] semanticLayer.notifyFileChanged threw:",z);for(let W of _.onErrorCallbacks)try{W(z instanceof O?z:new O("semantic","semantic notifyFileChanged failed",{cause:z}))}catch{}}}).catch((Q)=>{_.logger.error("[Gildash] failed to read file for semantic layer",J.filePath,Q);try{_.semanticLayer?.notifyFileDeleted(J.filePath)}catch(z){_.logger.error("[Gildash] semanticLayer.notifyFileDeleted threw during read error recovery:",z)}})}}async function uQ(_){if(!_.semanticLayer)return;let $=_.fileRepo.getAllFiles(_.defaultProject);await Promise.all($.map(async(J)=>{try{let Q=P_.resolve(_.projectRoot,J.filePath),z=await _.readFileFn(Q);_.semanticLayer?.notifyFileChanged(Q,z)}catch{}}))}async function f1(_,$){let J=_.coordinatorFactory?_.coordinatorFactory():new T0({projectRoot:_.projectRoot,boundaries:_.boundaries,extensions:_.extensions,ignorePatterns:_.ignorePatterns,dbConnection:_.db,parseCache:_.parseCache,fileRepo:_.fileRepo,symbolRepo:_.symbolRepo,relationRepo:_.relationRepo,annotationRepo:_.annotationRepo??void 0,changelogRepo:_.changelogRepo??void 0,onBoundariesChanged:(Q)=>EQ(_,Q),logger:_.logger});_.coordinator=J;for(let Q of _.onIndexedCallbacks)J.onIndexed(Q);if(J.onIndexed((Q)=>{let z=Q.changedFiles.length+Q.deletedFiles.length;if(_.graphCache&&z>0&&z<100){let W=_.relationRepo;_.graphCache.patchFiles(Q.changedFiles,Q.deletedFiles,(Z)=>{return[_.defaultProject,..._.boundaries.map((X)=>X.project)].flatMap((X)=>W.getByType(X,"imports").concat(W.getByType(X,"type-references")).concat(W.getByType(X,"re-exports"))).filter((X)=>X.dstFilePath!==null&&(X.srcFilePath===Z||X.dstFilePath===Z)).map((X)=>({srcFilePath:X.srcFilePath,dstFilePath:X.dstFilePath}))}),_.graphCacheBuiltAt=Date.now()}else Z0(_)}),$.isWatchMode){let Q=_.watcherFactory?_.watcherFactory():new w0({projectRoot:_.projectRoot,ignorePatterns:_.ignorePatterns,extensions:_.extensions},void 0,_.logger);await Q.start(vQ(_,J)).then((z)=>{if(c_(z))throw z.data}),_.watcher=Q,_.timer=setInterval(()=>{if(_.closed)return;_.updateHeartbeatFn(_.db,process.pid)},gQ)}await J.fullIndex(),await uQ(_)}function bQ(_,$){let J=["SIGTERM","SIGINT","beforeExit"];for(let Q of J){let z=()=>{$().catch((W)=>_.logger.error("[Gildash] close error during signal",Q,W))};if(Q==="beforeExit")process.on("beforeExit",z);else process.on(Q,z);_.signalHandlers.push([Q,z])}}async function y1(_){let{projectRoot:$,extensions:J=[".ts",".mts",".cts"],ignorePatterns:Q=["**/node_modules/**"],parseCacheCapacity:z=500,logger:W=console,existsSyncFn:Z=jQ,dbConnectionFactory:Y,watcherFactory:X,coordinatorFactory:K,repositoryFactory:V,acquireWatcherRoleFn:L=M1,releaseWatcherRoleFn:D=K1,updateHeartbeatFn:N=L1,discoverProjectsFn:w=r_,parseSourceFn:R=E_,extractSymbolsFn:F=R_,extractRelationsFn:S=d_,symbolSearchFn:u=S0,relationSearchFn:E=F0,patternSearchFn:y=j0,loadTsconfigPathsFn:l=n_,readFileFn:i=async(s)=>Bun.file(s).text(),unlinkFn:W_=async(s)=>{await Bun.file(s).unlink()},watchMode:X_,semantic:M_,semanticLayerFactory:U_}=_;if(!P_.isAbsolute($))throw new O("validation",`Gildash: projectRoot must be an absolute path, got: "${$}"`);if(!Z($))throw new O("validation",`Gildash: projectRoot does not exist: "${$}"`);let Y_=Y?Y():new H0({projectRoot:$}),c=Y_.open();if(c_(c))throw c.data;try{let s=await w($),C_=s[0]?.project??P_.basename($),C=V?V():(()=>{let G=Y_;return{fileRepo:new M0(G),symbolRepo:new K0(G),relationRepo:new L0(G),parseCache:new G0(z)}})(),q=V?null:Y_,U=q?new x0(q):null,H=q?new h0(q):null,M=X_??!0,B=crypto.randomUUID(),A;if(M)A=await Promise.resolve(L(Y_,process.pid,{instanceId:B}));else A="owner";let I={projectRoot:$,extensions:J,ignorePatterns:Q,logger:W,defaultProject:C_,role:A,db:Y_,symbolRepo:C.symbolRepo,relationRepo:C.relationRepo,fileRepo:C.fileRepo,parseCache:C.parseCache,annotationRepo:U,changelogRepo:H,annotationSearchFn:G1,releaseWatcherRoleFn:D,parseSourceFn:R,extractSymbolsFn:F,extractRelationsFn:S,symbolSearchFn:u,relationSearchFn:E,patternSearchFn:y,readFileFn:i,unlinkFn:W_,existsSyncFn:Z,acquireWatcherRoleFn:L,updateHeartbeatFn:N,watcherFactory:X,coordinatorFactory:K,instanceId:B,closed:!1,coordinator:null,watcher:null,timer:null,signalHandlers:[],tsconfigPaths:null,boundaries:s,onIndexedCallbacks:new Set,onFileChangedCallbacks:new Set,onErrorCallbacks:new Set,onRoleChangedCallbacks:new Set,graphCache:null,graphCacheKey:null,graphCacheBuiltAt:null,semanticLayer:null};if(o_($),I.tsconfigPaths=await l($),M_){let G=P_.join($,"tsconfig.json");try{if(U_)I.semanticLayer=U_(G);else{let T=W0.create(G);if(c_(T))throw T.data;I.semanticLayer=T}}catch(T){if(T instanceof O)throw T;throw new O("semantic","Gildash: semantic layer creation failed",{cause:T})}}if(A==="owner")await f1(I,{isWatchMode:M});else{let G=0,T=async()=>{try{let j=await Promise.resolve(I.acquireWatcherRoleFn(I.db,process.pid,{instanceId:I.instanceId}));if(G=0,j==="owner"){I.role="owner";for(let k of I.onRoleChangedCallbacks)try{k("owner")}catch(b){I.logger.error("[Gildash] onRoleChanged callback threw:",b)}clearInterval(I.timer),I.timer=null;try{await f1(I,{isWatchMode:!0})}catch(k){if(I.logger.error("[Gildash] owner promotion failed, reverting to reader",k),I.role="reader",I.timer!==null)clearInterval(I.timer),I.timer=null;if(I.watcher){let b=await I.watcher.close();if(c_(b))I.logger.error("[Gildash] watcher close error during promotion rollback",b.data);I.watcher=null}if(I.coordinator)await I.coordinator.shutdown().catch((b)=>I.logger.error("[Gildash] coordinator shutdown error during promotion rollback",b)),I.coordinator=null;try{I.releaseWatcherRoleFn(I.db,process.pid)}catch(b){I.logger.error("[Gildash] failed to release watcher role during promotion rollback",b)}I.timer=setInterval(T,P1)}}}catch(j){G++;let k=j instanceof O?j:new O("watcher","Gildash: healthcheck error",{cause:j});for(let b of I.onErrorCallbacks)try{b(k)}catch(d){I.logger.error("[Gildash] onError callback threw:",d)}if(I.logger.error("[Gildash] healthcheck error",j),G>=kQ)I.logger.error("[Gildash] healthcheck failed too many times, shutting down"),clearInterval(I.timer),I.timer=null,X0(I).catch((b)=>I.logger.error("[Gildash] close error during healthcheck shutdown",b))}};I.timer=setInterval(T,P1)}if(M)bQ(I,()=>X0(I));return I}catch(s){if(Y_.close(),s instanceof O)throw s;throw new O("store","Gildash: initialization failed",{cause:s})}}async function X0(_,$){if(_.closed)return;_.closed=!0;let J=[];for(let[Q,z]of _.signalHandlers)if(Q==="beforeExit")process.off("beforeExit",z);else process.off(Q,z);if(_.signalHandlers=[],_.semanticLayer){try{_.semanticLayer.dispose()}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}_.semanticLayer=null}if(_.coordinator)try{await _.coordinator.shutdown()}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}if(_.watcher){let Q=await _.watcher.close();if(c_(Q))J.push(Q.data)}if(_.timer!==null)clearInterval(_.timer),_.timer=null;try{_.releaseWatcherRoleFn(_.db,process.pid)}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}try{_.db.close()}catch(Q){J.push(Q instanceof Error?Q:Error(String(Q)))}if($?.cleanup)for(let Q of["","-wal","-shm"])try{await _.unlinkFn(P_.join(_.projectRoot,A_,a_+Q))}catch{}if(J.length>0)throw new O("close","Gildash: one or more errors occurred during close()",{cause:J})}import{isErr as x1}from"@zipbul/result";function h1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");let z=_.parseSourceFn($,J,Q);if(x1(z))throw z.data;return _.parseCache.set($,z),z}async function m1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");let Q=new Map,z=[];return await Promise.all($.map(async(W)=>{try{let Z=await _.readFileFn(W),Y=_.parseSourceFn(W,Z,J);if(!x1(Y))Q.set(W,Y);else z.push({filePath:W,error:Y.data})}catch(Z){z.push({filePath:W,error:Z instanceof Error?Z:Error(String(Z))})}})),{parsed:Q,failures:z}}function n1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");return _.parseCache.get($)}function p1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");return _.extractSymbolsFn($)}function d1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");return _.extractRelationsFn($.program,$.filePath,_.tsconfigPaths??void 0)}import l1 from"path";function i1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.symbolRepo.getStats($??_.defaultProject)}catch(J){if(J instanceof O)throw J;throw new O("store","Gildash: getStats failed",{cause:J})}}function n0(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.symbolSearchFn({symbolRepo:_.symbolRepo,project:_.defaultProject,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchSymbols failed",{cause:J})}}function c1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:_.defaultProject,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchRelations failed",{cause:J})}}function a1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.symbolSearchFn({symbolRepo:_.symbolRepo,project:void 0,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchAllSymbols failed",{cause:J})}}function s1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:void 0,query:$})}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: searchAllRelations failed",{cause:J})}}function r1(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.fileRepo.getAllFiles($??_.defaultProject)}catch(J){if(J instanceof O)throw J;throw new O("store","Gildash: listIndexedFiles failed",{cause:J})}}function o1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.relationSearchFn({relationRepo:_.relationRepo,project:J??_.defaultProject,query:{srcFilePath:$,dstFilePath:$,limit:1e4}})}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getInternalRelations failed",{cause:Q})}}function t1(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let z=Q??_.defaultProject,W=_.symbolSearchFn({symbolRepo:_.symbolRepo,project:z,query:{text:$,exact:!0,filePath:J,limit:1}});if(W.length===0)return null;let Z=W[0],Y=Z.detail,X={...Z,members:Y.members,jsDoc:Y.jsDoc,parameters:Y.parameters,returnType:Y.returnType,heritage:Y.heritage,decorators:Y.decorators,typeParameters:Y.typeParameters,initializer:Y.initializer};if(_.semanticLayer)try{let K=l1.isAbsolute(J)?J:l1.resolve(_.projectRoot,J),V=_.semanticLayer.lineColumnToPosition(K,Z.span.start.line,Z.span.start.column);if(V!==null){let L=_.semanticLayer.findNamePosition(K,V,Z.name)??V,D=_.semanticLayer.collectTypeAt(K,L);if(D)X.resolvedType=D}}catch{}return X}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getFullSymbol failed",{cause:z})}}function e1(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let Q=J??_.defaultProject,z=_.fileRepo.getFile(Q,$);if(!z)throw new O("search",`Gildash: file '${$}' is not in the index`);let W=_.symbolRepo.getFileSymbols(Q,$),Z=_.relationRepo.getOutgoing(Q,$);return{filePath:z.filePath,lineCount:z.lineCount??0,size:z.size,symbolCount:W.length,exportedSymbolCount:W.filter((Y)=>Y.isExported).length,relationCount:Z.length}}catch(Q){if(Q instanceof O)throw Q;throw new O("store","Gildash: getFileStats failed",{cause:Q})}}function _$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{return _.fileRepo.getFile(J??_.defaultProject,$)}catch(Q){if(Q instanceof O)throw Q;throw new O("store","Gildash: getFileInfo failed",{cause:Q})}}function $$(_,$,J){return n0(_,{filePath:$,project:J??void 0,limit:1e4})}function J$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let z=_.symbolSearchFn({symbolRepo:_.symbolRepo,project:J??_.defaultProject,query:{filePath:$,isExported:!0}}).map((W)=>({name:W.name,kind:W.kind,parameters:W.detail.parameters?`(${W.detail.parameters.map((Z)=>`${Z.name}${Z.isOptional?"?":""}: ${Z.type??"unknown"}`).join(", ")})`:void 0,returnType:W.detail.returnType??void 0,jsDoc:W.detail.jsDoc?.description??void 0}));return{filePath:$,exports:z}}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: getModuleInterface failed",{cause:Q})}}import f from"path";function f_(_,$,J,Q){let z=Q??_.defaultProject,W=f.isAbsolute(J)?f.relative(_.projectRoot,J):J,Z=_.symbolSearchFn({symbolRepo:_.symbolRepo,project:z,query:{text:$,exact:!0,filePath:W,limit:1}});if(Z.length===0)return null;let Y=Z[0],X=f.isAbsolute(J)?J:f.resolve(_.projectRoot,J),K=_.semanticLayer.lineColumnToPosition(X,Y.span.start.line,Y.span.start.column);if(K===null)return null;let V=_.semanticLayer.findNamePosition(X,K,Y.name)??K;return{sym:Y,position:V,absPath:X}}function Q$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f_(_,$,J,Q);if(!z)return null;return _.semanticLayer.collectTypeAt(z.absPath,z.position)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getResolvedType failed",{cause:z})}}function z$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f_(_,$,J,Q);if(!z)throw new O("search",`Gildash: symbol '${$}' not found in '${J}'`);return _.semanticLayer.findReferences(z.absPath,z.position)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getSemanticReferences failed",{cause:z})}}function W$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f_(_,$,J,Q);if(!z)throw new O("search",`Gildash: symbol '${$}' not found in '${J}'`);return _.semanticLayer.findEnrichedReferences(z.absPath,z.position)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getEnrichedReferences failed",{cause:z})}}function Y$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f_(_,$,J,Q);if(!z)throw new O("search",`Gildash: symbol '${$}' not found in '${J}'`);return _.semanticLayer.findImplementations(z.absPath,z.position)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getImplementations failed",{cause:z})}}function Z$(_,$,J,Q,z,W){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Z=f_(_,$,J,W);if(!Z)throw new O("search",`Gildash: source symbol '${$}' not found in '${J}'`);let Y=f_(_,Q,z,W);if(!Y)throw new O("search",`Gildash: target symbol '${Q}' not found in '${z}'`);return _.semanticLayer.isTypeAssignableTo(Z.absPath,Z.position,Y.absPath,Y.position)}catch(Z){if(Z instanceof O)throw Z;throw new O("semantic","Gildash: isTypeAssignableTo failed",{cause:Z})}}function X$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let J=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.collectFileTypes(J)}catch(J){if(J instanceof O)throw J;throw new O("semantic","Gildash: getFileTypes failed",{cause:J})}}function U$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f.isAbsolute($)?$:f.resolve(_.projectRoot,$),W=_.semanticLayer.lineColumnToPosition(z,J,Q);if(W===null)return null;return _.semanticLayer.collectTypeAt(z,W)}catch(z){if(z instanceof O)throw z;throw new O("semantic","Gildash: getResolvedTypeAt failed",{cause:z})}}function V$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let J=f.isAbsolute($.source.filePath)?$.source.filePath:f.resolve(_.projectRoot,$.source.filePath),Q=f.isAbsolute($.target.filePath)?$.target.filePath:f.resolve(_.projectRoot,$.target.filePath),z=_.semanticLayer.lineColumnToPosition(J,$.source.line,$.source.column);if(z===null)return null;let W=_.semanticLayer.lineColumnToPosition(Q,$.target.line,$.target.column);if(W===null)return null;return _.semanticLayer.isTypeAssignableTo(J,z,Q,W)}catch(J){if(J instanceof O)throw J;throw new O("semantic","Gildash: isTypeAssignableToAt failed",{cause:J})}}function O$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{return _.semanticLayer.getModuleInterface($)}catch(J){if(J instanceof O)throw J;throw new O("search","Gildash: getSemanticModuleInterface failed",{cause:J})}}function H$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.getBaseTypes(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getBaseTypes failed",{cause:Q})}}function M$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.collectTypesAtPositions(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getResolvedTypesAtPositions failed",{cause:Q})}}function K$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.collectTypeAt(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getResolvedTypeAtPosition failed",{cause:Q})}}function L$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.findReferences(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getSemanticReferencesAtPosition failed",{cause:Q})}}function B$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.findEnrichedReferences(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getEnrichedReferencesAtPosition failed",{cause:Q})}}function w$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let J=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.getFileBindings(J)}catch(J){if(J instanceof O)throw J;throw new O("semantic","Gildash: getFileBindings failed",{cause:J})}}function I$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.findImplementations(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getImplementationsAtPosition failed",{cause:Q})}}function C$(_,$,J,Q,z){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=f.isAbsolute($)?$:f.resolve(_.projectRoot,$),Z=f.isAbsolute(Q)?Q:f.resolve(_.projectRoot,Q);return _.semanticLayer.isTypeAssignableTo(W,J,Z,z)}catch(W){if(W instanceof O)throw W;throw new O("semantic","Gildash: isTypeAssignableToAtPosition failed",{cause:W})}}function D$(_,$,J,Q,z){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.isTypeAssignableToType(W,J,Q,z)}catch(W){if(W instanceof O)throw W;throw new O("semantic","Gildash: isTypeAssignableToType failed",{cause:W})}}function A$(_,$,J,Q,z){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let W=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.isTypeAssignableToTypeAtPositions(W,J,Q,z)}catch(W){if(W instanceof O)throw W;throw new O("semantic","Gildash: isTypeAssignableToTypeAtPositions failed",{cause:W})}}function q$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.lineColumnToPosition(z,J,Q)}catch(z){if(z instanceof O)throw z;throw new O("semantic","Gildash: lineColumnToPosition failed",{cause:z})}}function N$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let z=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.findNamePosition(z,J,Q)}catch(z){if(z instanceof O)throw z;throw new O("semantic","Gildash: findNamePosition failed",{cause:z})}}function R$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.getSymbolNode(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getSymbolNode failed",{cause:Q})}}function T$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.semanticLayer)throw new O("semantic","Gildash: semantic layer is not enabled");try{let Q=f.isAbsolute($)?$:f.resolve(_.projectRoot,$);return _.semanticLayer.getDiagnostics(Q,J)}catch(Q){if(Q instanceof O)throw Q;throw new O("semantic","Gildash: getSemanticDiagnostics failed",{cause:Q})}}function G$(_,$){let J=new Map(_.map((Y)=>[`${Y.name}::${Y.filePath}`,Y])),Q=new Map($.map((Y)=>[`${Y.name}::${Y.filePath}`,Y])),z=[],W=[],Z=[];for(let[Y,X]of Q){let K=J.get(Y);if(!K)z.push(X);else if(K.fingerprint!==X.fingerprint)Z.push({before:K,after:X})}for(let[Y,X]of J)if(!Q.has(Y))W.push(X);return{added:z,removed:W,modified:Z}}function S$(_,$){if(_.onIndexedCallbacks.add($),!_.coordinator)return()=>{_.onIndexedCallbacks.delete($)};let J=_.coordinator.onIndexed($);return()=>{_.onIndexedCallbacks.delete($),J()}}async function F$(_){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.coordinator)throw new O("closed","Gildash: reindex() is not available for readers");try{let $=await _.coordinator.fullIndex();return Z0(_),$}catch($){if($ instanceof O)throw $;throw new O("index","Gildash: reindex failed",{cause:$})}}function j$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");let z=Q??_.defaultProject,W=new Set,Z=[],Y=$,X=J;for(;;){let K=`${X}::${Y}`;if(W.has(K))return{originalName:Y,originalFilePath:X,reExportChain:Z,circular:!0};W.add(K);let V=_.relationSearchFn({relationRepo:_.relationRepo,project:z,query:{type:"re-exports",srcFilePath:X,limit:500}}),L,D;for(let N of V){let w;if(N.metaJson)try{let F=JSON.parse(N.metaJson);if(Array.isArray(F.specifiers))w=F.specifiers}catch{}if(!w)continue;let R=w.find((F)=>F.exported===Y);if(!R)continue;L=N.dstFilePath??void 0,D=R.local;break}if(!L||!D)return{originalName:Y,originalFilePath:X,reExportChain:Z,circular:!1};Z.push({filePath:X,exportedAs:Y}),X=L,Y=D}}function g$(_,$){return _.onFileChangedCallbacks.add($),()=>{_.onFileChangedCallbacks.delete($)}}function k$(_,$){return _.onErrorCallbacks.add($),()=>{_.onErrorCallbacks.delete($)}}function E$(_,$){return _.onRoleChangedCallbacks.add($),()=>{_.onRoleChangedCallbacks.delete($)}}async function v$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let Q=J?.project??_.defaultProject,z=J?.filePaths?J.filePaths:_.fileRepo.getAllFiles(Q).map((W)=>W.filePath);return await _.patternSearchFn({pattern:$,filePaths:z})}catch(Q){if(Q instanceof O)throw Q;throw new O("search","Gildash: findPattern failed",{cause:Q})}}async function u$(_,$,J,Q){if(_.closed)throw new O("closed","Gildash: instance is closed");try{let z=Q??_.defaultProject,W=new Set,Z=(Y,X,K)=>{let V=`${Y}::${X}`;if(W.has(V))return{symbolName:Y,filePath:X,kind:K,children:[]};W.add(V);let N=_.relationSearchFn({relationRepo:_.relationRepo,project:z,query:{srcFilePath:X,srcSymbolName:Y,limit:1000}}).filter((w)=>w.type==="extends"||w.type==="implements").filter((w)=>w.dstSymbolName!=null&&w.dstFilePath!=null).map((w)=>Z(w.dstSymbolName,w.dstFilePath,w.type));return{symbolName:Y,filePath:X,kind:K,children:N}};return Z($,J)}catch(z){if(z instanceof O)throw z;throw new O("search","Gildash: getHeritageChain failed",{cause:z})}}function b$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.annotationRepo||!_.annotationSearchFn)return[];return _.annotationSearchFn({annotationRepo:_.annotationRepo,project:$.project??_.defaultProject,query:$})}function P$(_,$,J){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.changelogRepo)return[];let Q=$ instanceof Date?$.toISOString():$,z=J?.project??_.defaultProject,W=J?.limit??1000;return _.changelogRepo.getSince({project:z,since:Q,symbolName:J?.symbolName,changeTypes:J?.changeTypes,filePath:J?.filePath,includeFullIndex:J?.includeFullIndex,indexRunId:J?.indexRunId,afterId:J?.afterId,limit:W}).map((Y)=>({changeType:Y.changeType,symbolName:Y.symbolName,symbolKind:Y.symbolKind,filePath:Y.filePath,oldName:Y.oldName,oldFilePath:Y.oldFilePath,fingerprint:Y.fingerprint,changedAt:Y.changedAt,isFullIndex:Y.isFullIndex===1,indexRunId:Y.indexRunId}))}function f$(_,$){if(_.closed)throw new O("closed","Gildash: instance is closed");if(!_.changelogRepo)return 0;let J=$ instanceof Date?$.toISOString():$,Q=0,z=[_.defaultProject,..._.boundaries.map((Z)=>Z.project)],W=[...new Set(z)];for(let Z of W)Q+=_.changelogRepo.pruneOlderThan(Z,J);return Q}class p0{_ctx;get projectRoot(){return this._ctx.projectRoot}get role(){return this._ctx.role}get projects(){return[...this._ctx.boundaries]}constructor(_){this._ctx=_}static async open(_){let $=await y1(_);return new p0($)}async close(_){return X0(this._ctx,_)}parseSource(_,$,J){return h1(this._ctx,_,$,J)}async batchParse(_,$){return m1(this._ctx,_,$)}getParsedAst(_){return n1(this._ctx,_)}extractSymbols(_){return p1(this._ctx,_)}extractRelations(_){return d1(this._ctx,_)}getStats(_){return i1(this._ctx,_)}searchSymbols(_){return n0(this._ctx,_)}searchRelations(_){return c1(this._ctx,_)}searchAllSymbols(_){return a1(this._ctx,_)}searchAllRelations(_){return s1(this._ctx,_)}listIndexedFiles(_){return r1(this._ctx,_)}getInternalRelations(_,$){return o1(this._ctx,_,$)}getFullSymbol(_,$,J){return t1(this._ctx,_,$,J)}getFileStats(_,$){return e1(this._ctx,_,$)}getFileInfo(_,$){return _$(this._ctx,_,$)}getSymbolsByFile(_,$){return $$(this._ctx,_,$)}getModuleInterface(_,$){return J$(this._ctx,_,$)}getDependencies(_,$,J=1e4){return S1(this._ctx,_,$,J)}getDependents(_,$,J=1e4){return F1(this._ctx,_,$,J)}async getAffected(_,$){return j1(this._ctx,_,$)}async hasCycle(_){return g1(this._ctx,_)}async getImportGraph(_){return k1(this._ctx,_)}async getTransitiveDependencies(_,$){return E1(this._ctx,_,$)}async getTransitiveDependents(_,$){return v1(this._ctx,_,$)}async getCyclePaths(_,$){return u1(this._ctx,_,$)}async getFanMetrics(_,$){return b1(this._ctx,_,$)}getResolvedType(_,$,J){return Q$(this._ctx,_,$,J)}getSemanticReferences(_,$,J){return z$(this._ctx,_,$,J)}getEnrichedReferences(_,$,J){return W$(this._ctx,_,$,J)}getImplementations(_,$,J){return Y$(this._ctx,_,$,J)}isTypeAssignableTo(_,$,J,Q,z){return Z$(this._ctx,_,$,J,Q,z)}getSemanticModuleInterface(_){return O$(this._ctx,_)}getFileTypes(_){return X$(this._ctx,_)}getResolvedTypeAt(_,$,J){return U$(this._ctx,_,$,J)}isTypeAssignableToAt(_){return V$(this._ctx,_)}getResolvedTypeAtPosition(_,$){return K$(this._ctx,_,$)}getResolvedTypesAtPositions(_,$){return M$(this._ctx,_,$)}getSemanticReferencesAtPosition(_,$){return L$(this._ctx,_,$)}getEnrichedReferencesAtPosition(_,$){return B$(this._ctx,_,$)}getFileBindings(_){return w$(this._ctx,_)}getImplementationsAtPosition(_,$){return I$(this._ctx,_,$)}isTypeAssignableToAtPosition(_,$,J,Q){return C$(this._ctx,_,$,J,Q)}isTypeAssignableToType(_,$,J,Q){return D$(this._ctx,_,$,J,Q)}isTypeAssignableToTypeAtPositions(_,$,J,Q){return A$(this._ctx,_,$,J,Q)}lineColumnToPosition(_,$,J){return q$(this._ctx,_,$,J)}findNamePosition(_,$,J){return N$(this._ctx,_,$,J)}getSymbolNode(_,$){return R$(this._ctx,_,$)}getBaseTypes(_,$){return H$(this._ctx,_,$)}getSemanticDiagnostics(_,$){return T$(this._ctx,_,$)}diffSymbols(_,$){return G$(_,$)}onIndexed(_){return S$(this._ctx,_)}async reindex(){return F$(this._ctx)}resolveSymbol(_,$,J){return j$(this._ctx,_,$,J)}async findPattern(_,$){return v$(this._ctx,_,$)}async getHeritageChain(_,$,J){return u$(this._ctx,_,$,J)}onFileChanged(_){return g$(this._ctx,_)}onError(_){return k$(this._ctx,_)}onRoleChanged(_){return E$(this._ctx,_)}searchAnnotations(_){return b$(this._ctx,_)}getSymbolChanges(_,$){return P$(this._ctx,_,$)}pruneChangelog(_){return f$(this._ctx,_)}}import{Visitor as h5,visitorKeys as m5}from"oxc-parser";import{walk as p5,parseAndWalk as d5,ScopeTracker as l5}from"oxc-walker";export{p5 as walk,m5 as visitorKeys,S0 as symbolSearch,F0 as relationSearch,j0 as patternSearch,E_ as parseSource,d5 as parseAndWalk,z_ as normalizePath,hJ as isVariableDeclaration,xJ as isTSQualifiedName,yJ as isMemberExpression,fJ as isIdentifier,kJ as isFunctionNode,PJ as isFunctionExpression,bJ as isFunctionDeclaration,uJ as isCallExpression,vJ as isAssignmentExpression,EJ as isArrowFunctionExpression,mJ as is,O_ as getLineColumn,R_ as extractSymbols,d_ as extractRelations,p_ as buildLineOffsets,h5 as Visitor,l5 as ScopeTracker,O as GildashError,p0 as Gildash,Y0 as DependencyGraph};
|
|
@@ -57,7 +57,7 @@ export type CoordinatorLike = Pick<IndexCoordinator, 'fullIndex' | 'shutdown' |
|
|
|
57
57
|
handleWatcherEvent?(event: FileChangeEvent): void;
|
|
58
58
|
};
|
|
59
59
|
export type WatcherLike = Pick<ProjectWatcher, 'start' | 'close'>;
|
|
60
|
-
export type SemanticLayerLike = Pick<SemanticLayer, 'collectTypeAt' | 'collectFileTypes' | 'collectTypesAtPositions' | 'findReferences' | 'findImplementations' | 'isTypeAssignableTo' | 'isTypeAssignableToType' | 'isTypeAssignableToTypeAtPositions' | 'getModuleInterface' | 'getSymbolNode' | 'getBaseTypes' | 'getDiagnostics' | 'notifyFileChanged' | 'notifyFileDeleted' | 'dispose' | 'isDisposed' | 'lineColumnToPosition' | 'findNamePosition'>;
|
|
60
|
+
export type SemanticLayerLike = Pick<SemanticLayer, 'collectTypeAt' | 'collectFileTypes' | 'collectTypesAtPositions' | 'findReferences' | 'findEnrichedReferences' | 'getFileBindings' | 'findImplementations' | 'isTypeAssignableTo' | 'isTypeAssignableToType' | 'isTypeAssignableToTypeAtPositions' | 'getModuleInterface' | 'getSymbolNode' | 'getBaseTypes' | 'getDiagnostics' | 'notifyFileChanged' | 'notifyFileDeleted' | 'dispose' | 'isDisposed' | 'lineColumnToPosition' | 'findNamePosition'>;
|
|
61
61
|
/** Internal shared state for all Gildash API modules. */
|
|
62
62
|
export interface GildashContext {
|
|
63
63
|
readonly projectRoot: string;
|
|
@@ -9,7 +9,7 @@ import type { RelationSearchQuery } from '../search/relation-search';
|
|
|
9
9
|
import type { SymbolStats } from '../store/repositories/symbol.repository';
|
|
10
10
|
import type { FileRecord } from '../store/repositories/file.repository';
|
|
11
11
|
import type { PatternMatch } from '../search/pattern-search';
|
|
12
|
-
import type { ResolvedType, SemanticReference, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from '../semantic/types';
|
|
12
|
+
import type { ResolvedType, SemanticReference, EnrichedReference, FileBinding, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from '../semantic/types';
|
|
13
13
|
import type { SymbolNode } from '../semantic/symbol-graph';
|
|
14
14
|
import type { GildashContext } from './context';
|
|
15
15
|
import type { FileChangeEvent } from '../watcher/types';
|
|
@@ -337,6 +337,17 @@ export declare class Gildash {
|
|
|
337
337
|
* @throws {GildashError} With type `'semantic'` if tsc initialisation fails.
|
|
338
338
|
*/
|
|
339
339
|
getSemanticReferences(symbolName: string, filePath: string, project?: string): SemanticReference[];
|
|
340
|
+
/**
|
|
341
|
+
* Like {@link getSemanticReferences}, but each reference is enriched with
|
|
342
|
+
* `writeKind`, `isAmbient`, and `enclosingScope` for dataflow analysis.
|
|
343
|
+
*
|
|
344
|
+
* @param symbolName - Exact symbol name.
|
|
345
|
+
* @param filePath - Relative path to the declaring file.
|
|
346
|
+
* @param project - Project name. Defaults to the primary project.
|
|
347
|
+
* @returns Array of enriched reference locations. Empty array if none found.
|
|
348
|
+
* @throws {GildashError} With type `'semantic'` if tsc initialisation fails.
|
|
349
|
+
*/
|
|
350
|
+
getEnrichedReferences(symbolName: string, filePath: string, project?: string): EnrichedReference[];
|
|
340
351
|
/**
|
|
341
352
|
* Find all implementations of an interface or abstract class member.
|
|
342
353
|
*
|
|
@@ -436,6 +447,28 @@ export declare class Gildash {
|
|
|
436
447
|
* @throws {GildashError} With type `'semantic'` if tsc initialisation fails.
|
|
437
448
|
*/
|
|
438
449
|
getSemanticReferencesAtPosition(filePath: string, position: number): SemanticReference[];
|
|
450
|
+
/**
|
|
451
|
+
* Like {@link getSemanticReferencesAtPosition}, but each reference is enriched
|
|
452
|
+
* with `writeKind`, `isAmbient`, and `enclosingScope` for dataflow analysis.
|
|
453
|
+
*
|
|
454
|
+
* @param filePath - Relative path to the file.
|
|
455
|
+
* @param position - 0-based byte offset of the symbol.
|
|
456
|
+
* @returns Array of enriched reference locations. Empty array if none found.
|
|
457
|
+
* @throws {GildashError} With type `'semantic'` if tsc initialisation fails.
|
|
458
|
+
*/
|
|
459
|
+
getEnrichedReferencesAtPosition(filePath: string, position: number): EnrichedReference[];
|
|
460
|
+
/**
|
|
461
|
+
* Collect every binding in a file in a single pass, each grouped with its
|
|
462
|
+
* in-file references (enriched with `writeKind` / `isAmbient` / `enclosingScope`).
|
|
463
|
+
*
|
|
464
|
+
* One call per file — `O(identifiers)` — replacing per-symbol
|
|
465
|
+
* {@link getEnrichedReferences} loops for dataflow / dead-store analysis.
|
|
466
|
+
*
|
|
467
|
+
* @param filePath - Relative path to the file.
|
|
468
|
+
* @returns One {@link FileBinding} per distinct binding referenced in the file.
|
|
469
|
+
* @throws {GildashError} With type `'semantic'` if tsc initialisation fails.
|
|
470
|
+
*/
|
|
471
|
+
getFileBindings(filePath: string): FileBinding[];
|
|
439
472
|
/**
|
|
440
473
|
* Find all implementations of the symbol at a specific byte position.
|
|
441
474
|
*
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { SymbolSearchResult } from '../search/symbol-search';
|
|
2
|
-
import type { ResolvedType, SemanticReference, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from '../semantic/types';
|
|
2
|
+
import type { ResolvedType, SemanticReference, EnrichedReference, FileBinding, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from '../semantic/types';
|
|
3
3
|
import type { SymbolNode } from '../semantic/symbol-graph';
|
|
4
4
|
import type { GildashContext } from './context';
|
|
5
5
|
/**
|
|
@@ -15,6 +15,8 @@ export declare function resolveSymbolPosition(ctx: GildashContext, symbolName: s
|
|
|
15
15
|
export declare function getResolvedType(ctx: GildashContext, symbolName: string, filePath: string, project?: string): ResolvedType | null;
|
|
16
16
|
/** Find all semantic references to a symbol. */
|
|
17
17
|
export declare function getSemanticReferences(ctx: GildashContext, symbolName: string, filePath: string, project?: string): SemanticReference[];
|
|
18
|
+
/** Find all references to a symbol, enriched with writeKind / isAmbient / enclosingScope. */
|
|
19
|
+
export declare function getEnrichedReferences(ctx: GildashContext, symbolName: string, filePath: string, project?: string): EnrichedReference[];
|
|
18
20
|
/** Find implementations of an interface/abstract class. */
|
|
19
21
|
export declare function getImplementations(ctx: GildashContext, symbolName: string, filePath: string, project?: string): Implementation[];
|
|
20
22
|
/** Check whether a source symbol's type is assignable to a target symbol's type. */
|
|
@@ -46,6 +48,10 @@ export declare function getResolvedTypesAtPositions(ctx: GildashContext, filePat
|
|
|
46
48
|
export declare function getResolvedTypeAtPosition(ctx: GildashContext, filePath: string, position: number): ResolvedType | null;
|
|
47
49
|
/** Find all semantic references at a byte offset. */
|
|
48
50
|
export declare function getSemanticReferencesAtPosition(ctx: GildashContext, filePath: string, position: number): SemanticReference[];
|
|
51
|
+
/** Find all enriched references at a byte offset. */
|
|
52
|
+
export declare function getEnrichedReferencesAtPosition(ctx: GildashContext, filePath: string, position: number): EnrichedReference[];
|
|
53
|
+
/** Collect all bindings in a file (single-pass), each with its in-file enriched references. */
|
|
54
|
+
export declare function getFileBindings(ctx: GildashContext, filePath: string): FileBinding[];
|
|
49
55
|
/** Find implementations at a byte offset. */
|
|
50
56
|
export declare function getImplementationsAtPosition(ctx: GildashContext, filePath: string, position: number): Implementation[];
|
|
51
57
|
/** Check type assignability at byte offsets. */
|
package/dist/src/index.d.ts
CHANGED
|
@@ -16,7 +16,8 @@ export type { SymbolStats } from "./store/repositories/symbol.repository";
|
|
|
16
16
|
export type { WatcherRole, FileChangeEvent } from "./watcher/types";
|
|
17
17
|
export type { ParsedFile } from "./parser/types";
|
|
18
18
|
export type { FileRecord } from "./store/repositories/file.repository";
|
|
19
|
-
export type { ResolvedType, SemanticReference, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from "./semantic/types";
|
|
19
|
+
export type { ResolvedType, SemanticReference, EnrichedReference, FileBinding, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from "./semantic/types";
|
|
20
|
+
export type { WriteKind, ScopeKind, EnclosingScope } from "./semantic/reference-classifier";
|
|
20
21
|
export type { SymbolNode } from "./semantic/symbol-graph";
|
|
21
22
|
export type { AnnotationSource, ExtractedAnnotation } from "./extractor/types";
|
|
22
23
|
export type { AnnotationSearchQuery, AnnotationSearchResult } from "./search/annotation-search";
|
|
@@ -3,9 +3,10 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import ts from "typescript";
|
|
5
5
|
/**
|
|
6
|
-
* `pos`
|
|
7
|
-
* 범위
|
|
6
|
+
* `pos` 위치를 포함하는 가장 작은(innermost) 노드를 반환한다.
|
|
7
|
+
* 범위 밖이거나 트리비아 위치면 `undefined`.
|
|
8
8
|
*
|
|
9
|
-
*
|
|
9
|
+
* 공개 API(`forEachChild`)만으로 하강 탐색한다 — `pos`를 실제로 포함하는
|
|
10
|
+
* (`getStart() <= pos < getEnd()`) 자식으로만 재귀하므로 가이드된 하강이다.
|
|
10
11
|
*/
|
|
11
12
|
export declare function findNodeAtPosition(sourceFile: ts.SourceFile, pos: number): ts.Node | undefined;
|
|
@@ -11,7 +11,7 @@ import { TypeCollector } from "./type-collector";
|
|
|
11
11
|
import { SymbolGraph, type SymbolNode } from "./symbol-graph";
|
|
12
12
|
import { ReferenceResolver } from "./reference-resolver";
|
|
13
13
|
import { ImplementationFinder } from "./implementation-finder";
|
|
14
|
-
import type { ResolvedType, SemanticReference, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from "./types";
|
|
14
|
+
import type { ResolvedType, SemanticReference, EnrichedReference, FileBinding, Implementation, SemanticModuleInterface, SemanticDiagnostic, GetDiagnosticsOptions } from "./types";
|
|
15
15
|
export interface SemanticLayerOptions extends TscProgramOptions {
|
|
16
16
|
/** Override TypeCollector (for testing). */
|
|
17
17
|
typeCollector?: TypeCollector;
|
|
@@ -37,6 +37,8 @@ export declare class SemanticLayer {
|
|
|
37
37
|
collectFileTypes(filePath: string): Map<number, ResolvedType>;
|
|
38
38
|
collectTypesAtPositions(filePath: string, positions: number[]): Map<number, ResolvedType>;
|
|
39
39
|
findReferences(filePath: string, position: number): SemanticReference[];
|
|
40
|
+
findEnrichedReferences(filePath: string, position: number): EnrichedReference[];
|
|
41
|
+
getFileBindings(filePath: string): FileBinding[];
|
|
40
42
|
findImplementations(filePath: string, position: number): Implementation[];
|
|
41
43
|
isTypeAssignableTo(sourceFilePath: string, sourcePosition: number, targetFilePath: string, targetPosition: number): boolean | null;
|
|
42
44
|
/**
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* reference-classifier — purely syntactic classification of identifier references.
|
|
3
|
+
*
|
|
4
|
+
* tsc's `LanguageService.findReferences` answers the authoritative binding
|
|
5
|
+
* question (which declaration a reference binds to, and `isWriteAccess`), but it
|
|
6
|
+
* does NOT distinguish *kinds* of writes. This module fills that gap by inspecting
|
|
7
|
+
* the syntactic context of an identifier — no type information is required.
|
|
8
|
+
*/
|
|
9
|
+
import ts from 'typescript';
|
|
10
|
+
/**
|
|
11
|
+
* The kind of write a reference represents.
|
|
12
|
+
*
|
|
13
|
+
* - `declaration` — a binding site (`var a`, `let {x}`, parameter, etc.).
|
|
14
|
+
* - `assignment` — plain assignment (`a = …`).
|
|
15
|
+
* - `compound-assignment` — arithmetic/bitwise compound (`a += …`, `a &= …`).
|
|
16
|
+
* - `logical-assignment` — short-circuit compound (`a &&= …`, `a ||= …`, `a ??= …`).
|
|
17
|
+
* - `update` — increment/decrement (`a++`, `--a`).
|
|
18
|
+
*/
|
|
19
|
+
export type WriteKind = 'declaration' | 'assignment' | 'compound-assignment' | 'logical-assignment' | 'update';
|
|
20
|
+
/** The kind of scope that lexically encloses a reference. */
|
|
21
|
+
export type ScopeKind = 'function' | 'module' | 'block';
|
|
22
|
+
/**
|
|
23
|
+
* The nearest scope enclosing a reference, with the scope-defining node's span
|
|
24
|
+
* for identity (two distinct blocks have distinct spans — needed by flow analysis).
|
|
25
|
+
*/
|
|
26
|
+
export interface EnclosingScope {
|
|
27
|
+
kind: ScopeKind;
|
|
28
|
+
/** Start offset of the scope-defining node. */
|
|
29
|
+
pos: number;
|
|
30
|
+
/** End offset of the scope-defining node. */
|
|
31
|
+
end: number;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Whether `decl` is an ambient declaration (no runtime definition) — `declare`
|
|
35
|
+
* declarations, members of `declare namespace`/`declare module`/`declare global`,
|
|
36
|
+
* and anything in a `.d.ts` declaration file.
|
|
37
|
+
*
|
|
38
|
+
* This is a per-declaration primitive. A *symbol* may have multiple declarations
|
|
39
|
+
* (declaration merging); the integration layer composes ambientness across them
|
|
40
|
+
* (`symbol.declarations.every(isAmbientDeclaration)` — ambient only when no
|
|
41
|
+
* declaration carries a runtime definition).
|
|
42
|
+
*/
|
|
43
|
+
export declare function isAmbientDeclaration(decl: ts.Declaration): boolean;
|
|
44
|
+
/**
|
|
45
|
+
* Find the nearest scope (`function` | `module` | `block`) that lexically
|
|
46
|
+
* encloses `node`. A function body's own block reports as `function`; nested
|
|
47
|
+
* blocks, `for` bodies and `catch` bodies report as `block`; the source file and
|
|
48
|
+
* `namespace`/`module` bodies report as `module`. Always resolves (module is the
|
|
49
|
+
* root fallback).
|
|
50
|
+
*/
|
|
51
|
+
export declare function getEnclosingScope(node: ts.Node): EnclosingScope;
|
|
52
|
+
/**
|
|
53
|
+
* Classify whether `node` is a write reference, and of what kind.
|
|
54
|
+
*
|
|
55
|
+
* Returns the {@link WriteKind} when the identifier occupies a write position,
|
|
56
|
+
* or `undefined` when it is a read. The compound/logical/update kinds also read
|
|
57
|
+
* their target; splitting out that read-component is the caller's responsibility.
|
|
58
|
+
*/
|
|
59
|
+
export declare function classifyWriteKind(node: ts.Identifier): WriteKind | undefined;
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* 텍스트 검색과 달리 심볼 identity 기반으로 참조를 찾으므로
|
|
5
5
|
* rename, re-export, shadowing을 정확히 처리한다.
|
|
6
6
|
*/
|
|
7
|
-
import type { SemanticReference } from "./types";
|
|
7
|
+
import type { EnrichedReference, FileBinding, SemanticReference } from "./types";
|
|
8
8
|
import type { TscProgram } from "./tsc-program";
|
|
9
9
|
export declare class ReferenceResolver {
|
|
10
10
|
#private;
|
|
@@ -16,4 +16,17 @@ export declare class ReferenceResolver {
|
|
|
16
16
|
* - LanguageService.findReferences를 사용하므로 cross-file 참조도 포함된다.
|
|
17
17
|
*/
|
|
18
18
|
findAt(filePath: string, position: number): SemanticReference[];
|
|
19
|
+
/**
|
|
20
|
+
* Like {@link findAt}, but enriches each reference with `writeKind`,
|
|
21
|
+
* `isAmbient`, and `enclosingScope` — the syntactic metadata that
|
|
22
|
+
* `findReferences` does not provide. Returns `[]` if disposed or unresolved.
|
|
23
|
+
*/
|
|
24
|
+
findEnrichedAt(filePath: string, position: number): EnrichedReference[];
|
|
25
|
+
/**
|
|
26
|
+
* Collect every binding referenced in `filePath`, grouped by symbol, in a
|
|
27
|
+
* single AST pass (no per-symbol `findReferences`). Each group lists the
|
|
28
|
+
* references that occur in this file enriched with `writeKind` / `isAmbient` /
|
|
29
|
+
* `enclosingScope`. Returns `[]` if disposed or the file is unknown.
|
|
30
|
+
*/
|
|
31
|
+
findFileBindings(filePath: string): FileBinding[];
|
|
19
32
|
}
|
|
@@ -4,6 +4,7 @@
|
|
|
4
4
|
* All types in this file are plain data shapes — no runtime logic.
|
|
5
5
|
* The Semantic Layer is opt-in via `Gildash.open({ semantic: true })`.
|
|
6
6
|
*/
|
|
7
|
+
import type { WriteKind, EnclosingScope } from './reference-classifier';
|
|
7
8
|
/**
|
|
8
9
|
* The resolved type of a TypeScript symbol, as determined by the tsc TypeChecker.
|
|
9
10
|
*
|
|
@@ -70,6 +71,52 @@ export interface SemanticReference {
|
|
|
70
71
|
/** Whether this reference is a write (assignment) rather than a read. */
|
|
71
72
|
isWrite: boolean;
|
|
72
73
|
}
|
|
74
|
+
/**
|
|
75
|
+
* A {@link SemanticReference} enriched with the syntactic classification that
|
|
76
|
+
* tsc's `findReferences` does not provide on its own: the kind of write, whether
|
|
77
|
+
* the binding is ambient (no runtime definition), and the lexical scope in which
|
|
78
|
+
* the reference occurs.
|
|
79
|
+
*
|
|
80
|
+
* Binding identity (which declaration each reference binds to, including `var`
|
|
81
|
+
* hoisting and shadowing) is supplied authoritatively by tsc; these fields layer
|
|
82
|
+
* dataflow-relevant metadata on top.
|
|
83
|
+
*/
|
|
84
|
+
export interface EnrichedReference extends SemanticReference {
|
|
85
|
+
/**
|
|
86
|
+
* The kind of write, or `undefined` for reads. Compound/logical/update writes
|
|
87
|
+
* also read their target — splitting that read-component is the consumer's job.
|
|
88
|
+
*/
|
|
89
|
+
writeKind?: WriteKind;
|
|
90
|
+
/**
|
|
91
|
+
* `true` when the binding has no runtime definition (all declarations are
|
|
92
|
+
* ambient: `declare` / `.d.ts`). Computed across the symbol's declarations.
|
|
93
|
+
*/
|
|
94
|
+
isAmbient: boolean;
|
|
95
|
+
/** The lexical scope in which this reference occurs. */
|
|
96
|
+
enclosingScope: EnclosingScope;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* All references to a single binding within one file, grouped by symbol identity.
|
|
100
|
+
*
|
|
101
|
+
* Produced by a single-pass walk + `getSymbolAtLocation` (no per-symbol
|
|
102
|
+
* `findReferences`), so collecting every binding in a file is `O(identifiers)`
|
|
103
|
+
* rather than `O(symbols × program)`. References are limited to the queried file
|
|
104
|
+
* (dataflow is intra-file); the declaration may live elsewhere.
|
|
105
|
+
*/
|
|
106
|
+
export interface FileBinding {
|
|
107
|
+
/** The binding's declaration site (may be in another file, e.g. an import). */
|
|
108
|
+
declaration: {
|
|
109
|
+
filePath: string;
|
|
110
|
+
/** Zero-based offset of the declaration name. */
|
|
111
|
+
position: number;
|
|
112
|
+
/** Symbol name. */
|
|
113
|
+
name: string;
|
|
114
|
+
/** Whether the binding is ambient (no runtime definition). */
|
|
115
|
+
isAmbient: boolean;
|
|
116
|
+
};
|
|
117
|
+
/** Every reference to this binding that occurs in the queried file. */
|
|
118
|
+
references: EnrichedReference[];
|
|
119
|
+
}
|
|
73
120
|
/**
|
|
74
121
|
* A concrete implementation of an interface or abstract class,
|
|
75
122
|
* found via `LanguageService.getImplementationAtPosition` and
|