C/C++ 通用日志打印宏实现。

可被GCC编译器编译支持的打印日志宏函数:

#define LOG_TAG(TAG, FORMAT, ...) ::fprintf(stdout, "[%s][" TAG "](%s:%d): " FORMAT "\r\n", ((char*)::frp::GetCurrentTimeText<std::string>().data()), __FILE__, __LINE__, __VA_ARGS__)

 通用实现日志打印宏函数:

#ifdef ANDROID
#include <android/log.h>

// 定义日志输出函数
#define LOG_TAG ("FRP")
#define LOG_INFO(...)   __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)
#define LOG_ERROR(...)  __android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__)
#define LOG_WARN(...)   __android_log_print(ANDROID_LOG_WARN, LOG_TAG, __VA_ARGS__)
#define LOG_DEBUG(...)  __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
#else
#ifdef _WIN32
#define LOG_TAG(TAG, FORMAT, ...) ::fprintf(stdout, "[%s][" ## TAG ## "](%s:%d): " ## FORMAT ## "\r\n", ((char*)::frp::GetCurrentTimeText<std::string>().data()), __FILE__, __LINE__, __VA_ARGS__)
#else
inline std::string                  __LOG_TAG_FORMAT__(const char* TAG, const char* FORMAT) noexcept {
    std::string result = "[%s][";
    if (TAG) {
        result.append(TAG);
    }
    result.append("](%s:%d): ");
    if (FORMAT) {
        result.append(FORMAT);
    }
    result.append("\r\n");
    return result;
}
#define LOG_TAG(TAG, FORMAT, ...) ::fprintf(stdout, ((char*)::__LOG_TAG_FORMAT__(TAG, FORMAT).data()), ((char*)::frp::GetCurrentTimeText<std::string>().data()), __FILE__, __LINE__, __VA_ARGS__)
#endif
#define LOG_INFO(FORMAT, ...)     LOG_TAG("INFO", FORMAT, __VA_ARGS__)
#define LOG_ERROR(FORMAT, ...)    LOG_TAG("ERROR", FORMAT, __VA_ARGS__)
#define LOG_WARN(FORMAT, ...)     LOG_TAG("WARN", FORMAT, __VA_ARGS__)
#define LOG_DEBUG(FORMAT, ...)    LOG_TAG("DEBUG", FORMAT, __VA_ARGS__)
#endif

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值