osagent-core 0.1.12

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 (1106) hide show
  1. package/dist/.last_build +0 -0
  2. package/dist/index.d.ts +19 -0
  3. package/dist/index.js +20 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/src/__mocks__/fs/promises.d.ts +11 -0
  6. package/dist/src/__mocks__/fs/promises.js +17 -0
  7. package/dist/src/__mocks__/fs/promises.js.map +1 -0
  8. package/dist/src/code_assist/codeAssist.d.ts +12 -0
  9. package/dist/src/code_assist/codeAssist.js +31 -0
  10. package/dist/src/code_assist/codeAssist.js.map +1 -0
  11. package/dist/src/code_assist/converter.d.ts +74 -0
  12. package/dist/src/code_assist/converter.js +160 -0
  13. package/dist/src/code_assist/converter.js.map +1 -0
  14. package/dist/src/code_assist/converter.test.d.ts +6 -0
  15. package/dist/src/code_assist/converter.test.js +372 -0
  16. package/dist/src/code_assist/converter.test.js.map +1 -0
  17. package/dist/src/code_assist/oauth-credential-storage.d.ts +25 -0
  18. package/dist/src/code_assist/oauth-credential-storage.js +109 -0
  19. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -0
  20. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +6 -0
  21. package/dist/src/code_assist/oauth-credential-storage.test.js +136 -0
  22. package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -0
  23. package/dist/src/code_assist/oauth2.d.ts +22 -0
  24. package/dist/src/code_assist/oauth2.js +431 -0
  25. package/dist/src/code_assist/oauth2.js.map +1 -0
  26. package/dist/src/code_assist/oauth2.test.d.ts +6 -0
  27. package/dist/src/code_assist/oauth2.test.js +818 -0
  28. package/dist/src/code_assist/oauth2.test.js.map +1 -0
  29. package/dist/src/code_assist/server.d.ts +37 -0
  30. package/dist/src/code_assist/server.js +148 -0
  31. package/dist/src/code_assist/server.js.map +1 -0
  32. package/dist/src/code_assist/server.test.d.ts +6 -0
  33. package/dist/src/code_assist/server.test.js +159 -0
  34. package/dist/src/code_assist/server.test.js.map +1 -0
  35. package/dist/src/code_assist/setup.d.ts +20 -0
  36. package/dist/src/code_assist/setup.js +101 -0
  37. package/dist/src/code_assist/setup.js.map +1 -0
  38. package/dist/src/code_assist/setup.test.d.ts +6 -0
  39. package/dist/src/code_assist/setup.test.js +171 -0
  40. package/dist/src/code_assist/setup.test.js.map +1 -0
  41. package/dist/src/code_assist/types.d.ts +163 -0
  42. package/dist/src/code_assist/types.js +46 -0
  43. package/dist/src/code_assist/types.js.map +1 -0
  44. package/dist/src/config/config.d.ts +429 -0
  45. package/dist/src/config/config.js +863 -0
  46. package/dist/src/config/config.js.map +1 -0
  47. package/dist/src/config/config.test.d.ts +6 -0
  48. package/dist/src/config/config.test.js +896 -0
  49. package/dist/src/config/config.test.js.map +1 -0
  50. package/dist/src/config/constants.d.ts +11 -0
  51. package/dist/src/config/constants.js +16 -0
  52. package/dist/src/config/constants.js.map +1 -0
  53. package/dist/src/config/flashFallback.test.d.ts +6 -0
  54. package/dist/src/config/flashFallback.test.js +87 -0
  55. package/dist/src/config/flashFallback.test.js.map +1 -0
  56. package/dist/src/config/models.d.ts +28 -0
  57. package/dist/src/config/models.js +44 -0
  58. package/dist/src/config/models.js.map +1 -0
  59. package/dist/src/config/models.test.d.ts +6 -0
  60. package/dist/src/config/models.test.js +55 -0
  61. package/dist/src/config/models.test.js.map +1 -0
  62. package/dist/src/config/storage.d.ts +36 -0
  63. package/dist/src/config/storage.js +103 -0
  64. package/dist/src/config/storage.js.map +1 -0
  65. package/dist/src/config/storage.test.d.ts +6 -0
  66. package/dist/src/config/storage.test.js +43 -0
  67. package/dist/src/config/storage.test.js.map +1 -0
  68. package/dist/src/core/__tests__/openaiTimeoutHandling.test.d.ts +6 -0
  69. package/dist/src/core/__tests__/openaiTimeoutHandling.test.js +295 -0
  70. package/dist/src/core/__tests__/openaiTimeoutHandling.test.js.map +1 -0
  71. package/dist/src/core/__tests__/orphanedToolCallsTest.d.ts +64 -0
  72. package/dist/src/core/__tests__/orphanedToolCallsTest.js +122 -0
  73. package/dist/src/core/__tests__/orphanedToolCallsTest.js.map +1 -0
  74. package/dist/src/core/baseLlmClient.d.ts +49 -0
  75. package/dist/src/core/baseLlmClient.js +104 -0
  76. package/dist/src/core/baseLlmClient.js.map +1 -0
  77. package/dist/src/core/baseLlmClient.test.d.ts +6 -0
  78. package/dist/src/core/baseLlmClient.test.js +323 -0
  79. package/dist/src/core/baseLlmClient.test.js.map +1 -0
  80. package/dist/src/core/client.d.ts +56 -0
  81. package/dist/src/core/client.js +522 -0
  82. package/dist/src/core/client.js.map +1 -0
  83. package/dist/src/core/client.test.d.ts +6 -0
  84. package/dist/src/core/client.test.js +1829 -0
  85. package/dist/src/core/client.test.js.map +1 -0
  86. package/dist/src/core/contentGenerator.d.ts +54 -0
  87. package/dist/src/core/contentGenerator.js +170 -0
  88. package/dist/src/core/contentGenerator.js.map +1 -0
  89. package/dist/src/core/contentGenerator.test.d.ts +6 -0
  90. package/dist/src/core/contentGenerator.test.js +77 -0
  91. package/dist/src/core/contentGenerator.test.js.map +1 -0
  92. package/dist/src/core/coreToolScheduler.d.ts +134 -0
  93. package/dist/src/core/coreToolScheduler.js +774 -0
  94. package/dist/src/core/coreToolScheduler.js.map +1 -0
  95. package/dist/src/core/coreToolScheduler.test.d.ts +6 -0
  96. package/dist/src/core/coreToolScheduler.test.js +1802 -0
  97. package/dist/src/core/coreToolScheduler.test.js.map +1 -0
  98. package/dist/src/core/geminiChat.d.ts +124 -0
  99. package/dist/src/core/geminiChat.js +518 -0
  100. package/dist/src/core/geminiChat.js.map +1 -0
  101. package/dist/src/core/geminiChat.test.d.ts +6 -0
  102. package/dist/src/core/geminiChat.test.js +1149 -0
  103. package/dist/src/core/geminiChat.test.js.map +1 -0
  104. package/dist/src/core/geminiRequest.d.ts +13 -0
  105. package/dist/src/core/geminiRequest.js +11 -0
  106. package/dist/src/core/geminiRequest.js.map +1 -0
  107. package/dist/src/core/geminiRequest.test.d.ts +6 -0
  108. package/dist/src/core/geminiRequest.test.js +73 -0
  109. package/dist/src/core/geminiRequest.test.js.map +1 -0
  110. package/dist/src/core/logger.d.ts +67 -0
  111. package/dist/src/core/logger.js +361 -0
  112. package/dist/src/core/logger.js.map +1 -0
  113. package/dist/src/core/logger.test.d.ts +6 -0
  114. package/dist/src/core/logger.test.js +534 -0
  115. package/dist/src/core/logger.test.js.map +1 -0
  116. package/dist/src/core/loggingContentGenerator.d.ts +25 -0
  117. package/dist/src/core/loggingContentGenerator.js +94 -0
  118. package/dist/src/core/loggingContentGenerator.js.map +1 -0
  119. package/dist/src/core/nonInteractiveToolExecutor.d.ts +16 -0
  120. package/dist/src/core/nonInteractiveToolExecutor.js +29 -0
  121. package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  122. package/dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
  123. package/dist/src/core/nonInteractiveToolExecutor.test.js +294 -0
  124. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
  125. package/dist/src/core/ollamaContentGenerator/index.d.ts +70 -0
  126. package/dist/src/core/ollamaContentGenerator/index.js +450 -0
  127. package/dist/src/core/ollamaContentGenerator/index.js.map +1 -0
  128. package/dist/src/core/openaiContentGenerator/constants.d.ts +7 -0
  129. package/dist/src/core/openaiContentGenerator/constants.js +8 -0
  130. package/dist/src/core/openaiContentGenerator/constants.js.map +1 -0
  131. package/dist/src/core/openaiContentGenerator/converter.d.ts +108 -0
  132. package/dist/src/core/openaiContentGenerator/converter.js +851 -0
  133. package/dist/src/core/openaiContentGenerator/converter.js.map +1 -0
  134. package/dist/src/core/openaiContentGenerator/converter.test.d.ts +6 -0
  135. package/dist/src/core/openaiContentGenerator/converter.test.js +108 -0
  136. package/dist/src/core/openaiContentGenerator/converter.test.js.map +1 -0
  137. package/dist/src/core/openaiContentGenerator/errorHandler.d.ts +20 -0
  138. package/dist/src/core/openaiContentGenerator/errorHandler.js +82 -0
  139. package/dist/src/core/openaiContentGenerator/errorHandler.js.map +1 -0
  140. package/dist/src/core/openaiContentGenerator/errorHandler.test.d.ts +6 -0
  141. package/dist/src/core/openaiContentGenerator/errorHandler.test.js +287 -0
  142. package/dist/src/core/openaiContentGenerator/errorHandler.test.js.map +1 -0
  143. package/dist/src/core/openaiContentGenerator/index.d.ts +22 -0
  144. package/dist/src/core/openaiContentGenerator/index.js +57 -0
  145. package/dist/src/core/openaiContentGenerator/index.js.map +1 -0
  146. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.d.ts +21 -0
  147. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.js +105 -0
  148. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.js.map +1 -0
  149. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.d.ts +6 -0
  150. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js +230 -0
  151. package/dist/src/core/openaiContentGenerator/openaiContentGenerator.test.js.map +1 -0
  152. package/dist/src/core/openaiContentGenerator/pipeline.d.ts +66 -0
  153. package/dist/src/core/openaiContentGenerator/pipeline.js +265 -0
  154. package/dist/src/core/openaiContentGenerator/pipeline.js.map +1 -0
  155. package/dist/src/core/openaiContentGenerator/pipeline.test.d.ts +6 -0
  156. package/dist/src/core/openaiContentGenerator/pipeline.test.js +1028 -0
  157. package/dist/src/core/openaiContentGenerator/pipeline.test.js.map +1 -0
  158. package/dist/src/core/openaiContentGenerator/provider/README.md +61 -0
  159. package/dist/src/core/openaiContentGenerator/provider/anthropic.d.ts +14 -0
  160. package/dist/src/core/openaiContentGenerator/provider/anthropic.js +28 -0
  161. package/dist/src/core/openaiContentGenerator/provider/anthropic.js.map +1 -0
  162. package/dist/src/core/openaiContentGenerator/provider/anthropic.test.d.ts +1 -0
  163. package/dist/src/core/openaiContentGenerator/provider/anthropic.test.js +138 -0
  164. package/dist/src/core/openaiContentGenerator/provider/anthropic.test.js.map +1 -0
  165. package/dist/src/core/openaiContentGenerator/provider/dashscope.d.ts +63 -0
  166. package/dist/src/core/openaiContentGenerator/provider/dashscope.js +241 -0
  167. package/dist/src/core/openaiContentGenerator/provider/dashscope.js.map +1 -0
  168. package/dist/src/core/openaiContentGenerator/provider/dashscope.test.d.ts +6 -0
  169. package/dist/src/core/openaiContentGenerator/provider/dashscope.test.js +707 -0
  170. package/dist/src/core/openaiContentGenerator/provider/dashscope.test.js.map +1 -0
  171. package/dist/src/core/openaiContentGenerator/provider/deepseek.d.ts +14 -0
  172. package/dist/src/core/openaiContentGenerator/provider/deepseek.js +70 -0
  173. package/dist/src/core/openaiContentGenerator/provider/deepseek.js.map +1 -0
  174. package/dist/src/core/openaiContentGenerator/provider/deepseek.test.d.ts +6 -0
  175. package/dist/src/core/openaiContentGenerator/provider/deepseek.test.js +151 -0
  176. package/dist/src/core/openaiContentGenerator/provider/deepseek.test.js.map +1 -0
  177. package/dist/src/core/openaiContentGenerator/provider/default.d.ts +15 -0
  178. package/dist/src/core/openaiContentGenerator/provider/default.js +38 -0
  179. package/dist/src/core/openaiContentGenerator/provider/default.js.map +1 -0
  180. package/dist/src/core/openaiContentGenerator/provider/default.test.d.ts +6 -0
  181. package/dist/src/core/openaiContentGenerator/provider/default.test.js +176 -0
  182. package/dist/src/core/openaiContentGenerator/provider/default.test.js.map +1 -0
  183. package/dist/src/core/openaiContentGenerator/provider/groq.d.ts +30 -0
  184. package/dist/src/core/openaiContentGenerator/provider/groq.js +60 -0
  185. package/dist/src/core/openaiContentGenerator/provider/groq.js.map +1 -0
  186. package/dist/src/core/openaiContentGenerator/provider/index.d.ts +9 -0
  187. package/dist/src/core/openaiContentGenerator/provider/index.js +9 -0
  188. package/dist/src/core/openaiContentGenerator/provider/index.js.map +1 -0
  189. package/dist/src/core/openaiContentGenerator/provider/modelscope.d.ts +17 -0
  190. package/dist/src/core/openaiContentGenerator/provider/modelscope.js +25 -0
  191. package/dist/src/core/openaiContentGenerator/provider/modelscope.js.map +1 -0
  192. package/dist/src/core/openaiContentGenerator/provider/modelscope.test.d.ts +6 -0
  193. package/dist/src/core/openaiContentGenerator/provider/modelscope.test.js +66 -0
  194. package/dist/src/core/openaiContentGenerator/provider/modelscope.test.js.map +1 -0
  195. package/dist/src/core/openaiContentGenerator/provider/ollama.d.ts +31 -0
  196. package/dist/src/core/openaiContentGenerator/provider/ollama.js +70 -0
  197. package/dist/src/core/openaiContentGenerator/provider/ollama.js.map +1 -0
  198. package/dist/src/core/openaiContentGenerator/provider/openrouter.d.ts +10 -0
  199. package/dist/src/core/openaiContentGenerator/provider/openrouter.js +33 -0
  200. package/dist/src/core/openaiContentGenerator/provider/openrouter.js.map +1 -0
  201. package/dist/src/core/openaiContentGenerator/provider/openrouter.test.d.ts +6 -0
  202. package/dist/src/core/openaiContentGenerator/provider/openrouter.test.js +175 -0
  203. package/dist/src/core/openaiContentGenerator/provider/openrouter.test.js.map +1 -0
  204. package/dist/src/core/openaiContentGenerator/provider/types.d.ts +23 -0
  205. package/dist/src/core/openaiContentGenerator/provider/types.js +2 -0
  206. package/dist/src/core/openaiContentGenerator/provider/types.js.map +1 -0
  207. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.d.ts +145 -0
  208. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.js +381 -0
  209. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.js.map +1 -0
  210. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.d.ts +6 -0
  211. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js +537 -0
  212. package/dist/src/core/openaiContentGenerator/streamingToolCallParser.test.js.map +1 -0
  213. package/dist/src/core/openaiContentGenerator/telemetryService.d.ts +36 -0
  214. package/dist/src/core/openaiContentGenerator/telemetryService.js +150 -0
  215. package/dist/src/core/openaiContentGenerator/telemetryService.js.map +1 -0
  216. package/dist/src/core/openaiContentGenerator/telemetryService.test.d.ts +6 -0
  217. package/dist/src/core/openaiContentGenerator/telemetryService.test.js +978 -0
  218. package/dist/src/core/openaiContentGenerator/telemetryService.test.js.map +1 -0
  219. package/dist/src/core/prompts.d.ts +73 -0
  220. package/dist/src/core/prompts.js +813 -0
  221. package/dist/src/core/prompts.js.map +1 -0
  222. package/dist/src/core/prompts.test.d.ts +6 -0
  223. package/dist/src/core/prompts.test.js +488 -0
  224. package/dist/src/core/prompts.test.js.map +1 -0
  225. package/dist/src/core/tokenLimits.d.ts +25 -0
  226. package/dist/src/core/tokenLimits.js +200 -0
  227. package/dist/src/core/tokenLimits.js.map +1 -0
  228. package/dist/src/core/tokenLimits.test.d.ts +1 -0
  229. package/dist/src/core/tokenLimits.test.js +304 -0
  230. package/dist/src/core/tokenLimits.test.js.map +1 -0
  231. package/dist/src/core/turn.d.ts +152 -0
  232. package/dist/src/core/turn.js +187 -0
  233. package/dist/src/core/turn.js.map +1 -0
  234. package/dist/src/core/turn.test.d.ts +6 -0
  235. package/dist/src/core/turn.test.js +628 -0
  236. package/dist/src/core/turn.test.js.map +1 -0
  237. package/dist/src/fallback/handler.d.ts +7 -0
  238. package/dist/src/fallback/handler.js +97 -0
  239. package/dist/src/fallback/handler.js.map +1 -0
  240. package/dist/src/fallback/handler.test.d.ts +6 -0
  241. package/dist/src/fallback/handler.test.js +130 -0
  242. package/dist/src/fallback/handler.test.js.map +1 -0
  243. package/dist/src/fallback/types.d.ts +14 -0
  244. package/dist/src/fallback/types.js +7 -0
  245. package/dist/src/fallback/types.js.map +1 -0
  246. package/dist/src/generated/git-commit.d.ts +7 -0
  247. package/dist/src/generated/git-commit.js +10 -0
  248. package/dist/src/generated/git-commit.js.map +1 -0
  249. package/dist/src/ide/constants.d.ts +10 -0
  250. package/dist/src/ide/constants.js +12 -0
  251. package/dist/src/ide/constants.js.map +1 -0
  252. package/dist/src/ide/detect-ide.d.ts +56 -0
  253. package/dist/src/ide/detect-ide.js +68 -0
  254. package/dist/src/ide/detect-ide.js.map +1 -0
  255. package/dist/src/ide/detect-ide.test.d.ts +6 -0
  256. package/dist/src/ide/detect-ide.test.js +113 -0
  257. package/dist/src/ide/detect-ide.test.js.map +1 -0
  258. package/dist/src/ide/ide-client.d.ts +110 -0
  259. package/dist/src/ide/ide-client.js +651 -0
  260. package/dist/src/ide/ide-client.js.map +1 -0
  261. package/dist/src/ide/ide-client.test.d.ts +6 -0
  262. package/dist/src/ide/ide-client.test.js +390 -0
  263. package/dist/src/ide/ide-client.test.js.map +1 -0
  264. package/dist/src/ide/ide-installer.d.ts +14 -0
  265. package/dist/src/ide/ide-installer.js +112 -0
  266. package/dist/src/ide/ide-installer.js.map +1 -0
  267. package/dist/src/ide/ide-installer.test.d.ts +6 -0
  268. package/dist/src/ide/ide-installer.test.js +134 -0
  269. package/dist/src/ide/ide-installer.test.js.map +1 -0
  270. package/dist/src/ide/ideContext.d.ts +44 -0
  271. package/dist/src/ide/ideContext.js +101 -0
  272. package/dist/src/ide/ideContext.js.map +1 -0
  273. package/dist/src/ide/ideContext.test.d.ts +6 -0
  274. package/dist/src/ide/ideContext.test.js +393 -0
  275. package/dist/src/ide/ideContext.test.js.map +1 -0
  276. package/dist/src/ide/process-utils.d.ts +21 -0
  277. package/dist/src/ide/process-utils.js +171 -0
  278. package/dist/src/ide/process-utils.js.map +1 -0
  279. package/dist/src/ide/process-utils.test.d.ts +6 -0
  280. package/dist/src/ide/process-utils.test.js +158 -0
  281. package/dist/src/ide/process-utils.test.js.map +1 -0
  282. package/dist/src/ide/types.d.ts +486 -0
  283. package/dist/src/ide/types.js +138 -0
  284. package/dist/src/ide/types.js.map +1 -0
  285. package/dist/src/index.d.ts +97 -0
  286. package/dist/src/index.js +110 -0
  287. package/dist/src/index.js.map +1 -0
  288. package/dist/src/index.test.d.ts +6 -0
  289. package/dist/src/index.test.js +12 -0
  290. package/dist/src/index.test.js.map +1 -0
  291. package/dist/src/mcp/google-auth-provider.d.ts +23 -0
  292. package/dist/src/mcp/google-auth-provider.js +72 -0
  293. package/dist/src/mcp/google-auth-provider.js.map +1 -0
  294. package/dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  295. package/dist/src/mcp/google-auth-provider.test.js +89 -0
  296. package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
  297. package/dist/src/mcp/oauth-provider.d.ts +150 -0
  298. package/dist/src/mcp/oauth-provider.js +613 -0
  299. package/dist/src/mcp/oauth-provider.js.map +1 -0
  300. package/dist/src/mcp/oauth-provider.test.d.ts +6 -0
  301. package/dist/src/mcp/oauth-provider.test.js +847 -0
  302. package/dist/src/mcp/oauth-provider.test.js.map +1 -0
  303. package/dist/src/mcp/oauth-token-storage.d.ts +65 -0
  304. package/dist/src/mcp/oauth-token-storage.js +180 -0
  305. package/dist/src/mcp/oauth-token-storage.js.map +1 -0
  306. package/dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  307. package/dist/src/mcp/oauth-token-storage.test.js +299 -0
  308. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  309. package/dist/src/mcp/oauth-utils.d.ts +119 -0
  310. package/dist/src/mcp/oauth-utils.js +236 -0
  311. package/dist/src/mcp/oauth-utils.js.map +1 -0
  312. package/dist/src/mcp/oauth-utils.test.d.ts +6 -0
  313. package/dist/src/mcp/oauth-utils.test.js +199 -0
  314. package/dist/src/mcp/oauth-utils.test.js.map +1 -0
  315. package/dist/src/mcp/sa-impersonation-provider.d.ts +33 -0
  316. package/dist/src/mcp/sa-impersonation-provider.js +130 -0
  317. package/dist/src/mcp/sa-impersonation-provider.js.map +1 -0
  318. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +6 -0
  319. package/dist/src/mcp/sa-impersonation-provider.test.js +117 -0
  320. package/dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
  321. package/dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  322. package/dist/src/mcp/token-storage/base-token-storage.js +36 -0
  323. package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  324. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  325. package/dist/src/mcp/token-storage/base-token-storage.test.js +160 -0
  326. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  327. package/dist/src/mcp/token-storage/file-token-storage.d.ts +24 -0
  328. package/dist/src/mcp/token-storage/file-token-storage.js +144 -0
  329. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
  330. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +6 -0
  331. package/dist/src/mcp/token-storage/file-token-storage.test.js +235 -0
  332. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
  333. package/dist/src/mcp/token-storage/hybrid-token-storage.d.ts +23 -0
  334. package/dist/src/mcp/token-storage/hybrid-token-storage.js +78 -0
  335. package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
  336. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +6 -0
  337. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +193 -0
  338. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
  339. package/dist/src/mcp/token-storage/index.d.ts +11 -0
  340. package/dist/src/mcp/token-storage/index.js +12 -0
  341. package/dist/src/mcp/token-storage/index.js.map +1 -0
  342. package/dist/src/mcp/token-storage/keychain-token-storage.d.ts +31 -0
  343. package/dist/src/mcp/token-storage/keychain-token-storage.js +190 -0
  344. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
  345. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +6 -0
  346. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +254 -0
  347. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
  348. package/dist/src/mcp/token-storage/types.d.ts +38 -0
  349. package/dist/src/mcp/token-storage/types.js +11 -0
  350. package/dist/src/mcp/token-storage/types.js.map +1 -0
  351. package/dist/src/mocks/msw.d.ts +6 -0
  352. package/dist/src/mocks/msw.js +8 -0
  353. package/dist/src/mocks/msw.js.map +1 -0
  354. package/dist/src/orchestration/agent-registry.d.ts +92 -0
  355. package/dist/src/orchestration/agent-registry.js +248 -0
  356. package/dist/src/orchestration/agent-registry.js.map +1 -0
  357. package/dist/src/orchestration/agents.d.ts +16 -0
  358. package/dist/src/orchestration/agents.js +857 -0
  359. package/dist/src/orchestration/agents.js.map +1 -0
  360. package/dist/src/orchestration/context-manager.d.ts +115 -0
  361. package/dist/src/orchestration/context-manager.js +609 -0
  362. package/dist/src/orchestration/context-manager.js.map +1 -0
  363. package/dist/src/orchestration/dynamic-factory.d.ts +204 -0
  364. package/dist/src/orchestration/dynamic-factory.js +496 -0
  365. package/dist/src/orchestration/dynamic-factory.js.map +1 -0
  366. package/dist/src/orchestration/index.d.ts +17 -0
  367. package/dist/src/orchestration/index.js +41 -0
  368. package/dist/src/orchestration/index.js.map +1 -0
  369. package/dist/src/orchestration/orchestration-queue.d.ts +107 -0
  370. package/dist/src/orchestration/orchestration-queue.js +268 -0
  371. package/dist/src/orchestration/orchestration-queue.js.map +1 -0
  372. package/dist/src/orchestration/orchestrator.d.ts +129 -0
  373. package/dist/src/orchestration/orchestrator.js +436 -0
  374. package/dist/src/orchestration/orchestrator.js.map +1 -0
  375. package/dist/src/orchestration/response-formatter.d.ts +118 -0
  376. package/dist/src/orchestration/response-formatter.js +302 -0
  377. package/dist/src/orchestration/response-formatter.js.map +1 -0
  378. package/dist/src/orchestration/skill-detector.d.ts +35 -0
  379. package/dist/src/orchestration/skill-detector.js +241 -0
  380. package/dist/src/orchestration/skill-detector.js.map +1 -0
  381. package/dist/src/orchestration/skills.d.ts +88 -0
  382. package/dist/src/orchestration/skills.js +987 -0
  383. package/dist/src/orchestration/skills.js.map +1 -0
  384. package/dist/src/orchestration/types.d.ts +371 -0
  385. package/dist/src/orchestration/types.js +7 -0
  386. package/dist/src/orchestration/types.js.map +1 -0
  387. package/dist/src/output/json-formatter.d.ts +11 -0
  388. package/dist/src/output/json-formatter.js +30 -0
  389. package/dist/src/output/json-formatter.js.map +1 -0
  390. package/dist/src/output/json-formatter.test.d.ts +6 -0
  391. package/dist/src/output/json-formatter.test.js +266 -0
  392. package/dist/src/output/json-formatter.test.js.map +1 -0
  393. package/dist/src/output/types.d.ts +25 -0
  394. package/dist/src/output/types.js +17 -0
  395. package/dist/src/output/types.js.map +1 -0
  396. package/dist/src/prompts/mcp-prompts.d.ts +8 -0
  397. package/dist/src/prompts/mcp-prompts.js +13 -0
  398. package/dist/src/prompts/mcp-prompts.js.map +1 -0
  399. package/dist/src/prompts/prompt-registry.d.ts +34 -0
  400. package/dist/src/prompts/prompt-registry.js +63 -0
  401. package/dist/src/prompts/prompt-registry.js.map +1 -0
  402. package/dist/src/qwen/qwenContentGenerator.d.ts +70 -0
  403. package/dist/src/qwen/qwenContentGenerator.js +180 -0
  404. package/dist/src/qwen/qwenContentGenerator.js.map +1 -0
  405. package/dist/src/qwen/qwenContentGenerator.test.d.ts +6 -0
  406. package/dist/src/qwen/qwenContentGenerator.test.js +1178 -0
  407. package/dist/src/qwen/qwenContentGenerator.test.js.map +1 -0
  408. package/dist/src/qwen/qwenOAuth2.d.ts +194 -0
  409. package/dist/src/qwen/qwenOAuth2.js +594 -0
  410. package/dist/src/qwen/qwenOAuth2.js.map +1 -0
  411. package/dist/src/qwen/qwenOAuth2.test.d.ts +6 -0
  412. package/dist/src/qwen/qwenOAuth2.test.js +1724 -0
  413. package/dist/src/qwen/qwenOAuth2.test.js.map +1 -0
  414. package/dist/src/qwen/sharedTokenManager.d.ts +196 -0
  415. package/dist/src/qwen/sharedTokenManager.js +647 -0
  416. package/dist/src/qwen/sharedTokenManager.js.map +1 -0
  417. package/dist/src/qwen/sharedTokenManager.test.d.ts +7 -0
  418. package/dist/src/qwen/sharedTokenManager.test.js +662 -0
  419. package/dist/src/qwen/sharedTokenManager.test.js.map +1 -0
  420. package/dist/src/services/chatCompressionService.d.ts +32 -0
  421. package/dist/src/services/chatCompressionService.js +180 -0
  422. package/dist/src/services/chatCompressionService.js.map +1 -0
  423. package/dist/src/services/chatCompressionService.test.d.ts +6 -0
  424. package/dist/src/services/chatCompressionService.test.js +292 -0
  425. package/dist/src/services/chatCompressionService.test.js.map +1 -0
  426. package/dist/src/services/chatRecordingService.d.ts +144 -0
  427. package/dist/src/services/chatRecordingService.js +330 -0
  428. package/dist/src/services/chatRecordingService.js.map +1 -0
  429. package/dist/src/services/chatRecordingService.test.d.ts +6 -0
  430. package/dist/src/services/chatRecordingService.test.js +332 -0
  431. package/dist/src/services/chatRecordingService.test.js.map +1 -0
  432. package/dist/src/services/fileDiscoveryService.d.ts +45 -0
  433. package/dist/src/services/fileDiscoveryService.js +104 -0
  434. package/dist/src/services/fileDiscoveryService.js.map +1 -0
  435. package/dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  436. package/dist/src/services/fileDiscoveryService.test.js +143 -0
  437. package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
  438. package/dist/src/services/fileSystemService.d.ts +40 -0
  439. package/dist/src/services/fileSystemService.js +29 -0
  440. package/dist/src/services/fileSystemService.js.map +1 -0
  441. package/dist/src/services/fileSystemService.test.d.ts +6 -0
  442. package/dist/src/services/fileSystemService.test.js +41 -0
  443. package/dist/src/services/fileSystemService.test.js.map +1 -0
  444. package/dist/src/services/gitService.d.ts +22 -0
  445. package/dist/src/services/gitService.js +98 -0
  446. package/dist/src/services/gitService.js.map +1 -0
  447. package/dist/src/services/gitService.test.d.ts +6 -0
  448. package/dist/src/services/gitService.test.js +187 -0
  449. package/dist/src/services/gitService.test.js.map +1 -0
  450. package/dist/src/services/loopDetectionService.d.ts +103 -0
  451. package/dist/src/services/loopDetectionService.js +379 -0
  452. package/dist/src/services/loopDetectionService.js.map +1 -0
  453. package/dist/src/services/loopDetectionService.test.d.ts +6 -0
  454. package/dist/src/services/loopDetectionService.test.js +588 -0
  455. package/dist/src/services/loopDetectionService.test.js.map +1 -0
  456. package/dist/src/services/shellExecutionService.d.ts +102 -0
  457. package/dist/src/services/shellExecutionService.js +522 -0
  458. package/dist/src/services/shellExecutionService.js.map +1 -0
  459. package/dist/src/services/shellExecutionService.test.d.ts +6 -0
  460. package/dist/src/services/shellExecutionService.test.js +655 -0
  461. package/dist/src/services/shellExecutionService.test.js.map +1 -0
  462. package/dist/src/subagents/builtin-agents.d.ts +36 -0
  463. package/dist/src/subagents/builtin-agents.js +351 -0
  464. package/dist/src/subagents/builtin-agents.js.map +1 -0
  465. package/dist/src/subagents/builtin-agents.test.d.ts +6 -0
  466. package/dist/src/subagents/builtin-agents.test.js +78 -0
  467. package/dist/src/subagents/builtin-agents.test.js.map +1 -0
  468. package/dist/src/subagents/index.d.ts +29 -0
  469. package/dist/src/subagents/index.js +15 -0
  470. package/dist/src/subagents/index.js.map +1 -0
  471. package/dist/src/subagents/subagent-events.d.ts +95 -0
  472. package/dist/src/subagents/subagent-events.js +31 -0
  473. package/dist/src/subagents/subagent-events.js.map +1 -0
  474. package/dist/src/subagents/subagent-hooks.d.ts +29 -0
  475. package/dist/src/subagents/subagent-hooks.js +7 -0
  476. package/dist/src/subagents/subagent-hooks.js.map +1 -0
  477. package/dist/src/subagents/subagent-manager.d.ts +170 -0
  478. package/dist/src/subagents/subagent-manager.js +596 -0
  479. package/dist/src/subagents/subagent-manager.js.map +1 -0
  480. package/dist/src/subagents/subagent-manager.test.d.ts +6 -0
  481. package/dist/src/subagents/subagent-manager.test.js +822 -0
  482. package/dist/src/subagents/subagent-manager.test.js.map +1 -0
  483. package/dist/src/subagents/subagent-statistics.d.ts +46 -0
  484. package/dist/src/subagents/subagent-statistics.js +193 -0
  485. package/dist/src/subagents/subagent-statistics.js.map +1 -0
  486. package/dist/src/subagents/subagent-statistics.test.d.ts +6 -0
  487. package/dist/src/subagents/subagent-statistics.test.js +231 -0
  488. package/dist/src/subagents/subagent-statistics.test.js.map +1 -0
  489. package/dist/src/subagents/subagent.d.ts +162 -0
  490. package/dist/src/subagents/subagent.js +677 -0
  491. package/dist/src/subagents/subagent.js.map +1 -0
  492. package/dist/src/subagents/subagent.test.d.ts +6 -0
  493. package/dist/src/subagents/subagent.test.js +477 -0
  494. package/dist/src/subagents/subagent.test.js.map +1 -0
  495. package/dist/src/subagents/types.d.ts +218 -0
  496. package/dist/src/subagents/types.js +58 -0
  497. package/dist/src/subagents/types.js.map +1 -0
  498. package/dist/src/subagents/types.test.d.ts +6 -0
  499. package/dist/src/subagents/types.test.js +31 -0
  500. package/dist/src/subagents/types.test.js.map +1 -0
  501. package/dist/src/subagents/validation.d.ts +63 -0
  502. package/dist/src/subagents/validation.js +293 -0
  503. package/dist/src/subagents/validation.js.map +1 -0
  504. package/dist/src/subagents/validation.test.d.ts +6 -0
  505. package/dist/src/subagents/validation.test.js +330 -0
  506. package/dist/src/subagents/validation.test.js.map +1 -0
  507. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +137 -0
  508. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +915 -0
  509. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
  510. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +18 -0
  511. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +594 -0
  512. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
  513. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +115 -0
  514. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +291 -0
  515. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
  516. package/dist/src/telemetry/config.d.ts +31 -0
  517. package/dist/src/telemetry/config.js +76 -0
  518. package/dist/src/telemetry/config.js.map +1 -0
  519. package/dist/src/telemetry/config.test.d.ts +6 -0
  520. package/dist/src/telemetry/config.test.js +124 -0
  521. package/dist/src/telemetry/config.test.js.map +1 -0
  522. package/dist/src/telemetry/constants.d.ts +36 -0
  523. package/dist/src/telemetry/constants.js +38 -0
  524. package/dist/src/telemetry/constants.js.map +1 -0
  525. package/dist/src/telemetry/file-exporters.d.ts +29 -0
  526. package/dist/src/telemetry/file-exporters.js +62 -0
  527. package/dist/src/telemetry/file-exporters.js.map +1 -0
  528. package/dist/src/telemetry/index.d.ts +25 -0
  529. package/dist/src/telemetry/index.js +31 -0
  530. package/dist/src/telemetry/index.js.map +1 -0
  531. package/dist/src/telemetry/integration.test.circular.d.ts +6 -0
  532. package/dist/src/telemetry/integration.test.circular.js +95 -0
  533. package/dist/src/telemetry/integration.test.circular.js.map +1 -0
  534. package/dist/src/telemetry/loggers.d.ts +37 -0
  535. package/dist/src/telemetry/loggers.js +651 -0
  536. package/dist/src/telemetry/loggers.js.map +1 -0
  537. package/dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  538. package/dist/src/telemetry/loggers.test.circular.js +107 -0
  539. package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
  540. package/dist/src/telemetry/loggers.test.d.ts +6 -0
  541. package/dist/src/telemetry/loggers.test.js +978 -0
  542. package/dist/src/telemetry/loggers.test.js.map +1 -0
  543. package/dist/src/telemetry/metrics.d.ts +320 -0
  544. package/dist/src/telemetry/metrics.js +532 -0
  545. package/dist/src/telemetry/metrics.js.map +1 -0
  546. package/dist/src/telemetry/metrics.test.d.ts +6 -0
  547. package/dist/src/telemetry/metrics.test.js +744 -0
  548. package/dist/src/telemetry/metrics.test.js.map +1 -0
  549. package/dist/src/telemetry/qwen-logger/event-types.d.ts +88 -0
  550. package/dist/src/telemetry/qwen-logger/event-types.js +2 -0
  551. package/dist/src/telemetry/qwen-logger/event-types.js.map +1 -0
  552. package/dist/src/telemetry/qwen-logger/qwen-logger.d.ts +91 -0
  553. package/dist/src/telemetry/qwen-logger/qwen-logger.js +685 -0
  554. package/dist/src/telemetry/qwen-logger/qwen-logger.js.map +1 -0
  555. package/dist/src/telemetry/qwen-logger/qwen-logger.test.d.ts +6 -0
  556. package/dist/src/telemetry/qwen-logger/qwen-logger.test.js +317 -0
  557. package/dist/src/telemetry/qwen-logger/qwen-logger.test.js.map +1 -0
  558. package/dist/src/telemetry/sdk.d.ts +9 -0
  559. package/dist/src/telemetry/sdk.js +164 -0
  560. package/dist/src/telemetry/sdk.js.map +1 -0
  561. package/dist/src/telemetry/sdk.test.d.ts +6 -0
  562. package/dist/src/telemetry/sdk.test.js +116 -0
  563. package/dist/src/telemetry/sdk.test.js.map +1 -0
  564. package/dist/src/telemetry/telemetry-utils.d.ts +6 -0
  565. package/dist/src/telemetry/telemetry-utils.js +14 -0
  566. package/dist/src/telemetry/telemetry-utils.js.map +1 -0
  567. package/dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  568. package/dist/src/telemetry/telemetry-utils.test.js +40 -0
  569. package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  570. package/dist/src/telemetry/telemetry.test.d.ts +6 -0
  571. package/dist/src/telemetry/telemetry.test.js +50 -0
  572. package/dist/src/telemetry/telemetry.test.js.map +1 -0
  573. package/dist/src/telemetry/tool-call-decision.d.ts +13 -0
  574. package/dist/src/telemetry/tool-call-decision.js +29 -0
  575. package/dist/src/telemetry/tool-call-decision.js.map +1 -0
  576. package/dist/src/telemetry/types.d.ts +327 -0
  577. package/dist/src/telemetry/types.js +558 -0
  578. package/dist/src/telemetry/types.js.map +1 -0
  579. package/dist/src/telemetry/uiTelemetry.d.ts +75 -0
  580. package/dist/src/telemetry/uiTelemetry.js +152 -0
  581. package/dist/src/telemetry/uiTelemetry.js.map +1 -0
  582. package/dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  583. package/dist/src/telemetry/uiTelemetry.test.js +625 -0
  584. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  585. package/dist/src/test-utils/config.d.ts +17 -0
  586. package/dist/src/test-utils/config.js +32 -0
  587. package/dist/src/test-utils/config.js.map +1 -0
  588. package/dist/src/test-utils/index.d.ts +6 -0
  589. package/dist/src/test-utils/index.js +7 -0
  590. package/dist/src/test-utils/index.js.map +1 -0
  591. package/dist/src/test-utils/mock-tool.d.ts +66 -0
  592. package/dist/src/test-utils/mock-tool.js +121 -0
  593. package/dist/src/test-utils/mock-tool.js.map +1 -0
  594. package/dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  595. package/dist/src/test-utils/mockWorkspaceContext.js +24 -0
  596. package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  597. package/dist/src/tools/diffOptions.d.ts +9 -0
  598. package/dist/src/tools/diffOptions.js +46 -0
  599. package/dist/src/tools/diffOptions.js.map +1 -0
  600. package/dist/src/tools/diffOptions.test.d.ts +6 -0
  601. package/dist/src/tools/diffOptions.test.js +155 -0
  602. package/dist/src/tools/diffOptions.test.js.map +1 -0
  603. package/dist/src/tools/edit.d.ts +55 -0
  604. package/dist/src/tools/edit.js +421 -0
  605. package/dist/src/tools/edit.js.map +1 -0
  606. package/dist/src/tools/edit.test.d.ts +6 -0
  607. package/dist/src/tools/edit.test.js +684 -0
  608. package/dist/src/tools/edit.test.js.map +1 -0
  609. package/dist/src/tools/exitPlanMode.d.ts +28 -0
  610. package/dist/src/tools/exitPlanMode.js +132 -0
  611. package/dist/src/tools/exitPlanMode.js.map +1 -0
  612. package/dist/src/tools/exitPlanMode.test.d.ts +6 -0
  613. package/dist/src/tools/exitPlanMode.test.js +178 -0
  614. package/dist/src/tools/exitPlanMode.test.js.map +1 -0
  615. package/dist/src/tools/glob.d.ts +44 -0
  616. package/dist/src/tools/glob.js +190 -0
  617. package/dist/src/tools/glob.js.map +1 -0
  618. package/dist/src/tools/glob.test.d.ts +6 -0
  619. package/dist/src/tools/glob.test.js +442 -0
  620. package/dist/src/tools/glob.test.js.map +1 -0
  621. package/dist/src/tools/grep.d.ts +44 -0
  622. package/dist/src/tools/grep.js +425 -0
  623. package/dist/src/tools/grep.js.map +1 -0
  624. package/dist/src/tools/grep.test.d.ts +6 -0
  625. package/dist/src/tools/grep.test.js +360 -0
  626. package/dist/src/tools/grep.test.js.map +1 -0
  627. package/dist/src/tools/ls.d.ts +68 -0
  628. package/dist/src/tools/ls.js +215 -0
  629. package/dist/src/tools/ls.js.map +1 -0
  630. package/dist/src/tools/ls.test.d.ts +6 -0
  631. package/dist/src/tools/ls.test.js +249 -0
  632. package/dist/src/tools/ls.test.js.map +1 -0
  633. package/dist/src/tools/mcp-client-manager.d.ts +40 -0
  634. package/dist/src/tools/mcp-client-manager.js +83 -0
  635. package/dist/src/tools/mcp-client-manager.js.map +1 -0
  636. package/dist/src/tools/mcp-client-manager.test.d.ts +6 -0
  637. package/dist/src/tools/mcp-client-manager.test.js +58 -0
  638. package/dist/src/tools/mcp-client-manager.test.js.map +1 -0
  639. package/dist/src/tools/mcp-client.d.ts +189 -0
  640. package/dist/src/tools/mcp-client.js +957 -0
  641. package/dist/src/tools/mcp-client.js.map +1 -0
  642. package/dist/src/tools/mcp-client.test.d.ts +6 -0
  643. package/dist/src/tools/mcp-client.test.js +309 -0
  644. package/dist/src/tools/mcp-client.test.js.map +1 -0
  645. package/dist/src/tools/mcp-tool.d.ts +24 -0
  646. package/dist/src/tools/mcp-tool.js +268 -0
  647. package/dist/src/tools/mcp-tool.js.map +1 -0
  648. package/dist/src/tools/mcp-tool.test.d.ts +6 -0
  649. package/dist/src/tools/mcp-tool.test.js +714 -0
  650. package/dist/src/tools/mcp-tool.test.js.map +1 -0
  651. package/dist/src/tools/memoryTool.d.ts +42 -0
  652. package/dist/src/tools/memoryTool.js +397 -0
  653. package/dist/src/tools/memoryTool.js.map +1 -0
  654. package/dist/src/tools/memoryTool.test.d.ts +6 -0
  655. package/dist/src/tools/memoryTool.test.js +419 -0
  656. package/dist/src/tools/memoryTool.test.js.map +1 -0
  657. package/dist/src/tools/modifiable-tool.d.ts +32 -0
  658. package/dist/src/tools/modifiable-tool.js +88 -0
  659. package/dist/src/tools/modifiable-tool.js.map +1 -0
  660. package/dist/src/tools/modifiable-tool.test.d.ts +6 -0
  661. package/dist/src/tools/modifiable-tool.test.js +193 -0
  662. package/dist/src/tools/modifiable-tool.test.js.map +1 -0
  663. package/dist/src/tools/read-file.d.ts +35 -0
  664. package/dist/src/tools/read-file.js +124 -0
  665. package/dist/src/tools/read-file.js.map +1 -0
  666. package/dist/src/tools/read-file.test.d.ts +6 -0
  667. package/dist/src/tools/read-file.test.js +339 -0
  668. package/dist/src/tools/read-file.test.js.map +1 -0
  669. package/dist/src/tools/read-many-files.d.ts +60 -0
  670. package/dist/src/tools/read-many-files.js +391 -0
  671. package/dist/src/tools/read-many-files.js.map +1 -0
  672. package/dist/src/tools/read-many-files.test.d.ts +6 -0
  673. package/dist/src/tools/read-many-files.test.js +566 -0
  674. package/dist/src/tools/read-many-files.test.js.map +1 -0
  675. package/dist/src/tools/ripGrep.d.ts +44 -0
  676. package/dist/src/tools/ripGrep.js +233 -0
  677. package/dist/src/tools/ripGrep.js.map +1 -0
  678. package/dist/src/tools/ripGrep.test.d.ts +6 -0
  679. package/dist/src/tools/ripGrep.test.js +529 -0
  680. package/dist/src/tools/ripGrep.test.js.map +1 -0
  681. package/dist/src/tools/shell.d.ts +33 -0
  682. package/dist/src/tools/shell.js +395 -0
  683. package/dist/src/tools/shell.js.map +1 -0
  684. package/dist/src/tools/shell.test.d.ts +6 -0
  685. package/dist/src/tools/shell.test.js +566 -0
  686. package/dist/src/tools/shell.test.js.map +1 -0
  687. package/dist/src/tools/smart-edit.d.ts +91 -0
  688. package/dist/src/tools/smart-edit.js +703 -0
  689. package/dist/src/tools/smart-edit.js.map +1 -0
  690. package/dist/src/tools/smart-edit.test.d.ts +6 -0
  691. package/dist/src/tools/smart-edit.test.js +542 -0
  692. package/dist/src/tools/smart-edit.test.js.map +1 -0
  693. package/dist/src/tools/task.d.ts +59 -0
  694. package/dist/src/tools/task.js +412 -0
  695. package/dist/src/tools/task.js.map +1 -0
  696. package/dist/src/tools/task.test.d.ts +6 -0
  697. package/dist/src/tools/task.test.js +369 -0
  698. package/dist/src/tools/task.test.js.map +1 -0
  699. package/dist/src/tools/todoWrite.d.ts +42 -0
  700. package/dist/src/tools/todoWrite.js +407 -0
  701. package/dist/src/tools/todoWrite.js.map +1 -0
  702. package/dist/src/tools/todoWrite.test.d.ts +6 -0
  703. package/dist/src/tools/todoWrite.test.js +234 -0
  704. package/dist/src/tools/todoWrite.test.js.map +1 -0
  705. package/dist/src/tools/tool-error.d.ts +45 -0
  706. package/dist/src/tools/tool-error.js +61 -0
  707. package/dist/src/tools/tool-error.js.map +1 -0
  708. package/dist/src/tools/tool-names.d.ts +56 -0
  709. package/dist/src/tools/tool-names.js +62 -0
  710. package/dist/src/tools/tool-names.js.map +1 -0
  711. package/dist/src/tools/tool-registry.d.ts +87 -0
  712. package/dist/src/tools/tool-registry.js +370 -0
  713. package/dist/src/tools/tool-registry.js.map +1 -0
  714. package/dist/src/tools/tool-registry.test.d.ts +6 -0
  715. package/dist/src/tools/tool-registry.test.js +332 -0
  716. package/dist/src/tools/tool-registry.test.js.map +1 -0
  717. package/dist/src/tools/tools.d.ts +327 -0
  718. package/dist/src/tools/tools.js +258 -0
  719. package/dist/src/tools/tools.js.map +1 -0
  720. package/dist/src/tools/tools.test.d.ts +6 -0
  721. package/dist/src/tools/tools.test.js +205 -0
  722. package/dist/src/tools/tools.test.js.map +1 -0
  723. package/dist/src/tools/web-fetch.d.ts +31 -0
  724. package/dist/src/tools/web-fetch.js +163 -0
  725. package/dist/src/tools/web-fetch.js.map +1 -0
  726. package/dist/src/tools/web-fetch.test.d.ts +6 -0
  727. package/dist/src/tools/web-fetch.test.js +133 -0
  728. package/dist/src/tools/web-fetch.test.js.map +1 -0
  729. package/dist/src/tools/web-search/base-provider.d.ts +31 -0
  730. package/dist/src/tools/web-search/base-provider.js +34 -0
  731. package/dist/src/tools/web-search/base-provider.js.map +1 -0
  732. package/dist/src/tools/web-search/index.d.ts +24 -0
  733. package/dist/src/tools/web-search/index.js +245 -0
  734. package/dist/src/tools/web-search/index.js.map +1 -0
  735. package/dist/src/tools/web-search/index.test.d.ts +6 -0
  736. package/dist/src/tools/web-search/index.test.js +237 -0
  737. package/dist/src/tools/web-search/index.test.js.map +1 -0
  738. package/dist/src/tools/web-search/providers/dashscope-provider.d.ts +23 -0
  739. package/dist/src/tools/web-search/providers/dashscope-provider.js +120 -0
  740. package/dist/src/tools/web-search/providers/dashscope-provider.js.map +1 -0
  741. package/dist/src/tools/web-search/providers/google-provider.d.ts +17 -0
  742. package/dist/src/tools/web-search/providers/google-provider.js +55 -0
  743. package/dist/src/tools/web-search/providers/google-provider.js.map +1 -0
  744. package/dist/src/tools/web-search/providers/tavily-provider.d.ts +17 -0
  745. package/dist/src/tools/web-search/providers/tavily-provider.js +54 -0
  746. package/dist/src/tools/web-search/providers/tavily-provider.js.map +1 -0
  747. package/dist/src/tools/web-search/types.d.ts +138 -0
  748. package/dist/src/tools/web-search/types.js +7 -0
  749. package/dist/src/tools/web-search/types.js.map +1 -0
  750. package/dist/src/tools/web-search/utils.d.ts +28 -0
  751. package/dist/src/tools/web-search/utils.js +35 -0
  752. package/dist/src/tools/web-search/utils.js.map +1 -0
  753. package/dist/src/tools/write-file.d.ts +52 -0
  754. package/dist/src/tools/write-file.js +293 -0
  755. package/dist/src/tools/write-file.js.map +1 -0
  756. package/dist/src/tools/write-file.test.d.ts +6 -0
  757. package/dist/src/tools/write-file.test.js +516 -0
  758. package/dist/src/tools/write-file.test.js.map +1 -0
  759. package/dist/src/utils/LruCache.d.ts +13 -0
  760. package/dist/src/utils/LruCache.js +38 -0
  761. package/dist/src/utils/LruCache.js.map +1 -0
  762. package/dist/src/utils/bfsFileSearch.d.ts +24 -0
  763. package/dist/src/utils/bfsFileSearch.js +95 -0
  764. package/dist/src/utils/bfsFileSearch.js.map +1 -0
  765. package/dist/src/utils/bfsFileSearch.test.d.ts +6 -0
  766. package/dist/src/utils/bfsFileSearch.test.js +163 -0
  767. package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
  768. package/dist/src/utils/browser.d.ts +13 -0
  769. package/dist/src/utils/browser.js +50 -0
  770. package/dist/src/utils/browser.js.map +1 -0
  771. package/dist/src/utils/editHelper.d.ts +53 -0
  772. package/dist/src/utils/editHelper.js +359 -0
  773. package/dist/src/utils/editHelper.js.map +1 -0
  774. package/dist/src/utils/editHelper.test.d.ts +6 -0
  775. package/dist/src/utils/editHelper.test.js +93 -0
  776. package/dist/src/utils/editHelper.test.js.map +1 -0
  777. package/dist/src/utils/editor.d.ts +28 -0
  778. package/dist/src/utils/editor.js +177 -0
  779. package/dist/src/utils/editor.js.map +1 -0
  780. package/dist/src/utils/editor.test.d.ts +6 -0
  781. package/dist/src/utils/editor.test.js +437 -0
  782. package/dist/src/utils/editor.test.js.map +1 -0
  783. package/dist/src/utils/environmentContext.d.ts +22 -0
  784. package/dist/src/utils/environmentContext.js +108 -0
  785. package/dist/src/utils/environmentContext.js.map +1 -0
  786. package/dist/src/utils/environmentContext.test.d.ts +6 -0
  787. package/dist/src/utils/environmentContext.test.js +219 -0
  788. package/dist/src/utils/environmentContext.test.js.map +1 -0
  789. package/dist/src/utils/errorParsing.d.ts +8 -0
  790. package/dist/src/utils/errorParsing.js +93 -0
  791. package/dist/src/utils/errorParsing.js.map +1 -0
  792. package/dist/src/utils/errorParsing.test.d.ts +6 -0
  793. package/dist/src/utils/errorParsing.test.js +172 -0
  794. package/dist/src/utils/errorParsing.test.js.map +1 -0
  795. package/dist/src/utils/errorReporting.d.ts +14 -0
  796. package/dist/src/utils/errorReporting.js +88 -0
  797. package/dist/src/utils/errorReporting.js.map +1 -0
  798. package/dist/src/utils/errorReporting.test.d.ts +6 -0
  799. package/dist/src/utils/errorReporting.test.js +130 -0
  800. package/dist/src/utils/errorReporting.test.js.map +1 -0
  801. package/dist/src/utils/errors.d.ts +39 -0
  802. package/dist/src/utils/errors.js +96 -0
  803. package/dist/src/utils/errors.js.map +1 -0
  804. package/dist/src/utils/fetch.d.ts +11 -0
  805. package/dist/src/utils/fetch.js +51 -0
  806. package/dist/src/utils/fetch.js.map +1 -0
  807. package/dist/src/utils/fileUtils.d.ts +69 -0
  808. package/dist/src/utils/fileUtils.js +426 -0
  809. package/dist/src/utils/fileUtils.js.map +1 -0
  810. package/dist/src/utils/fileUtils.test.d.ts +6 -0
  811. package/dist/src/utils/fileUtils.test.js +685 -0
  812. package/dist/src/utils/fileUtils.test.js.map +1 -0
  813. package/dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  814. package/dist/src/utils/filesearch/crawlCache.js +57 -0
  815. package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
  816. package/dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  817. package/dist/src/utils/filesearch/crawlCache.test.js +103 -0
  818. package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  819. package/dist/src/utils/filesearch/crawler.d.ts +15 -0
  820. package/dist/src/utils/filesearch/crawler.js +50 -0
  821. package/dist/src/utils/filesearch/crawler.js.map +1 -0
  822. package/dist/src/utils/filesearch/crawler.test.d.ts +6 -0
  823. package/dist/src/utils/filesearch/crawler.test.js +468 -0
  824. package/dist/src/utils/filesearch/crawler.test.js.map +1 -0
  825. package/dist/src/utils/filesearch/fileSearch.d.ts +38 -0
  826. package/dist/src/utils/filesearch/fileSearch.js +191 -0
  827. package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
  828. package/dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  829. package/dist/src/utils/filesearch/fileSearch.test.js +642 -0
  830. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  831. package/dist/src/utils/filesearch/ignore.d.ts +42 -0
  832. package/dist/src/utils/filesearch/ignore.js +106 -0
  833. package/dist/src/utils/filesearch/ignore.js.map +1 -0
  834. package/dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  835. package/dist/src/utils/filesearch/ignore.test.js +144 -0
  836. package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
  837. package/dist/src/utils/filesearch/result-cache.d.ts +33 -0
  838. package/dist/src/utils/filesearch/result-cache.js +59 -0
  839. package/dist/src/utils/filesearch/result-cache.js.map +1 -0
  840. package/dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  841. package/dist/src/utils/filesearch/result-cache.test.js +46 -0
  842. package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  843. package/dist/src/utils/flashFallback.test.d.ts +6 -0
  844. package/dist/src/utils/flashFallback.test.js +122 -0
  845. package/dist/src/utils/flashFallback.test.js.map +1 -0
  846. package/dist/src/utils/formatters.d.ts +6 -0
  847. package/dist/src/utils/formatters.js +16 -0
  848. package/dist/src/utils/formatters.js.map +1 -0
  849. package/dist/src/utils/generateContentResponseUtilities.d.ts +13 -0
  850. package/dist/src/utils/generateContentResponseUtilities.js +80 -0
  851. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  852. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  853. package/dist/src/utils/generateContentResponseUtilities.test.js +235 -0
  854. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  855. package/dist/src/utils/getFolderStructure.d.ts +31 -0
  856. package/dist/src/utils/getFolderStructure.js +246 -0
  857. package/dist/src/utils/getFolderStructure.js.map +1 -0
  858. package/dist/src/utils/getFolderStructure.test.d.ts +6 -0
  859. package/dist/src/utils/getFolderStructure.test.js +282 -0
  860. package/dist/src/utils/getFolderStructure.test.js.map +1 -0
  861. package/dist/src/utils/getPty.d.ts +19 -0
  862. package/dist/src/utils/getPty.js +23 -0
  863. package/dist/src/utils/getPty.js.map +1 -0
  864. package/dist/src/utils/gitIgnoreParser.d.ts +16 -0
  865. package/dist/src/utils/gitIgnoreParser.js +152 -0
  866. package/dist/src/utils/gitIgnoreParser.js.map +1 -0
  867. package/dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  868. package/dist/src/utils/gitIgnoreParser.test.js +185 -0
  869. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  870. package/dist/src/utils/gitUtils.d.ts +17 -0
  871. package/dist/src/utils/gitUtils.js +61 -0
  872. package/dist/src/utils/gitUtils.js.map +1 -0
  873. package/dist/src/utils/ignorePatterns.d.ts +103 -0
  874. package/dist/src/utils/ignorePatterns.js +220 -0
  875. package/dist/src/utils/ignorePatterns.js.map +1 -0
  876. package/dist/src/utils/ignorePatterns.test.d.ts +6 -0
  877. package/dist/src/utils/ignorePatterns.test.js +250 -0
  878. package/dist/src/utils/ignorePatterns.test.js.map +1 -0
  879. package/dist/src/utils/installationManager.d.ts +16 -0
  880. package/dist/src/utils/installationManager.js +50 -0
  881. package/dist/src/utils/installationManager.js.map +1 -0
  882. package/dist/src/utils/installationManager.test.d.ts +6 -0
  883. package/dist/src/utils/installationManager.test.js +83 -0
  884. package/dist/src/utils/installationManager.test.js.map +1 -0
  885. package/dist/src/utils/language-detection.d.ts +6 -0
  886. package/dist/src/utils/language-detection.js +101 -0
  887. package/dist/src/utils/language-detection.js.map +1 -0
  888. package/dist/src/utils/llm-edit-fixer.d.ts +26 -0
  889. package/dist/src/utils/llm-edit-fixer.js +131 -0
  890. package/dist/src/utils/llm-edit-fixer.js.map +1 -0
  891. package/dist/src/utils/llm-edit-fixer.test.d.ts +6 -0
  892. package/dist/src/utils/llm-edit-fixer.test.js +186 -0
  893. package/dist/src/utils/llm-edit-fixer.test.js.map +1 -0
  894. package/dist/src/utils/memoryDiscovery.d.ts +16 -0
  895. package/dist/src/utils/memoryDiscovery.js +272 -0
  896. package/dist/src/utils/memoryDiscovery.js.map +1 -0
  897. package/dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  898. package/dist/src/utils/memoryDiscovery.test.js +244 -0
  899. package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
  900. package/dist/src/utils/memoryImportProcessor.d.ts +42 -0
  901. package/dist/src/utils/memoryImportProcessor.js +284 -0
  902. package/dist/src/utils/memoryImportProcessor.js.map +1 -0
  903. package/dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  904. package/dist/src/utils/memoryImportProcessor.test.js +587 -0
  905. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  906. package/dist/src/utils/messageInspectors.d.ts +8 -0
  907. package/dist/src/utils/messageInspectors.js +16 -0
  908. package/dist/src/utils/messageInspectors.js.map +1 -0
  909. package/dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  910. package/dist/src/utils/nextSpeakerChecker.js +97 -0
  911. package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
  912. package/dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  913. package/dist/src/utils/nextSpeakerChecker.test.js +181 -0
  914. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  915. package/dist/src/utils/openaiLogger.d.ts +42 -0
  916. package/dist/src/utils/openaiLogger.js +138 -0
  917. package/dist/src/utils/openaiLogger.js.map +1 -0
  918. package/dist/src/utils/openaiLogger.test.d.ts +6 -0
  919. package/dist/src/utils/openaiLogger.test.js +304 -0
  920. package/dist/src/utils/openaiLogger.test.js.map +1 -0
  921. package/dist/src/utils/partUtils.d.ts +35 -0
  922. package/dist/src/utils/partUtils.js +133 -0
  923. package/dist/src/utils/partUtils.js.map +1 -0
  924. package/dist/src/utils/partUtils.test.d.ts +6 -0
  925. package/dist/src/utils/partUtils.test.js +241 -0
  926. package/dist/src/utils/partUtils.test.js.map +1 -0
  927. package/dist/src/utils/pathReader.d.ts +17 -0
  928. package/dist/src/utils/pathReader.js +92 -0
  929. package/dist/src/utils/pathReader.js.map +1 -0
  930. package/dist/src/utils/pathReader.test.d.ts +6 -0
  931. package/dist/src/utils/pathReader.test.js +365 -0
  932. package/dist/src/utils/pathReader.test.js.map +1 -0
  933. package/dist/src/utils/paths.d.ts +94 -0
  934. package/dist/src/utils/paths.js +231 -0
  935. package/dist/src/utils/paths.js.map +1 -0
  936. package/dist/src/utils/paths.test.d.ts +6 -0
  937. package/dist/src/utils/paths.test.js +438 -0
  938. package/dist/src/utils/paths.test.js.map +1 -0
  939. package/dist/src/utils/projectSummary.d.ts +22 -0
  940. package/dist/src/utils/projectSummary.js +86 -0
  941. package/dist/src/utils/projectSummary.js.map +1 -0
  942. package/dist/src/utils/promptIdContext.d.ts +7 -0
  943. package/dist/src/utils/promptIdContext.js +8 -0
  944. package/dist/src/utils/promptIdContext.js.map +1 -0
  945. package/dist/src/utils/quotaErrorDetection.d.ts +20 -0
  946. package/dist/src/utils/quotaErrorDetection.js +114 -0
  947. package/dist/src/utils/quotaErrorDetection.js.map +1 -0
  948. package/dist/src/utils/quotaErrorDetection.test.d.ts +6 -0
  949. package/dist/src/utils/quotaErrorDetection.test.js +153 -0
  950. package/dist/src/utils/quotaErrorDetection.test.js.map +1 -0
  951. package/dist/src/utils/qwenIgnoreParser.d.ts +18 -0
  952. package/dist/src/utils/qwenIgnoreParser.js +61 -0
  953. package/dist/src/utils/qwenIgnoreParser.js.map +1 -0
  954. package/dist/src/utils/qwenIgnoreParser.test.d.ts +6 -0
  955. package/dist/src/utils/qwenIgnoreParser.test.js +50 -0
  956. package/dist/src/utils/qwenIgnoreParser.test.js.map +1 -0
  957. package/dist/src/utils/request-tokenizer/imageTokenizer.d.ts +112 -0
  958. package/dist/src/utils/request-tokenizer/imageTokenizer.js +401 -0
  959. package/dist/src/utils/request-tokenizer/imageTokenizer.js.map +1 -0
  960. package/dist/src/utils/request-tokenizer/imageTokenizer.test.d.ts +6 -0
  961. package/dist/src/utils/request-tokenizer/imageTokenizer.test.js +114 -0
  962. package/dist/src/utils/request-tokenizer/imageTokenizer.test.js.map +1 -0
  963. package/dist/src/utils/request-tokenizer/index.d.ts +18 -0
  964. package/dist/src/utils/request-tokenizer/index.js +30 -0
  965. package/dist/src/utils/request-tokenizer/index.js.map +1 -0
  966. package/dist/src/utils/request-tokenizer/requestTokenizer.d.ts +56 -0
  967. package/dist/src/utils/request-tokenizer/requestTokenizer.js +263 -0
  968. package/dist/src/utils/request-tokenizer/requestTokenizer.js.map +1 -0
  969. package/dist/src/utils/request-tokenizer/requestTokenizer.test.d.ts +6 -0
  970. package/dist/src/utils/request-tokenizer/requestTokenizer.test.js +245 -0
  971. package/dist/src/utils/request-tokenizer/requestTokenizer.test.js.map +1 -0
  972. package/dist/src/utils/request-tokenizer/supportedImageFormats.d.ts +30 -0
  973. package/dist/src/utils/request-tokenizer/supportedImageFormats.js +41 -0
  974. package/dist/src/utils/request-tokenizer/supportedImageFormats.js.map +1 -0
  975. package/dist/src/utils/request-tokenizer/textTokenizer.d.ts +29 -0
  976. package/dist/src/utils/request-tokenizer/textTokenizer.js +88 -0
  977. package/dist/src/utils/request-tokenizer/textTokenizer.js.map +1 -0
  978. package/dist/src/utils/request-tokenizer/textTokenizer.test.d.ts +6 -0
  979. package/dist/src/utils/request-tokenizer/textTokenizer.test.js +253 -0
  980. package/dist/src/utils/request-tokenizer/textTokenizer.test.js.map +1 -0
  981. package/dist/src/utils/request-tokenizer/types.d.ts +55 -0
  982. package/dist/src/utils/request-tokenizer/types.js +7 -0
  983. package/dist/src/utils/request-tokenizer/types.js.map +1 -0
  984. package/dist/src/utils/retry.d.ts +32 -0
  985. package/dist/src/utils/retry.js +303 -0
  986. package/dist/src/utils/retry.js.map +1 -0
  987. package/dist/src/utils/retry.test.d.ts +6 -0
  988. package/dist/src/utils/retry.test.js +474 -0
  989. package/dist/src/utils/retry.test.js.map +1 -0
  990. package/dist/src/utils/ripgrepUtils.d.ts +62 -0
  991. package/dist/src/utils/ripgrepUtils.js +262 -0
  992. package/dist/src/utils/ripgrepUtils.js.map +1 -0
  993. package/dist/src/utils/ripgrepUtils.test.d.ts +6 -0
  994. package/dist/src/utils/ripgrepUtils.test.js +101 -0
  995. package/dist/src/utils/ripgrepUtils.test.js.map +1 -0
  996. package/dist/src/utils/safeJsonParse.d.ts +15 -0
  997. package/dist/src/utils/safeJsonParse.js +41 -0
  998. package/dist/src/utils/safeJsonParse.js.map +1 -0
  999. package/dist/src/utils/safeJsonParse.test.d.ts +6 -0
  1000. package/dist/src/utils/safeJsonParse.test.js +112 -0
  1001. package/dist/src/utils/safeJsonParse.test.js.map +1 -0
  1002. package/dist/src/utils/safeJsonStringify.d.ts +13 -0
  1003. package/dist/src/utils/safeJsonStringify.js +25 -0
  1004. package/dist/src/utils/safeJsonStringify.js.map +1 -0
  1005. package/dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  1006. package/dist/src/utils/safeJsonStringify.test.js +61 -0
  1007. package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
  1008. package/dist/src/utils/schemaValidator.d.ts +15 -0
  1009. package/dist/src/utils/schemaValidator.js +67 -0
  1010. package/dist/src/utils/schemaValidator.js.map +1 -0
  1011. package/dist/src/utils/schemaValidator.test.d.ts +6 -0
  1012. package/dist/src/utils/schemaValidator.test.js +113 -0
  1013. package/dist/src/utils/schemaValidator.test.js.map +1 -0
  1014. package/dist/src/utils/secure-browser-launcher.d.ts +23 -0
  1015. package/dist/src/utils/secure-browser-launcher.js +165 -0
  1016. package/dist/src/utils/secure-browser-launcher.js.map +1 -0
  1017. package/dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  1018. package/dist/src/utils/secure-browser-launcher.test.js +149 -0
  1019. package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  1020. package/dist/src/utils/session.d.ts +6 -0
  1021. package/dist/src/utils/session.js +8 -0
  1022. package/dist/src/utils/session.js.map +1 -0
  1023. package/dist/src/utils/shell-utils.d.ts +152 -0
  1024. package/dist/src/utils/shell-utils.js +467 -0
  1025. package/dist/src/utils/shell-utils.js.map +1 -0
  1026. package/dist/src/utils/shell-utils.test.d.ts +6 -0
  1027. package/dist/src/utils/shell-utils.test.js +351 -0
  1028. package/dist/src/utils/shell-utils.test.js.map +1 -0
  1029. package/dist/src/utils/shellReadOnlyChecker.d.ts +6 -0
  1030. package/dist/src/utils/shellReadOnlyChecker.js +247 -0
  1031. package/dist/src/utils/shellReadOnlyChecker.js.map +1 -0
  1032. package/dist/src/utils/shellReadOnlyChecker.test.d.ts +6 -0
  1033. package/dist/src/utils/shellReadOnlyChecker.test.js +47 -0
  1034. package/dist/src/utils/shellReadOnlyChecker.test.js.map +1 -0
  1035. package/dist/src/utils/subagentGenerator.d.ts +20 -0
  1036. package/dist/src/utils/subagentGenerator.js +120 -0
  1037. package/dist/src/utils/subagentGenerator.js.map +1 -0
  1038. package/dist/src/utils/subagentGenerator.test.d.ts +6 -0
  1039. package/dist/src/utils/subagentGenerator.test.js +135 -0
  1040. package/dist/src/utils/subagentGenerator.test.js.map +1 -0
  1041. package/dist/src/utils/summarizer.d.ts +25 -0
  1042. package/dist/src/utils/summarizer.js +51 -0
  1043. package/dist/src/utils/summarizer.js.map +1 -0
  1044. package/dist/src/utils/summarizer.test.d.ts +6 -0
  1045. package/dist/src/utils/summarizer.test.js +131 -0
  1046. package/dist/src/utils/summarizer.test.js.map +1 -0
  1047. package/dist/src/utils/systemEncoding.d.ts +40 -0
  1048. package/dist/src/utils/systemEncoding.js +149 -0
  1049. package/dist/src/utils/systemEncoding.js.map +1 -0
  1050. package/dist/src/utils/systemEncoding.test.d.ts +6 -0
  1051. package/dist/src/utils/systemEncoding.test.js +368 -0
  1052. package/dist/src/utils/systemEncoding.test.js.map +1 -0
  1053. package/dist/src/utils/terminalSerializer.d.ts +25 -0
  1054. package/dist/src/utils/terminalSerializer.js +432 -0
  1055. package/dist/src/utils/terminalSerializer.js.map +1 -0
  1056. package/dist/src/utils/terminalSerializer.test.d.ts +6 -0
  1057. package/dist/src/utils/terminalSerializer.test.js +176 -0
  1058. package/dist/src/utils/terminalSerializer.test.js.map +1 -0
  1059. package/dist/src/utils/testUtils.d.ts +29 -0
  1060. package/dist/src/utils/testUtils.js +70 -0
  1061. package/dist/src/utils/testUtils.js.map +1 -0
  1062. package/dist/src/utils/textUtils.d.ts +18 -0
  1063. package/dist/src/utils/textUtils.js +42 -0
  1064. package/dist/src/utils/textUtils.js.map +1 -0
  1065. package/dist/src/utils/textUtils.test.d.ts +6 -0
  1066. package/dist/src/utils/textUtils.test.js +59 -0
  1067. package/dist/src/utils/textUtils.test.js.map +1 -0
  1068. package/dist/src/utils/thoughtUtils.d.ts +21 -0
  1069. package/dist/src/utils/thoughtUtils.js +39 -0
  1070. package/dist/src/utils/thoughtUtils.js.map +1 -0
  1071. package/dist/src/utils/thoughtUtils.test.d.ts +6 -0
  1072. package/dist/src/utils/thoughtUtils.test.js +78 -0
  1073. package/dist/src/utils/thoughtUtils.test.js.map +1 -0
  1074. package/dist/src/utils/tool-utils.d.ts +22 -0
  1075. package/dist/src/utils/tool-utils.js +121 -0
  1076. package/dist/src/utils/tool-utils.js.map +1 -0
  1077. package/dist/src/utils/tool-utils.test.d.ts +6 -0
  1078. package/dist/src/utils/tool-utils.test.js +100 -0
  1079. package/dist/src/utils/tool-utils.test.js.map +1 -0
  1080. package/dist/src/utils/userAccountManager.d.ts +20 -0
  1081. package/dist/src/utils/userAccountManager.js +114 -0
  1082. package/dist/src/utils/userAccountManager.js.map +1 -0
  1083. package/dist/src/utils/userAccountManager.test.d.ts +6 -0
  1084. package/dist/src/utils/userAccountManager.test.js +223 -0
  1085. package/dist/src/utils/userAccountManager.test.js.map +1 -0
  1086. package/dist/src/utils/workspaceContext.d.ts +66 -0
  1087. package/dist/src/utils/workspaceContext.js +171 -0
  1088. package/dist/src/utils/workspaceContext.js.map +1 -0
  1089. package/dist/src/utils/workspaceContext.test.d.ts +6 -0
  1090. package/dist/src/utils/workspaceContext.test.js +318 -0
  1091. package/dist/src/utils/workspaceContext.test.js.map +1 -0
  1092. package/dist/src/utils/yaml-parser.d.ts +29 -0
  1093. package/dist/src/utils/yaml-parser.js +172 -0
  1094. package/dist/src/utils/yaml-parser.js.map +1 -0
  1095. package/dist/src/utils/yaml-parser.test.d.ts +6 -0
  1096. package/dist/src/utils/yaml-parser.test.js +170 -0
  1097. package/dist/src/utils/yaml-parser.test.js.map +1 -0
  1098. package/dist/tsconfig.tsbuildinfo +1 -0
  1099. package/package.json +93 -0
  1100. package/scripts/postinstall.js +100 -0
  1101. package/vendor/ripgrep/COPYING +3 -0
  1102. package/vendor/ripgrep/arm64-darwin/rg +0 -0
  1103. package/vendor/ripgrep/arm64-linux/rg +0 -0
  1104. package/vendor/ripgrep/x64-darwin/rg +0 -0
  1105. package/vendor/ripgrep/x64-linux/rg +0 -0
  1106. package/vendor/ripgrep/x64-win32/rg.exe +0 -0
@@ -0,0 +1,684 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 OSAgent OC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ /* eslint-disable @typescript-eslint/no-explicit-any */
7
+ const mockGenerateJson = vi.hoisted(() => vi.fn());
8
+ const mockOpenDiff = vi.hoisted(() => vi.fn());
9
+ import { IdeClient } from '../ide/ide-client.js';
10
+ vi.mock('../ide/ide-client.js', () => ({
11
+ IdeClient: {
12
+ getInstance: vi.fn(),
13
+ },
14
+ }));
15
+ vi.mock('../utils/editor.js', () => ({
16
+ openDiff: mockOpenDiff,
17
+ }));
18
+ vi.mock('../telemetry/loggers.js', () => ({
19
+ logFileOperation: vi.fn(),
20
+ }));
21
+ import { describe, it, expect, beforeEach, afterEach, vi } from 'vitest';
22
+ import { applyReplacement, EditTool } from './edit.js';
23
+ import { ToolConfirmationOutcome } from './tools.js';
24
+ import { ToolErrorType } from './tool-error.js';
25
+ import path from 'node:path';
26
+ import fs from 'node:fs';
27
+ import os from 'node:os';
28
+ import { ApprovalMode } from '../config/config.js';
29
+ import { createMockWorkspaceContext } from '../test-utils/mockWorkspaceContext.js';
30
+ import { StandardFileSystemService } from '../services/fileSystemService.js';
31
+ describe('EditTool', () => {
32
+ let tool;
33
+ let tempDir;
34
+ let rootDir;
35
+ let mockConfig;
36
+ let OSAClient;
37
+ let baseLlmClient;
38
+ beforeEach(() => {
39
+ vi.restoreAllMocks();
40
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'edit-tool-test-'));
41
+ rootDir = path.join(tempDir, 'root');
42
+ fs.mkdirSync(rootDir);
43
+ OSAClient = {
44
+ generateJson: mockGenerateJson, // mockGenerateJson is already defined and hoisted
45
+ };
46
+ baseLlmClient = {
47
+ generateJson: vi.fn(),
48
+ };
49
+ mockConfig = {
50
+ getOSAClient: vi.fn().mockReturnValue(OSAClient),
51
+ getBaseLlmClient: vi.fn().mockReturnValue(baseLlmClient),
52
+ getTargetDir: () => rootDir,
53
+ getApprovalMode: vi.fn(),
54
+ setApprovalMode: vi.fn(),
55
+ getWorkspaceContext: () => createMockWorkspaceContext(rootDir),
56
+ getFileSystemService: () => new StandardFileSystemService(),
57
+ getIdeMode: () => false,
58
+ getApiKey: () => 'test-api-key',
59
+ getModel: () => 'test-model',
60
+ getSandbox: () => false,
61
+ getDebugMode: () => false,
62
+ getQuestion: () => undefined,
63
+ getFullContext: () => false,
64
+ getToolDiscoveryCommand: () => undefined,
65
+ getToolCallCommand: () => undefined,
66
+ getMcpServerCommand: () => undefined,
67
+ getMcpServers: () => undefined,
68
+ getUserAgent: () => 'test-agent',
69
+ getUserMemory: () => '',
70
+ setUserMemory: vi.fn(),
71
+ getOSAMdFileCount: () => 0,
72
+ setOSAMdFileCount: vi.fn(),
73
+ getToolRegistry: () => ({}), // Minimal mock for ToolRegistry
74
+ };
75
+ // Reset mocks before each test
76
+ mockConfig.getApprovalMode.mockClear();
77
+ // Default to not skipping confirmation
78
+ mockConfig.getApprovalMode.mockReturnValue(ApprovalMode.DEFAULT);
79
+ tool = new EditTool(mockConfig);
80
+ });
81
+ afterEach(() => {
82
+ fs.rmSync(tempDir, { recursive: true, force: true });
83
+ });
84
+ describe('applyReplacement', () => {
85
+ it('should return newString if isNewFile is true', () => {
86
+ expect(applyReplacement(null, 'old', 'new', true)).toBe('new');
87
+ expect(applyReplacement('existing', 'old', 'new', true)).toBe('new');
88
+ });
89
+ it('should return newString if currentContent is null and oldString is empty (defensive)', () => {
90
+ expect(applyReplacement(null, '', 'new', false)).toBe('new');
91
+ });
92
+ it('should return empty string if currentContent is null and oldString is not empty (defensive)', () => {
93
+ expect(applyReplacement(null, 'old', 'new', false)).toBe('');
94
+ });
95
+ it('should replace oldString with newString in currentContent', () => {
96
+ expect(applyReplacement('hello old world old', 'old', 'new', false)).toBe('hello new world new');
97
+ });
98
+ it('should return currentContent if oldString is empty and not a new file', () => {
99
+ expect(applyReplacement('hello world', '', 'new', false)).toBe('hello world');
100
+ });
101
+ it('should treat $ literally and not as replacement pattern', () => {
102
+ const current = "price is $100 and pattern end is ' '";
103
+ const oldStr = 'price is $100';
104
+ const newStr = 'price is $200';
105
+ const result = applyReplacement(current, oldStr, newStr, false);
106
+ expect(result).toBe("price is $200 and pattern end is ' '");
107
+ });
108
+ it("should treat $' literally and not as a replacement pattern", () => {
109
+ const current = 'foo';
110
+ const oldStr = 'foo';
111
+ const newStr = "bar$'baz";
112
+ const result = applyReplacement(current, oldStr, newStr, false);
113
+ expect(result).toBe("bar$'baz");
114
+ });
115
+ it('should treat $& literally and not as a replacement pattern', () => {
116
+ const current = 'hello world';
117
+ const oldStr = 'hello';
118
+ const newStr = '$&-replacement';
119
+ const result = applyReplacement(current, oldStr, newStr, false);
120
+ expect(result).toBe('$&-replacement world');
121
+ });
122
+ it('should treat $` literally and not as a replacement pattern', () => {
123
+ const current = 'prefix-middle-suffix';
124
+ const oldStr = 'middle';
125
+ const newStr = 'new$`content';
126
+ const result = applyReplacement(current, oldStr, newStr, false);
127
+ expect(result).toBe('prefix-new$`content-suffix');
128
+ });
129
+ it('should treat $1, $2 capture groups literally', () => {
130
+ const current = 'test string';
131
+ const oldStr = 'test';
132
+ const newStr = '$1$2replacement';
133
+ const result = applyReplacement(current, oldStr, newStr, false);
134
+ expect(result).toBe('$1$2replacement string');
135
+ });
136
+ it('should use replaceAll for normal strings without problematic $ sequences', () => {
137
+ const current = 'normal text replacement';
138
+ const oldStr = 'text';
139
+ const newStr = 'string';
140
+ const result = applyReplacement(current, oldStr, newStr, false);
141
+ expect(result).toBe('normal string replacement');
142
+ });
143
+ it('should handle multiple occurrences with problematic $ sequences', () => {
144
+ const current = 'foo bar foo baz';
145
+ const oldStr = 'foo';
146
+ const newStr = "test$'end";
147
+ const result = applyReplacement(current, oldStr, newStr, false);
148
+ expect(result).toBe("test$'end bar test$'end baz");
149
+ });
150
+ it('should handle complex regex patterns with $ at end', () => {
151
+ const current = "| select('match', '^[sv]d[a-z]$')";
152
+ const oldStr = "'^[sv]d[a-z]$'";
153
+ const newStr = "'^[sv]d[a-z]$' # updated";
154
+ const result = applyReplacement(current, oldStr, newStr, false);
155
+ expect(result).toBe("| select('match', '^[sv]d[a-z]$' # updated)");
156
+ });
157
+ it('should handle empty replacement with problematic $ in newString', () => {
158
+ const current = 'test content';
159
+ const oldStr = 'nothing';
160
+ const newStr = "replacement$'text";
161
+ const result = applyReplacement(current, oldStr, newStr, false);
162
+ expect(result).toBe('test content'); // No replacement because oldStr not found
163
+ });
164
+ it('should handle $$ (escaped dollar) correctly', () => {
165
+ const current = 'price value';
166
+ const oldStr = 'value';
167
+ const newStr = '$$100';
168
+ const result = applyReplacement(current, oldStr, newStr, false);
169
+ expect(result).toBe('price $$100');
170
+ });
171
+ });
172
+ describe('validateToolParams', () => {
173
+ it('should return null for valid params', () => {
174
+ const params = {
175
+ file_path: path.join(rootDir, 'test.txt'),
176
+ old_string: 'old',
177
+ new_string: 'new',
178
+ };
179
+ expect(tool.validateToolParams(params)).toBeNull();
180
+ });
181
+ it('should return error for relative path', () => {
182
+ const params = {
183
+ file_path: 'test.txt',
184
+ old_string: 'old',
185
+ new_string: 'new',
186
+ };
187
+ expect(tool.validateToolParams(params)).toMatch(/File path must be absolute/);
188
+ });
189
+ it('should return error for path outside root', () => {
190
+ const params = {
191
+ file_path: path.join(tempDir, 'outside-root.txt'),
192
+ old_string: 'old',
193
+ new_string: 'new',
194
+ };
195
+ const error = tool.validateToolParams(params);
196
+ expect(error).toContain('File path must be within one of the workspace directories');
197
+ });
198
+ });
199
+ describe('shouldConfirmExecute', () => {
200
+ const testFile = 'edit_me.txt';
201
+ let filePath;
202
+ beforeEach(() => {
203
+ filePath = path.join(rootDir, testFile);
204
+ });
205
+ it('should throw an error if params are invalid', async () => {
206
+ const params = {
207
+ file_path: 'relative.txt',
208
+ old_string: 'old',
209
+ new_string: 'new',
210
+ };
211
+ expect(() => tool.build(params)).toThrow();
212
+ });
213
+ it('should request confirmation for valid edit', async () => {
214
+ fs.writeFileSync(filePath, 'some old content here');
215
+ const params = {
216
+ file_path: filePath,
217
+ old_string: 'old',
218
+ new_string: 'new',
219
+ };
220
+ const invocation = tool.build(params);
221
+ const confirmation = await invocation.shouldConfirmExecute(new AbortController().signal);
222
+ expect(confirmation).toEqual(expect.objectContaining({
223
+ title: `Confirm Edit: ${testFile}`,
224
+ fileName: testFile,
225
+ fileDiff: expect.any(String),
226
+ }));
227
+ });
228
+ it('should return false if old_string is not found', async () => {
229
+ fs.writeFileSync(filePath, 'some content here');
230
+ const params = {
231
+ file_path: filePath,
232
+ old_string: 'not_found',
233
+ new_string: 'new',
234
+ };
235
+ const invocation = tool.build(params);
236
+ const confirmation = await invocation.shouldConfirmExecute(new AbortController().signal);
237
+ expect(confirmation).toBe(false);
238
+ });
239
+ it('should return false if multiple occurrences of old_string are found', async () => {
240
+ fs.writeFileSync(filePath, 'old old content here');
241
+ const params = {
242
+ file_path: filePath,
243
+ old_string: 'old',
244
+ new_string: 'new',
245
+ };
246
+ const invocation = tool.build(params);
247
+ const confirmation = await invocation.shouldConfirmExecute(new AbortController().signal);
248
+ expect(confirmation).toBe(false);
249
+ });
250
+ it('should request confirmation for creating a new file (empty old_string)', async () => {
251
+ const newFileName = 'new_file.txt';
252
+ const newFilePath = path.join(rootDir, newFileName);
253
+ const params = {
254
+ file_path: newFilePath,
255
+ old_string: '',
256
+ new_string: 'new file content',
257
+ };
258
+ const invocation = tool.build(params);
259
+ const confirmation = await invocation.shouldConfirmExecute(new AbortController().signal);
260
+ expect(confirmation).toEqual(expect.objectContaining({
261
+ title: `Confirm Edit: ${newFileName}`,
262
+ fileName: newFileName,
263
+ fileDiff: expect.any(String),
264
+ }));
265
+ });
266
+ it('should rethrow calculateEdit errors when the abort signal is triggered', async () => {
267
+ const filePath = path.join(rootDir, 'abort-confirmation.txt');
268
+ const params = {
269
+ file_path: filePath,
270
+ old_string: 'old',
271
+ new_string: 'new',
272
+ };
273
+ const invocation = tool.build(params);
274
+ const abortController = new AbortController();
275
+ const abortError = new Error('Abort requested');
276
+ const calculateSpy = vi
277
+ .spyOn(invocation, 'calculateEdit')
278
+ .mockImplementation(async () => {
279
+ if (!abortController.signal.aborted) {
280
+ abortController.abort();
281
+ }
282
+ throw abortError;
283
+ });
284
+ await expect(invocation.shouldConfirmExecute(abortController.signal)).rejects.toBe(abortError);
285
+ calculateSpy.mockRestore();
286
+ });
287
+ });
288
+ describe('execute', () => {
289
+ const testFile = 'execute_me.txt';
290
+ let filePath;
291
+ beforeEach(() => {
292
+ filePath = path.join(rootDir, testFile);
293
+ });
294
+ it('should throw error if file path is not absolute', async () => {
295
+ const params = {
296
+ file_path: 'relative.txt',
297
+ old_string: 'old',
298
+ new_string: 'new',
299
+ };
300
+ expect(() => tool.build(params)).toThrow(/File path must be absolute/);
301
+ });
302
+ it('should throw error if file path is empty', async () => {
303
+ const params = {
304
+ file_path: '',
305
+ old_string: 'old',
306
+ new_string: 'new',
307
+ };
308
+ expect(() => tool.build(params)).toThrow(/The 'file_path' parameter must be non-empty./);
309
+ });
310
+ it('should reject when calculateEdit fails after an abort signal', async () => {
311
+ const params = {
312
+ file_path: path.join(rootDir, 'abort-execute.txt'),
313
+ old_string: 'old',
314
+ new_string: 'new',
315
+ };
316
+ const invocation = tool.build(params);
317
+ const abortController = new AbortController();
318
+ const abortError = new Error('Abort requested during execute');
319
+ const calculateSpy = vi
320
+ .spyOn(invocation, 'calculateEdit')
321
+ .mockImplementation(async () => {
322
+ if (!abortController.signal.aborted) {
323
+ abortController.abort();
324
+ }
325
+ throw abortError;
326
+ });
327
+ await expect(invocation.execute(abortController.signal)).rejects.toBe(abortError);
328
+ calculateSpy.mockRestore();
329
+ });
330
+ it('should edit an existing file and return diff with fileName', async () => {
331
+ const initialContent = 'This is some old text.';
332
+ const newContent = 'This is some new text.'; // old -> new
333
+ fs.writeFileSync(filePath, initialContent, 'utf8');
334
+ const params = {
335
+ file_path: filePath,
336
+ old_string: 'old',
337
+ new_string: 'new',
338
+ };
339
+ const invocation = tool.build(params);
340
+ const result = await invocation.execute(new AbortController().signal);
341
+ expect(result.llmContent).toMatch(/Showing lines \d+-\d+ of \d+ from the edited file:/);
342
+ expect(fs.readFileSync(filePath, 'utf8')).toBe(newContent);
343
+ const display = result.returnDisplay;
344
+ expect(display.fileDiff).toMatch(initialContent);
345
+ expect(display.fileDiff).toMatch(newContent);
346
+ expect(display.fileName).toBe(testFile);
347
+ });
348
+ it('should create a new file if old_string is empty and file does not exist, and return created message', async () => {
349
+ const newFileName = 'brand_new_file.txt';
350
+ const newFilePath = path.join(rootDir, newFileName);
351
+ const fileContent = 'Content for the new file.';
352
+ const params = {
353
+ file_path: newFilePath,
354
+ old_string: '',
355
+ new_string: fileContent,
356
+ };
357
+ mockConfig.getApprovalMode.mockReturnValueOnce(ApprovalMode.AUTO_EDIT);
358
+ const invocation = tool.build(params);
359
+ const result = await invocation.execute(new AbortController().signal);
360
+ expect(result.llmContent).toMatch(/Created new file/);
361
+ expect(result.llmContent).toMatch(/Showing lines \d+-\d+ of \d+ from the edited file:/);
362
+ expect(fs.existsSync(newFilePath)).toBe(true);
363
+ expect(fs.readFileSync(newFilePath, 'utf8')).toBe(fileContent);
364
+ const display = result.returnDisplay;
365
+ expect(display.fileDiff).toMatch(/\+Content for the new file\./);
366
+ expect(display.fileName).toBe(newFileName);
367
+ expect(result.returnDisplay.diffStat).toStrictEqual({
368
+ model_added_lines: 1,
369
+ model_removed_lines: 0,
370
+ model_added_chars: 25,
371
+ model_removed_chars: 0,
372
+ user_added_lines: 0,
373
+ user_removed_lines: 0,
374
+ user_added_chars: 0,
375
+ user_removed_chars: 0,
376
+ });
377
+ });
378
+ it('should return error if old_string is not found in file', async () => {
379
+ fs.writeFileSync(filePath, 'Some content.', 'utf8');
380
+ const params = {
381
+ file_path: filePath,
382
+ old_string: 'nonexistent',
383
+ new_string: 'replacement',
384
+ };
385
+ const invocation = tool.build(params);
386
+ const result = await invocation.execute(new AbortController().signal);
387
+ expect(result.llmContent).toMatch(/0 occurrences found for old_string in/);
388
+ expect(result.returnDisplay).toMatch(/Failed to edit, could not find the string to replace./);
389
+ });
390
+ it('should return error if multiple occurrences of old_string are found and replace_all is false', async () => {
391
+ fs.writeFileSync(filePath, 'multiple old old strings', 'utf8');
392
+ const params = {
393
+ file_path: filePath,
394
+ old_string: 'old',
395
+ new_string: 'new',
396
+ };
397
+ const invocation = tool.build(params);
398
+ const result = await invocation.execute(new AbortController().signal);
399
+ expect(result.llmContent).toMatch(/replace_all was not enabled/);
400
+ expect(result.returnDisplay).toMatch(/Failed to edit because the text matches multiple locations/);
401
+ });
402
+ it('should successfully replace multiple occurrences when replace_all is true', async () => {
403
+ fs.writeFileSync(filePath, 'old text\nold text\nold text', 'utf8');
404
+ const params = {
405
+ file_path: filePath,
406
+ old_string: 'old',
407
+ new_string: 'new',
408
+ replace_all: true,
409
+ };
410
+ const invocation = tool.build(params);
411
+ const result = await invocation.execute(new AbortController().signal);
412
+ expect(result.llmContent).toMatch(/Showing lines \d+-\d+ of \d+ from the edited file/);
413
+ expect(fs.readFileSync(filePath, 'utf8')).toBe('new text\nnew text\nnew text');
414
+ const display = result.returnDisplay;
415
+ expect(display.fileDiff).toMatch(/-old text\n-old text\n-old text/);
416
+ expect(display.fileDiff).toMatch(/\+new text\n\+new text\n\+new text/);
417
+ expect(display.fileName).toBe(testFile);
418
+ expect(result.returnDisplay.diffStat).toStrictEqual({
419
+ model_added_lines: 3,
420
+ model_removed_lines: 3,
421
+ model_added_chars: 24,
422
+ model_removed_chars: 24,
423
+ user_added_lines: 0,
424
+ user_removed_lines: 0,
425
+ user_added_chars: 0,
426
+ user_removed_chars: 0,
427
+ });
428
+ });
429
+ it('should return error if trying to create a file that already exists (empty old_string)', async () => {
430
+ fs.writeFileSync(filePath, 'Existing content', 'utf8');
431
+ const params = {
432
+ file_path: filePath,
433
+ old_string: '',
434
+ new_string: 'new content',
435
+ };
436
+ const invocation = tool.build(params);
437
+ const result = await invocation.execute(new AbortController().signal);
438
+ expect(result.llmContent).toMatch(/File already exists, cannot create/);
439
+ expect(result.returnDisplay).toMatch(/Attempted to create a file that already exists/);
440
+ });
441
+ it('should not include modification message when proposed content is not modified', async () => {
442
+ const initialContent = 'This is some old text.';
443
+ fs.writeFileSync(filePath, initialContent, 'utf8');
444
+ const params = {
445
+ file_path: filePath,
446
+ old_string: 'old',
447
+ new_string: 'new',
448
+ modified_by_user: false,
449
+ };
450
+ mockConfig.getApprovalMode.mockReturnValueOnce(ApprovalMode.AUTO_EDIT);
451
+ const invocation = tool.build(params);
452
+ const result = await invocation.execute(new AbortController().signal);
453
+ expect(result.llmContent).not.toMatch(/User modified the `new_string` content/);
454
+ });
455
+ it('should not include modification message when modified_by_user is not provided', async () => {
456
+ const initialContent = 'This is some old text.';
457
+ fs.writeFileSync(filePath, initialContent, 'utf8');
458
+ const params = {
459
+ file_path: filePath,
460
+ old_string: 'old',
461
+ new_string: 'new',
462
+ };
463
+ mockConfig.getApprovalMode.mockReturnValueOnce(ApprovalMode.AUTO_EDIT);
464
+ const invocation = tool.build(params);
465
+ const result = await invocation.execute(new AbortController().signal);
466
+ expect(result.llmContent).not.toMatch(/User modified the `new_string` content/);
467
+ });
468
+ it('should return error if old_string and new_string are identical', async () => {
469
+ const initialContent = 'This is some identical text.';
470
+ fs.writeFileSync(filePath, initialContent, 'utf8');
471
+ const params = {
472
+ file_path: filePath,
473
+ old_string: 'identical',
474
+ new_string: 'identical',
475
+ };
476
+ const invocation = tool.build(params);
477
+ const result = await invocation.execute(new AbortController().signal);
478
+ expect(result.llmContent).toMatch(/No changes to apply/);
479
+ expect(result.returnDisplay).toMatch(/No changes to apply/);
480
+ });
481
+ it('should return EDIT_NO_CHANGE error if replacement results in identical content', async () => {
482
+ // This can happen if the literal string replacement with `replaceAll` results in no change.
483
+ const initialContent = 'line 1\nline 2\nline 3'; // Note the double space
484
+ fs.writeFileSync(filePath, initialContent, 'utf8');
485
+ const params = {
486
+ file_path: filePath,
487
+ // old_string has a single space, so it won't be found by replaceAll
488
+ old_string: 'line 1\nline 2\nline 3',
489
+ new_string: 'line 1\nnew line 2\nline 3',
490
+ };
491
+ const invocation = tool.build(params);
492
+ const result = await invocation.execute(new AbortController().signal);
493
+ expect(result.error?.type).toBe(ToolErrorType.EDIT_NO_OCCURRENCE_FOUND);
494
+ expect(result.returnDisplay).toMatch(/Failed to edit, could not find the string to replace./);
495
+ // Ensure the file was not actually changed
496
+ expect(fs.readFileSync(filePath, 'utf8')).toBe(initialContent);
497
+ });
498
+ });
499
+ describe('Error Scenarios', () => {
500
+ const testFile = 'error_test.txt';
501
+ let filePath;
502
+ beforeEach(() => {
503
+ filePath = path.join(rootDir, testFile);
504
+ });
505
+ it('should return FILE_NOT_FOUND error', async () => {
506
+ const params = {
507
+ file_path: filePath,
508
+ old_string: 'any',
509
+ new_string: 'new',
510
+ };
511
+ const invocation = tool.build(params);
512
+ const result = await invocation.execute(new AbortController().signal);
513
+ expect(result.error?.type).toBe(ToolErrorType.FILE_NOT_FOUND);
514
+ });
515
+ it('should return ATTEMPT_TO_CREATE_EXISTING_FILE error', async () => {
516
+ fs.writeFileSync(filePath, 'existing content', 'utf8');
517
+ const params = {
518
+ file_path: filePath,
519
+ old_string: '',
520
+ new_string: 'new content',
521
+ };
522
+ const invocation = tool.build(params);
523
+ const result = await invocation.execute(new AbortController().signal);
524
+ expect(result.error?.type).toBe(ToolErrorType.ATTEMPT_TO_CREATE_EXISTING_FILE);
525
+ });
526
+ it('should return NO_OCCURRENCE_FOUND error', async () => {
527
+ fs.writeFileSync(filePath, 'content', 'utf8');
528
+ const params = {
529
+ file_path: filePath,
530
+ old_string: 'not-found',
531
+ new_string: 'new',
532
+ };
533
+ const invocation = tool.build(params);
534
+ const result = await invocation.execute(new AbortController().signal);
535
+ expect(result.error?.type).toBe(ToolErrorType.EDIT_NO_OCCURRENCE_FOUND);
536
+ });
537
+ it('should return EXPECTED_OCCURRENCE_MISMATCH error when replace_all is false and text is not unique', async () => {
538
+ fs.writeFileSync(filePath, 'one one two', 'utf8');
539
+ const params = {
540
+ file_path: filePath,
541
+ old_string: 'one',
542
+ new_string: 'new',
543
+ };
544
+ const invocation = tool.build(params);
545
+ const result = await invocation.execute(new AbortController().signal);
546
+ expect(result.error?.type).toBe(ToolErrorType.EDIT_EXPECTED_OCCURRENCE_MISMATCH);
547
+ });
548
+ it('should return NO_CHANGE error', async () => {
549
+ fs.writeFileSync(filePath, 'content', 'utf8');
550
+ const params = {
551
+ file_path: filePath,
552
+ old_string: 'content',
553
+ new_string: 'content',
554
+ };
555
+ const invocation = tool.build(params);
556
+ const result = await invocation.execute(new AbortController().signal);
557
+ expect(result.error?.type).toBe(ToolErrorType.EDIT_NO_CHANGE);
558
+ });
559
+ it('should throw INVALID_PARAMETERS error for relative path', async () => {
560
+ const params = {
561
+ file_path: 'relative/path.txt',
562
+ old_string: 'a',
563
+ new_string: 'b',
564
+ };
565
+ expect(() => tool.build(params)).toThrow();
566
+ });
567
+ it('should return FILE_WRITE_FAILURE on write error', async () => {
568
+ fs.writeFileSync(filePath, 'content', 'utf8');
569
+ // Make file readonly to trigger a write error
570
+ fs.chmodSync(filePath, '444');
571
+ const params = {
572
+ file_path: filePath,
573
+ old_string: 'content',
574
+ new_string: 'new content',
575
+ };
576
+ const invocation = tool.build(params);
577
+ const result = await invocation.execute(new AbortController().signal);
578
+ expect(result.error?.type).toBe(ToolErrorType.FILE_WRITE_FAILURE);
579
+ });
580
+ });
581
+ describe('getDescription', () => {
582
+ it('should return "No file changes to..." if old_string and new_string are the same', () => {
583
+ const testFileName = 'test.txt';
584
+ const params = {
585
+ file_path: path.join(rootDir, testFileName),
586
+ old_string: 'identical_string',
587
+ new_string: 'identical_string',
588
+ };
589
+ const invocation = tool.build(params);
590
+ // shortenPath will be called internally, resulting in just the file name
591
+ expect(invocation.getDescription()).toBe(`No file changes to ${testFileName}`);
592
+ });
593
+ it('should return a snippet of old and new strings if they are different', () => {
594
+ const testFileName = 'test.txt';
595
+ const params = {
596
+ file_path: path.join(rootDir, testFileName),
597
+ old_string: 'this is the old string value',
598
+ new_string: 'this is the new string value',
599
+ };
600
+ const invocation = tool.build(params);
601
+ // shortenPath will be called internally, resulting in just the file name
602
+ // The snippets are truncated at 30 chars + '...'
603
+ expect(invocation.getDescription()).toBe(`${testFileName}: this is the old string value => this is the new string value`);
604
+ });
605
+ it('should handle very short strings correctly in the description', () => {
606
+ const testFileName = 'short.txt';
607
+ const params = {
608
+ file_path: path.join(rootDir, testFileName),
609
+ old_string: 'old',
610
+ new_string: 'new',
611
+ };
612
+ const invocation = tool.build(params);
613
+ expect(invocation.getDescription()).toBe(`${testFileName}: old => new`);
614
+ });
615
+ it('should truncate long strings in the description', () => {
616
+ const testFileName = 'long.txt';
617
+ const params = {
618
+ file_path: path.join(rootDir, testFileName),
619
+ old_string: 'this is a very long old string that will definitely be truncated',
620
+ new_string: 'this is a very long new string that will also be truncated',
621
+ };
622
+ const invocation = tool.build(params);
623
+ expect(invocation.getDescription()).toBe(`${testFileName}: this is a very long old string... => this is a very long new string...`);
624
+ });
625
+ });
626
+ describe('workspace boundary validation', () => {
627
+ it('should validate paths are within workspace root', () => {
628
+ const validPath = {
629
+ file_path: path.join(rootDir, 'file.txt'),
630
+ old_string: 'old',
631
+ new_string: 'new',
632
+ };
633
+ expect(tool.validateToolParams(validPath)).toBeNull();
634
+ });
635
+ it('should reject paths outside workspace root', () => {
636
+ const invalidPath = {
637
+ file_path: '/etc/passwd',
638
+ old_string: 'root',
639
+ new_string: 'hacked',
640
+ };
641
+ const error = tool.validateToolParams(invalidPath);
642
+ expect(error).toContain('File path must be within one of the workspace directories');
643
+ expect(error).toContain(rootDir);
644
+ });
645
+ });
646
+ describe('IDE mode', () => {
647
+ const testFile = 'edit_me.txt';
648
+ let filePath;
649
+ let ideClient;
650
+ beforeEach(() => {
651
+ filePath = path.join(rootDir, testFile);
652
+ ideClient = {
653
+ openDiff: vi.fn(),
654
+ isDiffingEnabled: vi.fn().mockReturnValue(true),
655
+ };
656
+ vi.mocked(IdeClient.getInstance).mockResolvedValue(ideClient);
657
+ mockConfig.getIdeMode = () => true;
658
+ });
659
+ it('should call ideClient.openDiff and update params on confirmation', async () => {
660
+ const initialContent = 'some old content here';
661
+ const newContent = 'some new content here';
662
+ const modifiedContent = 'some modified content here';
663
+ fs.writeFileSync(filePath, initialContent);
664
+ const params = {
665
+ file_path: filePath,
666
+ old_string: 'old',
667
+ new_string: 'new',
668
+ };
669
+ ideClient.openDiff.mockResolvedValueOnce({
670
+ status: 'accepted',
671
+ content: modifiedContent,
672
+ });
673
+ const invocation = tool.build(params);
674
+ const confirmation = await invocation.shouldConfirmExecute(new AbortController().signal);
675
+ expect(ideClient.openDiff).toHaveBeenCalledWith(filePath, newContent);
676
+ if (confirmation && 'onConfirm' in confirmation) {
677
+ await confirmation.onConfirm(ToolConfirmationOutcome.ProceedOnce);
678
+ }
679
+ expect(params.old_string).toBe(initialContent);
680
+ expect(params.new_string).toBe(modifiedContent);
681
+ });
682
+ });
683
+ });
684
+ //# sourceMappingURL=edit.test.js.map