mia-code 0.2.0 → 0.3.0
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/.miette/260321.md +1 -0
- package/.miette/260323.md +9 -0
- package/.miette/260331.md +2 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/2604020008--d3417f2c-df12-4f0f-8a1b-d88e7968f822/d3417f2c-df12-4f0f-8a1b-d88e7968f822.md +63 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/2604020008--e6c3fc5d-4a70-4523-ba7d-a3250da4c235/e6c3fc5d-4a70-4523-ba7d-a3250da4c235.md +72 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/2604020008--efeb00a2-b17a-4d32-b1f0-b90c37a8d24e/efeb00a2-b17a-4d32-b1f0-b90c37a8d24e.md +62 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/83a2d7f9-24a5-4cf4-98d5-036c82f872e8.json +302 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/83a2d7f9-24a5-4cf4-98d5-036c82f872e8.md +149 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/AGENTS.md +31 -0
- package/.pde/2604011511--83a2d7f9-24a5-4cf4-98d5-036c82f872e8/meta-decomposition-3-children.md +67 -0
- package/.pde/2604040129--61f9dd4d-7aa6-45e6-a58b-e480b1aa6737/61f9dd4d-7aa6-45e6-a58b-e480b1aa6737--from-mia-openclaw-workspace.md +125 -0
- package/.pde/2604040129--61f9dd4d-7aa6-45e6-a58b-e480b1aa6737/STATUS.md +1 -0
- package/.pde/4f02ba94-9f52-422e-9389-b16f9b37f358.json +177 -0
- package/.pde/4f02ba94-9f52-422e-9389-b16f9b37f358.md +77 -0
- package/.pde/6ad9244d-5340-490f-b76c-c86728b9de52.json +222 -0
- package/.pde/6ad9244d-5340-490f-b76c-c86728b9de52.md +99 -0
- package/.pde/8b566792-ed15-4606-96f9-2b6f593d7e6b.json +111 -0
- package/.pde/8b566792-ed15-4606-96f9-2b6f593d7e6b.md +67 -0
- package/.pde/c7f1e74b-05a5-40e2-9f01-4cc48d2528f7.json +349 -0
- package/.pde/c7f1e74b-05a5-40e2-9f01-4cc48d2528f7.md +147 -0
- package/.pde/dfc00a78-1da0-4c09-8a16-c6982644051b.json +118 -0
- package/.pde/dfc00a78-1da0-4c09-8a16-c6982644051b.md +64 -0
- package/GUILLAUME.md +8 -0
- package/KINSHIP.md +9 -0
- package/MIA_CODE_ARCHITECTURE_REPORT.md +718 -0
- package/contextual_research/260119-MIA-CODE--98090899-8aff-4e11-9dc3-8b99466d1.md +1101 -0
- package/contextual_research/MIA.md +38 -0
- package/contextual_research/MIAWAPASCONE.md +59 -0
- package/contextual_research/MIETTE.md +38 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/2504.00218v2.pdf +7483 -12
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/2505.00212v3.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/CONTENT.md +1014 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/DESIGN.gemini.md +242 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/INDEX.md +45 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/2504.00218v2.md +2025 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/2504.00218v2.pdf +7483 -12
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/2505.00212v3.md +1755 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/2505.00212v3.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_12_decomposed_prompting.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_19_hugginggpt_planning.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_1_coordination_challenges.md +766 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_1_coordination_challenges.pdf +3431 -4
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_28_guardrails_multi_agent.md +260 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_28_guardrails_multi_agent.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_2_navigating_complexity.md +558 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_2_navigating_complexity.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_34_hierarchical_multi_agent.pdf +0 -0
- package/contextual_research/PDE-generalization--caefee82-efb1-4dbb-8733-691b01581464--260130/sources/footnote_1_5_open_intent_extraction.pdf +0 -0
- package/contextual_research/PODCAST.md +109 -0
- package/contextual_research/langchain-principles-roadmap.md +157 -0
- package/contextual_research/persona-to-narrative-character-inquiry_260201.md +50 -0
- package/dist/cli.js +35 -11
- package/dist/geminiHeadless.js +8 -2
- package/dist/index.js +2 -1
- package/dist/mcp/miaco-server.js +10 -1
- package/dist/mcp/miatel-server.js +10 -1
- package/dist/mcp/miawa-server.js +10 -1
- package/dist/mcp/utils.d.ts +6 -1
- package/dist/mcp/utils.js +24 -3
- package/dist/sessionStore.d.ts +8 -2
- package/dist/sessionStore.js +39 -3
- package/dist/types.d.ts +1 -0
- package/miaco/README.md +124 -0
- package/miaco/dist/commands/chart.d.ts +6 -0
- package/miaco/dist/commands/chart.d.ts.map +1 -0
- package/miaco/dist/commands/chart.js +222 -0
- package/miaco/dist/commands/chart.js.map +1 -0
- package/miaco/dist/commands/decompose.d.ts +6 -0
- package/miaco/dist/commands/decompose.d.ts.map +1 -0
- package/miaco/dist/commands/decompose.js +98 -0
- package/miaco/dist/commands/decompose.js.map +1 -0
- package/miaco/dist/commands/schema.d.ts +6 -0
- package/miaco/dist/commands/schema.d.ts.map +1 -0
- package/miaco/dist/commands/schema.js +66 -0
- package/miaco/dist/commands/schema.js.map +1 -0
- package/miaco/dist/commands/stc.d.ts +11 -0
- package/miaco/dist/commands/stc.d.ts.map +1 -0
- package/miaco/dist/commands/stc.js +590 -0
- package/miaco/dist/commands/stc.js.map +1 -0
- package/miaco/dist/commands/trace.d.ts +6 -0
- package/miaco/dist/commands/trace.d.ts.map +1 -0
- package/miaco/dist/commands/trace.js +83 -0
- package/miaco/dist/commands/trace.js.map +1 -0
- package/miaco/dist/commands/validate.d.ts +6 -0
- package/miaco/dist/commands/validate.d.ts.map +1 -0
- package/miaco/dist/commands/validate.js +58 -0
- package/miaco/dist/commands/validate.js.map +1 -0
- package/miaco/dist/decompose.d.ts +93 -0
- package/miaco/dist/decompose.d.ts.map +1 -0
- package/miaco/dist/decompose.js +562 -0
- package/miaco/dist/decompose.js.map +1 -0
- package/miaco/dist/index.d.ts +18 -0
- package/miaco/dist/index.d.ts.map +1 -0
- package/miaco/dist/index.js +83 -0
- package/miaco/dist/index.js.map +1 -0
- package/miaco/dist/storage.d.ts +60 -0
- package/miaco/dist/storage.d.ts.map +1 -0
- package/miaco/dist/storage.js +100 -0
- package/miaco/dist/storage.js.map +1 -0
- package/miaco/package-lock.json +4103 -0
- package/miaco/package.json +40 -0
- package/miaco/tsconfig.json +18 -0
- package/miaco/version-patch-commit-and-publish.sh +1 -0
- package/miatel/MISSION_251231.md +3 -0
- package/miatel/README.md +107 -0
- package/miatel/dist/commands/analyze.d.ts +6 -0
- package/miatel/dist/commands/analyze.d.ts.map +1 -0
- package/miatel/dist/commands/analyze.js +100 -0
- package/miatel/dist/commands/analyze.js.map +1 -0
- package/miatel/dist/commands/arc.d.ts +6 -0
- package/miatel/dist/commands/arc.d.ts.map +1 -0
- package/miatel/dist/commands/arc.js +71 -0
- package/miatel/dist/commands/arc.js.map +1 -0
- package/miatel/dist/commands/beat.d.ts +6 -0
- package/miatel/dist/commands/beat.d.ts.map +1 -0
- package/miatel/dist/commands/beat.js +165 -0
- package/miatel/dist/commands/beat.js.map +1 -0
- package/miatel/dist/commands/theme.d.ts +6 -0
- package/miatel/dist/commands/theme.d.ts.map +1 -0
- package/miatel/dist/commands/theme.js +54 -0
- package/miatel/dist/commands/theme.js.map +1 -0
- package/miatel/dist/index.d.ts +18 -0
- package/miatel/dist/index.d.ts.map +1 -0
- package/miatel/dist/index.js +80 -0
- package/miatel/dist/index.js.map +1 -0
- package/miatel/dist/storage.d.ts +55 -0
- package/miatel/dist/storage.d.ts.map +1 -0
- package/miatel/dist/storage.js +100 -0
- package/miatel/dist/storage.js.map +1 -0
- package/miatel/package-lock.json +4103 -0
- package/miatel/package.json +35 -0
- package/miatel/src/commands/analyze.ts +109 -0
- package/miatel/src/commands/arc.ts +78 -0
- package/miatel/src/commands/beat.ts +176 -0
- package/miatel/src/commands/theme.ts +60 -0
- package/miatel/src/index.ts +94 -0
- package/miatel/src/storage.ts +156 -0
- package/miatel/tsconfig.json +18 -0
- package/miawa/MISSION_251231.md +144 -0
- package/miawa/README.md +133 -0
- package/miawa/dist/commands/beat.d.ts +6 -0
- package/miawa/dist/commands/beat.d.ts.map +1 -0
- package/miawa/dist/commands/beat.js +69 -0
- package/miawa/dist/commands/beat.js.map +1 -0
- package/miawa/dist/commands/ceremony.d.ts +6 -0
- package/miawa/dist/commands/ceremony.d.ts.map +1 -0
- package/miawa/dist/commands/ceremony.js +239 -0
- package/miawa/dist/commands/ceremony.js.map +1 -0
- package/miawa/dist/commands/circle.d.ts +6 -0
- package/miawa/dist/commands/circle.d.ts.map +1 -0
- package/miawa/dist/commands/circle.js +75 -0
- package/miawa/dist/commands/circle.js.map +1 -0
- package/miawa/dist/commands/eva.d.ts +6 -0
- package/miawa/dist/commands/eva.d.ts.map +1 -0
- package/miawa/dist/commands/eva.js +73 -0
- package/miawa/dist/commands/eva.js.map +1 -0
- package/miawa/dist/commands/wound.d.ts +6 -0
- package/miawa/dist/commands/wound.d.ts.map +1 -0
- package/miawa/dist/commands/wound.js +74 -0
- package/miawa/dist/commands/wound.js.map +1 -0
- package/miawa/dist/index.d.ts +19 -0
- package/miawa/dist/index.d.ts.map +1 -0
- package/miawa/dist/index.js +91 -0
- package/miawa/dist/index.js.map +1 -0
- package/miawa/dist/storage.d.ts +73 -0
- package/miawa/dist/storage.d.ts.map +1 -0
- package/miawa/dist/storage.js +100 -0
- package/miawa/dist/storage.js.map +1 -0
- package/miawa/package-lock.json +4103 -0
- package/miawa/package.json +36 -0
- package/miawa/src/commands/beat.ts +74 -0
- package/miawa/src/commands/ceremony.ts +256 -0
- package/miawa/src/commands/circle.ts +83 -0
- package/miawa/src/commands/eva.ts +84 -0
- package/miawa/src/commands/wound.ts +79 -0
- package/miawa/src/index.ts +108 -0
- package/miawa/src/storage.ts +179 -0
- package/miawa/tsconfig.json +18 -0
- package/package.json +7 -5
- package/references/acp/CLAUDE.md +7 -0
- package/references/acp/agent-plan.md +84 -0
- package/references/acp/clients.md +31 -0
- package/references/acp/extensibility.md +137 -0
- package/references/acp/initialization.md +225 -0
- package/references/acp/prompt-turn.md +321 -0
- package/references/acp/proxy-chains.md +562 -0
- package/references/acp/schema.md +3171 -0
- package/references/acp/session-list.md +334 -0
- package/references/acp/session-modes.md +170 -0
- package/references/acp/slash-commands.md +99 -0
- package/references/acp/terminals.md +281 -0
- package/references/acp/tool-calls.md +311 -0
- package/references/acp/typescript.md +29 -0
- package/references/claude/agent-teams.md +399 -0
- package/references/claude/chrome.md +231 -0
- package/references/claude/headless.md +158 -0
- package/references/claude/hooks-guide.md +708 -0
- package/references/claude/output-styles.md +112 -0
- package/references/claude/plugins.md +432 -0
- package/references/claude/skills.md +693 -0
- package/references/claude/sub-agents.md +816 -0
- package/references/copilot/acp/agents.md +32 -0
- package/references/copilot/acp/architecture.md +37 -0
- package/references/copilot/acp/clients.md +31 -0
- package/references/copilot/acp/introduction.md +42 -0
- package/references/copilot/acp/registry.md +339 -0
- package/references/copilot/acp-server.md +117 -0
- package/references/copilot/create-copilot-instructions.md +840 -0
- package/references/langchain/llms.txt +833 -0
- package/references/langchain/python/agents.md +677 -0
- package/references/langchain/python/context-engineering.md +1195 -0
- package/references/langchain/python/human-in-the-loop.md +326 -0
- package/references/langchain/python/long-term-memory.md +168 -0
- package/references/langchain/python/mcp.md +949 -0
- package/references/langchain/python/multi-agents/custom-workflow.md +187 -0
- package/references/langchain/python/multi-agents/handoffs.md +436 -0
- package/references/langchain/python/multi-agents/overview.md +295 -0
- package/references/langchain/python/multi-agents/router.md +150 -0
- package/references/langchain/python/multi-agents/skills.md +92 -0
- package/references/langchain/python/multi-agents/subagents.md +486 -0
- package/references/langchain/python/retrieval.md +320 -0
- package/references/langchain/python/runtime.md +141 -0
- package/references/langchain/python/short-term-memory.md +658 -0
- package/references/langchain/python/structured-output.md +712 -0
- package/references/langfuse/llms.txt +148 -0
- package/references/langgraph/javascript/llms.txt +275 -0
- package/references/skills/home.md +259 -0
- package/references/skills/integrate-skills.md +103 -0
- package/references/skills/specification.md +254 -0
- package/references/skills/what-are-skills.md +74 -0
- package/rispecs/README.md +164 -0
- package/rispecs/_sync_/miadi-code/SPEC.md +313 -0
- package/rispecs/_sync_/miadi-code/STATUS.md +177 -0
- package/rispecs/_sync_/miadi-code/dashboard/SPEC.md +465 -0
- package/rispecs/_sync_/miadi-code/dashboard/STATUS.md +212 -0
- package/rispecs/_sync_/miadi-code/multiline-input/SPEC.md +232 -0
- package/rispecs/_sync_/miadi-code/multiline-input/STATUS.md +108 -0
- package/rispecs/_sync_/miadi-code/pde/SPEC.md +253 -0
- package/rispecs/_sync_/miadi-code/pde/STATUS.md +56 -0
- package/rispecs/_sync_/miadi-code/stc/SPEC.md +397 -0
- package/rispecs/_sync_/miadi-code/stc/STATUS.md +70 -0
- package/rispecs/ava-langstack/inquiry-routing-upgrade.spec.md +119 -0
- package/rispecs/borrowed_from_opencode/001-client-server-architecture.rispec.md +98 -0
- package/rispecs/borrowed_from_opencode/002-event-bus-system.rispec.md +125 -0
- package/rispecs/borrowed_from_opencode/003-instance-state-pattern.rispec.md +136 -0
- package/rispecs/borrowed_from_opencode/004-namespace-module-pattern.rispec.md +151 -0
- package/rispecs/borrowed_from_opencode/005-zod-schema-validation.rispec.md +139 -0
- package/rispecs/borrowed_from_opencode/006-named-error-system.rispec.md +155 -0
- package/rispecs/borrowed_from_opencode/007-structured-logging.rispec.md +138 -0
- package/rispecs/borrowed_from_opencode/008-lazy-initialization.rispec.md +127 -0
- package/rispecs/borrowed_from_opencode/009-multi-agent-system.rispec.md +97 -0
- package/rispecs/borrowed_from_opencode/010-agent-definition-config.rispec.md +135 -0
- package/rispecs/borrowed_from_opencode/011-agent-permission-rulesets.rispec.md +151 -0
- package/rispecs/borrowed_from_opencode/012-agent-prompt-templates.rispec.md +141 -0
- package/rispecs/borrowed_from_opencode/013-agent-generation.rispec.md +142 -0
- package/rispecs/borrowed_from_opencode/014-plan-build-mode-toggle.rispec.md +155 -0
- package/rispecs/borrowed_from_opencode/015-subagent-task-delegation.rispec.md +146 -0
- package/rispecs/borrowed_from_opencode/016-agent-model-selection.rispec.md +151 -0
- package/rispecs/borrowed_from_opencode/017-compaction-agent.rispec.md +150 -0
- package/rispecs/borrowed_from_opencode/018-session-persistence.rispec.md +125 -0
- package/rispecs/borrowed_from_opencode/019-session-compaction.rispec.md +132 -0
- package/rispecs/borrowed_from_opencode/020-session-forking.rispec.md +134 -0
- package/rispecs/borrowed_from_opencode/021-session-revert-snapshot.rispec.md +135 -0
- package/rispecs/borrowed_from_opencode/022-session-sharing.rispec.md +165 -0
- package/rispecs/borrowed_from_opencode/023-session-summary-diffs.rispec.md +165 -0
- package/rispecs/borrowed_from_opencode/024-child-sessions.rispec.md +164 -0
- package/rispecs/borrowed_from_opencode/025-session-title-generation.rispec.md +162 -0
- package/rispecs/borrowed_from_opencode/026-message-parts-model.rispec.md +201 -0
- package/rispecs/borrowed_from_opencode/027-streaming-message-deltas.rispec.md +212 -0
- package/rispecs/borrowed_from_opencode/028-multi-provider-architecture.rispec.md +184 -0
- package/rispecs/borrowed_from_opencode/029-provider-authentication.rispec.md +225 -0
- package/rispecs/borrowed_from_opencode/030-model-registry.rispec.md +222 -0
- package/rispecs/borrowed_from_opencode/031-cost-tracking.rispec.md +243 -0
- package/rispecs/borrowed_from_opencode/032-provider-transform-pipeline.rispec.md +282 -0
- package/rispecs/borrowed_from_opencode/033-provider-sdk-abstraction.rispec.md +338 -0
- package/rispecs/borrowed_from_opencode/034-tool-registry.rispec.md +110 -0
- package/rispecs/borrowed_from_opencode/035-tool-context-injection.rispec.md +155 -0
- package/rispecs/borrowed_from_opencode/036-tool-output-truncation.rispec.md +138 -0
- package/rispecs/borrowed_from_opencode/037-batch-tool.rispec.md +129 -0
- package/rispecs/borrowed_from_opencode/038-multi-edit-tool.rispec.md +167 -0
- package/rispecs/borrowed_from_opencode/039-apply-patch-tool.rispec.md +161 -0
- package/rispecs/borrowed_from_opencode/040-code-search-tool.rispec.md +143 -0
- package/rispecs/borrowed_from_opencode/041-web-fetch-tool.rispec.md +131 -0
- package/rispecs/borrowed_from_opencode/042-web-search-tool.rispec.md +159 -0
- package/rispecs/borrowed_from_opencode/043-todo-tool.rispec.md +156 -0
- package/rispecs/borrowed_from_opencode/044-plan-mode-tool.rispec.md +139 -0
- package/rispecs/borrowed_from_opencode/045-task-tool.rispec.md +146 -0
- package/rispecs/borrowed_from_opencode/046-question-tool.rispec.md +170 -0
- package/rispecs/borrowed_from_opencode/047-external-directory-tool.rispec.md +166 -0
- package/rispecs/borrowed_from_opencode/048-file-read-write-tools.rispec.md +205 -0
- package/rispecs/borrowed_from_opencode/049-lsp-server-management.rispec.md +104 -0
- package/rispecs/borrowed_from_opencode/050-lsp-hover-completion.rispec.md +102 -0
- package/rispecs/borrowed_from_opencode/051-lsp-diagnostics.rispec.md +86 -0
- package/rispecs/borrowed_from_opencode/052-lsp-root-detection.rispec.md +109 -0
- package/rispecs/borrowed_from_opencode/053-remote-mcp-servers.rispec.md +119 -0
- package/rispecs/borrowed_from_opencode/054-mcp-oauth-flow.rispec.md +107 -0
- package/rispecs/borrowed_from_opencode/055-mcp-tool-conversion.rispec.md +118 -0
- package/rispecs/borrowed_from_opencode/056-mcp-connection-monitoring.rispec.md +106 -0
- package/rispecs/borrowed_from_opencode/057-local-mcp-servers.rispec.md +116 -0
- package/rispecs/borrowed_from_opencode/058-rich-tui.rispec.md +108 -0
- package/rispecs/borrowed_from_opencode/059-streaming-display.rispec.md +116 -0
- package/rispecs/borrowed_from_opencode/060-permission-prompts.rispec.md +130 -0
- package/rispecs/borrowed_from_opencode/061-session-navigation.rispec.md +155 -0
- package/rispecs/borrowed_from_opencode/062-syntax-highlighting.rispec.md +151 -0
- package/rispecs/borrowed_from_opencode/063-keybinding-system.rispec.md +181 -0
- package/rispecs/borrowed_from_opencode/064-multi-level-config.rispec.md +155 -0
- package/rispecs/borrowed_from_opencode/065-jsonc-config.rispec.md +190 -0
- package/rispecs/borrowed_from_opencode/066-config-env-variables.rispec.md +153 -0
- package/rispecs/borrowed_from_opencode/067-config-deep-merging.rispec.md +178 -0
- package/rispecs/borrowed_from_opencode/068-remote-org-config.rispec.md +183 -0
- package/rispecs/borrowed_from_opencode/069-config-markdown-frontmatter.rispec.md +206 -0
- package/rispecs/borrowed_from_opencode/070-managed-config-directory.rispec.md +232 -0
- package/rispecs/borrowed_from_opencode/071-plugin-architecture.rispec.md +104 -0
- package/rispecs/borrowed_from_opencode/072-plugin-hooks.rispec.md +123 -0
- package/rispecs/borrowed_from_opencode/073-plugin-auto-install.rispec.md +115 -0
- package/rispecs/borrowed_from_opencode/074-permission-system.rispec.md +133 -0
- package/rispecs/borrowed_from_opencode/075-git-worktree-management.rispec.md +126 -0
- package/rispecs/borrowed_from_opencode/076-snapshot-system.rispec.md +124 -0
- package/rispecs/borrowed_from_opencode/077-snapshot-diff.rispec.md +117 -0
- package/rispecs/borrowed_from_opencode/078-snapshot-restore.rispec.md +128 -0
- package/rispecs/borrowed_from_opencode/079-worktree-branch-naming.rispec.md +122 -0
- package/rispecs/borrowed_from_opencode/080-sqlite-storage.rispec.md +134 -0
- package/rispecs/borrowed_from_opencode/081-database-migrations.rispec.md +148 -0
- package/rispecs/borrowed_from_opencode/082-database-transactions.rispec.md +138 -0
- package/rispecs/borrowed_from_opencode/083-deferred-effects.rispec.md +148 -0
- package/rispecs/borrowed_from_opencode/084-permission-rules.rispec.md +123 -0
- package/rispecs/borrowed_from_opencode/085-permission-glob-patterns.rispec.md +113 -0
- package/rispecs/borrowed_from_opencode/086-permission-merging.rispec.md +134 -0
- package/rispecs/borrowed_from_opencode/087-permission-modes.rispec.md +145 -0
- package/rispecs/borrowed_from_opencode/088-http-api-server.rispec.md +165 -0
- package/rispecs/borrowed_from_opencode/089-openapi-spec-generation.rispec.md +164 -0
- package/rispecs/borrowed_from_opencode/090-websocket-support.rispec.md +136 -0
- package/rispecs/borrowed_from_opencode/091-sse-streaming.rispec.md +168 -0
- package/rispecs/borrowed_from_opencode/092-mdns-discovery.rispec.md +145 -0
- package/rispecs/borrowed_from_opencode/093-javascript-sdk.rispec.md +200 -0
- package/rispecs/borrowed_from_opencode/094-skill-system.rispec.md +187 -0
- package/rispecs/borrowed_from_opencode/095-skill-discovery.rispec.md +182 -0
- package/rispecs/borrowed_from_opencode/096-desktop-remote-driving.rispec.md +175 -0
- package/rispecs/borrowed_from_opencode/INDEX.md +255 -0
- package/rispecs/core.rispecs.md +261 -0
- package/rispecs/engines.rispecs.md +241 -0
- package/rispecs/formatting.rispecs.md +252 -0
- package/rispecs/living-specifications.rispecs.md +361 -0
- package/rispecs/mcp.rispecs.md +197 -0
- package/rispecs/pde.rispecs.md +399 -0
- package/rispecs/pi-mono-envisionning/ENVISIONING.md +366 -0
- package/rispecs/pi-mono-envisionning/storytelling-horizon.rispecs.md +76 -0
- package/rispecs/pi-mono-envisionning/widget.rispecs.md +2 -0
- package/rispecs/relation-to-mcp-structural-thinking.kin.md +72 -0
- package/rispecs/research-for-better-framework/CLAUDE.md +7 -0
- package/rispecs/research-for-better-framework/survey-pi-openclaw-opencode-openhands.md +210 -0
- package/rispecs/session.rispecs.md +277 -0
- package/rispecs/stc.rispecs.md +138 -0
- package/rispecs/unifier.rispecs.md +317 -0
- package/scripts/LAUNCH--mcp-mia-code--testing--2603141315--ac705a66-2c15-4a1c-a26d-9491018c5ba8.sh +2 -0
- package/scripts/RESUME--mia-code--mcps--260313--ac705a66-2c15-4a1c-a26d-9491018c5ba8.sh +1 -0
- package/scripts/install-widget-in-home-pi-agent-extensions.sh +4 -0
- package/scripts/sample-decompose--2604011535-prompt.sh +1 -0
- package/skills/deep-search/AGENTS.md +17 -0
- package/skills/deep-search/SKILL.md +281 -0
- package/skills/deep-search/agent-templates.md +224 -0
- package/skills/deep-search/orchestration-patterns.md +95 -0
- package/skills/miaco-pde-inquiry-routing-deep-search/AGENTS.md +13 -0
- package/skills/miaco-pde-inquiry-routing-deep-search/SKILL.md +136 -0
- package/skills/miaco-pde-inquiry-routing-internal-external-relationship/AGENTS.md +4 -0
- package/skills/miaco-pde-inquiry-routing-internal-external-relationship/SKILL.md +157 -0
- package/skills/miaco-pde-inquiry-routing-local-qmd/AGENTS.md +42 -0
- package/skills/miaco-pde-inquiry-routing-local-qmd/SKILL.md +135 -0
- package/skills/qmd/AGENTS.md +3 -0
- package/skills/qmd/SKILL.md +144 -0
- package/skills/qmd/references/mcp-setup.md +102 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/SKILL.md +234 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/agent-templates.md +436 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/orchestration-patterns.md +197 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/references/ceremonial-technology.md +102 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/references/creative-orientation.md +99 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/references/prompt-decomposition.md +73 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/references/rise-framework.md +74 -0
- package/skills/rise-pde-inquiry-session-multi-agents-v3/references/structural-tension.md +82 -0
- package/src/cli.ts +35 -11
- package/src/geminiHeadless.ts +7 -2
- package/src/index.ts +2 -1
- package/src/mcp/miaco-server.ts +13 -1
- package/src/mcp/miatel-server.ts +13 -1
- package/src/mcp/miawa-server.ts +13 -1
- package/src/mcp/utils.ts +41 -8
- package/src/sessionStore.ts +44 -4
- package/src/types.ts +2 -1
- package/widget/mia-ceremony/README.md +36 -0
- package/widget/mia-ceremony/index.ts +143 -0
- package/widget/mia-interceptor/README.md +39 -0
- package/widget/mia-interceptor/index.ts +221 -0
- package/widget/mia-tools/README.md +37 -0
- package/widget/mia-tools/index.ts +569 -0
- package/widget/miette-echo/README.md +44 -0
- package/widget/miette-echo/index.ts +164 -0
- package/.claude/settings.local.json +0 -9
- package/.hch/issue_.env +0 -4
- package/.hch/issue_add__2601211715.json +0 -77
- package/.hch/issue_add__2601211715.md +0 -4
- package/.hch/issue_add__2602242020.json +0 -78
- package/.hch/issue_add__2602242020.md +0 -7
- package/.hch/issues.json +0 -2312
- package/.hch/issues.md +0 -30
- package/WS__mia-code__260214__IAIP_PDE.code-workspace +0 -29
- package/WS__mia-code__src332__260122.code-workspace +0 -23
- package/samples/copilot/session-state/be76abaa-a27f-4725-b2a9-22fb45f7e0f7/checkpoints/index.md +0 -6
- package/samples/copilot/session-state/be76abaa-a27f-4725-b2a9-22fb45f7e0f7/events.jsonl +0 -213
- package/samples/copilot/session-state/be76abaa-a27f-4725-b2a9-22fb45f7e0f7/plan.md +0 -243
- package/samples/copilot/session-state/be76abaa-a27f-4725-b2a9-22fb45f7e0f7/workspace.yaml +0 -5
|
@@ -0,0 +1,486 @@
|
|
|
1
|
+
> ## Documentation Index
|
|
2
|
+
> Fetch the complete documentation index at: https://docs.langchain.com/llms.txt
|
|
3
|
+
> Use this file to discover all available pages before exploring further.
|
|
4
|
+
|
|
5
|
+
# Subagents
|
|
6
|
+
|
|
7
|
+
In the **subagents** architecture, a central main [agent](/oss/python/langchain/agents) (often referred to as a **supervisor**) coordinates subagents by calling them as [tools](/oss/python/langchain/tools). The main agent decides which subagent to invoke, what input to provide, and how to combine results. Subagents are stateless—they don't remember past interactions, with all conversation memory maintained by the main agent. This provides [context](/oss/python/langchain/context-engineering) isolation: each subagent invocation works in a clean context window, preventing context bloat in the main conversation.
|
|
8
|
+
|
|
9
|
+
```mermaid theme={null}
|
|
10
|
+
graph LR
|
|
11
|
+
A[User] --> B[Main Agent]
|
|
12
|
+
B --> C[Subagent A]
|
|
13
|
+
B --> D[Subagent B]
|
|
14
|
+
B --> E[Subagent C]
|
|
15
|
+
C --> B
|
|
16
|
+
D --> B
|
|
17
|
+
E --> B
|
|
18
|
+
B --> F[User response]
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## Key characteristics
|
|
22
|
+
|
|
23
|
+
* Centralized control: All routing passes through the main agent
|
|
24
|
+
* No direct user interaction: Subagents return results to the main agent, not the user (though you can use [interrupts](/oss/python/langgraph/human-in-the-loop#interrupt) within a subagent to allow user interaction)
|
|
25
|
+
* Subagents via tools: Subagents are invoked via tools
|
|
26
|
+
* Parallel execution: The main agent can invoke multiple subagents in a single turn
|
|
27
|
+
|
|
28
|
+
<Note>
|
|
29
|
+
**Supervisor vs. Router**: A supervisor agent (this pattern) is different from a [router](/oss/python/langchain/multi-agent/router). The supervisor is a full agent that maintains conversation context and dynamically decides which subagents to call across multiple turns. A router is typically a single classification step that dispatches to agents without maintaining ongoing conversation state.
|
|
30
|
+
</Note>
|
|
31
|
+
|
|
32
|
+
## When to use
|
|
33
|
+
|
|
34
|
+
Use the subagents pattern when you have multiple distinct domains (e.g., calendar, email, CRM, database), subagents don't need to converse directly with users, or you want centralized workflow control. For simpler cases with just a few [tools](/oss/python/langchain/tools), use a [single agent](/oss/python/langchain/agents).
|
|
35
|
+
|
|
36
|
+
<Tip>
|
|
37
|
+
**Need user interaction within a subagent?** While subagents typically return results to the main agent rather than conversing directly with users, you can use [interrupts](/oss/python/langgraph/human-in-the-loop#interrupt) within a subagent to pause execution and gather user input. This is useful when a subagent needs clarification or approval before proceeding. The main agent remains the orchestrator, but the subagent can collect information from the user mid-task.
|
|
38
|
+
</Tip>
|
|
39
|
+
|
|
40
|
+
## Basic implementation
|
|
41
|
+
|
|
42
|
+
The core mechanism wraps a subagent as a tool that the main agent can call:
|
|
43
|
+
|
|
44
|
+
```python theme={null}
|
|
45
|
+
from langchain.tools import tool
|
|
46
|
+
from langchain.agents import create_agent
|
|
47
|
+
|
|
48
|
+
# Create a subagent
|
|
49
|
+
subagent = create_agent(model="anthropic:claude-sonnet-4-20250514", tools=[...])
|
|
50
|
+
|
|
51
|
+
# Wrap it as a tool
|
|
52
|
+
@tool("research", description="Research a topic and return findings")
|
|
53
|
+
def call_research_agent(query: str):
|
|
54
|
+
result = subagent.invoke({"messages": [{"role": "user", "content": query}]})
|
|
55
|
+
return result["messages"][-1].content
|
|
56
|
+
|
|
57
|
+
# Main agent with subagent as a tool
|
|
58
|
+
main_agent = create_agent(model="anthropic:claude-sonnet-4-20250514", tools=[call_research_agent])
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
<Card title="Tutorial: Build a personal assistant with subagents" icon="sitemap" href="/oss/python/langchain/multi-agent/subagents-personal-assistant" arrow cta="Learn more">
|
|
62
|
+
Learn how to build a personal assistant using the subagents pattern, where a central main agent (supervisor) coordinates specialized worker agents.
|
|
63
|
+
</Card>
|
|
64
|
+
|
|
65
|
+
## Design decisions
|
|
66
|
+
|
|
67
|
+
When implementing the subagents pattern, you'll make several key design choices. This table summarizes the options—each is covered in detail in the sections below.
|
|
68
|
+
|
|
69
|
+
| Decision | Options |
|
|
70
|
+
| ----------------------------------------- | -------------------------------------------------------------------------------------- |
|
|
71
|
+
| [**Sync vs. async**](#sync-vs-async) | Sync (blocking) vs. async (background) |
|
|
72
|
+
| [**Tool patterns**](#tool-patterns) | Tool per agent vs. single dispatch tool |
|
|
73
|
+
| [**Subagent specs**](#subagent-specs) | System prompt vs. enum constraint vs. tool-based discovery (single dispatch tool only) |
|
|
74
|
+
| [**Subagent inputs**](#subagent-inputs) | Query only vs. full context |
|
|
75
|
+
| [**Subagent outputs**](#subagent-outputs) | Subagent result vs full conversation history |
|
|
76
|
+
|
|
77
|
+
## Sync vs. async
|
|
78
|
+
|
|
79
|
+
Subagent execution can be **synchronous** (blocking) or **asynchronous** (background). Your choice depends on whether the main agent needs the result to continue.
|
|
80
|
+
|
|
81
|
+
| Mode | Main agent behavior | Best for | Tradeoff |
|
|
82
|
+
| --------- | ------------------------------------------- | -------------------------------------- | ----------------------------------- |
|
|
83
|
+
| **Sync** | Waits for subagent to complete | Main agent needs result to continue | Simple, but blocks the conversation |
|
|
84
|
+
| **Async** | Continues while subagent runs in background | Independent tasks, user shouldn't wait | Responsive, but more complex |
|
|
85
|
+
|
|
86
|
+
<Tip>
|
|
87
|
+
Not to be confused with Python's `async`/`await`. Here, "async" means the main agent kicks off a background job (typically in a separate process or service) and continues without blocking.
|
|
88
|
+
</Tip>
|
|
89
|
+
|
|
90
|
+
### Synchronous (default)
|
|
91
|
+
|
|
92
|
+
By default, subagent calls are **synchronous**—the main agent waits for each subagent to complete before continuing. Use sync when the main agent's next action depends on the subagent's result.
|
|
93
|
+
|
|
94
|
+
```mermaid theme={null}
|
|
95
|
+
sequenceDiagram
|
|
96
|
+
participant User
|
|
97
|
+
participant Main Agent
|
|
98
|
+
participant Research Subagent
|
|
99
|
+
|
|
100
|
+
User->>Main Agent: "What's the weather in Tokyo?"
|
|
101
|
+
Main Agent->>Research Subagent: research("Tokyo weather")
|
|
102
|
+
Note over Main Agent: Waiting for result...
|
|
103
|
+
Research Subagent-->>Main Agent: "Currently 72°F, sunny"
|
|
104
|
+
Main Agent-->>User: "It's 72°F and sunny in Tokyo"
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
**When to use sync:**
|
|
108
|
+
|
|
109
|
+
* Main agent needs the subagent's result to formulate its response
|
|
110
|
+
* Tasks have order dependencies (e.g., fetch data → analyze → respond)
|
|
111
|
+
* Subagent failures should block the main agent's response
|
|
112
|
+
|
|
113
|
+
**Tradeoffs:**
|
|
114
|
+
|
|
115
|
+
* Simple implementation—just call and wait
|
|
116
|
+
* User sees no response until all subagents complete
|
|
117
|
+
* Long-running tasks freeze the conversation
|
|
118
|
+
|
|
119
|
+
### Asynchronous
|
|
120
|
+
|
|
121
|
+
Use **asynchronous execution** when the subagent's work is independent—the main agent doesn't need the result to continue conversing with the user. The main agent kicks off a background job and remains responsive.
|
|
122
|
+
|
|
123
|
+
```mermaid theme={null}
|
|
124
|
+
sequenceDiagram
|
|
125
|
+
participant User
|
|
126
|
+
participant Main Agent
|
|
127
|
+
participant Job System
|
|
128
|
+
participant Contract Reviewer
|
|
129
|
+
|
|
130
|
+
User->>Main Agent: "Review this M&A contract"
|
|
131
|
+
Main Agent->>Job System: run_agent("legal_reviewer", task)
|
|
132
|
+
Job System->>Contract Reviewer: Start agent
|
|
133
|
+
Job System-->>Main Agent: job_id: "job_123"
|
|
134
|
+
Main Agent-->>User: "Started review (job_123)"
|
|
135
|
+
|
|
136
|
+
Note over Contract Reviewer: Reviewing 150+ pages...
|
|
137
|
+
|
|
138
|
+
User->>Main Agent: "What's the status?"
|
|
139
|
+
Main Agent->>Job System: check_status(job_id)
|
|
140
|
+
Job System-->>Main Agent: "running"
|
|
141
|
+
Main Agent-->>User: "Still reviewing contract..."
|
|
142
|
+
|
|
143
|
+
Note over Contract Reviewer: Review completes
|
|
144
|
+
|
|
145
|
+
User->>Main Agent: "Is it done yet?"
|
|
146
|
+
Main Agent->>Job System: check_status(job_id)
|
|
147
|
+
Job System-->>Main Agent: "completed"
|
|
148
|
+
Main Agent->>Job System: get_result(job_id)
|
|
149
|
+
Job System-->>Main Agent: Contract analysis
|
|
150
|
+
Main Agent-->>User: "Review complete: [findings]"
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
**When to use async:**
|
|
154
|
+
|
|
155
|
+
* Subagent work is independent of the main conversation flow
|
|
156
|
+
* Users should be able to continue chatting while work happens
|
|
157
|
+
* You want to run multiple independent tasks in parallel
|
|
158
|
+
|
|
159
|
+
**Three-tool pattern:**
|
|
160
|
+
|
|
161
|
+
1. **Start job**: Kicks off the background task, returns a job ID
|
|
162
|
+
2. **Check status**: Returns current state (pending, running, completed, failed)
|
|
163
|
+
3. **Get result**: Retrieves the completed result
|
|
164
|
+
|
|
165
|
+
**Handling job completion:** When a job finishes, your application needs to notify the user. One approach: surface a notification that, when clicked, sends a `HumanMessage` like "Check job\_123 and summarize the results."
|
|
166
|
+
|
|
167
|
+
## Tool patterns
|
|
168
|
+
|
|
169
|
+
There are two main ways to expose subagents as tools:
|
|
170
|
+
|
|
171
|
+
| Pattern | Best for | Trade-off |
|
|
172
|
+
| ------------------------------------------------- | ------------------------------------------------------------- | ------------------------------------------------- |
|
|
173
|
+
| [**Tool per agent**](#tool-per-agent) | Fine-grained control over each subagent's input/output | More setup, but more customization |
|
|
174
|
+
| [**Single dispatch tool**](#single-dispatch-tool) | Many agents, distributed teams, convention over configuration | Simpler composition, less per-agent customization |
|
|
175
|
+
|
|
176
|
+
### Tool per agent
|
|
177
|
+
|
|
178
|
+
```mermaid theme={null}
|
|
179
|
+
graph LR
|
|
180
|
+
A[User] --> B[Main Agent]
|
|
181
|
+
B --> C[Subagent A]
|
|
182
|
+
B --> D[Subagent B]
|
|
183
|
+
B --> E[Subagent C]
|
|
184
|
+
C --> B
|
|
185
|
+
D --> B
|
|
186
|
+
E --> B
|
|
187
|
+
B --> F[User response]
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
The key idea is wrapping subagents as tools that the main agent can call:
|
|
191
|
+
|
|
192
|
+
```python theme={null}
|
|
193
|
+
from langchain.tools import tool
|
|
194
|
+
from langchain.agents import create_agent
|
|
195
|
+
|
|
196
|
+
# Create a sub-agent
|
|
197
|
+
subagent = create_agent(model="...", tools=[...]) # [!code highlight]
|
|
198
|
+
|
|
199
|
+
# Wrap it as a tool # [!code highlight]
|
|
200
|
+
@tool("subagent_name", description="subagent_description") # [!code highlight]
|
|
201
|
+
def call_subagent(query: str): # [!code highlight]
|
|
202
|
+
result = subagent.invoke({"messages": [{"role": "user", "content": query}]})
|
|
203
|
+
return result["messages"][-1].content
|
|
204
|
+
|
|
205
|
+
# Main agent with subagent as a tool # [!code highlight]
|
|
206
|
+
main_agent = create_agent(model="...", tools=[call_subagent]) # [!code highlight]
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
The main agent invokes the subagent tool when it decides the task matches the subagent's description, receives the result, and continues orchestration. See [Context engineering](#context-engineering) for fine-grained control.
|
|
210
|
+
|
|
211
|
+
### Single dispatch tool
|
|
212
|
+
|
|
213
|
+
An alternative approach uses a single parameterized tool to invoke ephemeral sub-agents for independent tasks. Unlike the [tool per agent](#tool-per-agent) approach where each sub-agent is wrapped as a separate tool, this uses a convention-based approach with a single `task` tool: the task description is passed as a human message to the sub-agent, and the sub-agent's final message is returned as the tool result.
|
|
214
|
+
|
|
215
|
+
Use this approach when you want to distribute agent development across multiple teams, need to isolate complex tasks into separate context windows, need a scalable way to add new agents without modifying the coordinator, or prefer convention over customization. This approach trades flexibility in context engineering for simplicity in agent composition and strong context isolation.
|
|
216
|
+
|
|
217
|
+
```mermaid theme={null}
|
|
218
|
+
graph LR
|
|
219
|
+
A[User] --> B[Main Agent]
|
|
220
|
+
B --> C{task<br/>agent_name, description}
|
|
221
|
+
C -->|research| D[Research Agent]
|
|
222
|
+
C -->|writer| E[Writer Agent]
|
|
223
|
+
C -->|reviewer| F[Reviewer Agent]
|
|
224
|
+
D --> C
|
|
225
|
+
E --> C
|
|
226
|
+
F --> C
|
|
227
|
+
C --> B
|
|
228
|
+
B --> G[User response]
|
|
229
|
+
```
|
|
230
|
+
|
|
231
|
+
**Key characteristics:**
|
|
232
|
+
|
|
233
|
+
* Single task tool: One parameterized tool that can invoke any registered sub-agent by name
|
|
234
|
+
* Convention-based invocation: Agent selected by name, task passed as human message, final message returned as tool result
|
|
235
|
+
* Team distribution: Different teams can develop and deploy agents independently
|
|
236
|
+
* Agent discovery: Sub-agents can be discovered via system prompt (listing available agents) or through [progressive disclosure](/oss/python/langchain/multi-agent/skills-sql-assistant) (loading agent information on-demand via tools)
|
|
237
|
+
|
|
238
|
+
<Tip>
|
|
239
|
+
An interesting aspect of this approach is that sub-agents may have the exact same capabilities as the main agent. In such cases, invoking a sub-agent is **really about context isolation** as the primary reason—allowing complex, multi-step tasks to run in isolated context windows without bloating the main agent's conversation history. The sub-agent completes its work autonomously and returns only a concise summary, keeping the main thread focused and efficient.
|
|
240
|
+
</Tip>
|
|
241
|
+
|
|
242
|
+
<Accordion title="Agent registry with task dispatcher">
|
|
243
|
+
```python theme={null}
|
|
244
|
+
from langchain.tools import tool
|
|
245
|
+
from langchain.agents import create_agent
|
|
246
|
+
|
|
247
|
+
# Sub-agents developed by different teams
|
|
248
|
+
research_agent = create_agent(
|
|
249
|
+
model="gpt-4.1",
|
|
250
|
+
prompt="You are a research specialist..."
|
|
251
|
+
)
|
|
252
|
+
|
|
253
|
+
writer_agent = create_agent(
|
|
254
|
+
model="gpt-4.1",
|
|
255
|
+
prompt="You are a writing specialist..."
|
|
256
|
+
)
|
|
257
|
+
|
|
258
|
+
# Registry of available sub-agents
|
|
259
|
+
SUBAGENTS = {
|
|
260
|
+
"research": research_agent,
|
|
261
|
+
"writer": writer_agent,
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
@tool
|
|
265
|
+
def task(
|
|
266
|
+
agent_name: str,
|
|
267
|
+
description: str
|
|
268
|
+
) -> str:
|
|
269
|
+
"""Launch an ephemeral subagent for a task.
|
|
270
|
+
|
|
271
|
+
Available agents:
|
|
272
|
+
- research: Research and fact-finding
|
|
273
|
+
- writer: Content creation and editing
|
|
274
|
+
"""
|
|
275
|
+
agent = SUBAGENTS[agent_name]
|
|
276
|
+
result = agent.invoke({
|
|
277
|
+
"messages": [
|
|
278
|
+
{"role": "user", "content": description}
|
|
279
|
+
]
|
|
280
|
+
})
|
|
281
|
+
return result["messages"][-1].content
|
|
282
|
+
|
|
283
|
+
# Main coordinator agent
|
|
284
|
+
main_agent = create_agent(
|
|
285
|
+
model="gpt-4.1",
|
|
286
|
+
tools=[task],
|
|
287
|
+
system_prompt=(
|
|
288
|
+
"You coordinate specialized sub-agents. "
|
|
289
|
+
"Available: research (fact-finding), "
|
|
290
|
+
"writer (content creation). "
|
|
291
|
+
"Use the task tool to delegate work."
|
|
292
|
+
),
|
|
293
|
+
)
|
|
294
|
+
```
|
|
295
|
+
</Accordion>
|
|
296
|
+
|
|
297
|
+
## Context engineering
|
|
298
|
+
|
|
299
|
+
Control how context flows between the main agent and its subagents:
|
|
300
|
+
|
|
301
|
+
| Category | Purpose | Impacts |
|
|
302
|
+
| ----------------------------------------- | -------------------------------------------------------- | ---------------------------- |
|
|
303
|
+
| [**Subagent specs**](#subagent-specs) | Ensure subagents are invoked when they should be | Main agent routing decisions |
|
|
304
|
+
| [**Subagent inputs**](#subagent-inputs) | Ensure subagents can execute well with optimized context | Subagent performance |
|
|
305
|
+
| [**Subagent outputs**](#subagent-outputs) | Ensure the supervisor can act on subagent results | Main agent performance |
|
|
306
|
+
|
|
307
|
+
See also our comprehensive guide on [context engineering](/oss/python/langchain/context-engineering) for agents.
|
|
308
|
+
|
|
309
|
+
### Subagent specs
|
|
310
|
+
|
|
311
|
+
The **names** and **descriptions** associated with subagents are the primary way the main agent knows which subagents to invoke. These are prompting levers—choose them carefully.
|
|
312
|
+
|
|
313
|
+
* **Name**: How the main agent refers to the sub-agent. Keep it clear and action-oriented (e.g., `research_agent`, `code_reviewer`).
|
|
314
|
+
* **Description**: What the main agent knows about the sub-agent's capabilities. Be specific about what tasks it handles and when to use it.
|
|
315
|
+
|
|
316
|
+
For the [single dispatch tool](#single-dispatch-tool) design, you must additionally provide the main agent with information about the subagents it can invoke.
|
|
317
|
+
You can provide this information in different ways based on the number of agents and whether your registry is static or dynamic:
|
|
318
|
+
|
|
319
|
+
| Method | Best for | Tradeoff |
|
|
320
|
+
| ----------------------------- | ---------------------------------------- | -------------------------------------------------------------------- |
|
|
321
|
+
| **System prompt enumeration** | Small, static agent lists (\< 10 agents) | Simple, but requires prompt updates when agents change |
|
|
322
|
+
| **Enum constraint** | Small, static agent lists (\< 10 agents) | Type-safe and explicit, but requires code changes when agents change |
|
|
323
|
+
| **Tool-based discovery** | Large or dynamic agent registries | Flexible and scalable, but adds complexity |
|
|
324
|
+
|
|
325
|
+
#### System prompt enumeration
|
|
326
|
+
|
|
327
|
+
List available agents directly in the main agent's system prompt. The main agent sees the list of agents and their descriptions as part of its instructions.
|
|
328
|
+
|
|
329
|
+
**When to use:**
|
|
330
|
+
|
|
331
|
+
* You have a small, fixed set of agents (\< 10)
|
|
332
|
+
* Agent registry rarely changes
|
|
333
|
+
* You want the simplest implementation
|
|
334
|
+
|
|
335
|
+
**Example:**
|
|
336
|
+
|
|
337
|
+
```python theme={null}
|
|
338
|
+
main_agent = create_agent(
|
|
339
|
+
model="...",
|
|
340
|
+
tools=[task],
|
|
341
|
+
system_prompt=(
|
|
342
|
+
"You coordinate specialized sub-agents. "
|
|
343
|
+
"Available agents:\n"
|
|
344
|
+
"- research: Research and fact-finding\n"
|
|
345
|
+
"- writer: Content creation and editing\n"
|
|
346
|
+
"- reviewer: Code and document review\n"
|
|
347
|
+
"Use the task tool to delegate work."
|
|
348
|
+
),
|
|
349
|
+
)
|
|
350
|
+
```
|
|
351
|
+
|
|
352
|
+
#### Enum constraint on dispatch tool
|
|
353
|
+
|
|
354
|
+
Add an enum constraint to the `agent_name` parameter in your dispatch tool. This provides type safety and makes available agents explicit in the tool schema.
|
|
355
|
+
|
|
356
|
+
**When to use:**
|
|
357
|
+
|
|
358
|
+
* You have a small, fixed set of agents (\< 10)
|
|
359
|
+
* You want type safety and explicit agent names
|
|
360
|
+
* You prefer schema-based validation over prompt-based guidance
|
|
361
|
+
|
|
362
|
+
**Example:**
|
|
363
|
+
|
|
364
|
+
```python theme={null}
|
|
365
|
+
from enum import Enum
|
|
366
|
+
|
|
367
|
+
class AgentName(str, Enum):
|
|
368
|
+
RESEARCH = "research"
|
|
369
|
+
WRITER = "writer"
|
|
370
|
+
REVIEWER = "reviewer"
|
|
371
|
+
|
|
372
|
+
@tool
|
|
373
|
+
def task(
|
|
374
|
+
agent_name: AgentName, # Enum constraint
|
|
375
|
+
description: str
|
|
376
|
+
) -> str:
|
|
377
|
+
"""Launch an ephemeral subagent for a task."""
|
|
378
|
+
# ...
|
|
379
|
+
```
|
|
380
|
+
|
|
381
|
+
#### Tool-based discovery
|
|
382
|
+
|
|
383
|
+
Provide a separate tool (e.g., `list_agents` or `search_agents`) that the main agent can call to discover available agents on-demand. This enables progressive disclosure and supports dynamic registries.
|
|
384
|
+
|
|
385
|
+
**When to use:**
|
|
386
|
+
|
|
387
|
+
* You have many agents (> 10) or a growing registry
|
|
388
|
+
* Agent registry changes frequently or is dynamic
|
|
389
|
+
* You want to reduce prompt size and token usage
|
|
390
|
+
* Different teams manage different agents independently
|
|
391
|
+
|
|
392
|
+
**Example:**
|
|
393
|
+
|
|
394
|
+
```python theme={null}
|
|
395
|
+
@tool
|
|
396
|
+
def list_agents(query: str = "") -> str:
|
|
397
|
+
"""List available subagents, optionally filtered by query."""
|
|
398
|
+
agents = search_agent_registry(query)
|
|
399
|
+
return format_agent_list(agents)
|
|
400
|
+
|
|
401
|
+
@tool
|
|
402
|
+
def task(agent_name: str, description: str) -> str:
|
|
403
|
+
"""Launch an ephemeral subagent for a task."""
|
|
404
|
+
# ...
|
|
405
|
+
|
|
406
|
+
main_agent = create_agent(
|
|
407
|
+
model="...",
|
|
408
|
+
tools=[task, list_agents],
|
|
409
|
+
system_prompt="Use list_agents to discover available subagents, then use task to invoke them."
|
|
410
|
+
)
|
|
411
|
+
```
|
|
412
|
+
|
|
413
|
+
### Subagent inputs
|
|
414
|
+
|
|
415
|
+
Customize what context the subagent receives to execute its task. Add input that isn't practical to capture in a static prompt—full message history, prior results, or task metadata—by pulling from the agent's state.
|
|
416
|
+
|
|
417
|
+
```python Subagent inputs example expandable theme={null}
|
|
418
|
+
from langchain.agents import AgentState
|
|
419
|
+
from langchain.tools import tool, ToolRuntime
|
|
420
|
+
|
|
421
|
+
class CustomState(AgentState):
|
|
422
|
+
example_state_key: str
|
|
423
|
+
|
|
424
|
+
@tool(
|
|
425
|
+
"subagent1_name",
|
|
426
|
+
description="subagent1_description"
|
|
427
|
+
)
|
|
428
|
+
def call_subagent1(query: str, runtime: ToolRuntime[None, CustomState]):
|
|
429
|
+
# Apply any logic needed to transform the messages into a suitable input
|
|
430
|
+
subagent_input = some_logic(query, runtime.state["messages"])
|
|
431
|
+
result = subagent1.invoke({
|
|
432
|
+
"messages": subagent_input,
|
|
433
|
+
# You could also pass other state keys here as needed.
|
|
434
|
+
# Make sure to define these in both the main and subagent's
|
|
435
|
+
# state schemas.
|
|
436
|
+
"example_state_key": runtime.state["example_state_key"]
|
|
437
|
+
})
|
|
438
|
+
return result["messages"][-1].content
|
|
439
|
+
```
|
|
440
|
+
|
|
441
|
+
### Subagent outputs
|
|
442
|
+
|
|
443
|
+
Customize what the main agent receives back so it can make good decisions. Two strategies:
|
|
444
|
+
|
|
445
|
+
1. **Prompt the sub-agent**: Specify exactly what should be returned. A common failure mode is that the sub-agent performs tool calls or reasoning but doesn't include results in its final message—remind it that the supervisor only sees the final output.
|
|
446
|
+
2. **Format in code**: Adjust or enrich the response before returning it. For example, pass specific state keys back in addition to the final text using a [`Command`](/oss/python/langgraph/graph-api#command).
|
|
447
|
+
|
|
448
|
+
```python Subagent outputs example expandable theme={null}
|
|
449
|
+
from typing import Annotated
|
|
450
|
+
from langchain.agents import AgentState
|
|
451
|
+
from langchain.tools import InjectedToolCallId
|
|
452
|
+
from langgraph.types import Command
|
|
453
|
+
|
|
454
|
+
|
|
455
|
+
@tool(
|
|
456
|
+
"subagent1_name",
|
|
457
|
+
description="subagent1_description"
|
|
458
|
+
)
|
|
459
|
+
def call_subagent1(
|
|
460
|
+
query: str,
|
|
461
|
+
tool_call_id: Annotated[str, InjectedToolCallId],
|
|
462
|
+
) -> Command:
|
|
463
|
+
result = subagent1.invoke({
|
|
464
|
+
"messages": [{"role": "user", "content": query}]
|
|
465
|
+
})
|
|
466
|
+
return Command(update={
|
|
467
|
+
# Pass back additional state from the subagent
|
|
468
|
+
"example_state_key": result["example_state_key"],
|
|
469
|
+
"messages": [
|
|
470
|
+
ToolMessage(
|
|
471
|
+
content=result["messages"][-1].content,
|
|
472
|
+
tool_call_id=tool_call_id
|
|
473
|
+
)
|
|
474
|
+
]
|
|
475
|
+
})
|
|
476
|
+
```
|
|
477
|
+
|
|
478
|
+
***
|
|
479
|
+
|
|
480
|
+
<Callout icon="pen-to-square" iconType="regular">
|
|
481
|
+
[Edit this page on GitHub](https://github.com/langchain-ai/docs/edit/main/src/oss/langchain/multi-agent/subagents.mdx) or [file an issue](https://github.com/langchain-ai/docs/issues/new/choose).
|
|
482
|
+
</Callout>
|
|
483
|
+
|
|
484
|
+
<Tip icon="terminal" iconType="regular">
|
|
485
|
+
[Connect these docs](/use-these-docs) to Claude, VSCode, and more via MCP for real-time answers.
|
|
486
|
+
</Tip>
|