-debug_t debug_level = DEBUG_NOTHING;
-static logmode_t logmode = LOGMODE_STDERR;
-static pid_t logpid;
-#ifdef HAVE_MINGW
-static HANDLE loghandle = NULL;
-#endif
-static const char *logident = NULL;
-
-static void real_logger(int level, int priority, const char *message) {
- char timestr[32] = "";
- static bool suppress = false;
-
- // Bail out early if there is nothing to do.
- if(suppress)
- return;
-
- if(level > debug_level || logmode == LOGMODE_NULL)
- return;
-
- if(level <= debug_level) {
- switch(logmode) {
- case LOGMODE_STDERR:
- fprintf(stderr, "%s\n", message);
- fflush(stderr);
- break;
- case LOGMODE_SYSLOG:
-#ifdef HAVE_MINGW
- {
- const char *messages[] = {message};
- ReportEvent(loghandle, priority, 0, 0, NULL, 1, 0, messages, NULL);
- }
-#else
-#ifdef HAVE_SYSLOG_H
- syslog(priority, "%s", message);
-#endif
-#endif
- break;
- case LOGMODE_NULL:
- break;
+// TODO: refactor logging code to use a meshlink_handle_t *.
+void logger(meshlink_handle_t *mesh, meshlink_log_level_t level, const char *format, ...) {
+ if(mesh) {
+ if(level < mesh->log_level || !mesh->log_cb) {
+ return;
+ }
+ } else {
+ if(level < global_log_level || !global_log_cb) {
+ return;