Skip to content

04. Agents、Swarm、Memory 与 Workspace

这一章讲的是 clean SDK 里更高层的能力:不只是单轮对话,而是把 agent 组织成可以长期协作、持续运行、保留记忆的系统。

1. Named agents

如果你希望某些能力可以反复复用,先把它定义成命名 agent:

ts
const sdk = await createAgentSdk({
  agents: [
    {
      name: 'reviewer',
      description: '优先报告 bug、回归和验证缺口。',
      systemPrompt:
        'You are a careful reviewer. Prioritize bugs, regressions, and missing verification.',
    },
  ],
});

之后就可以直接按角色运行:

ts
const result = await sdk.runWithAgent(
  'reviewer',
  '请从发布前检查的角度审查这个仓库。',
);

2. Task 委派

定义了 named agents 之后,就可以把子任务委派给特定 agent。

常用入口:

  1. sdk.createTaskTool()
  2. sdk.runWithAgent(...)
  3. sdk.createAgentSession(...)

这很适合做:

  1. reviewer 子流程
  2. release-check 子流程
  3. 某个专门 agent 的后台分析任务

3. Swarm、Teammate 与 Side Session

如果你想做 leader + teammate 的协作模式,可以使用 swarm:

ts
const team = sdk.swarm.createTeam({
  name: 'release-team',
  leader: 'lead',
  continuous: true,
});

常见操作:

  1. spawn(...)
  2. message(...)
  3. continueFromMailbox(...)
  4. reenter(...)
  5. runBackground(...)
  6. transcript(...)
  7. waitForIdle()

你还可以给整个 team 设置统一的权限和审批语义:

ts
team.setRuntimeContext({
  permissions: [{ toolName: 'write_note', behavior: 'ask' }],
  approver: ({ publicName }) =>
    publicName === 'write_note'
      ? { behavior: 'allow', reason: '允许 teammate 写说明文档。' }
      : { behavior: 'deny', reason: '未预期的工具。' },
});

仓库示例:

4. Workspace 管理

如果你不希望 agent 直接在当前目录工作,可以先创建独立 workspace,再把它传给 SDK。

可用 helper:

  1. createWorkspace(...)
  2. createTempWorkspace(...)
  3. createGitWorktreeWorkspace(...)
ts
const workspace = await createTempWorkspace({
  prefix: 'actoviq-demo-',
  copyFrom: './examples',
});

const sdk = await createAgentSdk({
  workDir: workspace.path,
});

5. Buddy

Buddy 不是单独的导航页,而是 clean SDK 里的一种“陪伴式上下文能力”。它适合给 agent 注入固定风格、提示语气和持续性的 companion context。

常用入口:

  1. sdk.buddy.get()
  2. sdk.buddy.hatch(...)
  3. sdk.buddy.mute() / unmute()
  4. sdk.buddy.pet()
  5. sdk.buddy.getPromptContext()

一个最小例子:

ts
await sdk.buddy.hatch({
  name: 'Luna',
  persona: 'A calm engineering companion.',
});

console.log(await sdk.buddy.state());

Buddy 的内容会通过 prompt context 进入 clean SDK 主链,所以它更像“长期陪伴配置”,而不是一次性工具。

6. Memory、Session-Memory 与 Relevant Memories

clean SDK 当前已经提供:

  1. relevant memories 选择
  2. session-memory prompt / summary helper
  3. compact state 检查
  4. 会话足够长时自动提取 session-memory

主入口:

ts
const memory = sdk.memory;
console.log(await memory.findRelevantMemories('发布这个包之前应该注意什么?'));

在 session 级别:

ts
const extraction = await session.extractMemory();
const state = await session.compactState({
  includeSessionMemory: true,
  includeSummaryMessage: true,
});

仓库示例:

7. Dream:长期记忆整理

Dream 可以理解成一次“对最近若干会话做记忆整理和巩固”的 clean SDK 过程。它不会单独占据教程导航,而是作为 memory 系统的一部分来理解。

查看当前 dream 状态

ts
const state = await sdk.dreamState();
console.log(state);

手动运行 dream

ts
const session = await sdk.createSession({ title: 'Dream Demo' });
const result = await session.dream({
  extraContext: '把最近关于发布流程、稳定配置和工作方式的结论整理进长期记忆。',
});

console.log(result.result?.text);
console.log(result.touchedFiles);

触发自动 dream

ts
await sdk.memory.updateSettings({ autoDreamEnabled: true });

const autoResult = await sdk.maybeAutoDream({
  currentSessionId: session.id,
  background: true,
});

console.log(autoResult.task?.id);

仓库示例:

8. Compact

clean SDK 当前支持:

  1. 自动 compact
  2. reactive compact
  3. API-oriented microcompact
  4. compact history 和 continuity metadata 持久化

它最重要的作用是:

  1. 长对话时控制上下文长度
  2. 压缩后尽量保持推理连续性
  3. 让 session-memory 和 compact 一起工作

下一章:

Released under the MIT License.