Sdílet prostřednictvím


CodeAttribute2.Arguments – vlastnost

Získá kolekce CodeElement objekty, které obsahuje CodeAttributeArgument přidružené objekty atributů.

Obor názvů:  EnvDTE80
Sestavení:  EnvDTE80 (v EnvDTE80.dll)

Syntaxe

'Deklarace
ReadOnly Property Arguments As CodeElements
    Get
CodeElements Arguments { get; }
property CodeElements^ Arguments {
    CodeElements^ get ();
}
abstract Arguments : CodeElements
function get Arguments () : CodeElements

Hodnota vlastnosti

Typ: EnvDTE.CodeElements
Kolekce CodeElement objektů.

Poznámky

Toto je nová vlastnost pro Visual Studio 2005.

Poznámka

Kód hodnoty argumentu atributu, po přiřazen, nejsou zachovány v paměti pomocí Visual Studio, tedy může nebo nemusí být platné dojde budoucí aktualizace argumentu atributu kód. Další argument access může vrátit, E_FAIL nebo zcela jinou hodnotu. (Vše, co děti prvku ovlivňuje však nemá problém.)

V důsledku tohoto chování deterministický měly načíst hodnoty v argumentu před jeho změna. Pokud nastavíte argument atributu kód v kódu, jako například myAttrArg.Value = """a first value""", pak je měly explicitně odkazovat jej před aktualizací, například myAttrArg = myAttr.Arguments.Item("first value")a potom přiřadit novou hodnotu myAttrArg.Value = """a second value""". Tím předejdete změní správný argument.

Hodnoty prvků modelu kód jako třídy, struktury, funkce, atributy, delegátů a tak dále mohou být také-deterministický po provedení určité typy úprav, což znamená, že jejich hodnoty nelze dovolávat vždy zůstává stejné. Další informace naleznete v části Změna hodnoty prvku modelu kódu Discovering Code by Using the Code Model (Visual Basic).

Příklady

// The following example creates a new namespace and attribute in
// the current class and lists some of the attribute's properties.
public void CreateClassAndAttrib(DTE2 applicationObject)
{
    // Before running, load or create a project.
    FileCodeModel2 fcm2 = GetFileCodeModel(applicationObject);
    CodeAttribute2 cmAttribute;
    CodeClass2 cmClass;
    String msg = null;

    if (fcm2 != null)
    {
        CodeNamespace cmNamespace;
        // Try to create a new namespace.
        try
        {
            cmNamespace = fcm2.AddNamespace("CMNamespace", -1);
            // If successful, create the other code elements.
            if (cmNamespace != null)
            {
                cmClass = (CodeClass2)cmNamespace.AddClass("ANewClass", 
                -1, null, null, vsCMAccess.vsCMAccessPrivate);
                cmAttribute = (CodeAttribute2)cmClass.AddAttribute
                ("NewAttribute", "AttributeValue", -1);
                msg += "Arguments: " + cmAttribute.Arguments + 
                Environment.NewLine;
                msg += "Count: " + cmAttribute.Children.Count + 
                Environment.NewLine;
                msg += "Endpoint Location: " + 
                cmAttribute.EndPoint.DisplayColumn + 
                Environment.NewLine;
                MessageBox.Show(msg); 
            }
            else
            {
                MessageBox.Show("Cannot continue - no filecodemodel 
                available.");
            }
        }
        catch (Exception ex)
        {
            MessageBox.Show("ERROR: " + ex);
        }
    }
}

public FileCodeModel2 GetFileCodeModel(DTE2 applicationObject)
{
    // Returns the FileCodeModel object of the active 
    // window.
    TextWindow txtWin = 
    (TextWindow)applicationObject.ActiveWindow.Object;
    FileCodeModel2 fcm2;
    if (txtWin != null)
    {
        try
        {
             fcm2 = (FileCodeModel2)txtWin.Parent.
             ProjectItem.FileCodeModel;
             return fcm2;
        }
        catch (Exception ex)
        {
             MessageBox.Show("ERROR: " + ex);
             return null;
        }
    }
    else
        return null;
}

Zabezpečení rozhraní .NET Framework

Viz také

Odkaz

CodeAttribute2 Rozhraní

EnvDTE80 – obor názvů

Další zdroje

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

Discovering Code by Using the Code Model (Visual Basic)

Discovering Code by Using the Code Model (Visual C#)