Condividi tramite


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

Potrebbe essere necessario esaminare a livello di codice la struttura del codice in un'applicazione Visual Basic o Visual C#. desiderare di conoscere gli spazi dei nomi definiti nell'applicazione, nonché le relative relazioni di annidamento. In alternativa, è possibile creare un documento in cui siano elencate le classi, e i relativi membri pubblici, come base per la documentazione.

L'oggetto CodeModel2 è un oggetto estensibilità generale che consente di accedere al codice in un'applicazione. L'oggetto CodeModel2 non fornisce un elenco testuale del codice, ma una raccolta annidata di oggetti che rappresenta elementi di codice. Ogni spazio dei nomi nel codice, ad esempio, è rappresentato da un oggetto CodeNamespace. La proprietà CodeModel accede all'oggetto CodeModel2 associato a un progetto.

L'oggetto FileCodeModel2 è un oggetto estensibilità generale che consente di accedere al codice in un solo file di origine. Ogni file di origine di un'applicazione è rappresentato da un oggetto ProjectItem e l'oggetto FileCodeModel2 associato a un elemento di progetto è presente nella proprietà FileCodeModel.

Gli oggetti CodeModel2 e FileCodeModel2 forniscono rispettivamente le proprietà CodeModel2.CodeElements e FileCodeModel.CodeElements, ovvero una raccolta di oggetti CodeElement2. Visual Basic e Visual C# supportano gli oggetti CodeModel2 e FileCodeModel in modalità leggermente diverse. Per un esempio di implementazione di Visual Basic, vedere Individuazione di codice mediante il modello di codice (Visual Basic) e Procedura: utilizzare l'oggetto CodeModel per analizzare codice Visual Basic. Per un esempio di implementazione di Visual C#, vedere Individuazione di codice mediante il modello di codice (Visual C#) e Procedura: creare una classe C# utilizzando l'oggetto CodeModel.

In alcuni linguaggi non è implementato l’intero modello di codice di Visual Studio. Gli argomenti della Guida segnalano le eventuali eccezioni. La maggior parte delle differenze tra implementazioni del modello di codice è dovuta a differenze funzionali tra i linguaggi. Non è ad esempio possibile aggiungere funzioni a oggetti CodeNamespace in Visual Basic o Visual C# poiché solo in Visual C++ sono disponibili definizioni di funzioni di primo livello.

Nella tabella riportata di seguito sono elencati i principali oggetti modello di codice. Fare clic sui collegamenti per visualizzare l'elenco di metodi e proprietà per ogni oggetto.

Type

Descrizione

CodeNamespace

Rappresenta un costrutto di uno spazio dei nomi in un file di origine.

CodeStruct2

Rappresenta una struttura nel codice sorgente.

CodeInterface2

Rappresenta un'interfaccia nel codice sorgente.

CodeClass2

Rappresenta una classe nel codice sorgente.

CodeEnum

Rappresenta un'enumerazione nel codice sorgente.

CodeVariable2

Definisce un costrutto di una variabile in un file di origine.

CodeDelegate2

Rappresenta un delegato nel codice sorgente.

CodeElement2

Rappresenta un costrutto o un elemento di codice in un file di origine.

CodeEvent

Modella un elemento di un evento di codice.

CodeProperty2

Definisce un costrutto di una proprietà in un file di origine.

CodeAttribute2

Definisce un attributo per un elemento di codice.

CodeImport

Definisce l'utilizzo di istruzioni che importano spazi dei nomi.

CodeFunction2

Rappresenta un costrutto di funzione in un file di origine.

CodeParameter2

Definisce un parametro di una funzione, una proprietà e così via.

Elementi di codice annidati

Gli elementi di codice di un'applicazione sono organizzati in un'architettura annidata. È ad esempio possibile che nell'oggetto FileCodeModel2 di un elemento di progetto sia contenuto, nella relativa raccolta CodeElements, un elemento di codice per uno spazio dei nomi. L'oggetto CodeNamespace che rappresenta lo spazio dei nomi potrebbe contenere diversi altri elementi di codice che a loro volta rappresentano classi nella relativa proprietà Members. È possibile che in ogni elemento CodeClass2 siano a loro volta contenuti elementi di codice che rappresentano proprietà (oggetto CodeProperty2) e metodi (oggetto CodeFunction2). I metodi per il recupero di elementi di codice annidati dipendono dal tipo di elemento di codice e vengono descritti nella sezione successiva.

Categorie di elementi di codice

La classe CodeElement2 è una classe base che rappresenta tutti gli elementi di codice in un elemento di progetto (file di origine). Molte classi derivano da CodeElement2 per rappresentare i costrutti in un'applicazione, inclusi spazi dei nomi, classi, proprietà, metodi ed eventi. Gli elementi di codice sono raggruppati in due ampie categorie, quelli che rappresentano i tipi e quelli che non li rappresentano.

Alcuni elementi di codice in un'applicazione rappresentano dei tipi. Questi elementi di codice derivano dall'oggetto CodeType e dall'oggetto CodeElement2:

È possibile determinare se un riferimento a un oggetto CodeElement2 è uno di questi tipi utilizzando la proprietà IsCodeType. Per individuare gli elementi di codice annidati di questi tipi, utilizzare la proprietà Members, che restituisce una raccolta CodeElements. Procedura: utilizzare l'oggetto CodeModel per analizzare codice Visual Basic include un esempio che trova tutte le classi in un progetto.

Le procedure per trovare gli elementi di codice annidati sotto altri tipi di elementi di codice dipendono dal tipo di elemento di codice annidato. Poiché, ad esempio, una proprietà dispone unicamente di un metodo Get e di un metodo Set, l'oggetto CodeProperty2 associato a una proprietà disporrà di proprietà Getter e Setter dalle quali verranno restituiti elementi CodeFunction2. Nell'elenco che segue sono elencate le proprietà da utilizzare per individuare gli elementi di codice annidati nei tipi di elementi di codice.

Type

Proprietà

CodeFunction

Parameters

CodeNamespace

Members

CodeProperty

Getter e Setter.

Elementi di codice da riferimenti esterni

È possibile che nel codice siano contenute dichiarazioni di tipi provenienti da tipi definiti nei riferimenti al progetto. I riferimenti al progetto vengono aggiunti tramite la finestra di dialogo Aggiungi riferimenti o mediante il metodo di estensibilitàReferences.Add. Nel sistema del progetto Visual Basic gli oggetti CodeTypeRef2, che rappresentano questi riferimenti, non vengono risolti ad eccezione dei relativi nomi. Pertanto, se si tenta di utilizzare uno degli altri metodi o proprietà dell'oggetto CodeElement2 associato al riferimento, che non sia la proprietà Name, verrà generata un'eccezione "Not implemented". Questi riferimenti vengono definiti elementi di codice "con solo nome del tipo". Gli oggetti CodeType che rappresentano riferimenti esterni dispongono della proprietà InfoLocation impostata su vsCMInfoLocationNone.

Errori di compilazione e l'oggetto CodeModel

Quando si scrive codice che conserva riferimenti a oggetti CodeElement2, è necessario ricordare che il codice sorgente sottostante può cambiare mentre si conserva il riferimento. L'elemento di codice può essere eliminato, rinominato oppure essere compreso in un errore di compilazione. Quando si verifica uno di questi casi, qualsiasi chiamata all'oggetto CodeElement2 restituirà il messaggio di errore "Eccezione da HRESULT: 0x80047E2C".

Vedere anche

Attività

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

Risoluzione dei problemi relativi all'Extensibility in Visual Basic e Visual C#

Concetti

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

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