mnehmos.trace.mcp 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (339) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1662 -0
  3. package/dist/adapters/bootstrap.d.ts +29 -0
  4. package/dist/adapters/bootstrap.d.ts.map +1 -0
  5. package/dist/adapters/bootstrap.js +46 -0
  6. package/dist/adapters/bootstrap.js.map +1 -0
  7. package/dist/adapters/errors.d.ts +94 -0
  8. package/dist/adapters/errors.d.ts.map +1 -0
  9. package/dist/adapters/errors.js +107 -0
  10. package/dist/adapters/errors.js.map +1 -0
  11. package/dist/adapters/graphql/index.d.ts +9 -0
  12. package/dist/adapters/graphql/index.d.ts.map +1 -0
  13. package/dist/adapters/graphql/index.js +9 -0
  14. package/dist/adapters/graphql/index.js.map +1 -0
  15. package/dist/adapters/graphql/sdl-parser.d.ts +74 -0
  16. package/dist/adapters/graphql/sdl-parser.d.ts.map +1 -0
  17. package/dist/adapters/graphql/sdl-parser.js +559 -0
  18. package/dist/adapters/graphql/sdl-parser.js.map +1 -0
  19. package/dist/adapters/grpc/adapter.d.ts +76 -0
  20. package/dist/adapters/grpc/adapter.d.ts.map +1 -0
  21. package/dist/adapters/grpc/adapter.js +362 -0
  22. package/dist/adapters/grpc/adapter.js.map +1 -0
  23. package/dist/adapters/grpc/index.d.ts +10 -0
  24. package/dist/adapters/grpc/index.d.ts.map +1 -0
  25. package/dist/adapters/grpc/index.js +12 -0
  26. package/dist/adapters/grpc/index.js.map +1 -0
  27. package/dist/adapters/grpc/proto-parser.d.ts +76 -0
  28. package/dist/adapters/grpc/proto-parser.d.ts.map +1 -0
  29. package/dist/adapters/grpc/proto-parser.js +523 -0
  30. package/dist/adapters/grpc/proto-parser.js.map +1 -0
  31. package/dist/adapters/grpc/type-converter.d.ts +43 -0
  32. package/dist/adapters/grpc/type-converter.d.ts.map +1 -0
  33. package/dist/adapters/grpc/type-converter.js +270 -0
  34. package/dist/adapters/grpc/type-converter.js.map +1 -0
  35. package/dist/adapters/grpc/types.d.ts +85 -0
  36. package/dist/adapters/grpc/types.d.ts.map +1 -0
  37. package/dist/adapters/grpc/types.js +7 -0
  38. package/dist/adapters/grpc/types.js.map +1 -0
  39. package/dist/adapters/index.d.ts +39 -0
  40. package/dist/adapters/index.d.ts.map +1 -0
  41. package/dist/adapters/index.js +50 -0
  42. package/dist/adapters/index.js.map +1 -0
  43. package/dist/adapters/mcp.d.ts +23 -0
  44. package/dist/adapters/mcp.d.ts.map +1 -0
  45. package/dist/adapters/mcp.js +293 -0
  46. package/dist/adapters/mcp.js.map +1 -0
  47. package/dist/adapters/openapi/adapter.d.ts +213 -0
  48. package/dist/adapters/openapi/adapter.d.ts.map +1 -0
  49. package/dist/adapters/openapi/adapter.js +557 -0
  50. package/dist/adapters/openapi/adapter.js.map +1 -0
  51. package/dist/adapters/openapi/convert.d.ts +120 -0
  52. package/dist/adapters/openapi/convert.d.ts.map +1 -0
  53. package/dist/adapters/openapi/convert.js +363 -0
  54. package/dist/adapters/openapi/convert.js.map +1 -0
  55. package/dist/adapters/openapi/index.d.ts +39 -0
  56. package/dist/adapters/openapi/index.d.ts.map +1 -0
  57. package/dist/adapters/openapi/index.js +48 -0
  58. package/dist/adapters/openapi/index.js.map +1 -0
  59. package/dist/adapters/openapi/parser.d.ts +95 -0
  60. package/dist/adapters/openapi/parser.d.ts.map +1 -0
  61. package/dist/adapters/openapi/parser.js +171 -0
  62. package/dist/adapters/openapi/parser.js.map +1 -0
  63. package/dist/adapters/registry.d.ts +116 -0
  64. package/dist/adapters/registry.d.ts.map +1 -0
  65. package/dist/adapters/registry.js +246 -0
  66. package/dist/adapters/registry.js.map +1 -0
  67. package/dist/adapters/trpc/adapter.d.ts +159 -0
  68. package/dist/adapters/trpc/adapter.d.ts.map +1 -0
  69. package/dist/adapters/trpc/adapter.js +223 -0
  70. package/dist/adapters/trpc/adapter.js.map +1 -0
  71. package/dist/adapters/trpc/extractor.d.ts +218 -0
  72. package/dist/adapters/trpc/extractor.d.ts.map +1 -0
  73. package/dist/adapters/trpc/extractor.js +708 -0
  74. package/dist/adapters/trpc/extractor.js.map +1 -0
  75. package/dist/adapters/trpc/index.d.ts +31 -0
  76. package/dist/adapters/trpc/index.d.ts.map +1 -0
  77. package/dist/adapters/trpc/index.js +40 -0
  78. package/dist/adapters/trpc/index.js.map +1 -0
  79. package/dist/adapters/trpc/parser.d.ts +119 -0
  80. package/dist/adapters/trpc/parser.d.ts.map +1 -0
  81. package/dist/adapters/trpc/parser.js +128 -0
  82. package/dist/adapters/trpc/parser.js.map +1 -0
  83. package/dist/compare/index.d.ts +33 -0
  84. package/dist/compare/index.d.ts.map +1 -0
  85. package/dist/compare/index.js +261 -0
  86. package/dist/compare/index.js.map +1 -0
  87. package/dist/core/types.d.ts +188 -0
  88. package/dist/core/types.d.ts.map +1 -0
  89. package/dist/core/types.js +9 -0
  90. package/dist/core/types.js.map +1 -0
  91. package/dist/extract/index.d.ts +26 -0
  92. package/dist/extract/index.d.ts.map +1 -0
  93. package/dist/extract/index.js +44 -0
  94. package/dist/extract/index.js.map +1 -0
  95. package/dist/index.d.ts +9 -0
  96. package/dist/index.d.ts.map +1 -0
  97. package/dist/index.js +674 -0
  98. package/dist/index.js.map +1 -0
  99. package/dist/languages/base.d.ts +57 -0
  100. package/dist/languages/base.d.ts.map +1 -0
  101. package/dist/languages/base.js +6 -0
  102. package/dist/languages/base.js.map +1 -0
  103. package/dist/languages/bootstrap.d.ts +10 -0
  104. package/dist/languages/bootstrap.d.ts.map +1 -0
  105. package/dist/languages/bootstrap.js +25 -0
  106. package/dist/languages/bootstrap.js.map +1 -0
  107. package/dist/languages/go/handlers/chi.d.ts +24 -0
  108. package/dist/languages/go/handlers/chi.d.ts.map +1 -0
  109. package/dist/languages/go/handlers/chi.js +205 -0
  110. package/dist/languages/go/handlers/chi.js.map +1 -0
  111. package/dist/languages/go/handlers/gin.d.ts +24 -0
  112. package/dist/languages/go/handlers/gin.d.ts.map +1 -0
  113. package/dist/languages/go/handlers/gin.js +156 -0
  114. package/dist/languages/go/handlers/gin.js.map +1 -0
  115. package/dist/languages/go/handlers/stdlib.d.ts +19 -0
  116. package/dist/languages/go/handlers/stdlib.d.ts.map +1 -0
  117. package/dist/languages/go/handlers/stdlib.js +112 -0
  118. package/dist/languages/go/handlers/stdlib.js.map +1 -0
  119. package/dist/languages/go/index.d.ts +18 -0
  120. package/dist/languages/go/index.d.ts.map +1 -0
  121. package/dist/languages/go/index.js +20 -0
  122. package/dist/languages/go/index.js.map +1 -0
  123. package/dist/languages/go/parser.d.ts +33 -0
  124. package/dist/languages/go/parser.d.ts.map +1 -0
  125. package/dist/languages/go/parser.js +95 -0
  126. package/dist/languages/go/parser.js.map +1 -0
  127. package/dist/languages/go/struct-extractor.d.ts +59 -0
  128. package/dist/languages/go/struct-extractor.d.ts.map +1 -0
  129. package/dist/languages/go/struct-extractor.js +483 -0
  130. package/dist/languages/go/struct-extractor.js.map +1 -0
  131. package/dist/languages/go/tag-parser.d.ts +62 -0
  132. package/dist/languages/go/tag-parser.d.ts.map +1 -0
  133. package/dist/languages/go/tag-parser.js +108 -0
  134. package/dist/languages/go/tag-parser.js.map +1 -0
  135. package/dist/languages/go/type-converter.d.ts +32 -0
  136. package/dist/languages/go/type-converter.d.ts.map +1 -0
  137. package/dist/languages/go/type-converter.js +226 -0
  138. package/dist/languages/go/type-converter.js.map +1 -0
  139. package/dist/languages/go/types.d.ts +153 -0
  140. package/dist/languages/go/types.d.ts.map +1 -0
  141. package/dist/languages/go/types.js +6 -0
  142. package/dist/languages/go/types.js.map +1 -0
  143. package/dist/languages/import-resolver.d.ts +645 -0
  144. package/dist/languages/import-resolver.d.ts.map +1 -0
  145. package/dist/languages/import-resolver.js +1278 -0
  146. package/dist/languages/import-resolver.js.map +1 -0
  147. package/dist/languages/index.d.ts +34 -0
  148. package/dist/languages/index.d.ts.map +1 -0
  149. package/dist/languages/index.js +93 -0
  150. package/dist/languages/index.js.map +1 -0
  151. package/dist/languages/json-schema.d.ts +40 -0
  152. package/dist/languages/json-schema.d.ts.map +1 -0
  153. package/dist/languages/json-schema.js +188 -0
  154. package/dist/languages/json-schema.js.map +1 -0
  155. package/dist/languages/python-ast/index.d.ts +8 -0
  156. package/dist/languages/python-ast/index.d.ts.map +1 -0
  157. package/dist/languages/python-ast/index.js +7 -0
  158. package/dist/languages/python-ast/index.js.map +1 -0
  159. package/dist/languages/python-ast/parser.d.ts +174 -0
  160. package/dist/languages/python-ast/parser.d.ts.map +1 -0
  161. package/dist/languages/python-ast/parser.js +1205 -0
  162. package/dist/languages/python-ast/parser.js.map +1 -0
  163. package/dist/languages/python-ast/type-resolver.d.ts +75 -0
  164. package/dist/languages/python-ast/type-resolver.d.ts.map +1 -0
  165. package/dist/languages/python-ast/type-resolver.js +421 -0
  166. package/dist/languages/python-ast/type-resolver.js.map +1 -0
  167. package/dist/languages/python-ast/types.d.ts +216 -0
  168. package/dist/languages/python-ast/types.d.ts.map +1 -0
  169. package/dist/languages/python-ast/types.js +6 -0
  170. package/dist/languages/python-ast/types.js.map +1 -0
  171. package/dist/languages/python.d.ts +55 -0
  172. package/dist/languages/python.d.ts.map +1 -0
  173. package/dist/languages/python.js +311 -0
  174. package/dist/languages/python.js.map +1 -0
  175. package/dist/languages/typescript.d.ts +272 -0
  176. package/dist/languages/typescript.d.ts.map +1 -0
  177. package/dist/languages/typescript.js +1381 -0
  178. package/dist/languages/typescript.js.map +1 -0
  179. package/dist/patterns/base.d.ts +146 -0
  180. package/dist/patterns/base.d.ts.map +1 -0
  181. package/dist/patterns/base.js +89 -0
  182. package/dist/patterns/base.js.map +1 -0
  183. package/dist/patterns/errors.d.ts +172 -0
  184. package/dist/patterns/errors.d.ts.map +1 -0
  185. package/dist/patterns/errors.js +185 -0
  186. package/dist/patterns/errors.js.map +1 -0
  187. package/dist/patterns/extractors.d.ts +170 -0
  188. package/dist/patterns/extractors.d.ts.map +1 -0
  189. package/dist/patterns/extractors.js +305 -0
  190. package/dist/patterns/extractors.js.map +1 -0
  191. package/dist/patterns/graphql/apollo-client.d.ts +80 -0
  192. package/dist/patterns/graphql/apollo-client.d.ts.map +1 -0
  193. package/dist/patterns/graphql/apollo-client.js +800 -0
  194. package/dist/patterns/graphql/apollo-client.js.map +1 -0
  195. package/dist/patterns/graphql/apollo-server.d.ts +55 -0
  196. package/dist/patterns/graphql/apollo-server.d.ts.map +1 -0
  197. package/dist/patterns/graphql/apollo-server.js +523 -0
  198. package/dist/patterns/graphql/apollo-server.js.map +1 -0
  199. package/dist/patterns/graphql/index.d.ts +11 -0
  200. package/dist/patterns/graphql/index.d.ts.map +1 -0
  201. package/dist/patterns/graphql/index.js +12 -0
  202. package/dist/patterns/graphql/index.js.map +1 -0
  203. package/dist/patterns/graphql/types.d.ts +213 -0
  204. package/dist/patterns/graphql/types.d.ts.map +1 -0
  205. package/dist/patterns/graphql/types.js +16 -0
  206. package/dist/patterns/graphql/types.js.map +1 -0
  207. package/dist/patterns/http-clients/axios.d.ts +148 -0
  208. package/dist/patterns/http-clients/axios.d.ts.map +1 -0
  209. package/dist/patterns/http-clients/axios.js +652 -0
  210. package/dist/patterns/http-clients/axios.js.map +1 -0
  211. package/dist/patterns/http-clients/fetch.d.ts +88 -0
  212. package/dist/patterns/http-clients/fetch.d.ts.map +1 -0
  213. package/dist/patterns/http-clients/fetch.js +364 -0
  214. package/dist/patterns/http-clients/fetch.js.map +1 -0
  215. package/dist/patterns/http-clients/index.d.ts +36 -0
  216. package/dist/patterns/http-clients/index.d.ts.map +1 -0
  217. package/dist/patterns/http-clients/index.js +50 -0
  218. package/dist/patterns/http-clients/index.js.map +1 -0
  219. package/dist/patterns/http-clients/property-access.d.ts +46 -0
  220. package/dist/patterns/http-clients/property-access.d.ts.map +1 -0
  221. package/dist/patterns/http-clients/property-access.js +818 -0
  222. package/dist/patterns/http-clients/property-access.js.map +1 -0
  223. package/dist/patterns/http-clients/type-inference.d.ts +48 -0
  224. package/dist/patterns/http-clients/type-inference.d.ts.map +1 -0
  225. package/dist/patterns/http-clients/type-inference.js +293 -0
  226. package/dist/patterns/http-clients/type-inference.js.map +1 -0
  227. package/dist/patterns/http-clients/types.d.ts +168 -0
  228. package/dist/patterns/http-clients/types.d.ts.map +1 -0
  229. package/dist/patterns/http-clients/types.js +10 -0
  230. package/dist/patterns/http-clients/types.js.map +1 -0
  231. package/dist/patterns/http-clients/url-extractor.d.ts +53 -0
  232. package/dist/patterns/http-clients/url-extractor.d.ts.map +1 -0
  233. package/dist/patterns/http-clients/url-extractor.js +338 -0
  234. package/dist/patterns/http-clients/url-extractor.js.map +1 -0
  235. package/dist/patterns/index.d.ts +44 -0
  236. package/dist/patterns/index.d.ts.map +1 -0
  237. package/dist/patterns/index.js +49 -0
  238. package/dist/patterns/index.js.map +1 -0
  239. package/dist/patterns/python/aiohttp.d.ts +21 -0
  240. package/dist/patterns/python/aiohttp.d.ts.map +1 -0
  241. package/dist/patterns/python/aiohttp.js +188 -0
  242. package/dist/patterns/python/aiohttp.js.map +1 -0
  243. package/dist/patterns/python/httpx.d.ts +20 -0
  244. package/dist/patterns/python/httpx.d.ts.map +1 -0
  245. package/dist/patterns/python/httpx.js +183 -0
  246. package/dist/patterns/python/httpx.js.map +1 -0
  247. package/dist/patterns/python/index.d.ts +32 -0
  248. package/dist/patterns/python/index.d.ts.map +1 -0
  249. package/dist/patterns/python/index.js +63 -0
  250. package/dist/patterns/python/index.js.map +1 -0
  251. package/dist/patterns/python/property-access.d.ts +27 -0
  252. package/dist/patterns/python/property-access.d.ts.map +1 -0
  253. package/dist/patterns/python/property-access.js +132 -0
  254. package/dist/patterns/python/property-access.js.map +1 -0
  255. package/dist/patterns/python/requests.d.ts +19 -0
  256. package/dist/patterns/python/requests.d.ts.map +1 -0
  257. package/dist/patterns/python/requests.js +239 -0
  258. package/dist/patterns/python/requests.js.map +1 -0
  259. package/dist/patterns/python/types.d.ts +95 -0
  260. package/dist/patterns/python/types.d.ts.map +1 -0
  261. package/dist/patterns/python/types.js +43 -0
  262. package/dist/patterns/python/types.js.map +1 -0
  263. package/dist/patterns/registry.d.ts +181 -0
  264. package/dist/patterns/registry.d.ts.map +1 -0
  265. package/dist/patterns/registry.js +304 -0
  266. package/dist/patterns/registry.js.map +1 -0
  267. package/dist/patterns/rest/express.d.ts +78 -0
  268. package/dist/patterns/rest/express.d.ts.map +1 -0
  269. package/dist/patterns/rest/express.js +289 -0
  270. package/dist/patterns/rest/express.js.map +1 -0
  271. package/dist/patterns/rest/fastify.d.ts +93 -0
  272. package/dist/patterns/rest/fastify.d.ts.map +1 -0
  273. package/dist/patterns/rest/fastify.js +420 -0
  274. package/dist/patterns/rest/fastify.js.map +1 -0
  275. package/dist/patterns/rest/index.d.ts +31 -0
  276. package/dist/patterns/rest/index.d.ts.map +1 -0
  277. package/dist/patterns/rest/index.js +45 -0
  278. package/dist/patterns/rest/index.js.map +1 -0
  279. package/dist/patterns/rest/middleware.d.ts +25 -0
  280. package/dist/patterns/rest/middleware.d.ts.map +1 -0
  281. package/dist/patterns/rest/middleware.js +219 -0
  282. package/dist/patterns/rest/middleware.js.map +1 -0
  283. package/dist/patterns/rest/path-parser.d.ts +50 -0
  284. package/dist/patterns/rest/path-parser.d.ts.map +1 -0
  285. package/dist/patterns/rest/path-parser.js +137 -0
  286. package/dist/patterns/rest/path-parser.js.map +1 -0
  287. package/dist/patterns/rest/response-inference.d.ts +44 -0
  288. package/dist/patterns/rest/response-inference.d.ts.map +1 -0
  289. package/dist/patterns/rest/response-inference.js +218 -0
  290. package/dist/patterns/rest/response-inference.js.map +1 -0
  291. package/dist/patterns/rest/types.d.ts +102 -0
  292. package/dist/patterns/rest/types.d.ts.map +1 -0
  293. package/dist/patterns/rest/types.js +10 -0
  294. package/dist/patterns/rest/types.js.map +1 -0
  295. package/dist/patterns/types.d.ts +105 -0
  296. package/dist/patterns/types.d.ts.map +1 -0
  297. package/dist/patterns/types.js +11 -0
  298. package/dist/patterns/types.js.map +1 -0
  299. package/dist/report/index.d.ts +11 -0
  300. package/dist/report/index.d.ts.map +1 -0
  301. package/dist/report/index.js +55 -0
  302. package/dist/report/index.js.map +1 -0
  303. package/dist/tools/contract-comments.d.ts +48 -0
  304. package/dist/tools/contract-comments.d.ts.map +1 -0
  305. package/dist/tools/contract-comments.js +130 -0
  306. package/dist/tools/contract-comments.js.map +1 -0
  307. package/dist/tools/index.d.ts +6 -0
  308. package/dist/tools/index.d.ts.map +1 -0
  309. package/dist/tools/index.js +6 -0
  310. package/dist/tools/index.js.map +1 -0
  311. package/dist/tools/scaffold.d.ts +38 -0
  312. package/dist/tools/scaffold.d.ts.map +1 -0
  313. package/dist/tools/scaffold.js +373 -0
  314. package/dist/tools/scaffold.js.map +1 -0
  315. package/dist/trace/index.d.ts +28 -0
  316. package/dist/trace/index.d.ts.map +1 -0
  317. package/dist/trace/index.js +45 -0
  318. package/dist/trace/index.js.map +1 -0
  319. package/dist/types.d.ts +135 -0
  320. package/dist/types.d.ts.map +1 -0
  321. package/dist/types.js +22 -0
  322. package/dist/types.js.map +1 -0
  323. package/dist/watch/cache.d.ts +41 -0
  324. package/dist/watch/cache.d.ts.map +1 -0
  325. package/dist/watch/cache.js +230 -0
  326. package/dist/watch/cache.js.map +1 -0
  327. package/dist/watch/index.d.ts +9 -0
  328. package/dist/watch/index.d.ts.map +1 -0
  329. package/dist/watch/index.js +7 -0
  330. package/dist/watch/index.js.map +1 -0
  331. package/dist/watch/project.d.ts +128 -0
  332. package/dist/watch/project.d.ts.map +1 -0
  333. package/dist/watch/project.js +152 -0
  334. package/dist/watch/project.js.map +1 -0
  335. package/dist/watch/watcher.d.ts +76 -0
  336. package/dist/watch/watcher.d.ts.map +1 -0
  337. package/dist/watch/watcher.js +235 -0
  338. package/dist/watch/watcher.js.map +1 -0
  339. package/package.json +70 -0
@@ -0,0 +1,130 @@
1
+ /**
2
+ * Contract Comments Tool
3
+ * Adds cross-reference comments to producer and consumer code
4
+ * when a contract is validated as working.
5
+ */
6
+ import { Project, SyntaxKind } from 'ts-morph';
7
+ /**
8
+ * Generate cross-reference comments for a validated contract
9
+ */
10
+ export function generateContractComments(options) {
11
+ const { match, producer, consumer, style = 'block', includeTimestamp = true, prefix = '@trace-contract' } = options;
12
+ const timestamp = includeTimestamp ? ` | Validated: ${new Date().toISOString().split('T')[0]}` : '';
13
+ // Producer comment points to consumer
14
+ const producerComment = formatComment({
15
+ style,
16
+ lines: [
17
+ `${prefix} PRODUCER`,
18
+ `Tool: ${match.toolName}`,
19
+ `Consumer: ${consumer.callSite.file}:${consumer.callSite.line}`,
20
+ `Args: ${Object.keys(consumer.argumentsProvided).join(', ')}`,
21
+ `Expected Props: ${consumer.expectedProperties.slice(0, 5).join(', ')}${consumer.expectedProperties.length > 5 ? '...' : ''}`,
22
+ timestamp ? `Validated: ${timestamp}` : '',
23
+ ].filter(Boolean),
24
+ });
25
+ // Consumer comment points to producer
26
+ const consumerComment = formatComment({
27
+ style,
28
+ lines: [
29
+ `${prefix} CONSUMER`,
30
+ `Tool: ${match.toolName}`,
31
+ `Producer: ${producer.location.file}:${producer.location.line}`,
32
+ `Required Args: ${producer.inputSchema.required?.join(', ') || 'none'}`,
33
+ `Schema Props: ${Object.keys(producer.inputSchema.properties || {}).join(', ')}`,
34
+ timestamp ? `Validated: ${timestamp}` : '',
35
+ ].filter(Boolean),
36
+ });
37
+ return { producerComment, consumerComment };
38
+ }
39
+ /**
40
+ * Format a comment based on style
41
+ */
42
+ function formatComment(options) {
43
+ const { style, lines } = options;
44
+ switch (style) {
45
+ case 'jsdoc':
46
+ return `/**\n${lines.map(l => ` * ${l}`).join('\n')}\n */`;
47
+ case 'inline':
48
+ return lines.map(l => `// ${l}`).join('\n');
49
+ case 'block':
50
+ default:
51
+ return `/*\n${lines.map(l => ` * ${l}`).join('\n')}\n */`;
52
+ }
53
+ }
54
+ /**
55
+ * Add contract comments to source files
56
+ * WARNING: This modifies files! Use with caution.
57
+ */
58
+ export async function addContractComments(options) {
59
+ const { match, producer, consumer } = options;
60
+ const { producerComment, consumerComment } = generateContractComments(options);
61
+ const project = new Project({
62
+ skipAddingFilesFromTsConfig: true,
63
+ });
64
+ try {
65
+ // Add comment to producer file
66
+ const producerFile = project.addSourceFileAtPath(producer.location.file);
67
+ const producerNode = findNodeAtLine(producerFile, producer.location.line);
68
+ if (producerNode) {
69
+ // Add comment before the tool definition
70
+ producerNode.replaceWithText(`${producerComment}\n${producerNode.getText()}`);
71
+ }
72
+ // Add comment to consumer file
73
+ const consumerFile = project.addSourceFileAtPath(consumer.callSite.file);
74
+ const consumerNode = findNodeAtLine(consumerFile, consumer.callSite.line);
75
+ if (consumerNode) {
76
+ // Add comment before the callTool invocation
77
+ consumerNode.replaceWithText(`${consumerComment}\n${consumerNode.getText()}`);
78
+ }
79
+ // Save changes
80
+ await project.save();
81
+ return {
82
+ success: true,
83
+ producerFile: producer.location.file,
84
+ consumerFile: consumer.callSite.file,
85
+ producerComment,
86
+ consumerComment,
87
+ };
88
+ }
89
+ catch (error) {
90
+ return {
91
+ success: false,
92
+ producerFile: producer.location.file,
93
+ consumerFile: consumer.callSite.file,
94
+ producerComment,
95
+ consumerComment,
96
+ error: error instanceof Error ? error.message : String(error),
97
+ };
98
+ }
99
+ }
100
+ /**
101
+ * Find the statement node at a specific line
102
+ */
103
+ function findNodeAtLine(sourceFile, line) {
104
+ let targetNode = null;
105
+ sourceFile.forEachDescendant((node) => {
106
+ if (node.getStartLineNumber() === line) {
107
+ // Prefer statement-level nodes
108
+ const parent = node.getParent();
109
+ if (parent && parent.getKind() === SyntaxKind.ExpressionStatement) {
110
+ targetNode = parent;
111
+ }
112
+ else if (!targetNode) {
113
+ targetNode = node;
114
+ }
115
+ }
116
+ });
117
+ return targetNode;
118
+ }
119
+ /**
120
+ * Preview what comments would be added without modifying files
121
+ */
122
+ export function previewContractComments(options) {
123
+ const { producerComment, consumerComment } = generateContractComments(options);
124
+ const { producer, consumer } = options;
125
+ return {
126
+ producerPreview: `// At ${producer.location.file}:${producer.location.line}\n${producerComment}`,
127
+ consumerPreview: `// At ${consumer.callSite.file}:${consumer.callSite.line}\n${consumerComment}`,
128
+ };
129
+ }
130
+ //# sourceMappingURL=contract-comments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contract-comments.js","sourceRoot":"","sources":["../../src/tools/contract-comments.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Tools module exports
3
+ */
4
+ export { generateContractComments, addContractComments, previewContractComments, type ContractCommentOptions, type CommentResult, } from './contract-comments.js';
5
+ export { scaffoldConsumerFromProducer, scaffoldProducerFromConsumer, type ScaffoldOptions, type ScaffoldResult, } from './scaffold.js';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACnB,uBAAuB,EACvB,KAAK,sBAAsB,EAC3B,KAAK,aAAa,GACnB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,4BAA4B,EAC5B,4BAA4B,EAC5B,KAAK,eAAe,EACpB,KAAK,cAAc,GACpB,MAAM,eAAe,CAAC"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Tools module exports
3
+ */
4
+ export { generateContractComments, addContractComments, previewContractComments, } from './contract-comments.js';
5
+ export { scaffoldConsumerFromProducer, scaffoldProducerFromConsumer, } from './scaffold.js';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,wBAAwB,EACxB,mBAAmB,EACnB,uBAAuB,GAGxB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,4BAA4B,EAC5B,4BAA4B,GAG7B,MAAM,eAAe,CAAC"}
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Contract Scaffold Tool
3
+ * Generate consumer code from producer schema (or vice versa)
4
+ */
5
+ import type { ProducerSchema, ConsumerSchema } from '../types.js';
6
+ export interface ScaffoldOptions {
7
+ /** Output language/framework */
8
+ target: 'typescript' | 'javascript' | 'react-hook' | 'zustand-action';
9
+ /** Include error handling */
10
+ includeErrorHandling?: boolean;
11
+ /** Include TypeScript types */
12
+ includeTypes?: boolean;
13
+ /** Function name prefix */
14
+ functionPrefix?: string;
15
+ /** Add JSDoc comments */
16
+ includeJSDoc?: boolean;
17
+ }
18
+ export interface ScaffoldResult {
19
+ /** Generated code */
20
+ code: string;
21
+ /** Suggested filename */
22
+ suggestedFilename: string;
23
+ /** TypeScript type definitions (if applicable) */
24
+ types?: string;
25
+ /** Usage example */
26
+ example: string;
27
+ }
28
+ /**
29
+ * Generate consumer code from a producer schema
30
+ */
31
+ export declare function scaffoldConsumerFromProducer(producer: ProducerSchema, options?: ScaffoldOptions): ScaffoldResult;
32
+ /**
33
+ * Generate producer schema stub from consumer usage
34
+ */
35
+ export declare function scaffoldProducerFromConsumer(consumer: ConsumerSchema, options?: {
36
+ includeHandler?: boolean;
37
+ }): ScaffoldResult;
38
+ //# sourceMappingURL=scaffold.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scaffold.d.ts","sourceRoot":"","sources":["../../src/tools/scaffold.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAc,MAAM,aAAa,CAAC;AAE9E,MAAM,WAAW,eAAe;IAC9B,gCAAgC;IAChC,MAAM,EAAE,YAAY,GAAG,YAAY,GAAG,YAAY,GAAG,gBAAgB,CAAC;IACtE,6BAA6B;IAC7B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,+BAA+B;IAC/B,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,2BAA2B;IAC3B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,yBAAyB;IACzB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,cAAc;IAC7B,qBAAqB;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,yBAAyB;IACzB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,kDAAkD;IAClD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,oBAAoB;IACpB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED;;GAEG;AACH,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,cAAc,EACxB,OAAO,GAAE,eAA0C,GAClD,cAAc,CAyChB;AAED;;GAEG;AACH,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,cAAc,EACxB,OAAO,GAAE;IAAE,cAAc,CAAC,EAAE,OAAO,CAAA;CAAO,GACzC,cAAc,CA2ChB"}
@@ -0,0 +1,373 @@
1
+ /**
2
+ * Contract Scaffold Tool
3
+ * Generate consumer code from producer schema (or vice versa)
4
+ */
5
+ /**
6
+ * Generate consumer code from a producer schema
7
+ */
8
+ export function scaffoldConsumerFromProducer(producer, options = { target: 'typescript' }) {
9
+ const { target, includeErrorHandling = true, includeTypes = true, functionPrefix = '', includeJSDoc = true } = options;
10
+ const toolName = producer.toolName;
11
+ const functionName = `${functionPrefix}${toCamelCase(toolName)}`;
12
+ const inputProps = producer.inputSchema.properties || {};
13
+ const requiredArgs = producer.inputSchema.required || [];
14
+ // Generate TypeScript interface for args
15
+ const argsInterface = generateArgsInterface(toolName, inputProps, requiredArgs);
16
+ // Generate the function based on target
17
+ let code;
18
+ let types;
19
+ let example;
20
+ switch (target) {
21
+ case 'react-hook':
22
+ ({ code, types, example } = generateReactHook(toolName, functionName, inputProps, requiredArgs, { includeErrorHandling, includeTypes, includeJSDoc, producer }));
23
+ break;
24
+ case 'zustand-action':
25
+ ({ code, types, example } = generateZustandAction(toolName, functionName, inputProps, requiredArgs, { includeErrorHandling, includeTypes, includeJSDoc, producer }));
26
+ break;
27
+ case 'javascript':
28
+ const jsResult = generateJavaScript(toolName, functionName, inputProps, requiredArgs, { includeErrorHandling, includeJSDoc, producer });
29
+ code = jsResult.code;
30
+ example = jsResult.example;
31
+ types = undefined;
32
+ break;
33
+ case 'typescript':
34
+ default:
35
+ ({ code, types, example } = generateTypeScript(toolName, functionName, inputProps, requiredArgs, { includeErrorHandling, includeTypes, includeJSDoc, producer }));
36
+ break;
37
+ }
38
+ return {
39
+ code,
40
+ suggestedFilename: `use-${toKebabCase(toolName)}.${target === 'javascript' ? 'js' : 'ts'}`,
41
+ types,
42
+ example,
43
+ };
44
+ }
45
+ /**
46
+ * Generate producer schema stub from consumer usage
47
+ */
48
+ export function scaffoldProducerFromConsumer(consumer, options = {}) {
49
+ const { includeHandler = true } = options;
50
+ const toolName = consumer.toolName;
51
+ const args = consumer.argumentsProvided;
52
+ // Infer types from argument values (basic inference)
53
+ const inferredSchema = inferSchemaFromArgs(args);
54
+ const code = `
55
+ import { z } from 'zod';
56
+
57
+ // Tool: ${toolName}
58
+ // Scaffolded from consumer at ${consumer.callSite.file}:${consumer.callSite.line}
59
+ // @trace-contract PRODUCER (scaffolded)
60
+
61
+ server.tool(
62
+ '${toolName}',
63
+ 'TODO: Add description',
64
+ {
65
+ ${Object.entries(inferredSchema)
66
+ .map(([key, type]) => ` ${key}: ${type},`)
67
+ .join('\n')}
68
+ },
69
+ ${includeHandler ? ` async (args) => {
70
+ // TODO: Implement handler
71
+ // Consumer expects these properties: ${consumer.expectedProperties.join(', ')}
72
+ return {
73
+ content: [{
74
+ type: 'text',
75
+ text: JSON.stringify({
76
+ ${consumer.expectedProperties.map(p => ` ${p}: null, // TODO`).join('\n')}
77
+ })
78
+ }]
79
+ };
80
+ }` : ' async (args) => { /* TODO */ }'}
81
+ );
82
+ `.trim();
83
+ return {
84
+ code,
85
+ suggestedFilename: `${toKebabCase(toolName)}-tool.ts`,
86
+ example: `// This tool is called by:\n// ${consumer.callSite.file}:${consumer.callSite.line}`,
87
+ };
88
+ }
89
+ // ============================================================================
90
+ // Generator Functions
91
+ // ============================================================================
92
+ function generateTypeScript(toolName, functionName, inputProps, requiredArgs, options) {
93
+ const { includeErrorHandling, includeTypes, includeJSDoc, producer } = options;
94
+ const argsType = `${toPascalCase(toolName)}Args`;
95
+ const resultType = `${toPascalCase(toolName)}Result`;
96
+ const types = includeTypes ? `
97
+ export interface ${argsType} {
98
+ ${Object.entries(inputProps)
99
+ .map(([key, schema]) => ` ${key}${requiredArgs.includes(key) ? '' : '?'}: ${jsonSchemaToTsType(schema)};`)
100
+ .join('\n')}
101
+ }
102
+
103
+ export interface ${resultType} {
104
+ // TODO: Define based on actual response
105
+ [key: string]: unknown;
106
+ }
107
+ `.trim() : undefined;
108
+ const jsdoc = includeJSDoc ? `
109
+ /**
110
+ * ${producer.description || `Call the ${toolName} tool`}
111
+ * @trace-contract CONSUMER
112
+ * Producer: ${producer.location.file}:${producer.location.line}
113
+ */` : '';
114
+ const code = `
115
+ ${jsdoc}
116
+ export async function ${functionName}(
117
+ client: McpClient,
118
+ args: ${includeTypes ? argsType : `{ ${Object.keys(inputProps).join(', ')} }`}
119
+ ): Promise<${includeTypes ? resultType : 'unknown'}> {
120
+ ${includeErrorHandling ? ` try {
121
+ const result = await client.callTool('${toolName}', args);
122
+ return JSON.parse(result.content[0].text);
123
+ } catch (error) {
124
+ console.error('Error calling ${toolName}:', error);
125
+ throw error;
126
+ }` : ` const result = await client.callTool('${toolName}', args);
127
+ return JSON.parse(result.content[0].text);`}
128
+ }
129
+ `.trim();
130
+ const example = `
131
+ // Usage:
132
+ const result = await ${functionName}(client, {
133
+ ${requiredArgs.map(arg => ` ${arg}: /* ${jsonSchemaToTsType(inputProps[arg])} */,`).join('\n')}
134
+ });
135
+ `.trim();
136
+ return { code, types, example };
137
+ }
138
+ function generateJavaScript(toolName, functionName, inputProps, requiredArgs, options) {
139
+ const { includeErrorHandling, includeJSDoc, producer } = options;
140
+ const jsdoc = includeJSDoc ? `
141
+ /**
142
+ * ${producer.description || `Call the ${toolName} tool`}
143
+ * @param {Object} client - MCP client
144
+ * @param {Object} args - Tool arguments
145
+ ${Object.entries(inputProps)
146
+ .map(([key, schema]) => ` * @param {${jsonSchemaToJsType(schema)}} args.${key}`)
147
+ .join('\n')}
148
+ * @returns {Promise<Object>}
149
+ */` : '';
150
+ const code = `
151
+ ${jsdoc}
152
+ export async function ${functionName}(client, args) {
153
+ ${includeErrorHandling ? ` try {
154
+ const result = await client.callTool('${toolName}', args);
155
+ return JSON.parse(result.content[0].text);
156
+ } catch (error) {
157
+ console.error('Error calling ${toolName}:', error);
158
+ throw error;
159
+ }` : ` const result = await client.callTool('${toolName}', args);
160
+ return JSON.parse(result.content[0].text);`}
161
+ }
162
+ `.trim();
163
+ const example = `
164
+ // Usage:
165
+ const result = await ${functionName}(client, {
166
+ ${requiredArgs.map(arg => ` ${arg}: /* value */,`).join('\n')}
167
+ });
168
+ `.trim();
169
+ return { code, example };
170
+ }
171
+ function generateReactHook(toolName, _functionName, inputProps, requiredArgs, options) {
172
+ const { includeTypes, producer } = options;
173
+ const hookName = `use${toPascalCase(toolName)}`;
174
+ const argsType = `${toPascalCase(toolName)}Args`;
175
+ const types = includeTypes ? `
176
+ export interface ${argsType} {
177
+ ${Object.entries(inputProps)
178
+ .map(([key, schema]) => ` ${key}${requiredArgs.includes(key) ? '' : '?'}: ${jsonSchemaToTsType(schema)};`)
179
+ .join('\n')}
180
+ }
181
+ `.trim() : undefined;
182
+ const code = `
183
+ import { useState, useCallback } from 'react';
184
+ import { useMcpClient } from './mcp-context'; // Adjust import
185
+
186
+ /**
187
+ * ${producer.description || `Hook for ${toolName} tool`}
188
+ * @trace-contract CONSUMER (React Hook)
189
+ * Producer: ${producer.location.file}:${producer.location.line}
190
+ */
191
+ export function ${hookName}() {
192
+ const client = useMcpClient();
193
+ const [loading, setLoading] = useState(false);
194
+ const [error, setError] = useState<Error | null>(null);
195
+ const [data, setData] = useState<unknown>(null);
196
+
197
+ const execute = useCallback(async (args: ${includeTypes ? argsType : 'Record<string, unknown>'}) => {
198
+ setLoading(true);
199
+ setError(null);
200
+ try {
201
+ const result = await client.callTool('${toolName}', args);
202
+ const parsed = JSON.parse(result.content[0].text);
203
+ setData(parsed);
204
+ return parsed;
205
+ } catch (err) {
206
+ setError(err instanceof Error ? err : new Error(String(err)));
207
+ throw err;
208
+ } finally {
209
+ setLoading(false);
210
+ }
211
+ }, [client]);
212
+
213
+ return { execute, loading, error, data };
214
+ }
215
+ `.trim();
216
+ const example = `
217
+ // Usage in React component:
218
+ function MyComponent() {
219
+ const { execute, loading, error, data } = ${hookName}();
220
+
221
+ const handleClick = async () => {
222
+ await execute({
223
+ ${requiredArgs.map(arg => ` ${arg}: /* value */,`).join('\n')}
224
+ });
225
+ };
226
+
227
+ if (loading) return <div>Loading...</div>;
228
+ if (error) return <div>Error: {error.message}</div>;
229
+ return <div>{JSON.stringify(data)}</div>;
230
+ }
231
+ `.trim();
232
+ return { code, types, example };
233
+ }
234
+ function generateZustandAction(toolName, _functionName, inputProps, requiredArgs, options) {
235
+ const { includeTypes, producer } = options;
236
+ const actionName = toCamelCase(toolName);
237
+ const argsType = `${toPascalCase(toolName)}Args`;
238
+ const types = includeTypes ? `
239
+ export interface ${argsType} {
240
+ ${Object.entries(inputProps)
241
+ .map(([key, schema]) => ` ${key}${requiredArgs.includes(key) ? '' : '?'}: ${jsonSchemaToTsType(schema)};`)
242
+ .join('\n')}
243
+ }
244
+ `.trim() : undefined;
245
+ const code = `
246
+ /**
247
+ * Zustand action for ${toolName}
248
+ * @trace-contract CONSUMER (Zustand)
249
+ * Producer: ${producer.location.file}:${producer.location.line}
250
+ */
251
+ export const create${toPascalCase(toolName)}Slice = (set: any, get: any) => ({
252
+ ${actionName}Loading: false,
253
+ ${actionName}Error: null as Error | null,
254
+ ${actionName}Data: null as unknown,
255
+
256
+ ${actionName}: async (args: ${includeTypes ? argsType : 'Record<string, unknown>'}) => {
257
+ const { mcpClient } = get();
258
+ set({ ${actionName}Loading: true, ${actionName}Error: null });
259
+
260
+ try {
261
+ const result = await mcpClient.callTool('${toolName}', args);
262
+ const data = JSON.parse(result.content[0].text);
263
+ set({ ${actionName}Data: data, ${actionName}Loading: false });
264
+ return data;
265
+ } catch (error) {
266
+ set({
267
+ ${actionName}Error: error instanceof Error ? error : new Error(String(error)),
268
+ ${actionName}Loading: false
269
+ });
270
+ throw error;
271
+ }
272
+ },
273
+ });
274
+ `.trim();
275
+ const example = `
276
+ // Add to your Zustand store:
277
+ import { create } from 'zustand';
278
+
279
+ const useStore = create((set, get) => ({
280
+ mcpClient: null,
281
+ setMcpClient: (client) => set({ mcpClient: client }),
282
+ ...create${toPascalCase(toolName)}Slice(set, get),
283
+ }));
284
+
285
+ // Usage:
286
+ const { ${actionName}, ${actionName}Loading, ${actionName}Data } = useStore();
287
+ await ${actionName}({
288
+ ${requiredArgs.map(arg => ` ${arg}: /* value */,`).join('\n')}
289
+ });
290
+ `.trim();
291
+ return { code, types, example };
292
+ }
293
+ // ============================================================================
294
+ // Utilities
295
+ // ============================================================================
296
+ function generateArgsInterface(toolName, props, required) {
297
+ const lines = Object.entries(props).map(([key, schema]) => {
298
+ const optional = required.includes(key) ? '' : '?';
299
+ const type = jsonSchemaToTsType(schema);
300
+ return ` ${key}${optional}: ${type};`;
301
+ });
302
+ return `interface ${toPascalCase(toolName)}Args {\n${lines.join('\n')}\n}`;
303
+ }
304
+ function jsonSchemaToTsType(schema) {
305
+ if (!schema.type)
306
+ return 'unknown';
307
+ switch (schema.type) {
308
+ case 'string':
309
+ if (schema.enum && Array.isArray(schema.enum)) {
310
+ return schema.enum.map((v) => `'${v}'`).join(' | ');
311
+ }
312
+ return 'string';
313
+ case 'number':
314
+ case 'integer':
315
+ return 'number';
316
+ case 'boolean':
317
+ return 'boolean';
318
+ case 'array':
319
+ return `${jsonSchemaToTsType(schema.items || {})}[]`;
320
+ case 'object':
321
+ return 'Record<string, unknown>';
322
+ default:
323
+ return 'unknown';
324
+ }
325
+ }
326
+ function jsonSchemaToJsType(schema) {
327
+ if (!schema.type)
328
+ return '*';
329
+ switch (schema.type) {
330
+ case 'string': return 'string';
331
+ case 'number':
332
+ case 'integer': return 'number';
333
+ case 'boolean': return 'boolean';
334
+ case 'array': return 'Array';
335
+ case 'object': return 'Object';
336
+ default: return '*';
337
+ }
338
+ }
339
+ function inferSchemaFromArgs(args) {
340
+ const schema = {};
341
+ for (const [key, value] of Object.entries(args)) {
342
+ if (typeof value === 'string' || value === '<value>') {
343
+ schema[key] = 'z.string()';
344
+ }
345
+ else if (typeof value === 'number') {
346
+ schema[key] = 'z.number()';
347
+ }
348
+ else if (typeof value === 'boolean') {
349
+ schema[key] = 'z.boolean()';
350
+ }
351
+ else if (Array.isArray(value)) {
352
+ schema[key] = 'z.array(z.unknown())';
353
+ }
354
+ else if (typeof value === 'object') {
355
+ schema[key] = 'z.object({})';
356
+ }
357
+ else {
358
+ schema[key] = 'z.unknown()';
359
+ }
360
+ }
361
+ return schema;
362
+ }
363
+ function toCamelCase(str) {
364
+ return str.replace(/_([a-z])/g, (_, c) => c.toUpperCase());
365
+ }
366
+ function toPascalCase(str) {
367
+ const camel = toCamelCase(str);
368
+ return camel.charAt(0).toUpperCase() + camel.slice(1);
369
+ }
370
+ function toKebabCase(str) {
371
+ return str.replace(/_/g, '-').toLowerCase();
372
+ }
373
+ //# sourceMappingURL=scaffold.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scaffold.js","sourceRoot":"","sources":["../../src/tools/scaffold.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Trace MCP - Consumer Tracer
3
+ * Thin wrapper that delegates to language-specific parsers
4
+ */
5
+ import type { ConsumerSchema } from '../types.js';
6
+ export interface TracerOptions {
7
+ /** Root directory of the consumer source */
8
+ rootDir: string;
9
+ /** Language of the source files */
10
+ language?: string;
11
+ /** Patterns to identify MCP client calls */
12
+ callPatterns?: string[];
13
+ /** Glob patterns to include */
14
+ include?: string[];
15
+ /** Glob patterns to exclude */
16
+ exclude?: string[];
17
+ }
18
+ /**
19
+ * Trace MCP tool usage in consumer code
20
+ * Defaults to TypeScript parser for backward compatibility
21
+ */
22
+ export declare function traceConsumerUsage(options: TracerOptions): Promise<ConsumerSchema[]>;
23
+ /**
24
+ * Trace usage from a single file
25
+ * Defaults to TypeScript parser for backward compatibility
26
+ */
27
+ export declare function traceFromFile(filePath: string, language?: string): Promise<ConsumerSchema[]>;
28
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/trace/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAGlD,MAAM,WAAW,aAAa;IAC5B,4CAA4C;IAC5C,OAAO,EAAE,MAAM,CAAC;IAChB,mCAAmC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,4CAA4C;IAC5C,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,+BAA+B;IAC/B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,+BAA+B;IAC/B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;;GAGG;AACH,wBAAsB,kBAAkB,CACtC,OAAO,EAAE,aAAa,GACrB,OAAO,CAAC,cAAc,EAAE,CAAC,CAmB3B;AAED;;;GAGG;AACH,wBAAsB,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,CAsBlG"}