@decaf-ts/mcp-server 0.0.4 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (210) hide show
  1. package/README.md +18 -2
  2. package/dist/mcp-server.cjs +1986 -340
  3. package/dist/mcp-server.esm.cjs +1960 -337
  4. package/lib/McpWrapper.cjs +9 -9
  5. package/lib/McpWrapper.d.ts +1 -1
  6. package/lib/bin/validate-modules.cjs +24 -0
  7. package/lib/bin/validate-modules.d.ts +2 -0
  8. package/lib/constants.cjs +22 -2
  9. package/lib/constants.d.ts +16 -0
  10. package/lib/esm/McpWrapper.d.ts +1 -1
  11. package/lib/esm/McpWrapper.js +9 -9
  12. package/lib/esm/bin/validate-modules.d.ts +2 -0
  13. package/lib/esm/bin/validate-modules.js +22 -0
  14. package/lib/esm/constants.d.ts +16 -0
  15. package/lib/esm/constants.js +21 -1
  16. package/lib/esm/mcp/aggregateModules.d.ts +26 -0
  17. package/lib/esm/mcp/aggregateModules.js +185 -0
  18. package/lib/esm/mcp/code.d.ts +23 -0
  19. package/lib/esm/mcp/code.js +70 -0
  20. package/lib/esm/mcp/decorator-tools.js +237 -0
  21. package/lib/esm/mcp/fastmcp-wiring.d.ts +14 -0
  22. package/lib/esm/mcp/fastmcp-wiring.js +56 -0
  23. package/lib/esm/mcp/index.d.ts +7 -1
  24. package/lib/esm/mcp/index.js +26 -2
  25. package/lib/esm/mcp/mcp-module.d.ts +11 -0
  26. package/lib/esm/mcp/mcp-module.js +31 -0
  27. package/lib/esm/mcp/moduleRegistry.d.ts +12 -0
  28. package/lib/esm/mcp/moduleRegistry.js +46 -0
  29. package/lib/esm/mcp/prompts/index.d.ts +4 -0
  30. package/lib/esm/mcp/prompts/index.js +7 -0
  31. package/lib/esm/mcp/prompts/prompts.d.ts +22 -0
  32. package/lib/esm/mcp/prompts/prompts.js +197 -0
  33. package/lib/esm/mcp/resources/index.d.ts +1 -0
  34. package/lib/esm/mcp/resources/index.js +2 -0
  35. package/lib/esm/mcp/resources/resources.d.ts +2 -0
  36. package/lib/esm/mcp/resources/resources.js +69 -0
  37. package/lib/esm/mcp/schemas.d.ts +53 -0
  38. package/lib/esm/mcp/schemas.js +97 -0
  39. package/lib/esm/mcp/templates/codex-templates.d.ts +3 -0
  40. package/lib/esm/mcp/templates/codex-templates.js +33 -0
  41. package/lib/esm/mcp/templates/index.d.ts +71 -0
  42. package/lib/esm/mcp/templates/index.js +66 -0
  43. package/lib/esm/mcp/templates/resource-templates.d.ts +3 -0
  44. package/lib/esm/mcp/templates/resource-templates.js +60 -0
  45. package/lib/esm/mcp/templates/workspace-templates.d.ts +3 -0
  46. package/lib/esm/mcp/templates/workspace-templates.js +66 -0
  47. package/lib/esm/mcp/tools/codex-tools.d.ts +5 -0
  48. package/lib/esm/mcp/tools/codex-tools.js +244 -0
  49. package/lib/esm/mcp/tools/generateMcpModule.d.ts +9 -0
  50. package/lib/esm/mcp/tools/generateMcpModule.js +133 -0
  51. package/lib/esm/mcp/tools/index.d.ts +321 -0
  52. package/lib/esm/mcp/tools/index.js +29 -0
  53. package/lib/esm/mcp/tools/tools.d.ts +10 -0
  54. package/lib/esm/mcp/tools/tools.js +273 -0
  55. package/lib/esm/mcp/types.d.ts +66 -0
  56. package/lib/esm/mcp/types.js +2 -0
  57. package/lib/esm/mcp/utils.d.ts +4 -0
  58. package/lib/esm/mcp/utils.js +46 -0
  59. package/lib/esm/mcp/validation/index.d.ts +13 -0
  60. package/lib/esm/mcp/validation/index.js +116 -0
  61. package/lib/esm/mcp/validation/scaffoldModule.d.ts +9 -0
  62. package/lib/esm/mcp/validation/scaffoldModule.js +88 -0
  63. package/lib/esm/mcp/workspace.d.ts +9 -0
  64. package/lib/esm/mcp/workspace.js +73 -0
  65. package/lib/esm/metadata.d.ts +1 -1
  66. package/lib/esm/metadata.js +1 -1
  67. package/lib/esm/modules/_template/index.d.ts +32 -0
  68. package/lib/esm/modules/_template/index.js +16 -0
  69. package/lib/esm/modules/_template/prompts/index.d.ts +6 -0
  70. package/lib/esm/modules/_template/prompts/index.js +9 -0
  71. package/lib/esm/modules/_template/resources/index.d.ts +6 -0
  72. package/lib/esm/modules/_template/resources/index.js +9 -0
  73. package/lib/esm/modules/_template/templates/index.d.ts +7 -0
  74. package/lib/esm/modules/_template/templates/index.js +10 -0
  75. package/lib/esm/modules/_template/tools/index.d.ts +6 -0
  76. package/lib/esm/modules/_template/tools/index.js +15 -0
  77. package/lib/esm/modules/decoration/index.d.ts +46 -0
  78. package/lib/esm/modules/decoration/index.js +10 -2
  79. package/lib/esm/modules/decoration/prompts/index.d.ts +1 -0
  80. package/lib/esm/modules/decoration/prompts/index.js +2 -0
  81. package/lib/esm/modules/decoration/resources/index.d.ts +7 -0
  82. package/lib/esm/modules/decoration/resources/index.js +10 -0
  83. package/lib/esm/modules/decoration/templates/index.d.ts +6 -0
  84. package/lib/esm/modules/decoration/templates/index.js +9 -0
  85. package/lib/esm/modules/decoration/tools/index.d.ts +26 -0
  86. package/lib/esm/modules/decoration/tools/index.js +7 -0
  87. package/lib/esm/modules/index.d.ts +2 -0
  88. package/lib/esm/modules/index.js +10 -0
  89. package/lib/esm/modules/mcp/decoration-assist.d.ts +3 -38
  90. package/lib/esm/modules/mcp/decoration-assist.js +5 -352
  91. package/lib/esm/modules/mcp/index.d.ts +6 -2
  92. package/lib/esm/modules/mcp/index.js +16 -3
  93. package/lib/esm/modules/mcp/prompts/index.d.ts +2 -0
  94. package/lib/esm/modules/mcp/prompts/index.js +9 -0
  95. package/lib/esm/modules/mcp/resources/index.d.ts +2 -0
  96. package/lib/esm/modules/mcp/resources/index.js +24 -0
  97. package/lib/esm/modules/mcp/templates/index.d.ts +2 -0
  98. package/lib/esm/modules/mcp/templates/index.js +28 -0
  99. package/lib/esm/modules/mcp/tools/index.d.ts +6 -0
  100. package/lib/esm/modules/mcp/tools/index.js +15 -0
  101. package/lib/esm/types.d.ts +41 -1
  102. package/lib/esm/types.js +1 -1
  103. package/lib/esm/utils/modulePaths.d.ts +6 -0
  104. package/lib/esm/utils/modulePaths.js +33 -0
  105. package/lib/esm/utils/moduleValidator.d.ts +14 -0
  106. package/lib/esm/utils/moduleValidator.js +176 -0
  107. package/lib/esm/utils.d.ts +1 -0
  108. package/lib/esm/utils.js +2 -1
  109. package/lib/mcp/aggregateModules.cjs +225 -0
  110. package/lib/mcp/aggregateModules.d.ts +26 -0
  111. package/lib/mcp/code.cjs +81 -0
  112. package/lib/mcp/code.d.ts +23 -0
  113. package/lib/mcp/decorator-tools.cjs +243 -0
  114. package/lib/mcp/fastmcp-wiring.cjs +59 -0
  115. package/lib/mcp/fastmcp-wiring.d.ts +14 -0
  116. package/lib/mcp/index.cjs +47 -12
  117. package/lib/mcp/index.d.ts +7 -1
  118. package/lib/mcp/mcp-module.cjs +53 -0
  119. package/lib/mcp/mcp-module.d.ts +11 -0
  120. package/lib/mcp/moduleRegistry.cjs +50 -0
  121. package/lib/mcp/moduleRegistry.d.ts +12 -0
  122. package/lib/mcp/prompts/index.cjs +25 -0
  123. package/lib/mcp/prompts/index.d.ts +4 -0
  124. package/lib/mcp/prompts/prompts.cjs +211 -0
  125. package/lib/mcp/prompts/prompts.d.ts +22 -0
  126. package/lib/mcp/resources/index.cjs +18 -0
  127. package/lib/mcp/resources/index.d.ts +1 -0
  128. package/lib/mcp/resources/resources.cjs +72 -0
  129. package/lib/mcp/resources/resources.d.ts +2 -0
  130. package/lib/mcp/schemas.cjs +100 -0
  131. package/lib/mcp/schemas.d.ts +53 -0
  132. package/lib/mcp/templates/codex-templates.cjs +40 -0
  133. package/lib/mcp/templates/codex-templates.d.ts +3 -0
  134. package/lib/mcp/templates/index.cjs +76 -0
  135. package/lib/mcp/templates/index.d.ts +71 -0
  136. package/lib/mcp/templates/resource-templates.cjs +67 -0
  137. package/lib/mcp/templates/resource-templates.d.ts +3 -0
  138. package/lib/mcp/templates/workspace-templates.cjs +70 -0
  139. package/lib/mcp/templates/workspace-templates.d.ts +3 -0
  140. package/lib/mcp/tools/codex-tools.cjs +250 -0
  141. package/lib/mcp/tools/codex-tools.d.ts +5 -0
  142. package/lib/mcp/tools/generateMcpModule.cjs +139 -0
  143. package/lib/mcp/tools/generateMcpModule.d.ts +9 -0
  144. package/lib/mcp/tools/index.cjs +46 -0
  145. package/lib/mcp/tools/index.d.ts +321 -0
  146. package/lib/mcp/tools/tools.cjs +282 -0
  147. package/lib/mcp/tools/tools.d.ts +10 -0
  148. package/lib/mcp/types.cjs +3 -0
  149. package/lib/mcp/types.d.ts +66 -0
  150. package/lib/mcp/utils.cjs +54 -0
  151. package/lib/mcp/utils.d.ts +4 -0
  152. package/lib/mcp/validation/index.cjs +123 -0
  153. package/lib/mcp/validation/index.d.ts +13 -0
  154. package/lib/mcp/validation/scaffoldModule.cjs +94 -0
  155. package/lib/mcp/validation/scaffoldModule.d.ts +9 -0
  156. package/lib/mcp/workspace.cjs +119 -0
  157. package/lib/mcp/workspace.d.ts +9 -0
  158. package/lib/metadata.cjs +1 -1
  159. package/lib/metadata.d.ts +1 -1
  160. package/lib/modules/_template/index.cjs +23 -0
  161. package/lib/modules/_template/index.d.ts +32 -0
  162. package/lib/modules/_template/prompts/index.cjs +12 -0
  163. package/lib/modules/_template/prompts/index.d.ts +6 -0
  164. package/lib/modules/_template/resources/index.cjs +12 -0
  165. package/lib/modules/_template/resources/index.d.ts +6 -0
  166. package/lib/modules/_template/templates/index.cjs +13 -0
  167. package/lib/modules/_template/templates/index.d.ts +7 -0
  168. package/lib/modules/_template/tools/index.cjs +18 -0
  169. package/lib/modules/_template/tools/index.d.ts +6 -0
  170. package/lib/modules/decoration/index.cjs +16 -1
  171. package/lib/modules/decoration/index.d.ts +46 -0
  172. package/lib/modules/decoration/prompts/index.cjs +5 -0
  173. package/lib/modules/decoration/prompts/index.d.ts +1 -0
  174. package/lib/modules/decoration/resources/index.cjs +13 -0
  175. package/lib/modules/decoration/resources/index.d.ts +7 -0
  176. package/lib/modules/decoration/templates/index.cjs +12 -0
  177. package/lib/modules/decoration/templates/index.d.ts +6 -0
  178. package/lib/modules/decoration/tools/index.cjs +10 -0
  179. package/lib/modules/decoration/tools/index.d.ts +26 -0
  180. package/lib/modules/index.cjs +13 -0
  181. package/lib/modules/index.d.ts +2 -0
  182. package/lib/modules/mcp/decoration-assist.cjs +8 -355
  183. package/lib/modules/mcp/decoration-assist.d.ts +3 -38
  184. package/lib/modules/mcp/index.cjs +21 -22
  185. package/lib/modules/mcp/index.d.ts +6 -2
  186. package/lib/modules/mcp/prompts/index.cjs +12 -0
  187. package/lib/modules/mcp/prompts/index.d.ts +2 -0
  188. package/lib/modules/mcp/resources/index.cjs +27 -0
  189. package/lib/modules/mcp/resources/index.d.ts +2 -0
  190. package/lib/modules/mcp/templates/index.cjs +31 -0
  191. package/lib/modules/mcp/templates/index.d.ts +2 -0
  192. package/lib/modules/mcp/tools/index.cjs +18 -0
  193. package/lib/modules/mcp/tools/index.d.ts +6 -0
  194. package/lib/types.cjs +1 -1
  195. package/lib/types.d.ts +41 -1
  196. package/lib/utils/modulePaths.cjs +43 -0
  197. package/lib/utils/modulePaths.d.ts +6 -0
  198. package/lib/utils/moduleValidator.cjs +184 -0
  199. package/lib/utils/moduleValidator.d.ts +14 -0
  200. package/lib/utils.cjs +5 -1
  201. package/lib/utils.d.ts +1 -0
  202. package/package.json +14 -13
  203. package/lib/esm/modules/mcp/decorator-tools.js +0 -237
  204. package/lib/esm/modules/mcp/mcp-module.d.ts +0 -230
  205. package/lib/esm/modules/mcp/mcp-module.js +0 -406
  206. package/lib/modules/mcp/decorator-tools.cjs +0 -243
  207. package/lib/modules/mcp/mcp-module.cjs +0 -452
  208. package/lib/modules/mcp/mcp-module.d.ts +0 -230
  209. /package/lib/esm/{modules/mcp → mcp}/decorator-tools.d.ts +0 -0
  210. /package/lib/{modules/mcp → mcp}/decorator-tools.d.ts +0 -0
@@ -0,0 +1,321 @@
1
+ import { decoratorTools } from "../decorator-tools";
2
+ export * from "./tools";
3
+ export * from "./codex-tools";
4
+ export * from "./generateMcpModule";
5
+ export declare const toolList: any[];
6
+ export declare const decoratorToolList: ({
7
+ readonly name: "create-or-update-model";
8
+ readonly description: "Create or update a validation-ready model class";
9
+ readonly execute: (args: {
10
+ filePath: string;
11
+ className: string;
12
+ classDecorators?: import("../decorator-tools").DecoratorSpec[];
13
+ properties: import("../decorator-tools").AttributeSpec[];
14
+ importsFrom: string;
15
+ overwrite?: boolean;
16
+ }) => Promise<{
17
+ filePath: string;
18
+ }>;
19
+ } | {
20
+ readonly name: "add-attribute";
21
+ readonly description: "Add a decorated attribute to an existing model";
22
+ readonly execute: (args: {
23
+ filePath: string;
24
+ className: string;
25
+ attribute: import("../decorator-tools").AttributeSpec;
26
+ importsFrom: string;
27
+ }) => Promise<{
28
+ filePath: string;
29
+ }>;
30
+ } | {
31
+ readonly name: "remove-attribute";
32
+ readonly description: "Remove an attribute from a model class";
33
+ readonly execute: (args: {
34
+ filePath: string;
35
+ className: string;
36
+ attributeName: string;
37
+ }) => Promise<{
38
+ filePath: string;
39
+ }>;
40
+ } | {
41
+ readonly name: "apply-decorator";
42
+ readonly description: "Apply a decorator to a class or property";
43
+ readonly execute: (args: {
44
+ filePath: string;
45
+ className: string;
46
+ target: {
47
+ kind: "class" | "property";
48
+ name?: string;
49
+ };
50
+ decorator: import("../decorator-tools").DecoratorSpec;
51
+ importsFrom: string;
52
+ }) => Promise<{
53
+ filePath: string;
54
+ }>;
55
+ } | {
56
+ readonly name: "remove-decorator";
57
+ readonly description: "Remove a decorator from a class or property";
58
+ readonly execute: (args: {
59
+ filePath: string;
60
+ className: string;
61
+ target: {
62
+ kind: "class" | "property";
63
+ name?: string;
64
+ };
65
+ decoratorName: string;
66
+ }) => Promise<{
67
+ filePath: string;
68
+ }>;
69
+ } | {
70
+ readonly name: "scaffold-validator";
71
+ readonly description: "Scaffold a validator class and optional decorator";
72
+ readonly execute: (args: {
73
+ validatorsDir: string;
74
+ decoratorDir?: string;
75
+ name: string;
76
+ }) => Promise<{
77
+ classFile: string;
78
+ decoratorFile: string | undefined;
79
+ }>;
80
+ } | {
81
+ readonly name: "scaffold-serializer";
82
+ readonly description: "Scaffold a serializer class and optional registry";
83
+ readonly execute: (args: {
84
+ dir: string;
85
+ name: string;
86
+ registerDir?: string;
87
+ setDefault?: boolean;
88
+ }) => Promise<{
89
+ classFile: string;
90
+ registerFile: string | undefined;
91
+ }>;
92
+ } | {
93
+ readonly name: "scaffold-hashing";
94
+ readonly description: "Scaffold a hashing function and optional registry";
95
+ readonly execute: (args: {
96
+ dir: string;
97
+ name: string;
98
+ registerDir?: string;
99
+ setDefault?: boolean;
100
+ }) => Promise<{
101
+ functionFile: string;
102
+ registerFile: string | undefined;
103
+ }>;
104
+ })[];
105
+ export declare const tools: {
106
+ createOrUpdateModelTool: {
107
+ readonly name: "create-or-update-model";
108
+ readonly description: "Create or update a validation-ready model class";
109
+ readonly execute: (args: {
110
+ filePath: string;
111
+ className: string;
112
+ classDecorators?: import("../decorator-tools").DecoratorSpec[];
113
+ properties: import("../decorator-tools").AttributeSpec[];
114
+ importsFrom: string;
115
+ overwrite?: boolean;
116
+ }) => Promise<{
117
+ filePath: string;
118
+ }>;
119
+ };
120
+ addAttributeTool: {
121
+ readonly name: "add-attribute";
122
+ readonly description: "Add a decorated attribute to an existing model";
123
+ readonly execute: (args: {
124
+ filePath: string;
125
+ className: string;
126
+ attribute: import("../decorator-tools").AttributeSpec;
127
+ importsFrom: string;
128
+ }) => Promise<{
129
+ filePath: string;
130
+ }>;
131
+ };
132
+ removeAttributeTool: {
133
+ readonly name: "remove-attribute";
134
+ readonly description: "Remove an attribute from a model class";
135
+ readonly execute: (args: {
136
+ filePath: string;
137
+ className: string;
138
+ attributeName: string;
139
+ }) => Promise<{
140
+ filePath: string;
141
+ }>;
142
+ };
143
+ applyDecoratorTool: {
144
+ readonly name: "apply-decorator";
145
+ readonly description: "Apply a decorator to a class or property";
146
+ readonly execute: (args: {
147
+ filePath: string;
148
+ className: string;
149
+ target: {
150
+ kind: "class" | "property";
151
+ name?: string;
152
+ };
153
+ decorator: import("../decorator-tools").DecoratorSpec;
154
+ importsFrom: string;
155
+ }) => Promise<{
156
+ filePath: string;
157
+ }>;
158
+ };
159
+ removeDecoratorTool: {
160
+ readonly name: "remove-decorator";
161
+ readonly description: "Remove a decorator from a class or property";
162
+ readonly execute: (args: {
163
+ filePath: string;
164
+ className: string;
165
+ target: {
166
+ kind: "class" | "property";
167
+ name?: string;
168
+ };
169
+ decoratorName: string;
170
+ }) => Promise<{
171
+ filePath: string;
172
+ }>;
173
+ };
174
+ scaffoldValidatorTool: {
175
+ readonly name: "scaffold-validator";
176
+ readonly description: "Scaffold a validator class and optional decorator";
177
+ readonly execute: (args: {
178
+ validatorsDir: string;
179
+ decoratorDir?: string;
180
+ name: string;
181
+ }) => Promise<{
182
+ classFile: string;
183
+ decoratorFile: string | undefined;
184
+ }>;
185
+ };
186
+ scaffoldSerializerTool: {
187
+ readonly name: "scaffold-serializer";
188
+ readonly description: "Scaffold a serializer class and optional registry";
189
+ readonly execute: (args: {
190
+ dir: string;
191
+ name: string;
192
+ registerDir?: string;
193
+ setDefault?: boolean;
194
+ }) => Promise<{
195
+ classFile: string;
196
+ registerFile: string | undefined;
197
+ }>;
198
+ };
199
+ scaffoldHashingTool: {
200
+ readonly name: "scaffold-hashing";
201
+ readonly description: "Scaffold a hashing function and optional registry";
202
+ readonly execute: (args: {
203
+ dir: string;
204
+ name: string;
205
+ registerDir?: string;
206
+ setDefault?: boolean;
207
+ }) => Promise<{
208
+ functionFile: string;
209
+ registerFile: string | undefined;
210
+ }>;
211
+ };
212
+ analyzeRepositoryTool: {
213
+ annotations?: {
214
+ streamingHint?: boolean;
215
+ } & {
216
+ destructiveHint?: boolean;
217
+ idempotentHint?: boolean;
218
+ openWorldHint?: boolean;
219
+ readOnlyHint?: boolean;
220
+ title?: string;
221
+ };
222
+ canAccess?: ((auth: undefined) => boolean) | undefined;
223
+ description?: string;
224
+ execute: (args: any, context: import("fastmcp").Context<undefined>) => Promise<import("fastmcp").AudioContent | import("fastmcp").ContentResult | import("fastmcp").ImageContent | import("fastmcp").ResourceContent | import("fastmcp").ResourceLink | string | import("fastmcp").TextContent | void>;
225
+ name: string;
226
+ parameters?: any;
227
+ timeoutMs?: number;
228
+ };
229
+ enumerateCapabilitiesTool: {
230
+ annotations?: {
231
+ streamingHint?: boolean;
232
+ } & {
233
+ destructiveHint?: boolean;
234
+ idempotentHint?: boolean;
235
+ openWorldHint?: boolean;
236
+ readOnlyHint?: boolean;
237
+ title?: string;
238
+ };
239
+ canAccess?: ((auth: undefined) => boolean) | undefined;
240
+ description?: string;
241
+ execute: (args: any, context: import("fastmcp").Context<undefined>) => Promise<import("fastmcp").AudioContent | import("fastmcp").ContentResult | import("fastmcp").ImageContent | import("fastmcp").ResourceContent | import("fastmcp").ResourceLink | string | import("fastmcp").TextContent | void>;
242
+ name: string;
243
+ parameters?: any;
244
+ timeoutMs?: number;
245
+ };
246
+ planFeatureTool: {
247
+ annotations?: {
248
+ streamingHint?: boolean;
249
+ } & {
250
+ destructiveHint?: boolean;
251
+ idempotentHint?: boolean;
252
+ openWorldHint?: boolean;
253
+ readOnlyHint?: boolean;
254
+ title?: string;
255
+ };
256
+ canAccess?: ((auth: undefined) => boolean) | undefined;
257
+ description?: string;
258
+ execute: (args: any, context: import("fastmcp").Context<undefined>) => Promise<import("fastmcp").AudioContent | import("fastmcp").ContentResult | import("fastmcp").ImageContent | import("fastmcp").ResourceContent | import("fastmcp").ResourceLink | string | import("fastmcp").TextContent | void>;
259
+ name: string;
260
+ parameters?: any;
261
+ timeoutMs?: number;
262
+ };
263
+ documentCodeTool: {
264
+ annotations?: {
265
+ streamingHint?: boolean;
266
+ } & {
267
+ destructiveHint?: boolean;
268
+ idempotentHint?: boolean;
269
+ openWorldHint?: boolean;
270
+ readOnlyHint?: boolean;
271
+ title?: string;
272
+ };
273
+ canAccess?: ((auth: undefined) => boolean) | undefined;
274
+ description?: string;
275
+ execute: (args: any, context: import("fastmcp").Context<undefined>) => Promise<import("fastmcp").AudioContent | import("fastmcp").ContentResult | import("fastmcp").ImageContent | import("fastmcp").ResourceContent | import("fastmcp").ResourceLink | string | import("fastmcp").TextContent | void>;
276
+ name: string;
277
+ parameters?: any;
278
+ timeoutMs?: number;
279
+ };
280
+ applyCodeChangeTool: {
281
+ annotations?: {
282
+ streamingHint?: boolean;
283
+ } & {
284
+ destructiveHint?: boolean;
285
+ idempotentHint?: boolean;
286
+ openWorldHint?: boolean;
287
+ readOnlyHint?: boolean;
288
+ title?: string;
289
+ };
290
+ canAccess?: ((auth: undefined) => boolean) | undefined;
291
+ description?: string;
292
+ execute: (args: any, context: import("fastmcp").Context<undefined>) => Promise<import("fastmcp").AudioContent | import("fastmcp").ContentResult | import("fastmcp").ImageContent | import("fastmcp").ResourceContent | import("fastmcp").ResourceLink | string | import("fastmcp").TextContent | void>;
293
+ name: string;
294
+ parameters?: any;
295
+ timeoutMs?: number;
296
+ };
297
+ documentObjectTool: import("fastmcp").Tool<undefined, import("zod").ZodObject<{
298
+ basePath: import("zod").ZodString;
299
+ objectType: import("zod").ZodEnum<{
300
+ function: "function";
301
+ module: "module";
302
+ file: "file";
303
+ class: "class";
304
+ interface: "interface";
305
+ decorator: "decorator";
306
+ constant: "constant";
307
+ }>;
308
+ targetFile: import("zod").ZodOptional<import("zod").ZodString>;
309
+ includeContent: import("zod").ZodDefault<import("zod").ZodBoolean>;
310
+ }, import("zod/v4/core").$strict>>;
311
+ coverageEnforcerTool: import("fastmcp").Tool<undefined, import("zod").ZodObject<{
312
+ basePath: import("zod").ZodString;
313
+ coverage: import("zod").ZodDefault<import("zod").ZodNumber>;
314
+ dryRun: import("zod").ZodDefault<import("zod").ZodBoolean>;
315
+ }, import("zod/v4/core").$strict>>;
316
+ readmeImprovementTool: import("fastmcp").Tool<undefined, import("zod").ZodObject<{
317
+ basePath: import("zod").ZodString;
318
+ includeExamples: import("zod").ZodDefault<import("zod").ZodBoolean>;
319
+ }, import("zod/v4/core").$strict>>;
320
+ };
321
+ export { decoratorTools };
@@ -0,0 +1,282 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.toolList = exports.applyCodeChangeTool = exports.documentCodeTool = void 0;
7
+ exports.buildAnalyzeRepositoryTool = buildAnalyzeRepositoryTool;
8
+ exports.buildEnumerateCapabilitiesTool = buildEnumerateCapabilitiesTool;
9
+ exports.buildPlanFeatureTool = buildPlanFeatureTool;
10
+ const fs_1 = __importDefault(require("fs"));
11
+ const path_1 = __importDefault(require("path"));
12
+ const diff_1 = require("diff");
13
+ const schemas_1 = require("./../schemas.cjs");
14
+ const code_1 = require("./../code.cjs");
15
+ const utils_1 = require("./../utils.cjs");
16
+ const workspace_1 = require("./../workspace.cjs");
17
+ const prompts_1 = require("./../prompts/prompts.cjs");
18
+ function buildAnalyzeRepositoryTool() {
19
+ return {
20
+ name: "analyze-repository",
21
+ description: "Analyze a local repository's source, tests, and docs to extract exported APIs, decorators, and test mentions.",
22
+ parameters: schemas_1.analyzeRepoSchema,
23
+ execute: async (input) => {
24
+ let repoRoot = path_1.default.resolve(process.cwd(), input.repoPath);
25
+ if (!fs_1.default.existsSync(repoRoot)) {
26
+ // try resolving from monorepo root (parent of current cwd)
27
+ const alt = path_1.default.resolve(process.cwd(), "..", input.repoPath);
28
+ if (fs_1.default.existsSync(alt))
29
+ repoRoot = alt;
30
+ }
31
+ if (!fs_1.default.existsSync(repoRoot)) {
32
+ // if input was absolute and still not found, try ../<basename>
33
+ const alt2 = path_1.default.resolve(process.cwd(), "..", path_1.default.basename(input.repoPath));
34
+ if (fs_1.default.existsSync(alt2))
35
+ repoRoot = alt2;
36
+ }
37
+ if (!fs_1.default.existsSync(repoRoot))
38
+ throw new Error(`Repository not found at ${repoRoot}`);
39
+ const result = (0, code_1.analyzeRepo)(repoRoot);
40
+ return {
41
+ content: [{ type: "text", text: JSON.stringify(result, null, 2) }],
42
+ };
43
+ },
44
+ };
45
+ }
46
+ function buildEnumerateCapabilitiesTool() {
47
+ return {
48
+ name: "enumerate-capabilities",
49
+ description: "Enumerate developer-facing capabilities of the given repository, inferred from code, tests, and docs.",
50
+ parameters: schemas_1.enumerateCapabilitiesSchema,
51
+ execute: async (input) => {
52
+ let repoRoot = path_1.default.resolve(process.cwd(), input.repoPath);
53
+ if (!fs_1.default.existsSync(repoRoot)) {
54
+ const alt = path_1.default.resolve(process.cwd(), "..", input.repoPath);
55
+ if (fs_1.default.existsSync(alt))
56
+ repoRoot = alt;
57
+ }
58
+ if (!fs_1.default.existsSync(repoRoot)) {
59
+ const alt2 = path_1.default.resolve(process.cwd(), "..", path_1.default.basename(input.repoPath));
60
+ if (fs_1.default.existsSync(alt2))
61
+ repoRoot = alt2;
62
+ }
63
+ if (!fs_1.default.existsSync(repoRoot))
64
+ throw new Error(`Repository not found at ${repoRoot}`);
65
+ const analysis = (0, code_1.analyzeRepo)(repoRoot);
66
+ const capabilities = (0, utils_1.deriveCapabilities)(analysis);
67
+ return {
68
+ content: [
69
+ {
70
+ type: "text",
71
+ text: JSON.stringify({
72
+ capabilities,
73
+ analysisSummary: {
74
+ files: analysis.files.length,
75
+ testFiles: analysis.testFiles.length,
76
+ readme: analysis.readme?.title,
77
+ },
78
+ }, null, 2),
79
+ },
80
+ ],
81
+ };
82
+ },
83
+ };
84
+ }
85
+ function buildPlanFeatureTool() {
86
+ return {
87
+ name: "plan-feature-implementation",
88
+ description: "Given a feature request, select appropriate MCP tools (including existing and new ones) and produce an execution plan.",
89
+ parameters: schemas_1.planFeatureSchema,
90
+ execute: async (input) => {
91
+ const steps = [];
92
+ let i = 1;
93
+ steps.push({
94
+ step: i++,
95
+ action: "Analyze repository to enumerate APIs and decorators",
96
+ tool: "analyze-repository",
97
+ arguments: { repoPath: input.repoPath },
98
+ rationale: "Understand available building blocks.",
99
+ });
100
+ steps.push({
101
+ step: i++,
102
+ action: "List capabilities expected for developers",
103
+ tool: "enumerate-capabilities",
104
+ arguments: { repoPath: input.repoPath },
105
+ rationale: "Align the plan with supported capabilities.",
106
+ });
107
+ // Suggest existing generic tools from mcp-module
108
+ steps.push({
109
+ step: i++,
110
+ action: "Select documentation prompt and gather relevant source file(s)",
111
+ tool: "document-code",
112
+ arguments: { filePath: "<target-file>" },
113
+ rationale: "Provide context and instructions for changes.",
114
+ });
115
+ steps.push({
116
+ step: i++,
117
+ action: "Apply code changes using unified diff patch",
118
+ tool: "apply-code-change",
119
+ arguments: {
120
+ filePath: "<target-file>",
121
+ patch: "<unified-diff>",
122
+ dryRun: true,
123
+ },
124
+ rationale: "Validate changes safely before committing.",
125
+ });
126
+ steps.push({
127
+ step: i++,
128
+ action: "Commit code changes",
129
+ tool: "apply-code-change",
130
+ arguments: {
131
+ filePath: "<target-file>",
132
+ patch: "<unified-diff>",
133
+ dryRun: false,
134
+ },
135
+ rationale: "Persist the update.",
136
+ });
137
+ // If decoration-related terms present, suggest decorator tools
138
+ if (/decorat|flavour|override|extend|builder/i.test(input.feature)) {
139
+ steps.unshift({
140
+ step: 0,
141
+ action: "Use decorator tooling to insert/remove/modify decorators",
142
+ tool: "decorator-tools",
143
+ arguments: { action: "help" },
144
+ rationale: "Leverage specialized utilities for decoration patterns.",
145
+ });
146
+ steps.forEach((s, idx) => (s.step = idx + 1));
147
+ }
148
+ return {
149
+ content: [
150
+ {
151
+ type: "text",
152
+ text: JSON.stringify({
153
+ plan: steps,
154
+ notes: "Replace placeholder arguments like <target-file> and <unified-diff> based on the analysis output.",
155
+ }, null, 2),
156
+ },
157
+ ],
158
+ };
159
+ },
160
+ };
161
+ }
162
+ exports.documentCodeTool = {
163
+ annotations: {
164
+ idempotentHint: true,
165
+ openWorldHint: false,
166
+ readOnlyHint: true,
167
+ title: "Document Source File",
168
+ },
169
+ description: "Generate documentation guidance for a file by combining repository prompts with the target source code.",
170
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
171
+ execute: async (input, _context) => {
172
+ const args = schemas_1.documentCodeSchema.parse(input);
173
+ const root = (0, workspace_1.getWorkspaceRoot)();
174
+ let filePath;
175
+ try {
176
+ filePath = (0, workspace_1.resolveInWorkspace)(root, args.filePath);
177
+ }
178
+ catch (error) {
179
+ if (error instanceof workspace_1.WorkspaceError) {
180
+ return (0, workspace_1.throwUserError)(error.message);
181
+ }
182
+ /* istanbul ignore next */
183
+ throw error;
184
+ }
185
+ if (!fs_1.default.existsSync(filePath)) {
186
+ return (0, workspace_1.throwUserError)(`Cannot document missing file at ${args.filePath}`);
187
+ }
188
+ const fileContent = fs_1.default.readFileSync(filePath, {
189
+ encoding: args.encoding,
190
+ });
191
+ const prompts = (0, prompts_1.discoverDocPrompts)(root);
192
+ if (!prompts.length) {
193
+ return (0, workspace_1.throwUserError)("No documentation prompts found under .code/prompts or .codex/prompts");
194
+ }
195
+ const prompt = (0, prompts_1.selectPrompt)(prompts, args.promptName ?? prompts_1.DEFAULT_PROMPT_NAME);
196
+ return (0, prompts_1.buildDocumentationPayload)({
197
+ filePath: args.filePath,
198
+ fileContent,
199
+ prompt,
200
+ includeCode: args.includeCode,
201
+ includePrompt: args.includePrompt,
202
+ includeMetadata: args.includeMetadata,
203
+ additionalContext: args.additionalContext,
204
+ });
205
+ },
206
+ name: "document-code",
207
+ parameters: schemas_1.documentCodeSchema,
208
+ };
209
+ exports.applyCodeChangeTool = {
210
+ annotations: {
211
+ destructiveHint: true,
212
+ idempotentHint: false,
213
+ openWorldHint: false,
214
+ readOnlyHint: false,
215
+ title: "Apply Code Patch",
216
+ },
217
+ description: "Apply a unified diff patch to a workspace file with optional dry-run validation and diff preview.",
218
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
219
+ execute: async (input, _context) => {
220
+ const args = schemas_1.codeChangeSchema.parse(input);
221
+ const root = (0, workspace_1.getWorkspaceRoot)();
222
+ let filePath;
223
+ try {
224
+ filePath = (0, workspace_1.resolveInWorkspace)(root, args.filePath);
225
+ }
226
+ catch (error) {
227
+ if (error instanceof workspace_1.WorkspaceError) {
228
+ return (0, workspace_1.throwUserError)(error.message);
229
+ }
230
+ throw error;
231
+ }
232
+ const original = fs_1.default.existsSync(filePath)
233
+ ? fs_1.default.readFileSync(filePath, args.encoding)
234
+ : "";
235
+ let patched;
236
+ try {
237
+ patched = (0, diff_1.applyPatch)(original, args.patch);
238
+ }
239
+ catch (error) {
240
+ return (0, workspace_1.throwUserError)(`Failed to apply provided patch to ${args.filePath}: ${error instanceof Error ? error.message : error}`);
241
+ }
242
+ /* istanbul ignore next */
243
+ if (patched === false) {
244
+ return (0, workspace_1.throwUserError)(`Failed to apply provided patch to ${args.filePath}`);
245
+ }
246
+ if (!args.dryRun) {
247
+ fs_1.default.mkdirSync(path_1.default.dirname(filePath), { recursive: true });
248
+ fs_1.default.writeFileSync(filePath, patched, {
249
+ encoding: args.encoding,
250
+ });
251
+ }
252
+ if (!args.showDiff) {
253
+ return `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`;
254
+ }
255
+ const preview = (0, diff_1.createTwoFilesPatch)(args.filePath, args.filePath, original, patched, undefined, undefined, { context: args.diffContext });
256
+ return {
257
+ content: [
258
+ {
259
+ type: "text",
260
+ text: `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`,
261
+ },
262
+ {
263
+ type: "text",
264
+ text: ["```diff", preview.trim(), "```"].join("\n"),
265
+ },
266
+ ],
267
+ };
268
+ },
269
+ name: "apply-code-change",
270
+ parameters: schemas_1.codeChangeSchema,
271
+ };
272
+ const analyticTools = [
273
+ buildAnalyzeRepositoryTool(),
274
+ buildEnumerateCapabilitiesTool(),
275
+ buildPlanFeatureTool(),
276
+ ];
277
+ exports.toolList = [
278
+ ...analyticTools,
279
+ exports.documentCodeTool,
280
+ exports.applyCodeChangeTool,
281
+ ];
282
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tools.js","sourceRoot":"","sources":["../../../src/mcp/tools/tools.ts"],"names":[],"mappings":"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","sourcesContent":["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"]}
@@ -0,0 +1,10 @@
1
+ import { Tool } from "fastmcp";
2
+ import { analyzeRepoSchema, codeChangeSchema, documentCodeSchema, enumerateCapabilitiesSchema, planFeatureSchema } from "../schemas";
3
+ export declare function buildAnalyzeRepositoryTool(): Tool<undefined, typeof analyzeRepoSchema>;
4
+ export declare function buildEnumerateCapabilitiesTool(): Tool<undefined, typeof enumerateCapabilitiesSchema>;
5
+ export declare function buildPlanFeatureTool(): Tool<undefined, typeof planFeatureSchema>;
6
+ export declare const documentCodeTool: Tool<undefined, typeof documentCodeSchema>;
7
+ export declare const applyCodeChangeTool: Tool<undefined, typeof codeChangeSchema>;
8
+ type AnyTool = Tool<undefined, any>;
9
+ export declare const toolList: AnyTool[];
10
+ export {};
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvbWNwL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB6IH0gZnJvbSBcInpvZFwiO1xuaW1wb3J0IHtcbiAgYW5hbHl6ZVJlcG9TY2hlbWEsXG4gIGVudW1lcmF0ZUNhcGFiaWxpdGllc1NjaGVtYSxcbiAgcGxhbkZlYXR1cmVTY2hlbWEsXG4gIGRvY3VtZW50Q29kZVNjaGVtYSxcbiAgY29kZUNoYW5nZVNjaGVtYSxcbiAgZG9jdW1lbnRPYmplY3RTY2hlbWEsXG4gIGNvdmVyYWdlVGFza1NjaGVtYSxcbiAgcmVhZG1lSW1wcm92ZW1lbnRTY2hlbWEsXG59IGZyb20gXCIuL3NjaGVtYXNcIjtcblxuZXhwb3J0IHR5cGUgQW5hbHl6ZVJlcG9BcmdzID0gei5pbmZlcjx0eXBlb2YgYW5hbHl6ZVJlcG9TY2hlbWE+O1xuZXhwb3J0IHR5cGUgRW51bWVyYXRlQ2FwYWJpbGl0aWVzQXJncyA9IHouaW5mZXI8XG4gIHR5cGVvZiBlbnVtZXJhdGVDYXBhYmlsaXRpZXNTY2hlbWFcbj47XG5leHBvcnQgdHlwZSBQbGFuRmVhdHVyZUFyZ3MgPSB6LmluZmVyPHR5cGVvZiBwbGFuRmVhdHVyZVNjaGVtYT47XG5cbmV4cG9ydCB0eXBlIERlY29yYXRpb25SZXNvdXJjZVRlbXBsYXRlID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIHVyaVRlbXBsYXRlOiBzdHJpbmc7XG4gIG1pbWVUeXBlOiBzdHJpbmc7XG4gIGFyZ3VtZW50czogUmVhZG9ubHlBcnJheTx7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgcmVxdWlyZWQ6IGJvb2xlYW47XG4gIH0+O1xuICBsb2FkOiAoYXJnczogeyBwYXRoOiBzdHJpbmcgfSkgPT4gUHJvbWlzZTx7IHRleHQ6IHN0cmluZyB9Pjtcbn07XG5cbmV4cG9ydCB0eXBlIERvY3VtZW50Q29kZUFyZ3MgPSB6LmluZmVyPHR5cGVvZiBkb2N1bWVudENvZGVTY2hlbWE+O1xuXG5leHBvcnQgdHlwZSBBcHBseUNvZGVDaGFuZ2VBcmdzID0gei5pbmZlcjx0eXBlb2YgY29kZUNoYW5nZVNjaGVtYT47XG5cbmV4cG9ydCB0eXBlIERvY3VtZW50T2JqZWN0QXJncyA9IHouaW5mZXI8dHlwZW9mIGRvY3VtZW50T2JqZWN0U2NoZW1hPjtcblxuZXhwb3J0IHR5cGUgQ292ZXJhZ2VUYXNrQXJncyA9IHouaW5mZXI8dHlwZW9mIGNvdmVyYWdlVGFza1NjaGVtYT47XG5cbmV4cG9ydCB0eXBlIFJlYWRtZUltcHJvdmVtZW50QXJncyA9IHouaW5mZXI8dHlwZW9mIHJlYWRtZUltcHJvdmVtZW50U2NoZW1hPjtcblxuZXhwb3J0IHR5cGUgRG9jUHJvbXB0ID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIGNvbnRlbnQ6IHN0cmluZztcbiAgYWJzb2x1dGVQYXRoOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBXb3Jrc3BhY2VSZXNvdXJjZVRlbXBsYXRlID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gIHVyaVRlbXBsYXRlOiBzdHJpbmc7XG4gIG1pbWVUeXBlOiBzdHJpbmc7XG4gIGFyZ3VtZW50czogUmVhZG9ubHlBcnJheTx7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uOiBzdHJpbmc7XG4gICAgcmVxdWlyZWQ6IGJvb2xlYW47XG4gIH0+O1xuICBsb2FkOiAoYXJnczogeyBwYXRoOiBzdHJpbmcgfSkgPT4gUHJvbWlzZTx7IHRleHQ6IHN0cmluZyB9Pjtcbn07XG5cbmV4cG9ydCB0eXBlIFByb21wdFJlc291cmNlVGVtcGxhdGUgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgdXJpVGVtcGxhdGU6IHN0cmluZztcbiAgbWltZVR5cGU6IHN0cmluZztcbiAgYXJndW1lbnRzOiBSZWFkb25seUFycmF5PHtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICByZXF1aXJlZDogYm9vbGVhbjtcbiAgfT47XG4gIGxvYWQ6IChhcmdzOiB7IG5hbWU6IHN0cmluZyB9KSA9PiBQcm9taXNlPHsgdGV4dDogc3RyaW5nOyB1cmk/OiBzdHJpbmcgfT47XG59O1xuIl19