10#ifndef COMMON_LOGGING_H
11#define COMMON_LOGGING_H
86#define PG_LOG_FLAG_TERSE 1
108#define pg_log_error(...) \
109 pg_log_generic(PG_LOG_ERROR, PG_LOG_PRIMARY, __VA_ARGS__)
111#define pg_log_error_detail(...) \
112 pg_log_generic(PG_LOG_ERROR, PG_LOG_DETAIL, __VA_ARGS__)
114#define pg_log_error_hint(...) \
115 pg_log_generic(PG_LOG_ERROR, PG_LOG_HINT, __VA_ARGS__)
117#define pg_log_warning(...) \
118 pg_log_generic(PG_LOG_WARNING, PG_LOG_PRIMARY, __VA_ARGS__)
120#define pg_log_warning_detail(...) \
121 pg_log_generic(PG_LOG_WARNING, PG_LOG_DETAIL, __VA_ARGS__)
123#define pg_log_warning_hint(...) \
124 pg_log_generic(PG_LOG_WARNING, PG_LOG_HINT, __VA_ARGS__)
126#define pg_log_info(...) \
127 pg_log_generic(PG_LOG_INFO, PG_LOG_PRIMARY, __VA_ARGS__)
129#define pg_log_info_detail(...) \
130 pg_log_generic(PG_LOG_INFO, PG_LOG_DETAIL, __VA_ARGS__)
132#define pg_log_info_hint(...) \
133 pg_log_generic(PG_LOG_INFO, PG_LOG_HINT, __VA_ARGS__)
135#define pg_log_debug(...) do { \
136 if (unlikely(__pg_log_level <= PG_LOG_DEBUG)) \
137 pg_log_generic(PG_LOG_DEBUG, PG_LOG_PRIMARY, __VA_ARGS__); \
140#define pg_log_debug_detail(...) do { \
141 if (unlikely(__pg_log_level <= PG_LOG_DEBUG)) \
142 pg_log_generic(PG_LOG_DEBUG, PG_LOG_DETAIL, __VA_ARGS__); \
145#define pg_log_debug_hint(...) do { \
146 if (unlikely(__pg_log_level <= PG_LOG_DEBUG)) \
147 pg_log_generic(PG_LOG_DEBUG, PG_LOG_HINT, __VA_ARGS__); \
153#define pg_fatal(...) do { \
154 pg_log_generic(PG_LOG_ERROR, PG_LOG_PRIMARY, __VA_ARGS__); \
162#define pg_log_error_internal(...) pg_log_error(__VA_ARGS__)
163#define pg_fatal_internal(...) pg_fatal(__VA_ARGS__)
#define pg_attribute_printf(f, a)
void pg_logging_unset_logfile(void)
void pg_logging_increase_verbosity(void)
void pg_logging_set_logfile(FILE *logfile)
void pg_logging_init(const char *argv0)
void pg_logging_set_locus_callback(void(*cb)(const char **filename, uint64 *lineno))
void pg_logging_config(int new_flags)
void pg_logging_set_level(enum pg_log_level new_level)
void pg_log_generic(enum pg_log_level level, enum pg_log_part part, const char *pg_restrict fmt,...) pg_attribute_printf(3
void pg_logging_set_pre_callback(void(*cb)(void))
enum pg_log_level __pg_log_level
void void pg_log_generic_v(enum pg_log_level level, enum pg_log_part part, const char *pg_restrict fmt, va_list ap) pg_attribute_printf(3