One Level Up
  Top Level
 
  src/core/ngx_log.h - nginx-1.7.10
 Data types defined
 
 Functions defined
 
 Macros defined
 
 Source code
  
 
 
 
- #ifndef _NGX_LOG_H_INCLUDED_
 
- #define _NGX_LOG_H_INCLUDED_
 
 
 
- #include <ngx_config.h>
 
- #include <ngx_core.h>
 
 
 
- #define NGX_LOG_STDERR            0
 
- #define NGX_LOG_EMERG             1
 
- #define NGX_LOG_ALERT             2
 
- #define NGX_LOG_CRIT              3
 
- #define NGX_LOG_ERR               4
 
- #define NGX_LOG_WARN              5
 
- #define NGX_LOG_NOTICE            6
 
- #define NGX_LOG_INFO              7
 
- #define NGX_LOG_DEBUG             8
 
 
- #define NGX_LOG_DEBUG_CORE        0x010
 
- #define NGX_LOG_DEBUG_ALLOC       0x020
 
- #define NGX_LOG_DEBUG_MUTEX       0x040
 
- #define NGX_LOG_DEBUG_EVENT       0x080
 
- #define NGX_LOG_DEBUG_HTTP        0x100
 
- #define NGX_LOG_DEBUG_MAIL        0x200
 
- #define NGX_LOG_DEBUG_MYSQL       0x400
 
 
 
- #define NGX_LOG_DEBUG_FIRST       NGX_LOG_DEBUG_CORE
 
- #define NGX_LOG_DEBUG_LAST        NGX_LOG_DEBUG_MYSQL
 
- #define NGX_LOG_DEBUG_CONNECTION  0x80000000
 
- #define NGX_LOG_DEBUG_ALL         0x7ffffff0
 
 
 
- typedef u_char *(*ngx_log_handler_pt) (ngx_log_t *log, u_char *buf, size_t len);
 
- typedef void (*ngx_log_writer_pt) (ngx_log_t *log, ngx_uint_t level,
 
-     u_char *buf, size_t len);
 
 
 
- struct ngx_log_s {
 
-     ngx_uint_t           log_level;
 
-     ngx_open_file_t     *file;
 
 
-     ngx_atomic_uint_t    connection;
 
 
-     time_t               disk_full_time;
 
 
-     ngx_log_handler_pt   handler;
 
-     void                *data;
 
 
-     ngx_log_writer_pt    writer;
 
-     void                *wdata;
 
 
-     
 
-     char                *action;
 
 
-     ngx_log_t           *next;
 
- };
 
 
 
- #define NGX_MAX_ERROR_STR   2048
 
 
 
 
- #if (NGX_HAVE_C99_VARIADIC_MACROS)
 
 
- #define NGX_HAVE_VARIADIC_MACROS  1
 
 
- #define ngx_log_error(level, log, ...)                                        \
 
-     if ((log)->log_level >= level) ngx_log_error_core(level, log, __VA_ARGS__)
 
 
- void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
 
-     const char *fmt, ...);
 
 
- #define ngx_log_debug(level, log, ...)                                        \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_error_core(NGX_LOG_DEBUG, log, __VA_ARGS__)
 
 
 
- #elif (NGX_HAVE_GCC_VARIADIC_MACROS)
 
 
- #define NGX_HAVE_VARIADIC_MACROS  1
 
 
- #define ngx_log_error(level, log, args...)                                    \
 
-     if ((log)->log_level >= level) ngx_log_error_core(level, log, args)
 
 
- void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
 
-     const char *fmt, ...);
 
 
- #define ngx_log_debug(level, log, args...)                                    \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_error_core(NGX_LOG_DEBUG, log, args)
 
 
 
- #else 
 
- #define NGX_HAVE_VARIADIC_MACROS  0
 
 
- void ngx_cdecl ngx_log_error(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
 
-     const char *fmt, ...);
 
- void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
 
-     const char *fmt, va_list args);
 
- void ngx_cdecl ngx_log_debug_core(ngx_log_t *log, ngx_err_t err,
 
-     const char *fmt, ...);
 
 
 
- #endif 
 
 
 
- #if (NGX_DEBUG)
 
 
- #if (NGX_HAVE_VARIADIC_MACROS)
 
 
- #define ngx_log_debug0(level, log, err, fmt)                                  \
 
-         ngx_log_debug(level, log, err, fmt)
 
 
- #define ngx_log_debug1(level, log, err, fmt, arg1)                            \
 
-         ngx_log_debug(level, log, err, fmt, arg1)
 
 
- #define ngx_log_debug2(level, log, err, fmt, arg1, arg2)                      \
 
-         ngx_log_debug(level, log, err, fmt, arg1, arg2)
 
 
- #define ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3)                \
 
-         ngx_log_debug(level, log, err, fmt, arg1, arg2, arg3)
 
 
- #define ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4)          \
 
-         ngx_log_debug(level, log, err, fmt, arg1, arg2, arg3, arg4)
 
 
- #define ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)    \
 
-         ngx_log_debug(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)
 
 
- #define ngx_log_debug6(level, log, err, fmt,                                  \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6)                    \
 
-         ngx_log_debug(level, log, err, fmt,                                   \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6)
 
 
- #define ngx_log_debug7(level, log, err, fmt,                                  \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7)              \
 
-         ngx_log_debug(level, log, err, fmt,                                   \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7)
 
 
- #define ngx_log_debug8(level, log, err, fmt,                                  \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)        \
 
-         ngx_log_debug(level, log, err, fmt,                                   \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)
 
 
 
- #else 
 
- #define ngx_log_debug0(level, log, err, fmt)                                  \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt)
 
 
- #define ngx_log_debug1(level, log, err, fmt, arg1)                            \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt, arg1)
 
 
- #define ngx_log_debug2(level, log, err, fmt, arg1, arg2)                      \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt, arg1, arg2)
 
 
- #define ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3)                \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3)
 
 
- #define ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4)          \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4)
 
 
- #define ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)    \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4, arg5)
 
 
- #define ngx_log_debug6(level, log, err, fmt,                                  \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6)                    \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6)
 
 
- #define ngx_log_debug7(level, log, err, fmt,                                  \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7)              \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt,                                     \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7)
 
 
- #define ngx_log_debug8(level, log, err, fmt,                                  \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)        \
 
-     if ((log)->log_level & level)                                             \
 
-         ngx_log_debug_core(log, err, fmt,                                     \
 
-                        arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)
 
 
- #endif
 
 
- #else 
 
- #define ngx_log_debug0(level, log, err, fmt)
 
- #define ngx_log_debug1(level, log, err, fmt, arg1)
 
- #define ngx_log_debug2(level, log, err, fmt, arg1, arg2)
 
- #define ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3)
 
- #define ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4)
 
- #define ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5)
 
- #define ngx_log_debug6(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6)
 
- #define ngx_log_debug7(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5,    \
 
-                        arg6, arg7)
 
- #define ngx_log_debug8(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5,    \
 
-                        arg6, arg7, arg8)
 
 
- #endif
 
 
 
- ngx_log_t *ngx_log_init(u_char *prefix);
 
- void ngx_cdecl ngx_log_abort(ngx_err_t err, const char *fmt, ...);
 
- void ngx_cdecl ngx_log_stderr(ngx_err_t err, const char *fmt, ...);
 
- u_char *ngx_log_errno(u_char *buf, u_char *last, ngx_err_t err);
 
- ngx_int_t ngx_log_open_default(ngx_cycle_t *cycle);
 
- ngx_int_t ngx_log_redirect_stderr(ngx_cycle_t *cycle);
 
- ngx_log_t *ngx_log_get_file_log(ngx_log_t *head);
 
- char *ngx_log_set_log(ngx_conf_t *cf, ngx_log_t **head);
 
 
 
- static ngx_inline void
 
- ngx_write_stderr(char *text)
 
- {
 
-     (void) ngx_write_fd(ngx_stderr, text, ngx_strlen(text));
 
- }
 
 
 
- extern ngx_module_t  ngx_errlog_module;
 
- extern ngx_uint_t    ngx_use_stderr;
 
 
 
- #endif 
  One Level Up
  Top Level