@nanocollective/nanocoder 1.18.0 → 1.19.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 (603) hide show
  1. package/README.md +176 -8
  2. package/assets/nanocoder-vscode.vsix +0 -0
  3. package/dist/ai-sdk-client-empty-message.spec.js.map +1 -1
  4. package/dist/ai-sdk-client.d.ts +1 -1
  5. package/dist/ai-sdk-client.d.ts.map +1 -1
  6. package/dist/ai-sdk-client.js +261 -150
  7. package/dist/ai-sdk-client.js.map +1 -1
  8. package/dist/app/utils/appUtils.d.ts +1 -1
  9. package/dist/app/utils/appUtils.d.ts.map +1 -1
  10. package/dist/app/utils/appUtils.js +78 -12
  11. package/dist/app/utils/appUtils.js.map +1 -1
  12. package/dist/app.d.ts +22 -1
  13. package/dist/app.d.ts.map +1 -1
  14. package/dist/app.js +353 -48
  15. package/dist/app.js.map +1 -1
  16. package/dist/cli.js +37 -2
  17. package/dist/cli.js.map +1 -1
  18. package/dist/cli.spec.d.ts +2 -0
  19. package/dist/cli.spec.d.ts.map +1 -0
  20. package/dist/cli.spec.js +101 -0
  21. package/dist/cli.spec.js.map +1 -0
  22. package/dist/client-factory.d.ts.map +1 -1
  23. package/dist/client-factory.js +2 -2
  24. package/dist/client-factory.js.map +1 -1
  25. package/dist/commands/checkpoint.d.ts +6 -0
  26. package/dist/commands/checkpoint.d.ts.map +1 -0
  27. package/dist/commands/checkpoint.js +277 -0
  28. package/dist/commands/checkpoint.js.map +1 -0
  29. package/dist/commands/clear.d.ts.map +1 -1
  30. package/dist/commands/clear.js +1 -1
  31. package/dist/commands/clear.js.map +1 -1
  32. package/dist/commands/custom-commands.d.ts.map +1 -1
  33. package/dist/commands/custom-commands.js +4 -4
  34. package/dist/commands/custom-commands.js.map +1 -1
  35. package/dist/commands/exit.d.ts.map +1 -1
  36. package/dist/commands/exit.js.map +1 -1
  37. package/dist/commands/export.d.ts.map +1 -1
  38. package/dist/commands/export.js +2 -2
  39. package/dist/commands/export.js.map +1 -1
  40. package/dist/commands/help.d.ts.map +1 -1
  41. package/dist/commands/help.js +5 -5
  42. package/dist/commands/help.js.map +1 -1
  43. package/dist/commands/index.d.ts +1 -1
  44. package/dist/commands/index.d.ts.map +1 -1
  45. package/dist/commands/index.js +1 -1
  46. package/dist/commands/index.js.map +1 -1
  47. package/dist/commands/init.d.ts.map +1 -1
  48. package/dist/commands/init.js +15 -14
  49. package/dist/commands/init.js.map +1 -1
  50. package/dist/commands/lsp.d.ts.map +1 -1
  51. package/dist/commands/lsp.js +6 -6
  52. package/dist/commands/lsp.js.map +1 -1
  53. package/dist/commands/mcp.d.ts +1 -1
  54. package/dist/commands/mcp.d.ts.map +1 -1
  55. package/dist/commands/mcp.js +6 -6
  56. package/dist/commands/mcp.js.map +1 -1
  57. package/dist/commands/model-database.d.ts.map +1 -1
  58. package/dist/commands/model-database.js +8 -8
  59. package/dist/commands/model-database.js.map +1 -1
  60. package/dist/commands/model.d.ts.map +1 -1
  61. package/dist/commands/model.js.map +1 -1
  62. package/dist/commands/provider.d.ts.map +1 -1
  63. package/dist/commands/provider.js.map +1 -1
  64. package/dist/commands/setup-config.js +1 -1
  65. package/dist/commands/setup-config.js.map +1 -1
  66. package/dist/commands/status.d.ts.map +1 -1
  67. package/dist/commands/status.js.map +1 -1
  68. package/dist/commands/theme.d.ts.map +1 -1
  69. package/dist/commands/theme.js.map +1 -1
  70. package/dist/commands/update.d.ts.map +1 -1
  71. package/dist/commands/update.js +5 -5
  72. package/dist/commands/update.js.map +1 -1
  73. package/dist/commands/usage.d.ts.map +1 -1
  74. package/dist/commands/usage.js +3 -3
  75. package/dist/commands/usage.js.map +1 -1
  76. package/dist/commands.d.ts.map +1 -1
  77. package/dist/commands.js +1 -1
  78. package/dist/commands.js.map +1 -1
  79. package/dist/components/assistant-message.d.ts.map +1 -1
  80. package/dist/components/assistant-message.js +2 -2
  81. package/dist/components/assistant-message.js.map +1 -1
  82. package/dist/components/bash-execution-indicator.d.ts.map +1 -1
  83. package/dist/components/bash-execution-indicator.js +2 -2
  84. package/dist/components/bash-execution-indicator.js.map +1 -1
  85. package/dist/components/cancelling-indicator.js +3 -3
  86. package/dist/components/cancelling-indicator.js.map +1 -1
  87. package/dist/components/chat-queue.d.ts.map +1 -1
  88. package/dist/components/chat-queue.js +1 -1
  89. package/dist/components/chat-queue.js.map +1 -1
  90. package/dist/components/checkpoint-display.d.ts +8 -0
  91. package/dist/components/checkpoint-display.d.ts.map +1 -0
  92. package/dist/components/checkpoint-display.js +29 -0
  93. package/dist/components/checkpoint-display.js.map +1 -0
  94. package/dist/components/checkpoint-selector.d.ts +11 -0
  95. package/dist/components/checkpoint-selector.d.ts.map +1 -0
  96. package/dist/components/checkpoint-selector.js +55 -0
  97. package/dist/components/checkpoint-selector.js.map +1 -0
  98. package/dist/components/error-message.d.ts.map +1 -1
  99. package/dist/components/error-message.js +4 -4
  100. package/dist/components/error-message.js.map +1 -1
  101. package/dist/components/info-message.d.ts.map +1 -1
  102. package/dist/components/info-message.js +4 -4
  103. package/dist/components/info-message.js.map +1 -1
  104. package/dist/components/model-selector.d.ts.map +1 -1
  105. package/dist/components/model-selector.js +7 -7
  106. package/dist/components/model-selector.js.map +1 -1
  107. package/dist/components/provider-selector.d.ts.map +1 -1
  108. package/dist/components/provider-selector.js +6 -6
  109. package/dist/components/provider-selector.js.map +1 -1
  110. package/dist/components/security-disclaimer.d.ts.map +1 -1
  111. package/dist/components/security-disclaimer.js +4 -4
  112. package/dist/components/security-disclaimer.js.map +1 -1
  113. package/dist/components/status.d.ts +3 -1
  114. package/dist/components/status.d.ts.map +1 -1
  115. package/dist/components/status.js +17 -9
  116. package/dist/components/status.js.map +1 -1
  117. package/dist/components/success-message.d.ts.map +1 -1
  118. package/dist/components/success-message.js +4 -4
  119. package/dist/components/success-message.js.map +1 -1
  120. package/dist/components/theme-selector.d.ts.map +1 -1
  121. package/dist/components/theme-selector.js +8 -8
  122. package/dist/components/theme-selector.js.map +1 -1
  123. package/dist/components/tool-confirmation.d.ts.map +1 -1
  124. package/dist/components/tool-confirmation.js +7 -7
  125. package/dist/components/tool-confirmation.js.map +1 -1
  126. package/dist/components/tool-execution-indicator.d.ts.map +1 -1
  127. package/dist/components/tool-execution-indicator.js +2 -2
  128. package/dist/components/tool-execution-indicator.js.map +1 -1
  129. package/dist/components/tool-message.d.ts.map +1 -1
  130. package/dist/components/tool-message.js +4 -5
  131. package/dist/components/tool-message.js.map +1 -1
  132. package/dist/components/ui/titled-box.d.ts +16 -0
  133. package/dist/components/ui/titled-box.d.ts.map +1 -0
  134. package/dist/components/ui/titled-box.js +10 -0
  135. package/dist/components/ui/titled-box.js.map +1 -0
  136. package/dist/components/usage/progress-bar.d.ts.map +1 -1
  137. package/dist/components/usage/progress-bar.js +3 -0
  138. package/dist/components/usage/progress-bar.js.map +1 -1
  139. package/dist/components/usage/usage-display.d.ts.map +1 -1
  140. package/dist/components/usage/usage-display.js +7 -4
  141. package/dist/components/usage/usage-display.js.map +1 -1
  142. package/dist/components/user-input.d.ts.map +1 -1
  143. package/dist/components/user-input.js +7 -7
  144. package/dist/components/user-input.js.map +1 -1
  145. package/dist/components/user-message.d.ts.map +1 -1
  146. package/dist/components/user-message.js +1 -1
  147. package/dist/components/user-message.js.map +1 -1
  148. package/dist/components/vscode-extension-prompt.js +3 -3
  149. package/dist/components/vscode-extension-prompt.js.map +1 -1
  150. package/dist/components/warning-message.d.ts.map +1 -1
  151. package/dist/components/warning-message.js +4 -4
  152. package/dist/components/warning-message.js.map +1 -1
  153. package/dist/components/welcome-message.d.ts.map +1 -1
  154. package/dist/components/welcome-message.js +4 -4
  155. package/dist/components/welcome-message.js.map +1 -1
  156. package/dist/config/index.d.ts.map +1 -1
  157. package/dist/config/index.js +7 -7
  158. package/dist/config/index.js.map +1 -1
  159. package/dist/config/index.spec.js +4 -4
  160. package/dist/config/index.spec.js.map +1 -1
  161. package/dist/config/paths.spec.js +1 -1
  162. package/dist/config/paths.spec.js.map +1 -1
  163. package/dist/config/preferences.d.ts +0 -2
  164. package/dist/config/preferences.d.ts.map +1 -1
  165. package/dist/config/preferences.js +1 -11
  166. package/dist/config/preferences.js.map +1 -1
  167. package/dist/custom-commands/executor.d.ts.map +1 -1
  168. package/dist/custom-commands/executor.js.map +1 -1
  169. package/dist/custom-commands/loader.d.ts.map +1 -1
  170. package/dist/custom-commands/loader.js +1 -1
  171. package/dist/custom-commands/loader.js.map +1 -1
  172. package/dist/custom-commands/parser.d.ts.map +1 -1
  173. package/dist/custom-commands/parser.js.map +1 -1
  174. package/dist/hooks/useAppInitialization.d.ts +7 -5
  175. package/dist/hooks/useAppInitialization.d.ts.map +1 -1
  176. package/dist/hooks/useAppInitialization.js +21 -22
  177. package/dist/hooks/useAppInitialization.js.map +1 -1
  178. package/dist/hooks/useAppState.d.ts +22 -5
  179. package/dist/hooks/useAppState.d.ts.map +1 -1
  180. package/dist/hooks/useAppState.js +17 -1
  181. package/dist/hooks/useAppState.js.map +1 -1
  182. package/dist/hooks/useChatHandler.d.ts +4 -2
  183. package/dist/hooks/useChatHandler.d.ts.map +1 -1
  184. package/dist/hooks/useChatHandler.js +35 -10
  185. package/dist/hooks/useChatHandler.js.map +1 -1
  186. package/dist/hooks/useDirectoryTrust.js +1 -1
  187. package/dist/hooks/useDirectoryTrust.js.map +1 -1
  188. package/dist/hooks/useInputState.js +2 -2
  189. package/dist/hooks/useInputState.js.map +1 -1
  190. package/dist/hooks/useModeHandlers.d.ts +1 -1
  191. package/dist/hooks/useModeHandlers.d.ts.map +1 -1
  192. package/dist/hooks/useModeHandlers.js +3 -3
  193. package/dist/hooks/useModeHandlers.js.map +1 -1
  194. package/dist/hooks/useTerminalWidth.d.ts.map +1 -1
  195. package/dist/hooks/useTerminalWidth.js +3 -3
  196. package/dist/hooks/useTerminalWidth.js.map +1 -1
  197. package/dist/hooks/useTheme.d.ts.map +1 -1
  198. package/dist/hooks/useTheme.js +1 -1
  199. package/dist/hooks/useTheme.js.map +1 -1
  200. package/dist/hooks/useToolHandler.d.ts +1 -1
  201. package/dist/hooks/useToolHandler.d.ts.map +1 -1
  202. package/dist/hooks/useToolHandler.js +4 -4
  203. package/dist/hooks/useToolHandler.js.map +1 -1
  204. package/dist/hooks/useUIState.d.ts +1 -1
  205. package/dist/hooks/useUIState.d.ts.map +1 -1
  206. package/dist/hooks/useUIState.js.map +1 -1
  207. package/dist/hooks/useVSCodeServer.js +2 -2
  208. package/dist/hooks/useVSCodeServer.js.map +1 -1
  209. package/dist/init/agents-template-generator.d.ts +1 -1
  210. package/dist/init/agents-template-generator.d.ts.map +1 -1
  211. package/dist/init/agents-template-generator.js.map +1 -1
  212. package/dist/init/existing-rules-extractor.js +1 -1
  213. package/dist/init/existing-rules-extractor.js.map +1 -1
  214. package/dist/init/file-scanner.js +2 -2
  215. package/dist/init/file-scanner.js.map +1 -1
  216. package/dist/init/framework-detector.js +1 -1
  217. package/dist/init/framework-detector.js.map +1 -1
  218. package/dist/init/project-analyzer.d.ts +1 -1
  219. package/dist/init/project-analyzer.d.ts.map +1 -1
  220. package/dist/init/project-analyzer.js +3 -3
  221. package/dist/init/project-analyzer.js.map +1 -1
  222. package/dist/lsp/lsp-client.d.ts +1 -1
  223. package/dist/lsp/lsp-client.d.ts.map +1 -1
  224. package/dist/lsp/lsp-client.js +1 -1
  225. package/dist/lsp/lsp-client.js.map +1 -1
  226. package/dist/lsp/lsp-client.spec.js +1 -2
  227. package/dist/lsp/lsp-client.spec.js.map +1 -1
  228. package/dist/lsp/lsp-manager.d.ts +1 -1
  229. package/dist/lsp/lsp-manager.d.ts.map +1 -1
  230. package/dist/lsp/lsp-manager.js.map +1 -1
  231. package/dist/lsp/lsp-manager.spec.js +1 -1
  232. package/dist/lsp/lsp-manager.spec.js.map +1 -1
  233. package/dist/lsp/protocol.spec.js +1 -1
  234. package/dist/lsp/protocol.spec.js.map +1 -1
  235. package/dist/lsp/server-discovery.spec.js +1 -1
  236. package/dist/lsp/server-discovery.spec.js.map +1 -1
  237. package/dist/markdown-parser/index.spec.js.map +1 -1
  238. package/dist/markdown-parser/table-parser.spec.js.map +1 -1
  239. package/dist/mcp/mcp-client.d.ts +3 -2
  240. package/dist/mcp/mcp-client.d.ts.map +1 -1
  241. package/dist/mcp/mcp-client.js +264 -91
  242. package/dist/mcp/mcp-client.js.map +1 -1
  243. package/dist/mcp/transport-factory.d.ts +1 -1
  244. package/dist/mcp/transport-factory.d.ts.map +1 -1
  245. package/dist/mcp/transport-factory.js +16 -3
  246. package/dist/mcp/transport-factory.js.map +1 -1
  247. package/dist/mcp/transport-factory.spec.js +30 -48
  248. package/dist/mcp/transport-factory.spec.js.map +1 -1
  249. package/dist/message-handler.d.ts +1 -1
  250. package/dist/message-handler.d.ts.map +1 -1
  251. package/dist/model-database/database-engine.d.ts.map +1 -1
  252. package/dist/model-database/database-engine.js.map +1 -1
  253. package/dist/model-database/database-engine.spec.js.map +1 -1
  254. package/dist/model-database/model-database.js +1 -1
  255. package/dist/model-database/model-database.js.map +1 -1
  256. package/dist/model-database/model-engine.d.ts.map +1 -1
  257. package/dist/model-database/model-engine.js.map +1 -1
  258. package/dist/model-database/model-engine.spec.js +1 -1
  259. package/dist/model-database/model-engine.spec.js.map +1 -1
  260. package/dist/model-database/model-fetcher.d.ts.map +1 -1
  261. package/dist/model-database/model-fetcher.js +2 -1
  262. package/dist/model-database/model-fetcher.js.map +1 -1
  263. package/dist/model-database/model-fetcher.spec.js +1 -1
  264. package/dist/model-database/model-fetcher.spec.js.map +1 -1
  265. package/dist/models/models-cache.d.ts +1 -1
  266. package/dist/models/models-cache.d.ts.map +1 -1
  267. package/dist/models/models-cache.js +1 -1
  268. package/dist/models/models-cache.js.map +1 -1
  269. package/dist/models/models-dev-client.d.ts.map +1 -1
  270. package/dist/models/models-dev-client.js +18 -10
  271. package/dist/models/models-dev-client.js.map +1 -1
  272. package/dist/prompt-history.js +2 -2
  273. package/dist/prompt-history.js.map +1 -1
  274. package/dist/services/checkpoint-manager.d.ts +68 -0
  275. package/dist/services/checkpoint-manager.d.ts.map +1 -0
  276. package/dist/services/checkpoint-manager.js +345 -0
  277. package/dist/services/checkpoint-manager.js.map +1 -0
  278. package/dist/services/checkpoint-manager.spec.d.ts +2 -0
  279. package/dist/services/checkpoint-manager.spec.d.ts.map +1 -0
  280. package/dist/services/checkpoint-manager.spec.js +353 -0
  281. package/dist/services/checkpoint-manager.spec.js.map +1 -0
  282. package/dist/services/file-snapshot.d.ts +32 -0
  283. package/dist/services/file-snapshot.d.ts.map +1 -0
  284. package/dist/services/file-snapshot.js +161 -0
  285. package/dist/services/file-snapshot.js.map +1 -0
  286. package/dist/services/file-snapshot.spec.d.ts +2 -0
  287. package/dist/services/file-snapshot.spec.d.ts.map +1 -0
  288. package/dist/services/file-snapshot.spec.js +285 -0
  289. package/dist/services/file-snapshot.spec.js.map +1 -0
  290. package/dist/test-utils/render-with-theme.d.ts +7 -0
  291. package/dist/test-utils/render-with-theme.d.ts.map +1 -0
  292. package/dist/test-utils/render-with-theme.js +38 -0
  293. package/dist/test-utils/render-with-theme.js.map +1 -0
  294. package/dist/tokenization/tokenizer-factory.js +2 -2
  295. package/dist/tokenization/tokenizer-factory.js.map +1 -1
  296. package/dist/tokenization/tokenizer-factory.spec.js +2 -2
  297. package/dist/tokenization/tokenizer-factory.spec.js.map +1 -1
  298. package/dist/tokenization/tokenizers/anthropic-tokenizer.d.ts +1 -1
  299. package/dist/tokenization/tokenizers/anthropic-tokenizer.d.ts.map +1 -1
  300. package/dist/tokenization/tokenizers/anthropic-tokenizer.js.map +1 -1
  301. package/dist/tokenization/tokenizers/anthropic-tokenizer.spec.js.map +1 -1
  302. package/dist/tokenization/tokenizers/fallback-tokenizer.d.ts +1 -1
  303. package/dist/tokenization/tokenizers/fallback-tokenizer.d.ts.map +1 -1
  304. package/dist/tokenization/tokenizers/fallback-tokenizer.spec.js.map +1 -1
  305. package/dist/tokenization/tokenizers/llama-tokenizer.d.ts +1 -1
  306. package/dist/tokenization/tokenizers/llama-tokenizer.d.ts.map +1 -1
  307. package/dist/tokenization/tokenizers/llama-tokenizer.js.map +1 -1
  308. package/dist/tokenization/tokenizers/llama-tokenizer.spec.js.map +1 -1
  309. package/dist/tokenization/tokenizers/openai-tokenizer.d.ts +1 -1
  310. package/dist/tokenization/tokenizers/openai-tokenizer.d.ts.map +1 -1
  311. package/dist/tokenization/tokenizers/openai-tokenizer.js.map +1 -1
  312. package/dist/tokenization/tokenizers/openai-tokenizer.spec.js.map +1 -1
  313. package/dist/tool-calling/json-parser.d.ts.map +1 -1
  314. package/dist/tool-calling/json-parser.js +2 -10
  315. package/dist/tool-calling/json-parser.js.map +1 -1
  316. package/dist/tool-calling/json-parser.spec.js +7 -7
  317. package/dist/tool-calling/json-parser.spec.js.map +1 -1
  318. package/dist/tool-calling/tool-parser.d.ts.map +1 -1
  319. package/dist/tool-calling/tool-parser.js +1 -1
  320. package/dist/tool-calling/tool-parser.js.map +1 -1
  321. package/dist/tool-calling/tool-parser.spec.js +3 -3
  322. package/dist/tool-calling/tool-parser.spec.js.map +1 -1
  323. package/dist/tools/create-file.d.ts.map +1 -1
  324. package/dist/tools/create-file.js +7 -7
  325. package/dist/tools/create-file.js.map +1 -1
  326. package/dist/tools/delete-lines.d.ts.map +1 -1
  327. package/dist/tools/delete-lines.js +9 -9
  328. package/dist/tools/delete-lines.js.map +1 -1
  329. package/dist/tools/execute-bash.d.ts.map +1 -1
  330. package/dist/tools/execute-bash.js +3 -3
  331. package/dist/tools/execute-bash.js.map +1 -1
  332. package/dist/tools/execute-function.spec.js +4 -4
  333. package/dist/tools/execute-function.spec.js.map +1 -1
  334. package/dist/tools/fetch-url.d.ts.map +1 -1
  335. package/dist/tools/fetch-url.js +3 -3
  336. package/dist/tools/fetch-url.js.map +1 -1
  337. package/dist/tools/find-files.d.ts.map +1 -1
  338. package/dist/tools/find-files.js +6 -6
  339. package/dist/tools/find-files.js.map +1 -1
  340. package/dist/tools/index.d.ts +1 -1
  341. package/dist/tools/index.d.ts.map +1 -1
  342. package/dist/tools/index.js +7 -7
  343. package/dist/tools/index.js.map +1 -1
  344. package/dist/tools/insert-lines.d.ts.map +1 -1
  345. package/dist/tools/insert-lines.js +8 -8
  346. package/dist/tools/insert-lines.js.map +1 -1
  347. package/dist/tools/lsp-get-diagnostics.d.ts.map +1 -1
  348. package/dist/tools/lsp-get-diagnostics.js +5 -5
  349. package/dist/tools/lsp-get-diagnostics.js.map +1 -1
  350. package/dist/tools/needs-approval.spec.js +6 -6
  351. package/dist/tools/needs-approval.spec.js.map +1 -1
  352. package/dist/tools/read-file.js +6 -6
  353. package/dist/tools/read-file.js.map +1 -1
  354. package/dist/tools/replace-lines.d.ts.map +1 -1
  355. package/dist/tools/replace-lines.js +8 -8
  356. package/dist/tools/replace-lines.js.map +1 -1
  357. package/dist/tools/search-file-contents.d.ts.map +1 -1
  358. package/dist/tools/search-file-contents.js +6 -6
  359. package/dist/tools/search-file-contents.js.map +1 -1
  360. package/dist/tools/tool-manager.d.ts +1 -1
  361. package/dist/tools/tool-manager.d.ts.map +1 -1
  362. package/dist/tools/tool-manager.js +1 -1
  363. package/dist/tools/tool-manager.js.map +1 -1
  364. package/dist/tools/tool-registry.d.ts +1 -1
  365. package/dist/tools/tool-registry.d.ts.map +1 -1
  366. package/dist/tools/web-search.d.ts.map +1 -1
  367. package/dist/tools/web-search.js +4 -4
  368. package/dist/tools/web-search.js.map +1 -1
  369. package/dist/types/app.d.ts +6 -3
  370. package/dist/types/app.d.ts.map +1 -1
  371. package/dist/types/checkpoint.d.ts +43 -0
  372. package/dist/types/checkpoint.d.ts.map +1 -0
  373. package/dist/types/checkpoint.js +2 -0
  374. package/dist/types/checkpoint.js.map +1 -0
  375. package/dist/types/config.d.ts +0 -1
  376. package/dist/types/config.d.ts.map +1 -1
  377. package/dist/types/core-connection-status.spec.js.map +1 -1
  378. package/dist/types/core.d.ts +1 -1
  379. package/dist/types/core.d.ts.map +1 -1
  380. package/dist/types/core.js +1 -1
  381. package/dist/types/core.js.map +1 -1
  382. package/dist/types/index.d.ts +1 -0
  383. package/dist/types/index.d.ts.map +1 -1
  384. package/dist/types/index.js +1 -0
  385. package/dist/types/index.js.map +1 -1
  386. package/dist/usage/calculator.spec.js +1 -1
  387. package/dist/usage/calculator.spec.js.map +1 -1
  388. package/dist/usage/storage.d.ts +1 -1
  389. package/dist/usage/storage.d.ts.map +1 -1
  390. package/dist/usage/storage.js +9 -3
  391. package/dist/usage/storage.js.map +1 -1
  392. package/dist/usage/storage.spec.js +3 -3
  393. package/dist/usage/storage.spec.js.map +1 -1
  394. package/dist/usage/tracker.d.ts.map +1 -1
  395. package/dist/usage/tracker.js +1 -1
  396. package/dist/usage/tracker.js.map +1 -1
  397. package/dist/usage/tracker.spec.js +4 -4
  398. package/dist/usage/tracker.spec.js.map +1 -1
  399. package/dist/utils/atomic-deletion.spec.js +1 -1
  400. package/dist/utils/atomic-deletion.spec.js.map +1 -1
  401. package/dist/utils/checkpoint-utils.d.ts +12 -0
  402. package/dist/utils/checkpoint-utils.d.ts.map +1 -0
  403. package/dist/utils/checkpoint-utils.js +85 -0
  404. package/dist/utils/checkpoint-utils.js.map +1 -0
  405. package/dist/utils/checkpoint-utils.spec.d.ts +2 -0
  406. package/dist/utils/checkpoint-utils.spec.d.ts.map +1 -0
  407. package/dist/utils/checkpoint-utils.spec.js +182 -0
  408. package/dist/utils/checkpoint-utils.spec.js.map +1 -0
  409. package/dist/utils/error-formatter.d.ts +35 -0
  410. package/dist/utils/error-formatter.d.ts.map +1 -1
  411. package/dist/utils/error-formatter.js +123 -0
  412. package/dist/utils/error-formatter.js.map +1 -1
  413. package/dist/utils/file-autocomplete.js +2 -2
  414. package/dist/utils/file-autocomplete.js.map +1 -1
  415. package/dist/utils/file-autocomplete.spec.js +1 -1
  416. package/dist/utils/file-autocomplete.spec.js.map +1 -1
  417. package/dist/utils/file-content-loader.js +1 -1
  418. package/dist/utils/file-content-loader.js.map +1 -1
  419. package/dist/utils/file-content-loader.spec.js +4 -4
  420. package/dist/utils/file-content-loader.spec.js.map +1 -1
  421. package/dist/utils/file-mention-handler.js.map +1 -1
  422. package/dist/utils/file-mention-handler.spec.js +4 -4
  423. package/dist/utils/file-mention-handler.spec.js.map +1 -1
  424. package/dist/utils/file-mention-parser.spec.js +2 -2
  425. package/dist/utils/file-mention-parser.spec.js.map +1 -1
  426. package/dist/utils/installation-detector.js +2 -2
  427. package/dist/utils/installation-detector.js.map +1 -1
  428. package/dist/utils/installation-detector.spec.js +10 -17
  429. package/dist/utils/installation-detector.spec.js.map +1 -1
  430. package/dist/utils/logging/config.d.ts +41 -0
  431. package/dist/utils/logging/config.d.ts.map +1 -0
  432. package/dist/utils/logging/config.js +188 -0
  433. package/dist/utils/logging/config.js.map +1 -0
  434. package/dist/utils/logging/config.spec.d.ts +2 -0
  435. package/dist/utils/logging/config.spec.d.ts.map +1 -0
  436. package/dist/utils/logging/config.spec.js +233 -0
  437. package/dist/utils/logging/config.spec.js.map +1 -0
  438. package/dist/utils/logging/console-facade.d.ts +93 -0
  439. package/dist/utils/logging/console-facade.d.ts.map +1 -0
  440. package/dist/utils/logging/console-facade.js +295 -0
  441. package/dist/utils/logging/console-facade.js.map +1 -0
  442. package/dist/utils/logging/console-facade.spec.d.ts +2 -0
  443. package/dist/utils/logging/console-facade.spec.d.ts.map +1 -0
  444. package/dist/utils/logging/console-facade.spec.js +143 -0
  445. package/dist/utils/logging/console-facade.spec.js.map +1 -0
  446. package/dist/utils/logging/correlation.d.ts +139 -0
  447. package/dist/utils/logging/correlation.d.ts.map +1 -0
  448. package/dist/utils/logging/correlation.js +410 -0
  449. package/dist/utils/logging/correlation.js.map +1 -0
  450. package/dist/utils/logging/correlation.spec.d.ts +2 -0
  451. package/dist/utils/logging/correlation.spec.d.ts.map +1 -0
  452. package/dist/utils/logging/correlation.spec.js +449 -0
  453. package/dist/utils/logging/correlation.spec.js.map +1 -0
  454. package/dist/utils/logging/formatters.d.ts +70 -0
  455. package/dist/utils/logging/formatters.d.ts.map +1 -0
  456. package/dist/utils/logging/formatters.js +186 -0
  457. package/dist/utils/logging/formatters.js.map +1 -0
  458. package/dist/utils/logging/formatters.spec.d.ts +2 -0
  459. package/dist/utils/logging/formatters.spec.d.ts.map +1 -0
  460. package/dist/utils/logging/formatters.spec.js +356 -0
  461. package/dist/utils/logging/formatters.spec.js.map +1 -0
  462. package/dist/utils/logging/health-monitor.d.ts +216 -0
  463. package/dist/utils/logging/health-monitor.d.ts.map +1 -0
  464. package/dist/utils/logging/health-monitor.js +760 -0
  465. package/dist/utils/logging/health-monitor.js.map +1 -0
  466. package/dist/utils/logging/health-monitor.spec.d.ts +2 -0
  467. package/dist/utils/logging/health-monitor.spec.d.ts.map +1 -0
  468. package/dist/utils/logging/health-monitor.spec.js +305 -0
  469. package/dist/utils/logging/health-monitor.spec.js.map +1 -0
  470. package/dist/utils/logging/index.d.ts +100 -0
  471. package/dist/utils/logging/index.d.ts.map +1 -0
  472. package/dist/utils/logging/index.js +186 -0
  473. package/dist/utils/logging/index.js.map +1 -0
  474. package/dist/utils/logging/index.spec.d.ts +2 -0
  475. package/dist/utils/logging/index.spec.d.ts.map +1 -0
  476. package/dist/utils/logging/index.spec.js +214 -0
  477. package/dist/utils/logging/index.spec.js.map +1 -0
  478. package/dist/utils/logging/integration.spec.d.ts +2 -0
  479. package/dist/utils/logging/integration.spec.d.ts.map +1 -0
  480. package/dist/utils/logging/integration.spec.js +312 -0
  481. package/dist/utils/logging/integration.spec.js.map +1 -0
  482. package/dist/utils/logging/log-method-factory.d.ts +43 -0
  483. package/dist/utils/logging/log-method-factory.d.ts.map +1 -0
  484. package/dist/utils/logging/log-method-factory.js +176 -0
  485. package/dist/utils/logging/log-method-factory.js.map +1 -0
  486. package/dist/utils/logging/log-method-factory.spec.d.ts +2 -0
  487. package/dist/utils/logging/log-method-factory.spec.d.ts.map +1 -0
  488. package/dist/utils/logging/log-method-factory.spec.js +428 -0
  489. package/dist/utils/logging/log-method-factory.spec.js.map +1 -0
  490. package/dist/utils/logging/log-query.d.ts +275 -0
  491. package/dist/utils/logging/log-query.d.ts.map +1 -0
  492. package/dist/utils/logging/log-query.js +621 -0
  493. package/dist/utils/logging/log-query.js.map +1 -0
  494. package/dist/utils/logging/log-query.spec.d.ts +2 -0
  495. package/dist/utils/logging/log-query.spec.d.ts.map +1 -0
  496. package/dist/utils/logging/log-query.spec.js +737 -0
  497. package/dist/utils/logging/log-query.spec.js.map +1 -0
  498. package/dist/utils/logging/logger-provider.d.ts +73 -0
  499. package/dist/utils/logging/logger-provider.d.ts.map +1 -0
  500. package/dist/utils/logging/logger-provider.js +298 -0
  501. package/dist/utils/logging/logger-provider.js.map +1 -0
  502. package/dist/utils/logging/logger-provider.spec.d.ts +2 -0
  503. package/dist/utils/logging/logger-provider.spec.d.ts.map +1 -0
  504. package/dist/utils/logging/logger-provider.spec.js +204 -0
  505. package/dist/utils/logging/logger-provider.spec.js.map +1 -0
  506. package/dist/utils/logging/performance.d.ts +147 -0
  507. package/dist/utils/logging/performance.d.ts.map +1 -0
  508. package/dist/utils/logging/performance.js +520 -0
  509. package/dist/utils/logging/performance.js.map +1 -0
  510. package/dist/utils/logging/performance.spec.d.ts +2 -0
  511. package/dist/utils/logging/performance.spec.d.ts.map +1 -0
  512. package/dist/utils/logging/performance.spec.js +139 -0
  513. package/dist/utils/logging/performance.spec.js.map +1 -0
  514. package/dist/utils/logging/pino-logger.d.ts +22 -0
  515. package/dist/utils/logging/pino-logger.d.ts.map +1 -0
  516. package/dist/utils/logging/pino-logger.js +372 -0
  517. package/dist/utils/logging/pino-logger.js.map +1 -0
  518. package/dist/utils/logging/pino-logger.spec.d.ts +2 -0
  519. package/dist/utils/logging/pino-logger.spec.d.ts.map +1 -0
  520. package/dist/utils/logging/pino-logger.spec.js +294 -0
  521. package/dist/utils/logging/pino-logger.spec.js.map +1 -0
  522. package/dist/utils/logging/redaction.d.ts +38 -0
  523. package/dist/utils/logging/redaction.d.ts.map +1 -0
  524. package/dist/utils/logging/redaction.js +210 -0
  525. package/dist/utils/logging/redaction.js.map +1 -0
  526. package/dist/utils/logging/redaction.spec.d.ts +2 -0
  527. package/dist/utils/logging/redaction.spec.d.ts.map +1 -0
  528. package/dist/utils/logging/redaction.spec.js +338 -0
  529. package/dist/utils/logging/redaction.spec.js.map +1 -0
  530. package/dist/utils/logging/request-tracker.d.ts +189 -0
  531. package/dist/utils/logging/request-tracker.d.ts.map +1 -0
  532. package/dist/utils/logging/request-tracker.js +569 -0
  533. package/dist/utils/logging/request-tracker.js.map +1 -0
  534. package/dist/utils/logging/request-tracker.spec.d.ts +2 -0
  535. package/dist/utils/logging/request-tracker.spec.d.ts.map +1 -0
  536. package/dist/utils/logging/request-tracker.spec.js +868 -0
  537. package/dist/utils/logging/request-tracker.spec.js.map +1 -0
  538. package/dist/utils/logging/transports.d.ts +55 -0
  539. package/dist/utils/logging/transports.d.ts.map +1 -0
  540. package/dist/utils/logging/transports.js +252 -0
  541. package/dist/utils/logging/transports.js.map +1 -0
  542. package/dist/utils/logging/transports.spec.d.ts +2 -0
  543. package/dist/utils/logging/transports.spec.d.ts.map +1 -0
  544. package/dist/utils/logging/transports.spec.js +390 -0
  545. package/dist/utils/logging/transports.spec.js.map +1 -0
  546. package/dist/utils/logging/types.d.ts +173 -0
  547. package/dist/utils/logging/types.d.ts.map +1 -0
  548. package/dist/utils/logging/types.js +5 -0
  549. package/dist/utils/logging/types.js.map +1 -0
  550. package/dist/utils/message-queue.d.ts +64 -4
  551. package/dist/utils/message-queue.d.ts.map +1 -1
  552. package/dist/utils/message-queue.js +282 -28
  553. package/dist/utils/message-queue.js.map +1 -1
  554. package/dist/utils/paste-utils.spec.js +1 -1
  555. package/dist/utils/paste-utils.spec.js.map +1 -1
  556. package/dist/utils/prompt-processor.js +2 -2
  557. package/dist/utils/prompt-processor.js.map +1 -1
  558. package/dist/utils/tool-cancellation.spec.js.map +1 -1
  559. package/dist/utils/tool-result-display.d.ts +2 -2
  560. package/dist/utils/tool-result-display.d.ts.map +1 -1
  561. package/dist/utils/tool-result-display.js +3 -3
  562. package/dist/utils/tool-result-display.js.map +1 -1
  563. package/dist/utils/update-checker.d.ts.map +1 -1
  564. package/dist/utils/update-checker.js +1 -1
  565. package/dist/utils/update-checker.js.map +1 -1
  566. package/dist/utils/update-checker.spec.js +2 -2
  567. package/dist/utils/update-checker.spec.js.map +1 -1
  568. package/dist/vscode/extension-installer.js +1 -1
  569. package/dist/vscode/extension-installer.js.map +1 -1
  570. package/dist/vscode/extension-installer.spec.js +1 -1
  571. package/dist/vscode/extension-installer.spec.js.map +1 -1
  572. package/dist/vscode/protocol.spec.js +1 -1
  573. package/dist/vscode/protocol.spec.js.map +1 -1
  574. package/dist/vscode/vscode-server.d.ts.map +1 -1
  575. package/dist/vscode/vscode-server.js +2 -2
  576. package/dist/vscode/vscode-server.js.map +1 -1
  577. package/dist/vscode/vscode-server.spec.js.map +1 -1
  578. package/dist/wizard/config-wizard.d.ts.map +1 -1
  579. package/dist/wizard/config-wizard.js +16 -12
  580. package/dist/wizard/config-wizard.js.map +1 -1
  581. package/dist/wizard/steps/location-step.js +4 -4
  582. package/dist/wizard/steps/location-step.js.map +1 -1
  583. package/dist/wizard/steps/mcp-step.d.ts.map +1 -1
  584. package/dist/wizard/steps/mcp-step.js +4 -4
  585. package/dist/wizard/steps/mcp-step.js.map +1 -1
  586. package/dist/wizard/steps/provider-step.d.ts.map +1 -1
  587. package/dist/wizard/steps/provider-step.js +4 -4
  588. package/dist/wizard/steps/provider-step.js.map +1 -1
  589. package/dist/wizard/steps/summary-step.d.ts.map +1 -1
  590. package/dist/wizard/steps/summary-step.js +2 -2
  591. package/dist/wizard/steps/summary-step.js.map +1 -1
  592. package/dist/wizard/templates/provider-templates.d.ts.map +1 -1
  593. package/dist/wizard/templates/provider-templates.js +64 -0
  594. package/dist/wizard/templates/provider-templates.js.map +1 -1
  595. package/dist/wizard/validation-array.spec.js +1 -1
  596. package/dist/wizard/validation-array.spec.js.map +1 -1
  597. package/dist/wizard/validation.spec.js +1 -1
  598. package/dist/wizard/validation.spec.js.map +1 -1
  599. package/package.json +23 -22
  600. package/dist/commands/debugging.d.ts +0 -3
  601. package/dist/commands/debugging.d.ts.map +0 -1
  602. package/dist/commands/debugging.js +0 -23
  603. package/dist/commands/debugging.js.map +0 -1
@@ -0,0 +1,520 @@
1
+ /**
2
+ * Enhanced performance metrics collection for logging
3
+ * Provides comprehensive monitoring and analysis capabilities
4
+ */
5
+ import { loadavg } from 'os';
6
+ import { generateCorrelationId } from './index.js';
7
+ // Create correlation context function
8
+ function createCorrelationContext() {
9
+ const id = generateCorrelationId();
10
+ return {
11
+ id,
12
+ getId: () => id,
13
+ };
14
+ }
15
+ import { correlationStorage } from './correlation.js';
16
+ // Private CPU usage functions (used internally)
17
+ function getCpuUsage() {
18
+ return process.cpuUsage();
19
+ }
20
+ function calculateCpuUsage(startUsage, endUsage, timeDelta) {
21
+ const userDelta = endUsage.user - startUsage.user;
22
+ const systemDelta = endUsage.system - startUsage.system;
23
+ const totalDelta = userDelta + systemDelta;
24
+ // Convert to percentage (microseconds to seconds)
25
+ return (totalDelta / (timeDelta * 1000)) * 100;
26
+ }
27
+ // Lazy logger initialization to avoid circular dependency
28
+ let _logger = null;
29
+ function getLogger() {
30
+ if (!_logger) {
31
+ // Use dynamic import to avoid circular dependency
32
+ const loggingModule = import('./index.js');
33
+ // For now, create a simple fallback logger
34
+ _logger = {
35
+ fatal: () => { },
36
+ error: () => { },
37
+ warn: () => { },
38
+ info: () => { },
39
+ http: () => { },
40
+ debug: () => { },
41
+ trace: () => { },
42
+ child: () => _logger,
43
+ isLevelEnabled: () => false,
44
+ flush: async () => { },
45
+ end: async () => { },
46
+ };
47
+ void loggingModule.then(module => {
48
+ _logger = module.getLogger();
49
+ });
50
+ }
51
+ return _logger;
52
+ }
53
+ // Create a logger proxy that maintains the same API
54
+ const logger = new Proxy({}, {
55
+ get(_target, prop) {
56
+ const loggerInstance = getLogger();
57
+ if (loggerInstance &&
58
+ typeof loggerInstance === 'object' &&
59
+ prop in loggerInstance) {
60
+ // biome-ignore lint/suspicious/noExplicitAny: Dynamic property access
61
+ const value = loggerInstance[prop];
62
+ return typeof value === 'function' ? value.bind(loggerInstance) : value;
63
+ }
64
+ // Return fallback methods that match Logger interface
65
+ const fallbacks = {
66
+ fatal: (_msg, ..._args) => { },
67
+ error: (_msg, ..._args) => { },
68
+ warn: (_msg, ..._args) => { },
69
+ info: (_msg, ..._args) => { },
70
+ http: (_msg, ..._args) => { },
71
+ debug: (_msg, ..._args) => { },
72
+ trace: (_msg, ..._args) => { },
73
+ child: () => logger,
74
+ isLevelEnabled: () => false,
75
+ flush: async () => { },
76
+ end: async () => { },
77
+ };
78
+ return fallbacks[prop] || (() => { });
79
+ },
80
+ });
81
+ /**
82
+ * Start a performance measurement
83
+ */
84
+ export function startMetrics() {
85
+ return {
86
+ startTime: performance.now(),
87
+ memoryUsage: process.memoryUsage(),
88
+ };
89
+ }
90
+ /**
91
+ * End a performance measurement and calculate duration
92
+ */
93
+ export function endMetrics(metrics) {
94
+ const endTime = performance.now();
95
+ const duration = endTime - metrics.startTime;
96
+ return {
97
+ ...metrics,
98
+ duration,
99
+ memoryUsage: process.memoryUsage(),
100
+ };
101
+ }
102
+ /**
103
+ * Calculate memory usage delta
104
+ */
105
+ export function calculateMemoryDelta(initial, final) {
106
+ return {
107
+ heapUsedDelta: final.heapUsed - initial.heapUsed,
108
+ heapTotalDelta: final.heapTotal - initial.heapTotal,
109
+ externalDelta: final.external - initial.external,
110
+ rssDelta: final.rss - initial.rss,
111
+ };
112
+ }
113
+ /**
114
+ * Format memory usage for logging
115
+ */
116
+ export function formatMemoryUsage(memory) {
117
+ return {
118
+ heapUsed: formatBytes(memory.heapUsed),
119
+ heapTotal: formatBytes(memory.heapTotal),
120
+ external: formatBytes(memory.external),
121
+ rss: formatBytes(memory.rss),
122
+ };
123
+ }
124
+ /**
125
+ * Format bytes to human readable string
126
+ */
127
+ export function formatBytes(bytes) {
128
+ if (bytes === 0)
129
+ return '0 B';
130
+ const k = 1024;
131
+ const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];
132
+ const i = Math.floor(Math.log(bytes) / Math.log(k));
133
+ return `${parseFloat((bytes / Math.pow(k, i)).toFixed(2))} ${sizes[i]}`;
134
+ }
135
+ /**
136
+ * Performance tracking decorator with structured logging integration
137
+ */
138
+ export function trackPerformance(fn, name, options) {
139
+ const { logLevel = 'debug', trackMemory = true, trackCpu = true, trackArgs = false, thresholds = {}, } = options || {};
140
+ return (async (...args) => {
141
+ const metrics = startMetrics();
142
+ const cpuStart = process.cpuUsage();
143
+ // Create new correlation context for this performance tracking
144
+ const context = createCorrelationContext();
145
+ // Use AsyncLocalStorage.run() directly for proper async context handling
146
+ return correlationStorage.run(context, async () => {
147
+ try {
148
+ const result = await fn(...args);
149
+ const end = endMetrics(metrics);
150
+ const cpuEnd = process.cpuUsage();
151
+ const memoryDelta = calculateMemoryDelta(metrics.memoryUsage || process.memoryUsage(), end.memoryUsage || process.memoryUsage());
152
+ // Calculate CPU usage percentage
153
+ const userDelta = cpuEnd.user - cpuStart.user;
154
+ const systemDelta = cpuEnd.system - cpuStart.system;
155
+ const totalDelta = userDelta + systemDelta;
156
+ const cpuPercent = (totalDelta / (end.duration * 1000)) * 100;
157
+ // Prepare performance data
158
+ const perfData = {
159
+ functionName: name,
160
+ duration: `${end.duration.toFixed(2)}ms`,
161
+ durationMs: end.duration,
162
+ correlationId: context.id,
163
+ source: 'performance-tracker',
164
+ };
165
+ if (trackMemory) {
166
+ perfData.memoryDelta = memoryDelta;
167
+ perfData.memoryDeltaFormatted = {
168
+ heapUsed: formatBytes(memoryDelta.heapUsedDelta),
169
+ heapTotal: formatBytes(memoryDelta.heapTotalDelta),
170
+ external: formatBytes(memoryDelta.externalDelta),
171
+ rss: formatBytes(memoryDelta.rssDelta),
172
+ };
173
+ perfData.currentMemory = formatMemoryUsage(end.memoryUsage || process.memoryUsage());
174
+ }
175
+ if (trackCpu) {
176
+ perfData.cpuPercent = `${cpuPercent.toFixed(2)}%`;
177
+ perfData.cpuUsageRaw = cpuPercent;
178
+ }
179
+ if (trackArgs) {
180
+ perfData.argCount = args.length;
181
+ perfData.argTypes = args.map(arg => typeof arg);
182
+ }
183
+ // Check thresholds and set appropriate log level
184
+ let finalLogLevel = logLevel;
185
+ const warnings = [];
186
+ if (thresholds.duration && end.duration > thresholds.duration) {
187
+ warnings.push(`Duration threshold exceeded: ${end.duration.toFixed(2)}ms > ${thresholds.duration}ms`);
188
+ finalLogLevel = 'warn';
189
+ }
190
+ if (thresholds.memory &&
191
+ memoryDelta.heapUsedDelta > thresholds.memory * 1024 * 1024) {
192
+ warnings.push(`Memory threshold exceeded: ${formatBytes(memoryDelta.heapUsedDelta)} > ${formatBytes(thresholds.memory * 1024 * 1024)}`);
193
+ finalLogLevel = 'warn';
194
+ }
195
+ if (thresholds.cpu && cpuPercent > thresholds.cpu) {
196
+ warnings.push(`CPU threshold exceeded: ${cpuPercent.toFixed(2)}% > ${thresholds.cpu}%`);
197
+ finalLogLevel = 'warn';
198
+ }
199
+ if (warnings.length > 0) {
200
+ perfData.thresholdWarnings = warnings;
201
+ }
202
+ // Log performance metrics with structured logging
203
+ logger[finalLogLevel](`Performance: ${name}`, perfData);
204
+ return result;
205
+ }
206
+ catch (error) {
207
+ const end = endMetrics(metrics);
208
+ const memoryDelta = calculateMemoryDelta(metrics.memoryUsage || process.memoryUsage(), end.memoryUsage || process.memoryUsage());
209
+ const cpuEnd = getCpuUsage();
210
+ const cpuPercent = calculateCpuUsage(cpuStart, cpuEnd, end.duration);
211
+ // Log error performance metrics
212
+ logger.error(`Performance Error: ${name}`, {
213
+ functionName: name,
214
+ duration: `${end.duration.toFixed(2)}ms`,
215
+ durationMs: end.duration,
216
+ error: error instanceof Error ? error.message : error,
217
+ errorType: error instanceof Error ? error.constructor.name : typeof error,
218
+ memoryDelta: trackMemory ? memoryDelta : undefined,
219
+ cpuPercent: trackCpu ? `${cpuPercent.toFixed(2)}%` : undefined,
220
+ argCount: trackArgs ? args.length : undefined,
221
+ correlationId: context.id,
222
+ source: 'performance-tracker-error',
223
+ });
224
+ throw error;
225
+ }
226
+ });
227
+ });
228
+ }
229
+ /**
230
+ * Enhanced function execution time measurement with structured logging
231
+ */
232
+ export async function measureTime(fn, label, options) {
233
+ const { logPerformance = true, trackMemory = true, trackCpu = false, thresholds = {}, } = options || {};
234
+ const start = performance.now();
235
+ const memoryStart = process.memoryUsage();
236
+ const cpuStart = trackCpu ? process.cpuUsage() : undefined;
237
+ // Create new correlation context for this measurement
238
+ const context = createCorrelationContext();
239
+ // Use AsyncLocalStorage.run() directly for proper async context handling
240
+ return correlationStorage.run(context, async () => {
241
+ try {
242
+ const result = await fn();
243
+ const duration = performance.now() - start;
244
+ const memoryEnd = process.memoryUsage();
245
+ const cpuEnd = trackCpu ? process.cpuUsage() : undefined;
246
+ let memoryDelta;
247
+ let cpuUsage;
248
+ if (trackMemory) {
249
+ memoryDelta = calculateMemoryDelta(memoryStart, memoryEnd);
250
+ }
251
+ if (trackCpu && cpuStart && cpuEnd) {
252
+ // Calculate CPU usage percentage
253
+ const userDelta = cpuEnd.user - cpuStart.user;
254
+ const systemDelta = cpuEnd.system - cpuStart.system;
255
+ const totalDelta = userDelta + systemDelta;
256
+ cpuUsage = (totalDelta / (duration * 1000)) * 100;
257
+ }
258
+ if (logPerformance) {
259
+ const perfData = {
260
+ label: label || 'Anonymous function',
261
+ duration: `${duration.toFixed(2)}ms`,
262
+ durationMs: duration,
263
+ correlationId: context.id,
264
+ source: 'measure-time',
265
+ };
266
+ if (memoryDelta) {
267
+ perfData.memoryDelta = memoryDelta;
268
+ perfData.memoryDeltaFormatted = {
269
+ heapUsed: formatBytes(memoryDelta.heapUsedDelta),
270
+ heapTotal: formatBytes(memoryDelta.heapTotalDelta),
271
+ external: formatBytes(memoryDelta.externalDelta),
272
+ rss: formatBytes(memoryDelta.rssDelta),
273
+ };
274
+ }
275
+ if (cpuUsage !== undefined) {
276
+ perfData.cpuUsage = `${cpuUsage.toFixed(2)}%`;
277
+ perfData.cpuUsageRaw = cpuUsage;
278
+ }
279
+ // Check thresholds and adjust log level
280
+ let logLevel = 'debug';
281
+ const warnings = [];
282
+ if (thresholds.duration && duration > thresholds.duration) {
283
+ warnings.push(`Duration threshold exceeded: ${duration.toFixed(2)}ms > ${thresholds.duration}ms`);
284
+ logLevel = 'warn';
285
+ }
286
+ if (thresholds.memory &&
287
+ memoryDelta &&
288
+ memoryDelta.heapUsedDelta > thresholds.memory * 1024 * 1024) {
289
+ warnings.push(`Memory threshold exceeded: ${formatBytes(memoryDelta.heapUsedDelta)} > ${formatBytes(thresholds.memory * 1024 * 1024)}`);
290
+ logLevel = 'warn';
291
+ }
292
+ if (warnings.length > 0) {
293
+ perfData.thresholdWarnings = warnings;
294
+ }
295
+ logger[logLevel](`Measured function execution`, perfData);
296
+ }
297
+ return { result, duration, memoryDelta, cpuUsage };
298
+ }
299
+ catch (error) {
300
+ const duration = performance.now() - start;
301
+ logger.error(`Function execution measurement failed`, {
302
+ label: label || 'Anonymous function',
303
+ duration: `${duration.toFixed(2)}ms`,
304
+ durationMs: duration,
305
+ error: error instanceof Error ? error.message : error,
306
+ errorType: error instanceof Error ? error.constructor.name : typeof error,
307
+ correlationId: context.id,
308
+ source: 'measure-time-error',
309
+ });
310
+ throw error;
311
+ }
312
+ });
313
+ }
314
+ /**
315
+ * Enhanced memory threshold checking with structured logging
316
+ */
317
+ export function checkMemoryThresholds(memory, options) {
318
+ const { heapUsagePercentThreshold = 0.8, heapUsageAbsoluteThreshold = 512, logLevel = 'warn', correlationId = generateCorrelationId(), } = options || {};
319
+ const heapUsedMB = memory.heapUsed / 1024 / 1024;
320
+ const heapTotalMB = memory.heapTotal / 1024 / 1024;
321
+ const externalMB = memory.external / 1024 / 1024;
322
+ const rssMB = memory.rss / 1024 / 1024;
323
+ const heapUsagePercent = heapUsedMB / heapTotalMB;
324
+ const warnings = [];
325
+ let isHealthy = true;
326
+ // Check heap usage percentage
327
+ if (heapUsagePercent > heapUsagePercentThreshold) {
328
+ warnings.push(`High heap usage percentage: ${(heapUsagePercent * 100).toFixed(1)}% > ${(heapUsagePercentThreshold * 100).toFixed(1)}%`);
329
+ isHealthy = false;
330
+ }
331
+ // Check absolute heap usage
332
+ if (heapUsedMB > heapUsageAbsoluteThreshold) {
333
+ warnings.push(`High absolute heap usage: ${heapUsedMB.toFixed(2)}MB > ${heapUsageAbsoluteThreshold}MB`);
334
+ isHealthy = false;
335
+ }
336
+ // Check external memory usage
337
+ if (externalMB > 256) {
338
+ warnings.push(`High external memory usage: ${externalMB.toFixed(2)}MB`);
339
+ isHealthy = false;
340
+ }
341
+ // Check RSS (Resident Set Size)
342
+ if (rssMB > 1024) {
343
+ warnings.push(`High RSS usage: ${rssMB.toFixed(2)}MB`);
344
+ isHealthy = false;
345
+ }
346
+ const metrics = {
347
+ heapUsedMB,
348
+ heapTotalMB,
349
+ heapUsagePercent,
350
+ externalMB,
351
+ rssMB,
352
+ };
353
+ // Log with structured logging
354
+ if (!isHealthy) {
355
+ logger[logLevel]('Memory threshold warnings detected', {
356
+ metrics,
357
+ warnings,
358
+ thresholds: {
359
+ heapUsagePercent: `${(heapUsagePercentThreshold * 100).toFixed(1)}%`,
360
+ heapUsageAbsolute: `${heapUsageAbsoluteThreshold}MB`,
361
+ external: '256MB',
362
+ rss: '1024MB',
363
+ },
364
+ correlationId,
365
+ source: 'memory-threshold-check',
366
+ });
367
+ }
368
+ else {
369
+ logger.debug('Memory usage is healthy', {
370
+ metrics,
371
+ correlationId,
372
+ source: 'memory-threshold-check',
373
+ });
374
+ }
375
+ return { isHealthy, warnings, metrics };
376
+ }
377
+ /**
378
+ * Take a comprehensive system performance snapshot
379
+ */
380
+ export function takePerformanceSnapshot(options) {
381
+ const correlationId = options?.correlationId || generateCorrelationId();
382
+ const includeCpu = options?.includeCpu !== false;
383
+ const snapshot = {
384
+ timestamp: new Date().toISOString(),
385
+ memory: process.memoryUsage(),
386
+ memoryFormatted: formatMemoryUsage(process.memoryUsage()),
387
+ cpu: includeCpu ? process.cpuUsage() : { user: 0, system: 0 },
388
+ uptime: process.uptime(),
389
+ uptimeFormatted: formatUptime(process.uptime()),
390
+ loadAverage: loadavg(),
391
+ platform: process.platform,
392
+ arch: process.arch,
393
+ nodeVersion: process.version,
394
+ pid: process.pid,
395
+ correlationId,
396
+ };
397
+ logger.debug('Performance snapshot taken', {
398
+ timestamp: snapshot.timestamp,
399
+ memoryFormatted: snapshot.memoryFormatted,
400
+ uptimeFormatted: snapshot.uptimeFormatted,
401
+ loadAverage: snapshot.loadAverage,
402
+ correlationId,
403
+ source: 'performance-snapshot',
404
+ });
405
+ return snapshot;
406
+ }
407
+ /**
408
+ * Format uptime to human readable string
409
+ */
410
+ function formatUptime(seconds) {
411
+ const days = Math.floor(seconds / (24 * 3600));
412
+ const hours = Math.floor((seconds % (24 * 3600)) / 3600);
413
+ const minutes = Math.floor((seconds % 3600) / 60);
414
+ const secs = Math.floor(seconds % 60);
415
+ const parts = [];
416
+ if (days > 0)
417
+ parts.push(`${days}d`);
418
+ if (hours > 0)
419
+ parts.push(`${hours}h`);
420
+ if (minutes > 0)
421
+ parts.push(`${minutes}m`);
422
+ if (secs > 0 || parts.length === 0)
423
+ parts.push(`${secs}s`);
424
+ return parts.join(' ');
425
+ }
426
+ /**
427
+ * Performance monitor class for ongoing tracking (used internally)
428
+ */
429
+ class PerformanceMonitor {
430
+ measurements = new Map();
431
+ maxMeasurements;
432
+ constructor(maxMeasurements = 100) {
433
+ this.maxMeasurements = maxMeasurements;
434
+ }
435
+ /**
436
+ * Start measuring an operation
437
+ */
438
+ start(operation) {
439
+ const id = `${operation}_${Date.now()}_${Math.random()}`;
440
+ const metrics = startMetrics();
441
+ if (!this.measurements.has(operation)) {
442
+ this.measurements.set(operation, []);
443
+ }
444
+ const operationMeasurements = this.measurements.get(operation);
445
+ if (!operationMeasurements) {
446
+ this.measurements.set(operation, []);
447
+ return this.start(operation); // Retry with empty array
448
+ }
449
+ operationMeasurements.push({ ...metrics, id });
450
+ // Keep only the last N measurements
451
+ if (operationMeasurements.length > this.maxMeasurements) {
452
+ operationMeasurements.shift();
453
+ }
454
+ return id;
455
+ }
456
+ /**
457
+ * End measuring an operation
458
+ */
459
+ end(operation, id) {
460
+ const operationMeasurements = this.measurements.get(operation);
461
+ if (!operationMeasurements)
462
+ return null;
463
+ const index = operationMeasurements.findIndex(m => 'id' in m && m.id === id);
464
+ if (index === -1)
465
+ return null;
466
+ const metrics = operationMeasurements[index];
467
+ const end = endMetrics(metrics);
468
+ // Update the measurement
469
+ operationMeasurements[index] = end;
470
+ return end;
471
+ }
472
+ /**
473
+ * Get statistics for an operation
474
+ */
475
+ getStats(operation) {
476
+ const operationMeasurements = this.measurements.get(operation);
477
+ if (!operationMeasurements || operationMeasurements.length === 0) {
478
+ return null;
479
+ }
480
+ const durations = operationMeasurements
481
+ .filter((m) => 'duration' in m)
482
+ .map(m => m.duration);
483
+ if (durations.length === 0)
484
+ return null;
485
+ return {
486
+ count: durations.length,
487
+ avgDuration: durations.reduce((a, b) => a + b, 0) / durations.length,
488
+ minDuration: Math.min(...durations),
489
+ maxDuration: Math.max(...durations),
490
+ totalDuration: durations.reduce((a, b) => a + b, 0),
491
+ };
492
+ }
493
+ /**
494
+ * Get all operation statistics
495
+ */
496
+ getAllStats() {
497
+ const stats = {};
498
+ for (const operation of this.measurements.keys()) {
499
+ stats[operation] = this.getStats(operation);
500
+ }
501
+ return stats;
502
+ }
503
+ /**
504
+ * Clear all measurements
505
+ */
506
+ clear() {
507
+ this.measurements.clear();
508
+ }
509
+ /**
510
+ * Clear measurements for a specific operation
511
+ */
512
+ clearOperation(operation) {
513
+ this.measurements.delete(operation);
514
+ }
515
+ }
516
+ /**
517
+ * Global performance monitor instance
518
+ */
519
+ export const globalPerformanceMonitor = new PerformanceMonitor();
520
+ //# sourceMappingURL=performance.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"performance.js","sourceRoot":"","sources":["../../../source/utils/logging/performance.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=performance.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"performance.spec.d.ts","sourceRoot":"","sources":["../../../source/utils/logging/performance.spec.ts"],"names":[],"mappings":""}