mirror of
https://github.com/slhaf/Partner.git
synced 2026-05-12 16:53:04 +08:00
2.5 KiB
2.5 KiB
MetaActionInfo 行动描述覆写
MetaActionInfo 是行动能力进入 planner / evaluator / executor 前的描述层。它不负责执行行动,而是描述一个 action 可以被如何理解、选择、组装和调用。
不同来源的行动能力都会汇入 ActionCore.existedMetaActions,但它们生成描述信息的方式不同:
- 外部 MCP tool 会先生成基础
MetaActionInfo,再允许通过mcp/desc/*.desc.json进行覆盖。 - BUILTIN action 在注册时直接提供
MetaActionInfo。 - dynamic action 使用
dynamic/<name>/desc.json作为描述来源。
flowchart TD
subgraph Sources["MetaActionInfo 来源"]
A["外部 MCP tool"]
B["mcp/desc/*.desc.json<br/>描述覆盖"]
C["BuiltinActionDefinition"]
D["dynamic/name/desc.json"]
end
subgraph Build["描述构建 / 合并"]
A --> E["McpMetaRegistry<br/>基础描述"]
B --> E
C --> F["BuiltinActionRegistry"]
D --> G["DynamicActionMcpManager"]
end
subgraph ActionCore["行动核心: ActionCore"]
E --> H["existedMetaActions"]
F --> H
G --> H
end
subgraph Usage["使用位置"]
H --> I["listAvailableMetaActions"]
H --> J["loadMetaActionInfo"]
H --> K["loadMetaAction(actionKey)"]
K --> L["MetaAction"]
L --> M["ExecutableAction.actionChain"]
end
描述覆写主要服务于外部 MCP tool。外部 tool 自带的信息通常只够完成调用,但不一定足够支撑 Partner 的行动规划。mcp/desc/*.desc.json 可以补充或覆盖这些信息,让外部 tool 进入行动系统后具备更完整的行动语义。
当前描述信息会影响:
| 信息 | 作用 |
|---|---|
description |
让评估器和规划器理解 action 的用途 |
params |
描述行动参数,用于参数提取和调用装配 |
launcher |
为 ORIGIN / dynamic action 提供启动器信息 |
io |
描述输入输出形态,辅助行动组合 |
preActions / postActions |
描述行动前后依赖关系 |
strictDependencies |
表达必须满足的行动依赖 |
tags |
为 action 分类和筛选提供辅助信息 |
ActionCore.loadMetaAction(actionKey) 会根据 action key 前缀构造 MetaAction,但 MetaActionInfo 本身不会直接执行。它的价值在于让系统在执行前能够知道:有哪些 action 可用、它们需要什么参数、适合什么场景,以及是否存在依赖或补充约束。