-#ifndef __TINC_LOGGER_H__
+/*
+ logger.h -- header file for logger.c
+ Copyright (C) 2014 Guus Sliepen <guus@meshlink.io>
-#include <syslog.h>
-#include <stdarg.h>
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
-enum {
- DEBUG_NOTHING = 0, /* Quiet mode, only show starting/stopping of the daemon */
- DEBUG_ALWAYS = 0,
- DEBUG_CONNECTIONS = 1, /* Show (dis)connects of other tinc daemons via TCP */
- DEBUG_ERROR = 2, /* Show error messages received from other hosts */
- DEBUG_STATUS = 2, /* Show status messages received from other hosts */
- DEBUG_PROTOCOL = 3, /* Show the requests that are sent/received */
- DEBUG_META = 4, /* Show contents of every request that is sent/received */
- DEBUG_TRAFFIC = 5, /* Show network traffic information */
- DEBUG_PACKET = 6, /* Show contents of each packet that is being sent/received */
- DEBUG_SCARY_THINGS = 10 /* You have been warned */
-};
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
-enum {
- LOGMODE_NULL,
- LOGMODE_STDERR,
- LOGMODE_FILE,
- LOGMODE_SYSLOG
-};
+ You should have received a copy of the GNU General Public License along
+ with this program; if not, write to the Free Software Foundation, Inc.,
+ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+*/
-extern volatile int debug_level;
-extern void openlogger(const char *, int);
-extern void vlogger(int, const char *, va_list ap);
-extern void closelogger(void);
+#ifndef __MESHLINK_LOGGER_H__
+#define __MESHLINK_LOGGER_H__
-/* Inline logger function because it's used quite often */
+#include "meshlink_internal.h"
-static inline void logger(int level, int priority, const char *format, ...) {
- va_list ap;
+extern void logger(meshlink_handle_t *mesh, meshlink_log_level_t level, const char *format, ...) __attribute__ ((__format__(printf, 3, 4)));
- if(level == DEBUG_ALWAYS || debug_level >= level) {
- va_start(ap, format);
- vlogger(priority, format, ap);
- va_end(ap);
- }
-}
-
-#endif /* __TINC_LOGGER_H__ */
+#endif /* __MESHLINK_LOGGER_H__ */