C语言 log等级_实现

#include <stdarg.h>
#include "main.h"
typedef enum
{
	LogLevel_begin = -1,
     
	LogLevel_Trace,
	LogLevel_Debug,
	LogLevel_Info,
	LogLevel_Error,
	LogLevel_Fatal,

      LogLevel_end

} LogLevel_em;

#define PER_LOG_LINE_SIZE 512

static LogLevel_em	  w_emCurLogLevel = LogLevel_Debug ;       //log level switch

static void Send_logMsg(char* w_Msg, uint32_t u32MsgLen);
static void Logger_putMsg(LogLevel_em emLvl, const char*  pcszBodyFmt, va_list vaBodyArgs);

void Logger_trace( const char * w_Fmt, ...)
{
	va_list vaList;

	va_start(vaList, w_Fmt);
	Logger_putMsg(LogLevel_Trace, w_Fmt, vaList);
	va_end(vaList);
}

void Logger_debug(const char * w_Fmt, ...)
{
	va_list vaList;
    
	va_start(vaList, w_Fmt);
	Logger_putMsg(LogLevel_Debug, w_Fmt, vaList);
	va_end(vaList);
}

void Logger_info( const char * w_Fmt, ...)
{
	va_list vaList;

	va_start(vaList, w_Fmt);
	Logger_putMsg(LogLevel_Info, w_Fmt, vaList);
	va_end(vaList);
}

void Logger_error(  const char * w_Fmt, ...)
{
	va_list vaList;

	va_start(vaList, w_Fmt);
	Logger_putMsg(LogLevel_Error, w_Fmt, vaList);
	va_end(vaList);
}

void Logger_fatal( const char * w_Fmt, ...)
{
	va_list vaList;

	va_start(vaList, w_Fmt);
	Logger_putMsg(LogLevel_Fatal, w_Fmt, vaList);
	va_end(vaList);
}

static void Logger_putMsg(LogLevel_em emLvl, const char*  pcszBodyFmt, va_list vaBodyArgs){
    if (w_emCurLogLevel <= emLvl)
    {
            static char s_strMsg[PER_LOG_LINE_SIZE];
            uint32_t u32Len;
            u32Len = vsnprintf(s_strMsg, PER_LOG_LINE_SIZE, pcszBodyFmt, vaBodyArgs)-1;
            #if 0
            s_strMsg[u32Len++]='\n';
            s_strMsg[u32Len]='\0';
            #endif
            Send_logMsg(s_strMsg,u32Len);
    }
}

static void Send_logMsg(char* w_Msg, uint32_t u32MsgLen){   
    #if 1
    printf_log(w_Msg,u32MsgLen);   //需要自己现实    
    #endif
}





  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值