Files
opencode/packages/web/src/content/docs/ja/skills.mdx
opencode-agent[bot] d578f80f00 chore: generate
2026-02-09 17:35:30 +00:00

223 lines
6.0 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
---
title: 「エージェントスキル」
description: 「SKILL.md定義による再利用可能な動作の定義」
---
エージェント スキルにより、OpenCode はリポジトリまたはホーム ディレクトリから再利用可能な命令を検出できます。
スキルはネイティブの `skill` ツールを介してオンデマンドでロードされます。エージェントは利用可能なスキルを確認し、必要に応じて完全なコンテンツをロードできます。
---
## ファイルを配置する
スキル名ごとにフォルダーを 1 つ作成し、その中に `SKILL.md` を置きます。
OpenCode は次の場所を検索します。
- プロジェクト構成: `.opencode/skills/<name>/SKILL.md`
- グローバル構成: `~/.config/opencode/skills/<name>/SKILL.md`
- Project Claude互換: `.claude/skills/<name>/SKILL.md`
- グローバルクロード互換: `~/.claude/skills/<name>/SKILL.md`
- プロジェクトエージェント互換: `.agents/skills/<name>/SKILL.md`
- グローバルエージェント互換: `~/.agents/skills/<name>/SKILL.md`
---
## 発見を理解する
プロジェクトのローカル パスの場合、OpenCode は現在の作業ディレクトリから git ワークツリーに到達するまで進みます。
途中で、一致する `skills/*/SKILL.md` を `.opencode/` に読み込み、一致する `.claude/skills/*/SKILL.md` または `.agents/skills/*/SKILL.md` を読み込みます。
グローバル定義は、`~/.config/opencode/skills/*/SKILL.md`、`~/.claude/skills/*/SKILL.md`、および `~/.agents/skills/*/SKILL.md` からもロードされます。
---
## 前付を書く
各 `SKILL.md` は YAML フロントマターで始まる必要があります。
次のフィールドのみが認識されます。
- `name` (必須)
- `name` (必須)
- `license` (オプション)
- `license` (オプション)
- `metadata` (オプション、文字列間のマップ)
不明なフロントマターフィールドは無視されます。
---
## 名前を検証する
`name` は次のことを行う必要があります。
- 1 64 文字であること
- 単一のハイフンで区切られた小文字の英数字であること
- `-` で開始または終了しない
- 連続した `--` を含まない
- `SKILL.md` を含むディレクトリ名と一致する
同等の正規表現:
```text
^[a-z0-9]+(-[a-z0-9]+)*$
```
---
## 長さのルールに従ってください
`description` は 1 1024 文字である必要があります。
エージェントが正しく選択できるように、十分具体的な内容にしてください。
---
## 例を使用する
次のように `.opencode/skills/git-release/SKILL.md` を作成します。
```markdown
---
name: git-release
description: Create consistent releases and changelogs
license: MIT
compatibility: opencode
metadata:
audience: maintainers
workflow: github
---
## What I do
- Draft release notes from merged PRs
- Propose a version bump
- Provide a copy-pasteable `gh release create` command
## When to use me
Use this when you are preparing a tagged release.
Ask clarifying questions if the target versioning scheme is unclear.
```
---
## ツールの説明を認識する
OpenCode では、`skill` ツールの説明に利用可能なスキルがリストされています。
各エントリにはスキル名と説明が含まれます。
```xml
<available_skills>
<skill>
<name>git-release</name>
<description>Create consistent releases and changelogs</description>
</skill>
</available_skills>
```
エージェントはツールを呼び出してスキルをロードします。
```
skill({ name: "git-release" })
```
---
## 権限の構成
`opencode.json` のパターンベースの権限を使用して、エージェントがアクセスできるスキルを制御します。
```json
{
"permission": {
"skill": {
"*": "allow",
"pr-review": "allow",
"internal-*": "deny",
"experimental-*": "ask"
}
}
}
```
| 許可 | 行動 |
| ------- | ---------------------------------------------------------- |
| `allow` | スキルはすぐにロードされます |
| `deny` | スキルはエージェントから隠蔽され、アクセスは拒否されました |
| `ask` | ロードする前にユーザーに承認を求めるメッセージが表示される |
パターンはワイルドカードをサポートしています: `internal-*` は `internal-docs`、`internal-tools` などに一致します。
---
## エージェントごとに上書きする
特定のエージェントにグローバルのデフォルトとは異なる権限を与えます。
**カスタム エージェントの場合** (エージェント フロントマター内):
```yaml
---
permission:
skill:
"documents-*": "allow"
---
```
**組み込みエージェントの場合** (`opencode.json` 内):
```json
{
"agent": {
"plan": {
"permission": {
"skill": {
"internal-*": "allow"
}
}
}
}
}
```
---
## スキルツールを無効にする
スキルを使用すべきではないエージェントのスキルを完全に無効にします。
**カスタム エージェントの場合**:
```yaml
---
tools:
skill: false
---
```
**組み込みエージェントの場合**:
```json
{
"agent": {
"plan": {
"tools": {
"skill": false
}
}
}
}
```
無効にすると、`<available_skills>` セクションが完全に省略されます。
---
## 読み込みのトラブルシューティング
スキルが表示されない場合:
1. `SKILL.md` のスペルがすべて大文字であることを確認してください
2. フロントマターに `name` と `description` が含まれていることを確認します
3. スキル名がすべての場所で一意であることを確認する
4. 権限を確認してください - `deny` のスキルはエージェントから非表示になります