Tech

Copilot custom instructionsについて

投稿日:

はじめに

これまでに引き続き、Github Copilotの機能について見ていきます。

今回は、Copilot custom instructionsについてまとめました。

なお、この記事ではJetBrainsのIDEを対象としているため、VS Codeやブラウザでは異なる場合があります。

Copilot custom instructionsとは

Copilot custom instructionsでは、Github Copilotの応答を自分やチームなどに合わせてカスタマイズすることができます。

使っているツールや要件などのコンテキストをCopilotに伝えることにより、Copilot ChatやCode reviewなどで与えた情報を踏まえて応答してくれます。

Copilotの応答をカスタマイズする

リポジトリ内にCustom instructionsファイルを配置することで、Copilotとやり取りする際にプロンプトに毎回コンテキストを渡す必要がなくなり、自動的にこの情報が追加されます。

 

このファイルには以下の2種類が存在します。

  • Repository custom instructions
  • Prompt files

Repository custom instructionsは、Copilotがリポジトリのコンテキストで作業する際に考慮する指示や設定などを記述できます。

Prompt filesは、共通のプロンプト指示や関連するコンテキストなどをMarkdown形式で保存し、Chatで再利用できます。

このファイルは、 *.prompt.md の形式で名前を付ける必要があります。

これらの使い分けとしては、AIワークフローにコードベース全体のコンテキストを追加したい場合はRepository custom instructionsを用い、特定のチャットに指示を追加したい場合はPrompt filesを用います。

この2つの方法についてもっと詳しく見ていきます。

Repository custom instructionsについて

Repository custom instructionsでは、リポジトリ内に .github/copilot-instructions.md を追加し、そこに記述します。

このファイルに記述する内容は、プロンプトを補完するコンテキストや関連する情報を端的かつ完結した内容で記述することが望ましいようです。

ちなみに、Copilot code reviewでは、このファイルの最初から4000文字のみを読み取ります。これを超えた分についてはレビューに影響を与えません。

Custom instrucsionsでは、以下のようなユースケースが想定されます。

  • テストコードの生成
  • コードレビュー
  • コミットメッセージの生成

テストコードの生成では、特定のテストフレームワークを指定するなどを記述します。

コードレビューでは、レビュー担当者にコード内の特定のエラーを探すようなどの指示を記述します。

コミットメッセージの生成では、フォーマットや含めるべき情報の種類などを記述します。

Prompt filesについて

Prompt filesでは、追加のコンテキストを含む再利用可能なプロンプト指示を作成し、それを共有できます。

Prompt filesはMarkdown形式で保存されます。

Prompt filesでは、以下のようなユースケースが想定されます。

  • コード生成
  • ドメインエキスパート
  • チームコラボレーション
  • オンボーディング

コード生成では、コンポーネント、テスト、移行用の再利用可能なプロンプトなどを作成します。

ドメインエキスパートでは、セキュリティ対策やコンプライアンスチェックなどの専門知識をプロンプトを通して共有します。

チームコラボレーションでは、仕様書、ドキュメントを参照したパターンやガイドラインなどを文書化します。

オンボーディングでは、複雑なプロセスやプロジェクト固有のパターン向けに段階的なガイドを作成します。

これらのファイルはワークスペースに複数配置することができます。

有効なcustom instructionsを書くには

custom instructionsを書くうえでの注意点としては、custom instructionsはすべてのチャットメッセージといっしょに送信されるので、リポジトリのコンテキストで行われるほとんどのリクエストに対して適用できる汎用的な指示である必要があります。

プロジェクトの性質などによって有効な内容は変わってきますが、一般的には以下のような内容を意識すると良いようです。

  • プロジェクトの目的、目標、背景情報などの概要を説明する
  • リポジトリ内のフォルダ構成や重要なディレクトリやファイルについて記載する
  • コーディング規約、命名規則やベストプラクティスなどを明記する
  • プロジェクトで使用されるツール、ライブラリ、フレームワーク等を記載する

さいごに

Copilot custom instructionsについてとまとめました。

実際にどのような記述をすればよいのか試行錯誤して行きたいと思います。

おすすめ書籍

現場で活用するためのAIエージェント実践入門 (KS情報科学専門書) MCP AIエージェント開発入門

blog-page_footer_336




blog-page_footer_336




-Tech
-

執筆者:

免責事項

このブログは、記事上部に記載のある投稿日時点の一般的な情報を提供するものであり、投資等の勧誘・法的・税務上の助言を提供するものではありません。仮想通貨の投資・損益計算は複雑であり、個々の取引状況や法律の変更によって異なる可能性があります。ブログに記載された情報は参考程度のものであり、特定の状況に基づいた行動の決定には専門家の助言を求めることをお勧めします。当ブログの情報に基づいた行動に関連して生じた損失やリスクについて、筆者は責任を負いかねます。最新の法律や税務情報を確認し、必要に応じて専門家に相談することをお勧めします。


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

Go言語

生成AIプログラミング事始め

1 はじめに2 生成AIプログラミング2.1 生成AIプログラミングとは2.2 生成AIプログラミングのメリット2.3 生成AIプログラミングの流れ2.4 生成AIプログラミングにおける注意点3 生成 ...

入門スクラム〜スクラムフレームワーク

1 はじめに2 スクラムの特徴2.1 シンプルなフレームワークであること2.2 素早い反復を繰り返すこと2.3 検査・適応・透明性3 スクラムの役割3.1 プロダクトオーナー3.2 スクラムマスター3 ...

Go言語

[Go初心者]テストについて学習

1 はじめに2 テスト2.1 エラーの値を比較する2.2 エラーの型を比較する3 httptest3.1 httptestの使い方4 さいごに5 おすすめ書籍 はじめに 今回はGo言語のテストについて ...

icon

ドキュメント作成の技術「テクニカルライティング」とは

1 はじめに2 テクニカルライティングとは3 少しでも分かりやすく、簡潔にする3.1 一文一義3.2 長くしすぎない、繋げすぎない3.3 長さの目安は?4 伝わりやすく書く4.1 まず主題を書く4.2 ...

【Unity】URP対応のAssetのPrefabがピンク色になる件

1 はじめに2 レンダリングパイプラインとは2.1 ビルトインレンダリングパイプライン2.2 ユニバーサルレンダリングパイプライン3 URPの設定手順3.1 URPのインストール3.2 URPのアセッ ...

フォロー

blog-page_side_responsive

2026年1月
 123
45678910
11121314151617
18192021222324
25262728293031

アプリ情報

私たちは無料アプリもリリースしています、ぜひご覧ください。 下記のアイコンから無料でダウンロードできます。