nodmix 2026.5.25
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/CHANGELOG.md +11573 -0
- package/LICENSE +21 -0
- package/README.md +486 -0
- package/docs/.i18n/README.md +81 -0
- package/docs/.i18n/ar-navigation.json +18 -0
- package/docs/.i18n/de-navigation.json +18 -0
- package/docs/.i18n/es-navigation.json +18 -0
- package/docs/.i18n/fr-navigation.json +18 -0
- package/docs/.i18n/glossary.ar.json +78 -0
- package/docs/.i18n/glossary.de.json +78 -0
- package/docs/.i18n/glossary.es.json +78 -0
- package/docs/.i18n/glossary.fa.json +78 -0
- package/docs/.i18n/glossary.fr.json +78 -0
- package/docs/.i18n/glossary.id.json +78 -0
- package/docs/.i18n/glossary.it.json +78 -0
- package/docs/.i18n/glossary.ja-JP.json +98 -0
- package/docs/.i18n/glossary.ko.json +78 -0
- package/docs/.i18n/glossary.nl.json +78 -0
- package/docs/.i18n/glossary.pl.json +78 -0
- package/docs/.i18n/glossary.pt-BR.json +78 -0
- package/docs/.i18n/glossary.th.json +78 -0
- package/docs/.i18n/glossary.tr.json +78 -0
- package/docs/.i18n/glossary.uk.json +78 -0
- package/docs/.i18n/glossary.vi.json +78 -0
- package/docs/.i18n/glossary.zh-CN.json +1002 -0
- package/docs/.i18n/glossary.zh-TW.json +78 -0
- package/docs/.i18n/id-navigation.json +18 -0
- package/docs/.i18n/it-navigation.json +18 -0
- package/docs/.i18n/ja-navigation.json +18 -0
- package/docs/.i18n/ko-navigation.json +18 -0
- package/docs/.i18n/pl-navigation.json +18 -0
- package/docs/.i18n/pt-BR-navigation.json +18 -0
- package/docs/.i18n/tr-navigation.json +18 -0
- package/docs/.i18n/translation-workflow.md +111 -0
- package/docs/.i18n/zh-Hans-navigation.json +542 -0
- package/docs/AGENTS.md +36 -0
- package/docs/announcements/bluebubbles-imessage.md +79 -0
- package/docs/assets/install-script.svg +1 -0
- package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
- package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
- package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
- package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
- package/docs/assets/macos-onboarding/05-permissions.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.svg +418 -0
- package/docs/assets/openclaw-logo-text.png +0 -0
- package/docs/assets/openclaw-logo-text.svg +418 -0
- package/docs/assets/pixel-lobster.svg +60 -0
- package/docs/assets/pr/quick-settings-browser-tools.png +0 -0
- package/docs/assets/showcase/agents-ui.jpg +0 -0
- package/docs/assets/showcase/bambu-cli.png +0 -0
- package/docs/assets/showcase/codexmonitor.png +0 -0
- package/docs/assets/showcase/gohome-grafana.png +0 -0
- package/docs/assets/showcase/ios-testflight.jpg +0 -0
- package/docs/assets/showcase/oura-health.png +0 -0
- package/docs/assets/showcase/padel-cli.svg +11 -0
- package/docs/assets/showcase/padel-screenshot.jpg +0 -0
- package/docs/assets/showcase/papla-tts.jpg +0 -0
- package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
- package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
- package/docs/assets/showcase/roborock-status.svg +13 -0
- package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
- package/docs/assets/showcase/snag.png +0 -0
- package/docs/assets/showcase/tesco-shop.jpg +0 -0
- package/docs/assets/showcase/wienerlinien.png +0 -0
- package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
- package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
- package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
- package/docs/assets/sponsors/blacksmith-light.svg +14 -0
- package/docs/assets/sponsors/blacksmith.svg +14 -0
- package/docs/assets/sponsors/convex-light.svg +16 -0
- package/docs/assets/sponsors/convex.svg +16 -0
- package/docs/assets/sponsors/github-light.svg +3 -0
- package/docs/assets/sponsors/github.svg +3 -0
- package/docs/assets/sponsors/nvidia-dark.svg +9 -0
- package/docs/assets/sponsors/nvidia.svg +9 -0
- package/docs/assets/sponsors/openai-light.svg +3 -0
- package/docs/assets/sponsors/openai.svg +3 -0
- package/docs/assets/sponsors/vercel-light.svg +5 -0
- package/docs/assets/sponsors/vercel.svg +5 -0
- package/docs/auth-credential-semantics.md +124 -0
- package/docs/automation/auth-monitoring.md +11 -0
- package/docs/automation/clawflow.md +12 -0
- package/docs/automation/cron-jobs.md +500 -0
- package/docs/automation/cron-vs-heartbeat.md +11 -0
- package/docs/automation/gmail-pubsub.md +11 -0
- package/docs/automation/hooks.md +365 -0
- package/docs/automation/index.md +135 -0
- package/docs/automation/poll.md +12 -0
- package/docs/automation/standing-orders.md +250 -0
- package/docs/automation/taskflow.md +155 -0
- package/docs/automation/tasks.md +374 -0
- package/docs/automation/troubleshooting.md +12 -0
- package/docs/automation/webhook.md +12 -0
- package/docs/brave-search.md +11 -0
- package/docs/channels/access-groups.md +201 -0
- package/docs/channels/ambient-room-events.md +214 -0
- package/docs/channels/bot-loop-protection.md +131 -0
- package/docs/channels/broadcast-groups.md +472 -0
- package/docs/channels/channel-routing.md +162 -0
- package/docs/channels/clickclack.md +138 -0
- package/docs/channels/discord.md +1762 -0
- package/docs/channels/feishu.md +502 -0
- package/docs/channels/googlechat.md +284 -0
- package/docs/channels/group-messages.md +95 -0
- package/docs/channels/groups.md +519 -0
- package/docs/channels/imessage-from-bluebubbles.md +259 -0
- package/docs/channels/imessage.md +813 -0
- package/docs/channels/index.md +64 -0
- package/docs/channels/irc.md +253 -0
- package/docs/channels/line.md +243 -0
- package/docs/channels/location.md +71 -0
- package/docs/channels/matrix-migration.md +370 -0
- package/docs/channels/matrix-presentation.md +77 -0
- package/docs/channels/matrix-push-rules.md +150 -0
- package/docs/channels/matrix.md +921 -0
- package/docs/channels/mattermost.md +542 -0
- package/docs/channels/msteams.md +1042 -0
- package/docs/channels/nextcloud-talk.md +176 -0
- package/docs/channels/nostr.md +253 -0
- package/docs/channels/pairing.md +214 -0
- package/docs/channels/qqbot.md +309 -0
- package/docs/channels/signal.md +400 -0
- package/docs/channels/slack.md +1564 -0
- package/docs/channels/synology-chat.md +187 -0
- package/docs/channels/telegram.md +1107 -0
- package/docs/channels/tlon.md +296 -0
- package/docs/channels/troubleshooting.md +161 -0
- package/docs/channels/twitch.md +431 -0
- package/docs/channels/wechat.md +171 -0
- package/docs/channels/whatsapp.md +739 -0
- package/docs/channels/yuanbao.md +416 -0
- package/docs/channels/zalo.md +253 -0
- package/docs/channels/zalouser.md +199 -0
- package/docs/ci.md +612 -0
- package/docs/clawhub/publishing.md +96 -0
- package/docs/cli/acp.md +370 -0
- package/docs/cli/agent.md +103 -0
- package/docs/cli/agents.md +232 -0
- package/docs/cli/approvals.md +190 -0
- package/docs/cli/backup.md +97 -0
- package/docs/cli/browser.md +307 -0
- package/docs/cli/channels.md +154 -0
- package/docs/cli/clawbot.md +25 -0
- package/docs/cli/commitments.md +90 -0
- package/docs/cli/completion.md +39 -0
- package/docs/cli/config.md +504 -0
- package/docs/cli/configure.md +77 -0
- package/docs/cli/crestodian.md +332 -0
- package/docs/cli/cron.md +281 -0
- package/docs/cli/daemon.md +67 -0
- package/docs/cli/dashboard.md +33 -0
- package/docs/cli/devices.md +204 -0
- package/docs/cli/directory.md +68 -0
- package/docs/cli/dns.md +53 -0
- package/docs/cli/docs.md +73 -0
- package/docs/cli/doctor.md +237 -0
- package/docs/cli/flows.md +52 -0
- package/docs/cli/gateway.md +567 -0
- package/docs/cli/health.md +43 -0
- package/docs/cli/hooks.md +345 -0
- package/docs/cli/index.md +396 -0
- package/docs/cli/infer.md +364 -0
- package/docs/cli/logs.md +65 -0
- package/docs/cli/mcp.md +529 -0
- package/docs/cli/memory.md +183 -0
- package/docs/cli/message.md +317 -0
- package/docs/cli/migrate.md +290 -0
- package/docs/cli/models.md +224 -0
- package/docs/cli/node.md +177 -0
- package/docs/cli/nodes.md +76 -0
- package/docs/cli/onboard.md +245 -0
- package/docs/cli/pairing.md +77 -0
- package/docs/cli/path.md +502 -0
- package/docs/cli/plugins.md +454 -0
- package/docs/cli/policy.md +418 -0
- package/docs/cli/proxy.md +89 -0
- package/docs/cli/qr.md +56 -0
- package/docs/cli/reset.md +39 -0
- package/docs/cli/sandbox.md +208 -0
- package/docs/cli/secrets.md +202 -0
- package/docs/cli/security.md +124 -0
- package/docs/cli/sessions.md +164 -0
- package/docs/cli/setup.md +59 -0
- package/docs/cli/skills.md +102 -0
- package/docs/cli/status.md +45 -0
- package/docs/cli/system.md +89 -0
- package/docs/cli/tasks.md +111 -0
- package/docs/cli/tui.md +89 -0
- package/docs/cli/uninstall.md +44 -0
- package/docs/cli/update.md +242 -0
- package/docs/cli/voicecall.md +204 -0
- package/docs/cli/webhooks.md +117 -0
- package/docs/cli/wiki.md +256 -0
- package/docs/concepts/active-memory.md +856 -0
- package/docs/concepts/agent-loop.md +185 -0
- package/docs/concepts/agent-runtimes.md +243 -0
- package/docs/concepts/agent-workspace.md +230 -0
- package/docs/concepts/agent.md +136 -0
- package/docs/concepts/architecture.md +154 -0
- package/docs/concepts/channel-docking.md +145 -0
- package/docs/concepts/commitments.md +150 -0
- package/docs/concepts/compaction.md +203 -0
- package/docs/concepts/context-engine.md +306 -0
- package/docs/concepts/context.md +199 -0
- package/docs/concepts/delegate-architecture.md +319 -0
- package/docs/concepts/dreaming.md +261 -0
- package/docs/concepts/experimental-features.md +108 -0
- package/docs/concepts/features.md +91 -0
- package/docs/concepts/mantis-slack-desktop-runbook.md +202 -0
- package/docs/concepts/mantis.md +740 -0
- package/docs/concepts/markdown-formatting.md +139 -0
- package/docs/concepts/memory-builtin.md +146 -0
- package/docs/concepts/memory-honcho.md +144 -0
- package/docs/concepts/memory-qmd.md +271 -0
- package/docs/concepts/memory-search.md +166 -0
- package/docs/concepts/memory.md +258 -0
- package/docs/concepts/message-lifecycle-refactor.md +1128 -0
- package/docs/concepts/messages.md +214 -0
- package/docs/concepts/model-failover.md +385 -0
- package/docs/concepts/model-providers.md +715 -0
- package/docs/concepts/models.md +370 -0
- package/docs/concepts/multi-agent.md +619 -0
- package/docs/concepts/oauth.md +198 -0
- package/docs/concepts/openclaw-sdk.md +323 -0
- package/docs/concepts/parallel-specialist-lanes.md +127 -0
- package/docs/concepts/personal-agent-benchmark-pack.md +74 -0
- package/docs/concepts/presence.md +117 -0
- package/docs/concepts/progress-drafts.md +362 -0
- package/docs/concepts/qa-e2e-automation.md +820 -0
- package/docs/concepts/qa-matrix.md +139 -0
- package/docs/concepts/queue-steering.md +90 -0
- package/docs/concepts/queue.md +122 -0
- package/docs/concepts/retry.md +86 -0
- package/docs/concepts/session-pruning.md +104 -0
- package/docs/concepts/session-tool.md +190 -0
- package/docs/concepts/session.md +164 -0
- package/docs/concepts/soul.md +116 -0
- package/docs/concepts/streaming.md +251 -0
- package/docs/concepts/system-prompt.md +310 -0
- package/docs/concepts/timezone.md +47 -0
- package/docs/concepts/typebox.md +309 -0
- package/docs/concepts/typing-indicators.md +88 -0
- package/docs/concepts/usage-tracking.md +66 -0
- package/docs/date-time.md +126 -0
- package/docs/debug/node-issue.md +90 -0
- package/docs/diagnostics/flags.md +138 -0
- package/docs/docs.json +1832 -0
- package/docs/gateway/authentication.md +239 -0
- package/docs/gateway/background-process.md +147 -0
- package/docs/gateway/bonjour.md +303 -0
- package/docs/gateway/bridge-protocol.md +94 -0
- package/docs/gateway/cli-backends.md +420 -0
- package/docs/gateway/config-agents.md +1514 -0
- package/docs/gateway/config-channels.md +945 -0
- package/docs/gateway/config-tools.md +769 -0
- package/docs/gateway/configuration-examples.md +705 -0
- package/docs/gateway/configuration-reference.md +1393 -0
- package/docs/gateway/configuration.md +737 -0
- package/docs/gateway/diagnostics.md +213 -0
- package/docs/gateway/discovery.md +154 -0
- package/docs/gateway/doctor.md +574 -0
- package/docs/gateway/gateway-lock.md +37 -0
- package/docs/gateway/health.md +73 -0
- package/docs/gateway/heartbeat.md +493 -0
- package/docs/gateway/index.md +383 -0
- package/docs/gateway/local-model-services.md +205 -0
- package/docs/gateway/local-models.md +355 -0
- package/docs/gateway/logging.md +149 -0
- package/docs/gateway/multiple-gateways.md +178 -0
- package/docs/gateway/network-model.md +15 -0
- package/docs/gateway/openai-http-api.md +350 -0
- package/docs/gateway/openresponses-http-api.md +347 -0
- package/docs/gateway/openshell.md +316 -0
- package/docs/gateway/opentelemetry.md +404 -0
- package/docs/gateway/operator-scopes.md +111 -0
- package/docs/gateway/pairing.md +207 -0
- package/docs/gateway/prometheus.md +230 -0
- package/docs/gateway/protocol.md +803 -0
- package/docs/gateway/remote-gateway-readme.md +169 -0
- package/docs/gateway/remote.md +280 -0
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +146 -0
- package/docs/gateway/sandboxing.md +545 -0
- package/docs/gateway/secrets-plan-contract.md +114 -0
- package/docs/gateway/secrets.md +609 -0
- package/docs/gateway/security/audit-checks.md +127 -0
- package/docs/gateway/security/index.md +1326 -0
- package/docs/gateway/security/secure-file-operations.md +76 -0
- package/docs/gateway/tailscale.md +156 -0
- package/docs/gateway/tools-invoke-http-api.md +169 -0
- package/docs/gateway/troubleshooting.md +772 -0
- package/docs/gateway/trusted-proxy-auth.md +451 -0
- package/docs/help/debugging.md +344 -0
- package/docs/help/environment.md +214 -0
- package/docs/help/faq-first-run.md +867 -0
- package/docs/help/faq-models.md +553 -0
- package/docs/help/faq.md +1975 -0
- package/docs/help/gpt55-codex-agentic-parity-maintainers.md +196 -0
- package/docs/help/gpt55-codex-agentic-parity.md +230 -0
- package/docs/help/index.md +39 -0
- package/docs/help/scripts.md +56 -0
- package/docs/help/testing-live.md +580 -0
- package/docs/help/testing-updates-plugins.md +291 -0
- package/docs/help/testing.md +928 -0
- package/docs/help/troubleshooting.md +424 -0
- package/docs/images/configure-model-picker-unsearchable.png +0 -0
- package/docs/images/feishu-get-group-id.png +0 -0
- package/docs/images/groups-flow.svg +52 -0
- package/docs/images/mobile-ui-screenshot.png +0 -0
- package/docs/index.md +196 -0
- package/docs/install/ansible.md +233 -0
- package/docs/install/azure.md +315 -0
- package/docs/install/bun.md +59 -0
- package/docs/install/clawdock.md +112 -0
- package/docs/install/development-channels.md +135 -0
- package/docs/install/digitalocean.md +174 -0
- package/docs/install/docker-vm-runtime.md +154 -0
- package/docs/install/docker.md +562 -0
- package/docs/install/exe-dev.md +201 -0
- package/docs/install/fly.md +524 -0
- package/docs/install/gcp.md +418 -0
- package/docs/install/hetzner.md +285 -0
- package/docs/install/hostinger.md +98 -0
- package/docs/install/index.md +221 -0
- package/docs/install/installer.md +455 -0
- package/docs/install/kubernetes.md +196 -0
- package/docs/install/macos-vm.md +281 -0
- package/docs/install/migrating-claude.md +165 -0
- package/docs/install/migrating-hermes.md +177 -0
- package/docs/install/migrating.md +137 -0
- package/docs/install/nix.md +112 -0
- package/docs/install/node.md +142 -0
- package/docs/install/northflank.mdx +44 -0
- package/docs/install/oracle.md +218 -0
- package/docs/install/podman.md +210 -0
- package/docs/install/railway.mdx +92 -0
- package/docs/install/raspberry-pi.md +234 -0
- package/docs/install/render.mdx +167 -0
- package/docs/install/uninstall.md +131 -0
- package/docs/install/updating.md +280 -0
- package/docs/logging.md +318 -0
- package/docs/nav-tabs-underline.js +100 -0
- package/docs/network.md +72 -0
- package/docs/nodes/audio.md +215 -0
- package/docs/nodes/camera.md +166 -0
- package/docs/nodes/images.md +77 -0
- package/docs/nodes/index.md +439 -0
- package/docs/nodes/location-command.md +102 -0
- package/docs/nodes/media-understanding.md +469 -0
- package/docs/nodes/talk.md +154 -0
- package/docs/nodes/troubleshooting.md +123 -0
- package/docs/nodes/voicewake.md +93 -0
- package/docs/perplexity.md +11 -0
- package/docs/pi-dev.md +82 -0
- package/docs/pi.md +573 -0
- package/docs/plan/codex-context-engine-harness.md +624 -0
- package/docs/plan/ui-channels.md +284 -0
- package/docs/platforms/android.md +285 -0
- package/docs/platforms/digitalocean.md +12 -0
- package/docs/platforms/index.md +60 -0
- package/docs/platforms/ios.md +283 -0
- package/docs/platforms/linux.md +141 -0
- package/docs/platforms/mac/bundled-gateway.md +79 -0
- package/docs/platforms/mac/canvas.md +128 -0
- package/docs/platforms/mac/child-process.md +72 -0
- package/docs/platforms/mac/dev-setup.md +112 -0
- package/docs/platforms/mac/health.md +39 -0
- package/docs/platforms/mac/icon.md +36 -0
- package/docs/platforms/mac/logging.md +62 -0
- package/docs/platforms/mac/menu-bar.md +93 -0
- package/docs/platforms/mac/peekaboo.md +92 -0
- package/docs/platforms/mac/permissions.md +53 -0
- package/docs/platforms/mac/remote.md +123 -0
- package/docs/platforms/mac/signing.md +52 -0
- package/docs/platforms/mac/skills.md +43 -0
- package/docs/platforms/mac/voice-overlay.md +66 -0
- package/docs/platforms/mac/voicewake.md +73 -0
- package/docs/platforms/mac/webchat.md +54 -0
- package/docs/platforms/mac/xpc.md +66 -0
- package/docs/platforms/macos.md +226 -0
- package/docs/platforms/oracle.md +12 -0
- package/docs/platforms/raspberry-pi.md +13 -0
- package/docs/platforms/windows.md +286 -0
- package/docs/plugins/adding-capabilities.md +133 -0
- package/docs/plugins/admin-http-rpc.md +216 -0
- package/docs/plugins/agent-tools.md +13 -0
- package/docs/plugins/architecture-internals.md +1195 -0
- package/docs/plugins/architecture.md +481 -0
- package/docs/plugins/building-extensions.md +13 -0
- package/docs/plugins/building-plugins.md +330 -0
- package/docs/plugins/bundles.md +310 -0
- package/docs/plugins/cli-backend-plugins.md +310 -0
- package/docs/plugins/codex-computer-use.md +293 -0
- package/docs/plugins/codex-harness-reference.md +409 -0
- package/docs/plugins/codex-harness-runtime.md +247 -0
- package/docs/plugins/codex-harness.md +746 -0
- package/docs/plugins/codex-native-plugins.md +276 -0
- package/docs/plugins/community.md +77 -0
- package/docs/plugins/compatibility.md +164 -0
- package/docs/plugins/dependency-resolution.md +143 -0
- package/docs/plugins/google-meet.md +1737 -0
- package/docs/plugins/hooks.md +459 -0
- package/docs/plugins/install-overrides.md +80 -0
- package/docs/plugins/manage-plugins.md +210 -0
- package/docs/plugins/manifest.md +1359 -0
- package/docs/plugins/memory-lancedb.md +385 -0
- package/docs/plugins/memory-wiki.md +529 -0
- package/docs/plugins/message-presentation.md +473 -0
- package/docs/plugins/oc-path.md +166 -0
- package/docs/plugins/plugin-inventory.md +182 -0
- package/docs/plugins/reference/acpx.md +23 -0
- package/docs/plugins/reference/admin-http-rpc.md +23 -0
- package/docs/plugins/reference/alibaba.md +23 -0
- package/docs/plugins/reference/amazon-bedrock-mantle.md +23 -0
- package/docs/plugins/reference/amazon-bedrock.md +23 -0
- package/docs/plugins/reference/anthropic-vertex.md +19 -0
- package/docs/plugins/reference/anthropic.md +23 -0
- package/docs/plugins/reference/arcee.md +23 -0
- package/docs/plugins/reference/azure-speech.md +23 -0
- package/docs/plugins/reference/bonjour.md +19 -0
- package/docs/plugins/reference/brave.md +23 -0
- package/docs/plugins/reference/browser.md +23 -0
- package/docs/plugins/reference/byteplus.md +19 -0
- package/docs/plugins/reference/canvas.md +19 -0
- package/docs/plugins/reference/cerebras.md +23 -0
- package/docs/plugins/reference/chutes.md +23 -0
- package/docs/plugins/reference/clickclack.md +23 -0
- package/docs/plugins/reference/cloudflare-ai-gateway.md +23 -0
- package/docs/plugins/reference/codex.md +23 -0
- package/docs/plugins/reference/comfy.md +23 -0
- package/docs/plugins/reference/copilot-proxy.md +19 -0
- package/docs/plugins/reference/deepgram.md +23 -0
- package/docs/plugins/reference/deepinfra.md +23 -0
- package/docs/plugins/reference/deepseek.md +23 -0
- package/docs/plugins/reference/diagnostics-otel.md +19 -0
- package/docs/plugins/reference/diagnostics-prometheus.md +19 -0
- package/docs/plugins/reference/diffs.md +19 -0
- package/docs/plugins/reference/discord.md +23 -0
- package/docs/plugins/reference/document-extract.md +23 -0
- package/docs/plugins/reference/duckduckgo.md +23 -0
- package/docs/plugins/reference/elevenlabs.md +23 -0
- package/docs/plugins/reference/exa.md +23 -0
- package/docs/plugins/reference/fal.md +23 -0
- package/docs/plugins/reference/feishu.md +23 -0
- package/docs/plugins/reference/file-transfer.md +19 -0
- package/docs/plugins/reference/firecrawl.md +23 -0
- package/docs/plugins/reference/fireworks.md +23 -0
- package/docs/plugins/reference/github-copilot.md +23 -0
- package/docs/plugins/reference/google-meet.md +23 -0
- package/docs/plugins/reference/google.md +23 -0
- package/docs/plugins/reference/googlechat.md +23 -0
- package/docs/plugins/reference/gradium.md +23 -0
- package/docs/plugins/reference/groq.md +23 -0
- package/docs/plugins/reference/huggingface.md +23 -0
- package/docs/plugins/reference/imessage.md +23 -0
- package/docs/plugins/reference/inworld.md +23 -0
- package/docs/plugins/reference/irc.md +23 -0
- package/docs/plugins/reference/kilocode.md +23 -0
- package/docs/plugins/reference/kimi.md +23 -0
- package/docs/plugins/reference/line.md +23 -0
- package/docs/plugins/reference/litellm.md +23 -0
- package/docs/plugins/reference/llm-task.md +19 -0
- package/docs/plugins/reference/lmstudio.md +23 -0
- package/docs/plugins/reference/lobster.md +19 -0
- package/docs/plugins/reference/matrix.md +23 -0
- package/docs/plugins/reference/mattermost.md +23 -0
- package/docs/plugins/reference/memory-core.md +19 -0
- package/docs/plugins/reference/memory-lancedb.md +23 -0
- package/docs/plugins/reference/memory-wiki.md +23 -0
- package/docs/plugins/reference/microsoft-foundry.md +19 -0
- package/docs/plugins/reference/microsoft.md +19 -0
- package/docs/plugins/reference/migrate-claude.md +19 -0
- package/docs/plugins/reference/migrate-hermes.md +19 -0
- package/docs/plugins/reference/minimax.md +23 -0
- package/docs/plugins/reference/mistral.md +23 -0
- package/docs/plugins/reference/moonshot.md +23 -0
- package/docs/plugins/reference/msteams.md +23 -0
- package/docs/plugins/reference/nextcloud-talk.md +23 -0
- package/docs/plugins/reference/nostr.md +23 -0
- package/docs/plugins/reference/nvidia.md +23 -0
- package/docs/plugins/reference/oc-path.md +23 -0
- package/docs/plugins/reference/ollama.md +23 -0
- package/docs/plugins/reference/open-prose.md +19 -0
- package/docs/plugins/reference/openai.md +23 -0
- package/docs/plugins/reference/opencode-go.md +23 -0
- package/docs/plugins/reference/opencode.md +23 -0
- package/docs/plugins/reference/openrouter.md +23 -0
- package/docs/plugins/reference/openshell.md +19 -0
- package/docs/plugins/reference/perplexity.md +23 -0
- package/docs/plugins/reference/policy.md +23 -0
- package/docs/plugins/reference/qa-channel.md +23 -0
- package/docs/plugins/reference/qa-lab.md +19 -0
- package/docs/plugins/reference/qa-matrix.md +19 -0
- package/docs/plugins/reference/qianfan.md +23 -0
- package/docs/plugins/reference/qqbot.md +23 -0
- package/docs/plugins/reference/qwen.md +23 -0
- package/docs/plugins/reference/runway.md +23 -0
- package/docs/plugins/reference/searxng.md +19 -0
- package/docs/plugins/reference/senseaudio.md +23 -0
- package/docs/plugins/reference/sglang.md +23 -0
- package/docs/plugins/reference/signal.md +23 -0
- package/docs/plugins/reference/skill-workshop.md +23 -0
- package/docs/plugins/reference/slack.md +23 -0
- package/docs/plugins/reference/stepfun.md +23 -0
- package/docs/plugins/reference/synology-chat.md +23 -0
- package/docs/plugins/reference/synthetic.md +23 -0
- package/docs/plugins/reference/tavily.md +23 -0
- package/docs/plugins/reference/telegram.md +23 -0
- package/docs/plugins/reference/tencent.md +23 -0
- package/docs/plugins/reference/tlon.md +23 -0
- package/docs/plugins/reference/together.md +23 -0
- package/docs/plugins/reference/tokenjuice.md +23 -0
- package/docs/plugins/reference/tts-local-cli.md +19 -0
- package/docs/plugins/reference/twitch.md +23 -0
- package/docs/plugins/reference/venice.md +23 -0
- package/docs/plugins/reference/vercel-ai-gateway.md +23 -0
- package/docs/plugins/reference/vllm.md +23 -0
- package/docs/plugins/reference/voice-call.md +23 -0
- package/docs/plugins/reference/volcengine.md +23 -0
- package/docs/plugins/reference/voyage.md +19 -0
- package/docs/plugins/reference/vydra.md +23 -0
- package/docs/plugins/reference/web-readability.md +19 -0
- package/docs/plugins/reference/webhooks.md +23 -0
- package/docs/plugins/reference/whatsapp.md +23 -0
- package/docs/plugins/reference/xai.md +23 -0
- package/docs/plugins/reference/xiaomi.md +23 -0
- package/docs/plugins/reference/zai.md +23 -0
- package/docs/plugins/reference/zalo.md +23 -0
- package/docs/plugins/reference/zalouser.md +24 -0
- package/docs/plugins/reference.md +138 -0
- package/docs/plugins/sdk-agent-harness.md +339 -0
- package/docs/plugins/sdk-channel-ingress.md +137 -0
- package/docs/plugins/sdk-channel-message.md +458 -0
- package/docs/plugins/sdk-channel-plugins.md +762 -0
- package/docs/plugins/sdk-channel-turn.md +580 -0
- package/docs/plugins/sdk-entrypoints.md +333 -0
- package/docs/plugins/sdk-migration.md +949 -0
- package/docs/plugins/sdk-overview.md +501 -0
- package/docs/plugins/sdk-provider-plugins.md +807 -0
- package/docs/plugins/sdk-runtime.md +676 -0
- package/docs/plugins/sdk-setup.md +550 -0
- package/docs/plugins/sdk-subpaths.md +396 -0
- package/docs/plugins/sdk-testing.md +401 -0
- package/docs/plugins/skill-workshop.md +713 -0
- package/docs/plugins/tool-plugins.md +411 -0
- package/docs/plugins/voice-call.md +943 -0
- package/docs/plugins/webhooks.md +192 -0
- package/docs/plugins/zalouser.md +86 -0
- package/docs/prose.md +137 -0
- package/docs/providers/alibaba.md +158 -0
- package/docs/providers/anthropic.md +344 -0
- package/docs/providers/arcee.md +144 -0
- package/docs/providers/azure-speech.md +119 -0
- package/docs/providers/bedrock-mantle.md +211 -0
- package/docs/providers/bedrock.md +414 -0
- package/docs/providers/cerebras.md +130 -0
- package/docs/providers/chutes.md +153 -0
- package/docs/providers/claude-max-api-proxy.md +188 -0
- package/docs/providers/cloudflare-ai-gateway.md +119 -0
- package/docs/providers/comfy.md +362 -0
- package/docs/providers/deepgram.md +184 -0
- package/docs/providers/deepinfra.md +87 -0
- package/docs/providers/deepseek.md +146 -0
- package/docs/providers/ds4.md +309 -0
- package/docs/providers/elevenlabs.md +130 -0
- package/docs/providers/fal.md +204 -0
- package/docs/providers/fireworks.md +144 -0
- package/docs/providers/github-copilot.md +225 -0
- package/docs/providers/glm.md +137 -0
- package/docs/providers/google.md +472 -0
- package/docs/providers/gradium.md +123 -0
- package/docs/providers/groq.md +180 -0
- package/docs/providers/huggingface.md +235 -0
- package/docs/providers/index.md +102 -0
- package/docs/providers/inferrs.md +272 -0
- package/docs/providers/inworld.md +120 -0
- package/docs/providers/kilocode.md +135 -0
- package/docs/providers/litellm.md +234 -0
- package/docs/providers/lmstudio.md +224 -0
- package/docs/providers/minimax.md +505 -0
- package/docs/providers/mistral.md +235 -0
- package/docs/providers/models.md +65 -0
- package/docs/providers/moonshot.md +413 -0
- package/docs/providers/nvidia.md +140 -0
- package/docs/providers/ollama.md +1180 -0
- package/docs/providers/openai.md +1057 -0
- package/docs/providers/opencode-go.md +123 -0
- package/docs/providers/opencode.md +149 -0
- package/docs/providers/openrouter.md +349 -0
- package/docs/providers/perplexity-provider.md +123 -0
- package/docs/providers/qianfan.md +132 -0
- package/docs/providers/qwen.md +332 -0
- package/docs/providers/runway.md +103 -0
- package/docs/providers/senseaudio.md +68 -0
- package/docs/providers/sglang.md +161 -0
- package/docs/providers/stepfun.md +229 -0
- package/docs/providers/synthetic.md +154 -0
- package/docs/providers/tencent.md +130 -0
- package/docs/providers/together.md +141 -0
- package/docs/providers/venice.md +315 -0
- package/docs/providers/vercel-ai-gateway.md +128 -0
- package/docs/providers/vllm.md +383 -0
- package/docs/providers/volcengine.md +199 -0
- package/docs/providers/vydra.md +180 -0
- package/docs/providers/xai.md +560 -0
- package/docs/providers/xiaomi.md +188 -0
- package/docs/providers/zai.md +203 -0
- package/docs/refactor/access.md +9 -0
- package/docs/refactor/acp.md +298 -0
- package/docs/refactor/canvas.md +131 -0
- package/docs/refactor/ingress-core.md +341 -0
- package/docs/reference/AGENTS.default.md +129 -0
- package/docs/reference/RELEASING.md +767 -0
- package/docs/reference/api-usage-costs.md +202 -0
- package/docs/reference/application-modernization-plan.md +208 -0
- package/docs/reference/code-mode.md +757 -0
- package/docs/reference/credits.md +33 -0
- package/docs/reference/device-models.md +50 -0
- package/docs/reference/full-release-validation.md +202 -0
- package/docs/reference/memory-config.md +630 -0
- package/docs/reference/openclaw-sdk-api-design.md +390 -0
- package/docs/reference/prompt-caching.md +358 -0
- package/docs/reference/rich-output-protocol.md +79 -0
- package/docs/reference/rpc.md +43 -0
- package/docs/reference/secretref-credential-surface.md +159 -0
- package/docs/reference/secretref-user-supplied-credentials-matrix.json +663 -0
- package/docs/reference/session-management-compaction.md +461 -0
- package/docs/reference/templates/AGENTS.dev.md +89 -0
- package/docs/reference/templates/AGENTS.md +225 -0
- package/docs/reference/templates/BOOT.md +16 -0
- package/docs/reference/templates/BOOTSTRAP.md +66 -0
- package/docs/reference/templates/HEARTBEAT.md +16 -0
- package/docs/reference/templates/IDENTITY.dev.md +52 -0
- package/docs/reference/templates/IDENTITY.md +34 -0
- package/docs/reference/templates/SOUL.dev.md +82 -0
- package/docs/reference/templates/SOUL.md +49 -0
- package/docs/reference/templates/TOOLS.dev.md +29 -0
- package/docs/reference/templates/TOOLS.md +51 -0
- package/docs/reference/templates/USER.dev.md +23 -0
- package/docs/reference/templates/USER.md +28 -0
- package/docs/reference/test.md +239 -0
- package/docs/reference/token-use.md +233 -0
- package/docs/reference/transcript-hygiene.md +214 -0
- package/docs/reference/wizard.md +252 -0
- package/docs/security/CONTRIBUTING-THREAT-MODEL.md +101 -0
- package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
- package/docs/security/formal-verification.md +170 -0
- package/docs/security/incident-response.md +59 -0
- package/docs/security/network-proxy.md +268 -0
- package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +12 -0
- package/docs/snippets/plugin-publish/minimal-package.json +16 -0
- package/docs/start/bootstrapping.md +49 -0
- package/docs/start/docs-directory.md +69 -0
- package/docs/start/getting-started.md +152 -0
- package/docs/start/hubs.md +201 -0
- package/docs/start/lore.md +223 -0
- package/docs/start/onboarding-overview.md +72 -0
- package/docs/start/onboarding.md +95 -0
- package/docs/start/openclaw.md +244 -0
- package/docs/start/quickstart.md +25 -0
- package/docs/start/setup.md +178 -0
- package/docs/start/showcase.md +383 -0
- package/docs/start/wizard-cli-automation.md +232 -0
- package/docs/start/wizard-cli-reference.md +331 -0
- package/docs/start/wizard.md +141 -0
- package/docs/style.css +184 -0
- package/docs/superpowers/specs/2026-04-22-tweakcn-custom-theme-import-design.md +316 -0
- package/docs/tools/acp-agents-setup.md +352 -0
- package/docs/tools/acp-agents.md +847 -0
- package/docs/tools/agent-send.md +112 -0
- package/docs/tools/apply-patch.md +64 -0
- package/docs/tools/brave-search.md +139 -0
- package/docs/tools/browser-control.md +391 -0
- package/docs/tools/browser-linux-troubleshooting.md +173 -0
- package/docs/tools/browser-login.md +77 -0
- package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +219 -0
- package/docs/tools/browser.md +769 -0
- package/docs/tools/btw.md +159 -0
- package/docs/tools/capability-cookbook.md +12 -0
- package/docs/tools/clawhub.md +5 -0
- package/docs/tools/code-execution.md +173 -0
- package/docs/tools/creating-skills.md +120 -0
- package/docs/tools/diffs.md +506 -0
- package/docs/tools/duckduckgo-search.md +109 -0
- package/docs/tools/elevated.md +128 -0
- package/docs/tools/exa-search.md +152 -0
- package/docs/tools/exec-approvals-advanced.md +360 -0
- package/docs/tools/exec-approvals.md +474 -0
- package/docs/tools/exec.md +282 -0
- package/docs/tools/firecrawl.md +155 -0
- package/docs/tools/gemini-search.md +114 -0
- package/docs/tools/grok-search.md +113 -0
- package/docs/tools/image-generation.md +433 -0
- package/docs/tools/index.md +178 -0
- package/docs/tools/kimi-search.md +105 -0
- package/docs/tools/llm-task.md +137 -0
- package/docs/tools/lobster.md +365 -0
- package/docs/tools/loop-detection.md +154 -0
- package/docs/tools/media-overview.md +157 -0
- package/docs/tools/minimax-search.md +102 -0
- package/docs/tools/multi-agent-sandbox-tools.md +409 -0
- package/docs/tools/music-generation.md +371 -0
- package/docs/tools/ollama-search.md +153 -0
- package/docs/tools/pdf.md +195 -0
- package/docs/tools/perplexity-search.md +220 -0
- package/docs/tools/plugin.md +327 -0
- package/docs/tools/reactions.md +100 -0
- package/docs/tools/searxng-search.md +141 -0
- package/docs/tools/skills-config.md +195 -0
- package/docs/tools/skills.md +535 -0
- package/docs/tools/slash-commands.md +488 -0
- package/docs/tools/steer.md +84 -0
- package/docs/tools/subagents.md +650 -0
- package/docs/tools/tavily.md +162 -0
- package/docs/tools/thinking.md +140 -0
- package/docs/tools/tokenjuice.md +81 -0
- package/docs/tools/tool-search.md +269 -0
- package/docs/tools/trajectory.md +229 -0
- package/docs/tools/tts.md +1004 -0
- package/docs/tools/video-generation.md +552 -0
- package/docs/tools/web-fetch.md +195 -0
- package/docs/tools/web.md +459 -0
- package/docs/tts.md +11 -0
- package/docs/vps.md +139 -0
- package/docs/web/control-ui.md +503 -0
- package/docs/web/dashboard.md +107 -0
- package/docs/web/index.md +133 -0
- package/docs/web/tui.md +246 -0
- package/docs/web/webchat.md +99 -0
- package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
- package/docs/whatsapp-openclaw.jpg +0 -0
- package/nodmix.mjs +487 -0
- package/package.json +1852 -0
- package/patches/.gitkeep +0 -0
- package/patches/@agentclientprotocol__claude-agent-acp@0.36.1.patch +41 -0
- package/pnpm-workspace.yaml +63 -0
- package/scripts/crabbox-wrapper.mjs +353 -0
- package/scripts/lib/official-external-channel-catalog.json +559 -0
- package/scripts/lib/official-external-plugin-catalog.json +192 -0
- package/scripts/lib/official-external-provider-catalog.json +117 -0
- package/scripts/lib/package-dist-imports.mjs +171 -0
- package/scripts/npm-runner.mjs +91 -0
- package/scripts/postinstall-bundled-plugins.mjs +978 -0
- package/scripts/preinstall-package-manager-warning.mjs +64 -0
- package/scripts/windows-cmd-helpers.mjs +20 -0
- package/skills/1password/SKILL.md +70 -0
- package/skills/1password/references/cli-examples.md +29 -0
- package/skills/1password/references/get-started.md +17 -0
- package/skills/apple-notes/SKILL.md +77 -0
- package/skills/apple-reminders/SKILL.md +118 -0
- package/skills/bear-notes/SKILL.md +107 -0
- package/skills/blogwatcher/SKILL.md +69 -0
- package/skills/blucli/SKILL.md +47 -0
- package/skills/camsnap/SKILL.md +45 -0
- package/skills/canvas/SKILL.md +78 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +149 -0
- package/skills/diagram-maker/SKILL.md +53 -0
- package/skills/diagram-maker/references/excalidraw-patterns.md +85 -0
- package/skills/diagram-maker/references/svg-template.md +112 -0
- package/skills/discord/SKILL.md +136 -0
- package/skills/eightctl/SKILL.md +50 -0
- package/skills/gemini/SKILL.md +47 -0
- package/skills/gh-issues/SKILL.md +213 -0
- package/skills/gifgrep/SKILL.md +85 -0
- package/skills/github/SKILL.md +84 -0
- package/skills/gog/SKILL.md +116 -0
- package/skills/goplaces/SKILL.md +52 -0
- package/skills/healthcheck/SKILL.md +105 -0
- package/skills/himalaya/SKILL.md +80 -0
- package/skills/himalaya/references/configuration.md +184 -0
- package/skills/himalaya/references/message-composition.md +199 -0
- package/skills/imsg/SKILL.md +122 -0
- package/skills/mcporter/SKILL.md +61 -0
- package/skills/meme-maker/SKILL.md +42 -0
- package/skills/meme-maker/references/templates.json +358 -0
- package/skills/meme-maker/scripts/meme.mjs +398 -0
- package/skills/model-usage/SKILL.md +69 -0
- package/skills/model-usage/references/codexbar-cli.md +33 -0
- package/skills/model-usage/scripts/model_usage.py +319 -0
- package/skills/model-usage/scripts/test_model_usage.py +40 -0
- package/skills/nano-pdf/SKILL.md +38 -0
- package/skills/node-connect/SKILL.md +142 -0
- package/skills/node-inspect-debugger/SKILL.md +85 -0
- package/skills/notion/SKILL.md +150 -0
- package/skills/obsidian/SKILL.md +119 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +71 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +154 -0
- package/skills/openhue/SKILL.md +112 -0
- package/skills/oracle/SKILL.md +126 -0
- package/skills/ordercli/SKILL.md +78 -0
- package/skills/peekaboo/SKILL.md +190 -0
- package/skills/pyproject.toml +10 -0
- package/skills/python-debugpy/SKILL.md +73 -0
- package/skills/sag/SKILL.md +87 -0
- package/skills/session-logs/SKILL.md +151 -0
- package/skills/sherpa-onnx-tts/SKILL.md +109 -0
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
- package/skills/skill-creator/SKILL.md +78 -0
- package/skills/skill-creator/license.txt +202 -0
- package/skills/skill-creator/scripts/init_skill.py +378 -0
- package/skills/skill-creator/scripts/package_skill.py +139 -0
- package/skills/skill-creator/scripts/quick_validate.py +169 -0
- package/skills/skill-creator/scripts/test_package_skill.py +161 -0
- package/skills/skill-creator/scripts/test_quick_validate.py +116 -0
- package/skills/slack/SKILL.md +78 -0
- package/skills/songsee/SKILL.md +49 -0
- package/skills/sonoscli/SKILL.md +65 -0
- package/skills/spike/SKILL.md +51 -0
- package/skills/spotify-player/SKILL.md +64 -0
- package/skills/summarize/SKILL.md +87 -0
- package/skills/taskflow/SKILL.md +149 -0
- package/skills/taskflow/examples/inbox-triage.lobster +33 -0
- package/skills/taskflow/examples/pr-intake.lobster +32 -0
- package/skills/taskflow-inbox-triage/SKILL.md +119 -0
- package/skills/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +91 -0
- package/skills/tmux/scripts/find-sessions.sh +112 -0
- package/skills/tmux/scripts/wait-for-text.sh +83 -0
- package/skills/trello/SKILL.md +108 -0
- package/skills/video-frames/SKILL.md +46 -0
- package/skills/video-frames/scripts/frame.sh +81 -0
- package/skills/voice-call/SKILL.md +45 -0
- package/skills/wacli/SKILL.md +72 -0
- package/skills/weather/SKILL.md +64 -0
- package/skills/xurl/SKILL.md +120 -0
package/docs/cli/path.md
ADDED
|
@@ -0,0 +1,502 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "CLI reference for `nodmix path` (inspect and edit workspace files via the `oc://` addressing scheme)"
|
|
3
|
+
read_when:
|
|
4
|
+
- You want to read or write a leaf inside a workspace file from the terminal
|
|
5
|
+
- You're scripting against workspace state and want a stable, kind-agnostic addressing scheme
|
|
6
|
+
- You're debugging a `oc://` path (validate the syntax, see what it resolves to)
|
|
7
|
+
title: "Path"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# `nodmix path`
|
|
11
|
+
|
|
12
|
+
Plugin-provided shell access to the `oc://` addressing substrate: one
|
|
13
|
+
kind-dispatched path scheme for inspecting and editing addressable workspace
|
|
14
|
+
files (markdown, jsonc, jsonl, yaml/yml/lobster). Self-hosters, plugin
|
|
15
|
+
authors, and editor extensions use it to read, find, or update a narrow
|
|
16
|
+
location without hand-rolling per-file parsers.
|
|
17
|
+
|
|
18
|
+
The CLI mirrors the substrate's public verbs:
|
|
19
|
+
|
|
20
|
+
- `resolve` is concrete and single-match.
|
|
21
|
+
- `find` is the multi-match verb for wildcards, unions, predicates, and
|
|
22
|
+
positional expansion.
|
|
23
|
+
- `set` only accepts concrete paths or insertion markers; wildcard patterns are
|
|
24
|
+
rejected before writing.
|
|
25
|
+
|
|
26
|
+
`path` is provided by the bundled optional `oc-path` plugin. Enable it before
|
|
27
|
+
first use:
|
|
28
|
+
|
|
29
|
+
```bash
|
|
30
|
+
nodmix plugins enable oc-path
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Why use it
|
|
34
|
+
|
|
35
|
+
Nodmix state is spread across human-edited markdown, commented JSONC config,
|
|
36
|
+
append-only JSONL logs, and YAML workflow/spec files. Shell scripts, hooks,
|
|
37
|
+
and agents often need one small value from those files: a frontmatter key, a
|
|
38
|
+
plugin setting, a log record field, a YAML step, or a bullet item under a named
|
|
39
|
+
section.
|
|
40
|
+
|
|
41
|
+
`nodmix path` gives those callers a stable address instead of a one-off grep,
|
|
42
|
+
regex, or parser for each file kind. The same `oc://` path can be validated,
|
|
43
|
+
resolved, searched, dry-run, and written from the terminal, which makes narrow
|
|
44
|
+
automation easier to review and safer to replay. It is especially useful when
|
|
45
|
+
you want to update one leaf while preserving the rest of the file's comments,
|
|
46
|
+
line endings, and surrounding formatting.
|
|
47
|
+
|
|
48
|
+
Use it when the thing you want has a logical address, but the physical file
|
|
49
|
+
shape varies:
|
|
50
|
+
|
|
51
|
+
- A hook wants to read one setting from commented JSONC without losing comments
|
|
52
|
+
when it writes the value back.
|
|
53
|
+
- A maintenance script wants to find every matching event field in a JSONL log
|
|
54
|
+
without loading the whole log into a custom parser.
|
|
55
|
+
- An editor extension wants to jump to a markdown section or bullet item by
|
|
56
|
+
slug, then render the exact line it resolved to.
|
|
57
|
+
- An agent wants to dry-run a tiny workspace edit before applying it, with the
|
|
58
|
+
changed bytes visible in review.
|
|
59
|
+
|
|
60
|
+
You probably do not need `nodmix path` for ordinary whole-file edits, rich
|
|
61
|
+
config migrations, or memory-specific writes. Those should use the owner
|
|
62
|
+
command or plugin. `path` is for small, addressable file operations where a
|
|
63
|
+
repeatable terminal command is clearer than another bespoke parser.
|
|
64
|
+
|
|
65
|
+
## How it is used
|
|
66
|
+
|
|
67
|
+
Read one value from a human-edited config file:
|
|
68
|
+
|
|
69
|
+
```bash
|
|
70
|
+
nodmix path resolve 'oc://config.jsonc/plugins/github/enabled'
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
Preview a write without touching disk:
|
|
74
|
+
|
|
75
|
+
```bash
|
|
76
|
+
nodmix path set 'oc://config.jsonc/plugins/github/enabled' 'true' --dry-run
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
Find matching records in an append-only JSONL log:
|
|
80
|
+
|
|
81
|
+
```bash
|
|
82
|
+
nodmix path find 'oc://session.jsonl/[event=tool_call]/name'
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
Address an instruction in markdown by section and item instead of by line
|
|
86
|
+
number:
|
|
87
|
+
|
|
88
|
+
```bash
|
|
89
|
+
nodmix path resolve 'oc://AGENTS.md/runtime-safety/nodmix-gateway'
|
|
90
|
+
```
|
|
91
|
+
|
|
92
|
+
Validate a path in CI or a preflight script before the script reads or writes:
|
|
93
|
+
|
|
94
|
+
```bash
|
|
95
|
+
nodmix path validate 'oc://AGENTS.md/tools/$last/risk'
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
Those commands are meant to be copyable into shell scripts. Use `--json` when a
|
|
99
|
+
caller needs structured output and `--human` when a person is inspecting the
|
|
100
|
+
result.
|
|
101
|
+
|
|
102
|
+
## How it works
|
|
103
|
+
|
|
104
|
+
`nodmix path` does four things:
|
|
105
|
+
|
|
106
|
+
1. Parses the `oc://` address into slots: file, section, item, field, and
|
|
107
|
+
optional session.
|
|
108
|
+
2. Chooses the file-kind adapter from the target extension (`.md`, `.jsonc`,
|
|
109
|
+
`.jsonl`, `.yaml`, `.yml`, `.lobster`, and related aliases).
|
|
110
|
+
3. Resolves the slots against that file kind's AST: markdown headings/items,
|
|
111
|
+
JSONC object keys/array indexes, JSONL line records, or YAML map/sequence
|
|
112
|
+
nodes.
|
|
113
|
+
4. For `set`, emits edited bytes through the same adapter so the untouched
|
|
114
|
+
parts of the file keep their comments, line endings, and nearby formatting
|
|
115
|
+
where the kind supports it.
|
|
116
|
+
|
|
117
|
+
`resolve` and `set` require one concrete target. `find` is the exploratory
|
|
118
|
+
verb: it expands wildcards, unions, predicates, and ordinals into the concrete
|
|
119
|
+
matches you can inspect before choosing one to write.
|
|
120
|
+
|
|
121
|
+
## Subcommands
|
|
122
|
+
|
|
123
|
+
| Subcommand | Purpose |
|
|
124
|
+
| ----------------------- | ---------------------------------------------------------------------------- |
|
|
125
|
+
| `resolve <oc-path>` | Print the concrete match at the path (or "not found"). |
|
|
126
|
+
| `find <pattern>` | Enumerate matches for a wildcard / union / predicate path. |
|
|
127
|
+
| `set <oc-path> <value>` | Write a leaf or insertion target at a concrete path. Supports `--dry-run`. |
|
|
128
|
+
| `validate <oc-path>` | Parse-only; print structural breakdown (file / section / item / field). |
|
|
129
|
+
| `emit <file>` | Round-trip a file through `parseXxx` + `emitXxx` (byte-fidelity diagnostic). |
|
|
130
|
+
|
|
131
|
+
## Global flags
|
|
132
|
+
|
|
133
|
+
| Flag | Purpose |
|
|
134
|
+
| --------------- | ------------------------------------------------------------------------ |
|
|
135
|
+
| `--cwd <dir>` | Resolve the file slot against this directory (default: `process.cwd()`). |
|
|
136
|
+
| `--file <path>` | Override the file slot's resolved path (absolute access). |
|
|
137
|
+
| `--json` | Force JSON output (default when stdout is not a TTY). |
|
|
138
|
+
| `--human` | Force human output (default when stdout is a TTY). |
|
|
139
|
+
| `--dry-run` | (only on `set`) print the bytes that would be written without writing. |
|
|
140
|
+
| `--diff` | (with `set --dry-run`) print a unified diff instead of the full bytes. |
|
|
141
|
+
|
|
142
|
+
## `oc://` syntax
|
|
143
|
+
|
|
144
|
+
```
|
|
145
|
+
oc://FILE/SECTION/ITEM/FIELD?session=SCOPE
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
Slot rules: `field` requires `item`, and `item` requires `section`. Across all
|
|
149
|
+
four slots:
|
|
150
|
+
|
|
151
|
+
- **Quoted segments** — `"a/b.c"` survives `/` and `.` separators.
|
|
152
|
+
Content is byte-literal; `"` and `\` are not allowed inside quotes.
|
|
153
|
+
The file slot is also quote-aware: `oc://"skills/email-drafter"/Tools/$last`
|
|
154
|
+
treats `skills/email-drafter` as a single file path.
|
|
155
|
+
- **Predicates** — `[k=v]`, `[k!=v]`, `[k<v]`, `[k<=v]`, `[k>v]`,
|
|
156
|
+
`[k>=v]`. Numeric ops require both sides to coerce to finite numbers.
|
|
157
|
+
- **Unions** — `{a,b,c}` matches any of the alternatives.
|
|
158
|
+
- **Wildcards** — `*` (single sub-segment) and `**` (zero-or-more,
|
|
159
|
+
recursive). `find` accepts these; `resolve` and `set` reject them as
|
|
160
|
+
ambiguous.
|
|
161
|
+
- **Positional** — `$first` / `$last` resolve to the first / last index or
|
|
162
|
+
declared key.
|
|
163
|
+
- **Ordinal** — `#N` for Nth match by document order.
|
|
164
|
+
- **Insertion markers** — `+`, `+key`, `+nnn` for keyed / indexed
|
|
165
|
+
insertion (use with `set`).
|
|
166
|
+
- **Session scope** — `?session=cron-daily` etc. Orthogonal to slot
|
|
167
|
+
nesting. Session values are raw, not percent-decoded; they may not contain
|
|
168
|
+
control characters or reserved query delimiters (`?`, `&`, `%`).
|
|
169
|
+
|
|
170
|
+
Reserved characters (`?`, `&`, `%`) outside quoted, predicate, or union
|
|
171
|
+
segments are rejected. Control characters (U+0000-U+001F, U+007F) are rejected
|
|
172
|
+
anywhere, including the `session` query value.
|
|
173
|
+
|
|
174
|
+
`formatOcPath(parseOcPath(path)) === path` is guaranteed for canonical paths.
|
|
175
|
+
Non-canonical query parameters are ignored except for the first non-empty
|
|
176
|
+
`session=` value.
|
|
177
|
+
|
|
178
|
+
## Addressing by file kind
|
|
179
|
+
|
|
180
|
+
| Kind | Addressing model |
|
|
181
|
+
| ----------------- | --------------------------------------------------------------------------------------------------- |
|
|
182
|
+
| Markdown | H2 sections by slug, bullet items by slug or `#N`, frontmatter via `[frontmatter]`. |
|
|
183
|
+
| JSONC/JSON | Object keys and array indexes; dots split nested sub-segments unless quoted. |
|
|
184
|
+
| JSONL | Top-level line addresses (`L1`, `L2`, `$first`, `$last`), then JSONC-style descent inside the line. |
|
|
185
|
+
| YAML/YML/.lobster | Map keys and sequence indexes; comments and flow style are handled by the YAML document API. |
|
|
186
|
+
|
|
187
|
+
`resolve` returns a structured match: `root`, `node`, `leaf`, or
|
|
188
|
+
`insertion-point`, with a 1-based line number. Leaf values are surfaced as text
|
|
189
|
+
plus a `leafType` so plugin authors can render previews without depending on
|
|
190
|
+
the per-kind AST shape.
|
|
191
|
+
|
|
192
|
+
## Mutation contract
|
|
193
|
+
|
|
194
|
+
`set` writes one concrete target:
|
|
195
|
+
|
|
196
|
+
- Markdown frontmatter values and `- key: value` item fields are string leaves.
|
|
197
|
+
Markdown insertions append sections, frontmatter keys, or section items and
|
|
198
|
+
render a canonical markdown shape for the changed file.
|
|
199
|
+
- JSONC leaf writes coerce the string value to the existing leaf type
|
|
200
|
+
(`string`, finite `number`, `true`/`false`, or `null`). JSONC object and array
|
|
201
|
+
insertions parse `<value>` as JSON and use the `jsonc-parser` edit path for
|
|
202
|
+
ordinary leaf writes, preserving comments and nearby formatting.
|
|
203
|
+
- JSONL leaf writes coerce like JSONC inside a line. Whole-line replacement and
|
|
204
|
+
append parse `<value>` as JSON. Rendered JSONL preserves the file's dominant
|
|
205
|
+
LF/CRLF line-ending convention.
|
|
206
|
+
- YAML leaf writes coerce to the existing scalar type (`string`, finite
|
|
207
|
+
`number`, `true`/`false`, or `null`). YAML insertions use the bundled
|
|
208
|
+
`yaml` package's document API for map/sequence updates. Malformed YAML
|
|
209
|
+
documents with parser errors are refused before mutation with `parse-error`.
|
|
210
|
+
|
|
211
|
+
Use `--dry-run` before user-visible writes when the exact bytes matter. The
|
|
212
|
+
substrate preserves byte-identical output for parse/emit round-trips, but a
|
|
213
|
+
mutation can canonicalize the edited region or file depending on kind.
|
|
214
|
+
Add `--diff` when you want the preview as a focused before/after patch instead
|
|
215
|
+
of the full rendered file.
|
|
216
|
+
|
|
217
|
+
## Examples
|
|
218
|
+
|
|
219
|
+
```bash
|
|
220
|
+
# Validate a path (no filesystem access)
|
|
221
|
+
nodmix path validate 'oc://AGENTS.md/Tools/$last/risk'
|
|
222
|
+
|
|
223
|
+
# Read a leaf
|
|
224
|
+
nodmix path resolve 'oc://gateway.jsonc/version'
|
|
225
|
+
|
|
226
|
+
# Wildcard search
|
|
227
|
+
nodmix path find 'oc://session.jsonl/*/event' --file ./logs/session.jsonl
|
|
228
|
+
|
|
229
|
+
# Dry-run a write
|
|
230
|
+
nodmix path set 'oc://gateway.jsonc/version' '2.0' --dry-run
|
|
231
|
+
|
|
232
|
+
# Dry-run a write as a unified diff
|
|
233
|
+
nodmix path set 'oc://gateway.jsonc/version' '2.0' --dry-run --diff
|
|
234
|
+
|
|
235
|
+
# Apply the write
|
|
236
|
+
nodmix path set 'oc://gateway.jsonc/version' '2.0'
|
|
237
|
+
|
|
238
|
+
# Byte-fidelity round-trip (diagnostic)
|
|
239
|
+
nodmix path emit ./AGENTS.md
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
More grammar examples:
|
|
243
|
+
|
|
244
|
+
```bash
|
|
245
|
+
# Quote keys containing / or .
|
|
246
|
+
nodmix path resolve 'oc://config.jsonc/agents.defaults.models/"anthropic/claude-opus-4-7"/alias'
|
|
247
|
+
|
|
248
|
+
# Predicate search over JSONC children
|
|
249
|
+
nodmix path find 'oc://config.jsonc/plugins/[enabled=true]/id'
|
|
250
|
+
|
|
251
|
+
# Insert into a JSONC array
|
|
252
|
+
nodmix path set 'oc://config.jsonc/items/+1' '{"id":"new","enabled":true}' --dry-run
|
|
253
|
+
|
|
254
|
+
# Insert a JSONC object key
|
|
255
|
+
nodmix path set 'oc://config.jsonc/plugins/+github' '{"enabled":true}' --dry-run
|
|
256
|
+
|
|
257
|
+
# Append a JSONL event
|
|
258
|
+
nodmix path set 'oc://session.jsonl/+' '{"event":"checkpoint","ok":true}' --file ./logs/session.jsonl
|
|
259
|
+
|
|
260
|
+
# Resolve the last JSONL value line
|
|
261
|
+
nodmix path resolve 'oc://session.jsonl/$last/event' --file ./logs/session.jsonl
|
|
262
|
+
|
|
263
|
+
# Resolve a YAML workflow step
|
|
264
|
+
nodmix path resolve 'oc://workflow.yaml/steps/0/id'
|
|
265
|
+
|
|
266
|
+
# Update a YAML scalar
|
|
267
|
+
nodmix path set 'oc://workflow.yaml/steps/$last/id' 'classify-renamed' --dry-run
|
|
268
|
+
|
|
269
|
+
# Address markdown frontmatter
|
|
270
|
+
nodmix path resolve 'oc://AGENTS.md/[frontmatter]/name'
|
|
271
|
+
|
|
272
|
+
# Insert markdown frontmatter
|
|
273
|
+
nodmix path set 'oc://AGENTS.md/[frontmatter]/+description' 'Agent instructions' --dry-run
|
|
274
|
+
|
|
275
|
+
# Find markdown item fields
|
|
276
|
+
nodmix path find 'oc://SKILL.md/Tools/*/send_email'
|
|
277
|
+
|
|
278
|
+
# Validate a session-scoped path
|
|
279
|
+
nodmix path validate 'oc://AGENTS.md/Tools/$last/risk?session=cron-daily'
|
|
280
|
+
```
|
|
281
|
+
|
|
282
|
+
## Recipes by file kind
|
|
283
|
+
|
|
284
|
+
The same five verbs work across kinds; the addressing scheme dispatches on the
|
|
285
|
+
file extension. The examples below use the fixtures from the PR description.
|
|
286
|
+
|
|
287
|
+
### Markdown
|
|
288
|
+
|
|
289
|
+
```text
|
|
290
|
+
<!-- frontmatter.md -->
|
|
291
|
+
---
|
|
292
|
+
name: drafter
|
|
293
|
+
description: email drafting agent
|
|
294
|
+
tier: core
|
|
295
|
+
---
|
|
296
|
+
## Tools
|
|
297
|
+
- gh: GitHub CLI
|
|
298
|
+
- curl: HTTP client
|
|
299
|
+
- send_email: enabled
|
|
300
|
+
```
|
|
301
|
+
|
|
302
|
+
```bash
|
|
303
|
+
$ nodmix path resolve 'oc://x.md/[frontmatter]/tier' --file frontmatter.md --human
|
|
304
|
+
leaf @ L4: "core" (string)
|
|
305
|
+
|
|
306
|
+
$ nodmix path resolve 'oc://x.md/tools/gh/gh' --file frontmatter.md --human
|
|
307
|
+
leaf @ L9: "GitHub CLI" (string)
|
|
308
|
+
|
|
309
|
+
$ nodmix path find 'oc://x.md/tools/*' --file frontmatter.md --human
|
|
310
|
+
3 matches for oc://x.md/tools/*:
|
|
311
|
+
oc://x.md/tools/gh → node @ L9 [md-item]
|
|
312
|
+
oc://x.md/tools/curl → node @ L10 [md-item]
|
|
313
|
+
oc://x.md/tools/send-email → node @ L11 [md-item]
|
|
314
|
+
```
|
|
315
|
+
|
|
316
|
+
The `[frontmatter]` predicate addresses the YAML frontmatter block; `tools`
|
|
317
|
+
matches the `## Tools` heading via slug, and item leaves keep their slug form
|
|
318
|
+
even when the source uses underscores (`send_email` → `send-email`).
|
|
319
|
+
|
|
320
|
+
### JSONC
|
|
321
|
+
|
|
322
|
+
```text
|
|
323
|
+
// config.jsonc
|
|
324
|
+
{
|
|
325
|
+
"plugins": {
|
|
326
|
+
"github": {"enabled": true, "role": "vcs"},
|
|
327
|
+
"slack": {"enabled": false, "role": "chat"}
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
```
|
|
331
|
+
|
|
332
|
+
```bash
|
|
333
|
+
$ nodmix path resolve 'oc://config.jsonc/plugins/github/enabled' --file config.jsonc --human
|
|
334
|
+
leaf @ L4: "true" (boolean)
|
|
335
|
+
|
|
336
|
+
$ nodmix path set 'oc://config.jsonc/plugins/slack/enabled' 'true' --file config.jsonc --dry-run
|
|
337
|
+
--dry-run: would write 142 bytes to /…/config.jsonc
|
|
338
|
+
{
|
|
339
|
+
"plugins": {
|
|
340
|
+
"github": {"enabled": true, "role": "vcs"},
|
|
341
|
+
"slack": {"enabled": true, "role": "chat"}
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
```
|
|
345
|
+
|
|
346
|
+
JSONC edits go through `jsonc-parser`, so comments and whitespace survive a
|
|
347
|
+
`set`. Run with `--dry-run` first to inspect the bytes before committing.
|
|
348
|
+
|
|
349
|
+
### JSONL
|
|
350
|
+
|
|
351
|
+
```text
|
|
352
|
+
{"event":"start","userId":"u1","ts":1}
|
|
353
|
+
{"event":"action","userId":"u1","ts":2}
|
|
354
|
+
{"event":"end","userId":"u1","ts":3}
|
|
355
|
+
```
|
|
356
|
+
|
|
357
|
+
```bash
|
|
358
|
+
$ nodmix path find 'oc://session.jsonl/[event=action]/userId' --file session.jsonl --human
|
|
359
|
+
1 match for oc://session.jsonl/[event=action]/userId:
|
|
360
|
+
oc://session.jsonl/L2/userId → leaf @ L2: "u1" (string)
|
|
361
|
+
|
|
362
|
+
$ nodmix path resolve 'oc://session.jsonl/L2/ts' --file session.jsonl --human
|
|
363
|
+
leaf @ L2: "2" (number)
|
|
364
|
+
```
|
|
365
|
+
|
|
366
|
+
Each line is a record. Address by predicate (`[event=action]`) when you do not
|
|
367
|
+
know the line number, or by the canonical `LN` segment when you do.
|
|
368
|
+
|
|
369
|
+
### YAML
|
|
370
|
+
|
|
371
|
+
```text
|
|
372
|
+
# workflow.yaml
|
|
373
|
+
name: inbox-triage
|
|
374
|
+
steps:
|
|
375
|
+
- id: fetch
|
|
376
|
+
command: gmail.search
|
|
377
|
+
- id: classify
|
|
378
|
+
command: nodmix.invoke
|
|
379
|
+
```
|
|
380
|
+
|
|
381
|
+
```bash
|
|
382
|
+
$ nodmix path resolve 'oc://workflow.yaml/steps/0/id' --file workflow.yaml --human
|
|
383
|
+
leaf @ L3: "fetch" (string)
|
|
384
|
+
|
|
385
|
+
$ nodmix path set 'oc://workflow.yaml/steps/$last/id' 'classify-renamed' --file workflow.yaml --dry-run
|
|
386
|
+
--dry-run: would write 99 bytes to /…/workflow.yaml
|
|
387
|
+
name: inbox-triage
|
|
388
|
+
steps:
|
|
389
|
+
- id: fetch
|
|
390
|
+
command: gmail.search
|
|
391
|
+
- id: classify-renamed
|
|
392
|
+
command: nodmix.invoke
|
|
393
|
+
```
|
|
394
|
+
|
|
395
|
+
YAML uses the `yaml` package's `Document` API rather than a hand-rolled parser,
|
|
396
|
+
so ordinary parse/emit round-trips preserve comments and authoring shape while
|
|
397
|
+
resolved paths use the same map-key / sequence-index model as JSONC. The same
|
|
398
|
+
adapter handles `.yaml`, `.yml`, and `.lobster` files.
|
|
399
|
+
|
|
400
|
+
## Subcommand reference
|
|
401
|
+
|
|
402
|
+
### `resolve <oc-path>`
|
|
403
|
+
|
|
404
|
+
Read a single leaf or node. Wildcards are rejected — use `find` for those.
|
|
405
|
+
Exits `0` on a match, `1` on a clean miss, `2` on a parse error or refused
|
|
406
|
+
pattern.
|
|
407
|
+
|
|
408
|
+
```bash
|
|
409
|
+
nodmix path resolve 'oc://AGENTS.md/tools/gh/risk' --human
|
|
410
|
+
nodmix path resolve 'oc://gateway.jsonc/server/port' --json
|
|
411
|
+
```
|
|
412
|
+
|
|
413
|
+
### `find <pattern>`
|
|
414
|
+
|
|
415
|
+
Enumerate every match for a wildcard / predicate / union pattern. Exits `0`
|
|
416
|
+
on at least one match, `1` on zero. File-slot wildcards are rejected with
|
|
417
|
+
`OC_PATH_FILE_WILDCARD_UNSUPPORTED` — pass a concrete file (multi-file
|
|
418
|
+
globbing is a follow-up feature).
|
|
419
|
+
|
|
420
|
+
```bash
|
|
421
|
+
nodmix path find 'oc://AGENTS.md/tools/**/risk'
|
|
422
|
+
nodmix path find 'oc://session.jsonl/[event=action]/userId'
|
|
423
|
+
nodmix path find 'oc://config.jsonc/plugins/{github,slack}/enabled'
|
|
424
|
+
```
|
|
425
|
+
|
|
426
|
+
### `set <oc-path> <value>`
|
|
427
|
+
|
|
428
|
+
Write a leaf. Pair with `--dry-run` to preview the bytes that would be
|
|
429
|
+
written without touching the file. Add `--diff` for a unified diff preview.
|
|
430
|
+
Exits `0` on a successful write, `1` if the substrate refuses (for example, a
|
|
431
|
+
sentinel guard hit), `2` on parse errors.
|
|
432
|
+
|
|
433
|
+
```bash
|
|
434
|
+
nodmix path set 'oc://gateway.jsonc/version' '2.0' --dry-run
|
|
435
|
+
nodmix path set 'oc://gateway.jsonc/version' '2.0' --dry-run --diff
|
|
436
|
+
nodmix path set 'oc://gateway.jsonc/version' '2.0'
|
|
437
|
+
nodmix path set 'oc://AGENTS.md/Tools/+gh/risk' 'low'
|
|
438
|
+
```
|
|
439
|
+
|
|
440
|
+
The `+key` insertion marker creates the named child if it does not already
|
|
441
|
+
exist; `+nnn` and bare `+` work for indexed and append insertion respectively.
|
|
442
|
+
|
|
443
|
+
### `validate <oc-path>`
|
|
444
|
+
|
|
445
|
+
Parse-only check. No filesystem access. Useful when you want to confirm a
|
|
446
|
+
template path is well-formed before substituting variables, or when you want
|
|
447
|
+
the structural breakdown for debugging:
|
|
448
|
+
|
|
449
|
+
```bash
|
|
450
|
+
$ nodmix path validate 'oc://AGENTS.md/tools/gh' --human
|
|
451
|
+
valid: oc://AGENTS.md/tools/gh
|
|
452
|
+
file: AGENTS.md
|
|
453
|
+
section: tools
|
|
454
|
+
item: gh
|
|
455
|
+
```
|
|
456
|
+
|
|
457
|
+
Exits `0` when valid, `1` when invalid (with a structured `code` and
|
|
458
|
+
`message`), `2` on argument errors.
|
|
459
|
+
|
|
460
|
+
### `emit <file>`
|
|
461
|
+
|
|
462
|
+
Round-trip a file through the per-kind parser and emitter. The output should
|
|
463
|
+
be byte-identical to the input on a sound file — divergence indicates a
|
|
464
|
+
parser bug or a sentinel hit. Useful for debugging substrate behavior on
|
|
465
|
+
real-world inputs.
|
|
466
|
+
|
|
467
|
+
```bash
|
|
468
|
+
nodmix path emit ./AGENTS.md
|
|
469
|
+
nodmix path emit ./gateway.jsonc --json
|
|
470
|
+
```
|
|
471
|
+
|
|
472
|
+
## Exit codes
|
|
473
|
+
|
|
474
|
+
| Code | Meaning |
|
|
475
|
+
| ---- | -------------------------------------------------------------------------- |
|
|
476
|
+
| `0` | Success. (`resolve` / `find`: at least one match. `set`: write succeeded.) |
|
|
477
|
+
| `1` | No match, or `set` rejected by the substrate (no system-level error). |
|
|
478
|
+
| `2` | Argument or parse error. |
|
|
479
|
+
|
|
480
|
+
## Output mode
|
|
481
|
+
|
|
482
|
+
`nodmix path` is TTY-aware: human-readable output on a terminal, JSON when
|
|
483
|
+
stdout is piped or redirected. `--json` and `--human` override the
|
|
484
|
+
auto-detection.
|
|
485
|
+
|
|
486
|
+
## Notes
|
|
487
|
+
|
|
488
|
+
- `set` writes bytes through the substrate's emit path, which applies the
|
|
489
|
+
redaction-sentinel guard automatically. A leaf carrying
|
|
490
|
+
`__NODMIX_REDACTED__` (verbatim or as a substring) is refused at write
|
|
491
|
+
time.
|
|
492
|
+
- JSONC parsing and leaf edits use the plugin-local `jsonc-parser`
|
|
493
|
+
dependency, so comments and formatting are preserved on ordinary leaf
|
|
494
|
+
writes instead of going through a hand-rolled parser/re-render path.
|
|
495
|
+
- `path` does not know about LKG. If the file is LKG-tracked, the next
|
|
496
|
+
observe call decides whether to promote / recover. `set --batch` for
|
|
497
|
+
atomic multi-set through the LKG promote/recover lifecycle is planned
|
|
498
|
+
alongside the LKG-recovery substrate.
|
|
499
|
+
|
|
500
|
+
## Related
|
|
501
|
+
|
|
502
|
+
- [CLI reference](/cli)
|