章 ▾ 第2版

A1.8 付録A: 他の環境でのGit - PowerShellでのGit

PowerShellでのGit

Windowsのレガシーなコマンドライン端末(`cmd.exe`)は、Gitのカスタマイズされたエクスペリエンスにはあまり向いていませんが、PowerShellを使用しているなら幸運です。これはLinuxまたはmacOSでPowerShell Coreを実行している場合でも機能します。posh-git(https://github.com/dahlbyk/posh-git)と呼ばれるパッケージは、強力なタブ補完機能と、リポジトリの状態を把握するのに役立つ拡張されたプロンプトを提供します。表示は次のようになります。

PowerShell with Posh-git
図187. Posh-gitを伴うPowerShell

インストール

前提条件 (Windowsのみ)

マシンでPowerShellスクリプトを実行できるようにするには、ローカルの`ExecutionPolicy`を`RemoteSigned`に設定する必要があります(基本的には、`Undefined`と`Restricted`以外のすべて)。`RemoteSigned`の代わりに`AllSigned`を選択した場合、ローカルスクリプト(自分自身のスクリプト)も実行するためにデジタル署名されている必要があります。`RemoteSigned`の場合、`ZoneIdentifier`が`Internet`に設定されている(ウェブからダウンロードされた)スクリプトのみが署名されている必要があり、それ以外は必要ありません。管理者で、そのマシンのすべてのユーザーに対して設定したい場合は、`-Scope LocalMachine`を使用します。管理権限のない一般ユーザーの場合は、`-Scope CurrentUser`を使用して自分自身のみに設定できます。

すべてのユーザーに対して`ExecutionPolicy`の値を`RemoteSigned`に設定するには、次のコマンドを使用します

> Set-ExecutionPolicy -Scope LocalMachine -ExecutionPolicy RemoteSigned -Force

PowerShell 5以上、またはPackageManagementがインストールされたPowerShell 4をお持ちの場合、パッケージマネージャーを使用してposh-gitをインストールできます。

PowerShellギャラリーに関する詳細情報: https://learn.microsoft.com/en-us/powershell/scripting/gallery/overview

> Install-Module posh-git -Scope CurrentUser -Force
> Install-Module posh-git -Scope CurrentUser -AllowPrerelease -Force # Newer beta version with PowerShell Core support

すべてのユーザーにposh-gitをインストールしたい場合は、代わりに`-Scope AllUsers`を使用し、管理者権限のPowerShellコンソールからコマンドを実行します。2番目のコマンドが`Module 'PowerShellGet' was not installed by using Install-Module`のようなエラーで失敗した場合、まず別のコマンドを実行する必要があります

> Install-Module PowerShellGet -Force -SkipPublisherCheck

その後、戻って再試行できます。これは、Windows PowerShellに付属するモジュールが異なる公開証明書で署名されているために発生します。

PowerShellプロンプトの更新

プロンプトにGit情報を含めるには、posh-gitモジュールをインポートする必要があります。PowerShellが起動するたびにposh-gitをインポートするには、`Add-PoshGitToProfile`コマンドを実行します。これにより、インポートステートメントがあなたの`$profile`スクリプトに追加されます。このスクリプトは、新しいPowerShellコンソールを開くたびに実行されます。複数の`$profile`スクリプトがあることに注意してください。例えば、コンソール用とISE用の別のスクリプトがあります。

> Import-Module posh-git
> Add-PoshGitToProfile -AllHosts

ソースから

posh-gitのリリースをhttps://github.com/dahlbyk/posh-git/releasesからダウンロードし、解凍するだけです。次に、`posh-git.psd1`ファイルへの完全パスを使用してモジュールをインポートします

> Import-Module <path-to-uncompress-folder>\src\posh-git.psd1
> Add-PoshGitToProfile -AllHosts

これにより、適切な行があなたの`profile.ps1`ファイルに追加され、次回PowerShellを開いたときにposh-gitがアクティブになります。

プロンプトに表示されるGitステータスの要約情報の詳細については、https://github.com/dahlbyk/posh-git/blob/master/README.md#git-status-summary-informationを参照してください。posh-gitプロンプトのカスタマイズ方法に関する詳細については、https://github.com/dahlbyk/posh-git/blob/master/README.md#customization-variablesを参照してください。

scroll-to-top