@ouro.bot/cli 0.1.0-alpha.55 → 0.1.0-alpha.550
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/README.md +133 -19
- package/RepairGuide.ouro/agent.json +5 -0
- package/RepairGuide.ouro/psyche/IDENTITY.md +19 -0
- package/RepairGuide.ouro/psyche/SOUL.md +55 -0
- package/RepairGuide.ouro/skills/diagnose-bootstrap-drift.md +54 -0
- package/RepairGuide.ouro/skills/diagnose-broken-remote.md +63 -0
- package/RepairGuide.ouro/skills/diagnose-stacked-typed-issues.md +35 -0
- package/RepairGuide.ouro/skills/diagnose-sync-blocked.md +54 -0
- package/RepairGuide.ouro/skills/diagnose-vault-expired.md +60 -0
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/agent.json +4 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/SOUL.md +2 -2
- package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-serpent.md +1 -1
- package/changelog.json +3555 -0
- package/dist/arc/attention-types.js +8 -0
- package/dist/arc/cares.js +140 -0
- package/dist/arc/episodes.js +117 -0
- package/dist/arc/intentions.js +133 -0
- package/dist/arc/json-store.js +117 -0
- package/dist/arc/obligations.js +237 -0
- package/dist/arc/packets.js +193 -0
- package/dist/arc/presence.js +185 -0
- package/dist/arc/task-lifecycle.js +65 -0
- package/dist/heart/active-work.js +837 -26
- package/dist/heart/agent-entry.js +58 -3
- package/dist/heart/attachments/image-normalize.js +194 -0
- package/dist/heart/attachments/materialize.js +97 -0
- package/dist/heart/attachments/originals.js +88 -0
- package/dist/heart/attachments/render.js +29 -0
- package/dist/heart/attachments/sources/adapter.js +2 -0
- package/dist/heart/attachments/sources/bluebubbles.js +156 -0
- package/dist/heart/attachments/sources/cli-local-file.js +78 -0
- package/dist/heart/attachments/sources/index.js +16 -0
- package/dist/heart/attachments/store.js +103 -0
- package/dist/heart/attachments/types.js +93 -0
- package/dist/heart/auth/auth-flow.js +479 -0
- package/dist/heart/background-operations.js +281 -0
- package/dist/heart/bundle-state.js +168 -0
- package/dist/heart/commitments.js +111 -0
- package/dist/heart/config-registry.js +304 -0
- package/dist/heart/config.js +114 -118
- package/dist/heart/core.js +925 -246
- package/dist/heart/cross-chat-delivery.js +3 -18
- package/dist/heart/daemon/agent-config-check.js +512 -0
- package/dist/heart/daemon/agent-discovery.js +102 -3
- package/dist/heart/daemon/agent-service.js +522 -0
- package/dist/heart/daemon/agentic-repair.js +554 -0
- package/dist/heart/daemon/bluebubbles-health-diagnostics.js +122 -0
- package/dist/heart/daemon/boot-sync-probe.js +197 -0
- package/dist/heart/daemon/cadence.js +70 -0
- package/dist/heart/daemon/cli-defaults.js +665 -0
- package/dist/heart/daemon/cli-exec.js +7565 -0
- package/dist/heart/daemon/cli-help.js +498 -0
- package/dist/heart/daemon/cli-parse.js +1590 -0
- package/dist/heart/daemon/cli-render-doctor.js +57 -0
- package/dist/heart/daemon/cli-render.js +775 -0
- package/dist/heart/daemon/cli-types.js +8 -0
- package/dist/heart/daemon/connect-bay.js +323 -0
- package/dist/heart/daemon/daemon-cli.js +29 -1672
- package/dist/heart/daemon/daemon-entry.js +417 -2
- package/dist/heart/daemon/daemon-health.js +183 -0
- package/dist/heart/daemon/daemon-rollup.js +58 -0
- package/dist/heart/daemon/daemon-runtime-sync.js +87 -13
- package/dist/heart/daemon/daemon-tombstone.js +236 -0
- package/dist/heart/daemon/daemon.js +758 -71
- package/dist/heart/daemon/dns-workflow.js +394 -0
- package/dist/heart/daemon/doctor-types.js +8 -0
- package/dist/heart/daemon/doctor.js +844 -0
- package/dist/heart/daemon/drift-detection.js +146 -0
- package/dist/heart/daemon/health-monitor.js +122 -1
- package/dist/heart/daemon/hooks/agent-config-v2.js +33 -0
- package/dist/heart/daemon/hooks/bundle-meta.js +115 -1
- package/dist/heart/daemon/http-health-probe.js +80 -0
- package/dist/heart/daemon/human-command-screens.js +234 -0
- package/dist/heart/daemon/human-readiness.js +114 -0
- package/dist/heart/daemon/inner-status.js +102 -0
- package/dist/heart/daemon/interactive-repair.js +394 -0
- package/dist/heart/daemon/launchd.js +37 -8
- package/dist/heart/daemon/log-tailer.js +82 -12
- package/dist/heart/daemon/logs-prune.js +110 -0
- package/dist/heart/daemon/mcp-canary.js +297 -0
- package/dist/heart/daemon/message-router.js +2 -2
- package/dist/heart/daemon/os-cron-deps.js +135 -0
- package/dist/heart/daemon/os-cron.js +14 -12
- package/dist/heart/daemon/ouro-bot-entry.js +4 -2
- package/dist/heart/daemon/ouro-entry.js +3 -1
- package/dist/heart/daemon/process-manager.js +375 -33
- package/dist/heart/daemon/provider-discovery.js +137 -0
- package/dist/heart/daemon/provider-ping-progress.js +83 -0
- package/dist/heart/daemon/pulse.js +475 -0
- package/dist/heart/daemon/readiness-repair.js +365 -0
- package/dist/heart/daemon/run-hooks.js +2 -0
- package/dist/heart/daemon/runtime-logging.js +67 -16
- package/dist/heart/daemon/runtime-metadata.js +3 -31
- package/dist/heart/daemon/safe-mode.js +161 -0
- package/dist/heart/daemon/sense-manager.js +353 -38
- package/dist/heart/daemon/session-id-resolver.js +131 -0
- package/dist/heart/daemon/skill-management-installer.js +94 -0
- package/dist/heart/daemon/socket-client.js +158 -11
- package/dist/heart/daemon/stale-bundle-prune.js +96 -0
- package/dist/heart/daemon/startup-tui.js +330 -0
- package/dist/heart/daemon/task-scheduler.js +3 -25
- package/dist/heart/daemon/terminal-ui.js +499 -0
- package/dist/heart/daemon/thoughts.js +162 -17
- package/dist/heart/daemon/up-progress.js +366 -0
- package/dist/heart/daemon/vault-items.js +56 -0
- package/dist/heart/delegation.js +1 -1
- package/dist/heart/habits/habit-migration.js +189 -0
- package/dist/heart/habits/habit-parser.js +140 -0
- package/dist/heart/habits/habit-runtime-state.js +100 -0
- package/dist/heart/habits/habit-scheduler.js +372 -0
- package/dist/heart/{daemon → hatch}/hatch-flow.js +52 -117
- package/dist/heart/{daemon → hatch}/hatch-specialist.js +6 -8
- package/dist/heart/{daemon → hatch}/specialist-prompt.js +12 -9
- package/dist/heart/{daemon → hatch}/specialist-tools.js +35 -12
- package/dist/heart/identity.js +200 -51
- package/dist/heart/kept-notes.js +357 -0
- package/dist/heart/kicks.js +1 -1
- package/dist/heart/machine-identity.js +161 -0
- package/dist/heart/mail-import-discovery.js +353 -0
- package/dist/heart/mailbox/mailbox-http-hooks.js +66 -0
- package/dist/heart/mailbox/mailbox-http-response.js +7 -0
- package/dist/heart/mailbox/mailbox-http-routes.js +246 -0
- package/dist/heart/mailbox/mailbox-http-static.js +103 -0
- package/dist/heart/mailbox/mailbox-http-transport.js +116 -0
- package/dist/heart/mailbox/mailbox-http.js +99 -0
- package/dist/heart/mailbox/mailbox-read.js +31 -0
- package/dist/heart/mailbox/mailbox-types.js +27 -0
- package/dist/heart/mailbox/mailbox-view.js +195 -0
- package/dist/heart/mailbox/readers/agent-machine.js +382 -0
- package/dist/heart/mailbox/readers/continuity-readers.js +338 -0
- package/dist/heart/mailbox/readers/mail.js +362 -0
- package/dist/heart/mailbox/readers/runtime-readers.js +651 -0
- package/dist/heart/mailbox/readers/sessions.js +232 -0
- package/dist/heart/mailbox/readers/shared.js +111 -0
- package/dist/heart/mcp/mcp-server.js +683 -0
- package/dist/heart/migrate-config.js +100 -0
- package/dist/heart/model-capabilities.js +19 -0
- package/dist/heart/platform.js +81 -0
- package/dist/heart/provider-attempt.js +134 -0
- package/dist/heart/provider-binding-resolver.js +255 -0
- package/dist/heart/provider-credentials.js +425 -0
- package/dist/heart/provider-failover.js +301 -0
- package/dist/heart/provider-models.js +81 -0
- package/dist/heart/provider-ping.js +262 -0
- package/dist/heart/provider-state.js +216 -0
- package/dist/heart/provider-visibility.js +188 -0
- package/dist/heart/providers/anthropic-token.js +131 -0
- package/dist/heart/providers/anthropic.js +139 -52
- package/dist/heart/providers/azure.js +97 -13
- package/dist/heart/providers/error-classification.js +127 -0
- package/dist/heart/providers/github-copilot.js +145 -0
- package/dist/heart/providers/minimax-vlm.js +189 -0
- package/dist/heart/providers/minimax.js +26 -8
- package/dist/heart/providers/openai-codex.js +55 -40
- package/dist/heart/runtime-capability-check.js +170 -0
- package/dist/heart/runtime-credentials.js +367 -0
- package/dist/heart/runtime-cwd.js +87 -0
- package/dist/heart/sense-truth.js +11 -4
- package/dist/heart/session-activity.js +43 -22
- package/dist/heart/session-events.js +1149 -0
- package/dist/heart/session-playback-cli-main.js +5 -0
- package/dist/heart/session-playback-cli.js +36 -0
- package/dist/heart/session-playback.js +231 -0
- package/dist/heart/session-stats-cli-main.js +5 -0
- package/dist/heart/session-stats.js +182 -0
- package/dist/heart/session-transcript.js +243 -0
- package/dist/heart/start-of-turn-packet.js +345 -0
- package/dist/heart/streaming.js +44 -27
- package/dist/heart/sync-classification.js +176 -0
- package/dist/heart/sync.js +449 -0
- package/dist/heart/target-resolution.js +9 -5
- package/dist/heart/tempo.js +93 -0
- package/dist/heart/temporal-view.js +41 -0
- package/dist/heart/timeouts.js +101 -0
- package/dist/heart/tool-activity-callbacks.js +59 -0
- package/dist/heart/tool-description.js +139 -0
- package/dist/heart/tool-friction.js +55 -0
- package/dist/heart/tool-loop.js +200 -0
- package/dist/heart/turn-context.js +381 -0
- package/dist/heart/{daemon → versioning}/ouro-bot-global-installer.js +6 -5
- package/dist/heart/{daemon → versioning}/ouro-bot-wrapper.js +1 -1
- package/dist/heart/versioning/ouro-path-installer.js +426 -0
- package/dist/heart/versioning/ouro-version-manager.js +295 -0
- package/dist/heart/{daemon → versioning}/staged-restart.js +40 -8
- package/dist/heart/{daemon → versioning}/update-checker.js +6 -1
- package/dist/heart/{daemon → versioning}/update-hooks.js +63 -59
- package/dist/mailbox-ui/assets/index-BPr5vNuM.css +1 -0
- package/dist/mailbox-ui/assets/index-Cm51CY9W.js +61 -0
- package/dist/mailbox-ui/index.html +15 -0
- package/dist/mailroom/attention.js +167 -0
- package/dist/mailroom/autonomy.js +209 -0
- package/dist/mailroom/blob-store.js +674 -0
- package/dist/mailroom/body-cache.js +61 -0
- package/dist/mailroom/core.js +720 -0
- package/dist/mailroom/entry.js +160 -0
- package/dist/mailroom/file-store.js +430 -0
- package/dist/mailroom/mbox-import.js +383 -0
- package/dist/mailroom/outbound.js +380 -0
- package/dist/mailroom/policy.js +263 -0
- package/dist/mailroom/reader.js +233 -0
- package/dist/mailroom/search-cache.js +256 -0
- package/dist/mailroom/search-relevance.js +319 -0
- package/dist/mailroom/smtp-ingress.js +176 -0
- package/dist/mailroom/source-state.js +176 -0
- package/dist/mailroom/thread.js +109 -0
- package/dist/mailroom/travel-extract.js +89 -0
- package/dist/mind/bundle-manifest.js +7 -1
- package/dist/mind/context.js +165 -101
- package/dist/mind/diary-integrity.js +60 -0
- package/dist/mind/{memory.js → diary.js} +62 -75
- package/dist/mind/embedding-provider.js +60 -0
- package/dist/mind/file-state.js +179 -0
- package/dist/mind/friends/channel.js +30 -0
- package/dist/mind/friends/resolver.js +54 -2
- package/dist/mind/friends/store-file.js +39 -3
- package/dist/mind/friends/types.js +2 -2
- package/dist/mind/journal-index.js +161 -0
- package/dist/mind/note-search.js +268 -0
- package/dist/mind/obligation-steering.js +221 -0
- package/dist/mind/pending.js +4 -0
- package/dist/mind/prompt-refresh.js +3 -2
- package/dist/mind/prompt.js +995 -123
- package/dist/mind/provenance-trust.js +26 -0
- package/dist/mind/scrutiny.js +173 -0
- package/dist/nerves/cli-logging.js +7 -1
- package/dist/nerves/coverage/audit-rules.js +15 -6
- package/dist/nerves/coverage/audit.js +28 -2
- package/dist/nerves/coverage/cli.js +1 -1
- package/dist/nerves/coverage/contract.js +5 -5
- package/dist/nerves/coverage/file-completeness.js +139 -5
- package/dist/nerves/coverage/run-artifacts.js +1 -1
- package/dist/nerves/event-buffer.js +111 -0
- package/dist/nerves/index.js +224 -4
- package/dist/nerves/observation.js +20 -0
- package/dist/nerves/redact.js +79 -0
- package/dist/nerves/review/cli-main.js +5 -0
- package/dist/nerves/review/cli.js +156 -0
- package/dist/nerves/review/core.js +152 -0
- package/dist/nerves/runtime.js +5 -1
- package/dist/repertoire/ado-client.js +15 -56
- package/dist/repertoire/ado-semantic.js +11 -10
- package/dist/repertoire/api-client.js +97 -0
- package/dist/repertoire/bitwarden-store.js +816 -0
- package/dist/repertoire/bundle-templates.js +72 -0
- package/dist/repertoire/bw-installer.js +180 -0
- package/dist/repertoire/coding/codex-jsonl.js +64 -0
- package/dist/repertoire/coding/context-pack.js +330 -0
- package/dist/repertoire/coding/feedback.js +197 -30
- package/dist/repertoire/coding/manager.js +158 -9
- package/dist/repertoire/coding/spawner.js +55 -9
- package/dist/repertoire/coding/tools.js +170 -7
- package/dist/repertoire/commerce-errors.js +109 -0
- package/dist/repertoire/commerce-self-test.js +156 -0
- package/dist/repertoire/credential-access.js +111 -0
- package/dist/repertoire/duffel-client.js +185 -0
- package/dist/repertoire/github-client.js +14 -55
- package/dist/repertoire/graph-client.js +11 -52
- package/dist/repertoire/guardrails.js +396 -0
- package/dist/repertoire/mcp-client.js +295 -0
- package/dist/repertoire/mcp-manager.js +362 -0
- package/dist/repertoire/mcp-tools.js +63 -0
- package/dist/repertoire/shell-sessions.js +133 -0
- package/dist/repertoire/skills.js +15 -24
- package/dist/repertoire/stripe-client.js +131 -0
- package/dist/repertoire/tasks/board.js +31 -5
- package/dist/repertoire/tasks/fix.js +182 -0
- package/dist/repertoire/tasks/index.js +16 -4
- package/dist/repertoire/tasks/lifecycle.js +2 -2
- package/dist/repertoire/tasks/parser.js +3 -2
- package/dist/repertoire/tasks/scanner.js +194 -37
- package/dist/repertoire/tasks/transitions.js +16 -78
- package/dist/repertoire/tool-results.js +29 -0
- package/dist/repertoire/tools-attachments.js +317 -0
- package/dist/repertoire/tools-base.js +47 -1075
- package/dist/repertoire/tools-bluebubbles.js +1 -0
- package/dist/repertoire/tools-bridge.js +142 -0
- package/dist/repertoire/tools-bundle.js +984 -0
- package/dist/repertoire/tools-config.js +185 -0
- package/dist/repertoire/tools-continuity.js +248 -0
- package/dist/repertoire/tools-credential.js +381 -0
- package/dist/repertoire/tools-files.js +342 -0
- package/dist/repertoire/tools-flight.js +224 -0
- package/dist/repertoire/tools-flow.js +119 -0
- package/dist/repertoire/tools-github.js +1 -7
- package/dist/repertoire/tools-mail.js +1857 -0
- package/dist/repertoire/tools-notes.js +421 -0
- package/dist/repertoire/tools-session.js +750 -0
- package/dist/repertoire/tools-shell.js +120 -0
- package/dist/repertoire/tools-stripe.js +180 -0
- package/dist/repertoire/tools-surface.js +243 -0
- package/dist/repertoire/tools-teams.js +9 -39
- package/dist/repertoire/tools-travel.js +125 -0
- package/dist/repertoire/tools-trip.js +604 -0
- package/dist/repertoire/tools-user-profile.js +144 -0
- package/dist/repertoire/tools-vault.js +40 -0
- package/dist/repertoire/tools.js +108 -100
- package/dist/repertoire/travel-api-client.js +360 -0
- package/dist/repertoire/user-profile.js +131 -0
- package/dist/repertoire/vault-setup.js +246 -0
- package/dist/repertoire/vault-unlock.js +561 -0
- package/dist/scripts/claude-code-hook.js +41 -0
- package/dist/scripts/claude-code-stop-hook.js +47 -0
- package/dist/senses/attention-queue.js +116 -0
- package/dist/senses/bluebubbles/active-turns.js +216 -0
- package/dist/senses/bluebubbles/attachment-cache.js +53 -0
- package/dist/senses/bluebubbles/attachment-download.js +137 -0
- package/dist/senses/{bluebubbles-client.js → bluebubbles/client.js} +219 -18
- package/dist/senses/bluebubbles/entry.js +77 -0
- package/dist/senses/{bluebubbles-inbound-log.js → bluebubbles/inbound-log.js} +20 -3
- package/dist/senses/bluebubbles/index.js +2305 -0
- package/dist/senses/{bluebubbles-media.js → bluebubbles/media.js} +121 -70
- package/dist/senses/{bluebubbles-model.js → bluebubbles/model.js} +33 -12
- package/dist/senses/{bluebubbles-mutation-log.js → bluebubbles/mutation-log.js} +3 -3
- package/dist/senses/bluebubbles/processed-log.js +133 -0
- package/dist/senses/bluebubbles/replay.js +137 -0
- package/dist/senses/{bluebubbles-runtime-state.js → bluebubbles/runtime-state.js} +30 -2
- package/dist/senses/{bluebubbles-session-cleanup.js → bluebubbles/session-cleanup.js} +1 -1
- package/dist/senses/cli/bracketed-paste.js +82 -0
- package/dist/senses/cli/image-paste.js +287 -0
- package/dist/senses/cli/image-ref-navigation.js +75 -0
- package/dist/senses/cli/ink-app.js +156 -0
- package/dist/senses/cli/inline-diff.js +64 -0
- package/dist/senses/cli/input-keys.js +174 -0
- package/dist/senses/cli/kill-ring.js +86 -0
- package/dist/senses/cli/message-list.js +51 -0
- package/dist/senses/cli/ouro-tui.js +607 -0
- package/dist/senses/cli/spinner-imperative.js +135 -0
- package/dist/senses/cli/spinner.js +101 -0
- package/dist/senses/cli/status-line.js +60 -0
- package/dist/senses/cli/streaming-markdown.js +526 -0
- package/dist/senses/cli/tool-display.js +85 -0
- package/dist/senses/cli/tool-render.js +85 -0
- package/dist/senses/cli/tui-store.js +240 -0
- package/dist/senses/cli/virtual-list.js +35 -0
- package/dist/senses/cli-entry.js +60 -8
- package/dist/senses/cli-layout.js +187 -0
- package/dist/senses/cli.js +520 -209
- package/dist/senses/commands.js +66 -3
- package/dist/senses/habit-turn-message.js +108 -0
- package/dist/senses/inner-dialog-worker.js +175 -21
- package/dist/senses/inner-dialog.js +330 -27
- package/dist/senses/mail-entry.js +66 -0
- package/dist/senses/mail.js +379 -0
- package/dist/senses/pipeline.js +569 -182
- package/dist/senses/proactive-content-guard.js +51 -0
- package/dist/senses/shared-turn.js +248 -0
- package/dist/senses/surface-tool.js +68 -0
- package/dist/senses/teams-entry.js +60 -8
- package/dist/senses/teams.js +387 -98
- package/dist/senses/trust-gate.js +100 -5
- package/dist/trips/core.js +138 -0
- package/dist/trips/store.js +146 -0
- package/package.json +38 -7
- package/skills/agent-commerce.md +106 -0
- package/skills/browser-navigation.md +117 -0
- package/skills/commerce-setup-guide.md +116 -0
- package/skills/commerce-setup.md +84 -0
- package/skills/configure-dev-tools.md +101 -0
- package/skills/travel-planning.md +138 -0
- package/dist/heart/daemon/ouro-path-installer.js +0 -178
- package/dist/heart/daemon/subagent-installer.js +0 -166
- package/dist/heart/session-recall.js +0 -116
- package/dist/mind/associative-recall.js +0 -209
- package/dist/senses/bluebubbles-entry.js +0 -13
- package/dist/senses/bluebubbles.js +0 -1177
- package/dist/senses/debug-activity.js +0 -148
- package/subagents/README.md +0 -86
- package/subagents/work-doer.md +0 -237
- package/subagents/work-merger.md +0 -618
- package/subagents/work-planner.md +0 -390
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/basilisk.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jafar.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/jormungandr.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/kaa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/medusa.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/monty.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/nagini.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/ouroboros.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/python.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/quetzalcoatl.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/sir-hiss.md +0 -0
- /package/{AdoptionSpecialist.ouro → SerpentGuide.ouro}/psyche/identities/the-snake.md +0 -0
- /package/dist/heart/{daemon → hatch}/hatch-animation.js +0 -0
- /package/dist/heart/{daemon → hatch}/specialist-orchestrator.js +0 -0
- /package/dist/heart/{daemon → versioning}/ouro-uti.js +0 -0
- /package/dist/heart/{daemon → versioning}/wrapper-publish-guard.js +0 -0
package/dist/senses/commands.js
CHANGED
|
@@ -3,7 +3,11 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createCommandRegistry = createCommandRegistry;
|
|
4
4
|
exports.getToolChoiceRequired = getToolChoiceRequired;
|
|
5
5
|
exports.resetToolChoiceRequired = resetToolChoiceRequired;
|
|
6
|
+
exports.getDebugMode = getDebugMode;
|
|
7
|
+
exports.resetDebugMode = resetDebugMode;
|
|
6
8
|
exports.registerDefaultCommands = registerDefaultCommands;
|
|
9
|
+
exports.getSharedCommandRegistry = getSharedCommandRegistry;
|
|
10
|
+
exports.resetSharedCommandRegistry = resetSharedCommandRegistry;
|
|
7
11
|
exports.parseSlashCommand = parseSlashCommand;
|
|
8
12
|
const identity_1 = require("../heart/identity");
|
|
9
13
|
const runtime_1 = require("../nerves/runtime");
|
|
@@ -21,7 +25,7 @@ function createCommandRegistry() {
|
|
|
21
25
|
},
|
|
22
26
|
dispatch(name, ctx) {
|
|
23
27
|
const cmd = commands.get(name);
|
|
24
|
-
if (!cmd)
|
|
28
|
+
if (!cmd || !cmd.channels.includes(ctx.channel))
|
|
25
29
|
return { handled: false };
|
|
26
30
|
return { handled: true, result: cmd.handler(ctx) };
|
|
27
31
|
},
|
|
@@ -35,6 +39,14 @@ function getToolChoiceRequired() {
|
|
|
35
39
|
function resetToolChoiceRequired() {
|
|
36
40
|
_toolChoiceRequired = false;
|
|
37
41
|
}
|
|
42
|
+
// Module-level toggle for debug mode
|
|
43
|
+
let _debugMode = false;
|
|
44
|
+
function getDebugMode() {
|
|
45
|
+
return _debugMode;
|
|
46
|
+
}
|
|
47
|
+
function resetDebugMode() {
|
|
48
|
+
_debugMode = false;
|
|
49
|
+
}
|
|
38
50
|
function registerDefaultCommands(registry) {
|
|
39
51
|
(0, runtime_1.emitNervesEvent)({
|
|
40
52
|
event: "repertoire.load_start",
|
|
@@ -51,7 +63,7 @@ function registerDefaultCommands(registry) {
|
|
|
51
63
|
registry.register({
|
|
52
64
|
name: "new",
|
|
53
65
|
description: "start a new conversation",
|
|
54
|
-
channels: ["
|
|
66
|
+
channels: ["teams"],
|
|
55
67
|
handler: () => ({ action: "new" }),
|
|
56
68
|
});
|
|
57
69
|
registry.register({
|
|
@@ -60,10 +72,36 @@ function registerDefaultCommands(registry) {
|
|
|
60
72
|
channels: ["cli", "teams"],
|
|
61
73
|
handler: (ctx) => {
|
|
62
74
|
const cmds = registry.list(ctx.channel);
|
|
63
|
-
const lines = cmds.map((c) => `/${c.name}
|
|
75
|
+
const lines = cmds.map((c) => `/${c.name} \u2014 ${c.description}`);
|
|
64
76
|
return { action: "response", message: lines.join("\n") };
|
|
65
77
|
},
|
|
66
78
|
});
|
|
79
|
+
registry.register({
|
|
80
|
+
name: "help",
|
|
81
|
+
description: "show keyboard shortcuts and tips",
|
|
82
|
+
channels: ["cli"],
|
|
83
|
+
/* v8 ignore start -- integration: /help command tested via E2E @preserve */
|
|
84
|
+
handler: () => ({
|
|
85
|
+
action: "response",
|
|
86
|
+
message: [
|
|
87
|
+
"Keyboard shortcuts:",
|
|
88
|
+
" Ctrl-C abort current generation / clear input / exit (twice within 2s)",
|
|
89
|
+
" Escape clear input",
|
|
90
|
+
" ↑ / ↓ browse input history (includes previous sessions)",
|
|
91
|
+
" Option+← / → jump between words",
|
|
92
|
+
" Ctrl+A / E jump to start / end of line",
|
|
93
|
+
" Option+Delete delete word backward",
|
|
94
|
+
" Option+D delete word forward",
|
|
95
|
+
" Alt+Enter insert newline (multi-line input)",
|
|
96
|
+
"",
|
|
97
|
+
"Commands:",
|
|
98
|
+
" /help this help",
|
|
99
|
+
" /commands list all commands",
|
|
100
|
+
" /exit quit",
|
|
101
|
+
].join("\n"),
|
|
102
|
+
}),
|
|
103
|
+
/* v8 ignore stop */
|
|
104
|
+
});
|
|
67
105
|
registry.register({
|
|
68
106
|
name: "tool-required",
|
|
69
107
|
description: "toggle tool_choice required mode (forces tool calls)",
|
|
@@ -73,6 +111,20 @@ function registerDefaultCommands(registry) {
|
|
|
73
111
|
return { action: "response", message: `tool-required mode: ${_toolChoiceRequired ? "ON" : "OFF"}` };
|
|
74
112
|
},
|
|
75
113
|
});
|
|
114
|
+
registry.register({
|
|
115
|
+
name: "debug",
|
|
116
|
+
description: "toggle debug mode — see more detail about what I'm doing",
|
|
117
|
+
channels: ["cli", "teams", "bluebubbles", "mail", "mcp"],
|
|
118
|
+
handler: () => {
|
|
119
|
+
_debugMode = !_debugMode;
|
|
120
|
+
return {
|
|
121
|
+
action: "response",
|
|
122
|
+
message: _debugMode
|
|
123
|
+
? "debug mode on — you'll see more detail about what I'm doing"
|
|
124
|
+
: "debug mode off — back to clean output",
|
|
125
|
+
};
|
|
126
|
+
},
|
|
127
|
+
});
|
|
76
128
|
(0, runtime_1.emitNervesEvent)({
|
|
77
129
|
event: "repertoire.load_end",
|
|
78
130
|
component: "repertoire",
|
|
@@ -80,6 +132,17 @@ function registerDefaultCommands(registry) {
|
|
|
80
132
|
meta: {},
|
|
81
133
|
});
|
|
82
134
|
}
|
|
135
|
+
let _sharedRegistry = null;
|
|
136
|
+
function getSharedCommandRegistry() {
|
|
137
|
+
if (!_sharedRegistry) {
|
|
138
|
+
_sharedRegistry = createCommandRegistry();
|
|
139
|
+
registerDefaultCommands(_sharedRegistry);
|
|
140
|
+
}
|
|
141
|
+
return _sharedRegistry;
|
|
142
|
+
}
|
|
143
|
+
function resetSharedCommandRegistry() {
|
|
144
|
+
_sharedRegistry = null;
|
|
145
|
+
}
|
|
83
146
|
function parseSlashCommand(input) {
|
|
84
147
|
const trimmed = input.trim();
|
|
85
148
|
if (!trimmed.startsWith("/"))
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildHabitTurnMessage = buildHabitTurnMessage;
|
|
4
|
+
const runtime_1 = require("../nerves/runtime");
|
|
5
|
+
function formatElapsed(ms) {
|
|
6
|
+
const minutes = Math.floor(ms / 60000);
|
|
7
|
+
if (minutes < 60) {
|
|
8
|
+
return `${minutes} ${minutes === 1 ? "minute" : "minutes"}`;
|
|
9
|
+
}
|
|
10
|
+
const hours = Math.floor(minutes / 60);
|
|
11
|
+
return `${hours} ${hours === 1 ? "hour" : "hours"}`;
|
|
12
|
+
}
|
|
13
|
+
function buildHabitTurnMessage(options) {
|
|
14
|
+
const { habitName, habitTitle, habitBody, lastRun, checkpoint, alsoDue, staleObligations, parseErrors, degradedComponents, now, } = options;
|
|
15
|
+
const hasBody = habitBody !== undefined && habitBody !== "";
|
|
16
|
+
// First beat: lastRun is null
|
|
17
|
+
if (lastRun === null) {
|
|
18
|
+
// Cold start: no checkpoint, no body — bare awareness
|
|
19
|
+
if (!checkpoint && !hasBody) {
|
|
20
|
+
(0, runtime_1.emitNervesEvent)({
|
|
21
|
+
component: "senses",
|
|
22
|
+
event: "senses.habit_turn_message_built",
|
|
23
|
+
message: "habit turn message built (cold start)",
|
|
24
|
+
meta: { habitName, coldStart: true },
|
|
25
|
+
});
|
|
26
|
+
return "...time passing. anything stirring?";
|
|
27
|
+
}
|
|
28
|
+
if (!hasBody) {
|
|
29
|
+
// First beat with no body: nudge
|
|
30
|
+
const sections = [
|
|
31
|
+
`your ${habitTitle} fired but has no instructions \u2014 add a body to \`habits/${habitName}.md\``,
|
|
32
|
+
];
|
|
33
|
+
appendTrailingExtras(sections, alsoDue, staleObligations, parseErrors, degradedComponents);
|
|
34
|
+
(0, runtime_1.emitNervesEvent)({
|
|
35
|
+
component: "senses",
|
|
36
|
+
event: "senses.habit_turn_message_built",
|
|
37
|
+
message: "habit turn message built (first beat, no body)",
|
|
38
|
+
meta: { habitName, firstBeat: true, hasBody: false },
|
|
39
|
+
});
|
|
40
|
+
return sections.join("\n\n");
|
|
41
|
+
}
|
|
42
|
+
const sections = [
|
|
43
|
+
`your ${habitTitle} is alive. this is its first breath.`,
|
|
44
|
+
habitBody,
|
|
45
|
+
];
|
|
46
|
+
appendTrailingExtras(sections, alsoDue, staleObligations, parseErrors, degradedComponents);
|
|
47
|
+
(0, runtime_1.emitNervesEvent)({
|
|
48
|
+
component: "senses",
|
|
49
|
+
event: "senses.habit_turn_message_built",
|
|
50
|
+
message: "habit turn message built (first beat)",
|
|
51
|
+
meta: { habitName, firstBeat: true },
|
|
52
|
+
});
|
|
53
|
+
return sections.join("\n\n");
|
|
54
|
+
}
|
|
55
|
+
// Normal turn
|
|
56
|
+
const sections = [];
|
|
57
|
+
// 1. Checkpoint
|
|
58
|
+
if (checkpoint) {
|
|
59
|
+
sections.push(`you were thinking about ${checkpoint}.`);
|
|
60
|
+
}
|
|
61
|
+
// 2. Elapsed time
|
|
62
|
+
const nowMs = now().getTime();
|
|
63
|
+
const lastRunMs = new Date(lastRun).getTime();
|
|
64
|
+
const elapsed = nowMs - lastRunMs;
|
|
65
|
+
sections.push(`${formatElapsed(elapsed)} have passed.`);
|
|
66
|
+
// 3. Body or no-body nudge
|
|
67
|
+
if (hasBody) {
|
|
68
|
+
sections.push(habitBody);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
sections.push(`your ${habitTitle} fired but has no instructions \u2014 add a body to \`habits/${habitName}.md\``);
|
|
72
|
+
}
|
|
73
|
+
// 4-7. Trailing extras
|
|
74
|
+
appendTrailingExtras(sections, alsoDue, staleObligations, parseErrors, degradedComponents);
|
|
75
|
+
(0, runtime_1.emitNervesEvent)({
|
|
76
|
+
component: "senses",
|
|
77
|
+
event: "senses.habit_turn_message_built",
|
|
78
|
+
message: "habit turn message built",
|
|
79
|
+
meta: {
|
|
80
|
+
habitName,
|
|
81
|
+
hasCheckpoint: !!checkpoint,
|
|
82
|
+
hasBody: hasBody,
|
|
83
|
+
staleObligationCount: staleObligations.length,
|
|
84
|
+
},
|
|
85
|
+
});
|
|
86
|
+
return sections.join("\n\n");
|
|
87
|
+
}
|
|
88
|
+
function appendTrailingExtras(sections, alsoDue, staleObligations, parseErrors, degradedComponents) {
|
|
89
|
+
// 4. Also-due
|
|
90
|
+
if (alsoDue) {
|
|
91
|
+
sections.push(alsoDue);
|
|
92
|
+
}
|
|
93
|
+
// 5. Stale obligations
|
|
94
|
+
if (staleObligations.length > 0) {
|
|
95
|
+
const lines = staleObligations.map((o) => `[internal] obligation: ${o.friendName} — waiting ${formatElapsed(o.stalenessMs)}`);
|
|
96
|
+
sections.push(lines.join("\n"));
|
|
97
|
+
}
|
|
98
|
+
// 6. Parse errors
|
|
99
|
+
if (parseErrors.length > 0) {
|
|
100
|
+
const lines = parseErrors.map((e) => `I noticed my habit file \`${e.file}\` has invalid frontmatter \u2014 I should fix it. (${e.error})`);
|
|
101
|
+
sections.push(lines.join("\n"));
|
|
102
|
+
}
|
|
103
|
+
// 7. Degraded state
|
|
104
|
+
if (degradedComponents.length > 0) {
|
|
105
|
+
const reasons = degradedComponents.map((d) => `${d.component}: ${d.reason}`).join("; ");
|
|
106
|
+
sections.push(`[note: my scheduling is degraded: ${reasons}]`);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
@@ -1,33 +1,138 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
2
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.HABIT_RECURSION_BURST_THRESHOLD = exports.HABIT_RECURSION_BURST_WINDOW_MS = exports.HABIT_RECURSION_MIN_INTERVAL_MS = exports.MAX_CONSECUTIVE_INSTINCT_TURNS = void 0;
|
|
3
37
|
exports.createInnerDialogWorker = createInnerDialogWorker;
|
|
4
38
|
exports.startInnerDialogWorker = startInnerDialogWorker;
|
|
39
|
+
const path = __importStar(require("path"));
|
|
5
40
|
const inner_dialog_1 = require("./inner-dialog");
|
|
6
41
|
const runtime_1 = require("../nerves/runtime");
|
|
7
42
|
const identity_1 = require("../heart/identity");
|
|
8
43
|
const pending_1 = require("../mind/pending");
|
|
9
|
-
|
|
44
|
+
const habit_runtime_state_1 = require("../heart/habits/habit-runtime-state");
|
|
45
|
+
/**
|
|
46
|
+
* Cap on consecutive `instinct` follow-on turns triggered by `hasPendingWork()`
|
|
47
|
+
* with no externally-queued work in between. Without this cap, a turn that
|
|
48
|
+
* writes anything back into the inner-dialog pending dir as a side effect of
|
|
49
|
+
* processing (e.g. a surface tool routing a response) puts the worker into
|
|
50
|
+
* a self-sustaining loop where the next turn's drain produces another write,
|
|
51
|
+
* and so on. Real workflows rarely chain more than 2–3 instinct turns; an
|
|
52
|
+
* external trigger (habit, poke, chat) resets the counter so legitimate
|
|
53
|
+
* follow-on work is unaffected.
|
|
54
|
+
*
|
|
55
|
+
* Three feels right: legitimate cascading follow-ups (e.g. processing a
|
|
56
|
+
* batch of delegated returns) get through; a true self-loop caps fast.
|
|
57
|
+
*/
|
|
58
|
+
exports.MAX_CONSECUTIVE_INSTINCT_TURNS = 3;
|
|
59
|
+
/**
|
|
60
|
+
* Habit recursion detector thresholds. The instinct cap above protects
|
|
61
|
+
* against pending-dir self-loops; this protects against the *external*
|
|
62
|
+
* IPC self-loop where heartbeat-shaped messages get re-issued faster
|
|
63
|
+
* than their cadence — e.g. a hook misconfigured to repost on every
|
|
64
|
+
* heartbeat, a daemon retry storm, or a stuck timer firing back-to-back.
|
|
65
|
+
*
|
|
66
|
+
* MIN_INTERVAL_MS — two of the same habit within this window is suspect
|
|
67
|
+
* regardless of cadence (no realistic habit fires every few seconds).
|
|
68
|
+
* BURST_THRESHOLD over BURST_WINDOW_MS catches slower runaways that stay
|
|
69
|
+
* just under MIN_INTERVAL_MS.
|
|
70
|
+
*
|
|
71
|
+
* Detection is observation-only: it emits warn-level nerves events, it
|
|
72
|
+
* does not drop the message. An operator (or follow-up auto-recovery)
|
|
73
|
+
* decides what to do with the signal.
|
|
74
|
+
*/
|
|
75
|
+
exports.HABIT_RECURSION_MIN_INTERVAL_MS = 5_000;
|
|
76
|
+
exports.HABIT_RECURSION_BURST_WINDOW_MS = 60_000;
|
|
77
|
+
exports.HABIT_RECURSION_BURST_THRESHOLD = 5;
|
|
78
|
+
function createInnerDialogWorker(runTurn = (options) => (0, inner_dialog_1.runInnerDialogTurn)(options), hasPendingWork = () => (0, pending_1.hasPendingMessages)((0, pending_1.getInnerDialogPendingDir)((0, identity_1.getAgentName)())), nowSource = () => Date.now()) {
|
|
10
79
|
let running = false;
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
80
|
+
const queue = [];
|
|
81
|
+
const lastFireByHabit = new Map();
|
|
82
|
+
const recentHabitFires = [];
|
|
83
|
+
function recordHabitFireForRecursion(habitName) {
|
|
84
|
+
const now = nowSource();
|
|
85
|
+
const previous = lastFireByHabit.get(habitName);
|
|
86
|
+
if (previous !== undefined) {
|
|
87
|
+
const intervalMs = now - previous;
|
|
88
|
+
if (intervalMs < exports.HABIT_RECURSION_MIN_INTERVAL_MS) {
|
|
89
|
+
(0, runtime_1.emitNervesEvent)({
|
|
90
|
+
level: "warn",
|
|
91
|
+
component: "senses",
|
|
92
|
+
event: "senses.habit_recursion_suspected",
|
|
93
|
+
message: "habit fired suspiciously fast after the previous fire — possible self-recursion or duplicate dispatch",
|
|
94
|
+
meta: {
|
|
95
|
+
habitName,
|
|
96
|
+
intervalMs,
|
|
97
|
+
thresholdMs: exports.HABIT_RECURSION_MIN_INTERVAL_MS,
|
|
98
|
+
},
|
|
99
|
+
});
|
|
20
100
|
}
|
|
101
|
+
}
|
|
102
|
+
lastFireByHabit.set(habitName, now);
|
|
103
|
+
recentHabitFires.push(now);
|
|
104
|
+
while (recentHabitFires.length > 0 && now - recentHabitFires[0] > exports.HABIT_RECURSION_BURST_WINDOW_MS) {
|
|
105
|
+
recentHabitFires.shift();
|
|
106
|
+
}
|
|
107
|
+
if (recentHabitFires.length >= exports.HABIT_RECURSION_BURST_THRESHOLD) {
|
|
108
|
+
(0, runtime_1.emitNervesEvent)({
|
|
109
|
+
level: "warn",
|
|
110
|
+
component: "senses",
|
|
111
|
+
event: "senses.habit_recursion_burst",
|
|
112
|
+
message: "habit messages arriving in a burst — possible runaway loop",
|
|
113
|
+
meta: {
|
|
114
|
+
count: recentHabitFires.length,
|
|
115
|
+
windowMs: exports.HABIT_RECURSION_BURST_WINDOW_MS,
|
|
116
|
+
thresholdCount: exports.HABIT_RECURSION_BURST_THRESHOLD,
|
|
117
|
+
lastHabitName: habitName,
|
|
118
|
+
},
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
async function run(reason, taskId, habitName) {
|
|
123
|
+
if (running) {
|
|
124
|
+
queue.push({ reason, taskId, habitName });
|
|
21
125
|
return;
|
|
22
126
|
}
|
|
23
127
|
running = true;
|
|
24
128
|
try {
|
|
25
129
|
let nextReason = reason;
|
|
26
130
|
let nextTaskId = taskId;
|
|
131
|
+
let nextHabitName = habitName;
|
|
132
|
+
let consecutiveInstinctTurns = reason === "instinct" ? 1 : 0;
|
|
27
133
|
do {
|
|
28
|
-
rerunRequested = false;
|
|
29
134
|
try {
|
|
30
|
-
await runTurn({ reason: nextReason, taskId: nextTaskId });
|
|
135
|
+
await runTurn({ reason: nextReason, taskId: nextTaskId, habitName: nextHabitName });
|
|
31
136
|
}
|
|
32
137
|
catch (error) {
|
|
33
138
|
(0, runtime_1.emitNervesEvent)({
|
|
@@ -41,15 +146,55 @@ function createInnerDialogWorker(runTurn = (options) => (0, inner_dialog_1.runIn
|
|
|
41
146
|
},
|
|
42
147
|
});
|
|
43
148
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
149
|
+
// Record lastRun after a habit turn without dirtying the tracked habit file.
|
|
150
|
+
if (nextReason === "habit" && nextHabitName) {
|
|
151
|
+
try {
|
|
152
|
+
const agentRoot = (0, identity_1.getAgentRoot)();
|
|
153
|
+
(0, habit_runtime_state_1.recordHabitRun)(agentRoot, nextHabitName, new Date().toISOString(), {
|
|
154
|
+
definitionPath: path.join(agentRoot, "habits", `${nextHabitName}.md`),
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
catch {
|
|
158
|
+
// Habit file/state may be unavailable during the turn — skip gracefully
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
// Drain queue first. Externally-queued work resets the instinct cap
|
|
162
|
+
// because a real outside trigger arrived between turns.
|
|
163
|
+
if (queue.length > 0) {
|
|
164
|
+
const next = queue.shift();
|
|
165
|
+
nextReason = next.reason;
|
|
166
|
+
nextTaskId = next.taskId;
|
|
167
|
+
nextHabitName = next.habitName;
|
|
168
|
+
consecutiveInstinctTurns = nextReason === "instinct" ? consecutiveInstinctTurns + 1 : 0;
|
|
169
|
+
continue;
|
|
170
|
+
}
|
|
171
|
+
// Then check hasPendingWork fallback. This is the loop site: any
|
|
172
|
+
// tool that writes to the inner-dialog pending dir during a turn
|
|
173
|
+
// would cause hasPendingWork() to be true here, producing a
|
|
174
|
+
// self-sustaining "instinct" loop with no external input. Cap it.
|
|
175
|
+
if (hasPendingWork()) {
|
|
176
|
+
if (consecutiveInstinctTurns >= exports.MAX_CONSECUTIVE_INSTINCT_TURNS) {
|
|
177
|
+
(0, runtime_1.emitNervesEvent)({
|
|
178
|
+
level: "warn",
|
|
179
|
+
component: "senses",
|
|
180
|
+
event: "senses.inner_dialog_worker_instinct_loop_capped",
|
|
181
|
+
message: "inner dialog worker stopped chaining instinct turns; pending work remains for next external trigger",
|
|
182
|
+
meta: {
|
|
183
|
+
consecutiveInstinctTurns,
|
|
184
|
+
cap: exports.MAX_CONSECUTIVE_INSTINCT_TURNS,
|
|
185
|
+
lastReason: nextReason,
|
|
186
|
+
},
|
|
187
|
+
});
|
|
188
|
+
break;
|
|
189
|
+
}
|
|
190
|
+
consecutiveInstinctTurns += 1;
|
|
191
|
+
nextReason = "instinct";
|
|
192
|
+
nextTaskId = undefined;
|
|
193
|
+
nextHabitName = undefined;
|
|
194
|
+
continue;
|
|
47
195
|
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
rerunReason = "instinct";
|
|
51
|
-
rerunTaskId = undefined;
|
|
52
|
-
} while (rerunRequested);
|
|
196
|
+
break;
|
|
197
|
+
} while (true);
|
|
53
198
|
}
|
|
54
199
|
finally {
|
|
55
200
|
running = false;
|
|
@@ -59,8 +204,17 @@ function createInnerDialogWorker(runTurn = (options) => (0, inner_dialog_1.runIn
|
|
|
59
204
|
if (!message || typeof message !== "object")
|
|
60
205
|
return;
|
|
61
206
|
const maybeMessage = message;
|
|
207
|
+
if (maybeMessage.type === "habit") {
|
|
208
|
+
/* v8 ignore next -- defensive fallback: live habit dispatch always sets habitName @preserve */
|
|
209
|
+
const habitName = maybeMessage.habitName ?? "(unnamed)";
|
|
210
|
+
recordHabitFireForRecursion(habitName);
|
|
211
|
+
await run("habit", undefined, maybeMessage.habitName);
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
62
214
|
if (maybeMessage.type === "heartbeat") {
|
|
63
|
-
|
|
215
|
+
// Backward compatibility: heartbeat -> habit/heartbeat
|
|
216
|
+
recordHabitFireForRecursion("heartbeat");
|
|
217
|
+
await run("habit", undefined, "heartbeat");
|
|
64
218
|
return;
|
|
65
219
|
}
|
|
66
220
|
if (maybeMessage.type === "poke") {
|