Condividi tramite


Procedura: utilizzare l'oggetto CodeModel per analizzare codice Visual Basic

L'utilizzo della gerarchia di oggetti CodeModel2 rappresenta un'alternativa all'attività, potenzialmente complessa, di analisi del testo in un file di codice. È possibile utilizzare l'oggetto CodeModel2 nei seguenti casi:

  • Per analizzare la struttura del codice.

  • Come base per la documentazione del codice.

Nelle procedure riportate di seguito si presume che l'utente sia in grado di accedere all'ambiente di sviluppo delle macro e di creare un progetto macro. Per ulteriori informazioni, vedere Add Macro Project Dialog Box.

Gli spazi dei nomi sono contenuti al livello radice dell'oggetto CodeModel2 oppure annidati in altri oggetti CodeNamespace. Da questo derivano i vincoli di sintassi sugli spazi dei nomi. Uno spazio dei nomi può essere un blocco di codice di primo livello oppure uno spazio dei nomi contenuto in un altro spazio dei nomi. Per utilizzare le routine elencate di seguito, è necessario che un progetto sia aperto nell'ambiente di sviluppo integrato (IDE, Integrated Development Environment) di Visual Studio.

Nota

È possibile che le finestre di dialogo e i comandi di menu visualizzati siano diversi da quelli descritti nella Guida a seconda delle impostazioni attive o dell'edizione del programma.Queste procedure sono state sviluppate con le Impostazioni generali per lo sviluppo attive.Per modificare le impostazioni, scegliere Importa/esporta impostazioni dal menu Strumenti.Per ulteriori informazioni, vedere Personalizzazione delle impostazioni di sviluppo in Visual Studio.

Per trovare tutti gli spazi dei nomi contenuti in un progetto

  • Scrivere un metodo ricorsivo per recuperare tutti gli spazi dei nomi presenti in un'applicazione.

    L'oggetto CodeNamespace dispone di una proprietà Members che contiene tutti i CodeElements nel primo livello dello spazio dei nomi.

    ' 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
    

    Nota

    È possibile trovare tutti gli spazi dei nomi in un file di origine utilizzando la proprietà FileCodeModel dell'oggetto ProjectItem associato al file di origine.L'utilizzo di tale approccio richiederà una piccola modifica al metodo FindAllNamespaces .

Ricerca dello spazio dei nomi predefinito

Tramite la routine illustrata in precedenza vengono restituiti solo gli spazi dei nomi definiti nell'applicazione. In ciascun progetto Visual Basic è contenuto anche uno spazio dei nomi predefinito. Tutti gli elementi di codice dell'applicazione sono contenuti nello spazio dei nomi predefinito, sebbene nella raccolta CodeElements non sia presente un oggetto CodeNamespace a esso associato. È possibile recuperare lo spazio dei nomi predefinito da qualsiasi elemento CodeType di primo livello.

Per trovare lo spazio dei nomi predefinito per il progetto

  • Verificare gli elementi di codice di primo livello del progetto. Qualsiasi elemento di codice CodeType restituisce l'elemento CodeNamespace per il progetto.

    Sub FindDefaultNamespace()
       Dim cm As CodeModel
       cm = DTE.Solution.Projects.Item(1).CodeModel
    
       Dim ce As CodeElement
       Dim ct As CodeType = Nothing
       Dim defNameSpace As CodeNamespace
       For Each ce In cm.CodeElements
          If TypeOf ce Is CodeType Then
             ct = CType(ce, CodeType)
             defNameSpace = ct.Namespace
          End If
       Next
    
       If Not IsNothing(defNameSpace) Then
          MsgBox(defNameSpace.Name)
       End If
    End Sub
    

Ricerca delle classi

Gli spazi dei nomi e le dichiarazioni di classe vengono recuperate in modo analogo. Poiché le classi potrebbero essere annidate in altre classi, è possibile trovare classi definite sia negli spazi dei nomi sia in altre classi.

Per trovare tutte le classi contenute in un progetto

  • Scrivere un metodo ricorsivo, come quello riportato di seguito, per trovare le dichiarazioni di classe in un progetto.

    ' Macro editor
    Sub FindAllClasses()
       Dim cm As CodeModel
       cm = DTE.Solution.Projects.Item(1).CodeModel
    
       ' Look for all the namespaces and classes in the 
       ' project.
       Dim list As String
       Dim ce As CodeElement
       For Each ce In cm.CodeElements
          If (TypeOf ce Is CodeNamespace) Or (TypeOf ce Is CodeClass) Then
             ' Determine whether that namespace or class 
             ' contains other classes.
             GetClass(ce, list)
          End If
       Next
    
       MsgBox(list)
    End Sub
    
    Sub GetClass(ByVal ct As CodeElement, ByRef list As String)
       ' ct could be a namespace or a class. Add it to the list
       ' if it is a class.
       If (TypeOf ct Is CodeClass) Then
          list &= ct.Name & ControlChars.CrLf
       End If
    
       ' Determine whether there are nested namespaces or classes that 
       ' might contain other classes.
       Dim aspace As CodeNamespace
       Dim ce As CodeElement
       Dim cn As CodeNamespace
       Dim cc As CodeClass
       Dim elements As CodeElements
       If (TypeOf ct Is CodeNamespace) Then
          cn = CType(ct, CodeNamespace)
          elements = cn.Members
       Else
          cc = CType(ct, CodeClass)
          elements = cc.Members
       End If
    
       For Each ce In elements
          If (TypeOf ce Is CodeNamespace) Or (TypeOf ce Is CodeClass) Then
             GetClass(ce, list)
          End If
       Next
    End Sub
    

Vedere anche

Attività

Procedura: creare una classe C# utilizzando l'oggetto CodeModel

Concetti

Cenni preliminari sull'oggetto CodeModel per applicazioni Visual Basic e C#

Individuazione di codice mediante il modello di codice (Visual Basic)

Individuazione di codice mediante il modello di codice (Visual C#)