summaryrefslogtreecommitdiff
path: root/src/stlink-lib/logging.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/stlink-lib/logging.h')
-rw-r--r--src/stlink-lib/logging.h38
1 files changed, 29 insertions, 9 deletions
diff --git a/src/stlink-lib/logging.h b/src/stlink-lib/logging.h
index 7f39944..560e20e 100644
--- a/src/stlink-lib/logging.h
+++ b/src/stlink-lib/logging.h
@@ -1,13 +1,22 @@
/*
+ * File: logging.h
+ *
+ * UglyLogging: Slow, yet another wheel reinvented, but enough to make the rest of our code pretty enough.
* Ugly, low performance, configurable level, logging "framework"
*/
-#ifndef UGLYLOGGING_H
-#define UGLYLOGGING_H
+#ifndef LOGGING_H
+#define LOGGING_H
+
+#include <stdint.h>
+#include "spdlog_wrapper.h"
#ifdef __cplusplus
extern "C" {
-#endif
+#endif // __cplusplus
+
+/* Optional: Enable interface for SPDLOG to replace UglyLogging */
+// #define SPDLOG_LOGGING
enum ugly_loglevel {
UDEBUG = 90,
@@ -20,11 +29,11 @@ enum ugly_loglevel {
#define PRINTF_ARRT __attribute__ ((format (printf, 3, 4)))
#else
#define PRINTF_ARRT
-#endif
+#endif // __GNUC__
-int ugly_init(int maximum_threshold);
-int ugly_log(int level, const char *tag, const char *format, ...) PRINTF_ARRT;
-int ugly_libusb_log_level(enum ugly_loglevel v);
+int32_t ugly_init(int32_t maximum_threshold);
+int32_t ugly_log(int32_t level, const char *tag, const char *format, ...) PRINTF_ARRT;
+int32_t ugly_libusb_log_level(enum ugly_loglevel v);
#define UGLY_LOG_FILE (strstr(__FILE__, "/") != NULL ? \
strrchr(__FILE__, '/') + 1 : strstr(__FILE__, "\\") != NULL ? \
@@ -41,8 +50,19 @@ int ugly_libusb_log_level(enum ugly_loglevel v);
#define ELOG_HELPER(format, ...) ugly_log(UERROR, UGLY_LOG_FILE, format, __VA_ARGS__)
#define ELOG(...) ugly_log(UERROR, UGLY_LOG_FILE, __VA_ARGS__)
+#if defined(SPDLOG_LOGGING)
+#undef DLOG_HELPER
+#undef ILOG_HELPER
+#undef WLOG_HELPER
+#undef ELOG_HELPER
+#define DLOG(...) spdlogLog(UDEBUG, __VA_ARGS__)
+#define ILOG(...) spdlogLog(UINFO, __VA_ARGS__)
+#define WLOG(...) spdlogLog(UWARN, __VA_ARGS__)
+#define ELOG(...) spdlogLog(UERROR, __VA_ARGS__)
+#endif // SPDLOG_LOGGING
+
#ifdef __cplusplus
}
-#endif
+#endif // __cplusplus
-#endif // UGLYLOGGING_H
+#endif // LOGGING_H