aboutsummaryrefslogtreecommitdiff
path: root/src/debug.h
blob: fd2ef62d76159dca08d46647a55c2ea30e716c13 (plain)
  1. #ifndef CMARK_DEBUG_H
  2. #define CMARK_DEBUG_H
  3. #include <stdio.h>
  4. #include <errno.h>
  5. #include <string.h>
  6. #ifdef NDEBUG
  7. #define debug(M, ...)
  8. #else
  9. #define debug(M, ...) \
  10. fprintf(stderr, "DEBUG %s:%d: " M "\n", __FILE__, __LINE__, ##__VA_ARGS__)
  11. #endif
  12. #define clean_errno() (errno == 0 ? "None" : strerror(errno))
  13. #define log_err(M, ...) \
  14. fprintf(stderr, "[ERROR] (%s:%d: errno: %s) " M "\n", __FILE__, __LINE__, \
  15. clean_errno(), ##__VA_ARGS__)
  16. #define log_warn(M, ...) \
  17. fprintf(stderr, "[WARN] (%s:%d: errno: %s) " M "\n", __FILE__, __LINE__, \
  18. clean_errno(), ##__VA_ARGS__)
  19. #define log_info(M, ...) fprintf(stderr, "[INFO] (%s:%d) " M "\n", __FILE__, \
  20. __LINE__, ##__VA_ARGS__)
  21. #define check(A, M, ...) \
  22. if(!(A)) { log_err(M, ##__VA_ARGS__); errno=0; goto error; }
  23. #define sentinel(M, ...) \
  24. { log_err(M, ##__VA_ARGS__); errno=0; goto error; }
  25. #define check_debug(A, M, ...) \
  26. if(!(A)) { debug(M, ##__VA_ARGS__); errno=0; goto error; }
  27. #endif