@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.
- package/LICENSE +1 -1
- package/README.md +11 -191
- package/bin/pugi +8 -0
- package/package.json +15 -71
- package/postinstall.mjs +31 -0
- package/CHANGELOG.md +0 -132
- package/THIRD_PARTY_NOTICES.md +0 -40
- package/assets/pugi-mascot.ansi +0 -16
- package/assets/pugi-prozr2-mascot.ansi +0 -9
- package/bin/run.js +0 -34
- package/dist/commands/deploy.js +0 -439
- package/dist/commands/flatten.js +0 -191
- package/dist/commands/jobs-watch.js +0 -201
- package/dist/commands/jobs.js +0 -260
- package/dist/commands/retro.js +0 -210
- package/dist/commands/smoke.js +0 -133
- package/dist/core/agent-progress/cleanup.js +0 -134
- package/dist/core/agent-progress/schema.js +0 -144
- package/dist/core/agent-progress/writer.js +0 -101
- package/dist/core/agents/adaptive-router.js +0 -330
- package/dist/core/agents/loader.js +0 -104
- package/dist/core/agents/query-decomposer.js +0 -297
- package/dist/core/agents/registry.js +0 -69
- package/dist/core/approvals/shortcut-resolver.js +0 -98
- package/dist/core/artifact-chain/dispatcher.js +0 -148
- package/dist/core/artifact-chain/exporter.js +0 -164
- package/dist/core/artifact-chain/state.js +0 -243
- package/dist/core/artifact-chain/steps.js +0 -169
- package/dist/core/ask-user/question.js +0 -92
- package/dist/core/audit/audit-trail.js +0 -275
- package/dist/core/auth/ensure-authenticated.js +0 -129
- package/dist/core/auth/env-provider.js +0 -238
- package/dist/core/auto-open-browser.js +0 -128
- package/dist/core/auto-update/channels.js +0 -122
- package/dist/core/auto-update/checker.js +0 -241
- package/dist/core/auto-update/state.js +0 -235
- package/dist/core/bare-mode/index.js +0 -107
- package/dist/core/bash/redirect.js +0 -281
- package/dist/core/bash-classifier.js +0 -1397
- package/dist/core/checkpoint/resumer.js +0 -149
- package/dist/core/checkpoint/rewinder.js +0 -291
- package/dist/core/checkpoints/shadow-git.js +0 -670
- package/dist/core/citations/parser.js +0 -109
- package/dist/core/classifier/yolo-classifier.js +0 -88
- package/dist/core/clipboard.js +0 -70
- package/dist/core/codegraph/decision-store.js +0 -248
- package/dist/core/codegraph/detect-repo.js +0 -459
- package/dist/core/codegraph/install.js +0 -134
- package/dist/core/codegraph/offer-hook.js +0 -220
- package/dist/core/compact/auto-trigger.js +0 -96
- package/dist/core/compact/buffer-rewriter.js +0 -115
- package/dist/core/compact/summarizer.js +0 -208
- package/dist/core/compact/token-counter.js +0 -108
- package/dist/core/consensus/anvil-fanout.js +0 -276
- package/dist/core/consensus/diff-capture.js +0 -491
- package/dist/core/consensus/rubric.js +0 -233
- package/dist/core/context/builder.js +0 -114
- package/dist/core/context/compaction-events.js +0 -99
- package/dist/core/context/compaction.js +0 -602
- package/dist/core/context/index.js +0 -28
- package/dist/core/context/invariants.js +0 -250
- package/dist/core/context/markdown-loader.js +0 -288
- package/dist/core/context/markdown-traverse.js +0 -255
- package/dist/core/context/pugiignore.js +0 -316
- package/dist/core/context/repo-skeleton.js +0 -533
- package/dist/core/context/tool-eviction.js +0 -55
- package/dist/core/context/watcher.js +0 -342
- package/dist/core/context/working-set.js +0 -165
- package/dist/core/coordinator/agent-tools.js +0 -77
- package/dist/core/coordinator/agent-toolset.js +0 -65
- package/dist/core/coordinator/fsm.js +0 -73
- package/dist/core/coordinator/mode-fsm.js +0 -70
- package/dist/core/cost/rate-card.js +0 -129
- package/dist/core/cost/tracker.js +0 -221
- package/dist/core/credentials.js +0 -355
- package/dist/core/cron/scheduler.js +0 -138
- package/dist/core/denial-tracking/index.js +0 -8
- package/dist/core/denial-tracking/state.js +0 -264
- package/dist/core/diagnostics/probe-runner.js +0 -93
- package/dist/core/diagnostics/probes/api.js +0 -46
- package/dist/core/diagnostics/probes/auth.js +0 -93
- package/dist/core/diagnostics/probes/bare-mode.js +0 -42
- package/dist/core/diagnostics/probes/cli-version.js +0 -127
- package/dist/core/diagnostics/probes/config.js +0 -72
- package/dist/core/diagnostics/probes/denial-tracking.js +0 -57
- package/dist/core/diagnostics/probes/disk.js +0 -81
- package/dist/core/diagnostics/probes/engine-live.js +0 -46
- package/dist/core/diagnostics/probes/git.js +0 -65
- package/dist/core/diagnostics/probes/hooks.js +0 -118
- package/dist/core/diagnostics/probes/mcp.js +0 -75
- package/dist/core/diagnostics/probes/node.js +0 -59
- package/dist/core/diagnostics/probes/pnpm.js +0 -36
- package/dist/core/diagnostics/probes/pugi-md.js +0 -89
- package/dist/core/diagnostics/probes/sandbox.js +0 -72
- package/dist/core/diagnostics/probes/session.js +0 -74
- package/dist/core/diagnostics/probes/status-snapshot.js +0 -488
- package/dist/core/diagnostics/probes/workspace.js +0 -63
- package/dist/core/diagnostics/types.js +0 -70
- package/dist/core/dispatch/cache-cleanup.js +0 -197
- package/dist/core/dispatch/cache-handoff.js +0 -295
- package/dist/core/edits/apply-patch-layer-e.js +0 -189
- package/dist/core/edits/dispatch.js +0 -511
- package/dist/core/edits/format-detector.js +0 -260
- package/dist/core/edits/format-matrix.js +0 -26
- package/dist/core/edits/fuzzy-ladder.js +0 -650
- package/dist/core/edits/index.js +0 -19
- package/dist/core/edits/journal.js +0 -199
- package/dist/core/edits/layer-a-apply.js +0 -217
- package/dist/core/edits/layer-a-fuzzy-apply.js +0 -198
- package/dist/core/edits/layer-b-apply.js +0 -211
- package/dist/core/edits/layer-c-apply.js +0 -160
- package/dist/core/edits/layer-d-ast.js +0 -572
- package/dist/core/edits/marker-parser.js +0 -401
- package/dist/core/edits/security-gate.js +0 -223
- package/dist/core/edits/verify-hook.js +0 -273
- package/dist/core/edits/worktree.js +0 -322
- package/dist/core/engine/adapter-runner.js +0 -8
- package/dist/core/engine/anvil-client.js +0 -344
- package/dist/core/engine/auto-compact.js +0 -179
- package/dist/core/engine/budgets.js +0 -192
- package/dist/core/engine/context-prefix.js +0 -155
- package/dist/core/engine/index.js +0 -12
- package/dist/core/engine/intensity.js +0 -163
- package/dist/core/engine/intent.js +0 -260
- package/dist/core/engine/native-pugi.js +0 -1616
- package/dist/core/engine/noop.js +0 -27
- package/dist/core/engine/prompts.js +0 -236
- package/dist/core/engine/strip-internal-fields.js +0 -124
- package/dist/core/engine/tool-bridge.js +0 -2173
- package/dist/core/engine/verification-patterns.js +0 -195
- package/dist/core/evaluation/golden-dataset.js +0 -293
- package/dist/core/feedback/queue.js +0 -177
- package/dist/core/feedback/submitter.js +0 -145
- package/dist/core/file-cache.js +0 -141
- package/dist/core/flatten/flatten-repo.js +0 -439
- package/dist/core/format/osc8-link.js +0 -28
- package/dist/core/hook-chains.js +0 -392
- package/dist/core/hooks/citation-verify-hook.js +0 -138
- package/dist/core/hooks/citation-verify.js +0 -112
- package/dist/core/hooks/events.js +0 -46
- package/dist/core/hooks/index.js +0 -15
- package/dist/core/hooks/registry.js +0 -216
- package/dist/core/hooks/runner.js +0 -236
- package/dist/core/hooks/v2/event-emitter.js +0 -115
- package/dist/core/hooks/v2/executor.js +0 -282
- package/dist/core/hooks/v2/index.js +0 -25
- package/dist/core/hooks/v2/lifecycle.js +0 -104
- package/dist/core/hooks/v2/loader.js +0 -216
- package/dist/core/hooks/v2/matcher.js +0 -125
- package/dist/core/hooks/v2/trust.js +0 -143
- package/dist/core/hooks/v2/types.js +0 -86
- package/dist/core/hooks/worktree-events.js +0 -158
- package/dist/core/hooks.js +0 -415
- package/dist/core/image/renderer.js +0 -71
- package/dist/core/index-store.js +0 -260
- package/dist/core/init/detector.js +0 -582
- package/dist/core/init/template-renderer.js +0 -242
- package/dist/core/jobs/registry.js +0 -462
- package/dist/core/ledger/results-tsv.js +0 -142
- package/dist/core/log-discipline/stdout-redirect.js +0 -51
- package/dist/core/lsp/cache.js +0 -105
- package/dist/core/lsp/client.js +0 -1229
- package/dist/core/lsp/language-detect.js +0 -66
- package/dist/core/lsp/post-edit-diagnostics.js +0 -171
- package/dist/core/lsp/server-detect.js +0 -173
- package/dist/core/lsp/symbol-cache.js +0 -162
- package/dist/core/lsp/symbol-tools.js +0 -664
- package/dist/core/mcp/client.js +0 -385
- package/dist/core/mcp/http-server.js +0 -553
- package/dist/core/mcp/orchestrator-config.js +0 -192
- package/dist/core/mcp/orchestrator-tools.js +0 -806
- package/dist/core/mcp/permission.js +0 -190
- package/dist/core/mcp/registry.js +0 -193
- package/dist/core/mcp/server-tools.js +0 -219
- package/dist/core/mcp/server.js +0 -397
- package/dist/core/mcp/trust.js +0 -91
- package/dist/core/memory/dual-write.js +0 -416
- package/dist/core/memory/passive-extract.js +0 -130
- package/dist/core/memory/phase1-kinds.js +0 -20
- package/dist/core/memory/secret-scanner.js +0 -304
- package/dist/core/memory-sync/queue.js +0 -170
- package/dist/core/metrics/extract.js +0 -113
- package/dist/core/modes/roo-modes.js +0 -68
- package/dist/core/onboarding/ensure-initialized.js +0 -133
- package/dist/core/onboarding/marker.js +0 -111
- package/dist/core/onboarding/telemetry-state.js +0 -108
- package/dist/core/output-style/presets.js +0 -176
- package/dist/core/output-style/state.js +0 -185
- package/dist/core/path-security.js +0 -345
- package/dist/core/permission.js +0 -369
- package/dist/core/permissions/auto-classifier.js +0 -124
- package/dist/core/permissions/bash-parser.js +0 -371
- package/dist/core/permissions/circuit-breaker.js +0 -83
- package/dist/core/permissions/constrained-edit.js +0 -91
- package/dist/core/permissions/gate.js +0 -278
- package/dist/core/permissions/index.js +0 -20
- package/dist/core/permissions/mode.js +0 -174
- package/dist/core/permissions/network-egress.js +0 -137
- package/dist/core/permissions/state.js +0 -241
- package/dist/core/permissions/tool-class.js +0 -107
- package/dist/core/plan-mode/ui-state.js +0 -51
- package/dist/core/plans/plan-artifact.js +0 -721
- package/dist/core/policy-limits/etag-store.js +0 -122
- package/dist/core/prd-check/parser.js +0 -215
- package/dist/core/prd-check/reporter.js +0 -127
- package/dist/core/prd-check/session-review.js +0 -557
- package/dist/core/prd-check/verifiers.js +0 -223
- package/dist/core/prompt-cache/client-cache.js +0 -99
- package/dist/core/prompts/assembly.js +0 -29
- package/dist/core/prompts/registry.js +0 -364
- package/dist/core/pugi-gitignore.js +0 -52
- package/dist/core/pugi-md/cc-compat-rules.js +0 -735
- package/dist/core/pugi-md/context-injector.js +0 -76
- package/dist/core/pugi-md/walk-up.js +0 -207
- package/dist/core/python/uv-installer.js +0 -270
- package/dist/core/python/uv-resolver.js +0 -83
- package/dist/core/rate-limit/narrator.js +0 -146
- package/dist/core/recipes/cli-types.js +0 -20
- package/dist/core/recipes/loader.js +0 -103
- package/dist/core/recipes/runner.js +0 -345
- package/dist/core/recipes/schema.js +0 -587
- package/dist/core/release-notes/parser.js +0 -241
- package/dist/core/release-notes/state.js +0 -116
- package/dist/core/repl/ask.js +0 -512
- package/dist/core/repl/cancellation.js +0 -98
- package/dist/core/repl/cap-warning.js +0 -91
- package/dist/core/repl/clipboard-read.js +0 -174
- package/dist/core/repl/dispatch-fsm.js +0 -220
- package/dist/core/repl/engine-bridge.js +0 -303
- package/dist/core/repl/history-search.js +0 -175
- package/dist/core/repl/history.js +0 -182
- package/dist/core/repl/kill-ring.js +0 -138
- package/dist/core/repl/model-pricing.js +0 -135
- package/dist/core/repl/privacy-banner.js +0 -71
- package/dist/core/repl/session.js +0 -4962
- package/dist/core/repl/slash-commands.js +0 -747
- package/dist/core/repl/store/index.js +0 -12
- package/dist/core/repl/store/jsonl-log.js +0 -321
- package/dist/core/repl/store/lockfile.js +0 -155
- package/dist/core/repl/store/session-store.js +0 -821
- package/dist/core/repl/store/types.js +0 -44
- package/dist/core/repl/store/uuid-v7.js +0 -68
- package/dist/core/repl/tool-route.js +0 -382
- package/dist/core/repl/workspace-context.js +0 -206
- package/dist/core/repo-map/build.js +0 -125
- package/dist/core/repo-map/cache.js +0 -185
- package/dist/core/repo-map/extractor.js +0 -254
- package/dist/core/repo-map/formatter.js +0 -145
- package/dist/core/repo-map/page-rank.js +0 -105
- package/dist/core/repo-map/scanner.js +0 -211
- package/dist/core/retro/git-collector.js +0 -251
- package/dist/core/retro/health-card.js +0 -25
- package/dist/core/retro/metrics.js +0 -342
- package/dist/core/retro/narrative.js +0 -249
- package/dist/core/retro/plane-collector.js +0 -274
- package/dist/core/retro/pr-issue-link.js +0 -65
- package/dist/core/retro/types.js +0 -16
- package/dist/core/retry-budget/budget.js +0 -284
- package/dist/core/retry-budget/index.js +0 -5
- package/dist/core/retry-budget/retry-cap.js +0 -74
- package/dist/core/routing/lead-worker.js +0 -43
- package/dist/core/routing/pre-flight-estimator.js +0 -108
- package/dist/core/runs/run-tree.js +0 -103
- package/dist/core/sandboxing/adapter.js +0 -29
- package/dist/core/sandboxing/index.js +0 -49
- package/dist/core/sandboxing/none.js +0 -19
- package/dist/core/sandboxing/seatbelt.js +0 -183
- package/dist/core/security/injection-scanner.js +0 -367
- package/dist/core/security/output-filter.js +0 -418
- package/dist/core/session/env-file.js +0 -105
- package/dist/core/session/section-budgets.js +0 -140
- package/dist/core/session.js +0 -377
- package/dist/core/settings.js +0 -400
- package/dist/core/share/formatter.js +0 -271
- package/dist/core/share/redactor.js +0 -221
- package/dist/core/share/uploader.js +0 -267
- package/dist/core/skills/defaults.js +0 -457
- package/dist/core/skills/loader.js +0 -454
- package/dist/core/skills/sources.js +0 -480
- package/dist/core/skills/trust.js +0 -172
- package/dist/core/smoke/headless-driver.js +0 -174
- package/dist/core/smoke/orchestrator.js +0 -194
- package/dist/core/smoke/runner.js +0 -238
- package/dist/core/smoke/scenario-parser.js +0 -316
- package/dist/core/statusline.js +0 -99
- package/dist/core/subagents/dispatcher-real.js +0 -600
- package/dist/core/subagents/dispatcher.js +0 -352
- package/dist/core/subagents/index.js +0 -39
- package/dist/core/subagents/isolation-matrix.js +0 -213
- package/dist/core/subagents/spawn.js +0 -101
- package/dist/core/telemetry/emitter.js +0 -229
- package/dist/core/telemetry/queue.js +0 -251
- package/dist/core/theme/context.js +0 -91
- package/dist/core/theme/presets.js +0 -228
- package/dist/core/theme/state.js +0 -181
- package/dist/core/todos/invariant.js +0 -10
- package/dist/core/todos/state.js +0 -177
- package/dist/core/tool-schema/compressor.js +0 -89
- package/dist/core/transport/version-interceptor.js +0 -166
- package/dist/core/trust.js +0 -109
- package/dist/core/tui/thinking-block.js +0 -64
- package/dist/core/vim/keymap.js +0 -288
- package/dist/core/vim/state.js +0 -92
- package/dist/core/watch-markers/marker-watcher.js +0 -133
- package/dist/core/worktree/include-parser.js +0 -249
- package/dist/core/worktree-manager/cleanup.js +0 -123
- package/dist/core/worktree-manager/manager.js +0 -303
- package/dist/index.js +0 -44
- package/dist/runtime/bootstrap.js +0 -190
- package/dist/runtime/cli.js +0 -8121
- package/dist/runtime/commands/agents.js +0 -385
- package/dist/runtime/commands/budget.js +0 -192
- package/dist/runtime/commands/cancel.js +0 -231
- package/dist/runtime/commands/chain.js +0 -489
- package/dist/runtime/commands/codegraph-status.js +0 -227
- package/dist/runtime/commands/compact.js +0 -297
- package/dist/runtime/commands/config.js +0 -595
- package/dist/runtime/commands/cost.js +0 -199
- package/dist/runtime/commands/delegate.js +0 -312
- package/dist/runtime/commands/dispatch.js +0 -126
- package/dist/runtime/commands/doctor.js +0 -579
- package/dist/runtime/commands/feedback.js +0 -184
- package/dist/runtime/commands/hooks.js +0 -187
- package/dist/runtime/commands/init.js +0 -254
- package/dist/runtime/commands/lsp.js +0 -368
- package/dist/runtime/commands/mcp.js +0 -935
- package/dist/runtime/commands/memory.js +0 -582
- package/dist/runtime/commands/model.js +0 -237
- package/dist/runtime/commands/onboarding.js +0 -275
- package/dist/runtime/commands/patch.js +0 -128
- package/dist/runtime/commands/permissions.js +0 -112
- package/dist/runtime/commands/plan.js +0 -143
- package/dist/runtime/commands/prd-check.js +0 -285
- package/dist/runtime/commands/privacy.js +0 -107
- package/dist/runtime/commands/recipe.js +0 -325
- package/dist/runtime/commands/redo-blob-store.js +0 -92
- package/dist/runtime/commands/redo.js +0 -361
- package/dist/runtime/commands/release-notes.js +0 -229
- package/dist/runtime/commands/repo-map.js +0 -95
- package/dist/runtime/commands/report.js +0 -299
- package/dist/runtime/commands/resume.js +0 -118
- package/dist/runtime/commands/review-consensus.js +0 -414
- package/dist/runtime/commands/rewind.js +0 -333
- package/dist/runtime/commands/roster.js +0 -117
- package/dist/runtime/commands/sessions.js +0 -163
- package/dist/runtime/commands/share.js +0 -316
- package/dist/runtime/commands/skills.js +0 -401
- package/dist/runtime/commands/status.js +0 -186
- package/dist/runtime/commands/stickers.js +0 -82
- package/dist/runtime/commands/style.js +0 -194
- package/dist/runtime/commands/theme.js +0 -196
- package/dist/runtime/commands/undo.js +0 -361
- package/dist/runtime/commands/update.js +0 -289
- package/dist/runtime/commands/vim.js +0 -140
- package/dist/runtime/commands/worktree.js +0 -177
- package/dist/runtime/commands/worktrees.js +0 -155
- package/dist/runtime/deprecation-warning.js +0 -69
- package/dist/runtime/engine-exit-code.js +0 -50
- package/dist/runtime/headless-repl.js +0 -195
- package/dist/runtime/headless.js +0 -548
- package/dist/runtime/load-hooks-or-exit.js +0 -71
- package/dist/runtime/plan-decompose.js +0 -531
- package/dist/runtime/sigint-guard.js +0 -272
- package/dist/runtime/stream-renderer.js +0 -195
- package/dist/runtime/update-check.js +0 -294
- package/dist/runtime/version.js +0 -65
- package/dist/runtime/worktree-bootstrap.js +0 -579
- package/dist/skills/bundled/batch.js +0 -617
- package/dist/skills/bundled/index.js +0 -45
- package/dist/skills/bundled/loop.js +0 -358
- package/dist/skills/bundled/remember.js +0 -383
- package/dist/skills/bundled/simplify.js +0 -289
- package/dist/skills/bundled/skillify.js +0 -373
- package/dist/skills/bundled/stuck.js +0 -558
- package/dist/skills/bundled/verify.js +0 -439
- package/dist/testing/vcr.js +0 -486
- package/dist/tools/agent-tool.js +0 -229
- package/dist/tools/apply-patch.js +0 -556
- package/dist/tools/ask-user-question.js +0 -337
- package/dist/tools/ask-user.js +0 -115
- package/dist/tools/bash.js +0 -1238
- package/dist/tools/brief.js +0 -224
- package/dist/tools/cron.js +0 -433
- package/dist/tools/enter-worktree.js +0 -250
- package/dist/tools/exit-worktree.js +0 -147
- package/dist/tools/file-tools.js +0 -553
- package/dist/tools/http-request.js +0 -336
- package/dist/tools/lsp-tools.js +0 -565
- package/dist/tools/mcp-tool.js +0 -260
- package/dist/tools/multi-edit.js +0 -361
- package/dist/tools/powershell.js +0 -268
- package/dist/tools/registry.js +0 -166
- package/dist/tools/server-tools.js +0 -892
- package/dist/tools/skill-tool.js +0 -96
- package/dist/tools/sleep.js +0 -99
- package/dist/tools/synthetic-output.js +0 -133
- package/dist/tools/tasks.js +0 -208
- package/dist/tools/todo-write.js +0 -184
- package/dist/tools/verify-plan-execution.js +0 -295
- package/dist/tools/web-fetch-injection-scanner.js +0 -207
- package/dist/tools/web-fetch.js +0 -720
- package/dist/tools/web-search.js +0 -458
- package/dist/tui/agent-progress-card.js +0 -111
- package/dist/tui/agent-tree-pane.js +0 -9
- package/dist/tui/agent-tree.js +0 -87
- package/dist/tui/ask-cli.js +0 -52
- package/dist/tui/ask-modal.js +0 -211
- package/dist/tui/ask-user-question-chips.js +0 -315
- package/dist/tui/ask-user-question-prompt.js +0 -203
- package/dist/tui/compact-banner.js +0 -81
- package/dist/tui/conversation-pane.js +0 -164
- package/dist/tui/cost-table.js +0 -111
- package/dist/tui/device-flow.js +0 -142
- package/dist/tui/doctor-table.js +0 -46
- package/dist/tui/feedback-prompt.js +0 -156
- package/dist/tui/input-box.js +0 -732
- package/dist/tui/login-picker.js +0 -69
- package/dist/tui/markdown-render.js +0 -266
- package/dist/tui/multi-file-diff-approval.js +0 -375
- package/dist/tui/onboarding-wizard.js +0 -240
- package/dist/tui/permissions-picker.js +0 -86
- package/dist/tui/render.js +0 -160
- package/dist/tui/repl-render.js +0 -770
- package/dist/tui/repl-splash-art.js +0 -64
- package/dist/tui/repl-splash-mascot.js +0 -154
- package/dist/tui/repl-splash.js +0 -117
- package/dist/tui/repl.js +0 -378
- package/dist/tui/slash-palette.js +0 -106
- package/dist/tui/splash-data.js +0 -61
- package/dist/tui/splash.js +0 -31
- package/dist/tui/status-bar.js +0 -209
- package/dist/tui/status-table.js +0 -7
- package/dist/tui/stickers-art.js +0 -136
- package/dist/tui/style-table.js +0 -28
- package/dist/tui/theme-table.js +0 -29
- package/dist/tui/thinking-spinner.js +0 -123
- package/dist/tui/tool-stream-pane.js +0 -140
- package/dist/tui/update-banner.js +0 -33
- package/dist/tui/vim-input.js +0 -267
- package/dist/tui/welcome-banner.js +0 -107
- package/dist/tui/welcome-data.js +0 -293
- package/dist/tui/workspace-context.js +0 -105
- package/docs/examples/codegraph.mcp.json +0 -10
- package/test/scenarios/codegen-create-file.scenario.txt +0 -13
- package/test/scenarios/compact-force.scenario.txt +0 -12
- package/test/scenarios/identity.scenario.txt +0 -11
- package/test/scenarios/persona-handoff.scenario.txt +0 -12
- package/test/scenarios/walkback.scenario.txt +0 -12
package/dist/commands/smoke.js
DELETED
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* `pugi smoke` — runs the bundled scenario corpus through the headless
|
|
3
|
-
* harness and reports pass/fail per scenario (
|
|
4
|
-
*).
|
|
5
|
-
*
|
|
6
|
-
* The CLI surface lives here rather than in `runtime/cli.ts` so the
|
|
7
|
-
* dispatch surface stays focused on argv routing. This module owns:
|
|
8
|
-
*
|
|
9
|
-
* - Resolving the scenarios directory (default
|
|
10
|
-
* `<cli-root>/test/scenarios/` when bundled, configurable via
|
|
11
|
-
* `--scenarios-dir`).
|
|
12
|
-
* - Selecting the `pugi` binary the headless driver should spawn.
|
|
13
|
-
* Local development: `node <cli-root>/bin/run.js`. CI / published
|
|
14
|
-
* usage: the `pugi` on PATH.
|
|
15
|
-
* - Forwarding the orchestrator output to the unified
|
|
16
|
-
* `writeOutput` writer so `--json` mode works without a second
|
|
17
|
-
* code path.
|
|
18
|
-
*
|
|
19
|
-
* Phase 1 deliberately ships ONE flag (`--filter`) and one option
|
|
20
|
-
* (`--scenarios-dir`); the rest of the surface comes in Phase 2 once
|
|
21
|
-
* the engine path is wired and we know which scenarios actually need
|
|
22
|
-
* per-run plumbing (timeouts, fixture credentials, hermetic stubs).
|
|
23
|
-
*/
|
|
24
|
-
import { existsSync } from 'node:fs';
|
|
25
|
-
import { dirname, resolve } from 'node:path';
|
|
26
|
-
import { fileURLToPath } from 'node:url';
|
|
27
|
-
import { runSmoke, renderReportText, } from '../core/smoke/orchestrator.js';
|
|
28
|
-
import { runHeadlessScenario } from '../core/smoke/headless-driver.js';
|
|
29
|
-
/**
|
|
30
|
-
* Entry point invoked by `runtime/cli.ts::dispatchSmoke`. Returns the
|
|
31
|
-
* desired process exit code so the dispatcher can set
|
|
32
|
-
* `process.exitCode` without a second round-trip.
|
|
33
|
-
*/
|
|
34
|
-
export async function runSmokeCommand(ctx) {
|
|
35
|
-
// Parse the (small) command-local argv. We only honor flags this
|
|
36
|
-
// command actually consumes; unknown args produce a usage error so
|
|
37
|
-
// typos surface immediately.
|
|
38
|
-
let scenariosDirOverride = ctx.scenariosDir ?? undefined;
|
|
39
|
-
let filter = ctx.filter ?? '';
|
|
40
|
-
for (let i = 0; i < ctx.args.length; i += 1) {
|
|
41
|
-
const arg = ctx.args[i] ?? '';
|
|
42
|
-
if (arg === '--filter') {
|
|
43
|
-
const next = ctx.args[i + 1];
|
|
44
|
-
if (!next || next.startsWith('--')) {
|
|
45
|
-
ctx.writeOutput({ ok: false, error: '--filter requires a pattern' }, 'pugi smoke: --filter requires a pattern (substring or *-glob)');
|
|
46
|
-
return 2;
|
|
47
|
-
}
|
|
48
|
-
filter = next;
|
|
49
|
-
i += 1;
|
|
50
|
-
}
|
|
51
|
-
else if (arg.startsWith('--filter=')) {
|
|
52
|
-
filter = arg.slice('--filter='.length);
|
|
53
|
-
}
|
|
54
|
-
else if (arg === '--scenarios-dir') {
|
|
55
|
-
const next = ctx.args[i + 1];
|
|
56
|
-
if (!next || next.startsWith('--')) {
|
|
57
|
-
ctx.writeOutput({ ok: false, error: '--scenarios-dir requires a path' }, 'pugi smoke: --scenarios-dir requires a path');
|
|
58
|
-
return 2;
|
|
59
|
-
}
|
|
60
|
-
scenariosDirOverride = next;
|
|
61
|
-
i += 1;
|
|
62
|
-
}
|
|
63
|
-
else if (arg.startsWith('--scenarios-dir=')) {
|
|
64
|
-
scenariosDirOverride = arg.slice('--scenarios-dir='.length);
|
|
65
|
-
}
|
|
66
|
-
else if (arg === '--help' || arg === '-h') {
|
|
67
|
-
ctx.writeOutput({
|
|
68
|
-
ok: true,
|
|
69
|
-
usage: 'pugi smoke [--filter <pattern>] [--scenarios-dir <path>]',
|
|
70
|
-
}, [
|
|
71
|
-
'pugi smoke — run the bundled scenario corpus headlessly.',
|
|
72
|
-
'',
|
|
73
|
-
'Flags:',
|
|
74
|
-
' --filter <pattern> Run a subset (substring or *-glob match on scenario id).',
|
|
75
|
-
' --scenarios-dir <path> Override the scenarios directory (default: bundled corpus).',
|
|
76
|
-
].join('\n'));
|
|
77
|
-
return 0;
|
|
78
|
-
}
|
|
79
|
-
else {
|
|
80
|
-
ctx.writeOutput({ ok: false, error: `unknown arg: ${arg}` }, `pugi smoke: unknown arg ${arg}`);
|
|
81
|
-
return 2;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
const scenariosDir = scenariosDirOverride ?? resolveBundledScenariosDir();
|
|
85
|
-
if (!existsSync(scenariosDir)) {
|
|
86
|
-
ctx.writeOutput({ ok: false, error: `scenarios dir not found: ${scenariosDir}` }, `pugi smoke: scenarios dir not found: ${scenariosDir}`);
|
|
87
|
-
return 2;
|
|
88
|
-
}
|
|
89
|
-
const pugiBin = ctx.pugiBin ?? process.env.PUGI_SMOKE_BIN ?? 'pugi';
|
|
90
|
-
const log = ctx.log ?? ((line) => process.stderr.write(`${line}\n`));
|
|
91
|
-
const report = await runSmoke({
|
|
92
|
-
scenariosDir,
|
|
93
|
-
filter,
|
|
94
|
-
executor: (scenario) => runHeadlessScenario(scenario, { pugiBin }),
|
|
95
|
-
log,
|
|
96
|
-
});
|
|
97
|
-
if (ctx.json) {
|
|
98
|
-
ctx.writeOutput(report, renderReportText(report));
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
process.stdout.write(`${renderReportText(report)}\n`);
|
|
102
|
-
}
|
|
103
|
-
return report.exitCode;
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Resolve the scenarios directory that ships alongside the CLI.
|
|
107
|
-
*
|
|
108
|
-
* Both the dev source layout (`<cli-root>/src/commands/smoke.ts`) and
|
|
109
|
-
* the built output layout (`<cli-root>/dist/commands/smoke.js`) land
|
|
110
|
-
* on the same `../../test/scenarios` path relative to this file.
|
|
111
|
-
* The bundled `npm i -g @pugi/cli` install replicates that structure
|
|
112
|
-
* by shipping `test/scenarios` (glob `**\/*.scenario.txt`) via the
|
|
113
|
-
* `package.json` `files` field — so the single resolved path works in
|
|
114
|
-
* dev, in `tsx` runs, and in published installs without a config knob.
|
|
115
|
-
*
|
|
116
|
-
* If a future restructure ever bundles scenarios at
|
|
117
|
-
* `<cli-root>/dist/scenarios/` instead, add that to the fallback chain
|
|
118
|
-
* here AND mirror the path in `package.json` `files`. Until then we
|
|
119
|
-
* keep the resolver intentionally one-line.
|
|
120
|
-
*/
|
|
121
|
-
export function resolveBundledScenariosDir() {
|
|
122
|
-
const here = dirname(fileURLToPath(import.meta.url));
|
|
123
|
-
// Works for both src/commands/smoke.ts and dist/commands/smoke.js —
|
|
124
|
-
// both live two directories below the cli root.
|
|
125
|
-
const bundled = resolve(here, '..', '..', 'test', 'scenarios');
|
|
126
|
-
if (existsSync(bundled))
|
|
127
|
-
return bundled;
|
|
128
|
-
// Last resort: return the expected path so the orchestrator surfaces
|
|
129
|
-
// a clean "scenarios dir not found" diagnostic at the call site
|
|
130
|
-
// rather than the resolver swallowing it silently.
|
|
131
|
-
return bundled;
|
|
132
|
-
}
|
|
133
|
-
//# sourceMappingURL=smoke.js.map
|
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agent-progress auto-cleanup — live progress .
|
|
3
|
-
*
|
|
4
|
-
* Rule: a progress file whose status === 'completed' OR 'failed' AND
|
|
5
|
-
* whose `lastUpdate` is older than COMPLETION_TTL_MS (default 5 min)
|
|
6
|
-
* gets MOVED into `<dir>/archive/<id>-<ts>.json` rather than deleted.
|
|
7
|
-
* Operators sometimes want to inspect a finished agent's last state;
|
|
8
|
-
* the archive keeps that affordance while preventing the live watcher
|
|
9
|
-
* from cluttering up with stale rows.
|
|
10
|
-
*
|
|
11
|
-
* The function is pure-ish:
|
|
12
|
-
* - All clock reads go through the injected `now` (defaults Date.now).
|
|
13
|
-
* - Returns a structured report so the caller (the watcher or a CLI
|
|
14
|
-
* cron) can log what got swept.
|
|
15
|
-
* - File-system errors degrade silently — the cleanup is best-effort
|
|
16
|
-
* housekeeping, never a hot path.
|
|
17
|
-
*
|
|
18
|
-
* Hook-in point: `pugi jobs --watch` calls `runCleanup()` once per
|
|
19
|
-
* 60-second tick (cheap — readdir on a small directory). A separate
|
|
20
|
-
* cron entry can call it standalone via the (future) `pugi jobs
|
|
21
|
-
* gc` subcommand if the operator never runs --watch.
|
|
22
|
-
*/
|
|
23
|
-
import { existsSync, mkdirSync, readFileSync, readdirSync, renameSync, } from 'node:fs';
|
|
24
|
-
import { join } from 'node:path';
|
|
25
|
-
import { validateAgentProgress, } from './schema.js';
|
|
26
|
-
import { resolveProgressDir } from './writer.js';
|
|
27
|
-
/** Default time a completed/failed entry sits before getting swept. */
|
|
28
|
-
export const COMPLETION_TTL_MS = 5 * 60 * 1000;
|
|
29
|
-
/** Archive subdirectory under the resolved progress dir. */
|
|
30
|
-
export const ARCHIVE_SUBDIR = 'archive';
|
|
31
|
-
/**
|
|
32
|
-
* Run a single cleanup pass. Returns the report for telemetry / tests.
|
|
33
|
-
*/
|
|
34
|
-
export function runCleanup(options = {}) {
|
|
35
|
-
const dir = resolveProgressDir(options.dir);
|
|
36
|
-
const ttl = options.ttlMs ?? COMPLETION_TTL_MS;
|
|
37
|
-
const now = options.now ?? Date.now;
|
|
38
|
-
const report = { dir, archived: [], skipped: [] };
|
|
39
|
-
if (!existsSync(dir))
|
|
40
|
-
return report;
|
|
41
|
-
const archiveDir = join(dir, ARCHIVE_SUBDIR);
|
|
42
|
-
let entries;
|
|
43
|
-
try {
|
|
44
|
-
entries = readdirSync(dir);
|
|
45
|
-
}
|
|
46
|
-
catch (err) {
|
|
47
|
-
report.skipped.push({ path: dir, reason: `readdir failed: ${err.message}` });
|
|
48
|
-
return report;
|
|
49
|
-
}
|
|
50
|
-
for (const name of entries) {
|
|
51
|
-
if (!name.endsWith('.json'))
|
|
52
|
-
continue;
|
|
53
|
-
if (/\.tmp-/.test(name))
|
|
54
|
-
continue;
|
|
55
|
-
const path = join(dir, name);
|
|
56
|
-
let body;
|
|
57
|
-
try {
|
|
58
|
-
body = readFileSync(path, 'utf8');
|
|
59
|
-
}
|
|
60
|
-
catch {
|
|
61
|
-
report.skipped.push({ path, reason: 'read failed' });
|
|
62
|
-
continue;
|
|
63
|
-
}
|
|
64
|
-
let parsed;
|
|
65
|
-
try {
|
|
66
|
-
parsed = JSON.parse(body);
|
|
67
|
-
}
|
|
68
|
-
catch {
|
|
69
|
-
report.skipped.push({ path, reason: 'malformed JSON' });
|
|
70
|
-
continue;
|
|
71
|
-
}
|
|
72
|
-
const validation = validateAgentProgress(parsed);
|
|
73
|
-
if (!validation.ok) {
|
|
74
|
-
report.skipped.push({ path, reason: `invalid: ${validation.error}` });
|
|
75
|
-
continue;
|
|
76
|
-
}
|
|
77
|
-
const progress = validation.value;
|
|
78
|
-
if (!isExpired(progress, now(), ttl)) {
|
|
79
|
-
continue;
|
|
80
|
-
}
|
|
81
|
-
if (!existsSync(archiveDir)) {
|
|
82
|
-
try {
|
|
83
|
-
mkdirSync(archiveDir, { recursive: true });
|
|
84
|
-
}
|
|
85
|
-
catch (err) {
|
|
86
|
-
report.skipped.push({
|
|
87
|
-
path,
|
|
88
|
-
reason: `archive mkdir failed: ${err.message}`,
|
|
89
|
-
});
|
|
90
|
-
continue;
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
const target = join(archiveDir, `${progress.agentId}-${safeStamp(progress.lastUpdate)}.json`);
|
|
94
|
-
try {
|
|
95
|
-
renameSync(path, target);
|
|
96
|
-
report.archived.push({ agentId: progress.agentId, from: path, to: target });
|
|
97
|
-
}
|
|
98
|
-
catch (err) {
|
|
99
|
-
report.skipped.push({ path, reason: `rename failed: ${err.message}` });
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
return report;
|
|
103
|
-
}
|
|
104
|
-
/**
|
|
105
|
-
* Decide whether a single progress doc has aged out. Exported for the
|
|
106
|
-
* spec — kept pure so tests can probe edges (running entries never
|
|
107
|
-
* expire, completed entries before TTL stay, etc).
|
|
108
|
-
*/
|
|
109
|
-
export function isExpired(progress, nowEpochMs, ttlMs = COMPLETION_TTL_MS) {
|
|
110
|
-
if (progress.status === 'running')
|
|
111
|
-
return false;
|
|
112
|
-
const lastTs = Date.parse(progress.lastUpdate);
|
|
113
|
-
if (Number.isNaN(lastTs))
|
|
114
|
-
return false;
|
|
115
|
-
return nowEpochMs - lastTs >= ttlMs;
|
|
116
|
-
}
|
|
117
|
-
// Claude review followup: `pruneArchive` was removed.
|
|
118
|
-
// Rationale (P1 in the Claude review batch on PR):
|
|
119
|
-
// - hardcoded `/tmp` path was POSIX-only (Windows would break),
|
|
120
|
-
// - `renameSync` across volumes throws EXDEV,
|
|
121
|
-
// - collision risk between concurrent hosts/sessions sharing `/tmp`,
|
|
122
|
-
// - and crucially, the function had ZERO call-sites in the codebase.
|
|
123
|
-
// Deleting it is strictly safer than leaving a broken-on-Windows
|
|
124
|
-
// dead helper that future refactors might accidentally wire up.
|
|
125
|
-
// If/when an archive GC is needed, the right shape is:
|
|
126
|
-
// - `os.tmpdir()` (not '/tmp'),
|
|
127
|
-
// - `rmSync(path, {force: true})` for cross-volume safe delete,
|
|
128
|
-
// - exposed as `pugi jobs gc` so we have an explicit caller.
|
|
129
|
-
function safeStamp(iso) {
|
|
130
|
-
// Build a filename-safe slug — strip colons/dots which are friendly
|
|
131
|
-
// в ISO timestamps but hostile к some filesystems.
|
|
132
|
-
return iso.replace(/[:.]/g, '-');
|
|
133
|
-
}
|
|
134
|
-
//# sourceMappingURL=cleanup.js.map
|
|
@@ -1,144 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agent progress JSON schema — live-progress sprint .
|
|
3
|
-
*
|
|
4
|
-
* Long-running agents (spawned externally OR via `pugi /agent`) emit a
|
|
5
|
-
* single JSON document per agent to `~/.pugi/agent-progress/<id>.json`.
|
|
6
|
-
* `pugi jobs --watch` tails the directory via chokidar and re-renders
|
|
7
|
-
* an Ink TUI that mirrors the the upstream tool `/compact` visual pattern
|
|
8
|
-
* (header with elapsed + token counter, unicode progress bar, milestone
|
|
9
|
-
* list with done/active/pending status icons).
|
|
10
|
-
*
|
|
11
|
-
* Schema is intentionally optimistic — every numeric field is clamped
|
|
12
|
-
* by the writer/reader so a malformed document degrades to a partial
|
|
13
|
-
* card instead of crashing the watcher. The `pendingCount` /
|
|
14
|
-
* `completedCount` fields are pre-computed by the agent for the
|
|
15
|
-
* "… +N pending, M completed" footer; the renderer never re-counts
|
|
16
|
-
* (the agent may have collapsed milestone history to save bytes).
|
|
17
|
-
*/
|
|
18
|
-
/**
|
|
19
|
-
* Validate an unknown payload as an `AgentProgress` document. Returns
|
|
20
|
-
* the typed value on success and a string error otherwise. We deliberately
|
|
21
|
-
* keep this hand-rolled (no zod) — every field is checked exactly once,
|
|
22
|
-
* the error message is human-readable, and zero runtime deps.
|
|
23
|
-
*/
|
|
24
|
-
export function validateAgentProgress(value) {
|
|
25
|
-
if (typeof value !== 'object' || value === null) {
|
|
26
|
-
return { ok: false, error: 'progress payload must be a JSON object' };
|
|
27
|
-
}
|
|
28
|
-
const raw = value;
|
|
29
|
-
const requiredString = (field) => {
|
|
30
|
-
const v = raw[field];
|
|
31
|
-
return typeof v === 'string' && v.length > 0 ? v : null;
|
|
32
|
-
};
|
|
33
|
-
const agentId = requiredString('agentId');
|
|
34
|
-
if (!agentId)
|
|
35
|
-
return { ok: false, error: 'agentId required (non-empty string)' };
|
|
36
|
-
if (!/^[a-zA-Z0-9_-]+$/.test(agentId)) {
|
|
37
|
-
return { ok: false, error: 'agentId must match [a-zA-Z0-9_-]+ (filename-safe)' };
|
|
38
|
-
}
|
|
39
|
-
const agentType = requiredString('agentType');
|
|
40
|
-
if (!agentType)
|
|
41
|
-
return { ok: false, error: 'agentType required (non-empty string)' };
|
|
42
|
-
const task = requiredString('task');
|
|
43
|
-
if (!task)
|
|
44
|
-
return { ok: false, error: 'task required (non-empty string)' };
|
|
45
|
-
const startedAt = requiredString('startedAt');
|
|
46
|
-
if (!startedAt)
|
|
47
|
-
return { ok: false, error: 'startedAt required (ISO string)' };
|
|
48
|
-
if (Number.isNaN(Date.parse(startedAt))) {
|
|
49
|
-
return { ok: false, error: 'startedAt must be a parseable ISO timestamp' };
|
|
50
|
-
}
|
|
51
|
-
const lastUpdate = requiredString('lastUpdate');
|
|
52
|
-
if (!lastUpdate)
|
|
53
|
-
return { ok: false, error: 'lastUpdate required (ISO string)' };
|
|
54
|
-
if (Number.isNaN(Date.parse(lastUpdate))) {
|
|
55
|
-
return { ok: false, error: 'lastUpdate must be a parseable ISO timestamp' };
|
|
56
|
-
}
|
|
57
|
-
const elapsedMs = raw.elapsedMs;
|
|
58
|
-
if (typeof elapsedMs !== 'number' || !Number.isFinite(elapsedMs) || elapsedMs < 0) {
|
|
59
|
-
return { ok: false, error: 'elapsedMs required (non-negative number)' };
|
|
60
|
-
}
|
|
61
|
-
const percentComplete = raw.percentComplete;
|
|
62
|
-
if (typeof percentComplete !== 'number' ||
|
|
63
|
-
!Number.isFinite(percentComplete)) {
|
|
64
|
-
return { ok: false, error: 'percentComplete required (number 0..100)' };
|
|
65
|
-
}
|
|
66
|
-
const clampedPercent = Math.max(0, Math.min(100, percentComplete));
|
|
67
|
-
const status = raw.status;
|
|
68
|
-
if (status !== 'running' && status !== 'completed' && status !== 'failed') {
|
|
69
|
-
return { ok: false, error: 'status must be running | completed | failed' };
|
|
70
|
-
}
|
|
71
|
-
const currentStep = raw.currentStep;
|
|
72
|
-
if (typeof currentStep !== 'number' || currentStep < 0) {
|
|
73
|
-
return { ok: false, error: 'currentStep required (non-negative number)' };
|
|
74
|
-
}
|
|
75
|
-
const totalSteps = raw.totalSteps;
|
|
76
|
-
if (typeof totalSteps !== 'number' || totalSteps < 0) {
|
|
77
|
-
return { ok: false, error: 'totalSteps required (non-negative number)' };
|
|
78
|
-
}
|
|
79
|
-
const stepDescription = typeof raw.stepDescription === 'string'
|
|
80
|
-
? raw.stepDescription
|
|
81
|
-
: '';
|
|
82
|
-
const milestonesRaw = raw.milestones;
|
|
83
|
-
if (!Array.isArray(milestonesRaw)) {
|
|
84
|
-
return { ok: false, error: 'milestones required (array, may be empty)' };
|
|
85
|
-
}
|
|
86
|
-
const milestones = [];
|
|
87
|
-
for (let i = 0; i < milestonesRaw.length; i += 1) {
|
|
88
|
-
const m = milestonesRaw[i];
|
|
89
|
-
if (typeof m !== 'object' || m === null) {
|
|
90
|
-
return { ok: false, error: `milestones[${i}] must be an object` };
|
|
91
|
-
}
|
|
92
|
-
const mr = m;
|
|
93
|
-
const label = typeof mr.label === 'string' ? mr.label : '';
|
|
94
|
-
if (!label) {
|
|
95
|
-
return { ok: false, error: `milestones[${i}].label required` };
|
|
96
|
-
}
|
|
97
|
-
const mStatus = mr.status;
|
|
98
|
-
if (mStatus !== 'done' && mStatus !== 'active' && mStatus !== 'pending') {
|
|
99
|
-
return {
|
|
100
|
-
ok: false,
|
|
101
|
-
error: `milestones[${i}].status must be done | active | pending`,
|
|
102
|
-
};
|
|
103
|
-
}
|
|
104
|
-
const ts = typeof mr.ts === 'string' ? mr.ts : undefined;
|
|
105
|
-
milestones.push({ label, status: mStatus, ts });
|
|
106
|
-
}
|
|
107
|
-
const tokensUsed = typeof raw.tokensUsed === 'number' && Number.isFinite(raw.tokensUsed)
|
|
108
|
-
? Math.max(0, raw.tokensUsed)
|
|
109
|
-
: undefined;
|
|
110
|
-
const pendingCount = typeof raw.pendingCount === 'number' && Number.isFinite(raw.pendingCount)
|
|
111
|
-
? Math.max(0, Math.floor(raw.pendingCount))
|
|
112
|
-
: undefined;
|
|
113
|
-
const completedCount = typeof raw.completedCount === 'number' && Number.isFinite(raw.completedCount)
|
|
114
|
-
? Math.max(0, Math.floor(raw.completedCount))
|
|
115
|
-
: undefined;
|
|
116
|
-
return {
|
|
117
|
-
ok: true,
|
|
118
|
-
value: {
|
|
119
|
-
agentId,
|
|
120
|
-
agentType,
|
|
121
|
-
task,
|
|
122
|
-
startedAt,
|
|
123
|
-
lastUpdate,
|
|
124
|
-
elapsedMs,
|
|
125
|
-
tokensUsed,
|
|
126
|
-
percentComplete: clampedPercent,
|
|
127
|
-
status,
|
|
128
|
-
currentStep,
|
|
129
|
-
totalSteps,
|
|
130
|
-
stepDescription,
|
|
131
|
-
milestones,
|
|
132
|
-
pendingCount,
|
|
133
|
-
completedCount,
|
|
134
|
-
},
|
|
135
|
-
};
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Default directory the writer and watcher share. Lives under the
|
|
139
|
-
* project workspace by convention so worktree-isolated agents can emit
|
|
140
|
-
* progress without crossing tenant boundaries. Operators can override
|
|
141
|
-
* via `PUGI_AGENT_PROGRESS_DIR` env var.
|
|
142
|
-
*/
|
|
143
|
-
export const DEFAULT_AGENT_PROGRESS_DIRNAME = '.pugi/agent-progress';
|
|
144
|
-
//# sourceMappingURL=schema.js.map
|
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agent progress writer — atomic file ops so the chokidar watcher
|
|
3
|
-
* never reads a half-written JSON document.
|
|
4
|
-
*
|
|
5
|
-
* Pattern (POSIX-portable):
|
|
6
|
-
* 1. Build the canonical JSON body.
|
|
7
|
-
* 2. Write to `<dir>/<agentId>.json.tmp-<pid>-<seq>`.
|
|
8
|
-
* 3. Rename (atomic on the same filesystem) to `<dir>/<agentId>.json`.
|
|
9
|
-
* 4. Cleanup is a no-op on success; on failure the caller bubbles the
|
|
10
|
-
* error and the .tmp file is removed best-effort.
|
|
11
|
-
*
|
|
12
|
-
* The auto-cleanup of completed entries lives in `cleanup.ts` (commit 4);
|
|
13
|
-
* the writer here is the minimal surface the agent prompt boilerplate
|
|
14
|
-
* needs to copy + paste.
|
|
15
|
-
*/
|
|
16
|
-
import { existsSync, mkdirSync, renameSync, rmSync, writeFileSync } from 'node:fs';
|
|
17
|
-
import { homedir } from 'node:os';
|
|
18
|
-
import { dirname, join, resolve } from 'node:path';
|
|
19
|
-
import { DEFAULT_AGENT_PROGRESS_DIRNAME, validateAgentProgress, } from './schema.js';
|
|
20
|
-
let writeSequence = 0;
|
|
21
|
-
/**
|
|
22
|
-
* Resolve the effective progress directory. Public so the watcher can
|
|
23
|
-
* share the same resolution rules without duplicating env-var logic.
|
|
24
|
-
*/
|
|
25
|
-
export function resolveProgressDir(override) {
|
|
26
|
-
const candidate = override
|
|
27
|
-
?? process.env.PUGI_AGENT_PROGRESS_DIR
|
|
28
|
-
?? join(process.cwd(), DEFAULT_AGENT_PROGRESS_DIRNAME);
|
|
29
|
-
if (candidate.startsWith('~/')) {
|
|
30
|
-
return join(homedir(), candidate.slice(2));
|
|
31
|
-
}
|
|
32
|
-
return resolve(candidate);
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Write a progress document atomically.
|
|
36
|
-
*
|
|
37
|
-
* Throws on validation failure so the caller is loud about a schema
|
|
38
|
-
* regression. File-system errors propagate untouched.
|
|
39
|
-
*/
|
|
40
|
-
export function writeProgress(progress, options = {}) {
|
|
41
|
-
const validation = validateAgentProgress(progress);
|
|
42
|
-
if (!validation.ok) {
|
|
43
|
-
throw new Error(`invalid agent-progress payload: ${validation.error}`);
|
|
44
|
-
}
|
|
45
|
-
const dir = resolveProgressDir(options.dir);
|
|
46
|
-
if (!existsSync(dir)) {
|
|
47
|
-
mkdirSync(dir, { recursive: true });
|
|
48
|
-
}
|
|
49
|
-
const finalPath = join(dir, `${progress.agentId}.json`);
|
|
50
|
-
writeSequence += 1;
|
|
51
|
-
const tmpPath = `${finalPath}.tmp-${process.pid}-${writeSequence}`;
|
|
52
|
-
const body = `${JSON.stringify(progress, null, 2)}\n`;
|
|
53
|
-
try {
|
|
54
|
-
// mkdirSync above may have created `dir`, but a parallel agent could
|
|
55
|
-
// delete it between the existsSync and writeFile — ensure the parent
|
|
56
|
-
// of the tmp file exists right before the write.
|
|
57
|
-
const parent = dirname(tmpPath);
|
|
58
|
-
if (!existsSync(parent)) {
|
|
59
|
-
mkdirSync(parent, { recursive: true });
|
|
60
|
-
}
|
|
61
|
-
writeFileSync(tmpPath, body, 'utf8');
|
|
62
|
-
renameSync(tmpPath, finalPath);
|
|
63
|
-
}
|
|
64
|
-
catch (err) {
|
|
65
|
-
try {
|
|
66
|
-
rmSync(tmpPath, { force: true });
|
|
67
|
-
}
|
|
68
|
-
catch {
|
|
69
|
-
// best-effort cleanup; surface the original error
|
|
70
|
-
}
|
|
71
|
-
throw err;
|
|
72
|
-
}
|
|
73
|
-
return { path: finalPath };
|
|
74
|
-
}
|
|
75
|
-
/**
|
|
76
|
-
* Build a fresh progress document with sensible defaults. Mostly a
|
|
77
|
-
* convenience for tests + the agent prompt boilerplate — the writer
|
|
78
|
-
* does NOT call this implicitly because agents have richer context
|
|
79
|
-
* about their own milestone state.
|
|
80
|
-
*/
|
|
81
|
-
export function makeInitialProgress(input) {
|
|
82
|
-
const now = input.now ?? Date.now;
|
|
83
|
-
const iso = new Date(now()).toISOString();
|
|
84
|
-
return {
|
|
85
|
-
agentId: input.agentId,
|
|
86
|
-
agentType: input.agentType,
|
|
87
|
-
task: input.task,
|
|
88
|
-
startedAt: iso,
|
|
89
|
-
lastUpdate: iso,
|
|
90
|
-
elapsedMs: 0,
|
|
91
|
-
percentComplete: 0,
|
|
92
|
-
status: 'running',
|
|
93
|
-
currentStep: 0,
|
|
94
|
-
totalSteps: Math.max(0, Math.floor(input.totalSteps)),
|
|
95
|
-
stepDescription: '',
|
|
96
|
-
milestones: input.milestones ?? [],
|
|
97
|
-
pendingCount: input.milestones?.filter((m) => m.status === 'pending').length,
|
|
98
|
-
completedCount: input.milestones?.filter((m) => m.status === 'done').length,
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
//# sourceMappingURL=writer.js.map
|