@decaf-ts/mcp-server 0.4.0 → 0.4.2
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/dist/mcp-server.cjs +754 -976
- package/dist/mcp-server.esm.cjs +807 -1042
- package/lib/McpWrapper.cjs +68 -24
- package/lib/McpWrapper.d.ts +0 -12
- package/lib/bin/cli.cjs +2 -2
- package/lib/bin/cli.d.ts +0 -24
- package/lib/esm/McpWrapper.d.ts +0 -12
- package/lib/esm/McpWrapper.js +31 -17
- package/lib/esm/bin/cli.d.ts +0 -24
- package/lib/esm/bin/cli.js +1 -1
- package/lib/esm/mcp/fastmcp-wiring.js +5 -5
- package/lib/esm/mcp/index.d.ts +2 -0
- package/lib/esm/mcp/index.js +8 -5
- package/lib/esm/mcp/mcp-module.d.ts +3 -3
- package/lib/esm/mcp/mcp-module.js +3 -3
- package/lib/esm/mcp/moduleRegistry.d.ts +3 -1
- package/lib/esm/mcp/moduleRegistry.js +8 -7
- package/lib/esm/mcp/prompts/index.d.ts +1 -1
- package/lib/esm/mcp/prompts/index.js +2 -2
- package/lib/esm/mcp/prompts/prompts.js +9 -3
- package/lib/esm/mcp/templates/index.js +4 -4
- package/lib/esm/mcp/tools/codex-tools.js +1 -1
- package/lib/esm/mcp/tools/generateMcpModule.js +1 -1
- package/lib/esm/mcp/tools/index.d.ts +0 -102
- package/lib/esm/mcp/tools/index.js +6 -8
- package/lib/esm/mcp/tools/tools.js +4 -2
- package/lib/esm/mcp/utils.d.ts +1 -2
- package/lib/esm/mcp/utils.js +1 -1
- package/lib/esm/metadata.d.ts +1 -1
- package/lib/esm/metadata.js +1 -1
- package/lib/esm/modules/_template/index.d.ts +4 -4
- package/lib/esm/modules/_template/index.js +9 -9
- package/lib/esm/modules/decoration/index.d.ts +3 -3
- package/lib/esm/modules/decoration/resources/index.d.ts +2 -2
- package/lib/esm/modules/decoration/resources/index.js +3 -3
- package/lib/esm/modules/decoration/templates/index.d.ts +1 -1
- package/lib/esm/modules/decoration/templates/index.js +2 -2
- package/lib/esm/modules/index.js +11 -4
- package/lib/esm/modules/mcp/index.d.ts +4 -4
- package/lib/esm/modules/mcp/index.js +9 -9
- package/lib/mcp/fastmcp-wiring.cjs +10 -10
- package/lib/mcp/index.cjs +16 -11
- package/lib/mcp/index.d.ts +2 -0
- package/lib/mcp/mcp-module.cjs +2 -9
- package/lib/mcp/mcp-module.d.ts +3 -3
- package/lib/mcp/moduleRegistry.cjs +9 -7
- package/lib/mcp/moduleRegistry.d.ts +3 -1
- package/lib/mcp/prompts/index.cjs +2 -2
- package/lib/mcp/prompts/index.d.ts +1 -1
- package/lib/mcp/prompts/prompts.cjs +9 -3
- package/lib/mcp/templates/index.cjs +1 -1
- package/lib/mcp/tools/codex-tools.cjs +1 -1
- package/lib/mcp/tools/generateMcpModule.cjs +1 -1
- package/lib/mcp/tools/index.cjs +8 -24
- package/lib/mcp/tools/index.d.ts +0 -102
- package/lib/mcp/tools/tools.cjs +40 -5
- package/lib/mcp/utils.cjs +1 -1
- package/lib/mcp/utils.d.ts +1 -2
- package/lib/metadata.cjs +1 -1
- package/lib/metadata.d.ts +1 -1
- package/lib/modules/_template/index.cjs +17 -17
- package/lib/modules/_template/index.d.ts +4 -4
- package/lib/modules/decoration/index.d.ts +3 -3
- package/lib/modules/decoration/resources/index.cjs +3 -3
- package/lib/modules/decoration/resources/index.d.ts +2 -2
- package/lib/modules/decoration/templates/index.cjs +2 -2
- package/lib/modules/decoration/templates/index.d.ts +1 -1
- package/lib/modules/index.cjs +14 -7
- package/lib/modules/mcp/index.cjs +17 -17
- package/lib/modules/mcp/index.d.ts +4 -4
- package/package.json +6 -2
package/dist/mcp-server.esm.cjs
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
import fs from 'fs';
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
1
|
+
import * as fs from 'fs';
|
|
2
|
+
import fs__default from 'fs';
|
|
3
|
+
import * as path from 'path';
|
|
4
|
+
import path__default from 'path';
|
|
5
5
|
import { spawnSync } from 'child_process';
|
|
6
|
+
import { z } from 'zod';
|
|
7
|
+
import { applyPatch, createTwoFilesPatch } from 'diff';
|
|
6
8
|
import { Metadata } from '@decaf-ts/decoration';
|
|
7
|
-
import { pathToFileURL } from 'url';
|
|
9
|
+
import { pathToFileURL, fileURLToPath } from 'url';
|
|
8
10
|
import fs$1 from 'node:fs';
|
|
9
11
|
import path$1 from 'node:path';
|
|
10
12
|
import { FastMCP } from 'fastmcp';
|
|
@@ -50,7 +52,7 @@ class WorkspaceError extends Error {
|
|
|
50
52
|
function initializeWorkspaceRoot() {
|
|
51
53
|
const configured = process.env[WORKSPACE_ROOT_ENV];
|
|
52
54
|
if (configured && configured.trim().length > 0) {
|
|
53
|
-
return
|
|
55
|
+
return path__default.resolve(configured.trim());
|
|
54
56
|
}
|
|
55
57
|
return process.cwd();
|
|
56
58
|
}
|
|
@@ -77,17 +79,17 @@ async function throwUserError(message) {
|
|
|
77
79
|
throw new Ctor(message);
|
|
78
80
|
}
|
|
79
81
|
function setWorkspaceRoot(root) {
|
|
80
|
-
workspaceRoot =
|
|
82
|
+
workspaceRoot = path__default.resolve(root);
|
|
81
83
|
}
|
|
82
84
|
function getWorkspaceRoot() {
|
|
83
85
|
return workspaceRoot;
|
|
84
86
|
}
|
|
85
87
|
function resolveInWorkspace(root, targetPath) {
|
|
86
|
-
const resolved =
|
|
87
|
-
?
|
|
88
|
-
:
|
|
89
|
-
const relative =
|
|
90
|
-
if (relative.startsWith("..") ||
|
|
88
|
+
const resolved = path__default.isAbsolute(targetPath)
|
|
89
|
+
? path__default.normalize(targetPath)
|
|
90
|
+
: path__default.resolve(root, targetPath);
|
|
91
|
+
const relative = path__default.relative(root, resolved);
|
|
92
|
+
if (relative.startsWith("..") || path__default.isAbsolute(relative)) {
|
|
91
93
|
throw new WorkspaceError(`Path ${targetPath} escapes the workspace root at ${root}`);
|
|
92
94
|
}
|
|
93
95
|
return resolved;
|
|
@@ -95,7 +97,7 @@ function resolveInWorkspace(root, targetPath) {
|
|
|
95
97
|
async function readWorkspaceFile(root, target) {
|
|
96
98
|
try {
|
|
97
99
|
const absolute = resolveInWorkspace(root, target);
|
|
98
|
-
return
|
|
100
|
+
return fs__default.readFileSync(absolute, "utf8");
|
|
99
101
|
}
|
|
100
102
|
catch (error) {
|
|
101
103
|
if (error instanceof WorkspaceError) {
|
|
@@ -109,26 +111,256 @@ function __resetWorkspaceRoot(root) {
|
|
|
109
111
|
setWorkspaceRoot(root);
|
|
110
112
|
}
|
|
111
113
|
|
|
112
|
-
const prompts
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
114
|
+
const prompts = [];
|
|
115
|
+
// Read registered module packages from a runtime global set by modules/index
|
|
116
|
+
// This avoids importing moduleRegistry at module-eval time which creates circular imports.
|
|
117
|
+
function getRegisteredModulePackages() {
|
|
118
|
+
return globalThis.__DECAF_MODULE_PACKAGES__ ?? [];
|
|
119
|
+
}
|
|
120
|
+
const OBJECT_PROMPT_DEPENDENCIES = {
|
|
121
|
+
module: ["doc", "module"],
|
|
122
|
+
file: ["doc", "file"],
|
|
123
|
+
class: ["doc", "class"],
|
|
124
|
+
function: ["doc", "function"],
|
|
125
|
+
interface: ["doc", "interface"],
|
|
126
|
+
decorator: ["doc", "decorator"],
|
|
127
|
+
constant: ["doc", "constant"],
|
|
128
|
+
"bulk-docs": ["bulk-docs"],
|
|
129
|
+
"bulk-tests": ["bulk-tests"],
|
|
130
|
+
"update-readme": ["update-readme"],
|
|
131
|
+
"repo-setup": ["repo-setup"],
|
|
132
|
+
"release-notes": ["release-notes"],
|
|
133
|
+
"mcp-module": ["mcp-module"],
|
|
134
|
+
};
|
|
135
|
+
function getObjectPromptDependencies() {
|
|
136
|
+
return OBJECT_PROMPT_DEPENDENCIES;
|
|
137
|
+
}
|
|
138
|
+
function buildDocPrompts() {
|
|
139
|
+
const root = getWorkspaceRoot();
|
|
140
|
+
const fileBasedPrompts = discoverDocPrompts(root).map((prompt) => ({
|
|
141
|
+
name: `doc/${prompt.name}`,
|
|
142
|
+
description: prompt.description,
|
|
143
|
+
load: async () => prompt.content,
|
|
144
|
+
}));
|
|
145
|
+
const integrationPrompts = CLIENT_INTEGRATIONS.map((integration) => ({
|
|
146
|
+
name: `integration/${integration.id}`,
|
|
147
|
+
description: `${integration.display} integration guidance`,
|
|
148
|
+
load: async () => `You are coordinating with ${integration.display}. ${integration.instructions}\n\nTools available:\n- document-code\n- apply-code-change\n\nEnsure responses include actionable steps for the client.`,
|
|
149
|
+
}));
|
|
150
|
+
return [...fileBasedPrompts, ...integrationPrompts];
|
|
151
|
+
}
|
|
152
|
+
function summarizePromptContent(prompt, headingPrefix) {
|
|
153
|
+
return [`## ${headingPrefix}`, "", prompt.content.trim()].join("\n");
|
|
154
|
+
}
|
|
155
|
+
function buildObjectPrompts() {
|
|
156
|
+
const root = getWorkspaceRoot();
|
|
157
|
+
const discovered = discoverDocPrompts(root);
|
|
158
|
+
const promptByName = new Map();
|
|
159
|
+
for (const prompt of discovered) {
|
|
160
|
+
promptByName.set(prompt.name, prompt);
|
|
121
161
|
}
|
|
122
|
-
];
|
|
162
|
+
const outputs = [];
|
|
163
|
+
for (const [objectType, dependencies] of Object.entries(OBJECT_PROMPT_DEPENDENCIES)) {
|
|
164
|
+
const existing = dependencies
|
|
165
|
+
.map((name) => promptByName.get(name))
|
|
166
|
+
.filter((prompt) => Boolean(prompt));
|
|
167
|
+
if (!existing.length)
|
|
168
|
+
continue;
|
|
169
|
+
outputs.push({
|
|
170
|
+
name: `codex/${objectType}`,
|
|
171
|
+
description: `Guidance derived from .codex prompts for ${objectType} tasks.`,
|
|
172
|
+
load: async () => {
|
|
173
|
+
const sections = existing.map((prompt) => summarizePromptContent(prompt, toTitleCase(prompt.name)));
|
|
174
|
+
return [`# Codex guidance for ${objectType}`, "", ...sections].join("\n");
|
|
175
|
+
},
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
return outputs.sort((a, b) => a.name.localeCompare(b.name));
|
|
179
|
+
}
|
|
180
|
+
function toInputPrompt(asset) {
|
|
181
|
+
const provenance = asset.provenance ? ` (module: ${asset.provenance})` : "";
|
|
182
|
+
return {
|
|
183
|
+
name: asset.id,
|
|
184
|
+
description: `${asset.description ?? asset.title}${provenance}`,
|
|
185
|
+
load: async () => asset.load(),
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
function buildModulePrompts() {
|
|
189
|
+
const pkgs = getRegisteredModulePackages();
|
|
190
|
+
const assets = pkgs.flatMap((p) => p.prompts ?? []);
|
|
191
|
+
return assets.map(toInputPrompt);
|
|
192
|
+
}
|
|
193
|
+
function refreshPrompts(repoPath) {
|
|
194
|
+
const docPrompts = buildDocPrompts();
|
|
195
|
+
const objectPrompts = buildObjectPrompts();
|
|
196
|
+
const repoPrompts = [];
|
|
197
|
+
const modulePrompts = buildModulePrompts();
|
|
198
|
+
prompts.splice(0, prompts.length, ...docPrompts, ...objectPrompts, ...repoPrompts, ...modulePrompts);
|
|
199
|
+
return prompts;
|
|
200
|
+
}
|
|
201
|
+
function discoverDocPrompts(root) {
|
|
202
|
+
const discovered = [];
|
|
203
|
+
for (const directory of PROMPT_DIRECTORIES) {
|
|
204
|
+
const promptDir = path__default.join(root, directory);
|
|
205
|
+
// debug logging to help tests diagnose prompt discovery
|
|
206
|
+
console.debug("[discoverDocPrompts] checking", promptDir);
|
|
207
|
+
if (!fs__default.existsSync(promptDir) || !fs__default.statSync(promptDir).isDirectory()) {
|
|
208
|
+
continue;
|
|
209
|
+
}
|
|
210
|
+
for (const entry of fs__default.readdirSync(promptDir)) {
|
|
211
|
+
const fullPath = path__default.join(promptDir, entry);
|
|
212
|
+
if (!fs__default.statSync(fullPath).isFile())
|
|
213
|
+
continue;
|
|
214
|
+
const name = path__default.parse(entry).name;
|
|
215
|
+
const content = fs__default.readFileSync(fullPath, "utf8");
|
|
216
|
+
const title = toTitleCase(name.replace(/[-_]/g, " "));
|
|
217
|
+
const description = extractDescription(content, fullPath);
|
|
218
|
+
discovered.push({
|
|
219
|
+
name,
|
|
220
|
+
title,
|
|
221
|
+
description,
|
|
222
|
+
content,
|
|
223
|
+
absolutePath: fullPath,
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
const unique = new Map();
|
|
228
|
+
for (const prompt of discovered) {
|
|
229
|
+
if (!unique.has(prompt.name)) {
|
|
230
|
+
unique.set(prompt.name, prompt);
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
return Array.from(unique.values()).sort((a, b) => a.name.localeCompare(b.name));
|
|
234
|
+
}
|
|
235
|
+
function selectPrompt(promptList, requestedName) {
|
|
236
|
+
const direct = promptList.find((prompt) => prompt.name === requestedName);
|
|
237
|
+
if (direct)
|
|
238
|
+
return direct;
|
|
239
|
+
const fallback = promptList.find((prompt) => prompt.name === DEFAULT_PROMPT_NAME);
|
|
240
|
+
if (fallback)
|
|
241
|
+
return fallback;
|
|
242
|
+
if (!promptList.length) {
|
|
243
|
+
throw new Error("No documentation prompts available");
|
|
244
|
+
}
|
|
245
|
+
return promptList[0];
|
|
246
|
+
}
|
|
247
|
+
function buildDocumentationPayload({ filePath, fileContent, prompt, includePrompt, includeCode, includeMetadata, additionalContext, }) {
|
|
248
|
+
const sections = [];
|
|
249
|
+
if (includeMetadata) {
|
|
250
|
+
sections.push(`# Documentation Request\n- prompt: ${prompt.name}\n- file: ${filePath}`);
|
|
251
|
+
}
|
|
252
|
+
if (includePrompt) {
|
|
253
|
+
sections.push(`## Prompt Guidance (${prompt.title})\n\n${prompt.content.trim()}`);
|
|
254
|
+
}
|
|
255
|
+
if (additionalContext?.trim()) {
|
|
256
|
+
sections.push(`## Additional Context\n\n${additionalContext.trim()}`);
|
|
257
|
+
}
|
|
258
|
+
if (includeCode) {
|
|
259
|
+
sections.push(`## Source\n\n\`\`\`${inferLanguageFromPath(filePath)}\n${fileContent}\n\`\`\``);
|
|
260
|
+
}
|
|
261
|
+
return {
|
|
262
|
+
content: [
|
|
263
|
+
{
|
|
264
|
+
type: "text",
|
|
265
|
+
text: sections.join("\n\n"),
|
|
266
|
+
},
|
|
267
|
+
],
|
|
268
|
+
};
|
|
269
|
+
}
|
|
270
|
+
function extractDescription(content, filePath) {
|
|
271
|
+
const firstLine = content
|
|
272
|
+
.split(/\r?\n/)
|
|
273
|
+
.map((line) => line.trim())
|
|
274
|
+
.find((line) => line.length > 0);
|
|
275
|
+
return (firstLine?.slice(0, 240) ??
|
|
276
|
+
`Documentation prompt loaded from ${path__default.basename(filePath)}`);
|
|
277
|
+
}
|
|
278
|
+
function toTitleCase(value) {
|
|
279
|
+
return value
|
|
280
|
+
.split(/\s+/)
|
|
281
|
+
.filter(Boolean)
|
|
282
|
+
.map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())
|
|
283
|
+
.join(" ");
|
|
284
|
+
}
|
|
285
|
+
function inferLanguageFromPath(filePath) {
|
|
286
|
+
const extension = path__default.extname(filePath).toLowerCase();
|
|
287
|
+
switch (extension) {
|
|
288
|
+
case ".ts":
|
|
289
|
+
case ".tsx":
|
|
290
|
+
return "ts";
|
|
291
|
+
case ".js":
|
|
292
|
+
case ".jsx":
|
|
293
|
+
return "js";
|
|
294
|
+
case ".json":
|
|
295
|
+
return "json";
|
|
296
|
+
case ".md":
|
|
297
|
+
return "md";
|
|
298
|
+
default:
|
|
299
|
+
return "text";
|
|
300
|
+
}
|
|
301
|
+
}
|
|
123
302
|
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
303
|
+
var prompts$1 = /*#__PURE__*/Object.freeze({
|
|
304
|
+
__proto__: null,
|
|
305
|
+
DEFAULT_PROMPT_NAME: DEFAULT_PROMPT_NAME,
|
|
306
|
+
buildDocPrompts: buildDocPrompts,
|
|
307
|
+
buildDocumentationPayload: buildDocumentationPayload,
|
|
308
|
+
buildObjectPrompts: buildObjectPrompts,
|
|
309
|
+
discoverDocPrompts: discoverDocPrompts,
|
|
310
|
+
getObjectPromptDependencies: getObjectPromptDependencies,
|
|
311
|
+
prompts: prompts,
|
|
312
|
+
refreshPrompts: refreshPrompts,
|
|
313
|
+
selectPrompt: selectPrompt
|
|
314
|
+
});
|
|
315
|
+
|
|
316
|
+
const promptList = prompts;
|
|
317
|
+
function loadPrompts(repoPath) {
|
|
318
|
+
return refreshPrompts();
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
class ModuleRegistry {
|
|
322
|
+
constructor(packages = []) {
|
|
323
|
+
this.packages = packages;
|
|
130
324
|
}
|
|
131
|
-
|
|
325
|
+
setPackages(pkgs) {
|
|
326
|
+
this.packages = Array.isArray(pkgs) ? pkgs : [];
|
|
327
|
+
}
|
|
328
|
+
listPackages() {
|
|
329
|
+
return this.packages;
|
|
330
|
+
}
|
|
331
|
+
listPrompts() {
|
|
332
|
+
return this.collectAssets("prompts");
|
|
333
|
+
}
|
|
334
|
+
listResources() {
|
|
335
|
+
return this.collectAssets("resources");
|
|
336
|
+
}
|
|
337
|
+
listTemplates() {
|
|
338
|
+
return this.collectAssets("templates");
|
|
339
|
+
}
|
|
340
|
+
listTools() {
|
|
341
|
+
return this.collectAssets("tools");
|
|
342
|
+
}
|
|
343
|
+
collectAssets(key) {
|
|
344
|
+
const seen = new Map();
|
|
345
|
+
const aggregated = [];
|
|
346
|
+
for (const pkg of this.packages) {
|
|
347
|
+
if (pkg.status === "disabled")
|
|
348
|
+
continue;
|
|
349
|
+
for (const asset of pkg[key]) {
|
|
350
|
+
const maybeName = asset.name;
|
|
351
|
+
const assetKey = (asset && (asset.id ?? maybeName)) || JSON.stringify(asset);
|
|
352
|
+
if (seen.has(assetKey)) {
|
|
353
|
+
const conflict = seen.get(assetKey);
|
|
354
|
+
throw new Error(`Duplicate ${key} id '${assetKey}' from modules ${conflict} and ${pkg.name}`);
|
|
355
|
+
}
|
|
356
|
+
seen.set(assetKey, pkg.name);
|
|
357
|
+
aggregated.push({ ...asset, provenance: pkg.name });
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
return aggregated;
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
const moduleRegistry = new ModuleRegistry();
|
|
132
364
|
|
|
133
365
|
const analyzeRepoSchema = z
|
|
134
366
|
.object({
|
|
@@ -228,7 +460,7 @@ const readmeImprovementSchema = z
|
|
|
228
460
|
|
|
229
461
|
function readFileSafe(filePath, encoding = "utf8") {
|
|
230
462
|
try {
|
|
231
|
-
return
|
|
463
|
+
return fs__default.readFileSync(filePath, { encoding });
|
|
232
464
|
}
|
|
233
465
|
catch {
|
|
234
466
|
return undefined;
|
|
@@ -239,10 +471,10 @@ function listFilesRecursive(root, matcher) {
|
|
|
239
471
|
const stack = [root];
|
|
240
472
|
while (stack.length) {
|
|
241
473
|
const cur = stack.pop();
|
|
242
|
-
const stat =
|
|
474
|
+
const stat = fs__default.statSync(cur);
|
|
243
475
|
if (stat.isDirectory()) {
|
|
244
|
-
for (const f of
|
|
245
|
-
stack.push(
|
|
476
|
+
for (const f of fs__default.readdirSync(cur))
|
|
477
|
+
stack.push(path__default.join(cur, f));
|
|
246
478
|
}
|
|
247
479
|
else if (!matcher || matcher(cur)) {
|
|
248
480
|
out.push(cur);
|
|
@@ -312,18 +544,18 @@ function summarizeReadme(readme) {
|
|
|
312
544
|
return { title, bullets };
|
|
313
545
|
}
|
|
314
546
|
function analyzeRepo(root) {
|
|
315
|
-
const src =
|
|
316
|
-
const testDir =
|
|
317
|
-
const readmePath =
|
|
547
|
+
const src = path__default.join(root, "src");
|
|
548
|
+
const testDir = path__default.join(root, "tests");
|
|
549
|
+
const readmePath = path__default.join(root, "README.md");
|
|
318
550
|
const readme = readFileSafe(readmePath);
|
|
319
|
-
const files =
|
|
320
|
-
const testFiles =
|
|
551
|
+
const files = fs__default.existsSync(src) ? listFilesRecursive(src, isSourceFile) : [];
|
|
552
|
+
const testFiles = fs__default.existsSync(testDir)
|
|
321
553
|
? listFilesRecursive(testDir, (f) => isSourceFile(f) && isTestFile(f))
|
|
322
554
|
: [];
|
|
323
555
|
const api = {};
|
|
324
556
|
for (const f of files) {
|
|
325
557
|
const content = readFileSafe(f) || "";
|
|
326
|
-
api[
|
|
558
|
+
api[path__default.relative(root, f)] = {
|
|
327
559
|
exports: extractExports(content),
|
|
328
560
|
decorators: extractDecorators(content),
|
|
329
561
|
};
|
|
@@ -332,666 +564,246 @@ function analyzeRepo(root) {
|
|
|
332
564
|
for (const f of testFiles) {
|
|
333
565
|
const content = readFileSafe(f) || "";
|
|
334
566
|
const mentions = Array.from(new Set([...extractExports(content), ...extractDecorators(content)])).sort();
|
|
335
|
-
tests[
|
|
567
|
+
tests[path__default.relative(root, f)] = { mentions };
|
|
336
568
|
}
|
|
337
569
|
return { files, testFiles, api, tests, readme: summarizeReadme(readme) };
|
|
338
570
|
}
|
|
339
571
|
|
|
340
|
-
function
|
|
341
|
-
return
|
|
342
|
-
name: "analyze-repository",
|
|
343
|
-
description: "Analyze a local repository's source, tests, and docs to extract exported APIs, decorators, and test mentions.",
|
|
344
|
-
parameters: analyzeRepoSchema,
|
|
345
|
-
execute: async (input) => {
|
|
346
|
-
let repoRoot = path.resolve(process.cwd(), input.repoPath);
|
|
347
|
-
if (!fs.existsSync(repoRoot)) {
|
|
348
|
-
// try resolving from monorepo root (parent of current cwd)
|
|
349
|
-
const alt = path.resolve(process.cwd(), "..", input.repoPath);
|
|
350
|
-
if (fs.existsSync(alt))
|
|
351
|
-
repoRoot = alt;
|
|
352
|
-
}
|
|
353
|
-
if (!fs.existsSync(repoRoot)) {
|
|
354
|
-
// if input was absolute and still not found, try ../<basename>
|
|
355
|
-
const alt2 = path.resolve(process.cwd(), "..", path.basename(input.repoPath));
|
|
356
|
-
if (fs.existsSync(alt2))
|
|
357
|
-
repoRoot = alt2;
|
|
358
|
-
}
|
|
359
|
-
if (!fs.existsSync(repoRoot))
|
|
360
|
-
throw new Error(`Repository not found at ${repoRoot}`);
|
|
361
|
-
const result = analyzeRepo(repoRoot);
|
|
362
|
-
return {
|
|
363
|
-
content: [{ type: "text", text: JSON.stringify(result, null, 2) }],
|
|
364
|
-
};
|
|
365
|
-
},
|
|
366
|
-
};
|
|
572
|
+
function relativeFiles(root, files) {
|
|
573
|
+
return files.map((file) => path__default.relative(root, file)).sort();
|
|
367
574
|
}
|
|
368
|
-
function
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
const alt2 = path.resolve(process.cwd(), "..", path.basename(input.repoPath));
|
|
382
|
-
if (fs.existsSync(alt2))
|
|
383
|
-
repoRoot = alt2;
|
|
384
|
-
}
|
|
385
|
-
if (!fs.existsSync(repoRoot))
|
|
386
|
-
throw new Error(`Repository not found at ${repoRoot}`);
|
|
387
|
-
const analysis = analyzeRepo(repoRoot);
|
|
388
|
-
const capabilities = deriveCapabilities(analysis);
|
|
389
|
-
return {
|
|
390
|
-
content: [
|
|
391
|
-
{
|
|
392
|
-
type: "text",
|
|
393
|
-
text: JSON.stringify({
|
|
394
|
-
capabilities,
|
|
395
|
-
analysisSummary: {
|
|
396
|
-
files: analysis.files.length,
|
|
397
|
-
testFiles: analysis.testFiles.length,
|
|
398
|
-
readme: analysis.readme?.title,
|
|
399
|
-
},
|
|
400
|
-
}, null, 2),
|
|
401
|
-
},
|
|
402
|
-
],
|
|
403
|
-
};
|
|
404
|
-
},
|
|
405
|
-
};
|
|
406
|
-
}
|
|
407
|
-
function buildPlanFeatureTool() {
|
|
408
|
-
return {
|
|
409
|
-
name: "plan-feature-implementation",
|
|
410
|
-
description: "Given a feature request, select appropriate MCP tools (including existing and new ones) and produce an execution plan.",
|
|
411
|
-
parameters: planFeatureSchema,
|
|
412
|
-
execute: async (input) => {
|
|
413
|
-
const steps = [];
|
|
414
|
-
let i = 1;
|
|
415
|
-
steps.push({
|
|
416
|
-
step: i++,
|
|
417
|
-
action: "Analyze repository to enumerate APIs and decorators",
|
|
418
|
-
tool: "analyze-repository",
|
|
419
|
-
arguments: { repoPath: input.repoPath },
|
|
420
|
-
rationale: "Understand available building blocks.",
|
|
421
|
-
});
|
|
422
|
-
steps.push({
|
|
423
|
-
step: i++,
|
|
424
|
-
action: "List capabilities expected for developers",
|
|
425
|
-
tool: "enumerate-capabilities",
|
|
426
|
-
arguments: { repoPath: input.repoPath },
|
|
427
|
-
rationale: "Align the plan with supported capabilities.",
|
|
428
|
-
});
|
|
429
|
-
// Suggest existing generic tools from mcp-module
|
|
430
|
-
steps.push({
|
|
431
|
-
step: i++,
|
|
432
|
-
action: "Select documentation prompt and gather relevant source file(s)",
|
|
433
|
-
tool: "document-code",
|
|
434
|
-
arguments: { filePath: "<target-file>" },
|
|
435
|
-
rationale: "Provide context and instructions for changes.",
|
|
436
|
-
});
|
|
437
|
-
steps.push({
|
|
438
|
-
step: i++,
|
|
439
|
-
action: "Apply code changes using unified diff patch",
|
|
440
|
-
tool: "apply-code-change",
|
|
441
|
-
arguments: {
|
|
442
|
-
filePath: "<target-file>",
|
|
443
|
-
patch: "<unified-diff>",
|
|
444
|
-
dryRun: true,
|
|
445
|
-
},
|
|
446
|
-
rationale: "Validate changes safely before committing.",
|
|
447
|
-
});
|
|
448
|
-
steps.push({
|
|
449
|
-
step: i++,
|
|
450
|
-
action: "Commit code changes",
|
|
451
|
-
tool: "apply-code-change",
|
|
452
|
-
arguments: {
|
|
453
|
-
filePath: "<target-file>",
|
|
454
|
-
patch: "<unified-diff>",
|
|
455
|
-
dryRun: false,
|
|
456
|
-
},
|
|
457
|
-
rationale: "Persist the update.",
|
|
458
|
-
});
|
|
459
|
-
// If decoration-related terms present, suggest decorator tools
|
|
460
|
-
if (/decorat|flavour|override|extend|builder/i.test(input.feature)) {
|
|
461
|
-
steps.unshift({
|
|
462
|
-
step: 0,
|
|
463
|
-
action: "Use decorator tooling to insert/remove/modify decorators",
|
|
464
|
-
tool: "decorator-tools",
|
|
465
|
-
arguments: { action: "help" },
|
|
466
|
-
rationale: "Leverage specialized utilities for decoration patterns.",
|
|
467
|
-
});
|
|
468
|
-
steps.forEach((s, idx) => (s.step = idx + 1));
|
|
469
|
-
}
|
|
470
|
-
return {
|
|
471
|
-
content: [
|
|
472
|
-
{
|
|
473
|
-
type: "text",
|
|
474
|
-
text: JSON.stringify({
|
|
475
|
-
plan: steps,
|
|
476
|
-
notes: "Replace placeholder arguments like <target-file> and <unified-diff> based on the analysis output.",
|
|
477
|
-
}, null, 2),
|
|
478
|
-
},
|
|
479
|
-
],
|
|
480
|
-
};
|
|
481
|
-
},
|
|
482
|
-
};
|
|
483
|
-
}
|
|
484
|
-
const documentCodeTool = {
|
|
485
|
-
annotations: {
|
|
486
|
-
idempotentHint: true,
|
|
487
|
-
openWorldHint: false,
|
|
488
|
-
readOnlyHint: true,
|
|
489
|
-
title: "Document Source File",
|
|
490
|
-
},
|
|
491
|
-
description: "Generate documentation guidance for a file by combining repository prompts with the target source code.",
|
|
492
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
493
|
-
execute: async (input, _context) => {
|
|
494
|
-
const args = documentCodeSchema.parse(input);
|
|
495
|
-
const root = getWorkspaceRoot();
|
|
496
|
-
let filePath;
|
|
497
|
-
try {
|
|
498
|
-
filePath = resolveInWorkspace(root, args.filePath);
|
|
499
|
-
}
|
|
500
|
-
catch (error) {
|
|
501
|
-
if (error instanceof WorkspaceError) {
|
|
502
|
-
return throwUserError(error.message);
|
|
503
|
-
}
|
|
504
|
-
/* istanbul ignore next */
|
|
505
|
-
throw error;
|
|
506
|
-
}
|
|
507
|
-
if (!fs.existsSync(filePath)) {
|
|
508
|
-
return throwUserError(`Cannot document missing file at ${args.filePath}`);
|
|
509
|
-
}
|
|
510
|
-
const fileContent = fs.readFileSync(filePath, {
|
|
511
|
-
encoding: args.encoding,
|
|
512
|
-
});
|
|
513
|
-
const prompts = discoverDocPrompts(root);
|
|
514
|
-
if (!prompts.length) {
|
|
515
|
-
return throwUserError("No documentation prompts found under .code/prompts or .codex/prompts");
|
|
516
|
-
}
|
|
517
|
-
const prompt = selectPrompt(prompts, args.promptName ?? DEFAULT_PROMPT_NAME);
|
|
518
|
-
return buildDocumentationPayload({
|
|
519
|
-
filePath: args.filePath,
|
|
520
|
-
fileContent,
|
|
521
|
-
prompt,
|
|
522
|
-
includeCode: args.includeCode,
|
|
523
|
-
includePrompt: args.includePrompt,
|
|
524
|
-
includeMetadata: args.includeMetadata,
|
|
525
|
-
additionalContext: args.additionalContext,
|
|
526
|
-
});
|
|
527
|
-
},
|
|
528
|
-
name: "document-code",
|
|
529
|
-
parameters: documentCodeSchema,
|
|
530
|
-
};
|
|
531
|
-
const applyCodeChangeTool = {
|
|
532
|
-
annotations: {
|
|
533
|
-
destructiveHint: true,
|
|
534
|
-
idempotentHint: false,
|
|
535
|
-
openWorldHint: false,
|
|
536
|
-
readOnlyHint: false,
|
|
537
|
-
title: "Apply Code Patch",
|
|
538
|
-
},
|
|
539
|
-
description: "Apply a unified diff patch to a workspace file with optional dry-run validation and diff preview.",
|
|
540
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
541
|
-
execute: async (input, _context) => {
|
|
542
|
-
const args = codeChangeSchema.parse(input);
|
|
543
|
-
const root = getWorkspaceRoot();
|
|
544
|
-
let filePath;
|
|
545
|
-
try {
|
|
546
|
-
filePath = resolveInWorkspace(root, args.filePath);
|
|
547
|
-
}
|
|
548
|
-
catch (error) {
|
|
549
|
-
if (error instanceof WorkspaceError) {
|
|
550
|
-
return throwUserError(error.message);
|
|
551
|
-
}
|
|
552
|
-
throw error;
|
|
553
|
-
}
|
|
554
|
-
const original = fs.existsSync(filePath)
|
|
555
|
-
? fs.readFileSync(filePath, args.encoding)
|
|
556
|
-
: "";
|
|
557
|
-
let patched;
|
|
558
|
-
try {
|
|
559
|
-
patched = applyPatch(original, args.patch);
|
|
560
|
-
}
|
|
561
|
-
catch (error) {
|
|
562
|
-
return throwUserError(`Failed to apply provided patch to ${args.filePath}: ${error instanceof Error ? error.message : error}`);
|
|
563
|
-
}
|
|
564
|
-
/* istanbul ignore next */
|
|
565
|
-
if (patched === false) {
|
|
566
|
-
return throwUserError(`Failed to apply provided patch to ${args.filePath}`);
|
|
567
|
-
}
|
|
568
|
-
if (!args.dryRun) {
|
|
569
|
-
fs.mkdirSync(path.dirname(filePath), { recursive: true });
|
|
570
|
-
fs.writeFileSync(filePath, patched, {
|
|
571
|
-
encoding: args.encoding,
|
|
572
|
-
});
|
|
573
|
-
}
|
|
574
|
-
if (!args.showDiff) {
|
|
575
|
-
return `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`;
|
|
576
|
-
}
|
|
577
|
-
const preview = createTwoFilesPatch(args.filePath, args.filePath, original, patched, undefined, undefined, { context: args.diffContext });
|
|
578
|
-
return {
|
|
579
|
-
content: [
|
|
580
|
-
{
|
|
581
|
-
type: "text",
|
|
582
|
-
text: `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`,
|
|
583
|
-
},
|
|
584
|
-
{
|
|
585
|
-
type: "text",
|
|
586
|
-
text: ["```diff", preview.trim(), "```"].join("\n"),
|
|
587
|
-
},
|
|
588
|
-
],
|
|
589
|
-
};
|
|
590
|
-
},
|
|
591
|
-
name: "apply-code-change",
|
|
592
|
-
parameters: codeChangeSchema,
|
|
593
|
-
};
|
|
594
|
-
const analyticTools = [
|
|
595
|
-
buildAnalyzeRepositoryTool(),
|
|
596
|
-
buildEnumerateCapabilitiesTool(),
|
|
597
|
-
buildPlanFeatureTool(),
|
|
598
|
-
];
|
|
599
|
-
const toolList$1 = [
|
|
600
|
-
...analyticTools,
|
|
601
|
-
documentCodeTool,
|
|
602
|
-
applyCodeChangeTool,
|
|
603
|
-
];
|
|
604
|
-
|
|
605
|
-
const tools$3 = [
|
|
606
|
-
{ id: 'decoration.analyze', title: 'Analyze decoration', description: 'Analyze the target repository', tool: buildAnalyzeRepositoryTool() },
|
|
607
|
-
{ id: 'decoration.enumerate', title: 'Enumerate capabilities for decoration', description: 'Enumerate capabilities', tool: buildEnumerateCapabilitiesTool() },
|
|
608
|
-
{ id: 'decoration.plan', title: 'Plan features for decoration', description: 'Plan feature implementation', tool: buildPlanFeatureTool() },
|
|
609
|
-
];
|
|
610
|
-
|
|
611
|
-
const modulePackage$2 = { name: 'decoration', prompts: prompts$3, resources: resources$3, templates: templates$2, tools: tools$3 };
|
|
612
|
-
|
|
613
|
-
const prompts$2 = [
|
|
614
|
-
{
|
|
615
|
-
id: "mcp.prompt.module-catalog",
|
|
616
|
-
title: "Decaf MCP Module Catalog",
|
|
617
|
-
description: "Summarizes the modules contributing prompts/resources/templates/tools to FASTMCP.",
|
|
618
|
-
load: async () => "Use the module catalog tool to enumerate available module assets before fulfilling assistant requests.",
|
|
619
|
-
},
|
|
620
|
-
];
|
|
621
|
-
|
|
622
|
-
const resources$2 = [
|
|
623
|
-
{
|
|
624
|
-
id: "mcp.resource.registry-overview",
|
|
625
|
-
title: "Module Registry Overview",
|
|
626
|
-
description: "Explains how the ModuleRegistry aggregates module exports into FASTMCP catalogs.",
|
|
627
|
-
uri: "decaf://mcp/module-registry",
|
|
628
|
-
mimeType: "text/markdown",
|
|
629
|
-
load: async () => ({
|
|
630
|
-
content: [
|
|
631
|
-
{
|
|
632
|
-
type: "text",
|
|
633
|
-
text: [
|
|
634
|
-
"# Module Registry",
|
|
635
|
-
"",
|
|
636
|
-
"The Decaf MCP server aggregates prompts, resources, templates, and tools from every module under src/modules.",
|
|
637
|
-
"Validators ensure each module contains the canonical folder layout before the registry loads it.",
|
|
638
|
-
].join("\n"),
|
|
639
|
-
mimeType: "text/markdown",
|
|
640
|
-
},
|
|
641
|
-
],
|
|
642
|
-
}),
|
|
643
|
-
},
|
|
644
|
-
];
|
|
645
|
-
|
|
646
|
-
const templates$1 = [
|
|
647
|
-
{
|
|
648
|
-
id: "mcp.template.module-readme",
|
|
649
|
-
title: "Module README Template",
|
|
650
|
-
description: "Guides maintainers through documenting a new MCP-aware module.",
|
|
651
|
-
content: `# {{moduleName}} Module
|
|
652
|
-
|
|
653
|
-
## Purpose
|
|
654
|
-
Describe why this module exists and how assistants should use it.
|
|
655
|
-
|
|
656
|
-
## Assets
|
|
657
|
-
- Prompts: {{promptSummary}}
|
|
658
|
-
- Resources: {{resourceSummary}}
|
|
659
|
-
- Templates: {{templateSummary}}
|
|
660
|
-
- Tools: {{toolSummary}}
|
|
661
|
-
|
|
662
|
-
## Validation
|
|
663
|
-
Explain what needs to happen when this module changes (tests, docs, etc.).`,
|
|
664
|
-
placeholders: [
|
|
665
|
-
"moduleName",
|
|
666
|
-
"promptSummary",
|
|
667
|
-
"resourceSummary",
|
|
668
|
-
"templateSummary",
|
|
669
|
-
"toolSummary",
|
|
670
|
-
],
|
|
671
|
-
},
|
|
672
|
-
];
|
|
673
|
-
|
|
674
|
-
const describeModulesTool = {
|
|
675
|
-
name: "describe-modules",
|
|
676
|
-
description: "Summarize the purpose of Decaf MCP modules for assistant operators.",
|
|
677
|
-
// Minimal execute implementation to return a text result
|
|
678
|
-
execute: async () => "Modules contribute prompts, resources, templates, and tools that the registry exposes to FASTMCP clients.",
|
|
679
|
-
};
|
|
680
|
-
const tools$2 = [
|
|
681
|
-
{
|
|
682
|
-
id: "mcp.tool.describe-modules",
|
|
683
|
-
title: "Describe MCP Modules",
|
|
684
|
-
description: "Explains how module exports feed into the FASTMCP server.",
|
|
685
|
-
tool: describeModulesTool,
|
|
686
|
-
},
|
|
687
|
-
];
|
|
688
|
-
|
|
689
|
-
const modulePackage$1 = {
|
|
690
|
-
name: "mcp",
|
|
691
|
-
prompts: prompts$2,
|
|
692
|
-
resources: resources$2,
|
|
693
|
-
templates: templates$1,
|
|
694
|
-
tools: tools$2,
|
|
695
|
-
};
|
|
696
|
-
|
|
697
|
-
const prompts$1 = [
|
|
698
|
-
{
|
|
699
|
-
id: "_template.readme",
|
|
700
|
-
title: "Template README",
|
|
701
|
-
description: "A README prompt for module template",
|
|
702
|
-
load: () => "Template prompt content",
|
|
703
|
-
},
|
|
704
|
-
];
|
|
705
|
-
|
|
706
|
-
const resources$1 = [
|
|
707
|
-
{
|
|
708
|
-
id: "_template.repo",
|
|
709
|
-
name: "template repo",
|
|
710
|
-
description: "Template resource",
|
|
711
|
-
uri: "file:///tmp/template",
|
|
712
|
-
},
|
|
713
|
-
];
|
|
714
|
-
|
|
715
|
-
const templates = [
|
|
716
|
-
{
|
|
717
|
-
id: "_template.readme",
|
|
718
|
-
name: "template-readme",
|
|
719
|
-
description: "README guidance",
|
|
720
|
-
uriTemplate: "file:///tmp/template/README.md",
|
|
721
|
-
mimeType: "text/markdown",
|
|
722
|
-
},
|
|
723
|
-
];
|
|
724
|
-
|
|
725
|
-
const placeholderTool = {
|
|
726
|
-
name: "_template.tool",
|
|
727
|
-
description: "A placeholder tool",
|
|
728
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
729
|
-
execute: async (_input, _context) => "ok",
|
|
730
|
-
};
|
|
731
|
-
const tools$1 = [
|
|
732
|
-
{
|
|
733
|
-
id: "_template.tool",
|
|
734
|
-
title: "template tool",
|
|
735
|
-
description: "A placeholder tool",
|
|
736
|
-
tool: placeholderTool,
|
|
737
|
-
},
|
|
738
|
-
];
|
|
739
|
-
|
|
740
|
-
const modulePackage = {
|
|
741
|
-
name: "_template",
|
|
742
|
-
prompts: prompts$1,
|
|
743
|
-
resources: resources$1,
|
|
744
|
-
templates,
|
|
745
|
-
tools: tools$1,
|
|
746
|
-
};
|
|
747
|
-
|
|
748
|
-
// modulePackage objects may be declared with readonly arrays (as const). Cast to the mutable type expected by runtime APIs.
|
|
749
|
-
const modulePackages = [
|
|
750
|
-
modulePackage$2,
|
|
751
|
-
modulePackage$1,
|
|
752
|
-
modulePackage,
|
|
753
|
-
];
|
|
754
|
-
|
|
755
|
-
class ModuleRegistry {
|
|
756
|
-
// Defensive default: modulePackages may be undefined during circular imports
|
|
757
|
-
constructor(packages = Array.isArray(modulePackages)
|
|
758
|
-
? modulePackages
|
|
759
|
-
: []) {
|
|
760
|
-
this.packages = packages;
|
|
761
|
-
}
|
|
762
|
-
listPackages() {
|
|
763
|
-
return this.packages;
|
|
764
|
-
}
|
|
765
|
-
listPrompts() {
|
|
766
|
-
return this.collectAssets("prompts");
|
|
767
|
-
}
|
|
768
|
-
listResources() {
|
|
769
|
-
return this.collectAssets("resources");
|
|
770
|
-
}
|
|
771
|
-
listTemplates() {
|
|
772
|
-
return this.collectAssets("templates");
|
|
773
|
-
}
|
|
774
|
-
listTools() {
|
|
775
|
-
return this.collectAssets("tools");
|
|
776
|
-
}
|
|
777
|
-
collectAssets(key) {
|
|
778
|
-
const seen = new Map();
|
|
779
|
-
const aggregated = [];
|
|
780
|
-
for (const pkg of this.packages) {
|
|
781
|
-
if (pkg.status === "disabled")
|
|
782
|
-
continue;
|
|
783
|
-
for (const asset of pkg[key]) {
|
|
784
|
-
// asset.name is not guaranteed on all asset types; use type-safe fallback
|
|
785
|
-
const maybeName = asset.name;
|
|
786
|
-
const assetKey = (asset && (asset.id ?? maybeName)) || JSON.stringify(asset);
|
|
787
|
-
if (seen.has(assetKey)) {
|
|
788
|
-
const conflict = seen.get(assetKey);
|
|
789
|
-
throw new Error(`Duplicate ${key} id '${assetKey}' from modules ${conflict} and ${pkg.name}`);
|
|
790
|
-
}
|
|
791
|
-
seen.set(assetKey, pkg.name);
|
|
792
|
-
aggregated.push({ ...asset, provenance: pkg.name });
|
|
793
|
-
}
|
|
794
|
-
}
|
|
795
|
-
return aggregated;
|
|
796
|
-
}
|
|
575
|
+
function collectPromptSections(names) {
|
|
576
|
+
const root = getWorkspaceRoot();
|
|
577
|
+
const promptIndex = new Map(discoverDocPrompts(root).map((prompt) => [prompt.name, prompt]));
|
|
578
|
+
return names
|
|
579
|
+
.map((name) => promptIndex.get(name))
|
|
580
|
+
.filter((prompt) => Boolean(prompt))
|
|
581
|
+
.map((prompt) => ({
|
|
582
|
+
name: prompt.name,
|
|
583
|
+
title: prompt.title,
|
|
584
|
+
description: prompt.description,
|
|
585
|
+
content: prompt.content,
|
|
586
|
+
absolutePath: prompt.absolutePath,
|
|
587
|
+
}));
|
|
797
588
|
}
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
file: ["doc", "file"],
|
|
804
|
-
class: ["doc", "class"],
|
|
805
|
-
function: ["doc", "function"],
|
|
806
|
-
interface: ["doc", "interface"],
|
|
807
|
-
decorator: ["doc", "decorator"],
|
|
808
|
-
constant: ["doc", "constant"],
|
|
809
|
-
"bulk-docs": ["bulk-docs"],
|
|
810
|
-
"bulk-tests": ["bulk-tests"],
|
|
811
|
-
"update-readme": ["update-readme"],
|
|
812
|
-
"repo-setup": ["repo-setup"],
|
|
813
|
-
"release-notes": ["release-notes"],
|
|
814
|
-
"mcp-module": ["mcp-module"],
|
|
815
|
-
};
|
|
816
|
-
function getObjectPromptDependencies() {
|
|
817
|
-
return OBJECT_PROMPT_DEPENDENCIES;
|
|
589
|
+
function parseTaskLines(content) {
|
|
590
|
+
return content
|
|
591
|
+
.split(/\r?\n/)
|
|
592
|
+
.map((line) => line.trim())
|
|
593
|
+
.filter((line) => /^task\s+\d+/i.test(line));
|
|
818
594
|
}
|
|
819
|
-
function
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
595
|
+
function computeCoverageFromFinal(coveragePath) {
|
|
596
|
+
const payload = JSON.parse(fs__default.readFileSync(coveragePath, "utf8"));
|
|
597
|
+
const totals = {
|
|
598
|
+
statements: { covered: 0, total: 0 },
|
|
599
|
+
functions: { covered: 0, total: 0 },
|
|
600
|
+
branches: { covered: 0, total: 0 },
|
|
601
|
+
};
|
|
602
|
+
const files = Object.entries(payload).map(([filePath, info]) => {
|
|
603
|
+
const statementCounts = Object.values(info.s);
|
|
604
|
+
const functionCounts = Object.values(info.f);
|
|
605
|
+
const branchCounts = Object.values(info.b).flatMap((value) => Array.isArray(value) ? value : [value]);
|
|
606
|
+
const statementTotal = statementCounts.length;
|
|
607
|
+
const functionTotal = functionCounts.length;
|
|
608
|
+
const branchTotal = branchCounts.length;
|
|
609
|
+
const statementCovered = statementCounts.filter((count) => count > 0).length;
|
|
610
|
+
const functionCovered = functionCounts.filter((count) => count > 0).length;
|
|
611
|
+
const branchCovered = branchCounts.filter((count) => count > 0).length;
|
|
612
|
+
totals.statements.covered += statementCovered;
|
|
613
|
+
totals.statements.total += statementTotal;
|
|
614
|
+
totals.functions.covered += functionCovered;
|
|
615
|
+
totals.functions.total += functionTotal;
|
|
616
|
+
totals.branches.covered += branchCovered;
|
|
617
|
+
totals.branches.total += branchTotal;
|
|
618
|
+
const pct = (covered, total) => total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));
|
|
619
|
+
return {
|
|
620
|
+
path: filePath,
|
|
621
|
+
statements: pct(statementCovered, statementTotal),
|
|
622
|
+
functions: pct(functionCovered, functionTotal),
|
|
623
|
+
branches: pct(branchCovered, branchTotal),
|
|
624
|
+
};
|
|
625
|
+
});
|
|
626
|
+
const pct = (covered, total) => total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));
|
|
627
|
+
return {
|
|
628
|
+
totals: {
|
|
629
|
+
statements: {
|
|
630
|
+
...totals.statements,
|
|
631
|
+
pct: pct(totals.statements.covered, totals.statements.total),
|
|
632
|
+
},
|
|
633
|
+
functions: {
|
|
634
|
+
...totals.functions,
|
|
635
|
+
pct: pct(totals.functions.covered, totals.functions.total),
|
|
636
|
+
},
|
|
637
|
+
branches: {
|
|
638
|
+
...totals.branches,
|
|
639
|
+
pct: pct(totals.branches.covered, totals.branches.total),
|
|
640
|
+
},
|
|
825
641
|
},
|
|
826
|
-
|
|
642
|
+
files,
|
|
643
|
+
};
|
|
827
644
|
}
|
|
828
|
-
function
|
|
829
|
-
|
|
830
|
-
|
|
831
|
-
|
|
832
|
-
|
|
833
|
-
|
|
834
|
-
}));
|
|
835
|
-
const integrationPrompts = CLIENT_INTEGRATIONS.map((integration) => ({
|
|
836
|
-
name: `integration/${integration.id}`,
|
|
837
|
-
description: `${integration.display} integration guidance`,
|
|
838
|
-
load: async () => `You are coordinating with ${integration.display}. ${integration.instructions}\n\nTools available:\n- document-code\n- apply-code-change\n\nEnsure responses include actionable steps for the client.`,
|
|
645
|
+
function normalizePromptSections(sections) {
|
|
646
|
+
return sections.map((section) => ({
|
|
647
|
+
name: section.name,
|
|
648
|
+
title: section.title,
|
|
649
|
+
tasks: parseTaskLines(section.content),
|
|
650
|
+
content: section.content,
|
|
839
651
|
}));
|
|
840
|
-
return [...fileBasedPrompts, ...integrationPrompts];
|
|
841
|
-
}
|
|
842
|
-
function summarizePromptContent(prompt, headingPrefix) {
|
|
843
|
-
return [`## ${headingPrefix}`, "", prompt.content.trim()].join("\n");
|
|
844
652
|
}
|
|
845
|
-
function
|
|
653
|
+
async function resolveRepoRoot(basePath) {
|
|
846
654
|
const root = getWorkspaceRoot();
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
for (const prompt of discovered) {
|
|
850
|
-
promptByName.set(prompt.name, prompt);
|
|
655
|
+
try {
|
|
656
|
+
return resolveInWorkspace(root, basePath);
|
|
851
657
|
}
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
if (!existing.length)
|
|
858
|
-
continue;
|
|
859
|
-
outputs.push({
|
|
860
|
-
name: `codex/${objectType}`,
|
|
861
|
-
description: `Guidance derived from .codex prompts for ${objectType} tasks.`,
|
|
862
|
-
load: async () => {
|
|
863
|
-
const sections = existing.map((prompt) => summarizePromptContent(prompt, toTitleCase(prompt.name)));
|
|
864
|
-
return [`# Codex guidance for ${objectType}`, "", ...sections].join("\n");
|
|
865
|
-
},
|
|
866
|
-
});
|
|
658
|
+
catch (error) {
|
|
659
|
+
if (error instanceof WorkspaceError) {
|
|
660
|
+
await throwUserError(error.message);
|
|
661
|
+
}
|
|
662
|
+
throw error;
|
|
867
663
|
}
|
|
868
|
-
return outputs.sort((a, b) => a.name.localeCompare(b.name));
|
|
869
|
-
}
|
|
870
|
-
function toInputPrompt(asset) {
|
|
871
|
-
const provenance = asset.provenance ? ` (module: ${asset.provenance})` : "";
|
|
872
|
-
return {
|
|
873
|
-
name: asset.id,
|
|
874
|
-
description: `${asset.description ?? asset.title}${provenance}`,
|
|
875
|
-
load: async () => asset.load(),
|
|
876
|
-
};
|
|
877
|
-
}
|
|
878
|
-
function buildModulePrompts() {
|
|
879
|
-
return moduleRegistry.listPrompts().map(toInputPrompt);
|
|
880
|
-
}
|
|
881
|
-
function refreshPrompts(repoPath) {
|
|
882
|
-
const docPrompts = buildDocPrompts();
|
|
883
|
-
const objectPrompts = buildObjectPrompts();
|
|
884
|
-
const repoPrompts = repoPath ? buildPrompts(repoPath) : [];
|
|
885
|
-
const modulePrompts = buildModulePrompts();
|
|
886
|
-
prompts.splice(0, prompts.length, ...docPrompts, ...objectPrompts, ...repoPrompts, ...modulePrompts);
|
|
887
|
-
return prompts;
|
|
888
664
|
}
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
for
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
665
|
+
const documentObjectTool = {
|
|
666
|
+
name: "document-object",
|
|
667
|
+
description: "Create a documentation plan for a specific object type using .codex prompts and repository analysis.",
|
|
668
|
+
parameters: documentObjectSchema,
|
|
669
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
670
|
+
execute: async (input, _context) => {
|
|
671
|
+
const args = documentObjectSchema.parse(input);
|
|
672
|
+
const repoRoot = await resolveRepoRoot(args.basePath);
|
|
673
|
+
const dependencies = getObjectPromptDependencies()[args.objectType] ?? [];
|
|
674
|
+
if (!dependencies.length) {
|
|
675
|
+
await throwUserError(`No prompt guidance configured for object type ${args.objectType}`);
|
|
897
676
|
}
|
|
898
|
-
|
|
899
|
-
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
}
|
|
677
|
+
const sections = normalizePromptSections(collectPromptSections(dependencies));
|
|
678
|
+
const srcDir = path__default.join(repoRoot, "src");
|
|
679
|
+
const testDir = path__default.join(repoRoot, "tests");
|
|
680
|
+
const sourceFiles = fs__default.existsSync(srcDir)
|
|
681
|
+
? listFilesRecursive(srcDir, isSourceFile)
|
|
682
|
+
: [];
|
|
683
|
+
const testFiles = fs__default.existsSync(testDir)
|
|
684
|
+
? listFilesRecursive(testDir, (file) => isSourceFile(file) && isTestFile(file))
|
|
685
|
+
: [];
|
|
686
|
+
let targetFileContent;
|
|
687
|
+
if (args.targetFile) {
|
|
688
|
+
try {
|
|
689
|
+
const absolute = resolveInWorkspace(repoRoot, args.targetFile);
|
|
690
|
+
targetFileContent = readFileSafe(absolute) ?? undefined;
|
|
691
|
+
}
|
|
692
|
+
catch (error) {
|
|
693
|
+
if (error instanceof WorkspaceError) {
|
|
694
|
+
await throwUserError(error.message);
|
|
695
|
+
}
|
|
696
|
+
throw error;
|
|
697
|
+
}
|
|
913
698
|
}
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
699
|
+
const payload = {
|
|
700
|
+
basePath: path__default.relative(getWorkspaceRoot(), repoRoot) || ".",
|
|
701
|
+
objectType: args.objectType,
|
|
702
|
+
targetFile: args.targetFile,
|
|
703
|
+
guidance: sections,
|
|
704
|
+
files: {
|
|
705
|
+
source: relativeFiles(repoRoot, sourceFiles),
|
|
706
|
+
tests: relativeFiles(repoRoot, testFiles),
|
|
707
|
+
},
|
|
708
|
+
targetFileContent: args.includeContent ? targetFileContent : undefined,
|
|
709
|
+
};
|
|
710
|
+
return {
|
|
711
|
+
content: [
|
|
712
|
+
{
|
|
713
|
+
type: "text",
|
|
714
|
+
text: JSON.stringify(payload, null, 2),
|
|
715
|
+
},
|
|
716
|
+
],
|
|
717
|
+
};
|
|
718
|
+
},
|
|
719
|
+
};
|
|
720
|
+
const coverageEnforcerTool = {
|
|
721
|
+
name: "ensure-test-coverage",
|
|
722
|
+
description: "Run the configured coverage command and report whether the target percentage is met, highlighting weak files.",
|
|
723
|
+
parameters: coverageTaskSchema,
|
|
724
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
725
|
+
execute: async (input, _context) => {
|
|
726
|
+
const args = coverageTaskSchema.parse(input);
|
|
727
|
+
const repoRoot = await resolveRepoRoot(args.basePath);
|
|
728
|
+
if (!args.dryRun) {
|
|
729
|
+
const env = {
|
|
730
|
+
...process.env,
|
|
731
|
+
USE_WATCHMAN: "false",
|
|
732
|
+
WATCHMAN_DISABLE: "1",
|
|
733
|
+
JEST_DISABLE_WATCHMAN: "1",
|
|
734
|
+
};
|
|
735
|
+
const result = spawnSync("npm", ["run", "coverage", "--", "--watchman=false", "--runInBand"], { cwd: repoRoot, env, encoding: "utf8" });
|
|
736
|
+
if (result.status !== 0) {
|
|
737
|
+
const message = result.stderr || result.stdout || "Coverage command failed";
|
|
738
|
+
await throwUserError(message.trim());
|
|
739
|
+
}
|
|
919
740
|
}
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
}
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
}
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
741
|
+
const coveragePath = path__default.join(repoRoot, "workdocs", "reports", "coverage", "coverage-final.json");
|
|
742
|
+
if (!fs__default.existsSync(coveragePath)) {
|
|
743
|
+
await throwUserError(`Coverage report not found at ${path__default.relative(repoRoot, coveragePath)}`);
|
|
744
|
+
}
|
|
745
|
+
const summary = computeCoverageFromFinal(coveragePath);
|
|
746
|
+
const meetsThreshold = summary.totals.statements.pct >= args.coverage &&
|
|
747
|
+
summary.totals.functions.pct >= args.coverage &&
|
|
748
|
+
summary.totals.branches.pct >= args.coverage;
|
|
749
|
+
const weakest = [...summary.files]
|
|
750
|
+
.sort((a, b) => a.statements - b.statements)
|
|
751
|
+
.slice(0, 10);
|
|
752
|
+
const guidance = normalizePromptSections(collectPromptSections(["bulk-tests"]));
|
|
753
|
+
const payload = {
|
|
754
|
+
basePath: path__default.relative(getWorkspaceRoot(), repoRoot) || ".",
|
|
755
|
+
target: args.coverage,
|
|
756
|
+
meetsThreshold,
|
|
757
|
+
totals: summary.totals,
|
|
758
|
+
weakest,
|
|
759
|
+
guidance,
|
|
760
|
+
};
|
|
761
|
+
return {
|
|
762
|
+
content: [
|
|
763
|
+
{
|
|
764
|
+
type: "text",
|
|
765
|
+
text: JSON.stringify(payload, null, 2),
|
|
766
|
+
},
|
|
767
|
+
],
|
|
768
|
+
};
|
|
769
|
+
},
|
|
770
|
+
};
|
|
771
|
+
const readmeImprovementTool = {
|
|
772
|
+
name: "improve-readme",
|
|
773
|
+
description: "Summarize required steps to refresh README and workdocs content using .codex guidance and repository analysis.",
|
|
774
|
+
parameters: readmeImprovementSchema,
|
|
775
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
776
|
+
execute: async (input, _context) => {
|
|
777
|
+
const args = readmeImprovementSchema.parse(input);
|
|
778
|
+
const repoRoot = await resolveRepoRoot(args.basePath);
|
|
779
|
+
const analysis = analyzeRepo(repoRoot);
|
|
780
|
+
const modules = analysis.files
|
|
781
|
+
.filter((file) => /index\.ts$/.test(file))
|
|
782
|
+
.map((file) => path__default.relative(repoRoot, file));
|
|
783
|
+
const promptSections = normalizePromptSections(collectPromptSections(["update-readme", "doc", "module"]));
|
|
784
|
+
const testExamples = Object.keys(analysis.tests ?? {});
|
|
785
|
+
const examples = args.includeExamples ? testExamples.slice(0, 20) : [];
|
|
786
|
+
const payload = {
|
|
787
|
+
basePath: path__default.relative(getWorkspaceRoot(), repoRoot) || ".",
|
|
788
|
+
summary: {
|
|
789
|
+
modules,
|
|
790
|
+
totalSourceFiles: analysis.files.length,
|
|
791
|
+
totalTestFiles: analysis.testFiles.length,
|
|
792
|
+
hasReadme: Boolean(analysis.readme),
|
|
954
793
|
},
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
}
|
|
958
|
-
|
|
959
|
-
|
|
960
|
-
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
965
|
-
}
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
.split(/\s+/)
|
|
969
|
-
.filter(Boolean)
|
|
970
|
-
.map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())
|
|
971
|
-
.join(" ");
|
|
972
|
-
}
|
|
973
|
-
function inferLanguageFromPath(filePath) {
|
|
974
|
-
const extension = path.extname(filePath).toLowerCase();
|
|
975
|
-
switch (extension) {
|
|
976
|
-
case ".ts":
|
|
977
|
-
case ".tsx":
|
|
978
|
-
return "ts";
|
|
979
|
-
case ".js":
|
|
980
|
-
case ".jsx":
|
|
981
|
-
return "js";
|
|
982
|
-
case ".json":
|
|
983
|
-
return "json";
|
|
984
|
-
case ".md":
|
|
985
|
-
return "md";
|
|
986
|
-
default:
|
|
987
|
-
return "text";
|
|
988
|
-
}
|
|
989
|
-
}
|
|
990
|
-
|
|
991
|
-
const promptList = prompts;
|
|
992
|
-
function loadPrompts(repoPath) {
|
|
993
|
-
return refreshPrompts(repoPath);
|
|
994
|
-
}
|
|
794
|
+
guidance: promptSections,
|
|
795
|
+
suggestedExamples: examples,
|
|
796
|
+
};
|
|
797
|
+
return {
|
|
798
|
+
content: [
|
|
799
|
+
{
|
|
800
|
+
type: "text",
|
|
801
|
+
text: JSON.stringify(payload, null, 2),
|
|
802
|
+
},
|
|
803
|
+
],
|
|
804
|
+
};
|
|
805
|
+
},
|
|
806
|
+
};
|
|
995
807
|
|
|
996
808
|
function escapeRegExp(value) {
|
|
997
809
|
return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|
@@ -1001,7 +813,7 @@ function formatDecorator(spec) {
|
|
|
1001
813
|
return `@${spec.name}(${args})`;
|
|
1002
814
|
}
|
|
1003
815
|
function ensureDirectory(filePath) {
|
|
1004
|
-
|
|
816
|
+
fs__default.mkdirSync(path__default.dirname(filePath), { recursive: true });
|
|
1005
817
|
}
|
|
1006
818
|
function collectDecoratorNames(classDecorators, properties) {
|
|
1007
819
|
const names = new Set();
|
|
@@ -1092,14 +904,14 @@ function removeDecorator(content, decoratorName, target) {
|
|
|
1092
904
|
}
|
|
1093
905
|
function writeIfChanged(filePath, content) {
|
|
1094
906
|
ensureDirectory(filePath);
|
|
1095
|
-
|
|
907
|
+
fs__default.writeFileSync(filePath, content);
|
|
1096
908
|
}
|
|
1097
909
|
const decoratorTools = {
|
|
1098
910
|
createOrUpdateModelTool: {
|
|
1099
911
|
name: "create-or-update-model",
|
|
1100
912
|
description: "Create or update a validation-ready model class",
|
|
1101
913
|
execute: async (args) => {
|
|
1102
|
-
if (!args.overwrite &&
|
|
914
|
+
if (!args.overwrite && fs__default.existsSync(args.filePath)) {
|
|
1103
915
|
throw new Error(`File already exists at ${args.filePath}`);
|
|
1104
916
|
}
|
|
1105
917
|
const decorators = collectDecoratorNames(args.classDecorators, args.properties);
|
|
@@ -1120,10 +932,10 @@ const decoratorTools = {
|
|
|
1120
932
|
name: "add-attribute",
|
|
1121
933
|
description: "Add a decorated attribute to an existing model",
|
|
1122
934
|
execute: async (args) => {
|
|
1123
|
-
if (!
|
|
935
|
+
if (!fs__default.existsSync(args.filePath)) {
|
|
1124
936
|
throw new Error(`Model file not found at ${args.filePath}`);
|
|
1125
937
|
}
|
|
1126
|
-
let content =
|
|
938
|
+
let content = fs__default.readFileSync(args.filePath, "utf8");
|
|
1127
939
|
if (content.includes(`${args.attribute.name}:`)) {
|
|
1128
940
|
return { filePath: args.filePath };
|
|
1129
941
|
}
|
|
@@ -1142,9 +954,9 @@ const decoratorTools = {
|
|
|
1142
954
|
name: "remove-attribute",
|
|
1143
955
|
description: "Remove an attribute from a model class",
|
|
1144
956
|
execute: async (args) => {
|
|
1145
|
-
if (!
|
|
957
|
+
if (!fs__default.existsSync(args.filePath))
|
|
1146
958
|
return { filePath: args.filePath };
|
|
1147
|
-
const content =
|
|
959
|
+
const content = fs__default.readFileSync(args.filePath, "utf8");
|
|
1148
960
|
const updated = removePropertyBlock(content, args.attributeName);
|
|
1149
961
|
writeIfChanged(args.filePath, updated);
|
|
1150
962
|
return { filePath: args.filePath };
|
|
@@ -1154,10 +966,10 @@ const decoratorTools = {
|
|
|
1154
966
|
name: "apply-decorator",
|
|
1155
967
|
description: "Apply a decorator to a class or property",
|
|
1156
968
|
execute: async (args) => {
|
|
1157
|
-
if (!
|
|
969
|
+
if (!fs__default.existsSync(args.filePath)) {
|
|
1158
970
|
throw new Error(`Model file not found at ${args.filePath}`);
|
|
1159
971
|
}
|
|
1160
|
-
let content =
|
|
972
|
+
let content = fs__default.readFileSync(args.filePath, "utf8");
|
|
1161
973
|
const decorators = new Set([args.decorator.name]);
|
|
1162
974
|
content = ensureImport(content, args.importsFrom, decorators);
|
|
1163
975
|
content = insertDecorator(content, args.decorator, args.target);
|
|
@@ -1169,9 +981,9 @@ const decoratorTools = {
|
|
|
1169
981
|
name: "remove-decorator",
|
|
1170
982
|
description: "Remove a decorator from a class or property",
|
|
1171
983
|
execute: async (args) => {
|
|
1172
|
-
if (!
|
|
984
|
+
if (!fs__default.existsSync(args.filePath))
|
|
1173
985
|
return { filePath: args.filePath };
|
|
1174
|
-
let content =
|
|
986
|
+
let content = fs__default.readFileSync(args.filePath, "utf8");
|
|
1175
987
|
content = removeDecorator(content, args.decoratorName, args.target);
|
|
1176
988
|
writeIfChanged(args.filePath, content);
|
|
1177
989
|
return { filePath: args.filePath };
|
|
@@ -1181,15 +993,15 @@ const decoratorTools = {
|
|
|
1181
993
|
name: "scaffold-validator",
|
|
1182
994
|
description: "Scaffold a validator class and optional decorator",
|
|
1183
995
|
execute: async (args) => {
|
|
1184
|
-
const classFile =
|
|
996
|
+
const classFile = path__default.join(args.validatorsDir, `${args.name}.ts`);
|
|
1185
997
|
ensureDirectory(classFile);
|
|
1186
998
|
const classContent = `export class ${args.name} {\n validate(value: unknown): boolean {\n return value !== undefined;\n }\n}\n`;
|
|
1187
|
-
|
|
999
|
+
fs__default.writeFileSync(classFile, classContent);
|
|
1188
1000
|
let decoratorFile;
|
|
1189
1001
|
if (args.decoratorDir) {
|
|
1190
|
-
decoratorFile =
|
|
1002
|
+
decoratorFile = path__default.join(args.decoratorDir, `${args.name}Decorator.ts`);
|
|
1191
1003
|
ensureDirectory(decoratorFile);
|
|
1192
|
-
|
|
1004
|
+
fs__default.writeFileSync(decoratorFile, `export function ${args.name}Decorator() {\n return () => void 0;\n}\n`);
|
|
1193
1005
|
}
|
|
1194
1006
|
return { classFile, decoratorFile };
|
|
1195
1007
|
},
|
|
@@ -1198,14 +1010,14 @@ const decoratorTools = {
|
|
|
1198
1010
|
name: "scaffold-serializer",
|
|
1199
1011
|
description: "Scaffold a serializer class and optional registry",
|
|
1200
1012
|
execute: async (args) => {
|
|
1201
|
-
const classFile =
|
|
1013
|
+
const classFile = path__default.join(args.dir, `${args.name}.ts`);
|
|
1202
1014
|
ensureDirectory(classFile);
|
|
1203
|
-
|
|
1015
|
+
fs__default.writeFileSync(classFile, `export class ${args.name} {\n serialize(value: unknown): string {\n return JSON.stringify(value);\n }\n}\n`);
|
|
1204
1016
|
let registerFile;
|
|
1205
1017
|
if (args.registerDir) {
|
|
1206
|
-
registerFile =
|
|
1018
|
+
registerFile = path__default.join(args.registerDir, `${args.name}Register.ts`);
|
|
1207
1019
|
ensureDirectory(registerFile);
|
|
1208
|
-
|
|
1020
|
+
fs__default.writeFileSync(registerFile, `export function register${args.name}() {\n return ${args.setDefault ? "'default'" : "'optional'"};\n}\n`);
|
|
1209
1021
|
}
|
|
1210
1022
|
return { classFile, registerFile };
|
|
1211
1023
|
},
|
|
@@ -1214,355 +1026,296 @@ const decoratorTools = {
|
|
|
1214
1026
|
name: "scaffold-hashing",
|
|
1215
1027
|
description: "Scaffold a hashing function and optional registry",
|
|
1216
1028
|
execute: async (args) => {
|
|
1217
|
-
const functionFile =
|
|
1029
|
+
const functionFile = path__default.join(args.dir, `${args.name}.ts`);
|
|
1218
1030
|
ensureDirectory(functionFile);
|
|
1219
|
-
|
|
1031
|
+
fs__default.writeFileSync(functionFile, `export function ${args.name}(value: string): string {\n return value.split('').reverse().join('');\n}\n`);
|
|
1220
1032
|
let registerFile;
|
|
1221
1033
|
if (args.registerDir) {
|
|
1222
|
-
registerFile =
|
|
1034
|
+
registerFile = path__default.join(args.registerDir, `${args.name}Register.ts`);
|
|
1223
1035
|
ensureDirectory(registerFile);
|
|
1224
|
-
|
|
1036
|
+
fs__default.writeFileSync(registerFile, `export function register${args.name}() {\n return ${args.setDefault ? "'default'" : "'optional'"};\n}\n`);
|
|
1225
1037
|
}
|
|
1226
1038
|
return { functionFile, registerFile };
|
|
1227
1039
|
},
|
|
1228
1040
|
},
|
|
1229
1041
|
};
|
|
1230
1042
|
|
|
1231
|
-
function
|
|
1232
|
-
return
|
|
1233
|
-
|
|
1234
|
-
|
|
1235
|
-
|
|
1236
|
-
|
|
1237
|
-
|
|
1238
|
-
|
|
1239
|
-
|
|
1240
|
-
|
|
1241
|
-
|
|
1242
|
-
|
|
1243
|
-
|
|
1244
|
-
|
|
1245
|
-
|
|
1246
|
-
|
|
1247
|
-
|
|
1248
|
-
|
|
1249
|
-
|
|
1250
|
-
|
|
1251
|
-
|
|
1252
|
-
|
|
1043
|
+
function buildAnalyzeRepositoryTool() {
|
|
1044
|
+
return {
|
|
1045
|
+
name: "analyze-repository",
|
|
1046
|
+
description: "Analyze a local repository's source, tests, and docs to extract exported APIs, decorators, and test mentions.",
|
|
1047
|
+
parameters: analyzeRepoSchema,
|
|
1048
|
+
execute: async (input) => {
|
|
1049
|
+
let repoRoot = path__default.resolve(process.cwd(), input.repoPath);
|
|
1050
|
+
if (!fs__default.existsSync(repoRoot)) {
|
|
1051
|
+
// try resolving from monorepo root (parent of current cwd)
|
|
1052
|
+
const alt = path__default.resolve(process.cwd(), "..", input.repoPath);
|
|
1053
|
+
if (fs__default.existsSync(alt))
|
|
1054
|
+
repoRoot = alt;
|
|
1055
|
+
}
|
|
1056
|
+
if (!fs__default.existsSync(repoRoot)) {
|
|
1057
|
+
// if input was absolute and still not found, try ../<basename>
|
|
1058
|
+
const alt2 = path__default.resolve(process.cwd(), "..", path__default.basename(input.repoPath));
|
|
1059
|
+
if (fs__default.existsSync(alt2))
|
|
1060
|
+
repoRoot = alt2;
|
|
1061
|
+
}
|
|
1062
|
+
if (!fs__default.existsSync(repoRoot))
|
|
1063
|
+
throw new Error(`Repository not found at ${repoRoot}`);
|
|
1064
|
+
const result = analyzeRepo(repoRoot);
|
|
1065
|
+
return {
|
|
1066
|
+
content: [{ type: "text", text: JSON.stringify(result, null, 2) }],
|
|
1067
|
+
};
|
|
1068
|
+
},
|
|
1069
|
+
};
|
|
1253
1070
|
}
|
|
1254
|
-
function
|
|
1255
|
-
|
|
1256
|
-
|
|
1257
|
-
|
|
1258
|
-
|
|
1259
|
-
|
|
1071
|
+
function buildEnumerateCapabilitiesTool() {
|
|
1072
|
+
return {
|
|
1073
|
+
name: "enumerate-capabilities",
|
|
1074
|
+
description: "Enumerate developer-facing capabilities of the given repository, inferred from code, tests, and docs.",
|
|
1075
|
+
parameters: enumerateCapabilitiesSchema,
|
|
1076
|
+
execute: async (input) => {
|
|
1077
|
+
let repoRoot = path__default.resolve(process.cwd(), input.repoPath);
|
|
1078
|
+
if (!fs__default.existsSync(repoRoot)) {
|
|
1079
|
+
const alt = path__default.resolve(process.cwd(), "..", input.repoPath);
|
|
1080
|
+
if (fs__default.existsSync(alt))
|
|
1081
|
+
repoRoot = alt;
|
|
1082
|
+
}
|
|
1083
|
+
if (!fs__default.existsSync(repoRoot)) {
|
|
1084
|
+
const alt2 = path__default.resolve(process.cwd(), "..", path__default.basename(input.repoPath));
|
|
1085
|
+
if (fs__default.existsSync(alt2))
|
|
1086
|
+
repoRoot = alt2;
|
|
1087
|
+
}
|
|
1088
|
+
if (!fs__default.existsSync(repoRoot))
|
|
1089
|
+
throw new Error(`Repository not found at ${repoRoot}`);
|
|
1090
|
+
const analysis = analyzeRepo(repoRoot);
|
|
1091
|
+
const capabilities = deriveCapabilities(analysis);
|
|
1092
|
+
return {
|
|
1093
|
+
content: [
|
|
1094
|
+
{
|
|
1095
|
+
type: "text",
|
|
1096
|
+
text: JSON.stringify({
|
|
1097
|
+
capabilities,
|
|
1098
|
+
analysisSummary: {
|
|
1099
|
+
files: analysis.files.length,
|
|
1100
|
+
testFiles: analysis.testFiles.length,
|
|
1101
|
+
readme: analysis.readme?.title,
|
|
1102
|
+
},
|
|
1103
|
+
}, null, 2),
|
|
1104
|
+
},
|
|
1105
|
+
],
|
|
1106
|
+
};
|
|
1107
|
+
},
|
|
1260
1108
|
};
|
|
1261
|
-
|
|
1262
|
-
|
|
1263
|
-
const functionCounts = Object.values(info.f);
|
|
1264
|
-
const branchCounts = Object.values(info.b).flatMap((value) => Array.isArray(value) ? value : [value]);
|
|
1265
|
-
const statementTotal = statementCounts.length;
|
|
1266
|
-
const functionTotal = functionCounts.length;
|
|
1267
|
-
const branchTotal = branchCounts.length;
|
|
1268
|
-
const statementCovered = statementCounts.filter((count) => count > 0).length;
|
|
1269
|
-
const functionCovered = functionCounts.filter((count) => count > 0).length;
|
|
1270
|
-
const branchCovered = branchCounts.filter((count) => count > 0).length;
|
|
1271
|
-
totals.statements.covered += statementCovered;
|
|
1272
|
-
totals.statements.total += statementTotal;
|
|
1273
|
-
totals.functions.covered += functionCovered;
|
|
1274
|
-
totals.functions.total += functionTotal;
|
|
1275
|
-
totals.branches.covered += branchCovered;
|
|
1276
|
-
totals.branches.total += branchTotal;
|
|
1277
|
-
const pct = (covered, total) => total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));
|
|
1278
|
-
return {
|
|
1279
|
-
path: filePath,
|
|
1280
|
-
statements: pct(statementCovered, statementTotal),
|
|
1281
|
-
functions: pct(functionCovered, functionTotal),
|
|
1282
|
-
branches: pct(branchCovered, branchTotal),
|
|
1283
|
-
};
|
|
1284
|
-
});
|
|
1285
|
-
const pct = (covered, total) => total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));
|
|
1109
|
+
}
|
|
1110
|
+
function buildPlanFeatureTool() {
|
|
1286
1111
|
return {
|
|
1287
|
-
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1295
|
-
|
|
1296
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
}
|
|
1112
|
+
name: "plan-feature-implementation",
|
|
1113
|
+
description: "Given a feature request, select appropriate MCP tools (including existing and new ones) and produce an execution plan.",
|
|
1114
|
+
parameters: planFeatureSchema,
|
|
1115
|
+
execute: async (input) => {
|
|
1116
|
+
const steps = [];
|
|
1117
|
+
let i = 1;
|
|
1118
|
+
steps.push({
|
|
1119
|
+
step: i++,
|
|
1120
|
+
action: "Analyze repository to enumerate APIs and decorators",
|
|
1121
|
+
tool: "analyze-repository",
|
|
1122
|
+
arguments: { repoPath: input.repoPath },
|
|
1123
|
+
rationale: "Understand available building blocks.",
|
|
1124
|
+
});
|
|
1125
|
+
steps.push({
|
|
1126
|
+
step: i++,
|
|
1127
|
+
action: "List capabilities expected for developers",
|
|
1128
|
+
tool: "enumerate-capabilities",
|
|
1129
|
+
arguments: { repoPath: input.repoPath },
|
|
1130
|
+
rationale: "Align the plan with supported capabilities.",
|
|
1131
|
+
});
|
|
1132
|
+
// Suggest existing generic tools from mcp-module
|
|
1133
|
+
steps.push({
|
|
1134
|
+
step: i++,
|
|
1135
|
+
action: "Select documentation prompt and gather relevant source file(s)",
|
|
1136
|
+
tool: "document-code",
|
|
1137
|
+
arguments: { filePath: "<target-file>" },
|
|
1138
|
+
rationale: "Provide context and instructions for changes.",
|
|
1139
|
+
});
|
|
1140
|
+
steps.push({
|
|
1141
|
+
step: i++,
|
|
1142
|
+
action: "Apply code changes using unified diff patch",
|
|
1143
|
+
tool: "apply-code-change",
|
|
1144
|
+
arguments: {
|
|
1145
|
+
filePath: "<target-file>",
|
|
1146
|
+
patch: "<unified-diff>",
|
|
1147
|
+
dryRun: true,
|
|
1148
|
+
},
|
|
1149
|
+
rationale: "Validate changes safely before committing.",
|
|
1150
|
+
});
|
|
1151
|
+
steps.push({
|
|
1152
|
+
step: i++,
|
|
1153
|
+
action: "Commit code changes",
|
|
1154
|
+
tool: "apply-code-change",
|
|
1155
|
+
arguments: {
|
|
1156
|
+
filePath: "<target-file>",
|
|
1157
|
+
patch: "<unified-diff>",
|
|
1158
|
+
dryRun: false,
|
|
1159
|
+
},
|
|
1160
|
+
rationale: "Persist the update.",
|
|
1161
|
+
});
|
|
1162
|
+
// If decoration-related terms present, suggest decorator tools
|
|
1163
|
+
if (/decorat|flavour|override|extend|builder/i.test(input.feature)) {
|
|
1164
|
+
steps.unshift({
|
|
1165
|
+
step: 0,
|
|
1166
|
+
action: "Use decorator tooling to insert/remove/modify decorators",
|
|
1167
|
+
tool: "decorator-tools",
|
|
1168
|
+
arguments: { action: "help" },
|
|
1169
|
+
rationale: "Leverage specialized utilities for decoration patterns.",
|
|
1170
|
+
});
|
|
1171
|
+
steps.forEach((s, idx) => (s.step = idx + 1));
|
|
1172
|
+
}
|
|
1173
|
+
return {
|
|
1174
|
+
content: [
|
|
1175
|
+
{
|
|
1176
|
+
type: "text",
|
|
1177
|
+
text: JSON.stringify({
|
|
1178
|
+
plan: steps,
|
|
1179
|
+
notes: "Replace placeholder arguments like <target-file> and <unified-diff> based on the analysis output.",
|
|
1180
|
+
}, null, 2),
|
|
1181
|
+
},
|
|
1182
|
+
],
|
|
1183
|
+
};
|
|
1300
1184
|
},
|
|
1301
|
-
files,
|
|
1302
1185
|
};
|
|
1303
1186
|
}
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
}
|
|
1311
|
-
|
|
1312
|
-
async function resolveRepoRoot(basePath) {
|
|
1313
|
-
const root = getWorkspaceRoot();
|
|
1314
|
-
try {
|
|
1315
|
-
return resolveInWorkspace(root, basePath);
|
|
1316
|
-
}
|
|
1317
|
-
catch (error) {
|
|
1318
|
-
if (error instanceof WorkspaceError) {
|
|
1319
|
-
await throwUserError(error.message);
|
|
1320
|
-
}
|
|
1321
|
-
throw error;
|
|
1322
|
-
}
|
|
1323
|
-
}
|
|
1324
|
-
const documentObjectTool = {
|
|
1325
|
-
name: "document-object",
|
|
1326
|
-
description: "Create a documentation plan for a specific object type using .codex prompts and repository analysis.",
|
|
1327
|
-
parameters: documentObjectSchema,
|
|
1187
|
+
const documentCodeTool = {
|
|
1188
|
+
annotations: {
|
|
1189
|
+
idempotentHint: true,
|
|
1190
|
+
openWorldHint: false,
|
|
1191
|
+
readOnlyHint: true,
|
|
1192
|
+
title: "Document Source File",
|
|
1193
|
+
},
|
|
1194
|
+
description: "Generate documentation guidance for a file by combining repository prompts with the target source code.",
|
|
1328
1195
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1329
1196
|
execute: async (input, _context) => {
|
|
1330
|
-
const args =
|
|
1331
|
-
const
|
|
1332
|
-
|
|
1333
|
-
|
|
1334
|
-
|
|
1197
|
+
const args = documentCodeSchema.parse(input);
|
|
1198
|
+
const root = getWorkspaceRoot();
|
|
1199
|
+
let filePath;
|
|
1200
|
+
try {
|
|
1201
|
+
filePath = resolveInWorkspace(root, args.filePath);
|
|
1335
1202
|
}
|
|
1336
|
-
|
|
1337
|
-
|
|
1338
|
-
|
|
1339
|
-
const sourceFiles = fs.existsSync(srcDir)
|
|
1340
|
-
? listFilesRecursive(srcDir, isSourceFile)
|
|
1341
|
-
: [];
|
|
1342
|
-
const testFiles = fs.existsSync(testDir)
|
|
1343
|
-
? listFilesRecursive(testDir, (file) => isSourceFile(file) && isTestFile(file))
|
|
1344
|
-
: [];
|
|
1345
|
-
let targetFileContent;
|
|
1346
|
-
if (args.targetFile) {
|
|
1347
|
-
try {
|
|
1348
|
-
const absolute = resolveInWorkspace(repoRoot, args.targetFile);
|
|
1349
|
-
targetFileContent = readFileSafe(absolute) ?? undefined;
|
|
1350
|
-
}
|
|
1351
|
-
catch (error) {
|
|
1352
|
-
if (error instanceof WorkspaceError) {
|
|
1353
|
-
await throwUserError(error.message);
|
|
1354
|
-
}
|
|
1355
|
-
throw error;
|
|
1203
|
+
catch (error) {
|
|
1204
|
+
if (error instanceof WorkspaceError) {
|
|
1205
|
+
return throwUserError(error.message);
|
|
1356
1206
|
}
|
|
1207
|
+
/* istanbul ignore next */
|
|
1208
|
+
throw error;
|
|
1357
1209
|
}
|
|
1358
|
-
|
|
1359
|
-
|
|
1360
|
-
|
|
1361
|
-
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
|
|
1368
|
-
|
|
1369
|
-
|
|
1370
|
-
|
|
1371
|
-
|
|
1372
|
-
|
|
1373
|
-
|
|
1374
|
-
|
|
1375
|
-
|
|
1376
|
-
|
|
1210
|
+
if (!fs__default.existsSync(filePath)) {
|
|
1211
|
+
return throwUserError(`Cannot document missing file at ${args.filePath}`);
|
|
1212
|
+
}
|
|
1213
|
+
const fileContent = fs__default.readFileSync(filePath, {
|
|
1214
|
+
encoding: args.encoding,
|
|
1215
|
+
});
|
|
1216
|
+
// dynamically import prompt helpers
|
|
1217
|
+
const promptMod = await Promise.resolve().then(function () { return prompts$1; });
|
|
1218
|
+
const { discoverDocPrompts, selectPrompt, DEFAULT_PROMPT_NAME, buildDocumentationPayload, } = promptMod;
|
|
1219
|
+
const prompts = discoverDocPrompts(root);
|
|
1220
|
+
if (!prompts.length) {
|
|
1221
|
+
return throwUserError("No documentation prompts found under .code/prompts or .codex/prompts");
|
|
1222
|
+
}
|
|
1223
|
+
const prompt = selectPrompt(prompts, args.promptName ?? DEFAULT_PROMPT_NAME);
|
|
1224
|
+
return buildDocumentationPayload({
|
|
1225
|
+
filePath: args.filePath,
|
|
1226
|
+
fileContent,
|
|
1227
|
+
prompt,
|
|
1228
|
+
includeCode: args.includeCode,
|
|
1229
|
+
includePrompt: args.includePrompt,
|
|
1230
|
+
includeMetadata: args.includeMetadata,
|
|
1231
|
+
additionalContext: args.additionalContext,
|
|
1232
|
+
});
|
|
1377
1233
|
},
|
|
1234
|
+
name: "document-code",
|
|
1235
|
+
parameters: documentCodeSchema,
|
|
1378
1236
|
};
|
|
1379
|
-
const
|
|
1380
|
-
|
|
1381
|
-
|
|
1382
|
-
|
|
1237
|
+
const applyCodeChangeTool = {
|
|
1238
|
+
annotations: {
|
|
1239
|
+
destructiveHint: true,
|
|
1240
|
+
idempotentHint: false,
|
|
1241
|
+
openWorldHint: false,
|
|
1242
|
+
readOnlyHint: false,
|
|
1243
|
+
title: "Apply Code Patch",
|
|
1244
|
+
},
|
|
1245
|
+
description: "Apply a unified diff patch to a workspace file with optional dry-run validation and diff preview.",
|
|
1383
1246
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1384
1247
|
execute: async (input, _context) => {
|
|
1385
|
-
const args =
|
|
1386
|
-
const
|
|
1387
|
-
|
|
1388
|
-
|
|
1389
|
-
|
|
1390
|
-
|
|
1391
|
-
|
|
1392
|
-
|
|
1393
|
-
|
|
1394
|
-
const result = spawnSync("npm", ["run", "coverage", "--", "--watchman=false", "--runInBand"], { cwd: repoRoot, env, encoding: "utf8" });
|
|
1395
|
-
if (result.status !== 0) {
|
|
1396
|
-
const message = result.stderr || result.stdout || "Coverage command failed";
|
|
1397
|
-
await throwUserError(message.trim());
|
|
1248
|
+
const args = codeChangeSchema.parse(input);
|
|
1249
|
+
const root = getWorkspaceRoot();
|
|
1250
|
+
let filePath;
|
|
1251
|
+
try {
|
|
1252
|
+
filePath = resolveInWorkspace(root, args.filePath);
|
|
1253
|
+
}
|
|
1254
|
+
catch (error) {
|
|
1255
|
+
if (error instanceof WorkspaceError) {
|
|
1256
|
+
return throwUserError(error.message);
|
|
1398
1257
|
}
|
|
1258
|
+
throw error;
|
|
1399
1259
|
}
|
|
1400
|
-
const
|
|
1401
|
-
|
|
1402
|
-
|
|
1260
|
+
const original = fs__default.existsSync(filePath)
|
|
1261
|
+
? fs__default.readFileSync(filePath, args.encoding)
|
|
1262
|
+
: "";
|
|
1263
|
+
let patched;
|
|
1264
|
+
try {
|
|
1265
|
+
patched = applyPatch(original, args.patch);
|
|
1403
1266
|
}
|
|
1404
|
-
|
|
1405
|
-
|
|
1406
|
-
|
|
1407
|
-
|
|
1408
|
-
|
|
1409
|
-
|
|
1410
|
-
|
|
1411
|
-
|
|
1412
|
-
|
|
1413
|
-
|
|
1414
|
-
|
|
1415
|
-
|
|
1416
|
-
|
|
1417
|
-
|
|
1418
|
-
|
|
1419
|
-
}
|
|
1267
|
+
catch (error) {
|
|
1268
|
+
return throwUserError(`Failed to apply provided patch to ${args.filePath}: ${error instanceof Error ? error.message : error}`);
|
|
1269
|
+
}
|
|
1270
|
+
/* istanbul ignore next */
|
|
1271
|
+
if (patched === false) {
|
|
1272
|
+
return throwUserError(`Failed to apply provided patch to ${args.filePath}`);
|
|
1273
|
+
}
|
|
1274
|
+
if (!args.dryRun) {
|
|
1275
|
+
fs__default.mkdirSync(path__default.dirname(filePath), { recursive: true });
|
|
1276
|
+
fs__default.writeFileSync(filePath, patched, {
|
|
1277
|
+
encoding: args.encoding,
|
|
1278
|
+
});
|
|
1279
|
+
}
|
|
1280
|
+
if (!args.showDiff) {
|
|
1281
|
+
return `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`;
|
|
1282
|
+
}
|
|
1283
|
+
const preview = createTwoFilesPatch(args.filePath, args.filePath, original, patched, undefined, undefined, { context: args.diffContext });
|
|
1420
1284
|
return {
|
|
1421
1285
|
content: [
|
|
1422
1286
|
{
|
|
1423
1287
|
type: "text",
|
|
1424
|
-
text:
|
|
1288
|
+
text: `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`,
|
|
1425
1289
|
},
|
|
1426
|
-
],
|
|
1427
|
-
};
|
|
1428
|
-
},
|
|
1429
|
-
};
|
|
1430
|
-
const readmeImprovementTool = {
|
|
1431
|
-
name: "improve-readme",
|
|
1432
|
-
description: "Summarize required steps to refresh README and workdocs content using .codex guidance and repository analysis.",
|
|
1433
|
-
parameters: readmeImprovementSchema,
|
|
1434
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
1435
|
-
execute: async (input, _context) => {
|
|
1436
|
-
const args = readmeImprovementSchema.parse(input);
|
|
1437
|
-
const repoRoot = await resolveRepoRoot(args.basePath);
|
|
1438
|
-
const analysis = analyzeRepo(repoRoot);
|
|
1439
|
-
const modules = analysis.files
|
|
1440
|
-
.filter((file) => /index\.ts$/.test(file))
|
|
1441
|
-
.map((file) => path.relative(repoRoot, file));
|
|
1442
|
-
const promptSections = normalizePromptSections(collectPromptSections(["update-readme", "doc", "module"]));
|
|
1443
|
-
const testExamples = Object.keys(analysis.tests ?? {});
|
|
1444
|
-
const examples = args.includeExamples ? testExamples.slice(0, 20) : [];
|
|
1445
|
-
const payload = {
|
|
1446
|
-
basePath: path.relative(getWorkspaceRoot(), repoRoot) || ".",
|
|
1447
|
-
summary: {
|
|
1448
|
-
modules,
|
|
1449
|
-
totalSourceFiles: analysis.files.length,
|
|
1450
|
-
totalTestFiles: analysis.testFiles.length,
|
|
1451
|
-
hasReadme: Boolean(analysis.readme),
|
|
1452
|
-
},
|
|
1453
|
-
guidance: promptSections,
|
|
1454
|
-
suggestedExamples: examples,
|
|
1455
|
-
};
|
|
1456
|
-
return {
|
|
1457
|
-
content: [
|
|
1458
1290
|
{
|
|
1459
1291
|
type: "text",
|
|
1460
|
-
text:
|
|
1292
|
+
text: ["```diff", preview.trim(), "```"].join("\n"),
|
|
1461
1293
|
},
|
|
1462
1294
|
],
|
|
1463
1295
|
};
|
|
1464
1296
|
},
|
|
1297
|
+
name: "apply-code-change",
|
|
1298
|
+
parameters: codeChangeSchema,
|
|
1465
1299
|
};
|
|
1466
|
-
|
|
1467
|
-
|
|
1468
|
-
|
|
1469
|
-
|
|
1470
|
-
|
|
1471
|
-
|
|
1472
|
-
|
|
1473
|
-
|
|
1474
|
-
|
|
1475
|
-
|
|
1476
|
-
] as const;
|
|
1477
|
-
`,
|
|
1478
|
-
resources: `export const resources = [
|
|
1479
|
-
{
|
|
1480
|
-
id: "example-resource",
|
|
1481
|
-
name: "Example Resource",
|
|
1482
|
-
description: "A placeholder resource created by scaffoldModule",
|
|
1483
|
-
uri: "file://placeholder",
|
|
1484
|
-
absolutePath: __filename,
|
|
1485
|
-
},
|
|
1486
|
-
] as const;
|
|
1487
|
-
`,
|
|
1488
|
-
templates: `export const templates = [
|
|
1489
|
-
{
|
|
1490
|
-
name: "example-template",
|
|
1491
|
-
description: "A placeholder template created by scaffoldModule",
|
|
1492
|
-
uriTemplate: "file://template/{path}",
|
|
1493
|
-
mimeType: "text/plain",
|
|
1494
|
-
},
|
|
1495
|
-
] as const;
|
|
1496
|
-
`,
|
|
1497
|
-
tools: `export const toolList = [
|
|
1498
|
-
{
|
|
1499
|
-
id: "example-tool",
|
|
1500
|
-
name: "example-tool",
|
|
1501
|
-
description: "A placeholder tool created by scaffoldModule",
|
|
1502
|
-
run: async () => ({ result: "placeholder" }),
|
|
1503
|
-
},
|
|
1504
|
-
] as const;
|
|
1505
|
-
`,
|
|
1506
|
-
};
|
|
1507
|
-
/**
|
|
1508
|
-
* Create a module scaffold under repoRoot/src/modules/<moduleName>
|
|
1509
|
-
* Returns created files list.
|
|
1510
|
-
*/
|
|
1511
|
-
function scaffoldModule(repoRoot, moduleName) {
|
|
1512
|
-
if (!repoRoot)
|
|
1513
|
-
throw new Error("repoRoot is required");
|
|
1514
|
-
if (!moduleName)
|
|
1515
|
-
throw new Error("moduleName is required");
|
|
1516
|
-
const modulePath = path.join(repoRoot, "src", "modules", moduleName);
|
|
1517
|
-
const createdFiles = [];
|
|
1518
|
-
const subfolders = ["prompts", "resources", "templates", "tools"];
|
|
1519
|
-
for (const folder of subfolders) {
|
|
1520
|
-
const folderPath = path.join(modulePath, folder);
|
|
1521
|
-
fs.mkdirSync(folderPath, { recursive: true });
|
|
1522
|
-
const indexPath = path.join(folderPath, "index.ts");
|
|
1523
|
-
// if file exists, skip writing
|
|
1524
|
-
if (!fs.existsSync(indexPath)) {
|
|
1525
|
-
// insert __filename for absolutePath in placeholders
|
|
1526
|
-
const content = DEFAULT_PLACEHOLDERS[folder].replace(/__filename/g, JSON.stringify(indexPath));
|
|
1527
|
-
fs.writeFileSync(indexPath, content, { encoding: "utf8" });
|
|
1528
|
-
createdFiles.push(indexPath);
|
|
1529
|
-
}
|
|
1530
|
-
}
|
|
1531
|
-
return { modulePath, createdFiles };
|
|
1532
|
-
}
|
|
1533
|
-
// CLI support when required directly via ts-node registration
|
|
1534
|
-
if (require.main === module) {
|
|
1535
|
-
const [, , moduleName] = process.argv;
|
|
1536
|
-
if (!moduleName) {
|
|
1537
|
-
console.error("Usage: scaffold-module <module-name>");
|
|
1538
|
-
process.exit(1);
|
|
1539
|
-
}
|
|
1540
|
-
try {
|
|
1541
|
-
const res = scaffoldModule(process.cwd(), moduleName);
|
|
1542
|
-
console.log("Scaffolded module:", res.modulePath);
|
|
1543
|
-
for (const f of res.createdFiles)
|
|
1544
|
-
console.log(" created:", f);
|
|
1545
|
-
process.exit(0);
|
|
1546
|
-
}
|
|
1547
|
-
catch (err) {
|
|
1548
|
-
console.error(err && err.message ? err.message : err);
|
|
1549
|
-
process.exit(2);
|
|
1550
|
-
}
|
|
1551
|
-
}
|
|
1552
|
-
|
|
1553
|
-
// New tool: generate-mcp-module
|
|
1554
|
-
z.object({
|
|
1555
|
-
repoPath: z.string().optional().default("."),
|
|
1556
|
-
moduleName: z.string().optional(),
|
|
1557
|
-
includeDocs: z.boolean().default(true),
|
|
1558
|
-
});
|
|
1300
|
+
const analyticTools = [
|
|
1301
|
+
buildAnalyzeRepositoryTool(),
|
|
1302
|
+
buildEnumerateCapabilitiesTool(),
|
|
1303
|
+
buildPlanFeatureTool(),
|
|
1304
|
+
];
|
|
1305
|
+
const toolList$1 = [
|
|
1306
|
+
...analyticTools,
|
|
1307
|
+
documentCodeTool,
|
|
1308
|
+
applyCodeChangeTool,
|
|
1309
|
+
];
|
|
1559
1310
|
|
|
1560
1311
|
const codexToolList = [
|
|
1561
1312
|
documentObjectTool,
|
|
1562
1313
|
coverageEnforcerTool,
|
|
1563
1314
|
readmeImprovementTool,
|
|
1564
1315
|
];
|
|
1565
|
-
const moduleToolList = moduleRegistry
|
|
1316
|
+
const moduleToolList = moduleRegistry
|
|
1317
|
+
.listTools()
|
|
1318
|
+
.map((asset) => asset.tool);
|
|
1566
1319
|
const toolList = [...toolList$1, ...codexToolList, ...moduleToolList];
|
|
1567
1320
|
const [analyzeRepositoryTool, enumerateCapabilitiesTool, planFeatureTool, documentCodeToolRef, applyCodeChangeToolRef,] = toolList$1;
|
|
1568
1321
|
const tools = {
|
|
@@ -1660,11 +1413,11 @@ function buildCodexPromptTemplates() {
|
|
|
1660
1413
|
},
|
|
1661
1414
|
],
|
|
1662
1415
|
load: async ({ name }) => {
|
|
1663
|
-
const promptPath = resolveInWorkspace(root,
|
|
1664
|
-
if (!
|
|
1416
|
+
const promptPath = resolveInWorkspace(root, path__default.join(".codex", "prompts", `${name}.md`));
|
|
1417
|
+
if (!fs__default.existsSync(promptPath)) {
|
|
1665
1418
|
throw new Error(`Prompt .codex/prompts/${name}.md not found`);
|
|
1666
1419
|
}
|
|
1667
|
-
const text =
|
|
1420
|
+
const text = fs__default.readFileSync(promptPath, "utf8");
|
|
1668
1421
|
return { text, uri: `codex-prompt:///${name}` };
|
|
1669
1422
|
},
|
|
1670
1423
|
},
|
|
@@ -1677,7 +1430,7 @@ const decorationResourceTemplates = [];
|
|
|
1677
1430
|
function makeLoader(type) {
|
|
1678
1431
|
return async ({ path: relative }) => {
|
|
1679
1432
|
const root = getWorkspaceRoot();
|
|
1680
|
-
const target =
|
|
1433
|
+
const target = path__default.join(type, relative);
|
|
1681
1434
|
const text = await readWorkspaceFile(root, target);
|
|
1682
1435
|
return { text };
|
|
1683
1436
|
};
|
|
@@ -1862,7 +1615,7 @@ const templateList = buildResourceTemplates();
|
|
|
1862
1615
|
* @summary The actual version number is replaced during the build process.
|
|
1863
1616
|
* @type {string}
|
|
1864
1617
|
*/
|
|
1865
|
-
const VERSION$1 = "0.
|
|
1618
|
+
const VERSION$1 = "0.4.1";
|
|
1866
1619
|
const PACKAGE_NAME$1 = "##PACKAGE_NAME##";
|
|
1867
1620
|
try {
|
|
1868
1621
|
Metadata.registerLibrary(PACKAGE_NAME$1, VERSION$1);
|
|
@@ -1900,14 +1653,14 @@ const VERSION = VERSION$1;
|
|
|
1900
1653
|
// New: validation entrypoint for module structure
|
|
1901
1654
|
const REQUIRED_SUBFOLDERS = ["prompts", "resources", "templates", "tools"];
|
|
1902
1655
|
function findModuleDirs(repoRoot) {
|
|
1903
|
-
const modulesPath =
|
|
1904
|
-
if (!
|
|
1656
|
+
const modulesPath = path__default.resolve(repoRoot, "src", "modules");
|
|
1657
|
+
if (!fs__default.existsSync(modulesPath) || !fs__default.statSync(modulesPath).isDirectory()) {
|
|
1905
1658
|
return [];
|
|
1906
1659
|
}
|
|
1907
|
-
return
|
|
1660
|
+
return fs__default
|
|
1908
1661
|
.readdirSync(modulesPath, { withFileTypes: true })
|
|
1909
1662
|
.filter((d) => d.isDirectory())
|
|
1910
|
-
.map((d) =>
|
|
1663
|
+
.map((d) => path__default.join(modulesPath, d.name));
|
|
1911
1664
|
}
|
|
1912
1665
|
function hasIndexExport(folderPath) {
|
|
1913
1666
|
const candidates = [
|
|
@@ -1918,7 +1671,7 @@ function hasIndexExport(folderPath) {
|
|
|
1918
1671
|
"index.mjs",
|
|
1919
1672
|
];
|
|
1920
1673
|
for (const c of candidates) {
|
|
1921
|
-
if (
|
|
1674
|
+
if (fs__default.existsSync(path__default.join(folderPath, c)))
|
|
1922
1675
|
return true;
|
|
1923
1676
|
}
|
|
1924
1677
|
return false;
|
|
@@ -1927,10 +1680,10 @@ function validateModules(repoRoot) {
|
|
|
1927
1680
|
const dirs = findModuleDirs(repoRoot);
|
|
1928
1681
|
const issues = [];
|
|
1929
1682
|
for (const moduleDir of dirs) {
|
|
1930
|
-
const moduleName =
|
|
1683
|
+
const moduleName = path__default.basename(moduleDir);
|
|
1931
1684
|
for (const sub of REQUIRED_SUBFOLDERS) {
|
|
1932
|
-
const subPath =
|
|
1933
|
-
if (!
|
|
1685
|
+
const subPath = path__default.join(moduleDir, sub);
|
|
1686
|
+
if (!fs__default.existsSync(subPath) || !fs__default.statSync(subPath).isDirectory()) {
|
|
1934
1687
|
issues.push({
|
|
1935
1688
|
module: moduleName,
|
|
1936
1689
|
path: subPath,
|
|
@@ -1953,7 +1706,7 @@ function validateModules(repoRoot) {
|
|
|
1953
1706
|
try {
|
|
1954
1707
|
const indexFile = candidatesFindingIndex(subPath);
|
|
1955
1708
|
if (indexFile) {
|
|
1956
|
-
const content =
|
|
1709
|
+
const content = fs__default.readFileSync(indexFile, "utf8");
|
|
1957
1710
|
// crude heuristics: look for `export const name = [` or `export const name: Type[] = [`,
|
|
1958
1711
|
// or any named export like `export { something }` which implies exports exist.
|
|
1959
1712
|
const exportListPattern = /export\s+(const|let|var)\s+[\w$]+(?:\s*:\s*[^=]+)?\s*=\s*\[/;
|
|
@@ -1963,7 +1716,7 @@ function validateModules(repoRoot) {
|
|
|
1963
1716
|
module: moduleName,
|
|
1964
1717
|
path: indexFile,
|
|
1965
1718
|
type: "empty-list",
|
|
1966
|
-
detail: `Index file does not appear to export a list of assets: ${
|
|
1719
|
+
detail: `Index file does not appear to export a list of assets: ${path__default.basename(indexFile)}`,
|
|
1967
1720
|
});
|
|
1968
1721
|
}
|
|
1969
1722
|
}
|
|
@@ -1993,8 +1746,8 @@ function candidatesFindingIndex(folderPath) {
|
|
|
1993
1746
|
"index.mjs",
|
|
1994
1747
|
];
|
|
1995
1748
|
for (const c of candidates) {
|
|
1996
|
-
const full =
|
|
1997
|
-
if (
|
|
1749
|
+
const full = path__default.join(folderPath, c);
|
|
1750
|
+
if (fs__default.existsSync(full))
|
|
1998
1751
|
return full;
|
|
1999
1752
|
}
|
|
2000
1753
|
return undefined;
|
|
@@ -2022,8 +1775,8 @@ const INDEX_CANDIDATES = [
|
|
|
2022
1775
|
];
|
|
2023
1776
|
function findIndexFile(folder) {
|
|
2024
1777
|
for (const c of INDEX_CANDIDATES) {
|
|
2025
|
-
const f =
|
|
2026
|
-
if (
|
|
1778
|
+
const f = path__default.join(folder, c);
|
|
1779
|
+
if (fs__default.existsSync(f))
|
|
2027
1780
|
return f;
|
|
2028
1781
|
}
|
|
2029
1782
|
return undefined;
|
|
@@ -2050,7 +1803,7 @@ function makeKeyForItem(item) {
|
|
|
2050
1803
|
async function loadArrayFromIndex(filePath) {
|
|
2051
1804
|
// Prefer a fast, static parse of the first array literal found in the file.
|
|
2052
1805
|
try {
|
|
2053
|
-
const content =
|
|
1806
|
+
const content = fs__default.readFileSync(filePath, "utf8");
|
|
2054
1807
|
const start = content.indexOf("[");
|
|
2055
1808
|
if (start !== -1) {
|
|
2056
1809
|
let depth = 0;
|
|
@@ -2133,9 +1886,9 @@ async function aggregateModules(repoRoot) {
|
|
|
2133
1886
|
tools: new Map(),
|
|
2134
1887
|
};
|
|
2135
1888
|
for (const moduleDir of dirs) {
|
|
2136
|
-
const moduleName =
|
|
1889
|
+
const moduleName = path__default.basename(moduleDir);
|
|
2137
1890
|
for (const sub of SUBFOLDERS) {
|
|
2138
|
-
const folder =
|
|
1891
|
+
const folder = path__default.join(moduleDir, sub);
|
|
2139
1892
|
const indexFile = findIndexFile(folder);
|
|
2140
1893
|
if (!indexFile)
|
|
2141
1894
|
continue;
|
|
@@ -2341,7 +2094,7 @@ class McpUtils {
|
|
|
2341
2094
|
*/
|
|
2342
2095
|
static getPackage(basePath) {
|
|
2343
2096
|
try {
|
|
2344
|
-
return JSON.parse(
|
|
2097
|
+
return JSON.parse(fs__default.readFileSync(path__default.join(basePath, "package.json"), "utf8"));
|
|
2345
2098
|
}
|
|
2346
2099
|
catch (e) {
|
|
2347
2100
|
throw new Error(`Unable to read version from ${basePath}: ${e}`);
|
|
@@ -2374,18 +2127,6 @@ class McpUtils {
|
|
|
2374
2127
|
* @description Utility class to handle CLI functionality from all Decaf modules
|
|
2375
2128
|
* @summary This class provides a wrapper around Commander.js to handle CLI commands from different Decaf modules.
|
|
2376
2129
|
* It crawls the filesystem to find CLI modules, loads them, and registers their commands.
|
|
2377
|
-
*
|
|
2378
|
-
* @param {string} [basePath] The base path to look for modules in. Defaults to `./`
|
|
2379
|
-
* @param {number} [crawlLevels] Number of folder levels to crawl to find modules from the basePath. Defaults to 4
|
|
2380
|
-
*
|
|
2381
|
-
* @example
|
|
2382
|
-
* // Create a new CLI wrapper and run it with custom options
|
|
2383
|
-
* const cli = new CliWrapper('./src', 2);
|
|
2384
|
-
* cli.run(process.argv).then(() => {
|
|
2385
|
-
* console.log('CLI commands executed successfully');
|
|
2386
|
-
* });
|
|
2387
|
-
*
|
|
2388
|
-
* @class McpWrapper
|
|
2389
2130
|
*/
|
|
2390
2131
|
class McpWrapper extends LoggedClass {
|
|
2391
2132
|
constructor(basePath = "./", crawlLevels = 4) {
|
|
@@ -2393,7 +2134,32 @@ class McpWrapper extends LoggedClass {
|
|
|
2393
2134
|
this.basePath = basePath;
|
|
2394
2135
|
this.crawlLevels = crawlLevels;
|
|
2395
2136
|
this.modules = {};
|
|
2396
|
-
|
|
2137
|
+
// Support both CommonJS and ESM runtimes for filename/dirname
|
|
2138
|
+
let localDirname;
|
|
2139
|
+
if (typeof __filename !== "undefined" && typeof __dirname !== "undefined") {
|
|
2140
|
+
// CommonJS environment
|
|
2141
|
+
localDirname = __dirname;
|
|
2142
|
+
}
|
|
2143
|
+
else {
|
|
2144
|
+
// ESM or other env: compute import.meta.url at runtime to avoid TS compile-time import.meta checks
|
|
2145
|
+
let metaUrl;
|
|
2146
|
+
try {
|
|
2147
|
+
// Use a dynamic function so TypeScript won't parse `import.meta` at compile time
|
|
2148
|
+
const fn = new Function('return (typeof import !== "undefined" && typeof import.meta !== "undefined") ? import.meta.url : undefined;');
|
|
2149
|
+
metaUrl = fn();
|
|
2150
|
+
}
|
|
2151
|
+
catch {
|
|
2152
|
+
metaUrl = undefined;
|
|
2153
|
+
}
|
|
2154
|
+
if (metaUrl) {
|
|
2155
|
+
localDirname = path.dirname(fileURLToPath(metaUrl));
|
|
2156
|
+
}
|
|
2157
|
+
else {
|
|
2158
|
+
// Last-resort fallback: use current working directory
|
|
2159
|
+
localDirname = process.cwd();
|
|
2160
|
+
}
|
|
2161
|
+
}
|
|
2162
|
+
this.rootPath = path.resolve(localDirname, "..");
|
|
2397
2163
|
}
|
|
2398
2164
|
/**
|
|
2399
2165
|
* @description Retrieves and initializes the Commander Command object
|
|
@@ -2538,12 +2304,11 @@ class McpWrapper extends LoggedClass {
|
|
|
2538
2304
|
* Command-->>CliWrapper: result
|
|
2539
2305
|
* CliWrapper-->>Client: result
|
|
2540
2306
|
*/
|
|
2541
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
2542
2307
|
async run(args = process.argv) {
|
|
2543
2308
|
const server = await this.boot();
|
|
2544
2309
|
await server.start({ transportType: "stdio" });
|
|
2545
2310
|
}
|
|
2546
2311
|
}
|
|
2547
2312
|
|
|
2548
|
-
export { CLIENT_INTEGRATIONS, DEFAULT_PROMPT_NAME, EnrichCore, EnrichCoreWithAggregation, MCP_FILE_NAME, McpUtils, McpWrapper, PACKAGE_NAME, PROMPT_DIRECTORIES, REQUIRED_MODULE_FOLDERS, VERSION, WORKSPACE_ROOT_ENV, __resetWorkspaceRoot, aggregateModules, aggregateModulesSync, buildDecorationResourceTemplates, buildDocPrompts,
|
|
2549
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mcp-server.esm.cjs","sources":["../src/constants.ts","../src/mcp/workspace.ts","../src/modules/decoration/prompts/index.ts","../src/modules/decoration/resources/index.ts","../src/modules/decoration/templates/index.ts","../src/mcp/schemas.ts","../src/mcp/utils.ts","../src/mcp/code.ts","../src/mcp/tools/tools.ts","../src/modules/decoration/tools/index.ts","../src/modules/decoration/index.ts","../src/modules/mcp/prompts/index.ts","../src/modules/mcp/resources/index.ts","../src/modules/mcp/templates/index.ts","../src/modules/mcp/tools/index.ts","../src/modules/mcp/index.ts","../src/modules/_template/prompts/index.ts","../src/modules/_template/resources/index.ts","../src/modules/_template/templates/index.ts","../src/modules/_template/tools/index.ts","../src/modules/_template/index.ts","../src/modules/index.ts","../src/mcp/moduleRegistry.ts","../src/mcp/prompts/prompts.ts","../src/mcp/prompts/index.ts","../src/mcp/decorator-tools.ts","../src/mcp/tools/codex-tools.ts","../src/mcp/validation/scaffoldModule.ts","../src/mcp/tools/generateMcpModule.ts","../src/mcp/tools/index.ts","../src/mcp/resources/resources.ts","../src/mcp/templates/codex-templates.ts","../src/mcp/templates/resource-templates.ts","../src/mcp/templates/workspace-templates.ts","../src/mcp/templates/index.ts","../src/metadata.ts","../src/mcp/mcp-module.ts","../src/mcp/validation/index.ts","../src/mcp/aggregateModules.ts","../src/mcp/fastmcp-wiring.ts","../src/mcp/index.ts","../src/utils/modulePaths.ts","../src/utils.ts","../src/McpWrapper.ts"],"sourcesContent":["/**\n * @description The filename that identifies Decaf CLI modules\n * @summary The standard filename for CLI module files where each library must export a single CliModule function\n *\n * @const MCP_FILE_NAME\n * @memberOf module:MCP\n */\nexport const MCP_FILE_NAME = \"mcp-module\";\n\n\nexport const WORKSPACE_ROOT_ENV = \"MCP_WORKSPACE_ROOT\";\nexport const PROMPT_DIRECTORIES = [\".code/prompts\", \".codex/prompts\"];\nexport const DEFAULT_PROMPT_NAME = \"doc\";\nexport const CLIENT_INTEGRATIONS = [\n  {\n    id: \"vscode\",\n    display: \"Visual Studio Code\",\n    instructions:\n      \"When interacting from Visual Studio Code, prefer the vscode://workspace/{path} resource template to fetch file contents and use the apply-code-change tool to commit edits with previewable diffs.\",\n  },\n  {\n    id: \"cursor\",\n    display: \"Cursor\",\n    instructions:\n      \"Cursor clients can retrieve and update files through the cursor://workspace/{path} resource template. Always validate patches in dryRun mode before applying permanent changes.\",\n  },\n  {\n    id: \"copilot\",\n    display: \"GitHub Copilot\",\n    instructions:\n      \"Use the copilot://workspace/{path} resource template to stream file content into Copilot chat sessions. Prefer returning unified diffs to maintain alignment with Copilot's diff visualization.\",\n  },\n] as const;\n","import fs from \"fs\";\nimport path from \"path\";\nimport { WORKSPACE_ROOT_ENV } from \"../constants\";\n\nlet workspaceRoot = initializeWorkspaceRoot();\nlet userErrorCtor: (new (message: string) => Error) | undefined;\n\nexport class WorkspaceError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = \"WorkspaceError\";\n  }\n}\n\nfunction initializeWorkspaceRoot(): string {\n  const configured = process.env[WORKSPACE_ROOT_ENV];\n  if (configured && configured.trim().length > 0) {\n    return path.resolve(configured.trim());\n  }\n  return process.cwd();\n}\n\nasync function getUserErrorCtor(): Promise<new (message: string) => Error> {\n  if (!userErrorCtor) {\n    try {\n      const mod = await import(\"fastmcp\");\n      userErrorCtor = (mod as { UserError: new (message: string) => Error })\n        .UserError;\n    } catch {\n      userErrorCtor = class MCPUserError extends Error {\n        constructor(message: string) {\n          super(message);\n          this.name = \"MCPUserError\";\n        }\n      };\n    }\n  }\n  return userErrorCtor;\n}\n\nexport async function throwUserError(message: string): Promise<never> {\n  const Ctor = await getUserErrorCtor();\n  throw new Ctor(message);\n}\n\nexport function setWorkspaceRoot(root: string) {\n  workspaceRoot = path.resolve(root);\n}\n\nexport function getWorkspaceRoot(): string {\n  return workspaceRoot;\n}\n\nexport function resolveInWorkspace(root: string, targetPath: string): string {\n  const resolved = path.isAbsolute(targetPath)\n    ? path.normalize(targetPath)\n    : path.resolve(root, targetPath);\n\n  const relative = path.relative(root, resolved);\n  if (relative.startsWith(\"..\") || path.isAbsolute(relative)) {\n    throw new WorkspaceError(\n      `Path ${targetPath} escapes the workspace root at ${root}`\n    );\n  }\n\n  return resolved;\n}\n\nexport async function readWorkspaceFile(\n  root: string,\n  target: string\n): Promise<string> {\n  try {\n    const absolute = resolveInWorkspace(root, target);\n    return fs.readFileSync(absolute, \"utf8\" as BufferEncoding);\n  } catch (error) {\n    if (error instanceof WorkspaceError) {\n      await throwUserError(error.message);\n    }\n    /* istanbul ignore next */\n    throw error;\n  }\n}\n\nexport function __resetWorkspaceRoot(root: string) {\n  setWorkspaceRoot(root);\n}\n","export const prompts = [] as const;\n","export const resources = [\n  {\n    \"id\": \"decoration.repo\",\n    \"name\": \"decoration repository\",\n    \"description\": \"Source repository\",\n    \"uri\": \"file:///home/tvenceslau/local-workspace/decaf-ts/mcp-server/src/modules/decoration\",\n    \"absolutePath\": \"/home/tvenceslau/local-workspace/decaf-ts/mcp-server/src/modules/decoration\"\n  }\n] as const;\n","export const templates = [\n  {\n    \"name\": \"readme-template\",\n    \"description\": \"README as guidance\",\n    \"uriTemplate\": \"file:///home/tvenceslau/local-workspace/decaf-ts/mcp-server/src/modules/decoration/README.md\",\n    \"mimeType\": \"text/markdown\"\n  }\n] as const;\n","import { z } from \"zod\";\n\nexport const analyzeRepoSchema = z\n  .object({\n    repoPath: z\n      .string()\n      .min(1, \"repoPath is required\")\n      .describe(\n        \"Relative or absolute path to the target repository inside this monorepo, e.g. './decoration'.\"\n      ),\n    includeTests: z\n      .boolean()\n      .default(true)\n      .describe(\n        \"If true, analyze the tests directory (if present) to derive expected behaviors.\"\n      ),\n    includeDocs: z\n      .boolean()\n      .default(true)\n      .describe(\n        \"If true, analyze README.md and docs directories to extract documented features.\"\n      ),\n  })\n  .strict()\n  .describe(\n    \"Analyze a local repository (e.g. ./decoration) to extract APIs, features, tests, and documentation cues.\"\n  );\n\nexport const enumerateCapabilitiesSchema = z\n  .object({\n    repoPath: z\n      .string()\n      .min(1, \"repoPath is required\")\n      .describe(\n        \"Relative or absolute path to the target repository to enumerate developer-facing capabilities.\"\n      ),\n  })\n  .strict()\n  .describe(\n    \"Enumerate the complete set of capabilities a developer is expected to use from the given repository.\"\n  );\n\nexport const planFeatureSchema = z\n  .object({\n    feature: z\n      .string()\n      .min(5, \"feature must describe the goal clearly\")\n      .describe(\n        \"Natural-language description of a developer's requested feature or task to implement using the repository and available MCP tools.\"\n      ),\n    repoPath: z\n      .string()\n      .default(\"./decoration\")\n      .describe(\n        \"Target repository path providing the library to use, e.g. './decoration'.\"\n      ),\n  })\n  .strict()\n  .describe(\n    \"Plan which MCP tools to use and in what sequence to implement a requested feature using the repository.\"\n  );\n\nexport const documentCodeSchema = z\n  .object({\n    filePath: z.string().min(1, \"filePath is required\"),\n    promptName: z.string().optional(),\n    includePrompt: z.boolean().default(true),\n    includeCode: z.boolean().default(true),\n    includeMetadata: z.boolean().default(true),\n    additionalContext: z.string().optional(),\n    encoding: z.string().default(\"utf8\"),\n  })\n  .strict();\n\nexport const codeChangeSchema = z\n  .object({\n    filePath: z.string().min(1, \"filePath is required\"),\n    patch: z.string().min(1, \"patch is required\"),\n    dryRun: z.boolean().default(false),\n    showDiff: z.boolean().default(true),\n    diffContext: z.number().int().min(0).max(100).default(3),\n    encoding: z.string().default(\"utf8\"),\n  })\n  .strict();\n\nconst OBJECT_TYPES = [\n  \"module\",\n  \"file\",\n  \"class\",\n  \"function\",\n  \"interface\",\n  \"decorator\",\n  \"constant\",\n] as const;\n\nexport const documentObjectSchema = z\n  .object({\n    basePath: z.string().min(1, \"basePath is required\"),\n    objectType: z.enum(OBJECT_TYPES),\n    targetFile: z.string().optional(),\n    includeContent: z.boolean().default(false),\n  })\n  .strict();\n\nexport const coverageTaskSchema = z\n  .object({\n    basePath: z.string().min(1, \"basePath is required\"),\n    coverage: z\n      .number()\n      .min(0)\n      .max(100)\n      .default(90)\n      .describe(\"Target coverage percentage\"),\n    dryRun: z.boolean().default(false),\n  })\n  .strict();\n\nexport const readmeImprovementSchema = z\n  .object({\n    basePath: z.string().min(1, \"basePath is required\"),\n    includeExamples: z.boolean().default(true),\n  })\n  .strict();\n","import fs from \"fs\";\nimport path from \"path\";\nimport { analyzeRepo } from \"./code\";\n\nexport function readFileSafe(\n  filePath: string,\n  encoding: BufferEncoding = \"utf8\"\n): string | undefined {\n  try {\n    return fs.readFileSync(filePath, { encoding });\n  } catch {\n    return undefined;\n  }\n}\n\nexport function listFilesRecursive(\n  root: string,\n  matcher?: (p: string) => boolean\n): string[] {\n  const out: string[] = [];\n  const stack: string[] = [root];\n  while (stack.length) {\n    const cur = stack.pop()!;\n    const stat = fs.statSync(cur);\n    if (stat.isDirectory()) {\n      for (const f of fs.readdirSync(cur)) stack.push(path.join(cur, f));\n    } else if (!matcher || matcher(cur)) {\n      out.push(cur);\n    }\n  }\n  return out.sort();\n}\n\nexport function deriveCapabilities(\n  analysis: ReturnType<typeof analyzeRepo>\n): string[] {\n  const cap = new Set<string>();\n  // heuristics: if decorators like Decoration, flavouredAs, extend, override appear, add capabilities\n  const allDecs = new Set<string>();\n  for (const k of Object.keys(analysis.api)) {\n    for (const d of analysis.api[k].decorators) allDecs.add(d);\n    for (const e of analysis.api[k].exports)\n      if (/Decoration|decorate|Builder|Flavour/i.test(e))\n        cap.add(\"use-decoration-api\");\n  }\n  if ([...allDecs].some((d) => /override|extend/i.test(d)))\n    cap.add(\"override-and-extend-decorations\");\n  if (Object.keys(analysis.tests).length > 0) cap.add(\"validate-with-tests\");\n  if (analysis.readme) cap.add(\"follow-readme-guides\");\n  return [...cap].sort();\n}\n","// Analysis helpers (minimal yet effective, text-based to avoid heavy AST deps)\nimport path from \"path\";\nimport fs from \"fs\";\nimport { listFilesRecursive, readFileSafe } from \"./utils\";\n\nexport function isSourceFile(p: string) {\n  return /\\.(ts|tsx|js|jsx)$/.test(p) && !p.endsWith(\".d.ts\");\n}\nexport function isTestFile(p: string) {\n  return /(\\.test\\.|\\.spec\\.)/.test(p);\n}\n\nexport function extractExports(fileContent: string): string[] {\n  const names = new Set<string>();\n  const exportRe =\n    /(export\\s+(?:default\\s+)?(?:class|function|const|let|var|interface|type|enum)\\s+)([A-Za-z0-9_]+)/g;\n  const namedRe = /export\\s*\\{([^}]+)\\}/g;\n  let m: RegExpExecArray | null;\n  while ((m = exportRe.exec(fileContent))) names.add(m[2]);\n  while ((m = namedRe.exec(fileContent))) {\n    m[1]\n      .split(\",\")\n      .map((s) => s.trim().split(\" as \")[0].trim())\n      .forEach((n) => {\n        if (n) names.add(n);\n      });\n  }\n  return [...names].sort();\n}\n\nexport function extractDecorators(fileContent: string): string[] {\n  const decs = new Set<string>();\n  const decRe = /@([A-Za-z_][A-Za-z0-9_]*)/g;\n  let m: RegExpExecArray | null;\n  while ((m = decRe.exec(fileContent))) decs.add(m[1]);\n  return [...decs].sort();\n}\n\nexport function summarizeReadme(readme?: string) {\n  if (!readme) return undefined;\n  const lines = readme.split(/\\r?\\n/).filter(Boolean);\n  const title =\n    lines.find((l) => /^#\\s+/.test(l))?.replace(/^#\\s+/, \"\") || \"README\";\n  const bullets = lines.filter((l) => /^[-*]\\s+/.test(l)).slice(0, 20);\n  return { title, bullets };\n}\n\nexport function analyzeRepo(root: string) {\n  const src = path.join(root, \"src\");\n  const testDir = path.join(root, \"tests\");\n  const readmePath = path.join(root, \"README.md\");\n  const readme = readFileSafe(readmePath);\n\n  const files = fs.existsSync(src) ? listFilesRecursive(src, isSourceFile) : [];\n  const testFiles = fs.existsSync(testDir)\n    ? listFilesRecursive(testDir, (f) => isSourceFile(f) && isTestFile(f))\n    : [];\n\n  const api: Record<string, { exports: string[]; decorators: string[] }> = {};\n  for (const f of files) {\n    const content = readFileSafe(f) || \"\";\n    api[path.relative(root, f)] = {\n      exports: extractExports(content),\n      decorators: extractDecorators(content),\n    };\n  }\n  const tests: Record<string, { mentions: string[] }> = {};\n  for (const f of testFiles) {\n    const content = readFileSafe(f) || \"\";\n    const mentions = Array.from(\n      new Set([...extractExports(content), ...extractDecorators(content)])\n    ).sort();\n    tests[path.relative(root, f)] = { mentions };\n  }\n  return { files, testFiles, api, tests, readme: summarizeReadme(readme) };\n}\n","import fs from \"fs\";\nimport path from \"path\";\nimport { ContentResult, Tool } from \"fastmcp\";\nimport { applyPatch, createTwoFilesPatch } from \"diff\";\nimport {\n  analyzeRepoSchema,\n  codeChangeSchema,\n  documentCodeSchema,\n  enumerateCapabilitiesSchema,\n  planFeatureSchema,\n} from \"../schemas\";\nimport { analyzeRepo } from \"../code\";\nimport { deriveCapabilities } from \"../utils\";\nimport {\n  getWorkspaceRoot,\n  resolveInWorkspace,\n  throwUserError,\n  WorkspaceError,\n} from \"../workspace\";\nimport {\n  buildDocumentationPayload,\n  DEFAULT_PROMPT_NAME,\n  discoverDocPrompts,\n  selectPrompt,\n} from \"../prompts/prompts\";\nimport type { ApplyCodeChangeArgs, DocumentCodeArgs } from \"../types\";\nimport { generateMcpModuleTool } from \"./generateMcpModule\";\n\nexport function buildAnalyzeRepositoryTool(): Tool<\n  undefined,\n  typeof analyzeRepoSchema\n> {\n  return {\n    name: \"analyze-repository\",\n    description:\n      \"Analyze a local repository's source, tests, and docs to extract exported APIs, decorators, and test mentions.\",\n    parameters: analyzeRepoSchema,\n    execute: async (input) => {\n      let repoRoot = path.resolve(process.cwd(), input.repoPath);\n      if (!fs.existsSync(repoRoot)) {\n        // try resolving from monorepo root (parent of current cwd)\n        const alt = path.resolve(process.cwd(), \"..\", input.repoPath);\n        if (fs.existsSync(alt)) repoRoot = alt;\n      }\n      if (!fs.existsSync(repoRoot)) {\n        // if input was absolute and still not found, try ../<basename>\n        const alt2 = path.resolve(\n          process.cwd(),\n          \"..\",\n          path.basename(input.repoPath)\n        );\n        if (fs.existsSync(alt2)) repoRoot = alt2;\n      }\n      if (!fs.existsSync(repoRoot))\n        throw new Error(`Repository not found at ${repoRoot}`);\n      const result = analyzeRepo(repoRoot);\n      return {\n        content: [{ type: \"text\", text: JSON.stringify(result, null, 2) }],\n      };\n    },\n  };\n}\n\nexport function buildEnumerateCapabilitiesTool(): Tool<\n  undefined,\n  typeof enumerateCapabilitiesSchema\n> {\n  return {\n    name: \"enumerate-capabilities\",\n    description:\n      \"Enumerate developer-facing capabilities of the given repository, inferred from code, tests, and docs.\",\n    parameters: enumerateCapabilitiesSchema,\n    execute: async (input) => {\n      let repoRoot = path.resolve(process.cwd(), input.repoPath);\n      if (!fs.existsSync(repoRoot)) {\n        const alt = path.resolve(process.cwd(), \"..\", input.repoPath);\n        if (fs.existsSync(alt)) repoRoot = alt;\n      }\n      if (!fs.existsSync(repoRoot)) {\n        const alt2 = path.resolve(\n          process.cwd(),\n          \"..\",\n          path.basename(input.repoPath)\n        );\n        if (fs.existsSync(alt2)) repoRoot = alt2;\n      }\n      if (!fs.existsSync(repoRoot))\n        throw new Error(`Repository not found at ${repoRoot}`);\n      const analysis = analyzeRepo(repoRoot);\n      const capabilities = deriveCapabilities(analysis);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(\n              {\n                capabilities,\n                analysisSummary: {\n                  files: analysis.files.length,\n                  testFiles: analysis.testFiles.length,\n                  readme: analysis.readme?.title,\n                },\n              },\n              null,\n              2\n            ),\n          },\n        ],\n      };\n    },\n  };\n}\n\nexport function buildPlanFeatureTool(): Tool<\n  undefined,\n  typeof planFeatureSchema\n> {\n  return {\n    name: \"plan-feature-implementation\",\n    description:\n      \"Given a feature request, select appropriate MCP tools (including existing and new ones) and produce an execution plan.\",\n    parameters: planFeatureSchema,\n    execute: async (input) => {\n      const steps: Array<{\n        step: number;\n        action: string;\n        tool?: string;\n        arguments?: Record<string, any>;\n        rationale: string;\n      }> = [];\n      let i = 1;\n      steps.push({\n        step: i++,\n        action: \"Analyze repository to enumerate APIs and decorators\",\n        tool: \"analyze-repository\",\n        arguments: { repoPath: input.repoPath },\n        rationale: \"Understand available building blocks.\",\n      });\n      steps.push({\n        step: i++,\n        action: \"List capabilities expected for developers\",\n        tool: \"enumerate-capabilities\",\n        arguments: { repoPath: input.repoPath },\n        rationale: \"Align the plan with supported capabilities.\",\n      });\n      // Suggest existing generic tools from mcp-module\n      steps.push({\n        step: i++,\n        action:\n          \"Select documentation prompt and gather relevant source file(s)\",\n        tool: \"document-code\",\n        arguments: { filePath: \"<target-file>\" },\n        rationale: \"Provide context and instructions for changes.\",\n      });\n      steps.push({\n        step: i++,\n        action: \"Apply code changes using unified diff patch\",\n        tool: \"apply-code-change\",\n        arguments: {\n          filePath: \"<target-file>\",\n          patch: \"<unified-diff>\",\n          dryRun: true,\n        },\n        rationale: \"Validate changes safely before committing.\",\n      });\n      steps.push({\n        step: i++,\n        action: \"Commit code changes\",\n        tool: \"apply-code-change\",\n        arguments: {\n          filePath: \"<target-file>\",\n          patch: \"<unified-diff>\",\n          dryRun: false,\n        },\n        rationale: \"Persist the update.\",\n      });\n      // If decoration-related terms present, suggest decorator tools\n      if (/decorat|flavour|override|extend|builder/i.test(input.feature)) {\n        steps.unshift({\n          step: 0,\n          action: \"Use decorator tooling to insert/remove/modify decorators\",\n          tool: \"decorator-tools\",\n          arguments: { action: \"help\" },\n          rationale: \"Leverage specialized utilities for decoration patterns.\",\n        });\n        steps.forEach((s, idx) => (s.step = idx + 1));\n      }\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(\n              {\n                plan: steps,\n                notes:\n                  \"Replace placeholder arguments like <target-file> and <unified-diff> based on the analysis output.\",\n              },\n              null,\n              2\n            ),\n          },\n        ],\n      };\n    },\n  };\n}\n\nexport const documentCodeTool: Tool<undefined, typeof documentCodeSchema> = {\n  annotations: {\n    idempotentHint: true,\n    openWorldHint: false,\n    readOnlyHint: true,\n    title: \"Document Source File\",\n  },\n  description:\n    \"Generate documentation guidance for a file by combining repository prompts with the target source code.\",\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (input, _context): Promise<ContentResult> => {\n    const args = documentCodeSchema.parse(input as DocumentCodeArgs);\n    const root = getWorkspaceRoot();\n    let filePath: string;\n    try {\n      filePath = resolveInWorkspace(root, args.filePath);\n    } catch (error) {\n      if (error instanceof WorkspaceError) {\n        return throwUserError(error.message);\n      }\n      /* istanbul ignore next */\n      throw error;\n    }\n\n    if (!fs.existsSync(filePath)) {\n      return throwUserError(`Cannot document missing file at ${args.filePath}`);\n    }\n\n    const fileContent = fs.readFileSync(filePath, {\n      encoding: args.encoding as BufferEncoding,\n    });\n    const prompts = discoverDocPrompts(root);\n\n    if (!prompts.length) {\n      return throwUserError(\n        \"No documentation prompts found under .code/prompts or .codex/prompts\"\n      );\n    }\n\n    const prompt = selectPrompt(\n      prompts,\n      args.promptName ?? DEFAULT_PROMPT_NAME\n    );\n\n    return buildDocumentationPayload({\n      filePath: args.filePath,\n      fileContent,\n      prompt,\n      includeCode: args.includeCode,\n      includePrompt: args.includePrompt,\n      includeMetadata: args.includeMetadata,\n      additionalContext: args.additionalContext,\n    });\n  },\n  name: \"document-code\",\n  parameters: documentCodeSchema,\n};\n\nexport const applyCodeChangeTool: Tool<undefined, typeof codeChangeSchema> = {\n  annotations: {\n    destructiveHint: true,\n    idempotentHint: false,\n    openWorldHint: false,\n    readOnlyHint: false,\n    title: \"Apply Code Patch\",\n  },\n  description:\n    \"Apply a unified diff patch to a workspace file with optional dry-run validation and diff preview.\",\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (input, _context): Promise<string | ContentResult> => {\n    const args = codeChangeSchema.parse(input as ApplyCodeChangeArgs);\n    const root = getWorkspaceRoot();\n    let filePath: string;\n    try {\n      filePath = resolveInWorkspace(root, args.filePath);\n    } catch (error) {\n      if (error instanceof WorkspaceError) {\n        return throwUserError(error.message);\n      }\n      throw error;\n    }\n\n    const original = fs.existsSync(filePath)\n      ? fs.readFileSync(filePath, args.encoding as BufferEncoding)\n      : \"\";\n\n    let patched: string | false;\n    try {\n      patched = applyPatch(original, args.patch);\n    } catch (error) {\n      return throwUserError(\n        `Failed to apply provided patch to ${args.filePath}: ${error instanceof Error ? error.message : error}`\n      );\n    }\n    /* istanbul ignore next */\n    if (patched === false) {\n      return throwUserError(\n        `Failed to apply provided patch to ${args.filePath}`\n      );\n    }\n\n    if (!args.dryRun) {\n      fs.mkdirSync(path.dirname(filePath), { recursive: true });\n      fs.writeFileSync(filePath, patched, {\n        encoding: args.encoding as BufferEncoding,\n      });\n    }\n\n    if (!args.showDiff) {\n      return `Patch ${args.dryRun ? \"validated\" : \"applied\"} for ${args.filePath}`;\n    }\n\n    const preview = createTwoFilesPatch(\n      args.filePath,\n      args.filePath,\n      original,\n      patched,\n      undefined,\n      undefined,\n      { context: args.diffContext }\n    );\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `Patch ${args.dryRun ? \"validated\" : \"applied\"} for ${args.filePath}`,\n        },\n        {\n          type: \"text\",\n          text: [\"```diff\", preview.trim(), \"```\"].join(\"\\n\"),\n        },\n      ],\n    } satisfies ContentResult;\n  },\n  name: \"apply-code-change\",\n  parameters: codeChangeSchema,\n};\n\ntype AnyTool = Tool<undefined, any>;\n\nconst analyticTools: AnyTool[] = [\n  buildAnalyzeRepositoryTool(),\n  buildEnumerateCapabilitiesTool(),\n  buildPlanFeatureTool(),\n];\n\nexport const toolList: AnyTool[] = [\n  ...analyticTools,\n  documentCodeTool,\n  applyCodeChangeTool,\n];\n","import type { Tool } from 'fastmcp';\nimport { buildAnalyzeRepositoryTool, buildEnumerateCapabilitiesTool, buildPlanFeatureTool } from '../../../mcp/tools/tools';\nexport const tools = [\n  { id: 'decoration.analyze', title: 'Analyze decoration', description: 'Analyze the target repository', tool: buildAnalyzeRepositoryTool() },\n  { id: 'decoration.enumerate', title: 'Enumerate capabilities for decoration', description: 'Enumerate capabilities', tool: buildEnumerateCapabilitiesTool() },\n  { id: 'decoration.plan', title: 'Plan features for decoration', description: 'Plan feature implementation', tool: buildPlanFeatureTool() },\n] as const;\n","import { prompts } from './prompts';\nimport { resources } from './resources';\nimport { templates } from './templates';\nimport { tools } from './tools';\nexport { prompts } from './prompts';\nexport { resources } from './resources';\nexport { templates } from './templates';\nexport { tools } from './tools';\nexport const modulePackage = { name: 'decoration', prompts, resources, templates, tools } as const;\n","import type { PromptAsset } from \"../../../types\";\n\nexport const prompts: PromptAsset[] = [\n  {\n    id: \"mcp.prompt.module-catalog\",\n    title: \"Decaf MCP Module Catalog\",\n    description: \"Summarizes the modules contributing prompts/resources/templates/tools to FASTMCP.\",\n    load: async () =>\n      \"Use the module catalog tool to enumerate available module assets before fulfilling assistant requests.\",\n  },\n];\n","import type { ResourceAsset } from \"../../../types\";\n\nexport const resources: ResourceAsset[] = [\n  {\n    id: \"mcp.resource.registry-overview\",\n    title: \"Module Registry Overview\",\n    description:\n      \"Explains how the ModuleRegistry aggregates module exports into FASTMCP catalogs.\",\n    uri: \"decaf://mcp/module-registry\",\n    mimeType: \"text/markdown\",\n    load: async () => ({\n      content: [\n        {\n          type: \"text\",\n          text: [\n            \"# Module Registry\",\n            \"\",\n            \"The Decaf MCP server aggregates prompts, resources, templates, and tools from every module under src/modules.\",\n            \"Validators ensure each module contains the canonical folder layout before the registry loads it.\",\n          ].join(\"\\n\"),\n          mimeType: \"text/markdown\",\n        },\n      ],\n    }),\n  },\n];\n\n","import type { TemplateAsset } from \"../../../types\";\n\nexport const templates: TemplateAsset[] = [\n  {\n    id: \"mcp.template.module-readme\",\n    title: \"Module README Template\",\n    description: \"Guides maintainers through documenting a new MCP-aware module.\",\n    content: `# {{moduleName}} Module\n\n## Purpose\nDescribe why this module exists and how assistants should use it.\n\n## Assets\n- Prompts: {{promptSummary}}\n- Resources: {{resourceSummary}}\n- Templates: {{templateSummary}}\n- Tools: {{toolSummary}}\n\n## Validation\nExplain what needs to happen when this module changes (tests, docs, etc.).`,\n    placeholders: [\n      \"moduleName\",\n      \"promptSummary\",\n      \"resourceSummary\",\n      \"templateSummary\",\n      \"toolSummary\",\n    ],\n  },\n];\n","const describeModulesTool: any = {\n  name: \"describe-modules\",\n  description:\n    \"Summarize the purpose of Decaf MCP modules for assistant operators.\",\n  // Minimal execute implementation to return a text result\n  execute: async (): Promise<string> =>\n    \"Modules contribute prompts, resources, templates, and tools that the registry exposes to FASTMCP clients.\",\n};\n\nexport const tools = [\n  {\n    id: \"mcp.tool.describe-modules\",\n    title: \"Describe MCP Modules\",\n    description: \"Explains how module exports feed into the FASTMCP server.\",\n    tool: describeModulesTool,\n  },\n];\n","import type { ModuleExportPackage } from \"../../types\";\nimport { prompts } from \"./prompts\";\nimport { resources } from \"./resources\";\nimport { templates } from \"./templates\";\nimport { tools } from \"./tools\";\n\nexport { prompts } from \"./prompts\";\nexport { resources } from \"./resources\";\nexport { templates } from \"./templates\";\nexport { tools } from \"./tools\";\n\nexport const modulePackage: ModuleExportPackage = {\n  name: \"mcp\",\n  prompts,\n  resources,\n  templates,\n  tools,\n};\n","export const prompts = [\n  {\n    id: \"_template.readme\",\n    title: \"Template README\",\n    description: \"A README prompt for module template\",\n    load: () => \"Template prompt content\",\n  },\n] as const;\n","export const resources = [\n  {\n    id: \"_template.repo\",\n    name: \"template repo\",\n    description: \"Template resource\",\n    uri: \"file:///tmp/template\",\n  },\n] as const;\n","export const templates = [\n  {\n    id: \"_template.readme\",\n    name: \"template-readme\",\n    description: \"README guidance\",\n    uriTemplate: \"file:///tmp/template/README.md\",\n    mimeType: \"text/markdown\",\n  },\n] as const;\n","const placeholderTool: any = {\n  name: \"_template.tool\",\n  description: \"A placeholder tool\",\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (_input: any, _context: any): Promise<string> => \"ok\",\n};\n\nexport const tools = [\n  {\n    id: \"_template.tool\",\n    title: \"template tool\",\n    description: \"A placeholder tool\",\n    tool: placeholderTool,\n  },\n] as const;\n","import { prompts } from \"./prompts\";\nimport { resources } from \"./resources\";\nimport { templates } from \"./templates\";\nimport { tools } from \"./tools\";\nexport { prompts } from \"./prompts\";\nexport { resources } from \"./resources\";\nexport { templates } from \"./templates\";\nexport { tools } from \"./tools\";\nexport const modulePackage = {\n  name: \"_template\",\n  prompts,\n  resources,\n  templates,\n  tools,\n} as const;\n","import type { ModuleExportPackage } from \"../types\";\nimport { modulePackage as decorationModule } from \"./decoration\";\nimport { modulePackage as mcpModule } from \"./mcp\";\nimport { modulePackage as templateModule } from \"./_template\";\n\n// modulePackage objects may be declared with readonly arrays (as const). Cast to the mutable type expected by runtime APIs.\nexport const modulePackages: ModuleExportPackage[] = [\n  decorationModule as unknown as ModuleExportPackage,\n  mcpModule as unknown as ModuleExportPackage,\n  templateModule as unknown as ModuleExportPackage,\n];\n","import type {\n  ModuleExportPackage,\n  PromptAsset,\n  ResourceAsset,\n  TemplateAsset,\n  ToolAsset,\n} from \"../types\";\nimport { modulePackages } from \"../modules\";\n\ntype AssetKey = \"prompts\" | \"resources\" | \"templates\" | \"tools\";\n\nexport class ModuleRegistry {\n  // Defensive default: modulePackages may be undefined during circular imports\n  constructor(\n    private readonly packages: ModuleExportPackage[] = Array.isArray(\n      modulePackages\n    )\n      ? (modulePackages as ModuleExportPackage[])\n      : []\n  ) {}\n\n  listPackages(): ModuleExportPackage[] {\n    return this.packages;\n  }\n\n  listPrompts(): PromptAsset[] {\n    return this.collectAssets(\"prompts\");\n  }\n\n  listResources(): ResourceAsset[] {\n    return this.collectAssets(\"resources\");\n  }\n\n  listTemplates(): TemplateAsset[] {\n    return this.collectAssets(\"templates\");\n  }\n\n  listTools(): ToolAsset[] {\n    return this.collectAssets(\"tools\");\n  }\n\n  private collectAssets<\n    T extends PromptAsset | ResourceAsset | TemplateAsset | ToolAsset,\n  >(key: AssetKey): T[] {\n    const seen = new Map<string, string>();\n    const aggregated: T[] = [];\n\n    for (const pkg of this.packages) {\n      if (pkg.status === \"disabled\") continue;\n      for (const asset of pkg[key] as T[]) {\n        // asset.name is not guaranteed on all asset types; use type-safe fallback\n        const maybeName = (asset as any).name as string | undefined;\n        const assetKey =\n          (asset && (asset.id ?? maybeName)) || JSON.stringify(asset);\n        if (seen.has(assetKey)) {\n          const conflict = seen.get(assetKey);\n          throw new Error(\n            `Duplicate ${key} id '${assetKey}' from modules ${conflict} and ${pkg.name}`\n          );\n        }\n        seen.set(assetKey, pkg.name);\n        aggregated.push({ ...asset, provenance: pkg.name });\n      }\n    }\n\n    return aggregated;\n  }\n}\n\nexport const moduleRegistry = new ModuleRegistry();\n","import fs from \"fs\";\nimport path from \"path\";\nimport type { ContentResult, InputPrompt } from \"fastmcp\";\nimport {\n  CLIENT_INTEGRATIONS,\n  DEFAULT_PROMPT_NAME,\n  PROMPT_DIRECTORIES,\n} from \"../../constants\";\nimport type { DocPrompt } from \"../types\";\nimport { getWorkspaceRoot } from \"../workspace\";\nimport type { PromptAsset } from \"../../types\";\nimport { moduleRegistry } from \"../moduleRegistry\";\n\nexport const prompts: InputPrompt<undefined>[] = [];\n\nconst OBJECT_PROMPT_DEPENDENCIES: Record<string, readonly string[]> = {\n  module: [\"doc\", \"module\"],\n  file: [\"doc\", \"file\"],\n  class: [\"doc\", \"class\"],\n  function: [\"doc\", \"function\"],\n  interface: [\"doc\", \"interface\"],\n  decorator: [\"doc\", \"decorator\"],\n  constant: [\"doc\", \"constant\"],\n  \"bulk-docs\": [\"bulk-docs\"],\n  \"bulk-tests\": [\"bulk-tests\"],\n  \"update-readme\": [\"update-readme\"],\n  \"repo-setup\": [\"repo-setup\"],\n  \"release-notes\": [\"release-notes\"],\n  \"mcp-module\": [\"mcp-module\"],\n};\n\nexport function getObjectPromptDependencies(): Record<\n  string,\n  readonly string[]\n> {\n  return OBJECT_PROMPT_DEPENDENCIES;\n}\n\nexport function buildPrompts(repoPath: string): InputPrompt<undefined>[] {\n  return [\n    {\n      name: \"decoration-overview\",\n      description:\n        \"High-level guidance on using the decoration library: key exports, decorators, and common workflows.\",\n      load: async () =>\n        `You are assisting with the Decaf.ts decoration module located at ${repoPath}. Prefer using exported builders and decorators over ad-hoc patterns.\\n\\nProvide a concise, actionable overview of how to use the decoration APIs for extending and overriding behaviors.`,\n    },\n  ];\n}\n\nexport function buildDocPrompts(): InputPrompt<undefined>[] {\n  const root = getWorkspaceRoot();\n  const fileBasedPrompts = discoverDocPrompts(root).map((prompt) => ({\n    name: `doc/${prompt.name}`,\n    description: prompt.description,\n    load: async () => prompt.content,\n  }));\n\n  const integrationPrompts = CLIENT_INTEGRATIONS.map<InputPrompt<undefined>>(\n    (integration) => ({\n      name: `integration/${integration.id}`,\n      description: `${integration.display} integration guidance`,\n      load: async () =>\n        `You are coordinating with ${integration.display}. ${integration.instructions}\\n\\nTools available:\\n- document-code\\n- apply-code-change\\n\\nEnsure responses include actionable steps for the client.`,\n    })\n  );\n\n  return [...fileBasedPrompts, ...integrationPrompts];\n}\n\nfunction summarizePromptContent(\n  prompt: DocPrompt,\n  headingPrefix: string\n): string {\n  return [`## ${headingPrefix}`, \"\", prompt.content.trim()].join(\"\\n\");\n}\n\nexport function buildObjectPrompts(): InputPrompt<undefined>[] {\n  const root = getWorkspaceRoot();\n  const discovered = discoverDocPrompts(root);\n  const promptByName = new Map<string, DocPrompt>();\n  for (const prompt of discovered) {\n    promptByName.set(prompt.name, prompt);\n  }\n\n  const outputs: InputPrompt<undefined>[] = [];\n  for (const [objectType, dependencies] of Object.entries(\n    OBJECT_PROMPT_DEPENDENCIES\n  )) {\n    const existing = dependencies\n      .map((name) => promptByName.get(name))\n      .filter((prompt): prompt is DocPrompt => Boolean(prompt));\n    if (!existing.length) continue;\n\n    outputs.push({\n      name: `codex/${objectType}`,\n      description: `Guidance derived from .codex prompts for ${objectType} tasks.`,\n      load: async () => {\n        const sections = existing.map((prompt) =>\n          summarizePromptContent(prompt, toTitleCase(prompt.name))\n        );\n        return [`# Codex guidance for ${objectType}`, \"\", ...sections].join(\n          \"\\n\"\n        );\n      },\n    });\n  }\n\n  return outputs.sort((a, b) => a.name.localeCompare(b.name));\n}\n\nfunction toInputPrompt(asset: PromptAsset): InputPrompt<undefined> {\n  const provenance = asset.provenance ? ` (module: ${asset.provenance})` : \"\";\n  return {\n    name: asset.id,\n    description: `${asset.description ?? asset.title}${provenance}`,\n    load: async () => asset.load(),\n  };\n}\n\nfunction buildModulePrompts(): InputPrompt<undefined>[] {\n  return moduleRegistry.listPrompts().map(toInputPrompt);\n}\n\nexport function refreshPrompts(repoPath?: string): InputPrompt<undefined>[] {\n  const docPrompts = buildDocPrompts();\n  const objectPrompts = buildObjectPrompts();\n  const repoPrompts = repoPath ? buildPrompts(repoPath) : [];\n  const modulePrompts = buildModulePrompts();\n  prompts.splice(\n    0,\n    prompts.length,\n    ...docPrompts,\n    ...objectPrompts,\n    ...repoPrompts,\n    ...modulePrompts\n  );\n  return prompts;\n}\n\nexport function discoverDocPrompts(root: string): DocPrompt[] {\n  const discovered: DocPrompt[] = [];\n\n  for (const directory of PROMPT_DIRECTORIES) {\n    const promptDir = path.join(root, directory);\n    // debug logging to help tests diagnose prompt discovery\n\n    console.debug(\"[discoverDocPrompts] checking\", promptDir);\n    if (!fs.existsSync(promptDir) || !fs.statSync(promptDir).isDirectory()) {\n      continue;\n    }\n\n    for (const entry of fs.readdirSync(promptDir)) {\n      const fullPath = path.join(promptDir, entry);\n      if (!fs.statSync(fullPath).isFile()) continue;\n\n      const name = path.parse(entry).name;\n      const content = fs.readFileSync(fullPath, \"utf8\");\n      const title = toTitleCase(name.replace(/[-_]/g, \" \"));\n      const description = extractDescription(content, fullPath);\n\n      discovered.push({\n        name,\n        title,\n        description,\n        content,\n        absolutePath: fullPath,\n      });\n    }\n  }\n\n  const unique = new Map<string, DocPrompt>();\n  for (const prompt of discovered) {\n    if (!unique.has(prompt.name)) {\n      unique.set(prompt.name, prompt);\n    }\n  }\n\n  return Array.from(unique.values()).sort((a, b) =>\n    a.name.localeCompare(b.name)\n  );\n}\n\nexport function selectPrompt(\n  promptList: DocPrompt[],\n  requestedName: string\n): DocPrompt {\n  const direct = promptList.find((prompt) => prompt.name === requestedName);\n  if (direct) return direct;\n\n  const fallback = promptList.find(\n    (prompt) => prompt.name === DEFAULT_PROMPT_NAME\n  );\n  if (fallback) return fallback;\n\n  if (!promptList.length) {\n    throw new Error(\"No documentation prompts available\");\n  }\n\n  return promptList[0];\n}\n\nexport function buildDocumentationPayload({\n  filePath,\n  fileContent,\n  prompt,\n  includePrompt,\n  includeCode,\n  includeMetadata,\n  additionalContext,\n}: {\n  filePath: string;\n  fileContent: string;\n  prompt: DocPrompt;\n  includePrompt: boolean;\n  includeCode: boolean;\n  includeMetadata: boolean;\n  additionalContext?: string;\n}): ContentResult {\n  const sections: string[] = [];\n\n  if (includeMetadata) {\n    sections.push(\n      `# Documentation Request\\n- prompt: ${prompt.name}\\n- file: ${filePath}`\n    );\n  }\n\n  if (includePrompt) {\n    sections.push(\n      `## Prompt Guidance (${prompt.title})\\n\\n${prompt.content.trim()}`\n    );\n  }\n\n  if (additionalContext?.trim()) {\n    sections.push(`## Additional Context\\n\\n${additionalContext.trim()}`);\n  }\n\n  if (includeCode) {\n    sections.push(\n      `## Source\\n\\n\\`\\`\\`${inferLanguageFromPath(filePath)}\\n${fileContent}\\n\\`\\`\\``\n    );\n  }\n\n  return {\n    content: [\n      {\n        type: \"text\",\n        text: sections.join(\"\\n\\n\"),\n      },\n    ],\n  } satisfies ContentResult;\n}\n\nfunction extractDescription(content: string, filePath: string): string {\n  const firstLine = content\n    .split(/\\r?\\n/)\n    .map((line) => line.trim())\n    .find((line) => line.length > 0);\n\n  return (\n    firstLine?.slice(0, 240) ??\n    `Documentation prompt loaded from ${path.basename(filePath)}`\n  );\n}\n\nfunction toTitleCase(value: string): string {\n  return value\n    .split(/\\s+/)\n    .filter(Boolean)\n    .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())\n    .join(\" \");\n}\n\nfunction inferLanguageFromPath(filePath: string): string {\n  const extension = path.extname(filePath).toLowerCase();\n  switch (extension) {\n    case \".ts\":\n    case \".tsx\":\n      return \"ts\";\n    case \".js\":\n    case \".jsx\":\n      return \"js\";\n    case \".json\":\n      return \"json\";\n    case \".md\":\n      return \"md\";\n    default:\n      return \"text\";\n  }\n}\n\nexport { DEFAULT_PROMPT_NAME };\nexport type { DocPrompt };\n","import type { InputPrompt } from \"fastmcp\";\nimport { prompts, refreshPrompts } from \"./prompts\";\n\nexport * from \"./prompts\";\n\nexport const promptList: InputPrompt<undefined>[] = prompts;\n\nexport function loadPrompts(repoPath?: string): InputPrompt<undefined>[] {\n  return refreshPrompts(repoPath);\n}\n","import fs from \"fs\";\nimport path from \"path\";\n\nexport type DecoratorSpec = {\n  name: string;\n  args?: unknown[];\n};\n\nexport type AttributeSpec = {\n  name: string;\n  type: string;\n  decorators?: DecoratorSpec[];\n};\n\nfunction escapeRegExp(value: string) {\n  return value.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\nfunction formatDecorator(spec: DecoratorSpec): string {\n  const args = (spec.args || []).map((arg) => JSON.stringify(arg)).join(\", \");\n  return `@${spec.name}(${args})`;\n}\n\nfunction ensureDirectory(filePath: string) {\n  fs.mkdirSync(path.dirname(filePath), { recursive: true });\n}\n\nfunction collectDecoratorNames(\n  classDecorators: DecoratorSpec[] | undefined,\n  properties: AttributeSpec[] | undefined\n) {\n  const names = new Set<string>();\n  names.add(\"model\");\n  for (const decorator of classDecorators || []) {\n    names.add(decorator.name);\n  }\n  for (const property of properties || []) {\n    for (const decorator of property.decorators || []) {\n      names.add(decorator.name);\n    }\n  }\n  return names;\n}\n\nfunction ensureImport(\n  content: string,\n  importsFrom: string,\n  decorators: Set<string>\n) {\n  /* istanbul ignore next */\n  if (!decorators.size) return content;\n  const importRegex = new RegExp(\n    `import\\\\s+\\\\{([^}]+)\\\\}\\\\s+from\\\\s+[\"']${escapeRegExp(importsFrom)}[\"'];`\n  );\n  const match = content.match(importRegex);\n  const sorted = Array.from(decorators).sort();\n\n  if (match) {\n    const existing = match[1]\n      .split(\",\")\n      .map((name) => name.trim())\n      .filter(Boolean);\n    const merged = Array.from(new Set([...existing, ...sorted])).sort();\n    return content.replace(\n      importRegex,\n      `import { ${merged.join(\", \")} } from \"${importsFrom}\";`\n    );\n  }\n\n  const importLine = `import { ${sorted.join(\", \")} } from \"${importsFrom}\";`;\n  return `${importLine}\\n\\n${content}`;\n}\n\nfunction addPropertyBlock(property: AttributeSpec) {\n  const decorators = (property.decorators || [])\n    .map(formatDecorator)\n    .join(\"\\n  \");\n  const decoratorBlock = decorators ? `  ${decorators}\\n` : \"\";\n  return `${decoratorBlock}  ${property.name}: ${property.type};`;\n}\n\nfunction removePropertyBlock(content: string, propertyName: string) {\n  const lines = content.split(/\\r?\\n/);\n  const result: string[] = [];\n  for (let i = 0; i < lines.length; i++) {\n    const line = lines[i];\n    if (\n      line.trim().startsWith(`@`) &&\n      lines[i + 1]?.includes(`${propertyName}:`)\n    ) {\n      continue;\n    }\n    if (line.includes(`${propertyName}:`)) {\n      // skip this line and any trailing blank line\n      continue;\n    }\n    result.push(line);\n  }\n  return result.join(\"\\n\");\n}\n\nfunction insertDecorator(\n  content: string,\n  decorator: DecoratorSpec,\n  target: {\n    kind: \"class\" | \"property\";\n    name?: string;\n  }\n) {\n  const decoratorLine = formatDecorator(decorator);\n  if (target.kind === \"class\") {\n    const classRegex = /(export\\s+class\\s+[^\\s{]+\\s*\\{)/;\n    if (content.includes(decoratorLine)) return content;\n    return content.replace(classRegex, `${decoratorLine}\\n$1`);\n  }\n  if (!target.name) return content;\n  const propertyRegex = new RegExp(\n    `(^\\\\s*)(?:@.*\\\\n\\\\1)*${escapeRegExp(target.name)}:`,\n    \"m\"\n  );\n  const match = propertyRegex.exec(content);\n  if (!match) return content;\n  const indent = match[1] || \"  \";\n  if (content.includes(`${indent}${decoratorLine}`)) return content;\n  return (\n    content.slice(0, match.index) +\n    `${indent}${decoratorLine}\\n` +\n    content.slice(match.index)\n  );\n}\n\nfunction removeDecorator(\n  content: string,\n  decoratorName: string,\n  target: {\n    kind: \"class\" | \"property\";\n    name?: string;\n  }\n) {\n  const decoratorRegex = new RegExp(\n    `^\\\\s*@${escapeRegExp(decoratorName)}\\\\([^)]*\\\\)`,\n    \"m\"\n  );\n  if (target.kind === \"class\") {\n    return content.replace(decoratorRegex, \"\");\n  }\n  if (target.name) {\n    const pattern = new RegExp(\n      `(^\\\\s*@${escapeRegExp(decoratorName)}\\\\([^)]*\\\\)\\\\s*$\\\\n)(?=\\\\s*${escapeRegExp(target.name)}:)`,\n      \"m\"\n    );\n    return content.replace(pattern, \"\");\n  }\n  return content;\n}\n\nfunction writeIfChanged(filePath: string, content: string) {\n  ensureDirectory(filePath);\n  fs.writeFileSync(filePath, content);\n}\n\nexport const decoratorTools = {\n  createOrUpdateModelTool: {\n    name: \"create-or-update-model\",\n    description: \"Create or update a validation-ready model class\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      classDecorators?: DecoratorSpec[];\n      properties: AttributeSpec[];\n      importsFrom: string;\n      overwrite?: boolean;\n    }) => {\n      if (!args.overwrite && fs.existsSync(args.filePath)) {\n        throw new Error(`File already exists at ${args.filePath}`);\n      }\n      const decorators = collectDecoratorNames(\n        args.classDecorators,\n        args.properties\n      );\n      let content = `@model()`;\n      for (const decorator of args.classDecorators || []) {\n        content += `\\n${formatDecorator(decorator)}`;\n      }\n      const properties = (args.properties || [])\n        .map(addPropertyBlock)\n        .join(\"\\n\\n\");\n      content += `\\nexport class ${args.className} {\\n${properties ? `${properties}\\n` : \"\"}}\\n`;\n      content = ensureImport(content, args.importsFrom, decorators);\n      writeIfChanged(args.filePath, content);\n      return { filePath: args.filePath };\n    },\n  },\n  addAttributeTool: {\n    name: \"add-attribute\",\n    description: \"Add a decorated attribute to an existing model\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      attribute: AttributeSpec;\n      importsFrom: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) {\n        throw new Error(`Model file not found at ${args.filePath}`);\n      }\n      let content = fs.readFileSync(args.filePath, \"utf8\");\n      if (content.includes(`${args.attribute.name}:`)) {\n        return { filePath: args.filePath };\n      }\n      const decorators = collectDecoratorNames(undefined, [args.attribute]);\n      content = ensureImport(content, args.importsFrom, decorators);\n      const insertionPoint = content.lastIndexOf(\"}\");\n      const block = addPropertyBlock(args.attribute);\n      const before = content.slice(0, insertionPoint).replace(/\\s*$/, \"\");\n      const after = content.slice(insertionPoint);\n      const updated = `${before}\\n${block}\\n${after}`;\n      writeIfChanged(args.filePath, updated);\n      return { filePath: args.filePath };\n    },\n  },\n  removeAttributeTool: {\n    name: \"remove-attribute\",\n    description: \"Remove an attribute from a model class\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      attributeName: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) return { filePath: args.filePath };\n      const content = fs.readFileSync(args.filePath, \"utf8\");\n      const updated = removePropertyBlock(content, args.attributeName);\n      writeIfChanged(args.filePath, updated);\n      return { filePath: args.filePath };\n    },\n  },\n  applyDecoratorTool: {\n    name: \"apply-decorator\",\n    description: \"Apply a decorator to a class or property\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      target: { kind: \"class\" | \"property\"; name?: string };\n      decorator: DecoratorSpec;\n      importsFrom: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) {\n        throw new Error(`Model file not found at ${args.filePath}`);\n      }\n      let content = fs.readFileSync(args.filePath, \"utf8\");\n      const decorators = new Set<string>([args.decorator.name]);\n      content = ensureImport(content, args.importsFrom, decorators);\n      content = insertDecorator(content, args.decorator, args.target);\n      writeIfChanged(args.filePath, content);\n      return { filePath: args.filePath };\n    },\n  },\n  removeDecoratorTool: {\n    name: \"remove-decorator\",\n    description: \"Remove a decorator from a class or property\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      target: { kind: \"class\" | \"property\"; name?: string };\n      decoratorName: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) return { filePath: args.filePath };\n      let content = fs.readFileSync(args.filePath, \"utf8\");\n      content = removeDecorator(content, args.decoratorName, args.target);\n      writeIfChanged(args.filePath, content);\n      return { filePath: args.filePath };\n    },\n  },\n  scaffoldValidatorTool: {\n    name: \"scaffold-validator\",\n    description: \"Scaffold a validator class and optional decorator\",\n    execute: async (args: {\n      validatorsDir: string;\n      decoratorDir?: string;\n      name: string;\n    }) => {\n      const classFile = path.join(args.validatorsDir, `${args.name}.ts`);\n      ensureDirectory(classFile);\n      const classContent = `export class ${args.name} {\\n  validate(value: unknown): boolean {\\n    return value !== undefined;\\n  }\\n}\\n`;\n      fs.writeFileSync(classFile, classContent);\n      let decoratorFile: string | undefined;\n      if (args.decoratorDir) {\n        decoratorFile = path.join(\n          args.decoratorDir,\n          `${args.name}Decorator.ts`\n        );\n        ensureDirectory(decoratorFile);\n        fs.writeFileSync(\n          decoratorFile,\n          `export function ${args.name}Decorator() {\\n  return () => void 0;\\n}\\n`\n        );\n      }\n      return { classFile, decoratorFile };\n    },\n  },\n  scaffoldSerializerTool: {\n    name: \"scaffold-serializer\",\n    description: \"Scaffold a serializer class and optional registry\",\n    execute: async (args: {\n      dir: string;\n      name: string;\n      registerDir?: string;\n      setDefault?: boolean;\n    }) => {\n      const classFile = path.join(args.dir, `${args.name}.ts`);\n      ensureDirectory(classFile);\n      fs.writeFileSync(\n        classFile,\n        `export class ${args.name} {\\n  serialize(value: unknown): string {\\n    return JSON.stringify(value);\\n  }\\n}\\n`\n      );\n      let registerFile: string | undefined;\n      if (args.registerDir) {\n        registerFile = path.join(args.registerDir, `${args.name}Register.ts`);\n        ensureDirectory(registerFile);\n        fs.writeFileSync(\n          registerFile,\n          `export function register${args.name}() {\\n  return ${args.setDefault ? \"'default'\" : \"'optional'\"};\\n}\\n`\n        );\n      }\n      return { classFile, registerFile };\n    },\n  },\n  scaffoldHashingTool: {\n    name: \"scaffold-hashing\",\n    description: \"Scaffold a hashing function and optional registry\",\n    execute: async (args: {\n      dir: string;\n      name: string;\n      registerDir?: string;\n      setDefault?: boolean;\n    }) => {\n      const functionFile = path.join(args.dir, `${args.name}.ts`);\n      ensureDirectory(functionFile);\n      fs.writeFileSync(\n        functionFile,\n        `export function ${args.name}(value: string): string {\\n  return value.split('').reverse().join('');\\n}\\n`\n      );\n      let registerFile: string | undefined;\n      if (args.registerDir) {\n        registerFile = path.join(args.registerDir, `${args.name}Register.ts`);\n        ensureDirectory(registerFile);\n        fs.writeFileSync(\n          registerFile,\n          `export function register${args.name}() {\\n  return ${args.setDefault ? \"'default'\" : \"'optional'\"};\\n}\\n`\n        );\n      }\n      return { functionFile, registerFile };\n    },\n  },\n} as const;\n\nexport type DecoratorTools = typeof decoratorTools;\n","import fs from \"fs\";\nimport path from \"path\";\nimport { spawnSync } from \"child_process\";\nimport type { ContentResult, Tool } from \"fastmcp\";\nimport {\n  documentObjectSchema,\n  coverageTaskSchema,\n  readmeImprovementSchema,\n} from \"../schemas\";\nimport {\n  DocumentObjectArgs,\n  CoverageTaskArgs,\n  ReadmeImprovementArgs,\n} from \"../types\";\nimport {\n  getWorkspaceRoot,\n  resolveInWorkspace,\n  throwUserError,\n  WorkspaceError,\n} from \"../workspace\";\nimport {\n  buildObjectPrompts,\n  discoverDocPrompts,\n  getObjectPromptDependencies,\n} from \"../prompts/prompts\";\nimport type { DocPrompt } from \"../types\";\nimport { listFilesRecursive, readFileSafe } from \"../utils\";\nimport { analyzeRepo, isSourceFile, isTestFile } from \"../code\";\n\ntype PromptSection = {\n  name: string;\n  title: string;\n  description: string;\n  content: string;\n  absolutePath?: string;\n};\n\nfunction relativeFiles(root: string, files: string[]): string[] {\n  return files.map((file) => path.relative(root, file)).sort();\n}\n\nfunction collectPromptSections(names: readonly string[]): PromptSection[] {\n  const root = getWorkspaceRoot();\n  const promptIndex = new Map<string, DocPrompt>(\n    discoverDocPrompts(root).map((prompt) => [prompt.name, prompt])\n  );\n  return names\n    .map((name) => promptIndex.get(name))\n    .filter((prompt): prompt is DocPrompt => Boolean(prompt))\n    .map((prompt) => ({\n      name: prompt.name,\n      title: prompt.title,\n      description: prompt.description,\n      content: prompt.content,\n      absolutePath: prompt.absolutePath,\n    }));\n}\n\nfunction parseTaskLines(content: string): string[] {\n  return content\n    .split(/\\r?\\n/)\n    .map((line) => line.trim())\n    .filter((line) => /^task\\s+\\d+/i.test(line));\n}\n\nfunction computeCoverageFromFinal(coveragePath: string) {\n  const payload = JSON.parse(fs.readFileSync(coveragePath, \"utf8\")) as Record<\n    string,\n    {\n      s: Record<string, number>;\n      f: Record<string, number>;\n      b: Record<string, number | number[]>;\n    }\n  >;\n\n  const totals = {\n    statements: { covered: 0, total: 0 },\n    functions: { covered: 0, total: 0 },\n    branches: { covered: 0, total: 0 },\n  };\n\n  const files = Object.entries(payload).map(([filePath, info]) => {\n    const statementCounts = Object.values(info.s);\n    const functionCounts = Object.values(info.f);\n    const branchCounts = Object.values(info.b).flatMap((value) =>\n      Array.isArray(value) ? value : [value]\n    );\n\n    const statementTotal = statementCounts.length;\n    const functionTotal = functionCounts.length;\n    const branchTotal = branchCounts.length;\n\n    const statementCovered = statementCounts.filter(\n      (count) => count > 0\n    ).length;\n    const functionCovered = functionCounts.filter((count) => count > 0).length;\n    const branchCovered = branchCounts.filter((count) => count > 0).length;\n\n    totals.statements.covered += statementCovered;\n    totals.statements.total += statementTotal;\n    totals.functions.covered += functionCovered;\n    totals.functions.total += functionTotal;\n    totals.branches.covered += branchCovered;\n    totals.branches.total += branchTotal;\n\n    const pct = (covered: number, total: number) =>\n      total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));\n\n    return {\n      path: filePath,\n      statements: pct(statementCovered, statementTotal),\n      functions: pct(functionCovered, functionTotal),\n      branches: pct(branchCovered, branchTotal),\n    };\n  });\n\n  const pct = (covered: number, total: number) =>\n    total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));\n\n  return {\n    totals: {\n      statements: {\n        ...totals.statements,\n        pct: pct(totals.statements.covered, totals.statements.total),\n      },\n      functions: {\n        ...totals.functions,\n        pct: pct(totals.functions.covered, totals.functions.total),\n      },\n      branches: {\n        ...totals.branches,\n        pct: pct(totals.branches.covered, totals.branches.total),\n      },\n    },\n    files,\n  };\n}\n\nfunction normalizePromptSections(sections: PromptSection[]) {\n  return sections.map((section) => ({\n    name: section.name,\n    title: section.title,\n    tasks: parseTaskLines(section.content),\n    content: section.content,\n  }));\n}\n\nasync function resolveRepoRoot(basePath: string) {\n  const root = getWorkspaceRoot();\n  try {\n    return resolveInWorkspace(root, basePath);\n  } catch (error) {\n    if (error instanceof WorkspaceError) {\n      await throwUserError(error.message);\n    }\n    throw error;\n  }\n}\n\nexport const documentObjectTool: Tool<undefined, typeof documentObjectSchema> =\n  {\n    name: \"document-object\",\n    description:\n      \"Create a documentation plan for a specific object type using .codex prompts and repository analysis.\",\n    parameters: documentObjectSchema,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    execute: async (input, _context): Promise<ContentResult> => {\n      const args = documentObjectSchema.parse(input as DocumentObjectArgs);\n      const repoRoot = await resolveRepoRoot(args.basePath);\n\n      const dependencies = getObjectPromptDependencies()[args.objectType] ?? [];\n      if (!dependencies.length) {\n        await throwUserError(\n          `No prompt guidance configured for object type ${args.objectType}`\n        );\n      }\n\n      const sections = normalizePromptSections(\n        collectPromptSections(dependencies)\n      );\n\n      const srcDir = path.join(repoRoot, \"src\");\n      const testDir = path.join(repoRoot, \"tests\");\n\n      const sourceFiles = fs.existsSync(srcDir)\n        ? listFilesRecursive(srcDir, isSourceFile)\n        : [];\n      const testFiles = fs.existsSync(testDir)\n        ? listFilesRecursive(\n            testDir,\n            (file) => isSourceFile(file) && isTestFile(file)\n          )\n        : [];\n\n      let targetFileContent: string | undefined;\n      if (args.targetFile) {\n        try {\n          const absolute = resolveInWorkspace(repoRoot, args.targetFile);\n          targetFileContent = readFileSafe(absolute) ?? undefined;\n        } catch (error) {\n          if (error instanceof WorkspaceError) {\n            await throwUserError(error.message);\n          }\n          throw error;\n        }\n      }\n\n      const payload = {\n        basePath: path.relative(getWorkspaceRoot(), repoRoot) || \".\",\n        objectType: args.objectType,\n        targetFile: args.targetFile,\n        guidance: sections,\n        files: {\n          source: relativeFiles(repoRoot, sourceFiles),\n          tests: relativeFiles(repoRoot, testFiles),\n        },\n        targetFileContent: args.includeContent ? targetFileContent : undefined,\n      };\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(payload, null, 2),\n          },\n        ],\n      } satisfies ContentResult;\n    },\n  };\n\nexport const coverageEnforcerTool: Tool<undefined, typeof coverageTaskSchema> =\n  {\n    name: \"ensure-test-coverage\",\n    description:\n      \"Run the configured coverage command and report whether the target percentage is met, highlighting weak files.\",\n    parameters: coverageTaskSchema,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    execute: async (input, _context): Promise<ContentResult> => {\n      const args = coverageTaskSchema.parse(input as CoverageTaskArgs);\n      const repoRoot = await resolveRepoRoot(args.basePath);\n\n      if (!args.dryRun) {\n        const env = {\n          ...process.env,\n          USE_WATCHMAN: \"false\",\n          WATCHMAN_DISABLE: \"1\",\n          JEST_DISABLE_WATCHMAN: \"1\",\n        };\n        const result = spawnSync(\n          \"npm\",\n          [\"run\", \"coverage\", \"--\", \"--watchman=false\", \"--runInBand\"],\n          { cwd: repoRoot, env, encoding: \"utf8\" }\n        );\n\n        if (result.status !== 0) {\n          const message =\n            result.stderr || result.stdout || \"Coverage command failed\";\n          await throwUserError(message.trim());\n        }\n      }\n\n      const coveragePath = path.join(\n        repoRoot,\n        \"workdocs\",\n        \"reports\",\n        \"coverage\",\n        \"coverage-final.json\"\n      );\n\n      if (!fs.existsSync(coveragePath)) {\n        await throwUserError(\n          `Coverage report not found at ${path.relative(repoRoot, coveragePath)}`\n        );\n      }\n\n      const summary = computeCoverageFromFinal(coveragePath);\n      const meetsThreshold =\n        summary.totals.statements.pct >= args.coverage &&\n        summary.totals.functions.pct >= args.coverage &&\n        summary.totals.branches.pct >= args.coverage;\n\n      const weakest = [...summary.files]\n        .sort((a, b) => a.statements - b.statements)\n        .slice(0, 10);\n\n      const guidance = normalizePromptSections(\n        collectPromptSections([\"bulk-tests\"])\n      );\n\n      const payload = {\n        basePath: path.relative(getWorkspaceRoot(), repoRoot) || \".\",\n        target: args.coverage,\n        meetsThreshold,\n        totals: summary.totals,\n        weakest,\n        guidance,\n      };\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(payload, null, 2),\n          },\n        ],\n      } satisfies ContentResult;\n    },\n  };\n\nexport const readmeImprovementTool: Tool<\n  undefined,\n  typeof readmeImprovementSchema\n> = {\n  name: \"improve-readme\",\n  description:\n    \"Summarize required steps to refresh README and workdocs content using .codex guidance and repository analysis.\",\n  parameters: readmeImprovementSchema,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (input, _context): Promise<ContentResult> => {\n    const args = readmeImprovementSchema.parse(input as ReadmeImprovementArgs);\n    const repoRoot = await resolveRepoRoot(args.basePath);\n\n    const analysis = analyzeRepo(repoRoot);\n    const modules = analysis.files\n      .filter((file) => /index\\.ts$/.test(file))\n      .map((file) => path.relative(repoRoot, file));\n\n    const promptSections = normalizePromptSections(\n      collectPromptSections([\"update-readme\", \"doc\", \"module\"])\n    );\n\n    const testExamples = Object.keys(analysis.tests ?? {});\n    const examples = args.includeExamples ? testExamples.slice(0, 20) : [];\n\n    const payload = {\n      basePath: path.relative(getWorkspaceRoot(), repoRoot) || \".\",\n      summary: {\n        modules,\n        totalSourceFiles: analysis.files.length,\n        totalTestFiles: analysis.testFiles.length,\n        hasReadme: Boolean(analysis.readme),\n      },\n      guidance: promptSections,\n      suggestedExamples: examples,\n    };\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: JSON.stringify(payload, null, 2),\n        },\n      ],\n    } satisfies ContentResult;\n  },\n};\n","import fs from \"fs\";\nimport path from \"path\";\n\nexport type ScaffoldResult = {\n  modulePath: string;\n  createdFiles: string[];\n};\n\nconst DEFAULT_PLACEHOLDERS = {\n  prompts: `export const promptList = [\n  {\n    id: \"example-prompt\",\n    title: \"Example prompt\",\n    description: \"A placeholder prompt created by scaffoldModule\",\n    content: \"Describe the task for the assistant...\",\n    absolutePath: __filename,\n  },\n] as const;\n`,\n  resources: `export const resources = [\n  {\n    id: \"example-resource\",\n    name: \"Example Resource\",\n    description: \"A placeholder resource created by scaffoldModule\",\n    uri: \"file://placeholder\",\n    absolutePath: __filename,\n  },\n] as const;\n`,\n  templates: `export const templates = [\n  {\n    name: \"example-template\",\n    description: \"A placeholder template created by scaffoldModule\",\n    uriTemplate: \"file://template/{path}\",\n    mimeType: \"text/plain\",\n  },\n] as const;\n`,\n  tools: `export const toolList = [\n  {\n    id: \"example-tool\",\n    name: \"example-tool\",\n    description: \"A placeholder tool created by scaffoldModule\",\n    run: async () => ({ result: \"placeholder\" }),\n  },\n] as const;\n`,\n};\n\n/**\n * Create a module scaffold under repoRoot/src/modules/<moduleName>\n * Returns created files list.\n */\nexport function scaffoldModule(\n  repoRoot: string,\n  moduleName: string\n): ScaffoldResult {\n  if (!repoRoot) throw new Error(\"repoRoot is required\");\n  if (!moduleName) throw new Error(\"moduleName is required\");\n\n  const modulePath = path.join(repoRoot, \"src\", \"modules\", moduleName);\n  const createdFiles: string[] = [];\n\n  const subfolders = [\"prompts\", \"resources\", \"templates\", \"tools\"];\n\n  for (const folder of subfolders) {\n    const folderPath = path.join(modulePath, folder);\n    fs.mkdirSync(folderPath, { recursive: true });\n    const indexPath = path.join(folderPath, \"index.ts\");\n    // if file exists, skip writing\n    if (!fs.existsSync(indexPath)) {\n      // insert __filename for absolutePath in placeholders\n      const content = DEFAULT_PLACEHOLDERS[\n        folder as keyof typeof DEFAULT_PLACEHOLDERS\n      ].replace(/__filename/g, JSON.stringify(indexPath));\n      fs.writeFileSync(indexPath, content, { encoding: \"utf8\" });\n      createdFiles.push(indexPath);\n    }\n  }\n\n  return { modulePath, createdFiles };\n}\n\n// CLI support when required directly via ts-node registration\nif (require.main === module) {\n  const [, , moduleName] = process.argv;\n  if (!moduleName) {\n    console.error(\"Usage: scaffold-module <module-name>\");\n    process.exit(1);\n  }\n  try {\n    const res = scaffoldModule(process.cwd(), moduleName);\n    console.log(\"Scaffolded module:\", res.modulePath);\n    for (const f of res.createdFiles) console.log(\"  created:\", f);\n    process.exit(0);\n  } catch (err: any) {\n    console.error(err && err.message ? err.message : err);\n    process.exit(2);\n  }\n}\n","// New tool: generate-mcp-module\nimport fs from \"fs\";\nimport path from \"path\";\nimport type { Tool } from \"fastmcp\";\nimport { z } from \"zod\";\nimport { getWorkspaceRoot } from \"../workspace\";\nimport { analyzeRepo } from \"../code\";\nimport { scaffoldModule } from \"../validation/scaffoldModule\";\n\nconst generateSchema = z.object({\n  repoPath: z.string().optional().default(\".\"),\n  moduleName: z.string().optional(),\n  includeDocs: z.boolean().default(true),\n});\n\ntype GenerateArgs = z.infer<typeof generateSchema>;\n\nexport const generateMcpModuleTool: Tool<undefined, typeof generateSchema> = {\n  name: \"generate-mcp-module\",\n  description:\n    \"Generate a minimal MCP module under src/modules/<name> by analyzing a target repository and exporting prompts, resources, templates and tools.\",\n  parameters: generateSchema,\n  execute: async (input) => {\n    const args = generateSchema.parse(input as any);\n    const root = getWorkspaceRoot();\n    let repoRoot = path.resolve(process.cwd(), args.repoPath || \".\");\n    if (!fs.existsSync(repoRoot)) {\n      const alt = path.resolve(process.cwd(), \"..\", args.repoPath);\n      if (fs.existsSync(alt)) repoRoot = alt;\n    }\n    if (!fs.existsSync(repoRoot)) {\n      const alt2 = path.resolve(\n        process.cwd(),\n        \"..\",\n        path.basename(args.repoPath)\n      );\n      if (fs.existsSync(alt2)) repoRoot = alt2;\n    }\n    if (!fs.existsSync(repoRoot))\n      throw new Error(`Repository not found at ${repoRoot}`);\n\n    const analysis = analyzeRepo(repoRoot);\n    const inferredName =\n      args.moduleName ?? path.basename(path.resolve(repoRoot));\n    const moduleRoot = path.join(root, \"src\", \"modules\", inferredName);\n\n    // Use existing scaffold to create folders\n    scaffoldModule(root, inferredName);\n\n    // populate prompts: copy markdown prompts from README.md and docs/\n    const promptsDir = path.join(moduleRoot, \"prompts\");\n    const resourcesDir = path.join(moduleRoot, \"resources\");\n    const templatesDir = path.join(moduleRoot, \"templates\");\n    const toolsDir = path.join(moduleRoot, \"tools\");\n\n    // helper to write an index.ts that exports arrays\n    function writeIndex(dir: string, varName: string, items: string) {\n      const p = path.join(dir, \"index.ts\");\n      const content = `export const ${varName} = ${items} as const;\\n`;\n      fs.writeFileSync(p, content, { encoding: \"utf8\" });\n    }\n\n    // Prompts: create a simple prompt from README and any .md in docs\n    const promptAssets: any[] = [];\n    if (args.includeDocs) {\n      const readme = path.join(repoRoot, \"README.md\");\n      if (fs.existsSync(readme)) {\n        const content = fs.readFileSync(readme, \"utf8\");\n        const id = \"readme\";\n        const promptPath = path.join(promptsDir, `${id}.md`);\n        fs.writeFileSync(promptPath, content, { encoding: \"utf8\" });\n        promptAssets.push({\n          id,\n          title: \"README\",\n          description: \"Repository README\",\n          absolutePath: promptPath,\n          load: () => content,\n        });\n      }\n      const docsDir = path.join(repoRoot, \"docs\");\n      if (fs.existsSync(docsDir) && fs.statSync(docsDir).isDirectory()) {\n        for (const f of fs.readdirSync(docsDir)) {\n          if (!f.endsWith(\".md\")) continue;\n          const content = fs.readFileSync(path.join(docsDir, f), \"utf8\");\n          const id = path.parse(f).name;\n          const promptPath = path.join(promptsDir, `${id}.md`);\n          fs.writeFileSync(promptPath, content, { encoding: \"utf8\" });\n          promptAssets.push({\n            id,\n            title: id,\n            description: content.split(/\\r?\\n/)[0] || \"\",\n            absolutePath: promptPath,\n            load: () => content,\n          });\n        }\n      }\n    }\n\n    writeIndex(promptsDir, \"prompts\", JSON.stringify(promptAssets, null, 2));\n\n    // Resources: reference the repo root and docs\n    const resourceAssets = [\n      {\n        id: `${inferredName}.repo`,\n        name: `${inferredName} repository`,\n        description: \"Source repository\",\n        uri: `file://${repoRoot}`,\n        absolutePath: repoRoot,\n      },\n    ];\n    writeIndex(\n      resourcesDir,\n      \"resources\",\n      JSON.stringify(resourceAssets, null, 2)\n    );\n\n    // Templates: create a placeholder template that references README\n    const templateAssets = [\n      {\n        name: \"readme-template\",\n        description: \"README as guidance\",\n        uriTemplate: `file://${path.join(repoRoot, \"README.md\")}`,\n        mimeType: \"text/markdown\",\n      },\n    ];\n    writeIndex(\n      templatesDir,\n      \"templates\",\n      JSON.stringify(templateAssets, null, 2)\n    );\n\n    // Tools: create a wrapper tool that exposes analyze/enumerate for the module\n    const toolIndexPath = path.join(toolsDir, \"index.ts\");\n    const toolContent = `import type { Tool } from 'fastmcp';\\nimport { buildAnalyzeRepositoryTool, buildEnumerateCapabilitiesTool, buildPlanFeatureTool } from '../../../mcp/tools/tools';\\nexport const tools = [\\n  { id: '${inferredName}.analyze', title: 'Analyze ${inferredName}', description: 'Analyze the target repository', tool: buildAnalyzeRepositoryTool() },\\n  { id: '${inferredName}.enumerate', title: 'Enumerate capabilities for ${inferredName}', description: 'Enumerate capabilities', tool: buildEnumerateCapabilitiesTool() },\\n  { id: '${inferredName}.plan', title: 'Plan features for ${inferredName}', description: 'Plan feature implementation', tool: buildPlanFeatureTool() },\\n] as const;\\n`;\n    fs.writeFileSync(toolIndexPath, toolContent, { encoding: \"utf8\" });\n\n    // Write module index.ts\n    const moduleIndex = path.join(moduleRoot, \"index.ts\");\n    const moduleIndexContent = `import { prompts } from './prompts';\\nimport { resources } from './resources';\\nimport { templates } from './templates';\\nimport { tools } from './tools';\\nexport { prompts } from './prompts';\\nexport { resources } from './resources';\\nexport { templates } from './templates';\\nexport { tools } from './tools';\\nexport const modulePackage = { name: '${inferredName}', prompts, resources, templates, tools } as const;\\n`;\n    fs.writeFileSync(moduleIndex, moduleIndexContent, { encoding: \"utf8\" });\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: JSON.stringify(\n            {\n              moduleRoot,\n              inferredName,\n              analysisSummary: {\n                files: analysis.files.length,\n                testFiles: analysis.testFiles.length,\n              },\n            },\n            null,\n            2\n          ),\n        },\n      ],\n    };\n  },\n};\n\nexport default generateMcpModuleTool;\n","import { decoratorTools } from \"../decorator-tools\";\nimport { moduleRegistry } from \"../moduleRegistry\";\nimport {\n  applyCodeChangeTool,\n  documentCodeTool,\n  toolList as coreToolList,\n} from \"./tools\";\nimport {\n  coverageEnforcerTool,\n  documentObjectTool,\n  readmeImprovementTool,\n} from \"./codex-tools\";\n\nexport * from \"./tools\";\nexport * from \"./codex-tools\";\nexport * from \"./generateMcpModule\";\n\nconst codexToolList = [\n  documentObjectTool,\n  coverageEnforcerTool,\n  readmeImprovementTool,\n];\n\nconst moduleToolList = moduleRegistry.listTools().map((asset) => asset.tool as any);\n\nexport const toolList = [...coreToolList, ...codexToolList, ...moduleToolList];\nexport const decoratorToolList = Object.values(decoratorTools);\nconst [\n  analyzeRepositoryTool,\n  enumerateCapabilitiesTool,\n  planFeatureTool,\n  documentCodeToolRef,\n  applyCodeChangeToolRef,\n] = coreToolList;\n\nexport const tools = {\n  analyzeRepositoryTool,\n  enumerateCapabilitiesTool,\n  planFeatureTool,\n  documentCodeTool: documentCodeToolRef,\n  applyCodeChangeTool: applyCodeChangeToolRef,\n  documentObjectTool,\n  coverageEnforcerTool,\n  readmeImprovementTool,\n  ...decoratorTools,\n};\n\nexport { decoratorTools };","import type { Resource } from \"fastmcp\";\nimport type { ResourceAsset } from \"../../types\";\nimport { moduleRegistry } from \"../moduleRegistry\";\nimport { getWorkspaceRoot } from \"../workspace\";\nimport { buildObjectPrompts, discoverDocPrompts } from \"../prompts/prompts\";\n\nfunction toResource(asset: ResourceAsset): Resource<undefined> {\n  return {\n    name: asset.id,\n    uri: asset.uri,\n    description: asset.description ?? asset.title,\n    mimeType: asset.mimeType,\n    load: async () => {\n      const res = await asset.load();\n      // asset.load may return a ContentResult or a Promise of ContentResult; ensure we return ResourceResult-like object\n      if ((res as any)?.content) {\n        const cr = res as any;\n        // If ContentResult, convert to simple text result expected by Resource.load consumers\n        return {\n          text: Array.isArray(cr.content)\n            ? cr.content.map((c: any) => c.text).join(\"\\n\")\n            : String(cr),\n        };\n      }\n      // fallback for objects with text\n      return res as any as { text: string };\n    },\n  };\n}\n\nfunction buildModuleResources(): Resource<undefined>[] {\n  return moduleRegistry.listResources().map(toResource);\n}\n\nexport const resources: Resource<undefined>[] = [\n  {\n    name: \"codex-prompt-index\",\n    uri: \"codex://prompts/index\",\n    description:\n      \"Enumerate available .codex prompt files with titles and descriptions.\",\n    mimeType: \"application/json\",\n    load: async () => {\n      const root = getWorkspaceRoot();\n      const prompts = discoverDocPrompts(root).map((prompt) => ({\n        name: prompt.name,\n        title: prompt.title,\n        description: prompt.description,\n        path: prompt.absolutePath,\n      }));\n      return {\n        text: JSON.stringify({ prompts }, null, 2),\n        mimeType: \"application/json\",\n      };\n    },\n  },\n  {\n    name: \"codex-object-prompts\",\n    uri: \"codex://prompts/objects\",\n    description:\n      \"Provides the resolved prompt content for each documented object workflow.\",\n    mimeType: \"application/json\",\n    load: async () => {\n      const entries = await Promise.all(\n        buildObjectPrompts().map(async (prompt) => ({\n          name: prompt.name,\n          description: prompt.description,\n          content: await prompt.load({} as never),\n        }))\n      );\n      return {\n        text: JSON.stringify({ prompts: entries }, null, 2),\n        mimeType: \"application/json\",\n      };\n    },\n  },\n  ...buildModuleResources(),\n];\n","import path from \"path\";\nimport fs from \"fs\";\nimport { getWorkspaceRoot, resolveInWorkspace } from \"../workspace\";\nimport type { PromptResourceTemplate } from \"../types\";\n\nexport const codexPromptTemplates: PromptResourceTemplate[] = [];\n\nexport function buildCodexPromptTemplates(): PromptResourceTemplate[] {\n  const root = getWorkspaceRoot();\n  const templates: PromptResourceTemplate[] = [\n    {\n      name: \"codex-prompt\",\n      description:\n        \"Load a .codex prompt file by name (without extension) as markdown.\",\n      uriTemplate: \"codex-prompt://{name}\",\n      mimeType: \"text/markdown\",\n      arguments: [\n        {\n          name: \"name\",\n          description:\n            \"Name of the prompt file inside .codex/prompts (without .md).\",\n          required: true,\n        },\n      ],\n      load: async ({ name }) => {\n        const promptPath = resolveInWorkspace(\n          root,\n          path.join(\".codex\", \"prompts\", `${name}.md`)\n        );\n        if (!fs.existsSync(promptPath)) {\n          throw new Error(`Prompt .codex/prompts/${name}.md not found`);\n        }\n        const text = fs.readFileSync(promptPath, \"utf8\");\n        return { text, uri: `codex-prompt:///${name}` };\n      },\n    },\n  ];\n\n  codexPromptTemplates.splice(0, codexPromptTemplates.length, ...templates);\n  return codexPromptTemplates;\n}\n","import path from \"path\";\nimport type { DecorationResourceTemplate } from \"../types\";\nimport { getWorkspaceRoot, readWorkspaceFile } from \"../workspace\";\n\nexport const decorationResourceTemplates: DecorationResourceTemplate[] = [];\n\nfunction makeLoader(type: \"src\" | \"tests\" | \"workdocs\") {\n  return async ({ path: relative }: { path: string }) => {\n    const root = getWorkspaceRoot();\n    const target = path.join(type, relative);\n    const text = await readWorkspaceFile(root, target);\n    return { text };\n  };\n}\n\nexport function buildDecorationResourceTemplates(): DecorationResourceTemplate[] {\n  const templates: DecorationResourceTemplate[] = [\n    {\n      name: \"read-code-from-source\",\n      description:\n        \"Read a file from the <base_path>/src tree by relative path.\",\n      mimeType: \"text/plain\",\n      uriTemplate: \"from-source://src/{path}\",\n      arguments: [\n        {\n          name: \"path\",\n          description:\n            \"Path under <base_path>/src to load, e.g. 'decoration/types.ts'\",\n          required: true,\n        },\n      ],\n      load: makeLoader(\"src\"),\n    },\n    {\n      name: \"read-test-from-source\",\n      description:\n        \"Read a file from the <base_path>/tests tree by relative path.\",\n      mimeType: \"text/plain\",\n      uriTemplate: \"from-source://tests/{path}\",\n      arguments: [\n        {\n          name: \"path\",\n          description:\n            \"Path under <base_path>/tests to load, e.g. 'decoration/tests/types.test.ts'\",\n          required: true,\n        },\n      ],\n      load: makeLoader(\"tests\"),\n    },\n    {\n      name: \"read-doc-from-source\",\n      description:\n        \"Read a file from the <base_path>/workdocs tree by relative path.\",\n      mimeType: \"text/plain\",\n      uriTemplate: \"from-source://workdocs/{path}\",\n      arguments: [\n        {\n          name: \"path\",\n          description:\n            \"Path under <base_path>/workdocs to load, e.g. 'decoration/workdocs/tutorials/for-developers.md'\",\n          required: true,\n        },\n      ],\n      load: makeLoader(\"workdocs\"),\n    },\n  ];\n\n  decorationResourceTemplates.splice(\n    0,\n    decorationResourceTemplates.length,\n    ...templates\n  );\n  return decorationResourceTemplates;\n}\n","import { WorkspaceResourceTemplate } from \"../types\";\nimport { getWorkspaceRoot, readWorkspaceFile } from \"../workspace\";\n\nexport const workspaceResourceTemplates: WorkspaceResourceTemplate[] = [];\n\nexport function buildWorkspaceResourceTemplates(): WorkspaceResourceTemplate[] {\n  const root = getWorkspaceRoot();\n  const sharedArguments = [\n    {\n      name: \"path\",\n      description: \"Path relative to the workspace root\",\n      required: true,\n    },\n  ] as const;\n\n  const templates: WorkspaceResourceTemplate[] = [\n    {\n      name: \"vscode-workspace-file\",\n      description:\n        \"Expose workspace files to Visual Studio Code via vscode:// URIs\",\n      uriTemplate: \"vscode://workspace/{path}\",\n      mimeType: \"text/plain\",\n      arguments: sharedArguments,\n      load: async (args: { path: string }) => {\n        try {\n          const text = await readWorkspaceFile(root, args.path);\n          return { text: String(text) };\n        } catch (err) {\n          // propagate as-is for tests to assert errors\n          throw err;\n        }\n      },\n    },\n    {\n      name: \"cursor-workspace-file\",\n      description: \"Expose workspace files to Cursor via cursor:// URIs\",\n      uriTemplate: \"cursor://workspace/{path}\",\n      mimeType: \"text/plain\",\n      arguments: sharedArguments,\n      load: async (args: { path: string }) => {\n        try {\n          const text = await readWorkspaceFile(root, args.path);\n          return { text: String(text) };\n        } catch (err) {\n          throw err;\n        }\n      },\n    },\n    {\n      name: \"copilot-workspace-file\",\n      description:\n        \"Expose workspace files to GitHub Copilot via copilot:// URIs\",\n      uriTemplate: \"copilot://workspace/{path}\",\n      mimeType: \"text/plain\",\n      arguments: sharedArguments,\n      load: async (args: { path: string }) => {\n        try {\n          const text = await readWorkspaceFile(root, args.path);\n          return { text: String(text) };\n        } catch (err) {\n          throw err;\n        }\n      },\n    },\n  ];\n\n  workspaceResourceTemplates.splice(\n    0,\n    workspaceResourceTemplates.length,\n    ...templates\n  );\n  return workspaceResourceTemplates;\n}\n\n","import {\n  buildCodexPromptTemplates,\n  codexPromptTemplates,\n} from \"./codex-templates\";\nimport {\n  buildDecorationResourceTemplates,\n  decorationResourceTemplates,\n} from \"./resource-templates\";\nimport {\n  buildWorkspaceResourceTemplates,\n  workspaceResourceTemplates,\n} from \"./workspace-templates\";\nimport type { TemplateAsset } from \"../../types\";\nimport { moduleRegistry } from \"../moduleRegistry\";\n\nexport {\n  buildCodexPromptTemplates,\n  codexPromptTemplates,\n} from \"./codex-templates\";\nexport {\n  buildDecorationResourceTemplates,\n  decorationResourceTemplates,\n} from \"./resource-templates\";\nexport {\n  buildWorkspaceResourceTemplates,\n  workspaceResourceTemplates,\n} from \"./workspace-templates\";\n\nexport function buildResourceTemplates() {\n  const moduleTemplates = moduleRegistry.listTemplates().map((template) => ({\n    name: template.id,\n    description: template.description ?? template.title,\n    mimeType: \"text/markdown\",\n    uriTemplate: `module-template://${template.id}`,\n    arguments: (template.placeholders ?? []).map((name) => ({\n      name,\n      description: `Value for ${name}`,\n      required: true,\n    })),\n    load: async () => ({\n      text:\n        typeof (template as any).content === \"string\"\n          ? (template as any).content\n          : `# ${template.description ?? template.title ?? template.id}\\n\\nNo template content available for ${template.id}`,\n    }),\n  }));\n\n  const all = [\n    ...buildWorkspaceResourceTemplates(),\n    ...buildCodexPromptTemplates(),\n    ...buildDecorationResourceTemplates(),\n    ...moduleTemplates,\n  ];\n\n  // Normalise all loaders to always return { text: string }\n  function normaliseResult(res: any) {\n    if (res == null) return { text: \"\" };\n    if (typeof res === \"string\") return { text: res };\n    if (typeof res.text === \"string\") return res;\n    // handle legacy ContentResult shapes with content or content array\n    if (Array.isArray(res.content)) {\n      const parts = res.content\n        .map((c: any) => (c && typeof c.text === \"string\" ? c.text : String(c)))\n        .join(\"\\n\");\n      return { text: parts };\n    }\n    if (res.content && typeof res.content.text === \"string\") {\n      return { text: res.content.text };\n    }\n    // fallback: stringify\n    try {\n      return { text: JSON.stringify(res) };\n    } catch {\n      return { text: String(res) };\n    }\n  }\n\n  return all.map((t) => ({\n    ...t,\n    load: async (args: any) => {\n      const raw = await (t.load as any)(args);\n      return normaliseResult(raw);\n    },\n  }));\n}\n\nexport const templateList = buildResourceTemplates();\n","import { Metadata } from \"@decaf-ts/decoration\";\n\n/**\n * @const VERSION\n * @name VERSION\n * @description Represents the current version of the ts-workspace module.\n * @summary The actual version number is replaced during the build process.\n * @type {string}\n */\nexport const VERSION = \"##VERSION##\";\nexport const PACKAGE_NAME = \"##PACKAGE_NAME##\";\n\ntry {\n  Metadata.registerLibrary(PACKAGE_NAME, VERSION);\n} catch (error) {\n  if (error instanceof Error && error.message.includes(\"already\")) {\n    // Ignore duplicate registration during tests/bundling checks.\n  } else {\n    throw error;\n  }\n}\n","import type { FastMCP } from \"fastmcp\";\nimport { PACKAGE_NAME as PKG, VERSION as V } from \"../metadata\";\nimport {\n  buildDocPrompts,\n  buildPrompts,\n  buildDocumentationPayload,\n  discoverDocPrompts,\n  loadPrompts,\n  promptList,\n  refreshPrompts,\n  selectPrompt,\n  DEFAULT_PROMPT_NAME,\n} from \"./prompts\";\nimport { resources } from \"./resources\";\nimport {\n  buildDecorationResourceTemplates,\n  buildResourceTemplates,\n  decorationResourceTemplates,\n  templateList,\n  workspaceResourceTemplates,\n} from \"./templates\";\nimport { toolList, tools } from \"./tools\";\nimport {\n  __resetWorkspaceRoot,\n  getWorkspaceRoot,\n  setWorkspaceRoot,\n} from \"./workspace\";\n\nexport function enrich(mcp: FastMCP): FastMCP {\n  const promptEntries = loadPrompts();\n  for (const prompt of promptEntries) {\n    mcp.addPrompt(prompt as any);\n  }\n\n  for (const tool of toolList) {\n    mcp.addTool(tool as any);\n  }\n\n  const templates = buildResourceTemplates();\n  for (const template of templates) {\n    mcp.addResourceTemplate(template as any);\n  }\n\n  for (const resource of resources) {\n    const addResource = (mcp as unknown as { addResource?: (res: unknown) => void }).addResource;\n    if (typeof addResource === \"function\") {\n      addResource.call(mcp, resource as any);\n    }\n  }\n\n  return mcp;\n}\n\nexport default enrich;\nexport const PACKAGE_NAME = PKG;\nexport const VERSION = V;\n\nexport {\n  tools,\n  toolList,\n  buildDocPrompts,\n  buildPrompts,\n  buildDecorationResourceTemplates,\n  buildResourceTemplates,\n  buildDocumentationPayload,\n  decorationResourceTemplates,\n  discoverDocPrompts,\n  DEFAULT_PROMPT_NAME,\n  promptList,\n  refreshPrompts,\n  resources,\n  selectPrompt,\n  templateList,\n  workspaceResourceTemplates,\n  getWorkspaceRoot,\n  setWorkspaceRoot,\n  __resetWorkspaceRoot,\n};\n","// New: validation entrypoint for module structure\nimport fs from \"fs\";\nimport path from \"path\";\n\nexport type ValidationIssue = {\n  module: string;\n  path: string;\n  type:\n    | \"missing-folder\"\n    | \"missing-export\"\n    | \"empty-list\"\n    | \"disabled\"\n    | \"other\";\n  detail?: string;\n};\n\nexport type ValidationReport = {\n  ok: boolean;\n  modulesChecked: number;\n  issues: ValidationIssue[];\n};\n\nconst REQUIRED_SUBFOLDERS = [\"prompts\", \"resources\", \"templates\", \"tools\"];\n\nexport function findModuleDirs(repoRoot: string): string[] {\n  const modulesPath = path.resolve(repoRoot, \"src\", \"modules\");\n  if (!fs.existsSync(modulesPath) || !fs.statSync(modulesPath).isDirectory()) {\n    return [];\n  }\n  return fs\n    .readdirSync(modulesPath, { withFileTypes: true })\n    .filter((d) => d.isDirectory())\n    .map((d) => path.join(modulesPath, d.name));\n}\n\nfunction hasIndexExport(folderPath: string): boolean {\n  const candidates = [\n    \"index.ts\",\n    \"index.tsx\",\n    \"index.js\",\n    \"index.cjs\",\n    \"index.mjs\",\n  ];\n  for (const c of candidates) {\n    if (fs.existsSync(path.join(folderPath, c))) return true;\n  }\n  return false;\n}\n\nexport function validateModules(repoRoot: string): ValidationReport {\n  const dirs = findModuleDirs(repoRoot);\n  const issues: ValidationIssue[] = [];\n\n  for (const moduleDir of dirs) {\n    const moduleName = path.basename(moduleDir);\n    for (const sub of REQUIRED_SUBFOLDERS) {\n      const subPath = path.join(moduleDir, sub);\n      if (!fs.existsSync(subPath) || !fs.statSync(subPath).isDirectory()) {\n        issues.push({\n          module: moduleName,\n          path: subPath,\n          type: \"missing-folder\",\n          detail: `Required folder '${sub}' is missing in module '${moduleName}'`,\n        });\n        continue;\n      }\n      // If folder exists, check for index export\n      if (!hasIndexExport(subPath)) {\n        issues.push({\n          module: moduleName,\n          path: subPath,\n          type: \"missing-export\",\n          detail: `No index export found in '${subPath}'. Expected one of index.ts, index.js, etc.`,\n        });\n        continue;\n      }\n      // Optionally inspect the index file to see if it exports a list (lightweight check)\n      try {\n        const indexFile = candidatesFindingIndex(subPath);\n        if (indexFile) {\n          const content = fs.readFileSync(indexFile, \"utf8\");\n          // crude heuristics: look for `export const name = [` or `export const name: Type[] = [`,\n          // or any named export like `export { something }` which implies exports exist.\n          const exportListPattern =\n            /export\\s+(const|let|var)\\s+[\\w$]+(?:\\s*:\\s*[^=]+)?\\s*=\\s*\\[/;\n          if (\n            !exportListPattern.test(content) &&\n            !/export\\s+\\{/.test(content)\n          ) {\n            issues.push({\n              module: moduleName,\n              path: indexFile,\n              type: \"empty-list\",\n              detail: `Index file does not appear to export a list of assets: ${path.basename(indexFile)}`,\n            });\n          }\n        }\n      } catch (err: any) {\n        issues.push({\n          module: moduleName,\n          path: subPath,\n          type: \"other\",\n          detail: `Error reading index file: ${err.message}`,\n        });\n      }\n    }\n  }\n\n  return {\n    ok: issues.length === 0,\n    modulesChecked: dirs.length,\n    issues,\n  };\n}\n\nfunction candidatesFindingIndex(folderPath: string): string | undefined {\n  const candidates = [\n    \"index.ts\",\n    \"index.tsx\",\n    \"index.js\",\n    \"index.cjs\",\n    \"index.mjs\",\n  ];\n  for (const c of candidates) {\n    const full = path.join(folderPath, c);\n    if (fs.existsSync(full)) return full;\n  }\n  return undefined;\n}\n\n// CLI helper\nif (require.main === module) {\n  const repoRoot = process.cwd();\n  const report = validateModules(repoRoot);\n  if (!report.ok) {\n    console.error(\n      \"Module validation failed:\\n\",\n      JSON.stringify(report, null, 2)\n    );\n    process.exit(2);\n  }\n  console.log(\"Module validation passed\");\n  process.exit(0);\n}\n","// Aggregator: import module index files and merge exported arrays with provenance + duplicate detection\nimport path from \"path\";\nimport fs from \"fs\";\nimport { pathToFileURL } from \"url\";\nimport { findModuleDirs } from \"./validation\";\n\nexport type Provenance = { moduleName: string; modulePath: string };\nexport type AggregationConflict = {\n  key: string;\n  existing: Provenance;\n  incoming: Provenance;\n};\n\nexport type AggregationResult<T = any> = {\n  prompts: Array<T & { provenance: Provenance }>;\n  resources: Array<T & { provenance: Provenance }>;\n  templates: Array<T & { provenance: Provenance }>;\n  tools: Array<T & { provenance: Provenance }>;\n  conflicts: AggregationConflict[];\n};\n\nconst SUBFOLDERS = [\"prompts\", \"resources\", \"templates\", \"tools\"];\nconst INDEX_CANDIDATES = [\n  \"index.ts\",\n  \"index.tsx\",\n  \"index.js\",\n  \"index.cjs\",\n  \"index.mjs\",\n];\n\nfunction findIndexFile(folder: string): string | undefined {\n  for (const c of INDEX_CANDIDATES) {\n    const f = path.join(folder, c);\n    if (fs.existsSync(f)) return f;\n  }\n  return undefined;\n}\n\nfunction makeKeyForItem(item: any): string {\n  if (!item) return JSON.stringify(item);\n  if (typeof item === \"string\") return `str:${item}`;\n  if (typeof item === \"number\") return `num:${item}`;\n  if (item.id) return `id:${item.id}`;\n  if (item.name) return `name:${item.name}`;\n  // fallback to stable string\n  try {\n    return `obj:${JSON.stringify(item)}`;\n  } catch (e) {\n    return `obj:${String(item)}`;\n  }\n}\n\nasync function loadArrayFromIndex(\n  filePath: string\n): Promise<any[] | undefined> {\n  // Prefer a fast, static parse of the first array literal found in the file.\n  try {\n    const content = fs.readFileSync(filePath, \"utf8\");\n    const start = content.indexOf(\"[\");\n    if (start !== -1) {\n      let depth = 0;\n      let end = -1;\n      for (let i = start; i < content.length; i++) {\n        const ch = content[i];\n        if (ch === \"[\") depth++;\n        else if (ch === \"]\") {\n          depth--;\n          if (depth === 0) {\n            end = i;\n            break;\n          }\n        }\n      }\n      if (end !== -1) {\n        const arrText = content.slice(start, end + 1);\n        try {\n          return JSON.parse(arrText);\n        } catch (e) {\n          // Normalize TS object literals to JSON:\n          // - convert single quotes to double quotes\n          // - quote unquoted object keys\n          // - strip trailing commas\n          const normalized = arrText\n            // unify quotes in string literals\n            .replace(/'(?:\\\\'|[^'])*'/g, (m) => m.replace(/'/g, '\"'))\n            // quote unquoted keys after { or ,\n            .replace(/([\\{,]\\s*)([A-Za-z_$][\\w$]*)(\\s*:)/g, '$1\"$2\"$3')\n            // remove trailing commas before ] or }\n            .replace(/,(\\s*[\\}\\]])/g, '$1');\n          try {\n            return JSON.parse(normalized);\n          } catch (e2) {\n            // fallthrough to import attempt below\n          }\n        }\n      }\n    }\n  } catch (e) {\n    // ignore static parse errors and fall back to import\n  }\n\n  try {\n    const fileUrl = pathToFileURL(filePath).href;\n    const mod = await import(fileUrl);\n    // Find first export that is an array\n    for (const key of Object.keys(mod)) {\n      const val = (mod as any)[key];\n      if (Array.isArray(val)) return val;\n    }\n    // default export check\n    if (Array.isArray((mod as any).default)) return (mod as any).default;\n    return undefined;\n  } catch (err) {\n    // fallback: if import fails, try to static-parse again (already attempted) and finally return undefined\n    return undefined;\n  }\n}\n\nexport async function aggregateModules(\n  repoRoot: string\n): Promise<AggregationResult> {\n  const dirs = findModuleDirs(repoRoot);\n  const master = {\n    prompts: [] as any[],\n    resources: [] as any[],\n    templates: [] as any[],\n    tools: [] as any[],\n    conflicts: [] as AggregationConflict[],\n  };\n\n  // maps to detect duplicates per type\n  const maps: Record<string, Map<string, Provenance>> = {\n    prompts: new Map(),\n    resources: new Map(),\n    templates: new Map(),\n    tools: new Map(),\n  };\n\n  for (const moduleDir of dirs) {\n    const moduleName = path.basename(moduleDir);\n    for (const sub of SUBFOLDERS) {\n      const folder = path.join(moduleDir, sub);\n      const indexFile = findIndexFile(folder);\n      if (!indexFile) continue;\n      let arr: any[] | undefined;\n      try {\n        arr = await loadArrayFromIndex(indexFile);\n      } catch (err: any) {\n        // skip module on import error but record as conflict-like issue\n        master.conflicts.push({\n          key: `import-error:${moduleName}:${sub}`,\n          existing: { moduleName, modulePath: moduleDir },\n          incoming: { moduleName, modulePath: moduleDir },\n        });\n        continue;\n      }\n      if (!arr || !Array.isArray(arr)) continue;\n\n      for (const item of arr) {\n        const key = makeKeyForItem(item);\n        const provenance = { moduleName, modulePath: moduleDir };\n        const map = maps[sub];\n        if (map.has(key)) {\n          // record conflict deterministically (existing vs incoming)\n          const existing = map.get(key)!;\n          master.conflicts.push({ key, existing, incoming: provenance });\n          // skip adding duplicate\n          continue;\n        }\n        map.set(key, provenance);\n        (master as any)[sub].push({ ...item, provenance });\n      }\n    }\n  }\n\n  return master;\n}\n\n// For compatibility with CommonJS call sites (not exported by ESM), provide a sync wrapper\nexport function aggregateModulesSync(repoRoot: string) {\n  // synchronous wrapper that runs the async function and blocks — suitable for small module sets\n  const p = aggregateModules(repoRoot);\n  let result: any;\n  let done = false;\n  p.then((r) => {\n    result = r;\n    done = true;\n  }).catch((e) => {\n    throw e;\n  });\n  // spin-wait (acceptable in small dev scripts)\n  const until = Date.now() + 5000;\n  while (!done && Date.now() < until) {}\n  if (!done)\n    throw new Error(\n      \"aggregateModulesSync: timeout waiting for async aggregation\"\n    );\n  return result as AggregationResult;\n}\n","import { aggregateModules } from \"./aggregateModules\";\nimport { loadPrompts, promptList } from \"./prompts\";\nimport { toolList } from \"./tools\";\nimport { resources } from \"./resources\";\nimport { buildResourceTemplates } from \"./templates\";\n\nexport type FastMCPLike = {\n  addPrompt: (p: any) => void;\n  addTool: (t: any) => void;\n  addResource: (r: any) => void;\n  addResourceTemplate: (t: any) => void;\n};\n\n/**\n * Aggregate module assets and register them on the provided FastMCP-like server.\n * Falls back to built-in lists if aggregation yields none.\n */\nexport async function EnrichCoreWithAggregation(\n  server: FastMCPLike,\n  repoRoot = process.cwd()\n) {\n  // First register built-in prompts/tools/resources/templates (legacy behavior)\n  try {\n    loadPrompts();\n    for (const prompt of promptList) server.addPrompt(prompt as any);\n  } catch (e) {\n    // ignore if loadPrompts not available or fails\n  }\n\n  try {\n    for (const tool of toolList) server.addTool(tool as any);\n  } catch (e) {}\n\n  try {\n    for (const resource of resources) server.addResource(resource as any);\n  } catch (e) {}\n\n  try {\n    const templates = buildResourceTemplates();\n    for (const template of templates)\n      server.addResourceTemplate(template as any);\n  } catch (e) {}\n\n  // Now aggregate modules and register aggregated assets with provenance\n  const agg = await aggregateModules(repoRoot);\n\n  for (const p of agg.prompts) {\n    server.addPrompt(p);\n  }\n  for (const t of agg.tools) {\n    server.addTool(t);\n  }\n  for (const r of agg.resources) {\n    server.addResource(r);\n  }\n  for (const tpl of agg.templates) {\n    server.addResourceTemplate(tpl);\n  }\n\n  // return aggregation summary for calling tests/CI\n  return {\n    modulesChecked: agg.prompts.concat(agg.tools).length,\n    conflicts: agg.conflicts,\n  };\n}\n","import { FastMCP } from \"fastmcp\";\nimport { loadPrompts, promptList } from \"./prompts\";\nimport { toolList } from \"./tools\";\nimport { resources } from \"./resources\";\nimport { buildResourceTemplates } from \"./templates\";\n\nexport * from \"./mcp-module\";\nexport { default } from \"./mcp-module\";\n\nexport { validateModules } from \"./validation\";\nexport { aggregateModules, aggregateModulesSync } from \"./aggregateModules\";\nexport { EnrichCoreWithAggregation } from \"./fastmcp-wiring\";\n\nexport function EnrichCore(server: FastMCP) {\n  loadPrompts();\n  for (const prompt of promptList) {\n    server.addPrompt(prompt as any);\n  }\n  for (const tool of toolList) {\n    server.addTool(tool as any);\n  }\n  for (const resource of resources) {\n    server.addResource(resource as any);\n  }\n  const templates = buildResourceTemplates();\n  for (const template of templates) {\n    server.addResourceTemplate(template as any);\n  }\n}\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { getWorkspaceRoot } from \"../mcp/workspace\";\n\nexport const REQUIRED_MODULE_FOLDERS = [\n  \"prompts\",\n  \"resources\",\n  \"templates\",\n  \"tools\",\n] as const;\n\nexport type ModuleFolder = (typeof REQUIRED_MODULE_FOLDERS)[number];\n\nexport function resolveModulesRoot(workspaceRoot = getWorkspaceRoot()): string {\n  return path.resolve(workspaceRoot, \"src/modules\");\n}\n\nexport function listModuleDirectories(workspaceRoot = getWorkspaceRoot()): string[] {\n  const root = resolveModulesRoot(workspaceRoot);\n  if (!fs.existsSync(root)) return [];\n\n  return fs\n    .readdirSync(root)\n    .map((entry) => ({\n      entry,\n      absolute: path.join(root, entry),\n    }))\n    .filter(({ absolute }) => fs.statSync(absolute).isDirectory())\n    .map(({ entry }) => entry)\n    .sort();\n}\n\nexport function resolveModulePath(\n  moduleName: string,\n  workspaceRoot = getWorkspaceRoot()\n): string {\n  return path.join(resolveModulesRoot(workspaceRoot), moduleName);\n}\n\nexport function resolveModuleFolderPath(\n  moduleName: string,\n  folder: ModuleFolder,\n  workspaceRoot = getWorkspaceRoot()\n): string {\n  return path.join(resolveModulePath(moduleName, workspaceRoot), folder);\n}\n","/* istanbul ignore file */\nimport path from \"path\";\nimport fs from \"fs\";\nimport { McpModule } from \"./types\";\n\n/**\n * @description Utility class for CLI operations\n * @summary A static utility class that provides methods for loading modules, retrieving package information, and initializing CLI commands\n *\n * @example\n * // Initialize a Command object with package information\n * const command = new Command();\n * CLIUtils.initialize(command, './path/to/package');\n *\n * // Load a CLI module from a file\n * const module = await CLIUtils.loadFromFile('./path/to/cli-module.js');\n *\n * @class McpUtils\n */\nexport class McpUtils {\n  /**\n   * @description Dynamically imports a module file\n   * @summary Loads a JavaScript file and returns it as a CliModule, handling both ESM and CommonJS formats\n   *\n   * @param {string} path The file path to the module to load\n   * @return {Promise<McpModule>} A promise that resolves to the loaded CliModule\n   */\n  static async loadFromFile(path: string): Promise<McpModule> {\n    try {\n      return McpUtils.normalizeImport(import(path));\n    } catch (e: unknown) {\n      throw new Error(\n        `Failed to load from ${path}: ${e instanceof Error ? e.message : e}`\n      );\n    }\n  }\n\n  /**\n   * @description Normalizes module imports to handle both ESM and CommonJS formats\n   * @summary Properly imports JavaScript files regardless of their module format by handling the ESM wrapper for CommonJS modules\n   *\n   * @template T The type of the imported module\n   * @param {Promise<T>} importPromise The promise returned by the dynamic import\n   * @return {Promise<T>} A promise that resolves to the normalized module\n   * @private\n   */\n  static async normalizeImport<T>(importPromise: Promise<T>): Promise<T> {\n    // CommonJS's `module.exports` is wrapped as `default` in ESModule.\n    return importPromise.then(\n      (m: unknown) => ((m as { default: T }).default || m) as T\n    );\n  }\n\n  /**\n   * @description Retrieves and parses the package.json file\n   * @summary Reads the package.json file from the specified path and parses it into a JavaScript object\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {Record<string, unknown>} The parsed package.json content as an object\n   * @private\n   */\n  private static getPackage(basePath: string): Record<string, unknown> {\n    try {\n      return JSON.parse(\n        fs.readFileSync(path.join(basePath, \"package.json\"), \"utf8\")\n      );\n    } catch (e: unknown) {\n      throw new Error(`Unable to read version from ${basePath}: ${e}`);\n    }\n  }\n\n  /**\n   * @description Returns the version from package.json\n   * @summary Retrieves the version field from the package.json file at the specified path\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {string} The package version string\n   */\n  static packageVersion(basePath: string): string {\n    return McpUtils.getPackage(basePath)[\"version\"] as string;\n  }\n\n  /**\n   * @description Returns the name from package.json\n   * @summary Retrieves the name field from the package.json file at the specified path and extracts the package name without the scope\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {string} The package name without the scope (e.g., \"cli\" from \"@decaf-ts/cli\")\n   */\n  static packageName(basePath: string): string {\n    const name = (McpUtils.getPackage(basePath)[\"name\"] as string).split(\"/\");\n    return name[name.length - 1];\n  }\n}\n\nexport * from \"./utils/modulePaths\";\n","import fs from \"fs\";\nimport path from \"path\";\nimport { MCP_FILE_NAME } from \"./constants\";\nimport { McpUtils } from \"./utils\";\nimport { FastMCP } from \"fastmcp\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\nimport { VERSION } from \"./metadata\";\n\n/**\n * @description Utility class to handle CLI functionality from all Decaf modules\n * @summary This class provides a wrapper around Commander.js to handle CLI commands from different Decaf modules.\n * It crawls the filesystem to find CLI modules, loads them, and registers their commands.\n *\n * @param {string} [basePath] The base path to look for modules in. Defaults to `./`\n * @param {number} [crawlLevels] Number of folder levels to crawl to find modules from the basePath. Defaults to 4\n *\n * @example\n * // Create a new CLI wrapper and run it with custom options\n * const cli = new CliWrapper('./src', 2);\n * cli.run(process.argv).then(() => {\n *   console.log('CLI commands executed successfully');\n * });\n *\n * @class McpWrapper\n */\nexport class McpWrapper extends LoggedClass {\n  private _mcp?: FastMCP;\n  private modules: Record<string, string> = {};\n  private readonly rootPath: string;\n\n  constructor(\n    private basePath: string = \"./\",\n    private crawlLevels = 4\n  ) {\n    super();\n    this.rootPath = path.resolve(__dirname, \"..\");\n  }\n\n  /**\n   * @description Retrieves and initializes the Commander Command object\n   * @summary Lazy-loads the Command object, initializing it with the package name, description, and version\n   * @return {FastMCP} The initialized Command object\n   * @private\n   */\n  private get mcp() {\n    if (!this._mcp) {\n      this._mcp = new FastMCP({\n        name: \"decaf-ts MCP server\",\n        instructions: \"\",\n        version: VERSION as any,\n      });\n    }\n    return this._mcp;\n  }\n\n  /**\n   * @description Loads and registers an mcp extension module from a file\n   * @summary Dynamically imports an mcp extension module from the specified file path, initializes it, and registers it in the modules collection\n   *\n   */\n  private async load(\n    server: FastMCP,\n    filePath: string\n  ): Promise<{ mcp: FastMCP; package: string; version: string }> {\n    const log = this.log.for(this.load);\n\n    let pkg: string, version: string, enrich: any;\n    try {\n      const res = await McpUtils.loadFromFile(filePath);\n      pkg = res.PACKAGE_NAME;\n      version = res.VERSION;\n      enrich = res.enrich;\n    } catch (e: unknown) {\n      throw new Error((e as any).message || (e as any));\n    }\n    try {\n      log.info(`Enriching mcp server with module ${pkg} v${version}`);\n      const result = enrich(server);\n      server = result instanceof Promise ? await result : result;\n    } catch (e: unknown) {\n      throw new Error(\n        `failed to enrich mcp with module ${pkg || \"unnamed\"} under ${filePath}: ${e instanceof Error ? e.message : e}`\n      );\n    }\n    return {\n      mcp: server,\n      package: pkg,\n      version: version,\n    };\n  }\n\n  /**\n   * @description Finds and loads all CLI modules in the basePath\n   * @summary Uses the crawl method to find all CLI modules in the specified base path,\n   * then loads and registers each module as a subcommand\n   *\n   * @return {Promise<void>} A promise that resolves when all modules are loaded\n   *\n   * @private\n   * @mermaid\n   * sequenceDiagram\n   *   participant CliWrapper\n   *   participant Filesystem\n   *   participant Module\n   *\n   *   CliWrapper->>Filesystem: Join basePath with cwd\n   *   CliWrapper->>CliWrapper: crawl(basePath, crawlLevels)\n   *   CliWrapper-->>CliWrapper: modules[]\n   *   loop For each module\n   *     alt Not @decaf-ts/cli\n   *       CliWrapper->>CliWrapper: load(module, cwd)\n   *       CliWrapper-->>CliWrapper: name\n   *       CliWrapper->>CliWrapper: Check if command exists\n   *       alt Command doesn't exist\n   *         CliWrapper->>Command: command(name).addCommand(modules[name])\n   *       end\n   *     end\n   *   end\n   *   CliWrapper->>Console: Log loaded modules\n   */\n  private async boot() {\n    const log = this.log.for(this.boot);\n    let server = this.mcp;\n    // discover modules by crawling basePath\n    const moduleFiles = this.crawl(\n      path.resolve(this.basePath),\n      this.crawlLevels\n    );\n    for (const moduleFile of moduleFiles) {\n      if (moduleFile.includes(\"@decaf-ts/mcp\")) {\n        continue;\n      }\n      try {\n        const res = await this.load(server, moduleFile);\n        server = res.mcp;\n        this.modules[res.package] = moduleFile;\n      } catch (e: unknown) {\n        log.error(\n          `Failed to load MCP configs for ${moduleFile}: ${e instanceof Error ? e.message : e}`\n        );\n      }\n    }\n    console.log(\n      `loaded modules:\\n${Object.keys(this.modules)\n        .map((k) => `- ${k}`)\n        .join(\"\\n\")}`\n    );\n    return server;\n  }\n\n  /**\n   * @description Recursively searches for CLI module files in the directory structure\n   * @summary Crawls the basePath up to the specified number of folder levels to find files named according to CLI_FILE_NAME\n   *\n   * @param {string} basePath The absolute base path to start searching in\n   * @param {number} [levels=2] The maximum number of directory levels to crawl\n   * @return {string[]} An array of file paths to CLI modules\n   *\n   * @private\n   */\n  private crawl(basePath: string, levels: number = 2) {\n    if (levels <= 0) return [];\n    return fs.readdirSync(basePath).reduce((accum: string[], file) => {\n      file = path.join(basePath, file);\n      if (fs.statSync(file).isDirectory()) {\n        accum.push(...this.crawl(file, levels - 1));\n      } else if (file.match(new RegExp(`${MCP_FILE_NAME}.[cm]?js$`, \"gm\"))) {\n        accum.push(file);\n      }\n      return accum;\n    }, []);\n  }\n\n  /**\n   * @description Executes the CLI with the provided arguments\n   * @summary Boots the CLI by loading all modules, then parses and executes the command specified in the arguments\n   *\n   * @param {string[]} [args=process.argv] Command line arguments to parse and execute\n   * @return {Promise<void>} A promise that resolves when the command execution is complete\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant CliWrapper\n   *   participant Command\n   *\n   *   Client->>CliWrapper: run(args)\n   *   CliWrapper->>CliWrapper: boot()\n   *   Note over CliWrapper: Loads all modules\n   *   CliWrapper->>Command: parseAsync(args)\n   *   Command-->>CliWrapper: result\n   *   CliWrapper-->>Client: result\n   */\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  async run(args: string[] = process.argv) {\n    const server = await this.boot();\n    await server.start({ transportType: \"stdio\" });\n  }\n}\n"],"names":["prompts","resources","templates","toolList","tools","modulePackage","decorationModule","mcpModule","templateModule","coreToolList","VERSION","PACKAGE_NAME","PKG","V","path","fs"],"mappings":"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"}
|
|
2313
|
+
export { CLIENT_INTEGRATIONS, DEFAULT_PROMPT_NAME, EnrichCore, EnrichCoreWithAggregation, MCP_FILE_NAME, McpUtils, McpWrapper, PACKAGE_NAME, PROMPT_DIRECTORIES, REQUIRED_MODULE_FOLDERS, VERSION, WORKSPACE_ROOT_ENV, __resetWorkspaceRoot, aggregateModules, aggregateModulesSync, buildDecorationResourceTemplates, buildDocPrompts, buildResourceTemplates, decorationResourceTemplates, enrich, getWorkspaceRoot, listModuleDirectories, promptList, resolveModuleFolderPath, resolveModulePath, resolveModulesRoot, resources, setWorkspaceRoot, templateList, toolList, tools, validateModules, workspaceResourceTemplates };
|
|
2314
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mcp-server.esm.cjs","sources":["../src/constants.ts","../src/mcp/workspace.ts","../src/mcp/prompts/prompts.ts","../src/mcp/prompts/index.ts","../src/mcp/moduleRegistry.ts","../src/mcp/schemas.ts","../src/mcp/utils.ts","../src/mcp/code.ts","../src/mcp/tools/codex-tools.ts","../src/mcp/decorator-tools.ts","../src/mcp/tools/tools.ts","../src/mcp/tools/index.ts","../src/mcp/resources/resources.ts","../src/mcp/templates/codex-templates.ts","../src/mcp/templates/resource-templates.ts","../src/mcp/templates/workspace-templates.ts","../src/mcp/templates/index.ts","../src/metadata.ts","../src/mcp/mcp-module.ts","../src/mcp/validation/index.ts","../src/mcp/aggregateModules.ts","../src/mcp/fastmcp-wiring.ts","../src/mcp/index.ts","../src/utils/modulePaths.ts","../src/utils.ts","../src/McpWrapper.ts"],"sourcesContent":["/**\n * @description The filename that identifies Decaf CLI modules\n * @summary The standard filename for CLI module files where each library must export a single CliModule function\n *\n * @const MCP_FILE_NAME\n * @memberOf module:MCP\n */\nexport const MCP_FILE_NAME = \"mcp-module\";\n\n\nexport const WORKSPACE_ROOT_ENV = \"MCP_WORKSPACE_ROOT\";\nexport const PROMPT_DIRECTORIES = [\".code/prompts\", \".codex/prompts\"];\nexport const DEFAULT_PROMPT_NAME = \"doc\";\nexport const CLIENT_INTEGRATIONS = [\n  {\n    id: \"vscode\",\n    display: \"Visual Studio Code\",\n    instructions:\n      \"When interacting from Visual Studio Code, prefer the vscode://workspace/{path} resource template to fetch file contents and use the apply-code-change tool to commit edits with previewable diffs.\",\n  },\n  {\n    id: \"cursor\",\n    display: \"Cursor\",\n    instructions:\n      \"Cursor clients can retrieve and update files through the cursor://workspace/{path} resource template. Always validate patches in dryRun mode before applying permanent changes.\",\n  },\n  {\n    id: \"copilot\",\n    display: \"GitHub Copilot\",\n    instructions:\n      \"Use the copilot://workspace/{path} resource template to stream file content into Copilot chat sessions. Prefer returning unified diffs to maintain alignment with Copilot's diff visualization.\",\n  },\n] as const;\n","import fs from \"fs\";\nimport path from \"path\";\nimport { WORKSPACE_ROOT_ENV } from \"../constants\";\n\nlet workspaceRoot = initializeWorkspaceRoot();\nlet userErrorCtor: (new (message: string) => Error) | undefined;\n\nexport class WorkspaceError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = \"WorkspaceError\";\n  }\n}\n\nfunction initializeWorkspaceRoot(): string {\n  const configured = process.env[WORKSPACE_ROOT_ENV];\n  if (configured && configured.trim().length > 0) {\n    return path.resolve(configured.trim());\n  }\n  return process.cwd();\n}\n\nasync function getUserErrorCtor(): Promise<new (message: string) => Error> {\n  if (!userErrorCtor) {\n    try {\n      const mod = await import(\"fastmcp\");\n      userErrorCtor = (mod as { UserError: new (message: string) => Error })\n        .UserError;\n    } catch {\n      userErrorCtor = class MCPUserError extends Error {\n        constructor(message: string) {\n          super(message);\n          this.name = \"MCPUserError\";\n        }\n      };\n    }\n  }\n  return userErrorCtor;\n}\n\nexport async function throwUserError(message: string): Promise<never> {\n  const Ctor = await getUserErrorCtor();\n  throw new Ctor(message);\n}\n\nexport function setWorkspaceRoot(root: string) {\n  workspaceRoot = path.resolve(root);\n}\n\nexport function getWorkspaceRoot(): string {\n  return workspaceRoot;\n}\n\nexport function resolveInWorkspace(root: string, targetPath: string): string {\n  const resolved = path.isAbsolute(targetPath)\n    ? path.normalize(targetPath)\n    : path.resolve(root, targetPath);\n\n  const relative = path.relative(root, resolved);\n  if (relative.startsWith(\"..\") || path.isAbsolute(relative)) {\n    throw new WorkspaceError(\n      `Path ${targetPath} escapes the workspace root at ${root}`\n    );\n  }\n\n  return resolved;\n}\n\nexport async function readWorkspaceFile(\n  root: string,\n  target: string\n): Promise<string> {\n  try {\n    const absolute = resolveInWorkspace(root, target);\n    return fs.readFileSync(absolute, \"utf8\" as BufferEncoding);\n  } catch (error) {\n    if (error instanceof WorkspaceError) {\n      await throwUserError(error.message);\n    }\n    /* istanbul ignore next */\n    throw error;\n  }\n}\n\nexport function __resetWorkspaceRoot(root: string) {\n  setWorkspaceRoot(root);\n}\n","import fs from \"fs\";\nimport path from \"path\";\nimport type { ContentResult, InputPrompt } from \"fastmcp\";\nimport {\n  CLIENT_INTEGRATIONS,\n  DEFAULT_PROMPT_NAME,\n  PROMPT_DIRECTORIES,\n} from \"../../constants\";\nimport type { DocPrompt } from \"../types\";\nimport { getWorkspaceRoot } from \"../workspace\";\nimport type { PromptAsset } from \"../../types\";\n\nexport const prompts: InputPrompt<undefined>[] = [];\n\n// Read registered module packages from a runtime global set by modules/index\n// This avoids importing moduleRegistry at module-eval time which creates circular imports.\nfunction getRegisteredModulePackages(): any[] {\n  return (globalThis as any).__DECAF_MODULE_PACKAGES__ ?? [];\n}\n\nconst OBJECT_PROMPT_DEPENDENCIES: Record<string, readonly string[]> = {\n  module: [\"doc\", \"module\"],\n  file: [\"doc\", \"file\"],\n  class: [\"doc\", \"class\"],\n  function: [\"doc\", \"function\"],\n  interface: [\"doc\", \"interface\"],\n  decorator: [\"doc\", \"decorator\"],\n  constant: [\"doc\", \"constant\"],\n  \"bulk-docs\": [\"bulk-docs\"],\n  \"bulk-tests\": [\"bulk-tests\"],\n  \"update-readme\": [\"update-readme\"],\n  \"repo-setup\": [\"repo-setup\"],\n  \"release-notes\": [\"release-notes\"],\n  \"mcp-module\": [\"mcp-module\"],\n};\n\nexport function getObjectPromptDependencies(): Record<\n  string,\n  readonly string[]\n> {\n  return OBJECT_PROMPT_DEPENDENCIES;\n}\n\nexport function buildPrompts(repoPath: string): InputPrompt<undefined>[] {\n  return [\n    {\n      name: \"decoration-overview\",\n      description:\n        \"High-level guidance on using the decoration library: key exports, decorators, and common workflows.\",\n      load: async () =>\n        `You are assisting with the Decaf.ts decoration module located at ${repoPath}. Prefer using exported builders and decorators over ad-hoc patterns.\\n\\nProvide a concise, actionable overview of how to use the decoration APIs for extending and overriding behaviors.`,\n    },\n  ];\n}\n\nexport function buildDocPrompts(): InputPrompt<undefined>[] {\n  const root = getWorkspaceRoot();\n  const fileBasedPrompts = discoverDocPrompts(root).map((prompt) => ({\n    name: `doc/${prompt.name}`,\n    description: prompt.description,\n    load: async () => prompt.content,\n  }));\n\n  const integrationPrompts = CLIENT_INTEGRATIONS.map<InputPrompt<undefined>>(\n    (integration) => ({\n      name: `integration/${integration.id}`,\n      description: `${integration.display} integration guidance`,\n      load: async () =>\n        `You are coordinating with ${integration.display}. ${integration.instructions}\\n\\nTools available:\\n- document-code\\n- apply-code-change\\n\\nEnsure responses include actionable steps for the client.`,\n    })\n  );\n\n  return [...fileBasedPrompts, ...integrationPrompts];\n}\n\nfunction summarizePromptContent(\n  prompt: DocPrompt,\n  headingPrefix: string\n): string {\n  return [`## ${headingPrefix}`, \"\", prompt.content.trim()].join(\"\\n\");\n}\n\nexport function buildObjectPrompts(): InputPrompt<undefined>[] {\n  const root = getWorkspaceRoot();\n  const discovered = discoverDocPrompts(root);\n  const promptByName = new Map<string, DocPrompt>();\n  for (const prompt of discovered) {\n    promptByName.set(prompt.name, prompt);\n  }\n\n  const outputs: InputPrompt<undefined>[] = [];\n  for (const [objectType, dependencies] of Object.entries(\n    OBJECT_PROMPT_DEPENDENCIES\n  )) {\n    const existing = dependencies\n      .map((name) => promptByName.get(name))\n      .filter((prompt): prompt is DocPrompt => Boolean(prompt));\n    if (!existing.length) continue;\n\n    outputs.push({\n      name: `codex/${objectType}`,\n      description: `Guidance derived from .codex prompts for ${objectType} tasks.`,\n      load: async () => {\n        const sections = existing.map((prompt) =>\n          summarizePromptContent(prompt, toTitleCase(prompt.name))\n        );\n        return [`# Codex guidance for ${objectType}`, \"\", ...sections].join(\n          \"\\n\"\n        );\n      },\n    });\n  }\n\n  return outputs.sort((a, b) => a.name.localeCompare(b.name));\n}\n\nfunction toInputPrompt(asset: PromptAsset): InputPrompt<undefined> {\n  const provenance = asset.provenance ? ` (module: ${asset.provenance})` : \"\";\n  return {\n    name: asset.id,\n    description: `${asset.description ?? asset.title}${provenance}`,\n    load: async () => asset.load(),\n  };\n}\n\nfunction buildModulePrompts(): InputPrompt<undefined>[] {\n  const pkgs = getRegisteredModulePackages();\n  const assets: PromptAsset[] = pkgs.flatMap((p: any) => p.prompts ?? []);\n  return assets.map(toInputPrompt);\n}\n\nexport function refreshPrompts(repoPath?: string): InputPrompt<undefined>[] {\n  const docPrompts = buildDocPrompts();\n  const objectPrompts = buildObjectPrompts();\n  const repoPrompts = repoPath ? buildPrompts(repoPath) : [];\n  const modulePrompts = buildModulePrompts();\n  prompts.splice(\n    0,\n    prompts.length,\n    ...docPrompts,\n    ...objectPrompts,\n    ...repoPrompts,\n    ...modulePrompts\n  );\n  return prompts;\n}\n\nexport function discoverDocPrompts(root: string): DocPrompt[] {\n  const discovered: DocPrompt[] = [];\n\n  for (const directory of PROMPT_DIRECTORIES) {\n    const promptDir = path.join(root, directory);\n    // debug logging to help tests diagnose prompt discovery\n\n    console.debug(\"[discoverDocPrompts] checking\", promptDir);\n    if (!fs.existsSync(promptDir) || !fs.statSync(promptDir).isDirectory()) {\n      continue;\n    }\n\n    for (const entry of fs.readdirSync(promptDir)) {\n      const fullPath = path.join(promptDir, entry);\n      if (!fs.statSync(fullPath).isFile()) continue;\n\n      const name = path.parse(entry).name;\n      const content = fs.readFileSync(fullPath, \"utf8\");\n      const title = toTitleCase(name.replace(/[-_]/g, \" \"));\n      const description = extractDescription(content, fullPath);\n\n      discovered.push({\n        name,\n        title,\n        description,\n        content,\n        absolutePath: fullPath,\n      });\n    }\n  }\n\n  const unique = new Map<string, DocPrompt>();\n  for (const prompt of discovered) {\n    if (!unique.has(prompt.name)) {\n      unique.set(prompt.name, prompt);\n    }\n  }\n\n  return Array.from(unique.values()).sort((a, b) =>\n    a.name.localeCompare(b.name)\n  );\n}\n\nexport function selectPrompt(\n  promptList: DocPrompt[],\n  requestedName: string\n): DocPrompt {\n  const direct = promptList.find((prompt) => prompt.name === requestedName);\n  if (direct) return direct;\n\n  const fallback = promptList.find(\n    (prompt) => prompt.name === DEFAULT_PROMPT_NAME\n  );\n  if (fallback) return fallback;\n\n  if (!promptList.length) {\n    throw new Error(\"No documentation prompts available\");\n  }\n\n  return promptList[0];\n}\n\nexport function buildDocumentationPayload({\n  filePath,\n  fileContent,\n  prompt,\n  includePrompt,\n  includeCode,\n  includeMetadata,\n  additionalContext,\n}: {\n  filePath: string;\n  fileContent: string;\n  prompt: DocPrompt;\n  includePrompt: boolean;\n  includeCode: boolean;\n  includeMetadata: boolean;\n  additionalContext?: string;\n}): ContentResult {\n  const sections: string[] = [];\n\n  if (includeMetadata) {\n    sections.push(\n      `# Documentation Request\\n- prompt: ${prompt.name}\\n- file: ${filePath}`\n    );\n  }\n\n  if (includePrompt) {\n    sections.push(\n      `## Prompt Guidance (${prompt.title})\\n\\n${prompt.content.trim()}`\n    );\n  }\n\n  if (additionalContext?.trim()) {\n    sections.push(`## Additional Context\\n\\n${additionalContext.trim()}`);\n  }\n\n  if (includeCode) {\n    sections.push(\n      `## Source\\n\\n\\`\\`\\`${inferLanguageFromPath(filePath)}\\n${fileContent}\\n\\`\\`\\``\n    );\n  }\n\n  return {\n    content: [\n      {\n        type: \"text\",\n        text: sections.join(\"\\n\\n\"),\n      },\n    ],\n  } satisfies ContentResult;\n}\n\nfunction extractDescription(content: string, filePath: string): string {\n  const firstLine = content\n    .split(/\\r?\\n/)\n    .map((line) => line.trim())\n    .find((line) => line.length > 0);\n\n  return (\n    firstLine?.slice(0, 240) ??\n    `Documentation prompt loaded from ${path.basename(filePath)}`\n  );\n}\n\nfunction toTitleCase(value: string): string {\n  return value\n    .split(/\\s+/)\n    .filter(Boolean)\n    .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())\n    .join(\" \");\n}\n\nfunction inferLanguageFromPath(filePath: string): string {\n  const extension = path.extname(filePath).toLowerCase();\n  switch (extension) {\n    case \".ts\":\n    case \".tsx\":\n      return \"ts\";\n    case \".js\":\n    case \".jsx\":\n      return \"js\";\n    case \".json\":\n      return \"json\";\n    case \".md\":\n      return \"md\";\n    default:\n      return \"text\";\n  }\n}\n\nexport { DEFAULT_PROMPT_NAME };\nexport type { DocPrompt };\n","export * from \"./prompts\";\nimport { InputPrompt } from \"fastmcp\";\nimport { prompts, refreshPrompts } from \"./prompts\";\n\nexport const promptList: InputPrompt<undefined>[] = prompts;\n\nexport function loadPrompts(repoPath?: string): InputPrompt<undefined>[] {\n  return refreshPrompts(repoPath);\n}\n","import type {\n  ModuleExportPackage,\n  PromptAsset,\n  ResourceAsset,\n  TemplateAsset,\n  ToolAsset,\n} from \"../types\";\n\ntype AssetKey = \"prompts\" | \"resources\" | \"templates\" | \"tools\";\n\nexport class ModuleRegistry {\n  constructor(private packages: ModuleExportPackage[] = []) {}\n\n  setPackages(pkgs: ModuleExportPackage[]) {\n    this.packages = Array.isArray(pkgs) ? pkgs : [];\n  }\n\n  listPackages(): ModuleExportPackage[] {\n    return this.packages;\n  }\n\n  listPrompts(): PromptAsset[] {\n    return this.collectAssets(\"prompts\");\n  }\n\n  listResources(): ResourceAsset[] {\n    return this.collectAssets(\"resources\");\n  }\n\n  listTemplates(): TemplateAsset[] {\n    return this.collectAssets(\"templates\");\n  }\n\n  listTools(): ToolAsset[] {\n    return this.collectAssets(\"tools\");\n  }\n\n  private collectAssets<\n    T extends PromptAsset | ResourceAsset | TemplateAsset | ToolAsset,\n  >(key: AssetKey): T[] {\n    const seen = new Map<string, string>();\n    const aggregated: T[] = [];\n\n    for (const pkg of this.packages) {\n      if (pkg.status === \"disabled\") continue;\n      for (const asset of (pkg as any)[key] as T[]) {\n        const maybeName = (asset as any).name as string | undefined;\n        const assetKey =\n          (asset && (asset.id ?? maybeName)) || JSON.stringify(asset);\n        if (seen.has(assetKey)) {\n          const conflict = seen.get(assetKey);\n          throw new Error(\n            `Duplicate ${key} id '${assetKey}' from modules ${conflict} and ${pkg.name}`\n          );\n        }\n        seen.set(assetKey, pkg.name);\n        aggregated.push({ ...asset, provenance: pkg.name });\n      }\n    }\n\n    return aggregated;\n  }\n}\n\nexport const moduleRegistry = new ModuleRegistry();\n\nexport function registerModulePackages(pkgs: ModuleExportPackage[]) {\n  moduleRegistry.setPackages(pkgs);\n}\n","import { z } from \"zod\";\n\nexport const analyzeRepoSchema = z\n  .object({\n    repoPath: z\n      .string()\n      .min(1, \"repoPath is required\")\n      .describe(\n        \"Relative or absolute path to the target repository inside this monorepo, e.g. './decoration'.\"\n      ),\n    includeTests: z\n      .boolean()\n      .default(true)\n      .describe(\n        \"If true, analyze the tests directory (if present) to derive expected behaviors.\"\n      ),\n    includeDocs: z\n      .boolean()\n      .default(true)\n      .describe(\n        \"If true, analyze README.md and docs directories to extract documented features.\"\n      ),\n  })\n  .strict()\n  .describe(\n    \"Analyze a local repository (e.g. ./decoration) to extract APIs, features, tests, and documentation cues.\"\n  );\n\nexport const enumerateCapabilitiesSchema = z\n  .object({\n    repoPath: z\n      .string()\n      .min(1, \"repoPath is required\")\n      .describe(\n        \"Relative or absolute path to the target repository to enumerate developer-facing capabilities.\"\n      ),\n  })\n  .strict()\n  .describe(\n    \"Enumerate the complete set of capabilities a developer is expected to use from the given repository.\"\n  );\n\nexport const planFeatureSchema = z\n  .object({\n    feature: z\n      .string()\n      .min(5, \"feature must describe the goal clearly\")\n      .describe(\n        \"Natural-language description of a developer's requested feature or task to implement using the repository and available MCP tools.\"\n      ),\n    repoPath: z\n      .string()\n      .default(\"./decoration\")\n      .describe(\n        \"Target repository path providing the library to use, e.g. './decoration'.\"\n      ),\n  })\n  .strict()\n  .describe(\n    \"Plan which MCP tools to use and in what sequence to implement a requested feature using the repository.\"\n  );\n\nexport const documentCodeSchema = z\n  .object({\n    filePath: z.string().min(1, \"filePath is required\"),\n    promptName: z.string().optional(),\n    includePrompt: z.boolean().default(true),\n    includeCode: z.boolean().default(true),\n    includeMetadata: z.boolean().default(true),\n    additionalContext: z.string().optional(),\n    encoding: z.string().default(\"utf8\"),\n  })\n  .strict();\n\nexport const codeChangeSchema = z\n  .object({\n    filePath: z.string().min(1, \"filePath is required\"),\n    patch: z.string().min(1, \"patch is required\"),\n    dryRun: z.boolean().default(false),\n    showDiff: z.boolean().default(true),\n    diffContext: z.number().int().min(0).max(100).default(3),\n    encoding: z.string().default(\"utf8\"),\n  })\n  .strict();\n\nconst OBJECT_TYPES = [\n  \"module\",\n  \"file\",\n  \"class\",\n  \"function\",\n  \"interface\",\n  \"decorator\",\n  \"constant\",\n] as const;\n\nexport const documentObjectSchema = z\n  .object({\n    basePath: z.string().min(1, \"basePath is required\"),\n    objectType: z.enum(OBJECT_TYPES),\n    targetFile: z.string().optional(),\n    includeContent: z.boolean().default(false),\n  })\n  .strict();\n\nexport const coverageTaskSchema = z\n  .object({\n    basePath: z.string().min(1, \"basePath is required\"),\n    coverage: z\n      .number()\n      .min(0)\n      .max(100)\n      .default(90)\n      .describe(\"Target coverage percentage\"),\n    dryRun: z.boolean().default(false),\n  })\n  .strict();\n\nexport const readmeImprovementSchema = z\n  .object({\n    basePath: z.string().min(1, \"basePath is required\"),\n    includeExamples: z.boolean().default(true),\n  })\n  .strict();\n","import fs from \"fs\";\nimport path from \"path\";\n\nexport function readFileSafe(\n  filePath: string,\n  encoding: BufferEncoding = \"utf8\"\n): string | undefined {\n  try {\n    return fs.readFileSync(filePath, { encoding });\n  } catch {\n    return undefined;\n  }\n}\n\nexport function listFilesRecursive(\n  root: string,\n  matcher?: (p: string) => boolean\n): string[] {\n  const out: string[] = [];\n  const stack: string[] = [root];\n  while (stack.length) {\n    const cur = stack.pop()!;\n    const stat = fs.statSync(cur);\n    if (stat.isDirectory()) {\n      for (const f of fs.readdirSync(cur)) stack.push(path.join(cur, f));\n    } else if (!matcher || matcher(cur)) {\n      out.push(cur);\n    }\n  }\n  return out.sort();\n}\n\nexport function deriveCapabilities(analysis: any): string[] {\n  const cap = new Set<string>();\n  // heuristics: if decorators like Decoration, flavouredAs, extend, override appear, add capabilities\n  const allDecs = new Set<string>();\n  for (const k of Object.keys(analysis.api)) {\n    for (const d of analysis.api[k].decorators) allDecs.add(d);\n    for (const e of analysis.api[k].exports)\n      if (/Decoration|decorate|Builder|Flavour/i.test(e))\n        cap.add(\"use-decoration-api\");\n  }\n  if ([...allDecs].some((d) => /override|extend/i.test(d)))\n    cap.add(\"override-and-extend-decorations\");\n  if (Object.keys(analysis.tests).length > 0) cap.add(\"validate-with-tests\");\n  if (analysis.readme) cap.add(\"follow-readme-guides\");\n  return [...cap].sort();\n}\n\n","// Analysis helpers (minimal yet effective, text-based to avoid heavy AST deps)\nimport path from \"path\";\nimport fs from \"fs\";\nimport { listFilesRecursive, readFileSafe } from \"./utils\";\n\nexport function isSourceFile(p: string) {\n  return /\\.(ts|tsx|js|jsx)$/.test(p) && !p.endsWith(\".d.ts\");\n}\nexport function isTestFile(p: string) {\n  return /(\\.test\\.|\\.spec\\.)/.test(p);\n}\n\nexport function extractExports(fileContent: string): string[] {\n  const names = new Set<string>();\n  const exportRe =\n    /(export\\s+(?:default\\s+)?(?:class|function|const|let|var|interface|type|enum)\\s+)([A-Za-z0-9_]+)/g;\n  const namedRe = /export\\s*\\{([^}]+)\\}/g;\n  let m: RegExpExecArray | null;\n  while ((m = exportRe.exec(fileContent))) names.add(m[2]);\n  while ((m = namedRe.exec(fileContent))) {\n    m[1]\n      .split(\",\")\n      .map((s) => s.trim().split(\" as \")[0].trim())\n      .forEach((n) => {\n        if (n) names.add(n);\n      });\n  }\n  return [...names].sort();\n}\n\nexport function extractDecorators(fileContent: string): string[] {\n  const decs = new Set<string>();\n  const decRe = /@([A-Za-z_][A-Za-z0-9_]*)/g;\n  let m: RegExpExecArray | null;\n  while ((m = decRe.exec(fileContent))) decs.add(m[1]);\n  return [...decs].sort();\n}\n\nexport function summarizeReadme(readme?: string) {\n  if (!readme) return undefined;\n  const lines = readme.split(/\\r?\\n/).filter(Boolean);\n  const title =\n    lines.find((l) => /^#\\s+/.test(l))?.replace(/^#\\s+/, \"\") || \"README\";\n  const bullets = lines.filter((l) => /^[-*]\\s+/.test(l)).slice(0, 20);\n  return { title, bullets };\n}\n\nexport function analyzeRepo(root: string) {\n  const src = path.join(root, \"src\");\n  const testDir = path.join(root, \"tests\");\n  const readmePath = path.join(root, \"README.md\");\n  const readme = readFileSafe(readmePath);\n\n  const files = fs.existsSync(src) ? listFilesRecursive(src, isSourceFile) : [];\n  const testFiles = fs.existsSync(testDir)\n    ? listFilesRecursive(testDir, (f) => isSourceFile(f) && isTestFile(f))\n    : [];\n\n  const api: Record<string, { exports: string[]; decorators: string[] }> = {};\n  for (const f of files) {\n    const content = readFileSafe(f) || \"\";\n    api[path.relative(root, f)] = {\n      exports: extractExports(content),\n      decorators: extractDecorators(content),\n    };\n  }\n  const tests: Record<string, { mentions: string[] }> = {};\n  for (const f of testFiles) {\n    const content = readFileSafe(f) || \"\";\n    const mentions = Array.from(\n      new Set([...extractExports(content), ...extractDecorators(content)])\n    ).sort();\n    tests[path.relative(root, f)] = { mentions };\n  }\n  return { files, testFiles, api, tests, readme: summarizeReadme(readme) };\n}\n","import fs from \"fs\";\nimport path from \"path\";\nimport { spawnSync } from \"child_process\";\nimport type { ContentResult, Tool } from \"fastmcp\";\nimport {\n  documentObjectSchema,\n  coverageTaskSchema,\n  readmeImprovementSchema,\n} from \"../schemas\";\nimport {\n  DocumentObjectArgs,\n  CoverageTaskArgs,\n  ReadmeImprovementArgs,\n} from \"../types\";\nimport {\n  getWorkspaceRoot,\n  resolveInWorkspace,\n  throwUserError,\n  WorkspaceError,\n} from \"../workspace\";\nimport {\n  discoverDocPrompts,\n  getObjectPromptDependencies,\n} from \"../prompts/prompts\";\nimport type { DocPrompt } from \"../types\";\nimport { listFilesRecursive, readFileSafe } from \"../utils\";\nimport { analyzeRepo, isSourceFile, isTestFile } from \"../code\";\n\ntype PromptSection = {\n  name: string;\n  title: string;\n  description: string;\n  content: string;\n  absolutePath?: string;\n};\n\nfunction relativeFiles(root: string, files: string[]): string[] {\n  return files.map((file) => path.relative(root, file)).sort();\n}\n\nfunction collectPromptSections(names: readonly string[]): PromptSection[] {\n  const root = getWorkspaceRoot();\n  const promptIndex = new Map<string, DocPrompt>(\n    discoverDocPrompts(root).map((prompt) => [prompt.name, prompt])\n  );\n  return names\n    .map((name) => promptIndex.get(name))\n    .filter((prompt): prompt is DocPrompt => Boolean(prompt))\n    .map((prompt) => ({\n      name: prompt.name,\n      title: prompt.title,\n      description: prompt.description,\n      content: prompt.content,\n      absolutePath: prompt.absolutePath,\n    }));\n}\n\nfunction parseTaskLines(content: string): string[] {\n  return content\n    .split(/\\r?\\n/)\n    .map((line) => line.trim())\n    .filter((line) => /^task\\s+\\d+/i.test(line));\n}\n\nfunction computeCoverageFromFinal(coveragePath: string) {\n  const payload = JSON.parse(fs.readFileSync(coveragePath, \"utf8\")) as Record<\n    string,\n    {\n      s: Record<string, number>;\n      f: Record<string, number>;\n      b: Record<string, number | number[]>;\n    }\n  >;\n\n  const totals = {\n    statements: { covered: 0, total: 0 },\n    functions: { covered: 0, total: 0 },\n    branches: { covered: 0, total: 0 },\n  };\n\n  const files = Object.entries(payload).map(([filePath, info]) => {\n    const statementCounts = Object.values(info.s);\n    const functionCounts = Object.values(info.f);\n    const branchCounts = Object.values(info.b).flatMap((value) =>\n      Array.isArray(value) ? value : [value]\n    );\n\n    const statementTotal = statementCounts.length;\n    const functionTotal = functionCounts.length;\n    const branchTotal = branchCounts.length;\n\n    const statementCovered = statementCounts.filter(\n      (count) => count > 0\n    ).length;\n    const functionCovered = functionCounts.filter((count) => count > 0).length;\n    const branchCovered = branchCounts.filter((count) => count > 0).length;\n\n    totals.statements.covered += statementCovered;\n    totals.statements.total += statementTotal;\n    totals.functions.covered += functionCovered;\n    totals.functions.total += functionTotal;\n    totals.branches.covered += branchCovered;\n    totals.branches.total += branchTotal;\n\n    const pct = (covered: number, total: number) =>\n      total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));\n\n    return {\n      path: filePath,\n      statements: pct(statementCovered, statementTotal),\n      functions: pct(functionCovered, functionTotal),\n      branches: pct(branchCovered, branchTotal),\n    };\n  });\n\n  const pct = (covered: number, total: number) =>\n    total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));\n\n  return {\n    totals: {\n      statements: {\n        ...totals.statements,\n        pct: pct(totals.statements.covered, totals.statements.total),\n      },\n      functions: {\n        ...totals.functions,\n        pct: pct(totals.functions.covered, totals.functions.total),\n      },\n      branches: {\n        ...totals.branches,\n        pct: pct(totals.branches.covered, totals.branches.total),\n      },\n    },\n    files,\n  };\n}\n\nfunction normalizePromptSections(sections: PromptSection[]) {\n  return sections.map((section) => ({\n    name: section.name,\n    title: section.title,\n    tasks: parseTaskLines(section.content),\n    content: section.content,\n  }));\n}\n\nasync function resolveRepoRoot(basePath: string) {\n  const root = getWorkspaceRoot();\n  try {\n    return resolveInWorkspace(root, basePath);\n  } catch (error) {\n    if (error instanceof WorkspaceError) {\n      await throwUserError(error.message);\n    }\n    throw error;\n  }\n}\n\nexport const documentObjectTool: Tool<undefined, typeof documentObjectSchema> =\n  {\n    name: \"document-object\",\n    description:\n      \"Create a documentation plan for a specific object type using .codex prompts and repository analysis.\",\n    parameters: documentObjectSchema,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    execute: async (input, _context): Promise<ContentResult> => {\n      const args = documentObjectSchema.parse(input as DocumentObjectArgs);\n      const repoRoot = await resolveRepoRoot(args.basePath);\n\n      const dependencies = getObjectPromptDependencies()[args.objectType] ?? [];\n      if (!dependencies.length) {\n        await throwUserError(\n          `No prompt guidance configured for object type ${args.objectType}`\n        );\n      }\n\n      const sections = normalizePromptSections(\n        collectPromptSections(dependencies)\n      );\n\n      const srcDir = path.join(repoRoot, \"src\");\n      const testDir = path.join(repoRoot, \"tests\");\n\n      const sourceFiles = fs.existsSync(srcDir)\n        ? listFilesRecursive(srcDir, isSourceFile)\n        : [];\n      const testFiles = fs.existsSync(testDir)\n        ? listFilesRecursive(\n            testDir,\n            (file) => isSourceFile(file) && isTestFile(file)\n          )\n        : [];\n\n      let targetFileContent: string | undefined;\n      if (args.targetFile) {\n        try {\n          const absolute = resolveInWorkspace(repoRoot, args.targetFile);\n          targetFileContent = readFileSafe(absolute) ?? undefined;\n        } catch (error) {\n          if (error instanceof WorkspaceError) {\n            await throwUserError(error.message);\n          }\n          throw error;\n        }\n      }\n\n      const payload = {\n        basePath: path.relative(getWorkspaceRoot(), repoRoot) || \".\",\n        objectType: args.objectType,\n        targetFile: args.targetFile,\n        guidance: sections,\n        files: {\n          source: relativeFiles(repoRoot, sourceFiles),\n          tests: relativeFiles(repoRoot, testFiles),\n        },\n        targetFileContent: args.includeContent ? targetFileContent : undefined,\n      };\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(payload, null, 2),\n          },\n        ],\n      } satisfies ContentResult;\n    },\n  };\n\nexport const coverageEnforcerTool: Tool<undefined, typeof coverageTaskSchema> =\n  {\n    name: \"ensure-test-coverage\",\n    description:\n      \"Run the configured coverage command and report whether the target percentage is met, highlighting weak files.\",\n    parameters: coverageTaskSchema,\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    execute: async (input, _context): Promise<ContentResult> => {\n      const args = coverageTaskSchema.parse(input as CoverageTaskArgs);\n      const repoRoot = await resolveRepoRoot(args.basePath);\n\n      if (!args.dryRun) {\n        const env = {\n          ...process.env,\n          USE_WATCHMAN: \"false\",\n          WATCHMAN_DISABLE: \"1\",\n          JEST_DISABLE_WATCHMAN: \"1\",\n        };\n        const result = spawnSync(\n          \"npm\",\n          [\"run\", \"coverage\", \"--\", \"--watchman=false\", \"--runInBand\"],\n          { cwd: repoRoot, env, encoding: \"utf8\" }\n        );\n\n        if (result.status !== 0) {\n          const message =\n            result.stderr || result.stdout || \"Coverage command failed\";\n          await throwUserError(message.trim());\n        }\n      }\n\n      const coveragePath = path.join(\n        repoRoot,\n        \"workdocs\",\n        \"reports\",\n        \"coverage\",\n        \"coverage-final.json\"\n      );\n\n      if (!fs.existsSync(coveragePath)) {\n        await throwUserError(\n          `Coverage report not found at ${path.relative(repoRoot, coveragePath)}`\n        );\n      }\n\n      const summary = computeCoverageFromFinal(coveragePath);\n      const meetsThreshold =\n        summary.totals.statements.pct >= args.coverage &&\n        summary.totals.functions.pct >= args.coverage &&\n        summary.totals.branches.pct >= args.coverage;\n\n      const weakest = [...summary.files]\n        .sort((a, b) => a.statements - b.statements)\n        .slice(0, 10);\n\n      const guidance = normalizePromptSections(\n        collectPromptSections([\"bulk-tests\"])\n      );\n\n      const payload = {\n        basePath: path.relative(getWorkspaceRoot(), repoRoot) || \".\",\n        target: args.coverage,\n        meetsThreshold,\n        totals: summary.totals,\n        weakest,\n        guidance,\n      };\n\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(payload, null, 2),\n          },\n        ],\n      } satisfies ContentResult;\n    },\n  };\n\nexport const readmeImprovementTool: Tool<\n  undefined,\n  typeof readmeImprovementSchema\n> = {\n  name: \"improve-readme\",\n  description:\n    \"Summarize required steps to refresh README and workdocs content using .codex guidance and repository analysis.\",\n  parameters: readmeImprovementSchema,\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (input, _context): Promise<ContentResult> => {\n    const args = readmeImprovementSchema.parse(input as ReadmeImprovementArgs);\n    const repoRoot = await resolveRepoRoot(args.basePath);\n\n    const analysis = analyzeRepo(repoRoot);\n    const modules = analysis.files\n      .filter((file) => /index\\.ts$/.test(file))\n      .map((file) => path.relative(repoRoot, file));\n\n    const promptSections = normalizePromptSections(\n      collectPromptSections([\"update-readme\", \"doc\", \"module\"])\n    );\n\n    const testExamples = Object.keys(analysis.tests ?? {});\n    const examples = args.includeExamples ? testExamples.slice(0, 20) : [];\n\n    const payload = {\n      basePath: path.relative(getWorkspaceRoot(), repoRoot) || \".\",\n      summary: {\n        modules,\n        totalSourceFiles: analysis.files.length,\n        totalTestFiles: analysis.testFiles.length,\n        hasReadme: Boolean(analysis.readme),\n      },\n      guidance: promptSections,\n      suggestedExamples: examples,\n    };\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: JSON.stringify(payload, null, 2),\n        },\n      ],\n    } satisfies ContentResult;\n  },\n};\n","import fs from \"fs\";\nimport path from \"path\";\n\nexport type DecoratorSpec = {\n  name: string;\n  args?: unknown[];\n};\n\nexport type AttributeSpec = {\n  name: string;\n  type: string;\n  decorators?: DecoratorSpec[];\n};\n\nfunction escapeRegExp(value: string) {\n  return value.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\nfunction formatDecorator(spec: DecoratorSpec): string {\n  const args = (spec.args || []).map((arg) => JSON.stringify(arg)).join(\", \");\n  return `@${spec.name}(${args})`;\n}\n\nfunction ensureDirectory(filePath: string) {\n  fs.mkdirSync(path.dirname(filePath), { recursive: true });\n}\n\nfunction collectDecoratorNames(\n  classDecorators: DecoratorSpec[] | undefined,\n  properties: AttributeSpec[] | undefined\n) {\n  const names = new Set<string>();\n  names.add(\"model\");\n  for (const decorator of classDecorators || []) {\n    names.add(decorator.name);\n  }\n  for (const property of properties || []) {\n    for (const decorator of property.decorators || []) {\n      names.add(decorator.name);\n    }\n  }\n  return names;\n}\n\nfunction ensureImport(\n  content: string,\n  importsFrom: string,\n  decorators: Set<string>\n) {\n  /* istanbul ignore next */\n  if (!decorators.size) return content;\n  const importRegex = new RegExp(\n    `import\\\\s+\\\\{([^}]+)\\\\}\\\\s+from\\\\s+[\"']${escapeRegExp(importsFrom)}[\"'];`\n  );\n  const match = content.match(importRegex);\n  const sorted = Array.from(decorators).sort();\n\n  if (match) {\n    const existing = match[1]\n      .split(\",\")\n      .map((name) => name.trim())\n      .filter(Boolean);\n    const merged = Array.from(new Set([...existing, ...sorted])).sort();\n    return content.replace(\n      importRegex,\n      `import { ${merged.join(\", \")} } from \"${importsFrom}\";`\n    );\n  }\n\n  const importLine = `import { ${sorted.join(\", \")} } from \"${importsFrom}\";`;\n  return `${importLine}\\n\\n${content}`;\n}\n\nfunction addPropertyBlock(property: AttributeSpec) {\n  const decorators = (property.decorators || [])\n    .map(formatDecorator)\n    .join(\"\\n  \");\n  const decoratorBlock = decorators ? `  ${decorators}\\n` : \"\";\n  return `${decoratorBlock}  ${property.name}: ${property.type};`;\n}\n\nfunction removePropertyBlock(content: string, propertyName: string) {\n  const lines = content.split(/\\r?\\n/);\n  const result: string[] = [];\n  for (let i = 0; i < lines.length; i++) {\n    const line = lines[i];\n    if (\n      line.trim().startsWith(`@`) &&\n      lines[i + 1]?.includes(`${propertyName}:`)\n    ) {\n      continue;\n    }\n    if (line.includes(`${propertyName}:`)) {\n      // skip this line and any trailing blank line\n      continue;\n    }\n    result.push(line);\n  }\n  return result.join(\"\\n\");\n}\n\nfunction insertDecorator(\n  content: string,\n  decorator: DecoratorSpec,\n  target: {\n    kind: \"class\" | \"property\";\n    name?: string;\n  }\n) {\n  const decoratorLine = formatDecorator(decorator);\n  if (target.kind === \"class\") {\n    const classRegex = /(export\\s+class\\s+[^\\s{]+\\s*\\{)/;\n    if (content.includes(decoratorLine)) return content;\n    return content.replace(classRegex, `${decoratorLine}\\n$1`);\n  }\n  if (!target.name) return content;\n  const propertyRegex = new RegExp(\n    `(^\\\\s*)(?:@.*\\\\n\\\\1)*${escapeRegExp(target.name)}:`,\n    \"m\"\n  );\n  const match = propertyRegex.exec(content);\n  if (!match) return content;\n  const indent = match[1] || \"  \";\n  if (content.includes(`${indent}${decoratorLine}`)) return content;\n  return (\n    content.slice(0, match.index) +\n    `${indent}${decoratorLine}\\n` +\n    content.slice(match.index)\n  );\n}\n\nfunction removeDecorator(\n  content: string,\n  decoratorName: string,\n  target: {\n    kind: \"class\" | \"property\";\n    name?: string;\n  }\n) {\n  const decoratorRegex = new RegExp(\n    `^\\\\s*@${escapeRegExp(decoratorName)}\\\\([^)]*\\\\)`,\n    \"m\"\n  );\n  if (target.kind === \"class\") {\n    return content.replace(decoratorRegex, \"\");\n  }\n  if (target.name) {\n    const pattern = new RegExp(\n      `(^\\\\s*@${escapeRegExp(decoratorName)}\\\\([^)]*\\\\)\\\\s*$\\\\n)(?=\\\\s*${escapeRegExp(target.name)}:)`,\n      \"m\"\n    );\n    return content.replace(pattern, \"\");\n  }\n  return content;\n}\n\nfunction writeIfChanged(filePath: string, content: string) {\n  ensureDirectory(filePath);\n  fs.writeFileSync(filePath, content);\n}\n\nexport const decoratorTools = {\n  createOrUpdateModelTool: {\n    name: \"create-or-update-model\",\n    description: \"Create or update a validation-ready model class\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      classDecorators?: DecoratorSpec[];\n      properties: AttributeSpec[];\n      importsFrom: string;\n      overwrite?: boolean;\n    }) => {\n      if (!args.overwrite && fs.existsSync(args.filePath)) {\n        throw new Error(`File already exists at ${args.filePath}`);\n      }\n      const decorators = collectDecoratorNames(\n        args.classDecorators,\n        args.properties\n      );\n      let content = `@model()`;\n      for (const decorator of args.classDecorators || []) {\n        content += `\\n${formatDecorator(decorator)}`;\n      }\n      const properties = (args.properties || [])\n        .map(addPropertyBlock)\n        .join(\"\\n\\n\");\n      content += `\\nexport class ${args.className} {\\n${properties ? `${properties}\\n` : \"\"}}\\n`;\n      content = ensureImport(content, args.importsFrom, decorators);\n      writeIfChanged(args.filePath, content);\n      return { filePath: args.filePath };\n    },\n  },\n  addAttributeTool: {\n    name: \"add-attribute\",\n    description: \"Add a decorated attribute to an existing model\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      attribute: AttributeSpec;\n      importsFrom: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) {\n        throw new Error(`Model file not found at ${args.filePath}`);\n      }\n      let content = fs.readFileSync(args.filePath, \"utf8\");\n      if (content.includes(`${args.attribute.name}:`)) {\n        return { filePath: args.filePath };\n      }\n      const decorators = collectDecoratorNames(undefined, [args.attribute]);\n      content = ensureImport(content, args.importsFrom, decorators);\n      const insertionPoint = content.lastIndexOf(\"}\");\n      const block = addPropertyBlock(args.attribute);\n      const before = content.slice(0, insertionPoint).replace(/\\s*$/, \"\");\n      const after = content.slice(insertionPoint);\n      const updated = `${before}\\n${block}\\n${after}`;\n      writeIfChanged(args.filePath, updated);\n      return { filePath: args.filePath };\n    },\n  },\n  removeAttributeTool: {\n    name: \"remove-attribute\",\n    description: \"Remove an attribute from a model class\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      attributeName: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) return { filePath: args.filePath };\n      const content = fs.readFileSync(args.filePath, \"utf8\");\n      const updated = removePropertyBlock(content, args.attributeName);\n      writeIfChanged(args.filePath, updated);\n      return { filePath: args.filePath };\n    },\n  },\n  applyDecoratorTool: {\n    name: \"apply-decorator\",\n    description: \"Apply a decorator to a class or property\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      target: { kind: \"class\" | \"property\"; name?: string };\n      decorator: DecoratorSpec;\n      importsFrom: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) {\n        throw new Error(`Model file not found at ${args.filePath}`);\n      }\n      let content = fs.readFileSync(args.filePath, \"utf8\");\n      const decorators = new Set<string>([args.decorator.name]);\n      content = ensureImport(content, args.importsFrom, decorators);\n      content = insertDecorator(content, args.decorator, args.target);\n      writeIfChanged(args.filePath, content);\n      return { filePath: args.filePath };\n    },\n  },\n  removeDecoratorTool: {\n    name: \"remove-decorator\",\n    description: \"Remove a decorator from a class or property\",\n    execute: async (args: {\n      filePath: string;\n      className: string;\n      target: { kind: \"class\" | \"property\"; name?: string };\n      decoratorName: string;\n    }) => {\n      if (!fs.existsSync(args.filePath)) return { filePath: args.filePath };\n      let content = fs.readFileSync(args.filePath, \"utf8\");\n      content = removeDecorator(content, args.decoratorName, args.target);\n      writeIfChanged(args.filePath, content);\n      return { filePath: args.filePath };\n    },\n  },\n  scaffoldValidatorTool: {\n    name: \"scaffold-validator\",\n    description: \"Scaffold a validator class and optional decorator\",\n    execute: async (args: {\n      validatorsDir: string;\n      decoratorDir?: string;\n      name: string;\n    }) => {\n      const classFile = path.join(args.validatorsDir, `${args.name}.ts`);\n      ensureDirectory(classFile);\n      const classContent = `export class ${args.name} {\\n  validate(value: unknown): boolean {\\n    return value !== undefined;\\n  }\\n}\\n`;\n      fs.writeFileSync(classFile, classContent);\n      let decoratorFile: string | undefined;\n      if (args.decoratorDir) {\n        decoratorFile = path.join(\n          args.decoratorDir,\n          `${args.name}Decorator.ts`\n        );\n        ensureDirectory(decoratorFile);\n        fs.writeFileSync(\n          decoratorFile,\n          `export function ${args.name}Decorator() {\\n  return () => void 0;\\n}\\n`\n        );\n      }\n      return { classFile, decoratorFile };\n    },\n  },\n  scaffoldSerializerTool: {\n    name: \"scaffold-serializer\",\n    description: \"Scaffold a serializer class and optional registry\",\n    execute: async (args: {\n      dir: string;\n      name: string;\n      registerDir?: string;\n      setDefault?: boolean;\n    }) => {\n      const classFile = path.join(args.dir, `${args.name}.ts`);\n      ensureDirectory(classFile);\n      fs.writeFileSync(\n        classFile,\n        `export class ${args.name} {\\n  serialize(value: unknown): string {\\n    return JSON.stringify(value);\\n  }\\n}\\n`\n      );\n      let registerFile: string | undefined;\n      if (args.registerDir) {\n        registerFile = path.join(args.registerDir, `${args.name}Register.ts`);\n        ensureDirectory(registerFile);\n        fs.writeFileSync(\n          registerFile,\n          `export function register${args.name}() {\\n  return ${args.setDefault ? \"'default'\" : \"'optional'\"};\\n}\\n`\n        );\n      }\n      return { classFile, registerFile };\n    },\n  },\n  scaffoldHashingTool: {\n    name: \"scaffold-hashing\",\n    description: \"Scaffold a hashing function and optional registry\",\n    execute: async (args: {\n      dir: string;\n      name: string;\n      registerDir?: string;\n      setDefault?: boolean;\n    }) => {\n      const functionFile = path.join(args.dir, `${args.name}.ts`);\n      ensureDirectory(functionFile);\n      fs.writeFileSync(\n        functionFile,\n        `export function ${args.name}(value: string): string {\\n  return value.split('').reverse().join('');\\n}\\n`\n      );\n      let registerFile: string | undefined;\n      if (args.registerDir) {\n        registerFile = path.join(args.registerDir, `${args.name}Register.ts`);\n        ensureDirectory(registerFile);\n        fs.writeFileSync(\n          registerFile,\n          `export function register${args.name}() {\\n  return ${args.setDefault ? \"'default'\" : \"'optional'\"};\\n}\\n`\n        );\n      }\n      return { functionFile, registerFile };\n    },\n  },\n} as const;\n\nexport type DecoratorTools = typeof decoratorTools;\n","import fs from \"fs\";\nimport path from \"path\";\nimport { ContentResult, Tool } from \"fastmcp\";\nimport { applyPatch, createTwoFilesPatch } from \"diff\";\nimport {\n  analyzeRepoSchema,\n  codeChangeSchema,\n  documentCodeSchema,\n  enumerateCapabilitiesSchema,\n  planFeatureSchema,\n} from \"../schemas\";\nimport { analyzeRepo } from \"../code\";\nimport { deriveCapabilities } from \"../utils\";\nimport {\n  getWorkspaceRoot,\n  resolveInWorkspace,\n  throwUserError,\n  WorkspaceError,\n} from \"../workspace\";\n// NOTE: prompt helpers (buildDocumentationPayload, discoverDocPrompts, selectPrompt, DEFAULT_PROMPT_NAME)\n// are imported dynamically inside documentCodeTool.execute to avoid creating a static circular import\n// at module load time (moduleRegistry -> modules -> decoration tools -> mcp/tools -> prompts).\n// They will be loaded when the tool executes.\nimport type { ApplyCodeChangeArgs, DocumentCodeArgs } from \"../types\";\n\nexport function buildAnalyzeRepositoryTool(): Tool<\n  undefined,\n  typeof analyzeRepoSchema\n> {\n  return {\n    name: \"analyze-repository\",\n    description:\n      \"Analyze a local repository's source, tests, and docs to extract exported APIs, decorators, and test mentions.\",\n    parameters: analyzeRepoSchema,\n    execute: async (input) => {\n      let repoRoot = path.resolve(process.cwd(), input.repoPath);\n      if (!fs.existsSync(repoRoot)) {\n        // try resolving from monorepo root (parent of current cwd)\n        const alt = path.resolve(process.cwd(), \"..\", input.repoPath);\n        if (fs.existsSync(alt)) repoRoot = alt;\n      }\n      if (!fs.existsSync(repoRoot)) {\n        // if input was absolute and still not found, try ../<basename>\n        const alt2 = path.resolve(\n          process.cwd(),\n          \"..\",\n          path.basename(input.repoPath)\n        );\n        if (fs.existsSync(alt2)) repoRoot = alt2;\n      }\n      if (!fs.existsSync(repoRoot))\n        throw new Error(`Repository not found at ${repoRoot}`);\n      const result = analyzeRepo(repoRoot);\n      return {\n        content: [{ type: \"text\", text: JSON.stringify(result, null, 2) }],\n      };\n    },\n  };\n}\n\nexport function buildEnumerateCapabilitiesTool(): Tool<\n  undefined,\n  typeof enumerateCapabilitiesSchema\n> {\n  return {\n    name: \"enumerate-capabilities\",\n    description:\n      \"Enumerate developer-facing capabilities of the given repository, inferred from code, tests, and docs.\",\n    parameters: enumerateCapabilitiesSchema,\n    execute: async (input) => {\n      let repoRoot = path.resolve(process.cwd(), input.repoPath);\n      if (!fs.existsSync(repoRoot)) {\n        const alt = path.resolve(process.cwd(), \"..\", input.repoPath);\n        if (fs.existsSync(alt)) repoRoot = alt;\n      }\n      if (!fs.existsSync(repoRoot)) {\n        const alt2 = path.resolve(\n          process.cwd(),\n          \"..\",\n          path.basename(input.repoPath)\n        );\n        if (fs.existsSync(alt2)) repoRoot = alt2;\n      }\n      if (!fs.existsSync(repoRoot))\n        throw new Error(`Repository not found at ${repoRoot}`);\n      const analysis = analyzeRepo(repoRoot);\n      const capabilities = deriveCapabilities(analysis);\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(\n              {\n                capabilities,\n                analysisSummary: {\n                  files: analysis.files.length,\n                  testFiles: analysis.testFiles.length,\n                  readme: analysis.readme?.title,\n                },\n              },\n              null,\n              2\n            ),\n          },\n        ],\n      };\n    },\n  };\n}\n\nexport function buildPlanFeatureTool(): Tool<\n  undefined,\n  typeof planFeatureSchema\n> {\n  return {\n    name: \"plan-feature-implementation\",\n    description:\n      \"Given a feature request, select appropriate MCP tools (including existing and new ones) and produce an execution plan.\",\n    parameters: planFeatureSchema,\n    execute: async (input) => {\n      const steps: Array<{\n        step: number;\n        action: string;\n        tool?: string;\n        arguments?: Record<string, any>;\n        rationale: string;\n      }> = [];\n      let i = 1;\n      steps.push({\n        step: i++,\n        action: \"Analyze repository to enumerate APIs and decorators\",\n        tool: \"analyze-repository\",\n        arguments: { repoPath: input.repoPath },\n        rationale: \"Understand available building blocks.\",\n      });\n      steps.push({\n        step: i++,\n        action: \"List capabilities expected for developers\",\n        tool: \"enumerate-capabilities\",\n        arguments: { repoPath: input.repoPath },\n        rationale: \"Align the plan with supported capabilities.\",\n      });\n      // Suggest existing generic tools from mcp-module\n      steps.push({\n        step: i++,\n        action:\n          \"Select documentation prompt and gather relevant source file(s)\",\n        tool: \"document-code\",\n        arguments: { filePath: \"<target-file>\" },\n        rationale: \"Provide context and instructions for changes.\",\n      });\n      steps.push({\n        step: i++,\n        action: \"Apply code changes using unified diff patch\",\n        tool: \"apply-code-change\",\n        arguments: {\n          filePath: \"<target-file>\",\n          patch: \"<unified-diff>\",\n          dryRun: true,\n        },\n        rationale: \"Validate changes safely before committing.\",\n      });\n      steps.push({\n        step: i++,\n        action: \"Commit code changes\",\n        tool: \"apply-code-change\",\n        arguments: {\n          filePath: \"<target-file>\",\n          patch: \"<unified-diff>\",\n          dryRun: false,\n        },\n        rationale: \"Persist the update.\",\n      });\n      // If decoration-related terms present, suggest decorator tools\n      if (/decorat|flavour|override|extend|builder/i.test(input.feature)) {\n        steps.unshift({\n          step: 0,\n          action: \"Use decorator tooling to insert/remove/modify decorators\",\n          tool: \"decorator-tools\",\n          arguments: { action: \"help\" },\n          rationale: \"Leverage specialized utilities for decoration patterns.\",\n        });\n        steps.forEach((s, idx) => (s.step = idx + 1));\n      }\n      return {\n        content: [\n          {\n            type: \"text\",\n            text: JSON.stringify(\n              {\n                plan: steps,\n                notes:\n                  \"Replace placeholder arguments like <target-file> and <unified-diff> based on the analysis output.\",\n              },\n              null,\n              2\n            ),\n          },\n        ],\n      };\n    },\n  };\n}\n\nexport const documentCodeTool: Tool<undefined, typeof documentCodeSchema> = {\n  annotations: {\n    idempotentHint: true,\n    openWorldHint: false,\n    readOnlyHint: true,\n    title: \"Document Source File\",\n  },\n  description:\n    \"Generate documentation guidance for a file by combining repository prompts with the target source code.\",\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (input, _context): Promise<ContentResult> => {\n    const args = documentCodeSchema.parse(input as DocumentCodeArgs);\n    const root = getWorkspaceRoot();\n    let filePath: string;\n    try {\n      filePath = resolveInWorkspace(root, args.filePath);\n    } catch (error) {\n      if (error instanceof WorkspaceError) {\n        return throwUserError(error.message);\n      }\n      /* istanbul ignore next */\n      throw error;\n    }\n\n    if (!fs.existsSync(filePath)) {\n      return throwUserError(`Cannot document missing file at ${args.filePath}`);\n    }\n\n    const fileContent = fs.readFileSync(filePath, {\n      encoding: args.encoding as BufferEncoding,\n    });\n    // dynamically import prompt helpers\n    const promptMod = await import(\"../prompts/prompts\");\n    const {\n      discoverDocPrompts,\n      selectPrompt,\n      DEFAULT_PROMPT_NAME,\n      buildDocumentationPayload,\n    } = promptMod;\n    const prompts = discoverDocPrompts(root);\n\n    if (!prompts.length) {\n      return throwUserError(\n        \"No documentation prompts found under .code/prompts or .codex/prompts\"\n      );\n    }\n\n    const prompt = selectPrompt(\n      prompts,\n      args.promptName ?? DEFAULT_PROMPT_NAME\n    );\n\n    return buildDocumentationPayload({\n      filePath: args.filePath,\n      fileContent,\n      prompt,\n      includeCode: args.includeCode,\n      includePrompt: args.includePrompt,\n      includeMetadata: args.includeMetadata,\n      additionalContext: args.additionalContext,\n    });\n  },\n  name: \"document-code\",\n  parameters: documentCodeSchema,\n};\n\nexport const applyCodeChangeTool: Tool<undefined, typeof codeChangeSchema> = {\n  annotations: {\n    destructiveHint: true,\n    idempotentHint: false,\n    openWorldHint: false,\n    readOnlyHint: false,\n    title: \"Apply Code Patch\",\n  },\n  description:\n    \"Apply a unified diff patch to a workspace file with optional dry-run validation and diff preview.\",\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  execute: async (input, _context): Promise<string | ContentResult> => {\n    const args = codeChangeSchema.parse(input as ApplyCodeChangeArgs);\n    const root = getWorkspaceRoot();\n    let filePath: string;\n    try {\n      filePath = resolveInWorkspace(root, args.filePath);\n    } catch (error) {\n      if (error instanceof WorkspaceError) {\n        return throwUserError(error.message);\n      }\n      throw error;\n    }\n\n    const original = fs.existsSync(filePath)\n      ? fs.readFileSync(filePath, args.encoding as BufferEncoding)\n      : \"\";\n\n    let patched: string | false;\n    try {\n      patched = applyPatch(original, args.patch);\n    } catch (error) {\n      return throwUserError(\n        `Failed to apply provided patch to ${args.filePath}: ${error instanceof Error ? error.message : error}`\n      );\n    }\n    /* istanbul ignore next */\n    if (patched === false) {\n      return throwUserError(\n        `Failed to apply provided patch to ${args.filePath}`\n      );\n    }\n\n    if (!args.dryRun) {\n      fs.mkdirSync(path.dirname(filePath), { recursive: true });\n      fs.writeFileSync(filePath, patched, {\n        encoding: args.encoding as BufferEncoding,\n      });\n    }\n\n    if (!args.showDiff) {\n      return `Patch ${args.dryRun ? \"validated\" : \"applied\"} for ${args.filePath}`;\n    }\n\n    const preview = createTwoFilesPatch(\n      args.filePath,\n      args.filePath,\n      original,\n      patched,\n      undefined,\n      undefined,\n      { context: args.diffContext }\n    );\n\n    return {\n      content: [\n        {\n          type: \"text\",\n          text: `Patch ${args.dryRun ? \"validated\" : \"applied\"} for ${args.filePath}`,\n        },\n        {\n          type: \"text\",\n          text: [\"```diff\", preview.trim(), \"```\"].join(\"\\n\"),\n        },\n      ],\n    } satisfies ContentResult;\n  },\n  name: \"apply-code-change\",\n  parameters: codeChangeSchema,\n};\n\ntype AnyTool = Tool<undefined, any>;\n\nconst analyticTools: AnyTool[] = [\n  buildAnalyzeRepositoryTool(),\n  buildEnumerateCapabilitiesTool(),\n  buildPlanFeatureTool(),\n];\n\nexport const toolList: AnyTool[] = [\n  ...analyticTools,\n  documentCodeTool,\n  applyCodeChangeTool,\n];\n","import { moduleRegistry } from \"../moduleRegistry\";\nimport {\n  coverageEnforcerTool,\n  documentObjectTool,\n  readmeImprovementTool,\n} from \"./codex-tools\";\nimport { decoratorTools } from \"../decorator-tools\";\nconst codexToolList = [\n  documentObjectTool,\n  coverageEnforcerTool,\n  readmeImprovementTool,\n];\n\nimport { toolList as coreToolList } from \"./tools\";\n\nconst moduleToolList = moduleRegistry\n  .listTools()\n  .map((asset) => asset.tool as any);\n\nexport const toolList = [...coreToolList, ...codexToolList, ...moduleToolList];\nconst [\n  analyzeRepositoryTool,\n  enumerateCapabilitiesTool,\n  planFeatureTool,\n  documentCodeToolRef,\n  applyCodeChangeToolRef,\n] = coreToolList;\n\nexport const tools = {\n  analyzeRepositoryTool,\n  enumerateCapabilitiesTool,\n  planFeatureTool,\n  documentCodeTool: documentCodeToolRef,\n  applyCodeChangeTool: applyCodeChangeToolRef,\n  documentObjectTool,\n  coverageEnforcerTool,\n  readmeImprovementTool,\n  ...decoratorTools,\n};\nexport { decoratorTools };\n","import type { Resource } from \"fastmcp\";\nimport type { ResourceAsset } from \"../../types\";\nimport { moduleRegistry } from \"../moduleRegistry\";\nimport { getWorkspaceRoot } from \"../workspace\";\nimport { buildObjectPrompts, discoverDocPrompts } from \"../prompts/prompts\";\n\nfunction toResource(asset: ResourceAsset): Resource<undefined> {\n  return {\n    name: asset.id,\n    uri: asset.uri,\n    description: asset.description ?? asset.title,\n    mimeType: asset.mimeType,\n    load: async () => {\n      const res = await asset.load();\n      // asset.load may return a ContentResult or a Promise of ContentResult; ensure we return ResourceResult-like object\n      if ((res as any)?.content) {\n        const cr = res as any;\n        // If ContentResult, convert to simple text result expected by Resource.load consumers\n        return {\n          text: Array.isArray(cr.content)\n            ? cr.content.map((c: any) => c.text).join(\"\\n\")\n            : String(cr),\n        };\n      }\n      // fallback for objects with text\n      return res as any as { text: string };\n    },\n  };\n}\n\nfunction buildModuleResources(): Resource<undefined>[] {\n  return moduleRegistry.listResources().map(toResource);\n}\n\nexport const resources: Resource<undefined>[] = [\n  {\n    name: \"codex-prompt-index\",\n    uri: \"codex://prompts/index\",\n    description:\n      \"Enumerate available .codex prompt files with titles and descriptions.\",\n    mimeType: \"application/json\",\n    load: async () => {\n      const root = getWorkspaceRoot();\n      const prompts = discoverDocPrompts(root).map((prompt) => ({\n        name: prompt.name,\n        title: prompt.title,\n        description: prompt.description,\n        path: prompt.absolutePath,\n      }));\n      return {\n        text: JSON.stringify({ prompts }, null, 2),\n        mimeType: \"application/json\",\n      };\n    },\n  },\n  {\n    name: \"codex-object-prompts\",\n    uri: \"codex://prompts/objects\",\n    description:\n      \"Provides the resolved prompt content for each documented object workflow.\",\n    mimeType: \"application/json\",\n    load: async () => {\n      const entries = await Promise.all(\n        buildObjectPrompts().map(async (prompt) => ({\n          name: prompt.name,\n          description: prompt.description,\n          content: await prompt.load({} as never),\n        }))\n      );\n      return {\n        text: JSON.stringify({ prompts: entries }, null, 2),\n        mimeType: \"application/json\",\n      };\n    },\n  },\n  ...buildModuleResources(),\n];\n","import path from \"path\";\nimport fs from \"fs\";\nimport { getWorkspaceRoot, resolveInWorkspace } from \"../workspace\";\nimport type { PromptResourceTemplate } from \"../types\";\n\nexport const codexPromptTemplates: PromptResourceTemplate[] = [];\n\nexport function buildCodexPromptTemplates(): PromptResourceTemplate[] {\n  const root = getWorkspaceRoot();\n  const templates: PromptResourceTemplate[] = [\n    {\n      name: \"codex-prompt\",\n      description:\n        \"Load a .codex prompt file by name (without extension) as markdown.\",\n      uriTemplate: \"codex-prompt://{name}\",\n      mimeType: \"text/markdown\",\n      arguments: [\n        {\n          name: \"name\",\n          description:\n            \"Name of the prompt file inside .codex/prompts (without .md).\",\n          required: true,\n        },\n      ],\n      load: async ({ name }) => {\n        const promptPath = resolveInWorkspace(\n          root,\n          path.join(\".codex\", \"prompts\", `${name}.md`)\n        );\n        if (!fs.existsSync(promptPath)) {\n          throw new Error(`Prompt .codex/prompts/${name}.md not found`);\n        }\n        const text = fs.readFileSync(promptPath, \"utf8\");\n        return { text, uri: `codex-prompt:///${name}` };\n      },\n    },\n  ];\n\n  codexPromptTemplates.splice(0, codexPromptTemplates.length, ...templates);\n  return codexPromptTemplates;\n}\n","import path from \"path\";\nimport type { DecorationResourceTemplate } from \"../types\";\nimport { getWorkspaceRoot, readWorkspaceFile } from \"../workspace\";\n\nexport const decorationResourceTemplates: DecorationResourceTemplate[] = [];\n\nfunction makeLoader(type: \"src\" | \"tests\" | \"workdocs\") {\n  return async ({ path: relative }: { path: string }) => {\n    const root = getWorkspaceRoot();\n    const target = path.join(type, relative);\n    const text = await readWorkspaceFile(root, target);\n    return { text };\n  };\n}\n\nexport function buildDecorationResourceTemplates(): DecorationResourceTemplate[] {\n  const templates: DecorationResourceTemplate[] = [\n    {\n      name: \"read-code-from-source\",\n      description:\n        \"Read a file from the <base_path>/src tree by relative path.\",\n      mimeType: \"text/plain\",\n      uriTemplate: \"from-source://src/{path}\",\n      arguments: [\n        {\n          name: \"path\",\n          description:\n            \"Path under <base_path>/src to load, e.g. 'decoration/types.ts'\",\n          required: true,\n        },\n      ],\n      load: makeLoader(\"src\"),\n    },\n    {\n      name: \"read-test-from-source\",\n      description:\n        \"Read a file from the <base_path>/tests tree by relative path.\",\n      mimeType: \"text/plain\",\n      uriTemplate: \"from-source://tests/{path}\",\n      arguments: [\n        {\n          name: \"path\",\n          description:\n            \"Path under <base_path>/tests to load, e.g. 'decoration/tests/types.test.ts'\",\n          required: true,\n        },\n      ],\n      load: makeLoader(\"tests\"),\n    },\n    {\n      name: \"read-doc-from-source\",\n      description:\n        \"Read a file from the <base_path>/workdocs tree by relative path.\",\n      mimeType: \"text/plain\",\n      uriTemplate: \"from-source://workdocs/{path}\",\n      arguments: [\n        {\n          name: \"path\",\n          description:\n            \"Path under <base_path>/workdocs to load, e.g. 'decoration/workdocs/tutorials/for-developers.md'\",\n          required: true,\n        },\n      ],\n      load: makeLoader(\"workdocs\"),\n    },\n  ];\n\n  decorationResourceTemplates.splice(\n    0,\n    decorationResourceTemplates.length,\n    ...templates\n  );\n  return decorationResourceTemplates;\n}\n","import { WorkspaceResourceTemplate } from \"../types\";\nimport { getWorkspaceRoot, readWorkspaceFile } from \"../workspace\";\n\nexport const workspaceResourceTemplates: WorkspaceResourceTemplate[] = [];\n\nexport function buildWorkspaceResourceTemplates(): WorkspaceResourceTemplate[] {\n  const root = getWorkspaceRoot();\n  const sharedArguments = [\n    {\n      name: \"path\",\n      description: \"Path relative to the workspace root\",\n      required: true,\n    },\n  ] as const;\n\n  const templates: WorkspaceResourceTemplate[] = [\n    {\n      name: \"vscode-workspace-file\",\n      description:\n        \"Expose workspace files to Visual Studio Code via vscode:// URIs\",\n      uriTemplate: \"vscode://workspace/{path}\",\n      mimeType: \"text/plain\",\n      arguments: sharedArguments,\n      load: async (args: { path: string }) => {\n        try {\n          const text = await readWorkspaceFile(root, args.path);\n          return { text: String(text) };\n        } catch (err) {\n          // propagate as-is for tests to assert errors\n          throw err;\n        }\n      },\n    },\n    {\n      name: \"cursor-workspace-file\",\n      description: \"Expose workspace files to Cursor via cursor:// URIs\",\n      uriTemplate: \"cursor://workspace/{path}\",\n      mimeType: \"text/plain\",\n      arguments: sharedArguments,\n      load: async (args: { path: string }) => {\n        try {\n          const text = await readWorkspaceFile(root, args.path);\n          return { text: String(text) };\n        } catch (err) {\n          throw err;\n        }\n      },\n    },\n    {\n      name: \"copilot-workspace-file\",\n      description:\n        \"Expose workspace files to GitHub Copilot via copilot:// URIs\",\n      uriTemplate: \"copilot://workspace/{path}\",\n      mimeType: \"text/plain\",\n      arguments: sharedArguments,\n      load: async (args: { path: string }) => {\n        try {\n          const text = await readWorkspaceFile(root, args.path);\n          return { text: String(text) };\n        } catch (err) {\n          throw err;\n        }\n      },\n    },\n  ];\n\n  workspaceResourceTemplates.splice(\n    0,\n    workspaceResourceTemplates.length,\n    ...templates\n  );\n  return workspaceResourceTemplates;\n}\n\n","import { buildCodexPromptTemplates } from \"./codex-templates\";\nimport { buildDecorationResourceTemplates } from \"./resource-templates\";\nimport { buildWorkspaceResourceTemplates } from \"./workspace-templates\";\nimport { moduleRegistry } from \"../moduleRegistry\";\n\nexport {\n  buildCodexPromptTemplates,\n  codexPromptTemplates,\n} from \"./codex-templates\";\nexport {\n  buildDecorationResourceTemplates,\n  decorationResourceTemplates,\n} from \"./resource-templates\";\nexport {\n  buildWorkspaceResourceTemplates,\n  workspaceResourceTemplates,\n} from \"./workspace-templates\";\n\nexport function buildResourceTemplates() {\n  const moduleTemplates = moduleRegistry.listTemplates().map((template) => ({\n    name: template.id,\n    description: template.description ?? template.title,\n    mimeType: \"text/markdown\",\n    uriTemplate: `module-template://${template.id}`,\n    arguments: (template.placeholders ?? []).map((name) => ({\n      name,\n      description: `Value for ${name}`,\n      required: true,\n    })),\n    load: async () => ({\n      text:\n        typeof (template as any).content === \"string\"\n          ? (template as any).content\n          : `# ${template.description ?? template.title ?? template.id}\\n\\nNo template content available for ${template.id}`,\n    }),\n  }));\n\n  const all = [\n    ...buildWorkspaceResourceTemplates(),\n    ...buildCodexPromptTemplates(),\n    ...buildDecorationResourceTemplates(),\n    ...moduleTemplates,\n  ];\n\n  // Normalise all loaders to always return { text: string }\n  function normaliseResult(res: any) {\n    if (res == null) return { text: \"\" };\n    if (typeof res === \"string\") return { text: res };\n    if (typeof res.text === \"string\") return res;\n    // handle legacy ContentResult shapes with content or content array\n    if (Array.isArray(res.content)) {\n      const parts = res.content\n        .map((c: any) => (c && typeof c.text === \"string\" ? c.text : String(c)))\n        .join(\"\\n\");\n      return { text: parts };\n    }\n    if (res.content && typeof res.content.text === \"string\") {\n      return { text: res.content.text };\n    }\n    // fallback: stringify\n    try {\n      return { text: JSON.stringify(res) };\n    } catch {\n      return { text: String(res) };\n    }\n  }\n\n  return all.map((t) => ({\n    ...t,\n    load: async (args: any) => {\n      const raw = await (t.load as any)(args);\n      return normaliseResult(raw);\n    },\n  }));\n}\n\nexport const templateList = buildResourceTemplates();\n","import { Metadata } from \"@decaf-ts/decoration\";\n\n/**\n * @const VERSION\n * @name VERSION\n * @description Represents the current version of the ts-workspace module.\n * @summary The actual version number is replaced during the build process.\n * @type {string}\n */\nexport const VERSION = \"##VERSION##\";\nexport const PACKAGE_NAME = \"##PACKAGE_NAME##\";\n\ntry {\n  Metadata.registerLibrary(PACKAGE_NAME, VERSION);\n} catch (error) {\n  if (error instanceof Error && error.message.includes(\"already\")) {\n    // Ignore duplicate registration during tests/bundling checks.\n  } else {\n    throw error;\n  }\n}\n","import type { FastMCP } from \"fastmcp\";\nimport { PACKAGE_NAME as PKG, VERSION as V } from \"../metadata\";\nimport { loadPrompts, promptList } from \"./prompts\";\nimport { resources } from \"./resources\";\nimport {\n  buildDecorationResourceTemplates,\n  buildResourceTemplates,\n  decorationResourceTemplates,\n  templateList,\n  workspaceResourceTemplates,\n} from \"./templates\";\nimport { toolList, tools } from \"./tools\";\nimport {\n  __resetWorkspaceRoot,\n  getWorkspaceRoot,\n  setWorkspaceRoot,\n} from \"./workspace\";\n\nexport function enrich(mcp: FastMCP): FastMCP {\n  const promptEntries = loadPrompts();\n  for (const prompt of promptEntries) {\n    mcp.addPrompt(prompt as any);\n  }\n\n  for (const tool of toolList) {\n    mcp.addTool(tool as any);\n  }\n\n  const templates = buildResourceTemplates();\n  for (const template of templates) {\n    mcp.addResourceTemplate(template as any);\n  }\n\n  for (const resource of resources) {\n    const addResource = (\n      mcp as unknown as { addResource?: (res: unknown) => void }\n    ).addResource;\n    if (typeof addResource === \"function\") {\n      addResource.call(mcp, resource as any);\n    }\n  }\n\n  return mcp;\n}\n\nexport default enrich;\nexport const PACKAGE_NAME = PKG;\nexport const VERSION = V;\n\nexport {\n  tools,\n  toolList,\n  buildDecorationResourceTemplates,\n  buildResourceTemplates,\n  decorationResourceTemplates,\n  promptList,\n  resources,\n  templateList,\n  workspaceResourceTemplates,\n  getWorkspaceRoot,\n  setWorkspaceRoot,\n  __resetWorkspaceRoot,\n};\n","// New: validation entrypoint for module structure\nimport fs from \"fs\";\nimport path from \"path\";\n\nexport type ValidationIssue = {\n  module: string;\n  path: string;\n  type:\n    | \"missing-folder\"\n    | \"missing-export\"\n    | \"empty-list\"\n    | \"disabled\"\n    | \"other\";\n  detail?: string;\n};\n\nexport type ValidationReport = {\n  ok: boolean;\n  modulesChecked: number;\n  issues: ValidationIssue[];\n};\n\nconst REQUIRED_SUBFOLDERS = [\"prompts\", \"resources\", \"templates\", \"tools\"];\n\nexport function findModuleDirs(repoRoot: string): string[] {\n  const modulesPath = path.resolve(repoRoot, \"src\", \"modules\");\n  if (!fs.existsSync(modulesPath) || !fs.statSync(modulesPath).isDirectory()) {\n    return [];\n  }\n  return fs\n    .readdirSync(modulesPath, { withFileTypes: true })\n    .filter((d) => d.isDirectory())\n    .map((d) => path.join(modulesPath, d.name));\n}\n\nfunction hasIndexExport(folderPath: string): boolean {\n  const candidates = [\n    \"index.ts\",\n    \"index.tsx\",\n    \"index.js\",\n    \"index.cjs\",\n    \"index.mjs\",\n  ];\n  for (const c of candidates) {\n    if (fs.existsSync(path.join(folderPath, c))) return true;\n  }\n  return false;\n}\n\nexport function validateModules(repoRoot: string): ValidationReport {\n  const dirs = findModuleDirs(repoRoot);\n  const issues: ValidationIssue[] = [];\n\n  for (const moduleDir of dirs) {\n    const moduleName = path.basename(moduleDir);\n    for (const sub of REQUIRED_SUBFOLDERS) {\n      const subPath = path.join(moduleDir, sub);\n      if (!fs.existsSync(subPath) || !fs.statSync(subPath).isDirectory()) {\n        issues.push({\n          module: moduleName,\n          path: subPath,\n          type: \"missing-folder\",\n          detail: `Required folder '${sub}' is missing in module '${moduleName}'`,\n        });\n        continue;\n      }\n      // If folder exists, check for index export\n      if (!hasIndexExport(subPath)) {\n        issues.push({\n          module: moduleName,\n          path: subPath,\n          type: \"missing-export\",\n          detail: `No index export found in '${subPath}'. Expected one of index.ts, index.js, etc.`,\n        });\n        continue;\n      }\n      // Optionally inspect the index file to see if it exports a list (lightweight check)\n      try {\n        const indexFile = candidatesFindingIndex(subPath);\n        if (indexFile) {\n          const content = fs.readFileSync(indexFile, \"utf8\");\n          // crude heuristics: look for `export const name = [` or `export const name: Type[] = [`,\n          // or any named export like `export { something }` which implies exports exist.\n          const exportListPattern =\n            /export\\s+(const|let|var)\\s+[\\w$]+(?:\\s*:\\s*[^=]+)?\\s*=\\s*\\[/;\n          if (\n            !exportListPattern.test(content) &&\n            !/export\\s+\\{/.test(content)\n          ) {\n            issues.push({\n              module: moduleName,\n              path: indexFile,\n              type: \"empty-list\",\n              detail: `Index file does not appear to export a list of assets: ${path.basename(indexFile)}`,\n            });\n          }\n        }\n      } catch (err: any) {\n        issues.push({\n          module: moduleName,\n          path: subPath,\n          type: \"other\",\n          detail: `Error reading index file: ${err.message}`,\n        });\n      }\n    }\n  }\n\n  return {\n    ok: issues.length === 0,\n    modulesChecked: dirs.length,\n    issues,\n  };\n}\n\nfunction candidatesFindingIndex(folderPath: string): string | undefined {\n  const candidates = [\n    \"index.ts\",\n    \"index.tsx\",\n    \"index.js\",\n    \"index.cjs\",\n    \"index.mjs\",\n  ];\n  for (const c of candidates) {\n    const full = path.join(folderPath, c);\n    if (fs.existsSync(full)) return full;\n  }\n  return undefined;\n}\n\n// CLI helper\nif (require.main === module) {\n  const repoRoot = process.cwd();\n  const report = validateModules(repoRoot);\n  if (!report.ok) {\n    console.error(\n      \"Module validation failed:\\n\",\n      JSON.stringify(report, null, 2)\n    );\n    process.exit(2);\n  }\n  console.log(\"Module validation passed\");\n  process.exit(0);\n}\n","// Aggregator: import module index files and merge exported arrays with provenance + duplicate detection\nimport path from \"path\";\nimport fs from \"fs\";\nimport { pathToFileURL } from \"url\";\nimport { findModuleDirs } from \"./validation\";\n\nexport type Provenance = { moduleName: string; modulePath: string };\nexport type AggregationConflict = {\n  key: string;\n  existing: Provenance;\n  incoming: Provenance;\n};\n\nexport type AggregationResult<T = any> = {\n  prompts: Array<T & { provenance: Provenance }>;\n  resources: Array<T & { provenance: Provenance }>;\n  templates: Array<T & { provenance: Provenance }>;\n  tools: Array<T & { provenance: Provenance }>;\n  conflicts: AggregationConflict[];\n};\n\nconst SUBFOLDERS = [\"prompts\", \"resources\", \"templates\", \"tools\"];\nconst INDEX_CANDIDATES = [\n  \"index.ts\",\n  \"index.tsx\",\n  \"index.js\",\n  \"index.cjs\",\n  \"index.mjs\",\n];\n\nfunction findIndexFile(folder: string): string | undefined {\n  for (const c of INDEX_CANDIDATES) {\n    const f = path.join(folder, c);\n    if (fs.existsSync(f)) return f;\n  }\n  return undefined;\n}\n\nfunction makeKeyForItem(item: any): string {\n  if (!item) return JSON.stringify(item);\n  if (typeof item === \"string\") return `str:${item}`;\n  if (typeof item === \"number\") return `num:${item}`;\n  if (item.id) return `id:${item.id}`;\n  if (item.name) return `name:${item.name}`;\n  // fallback to stable string\n  try {\n    return `obj:${JSON.stringify(item)}`;\n  } catch (e) {\n    return `obj:${String(item)}`;\n  }\n}\n\nasync function loadArrayFromIndex(\n  filePath: string\n): Promise<any[] | undefined> {\n  // Prefer a fast, static parse of the first array literal found in the file.\n  try {\n    const content = fs.readFileSync(filePath, \"utf8\");\n    const start = content.indexOf(\"[\");\n    if (start !== -1) {\n      let depth = 0;\n      let end = -1;\n      for (let i = start; i < content.length; i++) {\n        const ch = content[i];\n        if (ch === \"[\") depth++;\n        else if (ch === \"]\") {\n          depth--;\n          if (depth === 0) {\n            end = i;\n            break;\n          }\n        }\n      }\n      if (end !== -1) {\n        const arrText = content.slice(start, end + 1);\n        try {\n          return JSON.parse(arrText);\n        } catch (e) {\n          // Normalize TS object literals to JSON:\n          // - convert single quotes to double quotes\n          // - quote unquoted object keys\n          // - strip trailing commas\n          const normalized = arrText\n            // unify quotes in string literals\n            .replace(/'(?:\\\\'|[^'])*'/g, (m) => m.replace(/'/g, '\"'))\n            // quote unquoted keys after { or ,\n            .replace(/([\\{,]\\s*)([A-Za-z_$][\\w$]*)(\\s*:)/g, '$1\"$2\"$3')\n            // remove trailing commas before ] or }\n            .replace(/,(\\s*[\\}\\]])/g, '$1');\n          try {\n            return JSON.parse(normalized);\n          } catch (e2) {\n            // fallthrough to import attempt below\n          }\n        }\n      }\n    }\n  } catch (e) {\n    // ignore static parse errors and fall back to import\n  }\n\n  try {\n    const fileUrl = pathToFileURL(filePath).href;\n    const mod = await import(fileUrl);\n    // Find first export that is an array\n    for (const key of Object.keys(mod)) {\n      const val = (mod as any)[key];\n      if (Array.isArray(val)) return val;\n    }\n    // default export check\n    if (Array.isArray((mod as any).default)) return (mod as any).default;\n    return undefined;\n  } catch (err) {\n    // fallback: if import fails, try to static-parse again (already attempted) and finally return undefined\n    return undefined;\n  }\n}\n\nexport async function aggregateModules(\n  repoRoot: string\n): Promise<AggregationResult> {\n  const dirs = findModuleDirs(repoRoot);\n  const master = {\n    prompts: [] as any[],\n    resources: [] as any[],\n    templates: [] as any[],\n    tools: [] as any[],\n    conflicts: [] as AggregationConflict[],\n  };\n\n  // maps to detect duplicates per type\n  const maps: Record<string, Map<string, Provenance>> = {\n    prompts: new Map(),\n    resources: new Map(),\n    templates: new Map(),\n    tools: new Map(),\n  };\n\n  for (const moduleDir of dirs) {\n    const moduleName = path.basename(moduleDir);\n    for (const sub of SUBFOLDERS) {\n      const folder = path.join(moduleDir, sub);\n      const indexFile = findIndexFile(folder);\n      if (!indexFile) continue;\n      let arr: any[] | undefined;\n      try {\n        arr = await loadArrayFromIndex(indexFile);\n      } catch (err: any) {\n        // skip module on import error but record as conflict-like issue\n        master.conflicts.push({\n          key: `import-error:${moduleName}:${sub}`,\n          existing: { moduleName, modulePath: moduleDir },\n          incoming: { moduleName, modulePath: moduleDir },\n        });\n        continue;\n      }\n      if (!arr || !Array.isArray(arr)) continue;\n\n      for (const item of arr) {\n        const key = makeKeyForItem(item);\n        const provenance = { moduleName, modulePath: moduleDir };\n        const map = maps[sub];\n        if (map.has(key)) {\n          // record conflict deterministically (existing vs incoming)\n          const existing = map.get(key)!;\n          master.conflicts.push({ key, existing, incoming: provenance });\n          // skip adding duplicate\n          continue;\n        }\n        map.set(key, provenance);\n        (master as any)[sub].push({ ...item, provenance });\n      }\n    }\n  }\n\n  return master;\n}\n\n// For compatibility with CommonJS call sites (not exported by ESM), provide a sync wrapper\nexport function aggregateModulesSync(repoRoot: string) {\n  // synchronous wrapper that runs the async function and blocks — suitable for small module sets\n  const p = aggregateModules(repoRoot);\n  let result: any;\n  let done = false;\n  p.then((r) => {\n    result = r;\n    done = true;\n  }).catch((e) => {\n    throw e;\n  });\n  // spin-wait (acceptable in small dev scripts)\n  const until = Date.now() + 5000;\n  while (!done && Date.now() < until) {}\n  if (!done)\n    throw new Error(\n      \"aggregateModulesSync: timeout waiting for async aggregation\"\n    );\n  return result as AggregationResult;\n}\n","import { aggregateModules } from \"./aggregateModules\";\nimport { loadPrompts, promptList } from \"./prompts/index\";\nimport { toolList } from \"./tools/index\";\nimport { resources } from \"./resources/index\";\nimport { buildResourceTemplates } from \"./templates/index\";\n\nexport type FastMCPLike = {\n  addPrompt: (p: any) => void;\n  addTool: (t: any) => void;\n  addResource: (r: any) => void;\n  addResourceTemplate: (t: any) => void;\n};\n\n/**\n * Aggregate module assets and register them on the provided FastMCP-like server.\n * Falls back to built-in lists if aggregation yields none.\n */\nexport async function EnrichCoreWithAggregation(\n  server: FastMCPLike,\n  repoRoot = process.cwd()\n) {\n  // First register built-in prompts/tools/resources/templates (legacy behavior)\n  try {\n    loadPrompts();\n    for (const prompt of promptList) server.addPrompt(prompt as any);\n  } catch (e) {\n    // ignore if loadPrompts not available or fails\n  }\n\n  try {\n    for (const tool of toolList) server.addTool(tool as any);\n  } catch (e) {}\n\n  try {\n    for (const resource of resources) server.addResource(resource as any);\n  } catch (e) {}\n\n  try {\n    const templates = buildResourceTemplates();\n    for (const template of templates)\n      server.addResourceTemplate(template as any);\n  } catch (e) {}\n\n  // Now aggregate modules and register aggregated assets with provenance\n  const agg = await aggregateModules(repoRoot);\n\n  for (const p of agg.prompts) {\n    server.addPrompt(p);\n  }\n  for (const t of agg.tools) {\n    server.addTool(t);\n  }\n  for (const r of agg.resources) {\n    server.addResource(r);\n  }\n  for (const tpl of agg.templates) {\n    server.addResourceTemplate(tpl);\n  }\n\n  // return aggregation summary for calling tests/CI\n  return {\n    modulesChecked: agg.prompts.concat(agg.tools).length,\n    conflicts: agg.conflicts,\n  };\n}\n","import { FastMCP } from \"fastmcp\";\nimport { loadPrompts, promptList } from \"./prompts/index\";\nimport { toolList } from \"./tools/index\";\nimport { resources } from \"./resources/index\";\nimport { buildResourceTemplates } from \"./templates/index\";\n\nexport * from \"./mcp-module\";\nexport { default } from \"./mcp-module\";\n\nexport { validateModules } from \"./validation\";\nexport { aggregateModules, aggregateModulesSync } from \"./aggregateModules\";\nexport { EnrichCoreWithAggregation } from \"./fastmcp-wiring\";\n\n// re-export helpers used by tests and other modules\nexport { buildDocPrompts } from \"./prompts/index\";\nexport { buildResourceTemplates } from \"./templates/index\";\n\nexport function EnrichCore(server: FastMCP) {\n  loadPrompts();\n  for (const prompt of promptList) {\n    server.addPrompt(prompt as any);\n  }\n  for (const tool of toolList) {\n    server.addTool(tool as any);\n  }\n  for (const resource of resources) {\n    server.addResource(resource as any);\n  }\n  const templates = buildResourceTemplates();\n  for (const template of templates) {\n    server.addResourceTemplate(template as any);\n  }\n}\n","import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { getWorkspaceRoot } from \"../mcp/workspace\";\n\nexport const REQUIRED_MODULE_FOLDERS = [\n  \"prompts\",\n  \"resources\",\n  \"templates\",\n  \"tools\",\n] as const;\n\nexport type ModuleFolder = (typeof REQUIRED_MODULE_FOLDERS)[number];\n\nexport function resolveModulesRoot(workspaceRoot = getWorkspaceRoot()): string {\n  return path.resolve(workspaceRoot, \"src/modules\");\n}\n\nexport function listModuleDirectories(workspaceRoot = getWorkspaceRoot()): string[] {\n  const root = resolveModulesRoot(workspaceRoot);\n  if (!fs.existsSync(root)) return [];\n\n  return fs\n    .readdirSync(root)\n    .map((entry) => ({\n      entry,\n      absolute: path.join(root, entry),\n    }))\n    .filter(({ absolute }) => fs.statSync(absolute).isDirectory())\n    .map(({ entry }) => entry)\n    .sort();\n}\n\nexport function resolveModulePath(\n  moduleName: string,\n  workspaceRoot = getWorkspaceRoot()\n): string {\n  return path.join(resolveModulesRoot(workspaceRoot), moduleName);\n}\n\nexport function resolveModuleFolderPath(\n  moduleName: string,\n  folder: ModuleFolder,\n  workspaceRoot = getWorkspaceRoot()\n): string {\n  return path.join(resolveModulePath(moduleName, workspaceRoot), folder);\n}\n","/* istanbul ignore file */\nimport path from \"path\";\nimport fs from \"fs\";\nimport { McpModule } from \"./types\";\n\n/**\n * @description Utility class for CLI operations\n * @summary A static utility class that provides methods for loading modules, retrieving package information, and initializing CLI commands\n *\n * @example\n * // Initialize a Command object with package information\n * const command = new Command();\n * CLIUtils.initialize(command, './path/to/package');\n *\n * // Load a CLI module from a file\n * const module = await CLIUtils.loadFromFile('./path/to/cli-module.js');\n *\n * @class McpUtils\n */\nexport class McpUtils {\n  /**\n   * @description Dynamically imports a module file\n   * @summary Loads a JavaScript file and returns it as a CliModule, handling both ESM and CommonJS formats\n   *\n   * @param {string} path The file path to the module to load\n   * @return {Promise<McpModule>} A promise that resolves to the loaded CliModule\n   */\n  static async loadFromFile(path: string): Promise<McpModule> {\n    try {\n      return McpUtils.normalizeImport(import(path));\n    } catch (e: unknown) {\n      throw new Error(\n        `Failed to load from ${path}: ${e instanceof Error ? e.message : e}`\n      );\n    }\n  }\n\n  /**\n   * @description Normalizes module imports to handle both ESM and CommonJS formats\n   * @summary Properly imports JavaScript files regardless of their module format by handling the ESM wrapper for CommonJS modules\n   *\n   * @template T The type of the imported module\n   * @param {Promise<T>} importPromise The promise returned by the dynamic import\n   * @return {Promise<T>} A promise that resolves to the normalized module\n   * @private\n   */\n  static async normalizeImport<T>(importPromise: Promise<T>): Promise<T> {\n    // CommonJS's `module.exports` is wrapped as `default` in ESModule.\n    return importPromise.then(\n      (m: unknown) => ((m as { default: T }).default || m) as T\n    );\n  }\n\n  /**\n   * @description Retrieves and parses the package.json file\n   * @summary Reads the package.json file from the specified path and parses it into a JavaScript object\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {Record<string, unknown>} The parsed package.json content as an object\n   * @private\n   */\n  private static getPackage(basePath: string): Record<string, unknown> {\n    try {\n      return JSON.parse(\n        fs.readFileSync(path.join(basePath, \"package.json\"), \"utf8\")\n      );\n    } catch (e: unknown) {\n      throw new Error(`Unable to read version from ${basePath}: ${e}`);\n    }\n  }\n\n  /**\n   * @description Returns the version from package.json\n   * @summary Retrieves the version field from the package.json file at the specified path\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {string} The package version string\n   */\n  static packageVersion(basePath: string): string {\n    return McpUtils.getPackage(basePath)[\"version\"] as string;\n  }\n\n  /**\n   * @description Returns the name from package.json\n   * @summary Retrieves the name field from the package.json file at the specified path and extracts the package name without the scope\n   *\n   * @param {string} basePath The base path where the package.json file is located\n   * @return {string} The package name without the scope (e.g., \"cli\" from \"@decaf-ts/cli\")\n   */\n  static packageName(basePath: string): string {\n    const name = (McpUtils.getPackage(basePath)[\"name\"] as string).split(\"/\");\n    return name[name.length - 1];\n  }\n}\n\nexport * from \"./utils/modulePaths\";\n","import * as fs from \"fs\";\nimport * as path from \"path\";\nimport { MCP_FILE_NAME } from \"./constants\";\nimport { McpUtils } from \"./utils\";\nimport { FastMCP } from \"fastmcp\";\nimport { LoggedClass } from \"@decaf-ts/logging\";\nimport { VERSION } from \"./metadata\";\nimport { fileURLToPath } from \"url\";\n\n// allow referencing __filename/__dirname in both CommonJS and ESM runtimes\ndeclare const __filename: string | undefined;\ndeclare const __dirname: string | undefined;\n\n/**\n * @description Utility class to handle CLI functionality from all Decaf modules\n * @summary This class provides a wrapper around Commander.js to handle CLI commands from different Decaf modules.\n * It crawls the filesystem to find CLI modules, loads them, and registers their commands.\n */\nexport class McpWrapper extends LoggedClass {\n  private _mcp?: FastMCP;\n  private modules: Record<string, string> = {};\n  private readonly rootPath: string;\n\n  constructor(\n    private basePath: string = \"./\",\n    private crawlLevels = 4\n  ) {\n    super();\n    // Support both CommonJS and ESM runtimes for filename/dirname\n    let localDirname: string;\n    if (typeof __filename !== \"undefined\" && typeof __dirname !== \"undefined\") {\n      // CommonJS environment\n      localDirname = __dirname as string;\n    } else {\n      // ESM or other env: compute import.meta.url at runtime to avoid TS compile-time import.meta checks\n      let metaUrl: string | undefined;\n      try {\n        // Use a dynamic function so TypeScript won't parse `import.meta` at compile time\n        const fn = new Function(\n          'return (typeof import !== \"undefined\" && typeof import.meta !== \"undefined\") ? import.meta.url : undefined;'\n        );\n        metaUrl = fn();\n      } catch {\n        metaUrl = undefined;\n      }\n      if (metaUrl) {\n        localDirname = path.dirname(fileURLToPath(metaUrl));\n      } else {\n        // Last-resort fallback: use current working directory\n        localDirname = process.cwd();\n      }\n    }\n    this.rootPath = path.resolve(localDirname, \"..\");\n  }\n\n  /**\n   * @description Retrieves and initializes the Commander Command object\n   * @summary Lazy-loads the Command object, initializing it with the package name, description, and version\n   * @return {FastMCP} The initialized Command object\n   * @private\n   */\n  private get mcp() {\n    if (!this._mcp) {\n      this._mcp = new FastMCP({\n        name: \"decaf-ts MCP server\",\n        instructions: \"\",\n        version: VERSION as any,\n      });\n    }\n    return this._mcp;\n  }\n\n  /**\n   * @description Loads and registers an mcp extension module from a file\n   * @summary Dynamically imports an mcp extension module from the specified file path, initializes it, and registers it in the modules collection\n   *\n   */\n  private async load(\n    server: FastMCP,\n    filePath: string\n  ): Promise<{ mcp: FastMCP; package: string; version: string }> {\n    const log = this.log.for(this.load);\n\n    let pkg: string, version: string, enrich: any;\n    try {\n      const res = await McpUtils.loadFromFile(filePath);\n      pkg = res.PACKAGE_NAME;\n      version = res.VERSION;\n      enrich = res.enrich;\n    } catch (e: unknown) {\n      throw new Error((e as any).message || (e as any));\n    }\n    try {\n      log.info(`Enriching mcp server with module ${pkg} v${version}`);\n      const result = enrich(server);\n      server = result instanceof Promise ? await result : result;\n    } catch (e: unknown) {\n      throw new Error(\n        `failed to enrich mcp with module ${pkg || \"unnamed\"} under ${filePath}: ${e instanceof Error ? e.message : e}`\n      );\n    }\n    return {\n      mcp: server,\n      package: pkg,\n      version: version,\n    };\n  }\n\n  /**\n   * @description Finds and loads all CLI modules in the basePath\n   * @summary Uses the crawl method to find all CLI modules in the specified base path,\n   * then loads and registers each module as a subcommand\n   *\n   * @return {Promise<void>} A promise that resolves when all modules are loaded\n   *\n   * @private\n   * @mermaid\n   * sequenceDiagram\n   *   participant CliWrapper\n   *   participant Filesystem\n   *   participant Module\n   *\n   *   CliWrapper->>Filesystem: Join basePath with cwd\n   *   CliWrapper->>CliWrapper: crawl(basePath, crawlLevels)\n   *   CliWrapper-->>CliWrapper: modules[]\n   *   loop For each module\n   *     alt Not @decaf-ts/cli\n   *       CliWrapper->>CliWrapper: load(module, cwd)\n   *       CliWrapper-->>CliWrapper: name\n   *       CliWrapper->>CliWrapper: Check if command exists\n   *       alt Command doesn't exist\n   *         CliWrapper->>Command: command(name).addCommand(modules[name])\n   *       end\n   *     end\n   *   end\n   *   CliWrapper->>Console: Log loaded modules\n   */\n  private async boot() {\n    const log = this.log.for(this.boot);\n    let server = this.mcp;\n    // discover modules by crawling basePath\n    const moduleFiles = this.crawl(\n      path.resolve(this.basePath),\n      this.crawlLevels\n    );\n    for (const moduleFile of moduleFiles) {\n      if (moduleFile.includes(\"@decaf-ts/mcp\")) {\n        continue;\n      }\n      try {\n        const res = await this.load(server, moduleFile);\n        server = res.mcp;\n        this.modules[res.package] = moduleFile;\n      } catch (e: unknown) {\n        log.error(\n          `Failed to load MCP configs for ${moduleFile}: ${e instanceof Error ? e.message : e}`\n        );\n      }\n    }\n    console.log(\n      `loaded modules:\\n${Object.keys(this.modules)\n        .map((k) => `- ${k}`)\n        .join(\"\\n\")}`\n    );\n    return server;\n  }\n\n  /**\n   * @description Recursively searches for CLI module files in the directory structure\n   * @summary Crawls the basePath up to the specified number of folder levels to find files named according to CLI_FILE_NAME\n   *\n   * @param {string} basePath The absolute base path to start searching in\n   * @param {number} [levels=2] The maximum number of directory levels to crawl\n   * @return {string[]} An array of file paths to CLI modules\n   *\n   * @private\n   */\n  private crawl(basePath: string, levels: number = 2) {\n    if (levels <= 0) return [];\n    return fs.readdirSync(basePath).reduce((accum: string[], file) => {\n      file = path.join(basePath, file);\n      if (fs.statSync(file).isDirectory()) {\n        accum.push(...this.crawl(file, levels - 1));\n      } else if (file.match(new RegExp(`${MCP_FILE_NAME}.[cm]?js$`, \"gm\"))) {\n        accum.push(file);\n      }\n      return accum;\n    }, []);\n  }\n\n  /**\n   * @description Executes the CLI with the provided arguments\n   * @summary Boots the CLI by loading all modules, then parses and executes the command specified in the arguments\n   *\n   * @param {string[]} [args=process.argv] Command line arguments to parse and execute\n   * @return {Promise<void>} A promise that resolves when the command execution is complete\n   *\n   * @mermaid\n   * sequenceDiagram\n   *   participant Client\n   *   participant CliWrapper\n   *   participant Command\n   *\n   *   Client->>CliWrapper: run(args)\n   *   CliWrapper->>CliWrapper: boot()\n   *   Note over CliWrapper: Loads all modules\n   *   CliWrapper->>Command: parseAsync(args)\n   *   Command-->>CliWrapper: result\n   *   CliWrapper-->>Client: result\n   */\n  async run(args: string[] = process.argv) {\n    void args;\n    const server = await this.boot();\n    await server.start({ transportType: \"stdio\" });\n  }\n}\n"],"names":["path","fs","toolList","coreToolList","VERSION","PACKAGE_NAME","PKG","V"],"mappings":"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"}
|