X-Git-Url: http://git.draconx.ca/gitweb/upkg.git/blobdiff_plain/a0efa108741b6cb53ddc3b1228a91b2e0c75a56a..e3726c0480d74840dd9104850cba0f3e5f93beed:/src/uobject/uobject.h diff --git a/src/uobject/uobject.h b/src/uobject/uobject.h index 2f70940..e91bf5b 100644 --- a/src/uobject/uobject.h +++ b/src/uobject/uobject.h @@ -20,6 +20,7 @@ #define U_OBJECT_H_ #include +#include #include "upkg.h" #define U_TYPE_OBJECT u_object_get_type() @@ -56,4 +57,12 @@ int u_object_deserialize(GObject *obj, struct upkg *pkg, unsigned long idx); GObject *u_object_new_from_package(struct upkg *pkg, unsigned long idx); +/* Logging helpers for UObject class implementations. */ +void u_vlog_full(GObject *o, GLogLevelFlags level, const char *fmt, va_list ap); +void u_log_full(GObject *o, GLogLevelFlags level, const char *fmt, ...); + +#define u_log(uo, ...) u_log_full(G_OBJECT(uo), G_LOG_LEVEL_MESSAGE, __VA_ARGS__) +#define u_warn(uo, ...) u_log_full(G_OBJECT(uo), G_LOG_LEVEL_WARNING, __VA_ARGS__) +#define u_err(uo, ...) u_log_full(G_OBJECT(uo), G_LOG_LEVEL_CRITICAL, __VA_ARGS__) + #endif