@iamsyr/agentmind 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (229) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/LICENSE +21 -0
  3. package/README.md +462 -0
  4. package/RELEASING.md +42 -0
  5. package/dist/adapters/cursor.d.ts +2 -0
  6. package/dist/adapters/cursor.d.ts.map +1 -0
  7. package/dist/adapters/cursor.js +39 -0
  8. package/dist/adapters/cursor.js.map +1 -0
  9. package/dist/adapters/index.d.ts +9 -0
  10. package/dist/adapters/index.d.ts.map +1 -0
  11. package/dist/adapters/index.js +16 -0
  12. package/dist/adapters/index.js.map +1 -0
  13. package/dist/adapters/types.d.ts +24 -0
  14. package/dist/adapters/types.d.ts.map +1 -0
  15. package/dist/adapters/types.js +66 -0
  16. package/dist/adapters/types.js.map +1 -0
  17. package/dist/adapters/windsurf.d.ts +2 -0
  18. package/dist/adapters/windsurf.d.ts.map +1 -0
  19. package/dist/adapters/windsurf.js +44 -0
  20. package/dist/adapters/windsurf.js.map +1 -0
  21. package/dist/bridge/conflict.d.ts +9 -0
  22. package/dist/bridge/conflict.d.ts.map +1 -0
  23. package/dist/bridge/conflict.js +38 -0
  24. package/dist/bridge/conflict.js.map +1 -0
  25. package/dist/bridge/index.d.ts +5 -0
  26. package/dist/bridge/index.d.ts.map +1 -0
  27. package/dist/bridge/index.js +3 -0
  28. package/dist/bridge/index.js.map +1 -0
  29. package/dist/bridge/state.d.ts +30 -0
  30. package/dist/bridge/state.d.ts.map +1 -0
  31. package/dist/bridge/state.js +130 -0
  32. package/dist/bridge/state.js.map +1 -0
  33. package/dist/cli/commands/agents.d.ts +2 -0
  34. package/dist/cli/commands/agents.d.ts.map +1 -0
  35. package/dist/cli/commands/agents.js +38 -0
  36. package/dist/cli/commands/agents.js.map +1 -0
  37. package/dist/cli/commands/annotate.d.ts +4 -0
  38. package/dist/cli/commands/annotate.d.ts.map +1 -0
  39. package/dist/cli/commands/annotate.js +116 -0
  40. package/dist/cli/commands/annotate.js.map +1 -0
  41. package/dist/cli/commands/behaviors.d.ts +6 -0
  42. package/dist/cli/commands/behaviors.d.ts.map +1 -0
  43. package/dist/cli/commands/behaviors.js +76 -0
  44. package/dist/cli/commands/behaviors.js.map +1 -0
  45. package/dist/cli/commands/bridge.d.ts +15 -0
  46. package/dist/cli/commands/bridge.d.ts.map +1 -0
  47. package/dist/cli/commands/bridge.js +75 -0
  48. package/dist/cli/commands/bridge.js.map +1 -0
  49. package/dist/cli/commands/health.d.ts +4 -0
  50. package/dist/cli/commands/health.d.ts.map +1 -0
  51. package/dist/cli/commands/health.js +382 -0
  52. package/dist/cli/commands/health.js.map +1 -0
  53. package/dist/cli/commands/hooks.d.ts +3 -0
  54. package/dist/cli/commands/hooks.d.ts.map +1 -0
  55. package/dist/cli/commands/hooks.js +59 -0
  56. package/dist/cli/commands/hooks.js.map +1 -0
  57. package/dist/cli/commands/init.d.ts +2 -0
  58. package/dist/cli/commands/init.d.ts.map +1 -0
  59. package/dist/cli/commands/init.js +128 -0
  60. package/dist/cli/commands/init.js.map +1 -0
  61. package/dist/cli/commands/inject.d.ts +6 -0
  62. package/dist/cli/commands/inject.d.ts.map +1 -0
  63. package/dist/cli/commands/inject.js +84 -0
  64. package/dist/cli/commands/inject.js.map +1 -0
  65. package/dist/cli/commands/insights.d.ts +4 -0
  66. package/dist/cli/commands/insights.d.ts.map +1 -0
  67. package/dist/cli/commands/insights.js +124 -0
  68. package/dist/cli/commands/insights.js.map +1 -0
  69. package/dist/cli/commands/learn.d.ts +8 -0
  70. package/dist/cli/commands/learn.d.ts.map +1 -0
  71. package/dist/cli/commands/learn.js +121 -0
  72. package/dist/cli/commands/learn.js.map +1 -0
  73. package/dist/cli/commands/log-behavior.d.ts +14 -0
  74. package/dist/cli/commands/log-behavior.d.ts.map +1 -0
  75. package/dist/cli/commands/log-behavior.js +50 -0
  76. package/dist/cli/commands/log-behavior.js.map +1 -0
  77. package/dist/cli/commands/overlay.d.ts +10 -0
  78. package/dist/cli/commands/overlay.d.ts.map +1 -0
  79. package/dist/cli/commands/overlay.js +303 -0
  80. package/dist/cli/commands/overlay.js.map +1 -0
  81. package/dist/cli/commands/pull.d.ts +4 -0
  82. package/dist/cli/commands/pull.d.ts.map +1 -0
  83. package/dist/cli/commands/pull.js +93 -0
  84. package/dist/cli/commands/pull.js.map +1 -0
  85. package/dist/cli/commands/push.d.ts +5 -0
  86. package/dist/cli/commands/push.d.ts.map +1 -0
  87. package/dist/cli/commands/push.js +71 -0
  88. package/dist/cli/commands/push.js.map +1 -0
  89. package/dist/cli/commands/scan.d.ts +5 -0
  90. package/dist/cli/commands/scan.d.ts.map +1 -0
  91. package/dist/cli/commands/scan.js +134 -0
  92. package/dist/cli/commands/scan.js.map +1 -0
  93. package/dist/cli/commands/serve.d.ts +2 -0
  94. package/dist/cli/commands/serve.d.ts.map +1 -0
  95. package/dist/cli/commands/serve.js +17 -0
  96. package/dist/cli/commands/serve.js.map +1 -0
  97. package/dist/cli/commands/share.d.ts +5 -0
  98. package/dist/cli/commands/share.d.ts.map +1 -0
  99. package/dist/cli/commands/share.js +97 -0
  100. package/dist/cli/commands/share.js.map +1 -0
  101. package/dist/cli/commands/status.d.ts +2 -0
  102. package/dist/cli/commands/status.d.ts.map +1 -0
  103. package/dist/cli/commands/status.js +167 -0
  104. package/dist/cli/commands/status.js.map +1 -0
  105. package/dist/cli/commands/sync.d.ts +6 -0
  106. package/dist/cli/commands/sync.d.ts.map +1 -0
  107. package/dist/cli/commands/sync.js +60 -0
  108. package/dist/cli/commands/sync.js.map +1 -0
  109. package/dist/cli/commands/template.d.ts +5 -0
  110. package/dist/cli/commands/template.d.ts.map +1 -0
  111. package/dist/cli/commands/template.js +98 -0
  112. package/dist/cli/commands/template.js.map +1 -0
  113. package/dist/cli/index.d.ts +3 -0
  114. package/dist/cli/index.d.ts.map +1 -0
  115. package/dist/cli/index.js +172 -0
  116. package/dist/cli/index.js.map +1 -0
  117. package/dist/cli/utils.d.ts +6 -0
  118. package/dist/cli/utils.d.ts.map +1 -0
  119. package/dist/cli/utils.js +49 -0
  120. package/dist/cli/utils.js.map +1 -0
  121. package/dist/hooks/claude.d.ts +6 -0
  122. package/dist/hooks/claude.d.ts.map +1 -0
  123. package/dist/hooks/claude.js +189 -0
  124. package/dist/hooks/claude.js.map +1 -0
  125. package/dist/hooks/codex.d.ts +6 -0
  126. package/dist/hooks/codex.d.ts.map +1 -0
  127. package/dist/hooks/codex.js +120 -0
  128. package/dist/hooks/codex.js.map +1 -0
  129. package/dist/hooks/index.d.ts +5 -0
  130. package/dist/hooks/index.d.ts.map +1 -0
  131. package/dist/hooks/index.js +4 -0
  132. package/dist/hooks/index.js.map +1 -0
  133. package/dist/hooks/template.d.ts +5 -0
  134. package/dist/hooks/template.d.ts.map +1 -0
  135. package/dist/hooks/template.js +176 -0
  136. package/dist/hooks/template.js.map +1 -0
  137. package/dist/index.d.ts +5 -0
  138. package/dist/index.d.ts.map +1 -0
  139. package/dist/index.js +4 -0
  140. package/dist/index.js.map +1 -0
  141. package/dist/learn/analyzer.d.ts +11 -0
  142. package/dist/learn/analyzer.d.ts.map +1 -0
  143. package/dist/learn/analyzer.js +145 -0
  144. package/dist/learn/analyzer.js.map +1 -0
  145. package/dist/learn/generator.d.ts +12 -0
  146. package/dist/learn/generator.d.ts.map +1 -0
  147. package/dist/learn/generator.js +37 -0
  148. package/dist/learn/generator.js.map +1 -0
  149. package/dist/mcp/index.d.ts +2 -0
  150. package/dist/mcp/index.d.ts.map +1 -0
  151. package/dist/mcp/index.js +2 -0
  152. package/dist/mcp/index.js.map +1 -0
  153. package/dist/mcp/server.d.ts +2 -0
  154. package/dist/mcp/server.d.ts.map +1 -0
  155. package/dist/mcp/server.js +325 -0
  156. package/dist/mcp/server.js.map +1 -0
  157. package/dist/router/index.d.ts +3 -0
  158. package/dist/router/index.d.ts.map +1 -0
  159. package/dist/router/index.js +44 -0
  160. package/dist/router/index.js.map +1 -0
  161. package/dist/scanner/classify.d.ts +6 -0
  162. package/dist/scanner/classify.d.ts.map +1 -0
  163. package/dist/scanner/classify.js +101 -0
  164. package/dist/scanner/classify.js.map +1 -0
  165. package/dist/scanner/graph.d.ts +3 -0
  166. package/dist/scanner/graph.d.ts.map +1 -0
  167. package/dist/scanner/graph.js +104 -0
  168. package/dist/scanner/graph.js.map +1 -0
  169. package/dist/scanner/index.d.ts +6 -0
  170. package/dist/scanner/index.d.ts.map +1 -0
  171. package/dist/scanner/index.js +23 -0
  172. package/dist/scanner/index.js.map +1 -0
  173. package/dist/scanner/patterns.d.ts +3 -0
  174. package/dist/scanner/patterns.d.ts.map +1 -0
  175. package/dist/scanner/patterns.js +179 -0
  176. package/dist/scanner/patterns.js.map +1 -0
  177. package/dist/store/db.d.ts +21 -0
  178. package/dist/store/db.d.ts.map +1 -0
  179. package/dist/store/db.js +55 -0
  180. package/dist/store/db.js.map +1 -0
  181. package/dist/store/index.d.ts +3 -0
  182. package/dist/store/index.d.ts.map +1 -0
  183. package/dist/store/index.js +3 -0
  184. package/dist/store/index.js.map +1 -0
  185. package/dist/store/jsonl.d.ts +6 -0
  186. package/dist/store/jsonl.d.ts.map +1 -0
  187. package/dist/store/jsonl.js +55 -0
  188. package/dist/store/jsonl.js.map +1 -0
  189. package/dist/store/schema.d.ts +32 -0
  190. package/dist/store/schema.d.ts.map +1 -0
  191. package/dist/store/schema.js +210 -0
  192. package/dist/store/schema.js.map +1 -0
  193. package/dist/templates/go.d.ts +3 -0
  194. package/dist/templates/go.d.ts.map +1 -0
  195. package/dist/templates/go.js +35 -0
  196. package/dist/templates/go.js.map +1 -0
  197. package/dist/templates/index.d.ts +13 -0
  198. package/dist/templates/index.d.ts.map +1 -0
  199. package/dist/templates/index.js +98 -0
  200. package/dist/templates/index.js.map +1 -0
  201. package/dist/templates/nextjs.d.ts +3 -0
  202. package/dist/templates/nextjs.d.ts.map +1 -0
  203. package/dist/templates/nextjs.js +53 -0
  204. package/dist/templates/nextjs.js.map +1 -0
  205. package/dist/templates/python.d.ts +3 -0
  206. package/dist/templates/python.d.ts.map +1 -0
  207. package/dist/templates/python.js +41 -0
  208. package/dist/templates/python.js.map +1 -0
  209. package/dist/templates/react-native.d.ts +3 -0
  210. package/dist/templates/react-native.d.ts.map +1 -0
  211. package/dist/templates/react-native.js +35 -0
  212. package/dist/templates/react-native.js.map +1 -0
  213. package/dist/templates/registry.d.ts +24 -0
  214. package/dist/templates/registry.d.ts.map +1 -0
  215. package/dist/templates/registry.js +2 -0
  216. package/dist/templates/registry.js.map +1 -0
  217. package/dist/templates/rust.d.ts +3 -0
  218. package/dist/templates/rust.d.ts.map +1 -0
  219. package/dist/templates/rust.js +41 -0
  220. package/dist/templates/rust.js.map +1 -0
  221. package/dist/templates/sst.d.ts +3 -0
  222. package/dist/templates/sst.d.ts.map +1 -0
  223. package/dist/templates/sst.js +35 -0
  224. package/dist/templates/sst.js.map +1 -0
  225. package/dist/types/index.d.ts +92 -0
  226. package/dist/types/index.d.ts.map +1 -0
  227. package/dist/types/index.js +2 -0
  228. package/dist/types/index.js.map +1 -0
  229. package/package.json +62 -0
@@ -0,0 +1,325 @@
1
+ import * as readline from "node:readline";
2
+ import * as fs from "node:fs";
3
+ import * as path from "node:path";
4
+ import { ContextStore } from "../store/schema.js";
5
+ import { route } from "../router/index.js";
6
+ import { formatBytes } from "../cli/utils.js";
7
+ // ── Tool definitions ───────────────────────────────────
8
+ const TOOLS = [
9
+ {
10
+ name: "get_context",
11
+ description: "Get project context for the current task. Returns rules, annotations, and behavior history relevant to the file being edited.",
12
+ inputSchema: {
13
+ type: "object",
14
+ properties: {
15
+ filePath: { type: "string", description: "File path to get context for" },
16
+ query: { type: "string", description: "Natural language query about the project" },
17
+ },
18
+ },
19
+ },
20
+ {
21
+ name: "get_health",
22
+ description: "Check project context health — coverage percentage, stale entries, files needing annotation.",
23
+ inputSchema: { type: "object", properties: {} },
24
+ },
25
+ {
26
+ name: "annotate_file",
27
+ description: "Add a context annotation to a file. Use when you learn something about a file that future agent sessions should know.",
28
+ inputSchema: {
29
+ type: "object",
30
+ properties: {
31
+ filePath: { type: "string", description: "File path" },
32
+ text: { type: "string", description: "Annotation text" },
33
+ priority: {
34
+ type: "string",
35
+ enum: ["critical", "high", "normal", "low"],
36
+ },
37
+ },
38
+ required: ["filePath", "text"],
39
+ },
40
+ },
41
+ {
42
+ name: "log_behavior",
43
+ description: "Log agent behavior — file edits, tool usage, success/failure. Called automatically by hooks.",
44
+ inputSchema: {
45
+ type: "object",
46
+ properties: {
47
+ filePath: { type: "string" },
48
+ tool: { type: "string" },
49
+ success: { type: "boolean" },
50
+ },
51
+ required: ["filePath", "tool", "success"],
52
+ },
53
+ },
54
+ {
55
+ name: "find_gaps",
56
+ description: "Find files that lack context annotations or rules. Helps identify where agentmind coverage is missing.",
57
+ inputSchema: {
58
+ type: "object",
59
+ properties: {
60
+ directory: { type: "string", description: "Filter to a specific directory" },
61
+ },
62
+ },
63
+ },
64
+ ];
65
+ // ── Server ─────────────────────────────────────────────
66
+ export function startServer(projectRoot) {
67
+ const store = ensureStore(projectRoot);
68
+ if (!store) {
69
+ process.exit(1);
70
+ }
71
+ const rl = readline.createInterface({ input: process.stdin });
72
+ const cleanup = () => {
73
+ store.close();
74
+ process.exit(0);
75
+ };
76
+ process.on("SIGINT", cleanup);
77
+ process.on("SIGTERM", cleanup);
78
+ const handle = (line) => {
79
+ let req;
80
+ try {
81
+ req = JSON.parse(line);
82
+ }
83
+ catch {
84
+ // Not valid JSON — skip per MCP spec
85
+ return;
86
+ }
87
+ const res = dispatch(req, store, projectRoot);
88
+ if (res) {
89
+ process.stdout.write(JSON.stringify(res) + "\n");
90
+ }
91
+ };
92
+ rl.on("line", handle);
93
+ log("agentmind MCP server ready (stdio)");
94
+ }
95
+ // ── Dispatch ───────────────────────────────────────────
96
+ function dispatch(req, store, projectRoot) {
97
+ const { id, method, params } = req;
98
+ // Notifications have no id — no response needed
99
+ if (id == null && method === "notifications/initialized")
100
+ return null;
101
+ const reply = (result) => ({ jsonrpc: "2.0", id: id, result });
102
+ const error = (code, message) => ({ jsonrpc: "2.0", id: id, error: { code, message } });
103
+ switch (method) {
104
+ case "initialize":
105
+ return reply({
106
+ protocolVersion: "2024-11-05",
107
+ capabilities: { tools: {} },
108
+ serverInfo: { name: "agentmind", version: "0.1.0" },
109
+ });
110
+ case "ping":
111
+ return reply({});
112
+ case "tools/list":
113
+ return reply({ tools: TOOLS });
114
+ case "tools/call": {
115
+ const name = params?.name;
116
+ const args = (params?.arguments ?? {});
117
+ try {
118
+ const result = handleToolCall(name, args, store, projectRoot);
119
+ return reply({ content: [{ type: "text", text: result }] });
120
+ }
121
+ catch (err) {
122
+ const msg = err instanceof Error ? err.message : String(err);
123
+ return error(-32603, msg);
124
+ }
125
+ }
126
+ default:
127
+ return error(-32601, `Method not found: ${method}`);
128
+ }
129
+ }
130
+ // ── Tool handlers ──────────────────────────────────────
131
+ function handleToolCall(name, args, store, projectRoot) {
132
+ switch (name) {
133
+ case "get_context": return handleGetContext(args, store);
134
+ case "get_health": return handleGetHealth(store);
135
+ case "annotate_file": return handleAnnotateFile(args, store, projectRoot);
136
+ case "log_behavior": return handleLogBehavior(args, store);
137
+ case "find_gaps": return handleFindGaps(args, store, projectRoot);
138
+ default: throw new Error(`Unknown tool: ${name}`);
139
+ }
140
+ }
141
+ function handleGetContext(args, store) {
142
+ const filePath = args.filePath;
143
+ const query = args.query;
144
+ let entries;
145
+ if (filePath) {
146
+ entries = store.queryContext({ filePath });
147
+ }
148
+ else if (query) {
149
+ const all = store.getEntries();
150
+ entries = route(query, all);
151
+ }
152
+ else {
153
+ entries = store.getEntries({ scope: "global" });
154
+ }
155
+ if (entries.length === 0)
156
+ return "No context entries found for this query.";
157
+ return formatContext(entries);
158
+ }
159
+ function handleGetHealth(store) {
160
+ const h = store.getHealth();
161
+ const total = h.entries || 1;
162
+ const stalePct = Math.round((h.staleEntries / total) * 100);
163
+ const orphans = h.orphanedRules;
164
+ const lines = [
165
+ "# Context Health",
166
+ "",
167
+ `Total entries: ${h.entries}`,
168
+ `Stale entries: ${h.staleEntries} (${stalePct}%)`,
169
+ `Orphaned rules: ${orphans}`,
170
+ `Database size: ${formatBytes(h.dbSize)}`,
171
+ "",
172
+ ];
173
+ if (h.staleEntries > 0)
174
+ lines.push("- Consider running `agentmind scan` to refresh stale entries.");
175
+ if (orphans > 0)
176
+ lines.push("- Some rules reference files with no annotations — use `find_gaps` to see them.");
177
+ if (h.entries === 0)
178
+ lines.push("- No context stored yet. Run `agentmind scan` and annotate key files.");
179
+ return lines.join("\n");
180
+ }
181
+ function handleAnnotateFile(args, store, projectRoot) {
182
+ const filePath = args.filePath;
183
+ const text = args.text;
184
+ const priority = args.priority || "normal";
185
+ // Path containment check
186
+ const resolved = path.resolve(projectRoot, filePath);
187
+ if (!resolved.startsWith(projectRoot + path.sep) && resolved !== projectRoot) {
188
+ return `Error: filePath must be within project root. Got: ${filePath}`;
189
+ }
190
+ const valid = ["critical", "high", "normal", "low"];
191
+ const normalizedPriority = valid.includes(priority) ? priority : "normal";
192
+ const annotation = {
193
+ id: `ann-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
194
+ path: filePath,
195
+ text,
196
+ author: "agent",
197
+ created: Date.now(),
198
+ };
199
+ store.addAnnotation(annotation);
200
+ store.setMeta(`priority:${annotation.id}`, normalizedPriority);
201
+ return `Annotation saved for ${filePath} (priority: ${normalizedPriority}).`;
202
+ }
203
+ function handleLogBehavior(args, store) {
204
+ const filePath = args.filePath;
205
+ const tool = args.tool;
206
+ const success = args.success;
207
+ store.getDb().run("INSERT INTO behavior_log (agent_type, action, file_path, success, metadata) VALUES (?, ?, ?, ?, ?)", ["mcp", `tool:${tool}`, filePath, success ? 1 : 0, "{}"]);
208
+ return `Behavior logged: ${tool} on ${filePath} (${success ? "success" : "failure"}).`;
209
+ }
210
+ function handleFindGaps(args, store, projectRoot) {
211
+ const directory = args.directory;
212
+ // Get paths with existing context
213
+ const entries = store.getEntries();
214
+ const covered = new Set();
215
+ for (const e of entries) {
216
+ if (e.path)
217
+ covered.add(e.path);
218
+ }
219
+ // Walk the filesystem to find source files without context
220
+ const gaps = [];
221
+ const root = directory ? path.resolve(projectRoot, directory) : projectRoot;
222
+ if (!root.startsWith(projectRoot + path.sep) && root !== projectRoot) {
223
+ return "Error: directory must be within project root.";
224
+ }
225
+ walkFiles(root, projectRoot, covered, gaps);
226
+ if (gaps.length === 0)
227
+ return "No gaps found — all scanned files have context entries.";
228
+ const lines = [
229
+ `# Context Gaps (${gaps.length} files without context)`,
230
+ "",
231
+ ];
232
+ const display = gaps.slice(0, 50);
233
+ for (const g of display) {
234
+ lines.push(`- ${g}`);
235
+ }
236
+ if (gaps.length > 50) {
237
+ lines.push(`- ... and ${gaps.length - 50} more`);
238
+ }
239
+ return lines.join("\n");
240
+ }
241
+ // ── Formatting ─────────────────────────────────────────
242
+ function formatContext(entries) {
243
+ const lines = [
244
+ "# Agentmind Context",
245
+ "",
246
+ "Relevant context from the project knowledge base:",
247
+ "",
248
+ ];
249
+ for (const e of entries) {
250
+ lines.push(`## ${e.path}`);
251
+ lines.push("");
252
+ if (e.classification) {
253
+ lines.push(`Classification: ${e.classification}`);
254
+ lines.push("");
255
+ }
256
+ if (e.annotations.length > 0) {
257
+ lines.push("### Annotations");
258
+ for (const a of e.annotations) {
259
+ const lineRef = a.line ? ` (line ${a.line})` : "";
260
+ lines.push(`- ${a.text}${lineRef}`);
261
+ }
262
+ lines.push("");
263
+ }
264
+ if (e.rules.length > 0) {
265
+ lines.push("### Rules");
266
+ for (const r of e.rules) {
267
+ lines.push(`- ${r.pattern}: ${r.description}`);
268
+ }
269
+ lines.push("");
270
+ }
271
+ if (e.behaviors.length > 0) {
272
+ lines.push("### Observed Patterns");
273
+ for (const b of e.behaviors) {
274
+ lines.push(`- ${b.pattern}: ${b.description} (${b.frequency}x)`);
275
+ }
276
+ lines.push("");
277
+ }
278
+ }
279
+ return lines.join("\n");
280
+ }
281
+ // ── Helpers ────────────────────────────────────────────
282
+ function ensureStore(projectRoot) {
283
+ const dbPath = path.join(projectRoot, ".agentmind", "context.db");
284
+ if (!fs.existsSync(dbPath)) {
285
+ log(`No .agentmind/context.db found in ${projectRoot}. Run 'agentmind init && agentmind scan' first.`);
286
+ return null;
287
+ }
288
+ return new ContextStore(projectRoot);
289
+ }
290
+ function log(msg) {
291
+ process.stderr.write(`[agentmind] ${msg}\n`);
292
+ }
293
+ const SOURCE_EXTS = new Set([
294
+ ".ts", ".tsx", ".js", ".jsx", ".mjs", ".cjs",
295
+ ".py", ".rb", ".go", ".rs", ".java", ".kt", ".swift",
296
+ ".c", ".cpp", ".h", ".cs", ".scala", ".clj",
297
+ ".ex", ".exs", ".hs", ".zig", ".nim", ".lua", ".php",
298
+ ".vue", ".svelte",
299
+ ]);
300
+ function walkFiles(dir, root, covered, out) {
301
+ let entries;
302
+ try {
303
+ entries = fs.readdirSync(dir, { withFileTypes: true });
304
+ }
305
+ catch {
306
+ return;
307
+ }
308
+ for (const entry of entries) {
309
+ if (entry.name.startsWith(".") || entry.name === "node_modules" || entry.name === "dist")
310
+ continue;
311
+ const full = path.join(dir, entry.name);
312
+ if (entry.isDirectory()) {
313
+ walkFiles(full, root, covered, out);
314
+ }
315
+ else if (entry.isFile()) {
316
+ const ext = path.extname(entry.name);
317
+ if (!SOURCE_EXTS.has(ext))
318
+ continue;
319
+ const rel = path.relative(root, full).replace(/\\/g, "/");
320
+ if (!covered.has(rel))
321
+ out.push(rel);
322
+ }
323
+ }
324
+ }
325
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { ContextEntry } from "../types/index.js";
2
+ export declare function route(query: string, entries: ContextEntry[]): ContextEntry[];
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/router/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAyBrD,wBAAgB,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,YAAY,EAAE,CA+B5E"}
@@ -0,0 +1,44 @@
1
+ const SCORE_WEIGHTS = { path: 3, pattern: 2, description: 1, classification: 0.5 };
2
+ const MAX_RESULTS = 10;
3
+ const STOPWORDS = new Set([
4
+ "the", "a", "an", "in", "on", "for", "to", "with", "and", "or",
5
+ "of", "is", "at", "by", "from", "it", "as", "be", "was", "are",
6
+ ]);
7
+ const tokenize = (input) => input
8
+ .toLowerCase()
9
+ .split(/[^a-z0-9_.\-/]+/)
10
+ .filter(t => t.length > 0 && !STOPWORDS.has(t));
11
+ const match = (tokens, text) => {
12
+ const lower = text.toLowerCase();
13
+ let hits = 0;
14
+ for (const t of tokens) {
15
+ if (lower.includes(t))
16
+ hits++;
17
+ }
18
+ return hits;
19
+ };
20
+ export function route(query, entries) {
21
+ const tokens = tokenize(query);
22
+ if (tokens.length === 0)
23
+ return entries;
24
+ const scored = entries.map(entry => {
25
+ let score = 0;
26
+ score += match(tokens, entry.path) * SCORE_WEIGHTS.path;
27
+ for (const rule of entry.rules) {
28
+ score += match(tokens, rule.pattern) * SCORE_WEIGHTS.pattern;
29
+ score += match(tokens, rule.description) * SCORE_WEIGHTS.description;
30
+ }
31
+ for (const ann of entry.annotations) {
32
+ score += match(tokens, ann.text) * SCORE_WEIGHTS.description;
33
+ }
34
+ score += match(tokens, entry.classification) * SCORE_WEIGHTS.classification;
35
+ return { entry, score };
36
+ });
37
+ const hits = scored
38
+ .filter(s => s.score > 0)
39
+ .sort((a, b) => b.score - a.score)
40
+ .slice(0, MAX_RESULTS)
41
+ .map(s => s.entry);
42
+ return hits.length > 0 ? hits : entries;
43
+ }
44
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/router/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type { FileInfo, FileClassification } from "../types/index.js";
2
+ export declare function classify(root: string): Promise<{
3
+ files: FileInfo[];
4
+ classifications: Map<string, FileClassification>;
5
+ }>;
6
+ //# sourceMappingURL=classify.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"classify.d.ts","sourceRoot":"","sources":["../../src/scanner/classify.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,QAAQ,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAuErE,wBAAsB,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC;IAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;IAAC,eAAe,EAAE,GAAG,CAAC,MAAM,EAAE,kBAAkB,CAAC,CAAA;CAAE,CAAC,CAuC7H"}
@@ -0,0 +1,101 @@
1
+ import { glob } from "glob";
2
+ import { stat } from "node:fs/promises";
3
+ import { createHash } from "node:crypto";
4
+ import { readFile } from "node:fs/promises";
5
+ const pathMatchers = [
6
+ // generated / vendor first — broadest exclusions
7
+ [/(^|\/)node_modules\//, "vendor"],
8
+ [/\.agentmind\//, "generated"],
9
+ [/(^|\/)(dist|\.next|coverage|build|out|\.output)\//, "build"],
10
+ [/\.min\.(js|css)$/, "generated"],
11
+ // test
12
+ [/(^|\/)(__tests__|test|tests|spec|specs)\//, "test"],
13
+ [/\.(test|spec)\.(ts|tsx|js|jsx|py|go|rs)$/, "test"],
14
+ [/_test\.(go|rs)$/, "test"],
15
+ // docs
16
+ [/\.md$/, "docs"],
17
+ [/(^|\/)docs\//, "docs"],
18
+ [/LICENSE|CHANGELOG|CONTRIBUTING/, "docs"],
19
+ // style
20
+ [/\.(css|scss|sass|less|styled|module\.css)$/, "asset"],
21
+ // data
22
+ [/\.(json|yaml|yml|toml|xml|csv|proto|graphql|gql)$/, "data"],
23
+ [/\.(sql|prisma|drizzle)$/, "data"],
24
+ // config
25
+ [/\.config\.(ts|js|mjs|cjs)$/, "config"],
26
+ [/^\.github\//, "config"],
27
+ [/^Dockerfile/, "config"],
28
+ [/^docker-compose/, "config"],
29
+ [/^tsconfig/, "config"],
30
+ [/^\.env/, "config"],
31
+ [/\.(lock|lockfile)$/, "config"],
32
+ [/^(package\.json|turbo\.json|nx\.json|lerna\.json|pnpm-workspace\.yaml)$/, "config"],
33
+ // images, fonts, binaries
34
+ [/\.(png|jpg|jpeg|gif|svg|ico|webp|avif|mp4|mp3|woff2?|ttf|eot)$/, "asset"],
35
+ ];
36
+ const sourceExts = new Set([
37
+ ".ts", ".tsx", ".js", ".jsx", ".mjs", ".cjs",
38
+ ".py", ".rb", ".go", ".rs", ".java", ".kt", ".swift", ".c", ".cpp", ".h", ".hpp",
39
+ ".cs", ".scala", ".clj", ".ex", ".exs", ".erl", ".hs", ".ml", ".vim", ".el",
40
+ ".sh", ".bash", ".zsh", ".fish",
41
+ ".html", ".htm", ".vue", ".svelte",
42
+ ".zig", ".nim", ".lua", ".php",
43
+ ]);
44
+ function classifyPath(p) {
45
+ for (const [re, cls] of pathMatchers) {
46
+ if (re.test(p))
47
+ return cls;
48
+ }
49
+ const ext = p.slice(p.lastIndexOf("."));
50
+ if (sourceExts.has(ext))
51
+ return "source";
52
+ // index files in root
53
+ if (/(^|\/)index\.(ts|js|mjs)$/.test(p))
54
+ return "source";
55
+ return "data";
56
+ }
57
+ async function hashFile(p) {
58
+ try {
59
+ const buf = await readFile(p);
60
+ return createHash("sha256").update(buf).digest("hex").slice(0, 12);
61
+ }
62
+ catch {
63
+ return "";
64
+ }
65
+ }
66
+ export async function classify(root) {
67
+ const entries = await glob("**/*", {
68
+ cwd: root,
69
+ ignore: [
70
+ "node_modules/**",
71
+ ".git/**",
72
+ "dist/**",
73
+ ".next/**",
74
+ "coverage/**",
75
+ ".agentmind/**",
76
+ ],
77
+ nodir: true,
78
+ dot: true,
79
+ absolute: false,
80
+ });
81
+ const classifications = new Map();
82
+ const files = [];
83
+ // batch stat + hash
84
+ const results = await Promise.allSettled(entries.map(async (p) => {
85
+ const full = `${root}/${p}`;
86
+ const [s, hash] = await Promise.all([
87
+ stat(full),
88
+ hashFile(full),
89
+ ]);
90
+ return { path: p, size: s.size, modified: s.mtimeMs, hash };
91
+ }));
92
+ for (const r of results) {
93
+ if (r.status !== "fulfilled")
94
+ continue;
95
+ const f = r.value;
96
+ files.push(f);
97
+ classifications.set(f.path, classifyPath(f.path));
98
+ }
99
+ return { files, classifications };
100
+ }
101
+ //# sourceMappingURL=classify.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"classify.js","sourceRoot":"","sources":["../../src/scanner/classify.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { DependencyGraph, FileInfo } from "../types/index.js";
2
+ export declare function buildGraph(root: string, files: FileInfo[]): Promise<DependencyGraph>;
3
+ //# sourceMappingURL=graph.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"graph.d.ts","sourceRoot":"","sources":["../../src/scanner/graph.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAkB,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAkDlF,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,eAAe,CAAC,CA6D1F"}
@@ -0,0 +1,104 @@
1
+ import { readFile } from "node:fs/promises";
2
+ // match static import/require paths
3
+ const importRe = /(?:import\s+.*?from|require\s*\(\s*)['"]([^'"]+)['"]/g;
4
+ const dynamicImportRe = /import\s*\(\s*['"]([^'"]+)['"]\s*\)/g;
5
+ const exportFromRe = /export\s+(?:\*|\{[^}]*\})\s+from\s+['"]([^'"]+)['"]/g;
6
+ const sourceExts = new Set([".ts", ".tsx", ".js", ".jsx", ".mjs", ".cjs", ".vue", ".svelte"]);
7
+ function extractImports(content) {
8
+ const imports = new Set();
9
+ for (const re of [importRe, dynamicImportRe, exportFromRe]) {
10
+ let m;
11
+ re.lastIndex = 0;
12
+ while ((m = re.exec(content)) !== null) {
13
+ const spec = m[1];
14
+ // skip node builtins and bare specifiers (no ./ or ../)
15
+ if (!spec.startsWith("."))
16
+ continue;
17
+ imports.add(spec);
18
+ }
19
+ }
20
+ return [...imports];
21
+ }
22
+ // resolve relative import to file path
23
+ function resolveImport(fromFile, spec, allFiles) {
24
+ const dir = fromFile.includes("/") ? fromFile.slice(0, fromFile.lastIndexOf("/")) : "";
25
+ const parts = dir ? dir.split("/") : [];
26
+ for (const seg of spec.split("/")) {
27
+ if (seg === "..")
28
+ parts.pop();
29
+ else if (seg !== ".")
30
+ parts.push(seg);
31
+ }
32
+ const base = parts.join("/");
33
+ // try exact match, then extensions
34
+ if (allFiles.has(base))
35
+ return base;
36
+ for (const ext of [".ts", ".tsx", ".js", ".jsx", ".mjs", ".cjs"]) {
37
+ const candidate = base + ext;
38
+ if (allFiles.has(candidate))
39
+ return candidate;
40
+ }
41
+ // try index
42
+ for (const ext of [".ts", ".tsx", ".js", ".jsx"]) {
43
+ const candidate = `${base}/index${ext}`;
44
+ if (allFiles.has(candidate))
45
+ return candidate;
46
+ }
47
+ return null;
48
+ }
49
+ export async function buildGraph(root, files) {
50
+ const allPaths = new Set(files.map(f => f.path));
51
+ const nodes = new Map();
52
+ // init all nodes
53
+ for (const f of files) {
54
+ const ext = f.path.slice(f.path.lastIndexOf("."));
55
+ if (!sourceExts.has(ext))
56
+ continue;
57
+ nodes.set(f.path, { path: f.path, imports: [], importedBy: [] });
58
+ }
59
+ // read + parse in chunks
60
+ const sourceFiles = [...nodes.keys()];
61
+ const chunkSize = 50;
62
+ for (let i = 0; i < sourceFiles.length; i += chunkSize) {
63
+ const chunk = sourceFiles.slice(i, i + chunkSize);
64
+ const contents = await Promise.all(chunk.map(async (p) => {
65
+ try {
66
+ return await readFile(`${root}/${p}`, "utf-8");
67
+ }
68
+ catch {
69
+ return null;
70
+ }
71
+ }));
72
+ for (let j = 0; j < chunk.length; j++) {
73
+ const p = chunk[j];
74
+ const content = contents[j];
75
+ if (!content)
76
+ continue;
77
+ const specs = extractImports(content);
78
+ const resolved = [];
79
+ for (const spec of specs) {
80
+ const target = resolveImport(p, spec, allPaths);
81
+ if (target && nodes.has(target)) {
82
+ resolved.push(target);
83
+ }
84
+ }
85
+ const node = nodes.get(p);
86
+ node.imports = resolved;
87
+ // populate reverse edges
88
+ for (const target of resolved) {
89
+ nodes.get(target).importedBy.push(p);
90
+ }
91
+ }
92
+ }
93
+ // find roots (no importers) and orphans (no imports and no importers)
94
+ const roots = [];
95
+ const orphans = [];
96
+ for (const [path, node] of nodes) {
97
+ if (node.importedBy.length === 0)
98
+ roots.push(path);
99
+ if (node.imports.length === 0 && node.importedBy.length === 0)
100
+ orphans.push(path);
101
+ }
102
+ return { nodes, roots, orphans };
103
+ }
104
+ //# sourceMappingURL=graph.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"graph.js","sourceRoot":"","sources":["../../src/scanner/graph.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAG3C,oCAAoC;AACpC,MAAM,QAAQ,GAAG,uDAAuD,CAAA;AACxE,MAAM,eAAe,GAAG,sCAAsC,CAAA;AAC9D,MAAM,YAAY,GAAG,sDAAsD,CAAA;AAE3E,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,CAAC,CAAA;AAE7F,SAAS,cAAc,CAAC,OAAe;IACrC,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAA;IACjC,KAAK,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,eAAe,EAAE,YAAY,CAAC,EAAE,CAAC;QAC3D,IAAI,CAAyB,CAAA;QAC7B,EAAE,CAAC,SAAS,GAAG,CAAC,CAAA;QAChB,OAAO,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;YACvC,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAA;YACjB,wDAAwD;YACxD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;gBAAE,SAAQ;YACnC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QACnB,CAAC;IACH,CAAC;IACD,OAAO,CAAC,GAAG,OAAO,CAAC,CAAA;AACrB,CAAC;AAED,uCAAuC;AACvC,SAAS,aAAa,CAAC,QAAgB,EAAE,IAAY,EAAE,QAAqB;IAC1E,MAAM,GAAG,GAAG,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IACtF,MAAM,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAA;IAEvC,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;QAClC,IAAI,GAAG,KAAK,IAAI;YAAE,KAAK,CAAC,GAAG,EAAE,CAAA;aACxB,IAAI,GAAG,KAAK,GAAG;YAAE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvC,CAAC;IAED,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IAE5B,mCAAmC;IACnC,IAAI,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAA;IACnC,KAAK,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;QACjE,MAAM,SAAS,GAAG,IAAI,GAAG,GAAG,CAAA;QAC5B,IAAI,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC;YAAE,OAAO,SAAS,CAAA;IAC/C,CAAC;IACD,YAAY;IACZ,KAAK,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,CAAC;QACjD,MAAM,SAAS,GAAG,GAAG,IAAI,SAAS,GAAG,EAAE,CAAA;QACvC,IAAI,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC;YAAE,OAAO,SAAS,CAAA;IAC/C,CAAC;IACD,OAAO,IAAI,CAAA;AACb,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,IAAY,EAAE,KAAiB;IAC9D,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAA;IAChD,MAAM,KAAK,GAAG,IAAI,GAAG,EAA0B,CAAA;IAE/C,iBAAiB;IACjB,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAA;QACjD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC;YAAE,SAAQ;QAClC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,CAAA;IAClE,CAAC;IAED,yBAAyB;IACzB,MAAM,WAAW,GAAG,CAAC,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,CAAA;IACrC,MAAM,SAAS,GAAG,EAAE,CAAA;IAEpB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC;QACvD,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAAA;QACjD,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,GAAG,CAChC,KAAK,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE;YACpB,IAAI,CAAC;gBACH,OAAO,MAAM,QAAQ,CAAC,GAAG,IAAI,IAAI,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;YAChD,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,IAAI,CAAA;YACb,CAAC;QACH,CAAC,CAAC,CACH,CAAA;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAA;YAClB,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;YAC3B,IAAI,CAAC,OAAO;gBAAE,SAAQ;YAEtB,MAAM,KAAK,GAAG,cAAc,CAAC,OAAO,CAAC,CAAA;YACrC,MAAM,QAAQ,GAAa,EAAE,CAAA;YAE7B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,MAAM,MAAM,GAAG,aAAa,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAA;gBAC/C,IAAI,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;oBAChC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;gBACvB,CAAC;YACH,CAAC;YAED,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAE,CAAA;YAC1B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAA;YAEvB,yBAAyB;YACzB,KAAK,MAAM,MAAM,IAAI,QAAQ,EAAE,CAAC;gBAC9B,KAAK,CAAC,GAAG,CAAC,MAAM,CAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACvC,CAAC;QACH,CAAC;IACH,CAAC;IAED,sEAAsE;IACtE,MAAM,KAAK,GAAa,EAAE,CAAA;IAC1B,MAAM,OAAO,GAAa,EAAE,CAAA;IAC5B,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,KAAK,EAAE,CAAC;QACjC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC;YAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAClD,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACnF,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAA;AAClC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import type { ScanResult } from "../types/index.js";
2
+ export { classify } from "./classify.js";
3
+ export { detectPatterns } from "./patterns.js";
4
+ export { buildGraph } from "./graph.js";
5
+ export declare function scan(root: string): Promise<ScanResult>;
6
+ //# sourceMappingURL=index.d.ts.map