Partilhar via


Interface SolutionFolder

As pastas de solução são recipientes de projeto que permitem aos desenvolvedores organizar melhor os aplicativos grandes.

Namespace:  EnvDTE80
Assembly:  EnvDTE80 (em EnvDTE80.dll)

Sintaxe

'Declaração
<GuidAttribute("F8F69788-267C-4408-8967-74F26108C438")> _
Public Interface SolutionFolder
[GuidAttribute("F8F69788-267C-4408-8967-74F26108C438")]
public interface SolutionFolder
[GuidAttribute(L"F8F69788-267C-4408-8967-74F26108C438")]
public interface class SolutionFolder
[<GuidAttribute("F8F69788-267C-4408-8967-74F26108C438")>]
type SolutionFolder =  interface end
public interface SolutionFolder

O tipo SolutionFolder expõe os membros a seguir.

Propriedades

  Nome Descrição
Propriedade pública DTE Obtém o objeto de extensibilidade de nível superior.
Propriedade pública Hidden Define ou obtém o atributo oculto da solução.
Propriedade pública Parent Obtém o objeto pai imediato de um Find objeto.

Início

Métodos

  Nome Descrição
Método público AddFromFile Adiciona um projeto existente para a pasta de solução.
Método público AddFromTemplate Adiciona um novo projeto para a pasta de solução com base em um modelo de projeto.
Método público AddSolutionFolder Adiciona uma pasta de solução para um ProjectItems coleção.

Início

Comentários

Em Visual Studio 2005, soluções pode conter pastas de solução com pastas de projeto. As pastas de solução são recipientes de projeto que permitem aos desenvolvedores organizar melhor os aplicativos grandes.

A solução Projects propriedade retorna uma coleção de Project objetos. Cada projeto tem um Kind propriedade que pode ser definida como vsProjectKindSolutionFolder. Para obter o SolutionFolder interface, chamada Project.Objecte em seguida, converta o objeto retornado para um SolutionFolder tipo.

Exemplos

Este exemplo cria uma nova pasta de solução e adiciona um projeto de um arquivo existente. Antes de executar este exemplo, criar um "projetos" pasta de sua unidade principal ("c:" Neste exemplo) e criar um Visual C# projeto de biblioteca de classe, denominado "classlibrary1" nessa pasta. Você também deve abrir um projeto a Visual Studio integradas ao ambiente de desenvolvimento (IDE) antes de executar este add-in.

Para obter mais informações sobre como executar este exemplo como um suplemento, consulte Como: compilar e Executar a automação de exemplos de Código do modelo de objeto.

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)
    solnFolderAddFromFileExample(_applicationObject)
End Sub
Sub solnFolderAddFromFileExample(ByVal dte As DTE2)
    ' Before running this example, create a "Projects" folder
    ' off your main drive (C: in this example), and create a C# 
    ' class library project, named ClassLibrary1 in that folder.
    Dim soln As Solution2 = CType(_applicationObject.Solution _
    , Solution2)
    Dim prj As Project
    Dim SF As SolutionFolder
    Try
        Dim prjPath As String = _
        "C:\Projects\ClassLibrary1\ClassLibrary1\ClassLibrary1.csproj"
        ' Open a project in the Visual Studio IDE before running 
        ' this add-in.
        ' Add a solution folder.
        prj = soln.AddSolutionFolder("A new soln folder")
        SF = CType(prj.Object, SolutionFolder)
        ' Add a project to the new solution folder.
        SF.AddFromFile(prjPath)
        MsgBox("Added a new solution folder that contains a _
        C# project named ClassLibrary1.")
    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;
    solnFolderAddFromFileExample(_applicationObject);
}
public void solnFolderAddFromFileExample(DTE2 dte)
{
    // Before running this example, create a "Projects" folder
    // off your main drive (C: in this example), and create a C# 
    // class library project, named ClassLibrary1 in that folder.
    Solution2 soln = (Solution2)_applicationObject.Solution;
    Project prj;
    SolutionFolder SF;
    try
    {
        String prjPath =
 "C:\\Projects\\ClassLibrary1\\ClassLibrary1\\ClassLibrary1.csproj";
        // Open a project in the Visual Studio IDE before running 
        // this add-in.
        // Add a solution folder.
        prj = soln.AddSolutionFolder("A new soln folder");
        SF = (SolutionFolder)prj.Object;
        // Add a project to the new solution folder.
        SF.AddFromFile(prjPath);
    MessageBox.Show("Added a new solution folder that contains a 
C# project named ClassLibrary1.");
    }
    catch(SystemException ex)
    {
        MessageBox.Show(ex.ToString());
    }
}

Consulte também

Referência

Namespace EnvDTE80