阅读Sofia-SIP源码 - su模块 - su_log.c/su_log.h

本文聚焦于Sofia-SIP的su_log模块,详细解读su_log_t结构体和su_log_init函数。su_log_t包含日志相关属性,如名称、环境变量、等级和初始化标志等。su_log_init的实现中,全局变量的赋值和SU_LOG_INIT宏的使用留待进一步探索,暗示其在客户代码中承担设置日志输出的角色。
摘要由CSDN通过智能技术生成


su.log.h

首先看头文件。最重要的莫过于su_log_t结构体了:

/** Type of log structure. */
typedef struct su_log_s su_log_t;

/** Prototype for logging function */
typedef void (su_logger_f)(void *stream, char const *fmt, va_list ap);

/** Log object. */
struct su_log_s {
  int          log_size;
  char const  *log_name;
  char const  *log_env;
  unsigned     log_default;
  unsigned     log_level;
  int          log_init;

  su_logger_f *log_logger;
  void        *log_stream;
};

结构体本身并不复杂。包括结构体对象空间大小、日志名称、日志的环境变量名、日志等级(包括缺省)、日志是否初始化标志、日志输出函数和日志流对象指针。

然后定义了一个初始化结构体变量的宏,可以用做右值。

/** Initialize a su_log_t structure */
#define SU_LOG_INIT(name, env, level) \
  { sizeof(su_log_t), name, env, level, SU_LOG_MAX, 0, NULL, NULL, }


接着看到了一个之前未见过的用法:

SOFIAPUBFUN void su_log(c
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值