Share via


Solution4.Properties Property

Gets a collection of all properties that pertain to the Solution2 object.

Namespace:  EnvDTE100
Assembly:  EnvDTE100 (in EnvDTE100.dll)

Syntax

'Declaration
ReadOnly Property Properties As Properties
    Get
Properties Properties { get; }
property Properties^ Properties {
    Properties^ get ();
}
abstract Properties : Properties
function get Properties () : Properties

Property Value

Type: EnvDTE.Properties
A Properties collection.

Implements

Solution3.Properties

Remarks

Some properties are exposed as automation properties on the _Solution or from objects you get to through the solution, such as the SolutionBuild object for build dependencies.

Examples

For information on how to run this add-in code, see How to: Compile and Run the Automation Object Model Code Examples.

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)
    PropertiesExample(_applicationObject)
End Sub

Sub PropertiesExample(ByVal dte As DTE2)
    ' This add-in lists all the properties for a solution.
    ' Open a solution in Visual Studio before 
    ' running this example.
    Try
        Dim soln As Solution4 = CType _
        (_applicationObject.Solution, Solution4)
        Dim solnName As String = _
        System.IO.Path.GetFileNameWithoutExtension(soln.FullName)
        Dim props As Properties = soln.Properties
        Dim prop As [Property]
        Dim msg As String = _
        solnName & " has the following properties:" & vbCrLf & vbCrLf
        For Each prop In props
            msg &= prop.Name & " = "
           Try
                msg &= prop.Value.ToString() & vbCrLf
           Catch
                msg &= "(Nothing)" & vbCrLf
            End Try
        Next
        MsgBox(msg)
    Catch ex As System.Exception
        MsgBox(ex.ToString)
    End Try
End Sub
using System.Windows.Forms;
public void OnConnection(object application,
 Extensibility.ext_ConnectMode connectMode, object addInInst,
 ref System.Array custom)
{
    _applicationObject = (DTE2)application;
    _addInInstance = (AddIn)addInInst;
    // Pass the applicationObject member variable to the code example.
    ProjectExample((DTE2)_applicationObject);
}

public void ProjectExample(DTE2 dte)
{
    // This add-in displays the properties in a solution. 
    // Open a solution in 
    // Visual Studio before running this example.
    try
    {
        Solution4 soln = (Solution4)_applicationObject.Solution;
        string solnName = 
          System.IO.Path.GetFileNameWithoutExtension(soln.FullName);
        Properties props = soln.Properties;
        string msg = solnName + " has the following properties:\n\n";
        foreach (Property prop in props)
        {
            msg += prop.Name + " = ";
            try
            {
                msg += prop.Value.ToString() + "\n";
            }
            catch
            {
                msg += "(Nothing)\n";
            }
        }
        MessageBox.Show(msg);
    }
    catch(SystemException ex)
    {
        MessageBox.Show("ERROR: " + ex);
    }
}

.NET Framework Security

See Also

Reference

Solution4 Interface

Properties Overload

EnvDTE100 Namespace

Other Resources

How to: Compile and Run the Automation Object Model Code Examples