Condividi tramite


Direttive per il compilatore

In questo argomento vengono descritte le direttive per il preprocessore e le direttive del compilatore.

Per le direttive F# Interactive (dotnet fsi), vedere Programmazione interattiva con F#.

Direttive per il preprocessore

Una direttiva per il preprocessore è preceduta dal simbolo # e viene visualizzata in una riga da sola. Viene interpretata dal preprocessore, che viene eseguito prima del compilatore stesso.

Nella tabella riportata di seguito sono elencate le direttive per il preprocessore disponibili in F#.

Direttiva Descrizione
#if simbolo Supporta la compilazione condizionale. Codice nella sezione dopo che #if è incluso se il simbolo è definito. Il simbolo può anche essere negato con !.
#else Supporta la compilazione condizionale. Contrassegna una sezione di codice da includere se il simbolo usato nella precedente direttiva #if non è definito.
#endif Supporta la compilazione condizionale. Contrassegna la fine di una sezione condizionale di codice.
#[riga] int,
#[riga] intstring,
#[riga] intverbatim-string
Indica la riga e il nome di file del codice sorgente originale per il debug. Questa funzionalità viene fornita per gli strumenti che generano codice sorgente F#.
#nowarn warningcode Disabilita un avviso o più avvisi del compilatore. Per disabilitare più numeri di avviso sulla stessa riga, separare ogni stringa con uno spazio.
Ad esempio: #nowarn 9 42

L'effetto della disabilitazione di un avviso si applica all'intero file, incluse parti del file che precedono la direttiva.|

Direttive di compilazione condizionale

Il codice disattivato da una di queste direttive viene visualizzato in grigio nell'editor di Visual Studio Code.

Nota

Il comportamento delle direttive di compilazione condizionale non è lo stesso come in altri linguaggi. Ad esempio, è possibile usare espressioni booleane che includono simboli e true e false non hanno alcun significato speciale. I simboli usati nella direttiva if devono essere definiti dalla riga di comando o nelle impostazioni del progetto e non esiste alcuna direttiva per il preprocessore define.

Nel codice di esempio che segue viene illustrato l'uso delle direttive #if, #else e #endif. In questo esempio, il codice contiene due versioni della definizione di function1. Quando VERSION1 viene definito usando l'opzione del compilatore -define, viene attivato il codice tra la #if direttiva e la #else direttiva . In caso contrario, viene attivato il codice tra #else e #endif.

#if VERSION1
let function1 x y =
   printfn "x: %d y: %d" x y
   x + 2 * y
#else
let function1 x y =
   printfn "x: %d y: %d" x y
   x - 2*y
#endif

let result = function1 10 20

Non esiste alcuna direttiva per il preprocessore #define in F#. È necessario usare l'opzione del compilatore o le impostazioni di progetto per definire i simboli usati per la direttiva #if.

Le direttive di compilazione condizionale possono essere annidate. Il rientro non è significativo per le direttive per il preprocessore.

È anche possibile negare un simbolo con !. In questo esempio il valore di una stringa è qualcosa solo quando non si esegue il debug:

#if !DEBUG
let str = "Not debugging!"
#else
let str = "Debugging!"
#endif

Direttive di riga

Durante la compilazione, il compilatore segnala errori nel codice F# facendo riferimento ai numeri di riga in cui si verifica ogni errore. Questi numeri di riga iniziano da 1 per la prima riga in un file. Tuttavia, se si genera codice sorgente F# da un altro strumento, i numeri di riga nel codice generato non sono generalmente di interesse, perché nel codice F# generato probabilmente gli errori sono causati da un'altra origine. La direttiva #line consente agli autori di strumenti che generano codice sorgente F# di passare le informazioni relative ai numeri di riga e ai file di origine originali al codice F# generato.

Quando si usa la direttiva #line, i nomi di file devono essere racchiusi tra virgolette. A meno che il token verbatim (@) venga visualizzato all'inizio della stringa, è necessario eseguire l'escape dei caratteri barra rovesciata usando due barre rovesciate anziché una per poterli usare nel percorso. Di seguito sono riportati dei token di riga validi. In questi esempi si presuppone che il file originale Script1 risulti in un file di codice F# generato automaticamente quando viene eseguito tramite uno strumento e che il codice nella posizione di tali direttive venga generato dagli stessi token alla riga 25 nel file Script1.

# 25
#line 25
#line 25 "C:\\Projects\\MyProject\\MyProject\\Script1"
#line 25 @"C:\Projects\MyProject\MyProject\Script1"
# 25 @"C:\Projects\MyProject\MyProject\Script1"

Questi token indicano che il codice F# generato in questa posizione è derivato da alcuni costrutti alla riga o vicino alla riga 25 in Script1.

Vedi anche