mirror of
https://gitea.toothfairyai.com/ToothFairyAI/tf_code.git
synced 2026-04-11 19:28:33 +00:00
323 lines
6.3 KiB
Plaintext
323 lines
6.3 KiB
Plaintext
---
|
||
title: 指令
|
||
description: 為重複任務建立自定義指令。
|
||
---
|
||
|
||
自定義指令允許您指定在 TUI 中執行該指令時要執行的提示。
|
||
|
||
```bash frame="none"
|
||
/my-command
|
||
```
|
||
|
||
除了 `/init`、`/undo`、`/redo`、`/share`、`/help` 等內建指令之外,還有自定義指令。 [了解更多](/docs/tui#commands)。
|
||
|
||
---
|
||
|
||
## 建立指令檔案
|
||
|
||
在 `commands/` 目錄中建立 markdown 檔案來定義自定義指令。
|
||
|
||
建立 `.opencode/commands/test.md`:
|
||
|
||
```md title=".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 定義指令屬性。內容成為範本。
|
||
|
||
透過輸入 `/` 後跟指令名稱來使用該指令。
|
||
|
||
```bash frame="none"
|
||
"/test"
|
||
```
|
||
|
||
---
|
||
|
||
## 設定
|
||
|
||
您 可以透過 opencode 設定或透過在 `commands/` 目錄中建立 markdown 檔案來新增自定義指令。
|
||
|
||
---
|
||
|
||
### JSON
|
||
|
||
在 opencode [設定](/docs/config) 中使用 `command` 選項:
|
||
|
||
```json title="opencode.jsonc" {4-12}
|
||
{
|
||
"$schema": "https://opencode.ai/config.json",
|
||
"command": {
|
||
// This becomes the name of the command
|
||
"test": {
|
||
// This is the prompt that will be sent to the LLM
|
||
"template": "Run the full test suite with coverage report and show any failures.\nFocus on the failing tests and suggest fixes.",
|
||
// This is shown as the description in the TUI
|
||
"description": "Run tests with coverage",
|
||
"agent": "build",
|
||
"model": "anthropic/claude-3-5-sonnet-20241022"
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
現在您可以在 TUI 中執行此指令:
|
||
|
||
```bash frame="none"
|
||
/test
|
||
```
|
||
|
||
---
|
||
|
||
### Markdown
|
||
|
||
您也可以使用 Markdown 檔案定義指令。將它們放入:
|
||
|
||
- 全域:`~/.config/opencode/commands/`
|
||
- 每個專案:`.opencode/commands/`
|
||
|
||
```markdown title="~/.config/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.
|
||
```
|
||
|
||
Markdown 檔名成為指令名。例如,`test.md` 讓您執行:
|
||
|
||
```bash frame="none"
|
||
/test
|
||
```
|
||
|
||
---
|
||
|
||
## 提示設定
|
||
|
||
自定義指令的提示支援幾個特殊的預留位置和語法。
|
||
|
||
---
|
||
|
||
### 參數 (Arguments)
|
||
|
||
使用 `$ARGUMENTS` 預留位置將參數傳遞給指令。
|
||
|
||
```md title=".opencode/commands/component.md"
|
||
---
|
||
description: Create a new component
|
||
---
|
||
|
||
Create a new React component named $ARGUMENTS with TypeScript support.
|
||
Include proper typing and basic structure.
|
||
```
|
||
|
||
使用參數執行指令:
|
||
|
||
```bash frame="none"
|
||
/component Button
|
||
```
|
||
|
||
`$ARGUMENTS` 將替換為 `Button`。
|
||
|
||
您也可以使用位置參數存取各個參數:
|
||
|
||
- `$1` - 第一個參數
|
||
- `$2` - 第二個參數
|
||
- `$3` - 第三個參數
|
||
- 等等...
|
||
|
||
例如:
|
||
|
||
```md title=".opencode/commands/create-file.md"
|
||
---
|
||
description: Create a new file with content
|
||
---
|
||
|
||
Create a file named $1 in the directory $2
|
||
with the following content: $3
|
||
```
|
||
|
||
執行指令:
|
||
|
||
```bash frame="none"
|
||
/create-file config.json src "{ \"key\": \"value\" }"
|
||
```
|
||
|
||
這取代了:
|
||
|
||
- `$1` 與 `config.json`
|
||
- `$2` 與 `src`
|
||
- `$3` 與 `{ "key": "value" }`
|
||
|
||
---
|
||
|
||
### Shell 輸出
|
||
|
||
使用 _!`command`_ 將 [bash 指令](/docs/tui#bash-commands) 輸出注入到提示中。
|
||
|
||
例如,要建立分析測試覆蓋率的自定義指令:
|
||
|
||
```md title=".opencode/commands/analyze-coverage.md"
|
||
---
|
||
description: Analyze test coverage
|
||
---
|
||
|
||
Here are the current test results:
|
||
!`npm test`
|
||
|
||
Based on these results, suggest improvements to increase coverage.
|
||
```
|
||
|
||
或者查看最近的變更:
|
||
|
||
```md title=".opencode/commands/review-changes.md"
|
||
---
|
||
description: Review recent changes
|
||
---
|
||
|
||
Recent git commits:
|
||
!`git log --oneline -10`
|
||
|
||
Review these changes and suggest any improvements.
|
||
```
|
||
|
||
指令在專案的根目錄中執行,其輸出成為提示的一部分。
|
||
|
||
---
|
||
|
||
### 檔案參考
|
||
|
||
使用 `@` 後跟檔名將檔案包含在指令中。
|
||
|
||
```md title=".opencode/commands/review-component.md"
|
||
---
|
||
description: Review component
|
||
---
|
||
|
||
Review the component in @src/components/Button.tsx.
|
||
Check for performance issues and suggest improvements.
|
||
```
|
||
|
||
檔案內容會自動包含在提示中。
|
||
|
||
---
|
||
|
||
## 選項
|
||
|
||
讓我們詳細看看設定選項。
|
||
|
||
---
|
||
|
||
### 範本 (Template)
|
||
|
||
`template` 選項定義執行指令時將發送到 LLM 的提示。
|
||
|
||
```json title="opencode.json"
|
||
{
|
||
"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` 選項提供指令功能的簡要描述。
|
||
|
||
```json title="opencode.json"
|
||
{
|
||
"command": {
|
||
"test": {
|
||
"description": "Run tests with coverage"
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
當您輸入指令時,這將在 TUI 中顯示為描述。
|
||
|
||
---
|
||
|
||
### 代理 (Agent)
|
||
|
||
使用 `agent` 設定可選擇指定哪個 [代理](/docs/agents) 應執行此指令。
|
||
如果這是 [子代理](/docs/agents/#subagents),該指令將預設觸發子代理呼叫。
|
||
要禁用此行為,請將 `subtask` 設定為 `false`。
|
||
|
||
```json title="opencode.json"
|
||
{
|
||
"command": {
|
||
"review": {
|
||
"agent": "plan"
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
這是一個**可選**設定選項。如果未指定,則預設為您當前的代理。
|
||
|
||
---
|
||
|
||
### 子任務 (Subtask)
|
||
|
||
使用 `subtask` 布林值強制指令觸發 [子代理](/docs/agents/#subagents) 呼叫。
|
||
如果您希望指令不污染您的主要上下文並且將**強制**代理充當子代理,那麼這非常有用,
|
||
即使 `mode` 在 [代理](/docs/agents) 設定上設定為 `primary`。
|
||
|
||
```json title="opencode.json"
|
||
{
|
||
"command": {
|
||
"analyze": {
|
||
"subtask": true
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
這是一個**可選**設定選項。
|
||
|
||
---
|
||
|
||
### 模型 (Model)
|
||
|
||
使用 `model` 設定覆寫此指令的預設模型。
|
||
|
||
```json title="opencode.json"
|
||
{
|
||
"command": {
|
||
"analyze": {
|
||
"model": "anthropic/claude-3-5-sonnet-20241022"
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
這是一個**可選**設定選項。
|
||
|
||
---
|
||
|
||
### 內建
|
||
|
||
opencode 包含 `/init`、`/undo`、`/redo`、`/share`、`/help` 等內建指令; [了解更多](/docs/tui#commands)。
|
||
|
||
:::note
|
||
自定義指令可以覆寫內建指令。
|
||
:::
|
||
|
||
如果您定義同名的自定義指令,它將覆寫內建指令。
|