@didim365/agent-cli-core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2061) hide show
  1. package/dist/.last_build +0 -0
  2. package/dist/docs/00_project/ai_adapter/01-overview.md +172 -0
  3. package/dist/docs/00_project/ai_adapter/02-architecture.md +448 -0
  4. package/dist/docs/00_project/ai_adapter/03-technical-design.md +1470 -0
  5. package/dist/docs/00_project/ai_adapter/04-integration-design.md +1934 -0
  6. package/dist/docs/00_project/ai_adapter/05-implementation-plan.md +336 -0
  7. package/dist/docs/00_project/ai_adapter/06-didiaistudio-plan.md +559 -0
  8. package/dist/docs/00_project/ai_adapter/README.md +145 -0
  9. package/dist/docs/00_project/ai_adapter/agent_service_openapi.json +1 -0
  10. package/dist/docs/00_project/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  11. package/dist/docs/00_project/ai_adapter/event-mapping-matrix.md +148 -0
  12. package/dist/docs/00_project/ai_adapter/migration-plan.md +205 -0
  13. package/dist/docs/00_project/ai_adapter/template/00_vibecoding_workflow.md +627 -0
  14. package/dist/docs/00_project/ai_adapter/template/01_todolist_performance_template.md +436 -0
  15. package/dist/docs/00_project/ai_adapter/template/02_code_review_template.md +248 -0
  16. package/dist/docs/00_project/ai_adapter/template/03_work_result_report_template.md +133 -0
  17. package/dist/docs/00_project/ai_adapter/template/100_Python_Performance_Guide.md +472 -0
  18. package/dist/docs/00_project/ai_adapter/template/99_TDD_plan.md +123 -0
  19. package/dist/docs/00_project/ai_adapter/todolist/00_master_implementation_plan.md +433 -0
  20. package/dist/docs/00_project/ai_adapter/todolist/phase1_foundation_todolist.md +726 -0
  21. package/dist/docs/00_project/ai_adapter/todolist/phase2_core_refactoring_todolist.md +974 -0
  22. package/dist/docs/00_project/ai_adapter/todolist/phase3_handoff.md +203 -0
  23. package/dist/docs/00_project/ai_adapter/todolist/phase3_provider_extension_todolist.md +1382 -0
  24. package/dist/docs/00_project/ai_adapter/utility-migration.md +237 -0
  25. package/dist/docs/00_project/ai_adapter/working_history/.gitkeep +0 -0
  26. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +197 -0
  27. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +185 -0
  28. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +378 -0
  29. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +269 -0
  30. package/dist/docs/00_project/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +86 -0
  31. package/dist/docs/00_project/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +157 -0
  32. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +107 -0
  33. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +630 -0
  34. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +372 -0
  35. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +205 -0
  36. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +275 -0
  37. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +239 -0
  38. package/dist/docs/00_project/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +228 -0
  39. package/dist/docs/00_project/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +470 -0
  40. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +271 -0
  41. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +330 -0
  42. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +251 -0
  43. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +136 -0
  44. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +232 -0
  45. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +191 -0
  46. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +225 -0
  47. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +171 -0
  48. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +198 -0
  49. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +98 -0
  50. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +264 -0
  51. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +204 -0
  52. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +106 -0
  53. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +251 -0
  54. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +264 -0
  55. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +176 -0
  56. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +204 -0
  57. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +316 -0
  58. package/dist/docs/00_project/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +262 -0
  59. package/dist/docs/00_project/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +286 -0
  60. package/dist/docs/00_project/white_labeling/template/00_vibecoding_workflow.md +627 -0
  61. package/dist/docs/00_project/white_labeling/template/01_todolist_performance_template.md +400 -0
  62. package/dist/docs/00_project/white_labeling/template/02_code_review_template.md +248 -0
  63. package/dist/docs/00_project/white_labeling/template/03_work_result_report_template.md +133 -0
  64. package/dist/docs/00_project/white_labeling/template/100_Python_Performance_Guide.md +472 -0
  65. package/dist/docs/00_project/white_labeling/template/99_TDD_plan.md +123 -0
  66. package/dist/docs/00_project/white_labeling/todolist/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_todolist.md +431 -0
  67. package/dist/docs/00_project/white_labeling/working_history/Phase_CLI/355/214/250/355/202/244/354/247/200/353/252/205/353/263/200/352/262/275_20260214.md +238 -0
  68. package/dist/docs/00_project/white_labeling//354/225/261/352/265/254/354/241/260.md +310 -0
  69. package/dist/docs/CONTRIBUTING.md +554 -0
  70. package/dist/docs/ai_adapter/01-overview.md +155 -0
  71. package/dist/docs/ai_adapter/02-architecture.md +452 -0
  72. package/dist/docs/ai_adapter/03-technical-design.md +1470 -0
  73. package/dist/docs/ai_adapter/04-integration-design.md +1904 -0
  74. package/dist/docs/ai_adapter/05-implementation-plan.md +312 -0
  75. package/dist/docs/ai_adapter/06-didiaistudio-plan.md +559 -0
  76. package/dist/docs/ai_adapter/README.md +118 -0
  77. package/dist/docs/ai_adapter/agent_service_openapi.json +1 -0
  78. package/dist/docs/ai_adapter/didimStudi-AISTUDIO /341/204/213/341/205/254/341/204/207/341/205/256 /341/204/211/341/205/245/341/204/207/341/205/265/341/204/211/341/205/263 /341/204/221/341/205/263/341/206/257/341/204/205/341/205/251/341/204/213/341/205/256 /341/204/213/341/205/247/341/206/253/341/204/200/341/205/247/341/206/257 /341/204/207/341/205/241/341/206/274/341/204/211/341/205/265/341/206/250-100226-093925.pdf +0 -0
  79. package/dist/docs/ai_adapter/event-mapping-matrix.md +140 -0
  80. package/dist/docs/ai_adapter/migration-plan.md +205 -0
  81. package/dist/docs/ai_adapter/template/00_vibecoding_workflow.md +636 -0
  82. package/dist/docs/ai_adapter/template/01_todolist_performance_template.md +372 -0
  83. package/dist/docs/ai_adapter/template/02_code_review_template.md +220 -0
  84. package/dist/docs/ai_adapter/template/03_work_result_report_template.md +120 -0
  85. package/dist/docs/ai_adapter/template/100_Python_Performance_Guide.md +453 -0
  86. package/dist/docs/ai_adapter/template/99_TDD_plan.md +111 -0
  87. package/dist/docs/ai_adapter/todolist/00_master_implementation_plan.md +433 -0
  88. package/dist/docs/ai_adapter/todolist/phase1_foundation_todolist.md +726 -0
  89. package/dist/docs/ai_adapter/todolist/phase2_core_refactoring_todolist.md +974 -0
  90. package/dist/docs/ai_adapter/todolist/phase3_handoff.md +203 -0
  91. package/dist/docs/ai_adapter/todolist/phase3_provider_extension_todolist.md +1382 -0
  92. package/dist/docs/ai_adapter/utility-migration.md +237 -0
  93. package/dist/docs/ai_adapter/working_history/.gitkeep +0 -0
  94. package/dist/docs/ai_adapter/working_history/Phase1_M1.0_/354/275/224/353/223/234/354/235/270/353/262/244/355/206/240/353/246/254_20260201.md +185 -0
  95. package/dist/docs/ai_adapter/working_history/Phase1_M1.1_/355/203/200/354/236/205/354/204/244/352/263/204_20260201.md +185 -0
  96. package/dist/docs/ai_adapter/working_history/Phase1_M1.2_Adapter/354/235/270/355/224/204/353/235/274_20260203.md +378 -0
  97. package/dist/docs/ai_adapter/working_history/Phase1_M1.3_Provider/354/204/240/355/203/235_20260206.md +269 -0
  98. package/dist/docs/ai_adapter/working_history/Phase1_M1.4_/354/234/240/355/213/270/353/246/254/355/213/260/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260206.md +86 -0
  99. package/dist/docs/ai_adapter/working_history/Phase2_ETC_/354/227/260/352/270/260/354/236/221/354/227/205/354/240/225/353/246/254_20260208.md +157 -0
  100. package/dist/docs/ai_adapter/working_history/Phase2_M2.0_/353/224/224/353/240/211/355/206/240/353/246/254/354/236/254/352/265/254/354/204/261_20260207.md +107 -0
  101. package/dist/docs/ai_adapter/working_history/Phase2_M2.1_ContentGenerator/354/235/270/355/204/260/355/216/230/354/235/264/354/212/244/354/236/254/354/240/225/354/235/230_20260207.md +630 -0
  102. package/dist/docs/ai_adapter/working_history/Phase2_M2.2_EventMapper/352/265/254/355/230/204_20260207.md +372 -0
  103. package/dist/docs/ai_adapter/working_history/Phase2_M2.3_GeminiAdapter/352/265/254/355/230/204_20260208.md +205 -0
  104. package/dist/docs/ai_adapter/working_history/Phase2_M2.4_ModelConfigService/355/230/270/355/231/230/353/240/210/354/235/264/354/226/264_20260208.md +275 -0
  105. package/dist/docs/ai_adapter/working_history/Phase2_M2.5_/354/234/240/355/213/270/353/246/254/355/213/260/353/240/210/354/235/264/354/226/264/353/246/254/355/214/251/355/206/240/353/247/201_20260208.md +239 -0
  106. package/dist/docs/ai_adapter/working_history/Phase2_M2.6_/353/235/274/354/232/260/355/214/205/353/240/210/354/235/264/354/226/264/355/203/200/354/236/205/353/217/205/353/246/275/355/231/224_20260208.md +228 -0
  107. package/dist/docs/ai_adapter/working_history/Phase3_ETC_/352/270/260/353/263/270/354/273/250/355/205/215/354/212/244/355/212/270/355/214/214/354/235/274/353/252/205AGENTS/354/240/204/355/231/230_20260211.md +367 -0
  108. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.1_Gemini/354/240/204/354/232/251/355/214/214/354/235/274/353/254/274/353/246/254/354/240/201/354/235/264/353/217/231_20260209.md +271 -0
  109. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.2_messageInspectors/353/247/210/354/235/264/352/267/270/353/240/210/354/235/264/354/205/230_20260209.md +330 -0
  110. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.3_/355/205/224/353/240/210/353/251/224/355/212/270/353/246/254Agent/353/217/205/353/246/275/355/231/224_20260209.md +251 -0
  111. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.4_/353/263/200/355/231/230/353/270/214/353/246/277/354/247/200/354/240/225/353/246/254_20260209.md +136 -0
  112. package/dist/docs/ai_adapter/working_history/Phase3_M3.0.5_/353/237/260/355/203/200/354/236/204/354/213/244/355/226/211/352/262/275/353/241/234/354/227/260/352/262/260_20260209.md +232 -0
  113. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.0_Claude/354/202/254/354/240/204/354/244/200/353/271/204_20260209.md +191 -0
  114. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.1_ClaudeAdapter/352/265/254/355/230/204_20260209.md +225 -0
  115. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.2_ClaudeConverter/352/263/240/353/217/204/355/231/224_20260209.md +171 -0
  116. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.3_ClaudeStreamError/352/263/240/353/217/204/355/231/224_20260209.md +198 -0
  117. package/dist/docs/ai_adapter/working_history/Phase3_M3.1.4_ClaudeErrorMapping_20260209.md +98 -0
  118. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.A_OpenAIAdapterCore_20260210.md +264 -0
  119. package/dist/docs/ai_adapter/working_history/Phase3_M3.2.B_OpenAIStreamConverter_20260210.md +204 -0
  120. package/dist/docs/ai_adapter/working_history/Phase3_M3.3.2_/353/252/250/353/215/270/355/205/234/355/224/214/353/246/277/355/233/205/353/263/264/354/231/204_20260211.md +106 -0
  121. package/dist/docs/ai_adapter/working_history/Phase3_M3.3_OpenAICompatibleAdapter_20260211.md +251 -0
  122. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.2_E2E/355/205/214/354/212/244/355/212/270/354/213/234/353/202/230/353/246/254/354/230/244_20260210.md +264 -0
  123. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.3_/354/204/261/353/212/245/355/232/214/352/267/200/355/205/214/354/212/244/355/212/270_20260211.md +176 -0
  124. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.5_/354/225/210/354/240/225/355/231/224/354/236/221/354/227/205_20260211.md +204 -0
  125. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_CLI/355/206/265/355/225/251_3Provider/355/206/265/355/225/251/355/205/214/354/212/244/355/212/270_20260210.md +316 -0
  126. package/dist/docs/ai_adapter/working_history/Phase3_M3.4.A_UI/354/203/201/355/203/234/353/260/224/354/210/230/354/240/225_20260210.md +262 -0
  127. package/dist/docs/ai_adapter/working_history/phase2_tradeoff_EventType/354/240/204/355/231/230_20260208.md +286 -0
  128. package/dist/docs/api/index.md +5 -0
  129. package/dist/docs/api/providers.md +56 -0
  130. package/dist/docs/architecture.md +80 -0
  131. package/dist/docs/assets/connected_devtools.png +0 -0
  132. package/dist/docs/assets/gemini-screenshot.png +0 -0
  133. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  134. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  135. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  136. package/dist/docs/assets/release_patch.png +0 -0
  137. package/dist/docs/assets/theme-ansi-light.png +0 -0
  138. package/dist/docs/assets/theme-ansi.png +0 -0
  139. package/dist/docs/assets/theme-atom-one.png +0 -0
  140. package/dist/docs/assets/theme-ayu-light.png +0 -0
  141. package/dist/docs/assets/theme-ayu.png +0 -0
  142. package/dist/docs/assets/theme-custom.png +0 -0
  143. package/dist/docs/assets/theme-default-light.png +0 -0
  144. package/dist/docs/assets/theme-default.png +0 -0
  145. package/dist/docs/assets/theme-dracula.png +0 -0
  146. package/dist/docs/assets/theme-github-light.png +0 -0
  147. package/dist/docs/assets/theme-github.png +0 -0
  148. package/dist/docs/assets/theme-google-light.png +0 -0
  149. package/dist/docs/assets/theme-xcode-light.png +0 -0
  150. package/dist/docs/change_model/model_command_multi_provider_plan.md +221 -0
  151. package/dist/docs/change_model/model_command_multi_provider_todolist.md +206 -0
  152. package/dist/docs/changelogs/index.md +726 -0
  153. package/dist/docs/changelogs/latest.md +370 -0
  154. package/dist/docs/changelogs/preview.md +332 -0
  155. package/dist/docs/cli/authentication.md +3 -0
  156. package/dist/docs/cli/checkpointing.md +94 -0
  157. package/dist/docs/cli/commands.md +375 -0
  158. package/dist/docs/cli/custom-commands.md +315 -0
  159. package/dist/docs/cli/enterprise.md +565 -0
  160. package/dist/docs/cli/gemini-ignore.md +71 -0
  161. package/dist/docs/cli/gemini-md.md +108 -0
  162. package/dist/docs/cli/generation-settings.md +210 -0
  163. package/dist/docs/cli/headless.md +388 -0
  164. package/dist/docs/cli/index.md +65 -0
  165. package/dist/docs/cli/keyboard-shortcuts.md +129 -0
  166. package/dist/docs/cli/model-routing.md +42 -0
  167. package/dist/docs/cli/model.md +62 -0
  168. package/dist/docs/cli/sandbox.md +171 -0
  169. package/dist/docs/cli/session-management.md +158 -0
  170. package/dist/docs/cli/settings.md +130 -0
  171. package/dist/docs/cli/skills.md +188 -0
  172. package/dist/docs/cli/system-prompt.md +125 -0
  173. package/dist/docs/cli/telemetry.md +826 -0
  174. package/dist/docs/cli/themes.md +235 -0
  175. package/dist/docs/cli/token-caching.md +20 -0
  176. package/dist/docs/cli/trusted-folders.md +95 -0
  177. package/dist/docs/cli/tutorials/skills-getting-started.md +124 -0
  178. package/dist/docs/cli/tutorials.md +87 -0
  179. package/dist/docs/cli/uninstall.md +65 -0
  180. package/dist/docs/configuration.md +108 -0
  181. package/dist/docs/core/index.md +105 -0
  182. package/dist/docs/core/long-term-memory-design.md +254 -0
  183. package/dist/docs/core/long-term-memory-proposal.md +112 -0
  184. package/dist/docs/core/memport.md +246 -0
  185. package/dist/docs/core/policy-engine.md +300 -0
  186. package/dist/docs/core/tools-api.md +131 -0
  187. package/dist/docs/examples/proxy-script.md +83 -0
  188. package/dist/docs/extensions/best-practices.md +139 -0
  189. package/dist/docs/extensions/index.md +44 -0
  190. package/dist/docs/extensions/reference.md +312 -0
  191. package/dist/docs/extensions/releasing.md +183 -0
  192. package/dist/docs/extensions/writing-extensions.md +283 -0
  193. package/dist/docs/faq.md +154 -0
  194. package/dist/docs/get-started/authentication.md +321 -0
  195. package/dist/docs/get-started/configuration-v1.md +888 -0
  196. package/dist/docs/get-started/configuration.md +1567 -0
  197. package/dist/docs/get-started/examples.md +219 -0
  198. package/dist/docs/get-started/gemini-3.md +101 -0
  199. package/dist/docs/get-started/index.md +71 -0
  200. package/dist/docs/get-started/installation.md +141 -0
  201. package/dist/docs/hooks/best-practices.md +677 -0
  202. package/dist/docs/hooks/index.md +178 -0
  203. package/dist/docs/hooks/reference.md +322 -0
  204. package/dist/docs/hooks/writing-hooks.md +450 -0
  205. package/dist/docs/ide-integration/ide-companion-spec.md +267 -0
  206. package/dist/docs/ide-integration/index.md +202 -0
  207. package/dist/docs/index.md +153 -0
  208. package/dist/docs/integration-tests.md +211 -0
  209. package/dist/docs/issue-and-pr-automation.md +134 -0
  210. package/dist/docs/local-development.md +128 -0
  211. package/dist/docs/mermaid/context.mmd +103 -0
  212. package/dist/docs/mermaid/render-path.mmd +64 -0
  213. package/dist/docs/migration.md +78 -0
  214. package/dist/docs/npm.md +62 -0
  215. package/dist/docs/providers.md +136 -0
  216. package/dist/docs/quota-and-pricing.md +158 -0
  217. package/dist/docs/release-confidence.md +164 -0
  218. package/dist/docs/releases.md +539 -0
  219. package/dist/docs/sidebar.json +140 -0
  220. package/dist/docs/tools/file-system.md +217 -0
  221. package/dist/docs/tools/index.md +98 -0
  222. package/dist/docs/tools/mcp-server.md +1068 -0
  223. package/dist/docs/tools/memory.md +54 -0
  224. package/dist/docs/tools/shell.md +260 -0
  225. package/dist/docs/tools/todos.md +57 -0
  226. package/dist/docs/tools/web-fetch.md +59 -0
  227. package/dist/docs/tools/web-search.md +42 -0
  228. package/dist/docs/tos-privacy.md +96 -0
  229. package/dist/docs/troubleshooting.md +173 -0
  230. package/dist/index.d.ts +24 -0
  231. package/dist/index.js +24 -0
  232. package/dist/index.js.map +1 -0
  233. package/dist/src/__mocks__/fs/promises.d.ts +11 -0
  234. package/dist/src/__mocks__/fs/promises.js +17 -0
  235. package/dist/src/__mocks__/fs/promises.js.map +1 -0
  236. package/dist/src/agents/a2a-client-manager.d.ts +77 -0
  237. package/dist/src/agents/a2a-client-manager.js +173 -0
  238. package/dist/src/agents/a2a-client-manager.js.map +1 -0
  239. package/dist/src/agents/a2a-client-manager.test.d.ts +6 -0
  240. package/dist/src/agents/a2a-client-manager.test.js +220 -0
  241. package/dist/src/agents/a2a-client-manager.test.js.map +1 -0
  242. package/dist/src/agents/a2aUtils.d.ts +29 -0
  243. package/dist/src/agents/a2aUtils.js +113 -0
  244. package/dist/src/agents/a2aUtils.js.map +1 -0
  245. package/dist/src/agents/a2aUtils.test.d.ts +6 -0
  246. package/dist/src/agents/a2aUtils.test.js +147 -0
  247. package/dist/src/agents/a2aUtils.test.js.map +1 -0
  248. package/dist/src/agents/acknowledgedAgents.d.ts +18 -0
  249. package/dist/src/agents/acknowledgedAgents.js +58 -0
  250. package/dist/src/agents/acknowledgedAgents.js.map +1 -0
  251. package/dist/src/agents/acknowledgedAgents.test.d.ts +6 -0
  252. package/dist/src/agents/acknowledgedAgents.test.js +70 -0
  253. package/dist/src/agents/acknowledgedAgents.test.js.map +1 -0
  254. package/dist/src/agents/agent-scheduler.d.ts +33 -0
  255. package/dist/src/agents/agent-scheduler.js +29 -0
  256. package/dist/src/agents/agent-scheduler.js.map +1 -0
  257. package/dist/src/agents/agent-scheduler.test.d.ts +6 -0
  258. package/dist/src/agents/agent-scheduler.test.js +56 -0
  259. package/dist/src/agents/agent-scheduler.test.js.map +1 -0
  260. package/dist/src/agents/agentLoader.d.ts +73 -0
  261. package/dist/src/agents/agentLoader.js +268 -0
  262. package/dist/src/agents/agentLoader.js.map +1 -0
  263. package/dist/src/agents/agentLoader.test.d.ts +6 -0
  264. package/dist/src/agents/agentLoader.test.js +304 -0
  265. package/dist/src/agents/agentLoader.test.js.map +1 -0
  266. package/dist/src/agents/cli-help-agent.d.ts +24 -0
  267. package/dist/src/agents/cli-help-agent.js +88 -0
  268. package/dist/src/agents/cli-help-agent.js.map +1 -0
  269. package/dist/src/agents/cli-help-agent.test.d.ts +6 -0
  270. package/dist/src/agents/cli-help-agent.test.js +67 -0
  271. package/dist/src/agents/cli-help-agent.test.js.map +1 -0
  272. package/dist/src/agents/codebase-investigator.d.ts +47 -0
  273. package/dist/src/agents/codebase-investigator.js +159 -0
  274. package/dist/src/agents/codebase-investigator.js.map +1 -0
  275. package/dist/src/agents/codebase-investigator.test.d.ts +6 -0
  276. package/dist/src/agents/codebase-investigator.test.js +42 -0
  277. package/dist/src/agents/codebase-investigator.test.js.map +1 -0
  278. package/dist/src/agents/generalist-agent.d.ts +21 -0
  279. package/dist/src/agents/generalist-agent.js +60 -0
  280. package/dist/src/agents/generalist-agent.js.map +1 -0
  281. package/dist/src/agents/generalist-agent.test.d.ts +6 -0
  282. package/dist/src/agents/generalist-agent.test.js +31 -0
  283. package/dist/src/agents/generalist-agent.test.js.map +1 -0
  284. package/dist/src/agents/local-executor.d.ts +111 -0
  285. package/dist/src/agents/local-executor.js +884 -0
  286. package/dist/src/agents/local-executor.js.map +1 -0
  287. package/dist/src/agents/local-executor.test.d.ts +6 -0
  288. package/dist/src/agents/local-executor.test.js +1577 -0
  289. package/dist/src/agents/local-executor.test.js.map +1 -0
  290. package/dist/src/agents/local-invocation.d.ts +45 -0
  291. package/dist/src/agents/local-invocation.js +101 -0
  292. package/dist/src/agents/local-invocation.js.map +1 -0
  293. package/dist/src/agents/local-invocation.test.d.ts +6 -0
  294. package/dist/src/agents/local-invocation.test.js +228 -0
  295. package/dist/src/agents/local-invocation.test.js.map +1 -0
  296. package/dist/src/agents/registry.d.ts +84 -0
  297. package/dist/src/agents/registry.js +346 -0
  298. package/dist/src/agents/registry.js.map +1 -0
  299. package/dist/src/agents/registry.test.d.ts +6 -0
  300. package/dist/src/agents/registry.test.js +773 -0
  301. package/dist/src/agents/registry.test.js.map +1 -0
  302. package/dist/src/agents/registry_acknowledgement.test.d.ts +6 -0
  303. package/dist/src/agents/registry_acknowledgement.test.js +130 -0
  304. package/dist/src/agents/registry_acknowledgement.test.js.map +1 -0
  305. package/dist/src/agents/remote-invocation.d.ts +35 -0
  306. package/dist/src/agents/remote-invocation.js +127 -0
  307. package/dist/src/agents/remote-invocation.js.map +1 -0
  308. package/dist/src/agents/remote-invocation.test.d.ts +6 -0
  309. package/dist/src/agents/remote-invocation.test.js +213 -0
  310. package/dist/src/agents/remote-invocation.test.js.map +1 -0
  311. package/dist/src/agents/subagent-tool-wrapper.d.ts +38 -0
  312. package/dist/src/agents/subagent-tool-wrapper.js +51 -0
  313. package/dist/src/agents/subagent-tool-wrapper.js.map +1 -0
  314. package/dist/src/agents/subagent-tool-wrapper.test.d.ts +6 -0
  315. package/dist/src/agents/subagent-tool-wrapper.test.js +109 -0
  316. package/dist/src/agents/subagent-tool-wrapper.test.js.map +1 -0
  317. package/dist/src/agents/subagent-tool.d.ts +15 -0
  318. package/dist/src/agents/subagent-tool.js +61 -0
  319. package/dist/src/agents/subagent-tool.js.map +1 -0
  320. package/dist/src/agents/types.d.ts +171 -0
  321. package/dist/src/agents/types.js +23 -0
  322. package/dist/src/agents/types.js.map +1 -0
  323. package/dist/src/agents/utils.d.ts +15 -0
  324. package/dist/src/agents/utils.js +29 -0
  325. package/dist/src/agents/utils.js.map +1 -0
  326. package/dist/src/agents/utils.test.d.ts +6 -0
  327. package/dist/src/agents/utils.test.js +87 -0
  328. package/dist/src/agents/utils.test.js.map +1 -0
  329. package/dist/src/availability/errorClassification.d.ts +7 -0
  330. package/dist/src/availability/errorClassification.js +20 -0
  331. package/dist/src/availability/errorClassification.js.map +1 -0
  332. package/dist/src/availability/fallbackIntegration.test.d.ts +6 -0
  333. package/dist/src/availability/fallbackIntegration.test.js +58 -0
  334. package/dist/src/availability/fallbackIntegration.test.js.map +1 -0
  335. package/dist/src/availability/modelAvailabilityService.d.ts +36 -0
  336. package/dist/src/availability/modelAvailabilityService.js +87 -0
  337. package/dist/src/availability/modelAvailabilityService.js.map +1 -0
  338. package/dist/src/availability/modelAvailabilityService.test.d.ts +6 -0
  339. package/dist/src/availability/modelAvailabilityService.test.js +140 -0
  340. package/dist/src/availability/modelAvailabilityService.test.js.map +1 -0
  341. package/dist/src/availability/modelPolicy.d.ts +49 -0
  342. package/dist/src/availability/modelPolicy.js +7 -0
  343. package/dist/src/availability/modelPolicy.js.map +1 -0
  344. package/dist/src/availability/policyCatalog.d.ts +24 -0
  345. package/dist/src/availability/policyCatalog.js +106 -0
  346. package/dist/src/availability/policyCatalog.js.map +1 -0
  347. package/dist/src/availability/policyCatalog.test.d.ts +6 -0
  348. package/dist/src/availability/policyCatalog.test.js +70 -0
  349. package/dist/src/availability/policyCatalog.test.js.map +1 -0
  350. package/dist/src/availability/policyHelpers.d.ts +52 -0
  351. package/dist/src/availability/policyHelpers.js +143 -0
  352. package/dist/src/availability/policyHelpers.js.map +1 -0
  353. package/dist/src/availability/policyHelpers.test.d.ts +6 -0
  354. package/dist/src/availability/policyHelpers.test.js +220 -0
  355. package/dist/src/availability/policyHelpers.test.js.map +1 -0
  356. package/dist/src/availability/testUtils.d.ts +10 -0
  357. package/dist/src/availability/testUtils.js +22 -0
  358. package/dist/src/availability/testUtils.js.map +1 -0
  359. package/dist/src/code_assist/admin/admin_controls.d.ts +23 -0
  360. package/dist/src/code_assist/admin/admin_controls.js +88 -0
  361. package/dist/src/code_assist/admin/admin_controls.js.map +1 -0
  362. package/dist/src/code_assist/admin/admin_controls.test.d.ts +6 -0
  363. package/dist/src/code_assist/admin/admin_controls.test.js +200 -0
  364. package/dist/src/code_assist/admin/admin_controls.test.js.map +1 -0
  365. package/dist/src/code_assist/codeAssist.d.ts +12 -0
  366. package/dist/src/code_assist/codeAssist.js +31 -0
  367. package/dist/src/code_assist/codeAssist.js.map +1 -0
  368. package/dist/src/code_assist/codeAssist.test.d.ts +6 -0
  369. package/dist/src/code_assist/codeAssist.test.js +102 -0
  370. package/dist/src/code_assist/codeAssist.test.js.map +1 -0
  371. package/dist/src/code_assist/converter.d.ts +75 -0
  372. package/dist/src/code_assist/converter.js +161 -0
  373. package/dist/src/code_assist/converter.js.map +1 -0
  374. package/dist/src/code_assist/converter.test.d.ts +6 -0
  375. package/dist/src/code_assist/converter.test.js +391 -0
  376. package/dist/src/code_assist/converter.test.js.map +1 -0
  377. package/dist/src/code_assist/experiments/client_metadata.d.ts +12 -0
  378. package/dist/src/code_assist/experiments/client_metadata.js +51 -0
  379. package/dist/src/code_assist/experiments/client_metadata.js.map +1 -0
  380. package/dist/src/code_assist/experiments/client_metadata.test.d.ts +6 -0
  381. package/dist/src/code_assist/experiments/client_metadata.test.js +96 -0
  382. package/dist/src/code_assist/experiments/client_metadata.test.js.map +1 -0
  383. package/dist/src/code_assist/experiments/experiments.d.ts +17 -0
  384. package/dist/src/code_assist/experiments/experiments.js +57 -0
  385. package/dist/src/code_assist/experiments/experiments.js.map +1 -0
  386. package/dist/src/code_assist/experiments/experiments.test.d.ts +6 -0
  387. package/dist/src/code_assist/experiments/experiments.test.js +93 -0
  388. package/dist/src/code_assist/experiments/experiments.test.js.map +1 -0
  389. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +6 -0
  390. package/dist/src/code_assist/experiments/experiments_local.test.js +115 -0
  391. package/dist/src/code_assist/experiments/experiments_local.test.js.map +1 -0
  392. package/dist/src/code_assist/experiments/flagNames.d.ts +16 -0
  393. package/dist/src/code_assist/experiments/flagNames.js +16 -0
  394. package/dist/src/code_assist/experiments/flagNames.js.map +1 -0
  395. package/dist/src/code_assist/experiments/types.d.ts +35 -0
  396. package/dist/src/code_assist/experiments/types.js +7 -0
  397. package/dist/src/code_assist/experiments/types.js.map +1 -0
  398. package/dist/src/code_assist/oauth-credential-storage.d.ts +25 -0
  399. package/dist/src/code_assist/oauth-credential-storage.js +109 -0
  400. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -0
  401. package/dist/src/code_assist/oauth-credential-storage.test.d.ts +6 -0
  402. package/dist/src/code_assist/oauth-credential-storage.test.js +198 -0
  403. package/dist/src/code_assist/oauth-credential-storage.test.js.map +1 -0
  404. package/dist/src/code_assist/oauth2.d.ts +24 -0
  405. package/dist/src/code_assist/oauth2.js +538 -0
  406. package/dist/src/code_assist/oauth2.js.map +1 -0
  407. package/dist/src/code_assist/oauth2.test.d.ts +6 -0
  408. package/dist/src/code_assist/oauth2.test.js +1065 -0
  409. package/dist/src/code_assist/oauth2.test.js.map +1 -0
  410. package/dist/src/code_assist/server.d.ts +50 -0
  411. package/dist/src/code_assist/server.js +227 -0
  412. package/dist/src/code_assist/server.js.map +1 -0
  413. package/dist/src/code_assist/server.test.d.ts +6 -0
  414. package/dist/src/code_assist/server.test.js +453 -0
  415. package/dist/src/code_assist/server.test.js.map +1 -0
  416. package/dist/src/code_assist/setup.d.ts +46 -0
  417. package/dist/src/code_assist/setup.js +179 -0
  418. package/dist/src/code_assist/setup.js.map +1 -0
  419. package/dist/src/code_assist/setup.test.d.ts +6 -0
  420. package/dist/src/code_assist/setup.test.js +517 -0
  421. package/dist/src/code_assist/setup.test.js.map +1 -0
  422. package/dist/src/code_assist/telemetry.d.ts +14 -0
  423. package/dist/src/code_assist/telemetry.js +157 -0
  424. package/dist/src/code_assist/telemetry.js.map +1 -0
  425. package/dist/src/code_assist/telemetry.test.d.ts +6 -0
  426. package/dist/src/code_assist/telemetry.test.js +301 -0
  427. package/dist/src/code_assist/telemetry.test.js.map +1 -0
  428. package/dist/src/code_assist/types.d.ts +303 -0
  429. package/dist/src/code_assist/types.js +92 -0
  430. package/dist/src/code_assist/types.js.map +1 -0
  431. package/dist/src/commands/extensions.d.ts +7 -0
  432. package/dist/src/commands/extensions.js +9 -0
  433. package/dist/src/commands/extensions.js.map +1 -0
  434. package/dist/src/commands/extensions.test.d.ts +6 -0
  435. package/dist/src/commands/extensions.test.js +19 -0
  436. package/dist/src/commands/extensions.test.js.map +1 -0
  437. package/dist/src/commands/init.d.ts +7 -0
  438. package/dist/src/commands/init.js +54 -0
  439. package/dist/src/commands/init.js.map +1 -0
  440. package/dist/src/commands/init.test.d.ts +6 -0
  441. package/dist/src/commands/init.test.js +25 -0
  442. package/dist/src/commands/init.test.js.map +1 -0
  443. package/dist/src/commands/memory.d.ts +11 -0
  444. package/dist/src/commands/memory.js +89 -0
  445. package/dist/src/commands/memory.js.map +1 -0
  446. package/dist/src/commands/memory.test.d.ts +6 -0
  447. package/dist/src/commands/memory.test.js +182 -0
  448. package/dist/src/commands/memory.test.js.map +1 -0
  449. package/dist/src/commands/restore.d.ts +9 -0
  450. package/dist/src/commands/restore.js +46 -0
  451. package/dist/src/commands/restore.js.map +1 -0
  452. package/dist/src/commands/restore.test.d.ts +6 -0
  453. package/dist/src/commands/restore.test.js +137 -0
  454. package/dist/src/commands/restore.test.js.map +1 -0
  455. package/dist/src/commands/types.d.ts +41 -0
  456. package/dist/src/commands/types.js +7 -0
  457. package/dist/src/commands/types.js.map +1 -0
  458. package/dist/src/config/config.d.ts +696 -0
  459. package/dist/src/config/config.js +1567 -0
  460. package/dist/src/config/config.js.map +1 -0
  461. package/dist/src/config/config.test.d.ts +6 -0
  462. package/dist/src/config/config.test.js +1811 -0
  463. package/dist/src/config/config.test.js.map +1 -0
  464. package/dist/src/config/constants.d.ts +13 -0
  465. package/dist/src/config/constants.js +20 -0
  466. package/dist/src/config/constants.js.map +1 -0
  467. package/dist/src/config/defaultModelConfigs.d.ts +7 -0
  468. package/dist/src/config/defaultModelConfigs.js +231 -0
  469. package/dist/src/config/defaultModelConfigs.js.map +1 -0
  470. package/dist/src/config/flashFallback.test.d.ts +6 -0
  471. package/dist/src/config/flashFallback.test.js +63 -0
  472. package/dist/src/config/flashFallback.test.js.map +1 -0
  473. package/dist/src/config/models.d.ts +67 -0
  474. package/dist/src/config/models.js +144 -0
  475. package/dist/src/config/models.js.map +1 -0
  476. package/dist/src/config/models.test.d.ts +6 -0
  477. package/dist/src/config/models.test.js +146 -0
  478. package/dist/src/config/models.test.js.map +1 -0
  479. package/dist/src/config/storage.d.ts +44 -0
  480. package/dist/src/config/storage.js +139 -0
  481. package/dist/src/config/storage.js.map +1 -0
  482. package/dist/src/config/storage.test.d.ts +6 -0
  483. package/dist/src/config/storage.test.js +115 -0
  484. package/dist/src/config/storage.test.js.map +1 -0
  485. package/dist/src/confirmation-bus/index.d.ts +7 -0
  486. package/dist/src/confirmation-bus/index.js +8 -0
  487. package/dist/src/confirmation-bus/index.js.map +1 -0
  488. package/dist/src/confirmation-bus/message-bus.d.ts +24 -0
  489. package/dist/src/confirmation-bus/message-bus.js +120 -0
  490. package/dist/src/confirmation-bus/message-bus.js.map +1 -0
  491. package/dist/src/confirmation-bus/message-bus.test.d.ts +6 -0
  492. package/dist/src/confirmation-bus/message-bus.test.js +170 -0
  493. package/dist/src/confirmation-bus/message-bus.test.js.map +1 -0
  494. package/dist/src/confirmation-bus/types.d.ts +141 -0
  495. package/dist/src/confirmation-bus/types.js +25 -0
  496. package/dist/src/confirmation-bus/types.js.map +1 -0
  497. package/dist/src/core/apiKeyCredentialStorage.d.ts +17 -0
  498. package/dist/src/core/apiKeyCredentialStorage.js +64 -0
  499. package/dist/src/core/apiKeyCredentialStorage.js.map +1 -0
  500. package/dist/src/core/apiKeyCredentialStorage.test.d.ts +6 -0
  501. package/dist/src/core/apiKeyCredentialStorage.test.js +71 -0
  502. package/dist/src/core/apiKeyCredentialStorage.test.js.map +1 -0
  503. package/dist/src/core/baseLlmClient.d.ts +131 -0
  504. package/dist/src/core/baseLlmClient.js +282 -0
  505. package/dist/src/core/baseLlmClient.js.map +1 -0
  506. package/dist/src/core/baseLlmClient.test.d.ts +6 -0
  507. package/dist/src/core/baseLlmClient.test.js +569 -0
  508. package/dist/src/core/baseLlmClient.test.js.map +1 -0
  509. package/dist/src/core/baseLlmClient_new_types.test.d.ts +1 -0
  510. package/dist/src/core/baseLlmClient_new_types.test.js +387 -0
  511. package/dist/src/core/baseLlmClient_new_types.test.js.map +1 -0
  512. package/dist/src/core/client.d.ts +71 -0
  513. package/dist/src/core/client.js +882 -0
  514. package/dist/src/core/client.js.map +1 -0
  515. package/dist/src/core/client.test.d.ts +6 -0
  516. package/dist/src/core/client.test.js +2654 -0
  517. package/dist/src/core/client.test.js.map +1 -0
  518. package/dist/src/core/contentGenerator.d.ts +55 -0
  519. package/dist/src/core/contentGenerator.js +201 -0
  520. package/dist/src/core/contentGenerator.js.map +1 -0
  521. package/dist/src/core/contentGenerator.multiProvider.test.d.ts +6 -0
  522. package/dist/src/core/contentGenerator.multiProvider.test.js +314 -0
  523. package/dist/src/core/contentGenerator.multiProvider.test.js.map +1 -0
  524. package/dist/src/core/contentGenerator.test.d.ts +6 -0
  525. package/dist/src/core/contentGenerator.test.js +299 -0
  526. package/dist/src/core/contentGenerator.test.js.map +1 -0
  527. package/dist/src/core/contentGenerator_new_types.test.d.ts +6 -0
  528. package/dist/src/core/contentGenerator_new_types.test.js +292 -0
  529. package/dist/src/core/contentGenerator_new_types.test.js.map +1 -0
  530. package/dist/src/core/coreToolHookTriggers.d.ts +23 -0
  531. package/dist/src/core/coreToolHookTriggers.js +195 -0
  532. package/dist/src/core/coreToolHookTriggers.js.map +1 -0
  533. package/dist/src/core/coreToolHookTriggers.test.d.ts +6 -0
  534. package/dist/src/core/coreToolHookTriggers.test.js +159 -0
  535. package/dist/src/core/coreToolHookTriggers.test.js.map +1 -0
  536. package/dist/src/core/coreToolScheduler.d.ts +50 -0
  537. package/dist/src/core/coreToolScheduler.js +703 -0
  538. package/dist/src/core/coreToolScheduler.js.map +1 -0
  539. package/dist/src/core/coreToolScheduler.test.d.ts +6 -0
  540. package/dist/src/core/coreToolScheduler.test.js +1684 -0
  541. package/dist/src/core/coreToolScheduler.test.js.map +1 -0
  542. package/dist/src/core/fakeContentGenerator.d.ts +49 -0
  543. package/dist/src/core/fakeContentGenerator.js +76 -0
  544. package/dist/src/core/fakeContentGenerator.js.map +1 -0
  545. package/dist/src/core/fakeContentGenerator.test.d.ts +6 -0
  546. package/dist/src/core/fakeContentGenerator.test.js +127 -0
  547. package/dist/src/core/fakeContentGenerator.test.js.map +1 -0
  548. package/dist/src/core/geminiChat.d.ts +11 -0
  549. package/dist/src/core/geminiChat.js +12 -0
  550. package/dist/src/core/geminiChat.js.map +1 -0
  551. package/dist/src/core/geminiChat.test.d.ts +6 -0
  552. package/dist/src/core/geminiChat.test.js +1773 -0
  553. package/dist/src/core/geminiChat.test.js.map +1 -0
  554. package/dist/src/core/geminiChat_network_retry.test.d.ts +6 -0
  555. package/dist/src/core/geminiChat_network_retry.test.js +201 -0
  556. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -0
  557. package/dist/src/core/geminiRequest.d.ts +13 -0
  558. package/dist/src/core/geminiRequest.js +11 -0
  559. package/dist/src/core/geminiRequest.js.map +1 -0
  560. package/dist/src/core/logger.d.ts +65 -0
  561. package/dist/src/core/logger.js +368 -0
  562. package/dist/src/core/logger.js.map +1 -0
  563. package/dist/src/core/logger.test.d.ts +6 -0
  564. package/dist/src/core/logger.test.js +550 -0
  565. package/dist/src/core/logger.test.js.map +1 -0
  566. package/dist/src/core/loggingContentGenerator.d.ts +35 -0
  567. package/dist/src/core/loggingContentGenerator.js +254 -0
  568. package/dist/src/core/loggingContentGenerator.js.map +1 -0
  569. package/dist/src/core/loggingContentGenerator.test.d.ts +6 -0
  570. package/dist/src/core/loggingContentGenerator.test.js +221 -0
  571. package/dist/src/core/loggingContentGenerator.test.js.map +1 -0
  572. package/dist/src/core/prompts-substitution.test.d.ts +6 -0
  573. package/dist/src/core/prompts-substitution.test.js +101 -0
  574. package/dist/src/core/prompts-substitution.test.js.map +1 -0
  575. package/dist/src/core/prompts.d.ts +18 -0
  576. package/dist/src/core/prompts.js +522 -0
  577. package/dist/src/core/prompts.js.map +1 -0
  578. package/dist/src/core/prompts.test.d.ts +6 -0
  579. package/dist/src/core/prompts.test.js +391 -0
  580. package/dist/src/core/prompts.test.js.map +1 -0
  581. package/dist/src/core/recordingContentGenerator.d.ts +25 -0
  582. package/dist/src/core/recordingContentGenerator.js +138 -0
  583. package/dist/src/core/recordingContentGenerator.js.map +1 -0
  584. package/dist/src/core/recordingContentGenerator.test.d.ts +6 -0
  585. package/dist/src/core/recordingContentGenerator.test.js +101 -0
  586. package/dist/src/core/recordingContentGenerator.test.js.map +1 -0
  587. package/dist/src/core/tokenLimits.d.ts +10 -0
  588. package/dist/src/core/tokenLimits.js +22 -0
  589. package/dist/src/core/tokenLimits.js.map +1 -0
  590. package/dist/src/core/tokenLimits.test.d.ts +6 -0
  591. package/dist/src/core/tokenLimits.test.js +30 -0
  592. package/dist/src/core/tokenLimits.test.js.map +1 -0
  593. package/dist/src/core/turn.d.ts +11 -0
  594. package/dist/src/core/turn.js +18 -0
  595. package/dist/src/core/turn.js.map +1 -0
  596. package/dist/src/core/turn.test.d.ts +6 -0
  597. package/dist/src/core/turn.test.js +739 -0
  598. package/dist/src/core/turn.test.js.map +1 -0
  599. package/dist/src/fallback/handler.d.ts +7 -0
  600. package/dist/src/fallback/handler.js +110 -0
  601. package/dist/src/fallback/handler.js.map +1 -0
  602. package/dist/src/fallback/handler.test.d.ts +6 -0
  603. package/dist/src/fallback/handler.test.js +242 -0
  604. package/dist/src/fallback/handler.test.js.map +1 -0
  605. package/dist/src/fallback/types.d.ts +31 -0
  606. package/dist/src/fallback/types.js +7 -0
  607. package/dist/src/fallback/types.js.map +1 -0
  608. package/dist/src/generated/git-commit.d.ts +7 -0
  609. package/dist/src/generated/git-commit.js +10 -0
  610. package/dist/src/generated/git-commit.js.map +1 -0
  611. package/dist/src/hooks/hookAggregator.d.ts +68 -0
  612. package/dist/src/hooks/hookAggregator.js +279 -0
  613. package/dist/src/hooks/hookAggregator.js.map +1 -0
  614. package/dist/src/hooks/hookAggregator.test.d.ts +6 -0
  615. package/dist/src/hooks/hookAggregator.test.js +387 -0
  616. package/dist/src/hooks/hookAggregator.test.js.map +1 -0
  617. package/dist/src/hooks/hookEventHandler.d.ts +120 -0
  618. package/dist/src/hooks/hookEventHandler.js +339 -0
  619. package/dist/src/hooks/hookEventHandler.js.map +1 -0
  620. package/dist/src/hooks/hookEventHandler.test.d.ts +6 -0
  621. package/dist/src/hooks/hookEventHandler.test.js +603 -0
  622. package/dist/src/hooks/hookEventHandler.test.js.map +1 -0
  623. package/dist/src/hooks/hookPlanner.d.ts +42 -0
  624. package/dist/src/hooks/hookPlanner.js +103 -0
  625. package/dist/src/hooks/hookPlanner.js.map +1 -0
  626. package/dist/src/hooks/hookPlanner.test.d.ts +6 -0
  627. package/dist/src/hooks/hookPlanner.test.js +315 -0
  628. package/dist/src/hooks/hookPlanner.test.js.map +1 -0
  629. package/dist/src/hooks/hookRegistry.d.ts +75 -0
  630. package/dist/src/hooks/hookRegistry.js +215 -0
  631. package/dist/src/hooks/hookRegistry.js.map +1 -0
  632. package/dist/src/hooks/hookRegistry.test.d.ts +6 -0
  633. package/dist/src/hooks/hookRegistry.test.js +529 -0
  634. package/dist/src/hooks/hookRegistry.test.js.map +1 -0
  635. package/dist/src/hooks/hookRunner.d.ts +44 -0
  636. package/dist/src/hooks/hookRunner.js +328 -0
  637. package/dist/src/hooks/hookRunner.js.map +1 -0
  638. package/dist/src/hooks/hookRunner.test.d.ts +6 -0
  639. package/dist/src/hooks/hookRunner.test.js +606 -0
  640. package/dist/src/hooks/hookRunner.test.js.map +1 -0
  641. package/dist/src/hooks/hookSystem.d.ts +110 -0
  642. package/dist/src/hooks/hookSystem.js +311 -0
  643. package/dist/src/hooks/hookSystem.js.map +1 -0
  644. package/dist/src/hooks/hookSystem.test.d.ts +6 -0
  645. package/dist/src/hooks/hookSystem.test.js +330 -0
  646. package/dist/src/hooks/hookSystem.test.js.map +1 -0
  647. package/dist/src/hooks/hookSystem_new_types.test.d.ts +6 -0
  648. package/dist/src/hooks/hookSystem_new_types.test.js +243 -0
  649. package/dist/src/hooks/hookSystem_new_types.test.js.map +1 -0
  650. package/dist/src/hooks/hookTranslator.d.ts +113 -0
  651. package/dist/src/hooks/hookTranslator.js +233 -0
  652. package/dist/src/hooks/hookTranslator.js.map +1 -0
  653. package/dist/src/hooks/hookTranslator.test.d.ts +6 -0
  654. package/dist/src/hooks/hookTranslator.test.js +192 -0
  655. package/dist/src/hooks/hookTranslator.test.js.map +1 -0
  656. package/dist/src/hooks/index.d.ts +16 -0
  657. package/dist/src/hooks/index.js +16 -0
  658. package/dist/src/hooks/index.js.map +1 -0
  659. package/dist/src/hooks/trustedHooks.d.ts +28 -0
  660. package/dist/src/hooks/trustedHooks.js +90 -0
  661. package/dist/src/hooks/trustedHooks.js.map +1 -0
  662. package/dist/src/hooks/trustedHooks.test.d.ts +6 -0
  663. package/dist/src/hooks/trustedHooks.test.js +154 -0
  664. package/dist/src/hooks/trustedHooks.test.js.map +1 -0
  665. package/dist/src/hooks/types.d.ts +462 -0
  666. package/dist/src/hooks/types.js +363 -0
  667. package/dist/src/hooks/types.js.map +1 -0
  668. package/dist/src/hooks/types.test.d.ts +6 -0
  669. package/dist/src/hooks/types.test.js +278 -0
  670. package/dist/src/hooks/types.test.js.map +1 -0
  671. package/dist/src/ide/constants.d.ts +9 -0
  672. package/dist/src/ide/constants.js +10 -0
  673. package/dist/src/ide/constants.js.map +1 -0
  674. package/dist/src/ide/detect-ide.d.ts +105 -0
  675. package/dist/src/ide/detect-ide.js +121 -0
  676. package/dist/src/ide/detect-ide.js.map +1 -0
  677. package/dist/src/ide/detect-ide.test.d.ts +6 -0
  678. package/dist/src/ide/detect-ide.test.js +195 -0
  679. package/dist/src/ide/detect-ide.test.js.map +1 -0
  680. package/dist/src/ide/ide-client.d.ts +113 -0
  681. package/dist/src/ide/ide-client.js +669 -0
  682. package/dist/src/ide/ide-client.js.map +1 -0
  683. package/dist/src/ide/ide-client.test.d.ts +6 -0
  684. package/dist/src/ide/ide-client.test.js +753 -0
  685. package/dist/src/ide/ide-client.test.js.map +1 -0
  686. package/dist/src/ide/ide-installer.d.ts +14 -0
  687. package/dist/src/ide/ide-installer.js +156 -0
  688. package/dist/src/ide/ide-installer.js.map +1 -0
  689. package/dist/src/ide/ide-installer.test.d.ts +6 -0
  690. package/dist/src/ide/ide-installer.test.js +193 -0
  691. package/dist/src/ide/ide-installer.test.js.map +1 -0
  692. package/dist/src/ide/ideContext.d.ts +44 -0
  693. package/dist/src/ide/ideContext.js +101 -0
  694. package/dist/src/ide/ideContext.js.map +1 -0
  695. package/dist/src/ide/ideContext.test.d.ts +6 -0
  696. package/dist/src/ide/ideContext.test.js +393 -0
  697. package/dist/src/ide/ideContext.test.js.map +1 -0
  698. package/dist/src/ide/process-utils.d.ts +21 -0
  699. package/dist/src/ide/process-utils.js +181 -0
  700. package/dist/src/ide/process-utils.js.map +1 -0
  701. package/dist/src/ide/process-utils.test.d.ts +6 -0
  702. package/dist/src/ide/process-utils.test.js +151 -0
  703. package/dist/src/ide/process-utils.test.js.map +1 -0
  704. package/dist/src/ide/types.d.ts +486 -0
  705. package/dist/src/ide/types.js +138 -0
  706. package/dist/src/ide/types.js.map +1 -0
  707. package/dist/src/index.d.ts +142 -0
  708. package/dist/src/index.js +157 -0
  709. package/dist/src/index.js.map +1 -0
  710. package/dist/src/index.test.d.ts +6 -0
  711. package/dist/src/index.test.js +53 -0
  712. package/dist/src/index.test.js.map +1 -0
  713. package/dist/src/mcp/auth-provider.d.ts +16 -0
  714. package/dist/src/mcp/auth-provider.js +7 -0
  715. package/dist/src/mcp/auth-provider.js.map +1 -0
  716. package/dist/src/mcp/google-auth-provider.d.ts +33 -0
  717. package/dist/src/mcp/google-auth-provider.js +118 -0
  718. package/dist/src/mcp/google-auth-provider.js.map +1 -0
  719. package/dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  720. package/dist/src/mcp/google-auth-provider.test.js +167 -0
  721. package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
  722. package/dist/src/mcp/oauth-provider.d.ts +160 -0
  723. package/dist/src/mcp/oauth-provider.js +729 -0
  724. package/dist/src/mcp/oauth-provider.js.map +1 -0
  725. package/dist/src/mcp/oauth-provider.test.d.ts +6 -0
  726. package/dist/src/mcp/oauth-provider.test.js +1355 -0
  727. package/dist/src/mcp/oauth-provider.test.js.map +1 -0
  728. package/dist/src/mcp/oauth-token-storage.d.ts +65 -0
  729. package/dist/src/mcp/oauth-token-storage.js +181 -0
  730. package/dist/src/mcp/oauth-token-storage.js.map +1 -0
  731. package/dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  732. package/dist/src/mcp/oauth-token-storage.test.js +305 -0
  733. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  734. package/dist/src/mcp/oauth-utils.d.ts +142 -0
  735. package/dist/src/mcp/oauth-utils.js +289 -0
  736. package/dist/src/mcp/oauth-utils.js.map +1 -0
  737. package/dist/src/mcp/oauth-utils.test.d.ts +6 -0
  738. package/dist/src/mcp/oauth-utils.test.js +289 -0
  739. package/dist/src/mcp/oauth-utils.test.js.map +1 -0
  740. package/dist/src/mcp/sa-impersonation-provider.d.ts +27 -0
  741. package/dist/src/mcp/sa-impersonation-provider.js +113 -0
  742. package/dist/src/mcp/sa-impersonation-provider.js.map +1 -0
  743. package/dist/src/mcp/sa-impersonation-provider.test.d.ts +6 -0
  744. package/dist/src/mcp/sa-impersonation-provider.test.js +117 -0
  745. package/dist/src/mcp/sa-impersonation-provider.test.js.map +1 -0
  746. package/dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  747. package/dist/src/mcp/token-storage/base-token-storage.js +36 -0
  748. package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  749. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  750. package/dist/src/mcp/token-storage/base-token-storage.test.js +151 -0
  751. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  752. package/dist/src/mcp/token-storage/file-token-storage.d.ts +24 -0
  753. package/dist/src/mcp/token-storage/file-token-storage.js +145 -0
  754. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -0
  755. package/dist/src/mcp/token-storage/file-token-storage.test.d.ts +6 -0
  756. package/dist/src/mcp/token-storage/file-token-storage.test.js +238 -0
  757. package/dist/src/mcp/token-storage/file-token-storage.test.js.map +1 -0
  758. package/dist/src/mcp/token-storage/hybrid-token-storage.d.ts +23 -0
  759. package/dist/src/mcp/token-storage/hybrid-token-storage.js +78 -0
  760. package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -0
  761. package/dist/src/mcp/token-storage/hybrid-token-storage.test.d.ts +6 -0
  762. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js +193 -0
  763. package/dist/src/mcp/token-storage/hybrid-token-storage.test.js.map +1 -0
  764. package/dist/src/mcp/token-storage/index.d.ts +11 -0
  765. package/dist/src/mcp/token-storage/index.js +12 -0
  766. package/dist/src/mcp/token-storage/index.js.map +1 -0
  767. package/dist/src/mcp/token-storage/keychain-token-storage.d.ts +35 -0
  768. package/dist/src/mcp/token-storage/keychain-token-storage.js +246 -0
  769. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -0
  770. package/dist/src/mcp/token-storage/keychain-token-storage.test.d.ts +6 -0
  771. package/dist/src/mcp/token-storage/keychain-token-storage.test.js +305 -0
  772. package/dist/src/mcp/token-storage/keychain-token-storage.test.js.map +1 -0
  773. package/dist/src/mcp/token-storage/types.d.ts +44 -0
  774. package/dist/src/mcp/token-storage/types.js +11 -0
  775. package/dist/src/mcp/token-storage/types.js.map +1 -0
  776. package/dist/src/mocks/msw.d.ts +6 -0
  777. package/dist/src/mocks/msw.js +8 -0
  778. package/dist/src/mocks/msw.js.map +1 -0
  779. package/dist/src/output/json-formatter.d.ts +11 -0
  780. package/dist/src/output/json-formatter.js +33 -0
  781. package/dist/src/output/json-formatter.js.map +1 -0
  782. package/dist/src/output/json-formatter.test.d.ts +6 -0
  783. package/dist/src/output/json-formatter.test.js +294 -0
  784. package/dist/src/output/json-formatter.test.js.map +1 -0
  785. package/dist/src/output/stream-json-formatter.d.ts +32 -0
  786. package/dist/src/output/stream-json-formatter.js +58 -0
  787. package/dist/src/output/stream-json-formatter.js.map +1 -0
  788. package/dist/src/output/stream-json-formatter.test.d.ts +6 -0
  789. package/dist/src/output/stream-json-formatter.test.js +477 -0
  790. package/dist/src/output/stream-json-formatter.test.js.map +1 -0
  791. package/dist/src/output/types.d.ts +85 -0
  792. package/dist/src/output/types.js +22 -0
  793. package/dist/src/output/types.js.map +1 -0
  794. package/dist/src/policy/config.d.ts +31 -0
  795. package/dist/src/policy/config.js +355 -0
  796. package/dist/src/policy/config.js.map +1 -0
  797. package/dist/src/policy/config.test.d.ts +6 -0
  798. package/dist/src/policy/config.test.js +598 -0
  799. package/dist/src/policy/config.test.js.map +1 -0
  800. package/dist/src/policy/index.d.ts +9 -0
  801. package/dist/src/policy/index.js +10 -0
  802. package/dist/src/policy/index.js.map +1 -0
  803. package/dist/src/policy/persistence.test.d.ts +6 -0
  804. package/dist/src/policy/persistence.test.js +154 -0
  805. package/dist/src/policy/persistence.test.js.map +1 -0
  806. package/dist/src/policy/policies/agent.toml +31 -0
  807. package/dist/src/policy/policies/discovered.toml +8 -0
  808. package/dist/src/policy/policies/plan.toml +73 -0
  809. package/dist/src/policy/policies/read-only.toml +56 -0
  810. package/dist/src/policy/policies/write.toml +78 -0
  811. package/dist/src/policy/policies/yolo.toml +32 -0
  812. package/dist/src/policy/policy-engine.d.ts +59 -0
  813. package/dist/src/policy/policy-engine.js +336 -0
  814. package/dist/src/policy/policy-engine.js.map +1 -0
  815. package/dist/src/policy/policy-engine.test.d.ts +6 -0
  816. package/dist/src/policy/policy-engine.test.js +1299 -0
  817. package/dist/src/policy/policy-engine.test.js.map +1 -0
  818. package/dist/src/policy/policy-updater.test.d.ts +6 -0
  819. package/dist/src/policy/policy-updater.test.js +116 -0
  820. package/dist/src/policy/policy-updater.test.js.map +1 -0
  821. package/dist/src/policy/shell-safety.test.d.ts +6 -0
  822. package/dist/src/policy/shell-safety.test.js +438 -0
  823. package/dist/src/policy/shell-safety.test.js.map +1 -0
  824. package/dist/src/policy/stable-stringify.d.ts +58 -0
  825. package/dist/src/policy/stable-stringify.js +122 -0
  826. package/dist/src/policy/stable-stringify.js.map +1 -0
  827. package/dist/src/policy/toml-loader.d.ts +45 -0
  828. package/dist/src/policy/toml-loader.js +364 -0
  829. package/dist/src/policy/toml-loader.js.map +1 -0
  830. package/dist/src/policy/toml-loader.test.d.ts +6 -0
  831. package/dist/src/policy/toml-loader.test.js +409 -0
  832. package/dist/src/policy/toml-loader.test.js.map +1 -0
  833. package/dist/src/policy/types.d.ts +215 -0
  834. package/dist/src/policy/types.js +44 -0
  835. package/dist/src/policy/types.js.map +1 -0
  836. package/dist/src/policy/utils.d.ts +21 -0
  837. package/dist/src/policy/utils.js +45 -0
  838. package/dist/src/policy/utils.js.map +1 -0
  839. package/dist/src/policy/utils.test.d.ts +6 -0
  840. package/dist/src/policy/utils.test.js +92 -0
  841. package/dist/src/policy/utils.test.js.map +1 -0
  842. package/dist/src/prompts/mcp-prompts.d.ts +8 -0
  843. package/dist/src/prompts/mcp-prompts.js +13 -0
  844. package/dist/src/prompts/mcp-prompts.js.map +1 -0
  845. package/dist/src/prompts/mcp-prompts.test.d.ts +6 -0
  846. package/dist/src/prompts/mcp-prompts.test.js +39 -0
  847. package/dist/src/prompts/mcp-prompts.test.js.map +1 -0
  848. package/dist/src/prompts/prompt-registry.d.ts +34 -0
  849. package/dist/src/prompts/prompt-registry.js +64 -0
  850. package/dist/src/prompts/prompt-registry.js.map +1 -0
  851. package/dist/src/prompts/prompt-registry.test.d.ts +6 -0
  852. package/dist/src/prompts/prompt-registry.test.js +96 -0
  853. package/dist/src/prompts/prompt-registry.test.js.map +1 -0
  854. package/dist/src/providers/__tests__/bundleSize.test.d.ts +6 -0
  855. package/dist/src/providers/__tests__/bundleSize.test.js +75 -0
  856. package/dist/src/providers/__tests__/bundleSize.test.js.map +1 -0
  857. package/dist/src/providers/__tests__/errorHandling.integration.test.d.ts +6 -0
  858. package/dist/src/providers/__tests__/errorHandling.integration.test.js +339 -0
  859. package/dist/src/providers/__tests__/errorHandling.integration.test.js.map +1 -0
  860. package/dist/src/providers/__tests__/multiProvider.integration.test.d.ts +6 -0
  861. package/dist/src/providers/__tests__/multiProvider.integration.test.js +419 -0
  862. package/dist/src/providers/__tests__/multiProvider.integration.test.js.map +1 -0
  863. package/dist/src/providers/__tests__/performance.test.d.ts +6 -0
  864. package/dist/src/providers/__tests__/performance.test.js +270 -0
  865. package/dist/src/providers/__tests__/performance.test.js.map +1 -0
  866. package/dist/src/providers/__tests__/providerConfigIntegration.test.d.ts +6 -0
  867. package/dist/src/providers/__tests__/providerConfigIntegration.test.js +245 -0
  868. package/dist/src/providers/__tests__/providerConfigIntegration.test.js.map +1 -0
  869. package/dist/src/providers/baseAdapter.d.ts +61 -0
  870. package/dist/src/providers/baseAdapter.js +77 -0
  871. package/dist/src/providers/baseAdapter.js.map +1 -0
  872. package/dist/src/providers/baseAdapter.test.d.ts +1 -0
  873. package/dist/src/providers/baseAdapter.test.js +142 -0
  874. package/dist/src/providers/baseAdapter.test.js.map +1 -0
  875. package/dist/src/providers/claude/adapter.d.ts +58 -0
  876. package/dist/src/providers/claude/adapter.js +184 -0
  877. package/dist/src/providers/claude/adapter.js.map +1 -0
  878. package/dist/src/providers/claude/adapter.test.d.ts +6 -0
  879. package/dist/src/providers/claude/adapter.test.js +628 -0
  880. package/dist/src/providers/claude/adapter.test.js.map +1 -0
  881. package/dist/src/providers/claude/bootstrap.d.ts +15 -0
  882. package/dist/src/providers/claude/bootstrap.js +38 -0
  883. package/dist/src/providers/claude/bootstrap.js.map +1 -0
  884. package/dist/src/providers/claude/bootstrap.test.d.ts +6 -0
  885. package/dist/src/providers/claude/bootstrap.test.js +74 -0
  886. package/dist/src/providers/claude/bootstrap.test.js.map +1 -0
  887. package/dist/src/providers/claude/converter.d.ts +92 -0
  888. package/dist/src/providers/claude/converter.js +427 -0
  889. package/dist/src/providers/claude/converter.js.map +1 -0
  890. package/dist/src/providers/claude/converter.test.d.ts +6 -0
  891. package/dist/src/providers/claude/converter.test.js +1002 -0
  892. package/dist/src/providers/claude/converter.test.js.map +1 -0
  893. package/dist/src/providers/claude/exports.test.d.ts +6 -0
  894. package/dist/src/providers/claude/exports.test.js +40 -0
  895. package/dist/src/providers/claude/exports.test.js.map +1 -0
  896. package/dist/src/providers/claude/index.d.ts +13 -0
  897. package/dist/src/providers/claude/index.js +14 -0
  898. package/dist/src/providers/claude/index.js.map +1 -0
  899. package/dist/src/providers/configAdapter.d.ts +106 -0
  900. package/dist/src/providers/configAdapter.js +139 -0
  901. package/dist/src/providers/configAdapter.js.map +1 -0
  902. package/dist/src/providers/configAdapter.test.d.ts +1 -0
  903. package/dist/src/providers/configAdapter.test.js +150 -0
  904. package/dist/src/providers/configAdapter.test.js.map +1 -0
  905. package/dist/src/providers/contentResolver.d.ts +93 -0
  906. package/dist/src/providers/contentResolver.js +152 -0
  907. package/dist/src/providers/contentResolver.js.map +1 -0
  908. package/dist/src/providers/contentResolver.test.d.ts +1 -0
  909. package/dist/src/providers/contentResolver.test.js +89 -0
  910. package/dist/src/providers/contentResolver.test.js.map +1 -0
  911. package/dist/src/providers/errors.d.ts +145 -0
  912. package/dist/src/providers/errors.js +255 -0
  913. package/dist/src/providers/errors.js.map +1 -0
  914. package/dist/src/providers/events.d.ts +294 -0
  915. package/dist/src/providers/events.js +128 -0
  916. package/dist/src/providers/events.js.map +1 -0
  917. package/dist/src/providers/factory.d.ts +103 -0
  918. package/dist/src/providers/factory.js +123 -0
  919. package/dist/src/providers/factory.js.map +1 -0
  920. package/dist/src/providers/factory.test.d.ts +1 -0
  921. package/dist/src/providers/factory.test.js +151 -0
  922. package/dist/src/providers/factory.test.js.map +1 -0
  923. package/dist/src/providers/gemini/adapter.d.ts +59 -0
  924. package/dist/src/providers/gemini/adapter.js +135 -0
  925. package/dist/src/providers/gemini/adapter.js.map +1 -0
  926. package/dist/src/providers/gemini/adapterBridge.d.ts +31 -0
  927. package/dist/src/providers/gemini/adapterBridge.js +40 -0
  928. package/dist/src/providers/gemini/adapterBridge.js.map +1 -0
  929. package/dist/src/providers/gemini/adapterBridge.test.d.ts +6 -0
  930. package/dist/src/providers/gemini/adapterBridge.test.js +164 -0
  931. package/dist/src/providers/gemini/adapterBridge.test.js.map +1 -0
  932. package/dist/src/providers/gemini/bootstrap.d.ts +15 -0
  933. package/dist/src/providers/gemini/bootstrap.js +39 -0
  934. package/dist/src/providers/gemini/bootstrap.js.map +1 -0
  935. package/dist/src/providers/gemini/bootstrap.test.d.ts +6 -0
  936. package/dist/src/providers/gemini/bootstrap.test.js +72 -0
  937. package/dist/src/providers/gemini/bootstrap.test.js.map +1 -0
  938. package/dist/src/providers/gemini/chat.d.ts +173 -0
  939. package/dist/src/providers/gemini/chat.js +747 -0
  940. package/dist/src/providers/gemini/chat.js.map +1 -0
  941. package/dist/src/providers/gemini/configConverter.d.ts +38 -0
  942. package/dist/src/providers/gemini/configConverter.js +166 -0
  943. package/dist/src/providers/gemini/configConverter.js.map +1 -0
  944. package/dist/src/providers/gemini/configConverter.test.d.ts +6 -0
  945. package/dist/src/providers/gemini/configConverter.test.js +218 -0
  946. package/dist/src/providers/gemini/configConverter.test.js.map +1 -0
  947. package/dist/src/providers/gemini/converter.d.ts +66 -0
  948. package/dist/src/providers/gemini/converter.js +270 -0
  949. package/dist/src/providers/gemini/converter.js.map +1 -0
  950. package/dist/src/providers/gemini/errorClassifier.d.ts +38 -0
  951. package/dist/src/providers/gemini/errorClassifier.js +51 -0
  952. package/dist/src/providers/gemini/errorClassifier.js.map +1 -0
  953. package/dist/src/providers/gemini/errorClassifier.test.d.ts +6 -0
  954. package/dist/src/providers/gemini/errorClassifier.test.js +83 -0
  955. package/dist/src/providers/gemini/errorClassifier.test.js.map +1 -0
  956. package/dist/src/providers/gemini/eventMapper.d.ts +56 -0
  957. package/dist/src/providers/gemini/eventMapper.js +337 -0
  958. package/dist/src/providers/gemini/eventMapper.js.map +1 -0
  959. package/dist/src/providers/gemini/eventMapper.test.d.ts +6 -0
  960. package/dist/src/providers/gemini/eventMapper.test.js +502 -0
  961. package/dist/src/providers/gemini/eventMapper.test.js.map +1 -0
  962. package/dist/src/providers/gemini/exports.test.d.ts +6 -0
  963. package/dist/src/providers/gemini/exports.test.js +90 -0
  964. package/dist/src/providers/gemini/exports.test.js.map +1 -0
  965. package/dist/src/providers/gemini/featureFlag.d.ts +31 -0
  966. package/dist/src/providers/gemini/featureFlag.js +68 -0
  967. package/dist/src/providers/gemini/featureFlag.js.map +1 -0
  968. package/dist/src/providers/gemini/featureFlag.test.d.ts +6 -0
  969. package/dist/src/providers/gemini/featureFlag.test.js +139 -0
  970. package/dist/src/providers/gemini/featureFlag.test.js.map +1 -0
  971. package/dist/src/providers/gemini/geminiAdapter.test.d.ts +6 -0
  972. package/dist/src/providers/gemini/geminiAdapter.test.js +279 -0
  973. package/dist/src/providers/gemini/geminiAdapter.test.js.map +1 -0
  974. package/dist/src/providers/gemini/geminiConverter.test.d.ts +6 -0
  975. package/dist/src/providers/gemini/geminiConverter.test.js +474 -0
  976. package/dist/src/providers/gemini/geminiConverter.test.js.map +1 -0
  977. package/dist/src/providers/gemini/geminiParity.test.d.ts +6 -0
  978. package/dist/src/providers/gemini/geminiParity.test.js +754 -0
  979. package/dist/src/providers/gemini/geminiParity.test.js.map +1 -0
  980. package/dist/src/providers/gemini/geminiStream.d.ts +60 -0
  981. package/dist/src/providers/gemini/geminiStream.js +50 -0
  982. package/dist/src/providers/gemini/geminiStream.js.map +1 -0
  983. package/dist/src/providers/gemini/geminiStream.test.d.ts +6 -0
  984. package/dist/src/providers/gemini/geminiStream.test.js +391 -0
  985. package/dist/src/providers/gemini/geminiStream.test.js.map +1 -0
  986. package/dist/src/providers/gemini/historyBuilder.d.ts +64 -0
  987. package/dist/src/providers/gemini/historyBuilder.js +116 -0
  988. package/dist/src/providers/gemini/historyBuilder.js.map +1 -0
  989. package/dist/src/providers/gemini/historyBuilder.test.d.ts +6 -0
  990. package/dist/src/providers/gemini/historyBuilder.test.js +207 -0
  991. package/dist/src/providers/gemini/historyBuilder.test.js.map +1 -0
  992. package/dist/src/providers/gemini/index.d.ts +21 -0
  993. package/dist/src/providers/gemini/index.js +22 -0
  994. package/dist/src/providers/gemini/index.js.map +1 -0
  995. package/dist/src/providers/gemini/requestBuilder.d.ts +55 -0
  996. package/dist/src/providers/gemini/requestBuilder.js +141 -0
  997. package/dist/src/providers/gemini/requestBuilder.js.map +1 -0
  998. package/dist/src/providers/gemini/requestBuilder.test.d.ts +6 -0
  999. package/dist/src/providers/gemini/requestBuilder.test.js +358 -0
  1000. package/dist/src/providers/gemini/requestBuilder.test.js.map +1 -0
  1001. package/dist/src/providers/gemini/streamConverter.d.ts +40 -0
  1002. package/dist/src/providers/gemini/streamConverter.js +50 -0
  1003. package/dist/src/providers/gemini/streamConverter.js.map +1 -0
  1004. package/dist/src/providers/gemini/streamConverter.test.d.ts +6 -0
  1005. package/dist/src/providers/gemini/streamConverter.test.js +131 -0
  1006. package/dist/src/providers/gemini/streamConverter.test.js.map +1 -0
  1007. package/dist/src/providers/gemini/turn.d.ts +29 -0
  1008. package/dist/src/providers/gemini/turn.js +230 -0
  1009. package/dist/src/providers/gemini/turn.js.map +1 -0
  1010. package/dist/src/providers/gemini/typeConversion.d.ts +51 -0
  1011. package/dist/src/providers/gemini/typeConversion.js +165 -0
  1012. package/dist/src/providers/gemini/typeConversion.js.map +1 -0
  1013. package/dist/src/providers/gemini/types.d.ts +158 -0
  1014. package/dist/src/providers/gemini/types.js +47 -0
  1015. package/dist/src/providers/gemini/types.js.map +1 -0
  1016. package/dist/src/providers/index.d.ts +37 -0
  1017. package/dist/src/providers/index.js +68 -0
  1018. package/dist/src/providers/index.js.map +1 -0
  1019. package/dist/src/providers/legacyAliases.d.ts +97 -0
  1020. package/dist/src/providers/legacyAliases.js +26 -0
  1021. package/dist/src/providers/legacyAliases.js.map +1 -0
  1022. package/dist/src/providers/modelSpec.d.ts +104 -0
  1023. package/dist/src/providers/modelSpec.js +107 -0
  1024. package/dist/src/providers/modelSpec.js.map +1 -0
  1025. package/dist/src/providers/modelSpec.test.d.ts +1 -0
  1026. package/dist/src/providers/modelSpec.test.js +119 -0
  1027. package/dist/src/providers/modelSpec.test.js.map +1 -0
  1028. package/dist/src/providers/openai/adapter.d.ts +55 -0
  1029. package/dist/src/providers/openai/adapter.js +165 -0
  1030. package/dist/src/providers/openai/adapter.js.map +1 -0
  1031. package/dist/src/providers/openai/adapter.test.d.ts +6 -0
  1032. package/dist/src/providers/openai/adapter.test.js +274 -0
  1033. package/dist/src/providers/openai/adapter.test.js.map +1 -0
  1034. package/dist/src/providers/openai/bootstrap.d.ts +15 -0
  1035. package/dist/src/providers/openai/bootstrap.js +38 -0
  1036. package/dist/src/providers/openai/bootstrap.js.map +1 -0
  1037. package/dist/src/providers/openai/bootstrap.test.d.ts +6 -0
  1038. package/dist/src/providers/openai/bootstrap.test.js +76 -0
  1039. package/dist/src/providers/openai/bootstrap.test.js.map +1 -0
  1040. package/dist/src/providers/openai/converter.d.ts +122 -0
  1041. package/dist/src/providers/openai/converter.js +473 -0
  1042. package/dist/src/providers/openai/converter.js.map +1 -0
  1043. package/dist/src/providers/openai/converter.test.d.ts +6 -0
  1044. package/dist/src/providers/openai/converter.test.js +1133 -0
  1045. package/dist/src/providers/openai/converter.test.js.map +1 -0
  1046. package/dist/src/providers/openai/index.d.ts +13 -0
  1047. package/dist/src/providers/openai/index.js +14 -0
  1048. package/dist/src/providers/openai/index.js.map +1 -0
  1049. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.d.ts +6 -0
  1050. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js +356 -0
  1051. package/dist/src/providers/openai-compatible/__tests__/compatibility.test.js.map +1 -0
  1052. package/dist/src/providers/openai-compatible/adapter.d.ts +40 -0
  1053. package/dist/src/providers/openai-compatible/adapter.js +85 -0
  1054. package/dist/src/providers/openai-compatible/adapter.js.map +1 -0
  1055. package/dist/src/providers/openai-compatible/adapter.test.d.ts +6 -0
  1056. package/dist/src/providers/openai-compatible/adapter.test.js +240 -0
  1057. package/dist/src/providers/openai-compatible/adapter.test.js.map +1 -0
  1058. package/dist/src/providers/openai-compatible/bootstrap.d.ts +16 -0
  1059. package/dist/src/providers/openai-compatible/bootstrap.js +76 -0
  1060. package/dist/src/providers/openai-compatible/bootstrap.js.map +1 -0
  1061. package/dist/src/providers/openai-compatible/bootstrap.test.d.ts +6 -0
  1062. package/dist/src/providers/openai-compatible/bootstrap.test.js +145 -0
  1063. package/dist/src/providers/openai-compatible/bootstrap.test.js.map +1 -0
  1064. package/dist/src/providers/openai-compatible/index.d.ts +14 -0
  1065. package/dist/src/providers/openai-compatible/index.js +14 -0
  1066. package/dist/src/providers/openai-compatible/index.js.map +1 -0
  1067. package/dist/src/providers/openai-compatible/promptBuilder.d.ts +89 -0
  1068. package/dist/src/providers/openai-compatible/promptBuilder.js +123 -0
  1069. package/dist/src/providers/openai-compatible/promptBuilder.js.map +1 -0
  1070. package/dist/src/providers/openai-compatible/promptBuilder.test.d.ts +6 -0
  1071. package/dist/src/providers/openai-compatible/promptBuilder.test.js +154 -0
  1072. package/dist/src/providers/openai-compatible/promptBuilder.test.js.map +1 -0
  1073. package/dist/src/providers/providerConfig.d.ts +143 -0
  1074. package/dist/src/providers/providerConfig.js +92 -0
  1075. package/dist/src/providers/providerConfig.js.map +1 -0
  1076. package/dist/src/providers/providerConfig.test.d.ts +1 -0
  1077. package/dist/src/providers/providerConfig.test.js +145 -0
  1078. package/dist/src/providers/providerConfig.test.js.map +1 -0
  1079. package/dist/src/providers/providerConfigIntegration.d.ts +95 -0
  1080. package/dist/src/providers/providerConfigIntegration.js +180 -0
  1081. package/dist/src/providers/providerConfigIntegration.js.map +1 -0
  1082. package/dist/src/providers/providerConfigIntegration.test.d.ts +6 -0
  1083. package/dist/src/providers/providerConfigIntegration.test.js +187 -0
  1084. package/dist/src/providers/providerConfigIntegration.test.js.map +1 -0
  1085. package/dist/src/providers/providerSelector.d.ts +91 -0
  1086. package/dist/src/providers/providerSelector.js +221 -0
  1087. package/dist/src/providers/providerSelector.js.map +1 -0
  1088. package/dist/src/providers/providerSelector.test.d.ts +1 -0
  1089. package/dist/src/providers/providerSelector.test.js +199 -0
  1090. package/dist/src/providers/providerSelector.test.js.map +1 -0
  1091. package/dist/src/providers/providerTypes.d.ts +94 -0
  1092. package/dist/src/providers/providerTypes.js +119 -0
  1093. package/dist/src/providers/providerTypes.js.map +1 -0
  1094. package/dist/src/providers/providerTypes.test.d.ts +1 -0
  1095. package/dist/src/providers/providerTypes.test.js +95 -0
  1096. package/dist/src/providers/providerTypes.test.js.map +1 -0
  1097. package/dist/src/providers/registry.d.ts +109 -0
  1098. package/dist/src/providers/registry.js +131 -0
  1099. package/dist/src/providers/registry.js.map +1 -0
  1100. package/dist/src/providers/registry.test.d.ts +1 -0
  1101. package/dist/src/providers/registry.test.js +207 -0
  1102. package/dist/src/providers/registry.test.js.map +1 -0
  1103. package/dist/src/providers/streamAssembler.d.ts +113 -0
  1104. package/dist/src/providers/streamAssembler.js +180 -0
  1105. package/dist/src/providers/streamAssembler.js.map +1 -0
  1106. package/dist/src/providers/streamAssembler.test.d.ts +1 -0
  1107. package/dist/src/providers/streamAssembler.test.js +247 -0
  1108. package/dist/src/providers/streamAssembler.test.js.map +1 -0
  1109. package/dist/src/providers/telemetryBridge.d.ts +89 -0
  1110. package/dist/src/providers/telemetryBridge.js +108 -0
  1111. package/dist/src/providers/telemetryBridge.js.map +1 -0
  1112. package/dist/src/providers/telemetryBridge.test.d.ts +6 -0
  1113. package/dist/src/providers/telemetryBridge.test.js +235 -0
  1114. package/dist/src/providers/telemetryBridge.test.js.map +1 -0
  1115. package/dist/src/providers/types.d.ts +318 -0
  1116. package/dist/src/providers/types.js +16 -0
  1117. package/dist/src/providers/types.js.map +1 -0
  1118. package/dist/src/providers/types.test.d.ts +6 -0
  1119. package/dist/src/providers/types.test.js +253 -0
  1120. package/dist/src/providers/types.test.js.map +1 -0
  1121. package/dist/src/resources/resource-registry.d.ts +30 -0
  1122. package/dist/src/resources/resource-registry.js +57 -0
  1123. package/dist/src/resources/resource-registry.js.map +1 -0
  1124. package/dist/src/resources/resource-registry.test.d.ts +6 -0
  1125. package/dist/src/resources/resource-registry.test.js +54 -0
  1126. package/dist/src/resources/resource-registry.test.js.map +1 -0
  1127. package/dist/src/routing/modelRouterService.d.ts +23 -0
  1128. package/dist/src/routing/modelRouterService.js +80 -0
  1129. package/dist/src/routing/modelRouterService.js.map +1 -0
  1130. package/dist/src/routing/modelRouterService.test.d.ts +6 -0
  1131. package/dist/src/routing/modelRouterService.test.js +106 -0
  1132. package/dist/src/routing/modelRouterService.test.js.map +1 -0
  1133. package/dist/src/routing/routingStrategy.d.ts +65 -0
  1134. package/dist/src/routing/routingStrategy.js +7 -0
  1135. package/dist/src/routing/routingStrategy.js.map +1 -0
  1136. package/dist/src/routing/strategies/classifierStrategy.d.ts +12 -0
  1137. package/dist/src/routing/strategies/classifierStrategy.js +156 -0
  1138. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -0
  1139. package/dist/src/routing/strategies/classifierStrategy.test.d.ts +6 -0
  1140. package/dist/src/routing/strategies/classifierStrategy.test.js +249 -0
  1141. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -0
  1142. package/dist/src/routing/strategies/compositeStrategy.d.ts +26 -0
  1143. package/dist/src/routing/strategies/compositeStrategy.js +70 -0
  1144. package/dist/src/routing/strategies/compositeStrategy.js.map +1 -0
  1145. package/dist/src/routing/strategies/compositeStrategy.test.d.ts +6 -0
  1146. package/dist/src/routing/strategies/compositeStrategy.test.js +124 -0
  1147. package/dist/src/routing/strategies/compositeStrategy.test.js.map +1 -0
  1148. package/dist/src/routing/strategies/defaultStrategy.d.ts +12 -0
  1149. package/dist/src/routing/strategies/defaultStrategy.js +21 -0
  1150. package/dist/src/routing/strategies/defaultStrategy.js.map +1 -0
  1151. package/dist/src/routing/strategies/defaultStrategy.test.d.ts +6 -0
  1152. package/dist/src/routing/strategies/defaultStrategy.test.js +102 -0
  1153. package/dist/src/routing/strategies/defaultStrategy.test.js.map +1 -0
  1154. package/dist/src/routing/strategies/fallbackStrategy.d.ts +12 -0
  1155. package/dist/src/routing/strategies/fallbackStrategy.js +33 -0
  1156. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -0
  1157. package/dist/src/routing/strategies/fallbackStrategy.test.d.ts +6 -0
  1158. package/dist/src/routing/strategies/fallbackStrategy.test.js +96 -0
  1159. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -0
  1160. package/dist/src/routing/strategies/numericalClassifierStrategy.d.ts +13 -0
  1161. package/dist/src/routing/strategies/numericalClassifierStrategy.js +171 -0
  1162. package/dist/src/routing/strategies/numericalClassifierStrategy.js.map +1 -0
  1163. package/dist/src/routing/strategies/numericalClassifierStrategy.test.d.ts +6 -0
  1164. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +367 -0
  1165. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +1 -0
  1166. package/dist/src/routing/strategies/overrideStrategy.d.ts +15 -0
  1167. package/dist/src/routing/strategies/overrideStrategy.js +29 -0
  1168. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -0
  1169. package/dist/src/routing/strategies/overrideStrategy.test.d.ts +6 -0
  1170. package/dist/src/routing/strategies/overrideStrategy.test.js +59 -0
  1171. package/dist/src/routing/strategies/overrideStrategy.test.js.map +1 -0
  1172. package/dist/src/safety/built-in.d.ts +21 -0
  1173. package/dist/src/safety/built-in.js +106 -0
  1174. package/dist/src/safety/built-in.js.map +1 -0
  1175. package/dist/src/safety/built-in.test.d.ts +6 -0
  1176. package/dist/src/safety/built-in.test.js +199 -0
  1177. package/dist/src/safety/built-in.test.js.map +1 -0
  1178. package/dist/src/safety/checker-runner.d.ts +48 -0
  1179. package/dist/src/safety/checker-runner.js +219 -0
  1180. package/dist/src/safety/checker-runner.js.map +1 -0
  1181. package/dist/src/safety/checker-runner.test.d.ts +6 -0
  1182. package/dist/src/safety/checker-runner.test.js +238 -0
  1183. package/dist/src/safety/checker-runner.test.js.map +1 -0
  1184. package/dist/src/safety/context-builder.d.ts +23 -0
  1185. package/dist/src/safety/context-builder.js +47 -0
  1186. package/dist/src/safety/context-builder.js.map +1 -0
  1187. package/dist/src/safety/context-builder.test.d.ts +6 -0
  1188. package/dist/src/safety/context-builder.test.js +49 -0
  1189. package/dist/src/safety/context-builder.test.js.map +1 -0
  1190. package/dist/src/safety/protocol.d.ts +88 -0
  1191. package/dist/src/safety/protocol.js +15 -0
  1192. package/dist/src/safety/protocol.js.map +1 -0
  1193. package/dist/src/safety/registry.d.ts +26 -0
  1194. package/dist/src/safety/registry.js +65 -0
  1195. package/dist/src/safety/registry.js.map +1 -0
  1196. package/dist/src/safety/registry.test.d.ts +6 -0
  1197. package/dist/src/safety/registry.test.js +31 -0
  1198. package/dist/src/safety/registry.test.js.map +1 -0
  1199. package/dist/src/scheduler/confirmation.d.ts +49 -0
  1200. package/dist/src/scheduler/confirmation.js +180 -0
  1201. package/dist/src/scheduler/confirmation.js.map +1 -0
  1202. package/dist/src/scheduler/confirmation.test.d.ts +6 -0
  1203. package/dist/src/scheduler/confirmation.test.js +325 -0
  1204. package/dist/src/scheduler/confirmation.test.js.map +1 -0
  1205. package/dist/src/scheduler/policy.d.ts +25 -0
  1206. package/dist/src/scheduler/policy.js +103 -0
  1207. package/dist/src/scheduler/policy.js.map +1 -0
  1208. package/dist/src/scheduler/policy.test.d.ts +6 -0
  1209. package/dist/src/scheduler/policy.test.js +299 -0
  1210. package/dist/src/scheduler/policy.test.js.map +1 -0
  1211. package/dist/src/scheduler/scheduler.d.ts +61 -0
  1212. package/dist/src/scheduler/scheduler.js +355 -0
  1213. package/dist/src/scheduler/scheduler.js.map +1 -0
  1214. package/dist/src/scheduler/scheduler.test.d.ts +6 -0
  1215. package/dist/src/scheduler/scheduler.test.js +822 -0
  1216. package/dist/src/scheduler/scheduler.test.js.map +1 -0
  1217. package/dist/src/scheduler/state-manager.d.ts +73 -0
  1218. package/dist/src/scheduler/state-manager.js +356 -0
  1219. package/dist/src/scheduler/state-manager.js.map +1 -0
  1220. package/dist/src/scheduler/state-manager.test.d.ts +6 -0
  1221. package/dist/src/scheduler/state-manager.test.js +429 -0
  1222. package/dist/src/scheduler/state-manager.test.js.map +1 -0
  1223. package/dist/src/scheduler/tool-executor.d.ts +22 -0
  1224. package/dist/src/scheduler/tool-executor.js +196 -0
  1225. package/dist/src/scheduler/tool-executor.js.map +1 -0
  1226. package/dist/src/scheduler/tool-executor.test.d.ts +6 -0
  1227. package/dist/src/scheduler/tool-executor.test.js +232 -0
  1228. package/dist/src/scheduler/tool-executor.test.js.map +1 -0
  1229. package/dist/src/scheduler/tool-modifier.d.ts +23 -0
  1230. package/dist/src/scheduler/tool-modifier.js +50 -0
  1231. package/dist/src/scheduler/tool-modifier.js.map +1 -0
  1232. package/dist/src/scheduler/tool-modifier.test.d.ts +6 -0
  1233. package/dist/src/scheduler/tool-modifier.test.js +159 -0
  1234. package/dist/src/scheduler/tool-modifier.test.js.map +1 -0
  1235. package/dist/src/scheduler/types.d.ts +114 -0
  1236. package/dist/src/scheduler/types.js +7 -0
  1237. package/dist/src/scheduler/types.js.map +1 -0
  1238. package/dist/src/services/chatCompressionService.d.ts +41 -0
  1239. package/dist/src/services/chatCompressionService.js +339 -0
  1240. package/dist/src/services/chatCompressionService.js.map +1 -0
  1241. package/dist/src/services/chatCompressionService.test.d.ts +6 -0
  1242. package/dist/src/services/chatCompressionService.test.js +573 -0
  1243. package/dist/src/services/chatCompressionService.test.js.map +1 -0
  1244. package/dist/src/services/chatRecordingService.d.ts +165 -0
  1245. package/dist/src/services/chatRecordingService.js +409 -0
  1246. package/dist/src/services/chatRecordingService.js.map +1 -0
  1247. package/dist/src/services/chatRecordingService.test.d.ts +6 -0
  1248. package/dist/src/services/chatRecordingService.test.js +486 -0
  1249. package/dist/src/services/chatRecordingService.test.js.map +1 -0
  1250. package/dist/src/services/contextManager.d.ts +29 -0
  1251. package/dist/src/services/contextManager.js +71 -0
  1252. package/dist/src/services/contextManager.js.map +1 -0
  1253. package/dist/src/services/contextManager.test.d.ts +6 -0
  1254. package/dist/src/services/contextManager.test.js +104 -0
  1255. package/dist/src/services/contextManager.test.js.map +1 -0
  1256. package/dist/src/services/environmentSanitization.d.ts +15 -0
  1257. package/dist/src/services/environmentSanitization.js +142 -0
  1258. package/dist/src/services/environmentSanitization.js.map +1 -0
  1259. package/dist/src/services/environmentSanitization.test.d.ts +6 -0
  1260. package/dist/src/services/environmentSanitization.test.js +284 -0
  1261. package/dist/src/services/environmentSanitization.test.js.map +1 -0
  1262. package/dist/src/services/fileDiscoveryService.d.ts +33 -0
  1263. package/dist/src/services/fileDiscoveryService.js +69 -0
  1264. package/dist/src/services/fileDiscoveryService.js.map +1 -0
  1265. package/dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  1266. package/dist/src/services/fileDiscoveryService.test.js +223 -0
  1267. package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
  1268. package/dist/src/services/fileSystemService.d.ts +31 -0
  1269. package/dist/src/services/fileSystemService.js +18 -0
  1270. package/dist/src/services/fileSystemService.js.map +1 -0
  1271. package/dist/src/services/fileSystemService.test.d.ts +6 -0
  1272. package/dist/src/services/fileSystemService.test.js +41 -0
  1273. package/dist/src/services/fileSystemService.test.js.map +1 -0
  1274. package/dist/src/services/gitService.d.ts +23 -0
  1275. package/dist/src/services/gitService.js +123 -0
  1276. package/dist/src/services/gitService.js.map +1 -0
  1277. package/dist/src/services/gitService.test.d.ts +6 -0
  1278. package/dist/src/services/gitService.test.js +264 -0
  1279. package/dist/src/services/gitService.test.js.map +1 -0
  1280. package/dist/src/services/loopDetectionService.d.ts +107 -0
  1281. package/dist/src/services/loopDetectionService.js +436 -0
  1282. package/dist/src/services/loopDetectionService.js.map +1 -0
  1283. package/dist/src/services/loopDetectionService.test.d.ts +6 -0
  1284. package/dist/src/services/loopDetectionService.test.js +881 -0
  1285. package/dist/src/services/loopDetectionService.test.js.map +1 -0
  1286. package/dist/src/services/modelConfig.golden.test.d.ts +6 -0
  1287. package/dist/src/services/modelConfig.golden.test.js +74 -0
  1288. package/dist/src/services/modelConfig.golden.test.js.map +1 -0
  1289. package/dist/src/services/modelConfig.integration.test.d.ts +6 -0
  1290. package/dist/src/services/modelConfig.integration.test.js +247 -0
  1291. package/dist/src/services/modelConfig.integration.test.js.map +1 -0
  1292. package/dist/src/services/modelConfigBridge.d.ts +75 -0
  1293. package/dist/src/services/modelConfigBridge.js +116 -0
  1294. package/dist/src/services/modelConfigBridge.js.map +1 -0
  1295. package/dist/src/services/modelConfigBridge.test.d.ts +6 -0
  1296. package/dist/src/services/modelConfigBridge.test.js +410 -0
  1297. package/dist/src/services/modelConfigBridge.test.js.map +1 -0
  1298. package/dist/src/services/modelConfigService.d.ts +86 -0
  1299. package/dist/src/services/modelConfigService.js +215 -0
  1300. package/dist/src/services/modelConfigService.js.map +1 -0
  1301. package/dist/src/services/modelConfigService.test.d.ts +6 -0
  1302. package/dist/src/services/modelConfigService.test.js +868 -0
  1303. package/dist/src/services/modelConfigService.test.js.map +1 -0
  1304. package/dist/src/services/modelConfigServiceTestUtils.d.ts +10 -0
  1305. package/dist/src/services/modelConfigServiceTestUtils.js +17 -0
  1306. package/dist/src/services/modelConfigServiceTestUtils.js.map +1 -0
  1307. package/dist/src/services/sessionSummaryService.d.ts +28 -0
  1308. package/dist/src/services/sessionSummaryService.js +131 -0
  1309. package/dist/src/services/sessionSummaryService.js.map +1 -0
  1310. package/dist/src/services/sessionSummaryService.test.d.ts +6 -0
  1311. package/dist/src/services/sessionSummaryService.test.js +785 -0
  1312. package/dist/src/services/sessionSummaryService.test.js.map +1 -0
  1313. package/dist/src/services/sessionSummaryUtils.d.ts +16 -0
  1314. package/dist/src/services/sessionSummaryUtils.js +137 -0
  1315. package/dist/src/services/sessionSummaryUtils.js.map +1 -0
  1316. package/dist/src/services/sessionSummaryUtils.test.d.ts +6 -0
  1317. package/dist/src/services/sessionSummaryUtils.test.js +160 -0
  1318. package/dist/src/services/sessionSummaryUtils.test.js.map +1 -0
  1319. package/dist/src/services/shellExecutionService.d.ts +107 -0
  1320. package/dist/src/services/shellExecutionService.js +654 -0
  1321. package/dist/src/services/shellExecutionService.js.map +1 -0
  1322. package/dist/src/services/shellExecutionService.test.d.ts +6 -0
  1323. package/dist/src/services/shellExecutionService.test.js +1080 -0
  1324. package/dist/src/services/shellExecutionService.test.js.map +1 -0
  1325. package/dist/src/services/test-data/resolved-aliases-retry.golden.json +238 -0
  1326. package/dist/src/services/test-data/resolved-aliases.golden.json +238 -0
  1327. package/dist/src/skills/builtin/skill-creator/SKILL.md +382 -0
  1328. package/dist/src/skills/builtin/skill-creator/scripts/init_skill.cjs +235 -0
  1329. package/dist/src/skills/builtin/skill-creator/scripts/package_skill.cjs +102 -0
  1330. package/dist/src/skills/builtin/skill-creator/scripts/validate_skill.cjs +127 -0
  1331. package/dist/src/skills/skillLoader.d.ts +31 -0
  1332. package/dist/src/skills/skillLoader.js +133 -0
  1333. package/dist/src/skills/skillLoader.js.map +1 -0
  1334. package/dist/src/skills/skillLoader.test.d.ts +6 -0
  1335. package/dist/src/skills/skillLoader.test.js +185 -0
  1336. package/dist/src/skills/skillLoader.test.js.map +1 -0
  1337. package/dist/src/skills/skillManager.d.ts +69 -0
  1338. package/dist/src/skills/skillManager.js +138 -0
  1339. package/dist/src/skills/skillManager.js.map +1 -0
  1340. package/dist/src/skills/skillManager.test.d.ts +6 -0
  1341. package/dist/src/skills/skillManager.test.js +297 -0
  1342. package/dist/src/skills/skillManager.test.js.map +1 -0
  1343. package/dist/src/telemetry/activity-detector.d.ts +41 -0
  1344. package/dist/src/telemetry/activity-detector.js +61 -0
  1345. package/dist/src/telemetry/activity-detector.js.map +1 -0
  1346. package/dist/src/telemetry/activity-detector.test.d.ts +6 -0
  1347. package/dist/src/telemetry/activity-detector.test.js +136 -0
  1348. package/dist/src/telemetry/activity-detector.test.js.map +1 -0
  1349. package/dist/src/telemetry/activity-monitor.d.ts +116 -0
  1350. package/dist/src/telemetry/activity-monitor.js +209 -0
  1351. package/dist/src/telemetry/activity-monitor.js.map +1 -0
  1352. package/dist/src/telemetry/activity-monitor.test.d.ts +6 -0
  1353. package/dist/src/telemetry/activity-monitor.test.js +251 -0
  1354. package/dist/src/telemetry/activity-monitor.test.js.map +1 -0
  1355. package/dist/src/telemetry/activity-types.d.ts +19 -0
  1356. package/dist/src/telemetry/activity-types.js +21 -0
  1357. package/dist/src/telemetry/activity-types.js.map +1 -0
  1358. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +172 -0
  1359. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +1316 -0
  1360. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
  1361. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +19 -0
  1362. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +964 -0
  1363. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
  1364. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +150 -0
  1365. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +377 -0
  1366. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
  1367. package/dist/src/telemetry/config.d.ts +31 -0
  1368. package/dist/src/telemetry/config.js +78 -0
  1369. package/dist/src/telemetry/config.js.map +1 -0
  1370. package/dist/src/telemetry/config.test.d.ts +6 -0
  1371. package/dist/src/telemetry/config.test.js +149 -0
  1372. package/dist/src/telemetry/config.test.js.map +1 -0
  1373. package/dist/src/telemetry/constants.d.ts +6 -0
  1374. package/dist/src/telemetry/constants.js +7 -0
  1375. package/dist/src/telemetry/constants.js.map +1 -0
  1376. package/dist/src/telemetry/file-exporters.d.ts +29 -0
  1377. package/dist/src/telemetry/file-exporters.js +62 -0
  1378. package/dist/src/telemetry/file-exporters.js.map +1 -0
  1379. package/dist/src/telemetry/gcp-exporters.d.ts +35 -0
  1380. package/dist/src/telemetry/gcp-exporters.js +120 -0
  1381. package/dist/src/telemetry/gcp-exporters.js.map +1 -0
  1382. package/dist/src/telemetry/gcp-exporters.test.d.ts +6 -0
  1383. package/dist/src/telemetry/gcp-exporters.test.js +318 -0
  1384. package/dist/src/telemetry/gcp-exporters.test.js.map +1 -0
  1385. package/dist/src/telemetry/high-water-mark-tracker.d.ts +43 -0
  1386. package/dist/src/telemetry/high-water-mark-tracker.js +88 -0
  1387. package/dist/src/telemetry/high-water-mark-tracker.js.map +1 -0
  1388. package/dist/src/telemetry/high-water-mark-tracker.test.d.ts +6 -0
  1389. package/dist/src/telemetry/high-water-mark-tracker.test.js +152 -0
  1390. package/dist/src/telemetry/high-water-mark-tracker.test.js.map +1 -0
  1391. package/dist/src/telemetry/index.d.ts +33 -0
  1392. package/dist/src/telemetry/index.js +44 -0
  1393. package/dist/src/telemetry/index.js.map +1 -0
  1394. package/dist/src/telemetry/integration.test.circular.d.ts +6 -0
  1395. package/dist/src/telemetry/integration.test.circular.js +54 -0
  1396. package/dist/src/telemetry/integration.test.circular.js.map +1 -0
  1397. package/dist/src/telemetry/loggers.d.ts +46 -0
  1398. package/dist/src/telemetry/loggers.js +517 -0
  1399. package/dist/src/telemetry/loggers.js.map +1 -0
  1400. package/dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  1401. package/dist/src/telemetry/loggers.test.circular.js +107 -0
  1402. package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
  1403. package/dist/src/telemetry/loggers.test.d.ts +6 -0
  1404. package/dist/src/telemetry/loggers.test.js +1618 -0
  1405. package/dist/src/telemetry/loggers.test.js.map +1 -0
  1406. package/dist/src/telemetry/memory-monitor.d.ts +149 -0
  1407. package/dist/src/telemetry/memory-monitor.js +335 -0
  1408. package/dist/src/telemetry/memory-monitor.js.map +1 -0
  1409. package/dist/src/telemetry/memory-monitor.test.d.ts +6 -0
  1410. package/dist/src/telemetry/memory-monitor.test.js +472 -0
  1411. package/dist/src/telemetry/memory-monitor.test.js.map +1 -0
  1412. package/dist/src/telemetry/metrics.d.ts +533 -0
  1413. package/dist/src/telemetry/metrics.js +852 -0
  1414. package/dist/src/telemetry/metrics.js.map +1 -0
  1415. package/dist/src/telemetry/metrics.test.d.ts +6 -0
  1416. package/dist/src/telemetry/metrics.test.js +1176 -0
  1417. package/dist/src/telemetry/metrics.test.js.map +1 -0
  1418. package/dist/src/telemetry/rate-limiter.d.ts +48 -0
  1419. package/dist/src/telemetry/rate-limiter.js +100 -0
  1420. package/dist/src/telemetry/rate-limiter.js.map +1 -0
  1421. package/dist/src/telemetry/rate-limiter.test.d.ts +6 -0
  1422. package/dist/src/telemetry/rate-limiter.test.js +207 -0
  1423. package/dist/src/telemetry/rate-limiter.test.js.map +1 -0
  1424. package/dist/src/telemetry/sanitize.d.ts +25 -0
  1425. package/dist/src/telemetry/sanitize.js +48 -0
  1426. package/dist/src/telemetry/sanitize.js.map +1 -0
  1427. package/dist/src/telemetry/sanitize.test.d.ts +6 -0
  1428. package/dist/src/telemetry/sanitize.test.js +279 -0
  1429. package/dist/src/telemetry/sanitize.test.js.map +1 -0
  1430. package/dist/src/telemetry/sdk.d.ts +16 -0
  1431. package/dist/src/telemetry/sdk.js +324 -0
  1432. package/dist/src/telemetry/sdk.js.map +1 -0
  1433. package/dist/src/telemetry/sdk.test.d.ts +6 -0
  1434. package/dist/src/telemetry/sdk.test.js +360 -0
  1435. package/dist/src/telemetry/sdk.test.js.map +1 -0
  1436. package/dist/src/telemetry/semantic.d.ts +110 -0
  1437. package/dist/src/telemetry/semantic.js +375 -0
  1438. package/dist/src/telemetry/semantic.js.map +1 -0
  1439. package/dist/src/telemetry/semantic.test.d.ts +6 -0
  1440. package/dist/src/telemetry/semantic.test.js +387 -0
  1441. package/dist/src/telemetry/semantic.test.js.map +1 -0
  1442. package/dist/src/telemetry/semantic.truncation.test.d.ts +1 -0
  1443. package/dist/src/telemetry/semantic.truncation.test.js +92 -0
  1444. package/dist/src/telemetry/semantic.truncation.test.js.map +1 -0
  1445. package/dist/src/telemetry/startupProfiler.d.ts +51 -0
  1446. package/dist/src/telemetry/startupProfiler.js +170 -0
  1447. package/dist/src/telemetry/startupProfiler.js.map +1 -0
  1448. package/dist/src/telemetry/startupProfiler.test.d.ts +6 -0
  1449. package/dist/src/telemetry/startupProfiler.test.js +285 -0
  1450. package/dist/src/telemetry/startupProfiler.test.js.map +1 -0
  1451. package/dist/src/telemetry/telemetry-utils.d.ts +6 -0
  1452. package/dist/src/telemetry/telemetry-utils.js +14 -0
  1453. package/dist/src/telemetry/telemetry-utils.js.map +1 -0
  1454. package/dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  1455. package/dist/src/telemetry/telemetry-utils.test.js +41 -0
  1456. package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  1457. package/dist/src/telemetry/telemetry.test.d.ts +6 -0
  1458. package/dist/src/telemetry/telemetry.test.js +57 -0
  1459. package/dist/src/telemetry/telemetry.test.js.map +1 -0
  1460. package/dist/src/telemetry/telemetryAttributes.d.ts +8 -0
  1461. package/dist/src/telemetry/telemetryAttributes.js +19 -0
  1462. package/dist/src/telemetry/telemetryAttributes.js.map +1 -0
  1463. package/dist/src/telemetry/tool-call-decision.d.ts +13 -0
  1464. package/dist/src/telemetry/tool-call-decision.js +29 -0
  1465. package/dist/src/telemetry/tool-call-decision.js.map +1 -0
  1466. package/dist/src/telemetry/trace.d.ts +46 -0
  1467. package/dist/src/telemetry/trace.js +121 -0
  1468. package/dist/src/telemetry/trace.js.map +1 -0
  1469. package/dist/src/telemetry/types.d.ts +597 -0
  1470. package/dist/src/telemetry/types.js +1495 -0
  1471. package/dist/src/telemetry/types.js.map +1 -0
  1472. package/dist/src/telemetry/uiTelemetry.d.ts +76 -0
  1473. package/dist/src/telemetry/uiTelemetry.js +154 -0
  1474. package/dist/src/telemetry/uiTelemetry.js.map +1 -0
  1475. package/dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  1476. package/dist/src/telemetry/uiTelemetry.test.js +584 -0
  1477. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  1478. package/dist/src/test-utils/config.d.ts +17 -0
  1479. package/dist/src/test-utils/config.js +32 -0
  1480. package/dist/src/test-utils/config.js.map +1 -0
  1481. package/dist/src/test-utils/index.d.ts +6 -0
  1482. package/dist/src/test-utils/index.js +7 -0
  1483. package/dist/src/test-utils/index.js.map +1 -0
  1484. package/dist/src/test-utils/mock-message-bus.d.ts +43 -0
  1485. package/dist/src/test-utils/mock-message-bus.js +96 -0
  1486. package/dist/src/test-utils/mock-message-bus.js.map +1 -0
  1487. package/dist/src/test-utils/mock-tool.d.ts +69 -0
  1488. package/dist/src/test-utils/mock-tool.js +123 -0
  1489. package/dist/src/test-utils/mock-tool.js.map +1 -0
  1490. package/dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  1491. package/dist/src/test-utils/mockWorkspaceContext.js +24 -0
  1492. package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  1493. package/dist/src/tools/activate-skill.d.ts +27 -0
  1494. package/dist/src/tools/activate-skill.js +133 -0
  1495. package/dist/src/tools/activate-skill.js.map +1 -0
  1496. package/dist/src/tools/activate-skill.test.d.ts +6 -0
  1497. package/dist/src/tools/activate-skill.test.js +113 -0
  1498. package/dist/src/tools/activate-skill.test.js.map +1 -0
  1499. package/dist/src/tools/ask-user.d.ts +20 -0
  1500. package/dist/src/tools/ask-user.js +142 -0
  1501. package/dist/src/tools/ask-user.js.map +1 -0
  1502. package/dist/src/tools/ask-user.test.d.ts +6 -0
  1503. package/dist/src/tools/ask-user.test.js +187 -0
  1504. package/dist/src/tools/ask-user.test.js.map +1 -0
  1505. package/dist/src/tools/base-tool-invocation.test.d.ts +6 -0
  1506. package/dist/src/tools/base-tool-invocation.test.js +85 -0
  1507. package/dist/src/tools/base-tool-invocation.test.js.map +1 -0
  1508. package/dist/src/tools/confirmation-policy.test.d.ts +6 -0
  1509. package/dist/src/tools/confirmation-policy.test.js +143 -0
  1510. package/dist/src/tools/confirmation-policy.test.js.map +1 -0
  1511. package/dist/src/tools/constants.d.ts +7 -0
  1512. package/dist/src/tools/constants.js +8 -0
  1513. package/dist/src/tools/constants.js.map +1 -0
  1514. package/dist/src/tools/diffOptions.d.ts +9 -0
  1515. package/dist/src/tools/diffOptions.js +50 -0
  1516. package/dist/src/tools/diffOptions.js.map +1 -0
  1517. package/dist/src/tools/diffOptions.test.d.ts +6 -0
  1518. package/dist/src/tools/diffOptions.test.js +172 -0
  1519. package/dist/src/tools/diffOptions.test.js.map +1 -0
  1520. package/dist/src/tools/edit.d.ts +79 -0
  1521. package/dist/src/tools/edit.js +747 -0
  1522. package/dist/src/tools/edit.js.map +1 -0
  1523. package/dist/src/tools/edit.test.d.ts +6 -0
  1524. package/dist/src/tools/edit.test.js +729 -0
  1525. package/dist/src/tools/edit.test.js.map +1 -0
  1526. package/dist/src/tools/get-internal-docs.d.ts +27 -0
  1527. package/dist/src/tools/get-internal-docs.js +122 -0
  1528. package/dist/src/tools/get-internal-docs.js.map +1 -0
  1529. package/dist/src/tools/get-internal-docs.test.d.ts +6 -0
  1530. package/dist/src/tools/get-internal-docs.test.js +57 -0
  1531. package/dist/src/tools/get-internal-docs.test.js.map +1 -0
  1532. package/dist/src/tools/glob.d.ts +57 -0
  1533. package/dist/src/tools/glob.js +241 -0
  1534. package/dist/src/tools/glob.js.map +1 -0
  1535. package/dist/src/tools/glob.test.d.ts +6 -0
  1536. package/dist/src/tools/glob.test.js +433 -0
  1537. package/dist/src/tools/glob.test.js.map +1 -0
  1538. package/dist/src/tools/grep.d.ts +48 -0
  1539. package/dist/src/tools/grep.js +509 -0
  1540. package/dist/src/tools/grep.js.map +1 -0
  1541. package/dist/src/tools/grep.test.d.ts +6 -0
  1542. package/dist/src/tools/grep.test.js +328 -0
  1543. package/dist/src/tools/grep.test.js.map +1 -0
  1544. package/dist/src/tools/ls.d.ts +69 -0
  1545. package/dist/src/tools/ls.js +208 -0
  1546. package/dist/src/tools/ls.js.map +1 -0
  1547. package/dist/src/tools/ls.test.d.ts +6 -0
  1548. package/dist/src/tools/ls.test.js +242 -0
  1549. package/dist/src/tools/ls.test.js.map +1 -0
  1550. package/dist/src/tools/mcp-client-manager.d.ts +93 -0
  1551. package/dist/src/tools/mcp-client-manager.js +338 -0
  1552. package/dist/src/tools/mcp-client-manager.js.map +1 -0
  1553. package/dist/src/tools/mcp-client-manager.test.d.ts +6 -0
  1554. package/dist/src/tools/mcp-client-manager.test.js +251 -0
  1555. package/dist/src/tools/mcp-client-manager.test.js.map +1 -0
  1556. package/dist/src/tools/mcp-client.d.ts +243 -0
  1557. package/dist/src/tools/mcp-client.js +1334 -0
  1558. package/dist/src/tools/mcp-client.js.map +1 -0
  1559. package/dist/src/tools/mcp-client.test.d.ts +6 -0
  1560. package/dist/src/tools/mcp-client.test.js +1346 -0
  1561. package/dist/src/tools/mcp-client.test.js.map +1 -0
  1562. package/dist/src/tools/mcp-tool.d.ts +49 -0
  1563. package/dist/src/tools/mcp-tool.js +300 -0
  1564. package/dist/src/tools/mcp-tool.js.map +1 -0
  1565. package/dist/src/tools/mcp-tool.test.d.ts +6 -0
  1566. package/dist/src/tools/mcp-tool.test.js +657 -0
  1567. package/dist/src/tools/mcp-tool.test.js.map +1 -0
  1568. package/dist/src/tools/memoryTool.d.ts +42 -0
  1569. package/dist/src/tools/memoryTool.js +269 -0
  1570. package/dist/src/tools/memoryTool.js.map +1 -0
  1571. package/dist/src/tools/memoryTool.test.d.ts +6 -0
  1572. package/dist/src/tools/memoryTool.test.js +302 -0
  1573. package/dist/src/tools/memoryTool.test.js.map +1 -0
  1574. package/dist/src/tools/message-bus-integration.test.d.ts +6 -0
  1575. package/dist/src/tools/message-bus-integration.test.js +169 -0
  1576. package/dist/src/tools/message-bus-integration.test.js.map +1 -0
  1577. package/dist/src/tools/modifiable-tool.d.ts +36 -0
  1578. package/dist/src/tools/modifiable-tool.js +110 -0
  1579. package/dist/src/tools/modifiable-tool.js.map +1 -0
  1580. package/dist/src/tools/modifiable-tool.test.d.ts +6 -0
  1581. package/dist/src/tools/modifiable-tool.test.js +237 -0
  1582. package/dist/src/tools/modifiable-tool.test.js.map +1 -0
  1583. package/dist/src/tools/read-file.d.ts +36 -0
  1584. package/dist/src/tools/read-file.js +133 -0
  1585. package/dist/src/tools/read-file.js.map +1 -0
  1586. package/dist/src/tools/read-file.test.d.ts +6 -0
  1587. package/dist/src/tools/read-file.test.js +376 -0
  1588. package/dist/src/tools/read-file.test.js.map +1 -0
  1589. package/dist/src/tools/read-many-files.d.ts +54 -0
  1590. package/dist/src/tools/read-many-files.js +355 -0
  1591. package/dist/src/tools/read-many-files.js.map +1 -0
  1592. package/dist/src/tools/read-many-files.test.d.ts +6 -0
  1593. package/dist/src/tools/read-many-files.test.js +567 -0
  1594. package/dist/src/tools/read-many-files.test.js.map +1 -0
  1595. package/dist/src/tools/ripGrep.d.ts +74 -0
  1596. package/dist/src/tools/ripGrep.js +398 -0
  1597. package/dist/src/tools/ripGrep.js.map +1 -0
  1598. package/dist/src/tools/ripGrep.test.d.ts +6 -0
  1599. package/dist/src/tools/ripGrep.test.js +1139 -0
  1600. package/dist/src/tools/ripGrep.test.js.map +1 -0
  1601. package/dist/src/tools/shell.d.ts +32 -0
  1602. package/dist/src/tools/shell.js +381 -0
  1603. package/dist/src/tools/shell.js.map +1 -0
  1604. package/dist/src/tools/shell.test.d.ts +6 -0
  1605. package/dist/src/tools/shell.test.js +526 -0
  1606. package/dist/src/tools/shell.test.js.map +1 -0
  1607. package/dist/src/tools/tool-error.d.ts +70 -0
  1608. package/dist/src/tools/tool-error.js +92 -0
  1609. package/dist/src/tools/tool-error.js.map +1 -0
  1610. package/dist/src/tools/tool-names.d.ts +40 -0
  1611. package/dist/src/tools/tool-names.js +92 -0
  1612. package/dist/src/tools/tool-names.js.map +1 -0
  1613. package/dist/src/tools/tool-names.test.d.ts +6 -0
  1614. package/dist/src/tools/tool-names.test.js +43 -0
  1615. package/dist/src/tools/tool-names.test.js.map +1 -0
  1616. package/dist/src/tools/tool-registry.d.ts +103 -0
  1617. package/dist/src/tools/tool-registry.js +429 -0
  1618. package/dist/src/tools/tool-registry.js.map +1 -0
  1619. package/dist/src/tools/tool-registry.test.d.ts +6 -0
  1620. package/dist/src/tools/tool-registry.test.js +461 -0
  1621. package/dist/src/tools/tool-registry.test.js.map +1 -0
  1622. package/dist/src/tools/tools.d.ts +330 -0
  1623. package/dist/src/tools/tools.js +405 -0
  1624. package/dist/src/tools/tools.js.map +1 -0
  1625. package/dist/src/tools/tools.test.d.ts +6 -0
  1626. package/dist/src/tools/tools.test.js +207 -0
  1627. package/dist/src/tools/tools.test.js.map +1 -0
  1628. package/dist/src/tools/web-fetch.d.ts +35 -0
  1629. package/dist/src/tools/web-fetch.js +299 -0
  1630. package/dist/src/tools/web-fetch.js.map +1 -0
  1631. package/dist/src/tools/web-fetch.test.d.ts +6 -0
  1632. package/dist/src/tools/web-fetch.test.js +442 -0
  1633. package/dist/src/tools/web-fetch.test.js.map +1 -0
  1634. package/dist/src/tools/web-search.d.ts +50 -0
  1635. package/dist/src/tools/web-search.js +141 -0
  1636. package/dist/src/tools/web-search.js.map +1 -0
  1637. package/dist/src/tools/web-search.test.d.ts +6 -0
  1638. package/dist/src/tools/web-search.test.js +214 -0
  1639. package/dist/src/tools/web-search.test.js.map +1 -0
  1640. package/dist/src/tools/write-file.d.ts +53 -0
  1641. package/dist/src/tools/write-file.js +318 -0
  1642. package/dist/src/tools/write-file.js.map +1 -0
  1643. package/dist/src/tools/write-file.test.d.ts +6 -0
  1644. package/dist/src/tools/write-file.test.js +681 -0
  1645. package/dist/src/tools/write-file.test.js.map +1 -0
  1646. package/dist/src/tools/write-todos.d.ts +50 -0
  1647. package/dist/src/tools/write-todos.js +194 -0
  1648. package/dist/src/tools/write-todos.js.map +1 -0
  1649. package/dist/src/tools/write-todos.test.d.ts +6 -0
  1650. package/dist/src/tools/write-todos.test.js +90 -0
  1651. package/dist/src/tools/write-todos.test.js.map +1 -0
  1652. package/dist/src/utils/apiConversionUtils.d.ts +12 -0
  1653. package/dist/src/utils/apiConversionUtils.js +46 -0
  1654. package/dist/src/utils/apiConversionUtils.js.map +1 -0
  1655. package/dist/src/utils/apiConversionUtils.test.d.ts +6 -0
  1656. package/dist/src/utils/apiConversionUtils.test.js +150 -0
  1657. package/dist/src/utils/apiConversionUtils.test.js.map +1 -0
  1658. package/dist/src/utils/bfsFileSearch.d.ts +32 -0
  1659. package/dist/src/utils/bfsFileSearch.js +136 -0
  1660. package/dist/src/utils/bfsFileSearch.js.map +1 -0
  1661. package/dist/src/utils/bfsFileSearch.test.d.ts +6 -0
  1662. package/dist/src/utils/bfsFileSearch.test.js +227 -0
  1663. package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
  1664. package/dist/src/utils/browser.d.ts +13 -0
  1665. package/dist/src/utils/browser.js +50 -0
  1666. package/dist/src/utils/browser.js.map +1 -0
  1667. package/dist/src/utils/channel.d.ts +19 -0
  1668. package/dist/src/utils/channel.js +49 -0
  1669. package/dist/src/utils/channel.js.map +1 -0
  1670. package/dist/src/utils/channel.test.d.ts +6 -0
  1671. package/dist/src/utils/channel.test.js +170 -0
  1672. package/dist/src/utils/channel.test.js.map +1 -0
  1673. package/dist/src/utils/checkpointUtils.d.ts +82 -0
  1674. package/dist/src/utils/checkpointUtils.js +117 -0
  1675. package/dist/src/utils/checkpointUtils.js.map +1 -0
  1676. package/dist/src/utils/checkpointUtils.test.d.ts +6 -0
  1677. package/dist/src/utils/checkpointUtils.test.js +229 -0
  1678. package/dist/src/utils/checkpointUtils.test.js.map +1 -0
  1679. package/dist/src/utils/constants.d.ts +7 -0
  1680. package/dist/src/utils/constants.js +8 -0
  1681. package/dist/src/utils/constants.js.map +1 -0
  1682. package/dist/src/utils/customHeaderUtils.d.ts +9 -0
  1683. package/dist/src/utils/customHeaderUtils.js +34 -0
  1684. package/dist/src/utils/customHeaderUtils.js.map +1 -0
  1685. package/dist/src/utils/customHeaderUtils.test.d.ts +6 -0
  1686. package/dist/src/utils/customHeaderUtils.test.js +77 -0
  1687. package/dist/src/utils/customHeaderUtils.test.js.map +1 -0
  1688. package/dist/src/utils/debugLogger.d.ts +28 -0
  1689. package/dist/src/utils/debugLogger.js +61 -0
  1690. package/dist/src/utils/debugLogger.js.map +1 -0
  1691. package/dist/src/utils/debugLogger.test.d.ts +6 -0
  1692. package/dist/src/utils/debugLogger.test.js +69 -0
  1693. package/dist/src/utils/debugLogger.test.js.map +1 -0
  1694. package/dist/src/utils/delay.d.ts +16 -0
  1695. package/dist/src/utils/delay.js +43 -0
  1696. package/dist/src/utils/delay.js.map +1 -0
  1697. package/dist/src/utils/delay.test.d.ts +6 -0
  1698. package/dist/src/utils/delay.test.js +88 -0
  1699. package/dist/src/utils/delay.test.js.map +1 -0
  1700. package/dist/src/utils/editCorrector.d.ts +54 -0
  1701. package/dist/src/utils/editCorrector.js +594 -0
  1702. package/dist/src/utils/editCorrector.js.map +1 -0
  1703. package/dist/src/utils/editCorrector.test.d.ts +6 -0
  1704. package/dist/src/utils/editCorrector.test.js +533 -0
  1705. package/dist/src/utils/editCorrector.test.js.map +1 -0
  1706. package/dist/src/utils/editor.d.ts +39 -0
  1707. package/dist/src/utils/editor.js +219 -0
  1708. package/dist/src/utils/editor.js.map +1 -0
  1709. package/dist/src/utils/editor.test.d.ts +6 -0
  1710. package/dist/src/utils/editor.test.js +429 -0
  1711. package/dist/src/utils/editor.test.js.map +1 -0
  1712. package/dist/src/utils/environmentContext.d.ts +23 -0
  1713. package/dist/src/utils/environmentContext.js +81 -0
  1714. package/dist/src/utils/environmentContext.js.map +1 -0
  1715. package/dist/src/utils/environmentContext.test.d.ts +6 -0
  1716. package/dist/src/utils/environmentContext.test.js +114 -0
  1717. package/dist/src/utils/environmentContext.test.js.map +1 -0
  1718. package/dist/src/utils/errorParsing.d.ts +8 -0
  1719. package/dist/src/utils/errorParsing.js +65 -0
  1720. package/dist/src/utils/errorParsing.js.map +1 -0
  1721. package/dist/src/utils/errorParsing.test.d.ts +6 -0
  1722. package/dist/src/utils/errorParsing.test.js +84 -0
  1723. package/dist/src/utils/errorParsing.test.js.map +1 -0
  1724. package/dist/src/utils/errorReporting.d.ts +14 -0
  1725. package/dist/src/utils/errorReporting.js +89 -0
  1726. package/dist/src/utils/errorReporting.js.map +1 -0
  1727. package/dist/src/utils/errorReporting.test.d.ts +6 -0
  1728. package/dist/src/utils/errorReporting.test.js +133 -0
  1729. package/dist/src/utils/errorReporting.test.js.map +1 -0
  1730. package/dist/src/utils/errors.d.ts +53 -0
  1731. package/dist/src/utils/errors.js +145 -0
  1732. package/dist/src/utils/errors.js.map +1 -0
  1733. package/dist/src/utils/errors.test.d.ts +6 -0
  1734. package/dist/src/utils/errors.test.js +155 -0
  1735. package/dist/src/utils/errors.test.js.map +1 -0
  1736. package/dist/src/utils/events.d.ts +198 -0
  1737. package/dist/src/utils/events.js +127 -0
  1738. package/dist/src/utils/events.js.map +1 -0
  1739. package/dist/src/utils/events.test.d.ts +6 -0
  1740. package/dist/src/utils/events.test.js +237 -0
  1741. package/dist/src/utils/events.test.js.map +1 -0
  1742. package/dist/src/utils/exitCodes.d.ts +12 -0
  1743. package/dist/src/utils/exitCodes.js +13 -0
  1744. package/dist/src/utils/exitCodes.js.map +1 -0
  1745. package/dist/src/utils/extensionLoader.d.ts +86 -0
  1746. package/dist/src/utils/extensionLoader.js +208 -0
  1747. package/dist/src/utils/extensionLoader.js.map +1 -0
  1748. package/dist/src/utils/extensionLoader.test.d.ts +6 -0
  1749. package/dist/src/utils/extensionLoader.test.js +176 -0
  1750. package/dist/src/utils/extensionLoader.test.js.map +1 -0
  1751. package/dist/src/utils/fetch.d.ts +12 -0
  1752. package/dist/src/utils/fetch.js +55 -0
  1753. package/dist/src/utils/fetch.js.map +1 -0
  1754. package/dist/src/utils/fileDiffUtils.d.ts +18 -0
  1755. package/dist/src/utils/fileDiffUtils.js +37 -0
  1756. package/dist/src/utils/fileDiffUtils.js.map +1 -0
  1757. package/dist/src/utils/fileDiffUtils.test.d.ts +6 -0
  1758. package/dist/src/utils/fileDiffUtils.test.js +84 -0
  1759. package/dist/src/utils/fileDiffUtils.test.js.map +1 -0
  1760. package/dist/src/utils/fileUtils.d.ts +85 -0
  1761. package/dist/src/utils/fileUtils.js +490 -0
  1762. package/dist/src/utils/fileUtils.js.map +1 -0
  1763. package/dist/src/utils/fileUtils.test.d.ts +6 -0
  1764. package/dist/src/utils/fileUtils.test.js +780 -0
  1765. package/dist/src/utils/fileUtils.test.js.map +1 -0
  1766. package/dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  1767. package/dist/src/utils/filesearch/crawlCache.js +57 -0
  1768. package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
  1769. package/dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  1770. package/dist/src/utils/filesearch/crawlCache.test.js +103 -0
  1771. package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  1772. package/dist/src/utils/filesearch/crawler.d.ts +16 -0
  1773. package/dist/src/utils/filesearch/crawler.js +67 -0
  1774. package/dist/src/utils/filesearch/crawler.js.map +1 -0
  1775. package/dist/src/utils/filesearch/crawler.test.d.ts +6 -0
  1776. package/dist/src/utils/filesearch/crawler.test.js +495 -0
  1777. package/dist/src/utils/filesearch/crawler.test.js.map +1 -0
  1778. package/dist/src/utils/filesearch/fileSearch.d.ts +39 -0
  1779. package/dist/src/utils/filesearch/fileSearch.js +192 -0
  1780. package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
  1781. package/dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  1782. package/dist/src/utils/filesearch/fileSearch.test.js +663 -0
  1783. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  1784. package/dist/src/utils/filesearch/ignore.d.ts +42 -0
  1785. package/dist/src/utils/filesearch/ignore.js +106 -0
  1786. package/dist/src/utils/filesearch/ignore.js.map +1 -0
  1787. package/dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  1788. package/dist/src/utils/filesearch/ignore.test.js +144 -0
  1789. package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
  1790. package/dist/src/utils/filesearch/result-cache.d.ts +33 -0
  1791. package/dist/src/utils/filesearch/result-cache.js +59 -0
  1792. package/dist/src/utils/filesearch/result-cache.js.map +1 -0
  1793. package/dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  1794. package/dist/src/utils/filesearch/result-cache.test.js +46 -0
  1795. package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  1796. package/dist/src/utils/flashFallback.test.d.ts +6 -0
  1797. package/dist/src/utils/flashFallback.test.js +103 -0
  1798. package/dist/src/utils/flashFallback.test.js.map +1 -0
  1799. package/dist/src/utils/formatters.d.ts +7 -0
  1800. package/dist/src/utils/formatters.js +17 -0
  1801. package/dist/src/utils/formatters.js.map +1 -0
  1802. package/dist/src/utils/formatters.test.d.ts +6 -0
  1803. package/dist/src/utils/formatters.test.js +26 -0
  1804. package/dist/src/utils/formatters.test.js.map +1 -0
  1805. package/dist/src/utils/geminiIgnoreParser.d.ts +29 -0
  1806. package/dist/src/utils/geminiIgnoreParser.js +81 -0
  1807. package/dist/src/utils/geminiIgnoreParser.js.map +1 -0
  1808. package/dist/src/utils/geminiIgnoreParser.test.d.ts +6 -0
  1809. package/dist/src/utils/geminiIgnoreParser.test.js +98 -0
  1810. package/dist/src/utils/geminiIgnoreParser.test.js.map +1 -0
  1811. package/dist/src/utils/geminiTypeConversion.d.ts +11 -0
  1812. package/dist/src/utils/geminiTypeConversion.js +12 -0
  1813. package/dist/src/utils/geminiTypeConversion.js.map +1 -0
  1814. package/dist/src/utils/geminiTypeConversion.test.d.ts +6 -0
  1815. package/dist/src/utils/geminiTypeConversion.test.js +310 -0
  1816. package/dist/src/utils/geminiTypeConversion.test.js.map +1 -0
  1817. package/dist/src/utils/generateContentResponseUtilities.d.ts +15 -0
  1818. package/dist/src/utils/generateContentResponseUtilities.js +186 -0
  1819. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  1820. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  1821. package/dist/src/utils/generateContentResponseUtilities.test.js +512 -0
  1822. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  1823. package/dist/src/utils/getFolderStructure.d.ts +31 -0
  1824. package/dist/src/utils/getFolderStructure.js +243 -0
  1825. package/dist/src/utils/getFolderStructure.js.map +1 -0
  1826. package/dist/src/utils/getFolderStructure.test.d.ts +6 -0
  1827. package/dist/src/utils/getFolderStructure.test.js +283 -0
  1828. package/dist/src/utils/getFolderStructure.test.js.map +1 -0
  1829. package/dist/src/utils/getPty.d.ts +19 -0
  1830. package/dist/src/utils/getPty.js +23 -0
  1831. package/dist/src/utils/getPty.js.map +1 -0
  1832. package/dist/src/utils/gitIgnoreParser.d.ts +19 -0
  1833. package/dist/src/utils/gitIgnoreParser.js +169 -0
  1834. package/dist/src/utils/gitIgnoreParser.js.map +1 -0
  1835. package/dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  1836. package/dist/src/utils/gitIgnoreParser.test.js +243 -0
  1837. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  1838. package/dist/src/utils/gitUtils.d.ts +17 -0
  1839. package/dist/src/utils/gitUtils.js +61 -0
  1840. package/dist/src/utils/gitUtils.js.map +1 -0
  1841. package/dist/src/utils/googleErrors.d.ts +104 -0
  1842. package/dist/src/utils/googleErrors.js +165 -0
  1843. package/dist/src/utils/googleErrors.js.map +1 -0
  1844. package/dist/src/utils/googleErrors.test.d.ts +6 -0
  1845. package/dist/src/utils/googleErrors.test.js +309 -0
  1846. package/dist/src/utils/googleErrors.test.js.map +1 -0
  1847. package/dist/src/utils/googleQuotaErrors.d.ts +51 -0
  1848. package/dist/src/utils/googleQuotaErrors.js +250 -0
  1849. package/dist/src/utils/googleQuotaErrors.js.map +1 -0
  1850. package/dist/src/utils/googleQuotaErrors.test.d.ts +6 -0
  1851. package/dist/src/utils/googleQuotaErrors.test.js +548 -0
  1852. package/dist/src/utils/googleQuotaErrors.test.js.map +1 -0
  1853. package/dist/src/utils/httpErrors.d.ts +18 -0
  1854. package/dist/src/utils/httpErrors.js +36 -0
  1855. package/dist/src/utils/httpErrors.js.map +1 -0
  1856. package/dist/src/utils/ignorePatterns.d.ts +103 -0
  1857. package/dist/src/utils/ignorePatterns.js +220 -0
  1858. package/dist/src/utils/ignorePatterns.js.map +1 -0
  1859. package/dist/src/utils/ignorePatterns.test.d.ts +6 -0
  1860. package/dist/src/utils/ignorePatterns.test.js +246 -0
  1861. package/dist/src/utils/ignorePatterns.test.js.map +1 -0
  1862. package/dist/src/utils/installationManager.d.ts +16 -0
  1863. package/dist/src/utils/installationManager.js +51 -0
  1864. package/dist/src/utils/installationManager.js.map +1 -0
  1865. package/dist/src/utils/installationManager.test.d.ts +6 -0
  1866. package/dist/src/utils/installationManager.test.js +93 -0
  1867. package/dist/src/utils/installationManager.test.js.map +1 -0
  1868. package/dist/src/utils/language-detection.d.ts +6 -0
  1869. package/dist/src/utils/language-detection.js +101 -0
  1870. package/dist/src/utils/language-detection.js.map +1 -0
  1871. package/dist/src/utils/llm-edit-fixer.d.ts +26 -0
  1872. package/dist/src/utils/llm-edit-fixer.js +152 -0
  1873. package/dist/src/utils/llm-edit-fixer.js.map +1 -0
  1874. package/dist/src/utils/llm-edit-fixer.test.d.ts +6 -0
  1875. package/dist/src/utils/llm-edit-fixer.test.js +223 -0
  1876. package/dist/src/utils/llm-edit-fixer.test.js.map +1 -0
  1877. package/dist/src/utils/llmUtils.d.ts +38 -0
  1878. package/dist/src/utils/llmUtils.js +64 -0
  1879. package/dist/src/utils/llmUtils.js.map +1 -0
  1880. package/dist/src/utils/llmUtils.test.d.ts +6 -0
  1881. package/dist/src/utils/llmUtils.test.js +196 -0
  1882. package/dist/src/utils/llmUtils.test.js.map +1 -0
  1883. package/dist/src/utils/memoryDiscovery.d.ts +40 -0
  1884. package/dist/src/utils/memoryDiscovery.js +421 -0
  1885. package/dist/src/utils/memoryDiscovery.js.map +1 -0
  1886. package/dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  1887. package/dist/src/utils/memoryDiscovery.test.js +542 -0
  1888. package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
  1889. package/dist/src/utils/memoryImportProcessor.d.ts +42 -0
  1890. package/dist/src/utils/memoryImportProcessor.js +273 -0
  1891. package/dist/src/utils/memoryImportProcessor.js.map +1 -0
  1892. package/dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  1893. package/dist/src/utils/memoryImportProcessor.test.js +581 -0
  1894. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  1895. package/dist/src/utils/messageInspectors.d.ts +16 -0
  1896. package/dist/src/utils/messageInspectors.js +24 -0
  1897. package/dist/src/utils/messageInspectors.js.map +1 -0
  1898. package/dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  1899. package/dist/src/utils/nextSpeakerChecker.js +97 -0
  1900. package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
  1901. package/dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  1902. package/dist/src/utils/nextSpeakerChecker.test.js +191 -0
  1903. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  1904. package/dist/src/utils/package.d.ts +26 -0
  1905. package/dist/src/utils/package.js +28 -0
  1906. package/dist/src/utils/package.js.map +1 -0
  1907. package/dist/src/utils/partUtils.d.ts +76 -0
  1908. package/dist/src/utils/partUtils.js +237 -0
  1909. package/dist/src/utils/partUtils.js.map +1 -0
  1910. package/dist/src/utils/partUtils.test.d.ts +6 -0
  1911. package/dist/src/utils/partUtils.test.js +397 -0
  1912. package/dist/src/utils/partUtils.test.js.map +1 -0
  1913. package/dist/src/utils/pathCorrector.d.ts +25 -0
  1914. package/dist/src/utils/pathCorrector.js +43 -0
  1915. package/dist/src/utils/pathCorrector.js.map +1 -0
  1916. package/dist/src/utils/pathCorrector.test.d.ts +6 -0
  1917. package/dist/src/utils/pathCorrector.test.js +87 -0
  1918. package/dist/src/utils/pathCorrector.test.js.map +1 -0
  1919. package/dist/src/utils/pathReader.d.ts +17 -0
  1920. package/dist/src/utils/pathReader.js +92 -0
  1921. package/dist/src/utils/pathReader.js.map +1 -0
  1922. package/dist/src/utils/pathReader.test.d.ts +6 -0
  1923. package/dist/src/utils/pathReader.test.js +406 -0
  1924. package/dist/src/utils/pathReader.test.js.map +1 -0
  1925. package/dist/src/utils/paths.d.ts +78 -0
  1926. package/dist/src/utils/paths.js +311 -0
  1927. package/dist/src/utils/paths.js.map +1 -0
  1928. package/dist/src/utils/paths.test.d.ts +6 -0
  1929. package/dist/src/utils/paths.test.js +402 -0
  1930. package/dist/src/utils/paths.test.js.map +1 -0
  1931. package/dist/src/utils/promptIdContext.d.ts +13 -0
  1932. package/dist/src/utils/promptIdContext.js +23 -0
  1933. package/dist/src/utils/promptIdContext.js.map +1 -0
  1934. package/dist/src/utils/quotaErrorDetection.d.ts +16 -0
  1935. package/dist/src/utils/quotaErrorDetection.js +19 -0
  1936. package/dist/src/utils/quotaErrorDetection.js.map +1 -0
  1937. package/dist/src/utils/retry.d.ts +43 -0
  1938. package/dist/src/utils/retry.js +337 -0
  1939. package/dist/src/utils/retry.js.map +1 -0
  1940. package/dist/src/utils/retry.test.d.ts +6 -0
  1941. package/dist/src/utils/retry.test.js +548 -0
  1942. package/dist/src/utils/retry.test.js.map +1 -0
  1943. package/dist/src/utils/retry_llm_error.test.d.ts +6 -0
  1944. package/dist/src/utils/retry_llm_error.test.js +280 -0
  1945. package/dist/src/utils/retry_llm_error.test.js.map +1 -0
  1946. package/dist/src/utils/safeJsonStringify.d.ts +13 -0
  1947. package/dist/src/utils/safeJsonStringify.js +49 -0
  1948. package/dist/src/utils/safeJsonStringify.js.map +1 -0
  1949. package/dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  1950. package/dist/src/utils/safeJsonStringify.test.js +61 -0
  1951. package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
  1952. package/dist/src/utils/schemaValidator.d.ts +21 -0
  1953. package/dist/src/utils/schemaValidator.js +59 -0
  1954. package/dist/src/utils/schemaValidator.js.map +1 -0
  1955. package/dist/src/utils/schemaValidator.test.d.ts +6 -0
  1956. package/dist/src/utils/schemaValidator.test.js +113 -0
  1957. package/dist/src/utils/schemaValidator.test.js.map +1 -0
  1958. package/dist/src/utils/secure-browser-launcher.d.ts +23 -0
  1959. package/dist/src/utils/secure-browser-launcher.js +165 -0
  1960. package/dist/src/utils/secure-browser-launcher.js.map +1 -0
  1961. package/dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  1962. package/dist/src/utils/secure-browser-launcher.test.js +149 -0
  1963. package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  1964. package/dist/src/utils/security.d.ts +16 -0
  1965. package/dist/src/utils/security.js +88 -0
  1966. package/dist/src/utils/security.js.map +1 -0
  1967. package/dist/src/utils/security.test.d.ts +1 -0
  1968. package/dist/src/utils/security.test.js +121 -0
  1969. package/dist/src/utils/security.test.js.map +1 -0
  1970. package/dist/src/utils/session.d.ts +6 -0
  1971. package/dist/src/utils/session.js +8 -0
  1972. package/dist/src/utils/session.js.map +1 -0
  1973. package/dist/src/utils/shell-utils.d.ts +118 -0
  1974. package/dist/src/utils/shell-utils.integration.test.d.ts +1 -0
  1975. package/dist/src/utils/shell-utils.integration.test.js +58 -0
  1976. package/dist/src/utils/shell-utils.integration.test.js.map +1 -0
  1977. package/dist/src/utils/shell-utils.js +708 -0
  1978. package/dist/src/utils/shell-utils.js.map +1 -0
  1979. package/dist/src/utils/shell-utils.test.d.ts +6 -0
  1980. package/dist/src/utils/shell-utils.test.js +437 -0
  1981. package/dist/src/utils/shell-utils.test.js.map +1 -0
  1982. package/dist/src/utils/stdio.d.ts +32 -0
  1983. package/dist/src/utils/stdio.js +85 -0
  1984. package/dist/src/utils/stdio.js.map +1 -0
  1985. package/dist/src/utils/stdio.test.d.ts +6 -0
  1986. package/dist/src/utils/stdio.test.js +47 -0
  1987. package/dist/src/utils/stdio.test.js.map +1 -0
  1988. package/dist/src/utils/summarizer.d.ts +27 -0
  1989. package/dist/src/utils/summarizer.js +50 -0
  1990. package/dist/src/utils/summarizer.js.map +1 -0
  1991. package/dist/src/utils/summarizer.test.d.ts +6 -0
  1992. package/dist/src/utils/summarizer.test.js +152 -0
  1993. package/dist/src/utils/summarizer.test.js.map +1 -0
  1994. package/dist/src/utils/systemEncoding.d.ts +40 -0
  1995. package/dist/src/utils/systemEncoding.js +150 -0
  1996. package/dist/src/utils/systemEncoding.js.map +1 -0
  1997. package/dist/src/utils/systemEncoding.test.d.ts +6 -0
  1998. package/dist/src/utils/systemEncoding.test.js +369 -0
  1999. package/dist/src/utils/systemEncoding.test.js.map +1 -0
  2000. package/dist/src/utils/terminal.d.ts +18 -0
  2001. package/dist/src/utils/terminal.js +50 -0
  2002. package/dist/src/utils/terminal.js.map +1 -0
  2003. package/dist/src/utils/terminalSerializer.d.ts +25 -0
  2004. package/dist/src/utils/terminalSerializer.js +432 -0
  2005. package/dist/src/utils/terminalSerializer.js.map +1 -0
  2006. package/dist/src/utils/terminalSerializer.test.d.ts +6 -0
  2007. package/dist/src/utils/terminalSerializer.test.js +193 -0
  2008. package/dist/src/utils/terminalSerializer.test.js.map +1 -0
  2009. package/dist/src/utils/testUtils.d.ts +29 -0
  2010. package/dist/src/utils/testUtils.js +70 -0
  2011. package/dist/src/utils/testUtils.js.map +1 -0
  2012. package/dist/src/utils/textUtils.d.ts +26 -0
  2013. package/dist/src/utils/textUtils.js +55 -0
  2014. package/dist/src/utils/textUtils.js.map +1 -0
  2015. package/dist/src/utils/textUtils.test.d.ts +6 -0
  2016. package/dist/src/utils/textUtils.test.js +76 -0
  2017. package/dist/src/utils/textUtils.test.js.map +1 -0
  2018. package/dist/src/utils/thoughtUtils.d.ts +21 -0
  2019. package/dist/src/utils/thoughtUtils.js +39 -0
  2020. package/dist/src/utils/thoughtUtils.js.map +1 -0
  2021. package/dist/src/utils/thoughtUtils.test.d.ts +6 -0
  2022. package/dist/src/utils/thoughtUtils.test.js +78 -0
  2023. package/dist/src/utils/thoughtUtils.test.js.map +1 -0
  2024. package/dist/src/utils/tokenCalculation.d.ts +33 -0
  2025. package/dist/src/utils/tokenCalculation.js +145 -0
  2026. package/dist/src/utils/tokenCalculation.js.map +1 -0
  2027. package/dist/src/utils/tokenCalculation.test.d.ts +6 -0
  2028. package/dist/src/utils/tokenCalculation.test.js +184 -0
  2029. package/dist/src/utils/tokenCalculation.test.js.map +1 -0
  2030. package/dist/src/utils/tool-utils.d.ts +28 -0
  2031. package/dist/src/utils/tool-utils.js +96 -0
  2032. package/dist/src/utils/tool-utils.js.map +1 -0
  2033. package/dist/src/utils/tool-utils.test.d.ts +6 -0
  2034. package/dist/src/utils/tool-utils.test.js +84 -0
  2035. package/dist/src/utils/tool-utils.test.js.map +1 -0
  2036. package/dist/src/utils/toolCallContext.d.ts +35 -0
  2037. package/dist/src/utils/toolCallContext.js +29 -0
  2038. package/dist/src/utils/toolCallContext.js.map +1 -0
  2039. package/dist/src/utils/toolCallContext.test.d.ts +6 -0
  2040. package/dist/src/utils/toolCallContext.test.js +68 -0
  2041. package/dist/src/utils/toolCallContext.test.js.map +1 -0
  2042. package/dist/src/utils/userAccountManager.d.ts +20 -0
  2043. package/dist/src/utils/userAccountManager.js +115 -0
  2044. package/dist/src/utils/userAccountManager.js.map +1 -0
  2045. package/dist/src/utils/userAccountManager.test.d.ts +6 -0
  2046. package/dist/src/utils/userAccountManager.test.js +225 -0
  2047. package/dist/src/utils/userAccountManager.test.js.map +1 -0
  2048. package/dist/src/utils/version.d.ts +6 -0
  2049. package/dist/src/utils/version.js +15 -0
  2050. package/dist/src/utils/version.js.map +1 -0
  2051. package/dist/src/utils/version.test.d.ts +6 -0
  2052. package/dist/src/utils/version.test.js +39 -0
  2053. package/dist/src/utils/version.test.js.map +1 -0
  2054. package/dist/src/utils/workspaceContext.d.ts +82 -0
  2055. package/dist/src/utils/workspaceContext.js +192 -0
  2056. package/dist/src/utils/workspaceContext.js.map +1 -0
  2057. package/dist/src/utils/workspaceContext.test.d.ts +6 -0
  2058. package/dist/src/utils/workspaceContext.test.js +374 -0
  2059. package/dist/src/utils/workspaceContext.test.js.map +1 -0
  2060. package/dist/tsconfig.tsbuildinfo +1 -0
  2061. package/package.json +99 -0
@@ -0,0 +1,1684 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, vi } from 'vitest';
7
+ import { CoreToolScheduler, PLAN_MODE_DENIAL_MESSAGE, } from './coreToolScheduler.js';
8
+ import { DEFAULT_TRUNCATE_TOOL_OUTPUT_LINES, DEFAULT_TRUNCATE_TOOL_OUTPUT_THRESHOLD, BaseDeclarativeTool, BaseToolInvocation, ToolConfirmationOutcome, Kind, ApprovalMode, HookSystem, PolicyDecision, ToolErrorType, } from '../index.js';
9
+ import { createMockMessageBus } from '../test-utils/mock-message-bus.js';
10
+ import { MockModifiableTool, MockTool, MOCK_TOOL_SHOULD_CONFIRM_EXECUTE, } from '../test-utils/mock-tool.js';
11
+ import * as modifiableToolModule from '../tools/modifiable-tool.js';
12
+ import { DEFAULT_GEMINI_MODEL } from '../config/models.js';
13
+ import { DiscoveredMCPTool } from '../tools/mcp-tool.js';
14
+ vi.mock('fs/promises', () => ({
15
+ writeFile: vi.fn(),
16
+ }));
17
+ class TestApprovalTool extends BaseDeclarativeTool {
18
+ config;
19
+ static Name = 'testApprovalTool';
20
+ constructor(config, messageBus) {
21
+ super(TestApprovalTool.Name, 'TestApprovalTool', 'A tool for testing approval logic', Kind.Edit, {
22
+ properties: { id: { type: 'string' } },
23
+ required: ['id'],
24
+ type: 'object',
25
+ }, messageBus);
26
+ this.config = config;
27
+ }
28
+ createInvocation(params, messageBus, _toolName, _toolDisplayName) {
29
+ return new TestApprovalInvocation(this.config, params, messageBus);
30
+ }
31
+ }
32
+ class TestApprovalInvocation extends BaseToolInvocation {
33
+ config;
34
+ constructor(config, params, messageBus) {
35
+ super(params, messageBus);
36
+ this.config = config;
37
+ }
38
+ getDescription() {
39
+ return `Test tool ${this.params.id}`;
40
+ }
41
+ async shouldConfirmExecute() {
42
+ // Need confirmation unless approval mode is AUTO_EDIT
43
+ if (this.config.getApprovalMode() === ApprovalMode.AUTO_EDIT) {
44
+ return false;
45
+ }
46
+ return {
47
+ type: 'edit',
48
+ title: `Confirm Test Tool ${this.params.id}`,
49
+ fileName: `test-${this.params.id}.txt`,
50
+ filePath: `/test-${this.params.id}.txt`,
51
+ fileDiff: 'Test diff content',
52
+ originalContent: '',
53
+ newContent: 'Test content',
54
+ onConfirm: async (outcome) => {
55
+ if (outcome === ToolConfirmationOutcome.ProceedAlways) {
56
+ this.config.setApprovalMode(ApprovalMode.AUTO_EDIT);
57
+ }
58
+ },
59
+ };
60
+ }
61
+ async execute() {
62
+ return {
63
+ llmContent: `Executed test tool ${this.params.id}`,
64
+ returnDisplay: `Executed test tool ${this.params.id}`,
65
+ };
66
+ }
67
+ }
68
+ class AbortDuringConfirmationInvocation extends BaseToolInvocation {
69
+ abortController;
70
+ abortError;
71
+ constructor(abortController, abortError, params, messageBus) {
72
+ super(params, messageBus);
73
+ this.abortController = abortController;
74
+ this.abortError = abortError;
75
+ }
76
+ async shouldConfirmExecute(_signal) {
77
+ this.abortController.abort();
78
+ throw this.abortError;
79
+ }
80
+ async execute(_abortSignal) {
81
+ throw new Error('execute should not be called when confirmation fails');
82
+ }
83
+ getDescription() {
84
+ return 'Abort during confirmation invocation';
85
+ }
86
+ }
87
+ class AbortDuringConfirmationTool extends BaseDeclarativeTool {
88
+ abortController;
89
+ abortError;
90
+ constructor(abortController, abortError, messageBus) {
91
+ super('abortDuringConfirmationTool', 'Abort During Confirmation Tool', 'A tool that aborts while confirming execution.', Kind.Other, {
92
+ type: 'object',
93
+ properties: {},
94
+ }, messageBus);
95
+ this.abortController = abortController;
96
+ this.abortError = abortError;
97
+ }
98
+ createInvocation(params, messageBus, _toolName, _toolDisplayName) {
99
+ return new AbortDuringConfirmationInvocation(this.abortController, this.abortError, params, messageBus);
100
+ }
101
+ }
102
+ async function waitForStatus(onToolCallsUpdate, status, timeout = 5000) {
103
+ return new Promise((resolve, reject) => {
104
+ const startTime = Date.now();
105
+ const check = () => {
106
+ if (Date.now() - startTime > timeout) {
107
+ const seenStatuses = onToolCallsUpdate.mock.calls
108
+ .flatMap((call) => call[0])
109
+ .map((toolCall) => toolCall.status);
110
+ reject(new Error(`Timed out waiting for status "${status}". Seen statuses: ${seenStatuses.join(', ')}`));
111
+ return;
112
+ }
113
+ const foundCall = onToolCallsUpdate.mock.calls
114
+ .flatMap((call) => call[0])
115
+ .find((toolCall) => toolCall.status === status);
116
+ if (foundCall) {
117
+ resolve(foundCall);
118
+ }
119
+ else {
120
+ setTimeout(check, 10); // Check again in 10ms
121
+ }
122
+ };
123
+ check();
124
+ });
125
+ }
126
+ function createMockConfig(overrides = {}) {
127
+ const defaultToolRegistry = {
128
+ getTool: () => undefined,
129
+ getToolByName: () => undefined,
130
+ getFunctionDeclarations: () => [],
131
+ tools: new Map(),
132
+ discovery: {},
133
+ registerTool: () => { },
134
+ getToolByDisplayName: () => undefined,
135
+ getTools: () => [],
136
+ discoverTools: async () => { },
137
+ getAllTools: () => [],
138
+ getToolsByServer: () => [],
139
+ getExperiments: () => { },
140
+ };
141
+ const baseConfig = {
142
+ getSessionId: () => 'test-session-id',
143
+ getUsageStatisticsEnabled: () => true,
144
+ getDebugMode: () => false,
145
+ isInteractive: () => true,
146
+ getApprovalMode: () => ApprovalMode.DEFAULT,
147
+ setApprovalMode: () => { },
148
+ getAllowedTools: () => [],
149
+ getContentGeneratorConfig: () => ({
150
+ model: 'test-model',
151
+ authType: 'oauth-personal',
152
+ }),
153
+ getShellExecutionConfig: () => ({
154
+ terminalWidth: 90,
155
+ terminalHeight: 30,
156
+ sanitizationConfig: {
157
+ enableEnvironmentVariableRedaction: true,
158
+ allowedEnvironmentVariables: [],
159
+ blockedEnvironmentVariables: [],
160
+ },
161
+ }),
162
+ storage: {
163
+ getProjectTempDir: () => '/tmp',
164
+ },
165
+ getTruncateToolOutputThreshold: () => DEFAULT_TRUNCATE_TOOL_OUTPUT_THRESHOLD,
166
+ getTruncateToolOutputLines: () => DEFAULT_TRUNCATE_TOOL_OUTPUT_LINES,
167
+ getToolRegistry: () => defaultToolRegistry,
168
+ getActiveModel: () => DEFAULT_GEMINI_MODEL,
169
+ getGeminiClient: () => null,
170
+ getMessageBus: () => createMockMessageBus(),
171
+ getEnableHooks: () => false,
172
+ getExperiments: () => { },
173
+ };
174
+ const finalConfig = { ...baseConfig, ...overrides };
175
+ // Patch the policy engine to use the final config if not overridden
176
+ if (!overrides.getPolicyEngine) {
177
+ finalConfig.getPolicyEngine = () => ({
178
+ check: async (toolCall, _serverName) => {
179
+ // Mock simple policy logic for tests
180
+ const mode = finalConfig.getApprovalMode();
181
+ if (mode === ApprovalMode.YOLO) {
182
+ return { decision: PolicyDecision.ALLOW };
183
+ }
184
+ const allowed = finalConfig.getAllowedTools();
185
+ if (allowed &&
186
+ (allowed.includes(toolCall.name) ||
187
+ allowed.some((p) => toolCall.name.startsWith(p)))) {
188
+ return { decision: PolicyDecision.ALLOW };
189
+ }
190
+ return { decision: PolicyDecision.ASK_USER };
191
+ },
192
+ });
193
+ }
194
+ return finalConfig;
195
+ }
196
+ describe('CoreToolScheduler', () => {
197
+ it('should cancel a tool call if the signal is aborted before confirmation', async () => {
198
+ const mockTool = new MockTool({
199
+ name: 'mockTool',
200
+ shouldConfirmExecute: MOCK_TOOL_SHOULD_CONFIRM_EXECUTE,
201
+ });
202
+ const declarativeTool = mockTool;
203
+ const mockToolRegistry = {
204
+ getTool: () => declarativeTool,
205
+ getFunctionDeclarations: () => [],
206
+ tools: new Map(),
207
+ discovery: {},
208
+ registerTool: () => { },
209
+ getToolByName: () => declarativeTool,
210
+ getToolByDisplayName: () => declarativeTool,
211
+ getTools: () => [],
212
+ discoverTools: async () => { },
213
+ getAllTools: () => [],
214
+ getToolsByServer: () => [],
215
+ };
216
+ const onAllToolCallsComplete = vi.fn();
217
+ const onToolCallsUpdate = vi.fn();
218
+ const mockConfig = createMockConfig({
219
+ getToolRegistry: () => mockToolRegistry,
220
+ isInteractive: () => false,
221
+ });
222
+ const scheduler = new CoreToolScheduler({
223
+ config: mockConfig,
224
+ onAllToolCallsComplete,
225
+ onToolCallsUpdate,
226
+ getPreferredEditor: () => 'vscode',
227
+ });
228
+ const abortController = new AbortController();
229
+ const request = {
230
+ callId: '1',
231
+ name: 'mockTool',
232
+ args: {},
233
+ isClientInitiated: false,
234
+ prompt_id: 'prompt-id-1',
235
+ };
236
+ abortController.abort();
237
+ await scheduler.schedule([request], abortController.signal);
238
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
239
+ const completedCalls = onAllToolCallsComplete.mock
240
+ .calls[0][0];
241
+ expect(completedCalls[0].status).toBe('cancelled');
242
+ });
243
+ it('should cancel all tools when cancelAll is called', async () => {
244
+ const mockTool1 = new MockTool({
245
+ name: 'mockTool1',
246
+ shouldConfirmExecute: MOCK_TOOL_SHOULD_CONFIRM_EXECUTE,
247
+ });
248
+ const mockTool2 = new MockTool({ name: 'mockTool2' });
249
+ const mockTool3 = new MockTool({ name: 'mockTool3' });
250
+ const mockToolRegistry = {
251
+ getTool: (name) => {
252
+ if (name === 'mockTool1')
253
+ return mockTool1;
254
+ if (name === 'mockTool2')
255
+ return mockTool2;
256
+ if (name === 'mockTool3')
257
+ return mockTool3;
258
+ return undefined;
259
+ },
260
+ getFunctionDeclarations: () => [],
261
+ tools: new Map(),
262
+ discovery: {},
263
+ registerTool: () => { },
264
+ getToolByName: (name) => {
265
+ if (name === 'mockTool1')
266
+ return mockTool1;
267
+ if (name === 'mockTool2')
268
+ return mockTool2;
269
+ if (name === 'mockTool3')
270
+ return mockTool3;
271
+ return undefined;
272
+ },
273
+ getToolByDisplayName: () => undefined,
274
+ getTools: () => [],
275
+ discoverTools: async () => { },
276
+ getAllTools: () => [],
277
+ getToolsByServer: () => [],
278
+ };
279
+ const onAllToolCallsComplete = vi.fn();
280
+ const onToolCallsUpdate = vi.fn();
281
+ const mockConfig = createMockConfig({
282
+ getToolRegistry: () => mockToolRegistry,
283
+ getHookSystem: () => undefined,
284
+ });
285
+ const scheduler = new CoreToolScheduler({
286
+ config: mockConfig,
287
+ onAllToolCallsComplete,
288
+ onToolCallsUpdate,
289
+ getPreferredEditor: () => 'vscode',
290
+ });
291
+ const abortController = new AbortController();
292
+ const requests = [
293
+ {
294
+ callId: '1',
295
+ name: 'mockTool1',
296
+ args: {},
297
+ isClientInitiated: false,
298
+ prompt_id: 'prompt-id-1',
299
+ },
300
+ {
301
+ callId: '2',
302
+ name: 'mockTool2',
303
+ args: {},
304
+ isClientInitiated: false,
305
+ prompt_id: 'prompt-id-1',
306
+ },
307
+ {
308
+ callId: '3',
309
+ name: 'mockTool3',
310
+ args: {},
311
+ isClientInitiated: false,
312
+ prompt_id: 'prompt-id-1',
313
+ },
314
+ ];
315
+ // Don't await, let it run in the background
316
+ void scheduler.schedule(requests, abortController.signal);
317
+ // Wait for the first tool to be awaiting approval
318
+ await waitForStatus(onToolCallsUpdate, 'awaiting_approval');
319
+ // Cancel all operations
320
+ scheduler.cancelAll(abortController.signal);
321
+ abortController.abort(); // Also fire the signal
322
+ await vi.waitFor(() => {
323
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
324
+ });
325
+ const completedCalls = onAllToolCallsComplete.mock
326
+ .calls[0][0];
327
+ expect(completedCalls).toHaveLength(3);
328
+ expect(completedCalls.find((c) => c.request.callId === '1')?.status).toBe('cancelled');
329
+ expect(completedCalls.find((c) => c.request.callId === '2')?.status).toBe('cancelled');
330
+ expect(completedCalls.find((c) => c.request.callId === '3')?.status).toBe('cancelled');
331
+ });
332
+ it('should cancel all tools in a batch when one is cancelled via confirmation', async () => {
333
+ const mockTool1 = new MockTool({
334
+ name: 'mockTool1',
335
+ shouldConfirmExecute: MOCK_TOOL_SHOULD_CONFIRM_EXECUTE,
336
+ });
337
+ const mockTool2 = new MockTool({ name: 'mockTool2' });
338
+ const mockTool3 = new MockTool({ name: 'mockTool3' });
339
+ const mockToolRegistry = {
340
+ getTool: (name) => {
341
+ if (name === 'mockTool1')
342
+ return mockTool1;
343
+ if (name === 'mockTool2')
344
+ return mockTool2;
345
+ if (name === 'mockTool3')
346
+ return mockTool3;
347
+ return undefined;
348
+ },
349
+ getFunctionDeclarations: () => [],
350
+ tools: new Map(),
351
+ discovery: {},
352
+ registerTool: () => { },
353
+ getToolByName: (name) => {
354
+ if (name === 'mockTool1')
355
+ return mockTool1;
356
+ if (name === 'mockTool2')
357
+ return mockTool2;
358
+ if (name === 'mockTool3')
359
+ return mockTool3;
360
+ return undefined;
361
+ },
362
+ getToolByDisplayName: () => undefined,
363
+ getTools: () => [],
364
+ discoverTools: async () => { },
365
+ getAllTools: () => [],
366
+ getToolsByServer: () => [],
367
+ };
368
+ const onAllToolCallsComplete = vi.fn();
369
+ const onToolCallsUpdate = vi.fn();
370
+ const mockConfig = createMockConfig({
371
+ getToolRegistry: () => mockToolRegistry,
372
+ getHookSystem: () => undefined,
373
+ });
374
+ const scheduler = new CoreToolScheduler({
375
+ config: mockConfig,
376
+ onAllToolCallsComplete,
377
+ onToolCallsUpdate,
378
+ getPreferredEditor: () => 'vscode',
379
+ });
380
+ const abortController = new AbortController();
381
+ const requests = [
382
+ {
383
+ callId: '1',
384
+ name: 'mockTool1',
385
+ args: {},
386
+ isClientInitiated: false,
387
+ prompt_id: 'prompt-id-1',
388
+ },
389
+ {
390
+ callId: '2',
391
+ name: 'mockTool2',
392
+ args: {},
393
+ isClientInitiated: false,
394
+ prompt_id: 'prompt-id-1',
395
+ },
396
+ {
397
+ callId: '3',
398
+ name: 'mockTool3',
399
+ args: {},
400
+ isClientInitiated: false,
401
+ prompt_id: 'prompt-id-1',
402
+ },
403
+ ];
404
+ // Don't await, let it run in the background
405
+ void scheduler.schedule(requests, abortController.signal);
406
+ // Wait for the first tool to be awaiting approval
407
+ const awaitingCall = (await waitForStatus(onToolCallsUpdate, 'awaiting_approval'));
408
+ // Cancel the first tool via its confirmation handler
409
+ const confirmationDetails = awaitingCall.confirmationDetails;
410
+ await confirmationDetails.onConfirm(ToolConfirmationOutcome.Cancel);
411
+ abortController.abort(); // User cancelling often involves an abort signal
412
+ await vi.waitFor(() => {
413
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
414
+ });
415
+ const completedCalls = onAllToolCallsComplete.mock
416
+ .calls[0][0];
417
+ expect(completedCalls).toHaveLength(3);
418
+ expect(completedCalls.find((c) => c.request.callId === '1')?.status).toBe('cancelled');
419
+ expect(completedCalls.find((c) => c.request.callId === '2')?.status).toBe('cancelled');
420
+ expect(completedCalls.find((c) => c.request.callId === '3')?.status).toBe('cancelled');
421
+ });
422
+ it('should mark tool call as cancelled when abort happens during confirmation error', async () => {
423
+ const abortController = new AbortController();
424
+ const abortError = new Error('Abort requested during confirmation');
425
+ const declarativeTool = new AbortDuringConfirmationTool(abortController, abortError, createMockMessageBus());
426
+ const mockToolRegistry = {
427
+ getTool: () => declarativeTool,
428
+ getFunctionDeclarations: () => [],
429
+ tools: new Map(),
430
+ discovery: {},
431
+ registerTool: () => { },
432
+ getToolByName: () => declarativeTool,
433
+ getToolByDisplayName: () => declarativeTool,
434
+ getTools: () => [],
435
+ discoverTools: async () => { },
436
+ getAllTools: () => [],
437
+ getToolsByServer: () => [],
438
+ };
439
+ const onAllToolCallsComplete = vi.fn();
440
+ const onToolCallsUpdate = vi.fn();
441
+ const mockConfig = createMockConfig({
442
+ getToolRegistry: () => mockToolRegistry,
443
+ isInteractive: () => true,
444
+ });
445
+ const scheduler = new CoreToolScheduler({
446
+ config: mockConfig,
447
+ onAllToolCallsComplete,
448
+ onToolCallsUpdate,
449
+ getPreferredEditor: () => 'vscode',
450
+ });
451
+ const request = {
452
+ callId: 'abort-1',
453
+ name: 'abortDuringConfirmationTool',
454
+ args: {},
455
+ isClientInitiated: false,
456
+ prompt_id: 'prompt-id-abort',
457
+ };
458
+ await scheduler.schedule([request], abortController.signal);
459
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
460
+ const completedCalls = onAllToolCallsComplete.mock
461
+ .calls[0][0];
462
+ expect(completedCalls[0].status).toBe('cancelled');
463
+ const statuses = onToolCallsUpdate.mock.calls.flatMap((call) => call[0].map((toolCall) => toolCall.status));
464
+ expect(statuses).not.toContain('error');
465
+ });
466
+ it('should error when tool requires confirmation in non-interactive mode', async () => {
467
+ const mockTool = new MockTool({
468
+ name: 'mockTool',
469
+ shouldConfirmExecute: MOCK_TOOL_SHOULD_CONFIRM_EXECUTE,
470
+ });
471
+ const declarativeTool = mockTool;
472
+ const mockToolRegistry = {
473
+ getTool: () => declarativeTool,
474
+ getFunctionDeclarations: () => [],
475
+ tools: new Map(),
476
+ discovery: {},
477
+ registerTool: () => { },
478
+ getToolByName: () => declarativeTool,
479
+ getToolByDisplayName: () => declarativeTool,
480
+ getTools: () => [],
481
+ discoverTools: async () => { },
482
+ getAllTools: () => [],
483
+ getToolsByServer: () => [],
484
+ };
485
+ const onAllToolCallsComplete = vi.fn();
486
+ const onToolCallsUpdate = vi.fn();
487
+ const mockConfig = createMockConfig({
488
+ getToolRegistry: () => mockToolRegistry,
489
+ isInteractive: () => false,
490
+ });
491
+ const scheduler = new CoreToolScheduler({
492
+ config: mockConfig,
493
+ onAllToolCallsComplete,
494
+ onToolCallsUpdate,
495
+ getPreferredEditor: () => 'vscode',
496
+ });
497
+ const abortController = new AbortController();
498
+ const request = {
499
+ callId: '1',
500
+ name: 'mockTool',
501
+ args: {},
502
+ isClientInitiated: false,
503
+ prompt_id: 'prompt-id-1',
504
+ };
505
+ await scheduler.schedule([request], abortController.signal);
506
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
507
+ const completedCalls = onAllToolCallsComplete.mock
508
+ .calls[0][0];
509
+ expect(completedCalls[0].status).toBe('error');
510
+ const erroredCall = completedCalls[0];
511
+ const errorResponse = erroredCall.response;
512
+ const errorParts = errorResponse.responseParts;
513
+ // @ts-expect-error - accessing internal structure of FunctionResponsePart
514
+ const errorMessage = errorParts[0].functionResponse.response.error;
515
+ expect(errorMessage).toContain('Tool execution for "mockTool" requires user confirmation, which is not supported in non-interactive mode.');
516
+ });
517
+ });
518
+ describe('CoreToolScheduler with payload', () => {
519
+ it('should update args and diff and execute tool when payload is provided', async () => {
520
+ const mockTool = new MockModifiableTool();
521
+ mockTool.executeFn = vi.fn();
522
+ const declarativeTool = mockTool;
523
+ const mockToolRegistry = {
524
+ getTool: () => declarativeTool,
525
+ getFunctionDeclarations: () => [],
526
+ tools: new Map(),
527
+ discovery: {},
528
+ registerTool: () => { },
529
+ getToolByName: () => declarativeTool,
530
+ getToolByDisplayName: () => declarativeTool,
531
+ getTools: () => [],
532
+ discoverTools: async () => { },
533
+ getAllTools: () => [],
534
+ getToolsByServer: () => [],
535
+ };
536
+ const onAllToolCallsComplete = vi.fn();
537
+ const onToolCallsUpdate = vi.fn();
538
+ const mockConfig = createMockConfig({
539
+ getToolRegistry: () => mockToolRegistry,
540
+ });
541
+ const mockMessageBus = createMockMessageBus();
542
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
543
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
544
+ mockConfig.getHookSystem = vi
545
+ .fn()
546
+ .mockReturnValue(new HookSystem(mockConfig));
547
+ const scheduler = new CoreToolScheduler({
548
+ config: mockConfig,
549
+ onAllToolCallsComplete,
550
+ onToolCallsUpdate,
551
+ getPreferredEditor: () => 'vscode',
552
+ });
553
+ const abortController = new AbortController();
554
+ const request = {
555
+ callId: '1',
556
+ name: 'mockModifiableTool',
557
+ args: {},
558
+ isClientInitiated: false,
559
+ prompt_id: 'prompt-id-2',
560
+ };
561
+ await scheduler.schedule([request], abortController.signal);
562
+ const awaitingCall = (await waitForStatus(onToolCallsUpdate, 'awaiting_approval'));
563
+ const confirmationDetails = awaitingCall.confirmationDetails;
564
+ if (confirmationDetails) {
565
+ const payload = { newContent: 'final version' };
566
+ await confirmationDetails.onConfirm(ToolConfirmationOutcome.ProceedOnce, payload);
567
+ }
568
+ // After internal update, the tool should be awaiting approval again with the NEW content.
569
+ const updatedAwaitingCall = (await waitForStatus(onToolCallsUpdate, 'awaiting_approval'));
570
+ // Now confirm for real to execute.
571
+ await updatedAwaitingCall.confirmationDetails.onConfirm(ToolConfirmationOutcome.ProceedOnce);
572
+ // Wait for the tool execution to complete
573
+ await vi.waitFor(() => {
574
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
575
+ });
576
+ const completedCalls = onAllToolCallsComplete.mock
577
+ .calls[0][0];
578
+ expect(completedCalls[0].status).toBe('success');
579
+ expect(mockTool.executeFn).toHaveBeenCalledWith({
580
+ newContent: 'final version',
581
+ });
582
+ });
583
+ });
584
+ class MockEditToolInvocation extends BaseToolInvocation {
585
+ constructor(params, messageBus) {
586
+ super(params, messageBus);
587
+ }
588
+ getDescription() {
589
+ return 'A mock edit tool invocation';
590
+ }
591
+ async shouldConfirmExecute(_abortSignal) {
592
+ return {
593
+ type: 'edit',
594
+ title: 'Confirm Edit',
595
+ fileName: 'test.txt',
596
+ filePath: 'test.txt',
597
+ fileDiff: '--- test.txt\n+++ test.txt\n@@ -1,1 +1,1 @@\n-old content\n+new content',
598
+ originalContent: 'old content',
599
+ newContent: 'new content',
600
+ onConfirm: async () => { },
601
+ };
602
+ }
603
+ async execute(_abortSignal) {
604
+ return {
605
+ llmContent: 'Edited successfully',
606
+ returnDisplay: 'Edited successfully',
607
+ };
608
+ }
609
+ }
610
+ class MockEditTool extends BaseDeclarativeTool {
611
+ constructor(messageBus) {
612
+ super('mockEditTool', 'mockEditTool', 'A mock edit tool', Kind.Edit, {}, messageBus);
613
+ }
614
+ createInvocation(params, messageBus, _toolName, _toolDisplayName) {
615
+ return new MockEditToolInvocation(params, messageBus);
616
+ }
617
+ }
618
+ describe('CoreToolScheduler edit cancellation', () => {
619
+ it('should preserve diff when an edit is cancelled', async () => {
620
+ const mockEditTool = new MockEditTool(createMockMessageBus());
621
+ const mockToolRegistry = {
622
+ getTool: () => mockEditTool,
623
+ getFunctionDeclarations: () => [],
624
+ tools: new Map(),
625
+ discovery: {},
626
+ registerTool: () => { },
627
+ getToolByName: () => mockEditTool,
628
+ getToolByDisplayName: () => mockEditTool,
629
+ getTools: () => [],
630
+ discoverTools: async () => { },
631
+ getAllTools: () => [],
632
+ getToolsByServer: () => [],
633
+ };
634
+ const onAllToolCallsComplete = vi.fn();
635
+ const onToolCallsUpdate = vi.fn();
636
+ const mockConfig = createMockConfig({
637
+ getToolRegistry: () => mockToolRegistry,
638
+ });
639
+ const mockMessageBus = createMockMessageBus();
640
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
641
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
642
+ mockConfig.getHookSystem = vi
643
+ .fn()
644
+ .mockReturnValue(new HookSystem(mockConfig));
645
+ const scheduler = new CoreToolScheduler({
646
+ config: mockConfig,
647
+ onAllToolCallsComplete,
648
+ onToolCallsUpdate,
649
+ getPreferredEditor: () => 'vscode',
650
+ });
651
+ const abortController = new AbortController();
652
+ const request = {
653
+ callId: '1',
654
+ name: 'mockEditTool',
655
+ args: {},
656
+ isClientInitiated: false,
657
+ prompt_id: 'prompt-id-1',
658
+ };
659
+ await scheduler.schedule([request], abortController.signal);
660
+ const awaitingCall = (await waitForStatus(onToolCallsUpdate, 'awaiting_approval'));
661
+ // Cancel the edit
662
+ const confirmationDetails = awaitingCall.confirmationDetails;
663
+ if (confirmationDetails) {
664
+ await confirmationDetails.onConfirm(ToolConfirmationOutcome.Cancel);
665
+ }
666
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
667
+ const completedCalls = onAllToolCallsComplete.mock
668
+ .calls[0][0];
669
+ expect(completedCalls[0].status).toBe('cancelled');
670
+ // Check that the diff is preserved
671
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
672
+ const cancelledCall = completedCalls[0];
673
+ expect(cancelledCall.response.resultDisplay).toBeDefined();
674
+ expect(cancelledCall.response.resultDisplay.fileDiff).toBe('--- test.txt\n+++ test.txt\n@@ -1,1 +1,1 @@\n-old content\n+new content');
675
+ expect(cancelledCall.response.resultDisplay.fileName).toBe('test.txt');
676
+ });
677
+ });
678
+ describe('CoreToolScheduler YOLO mode', () => {
679
+ it('should execute tool requiring confirmation directly without waiting', async () => {
680
+ // Arrange
681
+ const executeFn = vi.fn().mockResolvedValue({
682
+ llmContent: 'Tool executed',
683
+ returnDisplay: 'Tool executed',
684
+ });
685
+ const mockTool = new MockTool({
686
+ name: 'mockTool',
687
+ execute: executeFn,
688
+ shouldConfirmExecute: MOCK_TOOL_SHOULD_CONFIRM_EXECUTE,
689
+ });
690
+ const declarativeTool = mockTool;
691
+ const mockToolRegistry = {
692
+ getTool: () => declarativeTool,
693
+ getToolByName: () => declarativeTool,
694
+ // Other properties are not needed for this test but are included for type consistency.
695
+ getFunctionDeclarations: () => [],
696
+ tools: new Map(),
697
+ discovery: {},
698
+ registerTool: () => { },
699
+ getToolByDisplayName: () => declarativeTool,
700
+ getTools: () => [],
701
+ discoverTools: async () => { },
702
+ getAllTools: () => [],
703
+ getToolsByServer: () => [],
704
+ };
705
+ const onAllToolCallsComplete = vi.fn();
706
+ const onToolCallsUpdate = vi.fn();
707
+ // Configure the scheduler for YOLO mode.
708
+ const mockConfig = createMockConfig({
709
+ getToolRegistry: () => mockToolRegistry,
710
+ getApprovalMode: () => ApprovalMode.YOLO,
711
+ isInteractive: () => false,
712
+ });
713
+ const mockMessageBus = createMockMessageBus();
714
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
715
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
716
+ mockConfig.getHookSystem = vi
717
+ .fn()
718
+ .mockReturnValue(new HookSystem(mockConfig));
719
+ const scheduler = new CoreToolScheduler({
720
+ config: mockConfig,
721
+ onAllToolCallsComplete,
722
+ onToolCallsUpdate,
723
+ getPreferredEditor: () => 'vscode',
724
+ });
725
+ const abortController = new AbortController();
726
+ const request = {
727
+ callId: '1',
728
+ name: 'mockTool',
729
+ args: { param: 'value' },
730
+ isClientInitiated: false,
731
+ prompt_id: 'prompt-id-yolo',
732
+ };
733
+ // Act
734
+ await scheduler.schedule([request], abortController.signal);
735
+ // Wait for the tool execution to complete
736
+ await vi.waitFor(() => {
737
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
738
+ });
739
+ // Assert
740
+ // 1. The tool's execute method was called directly.
741
+ expect(executeFn).toHaveBeenCalledWith({ param: 'value' });
742
+ // 2. The tool call status never entered 'awaiting_approval'.
743
+ const statusUpdates = onToolCallsUpdate.mock.calls
744
+ .map((call) => call[0][0]?.status)
745
+ .filter(Boolean);
746
+ expect(statusUpdates).not.toContain('awaiting_approval');
747
+ expect(statusUpdates).toEqual([
748
+ 'validating',
749
+ 'scheduled',
750
+ 'executing',
751
+ 'success',
752
+ ]);
753
+ // 3. The final callback indicates the tool call was successful.
754
+ const completedCalls = onAllToolCallsComplete.mock
755
+ .calls[0][0];
756
+ expect(completedCalls).toHaveLength(1);
757
+ const completedCall = completedCalls[0];
758
+ expect(completedCall.status).toBe('success');
759
+ if (completedCall.status === 'success') {
760
+ expect(completedCall.response.resultDisplay).toBe('Tool executed');
761
+ }
762
+ });
763
+ });
764
+ describe('CoreToolScheduler request queueing', () => {
765
+ it('should queue a request if another is running', async () => {
766
+ let resolveFirstCall;
767
+ const firstCallPromise = new Promise((resolve) => {
768
+ resolveFirstCall = resolve;
769
+ });
770
+ const executeFn = vi.fn().mockImplementation(() => firstCallPromise);
771
+ const mockTool = new MockTool({ name: 'mockTool', execute: executeFn });
772
+ const declarativeTool = mockTool;
773
+ const mockToolRegistry = {
774
+ getTool: () => declarativeTool,
775
+ getToolByName: () => declarativeTool,
776
+ getFunctionDeclarations: () => [],
777
+ tools: new Map(),
778
+ discovery: {},
779
+ registerTool: () => { },
780
+ getToolByDisplayName: () => declarativeTool,
781
+ getTools: () => [],
782
+ discoverTools: async () => { },
783
+ getAllTools: () => [],
784
+ getToolsByServer: () => [],
785
+ };
786
+ const onAllToolCallsComplete = vi.fn();
787
+ const onToolCallsUpdate = vi.fn();
788
+ const mockConfig = createMockConfig({
789
+ getToolRegistry: () => mockToolRegistry,
790
+ getApprovalMode: () => ApprovalMode.YOLO, // Use YOLO to avoid confirmation prompts
791
+ isInteractive: () => false,
792
+ });
793
+ const mockMessageBus = createMockMessageBus();
794
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
795
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
796
+ mockConfig.getHookSystem = vi
797
+ .fn()
798
+ .mockReturnValue(new HookSystem(mockConfig));
799
+ const scheduler = new CoreToolScheduler({
800
+ config: mockConfig,
801
+ onAllToolCallsComplete,
802
+ onToolCallsUpdate,
803
+ getPreferredEditor: () => 'vscode',
804
+ });
805
+ const abortController = new AbortController();
806
+ const request1 = {
807
+ callId: '1',
808
+ name: 'mockTool',
809
+ args: { a: 1 },
810
+ isClientInitiated: false,
811
+ prompt_id: 'prompt-1',
812
+ };
813
+ const request2 = {
814
+ callId: '2',
815
+ name: 'mockTool',
816
+ args: { b: 2 },
817
+ isClientInitiated: false,
818
+ prompt_id: 'prompt-2',
819
+ };
820
+ // Schedule the first call, which will pause execution.
821
+ // eslint-disable-next-line @typescript-eslint/no-floating-promises
822
+ scheduler.schedule([request1], abortController.signal);
823
+ // Wait for the first call to be in the 'executing' state.
824
+ await waitForStatus(onToolCallsUpdate, 'executing');
825
+ // Schedule the second call while the first is "running".
826
+ const schedulePromise2 = scheduler.schedule([request2], abortController.signal);
827
+ // Ensure the second tool call hasn't been executed yet.
828
+ expect(executeFn).toHaveBeenCalledWith({ a: 1 });
829
+ // Complete the first tool call.
830
+ resolveFirstCall({
831
+ llmContent: 'First call complete',
832
+ returnDisplay: 'First call complete',
833
+ });
834
+ // Wait for the second schedule promise to resolve.
835
+ await schedulePromise2;
836
+ // Let the second call finish.
837
+ const secondCallResult = {
838
+ llmContent: 'Second call complete',
839
+ returnDisplay: 'Second call complete',
840
+ };
841
+ // Since the mock is shared, we need to resolve the current promise.
842
+ // In a real scenario, a new promise would be created for the second call.
843
+ resolveFirstCall(secondCallResult);
844
+ await vi.waitFor(() => {
845
+ // Now the second tool call should have been executed.
846
+ expect(executeFn).toHaveBeenCalledTimes(2);
847
+ });
848
+ expect(executeFn).toHaveBeenCalledWith({ b: 2 });
849
+ // Wait for the second completion.
850
+ await vi.waitFor(() => {
851
+ expect(onAllToolCallsComplete).toHaveBeenCalledTimes(2);
852
+ });
853
+ // Verify the completion callbacks were called correctly.
854
+ expect(onAllToolCallsComplete.mock.calls[0][0][0].status).toBe('success');
855
+ expect(onAllToolCallsComplete.mock.calls[1][0][0].status).toBe('success');
856
+ });
857
+ it('should auto-approve a tool call if it is on the allowedTools list', async () => {
858
+ // Arrange
859
+ const executeFn = vi.fn().mockResolvedValue({
860
+ llmContent: 'Tool executed',
861
+ returnDisplay: 'Tool executed',
862
+ });
863
+ const mockTool = new MockTool({
864
+ name: 'mockTool',
865
+ execute: executeFn,
866
+ shouldConfirmExecute: MOCK_TOOL_SHOULD_CONFIRM_EXECUTE,
867
+ });
868
+ const declarativeTool = mockTool;
869
+ const toolRegistry = {
870
+ getTool: () => declarativeTool,
871
+ getToolByName: () => declarativeTool,
872
+ getFunctionDeclarations: () => [],
873
+ tools: new Map(),
874
+ discovery: {},
875
+ registerTool: () => { },
876
+ getToolByDisplayName: () => declarativeTool,
877
+ getTools: () => [],
878
+ discoverTools: async () => { },
879
+ getAllTools: () => [],
880
+ getToolsByServer: () => [],
881
+ };
882
+ const onAllToolCallsComplete = vi.fn();
883
+ const onToolCallsUpdate = vi.fn();
884
+ // Configure the scheduler to auto-approve the specific tool call.
885
+ const mockConfig = createMockConfig({
886
+ getAllowedTools: () => ['mockTool'], // Auto-approve this tool
887
+ getToolRegistry: () => toolRegistry,
888
+ getShellExecutionConfig: () => ({
889
+ terminalWidth: 80,
890
+ terminalHeight: 24,
891
+ sanitizationConfig: {
892
+ enableEnvironmentVariableRedaction: true,
893
+ allowedEnvironmentVariables: [],
894
+ blockedEnvironmentVariables: [],
895
+ },
896
+ }),
897
+ isInteractive: () => false,
898
+ });
899
+ const mockMessageBus = createMockMessageBus();
900
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
901
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
902
+ mockConfig.getHookSystem = vi
903
+ .fn()
904
+ .mockReturnValue(new HookSystem(mockConfig));
905
+ const scheduler = new CoreToolScheduler({
906
+ config: mockConfig,
907
+ onAllToolCallsComplete,
908
+ onToolCallsUpdate,
909
+ getPreferredEditor: () => 'vscode',
910
+ });
911
+ const abortController = new AbortController();
912
+ const request = {
913
+ callId: '1',
914
+ name: 'mockTool',
915
+ args: { param: 'value' },
916
+ isClientInitiated: false,
917
+ prompt_id: 'prompt-auto-approved',
918
+ };
919
+ // Act
920
+ await scheduler.schedule([request], abortController.signal);
921
+ // Wait for the tool execution to complete
922
+ await vi.waitFor(() => {
923
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
924
+ });
925
+ // Assert
926
+ // 1. The tool's execute method was called directly.
927
+ expect(executeFn).toHaveBeenCalledWith({ param: 'value' });
928
+ // 2. The tool call status never entered 'awaiting_approval'.
929
+ const statusUpdates = onToolCallsUpdate.mock.calls
930
+ .map((call) => call[0][0]?.status)
931
+ .filter(Boolean);
932
+ expect(statusUpdates).not.toContain('awaiting_approval');
933
+ expect(statusUpdates).toEqual([
934
+ 'validating',
935
+ 'scheduled',
936
+ 'executing',
937
+ 'success',
938
+ ]);
939
+ // 3. The final callback indicates the tool call was successful.
940
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
941
+ const completedCalls = onAllToolCallsComplete.mock
942
+ .calls[0][0];
943
+ expect(completedCalls).toHaveLength(1);
944
+ const completedCall = completedCalls[0];
945
+ expect(completedCall.status).toBe('success');
946
+ if (completedCall.status === 'success') {
947
+ expect(completedCall.response.resultDisplay).toBe('Tool executed');
948
+ }
949
+ });
950
+ it('should require approval for a chained shell command even when prefix is allowlisted', async () => {
951
+ const executeFn = vi.fn().mockResolvedValue({
952
+ llmContent: 'Shell command executed',
953
+ returnDisplay: 'Shell command executed',
954
+ });
955
+ const mockShellTool = new MockTool({
956
+ name: 'run_shell_command',
957
+ shouldConfirmExecute: (params) => Promise.resolve({
958
+ type: 'exec',
959
+ title: 'Confirm Shell Command',
960
+ command: String(params['command'] ?? ''),
961
+ rootCommand: 'git',
962
+ rootCommands: ['git'],
963
+ onConfirm: async () => { },
964
+ }),
965
+ execute: () => executeFn({}),
966
+ });
967
+ const toolRegistry = {
968
+ getTool: () => mockShellTool,
969
+ getToolByName: () => mockShellTool,
970
+ getFunctionDeclarations: () => [],
971
+ tools: new Map(),
972
+ discovery: {},
973
+ registerTool: () => { },
974
+ getToolByDisplayName: () => mockShellTool,
975
+ getTools: () => [],
976
+ discoverTools: async () => { },
977
+ getAllTools: () => [],
978
+ getToolsByServer: () => [],
979
+ };
980
+ const onAllToolCallsComplete = vi.fn();
981
+ const onToolCallsUpdate = vi.fn();
982
+ const mockConfig = createMockConfig({
983
+ getAllowedTools: () => ['run_shell_command(git)'],
984
+ getShellExecutionConfig: () => ({
985
+ terminalWidth: 80,
986
+ terminalHeight: 24,
987
+ sanitizationConfig: {
988
+ enableEnvironmentVariableRedaction: true,
989
+ allowedEnvironmentVariables: [],
990
+ blockedEnvironmentVariables: [],
991
+ },
992
+ }),
993
+ getToolRegistry: () => toolRegistry,
994
+ getHookSystem: () => undefined,
995
+ getPolicyEngine: () => ({
996
+ check: async () => ({ decision: PolicyDecision.ASK_USER }),
997
+ }),
998
+ });
999
+ const scheduler = new CoreToolScheduler({
1000
+ config: mockConfig,
1001
+ onAllToolCallsComplete,
1002
+ onToolCallsUpdate,
1003
+ getPreferredEditor: () => 'vscode',
1004
+ });
1005
+ const abortController = new AbortController();
1006
+ const request = {
1007
+ callId: 'shell-1',
1008
+ name: 'run_shell_command',
1009
+ args: { command: 'git status && rm -rf /tmp/should-not-run' },
1010
+ isClientInitiated: false,
1011
+ prompt_id: 'prompt-shell-auto-approved',
1012
+ };
1013
+ await scheduler.schedule([request], abortController.signal);
1014
+ const statusUpdates = onToolCallsUpdate.mock.calls
1015
+ .map((call) => call[0][0]?.status)
1016
+ .filter(Boolean);
1017
+ expect(statusUpdates).toContain('awaiting_approval');
1018
+ expect(executeFn).not.toHaveBeenCalled();
1019
+ expect(onAllToolCallsComplete).not.toHaveBeenCalled();
1020
+ }, 20000);
1021
+ it('should handle two synchronous calls to schedule', async () => {
1022
+ const executeFn = vi.fn().mockResolvedValue({
1023
+ llmContent: 'Tool executed',
1024
+ returnDisplay: 'Tool executed',
1025
+ });
1026
+ const mockTool = new MockTool({ name: 'mockTool', execute: executeFn });
1027
+ const declarativeTool = mockTool;
1028
+ const mockToolRegistry = {
1029
+ getTool: () => declarativeTool,
1030
+ getToolByName: () => declarativeTool,
1031
+ getFunctionDeclarations: () => [],
1032
+ tools: new Map(),
1033
+ discovery: {},
1034
+ registerTool: () => { },
1035
+ getToolByDisplayName: () => declarativeTool,
1036
+ getTools: () => [],
1037
+ discoverTools: async () => { },
1038
+ getAllTools: () => [],
1039
+ getToolsByServer: () => [],
1040
+ };
1041
+ const onAllToolCallsComplete = vi.fn();
1042
+ const onToolCallsUpdate = vi.fn();
1043
+ const mockConfig = createMockConfig({
1044
+ getToolRegistry: () => mockToolRegistry,
1045
+ getApprovalMode: () => ApprovalMode.YOLO,
1046
+ });
1047
+ const mockMessageBus = createMockMessageBus();
1048
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
1049
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
1050
+ mockConfig.getHookSystem = vi
1051
+ .fn()
1052
+ .mockReturnValue(new HookSystem(mockConfig));
1053
+ const scheduler = new CoreToolScheduler({
1054
+ config: mockConfig,
1055
+ onAllToolCallsComplete,
1056
+ onToolCallsUpdate,
1057
+ getPreferredEditor: () => 'vscode',
1058
+ });
1059
+ const abortController = new AbortController();
1060
+ const request1 = {
1061
+ callId: '1',
1062
+ name: 'mockTool',
1063
+ args: { a: 1 },
1064
+ isClientInitiated: false,
1065
+ prompt_id: 'prompt-1',
1066
+ };
1067
+ const request2 = {
1068
+ callId: '2',
1069
+ name: 'mockTool',
1070
+ args: { b: 2 },
1071
+ isClientInitiated: false,
1072
+ prompt_id: 'prompt-2',
1073
+ };
1074
+ // Schedule two calls synchronously.
1075
+ const schedulePromise1 = scheduler.schedule([request1], abortController.signal);
1076
+ const schedulePromise2 = scheduler.schedule([request2], abortController.signal);
1077
+ // Wait for both promises to resolve.
1078
+ await Promise.all([schedulePromise1, schedulePromise2]);
1079
+ // Ensure the tool was called twice with the correct arguments.
1080
+ expect(executeFn).toHaveBeenCalledTimes(2);
1081
+ expect(executeFn).toHaveBeenCalledWith({ a: 1 });
1082
+ expect(executeFn).toHaveBeenCalledWith({ b: 2 });
1083
+ // Ensure completion callbacks were called twice.
1084
+ expect(onAllToolCallsComplete).toHaveBeenCalledTimes(2);
1085
+ });
1086
+ it('should auto-approve remaining tool calls when first tool call is approved with ProceedAlways', async () => {
1087
+ let approvalMode = ApprovalMode.DEFAULT;
1088
+ const mockConfig = createMockConfig({
1089
+ getApprovalMode: () => approvalMode,
1090
+ setApprovalMode: (mode) => {
1091
+ approvalMode = mode;
1092
+ },
1093
+ });
1094
+ const mockMessageBus = createMockMessageBus();
1095
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
1096
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
1097
+ mockConfig.getHookSystem = vi
1098
+ .fn()
1099
+ .mockReturnValue(new HookSystem(mockConfig));
1100
+ const testTool = new TestApprovalTool(mockConfig, mockMessageBus);
1101
+ const toolRegistry = {
1102
+ getTool: () => testTool,
1103
+ getFunctionDeclarations: () => [],
1104
+ getFunctionDeclarationsFiltered: () => [],
1105
+ registerTool: () => { },
1106
+ discoverAllTools: async () => { },
1107
+ discoverMcpTools: async () => { },
1108
+ discoverToolsForServer: async () => { },
1109
+ removeMcpToolsByServer: () => { },
1110
+ getAllTools: () => [],
1111
+ getToolsByServer: () => [],
1112
+ tools: new Map(),
1113
+ config: mockConfig,
1114
+ mcpClientManager: undefined,
1115
+ getToolByName: () => testTool,
1116
+ getToolByDisplayName: () => testTool,
1117
+ getTools: () => [],
1118
+ discoverTools: async () => { },
1119
+ discovery: {},
1120
+ };
1121
+ mockConfig.getToolRegistry = () => toolRegistry;
1122
+ const onAllToolCallsComplete = vi.fn();
1123
+ const onToolCallsUpdate = vi.fn();
1124
+ const pendingConfirmations = [];
1125
+ const scheduler = new CoreToolScheduler({
1126
+ config: mockConfig,
1127
+ onAllToolCallsComplete,
1128
+ onToolCallsUpdate: (toolCalls) => {
1129
+ onToolCallsUpdate(toolCalls);
1130
+ // Capture confirmation handlers for awaiting_approval tools
1131
+ toolCalls.forEach((call) => {
1132
+ if (call.status === 'awaiting_approval') {
1133
+ const waitingCall = call;
1134
+ const details = waitingCall.confirmationDetails;
1135
+ if (details?.onConfirm) {
1136
+ const originalHandler = pendingConfirmations.find((h) => h === details.onConfirm);
1137
+ if (!originalHandler) {
1138
+ pendingConfirmations.push(details.onConfirm);
1139
+ }
1140
+ }
1141
+ }
1142
+ });
1143
+ },
1144
+ getPreferredEditor: () => 'vscode',
1145
+ });
1146
+ const abortController = new AbortController();
1147
+ // Schedule multiple tools that need confirmation
1148
+ const requests = [
1149
+ {
1150
+ callId: '1',
1151
+ name: 'testApprovalTool',
1152
+ args: { id: 'first' },
1153
+ isClientInitiated: false,
1154
+ prompt_id: 'prompt-1',
1155
+ },
1156
+ {
1157
+ callId: '2',
1158
+ name: 'testApprovalTool',
1159
+ args: { id: 'second' },
1160
+ isClientInitiated: false,
1161
+ prompt_id: 'prompt-2',
1162
+ },
1163
+ {
1164
+ callId: '3',
1165
+ name: 'testApprovalTool',
1166
+ args: { id: 'third' },
1167
+ isClientInitiated: false,
1168
+ prompt_id: 'prompt-3',
1169
+ },
1170
+ ];
1171
+ await scheduler.schedule(requests, abortController.signal);
1172
+ // Wait for the FIRST tool to be awaiting approval
1173
+ await vi.waitFor(() => {
1174
+ const calls = onToolCallsUpdate.mock.calls.at(-1)?.[0];
1175
+ // With the sequential scheduler, the update includes the active call and the queue.
1176
+ expect(calls?.length).toBe(3);
1177
+ expect(calls?.[0].status).toBe('awaiting_approval');
1178
+ expect(calls?.[0].request.callId).toBe('1');
1179
+ // Check that the other two are in the queue (still in 'validating' state)
1180
+ expect(calls?.[1].status).toBe('validating');
1181
+ expect(calls?.[2].status).toBe('validating');
1182
+ });
1183
+ expect(pendingConfirmations.length).toBe(1);
1184
+ // Approve the first tool with ProceedAlways
1185
+ const firstConfirmation = pendingConfirmations[0];
1186
+ firstConfirmation(ToolConfirmationOutcome.ProceedAlways);
1187
+ // Wait for all tools to be completed
1188
+ await vi.waitFor(() => {
1189
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
1190
+ });
1191
+ const completedCalls = onAllToolCallsComplete.mock.calls.at(-1)?.[0];
1192
+ expect(completedCalls?.length).toBe(3);
1193
+ expect(completedCalls?.every((call) => call.status === 'success')).toBe(true);
1194
+ // Verify approval mode was changed
1195
+ expect(approvalMode).toBe(ApprovalMode.AUTO_EDIT);
1196
+ });
1197
+ });
1198
+ describe('CoreToolScheduler Sequential Execution', () => {
1199
+ it('should execute tool calls in a batch sequentially', async () => {
1200
+ // Arrange
1201
+ let firstCallFinished = false;
1202
+ const executeFn = vi
1203
+ .fn()
1204
+ .mockImplementation(async (args) => {
1205
+ if (args.call === 1) {
1206
+ // First call, wait for a bit to simulate work
1207
+ await new Promise((resolve) => setTimeout(resolve, 50));
1208
+ firstCallFinished = true;
1209
+ return { llmContent: 'First call done' };
1210
+ }
1211
+ if (args.call === 2) {
1212
+ // Second call, should only happen after the first is finished
1213
+ if (!firstCallFinished) {
1214
+ throw new Error('Second tool call started before the first one finished!');
1215
+ }
1216
+ return { llmContent: 'Second call done' };
1217
+ }
1218
+ return { llmContent: 'default' };
1219
+ });
1220
+ const mockTool = new MockTool({ name: 'mockTool', execute: executeFn });
1221
+ const declarativeTool = mockTool;
1222
+ const mockToolRegistry = {
1223
+ getTool: () => declarativeTool,
1224
+ getToolByName: () => declarativeTool,
1225
+ getFunctionDeclarations: () => [],
1226
+ tools: new Map(),
1227
+ discovery: {},
1228
+ registerTool: () => { },
1229
+ getToolByDisplayName: () => declarativeTool,
1230
+ getTools: () => [],
1231
+ discoverTools: async () => { },
1232
+ getAllTools: () => [],
1233
+ getToolsByServer: () => [],
1234
+ };
1235
+ const onAllToolCallsComplete = vi.fn();
1236
+ const onToolCallsUpdate = vi.fn();
1237
+ const mockConfig = createMockConfig({
1238
+ getToolRegistry: () => mockToolRegistry,
1239
+ getApprovalMode: () => ApprovalMode.YOLO, // Use YOLO to avoid confirmation prompts
1240
+ isInteractive: () => false,
1241
+ });
1242
+ const mockMessageBus = createMockMessageBus();
1243
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
1244
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
1245
+ mockConfig.getHookSystem = vi
1246
+ .fn()
1247
+ .mockReturnValue(new HookSystem(mockConfig));
1248
+ const scheduler = new CoreToolScheduler({
1249
+ config: mockConfig,
1250
+ onAllToolCallsComplete,
1251
+ onToolCallsUpdate,
1252
+ getPreferredEditor: () => 'vscode',
1253
+ });
1254
+ const abortController = new AbortController();
1255
+ const requests = [
1256
+ {
1257
+ callId: '1',
1258
+ name: 'mockTool',
1259
+ args: { call: 1 },
1260
+ isClientInitiated: false,
1261
+ prompt_id: 'prompt-1',
1262
+ },
1263
+ {
1264
+ callId: '2',
1265
+ name: 'mockTool',
1266
+ args: { call: 2 },
1267
+ isClientInitiated: false,
1268
+ prompt_id: 'prompt-1',
1269
+ },
1270
+ ];
1271
+ // Act
1272
+ await scheduler.schedule(requests, abortController.signal);
1273
+ // Assert
1274
+ await vi.waitFor(() => {
1275
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
1276
+ });
1277
+ // Check that execute was called twice
1278
+ expect(executeFn).toHaveBeenCalledTimes(2);
1279
+ // Check the order of calls
1280
+ const calls = executeFn.mock.calls;
1281
+ expect(calls[0][0]).toEqual({ call: 1 });
1282
+ expect(calls[1][0]).toEqual({ call: 2 });
1283
+ // The onAllToolCallsComplete should be called once with both results
1284
+ const completedCalls = onAllToolCallsComplete.mock
1285
+ .calls[0][0];
1286
+ expect(completedCalls).toHaveLength(2);
1287
+ expect(completedCalls[0].status).toBe('success');
1288
+ expect(completedCalls[1].status).toBe('success');
1289
+ });
1290
+ it('should cancel subsequent tools when the signal is aborted.', async () => {
1291
+ // Arrange
1292
+ const abortController = new AbortController();
1293
+ let secondCallStarted = false;
1294
+ const executeFn = vi
1295
+ .fn()
1296
+ .mockImplementation(async (args) => {
1297
+ if (args.call === 1) {
1298
+ return { llmContent: 'First call done' };
1299
+ }
1300
+ if (args.call === 2) {
1301
+ secondCallStarted = true;
1302
+ // This call will be cancelled while it's "running".
1303
+ await new Promise((resolve) => setTimeout(resolve, 100));
1304
+ // It should not return a value because it will be cancelled.
1305
+ return { llmContent: 'Second call should not complete' };
1306
+ }
1307
+ if (args.call === 3) {
1308
+ return { llmContent: 'Third call done' };
1309
+ }
1310
+ return { llmContent: 'default' };
1311
+ });
1312
+ const mockTool = new MockTool({ name: 'mockTool', execute: executeFn });
1313
+ const declarativeTool = mockTool;
1314
+ const mockToolRegistry = {
1315
+ getTool: () => declarativeTool,
1316
+ getToolByName: () => declarativeTool,
1317
+ getFunctionDeclarations: () => [],
1318
+ tools: new Map(),
1319
+ discovery: {},
1320
+ registerTool: () => { },
1321
+ getToolByDisplayName: () => declarativeTool,
1322
+ getTools: () => [],
1323
+ discoverTools: async () => { },
1324
+ getAllTools: () => [],
1325
+ getToolsByServer: () => [],
1326
+ };
1327
+ const onAllToolCallsComplete = vi.fn();
1328
+ const onToolCallsUpdate = vi.fn();
1329
+ const mockConfig = createMockConfig({
1330
+ getToolRegistry: () => mockToolRegistry,
1331
+ getApprovalMode: () => ApprovalMode.YOLO,
1332
+ isInteractive: () => false,
1333
+ });
1334
+ const mockMessageBus = createMockMessageBus();
1335
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
1336
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
1337
+ mockConfig.getHookSystem = vi
1338
+ .fn()
1339
+ .mockReturnValue(new HookSystem(mockConfig));
1340
+ const scheduler = new CoreToolScheduler({
1341
+ config: mockConfig,
1342
+ onAllToolCallsComplete,
1343
+ onToolCallsUpdate,
1344
+ getPreferredEditor: () => 'vscode',
1345
+ });
1346
+ const requests = [
1347
+ {
1348
+ callId: '1',
1349
+ name: 'mockTool',
1350
+ args: { call: 1 },
1351
+ isClientInitiated: false,
1352
+ prompt_id: 'prompt-1',
1353
+ },
1354
+ {
1355
+ callId: '2',
1356
+ name: 'mockTool',
1357
+ args: { call: 2 },
1358
+ isClientInitiated: false,
1359
+ prompt_id: 'prompt-1',
1360
+ },
1361
+ {
1362
+ callId: '3',
1363
+ name: 'mockTool',
1364
+ args: { call: 3 },
1365
+ isClientInitiated: false,
1366
+ prompt_id: 'prompt-1',
1367
+ },
1368
+ ];
1369
+ // Act
1370
+ const schedulePromise = scheduler.schedule(requests, abortController.signal);
1371
+ // Wait for the second call to start, then abort.
1372
+ await vi.waitFor(() => {
1373
+ expect(secondCallStarted).toBe(true);
1374
+ });
1375
+ abortController.abort();
1376
+ await schedulePromise;
1377
+ // Assert
1378
+ await vi.waitFor(() => {
1379
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
1380
+ });
1381
+ // Check that execute was called for the first two tools only
1382
+ expect(executeFn).toHaveBeenCalledTimes(2);
1383
+ expect(executeFn).toHaveBeenCalledWith({ call: 1 });
1384
+ expect(executeFn).toHaveBeenCalledWith({ call: 2 });
1385
+ const completedCalls = onAllToolCallsComplete.mock
1386
+ .calls[0][0];
1387
+ expect(completedCalls).toHaveLength(3);
1388
+ const call1 = completedCalls.find((c) => c.request.callId === '1');
1389
+ const call2 = completedCalls.find((c) => c.request.callId === '2');
1390
+ const call3 = completedCalls.find((c) => c.request.callId === '3');
1391
+ expect(call1?.status).toBe('success');
1392
+ expect(call2?.status).toBe('cancelled');
1393
+ expect(call3?.status).toBe('cancelled');
1394
+ });
1395
+ it('should pass confirmation diff data into modifyWithEditor overrides', async () => {
1396
+ const modifyWithEditorSpy = vi
1397
+ .spyOn(modifiableToolModule, 'modifyWithEditor')
1398
+ .mockResolvedValue({
1399
+ updatedParams: { param: 'updated' },
1400
+ updatedDiff: 'updated diff',
1401
+ });
1402
+ const mockModifiableTool = new MockModifiableTool('mockModifiableTool');
1403
+ const mockToolRegistry = {
1404
+ getTool: () => mockModifiableTool,
1405
+ getToolByName: () => mockModifiableTool,
1406
+ getFunctionDeclarations: () => [],
1407
+ tools: new Map(),
1408
+ discovery: {},
1409
+ registerTool: () => { },
1410
+ getToolByDisplayName: () => mockModifiableTool,
1411
+ getTools: () => [],
1412
+ discoverTools: async () => { },
1413
+ getAllTools: () => [],
1414
+ getToolsByServer: () => [],
1415
+ };
1416
+ const onAllToolCallsComplete = vi.fn();
1417
+ const onToolCallsUpdate = vi.fn();
1418
+ const mockConfig = createMockConfig({
1419
+ getToolRegistry: () => mockToolRegistry,
1420
+ });
1421
+ const mockMessageBus = createMockMessageBus();
1422
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
1423
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
1424
+ mockConfig.getHookSystem = vi
1425
+ .fn()
1426
+ .mockReturnValue(new HookSystem(mockConfig));
1427
+ const scheduler = new CoreToolScheduler({
1428
+ config: mockConfig,
1429
+ onAllToolCallsComplete,
1430
+ onToolCallsUpdate,
1431
+ getPreferredEditor: () => 'vscode',
1432
+ });
1433
+ const abortController = new AbortController();
1434
+ await scheduler.schedule([
1435
+ {
1436
+ callId: '1',
1437
+ name: 'mockModifiableTool',
1438
+ args: {},
1439
+ isClientInitiated: false,
1440
+ prompt_id: 'prompt-1',
1441
+ },
1442
+ ], abortController.signal);
1443
+ const toolCall = scheduler
1444
+ .toolCalls[0];
1445
+ expect(toolCall.status).toBe('awaiting_approval');
1446
+ const confirmationSignal = new AbortController().signal;
1447
+ await scheduler.handleConfirmationResponse(toolCall.request.callId, async () => { }, ToolConfirmationOutcome.ModifyWithEditor, confirmationSignal);
1448
+ expect(modifyWithEditorSpy).toHaveBeenCalled();
1449
+ const overrides = modifyWithEditorSpy.mock.calls[modifyWithEditorSpy.mock.calls.length - 1][4];
1450
+ expect(overrides).toEqual({
1451
+ currentContent: 'originalContent',
1452
+ proposedContent: 'newContent',
1453
+ });
1454
+ modifyWithEditorSpy.mockRestore();
1455
+ });
1456
+ it('should pass serverName to policy engine for DiscoveredMCPTool', async () => {
1457
+ const mockMcpTool = {
1458
+ tool: async () => ({ functionDeclarations: [] }),
1459
+ callTool: async () => [],
1460
+ };
1461
+ const serverName = 'test-server';
1462
+ const toolName = 'test-tool';
1463
+ const mcpTool = new DiscoveredMCPTool(mockMcpTool, serverName, toolName, 'description', { type: 'object', properties: {} }, createMockMessageBus());
1464
+ const mockToolRegistry = {
1465
+ getTool: () => mcpTool,
1466
+ getFunctionDeclarations: () => [],
1467
+ tools: new Map(),
1468
+ discovery: {},
1469
+ registerTool: () => { },
1470
+ getToolByName: () => mcpTool,
1471
+ getToolByDisplayName: () => mcpTool,
1472
+ getTools: () => [],
1473
+ discoverTools: async () => { },
1474
+ getAllTools: () => [],
1475
+ getToolsByServer: () => [],
1476
+ };
1477
+ const mockPolicyEngineCheck = vi.fn().mockResolvedValue({
1478
+ decision: PolicyDecision.ALLOW,
1479
+ });
1480
+ const mockConfig = createMockConfig({
1481
+ getToolRegistry: () => mockToolRegistry,
1482
+ getPolicyEngine: () => ({
1483
+ check: mockPolicyEngineCheck,
1484
+ }),
1485
+ isInteractive: () => false,
1486
+ });
1487
+ mockConfig.getHookSystem = vi.fn().mockReturnValue(undefined);
1488
+ const scheduler = new CoreToolScheduler({
1489
+ config: mockConfig,
1490
+ getPreferredEditor: () => 'vscode',
1491
+ });
1492
+ const abortController = new AbortController();
1493
+ const request = {
1494
+ callId: '1',
1495
+ name: toolName,
1496
+ args: {},
1497
+ isClientInitiated: false,
1498
+ prompt_id: 'prompt-id-1',
1499
+ };
1500
+ await scheduler.schedule(request, abortController.signal);
1501
+ expect(mockPolicyEngineCheck).toHaveBeenCalledWith(expect.objectContaining({ name: toolName }), serverName);
1502
+ });
1503
+ it('should not double-report completed tools when concurrent completions occur', async () => {
1504
+ // Arrange
1505
+ const executeFn = vi.fn().mockResolvedValue({ llmContent: 'success' });
1506
+ const mockTool = new MockTool({ name: 'mockTool', execute: executeFn });
1507
+ const declarativeTool = mockTool;
1508
+ const mockToolRegistry = {
1509
+ getTool: () => declarativeTool,
1510
+ getToolByName: () => declarativeTool,
1511
+ getFunctionDeclarations: () => [],
1512
+ tools: new Map(),
1513
+ discovery: {},
1514
+ registerTool: () => { },
1515
+ getToolByDisplayName: () => declarativeTool,
1516
+ getTools: () => [],
1517
+ discoverTools: async () => { },
1518
+ getAllTools: () => [],
1519
+ getToolsByServer: () => [],
1520
+ };
1521
+ let completionCallCount = 0;
1522
+ const onAllToolCallsComplete = vi.fn().mockImplementation(async () => {
1523
+ completionCallCount++;
1524
+ // Simulate slow reporting (e.g. Gemini API call)
1525
+ await new Promise((resolve) => setTimeout(resolve, 50));
1526
+ });
1527
+ const mockConfig = createMockConfig({
1528
+ getToolRegistry: () => mockToolRegistry,
1529
+ getApprovalMode: () => ApprovalMode.YOLO,
1530
+ isInteractive: () => false,
1531
+ });
1532
+ const mockMessageBus = createMockMessageBus();
1533
+ mockConfig.getMessageBus = vi.fn().mockReturnValue(mockMessageBus);
1534
+ mockConfig.getEnableHooks = vi.fn().mockReturnValue(false);
1535
+ mockConfig.getHookSystem = vi
1536
+ .fn()
1537
+ .mockReturnValue(new HookSystem(mockConfig));
1538
+ const scheduler = new CoreToolScheduler({
1539
+ config: mockConfig,
1540
+ onAllToolCallsComplete,
1541
+ getPreferredEditor: () => 'vscode',
1542
+ });
1543
+ const abortController = new AbortController();
1544
+ const request = {
1545
+ callId: '1',
1546
+ name: 'mockTool',
1547
+ args: {},
1548
+ isClientInitiated: false,
1549
+ prompt_id: 'prompt-1',
1550
+ };
1551
+ // Act
1552
+ // 1. Start execution
1553
+ const schedulePromise = scheduler.schedule([request], abortController.signal);
1554
+ // 2. Wait just enough for it to finish and enter checkAndNotifyCompletion
1555
+ // (awaiting our slow mock)
1556
+ await vi.waitFor(() => {
1557
+ expect(completionCallCount).toBe(1);
1558
+ });
1559
+ // 3. Trigger a concurrent completion event (e.g. via cancelAll)
1560
+ scheduler.cancelAll(abortController.signal);
1561
+ await schedulePromise;
1562
+ // Assert
1563
+ // Even though cancelAll was called while the first completion was in progress,
1564
+ // it should not have triggered a SECOND completion call because the first one
1565
+ // was still 'finalizing' and will drain any new tools.
1566
+ expect(onAllToolCallsComplete).toHaveBeenCalledTimes(1);
1567
+ });
1568
+ it('should complete reporting all tools even mid-callback during abort', async () => {
1569
+ // Arrange
1570
+ const onAllToolCallsComplete = vi.fn().mockImplementation(async () => {
1571
+ // Simulate slow reporting
1572
+ await new Promise((resolve) => setTimeout(resolve, 50));
1573
+ });
1574
+ const mockTool = new MockTool({ name: 'mockTool' });
1575
+ const mockToolRegistry = {
1576
+ getTool: () => mockTool,
1577
+ getToolByName: () => mockTool,
1578
+ getFunctionDeclarations: () => [],
1579
+ tools: new Map(),
1580
+ discovery: {},
1581
+ registerTool: () => { },
1582
+ getToolByDisplayName: () => mockTool,
1583
+ getTools: () => [],
1584
+ discoverTools: async () => { },
1585
+ getAllTools: () => [],
1586
+ getToolsByServer: () => [],
1587
+ };
1588
+ const mockConfig = createMockConfig({
1589
+ getToolRegistry: () => mockToolRegistry,
1590
+ getApprovalMode: () => ApprovalMode.YOLO,
1591
+ isInteractive: () => false,
1592
+ });
1593
+ mockConfig.getHookSystem = vi.fn().mockReturnValue(undefined);
1594
+ const scheduler = new CoreToolScheduler({
1595
+ config: mockConfig,
1596
+ onAllToolCallsComplete,
1597
+ getPreferredEditor: () => 'vscode',
1598
+ });
1599
+ const abortController = new AbortController();
1600
+ const signal = abortController.signal;
1601
+ // Act
1602
+ // 1. Start execution of two tools
1603
+ const schedulePromise = scheduler.schedule([
1604
+ {
1605
+ callId: '1',
1606
+ name: 'mockTool',
1607
+ args: {},
1608
+ isClientInitiated: false,
1609
+ prompt_id: 'prompt-1',
1610
+ },
1611
+ {
1612
+ callId: '2',
1613
+ name: 'mockTool',
1614
+ args: {},
1615
+ isClientInitiated: false,
1616
+ prompt_id: 'prompt-1',
1617
+ },
1618
+ ], signal);
1619
+ // 2. Wait for reporting to start
1620
+ await vi.waitFor(() => {
1621
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
1622
+ });
1623
+ // 3. Abort the signal while reporting is in progress
1624
+ abortController.abort();
1625
+ await schedulePromise;
1626
+ // Assert
1627
+ // Verify that onAllToolCallsComplete was called and processed the tools,
1628
+ // and that the scheduler didn't just drop them because of the abort.
1629
+ expect(onAllToolCallsComplete).toHaveBeenCalled();
1630
+ const reportedTools = onAllToolCallsComplete.mock.calls.flatMap((call) =>
1631
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1632
+ call[0].map((t) => t.request.callId));
1633
+ // Both tools should have been reported exactly once with success status
1634
+ expect(reportedTools).toContain('1');
1635
+ expect(reportedTools).toContain('2');
1636
+ const allStatuses = onAllToolCallsComplete.mock.calls.flatMap((call) =>
1637
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
1638
+ call[0].map((t) => t.status));
1639
+ expect(allStatuses).toEqual(['success', 'success']);
1640
+ expect(onAllToolCallsComplete).toHaveBeenCalledTimes(1);
1641
+ });
1642
+ describe('Policy Decisions in Plan Mode', () => {
1643
+ it('should return STOP_EXECUTION error type and informative message when denied in Plan Mode', async () => {
1644
+ const mockTool = new MockTool({
1645
+ name: 'dangerous_tool',
1646
+ displayName: 'Dangerous Tool',
1647
+ description: 'Does risky stuff',
1648
+ });
1649
+ const mockToolRegistry = {
1650
+ getTool: () => mockTool,
1651
+ getAllToolNames: () => ['dangerous_tool'],
1652
+ };
1653
+ const onAllToolCallsComplete = vi.fn();
1654
+ const mockConfig = createMockConfig({
1655
+ getToolRegistry: () => mockToolRegistry,
1656
+ getApprovalMode: () => ApprovalMode.PLAN,
1657
+ getPolicyEngine: () => ({
1658
+ check: async () => ({ decision: PolicyDecision.DENY }),
1659
+ }),
1660
+ });
1661
+ mockConfig.getHookSystem = vi.fn().mockReturnValue(undefined);
1662
+ const scheduler = new CoreToolScheduler({
1663
+ config: mockConfig,
1664
+ onAllToolCallsComplete,
1665
+ getPreferredEditor: () => 'vscode',
1666
+ });
1667
+ const request = {
1668
+ callId: 'call-1',
1669
+ name: 'dangerous_tool',
1670
+ args: {},
1671
+ isClientInitiated: false,
1672
+ prompt_id: 'prompt-1',
1673
+ };
1674
+ await scheduler.schedule(request, new AbortController().signal);
1675
+ expect(onAllToolCallsComplete).toHaveBeenCalledTimes(1);
1676
+ const reportedTools = onAllToolCallsComplete.mock.calls[0][0];
1677
+ const result = reportedTools[0];
1678
+ expect(result.status).toBe('error');
1679
+ expect(result.response.errorType).toBe(ToolErrorType.STOP_EXECUTION);
1680
+ expect(result.response.error.message).toBe(PLAN_MODE_DENIAL_MESSAGE);
1681
+ });
1682
+ });
1683
+ });
1684
+ //# sourceMappingURL=coreToolScheduler.test.js.map