Rexx - Gestione degli errori

Rexx ha la capacità di lavorare anche sulla gestione degli errori come in altri linguaggi di programmazione.

Le seguenti sono alcune delle varie condizioni di errore che si vedono in Rexx.

  • ERROR - Viene anche sollevato ogni volta che un comando inviato al sistema operativo restituisce un errore.

  • FAILURE - Viene anche sollevato ogni volta che un comando inviato al sistema operativo risulta in un errore.

  • HALT- Viene normalmente generato ogni volta che un'operazione dipende da un'altra operazione. Un esempio è se un'operazione di I / O viene interrotta per qualsiasi motivo.

  • NOVALUE - Questo evento viene generato quando un valore non è stato assegnato a una variabile.

  • NOTREADY - Questo viene generato da qualsiasi dispositivo I / O che non è pronto ad accettare alcuna operazione.

  • SYNTAX - Questo evento viene generato se è presente un errore di sintassi nel codice.

  • LOSTDIGITS - Questo evento viene generato quando un'operazione aritmetica comporta una perdita di cifre durante l'operazione.

Errori di trapping

Gli errori vengono bloccati con l'aiuto del comando signal. Diamo un'occhiata alla sintassi e un esempio di questo.

Sintassi

signal on [Errorcondition]

Dove,

  • Errorcondition - Questa è la condizione di errore riportata sopra.

Esempio

Diamo un'occhiata a un esempio su questo.

/* Main program */ 
signal on error 
signal on failure 
signal on syntax 
signal on novalue beep(1) 
signal off error 
signal off failure
signal off syntax 
signal off novalue 
exit 0 
error: failure: syntax: novalue: 
say 'An error has occured'

Nell'esempio precedente, per prima cosa attiviamo i segnali di errore. Aggiungiamo quindi una dichiarazione che risulterà in un errore. Abbiamo quindi l'etichetta di trap di errore per visualizzare un messaggio di errore personalizzato.

L'output del programma di cui sopra sarà come mostrato di seguito.

An error has occurred.

Un esempio di codici di errore è mostrato nel seguente programma.

/* Main program */ 
signal on error 
signal on failure 
signal on syntax 
signal on novalue beep(1) 
exit 0 
error: failure: syntax: novalue: 

say 'An error has occured' 
say rc 
say signal

L'output del programma di cui sopra sarà come mostrato di seguito.

An error has occured 
40 
6