CodeClass2.AddBase-Methode
Fügt der Liste der geerbten Objekte ein Element hinzu.
Namespace: EnvDTE80
Assembly: EnvDTE80 (in EnvDTE80.dll)
Syntax
'Declaration
Function AddBase ( _
Base As Object, _
Position As Object _
) As CodeElement
CodeElement AddBase(
Object Base,
Object Position
)
CodeElement^ AddBase(
Object^ Base,
Object^ Position
)
abstract AddBase :
Base:Object *
Position:Object -> CodeElement
function AddBase(
Base : Object,
Position : Object
) : CodeElement
Parameter
Base
Typ: ObjectErforderlich. Die Klasse, von der die Implementierung abgeleitet wird. Dabei handelt es sich entweder um eine CodeClass oder um einen vollqualifizierten Typnamen. Im systemeigenen Visual C++ ist ein doppelter Doppelpunkt (::) als Trennzeichen für vollqualifizierte Typnamen erforderlich. Alle anderen Sprachen verwenden das durch Punkte getrennte Format.
Position
Typ: ObjectOptional. Standardwert = 0. Das Codeelement, hinter dem die neue Basis hinzugefügt werden soll.
Wenn der Wert ein Long-Datentyp ist, gibt Position das Element an, hinter dem die neue Basis hinzugefügt werden soll.
Da die Zählung bei Auflistungen mit 1 beginnt, wird mit dem Wert 0 angegeben, dass das neue Element am Anfang der Auflistung eingefügt werden soll. Bei dem Wert -1 wird das Element am Ende eingefügt.
Rückgabewert
Typ: CodeElement
Ein CodeElement-Objekt.
Hinweise
Die AddBase-Methode gibt keinen CodeType, sondern ein CodeElement-Objekt zurück, um den Anforderungen von Visual C++ gerecht zu werden. Der Kind des zurückgegebenen Objekts ist vsCMElementVCBase für die Implementierung von Visual C++.
Hinweis
Die Werte von Codemodellelementen wie Klassen, Strukturen, Funktionen, Attributen, Delegaten usw. können nach bestimmten Bearbeitungsvorgängen nicht deterministisch sein, d. h., dass nicht mehr davon ausgegangen werden kann, dass ihre Werte immer unverändert bleiben.Weitere Informationen finden Sie im Abschnitt zum Änderungsverhalten von Codemodellelementwerten unter Ermitteln von Code über das Codemodell (Visual Basic).
Beispiele
[Visual Basic]
Sub AddBaseExample(ByVal dte As DTE2)
' Before running this example, open a code document from a project
' and place the insertion point inside a class definition.
Try
' Retrieve the CodeClass at the insertion point.
Dim sel As TextSelection = _
CType(dte.ActiveDocument.Selection, TextSelection)
Dim cls As CodeClass = _
CType(sel.ActivePoint.CodeElement( _
vsCMElement.vsCMElementClass), CodeClass)
Dim cm As CodeModel = _
cls.ProjectItem.ContainingProject.CodeModel
' Create a fully qualified base name.
Dim baseName As String = ConvertFullName(cm, _
"System.Collections.CollectionBase")
' Add a base to the class.
cls.AddBase(baseName)
Catch ex As Exception
MsgBox(ex.Message)
End Try
End Sub
Function ConvertFullName(ByVal cm As CodeModel, _
ByVal fullName As String) As String
' Convert a .NET type name into a C++ type name.
If (cm.Language = CodeModelLanguageConstants.vsCMLanguageVC) Or _
(cm.Language = CodeModelLanguageConstants.vsCMLanguageMC) Then
Return fullName.Replace(".", "::")
Else
Return fullName
End If
End Function
[C#]
public void AddBaseExample(DTE2 dte)
{
// Before running this example, open a code document from a project
// and place the insertion point inside a class definition.
try
{
// Retrieve the CodeClass at the insertion point.
TextSelection sel =
(TextSelection)dte.ActiveDocument.Selection;
CodeClass cls =
(CodeClass)sel.ActivePoint.get_CodeElement(
vsCMElement.vsCMElementClass);
CodeModel cm = cls.ProjectItem.ContainingProject.CodeModel;
// Create a fully qualified base name.
string baseName = ConvertFullName(cm,
"System.Collections.CollectionBase");
// Add a base to the class.
cls.AddBase(baseName, -1);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
string ConvertFullName(CodeModel cm, string fullName)
{
// Convert a .NET type name into a C++ type name.
if ((cm.Language == CodeModelLanguageConstants.vsCMLanguageVC) ||
(cm.Language == CodeModelLanguageConstants.vsCMLanguageMC))
return fullName.Replace(".", "::");
else
return fullName;
}
.NET Framework-Sicherheit
- Volle Vertrauenswürdigkeit für den unmittelbaren Aufrufer. Dieser Member kann von nur teilweise vertrauenswürdigem Code nicht verwendet werden. Weitere Informationen finden Sie unter Verwenden von Bibliotheken aus teilweise vertrauenswürdigem Code.
Siehe auch
Referenz
Weitere Ressourcen
Gewusst wie: Kompilieren und Ausführen der Codebeispiele für das Automatisierungsobjektmodell