echoping/SRC/error.c
Stephane Bortzmeyer 38b624167d INSTALL
2001-01-24 14:03:42 +00:00

134 lines
2.6 KiB
C

#include "echoping.h"
/* $Id$ */
/* Most of error-handling routines stolen from Stevens' books */
void
my_perror ()
{
fprintf (stderr, " %s\n", sys_err_str ());
}
/*
* Recoverable error. Print a message, and return to caller.
*
* err_ret(str, arg1, arg2, ...)
*
* The string "str" must specify the conversion specification for any args.
*/
/* VARARGS1 */
void
err_ret (va_alist)
va_dcl
{
va_list args;
char *fmt;
va_start (args); /* TODO: use stdarg, otherwise, on *some*
platforms: "macro `va_start' used with just one arg" because OpenSSL
includes stdarg. */
fmt = va_arg (args, char *);
vfprintf (stderr, fmt, args);
va_end (args);
my_perror ();
fflush (stdout);
fflush (stderr);
return;
}
/*
* Fatal error. Print a message and terminate. Don't dump core and don't
* print the system's errno value.
*
* err_quit(str, arg1, arg2, ...)
*
* The string "str" must specify the conversion specification for any args.
*/
/* VARARGS1 */
void
err_quit (va_alist)
va_dcl
{
va_list args;
char *fmt;
va_start (args);
fmt = va_arg (args, char *);
vfprintf (stderr, fmt, args);
fputc ('\n', stderr);
va_end (args);
exit (1);
}
/*
* Fatal error related to a system call. Print a message and terminate.
* Don't dump core, but do print the system's errno value and its associated
* message.
*
* err_sys(str, arg1, arg2, ...)
*
* The string "str" must specify the conversion specification for any args.
*/
/* VARARGS1 */
void
err_sys (va_alist)
va_dcl
{
va_list args;
char *fmt;
va_start (args);
fmt = va_arg (args, char *);
vfprintf (stderr, fmt, args);
va_end (args);
my_perror ();
exit (1);
}
void
usage ()
{
fprintf (stderr, "Usage: %s [-v] [-t timeout] [-c] [-d] [-u] [-s size] [-n number] [-w delay] [-h url] [-S] server-name[:port]\n", progname);
exit (1);
}
/*
* Return a string containing some additional operating-system dependent
* information. Note that different versions of UNIX assign different
* meanings to the same value of "errno" (compare errno's starting with 35
* between System V and BSD, for example). This means that if an error
* condition is being sent to another UNIX system, we must interpret the
* errno value on the system that generated the error, and not just send the
* decimal value of errno to the other system.
*/
char *
sys_err_str ()
{
static char msgstr[200];
if (errno != 0)
{
if (errno > 0 && errno < sys_nerr)
sprintf (msgstr, "(%s)", sys_errlist[errno]);
else
sprintf (msgstr, "(errno = %d)", errno);
}
else
{
msgstr[0] = '\0';
}
return (msgstr);
}