@pugi/cli 0.1.0-beta.98 → 1.0.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (448) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +11 -191
  3. package/bin/pugi +8 -0
  4. package/package.json +15 -71
  5. package/postinstall.mjs +31 -0
  6. package/CHANGELOG.md +0 -132
  7. package/THIRD_PARTY_NOTICES.md +0 -40
  8. package/assets/pugi-mascot.ansi +0 -16
  9. package/assets/pugi-prozr2-mascot.ansi +0 -9
  10. package/bin/run.js +0 -34
  11. package/dist/commands/deploy.js +0 -439
  12. package/dist/commands/flatten.js +0 -191
  13. package/dist/commands/jobs-watch.js +0 -201
  14. package/dist/commands/jobs.js +0 -260
  15. package/dist/commands/retro.js +0 -210
  16. package/dist/commands/smoke.js +0 -133
  17. package/dist/core/agent-progress/cleanup.js +0 -134
  18. package/dist/core/agent-progress/schema.js +0 -144
  19. package/dist/core/agent-progress/writer.js +0 -101
  20. package/dist/core/agents/adaptive-router.js +0 -330
  21. package/dist/core/agents/loader.js +0 -104
  22. package/dist/core/agents/query-decomposer.js +0 -297
  23. package/dist/core/agents/registry.js +0 -69
  24. package/dist/core/approvals/shortcut-resolver.js +0 -98
  25. package/dist/core/artifact-chain/dispatcher.js +0 -148
  26. package/dist/core/artifact-chain/exporter.js +0 -164
  27. package/dist/core/artifact-chain/state.js +0 -243
  28. package/dist/core/artifact-chain/steps.js +0 -169
  29. package/dist/core/ask-user/question.js +0 -92
  30. package/dist/core/audit/audit-trail.js +0 -275
  31. package/dist/core/auth/ensure-authenticated.js +0 -129
  32. package/dist/core/auth/env-provider.js +0 -238
  33. package/dist/core/auto-open-browser.js +0 -128
  34. package/dist/core/auto-update/channels.js +0 -122
  35. package/dist/core/auto-update/checker.js +0 -241
  36. package/dist/core/auto-update/state.js +0 -235
  37. package/dist/core/bare-mode/index.js +0 -107
  38. package/dist/core/bash/redirect.js +0 -281
  39. package/dist/core/bash-classifier.js +0 -1397
  40. package/dist/core/checkpoint/resumer.js +0 -149
  41. package/dist/core/checkpoint/rewinder.js +0 -291
  42. package/dist/core/checkpoints/shadow-git.js +0 -670
  43. package/dist/core/citations/parser.js +0 -109
  44. package/dist/core/classifier/yolo-classifier.js +0 -88
  45. package/dist/core/clipboard.js +0 -70
  46. package/dist/core/codegraph/decision-store.js +0 -248
  47. package/dist/core/codegraph/detect-repo.js +0 -459
  48. package/dist/core/codegraph/install.js +0 -134
  49. package/dist/core/codegraph/offer-hook.js +0 -220
  50. package/dist/core/compact/auto-trigger.js +0 -96
  51. package/dist/core/compact/buffer-rewriter.js +0 -115
  52. package/dist/core/compact/summarizer.js +0 -208
  53. package/dist/core/compact/token-counter.js +0 -108
  54. package/dist/core/consensus/anvil-fanout.js +0 -276
  55. package/dist/core/consensus/diff-capture.js +0 -491
  56. package/dist/core/consensus/rubric.js +0 -233
  57. package/dist/core/context/builder.js +0 -114
  58. package/dist/core/context/compaction-events.js +0 -99
  59. package/dist/core/context/compaction.js +0 -602
  60. package/dist/core/context/index.js +0 -28
  61. package/dist/core/context/invariants.js +0 -250
  62. package/dist/core/context/markdown-loader.js +0 -288
  63. package/dist/core/context/markdown-traverse.js +0 -255
  64. package/dist/core/context/pugiignore.js +0 -316
  65. package/dist/core/context/repo-skeleton.js +0 -533
  66. package/dist/core/context/tool-eviction.js +0 -55
  67. package/dist/core/context/watcher.js +0 -342
  68. package/dist/core/context/working-set.js +0 -165
  69. package/dist/core/coordinator/agent-tools.js +0 -77
  70. package/dist/core/coordinator/agent-toolset.js +0 -65
  71. package/dist/core/coordinator/fsm.js +0 -73
  72. package/dist/core/coordinator/mode-fsm.js +0 -70
  73. package/dist/core/cost/rate-card.js +0 -129
  74. package/dist/core/cost/tracker.js +0 -221
  75. package/dist/core/credentials.js +0 -355
  76. package/dist/core/cron/scheduler.js +0 -138
  77. package/dist/core/denial-tracking/index.js +0 -8
  78. package/dist/core/denial-tracking/state.js +0 -264
  79. package/dist/core/diagnostics/probe-runner.js +0 -93
  80. package/dist/core/diagnostics/probes/api.js +0 -46
  81. package/dist/core/diagnostics/probes/auth.js +0 -93
  82. package/dist/core/diagnostics/probes/bare-mode.js +0 -42
  83. package/dist/core/diagnostics/probes/cli-version.js +0 -127
  84. package/dist/core/diagnostics/probes/config.js +0 -72
  85. package/dist/core/diagnostics/probes/denial-tracking.js +0 -57
  86. package/dist/core/diagnostics/probes/disk.js +0 -81
  87. package/dist/core/diagnostics/probes/engine-live.js +0 -46
  88. package/dist/core/diagnostics/probes/git.js +0 -65
  89. package/dist/core/diagnostics/probes/hooks.js +0 -118
  90. package/dist/core/diagnostics/probes/mcp.js +0 -75
  91. package/dist/core/diagnostics/probes/node.js +0 -59
  92. package/dist/core/diagnostics/probes/pnpm.js +0 -36
  93. package/dist/core/diagnostics/probes/pugi-md.js +0 -89
  94. package/dist/core/diagnostics/probes/sandbox.js +0 -72
  95. package/dist/core/diagnostics/probes/session.js +0 -74
  96. package/dist/core/diagnostics/probes/status-snapshot.js +0 -488
  97. package/dist/core/diagnostics/probes/workspace.js +0 -63
  98. package/dist/core/diagnostics/types.js +0 -70
  99. package/dist/core/dispatch/cache-cleanup.js +0 -197
  100. package/dist/core/dispatch/cache-handoff.js +0 -295
  101. package/dist/core/edits/apply-patch-layer-e.js +0 -189
  102. package/dist/core/edits/dispatch.js +0 -511
  103. package/dist/core/edits/format-detector.js +0 -260
  104. package/dist/core/edits/format-matrix.js +0 -26
  105. package/dist/core/edits/fuzzy-ladder.js +0 -650
  106. package/dist/core/edits/index.js +0 -19
  107. package/dist/core/edits/journal.js +0 -199
  108. package/dist/core/edits/layer-a-apply.js +0 -217
  109. package/dist/core/edits/layer-a-fuzzy-apply.js +0 -198
  110. package/dist/core/edits/layer-b-apply.js +0 -211
  111. package/dist/core/edits/layer-c-apply.js +0 -160
  112. package/dist/core/edits/layer-d-ast.js +0 -572
  113. package/dist/core/edits/marker-parser.js +0 -401
  114. package/dist/core/edits/security-gate.js +0 -223
  115. package/dist/core/edits/verify-hook.js +0 -273
  116. package/dist/core/edits/worktree.js +0 -322
  117. package/dist/core/engine/adapter-runner.js +0 -8
  118. package/dist/core/engine/anvil-client.js +0 -344
  119. package/dist/core/engine/auto-compact.js +0 -179
  120. package/dist/core/engine/budgets.js +0 -192
  121. package/dist/core/engine/context-prefix.js +0 -155
  122. package/dist/core/engine/index.js +0 -12
  123. package/dist/core/engine/intensity.js +0 -163
  124. package/dist/core/engine/intent.js +0 -260
  125. package/dist/core/engine/native-pugi.js +0 -1616
  126. package/dist/core/engine/noop.js +0 -27
  127. package/dist/core/engine/prompts.js +0 -236
  128. package/dist/core/engine/strip-internal-fields.js +0 -124
  129. package/dist/core/engine/tool-bridge.js +0 -2173
  130. package/dist/core/engine/verification-patterns.js +0 -195
  131. package/dist/core/evaluation/golden-dataset.js +0 -293
  132. package/dist/core/feedback/queue.js +0 -177
  133. package/dist/core/feedback/submitter.js +0 -145
  134. package/dist/core/file-cache.js +0 -141
  135. package/dist/core/flatten/flatten-repo.js +0 -439
  136. package/dist/core/format/osc8-link.js +0 -28
  137. package/dist/core/hook-chains.js +0 -392
  138. package/dist/core/hooks/citation-verify-hook.js +0 -138
  139. package/dist/core/hooks/citation-verify.js +0 -112
  140. package/dist/core/hooks/events.js +0 -46
  141. package/dist/core/hooks/index.js +0 -15
  142. package/dist/core/hooks/registry.js +0 -216
  143. package/dist/core/hooks/runner.js +0 -236
  144. package/dist/core/hooks/v2/event-emitter.js +0 -115
  145. package/dist/core/hooks/v2/executor.js +0 -282
  146. package/dist/core/hooks/v2/index.js +0 -25
  147. package/dist/core/hooks/v2/lifecycle.js +0 -104
  148. package/dist/core/hooks/v2/loader.js +0 -216
  149. package/dist/core/hooks/v2/matcher.js +0 -125
  150. package/dist/core/hooks/v2/trust.js +0 -143
  151. package/dist/core/hooks/v2/types.js +0 -86
  152. package/dist/core/hooks/worktree-events.js +0 -158
  153. package/dist/core/hooks.js +0 -415
  154. package/dist/core/image/renderer.js +0 -71
  155. package/dist/core/index-store.js +0 -260
  156. package/dist/core/init/detector.js +0 -582
  157. package/dist/core/init/template-renderer.js +0 -242
  158. package/dist/core/jobs/registry.js +0 -462
  159. package/dist/core/ledger/results-tsv.js +0 -142
  160. package/dist/core/log-discipline/stdout-redirect.js +0 -51
  161. package/dist/core/lsp/cache.js +0 -105
  162. package/dist/core/lsp/client.js +0 -1229
  163. package/dist/core/lsp/language-detect.js +0 -66
  164. package/dist/core/lsp/post-edit-diagnostics.js +0 -171
  165. package/dist/core/lsp/server-detect.js +0 -173
  166. package/dist/core/lsp/symbol-cache.js +0 -162
  167. package/dist/core/lsp/symbol-tools.js +0 -664
  168. package/dist/core/mcp/client.js +0 -385
  169. package/dist/core/mcp/http-server.js +0 -553
  170. package/dist/core/mcp/orchestrator-config.js +0 -192
  171. package/dist/core/mcp/orchestrator-tools.js +0 -806
  172. package/dist/core/mcp/permission.js +0 -190
  173. package/dist/core/mcp/registry.js +0 -193
  174. package/dist/core/mcp/server-tools.js +0 -219
  175. package/dist/core/mcp/server.js +0 -397
  176. package/dist/core/mcp/trust.js +0 -91
  177. package/dist/core/memory/dual-write.js +0 -416
  178. package/dist/core/memory/passive-extract.js +0 -130
  179. package/dist/core/memory/phase1-kinds.js +0 -20
  180. package/dist/core/memory/secret-scanner.js +0 -304
  181. package/dist/core/memory-sync/queue.js +0 -170
  182. package/dist/core/metrics/extract.js +0 -113
  183. package/dist/core/modes/roo-modes.js +0 -68
  184. package/dist/core/onboarding/ensure-initialized.js +0 -133
  185. package/dist/core/onboarding/marker.js +0 -111
  186. package/dist/core/onboarding/telemetry-state.js +0 -108
  187. package/dist/core/output-style/presets.js +0 -176
  188. package/dist/core/output-style/state.js +0 -185
  189. package/dist/core/path-security.js +0 -345
  190. package/dist/core/permission.js +0 -369
  191. package/dist/core/permissions/auto-classifier.js +0 -124
  192. package/dist/core/permissions/bash-parser.js +0 -371
  193. package/dist/core/permissions/circuit-breaker.js +0 -83
  194. package/dist/core/permissions/constrained-edit.js +0 -91
  195. package/dist/core/permissions/gate.js +0 -278
  196. package/dist/core/permissions/index.js +0 -20
  197. package/dist/core/permissions/mode.js +0 -174
  198. package/dist/core/permissions/network-egress.js +0 -137
  199. package/dist/core/permissions/state.js +0 -241
  200. package/dist/core/permissions/tool-class.js +0 -107
  201. package/dist/core/plan-mode/ui-state.js +0 -51
  202. package/dist/core/plans/plan-artifact.js +0 -721
  203. package/dist/core/policy-limits/etag-store.js +0 -122
  204. package/dist/core/prd-check/parser.js +0 -215
  205. package/dist/core/prd-check/reporter.js +0 -127
  206. package/dist/core/prd-check/session-review.js +0 -557
  207. package/dist/core/prd-check/verifiers.js +0 -223
  208. package/dist/core/prompt-cache/client-cache.js +0 -99
  209. package/dist/core/prompts/assembly.js +0 -29
  210. package/dist/core/prompts/registry.js +0 -364
  211. package/dist/core/pugi-gitignore.js +0 -52
  212. package/dist/core/pugi-md/cc-compat-rules.js +0 -735
  213. package/dist/core/pugi-md/context-injector.js +0 -76
  214. package/dist/core/pugi-md/walk-up.js +0 -207
  215. package/dist/core/python/uv-installer.js +0 -270
  216. package/dist/core/python/uv-resolver.js +0 -83
  217. package/dist/core/rate-limit/narrator.js +0 -146
  218. package/dist/core/recipes/cli-types.js +0 -20
  219. package/dist/core/recipes/loader.js +0 -103
  220. package/dist/core/recipes/runner.js +0 -345
  221. package/dist/core/recipes/schema.js +0 -587
  222. package/dist/core/release-notes/parser.js +0 -241
  223. package/dist/core/release-notes/state.js +0 -116
  224. package/dist/core/repl/ask.js +0 -512
  225. package/dist/core/repl/cancellation.js +0 -98
  226. package/dist/core/repl/cap-warning.js +0 -91
  227. package/dist/core/repl/clipboard-read.js +0 -174
  228. package/dist/core/repl/dispatch-fsm.js +0 -220
  229. package/dist/core/repl/engine-bridge.js +0 -303
  230. package/dist/core/repl/history-search.js +0 -175
  231. package/dist/core/repl/history.js +0 -182
  232. package/dist/core/repl/kill-ring.js +0 -138
  233. package/dist/core/repl/model-pricing.js +0 -135
  234. package/dist/core/repl/privacy-banner.js +0 -71
  235. package/dist/core/repl/session.js +0 -4962
  236. package/dist/core/repl/slash-commands.js +0 -747
  237. package/dist/core/repl/store/index.js +0 -12
  238. package/dist/core/repl/store/jsonl-log.js +0 -321
  239. package/dist/core/repl/store/lockfile.js +0 -155
  240. package/dist/core/repl/store/session-store.js +0 -821
  241. package/dist/core/repl/store/types.js +0 -44
  242. package/dist/core/repl/store/uuid-v7.js +0 -68
  243. package/dist/core/repl/tool-route.js +0 -382
  244. package/dist/core/repl/workspace-context.js +0 -206
  245. package/dist/core/repo-map/build.js +0 -125
  246. package/dist/core/repo-map/cache.js +0 -185
  247. package/dist/core/repo-map/extractor.js +0 -254
  248. package/dist/core/repo-map/formatter.js +0 -145
  249. package/dist/core/repo-map/page-rank.js +0 -105
  250. package/dist/core/repo-map/scanner.js +0 -211
  251. package/dist/core/retro/git-collector.js +0 -251
  252. package/dist/core/retro/health-card.js +0 -25
  253. package/dist/core/retro/metrics.js +0 -342
  254. package/dist/core/retro/narrative.js +0 -249
  255. package/dist/core/retro/plane-collector.js +0 -274
  256. package/dist/core/retro/pr-issue-link.js +0 -65
  257. package/dist/core/retro/types.js +0 -16
  258. package/dist/core/retry-budget/budget.js +0 -284
  259. package/dist/core/retry-budget/index.js +0 -5
  260. package/dist/core/retry-budget/retry-cap.js +0 -74
  261. package/dist/core/routing/lead-worker.js +0 -43
  262. package/dist/core/routing/pre-flight-estimator.js +0 -108
  263. package/dist/core/runs/run-tree.js +0 -103
  264. package/dist/core/sandboxing/adapter.js +0 -29
  265. package/dist/core/sandboxing/index.js +0 -49
  266. package/dist/core/sandboxing/none.js +0 -19
  267. package/dist/core/sandboxing/seatbelt.js +0 -183
  268. package/dist/core/security/injection-scanner.js +0 -367
  269. package/dist/core/security/output-filter.js +0 -418
  270. package/dist/core/session/env-file.js +0 -105
  271. package/dist/core/session/section-budgets.js +0 -140
  272. package/dist/core/session.js +0 -377
  273. package/dist/core/settings.js +0 -400
  274. package/dist/core/share/formatter.js +0 -271
  275. package/dist/core/share/redactor.js +0 -221
  276. package/dist/core/share/uploader.js +0 -267
  277. package/dist/core/skills/defaults.js +0 -457
  278. package/dist/core/skills/loader.js +0 -454
  279. package/dist/core/skills/sources.js +0 -480
  280. package/dist/core/skills/trust.js +0 -172
  281. package/dist/core/smoke/headless-driver.js +0 -174
  282. package/dist/core/smoke/orchestrator.js +0 -194
  283. package/dist/core/smoke/runner.js +0 -238
  284. package/dist/core/smoke/scenario-parser.js +0 -316
  285. package/dist/core/statusline.js +0 -99
  286. package/dist/core/subagents/dispatcher-real.js +0 -600
  287. package/dist/core/subagents/dispatcher.js +0 -352
  288. package/dist/core/subagents/index.js +0 -39
  289. package/dist/core/subagents/isolation-matrix.js +0 -213
  290. package/dist/core/subagents/spawn.js +0 -101
  291. package/dist/core/telemetry/emitter.js +0 -229
  292. package/dist/core/telemetry/queue.js +0 -251
  293. package/dist/core/theme/context.js +0 -91
  294. package/dist/core/theme/presets.js +0 -228
  295. package/dist/core/theme/state.js +0 -181
  296. package/dist/core/todos/invariant.js +0 -10
  297. package/dist/core/todos/state.js +0 -177
  298. package/dist/core/tool-schema/compressor.js +0 -89
  299. package/dist/core/transport/version-interceptor.js +0 -166
  300. package/dist/core/trust.js +0 -109
  301. package/dist/core/tui/thinking-block.js +0 -64
  302. package/dist/core/vim/keymap.js +0 -288
  303. package/dist/core/vim/state.js +0 -92
  304. package/dist/core/watch-markers/marker-watcher.js +0 -133
  305. package/dist/core/worktree/include-parser.js +0 -249
  306. package/dist/core/worktree-manager/cleanup.js +0 -123
  307. package/dist/core/worktree-manager/manager.js +0 -303
  308. package/dist/index.js +0 -44
  309. package/dist/runtime/bootstrap.js +0 -190
  310. package/dist/runtime/cli.js +0 -8121
  311. package/dist/runtime/commands/agents.js +0 -385
  312. package/dist/runtime/commands/budget.js +0 -192
  313. package/dist/runtime/commands/cancel.js +0 -231
  314. package/dist/runtime/commands/chain.js +0 -489
  315. package/dist/runtime/commands/codegraph-status.js +0 -227
  316. package/dist/runtime/commands/compact.js +0 -297
  317. package/dist/runtime/commands/config.js +0 -595
  318. package/dist/runtime/commands/cost.js +0 -199
  319. package/dist/runtime/commands/delegate.js +0 -312
  320. package/dist/runtime/commands/dispatch.js +0 -126
  321. package/dist/runtime/commands/doctor.js +0 -579
  322. package/dist/runtime/commands/feedback.js +0 -184
  323. package/dist/runtime/commands/hooks.js +0 -187
  324. package/dist/runtime/commands/init.js +0 -254
  325. package/dist/runtime/commands/lsp.js +0 -368
  326. package/dist/runtime/commands/mcp.js +0 -935
  327. package/dist/runtime/commands/memory.js +0 -582
  328. package/dist/runtime/commands/model.js +0 -237
  329. package/dist/runtime/commands/onboarding.js +0 -275
  330. package/dist/runtime/commands/patch.js +0 -128
  331. package/dist/runtime/commands/permissions.js +0 -112
  332. package/dist/runtime/commands/plan.js +0 -143
  333. package/dist/runtime/commands/prd-check.js +0 -285
  334. package/dist/runtime/commands/privacy.js +0 -107
  335. package/dist/runtime/commands/recipe.js +0 -325
  336. package/dist/runtime/commands/redo-blob-store.js +0 -92
  337. package/dist/runtime/commands/redo.js +0 -361
  338. package/dist/runtime/commands/release-notes.js +0 -229
  339. package/dist/runtime/commands/repo-map.js +0 -95
  340. package/dist/runtime/commands/report.js +0 -299
  341. package/dist/runtime/commands/resume.js +0 -118
  342. package/dist/runtime/commands/review-consensus.js +0 -414
  343. package/dist/runtime/commands/rewind.js +0 -333
  344. package/dist/runtime/commands/roster.js +0 -117
  345. package/dist/runtime/commands/sessions.js +0 -163
  346. package/dist/runtime/commands/share.js +0 -316
  347. package/dist/runtime/commands/skills.js +0 -401
  348. package/dist/runtime/commands/status.js +0 -186
  349. package/dist/runtime/commands/stickers.js +0 -82
  350. package/dist/runtime/commands/style.js +0 -194
  351. package/dist/runtime/commands/theme.js +0 -196
  352. package/dist/runtime/commands/undo.js +0 -361
  353. package/dist/runtime/commands/update.js +0 -289
  354. package/dist/runtime/commands/vim.js +0 -140
  355. package/dist/runtime/commands/worktree.js +0 -177
  356. package/dist/runtime/commands/worktrees.js +0 -155
  357. package/dist/runtime/deprecation-warning.js +0 -69
  358. package/dist/runtime/engine-exit-code.js +0 -50
  359. package/dist/runtime/headless-repl.js +0 -195
  360. package/dist/runtime/headless.js +0 -548
  361. package/dist/runtime/load-hooks-or-exit.js +0 -71
  362. package/dist/runtime/plan-decompose.js +0 -531
  363. package/dist/runtime/sigint-guard.js +0 -272
  364. package/dist/runtime/stream-renderer.js +0 -195
  365. package/dist/runtime/update-check.js +0 -294
  366. package/dist/runtime/version.js +0 -65
  367. package/dist/runtime/worktree-bootstrap.js +0 -579
  368. package/dist/skills/bundled/batch.js +0 -617
  369. package/dist/skills/bundled/index.js +0 -45
  370. package/dist/skills/bundled/loop.js +0 -358
  371. package/dist/skills/bundled/remember.js +0 -383
  372. package/dist/skills/bundled/simplify.js +0 -289
  373. package/dist/skills/bundled/skillify.js +0 -373
  374. package/dist/skills/bundled/stuck.js +0 -558
  375. package/dist/skills/bundled/verify.js +0 -439
  376. package/dist/testing/vcr.js +0 -486
  377. package/dist/tools/agent-tool.js +0 -229
  378. package/dist/tools/apply-patch.js +0 -556
  379. package/dist/tools/ask-user-question.js +0 -337
  380. package/dist/tools/ask-user.js +0 -115
  381. package/dist/tools/bash.js +0 -1238
  382. package/dist/tools/brief.js +0 -224
  383. package/dist/tools/cron.js +0 -433
  384. package/dist/tools/enter-worktree.js +0 -250
  385. package/dist/tools/exit-worktree.js +0 -147
  386. package/dist/tools/file-tools.js +0 -553
  387. package/dist/tools/http-request.js +0 -336
  388. package/dist/tools/lsp-tools.js +0 -565
  389. package/dist/tools/mcp-tool.js +0 -260
  390. package/dist/tools/multi-edit.js +0 -361
  391. package/dist/tools/powershell.js +0 -268
  392. package/dist/tools/registry.js +0 -166
  393. package/dist/tools/server-tools.js +0 -892
  394. package/dist/tools/skill-tool.js +0 -96
  395. package/dist/tools/sleep.js +0 -99
  396. package/dist/tools/synthetic-output.js +0 -133
  397. package/dist/tools/tasks.js +0 -208
  398. package/dist/tools/todo-write.js +0 -184
  399. package/dist/tools/verify-plan-execution.js +0 -295
  400. package/dist/tools/web-fetch-injection-scanner.js +0 -207
  401. package/dist/tools/web-fetch.js +0 -720
  402. package/dist/tools/web-search.js +0 -458
  403. package/dist/tui/agent-progress-card.js +0 -111
  404. package/dist/tui/agent-tree-pane.js +0 -9
  405. package/dist/tui/agent-tree.js +0 -87
  406. package/dist/tui/ask-cli.js +0 -52
  407. package/dist/tui/ask-modal.js +0 -211
  408. package/dist/tui/ask-user-question-chips.js +0 -315
  409. package/dist/tui/ask-user-question-prompt.js +0 -203
  410. package/dist/tui/compact-banner.js +0 -81
  411. package/dist/tui/conversation-pane.js +0 -164
  412. package/dist/tui/cost-table.js +0 -111
  413. package/dist/tui/device-flow.js +0 -142
  414. package/dist/tui/doctor-table.js +0 -46
  415. package/dist/tui/feedback-prompt.js +0 -156
  416. package/dist/tui/input-box.js +0 -732
  417. package/dist/tui/login-picker.js +0 -69
  418. package/dist/tui/markdown-render.js +0 -266
  419. package/dist/tui/multi-file-diff-approval.js +0 -375
  420. package/dist/tui/onboarding-wizard.js +0 -240
  421. package/dist/tui/permissions-picker.js +0 -86
  422. package/dist/tui/render.js +0 -160
  423. package/dist/tui/repl-render.js +0 -770
  424. package/dist/tui/repl-splash-art.js +0 -64
  425. package/dist/tui/repl-splash-mascot.js +0 -154
  426. package/dist/tui/repl-splash.js +0 -117
  427. package/dist/tui/repl.js +0 -378
  428. package/dist/tui/slash-palette.js +0 -106
  429. package/dist/tui/splash-data.js +0 -61
  430. package/dist/tui/splash.js +0 -31
  431. package/dist/tui/status-bar.js +0 -209
  432. package/dist/tui/status-table.js +0 -7
  433. package/dist/tui/stickers-art.js +0 -136
  434. package/dist/tui/style-table.js +0 -28
  435. package/dist/tui/theme-table.js +0 -29
  436. package/dist/tui/thinking-spinner.js +0 -123
  437. package/dist/tui/tool-stream-pane.js +0 -140
  438. package/dist/tui/update-banner.js +0 -33
  439. package/dist/tui/vim-input.js +0 -267
  440. package/dist/tui/welcome-banner.js +0 -107
  441. package/dist/tui/welcome-data.js +0 -293
  442. package/dist/tui/workspace-context.js +0 -105
  443. package/docs/examples/codegraph.mcp.json +0 -10
  444. package/test/scenarios/codegen-create-file.scenario.txt +0 -13
  445. package/test/scenarios/compact-force.scenario.txt +0 -12
  446. package/test/scenarios/identity.scenario.txt +0 -11
  447. package/test/scenarios/persona-handoff.scenario.txt +0 -12
  448. package/test/scenarios/walkback.scenario.txt +0 -12
@@ -1,140 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from 'ink';
3
- import { RESULT_PREVIEW_MAX_CHARS, STREAMING_DELTA_MAX_CHARS, } from '../core/repl/session.js';
4
- const DEFAULT_COLLAPSE_THRESHOLD = 5;
5
- const DEFAULT_MAX_ROWS = 8;
6
- export function ToolStreamPane(props) {
7
- const calls = props.calls;
8
- const collapseThreshold = props.collapseThreshold ?? DEFAULT_COLLAPSE_THRESHOLD;
9
- const maxRows = props.maxRows ?? DEFAULT_MAX_ROWS;
10
- if (calls.length === 0) {
11
- return (_jsxs(Box, { flexDirection: "column", children: [_jsx(PaneHeader, { count: 0, collapsed: props.collapsed }), _jsx(Text, { dimColor: true, children: "No tool calls yet. Dispatch a brief and watch tools land here." })] }));
12
- }
13
- if (props.collapsed === true) {
14
- return (_jsx(Box, { flexDirection: "column", children: _jsx(PaneHeader, { count: calls.length, collapsed: true }) }));
15
- }
16
- // Tail-window the rows so a long-running session does not overflow
17
- // the bottom half of the frame. Older rows stay in the session state
18
- // for /jobs and /diff inspection.
19
- const visible = calls.slice(-maxRows);
20
- return (_jsxs(Box, { flexDirection: "column", children: [_jsx(PaneHeader, { count: calls.length, collapsed: false }), visible.map((call) => (_jsx(ToolCallRow, { call: call, collapseThreshold: collapseThreshold }, call.id)))] }));
21
- }
22
- function PaneHeader({ count, collapsed }) {
23
- const verb = collapsed ? 'Ctrl+T to expand' : 'Ctrl+T to collapse';
24
- return (_jsxs(Box, { children: [_jsx(Text, { bold: true, dimColor: true, children: '─ tools ' }), _jsx(Text, { dimColor: true, children: `(${count}) ` }), _jsx(Text, { dimColor: true, children: verb })] }));
25
- }
26
- function ToolCallRow({ call, collapseThreshold, }) {
27
- const glyph = statusGlyph(call.status);
28
- const color = statusColor(call.status);
29
- const label = formatToolLabel(call.tool, call.args);
30
- const summary = formatSummary(call);
31
- const showHint = (call.resultLines ?? 0) > collapseThreshold;
32
- // small-CC-parity batch : on a `running` row,
33
- // surface the rolling streaming delta as a dim inline preview after
34
- // the label. On a completed row, the same slot carries the
35
- // `resultPreview` quoted head. Either way the row stays single-line —
36
- // both fields are clamped к their respective char ceilings upstream.
37
- const inlineTail = call.status === 'running'
38
- ? call.streamingDelta
39
- : call.resultPreview;
40
- // Error rows: render the label too in red so the eye lands on the
41
- // failure even при peripheral attention. The other states keep the
42
- // glyph as the only color signal.
43
- const labelColor = call.status === 'error' ? 'red' : undefined;
44
- return (_jsxs(Box, { children: [_jsx(Text, { color: color, children: glyph }), _jsx(Text, { children: ' ' }), _jsx(Text, { bold: true, color: labelColor, children: label }), _jsx(Text, { dimColor: true, children: ` ${summary}` }), inlineTail ? (_jsx(Text, { dimColor: true, children: ` ${formatInlineTail(call.status, inlineTail)}` })) : null, showHint ? (_jsx(Text, { dimColor: true, children: ` · ${call.resultLines} lines, Ctrl+O to expand` })) : null] }));
45
- }
46
- /**
47
- * small-CC-parity batch : render the inline tail
48
- * slot for either the live `streamingDelta` (during `running`) or the
49
- * collapsed `resultPreview` (after completion). Pure helper so the
50
- * spec can assert the exact shape.
51
- *
52
- * running → `… npm WARN deprecated…`
53
- * ok / error → `"<preview head>"`
54
- */
55
- export function formatInlineTail(status, tail) {
56
- if (status === 'running') {
57
- return tail;
58
- }
59
- // Wrap the completed preview in quotes so the operator's eye groups
60
- // the preview block visually distinct from the canonical detail
61
- // (`OK`, `+12 -0`). Mirrors the the upstream tool TUI's quoted-preview
62
- // pattern.
63
- return `"${tail}"`;
64
- }
65
- function statusGlyph(status) {
66
- switch (status) {
67
- case 'running':
68
- return '→';
69
- case 'ok':
70
- return '✓';
71
- case 'error':
72
- return '✗';
73
- }
74
- }
75
- function statusColor(status) {
76
- switch (status) {
77
- case 'running':
78
- return 'cyan';
79
- case 'ok':
80
- return 'green';
81
- case 'error':
82
- return 'red';
83
- }
84
- }
85
- /**
86
- * Render the canonical `Tool(args)` form. Tool names are capitalised
87
- * the way the upstream tool shows them; args are truncated to keep the row
88
- * single-line even on 80-col terminals. Cap = 60 chars (chosen empirically
89
- * to leave room for the glyph + 1-space gap + summary + optional
90
- * inline tail without overflow on narrow shells).
91
- */
92
- function formatToolLabel(tool, args) {
93
- const name = toolDisplayName(tool);
94
- const trimmedArgs = args.length > 60 ? `${args.slice(0, 57)}…` : args;
95
- return `${name}(${trimmedArgs})`;
96
- }
97
- /**
98
- * Re-export the upstream char caps so the operator-facing constants
99
- * have one source of truth. The session module owns the canonical
100
- * values (used both during ingest и during the pane's render lookup);
101
- * tests assert against these names rather than literal numbers so a
102
- * future tuning сtays diff-friendly.
103
- */
104
- export { RESULT_PREVIEW_MAX_CHARS, STREAMING_DELTA_MAX_CHARS };
105
- function toolDisplayName(tool) {
106
- switch (tool) {
107
- case 'read':
108
- return 'Read';
109
- case 'write':
110
- // — Write is the most operator-visible tool for the
111
- // codegen-dispatch surface (Hiroshi writing index.html / style.css
112
- // / script.js for a tic-tac-toe brief). Add the display name so
113
- // the tool stream pane renders ✓ Write(index.html) instead of an
114
- // unlabeled placeholder. Mirrors the the upstream tool Write rendering.
115
- return 'Write';
116
- case 'edit':
117
- return 'Edit';
118
- case 'bash':
119
- return 'Bash';
120
- case 'grep':
121
- return 'Grep';
122
- case 'glob':
123
- return 'Glob';
124
- case 'web_fetch':
125
- return 'WebFetch';
126
- }
127
- }
128
- function formatSummary(call) {
129
- if (call.status === 'running') {
130
- return call.detail ?? 'running...';
131
- }
132
- if (call.status === 'error') {
133
- return call.detail ?? 'error';
134
- }
135
- // ok
136
- const duration = typeof call.durationMs === 'number' ? `${call.durationMs}ms` : '';
137
- const detail = call.detail ?? 'OK';
138
- return duration.length > 0 ? `${detail} ${duration}` : detail;
139
- }
140
- //# sourceMappingURL=tool-stream-pane.js.map
@@ -1,33 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from 'ink';
3
- import { compareVersions, upgradeCommand, } from '../runtime/update-check.js';
4
- import { getCachedServerRecommendation } from '../core/transport/version-interceptor.js';
5
- /**
6
- * Resolve the `latest` value the banner should show. Exported so the
7
- * spec can lock the merge logic without rendering Ink.
8
- */
9
- export function resolveDisplayedLatest(npmLatest, serverRecommended) {
10
- if (!serverRecommended)
11
- return npmLatest;
12
- return compareVersions(serverRecommended, npmLatest) > 0
13
- ? serverRecommended
14
- : npmLatest;
15
- }
16
- /**
17
- * peer-CLI-style corner banner: single line, dim orange, right
18
- * aligned. Renders to the bottom of the REPL frame so it never
19
- * displaces conversation content. Only mounts when an update is
20
- * actually available; identical to no-op when the registry poll
21
- * reports current. Suppress with `PUGI_SKIP_UPDATE_BANNER=1`.
22
- */
23
- export function UpdateBanner({ result }) {
24
- const command = upgradeCommand(result.method);
25
- // Read the cache lazily inside the render so a server response that
26
- // landed AFTER the banner was constructed still shows up on the next
27
- // re-render. The cache lookup is a single map read — cheap enough to
28
- // do per render.
29
- const serverRecommended = getCachedServerRecommendation();
30
- const displayedLatest = resolveDisplayedLatest(result.latest, serverRecommended);
31
- return (_jsx(Box, { justifyContent: "flex-end", children: _jsxs(Text, { color: "#d97706", children: [_jsx(Text, { dimColor: true, children: 'Update available! ' }), _jsx(Text, { dimColor: true, children: `v${displayedLatest} — Run: ` }), _jsx(Text, { bold: true, children: command })] }) }));
32
- }
33
- //# sourceMappingURL=update-banner.js.map
@@ -1,267 +0,0 @@
1
- import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
- /**
3
- * — Vim-mode-aware REPL input.
4
- *
5
- * Thin wrapper that sits BETWEEN the REPL session and the legacy
6
- * `InputBox`. When vim mode is off it forwards every prop unchanged
7
- * so existing operators see zero behavioural delta. When vim mode is
8
- * on it intercepts keystrokes through `useInput` BEFORE Ink's normal
9
- * dispatch and either:
10
- *
11
- * - in `insert` mode, lets the keystroke fall through to `InputBox`
12
- * so the legacy buffer / cursor / history / palette code stays
13
- * authoritative (we do NOT re-implement insert-mode editing);
14
- * - in `normal` mode, routes the key through `core/vim/keymap.ts`
15
- * and applies the result to a shadow buffer + cursor mirror that
16
- * it then pushes back into `InputBox` via the existing `initial`
17
- * prop on remount.
18
- *
19
- * Why a wrapper instead of inlining into `InputBox`?
20
- *
21
- * - Keeps the legacy input surface untouched for non-vim operators
22
- * (the L26 ship risks zero regression to ~year-old code).
23
- * - The wrapper renders a thin status row ABOVE the input frame so
24
- * the active mode + pending sequence + cheat sheet are visible.
25
- * - Tests can exercise the wrapper without dragging in the full
26
- * ink + clipboard stack of `InputBox` (the spec drives the
27
- * keymap directly; the wrapper is exercised via the runtime
28
- * command tests + manual smoke from the REPL).
29
- *
30
- * The component intentionally only models the SINGLE-LINE REPL prompt
31
- * buffer — that is the surface the upstream tool's `/vim` covers, and that
32
- * is what the upstream behavior validated. Multi-line + visual-mode +
33
- * counts are out of scope for this sprint.
34
- *
35
- * ─── Closure-staleness contract (post-L26 fix) ───
36
- *
37
- * Three-of-three reviewers flagged the original `setShadowLine`
38
- * functional updater for reading `shadowCursor` and `pending` from
39
- * the closure, which goes stale across consecutive keystrokes
40
- * (React batches dispatch, so the second `d` of `dd` saw the
41
- * `pending` value from the render that scheduled the first `d`,
42
- * not the post-first-d value). Same problem for cursor advancement
43
- * across chained `l`/`h`/`w`/`b` presses.
44
- *
45
- * Additionally, calling `props.onSubmit` inline inside a setState
46
- * updater is double-fired by React strict mode (updaters MUST be
47
- * pure — strict mode runs them twice to surface impurity).
48
- *
49
- * The fix moves shadow cursor + pending + mode into `useRef`
50
- * (refs survive across renders, are read synchronously, and are
51
- * not subject to closure capture), drives the keymap dispatch
52
- * OUTSIDE any setState callback, and defers `props.onSubmit` /
53
- * `props.onExit` invocations until AFTER the render via the
54
- * `useEffect` queued by toggling a transition ref.
55
- *
56
- * The `line` state is the only React state we mutate per keystroke
57
- * because the inner `InputBox` re-reads it via the `initial` prop
58
- * on remount — refs alone cannot trigger that remount. Cursor + mode
59
- * + pending are surfaced to the render path through the same
60
- * `line`/`tick` rerender, so the status bar stays in sync without
61
- * itself being captured by a stale closure.
62
- */
63
- import { useEffect, useRef, useState } from 'react';
64
- import { Box, Text, useInput } from 'ink';
65
- import { handleNormalKey, PENDING_NONE, describePending, } from '../core/vim/keymap.js';
66
- import { InputBox } from './input-box.js';
67
- /**
68
- * Render the mode badge + pending sequence + cheat sheet above the
69
- * input frame. Two lines:
70
- *
71
- * ─ NORMAL ─ d: Esc=normal · i=insert · :w=submit · :q=cancel
72
- * ─ INSERT ─ (mode-specific tail dropped when there's nothing to show)
73
- *
74
- * Plain ASCII + dim accents to match the rest of the REPL's chrome.
75
- */
76
- function VimStatusBar(props) {
77
- const modeLabel = props.mode === 'normal' ? '-- NORMAL --' : '-- INSERT --';
78
- const pendingLabel = describePending(props.pending);
79
- const hint = props.mode === 'normal'
80
- ? 'h/j/k/l move · i/a insert · x del · dd line · :w submit · :q cancel'
81
- : 'Esc → normal mode';
82
- return (_jsxs(Box, { children: [_jsx(Text, { color: "#3da9fc", bold: true, children: modeLabel }), pendingLabel.length > 0 ? (_jsxs(_Fragment, { children: [_jsx(Text, { children: " " }), _jsx(Text, { color: "yellow", children: `${pendingLabel}` })] })) : null, _jsx(Text, { children: " " }), _jsx(Text, { dimColor: true, children: hint })] }));
83
- }
84
- export function VimInput(props) {
85
- const { vimEnabled, initialMode, ...inputBoxProps } = props;
86
- // When vim mode is off we DO NOT mount the `useInput` overlay — the
87
- // legacy `InputBox` keeps full ownership of the keystrokes and
88
- // behaves byte-for-byte the way it always did. This is the same
89
- // pattern `output-style` followed (off → pass through; on → activate
90
- // the modal surface).
91
- if (!vimEnabled) {
92
- return _jsx(InputBox, { ...inputBoxProps });
93
- }
94
- // ─── Render-driving state ─────────────────────────────────────
95
- //
96
- // `line` + `tick` are the only pieces of state the render path
97
- // reads — the inner `InputBox` is remounted on every `tick` bump
98
- // so the `initial` prop is honoured. Cursor / pending / mode are
99
- // held in refs (see below) and mirrored into render state via the
100
- // same setLine/setTick burst at the end of each keystroke so the
101
- // status bar stays in lockstep without ever being captured by a
102
- // stale closure inside a setState updater.
103
- const [line, setLine] = useState(props.initial ?? '');
104
- const [mode, setMode] = useState(initialMode ?? 'normal');
105
- const [pending, setPending] = useState(PENDING_NONE);
106
- const [remountTick, setRemountTick] = useState(0);
107
- // ─── Closure-safe scratch refs ────────────────────────────────
108
- //
109
- // These refs are written synchronously inside the `useInput`
110
- // handler and read on the NEXT keystroke. They survive across
111
- // renders, are not captured by stale closures, and are NEVER
112
- // mutated inside a setState updater — so React strict-mode's
113
- // double-invocation cannot corrupt them.
114
- //
115
- // Why not `useReducer`? A reducer would also see fresh state on
116
- // every dispatch, but the keymap result is a tagged union whose
117
- // side effects (mode flip, submit, cancel, remount) are easier
118
- // to read as imperative steps after the pure `handleNormalKey`
119
- // call. Refs keep the dispatcher linear and the diff vs the
120
- // pre-fix file minimal.
121
- const lineRef = useRef(props.initial ?? '');
122
- const cursorRef = useRef(props.initial?.length ?? 0);
123
- const pendingRef = useRef(PENDING_NONE);
124
- const modeRef = useRef(initialMode ?? 'normal');
125
- // Deferred side-effect queue — submit / exit must NOT run inline
126
- // inside a setState updater (strict mode double-invokes them).
127
- // We stash the payload here and flush it from a `useEffect` after
128
- // the render commits.
129
- const pendingSubmitRef = useRef(null);
130
- const pendingExitRef = useRef(false);
131
- const [sideEffectTick, setSideEffectTick] = useState(0);
132
- useEffect(() => {
133
- // Flush any deferred host callback exactly once per scheduled
134
- // burst. The refs are nulled BEFORE the call so a re-entrant
135
- // host onSubmit handler that re-renders us cannot re-fire the
136
- // same payload.
137
- const submit = pendingSubmitRef.current;
138
- if (submit !== null) {
139
- pendingSubmitRef.current = null;
140
- props.onSubmit(submit);
141
- }
142
- if (pendingExitRef.current) {
143
- pendingExitRef.current = false;
144
- props.onExit();
145
- }
146
- // Intentionally only depends on `sideEffectTick`: we want this
147
- // effect to fire ONLY when the keystroke handler asked for it
148
- // (via setSideEffectTick), not on every prop change.
149
- // eslint-disable-next-line react-hooks/exhaustive-deps
150
- }, [sideEffectTick]);
151
- useInput((input, key) => {
152
- // Esc always returns to normal mode (and clears any pending
153
- // sequence). This binding wins over `InputBox`'s own Esc handling
154
- // because we own the `useInput` hook earlier in the render tree.
155
- if (key.escape) {
156
- modeRef.current = 'normal';
157
- pendingRef.current = PENDING_NONE;
158
- setMode('normal');
159
- setPending(PENDING_NONE);
160
- return;
161
- }
162
- // In insert mode we relinquish dispatch entirely so the legacy
163
- // input box owns typing / palette / history / clipboard / kill
164
- // ring without interference. Returning `undefined` from a
165
- // `useInput` callback is a no-op — InputBox's own `useInput` will
166
- // receive the same event on the next frame.
167
- if (modeRef.current === 'insert')
168
- return;
169
- // In normal mode we drive the buffer through the keymap.
170
- //
171
- // CRITICAL: all inputs to `handleNormalKey` are read from refs,
172
- // not from the React state closure captured at render time.
173
- // This is what makes consecutive keystrokes ("ll", "dd", ":w")
174
- // observe the post-previous-keystroke state instead of the
175
- // pre-batch render snapshot.
176
- const ch = input ?? '';
177
- const curLine = lineRef.current;
178
- const curCursor = cursorRef.current;
179
- const curPending = pendingRef.current;
180
- const out = handleNormalKey({
181
- line: curLine,
182
- cursor: curCursor,
183
- pending: curPending,
184
- ch,
185
- enter: key.return,
186
- escape: false,
187
- backspace: key.backspace || key.delete,
188
- });
189
- // Step 1: write the new pending state to BOTH the ref (read by
190
- // the next keystroke synchronously) AND the React state (drives
191
- // the status bar render).
192
- pendingRef.current = out.pending;
193
- setPending(out.pending);
194
- // Step 2: apply the discriminated result. Each branch updates
195
- // the refs first (synchronous, closure-safe) and then schedules
196
- // any required React state update or deferred side effect.
197
- switch (out.result.kind) {
198
- case 'move': {
199
- cursorRef.current = out.result.cursor;
200
- // Cursor lives in the ref; the inner InputBox does not need
201
- // a remount for a pure motion, so we skip the tick bump.
202
- break;
203
- }
204
- case 'edit': {
205
- cursorRef.current = out.result.cursor;
206
- lineRef.current = out.result.line;
207
- setLine(out.result.line);
208
- setRemountTick((t) => t + 1);
209
- break;
210
- }
211
- case 'mode': {
212
- cursorRef.current = out.result.cursor;
213
- modeRef.current = out.result.mode;
214
- setMode(out.result.mode);
215
- break;
216
- }
217
- case 'submit': {
218
- // Forward to the host's onSubmit and clear the shadow buffer
219
- // so the next prompt starts empty. We DO NOT re-route
220
- // through InputBox's Enter handler — that path also writes
221
- // history; submitting from `:w` should mirror that, so we
222
- // call props.onSubmit indirectly via the deferred-effect
223
- // queue. (The host's history append happens inside InputBox;
224
- // for the modal path the host can observe via props.onSubmit
225
- // and append manually if needed. The leak-parity surface for
226
- // L26 documents `:w` as equivalent to Enter so this is fine.)
227
- const payload = out.result.payload;
228
- if (payload.trim().length > 0) {
229
- // Queue the host callback; useEffect flushes it after the
230
- // render commits. This avoids React strict-mode's
231
- // double-invocation of setState updaters double-firing
232
- // onSubmit (which would, e.g., submit the same prompt
233
- // twice to the agent on every `:w`).
234
- pendingSubmitRef.current = payload;
235
- }
236
- cursorRef.current = 0;
237
- lineRef.current = '';
238
- setLine('');
239
- setRemountTick((t) => t + 1);
240
- setSideEffectTick((t) => t + 1);
241
- break;
242
- }
243
- case 'cancel': {
244
- cursorRef.current = 0;
245
- lineRef.current = '';
246
- setLine('');
247
- setRemountTick((t) => t + 1);
248
- break;
249
- }
250
- case 'noop': {
251
- // No-op result still may have advanced `pending` (e.g. the
252
- // first `d` of `dd` arms the pending state). The pending ref
253
- // and state were already updated above, so nothing else to
254
- // do here.
255
- break;
256
- }
257
- }
258
- });
259
- return (_jsxs(Box, { flexDirection: "column", children: [_jsx(VimStatusBar, { mode: mode, pending: pending }), _jsx(InputBox, { ...inputBoxProps,
260
- // In normal mode we seed the (possibly mutated) shadow line +
261
- // suppress the blink so the operator's caret is unambiguously
262
- // controlled by h/l/0/$/w/b. In insert mode we hand the
263
- // buffer back to InputBox as-is so the legacy typing path
264
- // takes over.
265
- initial: mode === 'normal' ? line : (props.initial ?? line), blinkCursor: mode === 'normal' ? false : (props.blinkCursor ?? true) }, `vim-${remountTick}`)] }));
266
- }
267
- //# sourceMappingURL=vim-input.js.map
@@ -1,107 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { Box, Text } from 'ink';
3
- import { PUG_MASCOT, PUG_MASCOT_CYAN_MASK, PUG_MASCOT_MAX_WIDTH, } from './repl-splash-art.js';
4
- /* ------------------------------------------------------------------ */
5
- /* Layout constants */
6
- /* ------------------------------------------------------------------ */
7
- /** Default left-column width when the parent box doesn't pin one. */
8
- const LEFT_COLUMN_WIDTH = 44;
9
- /** Default right-column width. */
10
- const RIGHT_COLUMN_WIDTH = 44;
11
- const ACCENT = '#3da9fc';
12
- const BULLET = '·';
13
- /* ------------------------------------------------------------------ */
14
- /* Component */
15
- /* ------------------------------------------------------------------ */
16
- export function WelcomeBanner(props) {
17
- const { data } = props;
18
- const showHandCraftedMascot = props.mascotPrePrinted !== true;
19
- const initToast = props.autoInitStatus === 'initialized'
20
- ? 'Pugi workspace initialised at .pugi/.'
21
- : null;
22
- const accountLine = formatAccountLine(data);
23
- const modelLine = formatModelLine(data);
24
- return (_jsx(Box, { flexDirection: "column", children: _jsxs(Box, { borderStyle: "round", borderColor: ACCENT, paddingX: 1, flexDirection: "row", children: [_jsx(LeftColumn, { greetingName: data.greetingName, cwd: data.cwd, modelLine: modelLine, accountLine: accountLine, cliVersion: data.cliVersion, showHandCraftedMascot: showHandCraftedMascot, initToast: initToast }), _jsx(Box, { width: 2 }), _jsx(RightColumn, { whatsNew: data.whatsNew })] }) }));
25
- }
26
- /* ------------------------------------------------------------------ */
27
- /* Left column — greeting + mascot + status */
28
- /* ------------------------------------------------------------------ */
29
- function LeftColumn({ greetingName, cwd, modelLine, accountLine, cliVersion, showHandCraftedMascot, initToast, }) {
30
- return (_jsxs(Box, { flexDirection: "column", width: LEFT_COLUMN_WIDTH, children: [_jsxs(Box, { children: [_jsx(Text, { bold: true, children: "Pugi" }), _jsx(Text, { bold: true, color: ACCENT, children: ".io" }), _jsx(Text, { dimColor: true, children: ` v${cliVersion}` })] }), _jsx(Box, { marginTop: 1, children: _jsx(Text, { children: `Welcome back ${greetingName}!` }) }), showHandCraftedMascot ? (_jsx(Box, { marginTop: 1, children: _jsx(MascotColumn, {}) })) : null, _jsxs(Box, { marginTop: 1, flexDirection: "column", children: [_jsx(Text, { children: modelLine }), _jsx(Text, { dimColor: true, children: accountLine }), _jsx(Text, { dimColor: true, children: truncatePath(cwd, LEFT_COLUMN_WIDTH - 2) })] }), initToast ? (_jsx(Box, { marginTop: 1, children: _jsx(Text, { color: ACCENT, children: initToast }) })) : null] }));
31
- }
32
- /* ------------------------------------------------------------------ */
33
- /* Right column — tips + what's new */
34
- /* ------------------------------------------------------------------ */
35
- function RightColumn({ whatsNew, }) {
36
- return (_jsxs(Box, { flexDirection: "column", width: RIGHT_COLUMN_WIDTH, children: [_jsx(Text, { dimColor: true, children: "Tips for getting started" }), _jsxs(Box, { flexDirection: "column", children: [_jsx(TipRow, { text: "Run /init to scaffold PUGI.md instructions" }), _jsx(TipRow, { text: "Brief Pugi \u2014 the workforce dispatches" }), _jsx(TipRow, { text: "Triple-review gate before push: /review --triple" }), _jsx(TipRow, { text: "/help for every slash command" })] }), _jsx(Box, { marginTop: 1, children: _jsx(Text, { dimColor: true, children: '─'.repeat(Math.min(RIGHT_COLUMN_WIDTH - 2, 18)) }) }), _jsx(Box, { marginTop: 1, children: _jsx(Text, { dimColor: true, children: "What's new" }) }), _jsx(Box, { flexDirection: "column", children: whatsNew.length > 0 ? (whatsNew.map((line, index) => (_jsx(TipRow, { text: line }, `whatsnew-${index}`)))) : (_jsx(Text, { dimColor: true, children: ` ${BULLET} /release-notes for the full changelog` })) })] }));
37
- }
38
- function TipRow({ text }) {
39
- return (_jsxs(Text, { children: [_jsx(Text, { color: ACCENT, children: ` ${BULLET} ` }), _jsx(Text, { children: text })] }));
40
- }
41
- /* ------------------------------------------------------------------ */
42
- /* Mascot column (hand-crafted ASCII fallback path) */
43
- /* ------------------------------------------------------------------ */
44
- function MascotColumn() {
45
- return (_jsx(Box, { flexDirection: "column", minWidth: PUG_MASCOT_MAX_WIDTH, children: PUG_MASCOT.map((row, rowIndex) => (_jsx(MascotRow, { row: row, mask: PUG_MASCOT_CYAN_MASK[rowIndex] ?? [] }, `mascot-row-${rowIndex}`))) }));
46
- }
47
- function MascotRow({ row, mask, }) {
48
- // Split into contiguous same-color runs so we emit one <Text> per
49
- // run instead of one per character (keeps the Ink tree shallow и
50
- // the snapshot diff readable).
51
- const runs = [];
52
- let buffer = '';
53
- let bufferCyan = false;
54
- for (let column = 0; column < row.length; column += 1) {
55
- const ch = row.charAt(column);
56
- const cyan = mask[column] === true;
57
- if (buffer.length === 0) {
58
- buffer = ch;
59
- bufferCyan = cyan;
60
- continue;
61
- }
62
- if (cyan === bufferCyan) {
63
- buffer += ch;
64
- }
65
- else {
66
- runs.push({ text: buffer, cyan: bufferCyan });
67
- buffer = ch;
68
- bufferCyan = cyan;
69
- }
70
- }
71
- if (buffer.length > 0)
72
- runs.push({ text: buffer, cyan: bufferCyan });
73
- return (_jsx(Text, { children: runs.map((run, runIndex) => run.cyan ? (_jsx(Text, { color: ACCENT, children: run.text }, runIndex)) : (_jsx(Text, { color: "gray", children: run.text }, runIndex))) }));
74
- }
75
- /* ------------------------------------------------------------------ */
76
- /* Formatters */
77
- /* ------------------------------------------------------------------ */
78
- function formatModelLine(data) {
79
- const tierLabel = data.plan ? ` ${BULLET} ${capitalize(data.plan)} Tier` : '';
80
- return `${data.model}${tierLabel}`;
81
- }
82
- function formatAccountLine(data) {
83
- if (!data.email) {
84
- return 'Anonymous (run /login to authenticate)';
85
- }
86
- const tenant = data.tenant ? ` ${BULLET} ${data.tenant} Org` : '';
87
- return `${data.email}${tenant}`;
88
- }
89
- function capitalize(value) {
90
- if (value.length === 0)
91
- return value;
92
- return value.charAt(0).toUpperCase() + value.slice(1).toLowerCase();
93
- }
94
- /**
95
- * Trim the cwd from the LEFT (preserving the basename) so the operator
96
- * always sees which project they're in even when the column is narrow.
97
- * Mirrors the the upstream tool boot card convention: long paths get an
98
- * ellipsis on the head, never on the tail.
99
- */
100
- export function truncatePath(path, max) {
101
- if (path.length <= max)
102
- return path;
103
- if (max <= 3)
104
- return path.slice(-max);
105
- return `…${path.slice(-(max - 1))}`;
106
- }
107
- //# sourceMappingURL=welcome-banner.js.map