Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
GitHub Copilot Tips and Tricks
Search
Yuichi Tanaka
March 17, 2024
Programming
34
12k
GitHub Copilot Tips and Tricks
Yuichi Tanaka
March 17, 2024
Tweet
Share
More Decks by Yuichi Tanaka
See All by Yuichi Tanaka
How GitHub uses Codespaces
yuichielectric
3
920
30分でわかるシステム運用アンチパターン / Operations Anti Patterns in 30 minutes
yuichielectric
12
17k
オープンソースのベストプラクティスを企業内で実践/How to implement InnerSource
yuichielectric
12
11k
GitHubにおける継続的デリバリー/How GitHub builds and deploy software
yuichielectric
12
3.9k
GitHubにおける GitHub Actions利用法/How GitHub uses GitHub Actions
yuichielectric
7
660
InnerSourceのすすめ / InnerSource
yuichielectric
8
1.8k
GitHub Pro Tips
yuichielectric
0
170
Other Decks in Programming
See All in Programming
CSC307 Lecture 11
javiergs
PRO
0
240
開発部に不満を持っていたCSがエンジニアにジョブチェンしてわかった「勝手に諦めない」ことの大切さ
sakuraikotone
28
16k
Composing an API the *right* way (Droidcon Berlin 2024)
zsmb
1
450
最近追加した型の紹介とその振り返り
aki19035vc
0
180
Google's Recipe for Scaling (Web) Security – LocoMocoSec 2024
lweichselbaum
0
170
ピグパーティにおけるMongoDB CommunityバージョンからAtlasへの移行事例
10969hotaka
0
130
Rubyのパフォーマンスプロファイリングの改善 / Enhancing performance profiling for Ruby
osyoyu
1
410
さきがけから振り返るアーキテクチャ刷新 / Reflecting on the Architectural Renewal from the Vanguard
nrslib
2
780
CSC307 Lecture 06
javiergs
PRO
0
360
How to use Macrobenchmark
veronikapj
0
160
Polarsの成長: v0.14からv1.0までの変遷と今後の展望
zerebom
1
350
HMSコンペ 11th Solution (team : kansai-kaggler)
t88
1
680
Featured
See All Featured
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
277
13k
Clear Off the Table
cherdarchuk
89
320k
Unsuck your backbone
ammeep
666
57k
How to train your dragon (web standard)
notwaldorf
79
5.5k
The Power of CSS Pseudo Elements
geoffreycrofte
64
5.2k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
26
2.1k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
78
15k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
26
1.6k
Rails Girls Zürich Keynote
gr2m
93
13k
Product Roadmaps are Hard
iamctodd
PRO
48
10k
Writing Fast Ruby
sferik
623
60k
Designing for Performance
lara
604
67k
Transcript
GitHub Copilotで できること一挙ご紹介
田中 裕一 プリンシパルソリューションズエンジニア GitHub @yuichielectric
本日のトピック GitHub Copilotに搭載されている様々な機能、使い方について 「コード補完」、「チャット」、「エディタ機能への統合」という 3つのトピックに沿ってご紹介します。 ※ Visual Studio Code 1.90(2024年5月版)を前提としています。
コード補完 いかに適切な文脈を渡すか
GitHub Copilot LLM 文脈 提案
GitHub Copilot 文脈とは? GitHub Copilot拡張によって、現在のファイルのカーソルの前後のソースコードや、 別のタブで開いているファイルの中から、関連するコードスニペット (コメント含む)を選択し、優先順位、フィルタリングを経た上でプロンプトに 追加される情報のこと。 https://github.blog/2023-05-17-how-github-copilot-is-getting-better-at-understanding-your-code/
GitHub Copilot 関連するファイルは常に開いておこう ピンどめしておくと開き忘れを防ぐことができる。 例) • TypeScriptプロジェクトで使うライブラリの 型定義ファイル(.d.tsファイル) • テストコードを書く時のテスト対象のコード、
もしくはその逆
GitHub Copilot 名前は大事 関連するコード箇所を探す上で、変数や関数の名前は大きなヒントとなる。 一貫性のある命名規則を用い、同一の概念に対して異なる名前を つけないように気をつけましょう。 後述する名前の提案機能も合わせて活用しましょう。
GitHub Copilot 良い提案を得るために • 複数の提案がある場合もあるので、それを確認 してみる。 ◦ コマンドパレットで “GitHub Copilot:
Open Completions Panel” • コメントとして、欲しいコードについての 説明を自然言語で書く。 ◦ 必要に応じて例も書く ◦ 例)「引数Xに〇〇という入力を渡したら××と いう値を返す関数」 • 自分でコードを書き始めてみる。 ◦ 書き始めたコードもCopilotにとっての 文脈となる。
チャット スラッシュコマンド、エージェント、コンテキスト変数 を使いこなす
Chat エディタ上のコンテキストを踏まえた、Copilotとのチャット コーディングに関する質問への回答 コードの説明 ユニットテストの生成 コードの修正提案 可読性の向上 言語変換
GitHub Copilot
GitHub Copilot 何が文脈として使われるか? [前提] 基本的には開いているファイルが文脈の候補。 ただし例外もあり(後述)。 1. エディタ上でテキストを選択している場合
→ 選択している箇所のテキストが使われる 2. 何も選択していない場合 → アクティブなエディタで表示されている範囲の テキストが使われる 3. コンテキスト変数で指定する(後述)
言語設定 チャットの返答や コミットメッセージの自動生成 (後述)の言語を指定可能 github.copilot.chat.localeOverride
コンテキスト 変数 #で始まり、プロンプトの中に 含めることで文脈を指定する ために使われるもの。 右の例の #file:BookDatabaseImpl.java の部分がコンテキスト変数。 この例だと、指定されたファイル 全体が文脈の対象となる。
GitHub Copilot 主要なコンテキスト変数一覧 #selection アクティブなエディタで選択されている箇所 #file 特定のファイル(VS Codeのファイル選択UIが表示される) #editor アクティブなエディタで表示されている箇所
#terminalLastCommand アクティブなターミナルの最後に実行したコマンドの結果 #terminalSelection アクティブなターミナルの選択されている箇所
GitHub Copilot コンテキスト変数の利用例 VS Code内のターミナルで、git diffで差分を表示した上で以下のプロンプトを実行 以下の観点でコードをレビューして、修正が必要な箇所を指摘してください。 • コードをさらに簡潔に書くことができるかどうか? •
このコードはコンパイルエラーやランタイムエラーを引き起こさないか? • セキュリティバグを入れ込んでしまっていないかどうか? #terminalLastCommand
GitHub Copilot
GUIでの コンテキスト の指定 チャット入力欄の📎アイコンを クリックすることでコンテキスト を以下から指定することも可能。 - エディタ上の選択範囲 - ターミナル上の選択範囲
- コードベース全体 - 特定のシンボル - 特定のファイル
スラッシュ コマンド / (スラッシュ) で始まる コマンドの事。 プロンプト中に指定することで Copilotへの依頼を簡潔に記載 することが可能。 右の例では
/explain を使って コードの説明を依頼している。
GitHub Copilot 主要なスラッシュコマンド /explain 選択されたコードを説明 /tests 選択されたコードのユニットテストを生成 /doc 選択されたコードのドキュメンテーションコメントを生成 (後述のインラインチャットのみ)
/fix 選択されたコードに含まれる問題を修正 /new 指定されたワークスペースの雛形を生成
エージェント @で始まり、プロンプトの中に 含めることで、どこから文脈を 収集するかを指定する。 右の例の @workspace の部分がエージェントの指定。 この例だと、開いていない ファイルも文脈の対象となる。
GitHub Copilot 主要なエージェント @workspace ワークスペース全体についてのチャット @terminal ターミナルについてのチャット @vscode VS Codeについてのチャット
エディタ機能への統合
インライン チャット チャットペインだけでなく エディタの中でチャットを 実行することが可能。 ここで提案されたコードは エディタ上に直接追記される。
インライン チャット 例)エラー処理のコードを 提案してもらう。
インライン チャット 例)インラインチャットで /doc を実行してdocstringを 提案してもらう。
ターミナル インライン チャット 例)srcディレクトリ以下で ファイルサイズで上位5つの ファイルを列挙
エラーの 修正提案 エディタ上のエラー(赤い波線) 箇所のQuick Fixメニューの中に Copilotを使うアイテムが表示。 “Fix using Copilot”を選択すると、 修正提案を適用。
エラーの 修正提案 エディタ上のエラー(赤い波線) 箇所のQuick Fixメニューの中に Copilotを使うアイテムが表示。 “Fix using Copilot”を選択すると、 修正提案を適用。
シンボルの rename コマンドパレットから“Rename Symbol”を実行すると周囲の文脈 から適切と思われる名前を提案 してくれる。
コミット メッセージの 提案 現在の変更差分から、それを 説明するコミットメッセージを 提案。 リポジトリの直近10個の コミット、コミッターの直近10個 のコミットも参照。
Thank you