跳转到内容

命令

命令

自定义命令允许你指定在 TUI 中执行该命令时要运行的提示词。

/my-command

自定义命令是内置命令(如 /init/undo/redo/share/help)的补充。了解更多


创建命令文件

commands/ 目录中创建 markdown 文件来定义自定义命令。

创建 .opencode/commands/test.md

---
description: Run tests with coverage
agent: build
model: anthropic/claude-3-5-sonnet-20241022
---

Run the full test suite with coverage report and show any failures.
Focus on the failing tests and suggest fixes.

frontmatter 定义命令属性。内容成为模板。

通过输入 / 后跟命令名来使用命令。

"/test"

配置

你可以通过 OpenCode 配置或通过在 commands/ 目录中创建 markdown 文件来添加自定义命令。


JSON

使用 command 选项配置命令:

{
  "$schema": "https://opencode.ai/config.json",
  "command": {
    // 这成为命令名称
    "test": {
      // 这是将发送给 LLM 的提示词
      "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes.",
      // 这在 TUI 中显示为描述
      "description": "Run tests with coverage",
      "agent": "build",
      "model": "anthropic/claude-3-5-sonnet-20241022"
    }
  }
}

现在你可以在 TUI 中运行此命令:

/test

Markdown

你也可以使用 markdown 文件定义命令。将它们放在:

  • 全局:~/.config/opencode/commands/
  • 项目级:.opencode/commands/
---
description: Run tests with coverage
agent: build
model: anthropic/claude-3-5-sonnet-20241022
---

Run the full test suite with coverage report and show any failures.
Focus on the failing tests and suggest fixes.

markdown 文件名成为命令名称。例如,test.md 让你可以运行:

/test

提示词配置

自定义命令的提示词支持多个特殊占位符和语法。


参数

使用 $ARGUMENTS 占位符将参数传递给命令。

---
description: Create a new component
---

Create a new React component named $ARGUMENTS with TypeScript support.
Include proper typing and basic structure.

使用参数运行命令:

/component Button

$ARGUMENTS 将被替换为 Button

你也可以使用位置参数访问单个参数:

  • $1 - 第一个参数
  • $2 - 第二个参数
  • $3 - 第三个参数
  • 以此类推…

例如:

---
description: Create a new file with content
---

Create a file named $1 in the directory $2
with the following content: $3

运行命令:

/create-file config.json src "{ \"key\": \"value\" }"

这将替换:

  • $1config.json
  • $2src
  • $3{ "key": "value" }

Shell 输出

使用 !commandbash 命令 输出注入到你的提示词中。

例如,创建一个分析测试覆盖率的自定义命令:

---
description: Analyze test coverage
---

Here are the current test results:
!`npm test`

Based on these results, suggest improvements to increase coverage.

或查看最近的更改:

---
description: Review recent changes
---

Recent git commits:
!`git log --oneline -10`

Review these changes and suggest any improvements.

命令在你的项目根目录中运行,其输出成为提示词的一部分。


文件引用

使用 @ 后跟文件名来引用文件。

---
description: Review component
---

Review the component in @src/components/Button.tsx.
Check for performance issues and suggest improvements.

文件内容会自动包含在提示词中。


配置选项

让我们详细了解配置选项。


Template

template 选项定义执行命令时发送给 LLM 的提示词。

{
  "command": {
    "test": {
      "template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes."
    }
  }
}

这是必填的配置选项。


Description

使用 description 选项提供命令功能的简要描述。

{
  "command": {
    "test": {
      "description": "Run tests with coverage"
    }
  }
}

这在 TUI 中输入命令时显示为描述。


Agent

使用 agent 配置可选地指定哪个 智能体 应该执行此命令。如果是 子智能体,命令将默认触发子智能体调用。要禁用此行为,请设置 subtaskfalse

{
  "command": {
    "review": {
      "agent": "plan"
    }
  }
}

这是可选的配置选项。如果未指定,默认为当前智能体。


Subtask

使用 subtask 布尔值强制命令触发 子智能体 调用。如果你希望命令不污染你的主上下文,这很有用,并且会强制智能体充当子智能体,即使智能体 配置中 mode 设置为 primary

{
  "command": {
    "analyze": {
      "subtask": true
    }
  }
}

这是可选的配置选项。


Model

使用 model 配置覆盖此命令的默认模型。

{
  "command": {
    "analyze": {
      "model": "anthropic/claude-3-5-sonnet-20241022"
    }
  }
}

这是可选的配置选项。


内置命令

opencode 包含多个内置命令,如 /init/undo/redo/share/help了解更多