2004-09-28 16:34:51 +08:00
|
|
|
|
|
|
|
/*
|
2004-09-30 00:00:49 +08:00
|
|
|
* Copyright (C) Igor Sysoev
|
2012-01-18 23:07:43 +08:00
|
|
|
* Copyright (C) Nginx, Inc.
|
2004-09-28 16:34:51 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2002-08-07 00:39:45 +08:00
|
|
|
#ifndef _NGX_LOG_H_INCLUDED_
|
|
|
|
#define _NGX_LOG_H_INCLUDED_
|
|
|
|
|
|
|
|
|
2003-06-03 23:42:58 +08:00
|
|
|
#include <ngx_config.h>
|
|
|
|
#include <ngx_core.h>
|
|
|
|
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2004-04-08 23:58:25 +08:00
|
|
|
#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
|
|
|
|
|
2004-07-07 00:12:16 +08:00
|
|
|
#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
|
2007-03-19 21:36:56 +08:00
|
|
|
#define NGX_LOG_DEBUG_MAIL 0x200
|
2006-05-04 23:32:46 +08:00
|
|
|
#define NGX_LOG_DEBUG_MYSQL 0x400
|
2004-09-07 23:29:22 +08:00
|
|
|
|
|
|
|
/*
|
2004-09-28 16:34:51 +08:00
|
|
|
* do not forget to update debug_levels[] in src/core/ngx_log.c
|
|
|
|
* after the adding a new debug level
|
2004-09-07 23:29:22 +08:00
|
|
|
*/
|
2004-04-08 23:58:25 +08:00
|
|
|
|
|
|
|
#define NGX_LOG_DEBUG_FIRST NGX_LOG_DEBUG_CORE
|
2007-03-19 21:36:56 +08:00
|
|
|
#define NGX_LOG_DEBUG_LAST NGX_LOG_DEBUG_MYSQL
|
2004-04-08 23:58:25 +08:00
|
|
|
#define NGX_LOG_DEBUG_CONNECTION 0x80000000
|
|
|
|
#define NGX_LOG_DEBUG_ALL 0x7ffffff0
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2003-05-20 23:37:55 +08:00
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
typedef u_char *(*ngx_log_handler_pt) (ngx_log_t *log, u_char *buf, size_t len);
|
2003-10-27 16:53:49 +08:00
|
|
|
|
|
|
|
|
2003-11-20 00:26:41 +08:00
|
|
|
struct ngx_log_s {
|
2004-02-12 01:08:49 +08:00
|
|
|
ngx_uint_t log_level;
|
2003-10-27 16:53:49 +08:00
|
|
|
ngx_open_file_t *file;
|
2005-01-25 20:27:35 +08:00
|
|
|
|
2005-02-24 20:29:09 +08:00
|
|
|
ngx_atomic_uint_t connection;
|
2005-01-25 20:27:35 +08:00
|
|
|
|
2003-10-27 16:53:49 +08:00
|
|
|
ngx_log_handler_pt handler;
|
2005-01-25 20:27:35 +08:00
|
|
|
void *data;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* we declare "action" as "char *" because the actions are usually
|
|
|
|
* the static strings and in the "u_char *" case we have to override
|
|
|
|
* their types all the time
|
|
|
|
*/
|
|
|
|
|
|
|
|
char *action;
|
2013-06-21 00:47:39 +08:00
|
|
|
|
|
|
|
ngx_log_t *next;
|
2003-11-20 00:26:41 +08:00
|
|
|
};
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2004-11-11 22:07:14 +08:00
|
|
|
|
|
|
|
#define NGX_MAX_ERROR_STR 2048
|
2002-08-07 00:39:45 +08:00
|
|
|
|
|
|
|
|
2003-12-01 04:03:18 +08:00
|
|
|
/*********************************/
|
|
|
|
|
2010-07-05 21:02:25 +08:00
|
|
|
#if (NGX_HAVE_C99_VARIADIC_MACROS)
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2004-10-21 23:34:38 +08:00
|
|
|
#define NGX_HAVE_VARIADIC_MACROS 1
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2010-07-05 21:02:25 +08:00
|
|
|
#define ngx_log_error(level, log, ...) \
|
|
|
|
if ((log)->log_level >= level) ngx_log_error_core(level, log, __VA_ARGS__)
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2004-03-04 15:04:55 +08:00
|
|
|
void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
|
2005-03-04 22:06:57 +08:00
|
|
|
const char *fmt, ...);
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2010-07-05 21:02:25 +08:00
|
|
|
#define ngx_log_debug(level, log, ...) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2010-07-05 21:02:25 +08:00
|
|
|
ngx_log_error_core(NGX_LOG_DEBUG, log, __VA_ARGS__)
|
2005-01-25 20:27:35 +08:00
|
|
|
|
2003-12-01 04:03:18 +08:00
|
|
|
/*********************************/
|
2003-05-20 23:37:55 +08:00
|
|
|
|
2010-07-05 21:02:25 +08:00
|
|
|
#elif (NGX_HAVE_GCC_VARIADIC_MACROS)
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2004-10-21 23:34:38 +08:00
|
|
|
#define NGX_HAVE_VARIADIC_MACROS 1
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2010-07-05 21:02:25 +08:00
|
|
|
#define ngx_log_error(level, log, args...) \
|
|
|
|
if ((log)->log_level >= level) ngx_log_error_core(level, log, args)
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2004-03-04 15:04:55 +08:00
|
|
|
void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
|
2005-03-04 22:06:57 +08:00
|
|
|
const char *fmt, ...);
|
2002-08-07 00:39:45 +08:00
|
|
|
|
2010-07-05 21:02:25 +08:00
|
|
|
#define ngx_log_debug(level, log, args...) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2010-07-05 21:02:25 +08:00
|
|
|
ngx_log_error_core(NGX_LOG_DEBUG, log, args)
|
2005-01-25 20:27:35 +08:00
|
|
|
|
2003-12-01 04:03:18 +08:00
|
|
|
/*********************************/
|
2003-05-20 23:37:55 +08:00
|
|
|
|
2002-08-07 00:39:45 +08:00
|
|
|
#else /* NO VARIADIC MACROS */
|
|
|
|
|
2004-10-21 23:34:38 +08:00
|
|
|
#define NGX_HAVE_VARIADIC_MACROS 0
|
2003-12-01 04:03:18 +08:00
|
|
|
|
2005-03-23 00:02:46 +08:00
|
|
|
void ngx_cdecl ngx_log_error(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
|
2005-03-04 22:06:57 +08:00
|
|
|
const char *fmt, ...);
|
2004-03-04 15:04:55 +08:00
|
|
|
void ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
|
2005-03-04 22:06:57 +08:00
|
|
|
const char *fmt, va_list args);
|
2005-03-23 00:02:46 +08:00
|
|
|
void ngx_cdecl ngx_log_debug_core(ngx_log_t *log, ngx_err_t err,
|
|
|
|
const char *fmt, ...);
|
2002-08-07 00:39:45 +08:00
|
|
|
|
|
|
|
|
|
|
|
#endif /* VARIADIC MACROS */
|
|
|
|
|
|
|
|
|
2003-12-01 04:03:18 +08:00
|
|
|
/*********************************/
|
|
|
|
|
2004-03-04 00:14:15 +08:00
|
|
|
#if (NGX_DEBUG)
|
|
|
|
|
2004-10-21 23:34:38 +08:00
|
|
|
#if (NGX_HAVE_VARIADIC_MACROS)
|
2003-12-01 04:03:18 +08:00
|
|
|
|
2012-01-10 15:28:32 +08:00
|
|
|
#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)
|
2004-07-14 01:59:12 +08:00
|
|
|
|
2005-05-19 21:25:22 +08:00
|
|
|
|
2003-12-01 04:03:18 +08:00
|
|
|
#else /* NO VARIADIC MACROS */
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug0(level, log, err, fmt) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-01 04:03:18 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug1(level, log, err, fmt, arg1) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-01 04:03:18 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, arg1)
|
2003-12-15 04:10:27 +08:00
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug2(level, log, err, fmt, arg1, arg2) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-15 04:10:27 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, arg1, arg2)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug3(level, log, err, fmt, arg1, arg2, arg3) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-19 20:45:27 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug4(level, log, err, fmt, arg1, arg2, arg3, arg4) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-22 17:40:48 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug5(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-22 17:40:48 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4, arg5)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug6(level, log, err, fmt, \
|
|
|
|
arg1, arg2, arg3, arg4, arg5, arg6) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2003-12-15 04:10:27 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, arg1, arg2, arg3, arg4, arg5, arg6)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug7(level, log, err, fmt, \
|
|
|
|
arg1, arg2, arg3, arg4, arg5, arg6, arg7) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2005-01-25 20:27:35 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, \
|
2004-07-14 01:59:12 +08:00
|
|
|
arg1, arg2, arg3, arg4, arg5, arg6, arg7)
|
|
|
|
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug8(level, log, err, fmt, \
|
|
|
|
arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8) \
|
2005-09-23 19:02:22 +08:00
|
|
|
if ((log)->log_level & level) \
|
2005-01-25 20:27:35 +08:00
|
|
|
ngx_log_debug_core(log, err, fmt, \
|
|
|
|
arg1, arg2, arg3, arg4, arg5, arg6, arg7, arg8)
|
|
|
|
|
2003-12-01 04:03:18 +08:00
|
|
|
#endif
|
|
|
|
|
2004-03-04 00:14:15 +08:00
|
|
|
#else /* NO NGX_DEBUG */
|
|
|
|
|
|
|
|
#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)
|
2004-09-15 03:39:54 +08:00
|
|
|
#define ngx_log_debug7(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, \
|
|
|
|
arg6, arg7)
|
2005-01-25 20:27:35 +08:00
|
|
|
#define ngx_log_debug8(level, log, err, fmt, arg1, arg2, arg3, arg4, arg5, \
|
|
|
|
arg6, arg7, arg8)
|
2004-03-04 00:14:15 +08:00
|
|
|
|
|
|
|
#endif
|
2003-12-01 04:03:18 +08:00
|
|
|
|
|
|
|
/*********************************/
|
|
|
|
|
2009-04-27 19:32:33 +08:00
|
|
|
ngx_log_t *ngx_log_init(u_char *prefix);
|
2009-04-24 23:50:51 +08:00
|
|
|
void ngx_cdecl ngx_log_abort(ngx_err_t err, const char *fmt, ...);
|
2009-04-23 19:13:12 +08:00
|
|
|
void ngx_cdecl ngx_log_stderr(ngx_err_t err, const char *fmt, ...);
|
2009-04-27 21:17:33 +08:00
|
|
|
u_char *ngx_log_errno(u_char *buf, u_char *last, ngx_err_t err);
|
2013-06-28 21:24:54 +08:00
|
|
|
ngx_int_t ngx_log_open_default(ngx_cycle_t *cycle);
|
|
|
|
ngx_int_t ngx_log_redirect_stderr(ngx_cycle_t *cycle);
|
2013-06-21 00:47:39 +08:00
|
|
|
char *ngx_log_set_log(ngx_conf_t *cf, ngx_log_t **head);
|
2004-01-21 04:40:08 +08:00
|
|
|
|
2003-07-02 22:41:17 +08:00
|
|
|
|
2011-11-14 22:59:00 +08:00
|
|
|
/*
|
|
|
|
* ngx_write_stderr() cannot be implemented as macro, since
|
|
|
|
* MSVC does not allow to use #ifdef inside macro parameters.
|
|
|
|
*
|
|
|
|
* ngx_write_fd() is used instead of ngx_write_console(), since
|
|
|
|
* CharToOemBuff() inside ngx_write_console() cannot be used with
|
|
|
|
* read only buffer as destination and CharToOemBuff() is not needed
|
|
|
|
* for ngx_write_stderr() anyway.
|
|
|
|
*/
|
|
|
|
static ngx_inline void
|
|
|
|
ngx_write_stderr(char *text)
|
|
|
|
{
|
|
|
|
(void) ngx_write_fd(ngx_stderr, text, strlen(text));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-06-03 23:42:58 +08:00
|
|
|
extern ngx_module_t ngx_errlog_module;
|
2009-04-23 19:13:12 +08:00
|
|
|
extern ngx_uint_t ngx_use_stderr;
|
2003-06-03 23:42:58 +08:00
|
|
|
|
|
|
|
|
2002-08-07 00:39:45 +08:00
|
|
|
#endif /* _NGX_LOG_H_INCLUDED_ */
|