@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
|
@@ -1,233 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Consensus rubric — `pugi review --consensus` .
|
|
3
|
-
*
|
|
4
|
-
* Three independent reviewers (Codex / Claude / DeepSeek) produce findings
|
|
5
|
-
* tagged `[P0]` / `[P1]` / `[P2]` / `[P3]`. The rubric translates the per-
|
|
6
|
-
* reviewer severity vector into one of `PASS` / `WARN` / `BLOCK`.
|
|
7
|
-
*
|
|
8
|
-
* Rubric (verbatim from /triple-review skill + admin-api OES MCP triple_review):
|
|
9
|
-
*
|
|
10
|
-
* any reviewer reports [P0] -> BLOCK
|
|
11
|
-
* two or more reviewers report [P1] -> BLOCK (consensus)
|
|
12
|
-
* exactly one reviewer reports [P1] -> WARN (asymmetric)
|
|
13
|
-
* no reviewer reports [P0] or [P1] -> PASS (P2/P3 only)
|
|
14
|
-
* every reviewer errored -> BLOCK (no signal)
|
|
15
|
-
*
|
|
16
|
-
* The rubric never reads model text beyond the severity markers; the
|
|
17
|
-
* reviewer-side narrative is shown to the operator unchanged. Keeping the
|
|
18
|
-
* verdict deterministic + LLM-free is the entire point of the gate (CEO
|
|
19
|
-
* directive): a model that disagrees with the rubric can be
|
|
20
|
-
* audited, a model that produces the verdict cannot.
|
|
21
|
-
*/
|
|
22
|
-
/**
|
|
23
|
-
* Regex matches the `[P0]` / `[P1]` / `[P2]` / `[P3]` token at the start
|
|
24
|
-
* of a line OR inline. Accepts surrounding whitespace and lowercase form.
|
|
25
|
-
* The line-anchored `m` flag scans every line; `g` allows `matchAll`.
|
|
26
|
-
*
|
|
27
|
-
* The capture group on the digit lets `parseFindings` reconstruct the
|
|
28
|
-
* severity without a second regex. Square brackets are escaped because
|
|
29
|
-
* the JS regex engine treats `[` as a character class otherwise.
|
|
30
|
-
*/
|
|
31
|
-
const SEVERITY_TOKEN = /\[\s*[Pp]([0-3])\s*\]/g;
|
|
32
|
-
/**
|
|
33
|
-
* Parse a raw reviewer text blob into structured findings.
|
|
34
|
-
*
|
|
35
|
-
* Heuristics (intentionally permissive — different models format very
|
|
36
|
-
* differently and a strict parser would drop signal):
|
|
37
|
-
*
|
|
38
|
-
* 1. Split the text on `[Px]` tokens, preserving the marker.
|
|
39
|
-
* 2. Each marker starts a new finding. The summary is the rest of the
|
|
40
|
-
* same line (and the next line if the first is `:` or empty after
|
|
41
|
-
* stripping whitespace).
|
|
42
|
-
* 3. Empty / whitespace-only summaries are dropped — a bare `[P1]`
|
|
43
|
-
* with no context cannot be acted on, and treating it as a finding
|
|
44
|
-
* would falsely trigger consensus.
|
|
45
|
-
*/
|
|
46
|
-
export function parseFindings(raw) {
|
|
47
|
-
if (typeof raw !== 'string' || raw.length === 0)
|
|
48
|
-
return [];
|
|
49
|
-
const findings = [];
|
|
50
|
-
// Track marker positions so we can slice the summary up to the next
|
|
51
|
-
// marker without quadratic re-scans.
|
|
52
|
-
const markers = [];
|
|
53
|
-
// Reset lastIndex defensively — `matchAll` allocates its own iterator,
|
|
54
|
-
// but belt-and-braces against a future caller passing a stateful regex.
|
|
55
|
-
SEVERITY_TOKEN.lastIndex = 0;
|
|
56
|
-
for (const match of raw.matchAll(SEVERITY_TOKEN)) {
|
|
57
|
-
const digit = match[1] ?? '';
|
|
58
|
-
const severity = `P${digit}`;
|
|
59
|
-
markers.push({ severity, index: match.index ?? 0, matchLength: match[0].length });
|
|
60
|
-
}
|
|
61
|
-
for (let i = 0; i < markers.length; i += 1) {
|
|
62
|
-
const marker = markers[i];
|
|
63
|
-
const start = marker.index + marker.matchLength;
|
|
64
|
-
const end = i + 1 < markers.length ? markers[i + 1].index : raw.length;
|
|
65
|
-
const slice = raw.slice(start, end);
|
|
66
|
-
const summary = extractSummary(slice);
|
|
67
|
-
if (summary.length === 0)
|
|
68
|
-
continue;
|
|
69
|
-
findings.push({ severity: marker.severity, summary });
|
|
70
|
-
}
|
|
71
|
-
return findings;
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Extract a single-line summary from the text following a severity
|
|
75
|
-
* marker. Trims leading colon / dash / whitespace; truncates at the
|
|
76
|
-
* first newline so multi-paragraph findings render as one line in the
|
|
77
|
-
* REPL transcript (the full reviewer text stays available in `rawContent`).
|
|
78
|
-
*/
|
|
79
|
-
function extractSummary(slice) {
|
|
80
|
-
let cursor = 0;
|
|
81
|
-
while (cursor < slice.length && /[\s:\-—–]/.test(slice[cursor]))
|
|
82
|
-
cursor += 1;
|
|
83
|
-
const tail = slice.slice(cursor);
|
|
84
|
-
const newlineIdx = tail.search(/\r?\n/);
|
|
85
|
-
const oneLine = newlineIdx === -1 ? tail : tail.slice(0, newlineIdx);
|
|
86
|
-
return oneLine.trim();
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Compute the highest BLOCKING severity from a finding list. Returns
|
|
90
|
-
* `null` when the reviewer is clean for gating purposes, i.e. either:
|
|
91
|
-
* - no findings at all, OR
|
|
92
|
-
* - only P2 / P3 findings (informational, non-blocking by rubric).
|
|
93
|
-
*
|
|
94
|
-
* `null` is the right contract for downstream tooling that gates on
|
|
95
|
-
* "did this reviewer flag anything that should block ship?" - the
|
|
96
|
-
* rubric in `aggregate` already treats P2/P3 as non-blocking, so an
|
|
97
|
-
* external `topSeverity === null` check matches the gate's semantics
|
|
98
|
-
* exactly without re-parsing the finding list.
|
|
99
|
-
*
|
|
100
|
-
* Per-finding severity is still preserved in `findings[].severity`
|
|
101
|
-
* for callers that want to surface P2/P3 counts in their UX.
|
|
102
|
-
*
|
|
103
|
-
* Returns the priority floor for blocking findings only: P0 > P1.
|
|
104
|
-
*/
|
|
105
|
-
export function topSeverityOf(findings) {
|
|
106
|
-
let best = null;
|
|
107
|
-
for (const finding of findings) {
|
|
108
|
-
if (finding.severity === 'P0')
|
|
109
|
-
return 'P0';
|
|
110
|
-
if (finding.severity === 'P1')
|
|
111
|
-
best = 'P1';
|
|
112
|
-
// P2 / P3 are non-blocking by rubric -> they do NOT contribute to
|
|
113
|
-
// topSeverity. They remain visible via `findings[].severity` for
|
|
114
|
-
// operators who want to see the full breakdown.
|
|
115
|
-
}
|
|
116
|
-
return best;
|
|
117
|
-
}
|
|
118
|
-
/**
|
|
119
|
-
* Convenience: parse a raw reviewer text blob into a `ReviewerVerdict`.
|
|
120
|
-
* `errored` defaults to false; callers that detected a transport-level
|
|
121
|
-
* failure should set it true and pass an empty raw string.
|
|
122
|
-
*/
|
|
123
|
-
export function reviewerVerdictFromRaw(reviewer, raw, errored = false) {
|
|
124
|
-
if (errored) {
|
|
125
|
-
return { reviewer, topSeverity: null, findings: [], errored: true };
|
|
126
|
-
}
|
|
127
|
-
const findings = parseFindings(raw);
|
|
128
|
-
return {
|
|
129
|
-
reviewer,
|
|
130
|
-
topSeverity: topSeverityOf(findings),
|
|
131
|
-
findings,
|
|
132
|
-
errored: false,
|
|
133
|
-
};
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* Apply the rubric to 1..N reviewer verdicts. The shape is N-aware so the
|
|
137
|
-
* same function handles the dev `/triple-review` 3-reviewer case AND a
|
|
138
|
-
* customer running with 2 reviewers (e.g. a tier that does not yet include
|
|
139
|
-
* DeepSeek).
|
|
140
|
-
*/
|
|
141
|
-
export function aggregate(verdicts) {
|
|
142
|
-
const totalReviewers = verdicts.length;
|
|
143
|
-
const erroredReviewers = verdicts.filter((v) => v.errored).length;
|
|
144
|
-
// Zero reviewers = zero signal. Falling through to the no-P0/no-P1
|
|
145
|
-
// branch would emit a false PASS — exactly the regression flagged by
|
|
146
|
-
// Codex during PR review. Treat empty input as BLOCK so the gate
|
|
147
|
-
// fails closed when the backend returns no events at all (5xx that
|
|
148
|
-
// somehow drained the SSE, server-side bug, dispatcher misconfig).
|
|
149
|
-
if (totalReviewers === 0) {
|
|
150
|
-
return {
|
|
151
|
-
verdict: 'BLOCK',
|
|
152
|
-
p0Count: 0,
|
|
153
|
-
p1Count: 0,
|
|
154
|
-
p1Reviewers: 0,
|
|
155
|
-
reasoning: 'No reviewer signal: backend returned 0 events. Fail-closed BLOCK.',
|
|
156
|
-
};
|
|
157
|
-
}
|
|
158
|
-
if (totalReviewers > 0 && erroredReviewers === totalReviewers) {
|
|
159
|
-
return {
|
|
160
|
-
verdict: 'BLOCK',
|
|
161
|
-
p0Count: 0,
|
|
162
|
-
p1Count: 0,
|
|
163
|
-
p1Reviewers: 0,
|
|
164
|
-
reasoning: 'Every reviewer errored: no signal. Treating as BLOCK until at least one reviewer returns.',
|
|
165
|
-
};
|
|
166
|
-
}
|
|
167
|
-
let p0Count = 0;
|
|
168
|
-
let p1Count = 0;
|
|
169
|
-
let p1Reviewers = 0;
|
|
170
|
-
for (const verdict of verdicts) {
|
|
171
|
-
if (verdict.errored)
|
|
172
|
-
continue;
|
|
173
|
-
const p0 = verdict.findings.filter((f) => f.severity === 'P0').length;
|
|
174
|
-
const p1 = verdict.findings.filter((f) => f.severity === 'P1').length;
|
|
175
|
-
p0Count += p0;
|
|
176
|
-
p1Count += p1;
|
|
177
|
-
if (p1 > 0)
|
|
178
|
-
p1Reviewers += 1;
|
|
179
|
-
}
|
|
180
|
-
if (p0Count > 0) {
|
|
181
|
-
return {
|
|
182
|
-
verdict: 'BLOCK',
|
|
183
|
-
p0Count,
|
|
184
|
-
p1Count,
|
|
185
|
-
p1Reviewers,
|
|
186
|
-
reasoning: `${p0Count}x P0 finding${p0Count === 1 ? '' : 's'}: BLOCK (any P0 fails the gate).`,
|
|
187
|
-
};
|
|
188
|
-
}
|
|
189
|
-
if (p1Reviewers >= 2) {
|
|
190
|
-
return {
|
|
191
|
-
verdict: 'BLOCK',
|
|
192
|
-
p0Count,
|
|
193
|
-
p1Count,
|
|
194
|
-
p1Reviewers,
|
|
195
|
-
reasoning: `${p1Reviewers} reviewers each reported P1: consensus = likely real bug, BLOCK.`,
|
|
196
|
-
};
|
|
197
|
-
}
|
|
198
|
-
if (p1Reviewers === 1) {
|
|
199
|
-
return {
|
|
200
|
-
verdict: 'WARN',
|
|
201
|
-
p0Count,
|
|
202
|
-
p1Count,
|
|
203
|
-
p1Reviewers,
|
|
204
|
-
reasoning: 'One reviewer reported P1: asymmetric signal, examine the disagreement before merging.',
|
|
205
|
-
};
|
|
206
|
-
}
|
|
207
|
-
return {
|
|
208
|
-
verdict: 'PASS',
|
|
209
|
-
p0Count,
|
|
210
|
-
p1Count,
|
|
211
|
-
p1Reviewers,
|
|
212
|
-
reasoning: 'No P0 or P1 findings: PASS. P2/P3 findings are non-blocking.',
|
|
213
|
-
};
|
|
214
|
-
}
|
|
215
|
-
/**
|
|
216
|
-
* Map a rubric verdict to the conventional exit code Pugi CLI uses for
|
|
217
|
-
* gates (spec ):
|
|
218
|
-
*
|
|
219
|
-
* PASS -> 0
|
|
220
|
-
* WARN -> 1
|
|
221
|
-
* BLOCK -> 2
|
|
222
|
-
*
|
|
223
|
-
* The non-zero codes are distinct so a shell script can branch on the
|
|
224
|
-
* exact outcome without re-parsing stdout.
|
|
225
|
-
*/
|
|
226
|
-
export function exitCodeFor(verdict) {
|
|
227
|
-
if (verdict === 'PASS')
|
|
228
|
-
return 0;
|
|
229
|
-
if (verdict === 'WARN')
|
|
230
|
-
return 1;
|
|
231
|
-
return 2;
|
|
232
|
-
}
|
|
233
|
-
//# sourceMappingURL=rubric.js.map
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Context builder — separates static and dynamic blocks so the model's
|
|
3
|
-
* prompt cache stays warm across turns.
|
|
4
|
-
*
|
|
5
|
-
* Per `docs/research/pugi-cli-corpus/patterns/context-compaction.md` §6,
|
|
6
|
-
* static and dynamic context live in different sections:
|
|
7
|
-
*
|
|
8
|
-
* STATIC DYNAMIC
|
|
9
|
-
* - system instructions - transcript turns (recent)
|
|
10
|
-
* - tool schemas (sorted) - session memory ref
|
|
11
|
-
* - safety rules - open task graph snapshot
|
|
12
|
-
* - PUGI.md + AGENTS.md
|
|
13
|
-
*
|
|
14
|
-
* Static blocks hash deterministically; identical session starts emit
|
|
15
|
-
* identical static prefixes, hitting the model provider's prompt cache.
|
|
16
|
-
* Dynamic blocks rebuild every turn — compaction touches dynamic only.
|
|
17
|
-
*
|
|
18
|
-
* This module is pure: no fs, no network. Markdown loading happens in
|
|
19
|
-
* `markdown-loader.ts` and is passed in. Hash inputs are sorted to keep
|
|
20
|
-
* the static hash stable under map-iteration-order changes.
|
|
21
|
-
*/
|
|
22
|
-
import { createHash } from 'node:crypto';
|
|
23
|
-
/**
|
|
24
|
-
* Build a `BuiltContext` from input. Pure function: same input always
|
|
25
|
-
* produces byte-identical static blocks (and therefore byte-identical
|
|
26
|
-
* static hashes). Dynamic blocks are returned as-is in transcript order;
|
|
27
|
-
* compaction reshuffles dynamic only.
|
|
28
|
-
*
|
|
29
|
-
* Marked async to match the codebase convention even though the body is
|
|
30
|
-
* fully sync. Callers chain `await buildContext(...)` so a future move
|
|
31
|
-
* to async markdown reloading or RAG injection does not break callers.
|
|
32
|
-
*/
|
|
33
|
-
export async function buildContext(input) {
|
|
34
|
-
const blocks = [];
|
|
35
|
-
// 1. Tools first — alphabetically sorted by name, per pattern card §6.
|
|
36
|
-
const sortedTools = [...input.tools].sort((a, b) => a.name.localeCompare(b.name));
|
|
37
|
-
const toolBundle = sortedTools.map((t) => `${t.name}:${t.schema}`).join('\n');
|
|
38
|
-
blocks.push({
|
|
39
|
-
kind: 'tool_schema',
|
|
40
|
-
name: 'tools',
|
|
41
|
-
content: toolBundle,
|
|
42
|
-
bytes: Buffer.byteLength(toolBundle, 'utf8'),
|
|
43
|
-
});
|
|
44
|
-
// 2. Instructions — single deterministic block.
|
|
45
|
-
const instructionsContent = normalizeNewlines(input.instructions);
|
|
46
|
-
blocks.push({
|
|
47
|
-
kind: 'instructions',
|
|
48
|
-
name: 'instructions',
|
|
49
|
-
content: instructionsContent,
|
|
50
|
-
bytes: Buffer.byteLength(instructionsContent, 'utf8'),
|
|
51
|
-
});
|
|
52
|
-
// 3. Safety rules — optional, hashed into the instructions block via
|
|
53
|
-
// concatenation when present so consumers can read both as one.
|
|
54
|
-
if (input.safetyRules) {
|
|
55
|
-
const safety = normalizeNewlines(input.safetyRules);
|
|
56
|
-
blocks.push({
|
|
57
|
-
kind: 'safety_rules',
|
|
58
|
-
name: 'safety',
|
|
59
|
-
content: safety,
|
|
60
|
-
bytes: Buffer.byteLength(safety, 'utf8'),
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
// 4. PUGI.md / AGENTS.md — loaded markdown in workspace-root order.
|
|
64
|
-
for (const md of input.markdown) {
|
|
65
|
-
blocks.push({
|
|
66
|
-
kind: md.source === 'PUGI.md' ? 'pugi_md' : 'agents_md',
|
|
67
|
-
name: md.source,
|
|
68
|
-
content: md.content,
|
|
69
|
-
bytes: Buffer.byteLength(md.content, 'utf8'),
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
const staticBytes = blocks.reduce((sum, b) => sum + b.bytes, 0);
|
|
73
|
-
const instructionsBlock = blocks.find((b) => b.kind === 'instructions');
|
|
74
|
-
const toolBlock = blocks.find((b) => b.kind === 'tool_schema');
|
|
75
|
-
const mdBlocks = blocks.filter((b) => b.kind === 'pugi_md' || b.kind === 'agents_md');
|
|
76
|
-
const instructionsHash = sha256(instructionsBlock?.content ?? '');
|
|
77
|
-
const toolSchemaHash = sha256(toolBundle);
|
|
78
|
-
const pugiMdHash = mdBlocks.length > 0 ? sha256(mdBlocks.map((b) => b.content).join('\n---\n')) : undefined;
|
|
79
|
-
const dynamicBytes = input.transcript.reduce((sum, t) => sum + Buffer.byteLength(t.content, 'utf8'), 0) +
|
|
80
|
-
(input.sessionMemory?.bytes ?? 0) +
|
|
81
|
-
estimateTaskGraphBytes(input.openTaskGraph);
|
|
82
|
-
const totalBytes = staticBytes + dynamicBytes;
|
|
83
|
-
return {
|
|
84
|
-
static: {
|
|
85
|
-
instructionsHash,
|
|
86
|
-
toolSchemaHash,
|
|
87
|
-
pugiMdHash,
|
|
88
|
-
blocks,
|
|
89
|
-
bytes: staticBytes,
|
|
90
|
-
},
|
|
91
|
-
dynamic: {
|
|
92
|
-
transcriptTurns: input.transcript,
|
|
93
|
-
sessionMemory: input.sessionMemory,
|
|
94
|
-
openTaskGraph: input.openTaskGraph,
|
|
95
|
-
bytes: dynamicBytes,
|
|
96
|
-
},
|
|
97
|
-
totalBytes,
|
|
98
|
-
estimatedTokens: Math.ceil(totalBytes / 4),
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
function sha256(input) {
|
|
102
|
-
return createHash('sha256').update(input, 'utf8').digest('hex');
|
|
103
|
-
}
|
|
104
|
-
function normalizeNewlines(input) {
|
|
105
|
-
// CRLF normalization plus trailing-newline strip so identical source
|
|
106
|
-
// emitted by different OS shells hashes identically.
|
|
107
|
-
return input.replace(/\r\n/g, '\n').replace(/\n+$/, '');
|
|
108
|
-
}
|
|
109
|
-
function estimateTaskGraphBytes(graph) {
|
|
110
|
-
if (!graph)
|
|
111
|
-
return 0;
|
|
112
|
-
return Buffer.byteLength(JSON.stringify(graph), 'utf8');
|
|
113
|
-
}
|
|
114
|
-
//# sourceMappingURL=builder.js.map
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Compaction event emitter — appends `compaction.*` events to the
|
|
3
|
-
* session's events.jsonl using the shared AuditEvent discriminated union
|
|
4
|
-
* in `@pugi/sdk/audit-trace.ts`.
|
|
5
|
-
*
|
|
6
|
-
* Until PR these events were written with the ad-hoc shape
|
|
7
|
-
* `{ id, ts, sessionId, ... }` and the comment in this header claimed
|
|
8
|
-
* "we keep `session.ts` untouched and write our events through a
|
|
9
|
-
* dedicated helper that bypasses the AuditEvent schema". The downside,
|
|
10
|
-
* caught by Claude review on PR, is that every consumer that
|
|
11
|
-
* calls `auditEventSchema.parse(line)` (cabinet UI, replay tooling,
|
|
12
|
-
* `core/index-store.ts`) would throw on every compaction event, and
|
|
13
|
-
* `safeParse` consumers would silently drop them.
|
|
14
|
-
*
|
|
15
|
-
* Fix: extend the discriminated union with four compaction event
|
|
16
|
-
* shapes and emit using the `timestamp` (full word) field name to
|
|
17
|
-
* match every other event already in the schema. The events now
|
|
18
|
-
* round-trip through `auditEventSchema.parse` without loss.
|
|
19
|
-
*
|
|
20
|
-
* Events emitted:
|
|
21
|
-
*
|
|
22
|
-
* compaction.started { sessionId, tier, trigger }
|
|
23
|
-
* compaction.completed { sessionId, tier, bytesReclaimed,
|
|
24
|
-
* newContextSize, artifactsCreated }
|
|
25
|
-
* compaction.skipped { sessionId, tier, reason }
|
|
26
|
-
* compaction.invariant_violated { sessionId, invariant, evidence,
|
|
27
|
-
* artifactRef? }
|
|
28
|
-
*
|
|
29
|
-
* All four are appended in mode 0o600 and respect the
|
|
30
|
-
* `session.enabled` flag (no-op when `.pugi/` is absent).
|
|
31
|
-
*/
|
|
32
|
-
import { appendFileSync } from 'node:fs';
|
|
33
|
-
import { randomUUID } from 'node:crypto';
|
|
34
|
-
export function emitCompactionStarted(session, tier, trigger) {
|
|
35
|
-
if (!session.enabled)
|
|
36
|
-
return;
|
|
37
|
-
appendCompactionEvent(session, {
|
|
38
|
-
type: 'compaction.started',
|
|
39
|
-
id: randomUUID(),
|
|
40
|
-
timestamp: nowIso(),
|
|
41
|
-
sessionId: session.id,
|
|
42
|
-
tier,
|
|
43
|
-
trigger,
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
export function emitCompactionCompleted(session, tier, bytesReclaimed, newContextSize, artifactsCreated) {
|
|
47
|
-
if (!session.enabled)
|
|
48
|
-
return;
|
|
49
|
-
appendCompactionEvent(session, {
|
|
50
|
-
type: 'compaction.completed',
|
|
51
|
-
id: randomUUID(),
|
|
52
|
-
timestamp: nowIso(),
|
|
53
|
-
sessionId: session.id,
|
|
54
|
-
tier,
|
|
55
|
-
bytesReclaimed,
|
|
56
|
-
newContextSize,
|
|
57
|
-
artifactsCreated: artifactsCreated.map((a) => ({
|
|
58
|
-
sha256: a.sha256,
|
|
59
|
-
size: a.size,
|
|
60
|
-
producedBy: a.producedBy,
|
|
61
|
-
})),
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
export function emitCompactionSkipped(session, tier, reason) {
|
|
65
|
-
if (!session.enabled)
|
|
66
|
-
return;
|
|
67
|
-
appendCompactionEvent(session, {
|
|
68
|
-
type: 'compaction.skipped',
|
|
69
|
-
id: randomUUID(),
|
|
70
|
-
timestamp: nowIso(),
|
|
71
|
-
sessionId: session.id,
|
|
72
|
-
tier,
|
|
73
|
-
reason,
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
export function emitCompactionInvariantViolated(session, violation) {
|
|
77
|
-
if (!session.enabled)
|
|
78
|
-
return;
|
|
79
|
-
const event = {
|
|
80
|
-
type: 'compaction.invariant_violated',
|
|
81
|
-
id: randomUUID(),
|
|
82
|
-
timestamp: nowIso(),
|
|
83
|
-
sessionId: session.id,
|
|
84
|
-
invariant: violation.invariant,
|
|
85
|
-
evidence: violation.evidence,
|
|
86
|
-
...(violation.artifactRef !== undefined ? { artifactRef: violation.artifactRef } : {}),
|
|
87
|
-
};
|
|
88
|
-
appendCompactionEvent(session, event);
|
|
89
|
-
}
|
|
90
|
-
function appendCompactionEvent(session, event) {
|
|
91
|
-
appendFileSync(session.eventsPath, `${JSON.stringify(event)}\n`, {
|
|
92
|
-
encoding: 'utf8',
|
|
93
|
-
mode: 0o600,
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
function nowIso() {
|
|
97
|
-
return new Date().toISOString();
|
|
98
|
-
}
|
|
99
|
-
//# sourceMappingURL=compaction-events.js.map
|