コマンドラインでVisual Studioを実行する
ここでは「BuildConsole.exe」(Incredibuild のインストール フォルダに格納) を使ってコマンドラインから Visual Studio のビルドを分散実行する方法をみていきます。
BuildConsole.exe の実行
BuildConsole <Target> [Options]
<Target> では次のどちらかを指定します。
-
Visual Studioソリューション(.slnファイル)へのパス
-
Visual Studioプロジェクト(.vcproj/.icproj/.vcxprojファイル)へのパス
特定のプロジェクトをビルドするために、必ずしもビルド コマンドに .sln ファイルをインクルードする必要はありませんが、.sln パラメーターの省略は推奨されていません。プロジェクト ファイルの情報が一部欠けている場合、プロジェクトを正しくコンパイルできないことがあります。BuildConsole コマンドに「/VsVersion」オプションが追加されました。これによりビルドで使用する Visual Studio のバージョンを指定できるようになりました。
コマンドの例:
-
MySln.sln ソリューションの Debug|Win32 のソリューション構成をリビルドする場合:
BuildConsole.exe MySln.sln /rebuild /cfg="Debug|Win32"
-
MySln.sln ソリューションの「Proj1」プロジェクトのみを Debug|Win32 と Release|Win32 両方のソリューョン構成でビルドする場合:
BuildConsole.exe MySln.sln /build /prj=Proj1 /cfg="Debug|Win32,Release|Win32"
-
プロジェクトと構成のより複雑な組み合わせをビルドするには、[Batch Buid] ダイアログから「MyPreset」プリセットを使用します。
BuildConsole.exe MySln.sln /build /preset="MyPreset"
このほかに、BuildConsole はプロジェクトをビルドするための「msdev.exe」と「devenv.exe」コマンドラインの構文もサポートしています。「msdev.exe」または「devenv.ex」を起動するバッチ ファイルをすでに使用している場合は、これらのプログラム名を「BuildConsole.exe」に置き換えると、標準の Visual C++ ビルドの代わりに Incredibuild の分散ビルドが実行されます。
Incredibuild Enterprise アカウントをお持ちでないかぎり、一度に実行できるビルドは1台の開始マシンのみとなります。他のビルドを実行中にビルドを実行しようとすると、現在実行中のビルドが終了するまでそのビルドが一時停止します。実行されます。
コマンドライン オプション
オプション | 機能 | 備考 |
---|---|---|
@ |
BuildConsole のコマンドラインが含まれる応答ファイルを指定します。 |
BuildConsole を実行するためのコマンドラインが長すぎて、スクリプトで明示的に指定できない場合に使用します。 |
/All |
一部プロジェクトのビルドに失敗しても、ソリューション / ワークスペースのビルドを続行します。 |
デフォルトでは、プロジェクトで出力ファイルのビルドに失敗するとビルドを停止しますが、このオプションを使って残りのビルドを継続することができます。 |
/Attach |
現在または直近のビルドの出力を表示します。 |
ビルド中の場合は、現時点までのビルドの出力を表示し、ビルドが終了するまで表示し続けます。ビルドを実行していない場合は、当該マシンで開始した最後のビルドの出力をすべて表示します。 |
/AvoidLocal=[On/Off] |
[エージェント設定]ダイアログボックスの可能な限りローカルマシンでのタスク実行を避ける オプ ションを上書きします。 |
値 (ON / OFF) が必須です。 |
/Beep |
ビルドの完了を通知音で知らせます。 |
|
/BrowseInfo=[ON/OFF] |
現在の設定にかかわらず、ブラウザ情報を作成または作成解除します。 |
ブラウズ情報の設定については、Agent Settings を参照してください。 |
/CEconfig="<configuration name>" |
eMbedded Visual C++ 4.0 ビルドの WCE プラットフォームを指定します。 |
VS 2008 以前のバージョンが対象です。 |
/Cfg=<configuration> |
ビルドするソリューション構成を指定します(VC6 ビルドの場合はプロジェクト構成を指定します)。 |
|
/cl_add="<options>" |
cl.exe のすべての呼び出しに、追加のコンパイラーオプションを追加できるようにしました。 |
cl.exe のコマンドラインに表示されるように、1 つまたは複数のコマンドをスペースで区切って入力します。 例:BuildConsole MyProj /cl_add="/O2 /FA" |
/cl_rem="<options>" |
cl.exe のすべての呼び出しから除外するコンパイラ オプションを指定します。 |
cl.exe のコマンドラインに表示されるように、1 つまたは複数のコマンドをスペースで区切って入力します 例: BuildConsole MyProj /cl_rem="/Z7 /Zd /Zi /ZI" |
/Clean |
プロジェクトとすべての依存関係の中間ファイルと出力ファイルを消去します。 |
|
/compile=<source file name> |
指定したファイルのみビルドします。 |
|
/Disable |
Incredibuild Agent を無効にします。 |
|
/DisablePdbForwarding |
このビルドの PDB 転送メカニズムを無効にします。 |
VS 2010 のみが対象です。 |
/DumpSourceFiles=filename |
プロジェクト / ソリューションの全ソース ファイルのパスをファイルに書き込みます。 |
<output filename> は必須です。 |
/Enable |
Incredibuild Agent を有効にします。 |
|
/Help |
使い方のヘルプやバージョン情報を表示します。 |
|
/IncrediLink |
このビルドでは、IncrediLink モード を強制します。 |
VS 2008 以前のバージョンが対象です。 |
/IntelCLVersion="<version>" |
デフォルトのインテル コンパイラのバージョンを上書きします。 |
VS 2008 以前のバージョンが対象です。 例: /IntelCLVersion=11.1 |
/link_add="<options>" |
link.exe のすべての呼び出しにリンカ オプションを追加します。 |
cl.exe のコマンドラインに表示されるように、1 つまたは複数のコマンドをスペースで区切って入力します。 例: BuildConsole MyProj /link_add="/map:MyProj.map" |
/link_rem="<options>" |
link.exe のすべての呼び出しから除外するリンカ オプションを指定します。 |
VS 2008 以前のバージョンが対象です。 cl.exe のコマンドラインに表示されるように、1 つまたは複数のコマンドをスペースで区切って入力します。 例: BuildConsole MyProj /link_rem="/map:MyProj.map" |
/Log[=filename] |
ビルド出力をファイルに書き込みます。 |
filename を指定しない場合は「IB_<target-name>.log」という名前のファイルがカレント ディレクトリに作成されます。 |
/LogLevel="<Level>" |
このビルドのログレベルを上書きします。 |
<Level> は、以下のいずれかになります。Minimal、Basic、Intermediate、Extended、Detailed. |
/MaxCPUS=<n> |
ビルド設定の最大 CPU / コア数を上書きします。 |
|
/MaxWinVer="<Version>" |
ビルドに参加できるリモート Agent の OS (最新のバージョン) を指定します。 |
これより新しい OS を搭載した Agent はビルドに参加できません。「XP」「2003」「VISTA」「2008」「7」「10」を設定できます。 |
/MinWinVer="<Version>" |
ビルドに参加できるリモート Agent の OS (最古のバージョン) を指定します。 |
これより古い OS を搭載した Agent はビルドに参加できません。「XP」「2003」「VISTA」「2008」「7」「8」「10」を設定できます。 |
/Mon[=filename] |
ビルド進行 (.ib_mon) ファイルのコピーを指定された場所に書き込みます。 |
|
/msbuildargs="/myarg1 /myarg2" |
BuildConsole /command /usemsbuild スイッチを使用する場合、MSBuild に追加の引数を渡します。 |
コマンドの例: BuildConsole dcom.sln /rebuild /cfg="debug|win32" /msbuildargs="/detailedsummary" /usemsbuild |
/NO_DOTNET_VIRT |
Helper マシン上の .NET 環境の仮想化を無効にします。 |
このオプションを指定すると、Initiator マシンの .NET 環境を Helper マシンに仮想化しません。様々な OS が混在する環境で .NET の互換性がない場合に使用します。 |
/NoIncrediLink |
IncrediLink モードを無効にします。 |
VS 2008 以前のバージョンが対象です。 |
/NoLink |
リンクを除くすべてのビルド ステップを実行します。 |
VS 2008 以前のバージョンが対象です。 |
/NoLogo |
ビルド出力の「Incredibuild」ヘッダーを非表示にします。 |
|
/NoRecurse |
指定したプロジェクト構成のみビルドしてサブプロジェクトを無視します。 |
|
/NoWait |
この Agent が開始した別のビルドが実行中の場合、BuildConsole は「Another build already running」のメッセージを表示して終了します。 |
|
/OpenMonitor |
プロセスの進行状況を表示するビルドモニター画面を開きます。 |
|
/out=filename |
コマンドラインの全出力をファイルにリダイレクトします。 |
|
/pemode |
Agentの投機的実行 の設定を上書きします。 |
/pemode=0は投機的実行を無効にします。 /pemode=2 は投機的実行を完全に有効にします。 /pemode=1 はリビルドのみ投機的実行を有効にします。 |
/Preset |
Batch Build ダイアログ で事前に保存したプリセットを使用してビルドするプロジェクト/コンフィグを決定します。 |
|
/Prj=<project name> |
ビルドするプロジェクトを決定します。 |
|
/QueryLicense |
有効なライセンス、割り当て済みのパッケージ、メンテナンスの有効期限などの情報を表示します。 |
|
/QueryPackage="<Package>" |
特定の Incredibuild 拡張パッケージが Agent に割り当てられているかどうかを確認して、終了コードとして「0」(割り当て済み) または「1」(未割り当て) を返します。 |
<Package> には「VC」「C#」「BuildTools」「DevToolAcc」「XGE」「Xbox One」「PlayStation」「Cafe」「3DS」「KlocWorkPro」「Coverity」のソリューション パッケージまたは、「4Cores」「8Cores」「12Cores」「16Cores」「24Cores」「32Cores」「48Cores」「64Cores」のコア パッケージを指定します。 |
/Rebuild |
プロジェクトをビルドする前にクリーンを行います。 |
複数の変数を設定/上書きしたい場合は /SETENV を複数回使用します。 |
/Reset |
Agent のファイルのキャッシュを消去します。 |
|
/SETENV="<name>=<value>" |
ビルドのコンテキストに合わせて環境変数を設定または上書きします。 |
|
/ShowAgent |
ビルドで使用した Agent を出力ファイルに表示します。 |
|
/ShowCmd |
Incredibuild がビルドで使用したコマンドラインを出力ファイルに表示します。 |
|
/ShowTime |
ビルドの開始時刻と終了時刻を出力ファイルに表示します。 |
|
/Silent |
標準出力に何も書き込みません。 |
デフォルトではビルドモニターの出力ディスプレイの通りにビルド結果を書き込みます。 |
/Stop[=<build-id>] | ローカルマシンで実行中のビルドを停止します。複数のビルドを実行している場合は <build-id> を指定します。 | ビルドが停止すると IBConsole はコード「3」を返します。ビルドが実行されていない場合はコード「2」を返します。 |
/StopOnErrors | 有効にするとエラーが発生した時点でビルドを停止します。 | |
/StopAll |
実行中のビルドをすべて停止します。 |
|
/Title=<build title> |
ビルド出力をテキスト表示する際にテキストの先頭に表示するカスタム ヘッダーを設定します。ここで設定した文字列がビルド履歴とビルドモニターにも表示されます。 |
値を引用符 (”) で囲みます。 |
/UseEnv |
Visual C++ IDE のパスの代わりに、PATH、INCLUDE、LIBPATH、LIB 環境変数を使用します。 |
|
/UseIDEMonitor |
このオプションを指定して Visual Studio IDE から を BuildConsole を実行すると、IDE のビルドモニターに処理の進行況が表示されます。 |
|
/UseMSBuild |
MSBuild を強制的に使用します。 |
デフォルトでは Devenv でビルドが行われます。このオプションを使うと、MSBuild でビルドが実行され、/msbuildargs を使って特定の MSBuild フラグを追加できるようになります。 これにより、VS 2022以降では64bit MSBuildが、それ以前のバージョンでは32bit MSBuildが自動的に使用されます。 この自動検出を無視し、使用するバージョンを手動で指定するには、=32 または =64 を追加します(例:/usemsbuild=32)。 |
/VsVersion="<Version>" |
指定バージョンの Visual Studio ツールセットを強制的に使用します。 |
<バージョン>は、vc8 (VS2005用)、vc9 (VS2008用)、vc10 (VS2010用)、vc11 (VS2012用)、vc12 (VS2013用)、vc14 ( VS2015用)、vc15 (VS2017) およびvc16 (VS2019 用)のいずれかです。 |
/wait |
この Agent が開始した別のビルドが実行中の場合、終了を待って新しいビルドを開始します。これはデフォルトの動作です。 |
リターンコード
-
0 - エラーなしでビルドに成功しました
-
1 - Incredibuild に関係のないエラー(コンパイルエラーなど)のため、ビルドに失敗しました
-
2 -ユーザーからのリクエストでBuildがキャンセルされました
-
3 - IncredibuildのシステムエラーによりBuildが失敗しました