Skip to content

ACP 支持

在任何兼容 ACP 的编辑器中使用 OpenCode。

OpenCode 支持 智能体客户端协议 (Agent Client Protocol,简称 ACP),允许你直接在兼容的编辑器和 IDE 中使用它。

ACP 是一种标准化代码编辑器与 AI 编程智能体之间通信的开放协议。


配置

要通过 ACP 使用 OpenCode,请将你的编辑器配置为运行 opencode acp 命令。

该命令将 OpenCode 作为兼容 ACP 的子进程启动,通过 stdio 上的 JSON-RPC 与你的编辑器进行通信。

以下是支持 ACP 的流行编辑器的示例。


Zed

添加到你的 Zed 配置 (~/.config/zed/settings.json):

~/.config/zed/settings.json
{
"agent_servers": {
"OpenCode": {
"command": "opencode",
"args": ["acp"]
}
}
}

要打开它,请在 命令面板 (Command Palette) 中使用 agent: new thread 操作。

你也可以通过编辑 keymap.json 来绑定键盘快捷键:

keymap.json
[
{
"bindings": {
"cmd-alt-o": [
"agent::NewExternalAgentThread",
{
"agent": {
"custom": {
"name": "OpenCode",
"command": {
"command": "opencode",
"args": ["acp"]
}
}
}
}
]
}
}
]

JetBrains IDEs

根据 文档 在你的 JetBrains IDE 的 acp.json 中添加:

acp.json
{
"agent_servers": {
"OpenCode": {
"command": "/absolute/path/bin/opencode",
"args": ["acp"]
}
}
}

要打开它,请在 AI Chat 智能体选择器中使用新的 ‘OpenCode’ 智能体。


Avante.nvim

添加到你的 Avante.nvim 配置中:

{
acp_providers = {
["opencode"] = {
command = "opencode",
args = { "acp" }
}
}
}

如果你需要传递环境变量:

{
acp_providers = {
["opencode"] = {
command = "opencode",
args = { "acp" },
env = {
OPENCODE_API_KEY = os.getenv("OPENCODE_API_KEY")
}
}
}
}

CodeCompanion.nvim

要在 CodeCompanion.nvim 中将 OpenCode 作为 ACP 智能体使用,请在你的 Neovim 配置中添加以下内容:

require("codecompanion").setup({
strategies = {
chat = {
adapter = {
name = "opencode",
model = "claude-sonnet-4",
},
},
},
})

此配置将 CodeCompanion 设置为使用 OpenCode 作为聊天的 ACP 智能体。

如果你需要传递环境变量(如 OPENCODE_API_KEY),请参阅 CodeCompanion.nvim 文档中的 配置适配器:环境变量 以获取详细信息。

支持

OpenCode 通过 ACP 工作的方式与在终端中相同。支持所有功能:

  • 内置工具(文件操作、终端命令等)
  • 自定义工具和斜杠命令
  • 在你的 OpenCode 配置中配置的 MCP 服务器
  • 来自 AGENTS.md 的项目特定规则
  • 自定义格式化程序和 linter
  • 智能体和权限系统