スキルとは何ですか?
SKILL.md ファイルで、Devin に再利用可能な手順——つまり、Devin に一貫して従わせたい、繰り返し可能なあらゆるワークフロー——を教えるものです。PR を作成する前のアプリのテスト、環境へのデプロイ、コードベースの調査、新しいサービスのひな形作成など、ステップごとの手順として書けるものであれば、スキルにできます。
オープンな Agent Skills standard に準拠しているため、同じスキルファイルを複数の AI コーディングツール間で共通して利用できます。
リポジトリ内の .agents/skills/<skill-name>/SKILL.md にスキルファイルを配置してください。Devin は、接続されているすべてのリポジトリからそれらを自動的に検出します。完全なファイル形式のリファレンスについては、Agent Skills specification を参照してください。
スキルが重要な理由
- 毎回同じやり方で実行する必要がある — テストのチェックリスト、デプロイ手順、レビュー手順
- リポジトリ固有の知識が必要である — 起動するサービス、使用するポート、実行するコマンド
- 動的なコンテキストを活用すると効果的である — 呼び出し時に git diff、ブランチ名、環境情報を取り込む
Devin はスキルを自動提案します
- 学習内容の要約 (例: 「Docker でバックエンドを起動する方法」)
- 提案された
SKILL.mdファイルの内容 - スキルをリポジトリにコミットするための “Create PR” ボタン
例
PR を作成する前のテスト
環境へのデプロイ
@skills:deploy staging で呼び出すと、staging が $ARGUMENTS と $0 に置き換えられ、!`command` ブロックによってその時点の Git 情報が挿入されます。triggers: ["user"] フィールドにより、Devin は明示的に依頼した場合にのみこのスキルを実行し、自動では有効になりません。
コードベースの一部を調査する
allowed-tools フィールドは、スキルが有効な間に Devin が利用するツールを読み取り専用の操作に制限します — 編集やシェルコマンドの実行はできません。これは、副作用を伴わずに分析したい探索タスクで役立ちます。
スキルの検出
- インデックス済みリポジトリ — Devin のバックエンドは、組織に接続されているすべてのリポジトリにある
SKILL.mdファイルをインデックス化します。これらは、どのリポジトリもクローンされる前の、セッション開始時点からすぐに利用できます。 - クローンされたリポジトリ — リポジトリがセッションのマシンにクローンされると、Devin はディスク上の
SKILL.mdファイルをスキャンします。ディスクから検出されたスキルは、同じリポジトリ内の該当するインデックス済みスキルを更新または上書きし、作業中のブランチで常に最新バージョンが使われるようにします。
サポートされているスキルファイルの配置場所
SKILL.md ファイルを検索します:
.agents/skills/<skill-name>/SKILL.md(推奨).github/skills/<skill-name>/SKILL.md.claude/skills/<skill-name>/SKILL.md.cursor/skills/<skill-name>/SKILL.md.codex/skills/<skill-name>/SKILL.md.cognition/skills/<skill-name>/SKILL.md.windsurf/skills/<skill-name>/SKILL.md
スキルファイルから Devin が読み込むもの
--- ブロック) をパースして、次の項目を抽出します。
| Field | Purpose |
|---|---|
name | スキルを識別します。省略された場合は親ディレクトリ名が代わりに使われます。 |
description | スキル一覧に表示される短い要約で、Devin (とあなた) がそのスキルの内容を理解できるようにします。 |
allowed-tools | スキルがアクティブな間に Devin が利用できるツールを制限します。 |
| Field | Purpose |
|---|---|
argument-hint | 期待される引数を説明するヒントテキストで、スキル名と一緒に表示されます。 |
triggers | 誰がスキルを呼び出せるかを制御します — デフォルトは ["user", "model"] です。Devin が自動的に有効化するのを防ぐには ["user"] に設定します。 |
動的コンテンツ
$ARGUMENTS— スキル呼び出し時に渡された引数文字列全体 (例:@skills:deploy staging prod) に置き換えられます。個々の引数にはインデックスでアクセスできます:1 番目は$ARGUMENTS[0]または$0、2 番目は$ARGUMENTS[1]または$1など。引数は空白で分割されます。!`command`— コマンドはリポジトリのルートで実行され、その標準出力に置き換えられます。これにより、ブランチ名やポート番号などの動的な値をスキルに含めることができます。
Devin がスキルをどのように利用するか
SKILL.md ファイル全体を読み、その内容を現在のコンテキストにシステムレベルの指示として取り込みます。これは、Devin がタスクの残りの間、そのスキルで定義された手順に積極的に従うことを意味します — 単なる参照ではなく、Devin の振る舞いを直接ガイドします。
Devin は複数の方法でスキルを使用できます:
自動呼び出し
test-before-pr というスキルが存在する場合、Devin は PR を作成する前にそのスキルを有効化します。明示的にのみ呼び出したいスキルで自動呼び出しを無効化するには、frontmatter で triggers: ["user"] を設定してください。
プロンプトでスキルを指定する
@skills:skill-name を含めることで、Devinに特定のスキルを使うよう指示できます。
$ARGUMENTS、$ARGUMENTS[0]、$1 などが現れる箇所に置き換えられます。
一度にアクティブにできるスキルは 1 つ
検索と一覧表示
制限事項
- グローバル / 組織レベルのスキル — 現時点では、スキルはリポジトリ内に存在します。組織全体で使うスキルについては、回避策として専用の「skills」リポジトリを作成できます。すべてのリポジトリに適用される組織レベルのスキルを、ファーストクラスでサポートすることを検討中です。
- 複数スキルの組み合わせ — 現在は一度に有効にできるスキルは 1 つだけです。スキルの連結やワークフローの合成をサポートする機能を開発中です。
スキルとプレイブックの違い
| Skills | Playbooks | |
|---|---|---|
| 保存場所 | リポジトリ内の SKILL.md ファイル — コードと一緒にバージョン管理される | Devin の Web アプリ内 — UI を通じて管理される |
| トリガー方法 | Devin が自動的に検出して実行するか、任意のプロンプトで @skills:name として参照する | セッション開始時に手動で紐づける |
| スコープ | リポジトリ単位 — Devin はタスクに関連するリポジトリに基づいて適切なスキルを選択する | 組織全体 — どのチームメンバーでも任意のプレイブックを任意のセッションに紐づけられる |
| 自動提案 | Devin がアプリをテストしたり新しいことを学習した後に、新しいスキルを提案する | チームメンバーが手動で作成する |
| 適している用途 | テスト手順、ローカル開発環境のセットアップ、デプロイチェックリスト、リポジトリ固有のワークフロー | 再利用可能なプロンプトテンプレート、複数リポジトリにまたがるタスクパターン、オンボーディングガイド |
詳細情報
- Agent Skills specification —
SKILL.mdファイル形式、frontmatter フィールド、ディレクトリ構造に関するオープンスタンダード - Knowledge — コンテキスト付きのヒントや事実 (手順ではない情報) を管理・参照するための機能
- Playbooks — セッションに紐づけて再利用できるプロンプトテンプレート向け
