@decaf-ts/mcp-server 0.4.2 → 0.4.7

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 (536) hide show
  1. package/LICENSE.md +31 -0
  2. package/dist/mcp-server.cjs +2 -2360
  3. package/dist/mcp-server.cjs.map +1 -0
  4. package/dist/mcp-server.js +2 -0
  5. package/dist/mcp-server.js.map +1 -0
  6. package/lib/bin/cli.cjs +7 -35
  7. package/lib/bin/cli.js.map +1 -0
  8. package/lib/builders/builder.cjs +91 -0
  9. package/lib/builders/builder.d.ts +25 -0
  10. package/lib/builders/builder.js.map +1 -0
  11. package/lib/{mcp/resources → builders}/index.cjs +5 -2
  12. package/lib/builders/index.d.ts +4 -0
  13. package/lib/builders/index.js.map +1 -0
  14. package/lib/builders/prompt-builder.cjs +76 -0
  15. package/lib/builders/prompt-builder.d.ts +12 -0
  16. package/lib/builders/prompt-builder.js.map +1 -0
  17. package/lib/builders/resource-builder.cjs +83 -0
  18. package/lib/builders/resource-builder.d.ts +14 -0
  19. package/lib/builders/resource-builder.js.map +1 -0
  20. package/lib/builders/tool-builder.cjs +104 -0
  21. package/lib/builders/tool-builder.d.ts +16 -0
  22. package/lib/builders/tool-builder.js.map +1 -0
  23. package/lib/constants.cjs +28 -30
  24. package/lib/constants.d.ts +19 -24
  25. package/lib/constants.js.map +1 -0
  26. package/lib/environment.cjs +32 -0
  27. package/lib/environment.d.ts +71 -0
  28. package/lib/environment.js.map +1 -0
  29. package/lib/esm/bin/cli.js +7 -35
  30. package/lib/esm/bin/cli.js.map +1 -0
  31. package/lib/esm/builders/builder.d.ts +25 -0
  32. package/lib/esm/builders/builder.js +86 -0
  33. package/lib/esm/builders/builder.js.map +1 -0
  34. package/lib/esm/builders/index.d.ts +4 -0
  35. package/lib/esm/builders/index.js +5 -0
  36. package/lib/esm/builders/index.js.map +1 -0
  37. package/lib/esm/builders/prompt-builder.d.ts +12 -0
  38. package/lib/esm/builders/prompt-builder.js +72 -0
  39. package/lib/esm/builders/prompt-builder.js.map +1 -0
  40. package/lib/esm/builders/resource-builder.d.ts +14 -0
  41. package/lib/esm/builders/resource-builder.js +79 -0
  42. package/lib/esm/builders/resource-builder.js.map +1 -0
  43. package/lib/esm/builders/tool-builder.d.ts +16 -0
  44. package/lib/esm/builders/tool-builder.js +100 -0
  45. package/lib/esm/builders/tool-builder.js.map +1 -0
  46. package/lib/esm/constants.d.ts +19 -24
  47. package/lib/esm/constants.js +27 -29
  48. package/lib/esm/constants.js.map +1 -0
  49. package/lib/esm/environment.d.ts +71 -0
  50. package/lib/esm/environment.js +29 -0
  51. package/lib/esm/environment.js.map +1 -0
  52. package/lib/esm/index.d.ts +3 -10
  53. package/lib/esm/index.js +4 -11
  54. package/lib/esm/index.js.map +1 -0
  55. package/lib/esm/mcp-server.d.ts +10 -0
  56. package/lib/esm/mcp-server.js +189 -0
  57. package/lib/esm/mcp-server.js.map +1 -0
  58. package/lib/esm/modules/template-module/index.d.ts +6 -0
  59. package/lib/esm/modules/template-module/index.js +4 -0
  60. package/lib/esm/modules/template-module/index.js.map +1 -0
  61. package/lib/esm/prompts/code/constants.d.ts +1 -0
  62. package/lib/esm/prompts/code/constants.js +2 -0
  63. package/lib/esm/prompts/code/constants.js.map +1 -0
  64. package/lib/esm/prompts/code/design-patterns/builder.d.ts +2 -0
  65. package/lib/esm/prompts/code/design-patterns/builder.js +118 -0
  66. package/lib/esm/prompts/code/design-patterns/builder.js.map +1 -0
  67. package/lib/esm/prompts/code/design-patterns/constants.d.ts +1 -0
  68. package/lib/esm/prompts/code/design-patterns/constants.js +3 -0
  69. package/lib/esm/prompts/code/design-patterns/constants.js.map +1 -0
  70. package/lib/esm/prompts/example-prompt/index.d.ts +2 -0
  71. package/lib/esm/prompts/example-prompt/index.js +18 -0
  72. package/lib/esm/prompts/example-prompt/index.js.map +1 -0
  73. package/lib/esm/prompts/index.d.ts +2 -0
  74. package/lib/esm/prompts/index.js +26 -0
  75. package/lib/esm/prompts/index.js.map +1 -0
  76. package/lib/esm/prompts/interactive-jsdoc/index.d.ts +2 -0
  77. package/lib/esm/prompts/interactive-jsdoc/index.js +18 -0
  78. package/lib/esm/prompts/interactive-jsdoc/index.js.map +1 -0
  79. package/lib/esm/prompts/jsdocs/class-prompt.d.ts +2 -0
  80. package/lib/esm/prompts/jsdocs/class-prompt.js +52 -0
  81. package/lib/esm/prompts/jsdocs/class-prompt.js.map +1 -0
  82. package/lib/esm/prompts/jsdocs/const-prompt.d.ts +2 -0
  83. package/lib/esm/prompts/jsdocs/const-prompt.js +24 -0
  84. package/lib/esm/prompts/jsdocs/const-prompt.js.map +1 -0
  85. package/lib/esm/prompts/jsdocs/constants.d.ts +4 -0
  86. package/lib/esm/prompts/jsdocs/constants.js +46 -0
  87. package/lib/esm/prompts/jsdocs/constants.js.map +1 -0
  88. package/lib/esm/prompts/jsdocs/decorator-prompt.d.ts +2 -0
  89. package/lib/esm/prompts/jsdocs/decorator-prompt.js +42 -0
  90. package/lib/esm/prompts/jsdocs/decorator-prompt.js.map +1 -0
  91. package/lib/esm/prompts/jsdocs/enum-prompt.d.ts +2 -0
  92. package/lib/esm/prompts/jsdocs/enum-prompt.js +24 -0
  93. package/lib/esm/prompts/jsdocs/enum-prompt.js.map +1 -0
  94. package/lib/esm/prompts/jsdocs/function-prompt.d.ts +2 -0
  95. package/lib/esm/prompts/jsdocs/function-prompt.js +43 -0
  96. package/lib/esm/prompts/jsdocs/function-prompt.js.map +1 -0
  97. package/lib/esm/prompts/jsdocs/interface-prompt.d.ts +2 -0
  98. package/lib/esm/prompts/jsdocs/interface-prompt.js +24 -0
  99. package/lib/esm/prompts/jsdocs/interface-prompt.js.map +1 -0
  100. package/lib/esm/prompts/jsdocs/types-prompt.d.ts +2 -0
  101. package/lib/esm/prompts/jsdocs/types-prompt.js +24 -0
  102. package/lib/esm/prompts/jsdocs/types-prompt.js.map +1 -0
  103. package/lib/esm/resources/example-resource/index.d.ts +2 -0
  104. package/lib/esm/resources/example-resource/index.js +19 -0
  105. package/lib/esm/resources/example-resource/index.js.map +1 -0
  106. package/lib/esm/resources/index.d.ts +2 -0
  107. package/lib/esm/resources/index.js +4 -0
  108. package/lib/esm/resources/index.js.map +1 -0
  109. package/lib/esm/resources/repo-metadata/index.d.ts +2 -0
  110. package/lib/esm/resources/repo-metadata/index.js +25 -0
  111. package/lib/esm/resources/repo-metadata/index.js.map +1 -0
  112. package/lib/esm/tools/ast/ts-ast-tool.d.ts +2 -0
  113. package/lib/esm/tools/ast/ts-ast-tool.js +67 -0
  114. package/lib/esm/tools/ast/ts-ast-tool.js.map +1 -0
  115. package/lib/esm/tools/ast/types.d.ts +105 -0
  116. package/lib/esm/tools/ast/types.js +33 -0
  117. package/lib/esm/tools/ast/types.js.map +1 -0
  118. package/lib/esm/tools/ast/utils.d.ts +5 -0
  119. package/lib/esm/tools/ast/utils.js +58 -0
  120. package/lib/esm/tools/ast/utils.js.map +1 -0
  121. package/lib/esm/tools/ast-jsdoc-tools/apply.d.ts +6 -0
  122. package/lib/esm/tools/ast-jsdoc-tools/apply.js +29 -0
  123. package/lib/esm/tools/ast-jsdoc-tools/apply.js.map +1 -0
  124. package/lib/esm/tools/ast-jsdoc-tools/cli.js +33 -0
  125. package/lib/esm/tools/ast-jsdoc-tools/cli.js.map +1 -0
  126. package/lib/esm/tools/ast-jsdoc-tools/enumerator.d.ts +1 -0
  127. package/lib/esm/tools/ast-jsdoc-tools/enumerator.js +25 -0
  128. package/lib/esm/tools/ast-jsdoc-tools/enumerator.js.map +1 -0
  129. package/lib/esm/tools/ast-jsdoc-tools/fileRunner.d.ts +11 -0
  130. package/lib/esm/tools/ast-jsdoc-tools/fileRunner.js +29 -0
  131. package/lib/esm/tools/ast-jsdoc-tools/fileRunner.js.map +1 -0
  132. package/lib/esm/tools/ast-jsdoc-tools/formatter.d.ts +6 -0
  133. package/lib/esm/tools/ast-jsdoc-tools/formatter.js +18 -0
  134. package/lib/esm/tools/ast-jsdoc-tools/formatter.js.map +1 -0
  135. package/lib/esm/tools/ast-jsdoc-tools/generator.d.ts +12 -0
  136. package/lib/esm/tools/ast-jsdoc-tools/generator.js +55 -0
  137. package/lib/esm/tools/ast-jsdoc-tools/generator.js.map +1 -0
  138. package/lib/esm/tools/ast-jsdoc-tools/index.d.ts +7 -0
  139. package/lib/esm/tools/ast-jsdoc-tools/index.js +29 -0
  140. package/lib/esm/tools/ast-jsdoc-tools/index.js.map +1 -0
  141. package/lib/esm/tools/ast-jsdoc-tools/interactive.d.ts +1 -0
  142. package/lib/esm/tools/ast-jsdoc-tools/interactive.js +7 -0
  143. package/lib/esm/tools/ast-jsdoc-tools/interactive.js.map +1 -0
  144. package/lib/esm/tools/ast-jsdoc-tools/parser.d.ts +13 -0
  145. package/lib/esm/tools/ast-jsdoc-tools/parser.js +71 -0
  146. package/lib/esm/tools/ast-jsdoc-tools/parser.js.map +1 -0
  147. package/lib/esm/tools/ast-jsdoc-tools/patch.d.ts +2 -0
  148. package/lib/esm/tools/ast-jsdoc-tools/patch.js +23 -0
  149. package/lib/esm/tools/ast-jsdoc-tools/patch.js.map +1 -0
  150. package/lib/esm/tools/ast-jsdoc-tools/prompts/loader.d.ts +10 -0
  151. package/lib/esm/tools/ast-jsdoc-tools/prompts/loader.js +26 -0
  152. package/lib/esm/tools/ast-jsdoc-tools/prompts/loader.js.map +1 -0
  153. package/lib/esm/tools/ast-jsdoc-tools/repoRunner.d.ts +16 -0
  154. package/lib/esm/tools/ast-jsdoc-tools/repoRunner.js +61 -0
  155. package/lib/esm/tools/ast-jsdoc-tools/repoRunner.js.map +1 -0
  156. package/lib/esm/tools/ast-jsdoc-tools/tools/jsdoc-generator.d.ts +5 -0
  157. package/lib/esm/tools/ast-jsdoc-tools/tools/jsdoc-generator.js +78 -0
  158. package/lib/esm/tools/ast-jsdoc-tools/tools/jsdoc-generator.js.map +1 -0
  159. package/lib/esm/tools/ast-jsdoc-tools/utils/conflict-detector.d.ts +5 -0
  160. package/lib/esm/tools/ast-jsdoc-tools/utils/conflict-detector.js +30 -0
  161. package/lib/esm/tools/ast-jsdoc-tools/utils/conflict-detector.js.map +1 -0
  162. package/lib/esm/tools/ast-jsdoc-tools/utils/context-schema.d.ts +7 -0
  163. package/lib/esm/tools/ast-jsdoc-tools/utils/context-schema.js +29 -0
  164. package/lib/esm/tools/ast-jsdoc-tools/utils/context-schema.js.map +1 -0
  165. package/lib/esm/tools/ast-jsdoc-tools/utils/heuristics.d.ts +2 -0
  166. package/lib/esm/tools/ast-jsdoc-tools/utils/heuristics.js +31 -0
  167. package/lib/esm/tools/ast-jsdoc-tools/utils/heuristics.js.map +1 -0
  168. package/lib/esm/tools/ast-jsdoc-tools/utils/ts-project.d.ts +12 -0
  169. package/lib/esm/tools/ast-jsdoc-tools/utils/ts-project.js +21 -0
  170. package/lib/esm/tools/ast-jsdoc-tools/utils/ts-project.js.map +1 -0
  171. package/lib/esm/tools/example-tool/index.d.ts +2 -0
  172. package/lib/esm/tools/example-tool/index.js +29 -0
  173. package/lib/esm/tools/example-tool/index.js.map +1 -0
  174. package/lib/esm/tools/file-summarizer/index.d.ts +2 -0
  175. package/lib/esm/tools/file-summarizer/index.js +29 -0
  176. package/lib/esm/tools/file-summarizer/index.js.map +1 -0
  177. package/lib/esm/tools/index.d.ts +2 -0
  178. package/lib/esm/tools/index.js +6 -0
  179. package/lib/esm/tools/index.js.map +1 -0
  180. package/lib/esm/tools/jsdoc/ts-jsdoc-element-tool.d.ts +2 -0
  181. package/lib/esm/tools/jsdoc/ts-jsdoc-element-tool.js +84 -0
  182. package/lib/esm/tools/jsdoc/ts-jsdoc-element-tool.js.map +1 -0
  183. package/lib/esm/tools/jsdoc/utils.d.ts +5 -0
  184. package/lib/esm/tools/jsdoc/utils.js +53 -0
  185. package/lib/esm/tools/jsdoc/utils.js.map +1 -0
  186. package/lib/esm/tools/testing/ts-jest-list-tests.d.ts +2 -0
  187. package/lib/esm/tools/testing/ts-jest-list-tests.js +53 -0
  188. package/lib/esm/tools/testing/ts-jest-list-tests.js.map +1 -0
  189. package/lib/esm/types.d.ts +56 -47
  190. package/lib/esm/types.js +1 -1
  191. package/lib/esm/types.js.map +1 -0
  192. package/lib/esm/utils/banner.d.ts +3 -0
  193. package/lib/esm/utils/banner.js +107 -0
  194. package/lib/esm/utils/banner.js.map +1 -0
  195. package/lib/esm/version.d.ts +2 -0
  196. package/lib/esm/version.js +5 -0
  197. package/lib/esm/version.js.map +1 -0
  198. package/lib/index.cjs +4 -11
  199. package/lib/index.d.ts +3 -10
  200. package/lib/index.js.map +1 -0
  201. package/lib/mcp-server.cjs +226 -0
  202. package/lib/mcp-server.d.ts +10 -0
  203. package/lib/mcp-server.js.map +1 -0
  204. package/lib/modules/template-module/index.cjs +7 -0
  205. package/lib/modules/template-module/index.d.ts +6 -0
  206. package/lib/modules/template-module/index.js.map +1 -0
  207. package/lib/prompts/code/constants.cjs +5 -0
  208. package/lib/prompts/code/constants.d.ts +1 -0
  209. package/lib/prompts/code/constants.js.map +1 -0
  210. package/lib/prompts/code/design-patterns/builder.cjs +121 -0
  211. package/lib/prompts/code/design-patterns/builder.d.ts +2 -0
  212. package/lib/prompts/code/design-patterns/builder.js.map +1 -0
  213. package/lib/prompts/code/design-patterns/constants.cjs +6 -0
  214. package/lib/prompts/code/design-patterns/constants.d.ts +1 -0
  215. package/lib/prompts/code/design-patterns/constants.js.map +1 -0
  216. package/lib/prompts/example-prompt/index.cjs +21 -0
  217. package/lib/prompts/example-prompt/index.d.ts +2 -0
  218. package/lib/prompts/example-prompt/index.js.map +1 -0
  219. package/lib/prompts/index.cjs +29 -0
  220. package/lib/prompts/index.d.ts +2 -0
  221. package/lib/prompts/index.js.map +1 -0
  222. package/lib/prompts/interactive-jsdoc/index.cjs +21 -0
  223. package/lib/prompts/interactive-jsdoc/index.d.ts +2 -0
  224. package/lib/prompts/interactive-jsdoc/index.js.map +1 -0
  225. package/lib/prompts/jsdocs/class-prompt.cjs +55 -0
  226. package/lib/prompts/jsdocs/class-prompt.d.ts +2 -0
  227. package/lib/prompts/jsdocs/class-prompt.js.map +1 -0
  228. package/lib/prompts/jsdocs/const-prompt.cjs +27 -0
  229. package/lib/prompts/jsdocs/const-prompt.d.ts +2 -0
  230. package/lib/prompts/jsdocs/const-prompt.js.map +1 -0
  231. package/lib/prompts/jsdocs/constants.cjs +49 -0
  232. package/lib/prompts/jsdocs/constants.d.ts +4 -0
  233. package/lib/prompts/jsdocs/constants.js.map +1 -0
  234. package/lib/prompts/jsdocs/decorator-prompt.cjs +45 -0
  235. package/lib/prompts/jsdocs/decorator-prompt.d.ts +2 -0
  236. package/lib/prompts/jsdocs/decorator-prompt.js.map +1 -0
  237. package/lib/prompts/jsdocs/enum-prompt.cjs +27 -0
  238. package/lib/prompts/jsdocs/enum-prompt.d.ts +2 -0
  239. package/lib/prompts/jsdocs/enum-prompt.js.map +1 -0
  240. package/lib/prompts/jsdocs/function-prompt.cjs +46 -0
  241. package/lib/prompts/jsdocs/function-prompt.d.ts +2 -0
  242. package/lib/prompts/jsdocs/function-prompt.js.map +1 -0
  243. package/lib/prompts/jsdocs/interface-prompt.cjs +27 -0
  244. package/lib/prompts/jsdocs/interface-prompt.d.ts +2 -0
  245. package/lib/prompts/jsdocs/interface-prompt.js.map +1 -0
  246. package/lib/prompts/jsdocs/types-prompt.cjs +27 -0
  247. package/lib/prompts/jsdocs/types-prompt.d.ts +2 -0
  248. package/lib/prompts/jsdocs/types-prompt.js.map +1 -0
  249. package/lib/resources/example-resource/index.cjs +22 -0
  250. package/lib/resources/example-resource/index.d.ts +2 -0
  251. package/lib/resources/example-resource/index.js.map +1 -0
  252. package/lib/resources/index.cjs +7 -0
  253. package/lib/resources/index.d.ts +2 -0
  254. package/lib/resources/index.js.map +1 -0
  255. package/lib/resources/repo-metadata/index.cjs +28 -0
  256. package/lib/resources/repo-metadata/index.d.ts +2 -0
  257. package/lib/resources/repo-metadata/index.js.map +1 -0
  258. package/lib/tools/ast/ts-ast-tool.cjs +70 -0
  259. package/lib/tools/ast/ts-ast-tool.d.ts +2 -0
  260. package/lib/tools/ast/ts-ast-tool.js.map +1 -0
  261. package/lib/tools/ast/types.cjs +36 -0
  262. package/lib/tools/ast/types.d.ts +105 -0
  263. package/lib/tools/ast/types.js.map +1 -0
  264. package/lib/tools/ast/utils.cjs +65 -0
  265. package/lib/tools/ast/utils.d.ts +5 -0
  266. package/lib/tools/ast/utils.js.map +1 -0
  267. package/lib/tools/ast-jsdoc-tools/apply.cjs +36 -0
  268. package/lib/tools/ast-jsdoc-tools/apply.d.ts +6 -0
  269. package/lib/tools/ast-jsdoc-tools/apply.js.map +1 -0
  270. package/lib/tools/ast-jsdoc-tools/cli.cjs +38 -0
  271. package/lib/tools/ast-jsdoc-tools/cli.js.map +1 -0
  272. package/lib/tools/ast-jsdoc-tools/enumerator.cjs +31 -0
  273. package/lib/tools/ast-jsdoc-tools/enumerator.d.ts +1 -0
  274. package/lib/tools/ast-jsdoc-tools/enumerator.js.map +1 -0
  275. package/lib/tools/ast-jsdoc-tools/fileRunner.cjs +35 -0
  276. package/lib/tools/ast-jsdoc-tools/fileRunner.d.ts +11 -0
  277. package/lib/tools/ast-jsdoc-tools/fileRunner.js.map +1 -0
  278. package/lib/tools/ast-jsdoc-tools/formatter.cjs +21 -0
  279. package/lib/tools/ast-jsdoc-tools/formatter.d.ts +6 -0
  280. package/lib/tools/ast-jsdoc-tools/formatter.js.map +1 -0
  281. package/lib/tools/ast-jsdoc-tools/generator.cjs +58 -0
  282. package/lib/tools/ast-jsdoc-tools/generator.d.ts +12 -0
  283. package/lib/tools/ast-jsdoc-tools/generator.js.map +1 -0
  284. package/lib/tools/ast-jsdoc-tools/index.cjs +33 -0
  285. package/lib/tools/ast-jsdoc-tools/index.d.ts +7 -0
  286. package/lib/tools/ast-jsdoc-tools/index.js.map +1 -0
  287. package/lib/tools/ast-jsdoc-tools/interactive.cjs +10 -0
  288. package/lib/tools/ast-jsdoc-tools/interactive.d.ts +1 -0
  289. package/lib/tools/ast-jsdoc-tools/interactive.js.map +1 -0
  290. package/lib/tools/ast-jsdoc-tools/parser.cjs +77 -0
  291. package/lib/tools/ast-jsdoc-tools/parser.d.ts +13 -0
  292. package/lib/tools/ast-jsdoc-tools/parser.js.map +1 -0
  293. package/lib/tools/ast-jsdoc-tools/patch.cjs +29 -0
  294. package/lib/tools/ast-jsdoc-tools/patch.d.ts +2 -0
  295. package/lib/tools/ast-jsdoc-tools/patch.js.map +1 -0
  296. package/lib/tools/ast-jsdoc-tools/prompts/loader.cjs +32 -0
  297. package/lib/tools/ast-jsdoc-tools/prompts/loader.d.ts +10 -0
  298. package/lib/tools/ast-jsdoc-tools/prompts/loader.js.map +1 -0
  299. package/lib/tools/ast-jsdoc-tools/repoRunner.cjs +67 -0
  300. package/lib/tools/ast-jsdoc-tools/repoRunner.d.ts +16 -0
  301. package/lib/tools/ast-jsdoc-tools/repoRunner.js.map +1 -0
  302. package/lib/tools/ast-jsdoc-tools/tools/jsdoc-generator.cjs +81 -0
  303. package/lib/tools/ast-jsdoc-tools/tools/jsdoc-generator.d.ts +5 -0
  304. package/lib/tools/ast-jsdoc-tools/tools/jsdoc-generator.js.map +1 -0
  305. package/lib/tools/ast-jsdoc-tools/utils/conflict-detector.cjs +33 -0
  306. package/lib/tools/ast-jsdoc-tools/utils/conflict-detector.d.ts +5 -0
  307. package/lib/tools/ast-jsdoc-tools/utils/conflict-detector.js.map +1 -0
  308. package/lib/tools/ast-jsdoc-tools/utils/context-schema.cjs +32 -0
  309. package/lib/tools/ast-jsdoc-tools/utils/context-schema.d.ts +7 -0
  310. package/lib/tools/ast-jsdoc-tools/utils/context-schema.js.map +1 -0
  311. package/lib/tools/ast-jsdoc-tools/utils/heuristics.cjs +34 -0
  312. package/lib/tools/ast-jsdoc-tools/utils/heuristics.d.ts +2 -0
  313. package/lib/tools/ast-jsdoc-tools/utils/heuristics.js.map +1 -0
  314. package/lib/tools/ast-jsdoc-tools/utils/ts-project.cjs +57 -0
  315. package/lib/tools/ast-jsdoc-tools/utils/ts-project.d.ts +12 -0
  316. package/lib/tools/ast-jsdoc-tools/utils/ts-project.js.map +1 -0
  317. package/lib/tools/example-tool/index.cjs +32 -0
  318. package/lib/tools/example-tool/index.d.ts +2 -0
  319. package/lib/tools/example-tool/index.js.map +1 -0
  320. package/lib/tools/file-summarizer/index.cjs +32 -0
  321. package/lib/tools/file-summarizer/index.d.ts +2 -0
  322. package/lib/tools/file-summarizer/index.js.map +1 -0
  323. package/lib/tools/index.cjs +9 -0
  324. package/lib/tools/index.d.ts +2 -0
  325. package/lib/tools/index.js.map +1 -0
  326. package/lib/tools/jsdoc/ts-jsdoc-element-tool.cjs +87 -0
  327. package/lib/tools/jsdoc/ts-jsdoc-element-tool.d.ts +2 -0
  328. package/lib/tools/jsdoc/ts-jsdoc-element-tool.js.map +1 -0
  329. package/lib/tools/jsdoc/utils.cjs +60 -0
  330. package/lib/tools/jsdoc/utils.d.ts +5 -0
  331. package/lib/tools/jsdoc/utils.js.map +1 -0
  332. package/lib/tools/testing/ts-jest-list-tests.cjs +56 -0
  333. package/lib/tools/testing/ts-jest-list-tests.d.ts +2 -0
  334. package/lib/tools/testing/ts-jest-list-tests.js.map +1 -0
  335. package/lib/types.cjs +1 -1
  336. package/lib/types.d.ts +56 -47
  337. package/lib/types.js.map +1 -0
  338. package/lib/utils/banner.cjs +114 -0
  339. package/lib/utils/banner.d.ts +3 -0
  340. package/lib/utils/banner.js.map +1 -0
  341. package/lib/version.cjs +8 -0
  342. package/lib/version.d.ts +2 -0
  343. package/lib/version.js.map +1 -0
  344. package/package.json +14 -63
  345. package/dist/mcp-server.esm.cjs +0 -2314
  346. package/lib/McpWrapper.cjs +0 -233
  347. package/lib/McpWrapper.d.ts +0 -89
  348. package/lib/bin/validate-modules.cjs +0 -24
  349. package/lib/esm/McpWrapper.d.ts +0 -89
  350. package/lib/esm/McpWrapper.js +0 -196
  351. package/lib/esm/bin/validate-modules.js +0 -22
  352. package/lib/esm/mcp/aggregateModules.d.ts +0 -26
  353. package/lib/esm/mcp/aggregateModules.js +0 -185
  354. package/lib/esm/mcp/code.d.ts +0 -23
  355. package/lib/esm/mcp/code.js +0 -70
  356. package/lib/esm/mcp/decorator-tools.d.ts +0 -118
  357. package/lib/esm/mcp/decorator-tools.js +0 -237
  358. package/lib/esm/mcp/fastmcp-wiring.d.ts +0 -14
  359. package/lib/esm/mcp/fastmcp-wiring.js +0 -56
  360. package/lib/esm/mcp/index.d.ts +0 -9
  361. package/lib/esm/mcp/index.js +0 -29
  362. package/lib/esm/mcp/mcp-module.d.ts +0 -11
  363. package/lib/esm/mcp/mcp-module.js +0 -31
  364. package/lib/esm/mcp/moduleRegistry.d.ts +0 -14
  365. package/lib/esm/mcp/moduleRegistry.js +0 -47
  366. package/lib/esm/mcp/prompts/index.d.ts +0 -4
  367. package/lib/esm/mcp/prompts/index.js +0 -7
  368. package/lib/esm/mcp/prompts/prompts.d.ts +0 -22
  369. package/lib/esm/mcp/prompts/prompts.js +0 -203
  370. package/lib/esm/mcp/resources/index.d.ts +0 -1
  371. package/lib/esm/mcp/resources/index.js +0 -2
  372. package/lib/esm/mcp/resources/resources.d.ts +0 -2
  373. package/lib/esm/mcp/resources/resources.js +0 -69
  374. package/lib/esm/mcp/schemas.d.ts +0 -53
  375. package/lib/esm/mcp/schemas.js +0 -97
  376. package/lib/esm/mcp/templates/codex-templates.d.ts +0 -3
  377. package/lib/esm/mcp/templates/codex-templates.js +0 -33
  378. package/lib/esm/mcp/templates/index.d.ts +0 -71
  379. package/lib/esm/mcp/templates/index.js +0 -66
  380. package/lib/esm/mcp/templates/resource-templates.d.ts +0 -3
  381. package/lib/esm/mcp/templates/resource-templates.js +0 -60
  382. package/lib/esm/mcp/templates/workspace-templates.d.ts +0 -3
  383. package/lib/esm/mcp/templates/workspace-templates.js +0 -66
  384. package/lib/esm/mcp/tools/codex-tools.d.ts +0 -5
  385. package/lib/esm/mcp/tools/codex-tools.js +0 -244
  386. package/lib/esm/mcp/tools/generateMcpModule.d.ts +0 -9
  387. package/lib/esm/mcp/tools/generateMcpModule.js +0 -133
  388. package/lib/esm/mcp/tools/index.d.ts +0 -219
  389. package/lib/esm/mcp/tools/index.js +0 -27
  390. package/lib/esm/mcp/tools/tools.d.ts +0 -10
  391. package/lib/esm/mcp/tools/tools.js +0 -275
  392. package/lib/esm/mcp/types.d.ts +0 -66
  393. package/lib/esm/mcp/types.js +0 -2
  394. package/lib/esm/mcp/utils.d.ts +0 -3
  395. package/lib/esm/mcp/utils.js +0 -46
  396. package/lib/esm/mcp/validation/index.d.ts +0 -13
  397. package/lib/esm/mcp/validation/index.js +0 -116
  398. package/lib/esm/mcp/validation/scaffoldModule.d.ts +0 -9
  399. package/lib/esm/mcp/validation/scaffoldModule.js +0 -88
  400. package/lib/esm/mcp/workspace.d.ts +0 -9
  401. package/lib/esm/mcp/workspace.js +0 -73
  402. package/lib/esm/metadata.d.ts +0 -9
  403. package/lib/esm/metadata.js +0 -22
  404. package/lib/esm/modules/_template/index.d.ts +0 -32
  405. package/lib/esm/modules/_template/index.js +0 -16
  406. package/lib/esm/modules/_template/prompts/index.d.ts +0 -6
  407. package/lib/esm/modules/_template/prompts/index.js +0 -9
  408. package/lib/esm/modules/_template/resources/index.d.ts +0 -6
  409. package/lib/esm/modules/_template/resources/index.js +0 -9
  410. package/lib/esm/modules/_template/templates/index.d.ts +0 -7
  411. package/lib/esm/modules/_template/templates/index.js +0 -10
  412. package/lib/esm/modules/_template/tools/index.d.ts +0 -6
  413. package/lib/esm/modules/_template/tools/index.js +0 -15
  414. package/lib/esm/modules/decoration/index.d.ts +0 -46
  415. package/lib/esm/modules/decoration/index.js +0 -10
  416. package/lib/esm/modules/decoration/prompts/index.d.ts +0 -1
  417. package/lib/esm/modules/decoration/prompts/index.js +0 -2
  418. package/lib/esm/modules/decoration/resources/index.d.ts +0 -7
  419. package/lib/esm/modules/decoration/resources/index.js +0 -10
  420. package/lib/esm/modules/decoration/templates/index.d.ts +0 -6
  421. package/lib/esm/modules/decoration/templates/index.js +0 -9
  422. package/lib/esm/modules/decoration/tools/index.d.ts +0 -26
  423. package/lib/esm/modules/decoration/tools/index.js +0 -7
  424. package/lib/esm/modules/index.d.ts +0 -2
  425. package/lib/esm/modules/index.js +0 -17
  426. package/lib/esm/modules/mcp/decoration-assist.d.ts +0 -4
  427. package/lib/esm/modules/mcp/decoration-assist.js +0 -6
  428. package/lib/esm/modules/mcp/index.d.ts +0 -6
  429. package/lib/esm/modules/mcp/index.js +0 -16
  430. package/lib/esm/modules/mcp/prompts/index.d.ts +0 -2
  431. package/lib/esm/modules/mcp/prompts/index.js +0 -9
  432. package/lib/esm/modules/mcp/resources/index.d.ts +0 -2
  433. package/lib/esm/modules/mcp/resources/index.js +0 -24
  434. package/lib/esm/modules/mcp/templates/index.d.ts +0 -2
  435. package/lib/esm/modules/mcp/templates/index.js +0 -28
  436. package/lib/esm/modules/mcp/tools/index.d.ts +0 -6
  437. package/lib/esm/modules/mcp/tools/index.js +0 -15
  438. package/lib/esm/utils/modulePaths.d.ts +0 -6
  439. package/lib/esm/utils/modulePaths.js +0 -33
  440. package/lib/esm/utils/moduleValidator.d.ts +0 -14
  441. package/lib/esm/utils/moduleValidator.js +0 -176
  442. package/lib/esm/utils.d.ts +0 -61
  443. package/lib/esm/utils.js +0 -86
  444. package/lib/mcp/aggregateModules.cjs +0 -225
  445. package/lib/mcp/aggregateModules.d.ts +0 -26
  446. package/lib/mcp/code.cjs +0 -81
  447. package/lib/mcp/code.d.ts +0 -23
  448. package/lib/mcp/decorator-tools.cjs +0 -243
  449. package/lib/mcp/decorator-tools.d.ts +0 -118
  450. package/lib/mcp/fastmcp-wiring.cjs +0 -59
  451. package/lib/mcp/fastmcp-wiring.d.ts +0 -14
  452. package/lib/mcp/index.cjs +0 -57
  453. package/lib/mcp/index.d.ts +0 -9
  454. package/lib/mcp/mcp-module.cjs +0 -46
  455. package/lib/mcp/mcp-module.d.ts +0 -11
  456. package/lib/mcp/moduleRegistry.cjs +0 -52
  457. package/lib/mcp/moduleRegistry.d.ts +0 -14
  458. package/lib/mcp/prompts/index.cjs +0 -25
  459. package/lib/mcp/prompts/index.d.ts +0 -4
  460. package/lib/mcp/prompts/prompts.cjs +0 -217
  461. package/lib/mcp/prompts/prompts.d.ts +0 -22
  462. package/lib/mcp/resources/index.d.ts +0 -1
  463. package/lib/mcp/resources/resources.cjs +0 -72
  464. package/lib/mcp/resources/resources.d.ts +0 -2
  465. package/lib/mcp/schemas.cjs +0 -100
  466. package/lib/mcp/schemas.d.ts +0 -53
  467. package/lib/mcp/templates/codex-templates.cjs +0 -40
  468. package/lib/mcp/templates/codex-templates.d.ts +0 -3
  469. package/lib/mcp/templates/index.cjs +0 -76
  470. package/lib/mcp/templates/index.d.ts +0 -71
  471. package/lib/mcp/templates/resource-templates.cjs +0 -67
  472. package/lib/mcp/templates/resource-templates.d.ts +0 -3
  473. package/lib/mcp/templates/workspace-templates.cjs +0 -70
  474. package/lib/mcp/templates/workspace-templates.d.ts +0 -3
  475. package/lib/mcp/tools/codex-tools.cjs +0 -250
  476. package/lib/mcp/tools/codex-tools.d.ts +0 -5
  477. package/lib/mcp/tools/generateMcpModule.cjs +0 -139
  478. package/lib/mcp/tools/generateMcpModule.d.ts +0 -9
  479. package/lib/mcp/tools/index.cjs +0 -30
  480. package/lib/mcp/tools/index.d.ts +0 -219
  481. package/lib/mcp/tools/tools.cjs +0 -317
  482. package/lib/mcp/tools/tools.d.ts +0 -10
  483. package/lib/mcp/types.cjs +0 -3
  484. package/lib/mcp/types.d.ts +0 -66
  485. package/lib/mcp/utils.cjs +0 -54
  486. package/lib/mcp/utils.d.ts +0 -3
  487. package/lib/mcp/validation/index.cjs +0 -123
  488. package/lib/mcp/validation/index.d.ts +0 -13
  489. package/lib/mcp/validation/scaffoldModule.cjs +0 -94
  490. package/lib/mcp/validation/scaffoldModule.d.ts +0 -9
  491. package/lib/mcp/workspace.cjs +0 -119
  492. package/lib/mcp/workspace.d.ts +0 -9
  493. package/lib/metadata.cjs +0 -25
  494. package/lib/metadata.d.ts +0 -9
  495. package/lib/modules/_template/index.cjs +0 -23
  496. package/lib/modules/_template/index.d.ts +0 -32
  497. package/lib/modules/_template/prompts/index.cjs +0 -12
  498. package/lib/modules/_template/prompts/index.d.ts +0 -6
  499. package/lib/modules/_template/resources/index.cjs +0 -12
  500. package/lib/modules/_template/resources/index.d.ts +0 -6
  501. package/lib/modules/_template/templates/index.cjs +0 -13
  502. package/lib/modules/_template/templates/index.d.ts +0 -7
  503. package/lib/modules/_template/tools/index.cjs +0 -18
  504. package/lib/modules/_template/tools/index.d.ts +0 -6
  505. package/lib/modules/decoration/index.cjs +0 -17
  506. package/lib/modules/decoration/index.d.ts +0 -46
  507. package/lib/modules/decoration/prompts/index.cjs +0 -5
  508. package/lib/modules/decoration/prompts/index.d.ts +0 -1
  509. package/lib/modules/decoration/resources/index.cjs +0 -13
  510. package/lib/modules/decoration/resources/index.d.ts +0 -7
  511. package/lib/modules/decoration/templates/index.cjs +0 -12
  512. package/lib/modules/decoration/templates/index.d.ts +0 -6
  513. package/lib/modules/decoration/tools/index.cjs +0 -10
  514. package/lib/modules/decoration/tools/index.d.ts +0 -26
  515. package/lib/modules/index.cjs +0 -20
  516. package/lib/modules/index.d.ts +0 -2
  517. package/lib/modules/mcp/decoration-assist.cjs +0 -13
  518. package/lib/modules/mcp/decoration-assist.d.ts +0 -4
  519. package/lib/modules/mcp/index.cjs +0 -23
  520. package/lib/modules/mcp/index.d.ts +0 -6
  521. package/lib/modules/mcp/prompts/index.cjs +0 -12
  522. package/lib/modules/mcp/prompts/index.d.ts +0 -2
  523. package/lib/modules/mcp/resources/index.cjs +0 -27
  524. package/lib/modules/mcp/resources/index.d.ts +0 -2
  525. package/lib/modules/mcp/templates/index.cjs +0 -31
  526. package/lib/modules/mcp/templates/index.d.ts +0 -2
  527. package/lib/modules/mcp/tools/index.cjs +0 -18
  528. package/lib/modules/mcp/tools/index.d.ts +0 -6
  529. package/lib/utils/modulePaths.cjs +0 -43
  530. package/lib/utils/modulePaths.d.ts +0 -6
  531. package/lib/utils/moduleValidator.cjs +0 -184
  532. package/lib/utils/moduleValidator.d.ts +0 -14
  533. package/lib/utils.cjs +0 -129
  534. package/lib/utils.d.ts +0 -61
  535. /package/lib/{bin/validate-modules.d.ts → esm/tools/ast-jsdoc-tools/cli.d.ts} +0 -0
  536. /package/lib/{esm/bin/validate-modules.d.ts → tools/ast-jsdoc-tools/cli.d.ts} +0 -0
@@ -1,2360 +1,2 @@
1
- (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('fs'), require('path'), require('child_process'), require('zod'), require('diff'), require('@decaf-ts/decoration'), require('url'), require('node:fs'), require('node:path'), require('fastmcp'), require('@decaf-ts/logging')) :
3
- typeof define === 'function' && define.amd ? define(['exports', 'fs', 'path', 'child_process', 'zod', 'diff', '@decaf-ts/decoration', 'url', 'node:fs', 'node:path', 'fastmcp', '@decaf-ts/logging'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["mcp-server"] = {}, global.fs, global.path, global.child_process, global.zod, global.diff, global.decoration, global.url, global.fs$1, global.path$1, global.fastmcp, global.logging));
5
- })(this, (function (exports, fs, path, child_process, zod, diff, decoration, url, fs$1, path$1, fastmcp, logging) { 'use strict';
6
-
7
- function _interopNamespaceDefault(e) {
8
- var n = Object.create(null);
9
- if (e) {
10
- Object.keys(e).forEach(function (k) {
11
- if (k !== 'default') {
12
- var d = Object.getOwnPropertyDescriptor(e, k);
13
- Object.defineProperty(n, k, d.get ? d : {
14
- enumerable: true,
15
- get: function () { return e[k]; }
16
- });
17
- }
18
- });
19
- }
20
- n.default = e;
21
- return Object.freeze(n);
22
- }
23
-
24
- var fs__namespace = /*#__PURE__*/_interopNamespaceDefault(fs);
25
- var path__namespace = /*#__PURE__*/_interopNamespaceDefault(path);
26
-
27
- /**
28
- * @description The filename that identifies Decaf CLI modules
29
- * @summary The standard filename for CLI module files where each library must export a single CliModule function
30
- *
31
- * @const MCP_FILE_NAME
32
- * @memberOf module:MCP
33
- */
34
- const MCP_FILE_NAME = "mcp-module";
35
- const WORKSPACE_ROOT_ENV = "MCP_WORKSPACE_ROOT";
36
- const PROMPT_DIRECTORIES = [".code/prompts", ".codex/prompts"];
37
- const DEFAULT_PROMPT_NAME = "doc";
38
- const CLIENT_INTEGRATIONS = [
39
- {
40
- id: "vscode",
41
- display: "Visual Studio Code",
42
- instructions: "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.",
43
- },
44
- {
45
- id: "cursor",
46
- display: "Cursor",
47
- instructions: "Cursor clients can retrieve and update files through the cursor://workspace/{path} resource template. Always validate patches in dryRun mode before applying permanent changes.",
48
- },
49
- {
50
- id: "copilot",
51
- display: "GitHub Copilot",
52
- instructions: "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.",
53
- },
54
- ];
55
-
56
- let workspaceRoot = initializeWorkspaceRoot();
57
- let userErrorCtor;
58
- class WorkspaceError extends Error {
59
- constructor(message) {
60
- super(message);
61
- this.name = "WorkspaceError";
62
- }
63
- }
64
- function initializeWorkspaceRoot() {
65
- const configured = process.env[WORKSPACE_ROOT_ENV];
66
- if (configured && configured.trim().length > 0) {
67
- return path.resolve(configured.trim());
68
- }
69
- return process.cwd();
70
- }
71
- async function getUserErrorCtor() {
72
- if (!userErrorCtor) {
73
- try {
74
- const mod = await import('fastmcp');
75
- userErrorCtor = mod
76
- .UserError;
77
- }
78
- catch {
79
- userErrorCtor = class MCPUserError extends Error {
80
- constructor(message) {
81
- super(message);
82
- this.name = "MCPUserError";
83
- }
84
- };
85
- }
86
- }
87
- return userErrorCtor;
88
- }
89
- async function throwUserError(message) {
90
- const Ctor = await getUserErrorCtor();
91
- throw new Ctor(message);
92
- }
93
- function setWorkspaceRoot(root) {
94
- workspaceRoot = path.resolve(root);
95
- }
96
- function getWorkspaceRoot() {
97
- return workspaceRoot;
98
- }
99
- function resolveInWorkspace(root, targetPath) {
100
- const resolved = path.isAbsolute(targetPath)
101
- ? path.normalize(targetPath)
102
- : path.resolve(root, targetPath);
103
- const relative = path.relative(root, resolved);
104
- if (relative.startsWith("..") || path.isAbsolute(relative)) {
105
- throw new WorkspaceError(`Path ${targetPath} escapes the workspace root at ${root}`);
106
- }
107
- return resolved;
108
- }
109
- async function readWorkspaceFile(root, target) {
110
- try {
111
- const absolute = resolveInWorkspace(root, target);
112
- return fs.readFileSync(absolute, "utf8");
113
- }
114
- catch (error) {
115
- if (error instanceof WorkspaceError) {
116
- await throwUserError(error.message);
117
- }
118
- /* istanbul ignore next */
119
- throw error;
120
- }
121
- }
122
- function __resetWorkspaceRoot(root) {
123
- setWorkspaceRoot(root);
124
- }
125
-
126
- const prompts = [];
127
- // Read registered module packages from a runtime global set by modules/index
128
- // This avoids importing moduleRegistry at module-eval time which creates circular imports.
129
- function getRegisteredModulePackages() {
130
- return globalThis.__DECAF_MODULE_PACKAGES__ ?? [];
131
- }
132
- const OBJECT_PROMPT_DEPENDENCIES = {
133
- module: ["doc", "module"],
134
- file: ["doc", "file"],
135
- class: ["doc", "class"],
136
- function: ["doc", "function"],
137
- interface: ["doc", "interface"],
138
- decorator: ["doc", "decorator"],
139
- constant: ["doc", "constant"],
140
- "bulk-docs": ["bulk-docs"],
141
- "bulk-tests": ["bulk-tests"],
142
- "update-readme": ["update-readme"],
143
- "repo-setup": ["repo-setup"],
144
- "release-notes": ["release-notes"],
145
- "mcp-module": ["mcp-module"],
146
- };
147
- function getObjectPromptDependencies() {
148
- return OBJECT_PROMPT_DEPENDENCIES;
149
- }
150
- function buildDocPrompts() {
151
- const root = getWorkspaceRoot();
152
- const fileBasedPrompts = discoverDocPrompts(root).map((prompt) => ({
153
- name: `doc/${prompt.name}`,
154
- description: prompt.description,
155
- load: async () => prompt.content,
156
- }));
157
- const integrationPrompts = CLIENT_INTEGRATIONS.map((integration) => ({
158
- name: `integration/${integration.id}`,
159
- description: `${integration.display} integration guidance`,
160
- 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.`,
161
- }));
162
- return [...fileBasedPrompts, ...integrationPrompts];
163
- }
164
- function summarizePromptContent(prompt, headingPrefix) {
165
- return [`## ${headingPrefix}`, "", prompt.content.trim()].join("\n");
166
- }
167
- function buildObjectPrompts() {
168
- const root = getWorkspaceRoot();
169
- const discovered = discoverDocPrompts(root);
170
- const promptByName = new Map();
171
- for (const prompt of discovered) {
172
- promptByName.set(prompt.name, prompt);
173
- }
174
- const outputs = [];
175
- for (const [objectType, dependencies] of Object.entries(OBJECT_PROMPT_DEPENDENCIES)) {
176
- const existing = dependencies
177
- .map((name) => promptByName.get(name))
178
- .filter((prompt) => Boolean(prompt));
179
- if (!existing.length)
180
- continue;
181
- outputs.push({
182
- name: `codex/${objectType}`,
183
- description: `Guidance derived from .codex prompts for ${objectType} tasks.`,
184
- load: async () => {
185
- const sections = existing.map((prompt) => summarizePromptContent(prompt, toTitleCase(prompt.name)));
186
- return [`# Codex guidance for ${objectType}`, "", ...sections].join("\n");
187
- },
188
- });
189
- }
190
- return outputs.sort((a, b) => a.name.localeCompare(b.name));
191
- }
192
- function toInputPrompt(asset) {
193
- const provenance = asset.provenance ? ` (module: ${asset.provenance})` : "";
194
- return {
195
- name: asset.id,
196
- description: `${asset.description ?? asset.title}${provenance}`,
197
- load: async () => asset.load(),
198
- };
199
- }
200
- function buildModulePrompts() {
201
- const pkgs = getRegisteredModulePackages();
202
- const assets = pkgs.flatMap((p) => p.prompts ?? []);
203
- return assets.map(toInputPrompt);
204
- }
205
- function refreshPrompts(repoPath) {
206
- const docPrompts = buildDocPrompts();
207
- const objectPrompts = buildObjectPrompts();
208
- const repoPrompts = [];
209
- const modulePrompts = buildModulePrompts();
210
- prompts.splice(0, prompts.length, ...docPrompts, ...objectPrompts, ...repoPrompts, ...modulePrompts);
211
- return prompts;
212
- }
213
- function discoverDocPrompts(root) {
214
- const discovered = [];
215
- for (const directory of PROMPT_DIRECTORIES) {
216
- const promptDir = path.join(root, directory);
217
- // debug logging to help tests diagnose prompt discovery
218
- console.debug("[discoverDocPrompts] checking", promptDir);
219
- if (!fs.existsSync(promptDir) || !fs.statSync(promptDir).isDirectory()) {
220
- continue;
221
- }
222
- for (const entry of fs.readdirSync(promptDir)) {
223
- const fullPath = path.join(promptDir, entry);
224
- if (!fs.statSync(fullPath).isFile())
225
- continue;
226
- const name = path.parse(entry).name;
227
- const content = fs.readFileSync(fullPath, "utf8");
228
- const title = toTitleCase(name.replace(/[-_]/g, " "));
229
- const description = extractDescription(content, fullPath);
230
- discovered.push({
231
- name,
232
- title,
233
- description,
234
- content,
235
- absolutePath: fullPath,
236
- });
237
- }
238
- }
239
- const unique = new Map();
240
- for (const prompt of discovered) {
241
- if (!unique.has(prompt.name)) {
242
- unique.set(prompt.name, prompt);
243
- }
244
- }
245
- return Array.from(unique.values()).sort((a, b) => a.name.localeCompare(b.name));
246
- }
247
- function selectPrompt(promptList, requestedName) {
248
- const direct = promptList.find((prompt) => prompt.name === requestedName);
249
- if (direct)
250
- return direct;
251
- const fallback = promptList.find((prompt) => prompt.name === DEFAULT_PROMPT_NAME);
252
- if (fallback)
253
- return fallback;
254
- if (!promptList.length) {
255
- throw new Error("No documentation prompts available");
256
- }
257
- return promptList[0];
258
- }
259
- function buildDocumentationPayload({ filePath, fileContent, prompt, includePrompt, includeCode, includeMetadata, additionalContext, }) {
260
- const sections = [];
261
- if (includeMetadata) {
262
- sections.push(`# Documentation Request\n- prompt: ${prompt.name}\n- file: ${filePath}`);
263
- }
264
- if (includePrompt) {
265
- sections.push(`## Prompt Guidance (${prompt.title})\n\n${prompt.content.trim()}`);
266
- }
267
- if (additionalContext?.trim()) {
268
- sections.push(`## Additional Context\n\n${additionalContext.trim()}`);
269
- }
270
- if (includeCode) {
271
- sections.push(`## Source\n\n\`\`\`${inferLanguageFromPath(filePath)}\n${fileContent}\n\`\`\``);
272
- }
273
- return {
274
- content: [
275
- {
276
- type: "text",
277
- text: sections.join("\n\n"),
278
- },
279
- ],
280
- };
281
- }
282
- function extractDescription(content, filePath) {
283
- const firstLine = content
284
- .split(/\r?\n/)
285
- .map((line) => line.trim())
286
- .find((line) => line.length > 0);
287
- return (firstLine?.slice(0, 240) ??
288
- `Documentation prompt loaded from ${path.basename(filePath)}`);
289
- }
290
- function toTitleCase(value) {
291
- return value
292
- .split(/\s+/)
293
- .filter(Boolean)
294
- .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())
295
- .join(" ");
296
- }
297
- function inferLanguageFromPath(filePath) {
298
- const extension = path.extname(filePath).toLowerCase();
299
- switch (extension) {
300
- case ".ts":
301
- case ".tsx":
302
- return "ts";
303
- case ".js":
304
- case ".jsx":
305
- return "js";
306
- case ".json":
307
- return "json";
308
- case ".md":
309
- return "md";
310
- default:
311
- return "text";
312
- }
313
- }
314
-
315
- var prompts$1 = /*#__PURE__*/Object.freeze({
316
- __proto__: null,
317
- DEFAULT_PROMPT_NAME: DEFAULT_PROMPT_NAME,
318
- buildDocPrompts: buildDocPrompts,
319
- buildDocumentationPayload: buildDocumentationPayload,
320
- buildObjectPrompts: buildObjectPrompts,
321
- discoverDocPrompts: discoverDocPrompts,
322
- getObjectPromptDependencies: getObjectPromptDependencies,
323
- prompts: prompts,
324
- refreshPrompts: refreshPrompts,
325
- selectPrompt: selectPrompt
326
- });
327
-
328
- const promptList = prompts;
329
- function loadPrompts(repoPath) {
330
- return refreshPrompts();
331
- }
332
-
333
- class ModuleRegistry {
334
- constructor(packages = []) {
335
- this.packages = packages;
336
- }
337
- setPackages(pkgs) {
338
- this.packages = Array.isArray(pkgs) ? pkgs : [];
339
- }
340
- listPackages() {
341
- return this.packages;
342
- }
343
- listPrompts() {
344
- return this.collectAssets("prompts");
345
- }
346
- listResources() {
347
- return this.collectAssets("resources");
348
- }
349
- listTemplates() {
350
- return this.collectAssets("templates");
351
- }
352
- listTools() {
353
- return this.collectAssets("tools");
354
- }
355
- collectAssets(key) {
356
- const seen = new Map();
357
- const aggregated = [];
358
- for (const pkg of this.packages) {
359
- if (pkg.status === "disabled")
360
- continue;
361
- for (const asset of pkg[key]) {
362
- const maybeName = asset.name;
363
- const assetKey = (asset && (asset.id ?? maybeName)) || JSON.stringify(asset);
364
- if (seen.has(assetKey)) {
365
- const conflict = seen.get(assetKey);
366
- throw new Error(`Duplicate ${key} id '${assetKey}' from modules ${conflict} and ${pkg.name}`);
367
- }
368
- seen.set(assetKey, pkg.name);
369
- aggregated.push({ ...asset, provenance: pkg.name });
370
- }
371
- }
372
- return aggregated;
373
- }
374
- }
375
- const moduleRegistry = new ModuleRegistry();
376
-
377
- const analyzeRepoSchema = zod.z
378
- .object({
379
- repoPath: zod.z
380
- .string()
381
- .min(1, "repoPath is required")
382
- .describe("Relative or absolute path to the target repository inside this monorepo, e.g. './decoration'."),
383
- includeTests: zod.z
384
- .boolean()
385
- .default(true)
386
- .describe("If true, analyze the tests directory (if present) to derive expected behaviors."),
387
- includeDocs: zod.z
388
- .boolean()
389
- .default(true)
390
- .describe("If true, analyze README.md and docs directories to extract documented features."),
391
- })
392
- .strict()
393
- .describe("Analyze a local repository (e.g. ./decoration) to extract APIs, features, tests, and documentation cues.");
394
- const enumerateCapabilitiesSchema = zod.z
395
- .object({
396
- repoPath: zod.z
397
- .string()
398
- .min(1, "repoPath is required")
399
- .describe("Relative or absolute path to the target repository to enumerate developer-facing capabilities."),
400
- })
401
- .strict()
402
- .describe("Enumerate the complete set of capabilities a developer is expected to use from the given repository.");
403
- const planFeatureSchema = zod.z
404
- .object({
405
- feature: zod.z
406
- .string()
407
- .min(5, "feature must describe the goal clearly")
408
- .describe("Natural-language description of a developer's requested feature or task to implement using the repository and available MCP tools."),
409
- repoPath: zod.z
410
- .string()
411
- .default("./decoration")
412
- .describe("Target repository path providing the library to use, e.g. './decoration'."),
413
- })
414
- .strict()
415
- .describe("Plan which MCP tools to use and in what sequence to implement a requested feature using the repository.");
416
- const documentCodeSchema = zod.z
417
- .object({
418
- filePath: zod.z.string().min(1, "filePath is required"),
419
- promptName: zod.z.string().optional(),
420
- includePrompt: zod.z.boolean().default(true),
421
- includeCode: zod.z.boolean().default(true),
422
- includeMetadata: zod.z.boolean().default(true),
423
- additionalContext: zod.z.string().optional(),
424
- encoding: zod.z.string().default("utf8"),
425
- })
426
- .strict();
427
- const codeChangeSchema = zod.z
428
- .object({
429
- filePath: zod.z.string().min(1, "filePath is required"),
430
- patch: zod.z.string().min(1, "patch is required"),
431
- dryRun: zod.z.boolean().default(false),
432
- showDiff: zod.z.boolean().default(true),
433
- diffContext: zod.z.number().int().min(0).max(100).default(3),
434
- encoding: zod.z.string().default("utf8"),
435
- })
436
- .strict();
437
- const OBJECT_TYPES = [
438
- "module",
439
- "file",
440
- "class",
441
- "function",
442
- "interface",
443
- "decorator",
444
- "constant",
445
- ];
446
- const documentObjectSchema = zod.z
447
- .object({
448
- basePath: zod.z.string().min(1, "basePath is required"),
449
- objectType: zod.z.enum(OBJECT_TYPES),
450
- targetFile: zod.z.string().optional(),
451
- includeContent: zod.z.boolean().default(false),
452
- })
453
- .strict();
454
- const coverageTaskSchema = zod.z
455
- .object({
456
- basePath: zod.z.string().min(1, "basePath is required"),
457
- coverage: zod.z
458
- .number()
459
- .min(0)
460
- .max(100)
461
- .default(90)
462
- .describe("Target coverage percentage"),
463
- dryRun: zod.z.boolean().default(false),
464
- })
465
- .strict();
466
- const readmeImprovementSchema = zod.z
467
- .object({
468
- basePath: zod.z.string().min(1, "basePath is required"),
469
- includeExamples: zod.z.boolean().default(true),
470
- })
471
- .strict();
472
-
473
- function readFileSafe(filePath, encoding = "utf8") {
474
- try {
475
- return fs.readFileSync(filePath, { encoding });
476
- }
477
- catch {
478
- return undefined;
479
- }
480
- }
481
- function listFilesRecursive(root, matcher) {
482
- const out = [];
483
- const stack = [root];
484
- while (stack.length) {
485
- const cur = stack.pop();
486
- const stat = fs.statSync(cur);
487
- if (stat.isDirectory()) {
488
- for (const f of fs.readdirSync(cur))
489
- stack.push(path.join(cur, f));
490
- }
491
- else if (!matcher || matcher(cur)) {
492
- out.push(cur);
493
- }
494
- }
495
- return out.sort();
496
- }
497
- function deriveCapabilities(analysis) {
498
- const cap = new Set();
499
- // heuristics: if decorators like Decoration, flavouredAs, extend, override appear, add capabilities
500
- const allDecs = new Set();
501
- for (const k of Object.keys(analysis.api)) {
502
- for (const d of analysis.api[k].decorators)
503
- allDecs.add(d);
504
- for (const e of analysis.api[k].exports)
505
- if (/Decoration|decorate|Builder|Flavour/i.test(e))
506
- cap.add("use-decoration-api");
507
- }
508
- if ([...allDecs].some((d) => /override|extend/i.test(d)))
509
- cap.add("override-and-extend-decorations");
510
- if (Object.keys(analysis.tests).length > 0)
511
- cap.add("validate-with-tests");
512
- if (analysis.readme)
513
- cap.add("follow-readme-guides");
514
- return [...cap].sort();
515
- }
516
-
517
- // Analysis helpers (minimal yet effective, text-based to avoid heavy AST deps)
518
- function isSourceFile(p) {
519
- return /\.(ts|tsx|js|jsx)$/.test(p) && !p.endsWith(".d.ts");
520
- }
521
- function isTestFile(p) {
522
- return /(\.test\.|\.spec\.)/.test(p);
523
- }
524
- function extractExports(fileContent) {
525
- const names = new Set();
526
- const exportRe = /(export\s+(?:default\s+)?(?:class|function|const|let|var|interface|type|enum)\s+)([A-Za-z0-9_]+)/g;
527
- const namedRe = /export\s*\{([^}]+)\}/g;
528
- let m;
529
- while ((m = exportRe.exec(fileContent)))
530
- names.add(m[2]);
531
- while ((m = namedRe.exec(fileContent))) {
532
- m[1]
533
- .split(",")
534
- .map((s) => s.trim().split(" as ")[0].trim())
535
- .forEach((n) => {
536
- if (n)
537
- names.add(n);
538
- });
539
- }
540
- return [...names].sort();
541
- }
542
- function extractDecorators(fileContent) {
543
- const decs = new Set();
544
- const decRe = /@([A-Za-z_][A-Za-z0-9_]*)/g;
545
- let m;
546
- while ((m = decRe.exec(fileContent)))
547
- decs.add(m[1]);
548
- return [...decs].sort();
549
- }
550
- function summarizeReadme(readme) {
551
- if (!readme)
552
- return undefined;
553
- const lines = readme.split(/\r?\n/).filter(Boolean);
554
- const title = lines.find((l) => /^#\s+/.test(l))?.replace(/^#\s+/, "") || "README";
555
- const bullets = lines.filter((l) => /^[-*]\s+/.test(l)).slice(0, 20);
556
- return { title, bullets };
557
- }
558
- function analyzeRepo(root) {
559
- const src = path.join(root, "src");
560
- const testDir = path.join(root, "tests");
561
- const readmePath = path.join(root, "README.md");
562
- const readme = readFileSafe(readmePath);
563
- const files = fs.existsSync(src) ? listFilesRecursive(src, isSourceFile) : [];
564
- const testFiles = fs.existsSync(testDir)
565
- ? listFilesRecursive(testDir, (f) => isSourceFile(f) && isTestFile(f))
566
- : [];
567
- const api = {};
568
- for (const f of files) {
569
- const content = readFileSafe(f) || "";
570
- api[path.relative(root, f)] = {
571
- exports: extractExports(content),
572
- decorators: extractDecorators(content),
573
- };
574
- }
575
- const tests = {};
576
- for (const f of testFiles) {
577
- const content = readFileSafe(f) || "";
578
- const mentions = Array.from(new Set([...extractExports(content), ...extractDecorators(content)])).sort();
579
- tests[path.relative(root, f)] = { mentions };
580
- }
581
- return { files, testFiles, api, tests, readme: summarizeReadme(readme) };
582
- }
583
-
584
- function relativeFiles(root, files) {
585
- return files.map((file) => path.relative(root, file)).sort();
586
- }
587
- function collectPromptSections(names) {
588
- const root = getWorkspaceRoot();
589
- const promptIndex = new Map(discoverDocPrompts(root).map((prompt) => [prompt.name, prompt]));
590
- return names
591
- .map((name) => promptIndex.get(name))
592
- .filter((prompt) => Boolean(prompt))
593
- .map((prompt) => ({
594
- name: prompt.name,
595
- title: prompt.title,
596
- description: prompt.description,
597
- content: prompt.content,
598
- absolutePath: prompt.absolutePath,
599
- }));
600
- }
601
- function parseTaskLines(content) {
602
- return content
603
- .split(/\r?\n/)
604
- .map((line) => line.trim())
605
- .filter((line) => /^task\s+\d+/i.test(line));
606
- }
607
- function computeCoverageFromFinal(coveragePath) {
608
- const payload = JSON.parse(fs.readFileSync(coveragePath, "utf8"));
609
- const totals = {
610
- statements: { covered: 0, total: 0 },
611
- functions: { covered: 0, total: 0 },
612
- branches: { covered: 0, total: 0 },
613
- };
614
- const files = Object.entries(payload).map(([filePath, info]) => {
615
- const statementCounts = Object.values(info.s);
616
- const functionCounts = Object.values(info.f);
617
- const branchCounts = Object.values(info.b).flatMap((value) => Array.isArray(value) ? value : [value]);
618
- const statementTotal = statementCounts.length;
619
- const functionTotal = functionCounts.length;
620
- const branchTotal = branchCounts.length;
621
- const statementCovered = statementCounts.filter((count) => count > 0).length;
622
- const functionCovered = functionCounts.filter((count) => count > 0).length;
623
- const branchCovered = branchCounts.filter((count) => count > 0).length;
624
- totals.statements.covered += statementCovered;
625
- totals.statements.total += statementTotal;
626
- totals.functions.covered += functionCovered;
627
- totals.functions.total += functionTotal;
628
- totals.branches.covered += branchCovered;
629
- totals.branches.total += branchTotal;
630
- const pct = (covered, total) => total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));
631
- return {
632
- path: filePath,
633
- statements: pct(statementCovered, statementTotal),
634
- functions: pct(functionCovered, functionTotal),
635
- branches: pct(branchCovered, branchTotal),
636
- };
637
- });
638
- const pct = (covered, total) => total === 0 ? 100 : Number(((covered / total) * 100).toFixed(2));
639
- return {
640
- totals: {
641
- statements: {
642
- ...totals.statements,
643
- pct: pct(totals.statements.covered, totals.statements.total),
644
- },
645
- functions: {
646
- ...totals.functions,
647
- pct: pct(totals.functions.covered, totals.functions.total),
648
- },
649
- branches: {
650
- ...totals.branches,
651
- pct: pct(totals.branches.covered, totals.branches.total),
652
- },
653
- },
654
- files,
655
- };
656
- }
657
- function normalizePromptSections(sections) {
658
- return sections.map((section) => ({
659
- name: section.name,
660
- title: section.title,
661
- tasks: parseTaskLines(section.content),
662
- content: section.content,
663
- }));
664
- }
665
- async function resolveRepoRoot(basePath) {
666
- const root = getWorkspaceRoot();
667
- try {
668
- return resolveInWorkspace(root, basePath);
669
- }
670
- catch (error) {
671
- if (error instanceof WorkspaceError) {
672
- await throwUserError(error.message);
673
- }
674
- throw error;
675
- }
676
- }
677
- const documentObjectTool = {
678
- name: "document-object",
679
- description: "Create a documentation plan for a specific object type using .codex prompts and repository analysis.",
680
- parameters: documentObjectSchema,
681
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
682
- execute: async (input, _context) => {
683
- const args = documentObjectSchema.parse(input);
684
- const repoRoot = await resolveRepoRoot(args.basePath);
685
- const dependencies = getObjectPromptDependencies()[args.objectType] ?? [];
686
- if (!dependencies.length) {
687
- await throwUserError(`No prompt guidance configured for object type ${args.objectType}`);
688
- }
689
- const sections = normalizePromptSections(collectPromptSections(dependencies));
690
- const srcDir = path.join(repoRoot, "src");
691
- const testDir = path.join(repoRoot, "tests");
692
- const sourceFiles = fs.existsSync(srcDir)
693
- ? listFilesRecursive(srcDir, isSourceFile)
694
- : [];
695
- const testFiles = fs.existsSync(testDir)
696
- ? listFilesRecursive(testDir, (file) => isSourceFile(file) && isTestFile(file))
697
- : [];
698
- let targetFileContent;
699
- if (args.targetFile) {
700
- try {
701
- const absolute = resolveInWorkspace(repoRoot, args.targetFile);
702
- targetFileContent = readFileSafe(absolute) ?? undefined;
703
- }
704
- catch (error) {
705
- if (error instanceof WorkspaceError) {
706
- await throwUserError(error.message);
707
- }
708
- throw error;
709
- }
710
- }
711
- const payload = {
712
- basePath: path.relative(getWorkspaceRoot(), repoRoot) || ".",
713
- objectType: args.objectType,
714
- targetFile: args.targetFile,
715
- guidance: sections,
716
- files: {
717
- source: relativeFiles(repoRoot, sourceFiles),
718
- tests: relativeFiles(repoRoot, testFiles),
719
- },
720
- targetFileContent: args.includeContent ? targetFileContent : undefined,
721
- };
722
- return {
723
- content: [
724
- {
725
- type: "text",
726
- text: JSON.stringify(payload, null, 2),
727
- },
728
- ],
729
- };
730
- },
731
- };
732
- const coverageEnforcerTool = {
733
- name: "ensure-test-coverage",
734
- description: "Run the configured coverage command and report whether the target percentage is met, highlighting weak files.",
735
- parameters: coverageTaskSchema,
736
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
737
- execute: async (input, _context) => {
738
- const args = coverageTaskSchema.parse(input);
739
- const repoRoot = await resolveRepoRoot(args.basePath);
740
- if (!args.dryRun) {
741
- const env = {
742
- ...process.env,
743
- USE_WATCHMAN: "false",
744
- WATCHMAN_DISABLE: "1",
745
- JEST_DISABLE_WATCHMAN: "1",
746
- };
747
- const result = child_process.spawnSync("npm", ["run", "coverage", "--", "--watchman=false", "--runInBand"], { cwd: repoRoot, env, encoding: "utf8" });
748
- if (result.status !== 0) {
749
- const message = result.stderr || result.stdout || "Coverage command failed";
750
- await throwUserError(message.trim());
751
- }
752
- }
753
- const coveragePath = path.join(repoRoot, "workdocs", "reports", "coverage", "coverage-final.json");
754
- if (!fs.existsSync(coveragePath)) {
755
- await throwUserError(`Coverage report not found at ${path.relative(repoRoot, coveragePath)}`);
756
- }
757
- const summary = computeCoverageFromFinal(coveragePath);
758
- const meetsThreshold = summary.totals.statements.pct >= args.coverage &&
759
- summary.totals.functions.pct >= args.coverage &&
760
- summary.totals.branches.pct >= args.coverage;
761
- const weakest = [...summary.files]
762
- .sort((a, b) => a.statements - b.statements)
763
- .slice(0, 10);
764
- const guidance = normalizePromptSections(collectPromptSections(["bulk-tests"]));
765
- const payload = {
766
- basePath: path.relative(getWorkspaceRoot(), repoRoot) || ".",
767
- target: args.coverage,
768
- meetsThreshold,
769
- totals: summary.totals,
770
- weakest,
771
- guidance,
772
- };
773
- return {
774
- content: [
775
- {
776
- type: "text",
777
- text: JSON.stringify(payload, null, 2),
778
- },
779
- ],
780
- };
781
- },
782
- };
783
- const readmeImprovementTool = {
784
- name: "improve-readme",
785
- description: "Summarize required steps to refresh README and workdocs content using .codex guidance and repository analysis.",
786
- parameters: readmeImprovementSchema,
787
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
788
- execute: async (input, _context) => {
789
- const args = readmeImprovementSchema.parse(input);
790
- const repoRoot = await resolveRepoRoot(args.basePath);
791
- const analysis = analyzeRepo(repoRoot);
792
- const modules = analysis.files
793
- .filter((file) => /index\.ts$/.test(file))
794
- .map((file) => path.relative(repoRoot, file));
795
- const promptSections = normalizePromptSections(collectPromptSections(["update-readme", "doc", "module"]));
796
- const testExamples = Object.keys(analysis.tests ?? {});
797
- const examples = args.includeExamples ? testExamples.slice(0, 20) : [];
798
- const payload = {
799
- basePath: path.relative(getWorkspaceRoot(), repoRoot) || ".",
800
- summary: {
801
- modules,
802
- totalSourceFiles: analysis.files.length,
803
- totalTestFiles: analysis.testFiles.length,
804
- hasReadme: Boolean(analysis.readme),
805
- },
806
- guidance: promptSections,
807
- suggestedExamples: examples,
808
- };
809
- return {
810
- content: [
811
- {
812
- type: "text",
813
- text: JSON.stringify(payload, null, 2),
814
- },
815
- ],
816
- };
817
- },
818
- };
819
-
820
- function escapeRegExp(value) {
821
- return value.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
822
- }
823
- function formatDecorator(spec) {
824
- const args = (spec.args || []).map((arg) => JSON.stringify(arg)).join(", ");
825
- return `@${spec.name}(${args})`;
826
- }
827
- function ensureDirectory(filePath) {
828
- fs.mkdirSync(path.dirname(filePath), { recursive: true });
829
- }
830
- function collectDecoratorNames(classDecorators, properties) {
831
- const names = new Set();
832
- names.add("model");
833
- for (const decorator of classDecorators || []) {
834
- names.add(decorator.name);
835
- }
836
- for (const property of properties || []) {
837
- for (const decorator of property.decorators || []) {
838
- names.add(decorator.name);
839
- }
840
- }
841
- return names;
842
- }
843
- function ensureImport(content, importsFrom, decorators) {
844
- /* istanbul ignore next */
845
- if (!decorators.size)
846
- return content;
847
- const importRegex = new RegExp(`import\\s+\\{([^}]+)\\}\\s+from\\s+["']${escapeRegExp(importsFrom)}["'];`);
848
- const match = content.match(importRegex);
849
- const sorted = Array.from(decorators).sort();
850
- if (match) {
851
- const existing = match[1]
852
- .split(",")
853
- .map((name) => name.trim())
854
- .filter(Boolean);
855
- const merged = Array.from(new Set([...existing, ...sorted])).sort();
856
- return content.replace(importRegex, `import { ${merged.join(", ")} } from "${importsFrom}";`);
857
- }
858
- const importLine = `import { ${sorted.join(", ")} } from "${importsFrom}";`;
859
- return `${importLine}\n\n${content}`;
860
- }
861
- function addPropertyBlock(property) {
862
- const decorators = (property.decorators || [])
863
- .map(formatDecorator)
864
- .join("\n ");
865
- const decoratorBlock = decorators ? ` ${decorators}\n` : "";
866
- return `${decoratorBlock} ${property.name}: ${property.type};`;
867
- }
868
- function removePropertyBlock(content, propertyName) {
869
- const lines = content.split(/\r?\n/);
870
- const result = [];
871
- for (let i = 0; i < lines.length; i++) {
872
- const line = lines[i];
873
- if (line.trim().startsWith(`@`) &&
874
- lines[i + 1]?.includes(`${propertyName}:`)) {
875
- continue;
876
- }
877
- if (line.includes(`${propertyName}:`)) {
878
- // skip this line and any trailing blank line
879
- continue;
880
- }
881
- result.push(line);
882
- }
883
- return result.join("\n");
884
- }
885
- function insertDecorator(content, decorator, target) {
886
- const decoratorLine = formatDecorator(decorator);
887
- if (target.kind === "class") {
888
- const classRegex = /(export\s+class\s+[^\s{]+\s*\{)/;
889
- if (content.includes(decoratorLine))
890
- return content;
891
- return content.replace(classRegex, `${decoratorLine}\n$1`);
892
- }
893
- if (!target.name)
894
- return content;
895
- const propertyRegex = new RegExp(`(^\\s*)(?:@.*\\n\\1)*${escapeRegExp(target.name)}:`, "m");
896
- const match = propertyRegex.exec(content);
897
- if (!match)
898
- return content;
899
- const indent = match[1] || " ";
900
- if (content.includes(`${indent}${decoratorLine}`))
901
- return content;
902
- return (content.slice(0, match.index) +
903
- `${indent}${decoratorLine}\n` +
904
- content.slice(match.index));
905
- }
906
- function removeDecorator(content, decoratorName, target) {
907
- const decoratorRegex = new RegExp(`^\\s*@${escapeRegExp(decoratorName)}\\([^)]*\\)`, "m");
908
- if (target.kind === "class") {
909
- return content.replace(decoratorRegex, "");
910
- }
911
- if (target.name) {
912
- const pattern = new RegExp(`(^\\s*@${escapeRegExp(decoratorName)}\\([^)]*\\)\\s*$\\n)(?=\\s*${escapeRegExp(target.name)}:)`, "m");
913
- return content.replace(pattern, "");
914
- }
915
- return content;
916
- }
917
- function writeIfChanged(filePath, content) {
918
- ensureDirectory(filePath);
919
- fs.writeFileSync(filePath, content);
920
- }
921
- const decoratorTools = {
922
- createOrUpdateModelTool: {
923
- name: "create-or-update-model",
924
- description: "Create or update a validation-ready model class",
925
- execute: async (args) => {
926
- if (!args.overwrite && fs.existsSync(args.filePath)) {
927
- throw new Error(`File already exists at ${args.filePath}`);
928
- }
929
- const decorators = collectDecoratorNames(args.classDecorators, args.properties);
930
- let content = `@model()`;
931
- for (const decorator of args.classDecorators || []) {
932
- content += `\n${formatDecorator(decorator)}`;
933
- }
934
- const properties = (args.properties || [])
935
- .map(addPropertyBlock)
936
- .join("\n\n");
937
- content += `\nexport class ${args.className} {\n${properties ? `${properties}\n` : ""}}\n`;
938
- content = ensureImport(content, args.importsFrom, decorators);
939
- writeIfChanged(args.filePath, content);
940
- return { filePath: args.filePath };
941
- },
942
- },
943
- addAttributeTool: {
944
- name: "add-attribute",
945
- description: "Add a decorated attribute to an existing model",
946
- execute: async (args) => {
947
- if (!fs.existsSync(args.filePath)) {
948
- throw new Error(`Model file not found at ${args.filePath}`);
949
- }
950
- let content = fs.readFileSync(args.filePath, "utf8");
951
- if (content.includes(`${args.attribute.name}:`)) {
952
- return { filePath: args.filePath };
953
- }
954
- const decorators = collectDecoratorNames(undefined, [args.attribute]);
955
- content = ensureImport(content, args.importsFrom, decorators);
956
- const insertionPoint = content.lastIndexOf("}");
957
- const block = addPropertyBlock(args.attribute);
958
- const before = content.slice(0, insertionPoint).replace(/\s*$/, "");
959
- const after = content.slice(insertionPoint);
960
- const updated = `${before}\n${block}\n${after}`;
961
- writeIfChanged(args.filePath, updated);
962
- return { filePath: args.filePath };
963
- },
964
- },
965
- removeAttributeTool: {
966
- name: "remove-attribute",
967
- description: "Remove an attribute from a model class",
968
- execute: async (args) => {
969
- if (!fs.existsSync(args.filePath))
970
- return { filePath: args.filePath };
971
- const content = fs.readFileSync(args.filePath, "utf8");
972
- const updated = removePropertyBlock(content, args.attributeName);
973
- writeIfChanged(args.filePath, updated);
974
- return { filePath: args.filePath };
975
- },
976
- },
977
- applyDecoratorTool: {
978
- name: "apply-decorator",
979
- description: "Apply a decorator to a class or property",
980
- execute: async (args) => {
981
- if (!fs.existsSync(args.filePath)) {
982
- throw new Error(`Model file not found at ${args.filePath}`);
983
- }
984
- let content = fs.readFileSync(args.filePath, "utf8");
985
- const decorators = new Set([args.decorator.name]);
986
- content = ensureImport(content, args.importsFrom, decorators);
987
- content = insertDecorator(content, args.decorator, args.target);
988
- writeIfChanged(args.filePath, content);
989
- return { filePath: args.filePath };
990
- },
991
- },
992
- removeDecoratorTool: {
993
- name: "remove-decorator",
994
- description: "Remove a decorator from a class or property",
995
- execute: async (args) => {
996
- if (!fs.existsSync(args.filePath))
997
- return { filePath: args.filePath };
998
- let content = fs.readFileSync(args.filePath, "utf8");
999
- content = removeDecorator(content, args.decoratorName, args.target);
1000
- writeIfChanged(args.filePath, content);
1001
- return { filePath: args.filePath };
1002
- },
1003
- },
1004
- scaffoldValidatorTool: {
1005
- name: "scaffold-validator",
1006
- description: "Scaffold a validator class and optional decorator",
1007
- execute: async (args) => {
1008
- const classFile = path.join(args.validatorsDir, `${args.name}.ts`);
1009
- ensureDirectory(classFile);
1010
- const classContent = `export class ${args.name} {\n validate(value: unknown): boolean {\n return value !== undefined;\n }\n}\n`;
1011
- fs.writeFileSync(classFile, classContent);
1012
- let decoratorFile;
1013
- if (args.decoratorDir) {
1014
- decoratorFile = path.join(args.decoratorDir, `${args.name}Decorator.ts`);
1015
- ensureDirectory(decoratorFile);
1016
- fs.writeFileSync(decoratorFile, `export function ${args.name}Decorator() {\n return () => void 0;\n}\n`);
1017
- }
1018
- return { classFile, decoratorFile };
1019
- },
1020
- },
1021
- scaffoldSerializerTool: {
1022
- name: "scaffold-serializer",
1023
- description: "Scaffold a serializer class and optional registry",
1024
- execute: async (args) => {
1025
- const classFile = path.join(args.dir, `${args.name}.ts`);
1026
- ensureDirectory(classFile);
1027
- fs.writeFileSync(classFile, `export class ${args.name} {\n serialize(value: unknown): string {\n return JSON.stringify(value);\n }\n}\n`);
1028
- let registerFile;
1029
- if (args.registerDir) {
1030
- registerFile = path.join(args.registerDir, `${args.name}Register.ts`);
1031
- ensureDirectory(registerFile);
1032
- fs.writeFileSync(registerFile, `export function register${args.name}() {\n return ${args.setDefault ? "'default'" : "'optional'"};\n}\n`);
1033
- }
1034
- return { classFile, registerFile };
1035
- },
1036
- },
1037
- scaffoldHashingTool: {
1038
- name: "scaffold-hashing",
1039
- description: "Scaffold a hashing function and optional registry",
1040
- execute: async (args) => {
1041
- const functionFile = path.join(args.dir, `${args.name}.ts`);
1042
- ensureDirectory(functionFile);
1043
- fs.writeFileSync(functionFile, `export function ${args.name}(value: string): string {\n return value.split('').reverse().join('');\n}\n`);
1044
- let registerFile;
1045
- if (args.registerDir) {
1046
- registerFile = path.join(args.registerDir, `${args.name}Register.ts`);
1047
- ensureDirectory(registerFile);
1048
- fs.writeFileSync(registerFile, `export function register${args.name}() {\n return ${args.setDefault ? "'default'" : "'optional'"};\n}\n`);
1049
- }
1050
- return { functionFile, registerFile };
1051
- },
1052
- },
1053
- };
1054
-
1055
- function buildAnalyzeRepositoryTool() {
1056
- return {
1057
- name: "analyze-repository",
1058
- description: "Analyze a local repository's source, tests, and docs to extract exported APIs, decorators, and test mentions.",
1059
- parameters: analyzeRepoSchema,
1060
- execute: async (input) => {
1061
- let repoRoot = path.resolve(process.cwd(), input.repoPath);
1062
- if (!fs.existsSync(repoRoot)) {
1063
- // try resolving from monorepo root (parent of current cwd)
1064
- const alt = path.resolve(process.cwd(), "..", input.repoPath);
1065
- if (fs.existsSync(alt))
1066
- repoRoot = alt;
1067
- }
1068
- if (!fs.existsSync(repoRoot)) {
1069
- // if input was absolute and still not found, try ../<basename>
1070
- const alt2 = path.resolve(process.cwd(), "..", path.basename(input.repoPath));
1071
- if (fs.existsSync(alt2))
1072
- repoRoot = alt2;
1073
- }
1074
- if (!fs.existsSync(repoRoot))
1075
- throw new Error(`Repository not found at ${repoRoot}`);
1076
- const result = analyzeRepo(repoRoot);
1077
- return {
1078
- content: [{ type: "text", text: JSON.stringify(result, null, 2) }],
1079
- };
1080
- },
1081
- };
1082
- }
1083
- function buildEnumerateCapabilitiesTool() {
1084
- return {
1085
- name: "enumerate-capabilities",
1086
- description: "Enumerate developer-facing capabilities of the given repository, inferred from code, tests, and docs.",
1087
- parameters: enumerateCapabilitiesSchema,
1088
- execute: async (input) => {
1089
- let repoRoot = path.resolve(process.cwd(), input.repoPath);
1090
- if (!fs.existsSync(repoRoot)) {
1091
- const alt = path.resolve(process.cwd(), "..", input.repoPath);
1092
- if (fs.existsSync(alt))
1093
- repoRoot = alt;
1094
- }
1095
- if (!fs.existsSync(repoRoot)) {
1096
- const alt2 = path.resolve(process.cwd(), "..", path.basename(input.repoPath));
1097
- if (fs.existsSync(alt2))
1098
- repoRoot = alt2;
1099
- }
1100
- if (!fs.existsSync(repoRoot))
1101
- throw new Error(`Repository not found at ${repoRoot}`);
1102
- const analysis = analyzeRepo(repoRoot);
1103
- const capabilities = deriveCapabilities(analysis);
1104
- return {
1105
- content: [
1106
- {
1107
- type: "text",
1108
- text: JSON.stringify({
1109
- capabilities,
1110
- analysisSummary: {
1111
- files: analysis.files.length,
1112
- testFiles: analysis.testFiles.length,
1113
- readme: analysis.readme?.title,
1114
- },
1115
- }, null, 2),
1116
- },
1117
- ],
1118
- };
1119
- },
1120
- };
1121
- }
1122
- function buildPlanFeatureTool() {
1123
- return {
1124
- name: "plan-feature-implementation",
1125
- description: "Given a feature request, select appropriate MCP tools (including existing and new ones) and produce an execution plan.",
1126
- parameters: planFeatureSchema,
1127
- execute: async (input) => {
1128
- const steps = [];
1129
- let i = 1;
1130
- steps.push({
1131
- step: i++,
1132
- action: "Analyze repository to enumerate APIs and decorators",
1133
- tool: "analyze-repository",
1134
- arguments: { repoPath: input.repoPath },
1135
- rationale: "Understand available building blocks.",
1136
- });
1137
- steps.push({
1138
- step: i++,
1139
- action: "List capabilities expected for developers",
1140
- tool: "enumerate-capabilities",
1141
- arguments: { repoPath: input.repoPath },
1142
- rationale: "Align the plan with supported capabilities.",
1143
- });
1144
- // Suggest existing generic tools from mcp-module
1145
- steps.push({
1146
- step: i++,
1147
- action: "Select documentation prompt and gather relevant source file(s)",
1148
- tool: "document-code",
1149
- arguments: { filePath: "<target-file>" },
1150
- rationale: "Provide context and instructions for changes.",
1151
- });
1152
- steps.push({
1153
- step: i++,
1154
- action: "Apply code changes using unified diff patch",
1155
- tool: "apply-code-change",
1156
- arguments: {
1157
- filePath: "<target-file>",
1158
- patch: "<unified-diff>",
1159
- dryRun: true,
1160
- },
1161
- rationale: "Validate changes safely before committing.",
1162
- });
1163
- steps.push({
1164
- step: i++,
1165
- action: "Commit code changes",
1166
- tool: "apply-code-change",
1167
- arguments: {
1168
- filePath: "<target-file>",
1169
- patch: "<unified-diff>",
1170
- dryRun: false,
1171
- },
1172
- rationale: "Persist the update.",
1173
- });
1174
- // If decoration-related terms present, suggest decorator tools
1175
- if (/decorat|flavour|override|extend|builder/i.test(input.feature)) {
1176
- steps.unshift({
1177
- step: 0,
1178
- action: "Use decorator tooling to insert/remove/modify decorators",
1179
- tool: "decorator-tools",
1180
- arguments: { action: "help" },
1181
- rationale: "Leverage specialized utilities for decoration patterns.",
1182
- });
1183
- steps.forEach((s, idx) => (s.step = idx + 1));
1184
- }
1185
- return {
1186
- content: [
1187
- {
1188
- type: "text",
1189
- text: JSON.stringify({
1190
- plan: steps,
1191
- notes: "Replace placeholder arguments like <target-file> and <unified-diff> based on the analysis output.",
1192
- }, null, 2),
1193
- },
1194
- ],
1195
- };
1196
- },
1197
- };
1198
- }
1199
- const documentCodeTool = {
1200
- annotations: {
1201
- idempotentHint: true,
1202
- openWorldHint: false,
1203
- readOnlyHint: true,
1204
- title: "Document Source File",
1205
- },
1206
- description: "Generate documentation guidance for a file by combining repository prompts with the target source code.",
1207
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
1208
- execute: async (input, _context) => {
1209
- const args = documentCodeSchema.parse(input);
1210
- const root = getWorkspaceRoot();
1211
- let filePath;
1212
- try {
1213
- filePath = resolveInWorkspace(root, args.filePath);
1214
- }
1215
- catch (error) {
1216
- if (error instanceof WorkspaceError) {
1217
- return throwUserError(error.message);
1218
- }
1219
- /* istanbul ignore next */
1220
- throw error;
1221
- }
1222
- if (!fs.existsSync(filePath)) {
1223
- return throwUserError(`Cannot document missing file at ${args.filePath}`);
1224
- }
1225
- const fileContent = fs.readFileSync(filePath, {
1226
- encoding: args.encoding,
1227
- });
1228
- // dynamically import prompt helpers
1229
- const promptMod = await Promise.resolve().then(function () { return prompts$1; });
1230
- const { discoverDocPrompts, selectPrompt, DEFAULT_PROMPT_NAME, buildDocumentationPayload, } = promptMod;
1231
- const prompts = discoverDocPrompts(root);
1232
- if (!prompts.length) {
1233
- return throwUserError("No documentation prompts found under .code/prompts or .codex/prompts");
1234
- }
1235
- const prompt = selectPrompt(prompts, args.promptName ?? DEFAULT_PROMPT_NAME);
1236
- return buildDocumentationPayload({
1237
- filePath: args.filePath,
1238
- fileContent,
1239
- prompt,
1240
- includeCode: args.includeCode,
1241
- includePrompt: args.includePrompt,
1242
- includeMetadata: args.includeMetadata,
1243
- additionalContext: args.additionalContext,
1244
- });
1245
- },
1246
- name: "document-code",
1247
- parameters: documentCodeSchema,
1248
- };
1249
- const applyCodeChangeTool = {
1250
- annotations: {
1251
- destructiveHint: true,
1252
- idempotentHint: false,
1253
- openWorldHint: false,
1254
- readOnlyHint: false,
1255
- title: "Apply Code Patch",
1256
- },
1257
- description: "Apply a unified diff patch to a workspace file with optional dry-run validation and diff preview.",
1258
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
1259
- execute: async (input, _context) => {
1260
- const args = codeChangeSchema.parse(input);
1261
- const root = getWorkspaceRoot();
1262
- let filePath;
1263
- try {
1264
- filePath = resolveInWorkspace(root, args.filePath);
1265
- }
1266
- catch (error) {
1267
- if (error instanceof WorkspaceError) {
1268
- return throwUserError(error.message);
1269
- }
1270
- throw error;
1271
- }
1272
- const original = fs.existsSync(filePath)
1273
- ? fs.readFileSync(filePath, args.encoding)
1274
- : "";
1275
- let patched;
1276
- try {
1277
- patched = diff.applyPatch(original, args.patch);
1278
- }
1279
- catch (error) {
1280
- return throwUserError(`Failed to apply provided patch to ${args.filePath}: ${error instanceof Error ? error.message : error}`);
1281
- }
1282
- /* istanbul ignore next */
1283
- if (patched === false) {
1284
- return throwUserError(`Failed to apply provided patch to ${args.filePath}`);
1285
- }
1286
- if (!args.dryRun) {
1287
- fs.mkdirSync(path.dirname(filePath), { recursive: true });
1288
- fs.writeFileSync(filePath, patched, {
1289
- encoding: args.encoding,
1290
- });
1291
- }
1292
- if (!args.showDiff) {
1293
- return `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`;
1294
- }
1295
- const preview = diff.createTwoFilesPatch(args.filePath, args.filePath, original, patched, undefined, undefined, { context: args.diffContext });
1296
- return {
1297
- content: [
1298
- {
1299
- type: "text",
1300
- text: `Patch ${args.dryRun ? "validated" : "applied"} for ${args.filePath}`,
1301
- },
1302
- {
1303
- type: "text",
1304
- text: ["```diff", preview.trim(), "```"].join("\n"),
1305
- },
1306
- ],
1307
- };
1308
- },
1309
- name: "apply-code-change",
1310
- parameters: codeChangeSchema,
1311
- };
1312
- const analyticTools = [
1313
- buildAnalyzeRepositoryTool(),
1314
- buildEnumerateCapabilitiesTool(),
1315
- buildPlanFeatureTool(),
1316
- ];
1317
- const toolList$1 = [
1318
- ...analyticTools,
1319
- documentCodeTool,
1320
- applyCodeChangeTool,
1321
- ];
1322
-
1323
- const codexToolList = [
1324
- documentObjectTool,
1325
- coverageEnforcerTool,
1326
- readmeImprovementTool,
1327
- ];
1328
- const moduleToolList = moduleRegistry
1329
- .listTools()
1330
- .map((asset) => asset.tool);
1331
- const toolList = [...toolList$1, ...codexToolList, ...moduleToolList];
1332
- const [analyzeRepositoryTool, enumerateCapabilitiesTool, planFeatureTool, documentCodeToolRef, applyCodeChangeToolRef,] = toolList$1;
1333
- const tools = {
1334
- analyzeRepositoryTool,
1335
- enumerateCapabilitiesTool,
1336
- planFeatureTool,
1337
- documentCodeTool: documentCodeToolRef,
1338
- applyCodeChangeTool: applyCodeChangeToolRef,
1339
- documentObjectTool,
1340
- coverageEnforcerTool,
1341
- readmeImprovementTool,
1342
- ...decoratorTools,
1343
- };
1344
-
1345
- function toResource(asset) {
1346
- return {
1347
- name: asset.id,
1348
- uri: asset.uri,
1349
- description: asset.description ?? asset.title,
1350
- mimeType: asset.mimeType,
1351
- load: async () => {
1352
- const res = await asset.load();
1353
- // asset.load may return a ContentResult or a Promise of ContentResult; ensure we return ResourceResult-like object
1354
- if (res?.content) {
1355
- const cr = res;
1356
- // If ContentResult, convert to simple text result expected by Resource.load consumers
1357
- return {
1358
- text: Array.isArray(cr.content)
1359
- ? cr.content.map((c) => c.text).join("\n")
1360
- : String(cr),
1361
- };
1362
- }
1363
- // fallback for objects with text
1364
- return res;
1365
- },
1366
- };
1367
- }
1368
- function buildModuleResources() {
1369
- return moduleRegistry.listResources().map(toResource);
1370
- }
1371
- const resources = [
1372
- {
1373
- name: "codex-prompt-index",
1374
- uri: "codex://prompts/index",
1375
- description: "Enumerate available .codex prompt files with titles and descriptions.",
1376
- mimeType: "application/json",
1377
- load: async () => {
1378
- const root = getWorkspaceRoot();
1379
- const prompts = discoverDocPrompts(root).map((prompt) => ({
1380
- name: prompt.name,
1381
- title: prompt.title,
1382
- description: prompt.description,
1383
- path: prompt.absolutePath,
1384
- }));
1385
- return {
1386
- text: JSON.stringify({ prompts }, null, 2),
1387
- mimeType: "application/json",
1388
- };
1389
- },
1390
- },
1391
- {
1392
- name: "codex-object-prompts",
1393
- uri: "codex://prompts/objects",
1394
- description: "Provides the resolved prompt content for each documented object workflow.",
1395
- mimeType: "application/json",
1396
- load: async () => {
1397
- const entries = await Promise.all(buildObjectPrompts().map(async (prompt) => ({
1398
- name: prompt.name,
1399
- description: prompt.description,
1400
- content: await prompt.load({}),
1401
- })));
1402
- return {
1403
- text: JSON.stringify({ prompts: entries }, null, 2),
1404
- mimeType: "application/json",
1405
- };
1406
- },
1407
- },
1408
- ...buildModuleResources(),
1409
- ];
1410
-
1411
- const codexPromptTemplates = [];
1412
- function buildCodexPromptTemplates() {
1413
- const root = getWorkspaceRoot();
1414
- const templates = [
1415
- {
1416
- name: "codex-prompt",
1417
- description: "Load a .codex prompt file by name (without extension) as markdown.",
1418
- uriTemplate: "codex-prompt://{name}",
1419
- mimeType: "text/markdown",
1420
- arguments: [
1421
- {
1422
- name: "name",
1423
- description: "Name of the prompt file inside .codex/prompts (without .md).",
1424
- required: true,
1425
- },
1426
- ],
1427
- load: async ({ name }) => {
1428
- const promptPath = resolveInWorkspace(root, path.join(".codex", "prompts", `${name}.md`));
1429
- if (!fs.existsSync(promptPath)) {
1430
- throw new Error(`Prompt .codex/prompts/${name}.md not found`);
1431
- }
1432
- const text = fs.readFileSync(promptPath, "utf8");
1433
- return { text, uri: `codex-prompt:///${name}` };
1434
- },
1435
- },
1436
- ];
1437
- codexPromptTemplates.splice(0, codexPromptTemplates.length, ...templates);
1438
- return codexPromptTemplates;
1439
- }
1440
-
1441
- const decorationResourceTemplates = [];
1442
- function makeLoader(type) {
1443
- return async ({ path: relative }) => {
1444
- const root = getWorkspaceRoot();
1445
- const target = path.join(type, relative);
1446
- const text = await readWorkspaceFile(root, target);
1447
- return { text };
1448
- };
1449
- }
1450
- function buildDecorationResourceTemplates() {
1451
- const templates = [
1452
- {
1453
- name: "read-code-from-source",
1454
- description: "Read a file from the <base_path>/src tree by relative path.",
1455
- mimeType: "text/plain",
1456
- uriTemplate: "from-source://src/{path}",
1457
- arguments: [
1458
- {
1459
- name: "path",
1460
- description: "Path under <base_path>/src to load, e.g. 'decoration/types.ts'",
1461
- required: true,
1462
- },
1463
- ],
1464
- load: makeLoader("src"),
1465
- },
1466
- {
1467
- name: "read-test-from-source",
1468
- description: "Read a file from the <base_path>/tests tree by relative path.",
1469
- mimeType: "text/plain",
1470
- uriTemplate: "from-source://tests/{path}",
1471
- arguments: [
1472
- {
1473
- name: "path",
1474
- description: "Path under <base_path>/tests to load, e.g. 'decoration/tests/types.test.ts'",
1475
- required: true,
1476
- },
1477
- ],
1478
- load: makeLoader("tests"),
1479
- },
1480
- {
1481
- name: "read-doc-from-source",
1482
- description: "Read a file from the <base_path>/workdocs tree by relative path.",
1483
- mimeType: "text/plain",
1484
- uriTemplate: "from-source://workdocs/{path}",
1485
- arguments: [
1486
- {
1487
- name: "path",
1488
- description: "Path under <base_path>/workdocs to load, e.g. 'decoration/workdocs/tutorials/for-developers.md'",
1489
- required: true,
1490
- },
1491
- ],
1492
- load: makeLoader("workdocs"),
1493
- },
1494
- ];
1495
- decorationResourceTemplates.splice(0, decorationResourceTemplates.length, ...templates);
1496
- return decorationResourceTemplates;
1497
- }
1498
-
1499
- const workspaceResourceTemplates = [];
1500
- function buildWorkspaceResourceTemplates() {
1501
- const root = getWorkspaceRoot();
1502
- const sharedArguments = [
1503
- {
1504
- name: "path",
1505
- description: "Path relative to the workspace root",
1506
- required: true,
1507
- },
1508
- ];
1509
- const templates = [
1510
- {
1511
- name: "vscode-workspace-file",
1512
- description: "Expose workspace files to Visual Studio Code via vscode:// URIs",
1513
- uriTemplate: "vscode://workspace/{path}",
1514
- mimeType: "text/plain",
1515
- arguments: sharedArguments,
1516
- load: async (args) => {
1517
- try {
1518
- const text = await readWorkspaceFile(root, args.path);
1519
- return { text: String(text) };
1520
- }
1521
- catch (err) {
1522
- // propagate as-is for tests to assert errors
1523
- throw err;
1524
- }
1525
- },
1526
- },
1527
- {
1528
- name: "cursor-workspace-file",
1529
- description: "Expose workspace files to Cursor via cursor:// URIs",
1530
- uriTemplate: "cursor://workspace/{path}",
1531
- mimeType: "text/plain",
1532
- arguments: sharedArguments,
1533
- load: async (args) => {
1534
- try {
1535
- const text = await readWorkspaceFile(root, args.path);
1536
- return { text: String(text) };
1537
- }
1538
- catch (err) {
1539
- throw err;
1540
- }
1541
- },
1542
- },
1543
- {
1544
- name: "copilot-workspace-file",
1545
- description: "Expose workspace files to GitHub Copilot via copilot:// URIs",
1546
- uriTemplate: "copilot://workspace/{path}",
1547
- mimeType: "text/plain",
1548
- arguments: sharedArguments,
1549
- load: async (args) => {
1550
- try {
1551
- const text = await readWorkspaceFile(root, args.path);
1552
- return { text: String(text) };
1553
- }
1554
- catch (err) {
1555
- throw err;
1556
- }
1557
- },
1558
- },
1559
- ];
1560
- workspaceResourceTemplates.splice(0, workspaceResourceTemplates.length, ...templates);
1561
- return workspaceResourceTemplates;
1562
- }
1563
-
1564
- function buildResourceTemplates() {
1565
- const moduleTemplates = moduleRegistry.listTemplates().map((template) => ({
1566
- name: template.id,
1567
- description: template.description ?? template.title,
1568
- mimeType: "text/markdown",
1569
- uriTemplate: `module-template://${template.id}`,
1570
- arguments: (template.placeholders ?? []).map((name) => ({
1571
- name,
1572
- description: `Value for ${name}`,
1573
- required: true,
1574
- })),
1575
- load: async () => ({
1576
- text: typeof template.content === "string"
1577
- ? template.content
1578
- : `# ${template.description ?? template.title ?? template.id}\n\nNo template content available for ${template.id}`,
1579
- }),
1580
- }));
1581
- const all = [
1582
- ...buildWorkspaceResourceTemplates(),
1583
- ...buildCodexPromptTemplates(),
1584
- ...buildDecorationResourceTemplates(),
1585
- ...moduleTemplates,
1586
- ];
1587
- // Normalise all loaders to always return { text: string }
1588
- function normaliseResult(res) {
1589
- if (res == null)
1590
- return { text: "" };
1591
- if (typeof res === "string")
1592
- return { text: res };
1593
- if (typeof res.text === "string")
1594
- return res;
1595
- // handle legacy ContentResult shapes with content or content array
1596
- if (Array.isArray(res.content)) {
1597
- const parts = res.content
1598
- .map((c) => (c && typeof c.text === "string" ? c.text : String(c)))
1599
- .join("\n");
1600
- return { text: parts };
1601
- }
1602
- if (res.content && typeof res.content.text === "string") {
1603
- return { text: res.content.text };
1604
- }
1605
- // fallback: stringify
1606
- try {
1607
- return { text: JSON.stringify(res) };
1608
- }
1609
- catch {
1610
- return { text: String(res) };
1611
- }
1612
- }
1613
- return all.map((t) => ({
1614
- ...t,
1615
- load: async (args) => {
1616
- const raw = await t.load(args);
1617
- return normaliseResult(raw);
1618
- },
1619
- }));
1620
- }
1621
- const templateList = buildResourceTemplates();
1622
-
1623
- /**
1624
- * @const VERSION
1625
- * @name VERSION
1626
- * @description Represents the current version of the ts-workspace module.
1627
- * @summary The actual version number is replaced during the build process.
1628
- * @type {string}
1629
- */
1630
- const VERSION$1 = "0.4.1";
1631
- const PACKAGE_NAME$1 = "##PACKAGE_NAME##";
1632
- try {
1633
- decoration.Metadata.registerLibrary(PACKAGE_NAME$1, VERSION$1);
1634
- }
1635
- catch (error) {
1636
- if (error instanceof Error && error.message.includes("already")) ;
1637
- else {
1638
- throw error;
1639
- }
1640
- }
1641
-
1642
- function enrich(mcp) {
1643
- const promptEntries = loadPrompts();
1644
- for (const prompt of promptEntries) {
1645
- mcp.addPrompt(prompt);
1646
- }
1647
- for (const tool of toolList) {
1648
- mcp.addTool(tool);
1649
- }
1650
- const templates = buildResourceTemplates();
1651
- for (const template of templates) {
1652
- mcp.addResourceTemplate(template);
1653
- }
1654
- for (const resource of resources) {
1655
- const addResource = mcp.addResource;
1656
- if (typeof addResource === "function") {
1657
- addResource.call(mcp, resource);
1658
- }
1659
- }
1660
- return mcp;
1661
- }
1662
- const PACKAGE_NAME = PACKAGE_NAME$1;
1663
- const VERSION = VERSION$1;
1664
-
1665
- // New: validation entrypoint for module structure
1666
- const REQUIRED_SUBFOLDERS = ["prompts", "resources", "templates", "tools"];
1667
- function findModuleDirs(repoRoot) {
1668
- const modulesPath = path.resolve(repoRoot, "src", "modules");
1669
- if (!fs.existsSync(modulesPath) || !fs.statSync(modulesPath).isDirectory()) {
1670
- return [];
1671
- }
1672
- return fs
1673
- .readdirSync(modulesPath, { withFileTypes: true })
1674
- .filter((d) => d.isDirectory())
1675
- .map((d) => path.join(modulesPath, d.name));
1676
- }
1677
- function hasIndexExport(folderPath) {
1678
- const candidates = [
1679
- "index.ts",
1680
- "index.tsx",
1681
- "index.js",
1682
- "index.cjs",
1683
- "index.mjs",
1684
- ];
1685
- for (const c of candidates) {
1686
- if (fs.existsSync(path.join(folderPath, c)))
1687
- return true;
1688
- }
1689
- return false;
1690
- }
1691
- function validateModules(repoRoot) {
1692
- const dirs = findModuleDirs(repoRoot);
1693
- const issues = [];
1694
- for (const moduleDir of dirs) {
1695
- const moduleName = path.basename(moduleDir);
1696
- for (const sub of REQUIRED_SUBFOLDERS) {
1697
- const subPath = path.join(moduleDir, sub);
1698
- if (!fs.existsSync(subPath) || !fs.statSync(subPath).isDirectory()) {
1699
- issues.push({
1700
- module: moduleName,
1701
- path: subPath,
1702
- type: "missing-folder",
1703
- detail: `Required folder '${sub}' is missing in module '${moduleName}'`,
1704
- });
1705
- continue;
1706
- }
1707
- // If folder exists, check for index export
1708
- if (!hasIndexExport(subPath)) {
1709
- issues.push({
1710
- module: moduleName,
1711
- path: subPath,
1712
- type: "missing-export",
1713
- detail: `No index export found in '${subPath}'. Expected one of index.ts, index.js, etc.`,
1714
- });
1715
- continue;
1716
- }
1717
- // Optionally inspect the index file to see if it exports a list (lightweight check)
1718
- try {
1719
- const indexFile = candidatesFindingIndex(subPath);
1720
- if (indexFile) {
1721
- const content = fs.readFileSync(indexFile, "utf8");
1722
- // crude heuristics: look for `export const name = [` or `export const name: Type[] = [`,
1723
- // or any named export like `export { something }` which implies exports exist.
1724
- const exportListPattern = /export\s+(const|let|var)\s+[\w$]+(?:\s*:\s*[^=]+)?\s*=\s*\[/;
1725
- if (!exportListPattern.test(content) &&
1726
- !/export\s+\{/.test(content)) {
1727
- issues.push({
1728
- module: moduleName,
1729
- path: indexFile,
1730
- type: "empty-list",
1731
- detail: `Index file does not appear to export a list of assets: ${path.basename(indexFile)}`,
1732
- });
1733
- }
1734
- }
1735
- }
1736
- catch (err) {
1737
- issues.push({
1738
- module: moduleName,
1739
- path: subPath,
1740
- type: "other",
1741
- detail: `Error reading index file: ${err.message}`,
1742
- });
1743
- }
1744
- }
1745
- }
1746
- return {
1747
- ok: issues.length === 0,
1748
- modulesChecked: dirs.length,
1749
- issues,
1750
- };
1751
- }
1752
- function candidatesFindingIndex(folderPath) {
1753
- const candidates = [
1754
- "index.ts",
1755
- "index.tsx",
1756
- "index.js",
1757
- "index.cjs",
1758
- "index.mjs",
1759
- ];
1760
- for (const c of candidates) {
1761
- const full = path.join(folderPath, c);
1762
- if (fs.existsSync(full))
1763
- return full;
1764
- }
1765
- return undefined;
1766
- }
1767
- // CLI helper
1768
- if (require.main === module) {
1769
- const repoRoot = process.cwd();
1770
- const report = validateModules(repoRoot);
1771
- if (!report.ok) {
1772
- console.error("Module validation failed:\n", JSON.stringify(report, null, 2));
1773
- process.exit(2);
1774
- }
1775
- console.log("Module validation passed");
1776
- process.exit(0);
1777
- }
1778
-
1779
- // Aggregator: import module index files and merge exported arrays with provenance + duplicate detection
1780
- const SUBFOLDERS = ["prompts", "resources", "templates", "tools"];
1781
- const INDEX_CANDIDATES = [
1782
- "index.ts",
1783
- "index.tsx",
1784
- "index.js",
1785
- "index.cjs",
1786
- "index.mjs",
1787
- ];
1788
- function findIndexFile(folder) {
1789
- for (const c of INDEX_CANDIDATES) {
1790
- const f = path.join(folder, c);
1791
- if (fs.existsSync(f))
1792
- return f;
1793
- }
1794
- return undefined;
1795
- }
1796
- function makeKeyForItem(item) {
1797
- if (!item)
1798
- return JSON.stringify(item);
1799
- if (typeof item === "string")
1800
- return `str:${item}`;
1801
- if (typeof item === "number")
1802
- return `num:${item}`;
1803
- if (item.id)
1804
- return `id:${item.id}`;
1805
- if (item.name)
1806
- return `name:${item.name}`;
1807
- // fallback to stable string
1808
- try {
1809
- return `obj:${JSON.stringify(item)}`;
1810
- }
1811
- catch (e) {
1812
- return `obj:${String(item)}`;
1813
- }
1814
- }
1815
- async function loadArrayFromIndex(filePath) {
1816
- // Prefer a fast, static parse of the first array literal found in the file.
1817
- try {
1818
- const content = fs.readFileSync(filePath, "utf8");
1819
- const start = content.indexOf("[");
1820
- if (start !== -1) {
1821
- let depth = 0;
1822
- let end = -1;
1823
- for (let i = start; i < content.length; i++) {
1824
- const ch = content[i];
1825
- if (ch === "[")
1826
- depth++;
1827
- else if (ch === "]") {
1828
- depth--;
1829
- if (depth === 0) {
1830
- end = i;
1831
- break;
1832
- }
1833
- }
1834
- }
1835
- if (end !== -1) {
1836
- const arrText = content.slice(start, end + 1);
1837
- try {
1838
- return JSON.parse(arrText);
1839
- }
1840
- catch (e) {
1841
- // Normalize TS object literals to JSON:
1842
- // - convert single quotes to double quotes
1843
- // - quote unquoted object keys
1844
- // - strip trailing commas
1845
- const normalized = arrText
1846
- // unify quotes in string literals
1847
- .replace(/'(?:\\'|[^'])*'/g, (m) => m.replace(/'/g, '"'))
1848
- // quote unquoted keys after { or ,
1849
- .replace(/([\{,]\s*)([A-Za-z_$][\w$]*)(\s*:)/g, '$1"$2"$3')
1850
- // remove trailing commas before ] or }
1851
- .replace(/,(\s*[\}\]])/g, '$1');
1852
- try {
1853
- return JSON.parse(normalized);
1854
- }
1855
- catch (e2) {
1856
- // fallthrough to import attempt below
1857
- }
1858
- }
1859
- }
1860
- }
1861
- }
1862
- catch (e) {
1863
- // ignore static parse errors and fall back to import
1864
- }
1865
- try {
1866
- const fileUrl = url.pathToFileURL(filePath).href;
1867
- const mod = await import(fileUrl);
1868
- // Find first export that is an array
1869
- for (const key of Object.keys(mod)) {
1870
- const val = mod[key];
1871
- if (Array.isArray(val))
1872
- return val;
1873
- }
1874
- // default export check
1875
- if (Array.isArray(mod.default))
1876
- return mod.default;
1877
- return undefined;
1878
- }
1879
- catch (err) {
1880
- // fallback: if import fails, try to static-parse again (already attempted) and finally return undefined
1881
- return undefined;
1882
- }
1883
- }
1884
- async function aggregateModules(repoRoot) {
1885
- const dirs = findModuleDirs(repoRoot);
1886
- const master = {
1887
- prompts: [],
1888
- resources: [],
1889
- templates: [],
1890
- tools: [],
1891
- conflicts: [],
1892
- };
1893
- // maps to detect duplicates per type
1894
- const maps = {
1895
- prompts: new Map(),
1896
- resources: new Map(),
1897
- templates: new Map(),
1898
- tools: new Map(),
1899
- };
1900
- for (const moduleDir of dirs) {
1901
- const moduleName = path.basename(moduleDir);
1902
- for (const sub of SUBFOLDERS) {
1903
- const folder = path.join(moduleDir, sub);
1904
- const indexFile = findIndexFile(folder);
1905
- if (!indexFile)
1906
- continue;
1907
- let arr;
1908
- try {
1909
- arr = await loadArrayFromIndex(indexFile);
1910
- }
1911
- catch (err) {
1912
- // skip module on import error but record as conflict-like issue
1913
- master.conflicts.push({
1914
- key: `import-error:${moduleName}:${sub}`,
1915
- existing: { moduleName, modulePath: moduleDir },
1916
- incoming: { moduleName, modulePath: moduleDir },
1917
- });
1918
- continue;
1919
- }
1920
- if (!arr || !Array.isArray(arr))
1921
- continue;
1922
- for (const item of arr) {
1923
- const key = makeKeyForItem(item);
1924
- const provenance = { moduleName, modulePath: moduleDir };
1925
- const map = maps[sub];
1926
- if (map.has(key)) {
1927
- // record conflict deterministically (existing vs incoming)
1928
- const existing = map.get(key);
1929
- master.conflicts.push({ key, existing, incoming: provenance });
1930
- // skip adding duplicate
1931
- continue;
1932
- }
1933
- map.set(key, provenance);
1934
- master[sub].push({ ...item, provenance });
1935
- }
1936
- }
1937
- }
1938
- return master;
1939
- }
1940
- // For compatibility with CommonJS call sites (not exported by ESM), provide a sync wrapper
1941
- function aggregateModulesSync(repoRoot) {
1942
- // synchronous wrapper that runs the async function and blocks — suitable for small module sets
1943
- const p = aggregateModules(repoRoot);
1944
- let result;
1945
- let done = false;
1946
- p.then((r) => {
1947
- result = r;
1948
- done = true;
1949
- }).catch((e) => {
1950
- throw e;
1951
- });
1952
- if (!done)
1953
- throw new Error("aggregateModulesSync: timeout waiting for async aggregation");
1954
- return result;
1955
- }
1956
-
1957
- /**
1958
- * Aggregate module assets and register them on the provided FastMCP-like server.
1959
- * Falls back to built-in lists if aggregation yields none.
1960
- */
1961
- async function EnrichCoreWithAggregation(server, repoRoot = process.cwd()) {
1962
- // First register built-in prompts/tools/resources/templates (legacy behavior)
1963
- try {
1964
- loadPrompts();
1965
- for (const prompt of promptList)
1966
- server.addPrompt(prompt);
1967
- }
1968
- catch (e) {
1969
- // ignore if loadPrompts not available or fails
1970
- }
1971
- try {
1972
- for (const tool of toolList)
1973
- server.addTool(tool);
1974
- }
1975
- catch (e) { }
1976
- try {
1977
- for (const resource of resources)
1978
- server.addResource(resource);
1979
- }
1980
- catch (e) { }
1981
- try {
1982
- const templates = buildResourceTemplates();
1983
- for (const template of templates)
1984
- server.addResourceTemplate(template);
1985
- }
1986
- catch (e) { }
1987
- // Now aggregate modules and register aggregated assets with provenance
1988
- const agg = await aggregateModules(repoRoot);
1989
- for (const p of agg.prompts) {
1990
- server.addPrompt(p);
1991
- }
1992
- for (const t of agg.tools) {
1993
- server.addTool(t);
1994
- }
1995
- for (const r of agg.resources) {
1996
- server.addResource(r);
1997
- }
1998
- for (const tpl of agg.templates) {
1999
- server.addResourceTemplate(tpl);
2000
- }
2001
- // return aggregation summary for calling tests/CI
2002
- return {
2003
- modulesChecked: agg.prompts.concat(agg.tools).length,
2004
- conflicts: agg.conflicts,
2005
- };
2006
- }
2007
-
2008
- function EnrichCore(server) {
2009
- loadPrompts();
2010
- for (const prompt of promptList) {
2011
- server.addPrompt(prompt);
2012
- }
2013
- for (const tool of toolList) {
2014
- server.addTool(tool);
2015
- }
2016
- for (const resource of resources) {
2017
- server.addResource(resource);
2018
- }
2019
- const templates = buildResourceTemplates();
2020
- for (const template of templates) {
2021
- server.addResourceTemplate(template);
2022
- }
2023
- }
2024
-
2025
- const REQUIRED_MODULE_FOLDERS = [
2026
- "prompts",
2027
- "resources",
2028
- "templates",
2029
- "tools",
2030
- ];
2031
- function resolveModulesRoot(workspaceRoot = getWorkspaceRoot()) {
2032
- return path$1.resolve(workspaceRoot, "src/modules");
2033
- }
2034
- function listModuleDirectories(workspaceRoot = getWorkspaceRoot()) {
2035
- const root = resolveModulesRoot(workspaceRoot);
2036
- if (!fs$1.existsSync(root))
2037
- return [];
2038
- return fs$1
2039
- .readdirSync(root)
2040
- .map((entry) => ({
2041
- entry,
2042
- absolute: path$1.join(root, entry),
2043
- }))
2044
- .filter(({ absolute }) => fs$1.statSync(absolute).isDirectory())
2045
- .map(({ entry }) => entry)
2046
- .sort();
2047
- }
2048
- function resolveModulePath(moduleName, workspaceRoot = getWorkspaceRoot()) {
2049
- return path$1.join(resolveModulesRoot(workspaceRoot), moduleName);
2050
- }
2051
- function resolveModuleFolderPath(moduleName, folder, workspaceRoot = getWorkspaceRoot()) {
2052
- return path$1.join(resolveModulePath(moduleName, workspaceRoot), folder);
2053
- }
2054
-
2055
- /* istanbul ignore file */
2056
- /**
2057
- * @description Utility class for CLI operations
2058
- * @summary A static utility class that provides methods for loading modules, retrieving package information, and initializing CLI commands
2059
- *
2060
- * @example
2061
- * // Initialize a Command object with package information
2062
- * const command = new Command();
2063
- * CLIUtils.initialize(command, './path/to/package');
2064
- *
2065
- * // Load a CLI module from a file
2066
- * const module = await CLIUtils.loadFromFile('./path/to/cli-module.js');
2067
- *
2068
- * @class McpUtils
2069
- */
2070
- class McpUtils {
2071
- /**
2072
- * @description Dynamically imports a module file
2073
- * @summary Loads a JavaScript file and returns it as a CliModule, handling both ESM and CommonJS formats
2074
- *
2075
- * @param {string} path The file path to the module to load
2076
- * @return {Promise<McpModule>} A promise that resolves to the loaded CliModule
2077
- */
2078
- static async loadFromFile(path) {
2079
- try {
2080
- return McpUtils.normalizeImport(import(path));
2081
- }
2082
- catch (e) {
2083
- throw new Error(`Failed to load from ${path}: ${e instanceof Error ? e.message : e}`);
2084
- }
2085
- }
2086
- /**
2087
- * @description Normalizes module imports to handle both ESM and CommonJS formats
2088
- * @summary Properly imports JavaScript files regardless of their module format by handling the ESM wrapper for CommonJS modules
2089
- *
2090
- * @template T The type of the imported module
2091
- * @param {Promise<T>} importPromise The promise returned by the dynamic import
2092
- * @return {Promise<T>} A promise that resolves to the normalized module
2093
- * @private
2094
- */
2095
- static async normalizeImport(importPromise) {
2096
- // CommonJS's `module.exports` is wrapped as `default` in ESModule.
2097
- return importPromise.then((m) => (m.default || m));
2098
- }
2099
- /**
2100
- * @description Retrieves and parses the package.json file
2101
- * @summary Reads the package.json file from the specified path and parses it into a JavaScript object
2102
- *
2103
- * @param {string} basePath The base path where the package.json file is located
2104
- * @return {Record<string, unknown>} The parsed package.json content as an object
2105
- * @private
2106
- */
2107
- static getPackage(basePath) {
2108
- try {
2109
- return JSON.parse(fs.readFileSync(path.join(basePath, "package.json"), "utf8"));
2110
- }
2111
- catch (e) {
2112
- throw new Error(`Unable to read version from ${basePath}: ${e}`);
2113
- }
2114
- }
2115
- /**
2116
- * @description Returns the version from package.json
2117
- * @summary Retrieves the version field from the package.json file at the specified path
2118
- *
2119
- * @param {string} basePath The base path where the package.json file is located
2120
- * @return {string} The package version string
2121
- */
2122
- static packageVersion(basePath) {
2123
- return McpUtils.getPackage(basePath)["version"];
2124
- }
2125
- /**
2126
- * @description Returns the name from package.json
2127
- * @summary Retrieves the name field from the package.json file at the specified path and extracts the package name without the scope
2128
- *
2129
- * @param {string} basePath The base path where the package.json file is located
2130
- * @return {string} The package name without the scope (e.g., "cli" from "@decaf-ts/cli")
2131
- */
2132
- static packageName(basePath) {
2133
- const name = McpUtils.getPackage(basePath)["name"].split("/");
2134
- return name[name.length - 1];
2135
- }
2136
- }
2137
-
2138
- /**
2139
- * @description Utility class to handle CLI functionality from all Decaf modules
2140
- * @summary This class provides a wrapper around Commander.js to handle CLI commands from different Decaf modules.
2141
- * It crawls the filesystem to find CLI modules, loads them, and registers their commands.
2142
- */
2143
- class McpWrapper extends logging.LoggedClass {
2144
- constructor(basePath = "./", crawlLevels = 4) {
2145
- super();
2146
- this.basePath = basePath;
2147
- this.crawlLevels = crawlLevels;
2148
- this.modules = {};
2149
- // Support both CommonJS and ESM runtimes for filename/dirname
2150
- let localDirname;
2151
- if (typeof __filename !== "undefined" && typeof __dirname !== "undefined") {
2152
- // CommonJS environment
2153
- localDirname = __dirname;
2154
- }
2155
- else {
2156
- // ESM or other env: compute import.meta.url at runtime to avoid TS compile-time import.meta checks
2157
- let metaUrl;
2158
- try {
2159
- // Use a dynamic function so TypeScript won't parse `import.meta` at compile time
2160
- const fn = new Function('return (typeof import !== "undefined" && typeof import.meta !== "undefined") ? import.meta.url : undefined;');
2161
- metaUrl = fn();
2162
- }
2163
- catch {
2164
- metaUrl = undefined;
2165
- }
2166
- if (metaUrl) {
2167
- localDirname = path__namespace.dirname(url.fileURLToPath(metaUrl));
2168
- }
2169
- else {
2170
- // Last-resort fallback: use current working directory
2171
- localDirname = process.cwd();
2172
- }
2173
- }
2174
- this.rootPath = path__namespace.resolve(localDirname, "..");
2175
- }
2176
- /**
2177
- * @description Retrieves and initializes the Commander Command object
2178
- * @summary Lazy-loads the Command object, initializing it with the package name, description, and version
2179
- * @return {FastMCP} The initialized Command object
2180
- * @private
2181
- */
2182
- get mcp() {
2183
- if (!this._mcp) {
2184
- this._mcp = new fastmcp.FastMCP({
2185
- name: "decaf-ts MCP server",
2186
- instructions: "",
2187
- version: VERSION$1,
2188
- });
2189
- }
2190
- return this._mcp;
2191
- }
2192
- /**
2193
- * @description Loads and registers an mcp extension module from a file
2194
- * @summary Dynamically imports an mcp extension module from the specified file path, initializes it, and registers it in the modules collection
2195
- *
2196
- */
2197
- async load(server, filePath) {
2198
- const log = this.log.for(this.load);
2199
- let pkg, version, enrich;
2200
- try {
2201
- const res = await McpUtils.loadFromFile(filePath);
2202
- pkg = res.PACKAGE_NAME;
2203
- version = res.VERSION;
2204
- enrich = res.enrich;
2205
- }
2206
- catch (e) {
2207
- throw new Error(e.message || e);
2208
- }
2209
- try {
2210
- log.info(`Enriching mcp server with module ${pkg} v${version}`);
2211
- const result = enrich(server);
2212
- server = result instanceof Promise ? await result : result;
2213
- }
2214
- catch (e) {
2215
- throw new Error(`failed to enrich mcp with module ${pkg || "unnamed"} under ${filePath}: ${e instanceof Error ? e.message : e}`);
2216
- }
2217
- return {
2218
- mcp: server,
2219
- package: pkg,
2220
- version: version,
2221
- };
2222
- }
2223
- /**
2224
- * @description Finds and loads all CLI modules in the basePath
2225
- * @summary Uses the crawl method to find all CLI modules in the specified base path,
2226
- * then loads and registers each module as a subcommand
2227
- *
2228
- * @return {Promise<void>} A promise that resolves when all modules are loaded
2229
- *
2230
- * @private
2231
- * @mermaid
2232
- * sequenceDiagram
2233
- * participant CliWrapper
2234
- * participant Filesystem
2235
- * participant Module
2236
- *
2237
- * CliWrapper->>Filesystem: Join basePath with cwd
2238
- * CliWrapper->>CliWrapper: crawl(basePath, crawlLevels)
2239
- * CliWrapper-->>CliWrapper: modules[]
2240
- * loop For each module
2241
- * alt Not @decaf-ts/cli
2242
- * CliWrapper->>CliWrapper: load(module, cwd)
2243
- * CliWrapper-->>CliWrapper: name
2244
- * CliWrapper->>CliWrapper: Check if command exists
2245
- * alt Command doesn't exist
2246
- * CliWrapper->>Command: command(name).addCommand(modules[name])
2247
- * end
2248
- * end
2249
- * end
2250
- * CliWrapper->>Console: Log loaded modules
2251
- */
2252
- async boot() {
2253
- const log = this.log.for(this.boot);
2254
- let server = this.mcp;
2255
- // discover modules by crawling basePath
2256
- const moduleFiles = this.crawl(path__namespace.resolve(this.basePath), this.crawlLevels);
2257
- for (const moduleFile of moduleFiles) {
2258
- if (moduleFile.includes("@decaf-ts/mcp")) {
2259
- continue;
2260
- }
2261
- try {
2262
- const res = await this.load(server, moduleFile);
2263
- server = res.mcp;
2264
- this.modules[res.package] = moduleFile;
2265
- }
2266
- catch (e) {
2267
- log.error(`Failed to load MCP configs for ${moduleFile}: ${e instanceof Error ? e.message : e}`);
2268
- }
2269
- }
2270
- console.log(`loaded modules:\n${Object.keys(this.modules)
2271
- .map((k) => `- ${k}`)
2272
- .join("\n")}`);
2273
- return server;
2274
- }
2275
- /**
2276
- * @description Recursively searches for CLI module files in the directory structure
2277
- * @summary Crawls the basePath up to the specified number of folder levels to find files named according to CLI_FILE_NAME
2278
- *
2279
- * @param {string} basePath The absolute base path to start searching in
2280
- * @param {number} [levels=2] The maximum number of directory levels to crawl
2281
- * @return {string[]} An array of file paths to CLI modules
2282
- *
2283
- * @private
2284
- */
2285
- crawl(basePath, levels = 2) {
2286
- if (levels <= 0)
2287
- return [];
2288
- return fs__namespace.readdirSync(basePath).reduce((accum, file) => {
2289
- file = path__namespace.join(basePath, file);
2290
- if (fs__namespace.statSync(file).isDirectory()) {
2291
- accum.push(...this.crawl(file, levels - 1));
2292
- }
2293
- else if (file.match(new RegExp(`${MCP_FILE_NAME}.[cm]?js$`, "gm"))) {
2294
- accum.push(file);
2295
- }
2296
- return accum;
2297
- }, []);
2298
- }
2299
- /**
2300
- * @description Executes the CLI with the provided arguments
2301
- * @summary Boots the CLI by loading all modules, then parses and executes the command specified in the arguments
2302
- *
2303
- * @param {string[]} [args=process.argv] Command line arguments to parse and execute
2304
- * @return {Promise<void>} A promise that resolves when the command execution is complete
2305
- *
2306
- * @mermaid
2307
- * sequenceDiagram
2308
- * participant Client
2309
- * participant CliWrapper
2310
- * participant Command
2311
- *
2312
- * Client->>CliWrapper: run(args)
2313
- * CliWrapper->>CliWrapper: boot()
2314
- * Note over CliWrapper: Loads all modules
2315
- * CliWrapper->>Command: parseAsync(args)
2316
- * Command-->>CliWrapper: result
2317
- * CliWrapper-->>Client: result
2318
- */
2319
- async run(args = process.argv) {
2320
- const server = await this.boot();
2321
- await server.start({ transportType: "stdio" });
2322
- }
2323
- }
2324
-
2325
- exports.CLIENT_INTEGRATIONS = CLIENT_INTEGRATIONS;
2326
- exports.DEFAULT_PROMPT_NAME = DEFAULT_PROMPT_NAME;
2327
- exports.EnrichCore = EnrichCore;
2328
- exports.EnrichCoreWithAggregation = EnrichCoreWithAggregation;
2329
- exports.MCP_FILE_NAME = MCP_FILE_NAME;
2330
- exports.McpUtils = McpUtils;
2331
- exports.McpWrapper = McpWrapper;
2332
- exports.PACKAGE_NAME = PACKAGE_NAME;
2333
- exports.PROMPT_DIRECTORIES = PROMPT_DIRECTORIES;
2334
- exports.REQUIRED_MODULE_FOLDERS = REQUIRED_MODULE_FOLDERS;
2335
- exports.VERSION = VERSION;
2336
- exports.WORKSPACE_ROOT_ENV = WORKSPACE_ROOT_ENV;
2337
- exports.__resetWorkspaceRoot = __resetWorkspaceRoot;
2338
- exports.aggregateModules = aggregateModules;
2339
- exports.aggregateModulesSync = aggregateModulesSync;
2340
- exports.buildDecorationResourceTemplates = buildDecorationResourceTemplates;
2341
- exports.buildDocPrompts = buildDocPrompts;
2342
- exports.buildResourceTemplates = buildResourceTemplates;
2343
- exports.decorationResourceTemplates = decorationResourceTemplates;
2344
- exports.enrich = enrich;
2345
- exports.getWorkspaceRoot = getWorkspaceRoot;
2346
- exports.listModuleDirectories = listModuleDirectories;
2347
- exports.promptList = promptList;
2348
- exports.resolveModuleFolderPath = resolveModuleFolderPath;
2349
- exports.resolveModulePath = resolveModulePath;
2350
- exports.resolveModulesRoot = resolveModulesRoot;
2351
- exports.resources = resources;
2352
- exports.setWorkspaceRoot = setWorkspaceRoot;
2353
- exports.templateList = templateList;
2354
- exports.toolList = toolList;
2355
- exports.tools = tools;
2356
- exports.validateModules = validateModules;
2357
- exports.workspaceResourceTemplates = workspaceResourceTemplates;
2358
-
2359
- }));
2360
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"mcp-server.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":["z","spawnSync","applyPatch","createTwoFilesPatch","toolList","coreToolList","VERSION","PACKAGE_NAME","Metadata","PKG","V","pathToFileURL","path","fs","LoggedClass","fileURLToPath","FastMCP"],"mappings":"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"}
1
+ var e,t;e=this,t=function(e,t,r,n,o,s,i,a,c,d,l,m,u,p,h,g,f){"use strict";function y(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var b,S,v,w=y(c),x=y(d);(e=>{e[e.NONE=0]="NONE",e[e.BASIC=1]="BASIC",e[e.ADVANCED=2]="ADVANCED",e[e.HIGH=3]="HIGH"})(b||(b={})),(e=>{e[e.NONE=0]="NONE",e[e.LOW=1]="LOW",e[e.MEDIUM=2]="MEDIUM",e[e.HIGH=3]="HIGH"})(S||(S={})),(e=>{e[e.FREE=0]="FREE",e[e.LOW=1]="LOW",e[e.MEDIUM=2]="MEDIUM",e[e.HIGH=3]="HIGH"})(v||(v={}));class T extends r.Model{constructor(e){super(e),r.Model.fromObject(this,e)}log(e){const{sessionId:t,requestId:r,authInfo:o}=e||{};let s="string"==typeof t&&t.length>0?n.Logging.for(t).for(this):n.Logging.for(this);return o&&o.clientId&&(s=s.for(o.clientId)),r&&(s=s.for(r.toString())),s}setDescription(e){return this.description=e,this}setName(e){return this.name=e,this}setTitle(e){return this.title=e,this}}t.__decorate([r.required(),t.__metadata("design:type",String)],T.prototype,"description",void 0),t.__decorate([r.required(),t.__metadata("design:type",String)],T.prototype,"name",void 0),t.__decorate([r.required(),t.__metadata("design:type",String)],T.prototype,"title",void 0);class N extends T{constructor(e){super(e),this.reasoning=b.NONE,this.effort=S.NONE,this.cost=v.FREE}setReasoning(e){return this.reasoning=e,this}setEffort(e){return this.effort=e,this}setCost(e){return this.cost=e,this}}t.__decorate([r.required(),t.__metadata("design:type",Number)],N.prototype,"reasoning",void 0),t.__decorate([r.required(),t.__metadata("design:type",Number)],N.prototype,"effort",void 0),t.__decorate([r.required(),t.__metadata("design:type",Number)],N.prototype,"cost",void 0);class _ extends N{setCb(e){return this.cb=e,this}setArgsSchema(e){return this.argsSchema=e,this}constructor(e){super(e)}static get builder(){return new _}build(e){const t=this.hasErrors();if(t)throw Error(t.toString());try{return e.registerPrompt(this.name,{title:this.title,description:this.description,argsSchema:this.argsSchema},async(e,t)=>{const r=this.log(t);e=e||{},r.verbose(`Executing prompt ${this.name} with args: ${JSON.stringify(e)}`),e._meta=Object.assign(e._meta||{},{usage:{reasoning:this.reasoning,effort:this.effort,cost:this.cost}});const n=await Promise.resolve(this.cb(e,t));return r.verbose(`Prompt ${this.name} executed successfully.`),r.debug("Prompt execution meta: "+JSON.stringify(n._meta)),n})}catch(e){throw n.Logging.for(this).error("Failed to register prompt "+this.name,e),e}}}t.__decorate([r.required(),t.__metadata("design:type",Object)],_.prototype,"cb",void 0),t.__decorate([r.required(),t.__metadata("design:type",Object)],_.prototype,"argsSchema",void 0);class E extends T{setCb(e){return this.cb=e,this}setConfig(e){return this.config=e,this}setUriOtTemplate(e){return this.uriOrTemplate=e,this}constructor(e){super(e)}static get builder(){return new E}build(e){const t=this.hasErrors();if(t)throw Error(t.toString());try{const t="string"==typeof this.uriOrTemplate&&this.uriOrTemplate.includes("{")?new s.ResourceTemplate(new o.UriTemplate(this.uriOrTemplate),{list:void 0}):this.uriOrTemplate,r=Object.assign(this.config,{_meta:{}}),n=async(e,t)=>{const r=this.log(t);r.verbose(`Requesting resource ${this.name} from ${e.toString()}`);const n=await Promise.resolve(this.cb(e,t));return r.verbose(`Resource ${this.name} retrieved successfully.`),r.debug("Resource retrieval meta: "+JSON.stringify(n._meta)),n};return e.resource(this.name,t,r,n)}catch(e){throw n.Logging.for(this).error("Error registering resource "+this.name,e),e}}}t.__decorate([r.required(),t.__metadata("design:type",String)],E.prototype,"uriOrTemplate",void 0),t.__decorate([r.required(),t.__metadata("design:type",Function)],E.prototype,"cb",void 0),t.__decorate([r.required(),t.__metadata("design:type",Object)],E.prototype,"config",void 0);class O extends N{setAnnotations(e){return this.annotations=Object.assign(this.annotations,e),this}setCb(e){return this.cb=e,this}setInputSchema(e){return this.inputSchema=e,this}setOutputSchema(e){return this.outputSchema=e,this}constructor(e){super(e),this.annotations={readOnlyHint:!0,destructiveHint:!1,idempotentHint:!0,openWorldHint:!1}}static get builder(){return new O}build(e){const t=this.hasErrors();if(t)throw Error(t.toString());try{return e.registerTool(this.name,{title:this.title,description:this.description,inputSchema:this.inputSchema,outputSchema:this.outputSchema,annotations:this.annotations,_meta:{usage:{reasoning:this.reasoning,effort:this.effort,cost:this.cost}}},async(e,t)=>{const r=this.log(t);r.verbose(`Executing tool ${this.name} with args: ${JSON.stringify(e)}`),t._meta=Object.assign(t._meta||{},{usage:{reasoning:this.reasoning,effort:this.effort,cost:this.cost}});const n=await Promise.resolve(this.cb(e,t));return r.verbose(`Tool ${this.name} executed successfully.`),r.debug("Tool execution meta: "+JSON.stringify(n._meta)),n})}catch(e){throw n.Logging.for(this).error("Error building tool",e),e}}}t.__decorate([r.required(),t.__metadata("design:type",Object)],O.prototype,"annotations",void 0),t.__decorate([r.required(),t.__metadata("design:type",Object)],O.prototype,"cb",void 0),t.__decorate([r.type(Object.name),r.required(),t.__metadata("design:type",Object)],O.prototype,"inputSchema",void 0),t.__decorate([r.type(Object.name),t.__metadata("design:type",Object)],O.prototype,"outputSchema",void 0);const D=["\x1b[38;5;215m","\x1b[38;5;209m","\x1b[38;5;205m","\x1b[38;5;210m","\x1b[38;5;217m","\x1b[38;5;216m","\x1b[38;5;224m","\x1b[38;5;230m","\x1b[38;5;230m"];let j=null;async function A(e){const t=j||(j=new m.Project({tsConfigFilePath:void 0,skipAddingFilesFromTsConfig:!0}),j),r=t.addSourceFileAtPathIfExists(e)||t.createSourceFile(e,void 0,{overwrite:!1});try{await Promise.race([t.resolveSourceFileDependencies(),new Promise(e=>setTimeout(e,2e3))])}catch(e){}const n=r.getExportedDeclarations();return{astObjects:Array.from(n.entries()).flatMap(([t,r])=>r.map(r=>{const n="function"==typeof r.getStartLineNumber?r.getStartLineNumber():0,o="function"==typeof r.getEndLineNumber?r.getEndLineNumber():0,s="function"==typeof r.getKindName?(r.getKindName()+"").toLowerCase():"unknown",i="function"==typeof r.getStartLinePos?r.getStartLinePos():0;return{id:`${e}::${t}`,name:t,kind:s,location:{filePath:e,startLine:n,startColumn:i,endLine:o,endColumn:0},isExported:!0}}))}}const C="ts.ast.extract",P="AST Extraction Tool for TypeScript",I=l.z.object({filePath:l.z.string().describe("The path to the TypeScript file to analyze.")}).describe(`the input schema for the ${C} tool`);l.z.object({}).describe(`the output schema for the ${C} tool`);const $=O.builder.setName(C).setTitle(P).setDescription("Extracts and analyzes the Abstract Syntax Tree (AST) of TypeScript code to provide insights into its structure and components.").setInputSchema(I).setAnnotations({title:P,readOnlyHint:!0,destructiveHint:!1,idempotentHint:!0,openWorldHint:!1}).setCb(async(e,t)=>{const{filePath:r}=e,n=await Promise.race([A(r),new Promise(e=>setTimeout(()=>e(null),1500))]);if(!n||!n.astObjects)return{content:[{type:"text",text:"No AST objects or analysis timed out"}],structuredContent:{astObjects:[]}};const o=n.astObjects.map(e=>({id:e.id,name:e.name,kind:e.kind||"unknown",location:e.location,isExported:!!e.isExported,signature:e.signature,parentId:e.parentId,children:e.children,decorators:e.decorators,contextHints:e.contextHints||[]}));return{content:[{type:"text",text:`Found ${o.length} AST objects`}],structuredContent:{astObjects:o}}}),k=O.builder.setName("example-tool").setTitle("Example: Reverse String Tool").setDescription("Reverses the provided `text` input and returns the result.").setInputSchema(l.z.object({text:l.z.string()})).setCb(async(e,t)=>{const r=((e?.text??"")+"").split("").reverse().join("");return{content:[{type:"text",text:r}],structuredContent:{result:r}}}).setReasoning(b.NONE).setEffort(S.NONE).setCost(v.FREE),R=O.builder.setName("ast.jsdoc").setTitle("AST \u2192 JSDoc Tool").setDescription("Generate suggested JSDoc comments for TypeScript AST objects (MVP stub).").setInputSchema(l.z.object({filePath:l.z.string()})).setCb(async(e,t)=>{const r=[{type:"text",text:"Not implemented (stub)"}];return{content:r,structuredContent:{content:r}}}).setReasoning(b.BASIC).setEffort(S.LOW).setCost(v.FREE),q=[$,k,O.builder.setName("file.summarizer").setTitle("File Summarizer").setDescription("Produce a short structured summary for a TypeScript file.").setInputSchema(l.z.object({filePath:l.z.string()})).setCb(async(e,t)=>{if(!(e?.filePath??e?.path))return{content:[{type:"text",text:""}]};const r=await(async()=>({astObjects:[]}))().catch(()=>null),n=r&&r.astObjects||[],o=n.map(e=>e.name||e.id||e.kind).slice(0,20),s=`Found ${n.length} AST objects. Top names: ${o.join(", ")}`;return{content:[{type:"text",text:s}],structuredContent:{summary:s},_meta:{count:n.length}}}).setReasoning(b.NONE).setEffort(S.NONE).setCost(v.FREE),R];var z=Object.freeze({__proto__:null,Tools:q});const J="You're a senior TypeScript developer writing JSDoc documentation for a class to be used with better-docs. Given the module code:\nGenerate a JSDoc comment block for a TypeScript module file using better-docs formatting:",M="document the target code, always including the @description tag with a short description of the target, and a@summary tag with a more detailed one.\n Include @interface and @typeDef an @template tags when appropriate.\n Include detailed @description for all properties.\n For methods, include @description and @summary tags as defined for the target. also document every argument, including its type definition, and return type, referencing @template tags when necessary.\n\n The order of tags (when applicable) should be as follows:\n1 - @description;\n2 - @summary;\n3 - @template;\n4 - @param;\n5 - @return;\n6 - @interface or @typeDef followed by the interface or type name;\n8 - @memberOf referencing the appropriate module using the appropriate syntax\n\nOutput only the completed JSDoc comment block for the type or interface.\nrefer to the module it belongs with @memberOf this the `@memberOf module:<module_name>` syntax\nnever omit or change any code\nif the element is already documented, only restructure, correct, or add to the documentation. NEVER remove existing information",L="document the target code, always including the @description tag with a short description of the target, and a@summary tag with a more detailed one.\nInclude @const and @typeDef tags when appropriate.\nInclude detailed @description for all properties.\n- For enums, include @enum and @readonly, and add inline documentation for each member\n- For object-like constants:\n - Create a @typedef with @property for each key\n - Reference it in the constant using @type\n - Alternatively, document each key inline if small\n\nThe order of tags (when applicable) should be as follows:\n1 - @description;\n2 - @summary;\n3 - @template;\n4 - @property;\n6 - @const followed by the const or enum name;\n8 - @memberOf referencing the appropriate module using the appropriate syntax\n\nRespond with the JSDoc comment block(s) for both the typedef and the constant or enum.\nrefer to the module it belongs with @memberOf this the `@memberOf module:<module_name>` syntax\nnever omit or change any code\nif the element is already documented, only restructure, correct, or add to the documentation. NEVER remove existing information",F="NOTES:\n - when document a function/method parameters, and there is a template type involved, ALWAYS reference it using the @template tag;\n - when documenting a function type as a parameter, ALWAYS use the function(type1,type2):return_type syntax;\n ",H=l.z.object({}),B=_.builder.setName("ts.jsdoc.class").setTitle("Class JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript class according to a curated template and prompt.").setArgsSchema(H).setReasoning(b.BASIC).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\ndocument the entire class and each of its functions including always including the @description tag with a short description of the target, and a@summary tag with a more detailed one.\nInclude @class tags when applicable.\ninclude @param tags in the class documentation and its type definitions\nInclude detailed @description for all properties.\nInclude @template tags when necessary.\nDo NOT document the constructor, but include the constructor arguments as @param in the class documentation\nFor methods and functions:\n- include @description and @summary tags as defined for the target. also document every argument, including its type definition, and return type, referencing @template tags when necessary.\n- create a usage example under the @example tag on the class documentation\n- create mermaid sequence diagrams under the @mermaid tag;\n\nThe order of tags (when applicable) should be as follows:\n1 - @description;\n2 - @summary;\n3 - @template;\n4 - @param;\n5 - @return;\n6 - @class\n7 - @example\n8 - @mermaid;\n\nignore @mermaid for methods with less that 15 lines and constructors.\nRespond only with the full JSDoc comment block for the class and its methods.\nNEVER user @memberOf in the class or any of it's methods\nif the element is already documented, only restructure, correct, or add to the documentation. NEVER remove existing information\nnever omit or change any code, including the constructor\n${F}`}}],_meta:{}})),G=l.z.object({}),U=_.builder.setName("ts.jsdoc.const").setTitle("Const JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript constant according to a curated template and prompt.").setArgsSchema(G).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\n${L}\n${F}`}}]})),V=l.z.object({}),W=_.builder.setName("ts.jsdoc.decorator").setTitle("Decorator JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript Decorator according to a curated template and prompt.").setArgsSchema(V).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\ndocument the target code, always including the @description tag with a short description of the target, and a@summary tag with a more detailed one.\nInclude @function an @template tags when appropriate.\nInclude detailed @description for all properties.\nFor methods, include @description and @summary tags as defined for the target. also document every argument, including its type definition, and return type, referencing @template tags when necessary.\ncreate mermaid sequence diagrams under the @mermaid tag;\n\nThe order of tags (when applicable) should be as follows:\n1 - @description;\n2 - @summary;\n3 - @template;\n4 - @param including type definitions;\n5 - @return;\n6 - @function followed by the interface or type name;\n7 - @mermaid with the sequence diagram for the function if it has over 10 lines\n8 - @category one of: "Decorators", "Class Decorators", "Method Decorators", "Property Decorators", "Parameter Decorators"\nOutput only the full JSDoc comment block for the function.\nDO NOT refer to the module it belongs with @memberOf\nnever omit or change any code\nif the element is already documented, only restructure, correct, or add to the documentation. NEVER remove existing information\n${F}`}}]})),K=l.z.object({}),Y=_.builder.setName("ts.jsdoc.enum").setTitle("Enum JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript enum according to a curated template and prompt.").setArgsSchema(K).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\n${L}\n${F}`}}]})),Q=l.z.object({}),X=_.builder.setName("ts.jsdoc.function").setTitle("Function JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript function according to a curated template and prompt.").setArgsSchema(Q).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\ndocument the target code, always including the @description tag with a short description of the target, and a@summary tag with a more detailed one.\nInclude @function an @template tags when appropriate.\nInclude detailed @description for all properties.\nFor methods, include @description and @summary tags as defined for the target. also document every argument, including its type definition, and return type, referencing @template tags when necessary.\ncreate mermaid sequence diagrams under the @mermaid tag;\n\nThe order of tags (when applicable) should be as follows:\n1 - @description;\n2 - @summary;\n3 - @template;\n4 - @param including type definitions;\n5 - @return;\n6 - @function followed by the interface or type name;\n7 - @mermaid with the sequence diagram for the function if ithas over 10 lines\n8 - @memberOf referencing the appropriate module using the appropriate syntax\n\nOutput only the full JSDoc comment block for the function.\nrefer to the module it belongs with @memberOf this the \`@memberOf module:<module_name>\` syntax\nnever omit or change any code\nif the element is already documented, only restructure, correct, or add to the documentation. NEVER remove existing information\n${F}`}}]})),Z=l.z.object({}),ee=_.builder.setName("ts.jsdoc.interface").setTitle("Interface JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript interface according to a curated template and prompt.").setArgsSchema(Z).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\n${M}\n${F}`}}]})),te=l.z.object({}),re=_.builder.setName("ts.jsdoc.type").setTitle("Type JSDocs Prompt").setDescription("Generate JSDoc comments for a TypeScript type according to a curated template and prompt.").setArgsSchema(te).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:`${J}\n${M}\n${F}`}}]})),ne=l.z.object({className:l.z.string().describe("the class name to turn into a builder")}),oe=_.builder.setName("ts.code.dp.builder").setTitle("Typescript builder design patter prompt").setDescription("for a class, with a defined set of properties, scafold a builder design pattern").setArgsSchema(ne).setReasoning(b.BASIC).setCb((e,t)=>(e.className=n.toPascalCase(e.className),{messages:[{role:"user",content:{type:"text",text:`You're a senior TypeScript developer writing typescript code.You're a senior TypeScript developer writing typescript code.\nTransform the selected class into a builder design pattern implementation in Typescript.\nuse @decaf-ts validation decorators to enforce the validation of your builder.\n\n- must extend the Model Class from @decaf-ts/decorator-validation;\n- each property must be marked as protected;\n- each property must have a setter method that returns 'this' for chaining;\n- the build() method must validate the properties using hasErrors() method from Model class;\n- if validation fails, throw an error with the validation errors;\n- if validation passes, return an instance of the original class with the set properties;\n- optionally (but do so by default) add the static builder and from methods from the example;\n- if the clasee already follows the pattern but has properties without decoration or without setters, simple add them;\n\nexample:\n\noriginal class:\n\`\`\`typescript\nexport class ${e.className} {\n description!: string;\n name!: string = "default name";\n title!: string;\n age?: string;\n dateOfBirth!: Date;\n}}\n\`\`\` \n\nresulting builder pattern implementation:\n\`\`\`typescript\nexport class ${e.className}Builder extends Model {\n\n @minlength(10\n @required()\n protected description!: string;\n \n @required()\n protected name!: string = "default value;\n \n @required()\n protected title!: string;\n \n @min(18)\n protected age?: string;\n \n @date()\n protected dateOfBirth!: Date;\n\n protected constructor(arg?: ModelArg<${e.className}Builder>>) {\n super(arg);\n Model.fromModel(this, arg);\n }\n\n setDescription(value: string) {\n this.description = value;\n return this;\n }\n\n setName(value: string) {\n this.name = value;\n return this;\n }\n\n setTitle(value: string) {\n this.title = value;\n return this;\n }\n setAge(value: number) {\n this.age = value;\n return this;\n }\n setDate(value: Date) {\n this.age = value;\n return this;\n }\n \n build(...args: any[]): ${e.className}Builder | Promise<${e.className}Builder> {\n const errs = this.hasErrors();\n if (errs) throw new Error(errs.toString());\n \n return // code that builds OBJ here\n }\n \n static get builder(): ${e.className}Builder {\n return new ${e.className}Builder(); // static method to get a new builder instance\n }\n \n static from<K extends keyof ${e.className}Builder>(obj: K, ${e.className}Builder[K]): ${e.className}Builder {\n return new ${e.className}Builder(); // static method to create a builder from an object\n }\n}\n\`\`\` \n\n`}}],_meta:{}})),se=l.z.object({text:l.z.string().optional()}),ie=_.builder.setName("example.prompt.echo").setTitle("Example: Echo Prompt").setDescription("Returns a short prompt containing the provided `text` as a user message.").setArgsSchema(se).setReasoning(b.BASIC).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:e?.text??"(no text provided)"}}],_meta:{}})),ae=l.z.object({code:l.z.string().optional(),astObject:l.z.any().optional()}),ce=[B,U,W,Y,X,ee,re,oe,ie,_.builder.setName("interactive.jsdoc.assistant").setTitle("Interactive JSDoc Assistant").setDescription("Produce a ready-to-insert JSDoc block for a provided code snippet or AST object.").setArgsSchema(ae).setReasoning(b.BASIC).setCb((e,t)=>({messages:[{role:"user",content:{type:"text",text:"Generate a complete JSDoc comment block for the following code. Respond only with the full JSDoc block.\n\n"+(e?.code??"")}}],_meta:{}}))],de=[E.builder.setName("example.resource.hello").setTitle("Example: Hello Resource").setDescription("A tiny example resource that returns a simple payload for any URI.").setUriOtTemplate("example://hello/{name}").setConfig({description:"Example resource",_meta:{usage:{reasoning:b.NONE,effort:S.NONE,cost:v.FREE}}}).setCb(async(e,t)=>({content:{type:"text",text:"hello from example resource"},_meta:{}})),E.builder.setName("repo.metadata").setTitle("Repository Metadata Resource").setDescription("Expose basic repository metadata such as package.json and lint rules.").setUriOtTemplate("repo://metadata/{file}").setConfig({description:"Repository metadata resource",_meta:{usage:{reasoning:b.NONE,effort:S.NONE,cost:v.FREE}}}).setCb(async(e,t)=>{const r=e.pathname.replace(/^\//,"")||"package.json";try{const e=c.resolve(process.cwd(),r),t=await u.readFile(e,{encoding:"utf8"}),n=JSON.parse(t);return{content:{type:"json",data:JSON.stringify(n)},_meta:{}}}catch(e){return{content:{type:"text",text:""},_meta:{}}}})],le="##VERSION##",me="##PACKAGE##";f.Metadata.registerLibrary(me,le);const ue={mcpId:me,name:"Official Decaf-TS MCP Server",title:"Official Decaf-TS MCP Server",description:"Provides precise coding assistance for the decaf-ts framework",version:le,websiteUrl:"https://decaf-ts.github.io",repositoryUrl:"https://github.com/decaf-ts",license:"AGPL-3.0",contacts:[{name:"Decaf-TS",url:"https://decaf-ts.github.io"}],tags:"server,official,decaf-ts",metadata:{},icons:[{src:"workdocs/assets/favicon.svg",mimeType:"image/svg+xml",sizes:"any"}]},pe=n.LoggedEnvironment.accumulate(ue);class he extends n.LoggedClass{get client(){if(!this._mcp)throw Error("Mcp server requires Mcp client");return this._mcp}constructor(){super()}async load(){try{const e=await Promise.all(de.map(e=>e.build(this.client)));this.log.verbose(`Loaded ${e.length} resources`);const t=await Promise.all(ce.map(e=>e.build(this.client)));this.log.verbose(`Loaded ${t.length} prompts`);const r=await Promise.all(q.map(e=>e.build(this.client)));this.log.verbose(`Loaded ${r.length} tools`);try{const e=await Promise.resolve().then(()=>z),t=Object.values(e).filter(e=>e&&"function"==typeof e.build).filter(e=>!q.includes(e));if(t.length>0){const e=await Promise.all(t.map(e=>e.build(this.client)));this.log.verbose(`Loaded ${e.length} exported builders from tools module`)}}catch(e){this.log.verbose("No additional exported builders loaded from tools module: "+e)}}catch(e){throw this.log.error("Error loading core MCP components",e),e}}async boot(e="stdio"){const t=this.log;this.log.for(this.boot).info("McpServer booting..."),((e=n.Logging.get())=>{let t;try{t=(()=>{let e,t=__dirname;try{for(;t&&t!==w.default.parse(t).root;){const r=w.default.join(t,"node_modules");if(x.default.existsSync(r)&&x.default.statSync(r).isDirectory()){e=r;break}const n=w.default.dirname(t);if(n===t)break;t=n}}catch{}const r=[];if(e){const t=w.default.join(e,"@decaf-ts");try{if(x.default.existsSync(t)&&x.default.statSync(t).isDirectory()){const e=x.default.readdirSync(t);for(const n of e){const e=w.default.join(t,n);try{const t=w.default.join(e,"workdocs","assets","slogans.json");if(x.default.existsSync(t)&&x.default.statSync(t).isFile()){const e=x.default.readFileSync(t,"utf-8"),n=JSON.parse(e);if(Array.isArray(n))for(const e of n)"string"==typeof e&&e.trim().length>0&&r.push(e.trim())}}catch{}}}}catch{}}return 0===r.length?"Decaf: strongly brewed TypeScript.":r[Math.floor(Math.random()*r.length)]})()}catch{t="Decaf: strongly brewed TypeScript."}const r="# \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n# ( ( \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# ) ) \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# [=======] \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n# `-----\xb4 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \n# \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591\u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2593\u2592\u2591 \u2591\u2592\u2593\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2593\u2592\u2591 \n#".split("\n"),o=r.reduce((e,t)=>Math.max(e,t.length),0);r.push("# "+t.padStart(o-3)),r.forEach((t,r)=>{const n=D[r%D.length]||"",o=e?e.info.bind(e):(()=>{}).bind();try{o(a.style(t||"").raw(n).text)}catch{o((t||"")+"")}})})(this.log);const r=((Array.isArray(pe.icons)?pe.icons:[pe.icons])||[]).map(e=>{const t="string"==typeof e?.src?e.src:(e?.src??"")+"",r="string"==typeof e?.mimeType?e.mimeType:(e?.mimeType??"")+"";let n=[];return Array.isArray(e?.sizes)?n=e.sizes.map(e=>e+""):"string"==typeof e?.sizes&&(n=(e.sizes+"").split(",").map(e=>e.trim())),{src:t,mimeType:r,sizes:n}}),o=pe.contacts;let s;if(null!=o)if(Array.isArray(o))s=o.map(e=>({name:"string"==typeof e?.name?e.name:(e?.name??"")+"",email:"string"==typeof e?.email?e.email:e?.email?e.email+"":void 0,url:"string"==typeof e?.url?e.url:e?.url?e.url+"":void 0}));else if("object"==typeof o){const e=Object.keys(o||{}).filter(e=>/^[0-9]+$/.test(e)).sort((e,t)=>Number(e)-Number(t));if(e.length>0)s=e.map(e=>{const t=o[e];return{name:"string"==typeof t?.name?t.name:(t?.name??"")+"",email:"string"==typeof t?.email?t.email:t?.email?t.email+"":void 0,url:"string"==typeof t?.url?t.url:t?.url?t.url+"":void 0}});else if("number"==typeof o.length){const e=Number(o.length)||0;s=[];for(let t=0;e>t;t++){const e=o[t];s.push({name:"string"==typeof e?.name?e.name:(e?.name??"")+"",email:"string"==typeof e?.email?e.email:e?.email?e.email+"":void 0,url:"string"==typeof e?.url?e.url:e?.url?e.url+"":void 0})}}else s=Object.keys(o).filter(e=>"length"!==e).map(e=>{const t=o[e];return{name:"string"==typeof t?.name?t.name:(t?.name??"")+"",email:"string"==typeof t?.email?t.email:t?.email?t.email+"":void 0,url:"string"==typeof t?.url?t.url:t?.url?t.url+"":void 0}})}const c={id:pe.mcpId,name:pe.name,title:pe.title,description:pe.description,websiteUrl:pe.websiteUrl,repositoryUrl:pe.repositoryUrl,version:pe.version,license:pe.license,contacts:s,tags:pe.tags?pe.tags.split(","):void 0,metadata:pe.metadata,icons:r};this._mcp=new i.McpServer(c,{instructions:"You are an AI assistant designed to help users with programming tasks related to the Decaf-TS framework. \nProvide clear, concise, and accurate information.\nIf you don't know the answer, admit it rather than making up information.\nAlways prioritize the user's intent and provide helpful suggestions when appropriate.\n",capabilities:{logging:{},completions:{},resources:{},tools:{},prompts:{}}});try{await this.load()}catch(e){throw this.log.error("Error loading resources/prompts/tools: "+e),e}if("string"==typeof e)switch(e){case"stdio":e=new h.StdioServerTransport;break;case"http":e=new p.StreamableHTTPServerTransport({sessionIdGenerator:()=>g.v4(),onsessioninitialized:e=>t.verbose("Session initialized: "+e),onsessionclosed:e=>t.verbose("Session closed: "+e),enableJsonResponse:!0,eventStore:void 0,allowedHosts:["*"],allowedOrigins:["*"],enableDnsRebindingProtection:!0});break;default:throw Error("Invalid transport type: "+e)}return this.client.connect(e)}}e.Builder=T,e.McpServer=he,e.PACKAGE_NAME=me,e.PromptBuilder=_,e.ResourceBuilder=E,e.ToolBuilder=O,e.UsableBuilder=N,e.VERSION=le},"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("tslib"),require("@decaf-ts/decorator-validation"),require("@decaf-ts/logging"),require("@modelcontextprotocol/sdk/shared/uriTemplate"),require("@modelcontextprotocol/sdk/server/mcp"),require("@modelcontextprotocol/sdk/server/mcp.js"),require("styled-string-builder"),require("path"),require("fs"),require("zod"),require("ts-morph"),require("fs/promises"),require("@modelcontextprotocol/sdk/server/streamableHttp"),require("@modelcontextprotocol/sdk/server/stdio"),require("uuid"),require("@decaf-ts/decoration")):"function"==typeof define&&define.amd?define(["exports","tslib","@decaf-ts/decorator-validation","@decaf-ts/logging","@modelcontextprotocol/sdk/shared/uriTemplate","@modelcontextprotocol/sdk/server/mcp","@modelcontextprotocol/sdk/server/mcp.js","styled-string-builder","path","fs","zod","ts-morph","fs/promises","@modelcontextprotocol/sdk/server/streamableHttp","@modelcontextprotocol/sdk/server/stdio","uuid","@decaf-ts/decoration"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self)["mcp-server"]={},e.tslib,e.decafTsDecoratorValidation,e.decafTsLogging,e.uriTemplate,e.mcp,e.mcp_js,e.styledStringBuilder,e.path,e.fs,e.zod,e.tsMorph,e.fsPromises,e.streamableHttp,e.stdio,e.uuid,e.decafTsDecoration);
2
+ //# sourceMappingURL=mcp-server.cjs.map