Back to Picoclaw

Pipeline 重构文档

docs/architecture/agent-refactor/pipeline-restructuring-plan.zh.md

0.2.83.0 KB
Original Source

Pipeline 重构文档

目标

agent/pipeline.go (1400行) 拆分为多个逻辑文件,代码按职责组织。

最终文件结构

pkg/agent/
├── pipeline.go           # Pipeline struct + NewPipeline (~39行)
├── pipeline_setup.go   # SetupTurn 方法 (~115行)
├── pipeline_llm.go     # CallLLM 方法 (~519行)
├── pipeline_execute.go  # ExecuteTools 方法 (~693行)
└── pipeline_finalize.go # Finalize 方法 (~78行)

实际行数

文件行数
pipeline.go39
pipeline_setup.go115
pipeline_llm.go519
pipeline_execute.go693
pipeline_finalize.go78
总计1444

职责说明

文件方法职责
pipeline.goPipeline struct, NewPipeline()Pipeline 依赖容器
pipeline_setup.goSetupTurn()Turn 初始化:历史组装、消息构建、候选人选择
pipeline_llm.goCallLLM()LLM 调用:PreLLM hook、fallback、重试、AfterLLM hook
pipeline_execute.goExecuteTools()工具执行:BeforeTool/ApproveTool/AfterTool hook、媒体发送、steering 处理
pipeline_finalize.goFinalize()Turn 终结:会话保存、压缩、状态设置

Pipeline 与 Turn Coordinator 的关系

AgentLoop (agent.go)
    │
    ├── runAgentLoop() ──────────────────┐
    │                                    │
    │    ┌───────────────────────────────▼───────────────────────────────┐
    │    │                    Turn Coordinator (turn_coord.go)              │
    │    │                                                           │
    │    │   runTurn() {                                             │
    │    │       exec = pipeline.SetupTurn()                           │
    │    │       loop {                                               │
    │    │           ctrl = pipeline.CallLLM()  ──► Pipeline (pipeline_*.go) │
    │    │           if ctrl == ToolLoop {                             │
    │    │               toolCtrl = pipeline.ExecuteTools()             │
    │    │           }                                                 │
    │    │       }                                                    │
    │    │       return pipeline.Finalize()                            │
    │    │   }                                                        │
    │    └─────────────────────────────────────────────────────────────┘
    │
    └── 发布响应 (agent_outbound.go)

验证结果

  • go build ./pkg/agent/... - 通过
  • go vet ./pkg/agent/... - 无警告
  • go test ./pkg/agent/... -skip "TestSeahorse|TestGlobalSkillFileContentChange" - 通过