Blame sysdeps/common/error.c

Packit Service 407539
/* Copyright (C) 1998-99 Martin Baulig
Packit Service 407539
   This file is part of LibGTop 1.0.
Packit Service 407539
Packit Service 407539
   Contributed by Martin Baulig <martin@home-of-linux.org>, April 1998.
Packit Service 407539
Packit Service 407539
   LibGTop is free software; you can redistribute it and/or modify it
Packit Service 407539
   under the terms of the GNU General Public License as published by
Packit Service 407539
   the Free Software Foundation; either version 2 of the License,
Packit Service 407539
   or (at your option) any later version.
Packit Service 407539
Packit Service 407539
   LibGTop is distributed in the hope that it will be useful, but WITHOUT
Packit Service 407539
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
Packit Service 407539
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit Service 407539
   for more details.
Packit Service 407539
Packit Service 407539
   You should have received a copy of the GNU General Public License
Packit Service 407539
   along with LibGTop; see the file COPYING. If not, write to the
Packit Service 407539
   Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Packit Service 407539
   Boston, MA 02110-1301, USA.
Packit Service 407539
*/
Packit Service 407539
Packit Service 407539
#include <config.h>
Packit Service 407539
Packit Service 407539
#include <glib.h>
Packit Service 407539
#include <errno.h>
Packit Service 407539
Packit Service 407539
#include <glibtop/error.h>
Packit Service 407539
Packit Service 407539
enum MESSAGE_LEVEL {
Packit Service 407539
	MESSAGE_DEBUG,
Packit Service 407539
	MESSAGE_WARNING,
Packit Service 407539
	MESSAGE_ERROR
Packit Service 407539
};
Packit Service 407539
Packit Service 407539
#define DEFAULT_NAME	"LibGTop-Server"
Packit Service 407539
Packit Service 407539
/* Prints error message and exits. */
Packit Service 407539
Packit Service 407539
static void
Packit Service 407539
print_message (const glibtop *server, int message_level, const char *format, int error, va_list args)
Packit Service 407539
{
Packit Service 407539
	const char *level;
Packit Service 407539
	GString* message;
Packit Service 407539
Packit Service 407539
	message = g_string_new(NULL);
Packit Service 407539
Packit Service 407539
	g_string_printf(message, "%s", (server && server->name ? server->name : DEFAULT_NAME));
Packit Service 407539
Packit Service 407539
	if (server && server->pid) {
Packit Service 407539
		g_string_append_printf(message, "(c=%u/s=%u)", getpid(), server->pid);
Packit Service 407539
	}
Packit Service 407539
	else {
Packit Service 407539
		g_string_append_printf(message, "(c=%u)", getpid());
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	switch (message_level) {
Packit Service 407539
	case MESSAGE_DEBUG:
Packit Service 407539
		level = "DEBUG";
Packit Service 407539
		break;
Packit Service 407539
	case MESSAGE_WARNING:
Packit Service 407539
		level = "WARNING";
Packit Service 407539
		break;
Packit Service 407539
	case MESSAGE_ERROR:
Packit Service 407539
		level = "ERROR";
Packit Service 407539
		break;
Packit Service 407539
	default:
Packit Service 407539
		level = "UNKNOWN";
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	g_string_append_printf(message, ": [%s] ", level);
Packit Service 407539
Packit Service 407539
	g_string_append_vprintf(message, format, args);
Packit Service 407539
Packit Service 407539
	if (error) {
Packit Service 407539
		g_string_append_printf(message, ": %s", g_strerror(error));
Packit Service 407539
	}
Packit Service 407539
Packit Service 407539
	g_string_append_c(message, '\n');
Packit Service 407539
Packit Service 407539
	fputs(message->str, stderr);
Packit Service 407539
Packit Service 407539
	g_string_free(message, TRUE);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_error_vr (glibtop *server, const char *format, va_list args)
Packit Service 407539
{
Packit Service 407539
	print_message (server, MESSAGE_ERROR, format, 0, args);
Packit Service 407539
Packit Service 407539
#ifdef LIBGTOP_ENABLE_DEBUG
Packit Service 407539
	abort ();
Packit Service 407539
#else
Packit Service 407539
	exit (1);
Packit Service 407539
#endif
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_error_io_vr (glibtop *server, const char *format, int error, va_list args)
Packit Service 407539
{
Packit Service 407539
	print_message (server, MESSAGE_ERROR, format, error, args);
Packit Service 407539
Packit Service 407539
#ifdef LIBGTOP_ENABLE_DEBUG
Packit Service 407539
	abort ();
Packit Service 407539
#else
Packit Service 407539
	exit (1);
Packit Service 407539
#endif
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_warn_vr (glibtop *server, const char *format, va_list args)
Packit Service 407539
{
Packit Service 407539
	print_message (server, MESSAGE_WARNING, format, 0, args);
Packit Service 407539
Packit Service 407539
#ifdef LIBGTOP_FATAL_WARNINGS
Packit Service 407539
	abort ();
Packit Service 407539
#endif
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_warn_io_vr (glibtop *server, const char *format, int error, va_list args)
Packit Service 407539
{
Packit Service 407539
	print_message (server, MESSAGE_WARNING, format, error, args);
Packit Service 407539
Packit Service 407539
#ifdef LIBGTOP_FATAL_WARNINGS
Packit Service 407539
	abort ();
Packit Service 407539
#endif
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_error_r (glibtop *server, const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_error_vr (server, format, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_warn_r (glibtop *server, const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_warn_vr (server, format, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_error_io_r (glibtop *server, const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_error_io_vr (server, format, errno, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_warn_io_r (glibtop *server, const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_warn_io_vr (server, format, errno, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_debug_vr (glibtop *server, const char *format, va_list args)
Packit Service 407539
{
Packit Service 407539
	print_message (server, MESSAGE_DEBUG, format, 0, args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_debug_r_real (glibtop *server, const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_debug_vr (server, format, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_error (const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_error_vr (glibtop_global_server, format, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_warn (const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_warn_vr (glibtop_global_server, format, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_error_io (const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_error_io_vr (glibtop_global_server, format, errno, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}
Packit Service 407539
Packit Service 407539
void
Packit Service 407539
glibtop_warn_io (const char *format, ...)
Packit Service 407539
{
Packit Service 407539
	va_list args;
Packit Service 407539
	va_start (args, format);
Packit Service 407539
	glibtop_warn_io_vr (glibtop_global_server, format, errno, args);
Packit Service 407539
	va_end (args);
Packit Service 407539
}