@keel_flow/repo-map 0.2.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/LICENSE +21 -0
- package/dist/budget.d.ts +9 -0
- package/dist/budget.d.ts.map +1 -0
- package/dist/budget.js +38 -0
- package/dist/budget.js.map +1 -0
- package/dist/build.d.ts +13 -0
- package/dist/build.d.ts.map +1 -0
- package/dist/build.js +91 -0
- package/dist/build.js.map +1 -0
- package/dist/cache.d.ts +12 -0
- package/dist/cache.d.ts.map +1 -0
- package/dist/cache.js +70 -0
- package/dist/cache.js.map +1 -0
- package/dist/diff.d.ts +3 -0
- package/dist/diff.d.ts.map +1 -0
- package/dist/diff.js +22 -0
- package/dist/diff.js.map +1 -0
- package/dist/extract.d.ts +9 -0
- package/dist/extract.d.ts.map +1 -0
- package/dist/extract.js +291 -0
- package/dist/extract.js.map +1 -0
- package/dist/graph.d.ts +3 -0
- package/dist/graph.d.ts.map +1 -0
- package/dist/graph.js +37 -0
- package/dist/graph.js.map +1 -0
- package/dist/index.d.ts +17 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/rank.d.ts +8 -0
- package/dist/rank.d.ts.map +1 -0
- package/dist/rank.js +68 -0
- package/dist/rank.js.map +1 -0
- package/dist/references.d.ts +8 -0
- package/dist/references.d.ts.map +1 -0
- package/dist/references.js +87 -0
- package/dist/references.js.map +1 -0
- package/dist/serialize.d.ts +3 -0
- package/dist/serialize.d.ts.map +1 -0
- package/dist/serialize.js +24 -0
- package/dist/serialize.js.map +1 -0
- package/dist/types.d.ts +56 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +20 -0
- package/dist/types.js.map +1 -0
- package/package.json +38 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 jglasskatz
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/dist/budget.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { RepoMapEntry, Symbol, SymbolGraph } from "./types.js";
|
|
2
|
+
export interface BudgetOpts {
|
|
3
|
+
maxTokens?: number;
|
|
4
|
+
tokensPerEntry?: number;
|
|
5
|
+
}
|
|
6
|
+
export declare function truncateToBudget(graph: SymbolGraph, scores: Map<string, number>, opts?: BudgetOpts): RepoMapEntry[];
|
|
7
|
+
export declare function toEntry(symbol: Symbol, score: number): RepoMapEntry;
|
|
8
|
+
export declare function entryId(entry: Pick<RepoMapEntry, "file" | "name" | "kind">): string;
|
|
9
|
+
//# sourceMappingURL=budget.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"budget.d.ts","sourceRoot":"","sources":["../src/budget.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAGpE,MAAM,WAAW,UAAU;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,wBAAgB,gBAAgB,CAC9B,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAC3B,IAAI,GAAE,UAAe,GACpB,YAAY,EAAE,CAmBhB;AAED,wBAAgB,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,YAAY,CAWnE;AAED,wBAAgB,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC,GAAG,MAAM,CAEnF"}
|
package/dist/budget.js
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { symbolId } from "./types.js";
|
|
2
|
+
export function truncateToBudget(graph, scores, opts = {}) {
|
|
3
|
+
const maxTokens = opts.maxTokens ?? 1500;
|
|
4
|
+
const tokensPerEntry = opts.tokensPerEntry ?? 10;
|
|
5
|
+
const maxEntries = Math.max(0, Math.floor(maxTokens / tokensPerEntry));
|
|
6
|
+
const ranked = Array.from(graph.nodes.values())
|
|
7
|
+
.map((node) => ({
|
|
8
|
+
id: node.id,
|
|
9
|
+
symbol: node.symbol,
|
|
10
|
+
score: scores.get(node.id) ?? 0,
|
|
11
|
+
}))
|
|
12
|
+
.sort((a, b) => {
|
|
13
|
+
if (b.score !== a.score)
|
|
14
|
+
return b.score - a.score;
|
|
15
|
+
if (a.symbol.file !== b.symbol.file)
|
|
16
|
+
return a.symbol.file.localeCompare(b.symbol.file);
|
|
17
|
+
return a.symbol.lineNumber - b.symbol.lineNumber;
|
|
18
|
+
})
|
|
19
|
+
.slice(0, maxEntries);
|
|
20
|
+
return ranked.map((r) => toEntry(r.symbol, r.score));
|
|
21
|
+
}
|
|
22
|
+
export function toEntry(symbol, score) {
|
|
23
|
+
const entry = {
|
|
24
|
+
file: symbol.file,
|
|
25
|
+
name: symbol.name,
|
|
26
|
+
kind: symbol.kind,
|
|
27
|
+
lineNumber: symbol.lineNumber,
|
|
28
|
+
exported: symbol.exported,
|
|
29
|
+
score,
|
|
30
|
+
};
|
|
31
|
+
if (symbol.signature)
|
|
32
|
+
entry.signature = symbol.signature;
|
|
33
|
+
return entry;
|
|
34
|
+
}
|
|
35
|
+
export function entryId(entry) {
|
|
36
|
+
return symbolId(entry);
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=budget.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"budget.js","sourceRoot":"","sources":["../src/budget.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAOtC,MAAM,UAAU,gBAAgB,CAC9B,KAAkB,EAClB,MAA2B,EAC3B,OAAmB,EAAE;IAErB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC;IACzC,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;IACjD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,CAAC,CAAC,CAAC;IAEvE,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;SAC5C,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACd,EAAE,EAAE,IAAI,CAAC,EAAE;QACX,MAAM,EAAE,IAAI,CAAC,MAAM;QACnB,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC;KAChC,CAAC,CAAC;SACF,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;QACb,IAAI,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK;YAAE,OAAO,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;QAClD,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI;YAAE,OAAO,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACvF,OAAO,CAAC,CAAC,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC;IACnD,CAAC,CAAC;SACD,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;IAExB,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,MAAc,EAAE,KAAa;IACnD,MAAM,KAAK,GAAiB;QAC1B,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,UAAU,EAAE,MAAM,CAAC,UAAU;QAC7B,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,KAAK;KACN,CAAC;IACF,IAAI,MAAM,CAAC,SAAS;QAAE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;IACzD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,KAAmD;IACzE,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC;AACzB,CAAC"}
|
package/dist/build.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { type RepoMap } from "./types.js";
|
|
2
|
+
export interface BuildRepoMapOpts {
|
|
3
|
+
cwd: string;
|
|
4
|
+
includeGlobs?: string[];
|
|
5
|
+
excludeGlobs?: string[];
|
|
6
|
+
maxTokens?: number;
|
|
7
|
+
tokensPerEntry?: number;
|
|
8
|
+
iterations?: number;
|
|
9
|
+
damping?: number;
|
|
10
|
+
exportedBoost?: number;
|
|
11
|
+
}
|
|
12
|
+
export declare function buildRepoMap(opts: BuildRepoMapOpts): Promise<RepoMap>;
|
|
13
|
+
//# sourceMappingURL=build.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../src/build.ts"],"names":[],"mappings":"AAQA,OAAO,EAAkB,KAAK,OAAO,EAA+B,MAAM,YAAY,CAAC;AAEvF,MAAM,WAAW,gBAAgB;IAC/B,GAAG,EAAE,MAAM,CAAC;IACZ,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAmCD,wBAAsB,YAAY,CAAC,IAAI,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC,CAqD3E"}
|
package/dist/build.js
ADDED
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { readFile } from "node:fs/promises";
|
|
2
|
+
import { relative, resolve } from "node:path";
|
|
3
|
+
import { globby } from "globby";
|
|
4
|
+
import { extractSymbols } from "./extract.js";
|
|
5
|
+
import { extractReferences } from "./references.js";
|
|
6
|
+
import { buildSymbolGraph } from "./graph.js";
|
|
7
|
+
import { pageRank } from "./rank.js";
|
|
8
|
+
import { truncateToBudget } from "./budget.js";
|
|
9
|
+
import { detectLanguage } from "./types.js";
|
|
10
|
+
const DEFAULT_INCLUDE = [
|
|
11
|
+
"**/*.ts",
|
|
12
|
+
"**/*.tsx",
|
|
13
|
+
"**/*.mts",
|
|
14
|
+
"**/*.cts",
|
|
15
|
+
"**/*.js",
|
|
16
|
+
"**/*.jsx",
|
|
17
|
+
"**/*.mjs",
|
|
18
|
+
"**/*.cjs",
|
|
19
|
+
"**/*.py",
|
|
20
|
+
"**/*.go",
|
|
21
|
+
"**/*.rs",
|
|
22
|
+
];
|
|
23
|
+
const DEFAULT_EXCLUDE = [
|
|
24
|
+
"**/node_modules/**",
|
|
25
|
+
"**/dist/**",
|
|
26
|
+
"**/build/**",
|
|
27
|
+
"**/.git/**",
|
|
28
|
+
"**/.next/**",
|
|
29
|
+
"**/.turbo/**",
|
|
30
|
+
"**/coverage/**",
|
|
31
|
+
"**/__tests__/**",
|
|
32
|
+
"**/*.test.ts",
|
|
33
|
+
"**/*.test.tsx",
|
|
34
|
+
"**/*.test.js",
|
|
35
|
+
"**/*.test.mjs",
|
|
36
|
+
"**/*.test.cjs",
|
|
37
|
+
"**/*.spec.ts",
|
|
38
|
+
"**/*.spec.js",
|
|
39
|
+
"**/*.d.ts",
|
|
40
|
+
];
|
|
41
|
+
export async function buildRepoMap(opts) {
|
|
42
|
+
const cwd = resolve(opts.cwd);
|
|
43
|
+
const include = opts.includeGlobs ?? DEFAULT_INCLUDE;
|
|
44
|
+
const exclude = opts.excludeGlobs ?? DEFAULT_EXCLUDE;
|
|
45
|
+
const absFiles = await globby(include, {
|
|
46
|
+
cwd,
|
|
47
|
+
absolute: true,
|
|
48
|
+
gitignore: true,
|
|
49
|
+
ignore: exclude,
|
|
50
|
+
dot: false,
|
|
51
|
+
});
|
|
52
|
+
const relFiles = absFiles
|
|
53
|
+
.map((f) => relative(cwd, f))
|
|
54
|
+
.filter((f) => detectLanguage(f) !== null)
|
|
55
|
+
.sort();
|
|
56
|
+
const allSymbols = [];
|
|
57
|
+
const allRefs = [];
|
|
58
|
+
for (const rel of relFiles) {
|
|
59
|
+
const abs = resolve(cwd, rel);
|
|
60
|
+
let content;
|
|
61
|
+
try {
|
|
62
|
+
content = await readFile(abs, "utf-8");
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
const lang = detectLanguage(rel);
|
|
68
|
+
if (!lang)
|
|
69
|
+
continue;
|
|
70
|
+
allSymbols.push(...extractSymbols({ filePath: rel, content, language: lang }));
|
|
71
|
+
allRefs.push(...extractReferences({ filePath: rel, content, language: lang }));
|
|
72
|
+
}
|
|
73
|
+
const graph = buildSymbolGraph(allSymbols, allRefs);
|
|
74
|
+
const scores = pageRank(graph, {
|
|
75
|
+
...(opts.iterations !== undefined ? { iterations: opts.iterations } : {}),
|
|
76
|
+
...(opts.damping !== undefined ? { damping: opts.damping } : {}),
|
|
77
|
+
...(opts.exportedBoost !== undefined ? { exportedBoost: opts.exportedBoost } : {}),
|
|
78
|
+
});
|
|
79
|
+
const entries = truncateToBudget(graph, scores, {
|
|
80
|
+
...(opts.maxTokens !== undefined ? { maxTokens: opts.maxTokens } : {}),
|
|
81
|
+
...(opts.tokensPerEntry !== undefined ? { tokensPerEntry: opts.tokensPerEntry } : {}),
|
|
82
|
+
});
|
|
83
|
+
return {
|
|
84
|
+
generatedAt: new Date().toISOString(),
|
|
85
|
+
cwd,
|
|
86
|
+
totalSymbols: allSymbols.length,
|
|
87
|
+
entries,
|
|
88
|
+
files: relFiles,
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=build.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.js","sourceRoot":"","sources":["../src/build.ts"],"names":[],"mappings":"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"}
|
package/dist/cache.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { RepoMap } from "./types.js";
|
|
2
|
+
export declare const CACHE_FILE = ".keel/repo-map.cache.json";
|
|
3
|
+
export declare const DEFAULT_TTL_MS: number;
|
|
4
|
+
export declare function cachePath(cwd: string): string;
|
|
5
|
+
export declare function loadCache(cwd: string): RepoMap | null;
|
|
6
|
+
export declare function saveCache(cwd: string, map: RepoMap): void;
|
|
7
|
+
export declare function isCacheStale(cwd: string, files: string[], opts?: {
|
|
8
|
+
ttlMs?: number;
|
|
9
|
+
currentFiles?: string[];
|
|
10
|
+
}): boolean;
|
|
11
|
+
export declare function cacheAgeMs(cwd: string): number | null;
|
|
12
|
+
//# sourceMappingURL=cache.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../src/cache.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAE1C,eAAO,MAAM,UAAU,8BAA8B,CAAC;AACtD,eAAO,MAAM,cAAc,QAAiB,CAAC;AAE7C,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAE7C;AAED,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,IAAI,CASrD;AAED,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,GAAG,IAAI,CAMzD;AAED,wBAAgB,YAAY,CAC1B,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EAAE,EACf,IAAI,GAAE;IAAE,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;CAAO,GACrD,OAAO,CA4BT;AAED,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAMrD"}
|
package/dist/cache.js
ADDED
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { existsSync, mkdirSync, readFileSync, renameSync, statSync, writeFileSync } from "node:fs";
|
|
2
|
+
import { dirname, isAbsolute, join, resolve } from "node:path";
|
|
3
|
+
export const CACHE_FILE = ".keel/repo-map.cache.json";
|
|
4
|
+
export const DEFAULT_TTL_MS = 10 * 60 * 1000;
|
|
5
|
+
export function cachePath(cwd) {
|
|
6
|
+
return join(cwd, CACHE_FILE);
|
|
7
|
+
}
|
|
8
|
+
export function loadCache(cwd) {
|
|
9
|
+
const path = cachePath(cwd);
|
|
10
|
+
if (!existsSync(path))
|
|
11
|
+
return null;
|
|
12
|
+
try {
|
|
13
|
+
const raw = readFileSync(path, "utf-8");
|
|
14
|
+
return JSON.parse(raw);
|
|
15
|
+
}
|
|
16
|
+
catch {
|
|
17
|
+
return null;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export function saveCache(cwd, map) {
|
|
21
|
+
const path = cachePath(cwd);
|
|
22
|
+
mkdirSync(dirname(path), { recursive: true });
|
|
23
|
+
const tmpFile = `${path}.${process.pid}.tmp`;
|
|
24
|
+
writeFileSync(tmpFile, JSON.stringify(map, null, 2), "utf-8");
|
|
25
|
+
renameSync(tmpFile, path);
|
|
26
|
+
}
|
|
27
|
+
export function isCacheStale(cwd, files, opts = {}) {
|
|
28
|
+
const cached = loadCache(cwd);
|
|
29
|
+
if (!cached)
|
|
30
|
+
return true;
|
|
31
|
+
const ttlMs = opts.ttlMs ?? DEFAULT_TTL_MS;
|
|
32
|
+
const generatedAt = Date.parse(cached.generatedAt);
|
|
33
|
+
if (!Number.isFinite(generatedAt))
|
|
34
|
+
return true;
|
|
35
|
+
if (Date.now() - generatedAt > ttlMs)
|
|
36
|
+
return true;
|
|
37
|
+
if (opts.currentFiles !== undefined) {
|
|
38
|
+
const cachedSet = new Set(cached.files);
|
|
39
|
+
for (const f of opts.currentFiles) {
|
|
40
|
+
if (!cachedSet.has(f))
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
if (opts.currentFiles.length !== cached.files.length)
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
let maxMtime = 0;
|
|
47
|
+
for (const file of files) {
|
|
48
|
+
const abs = isAbsolute(file) ? file : resolve(cwd, file);
|
|
49
|
+
try {
|
|
50
|
+
const stat = statSync(abs);
|
|
51
|
+
if (stat.mtimeMs > maxMtime)
|
|
52
|
+
maxMtime = stat.mtimeMs;
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
// missing file → treat as stale
|
|
56
|
+
return true;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return maxMtime > generatedAt;
|
|
60
|
+
}
|
|
61
|
+
export function cacheAgeMs(cwd) {
|
|
62
|
+
const cached = loadCache(cwd);
|
|
63
|
+
if (!cached)
|
|
64
|
+
return null;
|
|
65
|
+
const generatedAt = Date.parse(cached.generatedAt);
|
|
66
|
+
if (!Number.isFinite(generatedAt))
|
|
67
|
+
return null;
|
|
68
|
+
return Date.now() - generatedAt;
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../src/cache.ts"],"names":[],"mappings":"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"}
|
package/dist/diff.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../src/diff.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAgB,MAAM,YAAY,CAAC;AAGtE,wBAAgB,QAAQ,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,GAAG,YAAY,CAoBvE"}
|
package/dist/diff.js
ADDED
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { entryId } from "./budget.js";
|
|
2
|
+
export function diffMaps(oldMap, newMap) {
|
|
3
|
+
const oldById = new Map(oldMap.entries.map((e) => [entryId(e), e]));
|
|
4
|
+
const newById = new Map(newMap.entries.map((e) => [entryId(e), e]));
|
|
5
|
+
const added = [];
|
|
6
|
+
const removed = [];
|
|
7
|
+
const changed = [];
|
|
8
|
+
for (const [id, entry] of newById) {
|
|
9
|
+
const prev = oldById.get(id);
|
|
10
|
+
if (!prev)
|
|
11
|
+
added.push(entry);
|
|
12
|
+
else if (prev.lineNumber !== entry.lineNumber || prev.exported !== entry.exported) {
|
|
13
|
+
changed.push({ before: prev, after: entry });
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
for (const [id, entry] of oldById) {
|
|
17
|
+
if (!newById.has(id))
|
|
18
|
+
removed.push(entry);
|
|
19
|
+
}
|
|
20
|
+
return { added, removed, changed };
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=diff.js.map
|
package/dist/diff.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.js","sourceRoot":"","sources":["../src/diff.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,MAAM,UAAU,QAAQ,CAAC,MAAe,EAAE,MAAe;IACvD,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAEpE,MAAM,KAAK,GAAmB,EAAE,CAAC;IACjC,MAAM,OAAO,GAAmB,EAAE,CAAC;IACnC,MAAM,OAAO,GAAoD,EAAE,CAAC;IAEpE,KAAK,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,OAAO,EAAE,CAAC;QAClC,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAC7B,IAAI,CAAC,IAAI;YAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACxB,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,EAAE,CAAC;YAClF,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IACD,KAAK,MAAM,CAAC,EAAE,EAAE,KAAK,CAAC,IAAI,OAAO,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YAAE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;AACrC,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { type Language, type Symbol } from "./types.js";
|
|
2
|
+
export interface ExtractOpts {
|
|
3
|
+
filePath: string;
|
|
4
|
+
content: string;
|
|
5
|
+
language?: Language;
|
|
6
|
+
}
|
|
7
|
+
export declare function extractSymbols(opts: ExtractOpts): Symbol[];
|
|
8
|
+
export declare function stripStringsAndComments(content: string, lang: Language): string;
|
|
9
|
+
//# sourceMappingURL=extract.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extract.d.ts","sourceRoot":"","sources":["../src/extract.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,QAAQ,EAAE,KAAK,MAAM,EAAmB,MAAM,YAAY,CAAC;AAWzF,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,QAAQ,CAAC;CACrB;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,MAAM,EAAE,CAe1D;AAsMD,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,MAAM,CAiE/E"}
|
package/dist/extract.js
ADDED
|
@@ -0,0 +1,291 @@
|
|
|
1
|
+
import { detectLanguage } from "./types.js";
|
|
2
|
+
export function extractSymbols(opts) {
|
|
3
|
+
const lang = opts.language ?? detectLanguage(opts.filePath);
|
|
4
|
+
if (!lang)
|
|
5
|
+
return [];
|
|
6
|
+
const stripped = stripStringsAndComments(opts.content, lang);
|
|
7
|
+
switch (lang) {
|
|
8
|
+
case "typescript":
|
|
9
|
+
case "javascript":
|
|
10
|
+
return extractTsJs(opts.filePath, stripped);
|
|
11
|
+
case "python":
|
|
12
|
+
return extractPython(opts.filePath, stripped);
|
|
13
|
+
case "go":
|
|
14
|
+
return extractGo(opts.filePath, stripped);
|
|
15
|
+
case "rust":
|
|
16
|
+
return extractRust(opts.filePath, stripped);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
function pushMatches(content, file, matches) {
|
|
20
|
+
const lineStarts = computeLineStarts(content);
|
|
21
|
+
const seen = new Set();
|
|
22
|
+
const out = [];
|
|
23
|
+
for (const m of matches) {
|
|
24
|
+
const line = lineForIndex(lineStarts, m.index);
|
|
25
|
+
const key = `${m.name}::${m.kind}::${line}`;
|
|
26
|
+
if (seen.has(key))
|
|
27
|
+
continue;
|
|
28
|
+
seen.add(key);
|
|
29
|
+
const sym = {
|
|
30
|
+
file,
|
|
31
|
+
name: m.name,
|
|
32
|
+
kind: m.kind,
|
|
33
|
+
lineNumber: line,
|
|
34
|
+
exported: m.exported,
|
|
35
|
+
};
|
|
36
|
+
if (m.signature)
|
|
37
|
+
sym.signature = m.signature;
|
|
38
|
+
out.push(sym);
|
|
39
|
+
}
|
|
40
|
+
return out;
|
|
41
|
+
}
|
|
42
|
+
function extractTsJs(file, content) {
|
|
43
|
+
const matches = [];
|
|
44
|
+
const patterns = [
|
|
45
|
+
{
|
|
46
|
+
re: /^[\t ]*(export\s+(?:default\s+)?)?(?:async\s+)?function\s+([A-Za-z_$][\w$]*)/gm,
|
|
47
|
+
kind: "function",
|
|
48
|
+
nameGroup: 2,
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
re: /^[\t ]*(export\s+(?:default\s+)?)?class\s+([A-Za-z_$][\w$]*)/gm,
|
|
52
|
+
kind: "class",
|
|
53
|
+
nameGroup: 2,
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
re: /^[\t ]*(export\s+)?interface\s+([A-Za-z_$][\w$]*)/gm,
|
|
57
|
+
kind: "interface",
|
|
58
|
+
nameGroup: 2,
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
re: /^[\t ]*(export\s+)?type\s+([A-Za-z_$][\w$]*)\s*=/gm,
|
|
62
|
+
kind: "type",
|
|
63
|
+
nameGroup: 2,
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
re: /^[\t ]*(export\s+)?(?:const|let|var)\s+([A-Za-z_$][\w$]*)\s*=\s*(?:async\s+)?(?:\(|function)/gm,
|
|
67
|
+
kind: "const",
|
|
68
|
+
nameGroup: 2,
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
re: /^[\t ]*(export\s+default\s+)(?:async\s+)?function\s*\(/gm,
|
|
72
|
+
kind: "default-export",
|
|
73
|
+
nameGroup: -1,
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
re: /^[\t ]*export\s+\{\s*([^}]+)\s*\}/gm,
|
|
77
|
+
kind: "const",
|
|
78
|
+
nameGroup: -2,
|
|
79
|
+
},
|
|
80
|
+
];
|
|
81
|
+
for (const p of patterns) {
|
|
82
|
+
let m;
|
|
83
|
+
p.re.lastIndex = 0;
|
|
84
|
+
while ((m = p.re.exec(content)) !== null) {
|
|
85
|
+
const prefix = m[1] ?? "";
|
|
86
|
+
// Multiline ^ matches at the line start; m.index is therefore the index
|
|
87
|
+
// of the first column on that line (or 0). The keyword sits after any
|
|
88
|
+
// leading [\t ]*, but since lineForIndex computes the line for any index
|
|
89
|
+
// on that line, we use m.index directly.
|
|
90
|
+
const startIndex = m.index;
|
|
91
|
+
if (p.nameGroup === -1) {
|
|
92
|
+
matches.push({ index: startIndex, name: "default", kind: "default-export", exported: true });
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
if (p.nameGroup === -2) {
|
|
96
|
+
const list = m[1] ?? "";
|
|
97
|
+
for (const raw of list.split(",")) {
|
|
98
|
+
const name = raw.trim().split(/\s+as\s+/)[0]?.trim();
|
|
99
|
+
if (name && /^[A-Za-z_$][\w$]*$/.test(name)) {
|
|
100
|
+
matches.push({ index: startIndex, name, kind: "const", exported: true });
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
const name = m[p.nameGroup];
|
|
106
|
+
if (!name)
|
|
107
|
+
continue;
|
|
108
|
+
const exported = prefix.includes("export");
|
|
109
|
+
matches.push({ index: startIndex, name, kind: p.kind, exported });
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
return pushMatches(content, file, matches);
|
|
113
|
+
}
|
|
114
|
+
function extractPython(file, content) {
|
|
115
|
+
const matches = [];
|
|
116
|
+
const fnRe = /^[\t ]*(?:async\s+)?def\s+([A-Za-z_][\w]*)\s*\(/gm;
|
|
117
|
+
const clsRe = /^[\t ]*class\s+([A-Za-z_][\w]*)/gm;
|
|
118
|
+
let m;
|
|
119
|
+
while ((m = fnRe.exec(content)) !== null) {
|
|
120
|
+
const name = m[1];
|
|
121
|
+
if (!name)
|
|
122
|
+
continue;
|
|
123
|
+
matches.push({ index: m.index, name, kind: "function", exported: !name.startsWith("_") });
|
|
124
|
+
}
|
|
125
|
+
while ((m = clsRe.exec(content)) !== null) {
|
|
126
|
+
const name = m[1];
|
|
127
|
+
if (!name)
|
|
128
|
+
continue;
|
|
129
|
+
matches.push({ index: m.index, name, kind: "class", exported: !name.startsWith("_") });
|
|
130
|
+
}
|
|
131
|
+
return pushMatches(content, file, matches);
|
|
132
|
+
}
|
|
133
|
+
function extractGo(file, content) {
|
|
134
|
+
const matches = [];
|
|
135
|
+
const fnRe = /^[\t ]*func\s+(?:\([^)]*\)\s+)?([A-Za-z_][\w]*)\s*\(/gm;
|
|
136
|
+
const typeRe = /^[\t ]*type\s+([A-Za-z_][\w]*)\s+(?:struct|interface|=|\w)/gm;
|
|
137
|
+
let m;
|
|
138
|
+
while ((m = fnRe.exec(content)) !== null) {
|
|
139
|
+
const name = m[1];
|
|
140
|
+
if (!name)
|
|
141
|
+
continue;
|
|
142
|
+
const exported = /^[A-Z]/.test(name);
|
|
143
|
+
matches.push({ index: m.index, name, kind: "function", exported });
|
|
144
|
+
}
|
|
145
|
+
while ((m = typeRe.exec(content)) !== null) {
|
|
146
|
+
const name = m[1];
|
|
147
|
+
if (!name)
|
|
148
|
+
continue;
|
|
149
|
+
const exported = /^[A-Z]/.test(name);
|
|
150
|
+
matches.push({ index: m.index, name, kind: "type", exported });
|
|
151
|
+
}
|
|
152
|
+
return pushMatches(content, file, matches);
|
|
153
|
+
}
|
|
154
|
+
function extractRust(file, content) {
|
|
155
|
+
const matches = [];
|
|
156
|
+
const patterns = [
|
|
157
|
+
{ re: /^[\t ]*(pub\s+(?:\([^)]+\)\s+)?)?(?:async\s+)?fn\s+([A-Za-z_][\w]*)\s*[(<]/gm, kind: "function" },
|
|
158
|
+
{ re: /^[\t ]*(pub\s+(?:\([^)]+\)\s+)?)?struct\s+([A-Za-z_][\w]*)/gm, kind: "struct" },
|
|
159
|
+
{ re: /^[\t ]*(pub\s+(?:\([^)]+\)\s+)?)?trait\s+([A-Za-z_][\w]*)/gm, kind: "trait" },
|
|
160
|
+
{ re: /^[\t ]*(pub\s+(?:\([^)]+\)\s+)?)?enum\s+([A-Za-z_][\w]*)/gm, kind: "enum" },
|
|
161
|
+
{ re: /^[\t ]*impl\s+(?:<[^>]+>\s+)?([A-Za-z_][\w]*)/gm, kind: "impl" },
|
|
162
|
+
];
|
|
163
|
+
for (const p of patterns) {
|
|
164
|
+
p.re.lastIndex = 0;
|
|
165
|
+
let m;
|
|
166
|
+
while ((m = p.re.exec(content)) !== null) {
|
|
167
|
+
const isImpl = p.kind === "impl";
|
|
168
|
+
const name = isImpl ? m[1] : m[2];
|
|
169
|
+
if (!name)
|
|
170
|
+
continue;
|
|
171
|
+
const exported = !isImpl && /\bpub\b/.test(m[0]);
|
|
172
|
+
matches.push({ index: m.index, name, kind: p.kind, exported });
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return pushMatches(content, file, matches);
|
|
176
|
+
}
|
|
177
|
+
function computeLineStarts(content) {
|
|
178
|
+
const starts = [0];
|
|
179
|
+
for (let i = 0; i < content.length; i++) {
|
|
180
|
+
if (content[i] === "\n")
|
|
181
|
+
starts.push(i + 1);
|
|
182
|
+
}
|
|
183
|
+
return starts;
|
|
184
|
+
}
|
|
185
|
+
function lineForIndex(lineStarts, index) {
|
|
186
|
+
let lo = 0;
|
|
187
|
+
let hi = lineStarts.length - 1;
|
|
188
|
+
while (lo <= hi) {
|
|
189
|
+
const mid = (lo + hi) >> 1;
|
|
190
|
+
const start = lineStarts[mid] ?? 0;
|
|
191
|
+
if (start <= index) {
|
|
192
|
+
const next = lineStarts[mid + 1];
|
|
193
|
+
if (next === undefined || next > index)
|
|
194
|
+
return mid + 1;
|
|
195
|
+
lo = mid + 1;
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
hi = mid - 1;
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
return 1;
|
|
202
|
+
}
|
|
203
|
+
// Replace string/comment bytes with spaces so regex passes don't false-positive
|
|
204
|
+
// on keywords inside literals. Preserves indices.
|
|
205
|
+
export function stripStringsAndComments(content, lang) {
|
|
206
|
+
const chars = content.split("");
|
|
207
|
+
let i = 0;
|
|
208
|
+
const len = chars.length;
|
|
209
|
+
const blockCommentLangs = new Set(["typescript", "javascript", "go", "rust"]);
|
|
210
|
+
const lineCommentToken = lang === "python" ? "#" : "//";
|
|
211
|
+
const hasBlockComment = blockCommentLangs.has(lang);
|
|
212
|
+
while (i < len) {
|
|
213
|
+
const c = chars[i];
|
|
214
|
+
const next = chars[i + 1];
|
|
215
|
+
if (hasBlockComment && c === "/" && next === "*") {
|
|
216
|
+
chars[i] = " ";
|
|
217
|
+
chars[i + 1] = " ";
|
|
218
|
+
i += 2;
|
|
219
|
+
while (i < len && !(chars[i] === "*" && chars[i + 1] === "/")) {
|
|
220
|
+
if (chars[i] !== "\n")
|
|
221
|
+
chars[i] = " ";
|
|
222
|
+
i++;
|
|
223
|
+
}
|
|
224
|
+
if (i < len) {
|
|
225
|
+
chars[i] = " ";
|
|
226
|
+
chars[i + 1] = " ";
|
|
227
|
+
i += 2;
|
|
228
|
+
}
|
|
229
|
+
continue;
|
|
230
|
+
}
|
|
231
|
+
if (c === lineCommentToken[0] && (lang === "python" || next === "/")) {
|
|
232
|
+
const stop = lang === "python" ? 1 : 2;
|
|
233
|
+
while (i < len && chars[i] !== "\n") {
|
|
234
|
+
chars[i] = " ";
|
|
235
|
+
i++;
|
|
236
|
+
}
|
|
237
|
+
void stop;
|
|
238
|
+
continue;
|
|
239
|
+
}
|
|
240
|
+
if (c === '"' || c === "`" || (c === "'" && lang !== "rust")) {
|
|
241
|
+
const quote = c;
|
|
242
|
+
chars[i] = " ";
|
|
243
|
+
i++;
|
|
244
|
+
while (i < len && chars[i] !== quote) {
|
|
245
|
+
if (chars[i] === "\\" && i + 1 < len) {
|
|
246
|
+
if (chars[i + 1] !== "\n")
|
|
247
|
+
chars[i + 1] = " ";
|
|
248
|
+
chars[i] = " ";
|
|
249
|
+
i += 2;
|
|
250
|
+
continue;
|
|
251
|
+
}
|
|
252
|
+
if (chars[i] === "\n") {
|
|
253
|
+
i++;
|
|
254
|
+
continue;
|
|
255
|
+
}
|
|
256
|
+
chars[i] = " ";
|
|
257
|
+
i++;
|
|
258
|
+
}
|
|
259
|
+
if (i < len) {
|
|
260
|
+
chars[i] = " ";
|
|
261
|
+
i++;
|
|
262
|
+
}
|
|
263
|
+
continue;
|
|
264
|
+
}
|
|
265
|
+
if (c === "'" && lang === "rust") {
|
|
266
|
+
const n1 = chars[i + 1];
|
|
267
|
+
const n2 = chars[i + 2];
|
|
268
|
+
const n3 = chars[i + 3];
|
|
269
|
+
if (n1 === "\\" && n2 !== undefined && n3 === "'") {
|
|
270
|
+
chars[i] = " ";
|
|
271
|
+
chars[i + 1] = " ";
|
|
272
|
+
chars[i + 2] = " ";
|
|
273
|
+
chars[i + 3] = " ";
|
|
274
|
+
i += 4;
|
|
275
|
+
continue;
|
|
276
|
+
}
|
|
277
|
+
if (n1 !== undefined && n2 === "'") {
|
|
278
|
+
chars[i] = " ";
|
|
279
|
+
chars[i + 1] = " ";
|
|
280
|
+
chars[i + 2] = " ";
|
|
281
|
+
i += 3;
|
|
282
|
+
continue;
|
|
283
|
+
}
|
|
284
|
+
i++;
|
|
285
|
+
continue;
|
|
286
|
+
}
|
|
287
|
+
i++;
|
|
288
|
+
}
|
|
289
|
+
return chars.join("");
|
|
290
|
+
}
|
|
291
|
+
//# sourceMappingURL=extract.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extract.js","sourceRoot":"","sources":["../src/extract.ts"],"names":[],"mappings":"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"}
|
package/dist/graph.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph.d.ts","sourceRoot":"","sources":["../src/graph.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,MAAM,EAAE,KAAK,WAAW,EAAmB,KAAK,SAAS,EAAE,MAAM,YAAY,CAAC;AAEtG,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,WAAW,CAoCxF"}
|
package/dist/graph.js
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { symbolId } from "./types.js";
|
|
2
|
+
export function buildSymbolGraph(symbols, references) {
|
|
3
|
+
const nodes = new Map();
|
|
4
|
+
const symbolsByFile = new Map();
|
|
5
|
+
const byName = new Map();
|
|
6
|
+
for (const sym of symbols) {
|
|
7
|
+
const id = symbolId(sym);
|
|
8
|
+
nodes.set(id, { id, symbol: sym });
|
|
9
|
+
const fileList = symbolsByFile.get(sym.file) ?? [];
|
|
10
|
+
fileList.push(sym);
|
|
11
|
+
symbolsByFile.set(sym.file, fileList);
|
|
12
|
+
const nameList = byName.get(sym.name) ?? [];
|
|
13
|
+
nameList.push(sym);
|
|
14
|
+
byName.set(sym.name, nameList);
|
|
15
|
+
}
|
|
16
|
+
const counts = new Map();
|
|
17
|
+
for (const ref of references) {
|
|
18
|
+
const targets = byName.get(ref.name);
|
|
19
|
+
if (!targets)
|
|
20
|
+
continue;
|
|
21
|
+
for (const target of targets) {
|
|
22
|
+
if (target.file === ref.file)
|
|
23
|
+
continue;
|
|
24
|
+
const key = `${ref.file}->${symbolId(target)}`;
|
|
25
|
+
counts.set(key, (counts.get(key) ?? 0) + 1);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
const edges = [];
|
|
29
|
+
for (const [key, weight] of counts) {
|
|
30
|
+
const sep = key.indexOf("->");
|
|
31
|
+
const fromFile = key.slice(0, sep);
|
|
32
|
+
const toSymbolId = key.slice(sep + 2);
|
|
33
|
+
edges.push({ fromFile, toSymbolId, weight });
|
|
34
|
+
}
|
|
35
|
+
return { nodes, edges, symbolsByFile };
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=graph.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph.js","sourceRoot":"","sources":["../src/graph.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAkE,MAAM,YAAY,CAAC;AAEtG,MAAM,UAAU,gBAAgB,CAAC,OAAiB,EAAE,UAAuB;IACzE,MAAM,KAAK,GAAG,IAAI,GAAG,EAAsB,CAAC;IAC5C,MAAM,aAAa,GAAG,IAAI,GAAG,EAAoB,CAAC;IAClD,MAAM,MAAM,GAAG,IAAI,GAAG,EAAoB,CAAC;IAE3C,KAAK,MAAM,GAAG,IAAI,OAAO,EAAE,CAAC;QAC1B,MAAM,EAAE,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;QACzB,KAAK,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC;QACnC,MAAM,QAAQ,GAAG,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACnD,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnB,aAAa,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;QACtC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAC5C,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnB,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IACjC,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,GAAG,EAAkB,CAAC;IACzC,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO;YAAE,SAAS;QACvB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,MAAM,CAAC,IAAI,KAAK,GAAG,CAAC,IAAI;gBAAE,SAAS;YACvC,MAAM,GAAG,GAAG,GAAG,GAAG,CAAC,IAAI,KAAK,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YAC/C,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAED,MAAM,KAAK,GAAG,EAAE,CAAC;IACjB,KAAK,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACnC,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACnC,MAAM,UAAU,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;QACtC,KAAK,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;AACzC,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export { extractSymbols, stripStringsAndComments } from "./extract.js";
|
|
2
|
+
export type { ExtractOpts } from "./extract.js";
|
|
3
|
+
export { extractReferences } from "./references.js";
|
|
4
|
+
export type { ReferenceOpts } from "./references.js";
|
|
5
|
+
export { buildSymbolGraph } from "./graph.js";
|
|
6
|
+
export { pageRank } from "./rank.js";
|
|
7
|
+
export type { PageRankOpts } from "./rank.js";
|
|
8
|
+
export { truncateToBudget, toEntry, entryId } from "./budget.js";
|
|
9
|
+
export type { BudgetOpts } from "./budget.js";
|
|
10
|
+
export { toMarkdown } from "./serialize.js";
|
|
11
|
+
export { diffMaps } from "./diff.js";
|
|
12
|
+
export { CACHE_FILE, DEFAULT_TTL_MS, cachePath, loadCache, saveCache, isCacheStale, cacheAgeMs, } from "./cache.js";
|
|
13
|
+
export { buildRepoMap } from "./build.js";
|
|
14
|
+
export type { BuildRepoMapOpts } from "./build.js";
|
|
15
|
+
export { detectLanguage, symbolId, } from "./types.js";
|
|
16
|
+
export type { Language, Symbol, SymbolKind, SymbolRef, SymbolNode, SymbolEdge, SymbolGraph, RepoMap, RepoMapEntry, RepoMapDelta, } from "./types.js";
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvE,YAAY,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAEhD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,YAAY,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAErD,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AACrC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAE9C,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AACjE,YAAY,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAE9C,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,OAAO,EACL,UAAU,EACV,cAAc,EACd,SAAS,EACT,SAAS,EACT,SAAS,EACT,YAAY,EACZ,UAAU,GACX,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,YAAY,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,OAAO,EACL,cAAc,EACd,QAAQ,GACT,MAAM,YAAY,CAAC;AACpB,YAAY,EACV,QAAQ,EACR,MAAM,EACN,UAAU,EACV,SAAS,EACT,UAAU,EACV,UAAU,EACV,WAAW,EACX,OAAO,EACP,YAAY,EACZ,YAAY,GACb,MAAM,YAAY,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { extractSymbols, stripStringsAndComments } from "./extract.js";
|
|
2
|
+
export { extractReferences } from "./references.js";
|
|
3
|
+
export { buildSymbolGraph } from "./graph.js";
|
|
4
|
+
export { pageRank } from "./rank.js";
|
|
5
|
+
export { truncateToBudget, toEntry, entryId } from "./budget.js";
|
|
6
|
+
export { toMarkdown } from "./serialize.js";
|
|
7
|
+
export { diffMaps } from "./diff.js";
|
|
8
|
+
export { CACHE_FILE, DEFAULT_TTL_MS, cachePath, loadCache, saveCache, isCacheStale, cacheAgeMs, } from "./cache.js";
|
|
9
|
+
export { buildRepoMap } from "./build.js";
|
|
10
|
+
export { detectLanguage, symbolId, } from "./types.js";
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAGvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAGpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE9C,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAGrC,OAAO,EAAE,gBAAgB,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAGjE,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,OAAO,EACL,UAAU,EACV,cAAc,EACd,SAAS,EACT,SAAS,EACT,SAAS,EACT,YAAY,EACZ,UAAU,GACX,MAAM,YAAY,CAAC;AAEpB,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAG1C,OAAO,EACL,cAAc,EACd,QAAQ,GACT,MAAM,YAAY,CAAC"}
|
package/dist/rank.d.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { SymbolGraph } from "./types.js";
|
|
2
|
+
export interface PageRankOpts {
|
|
3
|
+
iterations?: number;
|
|
4
|
+
damping?: number;
|
|
5
|
+
exportedBoost?: number;
|
|
6
|
+
}
|
|
7
|
+
export declare function pageRank(graph: SymbolGraph, opts?: PageRankOpts): Map<string, number>;
|
|
8
|
+
//# sourceMappingURL=rank.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rank.d.ts","sourceRoot":"","sources":["../src/rank.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,MAAM,WAAW,YAAY;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,GAAE,YAAiB,GAAG,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CA4DzF"}
|
package/dist/rank.js
ADDED
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
export function pageRank(graph, opts = {}) {
|
|
2
|
+
const iterations = opts.iterations ?? 20;
|
|
3
|
+
const damping = opts.damping ?? 0.85;
|
|
4
|
+
const exportedBoost = opts.exportedBoost ?? 1.5;
|
|
5
|
+
const ids = Array.from(graph.nodes.keys());
|
|
6
|
+
const n = ids.length;
|
|
7
|
+
if (n === 0)
|
|
8
|
+
return new Map();
|
|
9
|
+
const scores = new Map();
|
|
10
|
+
let initialTotal = 0;
|
|
11
|
+
for (const id of ids) {
|
|
12
|
+
const node = graph.nodes.get(id);
|
|
13
|
+
if (!node)
|
|
14
|
+
continue;
|
|
15
|
+
const init = node.symbol.exported ? exportedBoost : 1.0;
|
|
16
|
+
scores.set(id, init);
|
|
17
|
+
initialTotal += init;
|
|
18
|
+
}
|
|
19
|
+
for (const id of ids) {
|
|
20
|
+
scores.set(id, (scores.get(id) ?? 0) / initialTotal);
|
|
21
|
+
}
|
|
22
|
+
const incoming = new Map();
|
|
23
|
+
const outgoingWeight = new Map();
|
|
24
|
+
for (const edge of graph.edges) {
|
|
25
|
+
const list = incoming.get(edge.toSymbolId) ?? [];
|
|
26
|
+
list.push({ fromFile: edge.fromFile, weight: edge.weight });
|
|
27
|
+
incoming.set(edge.toSymbolId, list);
|
|
28
|
+
outgoingWeight.set(edge.fromFile, (outgoingWeight.get(edge.fromFile) ?? 0) + edge.weight);
|
|
29
|
+
}
|
|
30
|
+
const fileToSymbolIds = new Map();
|
|
31
|
+
for (const id of ids) {
|
|
32
|
+
const node = graph.nodes.get(id);
|
|
33
|
+
if (!node)
|
|
34
|
+
continue;
|
|
35
|
+
const list = fileToSymbolIds.get(node.symbol.file) ?? [];
|
|
36
|
+
list.push(id);
|
|
37
|
+
fileToSymbolIds.set(node.symbol.file, list);
|
|
38
|
+
}
|
|
39
|
+
for (let iter = 0; iter < iterations; iter++) {
|
|
40
|
+
const next = new Map();
|
|
41
|
+
const base = (1 - damping) / n;
|
|
42
|
+
for (const id of ids)
|
|
43
|
+
next.set(id, base);
|
|
44
|
+
for (const [toId, edges] of incoming) {
|
|
45
|
+
let inflow = 0;
|
|
46
|
+
for (const edge of edges) {
|
|
47
|
+
const symbolsInFile = fileToSymbolIds.get(edge.fromFile);
|
|
48
|
+
const avgScore = avgFileScore(scores, symbolsInFile);
|
|
49
|
+
const outWeight = outgoingWeight.get(edge.fromFile) ?? 1;
|
|
50
|
+
inflow += (avgScore * edge.weight) / outWeight;
|
|
51
|
+
}
|
|
52
|
+
next.set(toId, (next.get(toId) ?? 0) + damping * inflow);
|
|
53
|
+
}
|
|
54
|
+
for (const [id, score] of next) {
|
|
55
|
+
scores.set(id, score);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return scores;
|
|
59
|
+
}
|
|
60
|
+
function avgFileScore(scores, symbolsInFile) {
|
|
61
|
+
if (!symbolsInFile || symbolsInFile.length === 0)
|
|
62
|
+
return 0;
|
|
63
|
+
let total = 0;
|
|
64
|
+
for (const id of symbolsInFile)
|
|
65
|
+
total += scores.get(id) ?? 0;
|
|
66
|
+
return total / symbolsInFile.length;
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=rank.js.map
|
package/dist/rank.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rank.js","sourceRoot":"","sources":["../src/rank.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type Language, type SymbolRef } from "./types.js";
|
|
2
|
+
export interface ReferenceOpts {
|
|
3
|
+
filePath: string;
|
|
4
|
+
content: string;
|
|
5
|
+
language?: Language;
|
|
6
|
+
}
|
|
7
|
+
export declare function extractReferences(opts: ReferenceOpts): SymbolRef[];
|
|
8
|
+
//# sourceMappingURL=references.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"references.d.ts","sourceRoot":"","sources":["../src/references.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,QAAQ,EAAE,KAAK,SAAS,EAAE,MAAM,YAAY,CAAC;AAG3E,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,QAAQ,CAAC;CACrB;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,aAAa,GAAG,SAAS,EAAE,CAmBlE"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { detectLanguage } from "./types.js";
|
|
2
|
+
import { stripStringsAndComments } from "./extract.js";
|
|
3
|
+
export function extractReferences(opts) {
|
|
4
|
+
const lang = opts.language ?? detectLanguage(opts.filePath);
|
|
5
|
+
if (!lang)
|
|
6
|
+
return [];
|
|
7
|
+
const stripped = stripStringsAndComments(opts.content, lang);
|
|
8
|
+
const refs = [];
|
|
9
|
+
const re = /[A-Za-z_$][\w$]*/g;
|
|
10
|
+
const lineStarts = computeLineStarts(stripped);
|
|
11
|
+
let m;
|
|
12
|
+
while ((m = re.exec(stripped)) !== null) {
|
|
13
|
+
const name = m[0];
|
|
14
|
+
if (name.length < 2)
|
|
15
|
+
continue;
|
|
16
|
+
if (isKeyword(name, lang))
|
|
17
|
+
continue;
|
|
18
|
+
refs.push({
|
|
19
|
+
file: opts.filePath,
|
|
20
|
+
name,
|
|
21
|
+
lineNumber: lineForIndex(lineStarts, m.index),
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
return refs;
|
|
25
|
+
}
|
|
26
|
+
const KEYWORDS = {
|
|
27
|
+
typescript: new Set([
|
|
28
|
+
"abstract", "any", "as", "async", "await", "boolean", "break", "case", "catch", "class", "const",
|
|
29
|
+
"continue", "debugger", "declare", "default", "delete", "do", "else", "enum", "export", "extends",
|
|
30
|
+
"false", "finally", "for", "from", "function", "get", "if", "implements", "import", "in", "instanceof",
|
|
31
|
+
"interface", "is", "keyof", "let", "module", "namespace", "never", "new", "null", "number", "object",
|
|
32
|
+
"of", "package", "private", "protected", "public", "readonly", "require", "return", "set", "static",
|
|
33
|
+
"string", "super", "switch", "symbol", "this", "throw", "true", "try", "type", "typeof", "undefined",
|
|
34
|
+
"unique", "unknown", "var", "void", "while", "with", "yield",
|
|
35
|
+
]),
|
|
36
|
+
javascript: new Set([
|
|
37
|
+
"async", "await", "break", "case", "catch", "class", "const", "continue", "debugger", "default",
|
|
38
|
+
"delete", "do", "else", "export", "extends", "false", "finally", "for", "from", "function", "if",
|
|
39
|
+
"import", "in", "instanceof", "let", "new", "null", "of", "return", "super", "switch", "this", "throw",
|
|
40
|
+
"true", "try", "typeof", "undefined", "var", "void", "while", "with", "yield",
|
|
41
|
+
]),
|
|
42
|
+
python: new Set([
|
|
43
|
+
"False", "None", "True", "and", "as", "assert", "async", "await", "break", "class", "continue", "def",
|
|
44
|
+
"del", "elif", "else", "except", "finally", "for", "from", "global", "if", "import", "in", "is",
|
|
45
|
+
"lambda", "nonlocal", "not", "or", "pass", "raise", "return", "try", "while", "with", "yield",
|
|
46
|
+
]),
|
|
47
|
+
go: new Set([
|
|
48
|
+
"break", "case", "chan", "const", "continue", "default", "defer", "else", "fallthrough", "for", "func",
|
|
49
|
+
"go", "goto", "if", "import", "interface", "map", "package", "range", "return", "select", "struct",
|
|
50
|
+
"switch", "type", "var", "true", "false", "nil",
|
|
51
|
+
]),
|
|
52
|
+
rust: new Set([
|
|
53
|
+
"as", "async", "await", "break", "const", "continue", "crate", "dyn", "else", "enum", "extern", "false",
|
|
54
|
+
"fn", "for", "if", "impl", "in", "let", "loop", "match", "mod", "move", "mut", "pub", "ref", "return",
|
|
55
|
+
"self", "Self", "static", "struct", "super", "trait", "true", "type", "unsafe", "use", "where", "while",
|
|
56
|
+
]),
|
|
57
|
+
};
|
|
58
|
+
function isKeyword(word, lang) {
|
|
59
|
+
return KEYWORDS[lang].has(word);
|
|
60
|
+
}
|
|
61
|
+
function computeLineStarts(content) {
|
|
62
|
+
const starts = [0];
|
|
63
|
+
for (let i = 0; i < content.length; i++) {
|
|
64
|
+
if (content[i] === "\n")
|
|
65
|
+
starts.push(i + 1);
|
|
66
|
+
}
|
|
67
|
+
return starts;
|
|
68
|
+
}
|
|
69
|
+
function lineForIndex(lineStarts, index) {
|
|
70
|
+
let lo = 0;
|
|
71
|
+
let hi = lineStarts.length - 1;
|
|
72
|
+
while (lo <= hi) {
|
|
73
|
+
const mid = (lo + hi) >> 1;
|
|
74
|
+
const start = lineStarts[mid] ?? 0;
|
|
75
|
+
if (start <= index) {
|
|
76
|
+
const next = lineStarts[mid + 1];
|
|
77
|
+
if (next === undefined || next > index)
|
|
78
|
+
return mid + 1;
|
|
79
|
+
lo = mid + 1;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
hi = mid - 1;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
return 1;
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=references.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"references.js","sourceRoot":"","sources":["../src/references.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialize.d.ts","sourceRoot":"","sources":["../src/serialize.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAE/C,wBAAgB,UAAU,CAAC,OAAO,EAAE,YAAY,EAAE,GAAG,MAAM,CAqB1D"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export function toMarkdown(entries) {
|
|
2
|
+
if (entries.length === 0)
|
|
3
|
+
return "";
|
|
4
|
+
const byFile = new Map();
|
|
5
|
+
for (const entry of entries) {
|
|
6
|
+
const list = byFile.get(entry.file) ?? [];
|
|
7
|
+
list.push(entry);
|
|
8
|
+
byFile.set(entry.file, list);
|
|
9
|
+
}
|
|
10
|
+
const files = Array.from(byFile.keys()).sort();
|
|
11
|
+
const lines = [];
|
|
12
|
+
for (const file of files) {
|
|
13
|
+
lines.push(`## ${file}`);
|
|
14
|
+
const entriesForFile = byFile.get(file) ?? [];
|
|
15
|
+
entriesForFile.sort((a, b) => a.lineNumber - b.lineNumber);
|
|
16
|
+
for (const entry of entriesForFile) {
|
|
17
|
+
const exportTag = entry.exported ? "export " : "";
|
|
18
|
+
lines.push(`- ${exportTag}${entry.kind} ${entry.name} (line ${entry.lineNumber})`);
|
|
19
|
+
}
|
|
20
|
+
lines.push("");
|
|
21
|
+
}
|
|
22
|
+
return lines.join("\n").trimEnd() + "\n";
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=serialize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serialize.js","sourceRoot":"","sources":["../src/serialize.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,UAAU,CAAC,OAAuB;IAChD,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IACpC,MAAM,MAAM,GAAG,IAAI,GAAG,EAA0B,CAAC;IACjD,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjB,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC/B,CAAC;IACD,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;IAC/C,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,KAAK,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;QACzB,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QAC9C,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC;QAC3D,KAAK,MAAM,KAAK,IAAI,cAAc,EAAE,CAAC;YACnC,MAAM,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;YAClD,KAAK,CAAC,IAAI,CAAC,KAAK,SAAS,GAAG,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,IAAI,UAAU,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC;QACrF,CAAC;QACD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjB,CAAC;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;AAC3C,CAAC"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
export type Language = "typescript" | "javascript" | "python" | "go" | "rust";
|
|
2
|
+
export type SymbolKind = "function" | "class" | "interface" | "type" | "const" | "method" | "struct" | "trait" | "impl" | "enum" | "default-export";
|
|
3
|
+
export interface Symbol {
|
|
4
|
+
file: string;
|
|
5
|
+
name: string;
|
|
6
|
+
kind: SymbolKind;
|
|
7
|
+
lineNumber: number;
|
|
8
|
+
exported: boolean;
|
|
9
|
+
signature?: string;
|
|
10
|
+
}
|
|
11
|
+
export interface SymbolRef {
|
|
12
|
+
file: string;
|
|
13
|
+
name: string;
|
|
14
|
+
lineNumber: number;
|
|
15
|
+
}
|
|
16
|
+
export interface SymbolNode {
|
|
17
|
+
id: string;
|
|
18
|
+
symbol: Symbol;
|
|
19
|
+
}
|
|
20
|
+
export interface SymbolEdge {
|
|
21
|
+
fromFile: string;
|
|
22
|
+
toSymbolId: string;
|
|
23
|
+
weight: number;
|
|
24
|
+
}
|
|
25
|
+
export interface SymbolGraph {
|
|
26
|
+
nodes: Map<string, SymbolNode>;
|
|
27
|
+
edges: SymbolEdge[];
|
|
28
|
+
symbolsByFile: Map<string, Symbol[]>;
|
|
29
|
+
}
|
|
30
|
+
export interface RepoMapEntry {
|
|
31
|
+
file: string;
|
|
32
|
+
name: string;
|
|
33
|
+
kind: SymbolKind;
|
|
34
|
+
lineNumber: number;
|
|
35
|
+
exported: boolean;
|
|
36
|
+
score: number;
|
|
37
|
+
signature?: string;
|
|
38
|
+
}
|
|
39
|
+
export interface RepoMap {
|
|
40
|
+
generatedAt: string;
|
|
41
|
+
cwd: string;
|
|
42
|
+
totalSymbols: number;
|
|
43
|
+
entries: RepoMapEntry[];
|
|
44
|
+
files: string[];
|
|
45
|
+
}
|
|
46
|
+
export interface RepoMapDelta {
|
|
47
|
+
added: RepoMapEntry[];
|
|
48
|
+
removed: RepoMapEntry[];
|
|
49
|
+
changed: {
|
|
50
|
+
before: RepoMapEntry;
|
|
51
|
+
after: RepoMapEntry;
|
|
52
|
+
}[];
|
|
53
|
+
}
|
|
54
|
+
export declare function symbolId(s: Pick<Symbol, "file" | "name" | "kind">): string;
|
|
55
|
+
export declare function detectLanguage(filePath: string): Language | null;
|
|
56
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,YAAY,GAAG,YAAY,GAAG,QAAQ,GAAG,IAAI,GAAG,MAAM,CAAC;AAE9E,MAAM,MAAM,UAAU,GAClB,UAAU,GACV,OAAO,GACP,WAAW,GACX,MAAM,GACN,OAAO,GACP,QAAQ,GACR,QAAQ,GACR,OAAO,GACP,MAAM,GACN,MAAM,GACN,gBAAgB,CAAC;AAErB,MAAM,WAAW,MAAM;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAC/B,KAAK,EAAE,UAAU,EAAE,CAAC;IACpB,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,OAAO;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC;IACZ,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,YAAY,EAAE,CAAC;IACtB,OAAO,EAAE,YAAY,EAAE,CAAC;IACxB,OAAO,EAAE;QAAE,MAAM,EAAE,YAAY,CAAC;QAAC,KAAK,EAAE,YAAY,CAAA;KAAE,EAAE,CAAC;CAC1D;AAED,wBAAgB,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC,GAAG,MAAM,CAE1E;AAED,wBAAgB,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,QAAQ,GAAG,IAAI,CAYhE"}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export function symbolId(s) {
|
|
2
|
+
return `${s.file}::${s.kind}::${s.name}`;
|
|
3
|
+
}
|
|
4
|
+
export function detectLanguage(filePath) {
|
|
5
|
+
const lower = filePath.toLowerCase();
|
|
6
|
+
if (lower.endsWith(".ts") || lower.endsWith(".tsx") || lower.endsWith(".mts") || lower.endsWith(".cts")) {
|
|
7
|
+
return "typescript";
|
|
8
|
+
}
|
|
9
|
+
if (lower.endsWith(".js") || lower.endsWith(".jsx") || lower.endsWith(".mjs") || lower.endsWith(".cjs")) {
|
|
10
|
+
return "javascript";
|
|
11
|
+
}
|
|
12
|
+
if (lower.endsWith(".py"))
|
|
13
|
+
return "python";
|
|
14
|
+
if (lower.endsWith(".go"))
|
|
15
|
+
return "go";
|
|
16
|
+
if (lower.endsWith(".rs"))
|
|
17
|
+
return "rust";
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAuEA,MAAM,UAAU,QAAQ,CAAC,CAAyC;IAChE,OAAO,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;AAC3C,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,QAAgB;IAC7C,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;IACrC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QACxG,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QACxG,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,QAAQ,CAAC;IAC3C,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IACvC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,MAAM,CAAC;IACzC,OAAO,IAAI,CAAC;AACd,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@keel_flow/repo-map",
|
|
3
|
+
"version": "0.2.0",
|
|
4
|
+
"private": false,
|
|
5
|
+
"type": "module",
|
|
6
|
+
"publishConfig": {
|
|
7
|
+
"access": "public"
|
|
8
|
+
},
|
|
9
|
+
"files": [
|
|
10
|
+
"dist"
|
|
11
|
+
],
|
|
12
|
+
"main": "./dist/index.js",
|
|
13
|
+
"types": "./dist/index.d.ts",
|
|
14
|
+
"exports": {
|
|
15
|
+
".": {
|
|
16
|
+
"import": "./dist/index.js",
|
|
17
|
+
"require": "./dist/index.js",
|
|
18
|
+
"types": "./dist/index.d.ts"
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
"dependencies": {
|
|
22
|
+
"globby": "^14.0.0"
|
|
23
|
+
},
|
|
24
|
+
"devDependencies": {
|
|
25
|
+
"@types/node": "^25.9.1",
|
|
26
|
+
"@typescript-eslint/eslint-plugin": "^8.0.0",
|
|
27
|
+
"@typescript-eslint/parser": "^8.0.0",
|
|
28
|
+
"eslint": "^9.0.0",
|
|
29
|
+
"typescript": "^5.5.0",
|
|
30
|
+
"vitest": "^2.0.0"
|
|
31
|
+
},
|
|
32
|
+
"scripts": {
|
|
33
|
+
"build": "tsc",
|
|
34
|
+
"typecheck": "tsc --noEmit",
|
|
35
|
+
"test": "vitest run",
|
|
36
|
+
"lint": "eslint src"
|
|
37
|
+
}
|
|
38
|
+
}
|