Reclineの構築手順
本記事では、Reclineの構築手順について解説します。Reclineは、CLIおよびエディタ内で動作し、コードの作成、編集、実行を支援します。このプロジェクトはClineをフォークしたものであり、Claude 3.5 Sonnetによって真価が発揮されます。。
これ何がすごいって、VSCodeのLanguageModelAPIとCopilotを使用するため、実質月額10ドル払えば無限にClaudeがClineで使えちゃうんですよね!!!!!!!!!!(ついでにcopilotも使えちゃう)
ということで、下記構築手順まとめます。
本記事を作成するにあたり、以下の情報を参考にしました。
- Reclineリポジトリ: https://github.com/julesmons/recline
- VSCodeダウンロードページ: https://code.visualstudio.com/download
- GitHub Copilotについて: https://docs.github.com/ja/copilot/about-github-copilot/what-is-github-copilot
動作環境
・Windows11
・CPU:Ryzen 7 9750X3D
・RAM:64GB
・GPU:RTX4060TI 16GB
手順
- 前提ソフトウェアのインストール
- VSCode: https://code.visualstudio.com/download から最新版をダウンロードし、インストールしてください。
- GitHub Copilotアカウントの準備: Reclineを最大限に活用するためにはGitHub Copilotのアカウントが必要です。詳細については、https://docs.github.com/ja/copilot/about-github-copilot/what-is-github-copilot を参照してください。
- Reclineリポジトリのクローン
- ターミナルまたはコマンドプロンプトを開き、以下のコマンドを実行してReclineリポジトリをクローンします。
git clone https://github.com/julesmons/recline.git
cd ./recline
- ターミナルまたはコマンドプロンプトを開き、以下のコマンドを実行してReclineリポジトリをクローンします。
- 依存関係のインストール
- Reclineはpnpmを使用して依存関係を管理します。まだインストールしていない場合は、以下のコマンドでインストールしてください。
npm install -g pnpm
- 次に、リポジトリのルートディレクトリで以下のコマンドを実行して依存関係をインストールします。
pnpm install
重要: ReclineはClineのnpm run install:allを使用せず、pnpmが必要です。
- Reclineはpnpmを使用して依存関係を管理します。まだインストールしていない場合は、以下のコマンドでインストールしてください。
- VSIXパッケージの作成
- VSIXパッケージを作成するために、@vscode/vsceがグローバルにインストールされている必要があります。まだインストールしていない場合は、以下のコマンドでインストールしてください。
npm install -g @vscode/vsce
- 次に、リポジトリのルートディレクトリで以下のコマンドを実行してVSIXパッケージを作成します。
pnpm run package
ルートフォルダにvisixが生成されてればOK!!
- VSIXパッケージを作成するために、@vscode/vsceがグローバルにインストールされている必要があります。まだインストールしていない場合は、以下のコマンドでインストールしてください。
- VSCodeへの拡張機能のインストール
- VSCodeを開き、作成されたVSIXファイルをインストールします。ターミナルから直接インストールする場合は、以下のコマンドを実行します。
code --install-extension ./recline-0.2.11.vsix
注: バージョン番号は./package.jsonの実際のバージョンによって異なります。
- VSCodeを開き、作成されたVSIXファイルをインストールします。ターミナルから直接インストールする場合は、以下のコマンドを実行します。
- GitHub Copilot拡張機能のインストール
- 重要: Reclineは、VSCodeのLanguage Model APIを介してAI機能を提供するために、GitHub Copilot拡張機能に依存しています。そのため、Reclineを利用するためにはGitHub Copilot拡張機能のインストールが必須となります。
- VSCodeのアクティビティバーにある拡張機能アイコンをクリックするか、Ctrl+Shift+X(またはCmd+Shift+X)を押して拡張機能ビューを開きます。
- 検索バーに「GitHub Copilot」と入力し、表示されたGitHub Copilot拡張機能をインストールします。
- インストール後、VSCodeの再起動が必要となる場合があります。
- Github Copilotをインストール後Githubにログインする必要があります。
- 画面右上のCopilotアイコンからチャットを開きます。
- 開いた画面のチャット欄でClaude 3.5 SonnetをEnableにしないとReclineでもClaudeが使用できないため注意。
- Reclineの利用開始
- 画面左の拡張機能のアイコンからこちらをクリック。
- すると見慣れた画面が立ち上がります。
- 左上の歯車マークから設定を開き、API ProviderをVScode Language Model APIとして、モデルをClaude3.5sonnet、お好みのカスタムインストラクション(システムプロンプト)を設定する。
- あとは楽しむだけ!!!
※今回は今度執筆予定のCode-serverについての環境構築をClineにお願いしてみました!
まとめ
VSCodeにReclineを構築し、利用を開始することができます。Reclineは、VSCode Language Model APIを利用し、GitHub Copilotが提供するClaude 3.5 Sonnetの強力なAIを活用して、単にコードの生成や編集を効率化するだけでなく、環境構築の際のコマンド生成支援、ドキュメントや記事の修正、さらには執筆のサポートなど、幅広い用途で活用できます。日々の開発業務から、ドキュメント作成、情報整理まで、Reclineはあなたの作業をよりスマートに進める強力なアシスタントとなるでしょう。ぜひ様々な場面でReclineの可能性を体験してみてください。
追記(問題点と対応策)
①送信プロンプトから日本語がすべて削除されて送信されてしまう問題があります。
対応策としてパッケージ化前のReclineの
@/src/extension/utils/sanitize.ts
下記該当箇所を以下の様に書き換える事で、対応可能。
再度パッケージ化してリプライで日本語になってればオッケー!
②Reclineがフォルダ構造を取得しようとしても失敗する。
Clineがファイル取得にfd.exeを使用しているため、これを環境変数パスを通す必要がある。
下記URLからfdをダウンロード。しとちゃ環境の場合これ~
https://github.com/sharkdp/fd/releases/tag/v10.2.0
パス通すのめんどちかったので、しとちゃはC:\Windows\System32に配置しました。
純粋パス通すなら
Win+Iキーからシステム
システムの詳細設定をクリック。
環境変数をクリック
このPathにfd.exeのパスを書き加えるでOK!
Cline上で@からAdd fileでファイルが表示されれば完了!
ちなみに本問題点はうみゆきさんのツイートを参照しました。(すごく助かりましたありがとうです!!!)
※注意!!(2025/1/15追記)
無限には使えないかもです!あとになってわかったのですが、Language Model APIのドキュメントを読んでいた所、一応レート制限が存在してるようで、詳細が記載されてないので、どの程度使えるか正直わからないのですが、その点は注意していたほうが良いかもしれません。一応しとちゃ環境では今のところ問題はありません。ただClineレベルの数万トークンの初期プロンプトで無料枠Copilotで使えたことを考えると、無料枠だけでも全然コスパいいレベルではあります!
まあ、しとちゃ的には会社で使えるClineがこれしかないので、どっちにしてもReClineを使うことになりそうです。
※歓喜!!(2025/1/16追記)
↑ドキュメント読み間違えてて、「レート制限」は、開発者がこのAPIを利用する際に、APIの使用頻度(リクエスト数)を制限する仕組みがあることを示しているようです。なので、少なくとも我々ユーザー側が気にする必要はないかもしれません!!ReCline側でちゃんとレート制限を組み込んでるなら問題ないのですが、その変はなんともわかりません。