code-kg 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +100 -0
  3. package/dist/cli/index.d.ts +14 -0
  4. package/dist/cli/index.js +68 -0
  5. package/dist/cli/index.js.map +1 -0
  6. package/dist/codekg-config.d.ts +14 -0
  7. package/dist/codekg-config.js +81 -0
  8. package/dist/codekg-config.js.map +1 -0
  9. package/dist/commands/graph.d.ts +7 -0
  10. package/dist/commands/graph.js +49 -0
  11. package/dist/commands/graph.js.map +1 -0
  12. package/dist/commands/init.d.ts +6 -0
  13. package/dist/commands/init.js +13 -0
  14. package/dist/commands/init.js.map +1 -0
  15. package/dist/commands/insights.d.ts +7 -0
  16. package/dist/commands/insights.js +31 -0
  17. package/dist/commands/insights.js.map +1 -0
  18. package/dist/commands/path.d.ts +7 -0
  19. package/dist/commands/path.js +47 -0
  20. package/dist/commands/path.js.map +1 -0
  21. package/dist/commands/reindex.d.ts +6 -0
  22. package/dist/commands/reindex.js +13 -0
  23. package/dist/commands/reindex.js.map +1 -0
  24. package/dist/commands/run.d.ts +6 -0
  25. package/dist/commands/run.js +20 -0
  26. package/dist/commands/run.js.map +1 -0
  27. package/dist/commands/serve.d.ts +8 -0
  28. package/dist/commands/serve.js +25 -0
  29. package/dist/commands/serve.js.map +1 -0
  30. package/dist/config/defaults.d.ts +6 -0
  31. package/dist/config/defaults.js +30 -0
  32. package/dist/config/defaults.js.map +1 -0
  33. package/dist/index.d.ts +52 -0
  34. package/dist/index.js +602 -0
  35. package/dist/index.js.map +1 -0
  36. package/dist/indexer/babel-fallback.d.ts +7 -0
  37. package/dist/indexer/babel-fallback.js +583 -0
  38. package/dist/indexer/babel-fallback.js.map +1 -0
  39. package/dist/indexer/file-discovery.d.ts +6 -0
  40. package/dist/indexer/file-discovery.js +106 -0
  41. package/dist/indexer/file-discovery.js.map +1 -0
  42. package/dist/indexer/indexer.d.ts +90 -0
  43. package/dist/indexer/indexer.js +620 -0
  44. package/dist/indexer/indexer.js.map +1 -0
  45. package/dist/indexer/metrics.d.ts +39 -0
  46. package/dist/indexer/metrics.js +147 -0
  47. package/dist/indexer/metrics.js.map +1 -0
  48. package/dist/indexer/structure-detector.d.ts +16 -0
  49. package/dist/indexer/structure-detector.js +159 -0
  50. package/dist/indexer/structure-detector.js.map +1 -0
  51. package/dist/indexer/ts-parser.d.ts +86 -0
  52. package/dist/indexer/ts-parser.js +437 -0
  53. package/dist/indexer/ts-parser.js.map +1 -0
  54. package/dist/model/edge.d.ts +21 -0
  55. package/dist/model/edge.js +25 -0
  56. package/dist/model/edge.js.map +1 -0
  57. package/dist/model/graph.d.ts +10 -0
  58. package/dist/model/graph.js +20 -0
  59. package/dist/model/graph.js.map +1 -0
  60. package/dist/model/node.d.ts +24 -0
  61. package/dist/model/node.js +22 -0
  62. package/dist/model/node.js.map +1 -0
  63. package/dist/query/query-dsl.d.ts +17 -0
  64. package/dist/query/query-dsl.js +75 -0
  65. package/dist/query/query-dsl.js.map +1 -0
  66. package/dist/query/query-engine.d.ts +32 -0
  67. package/dist/query/query-engine.js +126 -0
  68. package/dist/query/query-engine.js.map +1 -0
  69. package/dist/server/api.d.ts +19 -0
  70. package/dist/server/api.js +29 -0
  71. package/dist/server/api.js.map +1 -0
  72. package/dist/server/app.d.ts +7 -0
  73. package/dist/server/app.js +509 -0
  74. package/dist/server/app.js.map +1 -0
  75. package/dist/server/graph-controller.d.ts +147 -0
  76. package/dist/server/graph-controller.js +186 -0
  77. package/dist/server/graph-controller.js.map +1 -0
  78. package/dist/server/routes.d.ts +3 -0
  79. package/dist/server/routes.js +19 -0
  80. package/dist/server/routes.js.map +1 -0
  81. package/dist/server/ui.d.ts +1 -0
  82. package/dist/server/ui.js +1165 -0
  83. package/dist/server/ui.js.map +1 -0
  84. package/dist/store/sqlite-store.d.ts +83 -0
  85. package/dist/store/sqlite-store.js +647 -0
  86. package/dist/store/sqlite-store.js.map +1 -0
  87. package/dist/utils/ids.d.ts +2 -0
  88. package/dist/utils/ids.js +9 -0
  89. package/dist/utils/ids.js.map +1 -0
  90. package/dist/utils/path.d.ts +3 -0
  91. package/dist/utils/path.js +21 -0
  92. package/dist/utils/path.js.map +1 -0
  93. package/package.json +58 -0
@@ -0,0 +1,647 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.SqliteStore = void 0;
7
+ const better_sqlite3_1 = __importDefault(require("better-sqlite3"));
8
+ const query_dsl_1 = require("../query/query-dsl");
9
+ const query_engine_1 = require("../query/query-engine");
10
+ function safeParseJson(value) {
11
+ if (!value) {
12
+ return {};
13
+ }
14
+ try {
15
+ const parsed = JSON.parse(value);
16
+ if (parsed && typeof parsed === "object" && !Array.isArray(parsed)) {
17
+ return parsed;
18
+ }
19
+ return {};
20
+ }
21
+ catch {
22
+ return {};
23
+ }
24
+ }
25
+ function stringifyProps(props) {
26
+ if (!props) {
27
+ return "{}";
28
+ }
29
+ return JSON.stringify(props);
30
+ }
31
+ function sortById(rows) {
32
+ return [...rows].sort((left, right) => left.id.localeCompare(right.id));
33
+ }
34
+ function parseSpecifiers(value) {
35
+ const props = safeParseJson(value);
36
+ const raw = props.specifiers;
37
+ if (!Array.isArray(raw)) {
38
+ return [];
39
+ }
40
+ return raw.filter((item) => typeof item === "string");
41
+ }
42
+ function normalizeTypeFilter(values) {
43
+ if (!values || values.length === 0) {
44
+ return undefined;
45
+ }
46
+ const normalized = values
47
+ .map((value) => value.trim().toUpperCase())
48
+ .filter((value) => value.length > 0);
49
+ if (normalized.length === 0) {
50
+ return undefined;
51
+ }
52
+ return new Set(normalized);
53
+ }
54
+ class SqliteStore {
55
+ db;
56
+ constructor(dbPath) {
57
+ this.db = new better_sqlite3_1.default(dbPath);
58
+ }
59
+ close() {
60
+ this.db.close();
61
+ }
62
+ initializeSchema() {
63
+ this.db.exec(`
64
+ CREATE TABLE IF NOT EXISTS nodes(
65
+ id TEXT PRIMARY KEY,
66
+ type TEXT,
67
+ name TEXT,
68
+ path TEXT,
69
+ json_props TEXT
70
+ );
71
+
72
+ CREATE TABLE IF NOT EXISTS edges(
73
+ id TEXT PRIMARY KEY,
74
+ from_id TEXT,
75
+ to_id TEXT,
76
+ type TEXT,
77
+ json_props TEXT
78
+ );
79
+
80
+ CREATE INDEX IF NOT EXISTS idx_nodes_type ON nodes(type);
81
+ CREATE INDEX IF NOT EXISTS idx_nodes_name ON nodes(name);
82
+ CREATE INDEX IF NOT EXISTS idx_edges_from_id ON edges(from_id);
83
+ CREATE INDEX IF NOT EXISTS idx_edges_to_id ON edges(to_id);
84
+ `);
85
+ }
86
+ initSchema() {
87
+ this.initializeSchema();
88
+ }
89
+ replaceGraph(snapshot) {
90
+ const deleteEdges = this.db.prepare("DELETE FROM edges");
91
+ const deleteNodes = this.db.prepare("DELETE FROM nodes");
92
+ const insertNode = this.db.prepare(`
93
+ INSERT INTO nodes(id, type, name, path, json_props)
94
+ VALUES (?, ?, ?, ?, ?)
95
+ `);
96
+ const insertEdge = this.db.prepare(`
97
+ INSERT INTO edges(id, from_id, to_id, type, json_props)
98
+ VALUES (?, ?, ?, ?, ?)
99
+ `);
100
+ const transaction = this.db.transaction((nextSnapshot) => {
101
+ deleteEdges.run();
102
+ deleteNodes.run();
103
+ for (const node of sortById(nextSnapshot.nodes)) {
104
+ insertNode.run(node.id, node.type, node.name, node.path, stringifyProps(node.props));
105
+ }
106
+ for (const edge of sortById(nextSnapshot.edges)) {
107
+ insertEdge.run(edge.id, edge.fromId, edge.toId, edge.type, stringifyProps(edge.props));
108
+ }
109
+ });
110
+ transaction(snapshot);
111
+ }
112
+ replaceGraphAtomically(snapshot) {
113
+ this.replaceGraph(snapshot);
114
+ }
115
+ searchNodes(queryText, limit = 50) {
116
+ const trimmed = queryText.trim().toLowerCase();
117
+ const wildcard = `%${trimmed}%`;
118
+ const rows = this.db
119
+ .prepare(`
120
+ SELECT id, type, name, path, json_props
121
+ FROM nodes
122
+ WHERE ? = ''
123
+ OR LOWER(id) LIKE ?
124
+ OR LOWER(COALESCE(type, '')) LIKE ?
125
+ OR LOWER(COALESCE(name, '')) LIKE ?
126
+ OR LOWER(COALESCE(path, '')) LIKE ?
127
+ ORDER BY type COLLATE NOCASE ASC, name COLLATE NOCASE ASC, id ASC
128
+ LIMIT ?
129
+ `)
130
+ .all(trimmed, wildcard, wildcard, wildcard, wildcard, limit);
131
+ return rows.map((row) => this.mapNodeRow(row));
132
+ }
133
+ getNodeById(nodeId) {
134
+ const row = this.db
135
+ .prepare(`
136
+ SELECT id, type, name, path, json_props
137
+ FROM nodes
138
+ WHERE id = ?
139
+ LIMIT 1
140
+ `)
141
+ .get(nodeId);
142
+ return row ? this.mapNodeRow(row) : null;
143
+ }
144
+ findNodesByName(symbol) {
145
+ const rows = this.db
146
+ .prepare(`
147
+ SELECT id, type, name, path, json_props
148
+ FROM nodes
149
+ WHERE LOWER(COALESCE(name, '')) = LOWER(?)
150
+ OR LOWER(id) = LOWER(?)
151
+ ORDER BY id ASC
152
+ `)
153
+ .all(symbol, symbol);
154
+ return rows.map((row) => this.mapNodeRow(row));
155
+ }
156
+ getOutgoingEdges(nodeId) {
157
+ const rows = this.db
158
+ .prepare(`
159
+ SELECT id, from_id, to_id, type, json_props
160
+ FROM edges
161
+ WHERE from_id = ?
162
+ ORDER BY id ASC
163
+ `)
164
+ .all(nodeId);
165
+ return rows.map((row) => this.mapEdgeRow(row));
166
+ }
167
+ getIncomingEdges(nodeId) {
168
+ const rows = this.db
169
+ .prepare(`
170
+ SELECT id, from_id, to_id, type, json_props
171
+ FROM edges
172
+ WHERE to_id = ?
173
+ ORDER BY id ASC
174
+ `)
175
+ .all(nodeId);
176
+ return rows.map((row) => this.mapEdgeRow(row));
177
+ }
178
+ getAllGraph() {
179
+ const nodeRows = this.db
180
+ .prepare(`
181
+ SELECT id, type, name, path, json_props
182
+ FROM nodes
183
+ ORDER BY id ASC
184
+ `)
185
+ .all();
186
+ const edgeRows = this.db
187
+ .prepare(`
188
+ SELECT id, from_id, to_id, type, json_props
189
+ FROM edges
190
+ ORDER BY id ASC
191
+ `)
192
+ .all();
193
+ return {
194
+ nodes: nodeRows.map((row) => this.mapNodeRow(row)),
195
+ edges: edgeRows.map((row) => this.mapEdgeRow(row)),
196
+ };
197
+ }
198
+ getSymbolGraph() {
199
+ const nodeRows = this.db
200
+ .prepare(`
201
+ SELECT id, type, name, path, json_props
202
+ FROM nodes
203
+ WHERE UPPER(type) IN ('FUNCTION', 'CLASS', 'INTERFACE', 'VARIABLE', 'ROUTE')
204
+ ORDER BY id ASC
205
+ `)
206
+ .all();
207
+ const nodeIdSet = new Set(nodeRows.map((row) => row.id));
208
+ const edgeRows = this.db
209
+ .prepare(`
210
+ SELECT id, from_id, to_id, type, json_props
211
+ FROM edges
212
+ WHERE UPPER(type) IN ('DEFINES', 'EXPORTS', 'REFERENCES', 'CALLS', 'EXTENDS', 'IMPLEMENTS', 'HANDLES_ROUTE')
213
+ ORDER BY id ASC
214
+ `)
215
+ .all().filter((row) => nodeIdSet.has(row.from_id) && nodeIdSet.has(row.to_id));
216
+ return {
217
+ nodes: nodeRows.map((row) => this.mapNodeRow(row)),
218
+ edges: edgeRows.map((row) => this.mapEdgeRow(row)),
219
+ };
220
+ }
221
+ getFileDependencyGraph() {
222
+ const nodeRows = this.db
223
+ .prepare(`
224
+ SELECT id, type, name, path, json_props
225
+ FROM nodes
226
+ WHERE UPPER(type) = 'FILE'
227
+ ORDER BY COALESCE(path, name, id) ASC, id ASC
228
+ `)
229
+ .all();
230
+ const edgeRows = this.db
231
+ .prepare(`
232
+ SELECT e.id, e.from_id, e.to_id, e.type, e.json_props
233
+ FROM edges e
234
+ JOIN nodes source ON source.id = e.from_id
235
+ JOIN nodes target ON target.id = e.to_id
236
+ WHERE UPPER(e.type) IN ('IMPORTS', 'DEPENDS_ON')
237
+ AND UPPER(source.type) = 'FILE'
238
+ AND UPPER(target.type) = 'FILE'
239
+ ORDER BY e.from_id ASC, e.to_id ASC, e.id ASC
240
+ `)
241
+ .all();
242
+ return {
243
+ nodes: nodeRows.map((row) => this.mapNodeRow(row)),
244
+ edges: edgeRows.map((row) => this.mapEdgeRow(row)),
245
+ };
246
+ }
247
+ getGraph(options = {}) {
248
+ const view = (options.view ?? "all").trim();
249
+ const baseGraph = view === "fileDeps"
250
+ ? this.getFileDependencyGraph()
251
+ : view === "symbolGraph"
252
+ ? this.getSymbolGraph()
253
+ : this.getAllGraph();
254
+ const nodeTypeFilter = normalizeTypeFilter(options.nodeTypes);
255
+ const edgeTypeFilter = normalizeTypeFilter(options.edgeTypes);
256
+ const query = options.q?.trim().toLowerCase() ?? "";
257
+ const limit = Math.max(0, Math.floor(options.limit ?? 0));
258
+ let nodes = baseGraph.nodes;
259
+ if (nodeTypeFilter) {
260
+ nodes = nodes.filter((node) => nodeTypeFilter.has(node.type.toUpperCase()));
261
+ }
262
+ if (query.length > 0) {
263
+ nodes = nodes.filter((node) => {
264
+ const haystack = `${node.id} ${node.type} ${node.name ?? ""} ${node.path ?? ""}`.toLowerCase();
265
+ return haystack.includes(query);
266
+ });
267
+ }
268
+ nodes = sortById(nodes);
269
+ if (limit > 0 && nodes.length > limit) {
270
+ nodes = nodes.slice(0, limit);
271
+ }
272
+ const nodeIdSet = new Set(nodes.map((node) => node.id));
273
+ let edges = baseGraph.edges.filter((edge) => nodeIdSet.has(edge.fromId) && nodeIdSet.has(edge.toId));
274
+ if (edgeTypeFilter) {
275
+ edges = edges.filter((edge) => edgeTypeFilter.has(edge.type.toUpperCase()));
276
+ }
277
+ return {
278
+ nodes,
279
+ edges: sortById(edges),
280
+ };
281
+ }
282
+ getSubgraph(seedNodeId, depth = 1, direction = "both") {
283
+ const seed = this.getNodeById(seedNodeId);
284
+ if (!seed) {
285
+ return { nodes: [], edges: [] };
286
+ }
287
+ const maxDepth = Math.max(0, Math.floor(depth));
288
+ const visitedNodes = new Set([seed.id]);
289
+ const visitedEdges = new Map();
290
+ const queue = [{ nodeId: seed.id, remaining: maxDepth }];
291
+ while (queue.length > 0) {
292
+ const next = queue.shift();
293
+ if (!next || next.remaining < 0) {
294
+ continue;
295
+ }
296
+ const outgoing = direction === "in" ? [] : this.getOutgoingEdges(next.nodeId);
297
+ const incoming = direction === "out" ? [] : this.getIncomingEdges(next.nodeId);
298
+ const relatedEdges = [...outgoing, ...incoming];
299
+ for (const edge of relatedEdges) {
300
+ visitedEdges.set(edge.id, edge);
301
+ const neighborId = edge.fromId === next.nodeId ? edge.toId : edge.fromId;
302
+ if (!visitedNodes.has(neighborId)) {
303
+ visitedNodes.add(neighborId);
304
+ }
305
+ if (next.remaining > 0) {
306
+ queue.push({ nodeId: neighborId, remaining: next.remaining - 1 });
307
+ }
308
+ }
309
+ }
310
+ const nodes = sortById([...visitedNodes]
311
+ .map((nodeId) => this.getNodeById(nodeId))
312
+ .filter((node) => Boolean(node)));
313
+ const nodeIdSet = new Set(nodes.map((node) => node.id));
314
+ const edges = sortById([...visitedEdges.values()].filter((edge) => nodeIdSet.has(edge.fromId) && nodeIdSet.has(edge.toId)));
315
+ return { nodes, edges };
316
+ }
317
+ findShortestPath(fromNodeId, toNodeId, maxDepth = 12, edgeTypes) {
318
+ const fromNode = this.getNodeById(fromNodeId);
319
+ const toNode = this.getNodeById(toNodeId);
320
+ const boundedDepth = Math.max(1, Math.floor(maxDepth));
321
+ if (!fromNode || !toNode) {
322
+ return {
323
+ from: fromNodeId,
324
+ to: toNodeId,
325
+ maxDepth: boundedDepth,
326
+ found: false,
327
+ length: 0,
328
+ nodeIds: [],
329
+ edgeIds: [],
330
+ nodes: [],
331
+ edges: [],
332
+ };
333
+ }
334
+ const typeFilter = normalizeTypeFilter(edgeTypes);
335
+ const queue = [{ nodeId: fromNodeId, depth: 0 }];
336
+ const visited = new Set([fromNodeId]);
337
+ const previousByNode = new Map();
338
+ let found = false;
339
+ while (queue.length > 0) {
340
+ const current = queue.shift();
341
+ if (!current) {
342
+ continue;
343
+ }
344
+ if (current.nodeId === toNodeId) {
345
+ found = true;
346
+ break;
347
+ }
348
+ if (current.depth >= boundedDepth) {
349
+ continue;
350
+ }
351
+ const outgoing = this.getOutgoingEdges(current.nodeId).filter((edge) => !typeFilter || typeFilter.has(edge.type.toUpperCase()));
352
+ for (const edge of outgoing) {
353
+ if (visited.has(edge.toId)) {
354
+ continue;
355
+ }
356
+ visited.add(edge.toId);
357
+ previousByNode.set(edge.toId, { nodeId: current.nodeId, edge });
358
+ queue.push({ nodeId: edge.toId, depth: current.depth + 1 });
359
+ }
360
+ }
361
+ if (!found) {
362
+ return {
363
+ from: fromNodeId,
364
+ to: toNodeId,
365
+ maxDepth: boundedDepth,
366
+ found: false,
367
+ length: 0,
368
+ nodeIds: [],
369
+ edgeIds: [],
370
+ nodes: [],
371
+ edges: [],
372
+ };
373
+ }
374
+ const nodeIds = [toNodeId];
375
+ const edges = [];
376
+ let cursor = toNodeId;
377
+ while (cursor !== fromNodeId) {
378
+ const previous = previousByNode.get(cursor);
379
+ if (!previous) {
380
+ break;
381
+ }
382
+ edges.push(previous.edge);
383
+ nodeIds.push(previous.nodeId);
384
+ cursor = previous.nodeId;
385
+ }
386
+ nodeIds.reverse();
387
+ edges.reverse();
388
+ const nodes = nodeIds
389
+ .map((nodeId) => this.getNodeById(nodeId))
390
+ .filter((node) => Boolean(node));
391
+ return {
392
+ from: fromNodeId,
393
+ to: toNodeId,
394
+ maxDepth: boundedDepth,
395
+ found: true,
396
+ length: edges.length,
397
+ nodeIds,
398
+ edgeIds: edges.map((edge) => edge.id),
399
+ nodes,
400
+ edges,
401
+ };
402
+ }
403
+ getRoutesList() {
404
+ const rows = this.db
405
+ .prepare(`
406
+ SELECT id, type, name, path, json_props
407
+ FROM nodes
408
+ WHERE UPPER(type) = 'ROUTE'
409
+ ORDER BY COALESCE(path, name, id) ASC, id ASC
410
+ `)
411
+ .all();
412
+ return rows.map((row) => this.mapNodeRow(row));
413
+ }
414
+ getRoutes() {
415
+ return this.getRoutesList();
416
+ }
417
+ getCyclesInfo() {
418
+ const graph = this.getFileDependencyGraph();
419
+ const nodes = sortById(graph.nodes);
420
+ const edges = sortById(graph.edges);
421
+ const nodeById = new Map(nodes.map((node) => [node.id, node]));
422
+ const outgoing = new Map();
423
+ for (const node of nodes) {
424
+ outgoing.set(node.id, []);
425
+ }
426
+ for (const edge of edges) {
427
+ const adjacency = outgoing.get(edge.fromId);
428
+ if (!adjacency) {
429
+ continue;
430
+ }
431
+ adjacency.push(edge.toId);
432
+ }
433
+ for (const [nodeId, targets] of outgoing) {
434
+ outgoing.set(nodeId, [...targets].sort((left, right) => left.localeCompare(right)));
435
+ }
436
+ const indexByNode = new Map();
437
+ const lowLinkByNode = new Map();
438
+ const stack = [];
439
+ const onStack = new Set();
440
+ const components = [];
441
+ let index = 0;
442
+ const strongConnect = (nodeId) => {
443
+ indexByNode.set(nodeId, index);
444
+ lowLinkByNode.set(nodeId, index);
445
+ index += 1;
446
+ stack.push(nodeId);
447
+ onStack.add(nodeId);
448
+ const neighbors = outgoing.get(nodeId) ?? [];
449
+ for (const neighbor of neighbors) {
450
+ if (!indexByNode.has(neighbor)) {
451
+ strongConnect(neighbor);
452
+ const current = lowLinkByNode.get(nodeId) ?? 0;
453
+ const candidate = lowLinkByNode.get(neighbor) ?? current;
454
+ lowLinkByNode.set(nodeId, Math.min(current, candidate));
455
+ continue;
456
+ }
457
+ if (onStack.has(neighbor)) {
458
+ const current = lowLinkByNode.get(nodeId) ?? 0;
459
+ const neighborIndex = indexByNode.get(neighbor) ?? current;
460
+ lowLinkByNode.set(nodeId, Math.min(current, neighborIndex));
461
+ }
462
+ }
463
+ if (lowLinkByNode.get(nodeId) !== indexByNode.get(nodeId)) {
464
+ return;
465
+ }
466
+ const component = [];
467
+ while (stack.length > 0) {
468
+ const top = stack.pop();
469
+ if (!top) {
470
+ break;
471
+ }
472
+ onStack.delete(top);
473
+ component.push(top);
474
+ if (top === nodeId) {
475
+ break;
476
+ }
477
+ }
478
+ component.sort((left, right) => left.localeCompare(right));
479
+ if (component.length > 1) {
480
+ components.push(component);
481
+ return;
482
+ }
483
+ const single = component[0];
484
+ if (!single) {
485
+ return;
486
+ }
487
+ const selfLoop = edges.some((edge) => edge.fromId === single && edge.toId === single);
488
+ if (selfLoop) {
489
+ components.push(component);
490
+ }
491
+ };
492
+ for (const node of nodes) {
493
+ if (!indexByNode.has(node.id)) {
494
+ strongConnect(node.id);
495
+ }
496
+ }
497
+ const cycles = components
498
+ .map((component) => {
499
+ const memberIds = new Set(component);
500
+ return {
501
+ nodes: component
502
+ .map((nodeId) => nodeById.get(nodeId))
503
+ .filter((node) => Boolean(node)),
504
+ edges: edges.filter((edge) => memberIds.has(edge.fromId) && memberIds.has(edge.toId)),
505
+ };
506
+ })
507
+ .sort((left, right) => {
508
+ const leftStart = left.nodes[0]?.id ?? "";
509
+ const rightStart = right.nodes[0]?.id ?? "";
510
+ return leftStart.localeCompare(rightStart);
511
+ });
512
+ return {
513
+ cycles,
514
+ totalCycles: cycles.length,
515
+ };
516
+ }
517
+ getCycles() {
518
+ return this.getCyclesInfo();
519
+ }
520
+ getRefactorInsights(limit = 5) {
521
+ const boundedLimit = Math.max(1, Math.min(50, Math.floor(limit) || 5));
522
+ const graph = this.getFileDependencyGraph();
523
+ const uniqueDependencyKeys = new Set();
524
+ const fanIn = new Map();
525
+ const fanOut = new Map();
526
+ for (const fileNode of graph.nodes) {
527
+ fanIn.set(fileNode.id, 0);
528
+ fanOut.set(fileNode.id, 0);
529
+ }
530
+ for (const edge of graph.edges) {
531
+ const dedupeKey = `${edge.fromId}->${edge.toId}`;
532
+ if (uniqueDependencyKeys.has(dedupeKey)) {
533
+ continue;
534
+ }
535
+ uniqueDependencyKeys.add(dedupeKey);
536
+ fanOut.set(edge.fromId, (fanOut.get(edge.fromId) ?? 0) + 1);
537
+ fanIn.set(edge.toId, (fanIn.get(edge.toId) ?? 0) + 1);
538
+ }
539
+ const hotspots = graph.nodes
540
+ .map((node) => {
541
+ const incoming = fanIn.get(node.id) ?? 0;
542
+ const outgoing = fanOut.get(node.id) ?? 0;
543
+ return {
544
+ nodeId: node.id,
545
+ path: node.path,
546
+ fanIn: incoming,
547
+ fanOut: outgoing,
548
+ score: incoming + outgoing,
549
+ };
550
+ })
551
+ .sort((left, right) => right.score - left.score || left.nodeId.localeCompare(right.nodeId))
552
+ .slice(0, boundedLimit);
553
+ const orphanModules = graph.nodes
554
+ .filter((node) => (fanIn.get(node.id) ?? 0) === 0 && (fanOut.get(node.id) ?? 0) === 0)
555
+ .map((node) => ({ nodeId: node.id, path: node.path }))
556
+ .sort((left, right) => left.nodeId.localeCompare(right.nodeId));
557
+ const importedNamesByFile = new Map();
558
+ const importRows = this.db
559
+ .prepare(`
560
+ SELECT to_id, json_props
561
+ FROM edges
562
+ WHERE UPPER(type) = 'IMPORTS'
563
+ `)
564
+ .all();
565
+ for (const row of importRows) {
566
+ const names = importedNamesByFile.get(row.to_id) ?? new Set();
567
+ const specifiers = parseSpecifiers(row.json_props);
568
+ if (specifiers.length === 0) {
569
+ names.add("*");
570
+ }
571
+ else {
572
+ for (const specifier of specifiers) {
573
+ names.add(specifier);
574
+ }
575
+ }
576
+ importedNamesByFile.set(row.to_id, names);
577
+ }
578
+ const exportedRows = this.db
579
+ .prepare(`
580
+ SELECT
581
+ symbol.id AS symbol_id,
582
+ symbol.name AS symbol_name,
583
+ file.id AS file_id,
584
+ file.path AS file_path
585
+ FROM edges exported
586
+ JOIN nodes file ON file.id = exported.from_id
587
+ JOIN nodes symbol ON symbol.id = exported.to_id
588
+ WHERE UPPER(exported.type) = 'EXPORTS'
589
+ ORDER BY file.id ASC, symbol.id ASC
590
+ `)
591
+ .all();
592
+ const unusedExports = exportedRows
593
+ .filter((row) => {
594
+ const importedNames = importedNamesByFile.get(row.file_id);
595
+ if (!importedNames) {
596
+ return true;
597
+ }
598
+ if (importedNames.has("*")) {
599
+ return false;
600
+ }
601
+ const symbolName = row.symbol_name ?? "";
602
+ if (importedNames.has(symbolName)) {
603
+ return false;
604
+ }
605
+ return !importedNames.has("default");
606
+ })
607
+ .map((row) => ({
608
+ symbolId: row.symbol_id,
609
+ name: row.symbol_name,
610
+ fileId: row.file_id,
611
+ filePath: row.file_path,
612
+ }));
613
+ return {
614
+ hotspots,
615
+ orphanModules,
616
+ unusedExports,
617
+ cycleCount: this.getCyclesInfo().totalCycles,
618
+ };
619
+ }
620
+ runDeterministicQuery(queryInput) {
621
+ const query = (0, query_dsl_1.parseGraphQuery)(queryInput);
622
+ return (0, query_engine_1.executeDeterministicQuery)(query, this);
623
+ }
624
+ runQuery(queryInput) {
625
+ return this.runDeterministicQuery(queryInput);
626
+ }
627
+ mapNodeRow(row) {
628
+ return {
629
+ id: row.id,
630
+ type: row.type,
631
+ name: row.name,
632
+ path: row.path,
633
+ props: safeParseJson(row.json_props),
634
+ };
635
+ }
636
+ mapEdgeRow(row) {
637
+ return {
638
+ id: row.id,
639
+ fromId: row.from_id,
640
+ toId: row.to_id,
641
+ type: row.type,
642
+ props: safeParseJson(row.json_props),
643
+ };
644
+ }
645
+ }
646
+ exports.SqliteStore = SqliteStore;
647
+ //# sourceMappingURL=sqlite-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sqlite-store.js","sourceRoot":"","sources":["../../src/store/sqlite-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare const createId: (prefix?: string) => string;
2
+ export declare const isIdWithPrefix: (value: string, prefix: string) => boolean;