@gguf/coder 0.2.9 → 0.3.1

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 (439) hide show
  1. package/.editorconfig +16 -0
  2. package/.env.example +63 -0
  3. package/.gitattributes +1 -0
  4. package/.semgrepignore +19 -0
  5. package/coder-dummy-file.ts +52 -0
  6. package/coder.config.example.json +59 -0
  7. package/coder.config.json +13 -0
  8. package/color_picker.html +36 -0
  9. package/dist/tools/execute-bash.js +3 -3
  10. package/dist/tools/execute-bash.js.map +1 -1
  11. package/dist/tools/fetch-url.js +3 -3
  12. package/dist/tools/fetch-url.js.map +1 -1
  13. package/dist/tools/find-files.d.ts.map +1 -1
  14. package/dist/tools/find-files.js +1 -1
  15. package/dist/tools/find-files.js.map +1 -1
  16. package/dist/tools/lsp-get-diagnostics.js +1 -1
  17. package/dist/tools/lsp-get-diagnostics.js.map +1 -1
  18. package/dist/tools/read-file.d.ts.map +1 -1
  19. package/dist/tools/read-file.js +6 -6
  20. package/dist/tools/read-file.js.map +1 -1
  21. package/dist/tools/search-file-contents.d.ts.map +1 -1
  22. package/dist/tools/search-file-contents.js +1 -1
  23. package/dist/tools/search-file-contents.js.map +1 -1
  24. package/dist/tools/string-replace.js +11 -11
  25. package/dist/tools/string-replace.js.map +1 -1
  26. package/dist/tools/web-search.d.ts.map +1 -1
  27. package/dist/tools/web-search.js +3 -3
  28. package/dist/tools/web-search.js.map +1 -1
  29. package/dist/tools/write-file.js +4 -4
  30. package/dist/tools/write-file.js.map +1 -1
  31. package/dist/utils/tool-result-display.d.ts.map +1 -1
  32. package/dist/utils/tool-result-display.js +3 -3
  33. package/dist/utils/tool-result-display.js.map +1 -1
  34. package/package.json +2 -14
  35. package/scripts/extract-changelog.js +73 -0
  36. package/scripts/fetch-models.js +143 -0
  37. package/scripts/test.sh +40 -0
  38. package/scripts/update-homebrew-formula.sh +125 -0
  39. package/scripts/update-nix-version.sh +157 -0
  40. package/source/ai-sdk-client/AISDKClient.spec.ts +117 -0
  41. package/source/ai-sdk-client/AISDKClient.ts +155 -0
  42. package/source/ai-sdk-client/chat/chat-handler.spec.ts +121 -0
  43. package/source/ai-sdk-client/chat/chat-handler.ts +276 -0
  44. package/source/ai-sdk-client/chat/streaming-handler.spec.ts +173 -0
  45. package/source/ai-sdk-client/chat/streaming-handler.ts +110 -0
  46. package/source/ai-sdk-client/chat/tool-processor.spec.ts +92 -0
  47. package/source/ai-sdk-client/chat/tool-processor.ts +70 -0
  48. package/source/ai-sdk-client/converters/message-converter.spec.ts +220 -0
  49. package/source/ai-sdk-client/converters/message-converter.ts +113 -0
  50. package/source/ai-sdk-client/converters/tool-converter.spec.ts +90 -0
  51. package/source/ai-sdk-client/converters/tool-converter.ts +46 -0
  52. package/source/ai-sdk-client/error-handling/error-extractor.spec.ts +55 -0
  53. package/source/ai-sdk-client/error-handling/error-extractor.ts +15 -0
  54. package/source/ai-sdk-client/error-handling/error-parser.spec.ts +169 -0
  55. package/source/ai-sdk-client/error-handling/error-parser.ts +161 -0
  56. package/source/ai-sdk-client/index.ts +7 -0
  57. package/source/ai-sdk-client/providers/provider-factory.spec.ts +71 -0
  58. package/source/ai-sdk-client/providers/provider-factory.ts +41 -0
  59. package/source/ai-sdk-client/types.ts +9 -0
  60. package/source/ai-sdk-client-empty-message.spec.ts +141 -0
  61. package/source/ai-sdk-client-error-handling.spec.ts +186 -0
  62. package/source/ai-sdk-client-maxretries.spec.ts +114 -0
  63. package/source/ai-sdk-client-preparestep.spec.ts +279 -0
  64. package/source/app/App.spec.tsx +32 -0
  65. package/source/app/App.tsx +480 -0
  66. package/source/app/components/AppContainer.spec.tsx +96 -0
  67. package/source/app/components/AppContainer.tsx +56 -0
  68. package/source/app/components/ChatInterface.spec.tsx +163 -0
  69. package/source/app/components/ChatInterface.tsx +144 -0
  70. package/source/app/components/ModalSelectors.spec.tsx +141 -0
  71. package/source/app/components/ModalSelectors.tsx +135 -0
  72. package/source/app/helpers.spec.ts +97 -0
  73. package/source/app/helpers.ts +63 -0
  74. package/source/app/index.ts +4 -0
  75. package/source/app/types.ts +39 -0
  76. package/source/app/utils/appUtils.ts +294 -0
  77. package/source/app/utils/conversationState.ts +310 -0
  78. package/source/app.spec.tsx +244 -0
  79. package/source/cli.spec.ts +73 -0
  80. package/source/cli.tsx +51 -0
  81. package/source/client-factory.spec.ts +48 -0
  82. package/source/client-factory.ts +178 -0
  83. package/source/command-parser.spec.ts +127 -0
  84. package/source/command-parser.ts +36 -0
  85. package/source/commands/checkpoint.spec.tsx +277 -0
  86. package/source/commands/checkpoint.tsx +366 -0
  87. package/source/commands/clear.tsx +22 -0
  88. package/source/commands/custom-commands.tsx +121 -0
  89. package/source/commands/exit.ts +21 -0
  90. package/source/commands/export.spec.tsx +131 -0
  91. package/source/commands/export.tsx +79 -0
  92. package/source/commands/help.tsx +120 -0
  93. package/source/commands/index.ts +17 -0
  94. package/source/commands/init.tsx +339 -0
  95. package/source/commands/lsp-command.spec.tsx +281 -0
  96. package/source/commands/lsp.tsx +120 -0
  97. package/source/commands/mcp-command.spec.tsx +313 -0
  98. package/source/commands/mcp.tsx +162 -0
  99. package/source/commands/model-database.spec.tsx +758 -0
  100. package/source/commands/model-database.tsx +418 -0
  101. package/source/commands/model.ts +12 -0
  102. package/source/commands/provider.ts +12 -0
  103. package/source/commands/setup-config.tsx +16 -0
  104. package/source/commands/simple-commands.spec.tsx +175 -0
  105. package/source/commands/status.ts +12 -0
  106. package/source/commands/theme.ts +12 -0
  107. package/source/commands/update.spec.tsx +261 -0
  108. package/source/commands/update.tsx +201 -0
  109. package/source/commands/usage.spec.tsx +495 -0
  110. package/source/commands/usage.tsx +100 -0
  111. package/source/commands.spec.ts +436 -0
  112. package/source/commands.ts +83 -0
  113. package/source/components/assistant-message.spec.tsx +796 -0
  114. package/source/components/assistant-message.tsx +34 -0
  115. package/source/components/bash-execution-indicator.tsx +21 -0
  116. package/source/components/cancelling-indicator.tsx +16 -0
  117. package/source/components/chat-queue.spec.tsx +83 -0
  118. package/source/components/chat-queue.tsx +36 -0
  119. package/source/components/checkpoint-display.spec.tsx +219 -0
  120. package/source/components/checkpoint-display.tsx +126 -0
  121. package/source/components/checkpoint-selector.spec.tsx +173 -0
  122. package/source/components/checkpoint-selector.tsx +173 -0
  123. package/source/components/development-mode-indicator.spec.tsx +268 -0
  124. package/source/components/development-mode-indicator.tsx +38 -0
  125. package/source/components/message-box.spec.tsx +427 -0
  126. package/source/components/message-box.tsx +87 -0
  127. package/source/components/model-selector.tsx +132 -0
  128. package/source/components/provider-selector.tsx +75 -0
  129. package/source/components/random-spinner.tsx +19 -0
  130. package/source/components/security-disclaimer.tsx +73 -0
  131. package/source/components/status-connection-display.spec.tsx +133 -0
  132. package/source/components/status.tsx +267 -0
  133. package/source/components/theme-selector.tsx +126 -0
  134. package/source/components/tool-confirmation.tsx +190 -0
  135. package/source/components/tool-execution-indicator.tsx +33 -0
  136. package/source/components/tool-message.tsx +85 -0
  137. package/source/components/ui/titled-box.spec.tsx +207 -0
  138. package/source/components/ui/titled-box.tsx +57 -0
  139. package/source/components/usage/progress-bar.spec.tsx +398 -0
  140. package/source/components/usage/progress-bar.tsx +30 -0
  141. package/source/components/usage/usage-display.spec.tsx +780 -0
  142. package/source/components/usage/usage-display.tsx +291 -0
  143. package/source/components/user-input.spec.tsx +327 -0
  144. package/source/components/user-input.tsx +533 -0
  145. package/source/components/user-message.spec.tsx +230 -0
  146. package/source/components/user-message.tsx +84 -0
  147. package/source/components/welcome-message.tsx +76 -0
  148. package/source/config/env-substitution.ts +65 -0
  149. package/source/config/index.spec.ts +171 -0
  150. package/source/config/index.ts +154 -0
  151. package/source/config/paths.spec.ts +241 -0
  152. package/source/config/paths.ts +55 -0
  153. package/source/config/preferences.ts +51 -0
  154. package/source/config/themes.ts +315 -0
  155. package/source/constants.ts +130 -0
  156. package/source/context/mode-context.spec.ts +79 -0
  157. package/source/context/mode-context.ts +24 -0
  158. package/source/custom-commands/executor.spec.ts +142 -0
  159. package/source/custom-commands/executor.ts +64 -0
  160. package/source/custom-commands/loader.spec.ts +314 -0
  161. package/source/custom-commands/loader.ts +153 -0
  162. package/source/custom-commands/parser.ts +196 -0
  163. package/source/hooks/chat-handler/conversation/conversation-loop.spec.ts +39 -0
  164. package/source/hooks/chat-handler/conversation/conversation-loop.tsx +511 -0
  165. package/source/hooks/chat-handler/conversation/tool-executor.spec.ts +50 -0
  166. package/source/hooks/chat-handler/conversation/tool-executor.tsx +109 -0
  167. package/source/hooks/chat-handler/index.ts +12 -0
  168. package/source/hooks/chat-handler/state/streaming-state.spec.ts +26 -0
  169. package/source/hooks/chat-handler/state/streaming-state.ts +19 -0
  170. package/source/hooks/chat-handler/types.ts +38 -0
  171. package/source/hooks/chat-handler/useChatHandler.spec.tsx +321 -0
  172. package/source/hooks/chat-handler/useChatHandler.tsx +194 -0
  173. package/source/hooks/chat-handler/utils/context-checker.spec.ts +60 -0
  174. package/source/hooks/chat-handler/utils/context-checker.tsx +73 -0
  175. package/source/hooks/chat-handler/utils/message-helpers.spec.ts +42 -0
  176. package/source/hooks/chat-handler/utils/message-helpers.tsx +36 -0
  177. package/source/hooks/chat-handler/utils/tool-filters.spec.ts +109 -0
  178. package/source/hooks/chat-handler/utils/tool-filters.ts +64 -0
  179. package/source/hooks/useAppHandlers.tsx +291 -0
  180. package/source/hooks/useAppInitialization.tsx +422 -0
  181. package/source/hooks/useAppState.tsx +311 -0
  182. package/source/hooks/useDirectoryTrust.tsx +98 -0
  183. package/source/hooks/useInputState.ts +414 -0
  184. package/source/hooks/useModeHandlers.tsx +302 -0
  185. package/source/hooks/useNonInteractiveMode.ts +140 -0
  186. package/source/hooks/useTerminalWidth.tsx +81 -0
  187. package/source/hooks/useTheme.ts +18 -0
  188. package/source/hooks/useToolHandler.tsx +349 -0
  189. package/source/hooks/useUIState.ts +61 -0
  190. package/source/init/agents-template-generator.ts +421 -0
  191. package/source/init/existing-rules-extractor.ts +319 -0
  192. package/source/init/file-scanner.spec.ts +227 -0
  193. package/source/init/file-scanner.ts +238 -0
  194. package/source/init/framework-detector.ts +382 -0
  195. package/source/init/language-detector.ts +269 -0
  196. package/source/init/project-analyzer.spec.ts +231 -0
  197. package/source/init/project-analyzer.ts +458 -0
  198. package/source/lsp/index.ts +31 -0
  199. package/source/lsp/lsp-client.spec.ts +508 -0
  200. package/source/lsp/lsp-client.ts +487 -0
  201. package/source/lsp/lsp-manager.spec.ts +477 -0
  202. package/source/lsp/lsp-manager.ts +419 -0
  203. package/source/lsp/protocol.spec.ts +502 -0
  204. package/source/lsp/protocol.ts +360 -0
  205. package/source/lsp/server-discovery.spec.ts +654 -0
  206. package/source/lsp/server-discovery.ts +515 -0
  207. package/source/markdown-parser/html-entities.spec.ts +88 -0
  208. package/source/markdown-parser/html-entities.ts +45 -0
  209. package/source/markdown-parser/index.spec.ts +281 -0
  210. package/source/markdown-parser/index.ts +126 -0
  211. package/source/markdown-parser/table-parser.spec.ts +133 -0
  212. package/source/markdown-parser/table-parser.ts +114 -0
  213. package/source/markdown-parser/utils.spec.ts +70 -0
  214. package/source/markdown-parser/utils.ts +13 -0
  215. package/source/mcp/mcp-client.spec.ts +81 -0
  216. package/source/mcp/mcp-client.ts +625 -0
  217. package/source/mcp/transport-factory.spec.ts +406 -0
  218. package/source/mcp/transport-factory.ts +312 -0
  219. package/source/message-handler.ts +67 -0
  220. package/source/model-database/database-engine.spec.ts +494 -0
  221. package/source/model-database/database-engine.ts +50 -0
  222. package/source/model-database/model-database.spec.ts +363 -0
  223. package/source/model-database/model-database.ts +91 -0
  224. package/source/model-database/model-engine.spec.ts +447 -0
  225. package/source/model-database/model-engine.ts +65 -0
  226. package/source/model-database/model-fetcher.spec.ts +583 -0
  227. package/source/model-database/model-fetcher.ts +330 -0
  228. package/source/models/index.ts +1 -0
  229. package/source/models/models-cache.spec.ts +214 -0
  230. package/source/models/models-cache.ts +78 -0
  231. package/source/models/models-dev-client.spec.ts +379 -0
  232. package/source/models/models-dev-client.ts +329 -0
  233. package/source/models/models-types.ts +68 -0
  234. package/source/prompt-history.ts +155 -0
  235. package/source/security/command-injection.spec.ts +240 -0
  236. package/source/services/checkpoint-manager.spec.ts +523 -0
  237. package/source/services/checkpoint-manager.ts +466 -0
  238. package/source/services/file-snapshot.spec.ts +569 -0
  239. package/source/services/file-snapshot.ts +220 -0
  240. package/source/test-utils/render-with-theme.tsx +48 -0
  241. package/source/tokenization/index.ts +1 -0
  242. package/source/tokenization/tokenizer-factory.spec.ts +170 -0
  243. package/source/tokenization/tokenizer-factory.ts +125 -0
  244. package/source/tokenization/tokenizers/anthropic-tokenizer.spec.ts +200 -0
  245. package/source/tokenization/tokenizers/anthropic-tokenizer.ts +43 -0
  246. package/source/tokenization/tokenizers/fallback-tokenizer.spec.ts +236 -0
  247. package/source/tokenization/tokenizers/fallback-tokenizer.ts +26 -0
  248. package/source/tokenization/tokenizers/llama-tokenizer.spec.ts +224 -0
  249. package/source/tokenization/tokenizers/llama-tokenizer.ts +41 -0
  250. package/source/tokenization/tokenizers/openai-tokenizer.spec.ts +184 -0
  251. package/source/tokenization/tokenizers/openai-tokenizer.ts +57 -0
  252. package/source/tool-calling/index.ts +5 -0
  253. package/source/tool-calling/json-parser.spec.ts +639 -0
  254. package/source/tool-calling/json-parser.ts +247 -0
  255. package/source/tool-calling/tool-parser.spec.ts +395 -0
  256. package/source/tool-calling/tool-parser.ts +120 -0
  257. package/source/tool-calling/xml-parser.spec.ts +662 -0
  258. package/source/tool-calling/xml-parser.ts +289 -0
  259. package/source/tools/execute-bash.spec.tsx +353 -0
  260. package/source/tools/execute-bash.tsx +219 -0
  261. package/source/tools/execute-function.spec.ts +130 -0
  262. package/source/tools/fetch-url.spec.tsx +342 -0
  263. package/source/tools/fetch-url.tsx +172 -0
  264. package/source/tools/find-files.spec.tsx +924 -0
  265. package/source/tools/find-files.tsx +293 -0
  266. package/source/tools/index.ts +102 -0
  267. package/source/tools/lsp-get-diagnostics.tsx +192 -0
  268. package/source/tools/needs-approval.spec.ts +282 -0
  269. package/source/tools/read-file.spec.tsx +801 -0
  270. package/source/tools/read-file.tsx +387 -0
  271. package/source/tools/search-file-contents.spec.tsx +1273 -0
  272. package/source/tools/search-file-contents.tsx +293 -0
  273. package/source/tools/string-replace.spec.tsx +730 -0
  274. package/source/tools/string-replace.tsx +548 -0
  275. package/source/tools/tool-manager.ts +210 -0
  276. package/source/tools/tool-registry.spec.ts +415 -0
  277. package/source/tools/tool-registry.ts +228 -0
  278. package/source/tools/web-search.tsx +223 -0
  279. package/source/tools/write-file.spec.tsx +559 -0
  280. package/source/tools/write-file.tsx +228 -0
  281. package/source/types/app.ts +37 -0
  282. package/source/types/checkpoint.ts +48 -0
  283. package/source/types/commands.ts +46 -0
  284. package/source/types/components.ts +27 -0
  285. package/source/types/config.ts +103 -0
  286. package/source/types/core-connection-status.spec.ts +67 -0
  287. package/source/types/core.ts +181 -0
  288. package/source/types/hooks.ts +50 -0
  289. package/source/types/index.ts +12 -0
  290. package/source/types/markdown-parser.ts +11 -0
  291. package/source/types/mcp.ts +52 -0
  292. package/source/types/system.ts +16 -0
  293. package/source/types/tokenization.ts +41 -0
  294. package/source/types/ui.ts +40 -0
  295. package/source/types/usage.ts +58 -0
  296. package/source/types/utils.ts +16 -0
  297. package/source/usage/calculator.spec.ts +385 -0
  298. package/source/usage/calculator.ts +104 -0
  299. package/source/usage/storage.spec.ts +703 -0
  300. package/source/usage/storage.ts +238 -0
  301. package/source/usage/tracker.spec.ts +456 -0
  302. package/source/usage/tracker.ts +102 -0
  303. package/source/utils/atomic-deletion.spec.ts +194 -0
  304. package/source/utils/atomic-deletion.ts +127 -0
  305. package/source/utils/bounded-map.spec.ts +300 -0
  306. package/source/utils/bounded-map.ts +193 -0
  307. package/source/utils/checkpoint-utils.spec.ts +222 -0
  308. package/source/utils/checkpoint-utils.ts +92 -0
  309. package/source/utils/error-formatter.spec.ts +169 -0
  310. package/source/utils/error-formatter.ts +194 -0
  311. package/source/utils/file-autocomplete.spec.ts +173 -0
  312. package/source/utils/file-autocomplete.ts +196 -0
  313. package/source/utils/file-cache.spec.ts +309 -0
  314. package/source/utils/file-cache.ts +195 -0
  315. package/source/utils/file-content-loader.spec.ts +180 -0
  316. package/source/utils/file-content-loader.ts +179 -0
  317. package/source/utils/file-mention-handler.spec.ts +261 -0
  318. package/source/utils/file-mention-handler.ts +84 -0
  319. package/source/utils/file-mention-parser.spec.ts +182 -0
  320. package/source/utils/file-mention-parser.ts +170 -0
  321. package/source/utils/fuzzy-matching.spec.ts +149 -0
  322. package/source/utils/fuzzy-matching.ts +146 -0
  323. package/source/utils/indentation-normalizer.spec.ts +216 -0
  324. package/source/utils/indentation-normalizer.ts +76 -0
  325. package/source/utils/installation-detector.spec.ts +178 -0
  326. package/source/utils/installation-detector.ts +153 -0
  327. package/source/utils/logging/config.spec.ts +311 -0
  328. package/source/utils/logging/config.ts +210 -0
  329. package/source/utils/logging/console-facade.spec.ts +184 -0
  330. package/source/utils/logging/console-facade.ts +384 -0
  331. package/source/utils/logging/correlation.spec.ts +679 -0
  332. package/source/utils/logging/correlation.ts +474 -0
  333. package/source/utils/logging/formatters.spec.ts +464 -0
  334. package/source/utils/logging/formatters.ts +207 -0
  335. package/source/utils/logging/health-monitor/alerts/alert-manager.spec.ts +93 -0
  336. package/source/utils/logging/health-monitor/alerts/alert-manager.ts +79 -0
  337. package/source/utils/logging/health-monitor/checks/configuration-check.spec.ts +56 -0
  338. package/source/utils/logging/health-monitor/checks/configuration-check.ts +43 -0
  339. package/source/utils/logging/health-monitor/checks/logging-check.spec.ts +56 -0
  340. package/source/utils/logging/health-monitor/checks/logging-check.ts +58 -0
  341. package/source/utils/logging/health-monitor/checks/memory-check.spec.ts +100 -0
  342. package/source/utils/logging/health-monitor/checks/memory-check.ts +78 -0
  343. package/source/utils/logging/health-monitor/checks/performance-check.spec.ts +56 -0
  344. package/source/utils/logging/health-monitor/checks/performance-check.ts +56 -0
  345. package/source/utils/logging/health-monitor/checks/request-check.spec.ts +56 -0
  346. package/source/utils/logging/health-monitor/checks/request-check.ts +76 -0
  347. package/source/utils/logging/health-monitor/core/health-check-runner.spec.ts +70 -0
  348. package/source/utils/logging/health-monitor/core/health-check-runner.ts +138 -0
  349. package/source/utils/logging/health-monitor/core/health-monitor.spec.ts +58 -0
  350. package/source/utils/logging/health-monitor/core/health-monitor.ts +344 -0
  351. package/source/utils/logging/health-monitor/core/scoring.spec.ts +65 -0
  352. package/source/utils/logging/health-monitor/core/scoring.ts +91 -0
  353. package/source/utils/logging/health-monitor/index.ts +15 -0
  354. package/source/utils/logging/health-monitor/instances.ts +48 -0
  355. package/source/utils/logging/health-monitor/middleware/http-middleware.spec.ts +141 -0
  356. package/source/utils/logging/health-monitor/middleware/http-middleware.ts +75 -0
  357. package/source/utils/logging/health-monitor/types.ts +126 -0
  358. package/source/utils/logging/index.spec.ts +284 -0
  359. package/source/utils/logging/index.ts +236 -0
  360. package/source/utils/logging/integration.spec.ts +441 -0
  361. package/source/utils/logging/log-method-factory.spec.ts +573 -0
  362. package/source/utils/logging/log-method-factory.ts +233 -0
  363. package/source/utils/logging/log-query/aggregation/aggregator.spec.ts +277 -0
  364. package/source/utils/logging/log-query/aggregation/aggregator.ts +159 -0
  365. package/source/utils/logging/log-query/aggregation/facet-generator.spec.ts +159 -0
  366. package/source/utils/logging/log-query/aggregation/facet-generator.ts +47 -0
  367. package/source/utils/logging/log-query/index.ts +23 -0
  368. package/source/utils/logging/log-query/query/filter-predicates.spec.ts +247 -0
  369. package/source/utils/logging/log-query/query/filter-predicates.ts +154 -0
  370. package/source/utils/logging/log-query/query/query-builder.spec.ts +182 -0
  371. package/source/utils/logging/log-query/query/query-builder.ts +151 -0
  372. package/source/utils/logging/log-query/query/query-engine.spec.ts +214 -0
  373. package/source/utils/logging/log-query/query/query-engine.ts +45 -0
  374. package/source/utils/logging/log-query/storage/circular-buffer.spec.ts +143 -0
  375. package/source/utils/logging/log-query/storage/circular-buffer.ts +75 -0
  376. package/source/utils/logging/log-query/storage/index-manager.spec.ts +150 -0
  377. package/source/utils/logging/log-query/storage/index-manager.ts +71 -0
  378. package/source/utils/logging/log-query/storage/log-storage.spec.ts +257 -0
  379. package/source/utils/logging/log-query/storage/log-storage.ts +80 -0
  380. package/source/utils/logging/log-query/types.ts +163 -0
  381. package/source/utils/logging/log-query/utils/helpers.spec.ts +263 -0
  382. package/source/utils/logging/log-query/utils/helpers.ts +72 -0
  383. package/source/utils/logging/log-query/utils/sorting.spec.ts +182 -0
  384. package/source/utils/logging/log-query/utils/sorting.ts +61 -0
  385. package/source/utils/logging/logger-provider.spec.ts +262 -0
  386. package/source/utils/logging/logger-provider.ts +362 -0
  387. package/source/utils/logging/performance.spec.ts +209 -0
  388. package/source/utils/logging/performance.ts +757 -0
  389. package/source/utils/logging/pino-logger.spec.ts +425 -0
  390. package/source/utils/logging/pino-logger.ts +514 -0
  391. package/source/utils/logging/redaction.spec.ts +490 -0
  392. package/source/utils/logging/redaction.ts +267 -0
  393. package/source/utils/logging/request-tracker.spec.ts +1198 -0
  394. package/source/utils/logging/request-tracker.ts +803 -0
  395. package/source/utils/logging/transports.spec.ts +505 -0
  396. package/source/utils/logging/transports.ts +305 -0
  397. package/source/utils/logging/types.ts +216 -0
  398. package/source/utils/message-builder.spec.ts +179 -0
  399. package/source/utils/message-builder.ts +101 -0
  400. package/source/utils/message-queue.tsx +486 -0
  401. package/source/utils/paste-detection.spec.ts +69 -0
  402. package/source/utils/paste-detection.ts +124 -0
  403. package/source/utils/paste-roundtrip.spec.ts +442 -0
  404. package/source/utils/paste-utils.spec.ts +128 -0
  405. package/source/utils/paste-utils.ts +52 -0
  406. package/source/utils/programming-language-helper.spec.ts +74 -0
  407. package/source/utils/programming-language-helper.ts +32 -0
  408. package/source/utils/prompt-assembly.spec.ts +221 -0
  409. package/source/utils/prompt-processor.ts +173 -0
  410. package/source/utils/tool-args-parser.spec.ts +136 -0
  411. package/source/utils/tool-args-parser.ts +54 -0
  412. package/source/utils/tool-cancellation.spec.ts +230 -0
  413. package/source/utils/tool-cancellation.ts +28 -0
  414. package/source/utils/tool-result-display.spec.tsx +469 -0
  415. package/source/utils/tool-result-display.tsx +90 -0
  416. package/source/utils/update-checker.spec.ts +383 -0
  417. package/source/utils/update-checker.ts +183 -0
  418. package/source/wizard/config-wizard.spec.tsx +103 -0
  419. package/source/wizard/config-wizard.tsx +382 -0
  420. package/source/wizard/steps/location-step.spec.tsx +186 -0
  421. package/source/wizard/steps/location-step.tsx +147 -0
  422. package/source/wizard/steps/mcp-step.spec.tsx +607 -0
  423. package/source/wizard/steps/mcp-step.tsx +632 -0
  424. package/source/wizard/steps/provider-step.spec.tsx +342 -0
  425. package/source/wizard/steps/provider-step.tsx +957 -0
  426. package/source/wizard/steps/summary-step.spec.tsx +749 -0
  427. package/source/wizard/steps/summary-step.tsx +228 -0
  428. package/source/wizard/templates/mcp-templates.spec.ts +613 -0
  429. package/source/wizard/templates/mcp-templates.ts +570 -0
  430. package/source/wizard/templates/provider-templates.spec.ts +152 -0
  431. package/source/wizard/templates/provider-templates.ts +485 -0
  432. package/source/wizard/utils/fetch-cloud-models.spec.ts +428 -0
  433. package/source/wizard/utils/fetch-cloud-models.ts +223 -0
  434. package/source/wizard/utils/fetch-local-models.spec.ts +297 -0
  435. package/source/wizard/utils/fetch-local-models.ts +192 -0
  436. package/source/wizard/validation-array.spec.ts +264 -0
  437. package/source/wizard/validation.spec.ts +373 -0
  438. package/source/wizard/validation.ts +232 -0
  439. package/source/app/prompts/main-prompt.md +0 -122
@@ -0,0 +1,238 @@
1
+ import {existsSync, readFileSync, readdirSync, statSync} from 'fs';
2
+ import {basename, join, relative} from 'path';
3
+ import {MAX_DIRECTORY_DEPTH, MAX_FILES_TO_SCAN} from '@/constants';
4
+
5
+ interface ScanResult {
6
+ files: string[];
7
+ directories: string[];
8
+ totalFiles: number;
9
+ scannedFiles: number;
10
+ }
11
+
12
+ export class FileScanner {
13
+ private gitignorePatterns: string[] = [];
14
+ private maxFiles = MAX_FILES_TO_SCAN; // Prevent scanning massive codebases
15
+ private maxDepth = MAX_DIRECTORY_DEPTH; // Prevent infinite recursion
16
+
17
+ constructor(private rootPath: string) {
18
+ this.loadGitignore();
19
+ }
20
+
21
+ /**
22
+ * Load and parse .gitignore patterns
23
+ */
24
+ private loadGitignore(): void {
25
+ const gitignorePath = join(this.rootPath, '.gitignore');
26
+
27
+ if (!existsSync(gitignorePath)) {
28
+ return;
29
+ }
30
+
31
+ try {
32
+ const content = readFileSync(gitignorePath, 'utf-8');
33
+ this.gitignorePatterns = content
34
+ .split('\n')
35
+ .map(line => line.trim())
36
+ .filter(line => line && !line.startsWith('#'))
37
+ .map(pattern => {
38
+ // Convert gitignore patterns to simple regex patterns
39
+ return pattern
40
+ .replace(/\*/g, '.*') // * -> .*
41
+ .replace(/\?/g, '.') // ? -> .
42
+ .replace(/\/$/, ''); // Remove trailing slash
43
+ });
44
+ } catch {
45
+ // Ignore gitignore parsing errors
46
+ }
47
+ }
48
+
49
+ /**
50
+ * Check if a file/directory should be ignored based on .gitignore
51
+ */
52
+ private shouldIgnore(filePath: string): boolean {
53
+ const relativePath = relative(this.rootPath, filePath);
54
+ const fileName = basename(filePath);
55
+
56
+ // Always ignore these directories
57
+ const alwaysIgnore = [
58
+ 'node_modules',
59
+ '.git',
60
+ '.svn',
61
+ '.hg',
62
+ 'dist',
63
+ 'build',
64
+ '.next',
65
+ '.nuxt',
66
+ '__pycache__',
67
+ '.pytest_cache',
68
+ 'target',
69
+ 'coverage',
70
+ ];
71
+
72
+ if (
73
+ alwaysIgnore.some(
74
+ ignored => relativePath.includes(ignored) || fileName === ignored,
75
+ )
76
+ ) {
77
+ return true;
78
+ }
79
+
80
+ // Check gitignore patterns
81
+ return this.gitignorePatterns.some(pattern => {
82
+ // nosemgrep: javascript.lang.security.audit.detect-non-literal-regexp.detect-non-literal-regexp
83
+ // pattern comes from .gitignore file, not user input
84
+ const regex = new RegExp(`^${pattern}$`); // nosemgrep: javascript.lang.security.audit.detect-non-literal-regexp.detect-non-literal-regexp
85
+ return regex.test(relativePath) || regex.test(fileName);
86
+ });
87
+ }
88
+
89
+ /**
90
+ * Recursively scan directory for files
91
+ */
92
+ public scan(): ScanResult {
93
+ const result: ScanResult = {
94
+ files: [],
95
+ directories: [],
96
+ totalFiles: 0,
97
+ scannedFiles: 0,
98
+ };
99
+
100
+ this.scanDirectory(this.rootPath, result, 0);
101
+ return result;
102
+ }
103
+
104
+ /**
105
+ * Recursively scan a directory
106
+ */
107
+ private scanDirectory(
108
+ dirPath: string,
109
+ result: ScanResult,
110
+ depth: number,
111
+ ): void {
112
+ if (depth > this.maxDepth || result.scannedFiles >= this.maxFiles) {
113
+ return;
114
+ }
115
+
116
+ if (this.shouldIgnore(dirPath)) {
117
+ return;
118
+ }
119
+
120
+ try {
121
+ const entries = readdirSync(dirPath);
122
+
123
+ for (const entry of entries) {
124
+ if (result.scannedFiles >= this.maxFiles) {
125
+ break;
126
+ }
127
+
128
+ // nosemgrep
129
+ const fullPath = join(dirPath, entry); // nosemgrep
130
+ const relativePath = relative(this.rootPath, fullPath);
131
+
132
+ if (this.shouldIgnore(fullPath)) {
133
+ continue;
134
+ }
135
+
136
+ try {
137
+ const stats = statSync(fullPath);
138
+
139
+ if (stats.isDirectory()) {
140
+ result.directories.push(relativePath);
141
+ this.scanDirectory(fullPath, result, depth + 1);
142
+ } else if (stats.isFile()) {
143
+ result.files.push(relativePath);
144
+ result.scannedFiles++;
145
+ }
146
+
147
+ result.totalFiles++;
148
+ } catch {
149
+ // Skip files we can't stat (permission issues, etc.)
150
+ continue;
151
+ }
152
+ }
153
+ } catch {
154
+ // Skip directories we can't read
155
+ return;
156
+ }
157
+ }
158
+
159
+ /**
160
+ * Convert a simple glob-like pattern (using '*' as wildcard) to a RegExp.
161
+ * Escapes regex metacharacters before expanding '*' to '.*'.
162
+ */
163
+ private globToRegExp(pattern: string): RegExp {
164
+ // Validate pattern to prevent ReDoS - only allow safe glob patterns
165
+ if (pattern.length > 1000) {
166
+ throw new Error('Pattern too long');
167
+ }
168
+
169
+ // Only allow safe characters in glob patterns
170
+ if (/[^a-zA-Z0-9_\-./\\*?+[\]{}^$|()]/.test(pattern)) {
171
+ throw new Error('Pattern contains unsafe characters');
172
+ }
173
+
174
+ // Escape all regex metacharacters, then replace escaped '*' with '.*'
175
+ const escaped = pattern.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
176
+ const regexSource = escaped.replace(/\\\*/g, '.*');
177
+ return new RegExp(regexSource, 'i'); /* nosemgrep */
178
+ }
179
+
180
+ /**
181
+ * Get files matching specific patterns
182
+ */
183
+ public getFilesByPattern(patterns: string[]): string[] {
184
+ const scanResult = this.scan();
185
+ return scanResult.files.filter(file =>
186
+ patterns.some(pattern => {
187
+ const regex = this.globToRegExp(pattern);
188
+ return regex.test(file) || regex.test(basename(file));
189
+ }),
190
+ );
191
+ }
192
+
193
+ /**
194
+ * Get key project files
195
+ */
196
+ public getProjectFiles(): {[key: string]: string[]} {
197
+ return {
198
+ config: this.getFilesByPattern([
199
+ 'package.json',
200
+ 'requirements.txt',
201
+ 'Cargo.toml',
202
+ 'go.mod',
203
+ 'composer.json',
204
+ 'Gemfile',
205
+ 'setup.py',
206
+ 'pyproject.toml',
207
+ 'yarn.lock',
208
+ 'pnpm-lock.yaml',
209
+ ]),
210
+ documentation: this.getFilesByPattern([
211
+ 'README*',
212
+ 'CHANGELOG*',
213
+ 'LICENSE*',
214
+ 'CONTRIBUTING*',
215
+ '*.md',
216
+ 'docs/*',
217
+ ]),
218
+ build: this.getFilesByPattern([
219
+ 'Makefile',
220
+ 'CMakeLists.txt',
221
+ 'build.gradle',
222
+ 'webpack.config.*',
223
+ 'vite.config.*',
224
+ 'rollup.config.*',
225
+ 'tsconfig.json',
226
+ 'jsconfig.json',
227
+ ]),
228
+ test: this.getFilesByPattern([
229
+ '*test*',
230
+ '*spec*',
231
+ '__tests__/*',
232
+ 'test/*',
233
+ 'tests/*',
234
+ 'spec/*',
235
+ ]),
236
+ };
237
+ }
238
+ }
@@ -0,0 +1,382 @@
1
+ import {existsSync, readFileSync} from 'fs';
2
+ import {join} from 'path';
3
+
4
+ interface FrameworkInfo {
5
+ name: string;
6
+ version?: string;
7
+ category:
8
+ | 'web'
9
+ | 'mobile'
10
+ | 'desktop'
11
+ | 'backend'
12
+ | 'testing'
13
+ | 'build'
14
+ | 'other';
15
+ confidence: 'high' | 'medium' | 'low';
16
+ }
17
+
18
+ interface BuildInfo {
19
+ scripts?: {[script: string]: string};
20
+ buildCommand?: string;
21
+ testCommand?: string;
22
+ devCommand?: string;
23
+ startCommand?: string;
24
+ }
25
+
26
+ interface PackageJson {
27
+ scripts?: {[script: string]: string};
28
+ dependencies?: {[dep: string]: string};
29
+ devDependencies?: {[dep: string]: string};
30
+ peerDependencies?: {[dep: string]: string};
31
+ }
32
+
33
+ export interface ProjectDependencies {
34
+ frameworks: FrameworkInfo[];
35
+ buildTools: string[];
36
+ testingFrameworks: string[];
37
+ buildInfo: BuildInfo;
38
+ }
39
+
40
+ export class FrameworkDetector {
41
+ private static readonly FRAMEWORK_PATTERNS = {
42
+ // Web Frameworks
43
+ react: {name: 'React', category: 'web' as const},
44
+ vue: {name: 'Vue.js', category: 'web' as const},
45
+ angular: {name: 'Angular', category: 'web' as const},
46
+ '@angular/core': {name: 'Angular', category: 'web' as const},
47
+ svelte: {name: 'Svelte', category: 'web' as const},
48
+ next: {name: 'Next.js', category: 'web' as const},
49
+ nuxt: {name: 'Nuxt.js', category: 'web' as const},
50
+ express: {name: 'Express.js', category: 'backend' as const},
51
+ fastify: {name: 'Fastify', category: 'backend' as const},
52
+ koa: {name: 'Koa', category: 'backend' as const},
53
+ nestjs: {name: 'NestJS', category: 'backend' as const},
54
+
55
+ // Python Frameworks
56
+ django: {name: 'Django', category: 'backend' as const},
57
+ flask: {name: 'Flask', category: 'backend' as const},
58
+ fastapi: {name: 'FastAPI', category: 'backend' as const},
59
+
60
+ // Build Tools
61
+ webpack: {name: 'Webpack', category: 'build' as const},
62
+ vite: {name: 'Vite', category: 'build' as const},
63
+ rollup: {name: 'Rollup', category: 'build' as const},
64
+ parcel: {name: 'Parcel', category: 'build' as const},
65
+ esbuild: {name: 'esbuild', category: 'build' as const},
66
+
67
+ // Testing Frameworks
68
+ jest: {name: 'Jest', category: 'testing' as const},
69
+ mocha: {name: 'Mocha', category: 'testing' as const},
70
+ chai: {name: 'Chai', category: 'testing' as const},
71
+ jasmine: {name: 'Jasmine', category: 'testing' as const},
72
+ cypress: {name: 'Cypress', category: 'testing' as const},
73
+ playwright: {name: 'Playwright', category: 'testing' as const},
74
+ vitest: {name: 'Vitest', category: 'testing' as const},
75
+
76
+ // Mobile
77
+ 'react-native': {name: 'React Native', category: 'mobile' as const},
78
+ flutter: {name: 'Flutter', category: 'mobile' as const},
79
+ ionic: {name: 'Ionic', category: 'mobile' as const},
80
+
81
+ // Desktop
82
+ electron: {name: 'Electron', category: 'desktop' as const},
83
+ tauri: {name: 'Tauri', category: 'desktop' as const},
84
+ };
85
+
86
+ constructor(private projectPath: string) {}
87
+
88
+ /**
89
+ * Detect frameworks and dependencies in the project
90
+ */
91
+ public detectDependencies(): ProjectDependencies {
92
+ const result: ProjectDependencies = {
93
+ frameworks: [],
94
+ buildTools: [],
95
+ testingFrameworks: [],
96
+ buildInfo: {},
97
+ };
98
+
99
+ // Check different dependency files
100
+ this.checkPackageJson(result);
101
+ this.checkRequirementsTxt(result);
102
+ this.checkCargoToml(result);
103
+ this.checkGoMod(result);
104
+
105
+ // Deduplicate frameworks by name
106
+ const uniqueFrameworks = new Map<string, FrameworkInfo>();
107
+ for (const framework of result.frameworks) {
108
+ const existing = uniqueFrameworks.get(framework.name);
109
+ if (!existing || framework.confidence === 'high') {
110
+ uniqueFrameworks.set(framework.name, framework);
111
+ }
112
+ }
113
+ result.frameworks = Array.from(uniqueFrameworks.values());
114
+
115
+ // Deduplicate build tools and testing frameworks
116
+ result.buildTools = [...new Set(result.buildTools)];
117
+ result.testingFrameworks = [...new Set(result.testingFrameworks)];
118
+
119
+ return result;
120
+ }
121
+
122
+ /**
123
+ * Check package.json for Node.js dependencies
124
+ */
125
+ private checkPackageJson(result: ProjectDependencies): void {
126
+ const packageJsonPath = join(this.projectPath, 'package.json');
127
+
128
+ if (!existsSync(packageJsonPath)) {
129
+ return;
130
+ }
131
+
132
+ try {
133
+ const content = readFileSync(packageJsonPath, 'utf-8');
134
+ const packageJson = JSON.parse(content) as PackageJson;
135
+
136
+ // Extract build info
137
+ if (packageJson.scripts) {
138
+ result.buildInfo.scripts = packageJson.scripts;
139
+ result.buildInfo.buildCommand = packageJson.scripts.build;
140
+ result.buildInfo.testCommand = packageJson.scripts.test;
141
+ result.buildInfo.devCommand =
142
+ packageJson.scripts.dev || packageJson.scripts['dev:server'];
143
+ result.buildInfo.startCommand = packageJson.scripts.start;
144
+ }
145
+
146
+ // Check dependencies and devDependencies
147
+ const allDeps = {
148
+ ...packageJson.dependencies,
149
+ ...packageJson.devDependencies,
150
+ ...packageJson.peerDependencies,
151
+ };
152
+
153
+ for (const [depName, version] of Object.entries(allDeps)) {
154
+ const framework = this.matchFramework(depName, version);
155
+ if (framework) {
156
+ result.frameworks.push(framework);
157
+
158
+ // Categorize
159
+ if (framework.category === 'build') {
160
+ result.buildTools.push(framework.name);
161
+ } else if (framework.category === 'testing') {
162
+ result.testingFrameworks.push(framework.name);
163
+ }
164
+ }
165
+ }
166
+ } catch {
167
+ // Ignore parsing errors
168
+ }
169
+ }
170
+
171
+ /**
172
+ * Check requirements.txt for Python dependencies
173
+ */
174
+ private checkRequirementsTxt(result: ProjectDependencies): void {
175
+ const reqPath = join(this.projectPath, 'requirements.txt');
176
+
177
+ if (!existsSync(reqPath)) {
178
+ return;
179
+ }
180
+
181
+ try {
182
+ const content = readFileSync(reqPath, 'utf-8');
183
+ const lines = content
184
+ .split('\n')
185
+ .filter(line => line.trim() && !line.startsWith('#'));
186
+
187
+ for (const line of lines) {
188
+ const depName = line.split(/[>=<]/)[0].trim();
189
+ const framework = this.matchFramework(depName, '');
190
+ if (framework) {
191
+ result.frameworks.push(framework);
192
+ }
193
+ }
194
+ } catch {
195
+ // Ignore parsing errors
196
+ }
197
+ }
198
+
199
+ /**
200
+ * Check Cargo.toml for Rust dependencies
201
+ */
202
+ private checkCargoToml(result: ProjectDependencies): void {
203
+ const cargoPath = join(this.projectPath, 'Cargo.toml');
204
+
205
+ if (!existsSync(cargoPath)) {
206
+ return;
207
+ }
208
+
209
+ try {
210
+ const content = readFileSync(cargoPath, 'utf-8');
211
+
212
+ // Simple TOML parsing for dependencies section
213
+ const depsMatch = content.match(/\[dependencies\]([\s\S]*?)(?:\[|$)/);
214
+ if (depsMatch) {
215
+ const depsSection = depsMatch[1];
216
+ const lines = depsSection
217
+ .split('\n')
218
+ .filter(line => line.trim() && !line.startsWith('#'));
219
+
220
+ for (const line of lines) {
221
+ const match = line.match(/^([^=]+)\s*=/);
222
+ if (match) {
223
+ const depName = match[1].trim();
224
+ const framework = this.matchFramework(depName, '');
225
+ if (framework) {
226
+ result.frameworks.push(framework);
227
+ }
228
+ }
229
+ }
230
+ }
231
+
232
+ // Check for common Rust web frameworks
233
+ if (content.includes('actix-web')) {
234
+ result.frameworks.push({
235
+ name: 'Actix Web',
236
+ category: 'backend',
237
+ confidence: 'high',
238
+ });
239
+ }
240
+ if (content.includes('warp')) {
241
+ result.frameworks.push({
242
+ name: 'Warp',
243
+ category: 'backend',
244
+ confidence: 'high',
245
+ });
246
+ }
247
+ if (content.includes('rocket')) {
248
+ result.frameworks.push({
249
+ name: 'Rocket',
250
+ category: 'backend',
251
+ confidence: 'high',
252
+ });
253
+ }
254
+ } catch {
255
+ // Ignore parsing errors
256
+ }
257
+ }
258
+
259
+ /**
260
+ * Check go.mod for Go dependencies
261
+ */
262
+ private checkGoMod(result: ProjectDependencies): void {
263
+ const goModPath = join(this.projectPath, 'go.mod');
264
+
265
+ if (!existsSync(goModPath)) {
266
+ return;
267
+ }
268
+
269
+ try {
270
+ const content = readFileSync(goModPath, 'utf-8');
271
+
272
+ // Check for common Go frameworks
273
+ if (content.includes('gin-gonic/gin')) {
274
+ result.frameworks.push({
275
+ name: 'Gin',
276
+ category: 'backend',
277
+ confidence: 'high',
278
+ });
279
+ }
280
+ if (content.includes('gorilla/mux')) {
281
+ result.frameworks.push({
282
+ name: 'Gorilla Mux',
283
+ category: 'backend',
284
+ confidence: 'high',
285
+ });
286
+ }
287
+ if (content.includes('echo')) {
288
+ result.frameworks.push({
289
+ name: 'Echo',
290
+ category: 'backend',
291
+ confidence: 'high',
292
+ });
293
+ }
294
+ } catch {
295
+ // Ignore parsing errors
296
+ }
297
+ }
298
+
299
+ /**
300
+ * Match a dependency name to a known framework
301
+ */
302
+ private matchFramework(
303
+ depName: string,
304
+ version: string,
305
+ ): FrameworkInfo | null {
306
+ const pattern =
307
+ FrameworkDetector.FRAMEWORK_PATTERNS[
308
+ depName as keyof typeof FrameworkDetector.FRAMEWORK_PATTERNS
309
+ ];
310
+
311
+ if (pattern) {
312
+ return {
313
+ name: pattern.name,
314
+ category: pattern.category,
315
+ version: version || undefined,
316
+ confidence: 'high',
317
+ };
318
+ }
319
+
320
+ // Check for partial matches with more precise logic
321
+ for (const [key, pattern] of Object.entries(
322
+ FrameworkDetector.FRAMEWORK_PATTERNS,
323
+ )) {
324
+ // Avoid false positives by checking for word boundaries and common prefixes
325
+ const isExactWordMatch = depName === key;
326
+ const hasCommonPrefix =
327
+ depName.startsWith(key + '/') || depName.startsWith(key + '-');
328
+ const isPackageVariant = key.startsWith('@') && depName.startsWith(key);
329
+
330
+ // Only match if it's a clear variant of the framework, not just a substring
331
+ if (isExactWordMatch || hasCommonPrefix || isPackageVariant) {
332
+ return {
333
+ name: pattern.name,
334
+ category: pattern.category,
335
+ version: version || undefined,
336
+ confidence: 'medium',
337
+ };
338
+ }
339
+ }
340
+
341
+ return null;
342
+ }
343
+
344
+ /**
345
+ * Get build commands based on detected frameworks and package.json
346
+ */
347
+ public getBuildCommands(): {[key: string]: string} {
348
+ const deps = this.detectDependencies();
349
+ const commands: {[key: string]: string} = {};
350
+
351
+ if (deps.buildInfo.scripts) {
352
+ const scripts = deps.buildInfo.scripts;
353
+
354
+ // Standard npm/yarn commands
355
+ if (scripts.build) commands['Build'] = 'npm run build';
356
+ if (scripts.test) commands['Test'] = 'npm run test';
357
+ if (scripts.dev) commands['Development'] = 'npm run dev';
358
+ if (scripts.start) commands['Start'] = 'npm run start';
359
+ if (scripts.lint) commands['Lint'] = 'npm run lint';
360
+ }
361
+
362
+ // Add language-specific commands
363
+ if (existsSync(join(this.projectPath, 'Cargo.toml'))) {
364
+ commands['Build'] = 'cargo build';
365
+ commands['Test'] = 'cargo test';
366
+ commands['Run'] = 'cargo run';
367
+ }
368
+
369
+ if (existsSync(join(this.projectPath, 'go.mod'))) {
370
+ commands['Build'] = 'go build';
371
+ commands['Test'] = 'go test ./...';
372
+ commands['Run'] = 'go run .';
373
+ }
374
+
375
+ if (existsSync(join(this.projectPath, 'requirements.txt'))) {
376
+ commands['Install'] = 'pip install -r requirements.txt';
377
+ commands['Test'] = 'python -m pytest';
378
+ }
379
+
380
+ return commands;
381
+ }
382
+ }