mirror of
https://framagit.org/bortzmeyer/echoping
synced 2024-11-05 06:00:37 +00:00
131 lines
2.5 KiB
C
131 lines
2.5 KiB
C
#include "echoping.h"
|
|
|
|
|
|
/* 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);
|
|
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] 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);
|
|
}
|