#pragma once
#include <stdio.h>
#include <iostream>
#define RESET "\033[0m"
#define BLACK "\033[30m" /* Black */
#define RED "\033[31m" /* Red */
#define GREEN "\033[32m" /* Green */
#define YELLOW "\033[33m" /* Yellow */
#define BLUE "\033[34m" /* Blue */
#define MAGENTA "\033[35m" /* Magenta */
#define CYAN "\033[36m" /* Cyan */
#define WHITE "\033[37m" /* White */
#define BOLDBLACK "\033[1m\033[30m" /* Bold Black */
#define BOLDRED "\033[1m\033[31m" /* Bold Red */
#define BOLDGREEN "\033[1m\033[32m" /* Bold Green */
#define BOLDYELLOW "\033[1m\033[33m" /* Bold Yellow */
#define BOLDBLUE "\033[1m\033[34m" /* Bold Blue */
#define BOLDMAGENTA "\033[1m\033[35m" /* Bold Magenta */
#define BOLDCYAN "\033[1m\033[36m" /* Bold Cyan */
#define BOLDWHITE "\033[1m\033[37m" /* Bold White */
#define DEBUG_ON
#ifdef DEBUG_ON
#define DEBUG(format, ...) do{\
const char *str = strrchr(__FILE__, '\\');\
str++;\
std::cout << YELLOW << "Fun:" << __FUNCTION__ << " " << RESET ; \
printf("Line:%d, "format", File:%s \n" , __LINE__, ##__VA_ARGS__, str); \
\
} while(0)
#else
#define DEBUG(format, ...)
#endif
#define INFO_ON
#ifdef INFO_ON
#define INFO(format, ...) do{\
std::cout << BLUE << "[INFO] " << RESET ; \
printf("Line:%d, "format"\n" , __LINE__, ##__VA_ARGS__); \
\
} while(0)
#define ERROR(format, ...) do{\
std::cout << BLUE << "[ERROR] " << RESET ; \
printf("Line:%d, "format"\n" , __LINE__, ##__VA_ARGS__); \
\
} while(0)
#else
#define INFO(format, ...)
#define ERROR(format, ...)
#endif
使用方法:
DEBUG("This debug info.");
DEBUG("This debug data %d %d", 1, 2);
?
|