Чтение онлайн

ЖАНРЫ

UNIX: разработка сетевых приложений
Шрифт:

63 #define t_uscalar_t uint32_t /* <xti.h> */

64 /* Определены, если система поддерживает указанное свойство */

65 #define IPV4 1 /* IPv4, V в верхнем регистре */

66 #define IPv4 1 /* IPv4, v в нижнем регистре, на всякий случай */

67 /* #undef IPV6 */ /* IPv6, V в верхнем регистре */

68 /* #undef IPv6 */ /* IPv6, v в нижнем регистре, на всякий случай */

69 #define UNIXDOMAIN 1 /* доменные сокеты Unix */

70 #define UNIXdomain 1 /*
доменные сокеты Unix */

71 #define MCAST 1 /* поддержка многоадресной передачи */

Г.3. Стандартные функции обработки ошибок

В этой книге мы определяем набор своих собственных функций для обработки ошибок. Причина, по который мы создаем эти функции, заключается в том, что они позволяют нам обрабатывать ошибки с помощью одной строки кода, как, например, показано ниже:

if ( условие ошибки)

err_sys( формат printf с любым количеством аргументов);

вместо

if ( условие ошибки) {

char buff[200];

snprintf(buff, sizeof(buff), формат printf с любым количеством аргументов);

perror(buff);

exit(1);

}

Наши функции обработки ошибок используют следующую возможность ANSI С: список аргументов может иметь переменную длину. Более подробную информацию об этом вы найдете в разделе 7.3 книги [68].

В табл. Г.1 показано, в чем заключаются различия между функциями обработки ошибок. Если глобальная целочисленная переменная

daemon_proc
отлична от нуля, то сообщение об ошибке передается функции
syslog
с указанным уровнем, в противном случае оно отправляется в стандартный поток вывода сообщений об ошибках.

Таблица Г.1. Стандартные функции обработки ошибок

Функция strerror (errno ?) Завершение ? Уровень syslog
err_dump Да abort; LOG_ERR
err_msg Нет return; LOG_INFO
err_quit Нет exit(1); LOG_ERR
err_ret Да return; LOG_INFO
err_sys Да exit(1); LOG_ERR

В листинге Г.3 показаны первые пять функций из табл. Г.1.

Листинг Г.3. Стандартные функции обработки ошибок

//lib/error.c

1 #include "unp.h"

2 #include <stdarg.h> /* заголовочный файл ANSI С */

3 #include <syslog.h> /* для syslog */

4 int daemon_proc; /*
устанавливается в ненулевое значение с

помощью daemon_init */

5 static void err_doit(int, int, const char*, va_list);

6 /* Нефатальная ошибка, связанная с системным вызовом.

7 Выводим сообщение и возвращаем управление */

8 void

9 err_ret(const char *fmt , ...)

10 {

11 va_list ap;

12 va_start(ap, fmt);

13 err_doit(1, LOG_INFO, fmt, ap);

14 va_end(ap);

15 return;

16 }

17 /* Фатальная ошибка, связанная с системным вызовом.

18 Выводим сообщение и завершаем работу */

19 void

20 err_sys(const char *fmt)

21 {

22 va_list ap;

23 va_start(ap, fmt);

24 err_doit(1, LOG_ERR, fmt, ap);

25 va_end(ap);

26 exit(1);

27 }

28 /* Фатальная ошибка, связанная с системным вызовом.

29 Выводим сообщение, сохраняем дамп памяти процесса и заканчиваем работу */

30 void

31 err_dump(const char *fmt, ... )

32 {

33 va_list ар;

34 va_start(ap, fmt);

35 err_doit(1, LOG_ERR, fmt, ap);

36 va_end(ap);

37 abort; /* сохраняем дамп памяти и заканчиваем работу */

38 exit(1);

39 }

40 /* Нефатальная ошибка, не относящаяся к системному вызову.

41 Выводим сообщение и возвращаем управление */

42 void

43 err_msg(const char *fmt , ...)

44 {

45 va_list ap;

46 va_start(ap, fmt);

47 err_doit(0, LOG_INFO, fmt, ap);

48 va_end(ap);

49 return;

50 }

51 /* Фатальная ошибка, не относящаяся к системному вызову.

Поделиться с друзьями: