Mise à jour : novembre 2007
L'utilisation de la hiérarchie des objets CodeModel2 est une alternative à la tâche parfois complexe qu'est l'analyse de texte dans un fichier code. Vous pouvez utiliser l'objet CodeModel2 :
Les procédures suivantes supposent que vous sachiez comment accéder à l'environnement de développement des macros et créer un projet macro. Pour plus d'informations, consultez Ajouter le projet macro, boîte de dialogue.
Les espaces de noms se trouvent à la racine de l'objet CodeModel2 ou sont imbriqués dans d'autres objets CodeNamespace. Ceci reflète les contraintes de syntaxe sur les espaces de noms. Un espace de noms est soit un bloc de code de niveau supérieur soit contenu dans un autre espace de noms. Pour utiliser les procédures suivantes, vous devez avoir ouvert un projet dans l'environnement de développement intégré (IDE) de Visual Studio.
Remarque : |
|---|
Selon vos paramètres actifs ou votre édition, les boîtes de dialogue et les commandes de menu que vous voyez peuvent différer de celles qui sont décrites dans l'aide. Ces procédures ont été développées avec les paramètres de développement généraux actifs. Pour modifier vos paramètres, choisissez Importation et exportation de paramètres dans le menu Outils. Pour plus d'informations, consultez Paramètres Visual Studio. |
Pour trouver tous les espaces de noms contenus dans votre projet
Écrivez une méthode récursive pour récupérer tous les espaces de noms d'une application.
L'objet CodeNamespace possède une propriété Members qui contient tous les CodeElements au premier niveau de l'espace de noms.
' Macro editor
Sub FindAllNamespaces()
Dim cm As CodeModel
cm = DTE.Solution.Projects.Item(1).CodeModel
' Look for all the namespaces in the CodeElements
' of the project.
Dim list As String
Dim ce As CodeElement
For Each ce In cm.CodeElements
If TypeOf ce Is CodeNamespace Then
GetNamespace(CType(ce, CodeNamespace), list)
End If
Next
MsgBox(list)
End Sub
Sub GetNamespace(ByVal ns As CodeNamespace, ByRef list As String)
' Add this namespace to the list.
list &= ns.Name & ControlChars.CrLf
Dim aspace As CodeNamespace
Dim ce As CodeElement
' Look for more namespaces.
For Each ce In ns.Members
If TypeOf ce Is CodeNamespace Then
GetNamespace(CType(ce, CodeNamespace), list)
End If
Next
End Sub
Remarque : |
|---|
Vous trouverez tous les espaces de noms dans un même fichier source en utilisant la propriété FileCodeModel de l'objet ProjectItem associé au fichier source. L'utilisation de cette approche nécessite une légère modification de la méthode FindAllNamespaces . |

Recherche de l'espace de noms par défaut
La procédure ci-dessus retourne uniquement les espaces de noms que vous avez définis dans votre application. Chaque projet Visual Basic contient également un espace de noms par défaut. Tous les éléments de code de votre application se trouvent dans l'espace de noms par défaut, alors que la collection CodeElements ne contient pas d'objet CodeNamespace pour celui-ci. L'espace de noms par défaut peut être récupéré de tout élément CodeType de niveau supérieur.
Pour trouver l'espace de noms par défaut de votre projet

Recherche de classes
Les déclarations de classes et les espaces de noms sont récupérés par le biais de moyens semblables. Les classes peuvent être imbriquées dans d'autres classes. Vous pouvez donc trouver des classes définies à la fois dans les espaces de noms et dans d'autres classes.
Pour trouver toutes les classes contenues dans votre projet

Voir aussi