VS Code 1.120 のターミナル出力圧縮とリスク評価がなかなかよさそう
TL;DR — VS Code 1.120 でプレビュー追加されたターミナル出力圧縮(
chat.tools.compressOutput.enabled)とリスク評価(chat.tools.riskAssessment.enabled)。圧縮はコンテキスト管理、リスク評価は実行前の安全確認と役割が違う。特に圧縮は RTK と処理レイヤーが完全に別なので共存できる(らしい)。
何が追加されたか
VS Code 1.120 のリリースノートを眺めていたら、エージェント周りで自分の関心をひく機能が 2 つ入っていた。
ターミナル出力の自動圧縮とターミナルコマンドのリスク評価だ。
ターミナル出力の自動圧縮
設定は Chat › Tools › Compress Output: Enabled。これはプレビュー。
Claude さんの解説は以下。
有効にすると、エージェントがターミナルコマンドを実行したあと、その出力をモデルに送る前に VS Code 側で自動的に削減してくれる。具体的には以下の処理が入る。
git diffの差分で変更のない部分を折りたたむ- lockfile や snapshot の差分を丸ごと除外
ls -lをファイル名だけに削減npm installの進捗バー・非推奨警告・audit サマリーを除去圧縮された出力には先頭にバナーが付く。「どのフィルタが適用されたか」「生のテキストが必要なら圧縮を無効にできる」という情報をモデルに伝えるためのやつ。モデルが圧縮済みであることを認識できるのは地味に大事。
いや、これ RTK と同じじゃね?
AI を提供している会社のどれかがそのうち自社で実装するかもなー、とか思ってたけど案外早かったな。
リスク評価
設定は Chat › Tools › Risk Assessment: Enabled。こちらはエクスペリメンタル。
おなじみの Claude さんの解説は以下。
エージェントがターミナルコマンドを実行しようとしたとき、確認ダイアログにリスクバッジと AI 生成の説明が表示されるようになる。バッジは 3 段階。
バッジ 意味 🟢 Safe ファイルの読み取りや出力のみ。変更なし 🟠 Caution ワークスペースへの変更やネットワーク呼び出しを含む 🔴 Review carefully force push や外部への削除など、要注意な操作 バッジの横に 1 文のサマリーが出る。「このコマンドが何をするか」を一言で教えてくれるやつ。自動承認の判断材料として使える。