log.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. /**
  2. * Copyright (c) 2020 rxi
  3. *
  4. * This library is free software; you can redistribute it and/or modify it
  5. * under the terms of the MIT license. See `log.c` for details.
  6. */
  7. #ifndef LOG_H
  8. #define LOG_H
  9. #include <stdio.h>
  10. #include <stdarg.h>
  11. #include <stdbool.h>
  12. #include <time.h>
  13. #include <unistd.h>
  14. #define LOG_VERSION "0.1.0"
  15. typedef struct {
  16. va_list ap;
  17. const char *fmt;
  18. const char *file;
  19. struct tm *time;
  20. void *udata;
  21. int line;
  22. int level;
  23. } log_Event;
  24. typedef void (*log_LogFn)(log_Event *ev);
  25. typedef void (*log_LockFn)(bool lock, void *udata);
  26. enum { LOG_TRACE, LOG_DEBUG, LOG_INFO, LOG_WARN, LOG_ERROR, LOG_FATAL };
  27. #define log_trace(...) log_log(LOG_TRACE, __FILE__, __LINE__, __VA_ARGS__)
  28. #define log_debug(...) log_log(LOG_DEBUG, __FILE__, __LINE__, __VA_ARGS__)
  29. #define log_info(...) log_log(LOG_INFO, __FILE__, __LINE__, __VA_ARGS__)
  30. #define log_warn(...) log_log(LOG_WARN, __FILE__, __LINE__, __VA_ARGS__)
  31. #define log_error(...) log_log(LOG_ERROR, __FILE__, __LINE__, __VA_ARGS__)
  32. #define log_fatal(...) log_log(LOG_FATAL, __FILE__, __LINE__, __VA_ARGS__)
  33. const char* log_level_string(int level);
  34. void log_set_lock(log_LockFn fn, void *udata);
  35. void log_set_level(int level);
  36. void log_set_quiet(bool enable);
  37. int log_add_callback(log_LogFn fn, void *udata, int level);
  38. int log_add_fp(FILE *fp, int level);
  39. void log_init_callback();
  40. void log_log(int level, const char *file, int line, const char *fmt, ...);
  41. #endif