diff options
-rw-r--r-- | e-util/ChangeLog | 4 | ||||
-rw-r--r-- | e-util/e-logger.c | 221 | ||||
-rw-r--r-- | e-util/e-logger.h | 44 |
3 files changed, 192 insertions, 77 deletions
diff --git a/e-util/ChangeLog b/e-util/ChangeLog index c1abed1c56..ce11387828 100644 --- a/e-util/ChangeLog +++ b/e-util/ChangeLog @@ -1,3 +1,7 @@ +2008-06-08 Matthew Barnes <mbarnes@redhat.com> + + * e-logger.[ch]: Code cleanup. + 2008-06-06 Tor Lillqvist <tml@novell.com> * e-plugin.c (epl_loadmodule): Tell which plugin it could not load diff --git a/e-util/e-logger.c b/e-util/e-logger.c index 369f7ea90d..a79793b045 100644 --- a/e-util/e-logger.c +++ b/e-util/e-logger.c @@ -28,6 +28,7 @@ #include <stdlib.h> #include <glib.h> +#include <glib/gi18n.h> #include <glib/gstdio.h> #include "e-logger.h" #include "e-mktemp.h" @@ -35,129 +36,220 @@ /* 5 Minutes */ #define TIMEOUT_INTERVAL 300000 -static GObjectClass *parent; +#define E_LOGGER_GET_PRIVATE(obj) \ + (G_TYPE_INSTANCE_GET_PRIVATE \ + ((obj), E_TYPE_LOGGER, ELoggerPrivate)) struct _ELoggerPrivate { - char *component; - char *logfile; + gchar *component; + gchar *logfile; FILE *fp; guint timer; }; +enum { + PROP_0, + PROP_COMPONENT +}; + +static gpointer parent_class; + static gboolean -flush_logfile (ELogger *el) +flush_logfile (ELogger *logger) { - fflush (el->priv->fp); - el->priv->timer = 0; + fflush (logger->priv->fp); + logger->priv->timer = 0; return FALSE; } static void -el_init(GObject *o) +logger_set_component (ELogger *logger, + const gchar *component) { - ELogger *l = (ELogger *) o; - ELoggerPrivate *priv; - - priv = g_new (ELoggerPrivate, 1); - priv->logfile = NULL; - priv->fp = NULL; - l->priv=priv; + gchar *temp; + + g_return_if_fail (logger->priv->component == NULL); + + temp = g_strdup_printf ("%s.log.XXXXXX", component); + + logger->priv->component = g_strdup (component); + logger->priv->logfile = e_mktemp (temp); + logger->priv->fp = g_fopen (logger->priv->logfile, "w"); + logger->priv->timer = 0; + + g_free (temp); } static void -el_finalise(GObject *o) +logger_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec) { - ELogger *el = (ELogger *) o; - ELoggerPrivate *priv = el->priv; - - if (priv->timer) - g_source_remove (priv->timer); - flush_logfile (el); - fclose (el->priv->fp); - g_free (el->priv); - ((GObjectClass *)parent)->finalize(o); + switch (property_id) { + case PROP_COMPONENT: + logger_set_component ( + E_LOGGER (object), + g_value_get_string (value)); + return; + } + + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); } static void -el_class_init(GObjectClass *klass) +logger_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec) { - klass->finalize = el_finalise; + switch (property_id) { + case PROP_COMPONENT: + g_value_set_string ( + value, e_logger_get_component ( + E_LOGGER (object))); + return; + } + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); +} + +static void +logger_finalize (GObject *object) +{ + ELogger *logger = E_LOGGER (object); + + if (logger->priv->timer) + g_source_remove (logger->priv->timer); + flush_logfile (logger); + fclose (logger->priv->fp); + + g_free (logger->priv->component); + g_free (logger->priv->logfile); + + /* Chain up to parent's finalize() method. */ + G_OBJECT_CLASS (parent_class)->finalize (object); +} + +static void +logger_class_init (ELoggerClass *class) +{ + GObjectClass *object_class; + + parent_class = g_type_class_peek_parent (class); + g_type_class_add_private (class, sizeof (ELoggerPrivate)); + + object_class = G_OBJECT_CLASS (class); + object_class->set_property = logger_set_property; + object_class->get_property = logger_get_property; + object_class->finalize = logger_finalize; + + g_object_class_install_property ( + object_class, + PROP_COMPONENT, + g_param_spec_string ( + "component", + _("Component"), + _("Name of the component being logged"), + "anonymous", + G_PARAM_READWRITE | + G_PARAM_CONSTRUCT_ONLY)); +} + +static void +logger_init (ELogger *logger) +{ + logger->priv = E_LOGGER_GET_PRIVATE (logger); } GType -e_logger_get_type(void) +e_logger_get_type (void) { static GType type = 0; - if (type == 0) { - static const GTypeInfo info = { - sizeof(ELoggerClass), - NULL, NULL, - (GClassInitFunc)el_class_init, - NULL, NULL, - sizeof(ELogger), 0, - (GInstanceInitFunc)el_init + if (G_UNLIKELY (type == 0)) { + static const GTypeInfo type_info = { + sizeof (ELoggerClass), + (GBaseInitFunc) NULL, + (GBaseFinalizeFunc) NULL, + (GClassInitFunc) logger_class_init, + (GClassFinalizeFunc) NULL, + NULL, /* class_data */ + sizeof (ELogger), + 0, /* n_preallocs */ + (GInstanceInitFunc) logger_init, + NULL /* value_table */ }; - parent = g_type_class_ref(G_TYPE_OBJECT); - type = g_type_register_static(G_TYPE_OBJECT, "ELogger", &info, 0); + + type = g_type_register_static ( + G_TYPE_OBJECT, "ELogger", &type_info, 0); } return type; } - -ELogger *e_logger_create(char *component) +ELogger * +e_logger_create (gchar *component) { - ELogger *el = g_object_new(e_logger_get_type(), 0); - ELoggerPrivate *priv; - char *tmp; - - tmp = g_strdup_printf("%s.log.XXXXXX", component); - priv = el->priv; - priv->component = g_strdup (component); - priv->logfile = e_mktemp (tmp); - g_free (tmp); - priv->fp = g_fopen (priv->logfile, "w"); - - priv->timer = 0; - return el; + g_return_val_if_fail (component != NULL, NULL); + + return g_object_new (E_TYPE_LOGGER, "component", component, NULL); } +const gchar * +e_logger_get_component (ELogger *logger) +{ + g_return_val_if_fail (E_IS_LOGGER (logger), NULL); + return logger->priv->component; +} -static void set_dirty (ELogger *el) +static void +set_dirty (ELogger *logger) { - if (el->priv->timer) + if (logger->priv->timer) return; - el->priv->timer = g_timeout_add (TIMEOUT_INTERVAL, (GSourceFunc) flush_logfile, el); + logger->priv->timer = g_timeout_add ( + TIMEOUT_INTERVAL, (GSourceFunc) flush_logfile, logger); } void -e_logger_log (ELogger *el, int level, char *primary, char *secondary) +e_logger_log (ELogger *logger, + gint level, + gchar *primary, + gchar *secondary) { time_t t = time (NULL); - fprintf(el->priv->fp, "%d:%ld:%s\n", level, t, primary); - fprintf(el->priv->fp, "%d:%ld:%s\n", level, t, secondary); - set_dirty (el); + g_return_if_fail (E_LOGGER (logger)); + g_return_if_fail (primary != NULL); + g_return_if_fail (secondary != NULL); + + fprintf (logger->priv->fp, "%d:%ld:%s\n", level, t, primary); + fprintf (logger->priv->fp, "%d:%ld:%s\n", level, t, secondary); + set_dirty (logger); } void -e_logger_get_logs (ELogger *el, ELogFunction func, gpointer data) +e_logger_get_logs (ELogger *logger, + ELogFunction func, + gpointer data) { FILE *fp; - char buf[250]; + gchar buf[250]; gboolean error = FALSE; + g_return_if_fail (E_LOGGER (logger)); + g_return_if_fail (func != NULL); + /* Flush everything before we get the logs */ - fflush (el->priv->fp); - fp = g_fopen (el->priv->logfile, "r"); + fflush (logger->priv->fp); + fp = g_fopen (logger->priv->logfile, "r"); while (!error || feof(fp)) { - char *tmp; + gchar *tmp; tmp = fgets (buf, 250, fp); if (!tmp) break; @@ -170,4 +262,3 @@ e_logger_get_logs (ELogger *el, ELogFunction func, gpointer data) } fclose(fp); } - diff --git a/e-util/e-logger.h b/e-util/e-logger.h index 0dc8b53921..1b2b0ba8da 100644 --- a/e-util/e-logger.h +++ b/e-util/e-logger.h @@ -24,16 +24,32 @@ #include <glib-object.h> -#ifdef __cplusplus -extern "C" { -#pragma } -#endif /* __cplusplus */ +/* Standard GObject macros */ +#define E_TYPE_LOGGER \ + (e_logger_get_type ()) +#define E_LOGGER(obj) \ + (G_TYPE_CHECK_INSTANCE_CAST \ + ((obj), E_TYPE_LOGGER, ELogger)) +#define E_LOGGER_CLASS(cls) \ + (G_TYPE_CHECK_CLASS_CAST \ + ((cls), E_TYPE_LOGGER, ELoggerClass)) +#define E_IS_LOGGER(obj) \ + (G_TYPE_CHECK_INSTANCE_TYPE \ + ((obj), E_TYPE_LOGGER)) +#define E_IS_LOGGER_CLASS(cls) \ + (G_TYPE_CHECK_CLASS_TYPE \ + ((cls), E_TYPE_LOGGER)) +#define E_LOGGER_GET_CLASS(obj) \ + (G_TYPE_INSTANCE_GET_CLASS \ + ((obj), E_TYPE_LOGGER, ELoggerClass)) + +G_BEGIN_DECLS typedef struct _ELogger ELogger; typedef struct _ELoggerClass ELoggerClass; typedef struct _ELoggerPrivate ELoggerPrivate; -typedef void (* ELogFunction) (char *line, gpointer data); +typedef void (*ELogFunction) (gchar *line, gpointer data); enum e_log_level_t { E_LOG_ERROR, @@ -52,13 +68,17 @@ struct _ELoggerClass { GObjectClass popup_class; }; -GType e_logger_get_type(void); -ELogger *e_logger_create(char *component); -void e_logger_log (ELogger *el, int level, char *primary, char *secondary); -void e_logger_get_logs (ELogger *el, ELogFunction func, gpointer data); +GType e_logger_get_type (void); +ELogger * e_logger_create (gchar *component); +const gchar * e_logger_get_component (ELogger *logger); +void e_logger_log (ELogger *logger, + gint level, + gchar *primary, + gchar *secondary); +void e_logger_get_logs (ELogger *logger, + ELogFunction func, + gpointer data); -#ifdef __cplusplus -} -#endif /* __cplusplus */ +G_END_DECLS #endif /* __E_LOGGER_H__ */ |