maestro-flow 0.4.23 → 0.4.25
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/.agents/skills/maestro-impeccable/SKILL.md +5 -1
- package/.agents/skills/maestro-next/SKILL.md +7 -1
- package/.agents/skills/maestro-player/SKILL.md +9 -2
- package/.agents/skills/maestro-tools-execute/SKILL.md +4 -4
- package/.agents/skills/manage-codebase-rebuild/SKILL.md +4 -6
- package/.agents/skills/spec-load/SKILL.md +11 -4
- package/.agy/skills/maestro-impeccable/SKILL.md +5 -1
- package/.agy/skills/maestro-next/SKILL.md +7 -1
- package/.agy/skills/maestro-player/SKILL.md +9 -2
- package/.agy/skills/maestro-tools-execute/SKILL.md +4 -4
- package/.agy/skills/manage-codebase-rebuild/SKILL.md +4 -6
- package/.agy/skills/spec-load/SKILL.md +11 -4
- package/.claude/commands/maestro-impeccable.md +5 -1
- package/.claude/commands/maestro-next.md +7 -1
- package/.claude/commands/maestro-player.md +9 -2
- package/.claude/commands/maestro-tools-execute.md +4 -4
- package/.claude/commands/manage-codebase-rebuild.md +4 -6
- package/.claude/commands/spec-load.md +11 -4
- package/.codex/skills/manage-codebase-rebuild/SKILL.md +2 -2
- package/dashboard/dist-server/dashboard/src/server/routes/specs.js +96 -25
- package/dashboard/dist-server/dashboard/src/server/routes/specs.js.map +1 -1
- package/dashboard/dist-server/dashboard/src/server/wiki/virtual-wiki-adapters.js +7 -7
- package/dashboard/dist-server/dashboard/src/server/wiki/virtual-wiki-adapters.js.map +1 -1
- package/dashboard/dist-server/dashboard/src/server/wiki/wiki-indexer.js +1 -1
- package/dashboard/dist-server/dashboard/src/server/wiki/wiki-indexer.js.map +1 -1
- package/dashboard/dist-server/dashboard/src/shared/constants.d.ts +1 -0
- package/dashboard/dist-server/dashboard/src/shared/constants.js +1 -0
- package/dashboard/dist-server/dashboard/src/shared/constants.js.map +1 -1
- package/dashboard/dist-server/src/graph/types.d.ts +98 -0
- package/dashboard/dist-server/src/graph/types.js +19 -1
- package/dashboard/dist-server/src/graph/types.js.map +1 -1
- package/dist/src/commands/kg.d.ts.map +1 -1
- package/dist/src/commands/kg.js +345 -2
- package/dist/src/commands/kg.js.map +1 -1
- package/dist/src/commands/spec.d.ts.map +1 -1
- package/dist/src/commands/spec.js +82 -38
- package/dist/src/commands/spec.js.map +1 -1
- package/dist/src/graph/db/connection.d.ts +22 -0
- package/dist/src/graph/db/connection.d.ts.map +1 -0
- package/dist/src/graph/db/connection.js +113 -0
- package/dist/src/graph/db/connection.js.map +1 -0
- package/dist/src/graph/db/index.d.ts +4 -0
- package/dist/src/graph/db/index.d.ts.map +1 -0
- package/dist/src/graph/db/index.js +4 -0
- package/dist/src/graph/db/index.js.map +1 -0
- package/dist/src/graph/db/migrations.d.ts +5 -0
- package/dist/src/graph/db/migrations.d.ts.map +1 -0
- package/dist/src/graph/db/migrations.js +18 -0
- package/dist/src/graph/db/migrations.js.map +1 -0
- package/dist/src/graph/db/queries.d.ts +50 -0
- package/dist/src/graph/db/queries.d.ts.map +1 -0
- package/dist/src/graph/db/queries.js +313 -0
- package/dist/src/graph/db/queries.js.map +1 -0
- package/dist/src/graph/db/schema.sql +131 -0
- package/dist/src/graph/facade.d.ts +53 -0
- package/dist/src/graph/facade.d.ts.map +1 -0
- package/dist/src/graph/facade.js +172 -0
- package/dist/src/graph/facade.js.map +1 -0
- package/dist/src/graph/graph-queries.d.ts +24 -0
- package/dist/src/graph/graph-queries.d.ts.map +1 -0
- package/dist/src/graph/graph-queries.js +173 -0
- package/dist/src/graph/graph-queries.js.map +1 -0
- package/dist/src/graph/index.d.ts +8 -0
- package/dist/src/graph/index.d.ts.map +1 -1
- package/dist/src/graph/index.js +9 -0
- package/dist/src/graph/index.js.map +1 -1
- package/dist/src/graph/loader.d.ts +8 -0
- package/dist/src/graph/loader.d.ts.map +1 -1
- package/dist/src/graph/loader.js +20 -0
- package/dist/src/graph/loader.js.map +1 -1
- package/dist/src/graph/migration.d.ts +8 -0
- package/dist/src/graph/migration.d.ts.map +1 -0
- package/dist/src/graph/migration.js +134 -0
- package/dist/src/graph/migration.js.map +1 -0
- package/dist/src/graph/search/index.d.ts +4 -0
- package/dist/src/graph/search/index.d.ts.map +1 -0
- package/dist/src/graph/search/index.js +3 -0
- package/dist/src/graph/search/index.js.map +1 -0
- package/dist/src/graph/search/query-parser.d.ts +11 -0
- package/dist/src/graph/search/query-parser.d.ts.map +1 -0
- package/dist/src/graph/search/query-parser.js +111 -0
- package/dist/src/graph/search/query-parser.js.map +1 -0
- package/dist/src/graph/search/query-utils.d.ts +12 -0
- package/dist/src/graph/search/query-utils.d.ts.map +1 -0
- package/dist/src/graph/search/query-utils.js +184 -0
- package/dist/src/graph/search/query-utils.js.map +1 -0
- package/dist/src/graph/sync/content-hash.d.ts +7 -0
- package/dist/src/graph/sync/content-hash.d.ts.map +1 -0
- package/dist/src/graph/sync/content-hash.js +33 -0
- package/dist/src/graph/sync/content-hash.js.map +1 -0
- package/dist/src/graph/sync/incremental-sync.d.ts +23 -0
- package/dist/src/graph/sync/incremental-sync.d.ts.map +1 -0
- package/dist/src/graph/sync/incremental-sync.js +338 -0
- package/dist/src/graph/sync/incremental-sync.js.map +1 -0
- package/dist/src/graph/sync/index.d.ts +7 -0
- package/dist/src/graph/sync/index.d.ts.map +1 -0
- package/dist/src/graph/sync/index.js +5 -0
- package/dist/src/graph/sync/index.js.map +1 -0
- package/dist/src/graph/sync/watch-policy.d.ts +2 -0
- package/dist/src/graph/sync/watch-policy.d.ts.map +1 -0
- package/dist/src/graph/sync/watch-policy.js +38 -0
- package/dist/src/graph/sync/watch-policy.js.map +1 -0
- package/dist/src/graph/sync/watcher.d.ts +44 -0
- package/dist/src/graph/sync/watcher.d.ts.map +1 -0
- package/dist/src/graph/sync/watcher.js +153 -0
- package/dist/src/graph/sync/watcher.js.map +1 -0
- package/dist/src/graph/traversal.d.ts +37 -0
- package/dist/src/graph/traversal.d.ts.map +1 -0
- package/dist/src/graph/traversal.js +335 -0
- package/dist/src/graph/traversal.js.map +1 -0
- package/dist/src/graph/types.d.ts +98 -0
- package/dist/src/graph/types.d.ts.map +1 -1
- package/dist/src/graph/types.js +19 -1
- package/dist/src/graph/types.js.map +1 -1
- package/dist/src/utils/update-notices.js +11 -0
- package/dist/src/utils/update-notices.js.map +1 -1
- package/package.json +4 -2
- package/workflows/analyze.md +19 -13
- package/workflows/codebase-rebuild.md +18 -107
- package/workflows/execute.md +6 -5
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
import { existsSync } from 'node:fs';
|
|
2
|
+
import { loadGraph } from './loader.js';
|
|
3
|
+
import { searchNodes as searchNodesJson, findPath as findPathJson, diffChanges as diffChangesJson } from './query.js';
|
|
4
|
+
import { DatabaseConnection, getDatabasePath } from './db/connection.js';
|
|
5
|
+
import { QueryBuilder } from './db/queries.js';
|
|
6
|
+
import { GraphTraverser } from './traversal.js';
|
|
7
|
+
import { GraphQueryManager } from './graph-queries.js';
|
|
8
|
+
import { IncrementalSync } from './sync/incremental-sync.js';
|
|
9
|
+
import { parseQuery } from './search/query-parser.js';
|
|
10
|
+
export function detectBackend(projectRoot) {
|
|
11
|
+
const dbPath = getDatabasePath(projectRoot);
|
|
12
|
+
if (existsSync(dbPath))
|
|
13
|
+
return 'sqlite';
|
|
14
|
+
try {
|
|
15
|
+
loadGraph();
|
|
16
|
+
return 'json';
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
return 'none';
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export class GraphFacade {
|
|
23
|
+
backend;
|
|
24
|
+
conn = null;
|
|
25
|
+
queries = null;
|
|
26
|
+
manager = null;
|
|
27
|
+
traverser = null;
|
|
28
|
+
jsonGraph = null;
|
|
29
|
+
constructor(projectRoot) {
|
|
30
|
+
this.backend = detectBackend(projectRoot);
|
|
31
|
+
if (this.backend === 'sqlite') {
|
|
32
|
+
this.conn = new DatabaseConnection();
|
|
33
|
+
this.conn.open(getDatabasePath(projectRoot));
|
|
34
|
+
this.queries = new QueryBuilder(this.conn);
|
|
35
|
+
this.manager = new GraphQueryManager(this.queries);
|
|
36
|
+
this.traverser = new GraphTraverser(this.queries);
|
|
37
|
+
}
|
|
38
|
+
else if (this.backend === 'json') {
|
|
39
|
+
this.jsonGraph = loadGraph();
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
getBackend() {
|
|
43
|
+
return this.backend;
|
|
44
|
+
}
|
|
45
|
+
close() {
|
|
46
|
+
this.conn?.close();
|
|
47
|
+
this.conn = null;
|
|
48
|
+
}
|
|
49
|
+
search(query, opts) {
|
|
50
|
+
if (this.backend === 'sqlite' && this.queries) {
|
|
51
|
+
const parsed = parseQuery(query);
|
|
52
|
+
const nodes = this.queries.searchNodes(parsed.text || query, {
|
|
53
|
+
kinds: parsed.kinds.length > 0 ? parsed.kinds : undefined,
|
|
54
|
+
languages: parsed.languages.length > 0 ? parsed.languages : undefined,
|
|
55
|
+
pathFilters: parsed.pathFilters.length > 0 ? parsed.pathFilters : undefined,
|
|
56
|
+
nameFilters: parsed.nameFilters.length > 0 ? parsed.nameFilters : undefined,
|
|
57
|
+
limit: opts?.limit ?? 10,
|
|
58
|
+
});
|
|
59
|
+
return nodes.map(n => ({
|
|
60
|
+
id: n.id, kind: n.kind, name: n.name, filePath: n.filePath,
|
|
61
|
+
summary: n.signature || n.docstring,
|
|
62
|
+
}));
|
|
63
|
+
}
|
|
64
|
+
if (this.jsonGraph) {
|
|
65
|
+
const results = searchNodesJson(this.jsonGraph, query, { limit: opts?.limit, type: opts?.type });
|
|
66
|
+
return results.map(n => ({
|
|
67
|
+
id: n.id, kind: n.type, name: n.name, filePath: n.filePath,
|
|
68
|
+
summary: n.summary,
|
|
69
|
+
}));
|
|
70
|
+
}
|
|
71
|
+
return [];
|
|
72
|
+
}
|
|
73
|
+
findPath(fromId, toId) {
|
|
74
|
+
if (this.jsonGraph) {
|
|
75
|
+
const result = findPathJson(this.jsonGraph, fromId, toId);
|
|
76
|
+
return result.found ? result : null;
|
|
77
|
+
}
|
|
78
|
+
if (this.traverser) {
|
|
79
|
+
const path = this.traverser.findPath(fromId, toId);
|
|
80
|
+
if (!path)
|
|
81
|
+
return null;
|
|
82
|
+
return {
|
|
83
|
+
from: fromId,
|
|
84
|
+
to: toId,
|
|
85
|
+
found: true,
|
|
86
|
+
length: path.length - 1,
|
|
87
|
+
steps: path.map((step, i) => ({
|
|
88
|
+
node: step.node.id,
|
|
89
|
+
type: step.node.kind,
|
|
90
|
+
name: step.node.name,
|
|
91
|
+
edgeToNext: i < path.length - 1 ? path[i + 1]?.edge?.kind : undefined,
|
|
92
|
+
})),
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
return null;
|
|
96
|
+
}
|
|
97
|
+
diffChanges(changedFiles) {
|
|
98
|
+
if (this.jsonGraph)
|
|
99
|
+
return diffChangesJson(this.jsonGraph, changedFiles);
|
|
100
|
+
if (this.queries && this.traverser) {
|
|
101
|
+
const direct = [];
|
|
102
|
+
const impactedIds = new Set();
|
|
103
|
+
for (const file of changedFiles) {
|
|
104
|
+
const nodes = this.queries.getNodesByFile(file);
|
|
105
|
+
for (const n of nodes) {
|
|
106
|
+
direct.push({ id: n.id, type: n.kind, name: n.name, filePath: n.filePath, summary: n.signature || n.docstring, tags: [n.kind] });
|
|
107
|
+
const impact = this.traverser.getImpactRadius(n.id, 1);
|
|
108
|
+
for (const impacted of impact.nodes.values()) {
|
|
109
|
+
if (!direct.some(d => d.id === impacted.id))
|
|
110
|
+
impactedIds.add(impacted.id);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
const impacted = [];
|
|
115
|
+
if (impactedIds.size > 0) {
|
|
116
|
+
const impactedNodes = this.queries.getNodesByIds([...impactedIds]);
|
|
117
|
+
for (const n of impactedNodes.values()) {
|
|
118
|
+
impacted.push({ id: n.id, type: n.kind, name: n.name, filePath: n.filePath, summary: n.signature || n.docstring, tags: [n.kind] });
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
return { changedFiles, direct, impacted };
|
|
122
|
+
}
|
|
123
|
+
return { changedFiles, direct: [], impacted: [] };
|
|
124
|
+
}
|
|
125
|
+
stats() {
|
|
126
|
+
if (this.queries && this.conn) {
|
|
127
|
+
return this.queries.getStats(this.conn.getSize());
|
|
128
|
+
}
|
|
129
|
+
return null;
|
|
130
|
+
}
|
|
131
|
+
// SQLite-only methods
|
|
132
|
+
getCallers(nodeId, depth) {
|
|
133
|
+
this.requireSqlite('getCallers');
|
|
134
|
+
return this.traverser.getCallers(nodeId, depth ?? 2);
|
|
135
|
+
}
|
|
136
|
+
getCallees(nodeId, depth) {
|
|
137
|
+
this.requireSqlite('getCallees');
|
|
138
|
+
return this.traverser.getCallees(nodeId, depth ?? 2);
|
|
139
|
+
}
|
|
140
|
+
getImpactRadius(nodeId, depth) {
|
|
141
|
+
this.requireSqlite('getImpactRadius');
|
|
142
|
+
return this.traverser.getImpactRadius(nodeId, depth ?? 3);
|
|
143
|
+
}
|
|
144
|
+
findDeadCode(kinds) {
|
|
145
|
+
this.requireSqlite('findDeadCode');
|
|
146
|
+
return this.manager.findDeadCode(kinds);
|
|
147
|
+
}
|
|
148
|
+
findCircularDependencies() {
|
|
149
|
+
this.requireSqlite('findCircularDependencies');
|
|
150
|
+
return this.manager.findCircularDependencies();
|
|
151
|
+
}
|
|
152
|
+
getContext(nodeId) {
|
|
153
|
+
this.requireSqlite('getContext');
|
|
154
|
+
return this.manager.getContext(nodeId);
|
|
155
|
+
}
|
|
156
|
+
getNodeMetrics(nodeId) {
|
|
157
|
+
this.requireSqlite('getNodeMetrics');
|
|
158
|
+
return this.manager.getNodeMetrics(nodeId);
|
|
159
|
+
}
|
|
160
|
+
sync() {
|
|
161
|
+
this.requireSqlite('sync');
|
|
162
|
+
const sync = new IncrementalSync(process.cwd(), this.conn);
|
|
163
|
+
const result = sync.sync();
|
|
164
|
+
return { filesChanged: result.filesChanged, durationMs: result.durationMs };
|
|
165
|
+
}
|
|
166
|
+
requireSqlite(method) {
|
|
167
|
+
if (this.backend !== 'sqlite') {
|
|
168
|
+
throw new Error(`${method}() requires SQLite backend. Run "maestro kg index --sqlite" first.`);
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
//# sourceMappingURL=facade.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"facade.js","sourceRoot":"","sources":["../../../src/graph/facade.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { EnhancedNode, NodeContext, NodeKind } from './types.js';
|
|
2
|
+
import type { QueryBuilder } from './db/queries.js';
|
|
3
|
+
import { GraphTraverser } from './traversal.js';
|
|
4
|
+
export declare class GraphQueryManager {
|
|
5
|
+
private queries;
|
|
6
|
+
private traverser;
|
|
7
|
+
constructor(queries: QueryBuilder);
|
|
8
|
+
getTraverser(): GraphTraverser;
|
|
9
|
+
getContext(nodeId: string): NodeContext;
|
|
10
|
+
getFileDependencies(filePath: string): string[];
|
|
11
|
+
getFileDependents(filePath: string): string[];
|
|
12
|
+
getExportedSymbols(filePath: string): EnhancedNode[];
|
|
13
|
+
findCircularDependencies(): string[][];
|
|
14
|
+
findDeadCode(kinds?: NodeKind[]): EnhancedNode[];
|
|
15
|
+
getNodeMetrics(nodeId: string): {
|
|
16
|
+
incomingEdgeCount: number;
|
|
17
|
+
outgoingEdgeCount: number;
|
|
18
|
+
callCount: number;
|
|
19
|
+
callerCount: number;
|
|
20
|
+
childCount: number;
|
|
21
|
+
depth: number;
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=graph-queries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph-queries.d.ts","sourceRoot":"","sources":["../../../src/graph/graph-queries.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAgB,WAAW,EAAY,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC9F,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEhD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAAe;IAC9B,OAAO,CAAC,SAAS,CAAiB;gBAEtB,OAAO,EAAE,YAAY;IAKjC,YAAY,IAAI,cAAc;IAI9B,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,WAAW;IAwDvC,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,EAAE;IAe/C,iBAAiB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,EAAE;IA6B7C,kBAAkB,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,EAAE;IAKpD,wBAAwB,IAAI,MAAM,EAAE,EAAE;IA2BtC,YAAY,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,GAAG,YAAY,EAAE;IAgBhD,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG;QAC9B,iBAAiB,EAAE,MAAM,CAAC;QAC1B,iBAAiB,EAAE,MAAM,CAAC;QAC1B,SAAS,EAAE,MAAM,CAAC;QAClB,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,EAAE,MAAM,CAAC;QACnB,KAAK,EAAE,MAAM,CAAC;KACf;CAaF"}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { GraphTraverser } from './traversal.js';
|
|
2
|
+
export class GraphQueryManager {
|
|
3
|
+
queries;
|
|
4
|
+
traverser;
|
|
5
|
+
constructor(queries) {
|
|
6
|
+
this.queries = queries;
|
|
7
|
+
this.traverser = new GraphTraverser(queries);
|
|
8
|
+
}
|
|
9
|
+
getTraverser() {
|
|
10
|
+
return this.traverser;
|
|
11
|
+
}
|
|
12
|
+
getContext(nodeId) {
|
|
13
|
+
const focal = this.queries.getNodeById(nodeId);
|
|
14
|
+
if (!focal)
|
|
15
|
+
throw new Error(`Node not found: ${nodeId}`);
|
|
16
|
+
const ancestors = this.traverser.getAncestors(nodeId);
|
|
17
|
+
const children = this.traverser.getChildren(nodeId);
|
|
18
|
+
const incomingEdges = this.queries.getIncomingEdges(nodeId);
|
|
19
|
+
const incomingRefs = [];
|
|
20
|
+
const inSourceIds = incomingEdges.filter(e => e.kind !== 'contains').map(e => e.source);
|
|
21
|
+
const inSources = inSourceIds.length > 0 ? this.queries.getNodesByIds(inSourceIds) : new Map();
|
|
22
|
+
for (const edge of incomingEdges) {
|
|
23
|
+
if (edge.kind === 'contains')
|
|
24
|
+
continue;
|
|
25
|
+
const node = inSources.get(edge.source);
|
|
26
|
+
if (node)
|
|
27
|
+
incomingRefs.push({ node, edge });
|
|
28
|
+
}
|
|
29
|
+
const outgoingEdges = this.queries.getOutgoingEdges(nodeId);
|
|
30
|
+
const outgoingRefs = [];
|
|
31
|
+
const outTargetIds = outgoingEdges.filter(e => e.kind !== 'contains').map(e => e.target);
|
|
32
|
+
const outTargets = outTargetIds.length > 0 ? this.queries.getNodesByIds(outTargetIds) : new Map();
|
|
33
|
+
for (const edge of outgoingEdges) {
|
|
34
|
+
if (edge.kind === 'contains')
|
|
35
|
+
continue;
|
|
36
|
+
const node = outTargets.get(edge.target);
|
|
37
|
+
if (node)
|
|
38
|
+
outgoingRefs.push({ node, edge });
|
|
39
|
+
}
|
|
40
|
+
const types = [];
|
|
41
|
+
const typeEdgeKinds = ['type_of', 'returns'];
|
|
42
|
+
for (const kind of typeEdgeKinds) {
|
|
43
|
+
const typeEdges = this.queries.getOutgoingEdges(nodeId, [kind]);
|
|
44
|
+
const typeNodes = typeEdges.length > 0
|
|
45
|
+
? this.queries.getNodesByIds(typeEdges.map(e => e.target))
|
|
46
|
+
: new Map();
|
|
47
|
+
for (const edge of typeEdges) {
|
|
48
|
+
const typeNode = typeNodes.get(edge.target);
|
|
49
|
+
if (typeNode && !types.some(t => t.id === typeNode.id))
|
|
50
|
+
types.push(typeNode);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
const imports = [];
|
|
54
|
+
const fileNode = ancestors.find(a => a.kind === 'file');
|
|
55
|
+
if (fileNode) {
|
|
56
|
+
const importEdges = this.queries.getOutgoingEdges(fileNode.id, ['imports']);
|
|
57
|
+
const importNodes = importEdges.length > 0
|
|
58
|
+
? this.queries.getNodesByIds(importEdges.map(e => e.target))
|
|
59
|
+
: new Map();
|
|
60
|
+
for (const edge of importEdges) {
|
|
61
|
+
const importNode = importNodes.get(edge.target);
|
|
62
|
+
if (importNode)
|
|
63
|
+
imports.push(importNode);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return { focal, ancestors, children, incomingRefs, outgoingRefs, types, imports };
|
|
67
|
+
}
|
|
68
|
+
getFileDependencies(filePath) {
|
|
69
|
+
const nodes = this.queries.getNodesByFile(filePath);
|
|
70
|
+
const fileNode = nodes.find(n => n.kind === 'file');
|
|
71
|
+
if (!fileNode)
|
|
72
|
+
return [];
|
|
73
|
+
const dependencies = new Set();
|
|
74
|
+
const importEdges = this.queries.getOutgoingEdges(fileNode.id, ['imports']);
|
|
75
|
+
const targetIds = importEdges.map(e => e.target);
|
|
76
|
+
const targets = targetIds.length > 0 ? this.queries.getNodesByIds(targetIds) : new Map();
|
|
77
|
+
for (const edge of importEdges) {
|
|
78
|
+
const targetNode = targets.get(edge.target);
|
|
79
|
+
if (targetNode && targetNode.filePath !== filePath)
|
|
80
|
+
dependencies.add(targetNode.filePath);
|
|
81
|
+
}
|
|
82
|
+
return Array.from(dependencies);
|
|
83
|
+
}
|
|
84
|
+
getFileDependents(filePath) {
|
|
85
|
+
const nodes = this.queries.getNodesByFile(filePath);
|
|
86
|
+
const dependents = new Set();
|
|
87
|
+
const fileNode = nodes.find(n => n.kind === 'file');
|
|
88
|
+
if (fileNode) {
|
|
89
|
+
const incomingEdges = this.queries.getIncomingEdges(fileNode.id, ['imports']);
|
|
90
|
+
const sourceIds = incomingEdges.map(e => e.source);
|
|
91
|
+
const sources = sourceIds.length > 0 ? this.queries.getNodesByIds(sourceIds) : new Map();
|
|
92
|
+
for (const edge of incomingEdges) {
|
|
93
|
+
const sourceNode = sources.get(edge.source);
|
|
94
|
+
if (sourceNode && sourceNode.filePath !== filePath)
|
|
95
|
+
dependents.add(sourceNode.filePath);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
for (const node of nodes) {
|
|
99
|
+
if (node.isExported) {
|
|
100
|
+
const incomingEdges = this.queries.getIncomingEdges(node.id, ['imports']);
|
|
101
|
+
const sourceIds = incomingEdges.map(e => e.source);
|
|
102
|
+
const sources = sourceIds.length > 0 ? this.queries.getNodesByIds(sourceIds) : new Map();
|
|
103
|
+
for (const edge of incomingEdges) {
|
|
104
|
+
const sourceNode = sources.get(edge.source);
|
|
105
|
+
if (sourceNode && sourceNode.filePath !== filePath)
|
|
106
|
+
dependents.add(sourceNode.filePath);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return Array.from(dependents);
|
|
111
|
+
}
|
|
112
|
+
getExportedSymbols(filePath) {
|
|
113
|
+
const nodes = this.queries.getNodesByFile(filePath);
|
|
114
|
+
return nodes.filter(n => n.isExported);
|
|
115
|
+
}
|
|
116
|
+
findCircularDependencies() {
|
|
117
|
+
const files = this.queries.getAllFiles();
|
|
118
|
+
const cycles = [];
|
|
119
|
+
const visited = new Set();
|
|
120
|
+
const recursionStack = new Set();
|
|
121
|
+
const dfs = (filePath, path) => {
|
|
122
|
+
if (recursionStack.has(filePath)) {
|
|
123
|
+
const cycleStart = path.indexOf(filePath);
|
|
124
|
+
if (cycleStart !== -1)
|
|
125
|
+
cycles.push(path.slice(cycleStart));
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
if (visited.has(filePath))
|
|
129
|
+
return;
|
|
130
|
+
visited.add(filePath);
|
|
131
|
+
recursionStack.add(filePath);
|
|
132
|
+
const dependencies = this.getFileDependencies(filePath);
|
|
133
|
+
for (const dep of dependencies)
|
|
134
|
+
dfs(dep, [...path, filePath]);
|
|
135
|
+
recursionStack.delete(filePath);
|
|
136
|
+
};
|
|
137
|
+
for (const file of files) {
|
|
138
|
+
if (!visited.has(file.path))
|
|
139
|
+
dfs(file.path, []);
|
|
140
|
+
}
|
|
141
|
+
return cycles;
|
|
142
|
+
}
|
|
143
|
+
findDeadCode(kinds) {
|
|
144
|
+
const targetKinds = kinds ?? ['function', 'method', 'class'];
|
|
145
|
+
const deadCode = [];
|
|
146
|
+
for (const kind of targetKinds) {
|
|
147
|
+
const nodes = this.queries.getNodesByKind(kind);
|
|
148
|
+
for (const node of nodes) {
|
|
149
|
+
if (node.isExported)
|
|
150
|
+
continue;
|
|
151
|
+
const incomingEdges = this.queries.getIncomingEdges(node.id);
|
|
152
|
+
const references = incomingEdges.filter(e => e.kind !== 'contains');
|
|
153
|
+
if (references.length === 0)
|
|
154
|
+
deadCode.push(node);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
return deadCode;
|
|
158
|
+
}
|
|
159
|
+
getNodeMetrics(nodeId) {
|
|
160
|
+
const incomingEdges = this.queries.getIncomingEdges(nodeId);
|
|
161
|
+
const outgoingEdges = this.queries.getOutgoingEdges(nodeId);
|
|
162
|
+
const ancestors = this.traverser.getAncestors(nodeId);
|
|
163
|
+
return {
|
|
164
|
+
incomingEdgeCount: incomingEdges.length,
|
|
165
|
+
outgoingEdgeCount: outgoingEdges.length,
|
|
166
|
+
callCount: outgoingEdges.filter(e => e.kind === 'calls').length,
|
|
167
|
+
callerCount: incomingEdges.filter(e => e.kind === 'calls').length,
|
|
168
|
+
childCount: outgoingEdges.filter(e => e.kind === 'contains').length,
|
|
169
|
+
depth: ancestors.length,
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
//# sourceMappingURL=graph-queries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph-queries.js","sourceRoot":"","sources":["../../../src/graph/graph-queries.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,4 +3,12 @@ export { loadGraph } from './loader.js';
|
|
|
3
3
|
export { mergeGraphs, linkTests, normalizeNodeId, normalizeComplexity, normalizeDirection, isTestPath, productionCandidates, recoverImportsFromScan, } from './merger.js';
|
|
4
4
|
export { searchNodes, findPath, diffChanges, countBy, truncate } from './query.js';
|
|
5
5
|
export { FsAnalyzer } from './analyzers/fs-analyzer.js';
|
|
6
|
+
export { DatabaseConnection, QueryBuilder, getDatabasePath } from './db/index.js';
|
|
7
|
+
export { GraphTraverser } from './traversal.js';
|
|
8
|
+
export { GraphQueryManager } from './graph-queries.js';
|
|
9
|
+
export { parseQuery, extractSearchTerms, scorePathRelevance, nameMatchBonus, kindBonus } from './search/index.js';
|
|
10
|
+
export { IncrementalSync, FileWatcher } from './sync/index.js';
|
|
11
|
+
export { GraphFacade, detectBackend as detectGraphBackend } from './facade.js';
|
|
12
|
+
export { migrateJsonToSqlite, exportSqliteToJson } from './migration.js';
|
|
13
|
+
export { loadGraphSqlite, detectBackend } from './loader.js';
|
|
6
14
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/graph/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EACL,WAAW,EACX,SAAS,EACT,eAAe,EACf,mBAAmB,EACnB,kBAAkB,EAClB,UAAU,EACV,oBAAoB,EACpB,sBAAsB,GACvB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/graph/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EACL,WAAW,EACX,SAAS,EACT,eAAe,EACf,mBAAmB,EACnB,kBAAkB,EAClB,UAAU,EACV,oBAAoB,EACpB,sBAAsB,GACvB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAGxD,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAClH,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,aAAa,IAAI,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC/E,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC"}
|
package/dist/src/graph/index.js
CHANGED
|
@@ -3,4 +3,13 @@ export { loadGraph } from './loader.js';
|
|
|
3
3
|
export { mergeGraphs, linkTests, normalizeNodeId, normalizeComplexity, normalizeDirection, isTestPath, productionCandidates, recoverImportsFromScan, } from './merger.js';
|
|
4
4
|
export { searchNodes, findPath, diffChanges, countBy, truncate } from './query.js';
|
|
5
5
|
export { FsAnalyzer } from './analyzers/fs-analyzer.js';
|
|
6
|
+
// Enhanced modules (codegraph-derived)
|
|
7
|
+
export { DatabaseConnection, QueryBuilder, getDatabasePath } from './db/index.js';
|
|
8
|
+
export { GraphTraverser } from './traversal.js';
|
|
9
|
+
export { GraphQueryManager } from './graph-queries.js';
|
|
10
|
+
export { parseQuery, extractSearchTerms, scorePathRelevance, nameMatchBonus, kindBonus } from './search/index.js';
|
|
11
|
+
export { IncrementalSync, FileWatcher } from './sync/index.js';
|
|
12
|
+
export { GraphFacade, detectBackend as detectGraphBackend } from './facade.js';
|
|
13
|
+
export { migrateJsonToSqlite, exportSqliteToJson } from './migration.js';
|
|
14
|
+
export { loadGraphSqlite, detectBackend } from './loader.js';
|
|
6
15
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/graph/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EACL,WAAW,EACX,SAAS,EACT,eAAe,EACf,mBAAmB,EACnB,kBAAkB,EAClB,UAAU,EACV,oBAAoB,EACpB,sBAAsB,GACvB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/graph/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,EACL,WAAW,EACX,SAAS,EACT,eAAe,EACf,mBAAmB,EACnB,kBAAkB,EAClB,UAAU,EACV,oBAAoB,EACpB,sBAAsB,GACvB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACnF,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAExD,uCAAuC;AACvC,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAClH,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,aAAa,IAAI,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC/E,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1,3 +1,11 @@
|
|
|
1
1
|
import type { KnowledgeGraph } from './types.js';
|
|
2
|
+
import { DatabaseConnection } from './db/connection.js';
|
|
3
|
+
import { QueryBuilder } from './db/queries.js';
|
|
4
|
+
export type DetectedBackend = 'sqlite' | 'json' | 'none';
|
|
2
5
|
export declare function loadGraph(kgPath?: string): KnowledgeGraph;
|
|
6
|
+
export declare function loadGraphSqlite(projectRoot?: string): {
|
|
7
|
+
conn: DatabaseConnection;
|
|
8
|
+
queries: QueryBuilder;
|
|
9
|
+
};
|
|
10
|
+
export declare function detectBackend(projectRoot?: string): DetectedBackend;
|
|
3
11
|
//# sourceMappingURL=loader.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../../src/graph/loader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../../src/graph/loader.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAmB,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAI/C,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;AAEzD,wBAAgB,SAAS,CAAC,MAAM,GAAE,MAAwB,GAAG,cAAc,CAO1E;AAED,wBAAgB,eAAe,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG;IAAE,IAAI,EAAE,kBAAkB,CAAC;IAAC,OAAO,EAAE,YAAY,CAAA;CAAE,CAQzG;AAED,wBAAgB,aAAa,CAAC,WAAW,CAAC,EAAE,MAAM,GAAG,eAAe,CAMnE"}
|
package/dist/src/graph/loader.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { readFileSync, existsSync } from 'node:fs';
|
|
2
2
|
import { resolve } from 'node:path';
|
|
3
|
+
import { DatabaseConnection, getDatabasePath } from './db/connection.js';
|
|
4
|
+
import { QueryBuilder } from './db/queries.js';
|
|
3
5
|
const DEFAULT_KG_PATH = '.workflow/codebase/knowledge-graph.json';
|
|
4
6
|
export function loadGraph(kgPath = DEFAULT_KG_PATH) {
|
|
5
7
|
const fullPath = resolve(kgPath);
|
|
@@ -9,4 +11,22 @@ export function loadGraph(kgPath = DEFAULT_KG_PATH) {
|
|
|
9
11
|
const raw = readFileSync(fullPath, 'utf-8');
|
|
10
12
|
return JSON.parse(raw);
|
|
11
13
|
}
|
|
14
|
+
export function loadGraphSqlite(projectRoot) {
|
|
15
|
+
const dbPath = getDatabasePath(projectRoot);
|
|
16
|
+
if (!existsSync(dbPath)) {
|
|
17
|
+
throw new Error(`SQLite graph not found: ${dbPath}`);
|
|
18
|
+
}
|
|
19
|
+
const conn = new DatabaseConnection();
|
|
20
|
+
conn.open(dbPath);
|
|
21
|
+
return { conn, queries: new QueryBuilder(conn) };
|
|
22
|
+
}
|
|
23
|
+
export function detectBackend(projectRoot) {
|
|
24
|
+
const dbPath = getDatabasePath(projectRoot);
|
|
25
|
+
if (existsSync(dbPath))
|
|
26
|
+
return 'sqlite';
|
|
27
|
+
const jsonPath = resolve(projectRoot ?? process.cwd(), DEFAULT_KG_PATH);
|
|
28
|
+
if (existsSync(jsonPath))
|
|
29
|
+
return 'json';
|
|
30
|
+
return 'none';
|
|
31
|
+
}
|
|
12
32
|
//# sourceMappingURL=loader.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../src/graph/loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../src/graph/loader.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,MAAM,eAAe,GAAG,yCAAyC,CAAC;AAIlE,MAAM,UAAU,SAAS,CAAC,SAAiB,eAAe;IACxD,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IACjC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,MAAM,IAAI,KAAK,CAAC,8BAA8B,QAAQ,EAAE,CAAC,CAAC;IAC5D,CAAC;IACD,MAAM,GAAG,GAAG,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAmB,CAAC;AAC3C,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,WAAoB;IAClD,MAAM,MAAM,GAAG,eAAe,CAAC,WAAW,CAAC,CAAC;IAC5C,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,2BAA2B,MAAM,EAAE,CAAC,CAAC;IACvD,CAAC;IACD,MAAM,IAAI,GAAG,IAAI,kBAAkB,EAAE,CAAC;IACtC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClB,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,WAAoB;IAChD,MAAM,MAAM,GAAG,eAAe,CAAC,WAAW,CAAC,CAAC;IAC5C,IAAI,UAAU,CAAC,MAAM,CAAC;QAAE,OAAO,QAAQ,CAAC;IACxC,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE,EAAE,eAAe,CAAC,CAAC;IACxE,IAAI,UAAU,CAAC,QAAQ,CAAC;QAAE,OAAO,MAAM,CAAC;IACxC,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { KnowledgeGraph } from './types.js';
|
|
2
|
+
export declare function migrateJsonToSqlite(jsonPath?: string, dbPath?: string): {
|
|
3
|
+
nodes: number;
|
|
4
|
+
edges: number;
|
|
5
|
+
dbPath: string;
|
|
6
|
+
};
|
|
7
|
+
export declare function exportSqliteToJson(dbPath?: string): KnowledgeGraph;
|
|
8
|
+
//# sourceMappingURL=migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migration.d.ts","sourceRoot":"","sources":["../../../src/graph/migration.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,cAAc,EAAkF,MAAM,YAAY,CAAC;AAyDjI,wBAAgB,mBAAmB,CAAC,QAAQ,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG;IACvE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;CAC9C,CA4BA;AAED,wBAAgB,kBAAkB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,cAAc,CA0DlE"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { existsSync, mkdirSync } from 'node:fs';
|
|
2
|
+
import { dirname } from 'node:path';
|
|
3
|
+
import { loadGraph } from './loader.js';
|
|
4
|
+
import { DatabaseConnection, getDatabasePath } from './db/connection.js';
|
|
5
|
+
import { QueryBuilder } from './db/queries.js';
|
|
6
|
+
const NODE_TYPE_TO_KIND = {
|
|
7
|
+
file: 'file', function: 'function', func: 'function', class: 'class',
|
|
8
|
+
module: 'module', interface: 'interface', enum: 'enum', type: 'type_alias',
|
|
9
|
+
type_alias: 'type_alias', variable: 'variable', constant: 'constant',
|
|
10
|
+
method: 'method', property: 'property', field: 'field',
|
|
11
|
+
struct: 'struct', trait: 'trait', namespace: 'namespace',
|
|
12
|
+
component: 'component', route: 'route',
|
|
13
|
+
concept: 'module', config: 'file', document: 'file',
|
|
14
|
+
service: 'module', endpoint: 'route', pipeline: 'module',
|
|
15
|
+
schema: 'module', resource: 'module', domain: 'module',
|
|
16
|
+
flow: 'module', step: 'function',
|
|
17
|
+
article: 'file', entity: 'module', topic: 'module', claim: 'variable', source: 'file',
|
|
18
|
+
};
|
|
19
|
+
const EDGE_TYPE_TO_KIND = {
|
|
20
|
+
imports: 'imports', calls: 'calls', contains: 'contains',
|
|
21
|
+
tested_by: 'references', extends: 'extends', implements: 'implements',
|
|
22
|
+
references: 'references', type_of: 'type_of', returns: 'returns',
|
|
23
|
+
exports: 'exports', instantiates: 'instantiates', overrides: 'overrides',
|
|
24
|
+
decorates: 'decorates',
|
|
25
|
+
};
|
|
26
|
+
function graphNodeToEnhanced(node) {
|
|
27
|
+
const kind = NODE_TYPE_TO_KIND[node.type] ?? 'module';
|
|
28
|
+
return {
|
|
29
|
+
id: node.id,
|
|
30
|
+
kind,
|
|
31
|
+
name: node.name,
|
|
32
|
+
qualifiedName: node.id,
|
|
33
|
+
filePath: node.filePath ?? '',
|
|
34
|
+
language: 'unknown',
|
|
35
|
+
startLine: 0, endLine: 0, startColumn: 0, endColumn: 0,
|
|
36
|
+
docstring: node.summary ?? '',
|
|
37
|
+
signature: '',
|
|
38
|
+
visibility: '',
|
|
39
|
+
isExported: false,
|
|
40
|
+
isAsync: false,
|
|
41
|
+
isStatic: false,
|
|
42
|
+
isAbstract: false,
|
|
43
|
+
decorators: [],
|
|
44
|
+
typeParameters: [],
|
|
45
|
+
updatedAt: new Date().toISOString(),
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
function graphEdgeToEnhanced(edge) {
|
|
49
|
+
const kind = EDGE_TYPE_TO_KIND[edge.type] ?? 'references';
|
|
50
|
+
return {
|
|
51
|
+
source: edge.source,
|
|
52
|
+
target: edge.target,
|
|
53
|
+
kind,
|
|
54
|
+
provenance: 'json-migration',
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
export function migrateJsonToSqlite(jsonPath, dbPath) {
|
|
58
|
+
const graph = loadGraph(jsonPath);
|
|
59
|
+
const targetDb = dbPath ?? getDatabasePath();
|
|
60
|
+
const dir = dirname(targetDb);
|
|
61
|
+
if (!existsSync(dir))
|
|
62
|
+
mkdirSync(dir, { recursive: true });
|
|
63
|
+
const conn = new DatabaseConnection();
|
|
64
|
+
conn.initialize(targetDb);
|
|
65
|
+
const queries = new QueryBuilder(conn);
|
|
66
|
+
const enhancedNodes = graph.nodes.map(graphNodeToEnhanced);
|
|
67
|
+
const enhancedEdges = graph.edges
|
|
68
|
+
.map(graphEdgeToEnhanced)
|
|
69
|
+
.filter(e => enhancedNodes.some(n => n.id === e.source) && enhancedNodes.some(n => n.id === e.target));
|
|
70
|
+
queries.insertNodes(enhancedNodes);
|
|
71
|
+
queries.insertEdges(enhancedEdges);
|
|
72
|
+
if (graph.project) {
|
|
73
|
+
queries.setMetadata('project_name', graph.project.name);
|
|
74
|
+
queries.setMetadata('languages', JSON.stringify(graph.project.languages));
|
|
75
|
+
queries.setMetadata('frameworks', JSON.stringify(graph.project.frameworks));
|
|
76
|
+
}
|
|
77
|
+
conn.runMaintenance();
|
|
78
|
+
conn.close();
|
|
79
|
+
return { nodes: enhancedNodes.length, edges: enhancedEdges.length, dbPath: targetDb };
|
|
80
|
+
}
|
|
81
|
+
export function exportSqliteToJson(dbPath) {
|
|
82
|
+
const targetDb = dbPath ?? getDatabasePath();
|
|
83
|
+
const conn = new DatabaseConnection();
|
|
84
|
+
conn.open(targetDb);
|
|
85
|
+
const queries = new QueryBuilder(conn);
|
|
86
|
+
const stats = queries.getStats();
|
|
87
|
+
const allNodes = [];
|
|
88
|
+
const allEdges = [];
|
|
89
|
+
for (const [kind] of Object.entries(stats.nodesByKind)) {
|
|
90
|
+
const nodes = queries.getNodesByKind(kind);
|
|
91
|
+
for (const n of nodes) {
|
|
92
|
+
allNodes.push({
|
|
93
|
+
id: n.id,
|
|
94
|
+
type: n.kind,
|
|
95
|
+
name: n.name,
|
|
96
|
+
filePath: n.filePath || undefined,
|
|
97
|
+
summary: n.docstring || n.signature || `${n.kind}: ${n.name}`,
|
|
98
|
+
tags: [n.kind, n.language].filter(Boolean),
|
|
99
|
+
complexity: undefined,
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
for (const node of allNodes) {
|
|
104
|
+
const outEdges = queries.getOutgoingEdges(node.id);
|
|
105
|
+
for (const e of outEdges) {
|
|
106
|
+
allEdges.push({
|
|
107
|
+
source: e.source,
|
|
108
|
+
target: e.target,
|
|
109
|
+
type: e.kind,
|
|
110
|
+
direction: 'forward',
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
const projectName = queries.getMetadata('project_name') ?? 'unknown';
|
|
115
|
+
const languages = JSON.parse(queries.getMetadata('languages') ?? '[]');
|
|
116
|
+
const frameworks = JSON.parse(queries.getMetadata('frameworks') ?? '[]');
|
|
117
|
+
conn.close();
|
|
118
|
+
return {
|
|
119
|
+
version: '1.0.0',
|
|
120
|
+
valid: true,
|
|
121
|
+
project: {
|
|
122
|
+
name: projectName,
|
|
123
|
+
languages,
|
|
124
|
+
frameworks,
|
|
125
|
+
description: `Exported from SQLite: ${stats.nodeCount} nodes, ${stats.edgeCount} edges`,
|
|
126
|
+
analyzedAt: new Date().toISOString(),
|
|
127
|
+
},
|
|
128
|
+
nodes: allNodes,
|
|
129
|
+
edges: allEdges,
|
|
130
|
+
layers: [],
|
|
131
|
+
tour: [],
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
//# sourceMappingURL=migration.js.map
|