次の方法で共有


SolutionBuild2.BuildProject メソッド (String, String, Boolean)

指定されたソリューション構成のコンテキストで、指定されたプロジェクトとその依存関係をビルドします。

名前空間:  EnvDTE80
アセンブリ:  EnvDTE80 (EnvDTE80.dll 内)

構文

'宣言
Sub BuildProject ( _
    SolutionConfiguration As String, _
    ProjectUniqueName As String, _
    WaitForBuildToFinish As Boolean _
)
void BuildProject(
    string SolutionConfiguration,
    string ProjectUniqueName,
    bool WaitForBuildToFinish
)
void BuildProject(
    String^ SolutionConfiguration, 
    String^ ProjectUniqueName, 
    bool WaitForBuildToFinish
)
abstract BuildProject : 
        SolutionConfiguration:string * 
        ProjectUniqueName:string * 
        WaitForBuildToFinish:bool -> unit 
function BuildProject(
    SolutionConfiguration : String, 
    ProjectUniqueName : String, 
    WaitForBuildToFinish : boolean
)

パラメーター

  • SolutionConfiguration
    型 : System.String
    必ず指定します。プロジェクトをビルドするためのコンテキストを提供する新しいソリューションの構成名。
  • ProjectUniqueName
    型 : System.String
    必ず指定します。ビルドするプロジェクト。
  • WaitForBuildToFinish
    型 : System.Boolean
    省略可能です。ビルドが完了するのを待つかどうかを指定します。 true の場合は待機し、それ以外の場合は待機しません。

解説

BuildProject はすぐに制御が戻ります。ソリューションのビルド操作がいつ完了したのかを判断するには、OnBuildDone イベントを確認する必要があります。

BuildProject では、アクティブなソリューション構成や選択されているプロジェクトを変更するような形でユーザー インターフェイス (UI: User Interface) に影響を与えることはありません。アクティブなソリューション構成に関連してプロジェクトをビルドするには、DTE.SolutionBuild.ActiveConfiguration.Name を使います。

BuildProject は、DTE.SuppressUI フラグに基づいた UI に影響を与えます。ステータス バーがちらつき、[出力ウィンドウ] および [タスク一覧] は常に更新されます。

BuildProject は、指定されたプロジェクト、および指定されたソリューション構成でビルドされるように選択されたすべての依存関係をビルドします。

この例では、デバッグ モードでプロジェクトをビルドします。このアドインを実行する前に、Visual Studio 統合開発環境 (IDE: integrated development environment) でプロジェクトを開きます。

このアドインの例を実行する方法の詳細については、「方法 : オートメーション オブジェクト モデルのコード例をコンパイルおよび実行する」を参照してください。

Imports EnvDTE
Imports EnvDTE80
Public Sub OnConnection(ByVal application As Object, _
 ByVal connectMode As ext_ConnectMode, ByVal addInInst As Object, _
 ByRef custom As Array) Implements IDTExtensibility2.OnConnection
    _applicationObject = CType(application, DTE2)
    _addInInstance = CType(addInInst, AddIn)
    SolutionBuildProjectExample(_applicationObject)
End Sub
Sub SolutionBuildProjectExample(ByVal dte As DTE2)
    ' Open a solution in Visual Studio before running this example.
    Try
        Dim soln As Solution2 = CType(_applicationObject.Solution, _
        Solution2)
        Dim sb As SolutionBuild2
        Dim bld As BuildDependencies
        Dim p1 As Project = soln.Projects.Item(1)
        sb = CType(soln.SolutionBuild, SolutionBuild2)
        bld = sb.BuildDependencies
        MsgBox("The project " & bld.Item(1).Project.Name & " has "  _
        & bld.Count.ToString() & " build dependencies.")
        MsgBox("Building the project in debug mode...")
        sb.BuildProject("Debug", p1.FullName, True)
    Catch ex As System.Exception
        MsgBox(ex.ToString)
    End Try
End Sub
using EnvDTE;
using EnvDTE80;
using System.Windows.Forms;
public void OnConnection(object application,
 ext_ConnectMode connectMode, object addInInst, ref Array custom)
{
    _applicationObject = (DTE2)application;
    _addInInstance = (AddIn)addInInst;
    SolutionBuildProjectExample(_applicationObject);
}
public void SolutionBuildProjectExample(DTE2 dte)
{
    try
    {
        Solution2 soln = (Solution2)_applicationObject.Solution;
        SolutionBuild2 sb;
        BuildDependencies bld;
        Project p1 = soln.Projects.Item(1);
        // Open a solution in Visual Studio before 
        // running this example.
        sb = (SolutionBuild2)soln.SolutionBuild;
        bld = sb.BuildDependencies;
        MessageBox.Show("The project " + bld.Item(1).Project.Name 
+ " has " + bld.Count.ToString() + " build dependencies.");
        MessageBox.Show("Building the project in debug mode...");
        sb.BuildProject("Debug", p1.FullName,true);
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.Message);
    }
}

.NET Framework セキュリティ

  • 直前の呼び出し元に対する完全な信頼。このメンバーは、部分的に信頼されているコードから使用することはできません。詳細については、「部分信頼コードからのライブラリの使用」を参照してください。

参照

関連項目

SolutionBuild2 インターフェイス

BuildProject オーバーロード

EnvDTE80 名前空間