Scroll to navigation

ERR(3) Linux Programmer's Manual ERR(3)

NOME

err, verr, errx, verrx, warn, vwarn, warnx, vwarnx - messaggi di errore formattati

SINTASSI

#include <err.h>
 
void err(int eval, const char *fmt, ...);
 
void errx(int eval, const char *fmt, ...);
 
void warn(const char *fmt, ...);
 
void warnx(const char *fmt, ...);
 
#include <stdarg.h>
 
void verr(int eval, const char *fmt, va_list args);
 
void verrx(int eval, const char *fmt, va_list args);
 
void vwarn(const char *fmt, va_list args);
 
void vwarnx(const char *fmt, va_list args);

DESCRIZIONE

Le famiglie di funzioni err e warn visualizzano un messaggio di errore formattato sull'uscita dello standard error. In ogni caso vengono stampati l'ultimo componente del nome del programma, un carattere di due punti, e uno spazio. Se l'argomento fmt non è NULL viene emesso un messaggio di errore formattato in stile printf(3)-like. L'output è concluso da un carattere newline.
Le funzioni err(), verr(), warn(), e vwarn() aggiungono un messaggio di errore ottenuto da strerror(3) basato su un codice o sulla variabile globale R errno , preceduto da un altro ":" e uno spazio a meno che l'argomento fmt sia NULL.
Le funzioni err(), verr(), warn(), e vwarn() usano la variabile globale errno per trovare il messaggio di errore.
Le funzioni errx() e warnx() non aggiungono un messaggio di errore.
Le funzioni err(), verr(), errx(), e verrx() non ritornano, ma escono con il valore dell'argomento R eval .

ESEMPI

Mostra la stringa di informazione attuale errno ed esce:
if ((p = malloc(size)) == NULL) err(1, NULL); if ((fd = open(file_name, O_RDONLY, 0)) == -1) err(1, "%s", file_name);

Visualizza un messaggio di errore ed esce:
if (tm.tm_hour < START_TIME) errx(1, "too early, wait until %s", start_time_string);

Avvisa di un errore:
if ((fd = open(raw_device, O_RDONLY, 0)) == -1) warnx("%s: %s: trying the block device", raw_device, strerror(errno)); if ((fd = open(block_device, O_RDONLY, 0)) == -1) err(1, "%s", block_device);

CONFORME A

Queste funzioni sono estensioni BSD non standard.

STORIA

VEDERE ANCHE

error(3), exit(3), printf(3), perror(3), strerror(3)

COLOPHON

Questa pagina fa parte del rilascio 2.75 del progetto man-pages di Linux. Si può trovare una descrizione del progetto, e informazioni su come riportare bachi, presso http://www.kernel.org/doc/man-pages/. Per la traduzione in italiano si può fare riferimento a http://www.pluto.it/ildp/collaborare/
28 dicembre 2007 Linux