diff --git a/src/utils/error.c b/src/utils/error.c
index 5b9b448deefc4737c7e812e828d3a9fdd041f5a2..f40e31ada656f24e4719783bbe279cf49cfb7be2 100644 (file)
--- a/src/utils/error.c
+++ b/src/utils/error.c
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-#include "core/plugin.h"
+#if HAVE_CONFIG_H
+# include "config.h"
+#endif /* HAVE_CONFIG_H */
+
#include "utils/error.h"
#include "utils/strbuf.h"
static pthread_key_t error_ctx_key;
static _Bool error_ctx_key_initialized = 0;
+static int (*logger)(int prio, const char *msg) = NULL;
+
/*
* private helper functions
*/
if (ctx->logged)
return 0;
- ret = sdb_plugin_log(prio, sdb_strbuf_string(ctx->msg));
+ if (logger)
+ ret = logger(prio, sdb_strbuf_string(ctx->msg));
+ else
+ ret = fprintf(stderr, "[%s] %s\n", SDB_LOG_PRIO_TO_STRING(prio),
+ sdb_strbuf_string(ctx->msg));
+
ctx->logged = 1;
return ret;
} /* sdb_do_log */
* public API
*/
+void
+sdb_error_set_logger(int (*f)(int, const char *))
+{
+ logger = f;
+} /* sdb_error_set_logger */
+
int
sdb_log(int prio, const char *fmt, ...)
{