This documentation is archived and is not being maintained.

BuildPropertyGroup Class

Represents a collection of BuildProperty objects.

Namespace:  Microsoft.Build.BuildEngine
Assembly:  Microsoft.Build.Engine (in Microsoft.Build.Engine.dll)

Public Class BuildPropertyGroup _
	Implements IEnumerable
Dim instance As BuildPropertyGroup

A BuildPropertyGroup object can represent a PropertyGroup element in the project, or a virtual collection of properties, such as global properties or environment variable properties.

The following example creates a Project object and uses the LoadXml method to add content to the project. The BuildProperty, BuildPropertyGroup, and BuildPropertyGroupCollection classes are used to add, remove, and change items in the project.

Module Module1

    ''' <summary> 
    ''' This code demonstrates the use of the following methods: 
    '''     Engine constructor 
    '''     Project constructor 
    '''     Project.LoadFromXml 
    '''     Project.Xml 
    '''     BuildPropertyGroupCollection.GetEnumerator 
    '''     BuildPropertyGroup.GetEnumerator 
    '''     BuildProperty.Name (get) 
    '''     BuildProperty.Value (set) 
    '''     BuildPropertyGroup.RemoveProperty 
    '''     BuildPropertyGroup.AddNewProperty 
    ''' </summary> 
    ''' <remarks></remarks> 
    Sub Main()

        ' Create a new Engine object. 
        Dim engine As New Engine(Environment.CurrentDirectory)

        ' Create a new Project object. 
        Dim project As New Project(engine)

        ' Load the project with the following XML, which contains 
        ' two PropertyGroups.
        project.LoadXml( _
            "<Project xmlns=''>" & _
                "<PropertyGroup>" & _
                    "<Optimize>true</Optimize>" & _
                    "<WarningLevel>4</WarningLevel>" & _
                "</PropertyGroup>" & _
                "<PropertyGroup>" & _
                    "<OutputPath>bin\debug\</OutputPath>" & _
                    "<RemoveThisPropertyPlease>1</RemoveThisPropertyPlease>" & _
                "</PropertyGroup>" & _

        ' Iterate through each PropertyGroup in the Project.  There are two. 
        For Each pg As BuildPropertyGroup In project.PropertyGroups

            Dim propertyToRemove As BuildProperty
            propertyToRemove = Nothing 

            ' Iterate through each Property in the PropertyGroup. 
            For Each buildProperty As BuildProperty In pg

                ' If the property's name is "RemoveThisPropertyPlease", then 
                ' store a reference to this property in a local variable, 
                ' so we can remove it later. 
                If buildProperty.Name = "RemoveThisPropertyPlease" Then
                    propertyToRemove = buildProperty
                End If 

                ' If the property's name is "OutputPath", change its value 
                ' from "bin\debug\" to "bin\release\". 
                If buildProperty.Name = "OutputPath" Then
                    buildProperty.Value = "bin\release\" 
                End If 


            ' Remove the property named "RemoveThisPropertyPlease" from the 
            ' PropertyGroup 
            If Not propertyToRemove Is Nothing Then
            End If 

            ' For each PropertyGroup that we found, add to the end of it 
            ' a new property called "MyNewProperty".
            pg.AddNewProperty("MyNewProperty", "MyNewValue")


        '  The project now looks like this: 
        '      <?xml version="1.0" encoding="utf-16"?> 
        '      <Project xmlns=""> 
        '        <PropertyGroup> 
        '          <Optimize>true</Optimize> 
        '          <WarningLevel>4</WarningLevel> 
        '          <MyNewProperty>MyNewValue</MyNewProperty> 
        '        </PropertyGroup> 
        '        <PropertyGroup> 
        '          <OutputPath>bin\release</OutputPath> 
        '          <MyNewProperty>MyNewValue</MyNewProperty> 
        '        </PropertyGroup> 
        '      </Project>

    End Sub 

End Module


Any public static (Shared in Visual Basic) members of this type are thread safe. Any instance members are not guaranteed to be thread safe.

Windows 7, Windows Vista, Windows XP SP2, Windows XP Media Center Edition, Windows XP Professional x64 Edition, Windows XP Starter Edition, Windows Server 2008 R2, Windows Server 2008, Windows Server 2003, Windows Server 2000 SP4, Windows Millennium Edition, Windows 98

The .NET Framework and .NET Compact Framework do not support all versions of every platform. For a list of the supported versions, see .NET Framework System Requirements.

.NET Framework

Supported in: 3.5, 3.0, 2.0