@machina.ai/cell-cli-core 1.22.5-rc1 → 1.25.0-rc2

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 (732) hide show
  1. package/dist/docs/AFTER_MERGE_PROMPT.md +26 -0
  2. package/dist/docs/CHANGES.md +124 -0
  3. package/dist/docs/api-proxy.md +27 -0
  4. package/dist/docs/architecture.md +80 -0
  5. package/dist/docs/assets/connected_devtools.png +0 -0
  6. package/dist/docs/assets/gemini-screenshot.png +0 -0
  7. package/dist/docs/assets/monitoring-dashboard-logs.png +0 -0
  8. package/dist/docs/assets/monitoring-dashboard-metrics.png +0 -0
  9. package/dist/docs/assets/monitoring-dashboard-overview.png +0 -0
  10. package/dist/docs/assets/release_patch.png +0 -0
  11. package/dist/docs/assets/theme-ansi-light.png +0 -0
  12. package/dist/docs/assets/theme-ansi.png +0 -0
  13. package/dist/docs/assets/theme-atom-one.png +0 -0
  14. package/dist/docs/assets/theme-ayu-light.png +0 -0
  15. package/dist/docs/assets/theme-ayu.png +0 -0
  16. package/dist/docs/assets/theme-custom.png +0 -0
  17. package/dist/docs/assets/theme-default-light.png +0 -0
  18. package/dist/docs/assets/theme-default.png +0 -0
  19. package/dist/docs/assets/theme-dracula.png +0 -0
  20. package/dist/docs/assets/theme-github-light.png +0 -0
  21. package/dist/docs/assets/theme-github.png +0 -0
  22. package/dist/docs/assets/theme-google-light.png +0 -0
  23. package/dist/docs/assets/theme-xcode-light.png +0 -0
  24. package/dist/docs/changelogs/index.md +612 -0
  25. package/dist/docs/changelogs/latest.md +153 -0
  26. package/dist/docs/changelogs/preview.md +131 -0
  27. package/dist/docs/changelogs/releases.md +1162 -0
  28. package/dist/docs/cli/authentication.md +3 -0
  29. package/dist/docs/cli/checkpointing.md +94 -0
  30. package/dist/docs/cli/commands.md +357 -0
  31. package/dist/docs/cli/custom-commands.md +315 -0
  32. package/dist/docs/cli/enterprise.md +564 -0
  33. package/dist/docs/cli/gemini-ignore.md +71 -0
  34. package/dist/docs/cli/gemini-md.md +109 -0
  35. package/dist/docs/cli/generation-settings.md +210 -0
  36. package/dist/docs/cli/headless.md +388 -0
  37. package/dist/docs/cli/index.md +63 -0
  38. package/dist/docs/cli/keyboard-shortcuts.md +136 -0
  39. package/dist/docs/cli/model-routing.md +37 -0
  40. package/dist/docs/cli/model.md +62 -0
  41. package/dist/docs/cli/sandbox.md +171 -0
  42. package/dist/docs/cli/session-management.md +158 -0
  43. package/dist/docs/cli/settings.md +148 -0
  44. package/dist/docs/cli/skills.md +188 -0
  45. package/dist/docs/cli/system-prompt.md +94 -0
  46. package/dist/docs/cli/telemetry.md +813 -0
  47. package/dist/docs/cli/themes.md +237 -0
  48. package/dist/docs/cli/token-caching.md +20 -0
  49. package/dist/docs/cli/trusted-folders.md +95 -0
  50. package/dist/docs/cli/tutorials/skills-getting-started.md +124 -0
  51. package/dist/docs/cli/tutorials.md +87 -0
  52. package/dist/docs/cli/uninstall.md +47 -0
  53. package/dist/docs/core/index.md +101 -0
  54. package/dist/docs/core/memport.md +246 -0
  55. package/dist/docs/core/policy-engine.md +268 -0
  56. package/dist/docs/core/tools-api.md +131 -0
  57. package/dist/docs/examples/proxy-script.md +83 -0
  58. package/dist/docs/extensions/extension-releasing.md +183 -0
  59. package/dist/docs/extensions/getting-started-extensions.md +244 -0
  60. package/dist/docs/extensions/index.md +343 -0
  61. package/dist/docs/faq.md +153 -0
  62. package/dist/docs/get-started/authentication.md +321 -0
  63. package/dist/docs/get-started/configuration-v1.md +890 -0
  64. package/dist/docs/get-started/configuration.md +1643 -0
  65. package/dist/docs/get-started/examples.md +218 -0
  66. package/dist/docs/get-started/gemini-3.md +101 -0
  67. package/dist/docs/get-started/index.md +71 -0
  68. package/dist/docs/get-started/installation.md +141 -0
  69. package/dist/docs/hooks/best-practices.md +856 -0
  70. package/dist/docs/hooks/index.md +723 -0
  71. package/dist/docs/hooks/reference.md +178 -0
  72. package/dist/docs/hooks/writing-hooks.md +1044 -0
  73. package/dist/docs/ide-integration/ide-companion-spec.md +267 -0
  74. package/dist/docs/ide-integration/index.md +201 -0
  75. package/dist/docs/index.md +147 -0
  76. package/dist/docs/integration-tests.md +211 -0
  77. package/dist/docs/issue-and-pr-automation.md +134 -0
  78. package/dist/docs/local-development.md +128 -0
  79. package/dist/docs/mcp_integration.md +160 -0
  80. package/dist/docs/mermaid/context.mmd +103 -0
  81. package/dist/docs/mermaid/render-path.mmd +64 -0
  82. package/dist/docs/npm.md +62 -0
  83. package/dist/docs/quota-and-pricing.md +158 -0
  84. package/dist/docs/release-confidence.md +164 -0
  85. package/dist/docs/releases.md +540 -0
  86. package/dist/docs/sidebar.json +301 -0
  87. package/dist/docs/tools/file-system.md +217 -0
  88. package/dist/docs/tools/index.md +95 -0
  89. package/dist/docs/tools/mcp-server.md +1045 -0
  90. package/dist/docs/tools/memory.md +54 -0
  91. package/dist/docs/tools/shell.md +260 -0
  92. package/dist/docs/tools/todos.md +56 -0
  93. package/dist/docs/tools/web-fetch.md +59 -0
  94. package/dist/docs/tools/web-search.md +42 -0
  95. package/dist/docs/tos-privacy.md +96 -0
  96. package/dist/docs/troubleshooting.md +162 -0
  97. package/dist/package.json +7 -4
  98. package/dist/src/agents/a2a-client-manager.d.ts +82 -0
  99. package/dist/src/agents/a2a-client-manager.js +295 -0
  100. package/dist/src/agents/a2a-client-manager.js.map +1 -0
  101. package/dist/src/agents/a2a-client-manager.test.js +281 -0
  102. package/dist/src/agents/a2a-client-manager.test.js.map +1 -0
  103. package/dist/src/agents/a2aUtils.d.ts +29 -0
  104. package/dist/src/agents/a2aUtils.js +113 -0
  105. package/dist/src/agents/a2aUtils.js.map +1 -0
  106. package/dist/src/agents/a2aUtils.test.js +147 -0
  107. package/dist/src/agents/a2aUtils.test.js.map +1 -0
  108. package/dist/src/agents/agentLoader.d.ts +68 -0
  109. package/dist/src/agents/agentLoader.js +255 -0
  110. package/dist/src/agents/agentLoader.js.map +1 -0
  111. package/dist/src/agents/agentLoader.test.js +307 -0
  112. package/dist/src/agents/agentLoader.test.js.map +1 -0
  113. package/dist/src/agents/cli-help-agent.d.ts +24 -0
  114. package/dist/src/agents/cli-help-agent.js +85 -0
  115. package/dist/src/agents/cli-help-agent.js.map +1 -0
  116. package/dist/src/agents/cli-help-agent.test.js +65 -0
  117. package/dist/src/agents/cli-help-agent.test.js.map +1 -0
  118. package/dist/src/agents/codebase-investigator.d.ts +2 -2
  119. package/dist/src/agents/codebase-investigator.js +14 -8
  120. package/dist/src/agents/codebase-investigator.js.map +1 -1
  121. package/dist/src/agents/delegate-to-agent-tool.d.ts +2 -2
  122. package/dist/src/agents/delegate-to-agent-tool.js +25 -14
  123. package/dist/src/agents/delegate-to-agent-tool.js.map +1 -1
  124. package/dist/src/agents/delegate-to-agent-tool.test.js +101 -21
  125. package/dist/src/agents/delegate-to-agent-tool.test.js.map +1 -1
  126. package/dist/src/agents/{executor.d.ts → local-executor.d.ts} +5 -11
  127. package/dist/src/agents/{executor.js → local-executor.js} +123 -62
  128. package/dist/src/agents/local-executor.js.map +1 -0
  129. package/dist/src/agents/local-executor.test.d.ts +6 -0
  130. package/dist/src/agents/{executor.test.js → local-executor.test.js} +136 -58
  131. package/dist/src/agents/local-executor.test.js.map +1 -0
  132. package/dist/src/agents/{invocation.d.ts → local-invocation.d.ts} +6 -7
  133. package/dist/src/agents/{invocation.js → local-invocation.js} +9 -10
  134. package/dist/src/agents/local-invocation.js.map +1 -0
  135. package/dist/src/agents/local-invocation.test.d.ts +6 -0
  136. package/dist/src/agents/{invocation.test.js → local-invocation.test.js} +29 -20
  137. package/dist/src/agents/local-invocation.test.js.map +1 -0
  138. package/dist/src/agents/registry.d.ts +22 -1
  139. package/dist/src/agents/registry.js +192 -35
  140. package/dist/src/agents/registry.js.map +1 -1
  141. package/dist/src/agents/registry.test.js +407 -33
  142. package/dist/src/agents/registry.test.js.map +1 -1
  143. package/dist/src/agents/remote-invocation.d.ts +35 -0
  144. package/dist/src/agents/remote-invocation.js +126 -0
  145. package/dist/src/agents/remote-invocation.js.map +1 -0
  146. package/dist/src/agents/remote-invocation.test.d.ts +6 -0
  147. package/dist/src/agents/remote-invocation.test.js +201 -0
  148. package/dist/src/agents/remote-invocation.test.js.map +1 -0
  149. package/dist/src/agents/subagent-tool-wrapper.d.ts +2 -2
  150. package/dist/src/agents/subagent-tool-wrapper.js +11 -6
  151. package/dist/src/agents/subagent-tool-wrapper.js.map +1 -1
  152. package/dist/src/agents/subagent-tool-wrapper.test.js +33 -19
  153. package/dist/src/agents/subagent-tool-wrapper.test.js.map +1 -1
  154. package/dist/src/agents/types.d.ts +21 -15
  155. package/dist/src/agents/types.js.map +1 -1
  156. package/dist/src/availability/fallbackIntegration.test.d.ts +6 -0
  157. package/dist/src/availability/fallbackIntegration.test.js +58 -0
  158. package/dist/src/availability/fallbackIntegration.test.js.map +1 -0
  159. package/dist/src/availability/modelAvailabilityService.d.ts +2 -1
  160. package/dist/src/availability/policyHelpers.d.ts +4 -3
  161. package/dist/src/availability/policyHelpers.js +13 -22
  162. package/dist/src/availability/policyHelpers.js.map +1 -1
  163. package/dist/src/availability/policyHelpers.test.js +28 -18
  164. package/dist/src/availability/policyHelpers.test.js.map +1 -1
  165. package/dist/src/code_assist/experiments/experiments.d.ts +1 -1
  166. package/dist/src/code_assist/experiments/experiments.js +21 -0
  167. package/dist/src/code_assist/experiments/experiments.js.map +1 -1
  168. package/dist/src/code_assist/experiments/experiments_local.test.d.ts +6 -0
  169. package/dist/src/code_assist/experiments/experiments_local.test.js +110 -0
  170. package/dist/src/code_assist/experiments/experiments_local.test.js.map +1 -0
  171. package/dist/src/code_assist/oauth-credential-storage.js +3 -4
  172. package/dist/src/code_assist/oauth-credential-storage.js.map +1 -1
  173. package/dist/src/code_assist/oauth2.js +32 -2
  174. package/dist/src/code_assist/oauth2.js.map +1 -1
  175. package/dist/src/code_assist/oauth2.test.js +111 -16
  176. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  177. package/dist/src/code_assist/server.d.ts +9 -1
  178. package/dist/src/code_assist/server.js +74 -11
  179. package/dist/src/code_assist/server.js.map +1 -1
  180. package/dist/src/code_assist/server.test.js +199 -27
  181. package/dist/src/code_assist/server.test.js.map +1 -1
  182. package/dist/src/code_assist/setup.js +6 -4
  183. package/dist/src/code_assist/setup.js.map +1 -1
  184. package/dist/src/code_assist/setup.test.js +63 -0
  185. package/dist/src/code_assist/setup.test.js.map +1 -1
  186. package/dist/src/code_assist/telemetry.d.ts +14 -0
  187. package/dist/src/code_assist/telemetry.js +157 -0
  188. package/dist/src/code_assist/telemetry.js.map +1 -0
  189. package/dist/src/code_assist/telemetry.test.d.ts +6 -0
  190. package/dist/src/code_assist/telemetry.test.js +301 -0
  191. package/dist/src/code_assist/telemetry.test.js.map +1 -0
  192. package/dist/src/code_assist/types.d.ts +77 -1
  193. package/dist/src/code_assist/types.js +28 -0
  194. package/dist/src/code_assist/types.js.map +1 -1
  195. package/dist/src/commands/memory.d.ts +11 -0
  196. package/dist/src/commands/memory.js +80 -0
  197. package/dist/src/commands/memory.js.map +1 -0
  198. package/dist/src/commands/memory.test.d.ts +6 -0
  199. package/dist/src/commands/memory.test.js +155 -0
  200. package/dist/src/commands/memory.test.js.map +1 -0
  201. package/dist/src/config/config.d.ts +120 -26
  202. package/dist/src/config/config.js +241 -120
  203. package/dist/src/config/config.js.map +1 -1
  204. package/dist/src/config/config.test.js +215 -43
  205. package/dist/src/config/config.test.js.map +1 -1
  206. package/dist/src/config/flashFallback.test.js +11 -35
  207. package/dist/src/config/flashFallback.test.js.map +1 -1
  208. package/dist/src/config/models.d.ts +8 -9
  209. package/dist/src/config/models.js +18 -15
  210. package/dist/src/config/models.js.map +1 -1
  211. package/dist/src/config/models.test.js +52 -16
  212. package/dist/src/config/models.test.js.map +1 -1
  213. package/dist/src/config/storage.d.ts +5 -0
  214. package/dist/src/config/storage.js +17 -2
  215. package/dist/src/config/storage.js.map +1 -1
  216. package/dist/src/config/storage.test.js +16 -0
  217. package/dist/src/config/storage.test.js.map +1 -1
  218. package/dist/src/confirmation-bus/message-bus.js +2 -1
  219. package/dist/src/confirmation-bus/message-bus.js.map +1 -1
  220. package/dist/src/core/baseLlmClient.js +44 -43
  221. package/dist/src/core/baseLlmClient.js.map +1 -1
  222. package/dist/src/core/baseLlmClient.test.js +12 -19
  223. package/dist/src/core/baseLlmClient.test.js.map +1 -1
  224. package/dist/src/core/client.d.ts +7 -1
  225. package/dist/src/core/client.js +245 -114
  226. package/dist/src/core/client.js.map +1 -1
  227. package/dist/src/core/client.test.js +277 -74
  228. package/dist/src/core/client.test.js.map +1 -1
  229. package/dist/src/core/clientHookTriggers.js +2 -2
  230. package/dist/src/core/clientHookTriggers.js.map +1 -1
  231. package/dist/src/core/contentGenerator.js +3 -3
  232. package/dist/src/core/contentGenerator.js.map +1 -1
  233. package/dist/src/core/contentGenerator.test.js +1 -7
  234. package/dist/src/core/contentGenerator.test.js.map +1 -1
  235. package/dist/src/core/coreToolHookTriggers.d.ts +9 -5
  236. package/dist/src/core/coreToolHookTriggers.js +119 -21
  237. package/dist/src/core/coreToolHookTriggers.js.map +1 -1
  238. package/dist/src/core/coreToolHookTriggers.test.d.ts +6 -0
  239. package/dist/src/core/coreToolHookTriggers.test.js +191 -0
  240. package/dist/src/core/coreToolHookTriggers.test.js.map +1 -0
  241. package/dist/src/core/coreToolScheduler.d.ts +7 -93
  242. package/dist/src/core/coreToolScheduler.js +133 -369
  243. package/dist/src/core/coreToolScheduler.js.map +1 -1
  244. package/dist/src/core/coreToolScheduler.test.js +252 -394
  245. package/dist/src/core/coreToolScheduler.test.js.map +1 -1
  246. package/dist/src/core/geminiChat.d.ts +26 -1
  247. package/dist/src/core/geminiChat.js +112 -79
  248. package/dist/src/core/geminiChat.js.map +1 -1
  249. package/dist/src/core/geminiChat.test.js +125 -92
  250. package/dist/src/core/geminiChat.test.js.map +1 -1
  251. package/dist/src/core/geminiChatHookTriggers.d.ts +8 -4
  252. package/dist/src/core/geminiChatHookTriggers.js +34 -12
  253. package/dist/src/core/geminiChatHookTriggers.js.map +1 -1
  254. package/dist/src/core/geminiChatHookTriggers.test.d.ts +6 -0
  255. package/dist/src/core/geminiChatHookTriggers.test.js +153 -0
  256. package/dist/src/core/geminiChatHookTriggers.test.js.map +1 -0
  257. package/dist/src/core/geminiChat_network_retry.test.js +4 -6
  258. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -1
  259. package/dist/src/core/loggingContentGenerator.js +19 -2
  260. package/dist/src/core/loggingContentGenerator.js.map +1 -1
  261. package/dist/src/core/loggingContentGenerator.test.js +30 -0
  262. package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
  263. package/dist/src/core/nonInteractiveToolExecutor.test.js +4 -4
  264. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -1
  265. package/dist/src/core/prompts.js +37 -13
  266. package/dist/src/core/prompts.js.map +1 -1
  267. package/dist/src/core/prompts.test.js +47 -3
  268. package/dist/src/core/prompts.test.js.map +1 -1
  269. package/dist/src/core/tokenLimits.js +6 -12
  270. package/dist/src/core/tokenLimits.js.map +1 -1
  271. package/dist/src/core/tokenLimits.test.js +8 -4
  272. package/dist/src/core/tokenLimits.test.js.map +1 -1
  273. package/dist/src/core/turn.d.ts +21 -22
  274. package/dist/src/core/turn.js +31 -21
  275. package/dist/src/core/turn.js.map +1 -1
  276. package/dist/src/core/turn.test.js +79 -5
  277. package/dist/src/core/turn.test.js.map +1 -1
  278. package/dist/src/fallback/handler.js +1 -7
  279. package/dist/src/fallback/handler.js.map +1 -1
  280. package/dist/src/fallback/handler.test.js +10 -29
  281. package/dist/src/fallback/handler.test.js.map +1 -1
  282. package/dist/src/generated/git-commit.d.ts +3 -3
  283. package/dist/src/generated/git-commit.js +3 -3
  284. package/dist/src/hooks/hookAggregator.js +7 -0
  285. package/dist/src/hooks/hookAggregator.js.map +1 -1
  286. package/dist/src/hooks/hookEventHandler.d.ts +9 -5
  287. package/dist/src/hooks/hookEventHandler.js +61 -15
  288. package/dist/src/hooks/hookEventHandler.js.map +1 -1
  289. package/dist/src/hooks/hookEventHandler.test.js +223 -8
  290. package/dist/src/hooks/hookEventHandler.test.js.map +1 -1
  291. package/dist/src/hooks/hookPlanner.d.ts +1 -5
  292. package/dist/src/hooks/hookPlanner.js +2 -7
  293. package/dist/src/hooks/hookPlanner.js.map +1 -1
  294. package/dist/src/hooks/hookPlanner.test.js +62 -2
  295. package/dist/src/hooks/hookPlanner.test.js.map +1 -1
  296. package/dist/src/hooks/hookRegistry.d.ts +6 -11
  297. package/dist/src/hooks/hookRegistry.js +41 -14
  298. package/dist/src/hooks/hookRegistry.js.map +1 -1
  299. package/dist/src/hooks/hookRegistry.test.js +166 -2
  300. package/dist/src/hooks/hookRegistry.test.js.map +1 -1
  301. package/dist/src/hooks/hookRunner.d.ts +5 -3
  302. package/dist/src/hooks/hookRunner.js +57 -17
  303. package/dist/src/hooks/hookRunner.js.map +1 -1
  304. package/dist/src/hooks/hookRunner.test.js +172 -35
  305. package/dist/src/hooks/hookRunner.test.js.map +1 -1
  306. package/dist/src/hooks/hookSystem.d.ts +12 -0
  307. package/dist/src/hooks/hookSystem.js +39 -1
  308. package/dist/src/hooks/hookSystem.js.map +1 -1
  309. package/dist/src/hooks/hookTranslator.js +2 -1
  310. package/dist/src/hooks/hookTranslator.js.map +1 -1
  311. package/dist/src/hooks/index.d.ts +1 -2
  312. package/dist/src/hooks/index.js +1 -3
  313. package/dist/src/hooks/index.js.map +1 -1
  314. package/dist/src/hooks/trustedHooks.d.ts +28 -0
  315. package/dist/src/hooks/trustedHooks.js +90 -0
  316. package/dist/src/hooks/trustedHooks.js.map +1 -0
  317. package/dist/src/hooks/trustedHooks.test.d.ts +6 -0
  318. package/dist/src/hooks/trustedHooks.test.js +154 -0
  319. package/dist/src/hooks/trustedHooks.test.js.map +1 -0
  320. package/dist/src/hooks/types.d.ts +41 -9
  321. package/dist/src/hooks/types.js +31 -41
  322. package/dist/src/hooks/types.js.map +1 -1
  323. package/dist/src/hooks/types.test.js +9 -52
  324. package/dist/src/hooks/types.test.js.map +1 -1
  325. package/dist/src/ide/detect-ide.d.ts +4 -0
  326. package/dist/src/ide/detect-ide.js +7 -2
  327. package/dist/src/ide/detect-ide.js.map +1 -1
  328. package/dist/src/ide/detect-ide.test.js +10 -0
  329. package/dist/src/ide/detect-ide.test.js.map +1 -1
  330. package/dist/src/ide/ide-client.js +4 -1
  331. package/dist/src/ide/ide-client.js.map +1 -1
  332. package/dist/src/ide/ide-installer.js +2 -2
  333. package/dist/src/ide/ide-installer.js.map +1 -1
  334. package/dist/src/ide/ide-installer.test.js +11 -2
  335. package/dist/src/ide/ide-installer.test.js.map +1 -1
  336. package/dist/src/index.d.ts +16 -2
  337. package/dist/src/index.js +18 -3
  338. package/dist/src/index.js.map +1 -1
  339. package/dist/src/mcp/oauth-provider.js +7 -3
  340. package/dist/src/mcp/oauth-provider.js.map +1 -1
  341. package/dist/src/mcp/oauth-provider.test.js +4 -1
  342. package/dist/src/mcp/oauth-provider.test.js.map +1 -1
  343. package/dist/src/mcp/oauth-utils.d.ts +8 -1
  344. package/dist/src/mcp/oauth-utils.js +31 -2
  345. package/dist/src/mcp/oauth-utils.js.map +1 -1
  346. package/dist/src/mcp/oauth-utils.test.js +42 -0
  347. package/dist/src/mcp/oauth-utils.test.js.map +1 -1
  348. package/dist/src/mcp/token-storage/file-token-storage.js +2 -2
  349. package/dist/src/mcp/token-storage/file-token-storage.js.map +1 -1
  350. package/dist/src/mcp/token-storage/keychain-token-storage.js +1 -1
  351. package/dist/src/mcp/token-storage/keychain-token-storage.js.map +1 -1
  352. package/dist/src/policy/config.js +62 -23
  353. package/dist/src/policy/config.js.map +1 -1
  354. package/dist/src/policy/config.test.js +24 -2
  355. package/dist/src/policy/config.test.js.map +1 -1
  356. package/dist/src/policy/persistence.test.js +1 -1
  357. package/dist/src/policy/persistence.test.js.map +1 -1
  358. package/dist/src/policy/policies/agent.toml +1 -1
  359. package/dist/src/policy/policies/write.toml +5 -0
  360. package/dist/src/policy/policies/yolo.toml +1 -0
  361. package/dist/src/policy/policy-engine.d.ts +4 -0
  362. package/dist/src/policy/policy-engine.js +137 -53
  363. package/dist/src/policy/policy-engine.js.map +1 -1
  364. package/dist/src/policy/policy-engine.test.js +289 -1
  365. package/dist/src/policy/policy-engine.test.js.map +1 -1
  366. package/dist/src/policy/policy-updater.test.js +5 -5
  367. package/dist/src/policy/policy-updater.test.js.map +1 -1
  368. package/dist/src/policy/shell-safety.test.js +371 -8
  369. package/dist/src/policy/shell-safety.test.js.map +1 -1
  370. package/dist/src/policy/toml-loader.d.ts +0 -8
  371. package/dist/src/policy/toml-loader.js +13 -45
  372. package/dist/src/policy/toml-loader.js.map +1 -1
  373. package/dist/src/policy/toml-loader.test.js +13 -0
  374. package/dist/src/policy/toml-loader.test.js.map +1 -1
  375. package/dist/src/policy/types.d.ts +10 -0
  376. package/dist/src/policy/utils.d.ts +21 -0
  377. package/dist/src/policy/utils.js +45 -0
  378. package/dist/src/policy/utils.js.map +1 -0
  379. package/dist/src/policy/utils.test.d.ts +6 -0
  380. package/dist/src/policy/utils.test.js +92 -0
  381. package/dist/src/policy/utils.test.js.map +1 -0
  382. package/dist/src/routing/routingStrategy.d.ts +2 -0
  383. package/dist/src/routing/strategies/classifierStrategy.js +1 -1
  384. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -1
  385. package/dist/src/routing/strategies/classifierStrategy.test.js +16 -0
  386. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -1
  387. package/dist/src/routing/strategies/compositeStrategy.js +4 -2
  388. package/dist/src/routing/strategies/compositeStrategy.js.map +1 -1
  389. package/dist/src/routing/strategies/compositeStrategy.test.js +11 -10
  390. package/dist/src/routing/strategies/compositeStrategy.test.js.map +1 -1
  391. package/dist/src/routing/strategies/fallbackStrategy.d.ts +1 -1
  392. package/dist/src/routing/strategies/fallbackStrategy.js +2 -5
  393. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -1
  394. package/dist/src/routing/strategies/fallbackStrategy.test.js +13 -6
  395. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -1
  396. package/dist/src/routing/strategies/overrideStrategy.d.ts +1 -1
  397. package/dist/src/routing/strategies/overrideStrategy.js +6 -6
  398. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -1
  399. package/dist/src/routing/strategies/overrideStrategy.test.js +14 -0
  400. package/dist/src/routing/strategies/overrideStrategy.test.js.map +1 -1
  401. package/dist/src/scheduler/tool-executor.d.ts +22 -0
  402. package/dist/src/scheduler/tool-executor.js +198 -0
  403. package/dist/src/scheduler/tool-executor.js.map +1 -0
  404. package/dist/src/scheduler/tool-executor.test.d.ts +6 -0
  405. package/dist/src/scheduler/tool-executor.test.js +231 -0
  406. package/dist/src/scheduler/tool-executor.test.js.map +1 -0
  407. package/dist/src/scheduler/tool-modifier.d.ts +23 -0
  408. package/dist/src/scheduler/tool-modifier.js +50 -0
  409. package/dist/src/scheduler/tool-modifier.js.map +1 -0
  410. package/dist/src/scheduler/tool-modifier.test.d.ts +6 -0
  411. package/dist/src/scheduler/tool-modifier.test.js +159 -0
  412. package/dist/src/scheduler/tool-modifier.test.js.map +1 -0
  413. package/dist/src/scheduler/types.d.ts +95 -0
  414. package/dist/src/scheduler/types.js +7 -0
  415. package/dist/src/scheduler/types.js.map +1 -0
  416. package/dist/src/services/chatCompressionService.js +3 -10
  417. package/dist/src/services/chatCompressionService.js.map +1 -1
  418. package/dist/src/services/chatCompressionService.test.js +1 -0
  419. package/dist/src/services/chatCompressionService.test.js.map +1 -1
  420. package/dist/src/services/chatRecordingService.d.ts +7 -1
  421. package/dist/src/services/chatRecordingService.js +20 -2
  422. package/dist/src/services/chatRecordingService.js.map +1 -1
  423. package/dist/src/services/chatRecordingService.test.js +43 -0
  424. package/dist/src/services/chatRecordingService.test.js.map +1 -1
  425. package/dist/src/services/contextManager.d.ts +5 -11
  426. package/dist/src/services/contextManager.js +20 -17
  427. package/dist/src/services/contextManager.js.map +1 -1
  428. package/dist/src/services/contextManager.test.js +40 -41
  429. package/dist/src/services/contextManager.test.js.map +1 -1
  430. package/dist/src/services/environmentSanitization.d.ts +15 -0
  431. package/dist/src/services/environmentSanitization.js +142 -0
  432. package/dist/src/services/environmentSanitization.js.map +1 -0
  433. package/dist/src/services/environmentSanitization.test.d.ts +6 -0
  434. package/dist/src/services/environmentSanitization.test.js +284 -0
  435. package/dist/src/services/environmentSanitization.test.js.map +1 -0
  436. package/dist/src/services/gitService.js +10 -1
  437. package/dist/src/services/gitService.js.map +1 -1
  438. package/dist/src/services/gitService.test.js +28 -2
  439. package/dist/src/services/gitService.test.js.map +1 -1
  440. package/dist/src/services/loopDetectionService.js +2 -1
  441. package/dist/src/services/loopDetectionService.js.map +1 -1
  442. package/dist/src/services/loopDetectionService.test.js +14 -8
  443. package/dist/src/services/loopDetectionService.test.js.map +1 -1
  444. package/dist/src/services/modelConfig.integration.test.js +3 -3
  445. package/dist/src/services/modelConfig.integration.test.js.map +1 -1
  446. package/dist/src/services/modelConfigService.d.ts +38 -4
  447. package/dist/src/services/modelConfigService.js +135 -76
  448. package/dist/src/services/modelConfigService.js.map +1 -1
  449. package/dist/src/services/modelConfigService.test.js +116 -0
  450. package/dist/src/services/modelConfigService.test.js.map +1 -1
  451. package/dist/src/services/shellExecutionService.d.ts +2 -0
  452. package/dist/src/services/shellExecutionService.js +6 -50
  453. package/dist/src/services/shellExecutionService.js.map +1 -1
  454. package/dist/src/services/shellExecutionService.test.js +68 -4
  455. package/dist/src/services/shellExecutionService.test.js.map +1 -1
  456. package/dist/src/skills/skillLoader.d.ts +31 -0
  457. package/dist/src/skills/skillLoader.js +77 -0
  458. package/dist/src/skills/skillLoader.js.map +1 -0
  459. package/dist/src/skills/skillLoader.test.d.ts +6 -0
  460. package/dist/src/skills/skillLoader.test.js +75 -0
  461. package/dist/src/skills/skillLoader.test.js.map +1 -0
  462. package/dist/src/skills/skillManager.d.ts +69 -0
  463. package/dist/src/skills/skillManager.js +127 -0
  464. package/dist/src/skills/skillManager.js.map +1 -0
  465. package/dist/src/skills/skillManager.test.d.ts +6 -0
  466. package/dist/src/skills/skillManager.test.js +210 -0
  467. package/dist/src/skills/skillManager.test.js.map +1 -0
  468. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +18 -9
  469. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +234 -160
  470. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
  471. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +162 -32
  472. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
  473. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +11 -3
  474. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +24 -5
  475. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
  476. package/dist/src/telemetry/loggers.d.ts +3 -3
  477. package/dist/src/telemetry/loggers.js +6 -5
  478. package/dist/src/telemetry/loggers.js.map +1 -1
  479. package/dist/src/telemetry/loggers.test.circular.js +1 -0
  480. package/dist/src/telemetry/loggers.test.circular.js.map +1 -1
  481. package/dist/src/telemetry/loggers.test.js +51 -10
  482. package/dist/src/telemetry/loggers.test.js.map +1 -1
  483. package/dist/src/telemetry/sdk.js +5 -6
  484. package/dist/src/telemetry/sdk.js.map +1 -1
  485. package/dist/src/telemetry/types.d.ts +7 -7
  486. package/dist/src/telemetry/types.js +14 -12
  487. package/dist/src/telemetry/types.js.map +1 -1
  488. package/dist/src/test-utils/mock-message-bus.d.ts +1 -0
  489. package/dist/src/test-utils/mock-message-bus.js +29 -0
  490. package/dist/src/test-utils/mock-message-bus.js.map +1 -1
  491. package/dist/src/test-utils/mock-tool.d.ts +5 -3
  492. package/dist/src/test-utils/mock-tool.js +11 -10
  493. package/dist/src/test-utils/mock-tool.js.map +1 -1
  494. package/dist/src/tools/activate-skill.d.ts +27 -0
  495. package/dist/src/tools/activate-skill.js +133 -0
  496. package/dist/src/tools/activate-skill.js.map +1 -0
  497. package/dist/src/tools/activate-skill.test.d.ts +6 -0
  498. package/dist/src/tools/activate-skill.test.js +113 -0
  499. package/dist/src/tools/activate-skill.test.js.map +1 -0
  500. package/dist/src/tools/confirmation-policy.test.js +3 -12
  501. package/dist/src/tools/confirmation-policy.test.js.map +1 -1
  502. package/dist/src/tools/edit.d.ts +27 -5
  503. package/dist/src/tools/edit.js +455 -136
  504. package/dist/src/tools/edit.js.map +1 -1
  505. package/dist/src/tools/edit.test.js +292 -526
  506. package/dist/src/tools/edit.test.js.map +1 -1
  507. package/dist/src/tools/get-internal-docs.d.ts +27 -0
  508. package/dist/src/tools/get-internal-docs.js +122 -0
  509. package/dist/src/tools/get-internal-docs.js.map +1 -0
  510. package/dist/src/tools/get-internal-docs.test.d.ts +6 -0
  511. package/dist/src/tools/get-internal-docs.test.js +57 -0
  512. package/dist/src/tools/get-internal-docs.test.js.map +1 -0
  513. package/dist/src/tools/glob.d.ts +2 -2
  514. package/dist/src/tools/glob.js +1 -1
  515. package/dist/src/tools/glob.js.map +1 -1
  516. package/dist/src/tools/glob.test.js +2 -1
  517. package/dist/src/tools/glob.test.js.map +1 -1
  518. package/dist/src/tools/grep.d.ts +2 -2
  519. package/dist/src/tools/grep.js +1 -1
  520. package/dist/src/tools/grep.js.map +1 -1
  521. package/dist/src/tools/grep.test.js +5 -4
  522. package/dist/src/tools/grep.test.js.map +1 -1
  523. package/dist/src/tools/ls.d.ts +2 -2
  524. package/dist/src/tools/ls.js +2 -2
  525. package/dist/src/tools/ls.js.map +1 -1
  526. package/dist/src/tools/ls.test.js +2 -1
  527. package/dist/src/tools/ls.test.js.map +1 -1
  528. package/dist/src/tools/mcp-client-manager.js +14 -7
  529. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  530. package/dist/src/tools/mcp-client-manager.test.js +28 -0
  531. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  532. package/dist/src/tools/mcp-client.d.ts +5 -4
  533. package/dist/src/tools/mcp-client.js +10 -8
  534. package/dist/src/tools/mcp-client.js.map +1 -1
  535. package/dist/src/tools/mcp-client.test.js +47 -42
  536. package/dist/src/tools/mcp-client.test.js.map +1 -1
  537. package/dist/src/tools/mcp-tool.d.ts +20 -5
  538. package/dist/src/tools/mcp-tool.js +8 -8
  539. package/dist/src/tools/mcp-tool.js.map +1 -1
  540. package/dist/src/tools/mcp-tool.test.js +11 -6
  541. package/dist/src/tools/mcp-tool.test.js.map +1 -1
  542. package/dist/src/tools/memoryTool.d.ts +3 -3
  543. package/dist/src/tools/memoryTool.js +2 -4
  544. package/dist/src/tools/memoryTool.js.map +1 -1
  545. package/dist/src/tools/memoryTool.test.js +5 -2
  546. package/dist/src/tools/memoryTool.test.js.map +1 -1
  547. package/dist/src/tools/message-bus-integration.test.js +10 -37
  548. package/dist/src/tools/message-bus-integration.test.js.map +1 -1
  549. package/dist/src/tools/read-file.d.ts +2 -2
  550. package/dist/src/tools/read-file.js +1 -1
  551. package/dist/src/tools/read-file.js.map +1 -1
  552. package/dist/src/tools/read-file.test.js +3 -2
  553. package/dist/src/tools/read-file.test.js.map +1 -1
  554. package/dist/src/tools/read-many-files.d.ts +2 -2
  555. package/dist/src/tools/read-many-files.js +2 -3
  556. package/dist/src/tools/read-many-files.js.map +1 -1
  557. package/dist/src/tools/read-many-files.test.js +3 -2
  558. package/dist/src/tools/read-many-files.test.js.map +1 -1
  559. package/dist/src/tools/ripGrep.d.ts +3 -2
  560. package/dist/src/tools/ripGrep.js +18 -7
  561. package/dist/src/tools/ripGrep.js.map +1 -1
  562. package/dist/src/tools/ripGrep.test.js +60 -4
  563. package/dist/src/tools/ripGrep.test.js.map +1 -1
  564. package/dist/src/tools/shell.d.ts +3 -6
  565. package/dist/src/tools/shell.js +21 -49
  566. package/dist/src/tools/shell.js.map +1 -1
  567. package/dist/src/tools/shell.test.js +35 -59
  568. package/dist/src/tools/shell.test.js.map +1 -1
  569. package/dist/src/tools/tool-error.d.ts +6 -1
  570. package/dist/src/tools/tool-error.js +6 -0
  571. package/dist/src/tools/tool-error.js.map +1 -1
  572. package/dist/src/tools/tool-names.d.ts +15 -0
  573. package/dist/src/tools/tool-names.js +57 -0
  574. package/dist/src/tools/tool-names.js.map +1 -1
  575. package/dist/src/tools/tool-names.test.d.ts +6 -0
  576. package/dist/src/tools/tool-names.test.js +43 -0
  577. package/dist/src/tools/tool-names.test.js.map +1 -0
  578. package/dist/src/tools/tool-registry.d.ts +11 -7
  579. package/dist/src/tools/tool-registry.js +15 -10
  580. package/dist/src/tools/tool-registry.js.map +1 -1
  581. package/dist/src/tools/tool-registry.test.js +16 -11
  582. package/dist/src/tools/tool-registry.test.js.map +1 -1
  583. package/dist/src/tools/tools.d.ts +8 -6
  584. package/dist/src/tools/tools.js +16 -18
  585. package/dist/src/tools/tools.js.map +1 -1
  586. package/dist/src/tools/tools.test.js +3 -1
  587. package/dist/src/tools/tools.test.js.map +1 -1
  588. package/dist/src/tools/web-fetch.d.ts +2 -2
  589. package/dist/src/tools/web-fetch.js +4 -4
  590. package/dist/src/tools/web-fetch.js.map +1 -1
  591. package/dist/src/tools/web-fetch.test.js +17 -19
  592. package/dist/src/tools/web-fetch.test.js.map +1 -1
  593. package/dist/src/tools/web-search.d.ts +2 -2
  594. package/dist/src/tools/web-search.js +5 -5
  595. package/dist/src/tools/web-search.js.map +1 -1
  596. package/dist/src/tools/web-search.test.js +2 -1
  597. package/dist/src/tools/web-search.test.js.map +1 -1
  598. package/dist/src/tools/write-file.d.ts +2 -2
  599. package/dist/src/tools/write-file.js +9 -6
  600. package/dist/src/tools/write-file.js.map +1 -1
  601. package/dist/src/tools/write-file.test.js +49 -7
  602. package/dist/src/tools/write-file.test.js.map +1 -1
  603. package/dist/src/tools/write-todos.d.ts +2 -2
  604. package/dist/src/tools/write-todos.js +5 -4
  605. package/dist/src/tools/write-todos.js.map +1 -1
  606. package/dist/src/tools/write-todos.test.js +2 -1
  607. package/dist/src/tools/write-todos.test.js.map +1 -1
  608. package/dist/src/utils/apiConversionUtils.d.ts +12 -0
  609. package/dist/src/utils/apiConversionUtils.js +46 -0
  610. package/dist/src/utils/apiConversionUtils.js.map +1 -0
  611. package/dist/src/utils/apiConversionUtils.test.d.ts +6 -0
  612. package/dist/src/utils/apiConversionUtils.test.js +150 -0
  613. package/dist/src/utils/apiConversionUtils.test.js.map +1 -0
  614. package/dist/src/utils/checkpointUtils.d.ts +1 -1
  615. package/dist/src/utils/checkpointUtils.js +1 -1
  616. package/dist/src/utils/checkpointUtils.js.map +1 -1
  617. package/dist/src/utils/checkpointUtils.test.js +1 -1
  618. package/dist/src/utils/checkpointUtils.test.js.map +1 -1
  619. package/dist/src/utils/debugLogger.js +1 -0
  620. package/dist/src/utils/debugLogger.js.map +1 -1
  621. package/dist/src/utils/editCorrector.d.ts +3 -3
  622. package/dist/src/utils/editCorrector.js +27 -10
  623. package/dist/src/utils/editCorrector.js.map +1 -1
  624. package/dist/src/utils/editCorrector.test.js +23 -23
  625. package/dist/src/utils/editCorrector.test.js.map +1 -1
  626. package/dist/src/utils/editor.d.ts +3 -2
  627. package/dist/src/utils/editor.js +26 -6
  628. package/dist/src/utils/editor.js.map +1 -1
  629. package/dist/src/utils/editor.test.js +27 -4
  630. package/dist/src/utils/editor.test.js.map +1 -1
  631. package/dist/src/utils/environmentContext.d.ts +1 -0
  632. package/dist/src/utils/environmentContext.js +4 -0
  633. package/dist/src/utils/environmentContext.js.map +1 -1
  634. package/dist/src/utils/environmentContext.test.js +2 -0
  635. package/dist/src/utils/environmentContext.test.js.map +1 -1
  636. package/dist/src/utils/errorReporting.d.ts +1 -1
  637. package/dist/src/utils/errorReporting.js +13 -12
  638. package/dist/src/utils/errorReporting.js.map +1 -1
  639. package/dist/src/utils/errorReporting.test.js +17 -14
  640. package/dist/src/utils/errorReporting.test.js.map +1 -1
  641. package/dist/src/utils/events.d.ts +71 -19
  642. package/dist/src/utils/events.js +35 -9
  643. package/dist/src/utils/events.js.map +1 -1
  644. package/dist/src/utils/events.test.js +25 -0
  645. package/dist/src/utils/events.test.js.map +1 -1
  646. package/dist/src/utils/fileDiffUtils.d.ts +18 -0
  647. package/dist/src/utils/fileDiffUtils.js +37 -0
  648. package/dist/src/utils/fileDiffUtils.js.map +1 -0
  649. package/dist/src/utils/fileDiffUtils.test.d.ts +6 -0
  650. package/dist/src/utils/fileDiffUtils.test.js +84 -0
  651. package/dist/src/utils/fileDiffUtils.test.js.map +1 -0
  652. package/dist/src/utils/fileUtils.d.ts +4 -0
  653. package/dist/src/utils/fileUtils.js +53 -0
  654. package/dist/src/utils/fileUtils.js.map +1 -1
  655. package/dist/src/utils/fileUtils.test.js +112 -1
  656. package/dist/src/utils/fileUtils.test.js.map +1 -1
  657. package/dist/src/utils/geminiIgnoreParser.d.ts +11 -0
  658. package/dist/src/utils/geminiIgnoreParser.js +20 -0
  659. package/dist/src/utils/geminiIgnoreParser.js.map +1 -1
  660. package/dist/src/utils/geminiIgnoreParser.test.js +48 -0
  661. package/dist/src/utils/geminiIgnoreParser.test.js.map +1 -1
  662. package/dist/src/utils/generateContentResponseUtilities.d.ts +3 -1
  663. package/dist/src/utils/generateContentResponseUtilities.js +106 -0
  664. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -1
  665. package/dist/src/utils/generateContentResponseUtilities.test.js +279 -2
  666. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -1
  667. package/dist/src/utils/getFolderStructure.js +7 -2
  668. package/dist/src/utils/getFolderStructure.js.map +1 -1
  669. package/dist/src/utils/gitIgnoreParser.js +9 -10
  670. package/dist/src/utils/gitIgnoreParser.js.map +1 -1
  671. package/dist/src/utils/installationManager.test.js +11 -3
  672. package/dist/src/utils/installationManager.test.js.map +1 -1
  673. package/dist/src/utils/memoryDiscovery.js +3 -4
  674. package/dist/src/utils/memoryDiscovery.js.map +1 -1
  675. package/dist/src/utils/memoryDiscovery.test.js +12 -1
  676. package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
  677. package/dist/src/utils/partUtils.js +1 -1
  678. package/dist/src/utils/partUtils.js.map +1 -1
  679. package/dist/src/utils/paths.d.ts +10 -0
  680. package/dist/src/utils/paths.js +20 -1
  681. package/dist/src/utils/paths.js.map +1 -1
  682. package/dist/src/utils/retry.d.ts +1 -0
  683. package/dist/src/utils/retry.js +17 -5
  684. package/dist/src/utils/retry.js.map +1 -1
  685. package/dist/src/utils/retry.test.js +11 -11
  686. package/dist/src/utils/retry.test.js.map +1 -1
  687. package/dist/src/utils/shell-utils.d.ts +6 -0
  688. package/dist/src/utils/shell-utils.js +97 -12
  689. package/dist/src/utils/shell-utils.js.map +1 -1
  690. package/dist/src/utils/shell-utils.test.js +99 -1
  691. package/dist/src/utils/shell-utils.test.js.map +1 -1
  692. package/dist/src/utils/summarizer.test.js +3 -2
  693. package/dist/src/utils/summarizer.test.js.map +1 -1
  694. package/dist/src/utils/terminal.d.ts +4 -0
  695. package/dist/src/utils/terminal.js +12 -0
  696. package/dist/src/utils/terminal.js.map +1 -1
  697. package/dist/src/utils/tokenCalculation.js +20 -5
  698. package/dist/src/utils/tokenCalculation.js.map +1 -1
  699. package/dist/src/utils/tokenCalculation.test.js +11 -2
  700. package/dist/src/utils/tokenCalculation.test.js.map +1 -1
  701. package/dist/src/utils/tool-utils.d.ts +9 -0
  702. package/dist/src/utils/tool-utils.js +29 -0
  703. package/dist/src/utils/tool-utils.js.map +1 -1
  704. package/dist/src/utils/tool-utils.test.js +17 -2
  705. package/dist/src/utils/tool-utils.test.js.map +1 -1
  706. package/dist/src/utils/userAccountManager.test.js +5 -5
  707. package/dist/src/utils/userAccountManager.test.js.map +1 -1
  708. package/dist/src/utils/workspaceContext.test.js +1 -1
  709. package/dist/src/utils/workspaceContext.test.js.map +1 -1
  710. package/dist/tsconfig.tsbuildinfo +1 -1
  711. package/package.json +8 -6
  712. package/dist/src/agents/executor.js.map +0 -1
  713. package/dist/src/agents/executor.test.js.map +0 -1
  714. package/dist/src/agents/invocation.js.map +0 -1
  715. package/dist/src/agents/invocation.test.js.map +0 -1
  716. package/dist/src/core/sessionHookTriggers.d.ts +0 -28
  717. package/dist/src/core/sessionHookTriggers.js +0 -68
  718. package/dist/src/core/sessionHookTriggers.js.map +0 -1
  719. package/dist/src/tools/smart-edit.d.ts +0 -78
  720. package/dist/src/tools/smart-edit.js +0 -722
  721. package/dist/src/tools/smart-edit.js.map +0 -1
  722. package/dist/src/tools/smart-edit.test.js +0 -592
  723. package/dist/src/tools/smart-edit.test.js.map +0 -1
  724. package/dist/src/utils/shell-permissions.d.ts +0 -52
  725. package/dist/src/utils/shell-permissions.js +0 -188
  726. package/dist/src/utils/shell-permissions.js.map +0 -1
  727. package/dist/src/utils/shell-permissions.test.js +0 -347
  728. package/dist/src/utils/shell-permissions.test.js.map +0 -1
  729. /package/dist/src/agents/{executor.test.d.ts → a2a-client-manager.test.d.ts} +0 -0
  730. /package/dist/src/agents/{invocation.test.d.ts → a2aUtils.test.d.ts} +0 -0
  731. /package/dist/src/{tools/smart-edit.test.d.ts → agents/agentLoader.test.d.ts} +0 -0
  732. /package/dist/src/{utils/shell-permissions.test.d.ts → agents/cli-help-agent.test.d.ts} +0 -0
@@ -0,0 +1,131 @@
1
+ # Cell CLI core: Tools API
2
+
3
+ The Cell CLI core (`packages/core`) features a robust system for defining,
4
+ registering, and executing tools. These tools extend the capabilities of the
5
+ Gemini model, allowing it to interact with the local environment, fetch web
6
+ content, and perform various actions beyond simple text generation.
7
+
8
+ ## Core concepts
9
+
10
+ - **Tool (`tools.ts`):** An interface and base class (`BaseTool`) that defines
11
+ the contract for all tools. Each tool must have:
12
+ - `name`: A unique internal name (used in API calls to Gemini).
13
+ - `displayName`: A user-friendly name.
14
+ - `description`: A clear explanation of what the tool does, which is provided
15
+ to the Gemini model.
16
+ - `parameterSchema`: A JSON schema defining the parameters that the tool
17
+ accepts. This is crucial for the Gemini model to understand how to call the
18
+ tool correctly.
19
+ - `validateToolParams()`: A method to validate incoming parameters.
20
+ - `getDescription()`: A method to provide a human-readable description of what
21
+ the tool will do with specific parameters before execution.
22
+ - `shouldConfirmExecute()`: A method to determine if user confirmation is
23
+ required before execution (e.g., for potentially destructive operations).
24
+ - `execute()`: The core method that performs the tool's action and returns a
25
+ `ToolResult`.
26
+
27
+ - **`ToolResult` (`tools.ts`):** An interface defining the structure of a tool's
28
+ execution outcome:
29
+ - `llmContent`: The factual content to be included in the history sent back to
30
+ the LLM for context. This can be a simple string or a `PartListUnion` (an
31
+ array of `Part` objects and strings) for rich content.
32
+ - `returnDisplay`: A user-friendly string (often Markdown) or a special object
33
+ (like `FileDiff`) for display in the CLI.
34
+
35
+ - **Returning rich content:** Tools are not limited to returning simple text.
36
+ The `llmContent` can be a `PartListUnion`, which is an array that can contain
37
+ a mix of `Part` objects (for images, audio, etc.) and `string`s. This allows a
38
+ single tool execution to return multiple pieces of rich content.
39
+
40
+ - **Tool registry (`tool-registry.ts`):** A class (`ToolRegistry`) responsible
41
+ for:
42
+ - **Registering tools:** Holding a collection of all available built-in tools
43
+ (e.g., `ReadFileTool`, `ShellTool`).
44
+ - **Discovering tools:** It can also discover tools dynamically:
45
+ - **Command-based discovery:** If `tools.discoveryCommand` is configured in
46
+ settings, this command is executed. It's expected to output JSON
47
+ describing custom tools, which are then registered as `DiscoveredTool`
48
+ instances.
49
+ - **MCP-based discovery:** If `mcp.serverCommand` is configured, the
50
+ registry can connect to a Model Context Protocol (MCP) server to list and
51
+ register tools (`DiscoveredMCPTool`).
52
+ - **Providing schemas:** Exposing the `FunctionDeclaration` schemas of all
53
+ registered tools to the Gemini model, so it knows what tools are available
54
+ and how to use them.
55
+ - **Retrieving tools:** Allowing the core to get a specific tool by name for
56
+ execution.
57
+
58
+ ## Built-in tools
59
+
60
+ The core comes with a suite of pre-defined tools, typically found in
61
+ `packages/core/src/tools/`. These include:
62
+
63
+ - **File system tools:**
64
+ - `LSTool` (`ls.ts`): Lists directory contents.
65
+ - `ReadFileTool` (`read-file.ts`): Reads the content of a single file.
66
+ - `WriteFileTool` (`write-file.ts`): Writes content to a file.
67
+ - `GrepTool` (`grep.ts`): Searches for patterns in files.
68
+ - `GlobTool` (`glob.ts`): Finds files matching glob patterns.
69
+ - `EditTool` (`edit.ts`): Performs in-place modifications to files (often
70
+ requiring confirmation).
71
+ - `ReadManyFilesTool` (`read-many-files.ts`): Reads and concatenates content
72
+ from multiple files or glob patterns (used by the `@` command in CLI).
73
+ - **Execution tools:**
74
+ - `ShellTool` (`shell.ts`): Executes arbitrary shell commands (requires
75
+ careful sandboxing and user confirmation).
76
+ - **Web tools:**
77
+ - `WebFetchTool` (`web-fetch.ts`): Fetches content from a URL.
78
+ - `WebSearchTool` (`web-search.ts`): Performs a web search.
79
+ - **Memory tools:**
80
+ - `MemoryTool` (`memoryTool.ts`): Interacts with the AI's memory.
81
+
82
+ Each of these tools extends `BaseTool` and implements the required methods for
83
+ its specific functionality.
84
+
85
+ ## Tool execution flow
86
+
87
+ 1. **Model request:** The Gemini model, based on the user's prompt and the
88
+ provided tool schemas, decides to use a tool and returns a `FunctionCall`
89
+ part in its response, specifying the tool name and arguments.
90
+ 2. **Core receives request:** The core parses this `FunctionCall`.
91
+ 3. **Tool retrieval:** It looks up the requested tool in the `ToolRegistry`.
92
+ 4. **Parameter validation:** The tool's `validateToolParams()` method is
93
+ called.
94
+ 5. **Confirmation (if needed):**
95
+ - The tool's `shouldConfirmExecute()` method is called.
96
+ - If it returns details for confirmation, the core communicates this back to
97
+ the CLI, which prompts the user.
98
+ - The user's decision (e.g., proceed, cancel) is sent back to the core.
99
+ 6. **Execution:** If validated and confirmed (or if no confirmation is needed),
100
+ the core calls the tool's `execute()` method with the provided arguments and
101
+ an `AbortSignal` (for potential cancellation).
102
+ 7. **Result processing:** The `ToolResult` from `execute()` is received by the
103
+ core.
104
+ 8. **Response to model:** The `llmContent` from the `ToolResult` is packaged as
105
+ a `FunctionResponse` and sent back to the Gemini model so it can continue
106
+ generating a user-facing response.
107
+ 9. **Display to user:** The `returnDisplay` from the `ToolResult` is sent to
108
+ the CLI to show the user what the tool did.
109
+
110
+ ## Extending with custom tools
111
+
112
+ While direct programmatic registration of new tools by users isn't explicitly
113
+ detailed as a primary workflow in the provided files for typical end-users, the
114
+ architecture supports extension through:
115
+
116
+ - **Command-based discovery:** Advanced users or project administrators can
117
+ define a `tools.discoveryCommand` in `settings.json`. This command, when run
118
+ by the Cell CLI core, should output a JSON array of `FunctionDeclaration`
119
+ objects. The core will then make these available as `DiscoveredTool`
120
+ instances. The corresponding `tools.callCommand` would then be responsible for
121
+ actually executing these custom tools.
122
+ - **MCP server(s):** For more complex scenarios, one or more MCP servers can be
123
+ set up and configured via the `mcpServers` setting in `settings.json`. The
124
+ Cell CLI core can then discover and use tools exposed by these servers. As
125
+ mentioned, if you have multiple MCP servers, the tool names will be prefixed
126
+ with the server name from your configuration (e.g.,
127
+ `serverAlias__actualToolName`).
128
+
129
+ This tool system provides a flexible and powerful way to augment the Gemini
130
+ model's capabilities, making the Cell CLI a versatile assistant for a wide range
131
+ of tasks.
@@ -0,0 +1,83 @@
1
+ # Example proxy script
2
+
3
+ The following is an example of a proxy script that can be used with the
4
+ `GEMINI_SANDBOX_PROXY_COMMAND` environment variable. This script only allows
5
+ `HTTPS` connections to `example.com:443` and declines all other requests.
6
+
7
+ ```javascript
8
+ #!/usr/bin/env node
9
+
10
+ /**
11
+ * @license
12
+ * Copyright 2025 Google LLC
13
+ * SPDX-License-Identifier: Apache-2.0
14
+ */
15
+
16
+ // Example proxy server that listens on :::8877 and only allows HTTPS connections to example.com.
17
+ // Set `GEMINI_SANDBOX_PROXY_COMMAND=scripts/example-proxy.js` to run proxy alongside sandbox
18
+ // Test via `curl https://example.com` inside sandbox (in shell mode or via shell tool)
19
+
20
+ import http from 'node:http';
21
+ import net from 'node:net';
22
+ import { URL } from 'node:url';
23
+ import console from 'node:console';
24
+
25
+ const PROXY_PORT = 8877;
26
+ const ALLOWED_DOMAINS = ['example.com', 'googleapis.com'];
27
+ const ALLOWED_PORT = '443';
28
+
29
+ const server = http.createServer((req, res) => {
30
+ // Deny all requests other than CONNECT for HTTPS
31
+ console.log(
32
+ `[PROXY] Denying non-CONNECT request for: ${req.method} ${req.url}`,
33
+ );
34
+ res.writeHead(405, { 'Content-Type': 'text/plain' });
35
+ res.end('Method Not Allowed');
36
+ });
37
+
38
+ server.on('connect', (req, clientSocket, head) => {
39
+ // req.url will be in the format "hostname:port" for a CONNECT request.
40
+ const { port, hostname } = new URL(`http://${req.url}`);
41
+
42
+ console.log(`[PROXY] Intercepted CONNECT request for: ${hostname}:${port}`);
43
+
44
+ if (
45
+ ALLOWED_DOMAINS.some(
46
+ (domain) => hostname == domain || hostname.endsWith(`.${domain}`),
47
+ ) &&
48
+ port === ALLOWED_PORT
49
+ ) {
50
+ console.log(`[PROXY] Allowing connection to ${hostname}:${port}`);
51
+
52
+ // Establish a TCP connection to the original destination.
53
+ const serverSocket = net.connect(port, hostname, () => {
54
+ clientSocket.write('HTTP/1.1 200 Connection Established\r\n\r\n');
55
+ // Create a tunnel by piping data between the client and the destination server.
56
+ serverSocket.write(head);
57
+ serverSocket.pipe(clientSocket);
58
+ clientSocket.pipe(serverSocket);
59
+ });
60
+
61
+ serverSocket.on('error', (err) => {
62
+ console.error(`[PROXY] Error connecting to destination: ${err.message}`);
63
+ clientSocket.end(`HTTP/1.1 502 Bad Gateway\r\n\r\n`);
64
+ });
65
+ } else {
66
+ console.log(`[PROXY] Denying connection to ${hostname}:${port}`);
67
+ clientSocket.end('HTTP/1.1 403 Forbidden\r\n\r\n');
68
+ }
69
+
70
+ clientSocket.on('error', (err) => {
71
+ // This can happen if the client hangs up.
72
+ console.error(`[PROXY] Client socket error: ${err.message}`);
73
+ });
74
+ });
75
+
76
+ server.listen(PROXY_PORT, () => {
77
+ const address = server.address();
78
+ console.log(`[PROXY] Proxy listening on ${address.address}:${address.port}`);
79
+ console.log(
80
+ `[PROXY] Allowing HTTPS connections to domains: ${ALLOWED_DOMAINS.join(', ')}`,
81
+ );
82
+ });
83
+ ```
@@ -0,0 +1,183 @@
1
+ # Extension releasing
2
+
3
+ There are two primary ways of releasing extensions to users:
4
+
5
+ - [Git repository](#releasing-through-a-git-repository)
6
+ - [Github Releases](#releasing-through-github-releases)
7
+
8
+ Git repository releases tend to be the simplest and most flexible approach,
9
+ while GitHub releases can be more efficient on initial install as they are
10
+ shipped as single archives instead of requiring a git clone which downloads each
11
+ file individually. Github releases may also contain platform specific archives
12
+ if you need to ship platform specific binary files.
13
+
14
+ ## Releasing through a git repository
15
+
16
+ This is the most flexible and simple option. All you need to do is create a
17
+ publicly accessible git repo (such as a public github repository) and then users
18
+ can install your extension using `gemini extensions install <your-repo-uri>`.
19
+ They can optionally depend on a specific ref (branch/tag/commit) using the
20
+ `--ref=<some-ref>` argument, this defaults to the default branch.
21
+
22
+ Whenever commits are pushed to the ref that a user depends on, they will be
23
+ prompted to update the extension. Note that this also allows for easy rollbacks,
24
+ the HEAD commit is always treated as the latest version regardless of the actual
25
+ version in the `gemini-extension.json` file.
26
+
27
+ ### Managing release channels using a git repository
28
+
29
+ Users can depend on any ref from your git repo, such as a branch or tag, which
30
+ allows you to manage multiple release channels.
31
+
32
+ For instance, you can maintain a `stable` branch, which users can install this
33
+ way `gemini extensions install <your-repo-uri> --ref=stable`. Or, you could make
34
+ this the default by treating your default branch as your stable release branch,
35
+ and doing development in a different branch (for instance called `dev`). You can
36
+ maintain as many branches or tags as you like, providing maximum flexibility for
37
+ you and your users.
38
+
39
+ Note that these `ref` arguments can be tags, branches, or even specific commits,
40
+ which allows users to depend on a specific version of your extension. It is up
41
+ to you how you want to manage your tags and branches.
42
+
43
+ ### Example releasing flow using a git repo
44
+
45
+ While there are many options for how you want to manage releases using a git
46
+ flow, we recommend treating your default branch as your "stable" release branch.
47
+ This means that the default behavior for
48
+ `gemini extensions install <your-repo-uri>` is to be on the stable release
49
+ branch.
50
+
51
+ Lets say you want to maintain three standard release channels, `stable`,
52
+ `preview`, and `dev`. You would do all your standard development in the `dev`
53
+ branch. When you are ready to do a preview release, you merge that branch into
54
+ your `preview` branch. When you are ready to promote your preview branch to
55
+ stable, you merge `preview` into your stable branch (which might be your default
56
+ branch or a different branch).
57
+
58
+ You can also cherry pick changes from one branch into another using
59
+ `git cherry-pick`, but do note that this will result in your branches having a
60
+ slightly divergent history from each other, unless you force push changes to
61
+ your branches on each release to restore the history to a clean slate (which may
62
+ not be possible for the default branch depending on your repository settings).
63
+ If you plan on doing cherry picks, you may want to avoid having your default
64
+ branch be the stable branch to avoid force-pushing to the default branch which
65
+ should generally be avoided.
66
+
67
+ ## Releasing through GitHub releases
68
+
69
+ Cell CLI extensions can be distributed through
70
+ [GitHub Releases](https://docs.github.com/en/repositories/releasing-projects-on-github/about-releases).
71
+ This provides a faster and more reliable initial installation experience for
72
+ users, as it avoids the need to clone the repository.
73
+
74
+ Each release includes at least one archive file, which contains the full
75
+ contents of the repo at the tag that it was linked to. Releases may also include
76
+ [pre-built archives](#custom-pre-built-archives) if your extension requires some
77
+ build step or has platform specific binaries attached to it.
78
+
79
+ When checking for updates, gemini will just look for the "latest" release on
80
+ github (you must mark it as such when creating the release), unless the user
81
+ installed a specific release by passing `--ref=<some-release-tag>`.
82
+
83
+ You may also install extensions with the `--pre-release` flag in order to get
84
+ the latest release regardless of whether it has been marked as "latest". This
85
+ allows you to test that your release works before actually pushing it to all
86
+ users.
87
+
88
+ ### Custom pre-built archives
89
+
90
+ Custom archives must be attached directly to the github release as assets and
91
+ must be fully self-contained. This means they should include the entire
92
+ extension, see [archive structure](#archive-structure).
93
+
94
+ If your extension is platform-independent, you can provide a single generic
95
+ asset. In this case, there should be only one asset attached to the release.
96
+
97
+ Custom archives may also be used if you want to develop your extension within a
98
+ larger repository, you can build an archive which has a different layout from
99
+ the repo itself (for instance it might just be an archive of a subdirectory
100
+ containing the extension).
101
+
102
+ #### Platform specific archives
103
+
104
+ To ensure Cell CLI can automatically find the correct release asset for each
105
+ platform, you must follow this naming convention. The CLI will search for assets
106
+ in the following order:
107
+
108
+ 1. **Platform and architecture-Specific:**
109
+ `{platform}.{arch}.{name}.{extension}`
110
+ 2. **Platform-specific:** `{platform}.{name}.{extension}`
111
+ 3. **Generic:** If only one asset is provided, it will be used as a generic
112
+ fallback.
113
+
114
+ - `{name}`: The name of your extension.
115
+ - `{platform}`: The operating system. Supported values are:
116
+ - `darwin` (macOS)
117
+ - `linux`
118
+ - `win32` (Windows)
119
+ - `{arch}`: The architecture. Supported values are:
120
+ - `x64`
121
+ - `arm64`
122
+ - `{extension}`: The file extension of the archive (e.g., `.tar.gz` or `.zip`).
123
+
124
+ **Examples:**
125
+
126
+ - `darwin.arm64.my-tool.tar.gz` (specific to Apple Silicon Macs)
127
+ - `darwin.my-tool.tar.gz` (for all Macs)
128
+ - `linux.x64.my-tool.tar.gz`
129
+ - `win32.my-tool.zip`
130
+
131
+ #### Archive structure
132
+
133
+ Archives must be fully contained extensions and have all the standard
134
+ requirements - specifically the `gemini-extension.json` file must be at the root
135
+ of the archive.
136
+
137
+ The rest of the layout should look exactly the same as a typical extension, see
138
+ [extensions.md](./index.md).
139
+
140
+ #### Example GitHub Actions workflow
141
+
142
+ Here is an example of a GitHub Actions workflow that builds and releases a Cell
143
+ CLI extension for multiple platforms:
144
+
145
+ ```yaml
146
+ name: Release Extension
147
+
148
+ on:
149
+ push:
150
+ tags:
151
+ - 'v*'
152
+
153
+ jobs:
154
+ release:
155
+ runs-on: ubuntu-latest
156
+ steps:
157
+ - uses: actions/checkout@v3
158
+
159
+ - name: Set up Node.js
160
+ uses: actions/setup-node@v3
161
+ with:
162
+ node-version: '20'
163
+
164
+ - name: Install dependencies
165
+ run: npm ci
166
+
167
+ - name: Build extension
168
+ run: npm run build
169
+
170
+ - name: Create release assets
171
+ run: |
172
+ npm run package -- --platform=darwin --arch=arm64
173
+ npm run package -- --platform=linux --arch=x64
174
+ npm run package -- --platform=win32 --arch=x64
175
+
176
+ - name: Create GitHub Release
177
+ uses: softprops/action-gh-release@v1
178
+ with:
179
+ files: |
180
+ release/darwin.arm64.my-tool.tar.gz
181
+ release/linux.arm64.my-tool.tar.gz
182
+ release/win32.arm64.my-tool.zip
183
+ ```
@@ -0,0 +1,244 @@
1
+ # Getting started with Cell CLI extensions
2
+
3
+ This guide will walk you through creating your first Cell CLI extension. You'll
4
+ learn how to set up a new extension, add a custom tool via an MCP server, create
5
+ a custom command, and provide context to the model with a `GEMINI.md` file.
6
+
7
+ ## Prerequisites
8
+
9
+ Before you start, make sure you have the Cell CLI installed and a basic
10
+ understanding of Node.js and TypeScript.
11
+
12
+ ## Step 1: Create a new extension
13
+
14
+ The easiest way to start is by using one of the built-in templates. We'll use
15
+ the `mcp-server` example as our foundation.
16
+
17
+ Run the following command to create a new directory called `my-first-extension`
18
+ with the template files:
19
+
20
+ ```bash
21
+ gemini extensions new my-first-extension mcp-server
22
+ ```
23
+
24
+ This will create a new directory with the following structure:
25
+
26
+ ```
27
+ my-first-extension/
28
+ ├── example.ts
29
+ ├── gemini-extension.json
30
+ ├── package.json
31
+ └── tsconfig.json
32
+ ```
33
+
34
+ ## Step 2: Understand the extension files
35
+
36
+ Let's look at the key files in your new extension.
37
+
38
+ ### `gemini-extension.json`
39
+
40
+ This is the manifest file for your extension. It tells Cell CLI how to load and
41
+ use your extension.
42
+
43
+ ```json
44
+ {
45
+ "name": "my-first-extension",
46
+ "version": "1.0.0",
47
+ "mcpServers": {
48
+ "nodeServer": {
49
+ "command": "node",
50
+ "args": ["${extensionPath}${/}dist${/}example.js"],
51
+ "cwd": "${extensionPath}"
52
+ }
53
+ }
54
+ }
55
+ ```
56
+
57
+ - `name`: The unique name for your extension.
58
+ - `version`: The version of your extension.
59
+ - `mcpServers`: This section defines one or more Model Context Protocol (MCP)
60
+ servers. MCP servers are how you can add new tools for the model to use.
61
+ - `command`, `args`, `cwd`: These fields specify how to start your server.
62
+ Notice the use of the `${extensionPath}` variable, which Cell CLI replaces
63
+ with the absolute path to your extension's installation directory. This
64
+ allows your extension to work regardless of where it's installed.
65
+
66
+ ### `example.ts`
67
+
68
+ This file contains the source code for your MCP server. It's a simple Node.js
69
+ server that uses the `@modelcontextprotocol/sdk`.
70
+
71
+ ```typescript
72
+ /**
73
+ * @license
74
+ * Copyright 2025 Google LLC
75
+ * SPDX-License-Identifier: Apache-2.0
76
+ */
77
+
78
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
79
+ import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
80
+ import { z } from 'zod';
81
+
82
+ const server = new McpServer({
83
+ name: 'prompt-server',
84
+ version: '1.0.0',
85
+ });
86
+
87
+ // Registers a new tool named 'fetch_posts'
88
+ server.registerTool(
89
+ 'fetch_posts',
90
+ {
91
+ description: 'Fetches a list of posts from a public API.',
92
+ inputSchema: z.object({}).shape,
93
+ },
94
+ async () => {
95
+ const apiResponse = await fetch(
96
+ 'https://jsonplaceholder.typicode.com/posts',
97
+ );
98
+ const posts = await apiResponse.json();
99
+ const response = { posts: posts.slice(0, 5) };
100
+ return {
101
+ content: [
102
+ {
103
+ type: 'text',
104
+ text: JSON.stringify(response),
105
+ },
106
+ ],
107
+ };
108
+ },
109
+ );
110
+
111
+ // ... (prompt registration omitted for brevity)
112
+
113
+ const transport = new StdioServerTransport();
114
+ await server.connect(transport);
115
+ ```
116
+
117
+ This server defines a single tool called `fetch_posts` that fetches data from a
118
+ public API.
119
+
120
+ ### `package.json` and `tsconfig.json`
121
+
122
+ These are standard configuration files for a TypeScript project. The
123
+ `package.json` file defines dependencies and a `build` script, and
124
+ `tsconfig.json` configures the TypeScript compiler.
125
+
126
+ ## Step 3: Build and link your extension
127
+
128
+ Before you can use the extension, you need to compile the TypeScript code and
129
+ link the extension to your Cell CLI installation for local development.
130
+
131
+ 1. **Install dependencies:**
132
+
133
+ ```bash
134
+ cd my-first-extension
135
+ npm install
136
+ ```
137
+
138
+ 2. **Build the server:**
139
+
140
+ ```bash
141
+ npm run build
142
+ ```
143
+
144
+ This will compile `example.ts` into `dist/example.js`, which is the file
145
+ referenced in your `gemini-extension.json`.
146
+
147
+ 3. **Link the extension:**
148
+
149
+ The `link` command creates a symbolic link from the Cell CLI extensions
150
+ directory to your development directory. This means any changes you make
151
+ will be reflected immediately without needing to reinstall.
152
+
153
+ ```bash
154
+ gemini extensions link .
155
+ ```
156
+
157
+ Now, restart your Cell CLI session. The new `fetch_posts` tool will be
158
+ available. You can test it by asking: "fetch posts".
159
+
160
+ ## Step 4: Add a custom command
161
+
162
+ Custom commands provide a way to create shortcuts for complex prompts. Let's add
163
+ a command that searches for a pattern in your code.
164
+
165
+ 1. Create a `commands` directory and a subdirectory for your command group:
166
+
167
+ ```bash
168
+ mkdir -p commands/fs
169
+ ```
170
+
171
+ 2. Create a file named `commands/fs/grep-code.toml`:
172
+
173
+ ```toml
174
+ prompt = """
175
+ Please summarize the findings for the pattern `{{args}}`.
176
+
177
+ Search Results:
178
+ !{grep -r {{args}} .}
179
+ """
180
+ ```
181
+
182
+ This command, `/fs:grep-code`, will take an argument, run the `grep` shell
183
+ command with it, and pipe the results into a prompt for summarization.
184
+
185
+ After saving the file, restart the Cell CLI. You can now run
186
+ `/fs:grep-code "some pattern"` to use your new command.
187
+
188
+ ## Step 5: Add a custom `GEMINI.md`
189
+
190
+ You can provide persistent context to the model by adding a `GEMINI.md` file to
191
+ your extension. This is useful for giving the model instructions on how to
192
+ behave or information about your extension's tools. Note that you may not always
193
+ need this for extensions built to expose commands and prompts.
194
+
195
+ 1. Create a file named `GEMINI.md` in the root of your extension directory:
196
+
197
+ ```markdown
198
+ # My First Extension Instructions
199
+
200
+ You are an expert developer assistant. When the user asks you to fetch
201
+ posts, use the `fetch_posts` tool. Be concise in your responses.
202
+ ```
203
+
204
+ 2. Update your `gemini-extension.json` to tell the CLI to load this file:
205
+
206
+ ```json
207
+ {
208
+ "name": "my-first-extension",
209
+ "version": "1.0.0",
210
+ "contextFileName": "GEMINI.md",
211
+ "mcpServers": {
212
+ "nodeServer": {
213
+ "command": "node",
214
+ "args": ["${extensionPath}${/}dist${/}example.js"],
215
+ "cwd": "${extensionPath}"
216
+ }
217
+ }
218
+ }
219
+ ```
220
+
221
+ Restart the CLI again. The model will now have the context from your `GEMINI.md`
222
+ file in every session where the extension is active.
223
+
224
+ ## Step 6: Releasing your extension
225
+
226
+ Once you are happy with your extension, you can share it with others. The two
227
+ primary ways of releasing extensions are via a Git repository or through GitHub
228
+ Releases. Using a public Git repository is the simplest method.
229
+
230
+ For detailed instructions on both methods, please refer to the
231
+ [Extension Releasing Guide](./extension-releasing.md).
232
+
233
+ ## Conclusion
234
+
235
+ You've successfully created a Cell CLI extension! You learned how to:
236
+
237
+ - Bootstrap a new extension from a template.
238
+ - Add custom tools with an MCP server.
239
+ - Create convenient custom commands.
240
+ - Provide persistent context to the model.
241
+ - Link your extension for local development.
242
+
243
+ From here, you can explore more advanced features and build powerful new
244
+ capabilities into the Cell CLI.