25 #ifndef PIPEWIRE_LOG_H 
   26 #define PIPEWIRE_LOG_H 
   68             int line, 
const char *func,
 
   76              int line, const 
char *func,
 
   85            int line, const 
char *func,
 
   92             int line, const 
char *func,
 
  117 #define PW_LOG_TOPIC_STATIC(var, topic) \ 
  118   static struct spa_log_topic var##__LINE__ = SPA_LOG_TOPIC(0, topic); \ 
  119   static struct spa_log_topic *(var) = &(var##__LINE__) 
  125 #define PW_LOG_TOPIC_EXTERN(var) \ 
  126   extern struct spa_log_topic *var 
  132 #define PW_LOG_TOPIC(var, topic) \ 
  133   struct spa_log_topic var##__LINE__ = SPA_LOG_TOPIC(0, topic); \ 
  134   struct spa_log_topic *(var) = &(var##__LINE__) 
  136 #define PW_LOG_TOPIC_INIT(var) \ 
  137    spa_log_topic_init(pw_log_get(), var); 
  140 #define pw_log_level_enabled(lev) (pw_log_level >= (lev)) 
  141 #define pw_log_topic_enabled(lev,t) ((t) && (t)->has_custom_level ? (t)->level >= (lev) : pw_log_level_enabled((lev))) 
  143 #define pw_logtv(lev,topic,fmt,ap)                                              \ 
  145         if (SPA_UNLIKELY(pw_log_topic_enabled(lev,topic)))                      \ 
  146                 pw_log_logtv(lev,topic,__FILE__,__LINE__,__func__,fmt,ap);      \ 
  149 #define pw_logt(lev,topic,...)                                                  \ 
  151         if (SPA_UNLIKELY(pw_log_topic_enabled(lev,topic)))                      \ 
  152                 pw_log_logt(lev,topic,__FILE__,__LINE__,__func__,__VA_ARGS__);  \ 
  155 #define pw_log(lev,...) pw_logt(lev,PW_LOG_TOPIC_DEFAULT,__VA_ARGS__) 
  157 #define pw_log_error(...)   pw_log(SPA_LOG_LEVEL_ERROR,__VA_ARGS__) 
  158 #define pw_log_warn(...)    pw_log(SPA_LOG_LEVEL_WARN,__VA_ARGS__) 
  159 #define pw_log_info(...)    pw_log(SPA_LOG_LEVEL_INFO,__VA_ARGS__) 
  160 #define pw_log_debug(...)   pw_log(SPA_LOG_LEVEL_DEBUG,__VA_ARGS__) 
  161 #define pw_log_trace(...)   pw_log(SPA_LOG_LEVEL_TRACE,__VA_ARGS__) 
  163 #define pw_logt_error(t,...)   pw_logt(SPA_LOG_LEVEL_ERROR,t,__VA_ARGS__) 
  164 #define pw_logt_warn(t,...)    pw_logt(SPA_LOG_LEVEL_WARN,t,__VA_ARGS__) 
  165 #define pw_logt_info(t,...)    pw_logt(SPA_LOG_LEVEL_INFO,t,__VA_ARGS__) 
  166 #define pw_logt_debug(t,...)   pw_logt(SPA_LOG_LEVEL_DEBUG,t,__VA_ARGS__) 
  167 #define pw_logt_trace(t,...)   pw_logt(SPA_LOG_LEVEL_TRACE,t,__VA_ARGS__) 
  170 #define pw_log_trace_fp(...)   pw_log(SPA_LOG_LEVEL_TRACE,__VA_ARGS__) 
  172 #define pw_log_trace_fp(...) 
void void pw_log_logtv(enum spa_log_level level, const struct spa_log_topic *topic, const char *file, int line, const char *func, const char *fmt, va_list args) 1(6
Log a message for a topic.
 
void pw_log_set(struct spa_log *log)
Configure a logging module.
Definition: log.c:83
 
void void void void pw_log_logv(enum spa_log_level level, const char *file, int line, const char *func, const char *fmt, va_list args) 1(5
Log a message for the default topic.
 
struct spa_log * pw_log_get(void)
Get the log interface.
Definition: log.c:98
 
void pw_log_set_level(enum spa_log_level level)
Configure the logging level.
Definition: log.c:107
 
struct spa_log_topic * PW_LOG_TOPIC_DEFAULT
Definition: log.c:48
 
enum spa_log_level pw_log_level
The global log level.
Definition: log.c:43
 
void pw_log_logt(enum spa_log_level level, const struct spa_log_topic *topic, const char *file, int line, const char *func, const char *fmt,...) 1(6
Log a message for a topic.
 
void void void pw_log_log(enum spa_log_level level, const char *file, int line, const char *func, const char *fmt,...) 1(5
Log a message for the default topic.
 
void void void void void _pw_log_topic_new(struct spa_log_topic *topic)
Initialize the log topic.
Definition: log.c:422
 
spa_log_level
Definition: log.h:65
 
#define SPA_PRINTF_FUNC(fmt, arg1)
Definition: defs.h:289
 
Identifier for a topic.
Definition: log.h:103
 
enum spa_log_level level
Logging level, everything above this level is not logged.
Definition: log.h:90