summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2005-10-27 14:27:47 +0000
committerJonathan Kolb <jon@b0g.us>2005-10-27 14:27:47 +0000
commit419eefdf38f7c94fe553fe811f05101bb1bb1709 (patch)
tree835d3ad6016d0bf3b22f2f4309168902a3532e20
parent08215fca08617c8fd56f416b56f8216f1d5090b3 (diff)
downloadnginx-419eefdf38f7c94fe553fe811f05101bb1bb1709.tar.gz
Changes with nginx 0.3.7 27 Oct 2005v0.3.7
*) Feature: the "access_log" supports the "buffer=" parameter. *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc и ppc; bug appeared in 0.3.2.
-rw-r--r--CHANGES8
-rw-r--r--CHANGES.ru8
-rw-r--r--auto/threads2
-rw-r--r--src/core/nginx.h2
-rw-r--r--src/core/ngx_conf_file.c37
-rw-r--r--src/core/ngx_conf_file.h12
-rw-r--r--src/core/ngx_cycle.c6
-rw-r--r--src/core/ngx_log.c38
-rw-r--r--src/event/ngx_event_openssl.c14
-rw-r--r--src/http/modules/ngx_http_log_module.c93
-rw-r--r--src/http/ngx_http_variables.c44
-rw-r--r--src/imap/ngx_imap.h4
-rw-r--r--src/imap/ngx_imap_proxy_module.c46
-rw-r--r--src/os/unix/ngx_atomic.h5
-rw-r--r--src/os/unix/ngx_files.h6
-rw-r--r--src/os/unix/ngx_process_cycle.c21
16 files changed, 236 insertions, 110 deletions
diff --git a/CHANGES b/CHANGES
index 8a689ed06..7654f4de6 100644
--- a/CHANGES
+++ b/CHANGES
@@ -1,4 +1,12 @@
+Changes with nginx 0.3.7 27 Oct 2005
+
+ *) Feature: the "access_log" supports the "buffer=" parameter.
+
+ *) Bugfix: nginx could not be built on platforms different from i386,
+ amd64, sparc и ppc; bug appeared in 0.3.2.
+
+
Changes with nginx 0.3.6 24 Oct 2005
*) Change: now the IMAP/POP3 proxy do not send the empty login to
diff --git a/CHANGES.ru b/CHANGES.ru
index c19ed88e5..498d678e1 100644
--- a/CHANGES.ru
+++ b/CHANGES.ru
@@ -1,4 +1,12 @@
+Изменения в nginx 0.3.7 27.10.2005
+
+ *) Добавление: директива access_log поддерживает параметр buffer=.
+
+ *) Исправление: nginx не собирался на платформах, отличных от i386,
+ amd64, sparc и ppc; ошибка появилась в 0.3.2.
+
+
Изменения в nginx 0.3.6 24.10.2005
*) Изменение: IMAP/POP3 прокси теперь не передаёт серверу авторизации
diff --git a/auto/threads b/auto/threads
index 2bf85b65f..29bc72476 100644
--- a/auto/threads
+++ b/auto/threads
@@ -50,7 +50,7 @@ case $USE_THREADS in
CORE_LIBS="$CORE_LIBS -pthread"
;;
- FreeBSD:[567]*)
+ FreeBSD:[56]*)
have=NGX_THREADS . auto/have
CORE_SRCS="$CORE_SRCS $PTHREAD_SRCS"
CORE_LIBS="$CORE_LIBS -lc_r"
diff --git a/src/core/nginx.h b/src/core/nginx.h
index 5a3593d35..78ae2a78a 100644
--- a/src/core/nginx.h
+++ b/src/core/nginx.h
@@ -8,7 +8,7 @@
#define _NGINX_H_INCLUDED_
-#define NGINX_VER "nginx/0.3.6"
+#define NGINX_VER "nginx/0.3.7"
#define NGINX_VAR "NGINX"
#define NGX_OLDPID_EXT ".oldbin"
diff --git a/src/core/ngx_conf_file.c b/src/core/ngx_conf_file.c
index 78e61f8c1..acec1308f 100644
--- a/src/core/ngx_conf_file.c
+++ b/src/core/ngx_conf_file.c
@@ -11,6 +11,7 @@
static ngx_int_t ngx_conf_handler(ngx_conf_t *cf, ngx_int_t last);
static ngx_int_t ngx_conf_read_token(ngx_conf_t *cf);
static char *ngx_conf_include(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
+static void ngx_conf_flush_files(ngx_cycle_t *cycle);
static ngx_command_t ngx_conf_commands[] = {
@@ -36,7 +37,7 @@ ngx_module_t ngx_conf_module = {
NULL, /* init process */
NULL, /* init thread */
NULL, /* exit thread */
- NULL, /* exit process */
+ ngx_conf_flush_files, /* exit process */
NULL, /* exit master */
NGX_MODULE_V1_PADDING
};
@@ -742,10 +743,44 @@ ngx_conf_open_file(ngx_cycle_t *cycle, ngx_str_t *name)
file->name.data = NULL;
}
+ file->buffer = NULL;
+
return file;
}
+static void
+ngx_conf_flush_files(ngx_cycle_t *cycle)
+{
+ ngx_uint_t i;
+ ngx_list_part_t *part;
+ ngx_open_file_t *file;
+
+ ngx_log_debug0(NGX_LOG_DEBUG_CORE, cycle->log, 0, "flush files");
+
+ part = &cycle->open_files.part;
+ file = part->elts;
+
+ for (i = 0; /* void */ ; i++) {
+
+ if (i >= part->nelts) {
+ if (part->next == NULL) {
+ break;
+ }
+ part = part->next;
+ file = part->elts;
+ i = 0;
+ }
+
+ if (file[i].buffer == NULL || file[i].pos - file[i].buffer == 0) {
+ continue;
+ }
+
+ ngx_write_fd(file[i].fd, file[i].buffer, file[i].pos - file[i].buffer);
+ }
+}
+
+
void ngx_cdecl
ngx_conf_log_error(ngx_uint_t level, ngx_conf_t *cf, ngx_err_t err,
char *fmt, ...)
diff --git a/src/core/ngx_conf_file.h b/src/core/ngx_conf_file.h
index 9f344e64c..b09d8cc6a 100644
--- a/src/core/ngx_conf_file.h
+++ b/src/core/ngx_conf_file.h
@@ -34,6 +34,7 @@
#define NGX_CONF_TAKE23 (NGX_CONF_TAKE2|NGX_CONF_TAKE3)
+#define NGX_CONF_TAKE123 (NGX_CONF_TAKE1|NGX_CONF_TAKE2|NGX_CONF_TAKE3)
#define NGX_CONF_TAKE1234 (NGX_CONF_TAKE1|NGX_CONF_TAKE2|NGX_CONF_TAKE3 \
|NGX_CONF_TAKE4)
@@ -87,6 +88,11 @@ struct ngx_command_s {
struct ngx_open_file_s {
ngx_fd_t fd;
ngx_str_t name;
+
+ u_char *buffer;
+ u_char *pos;
+ u_char *last;
+
#if 0
/* e.g. append mode, error_log */
ngx_uint_t flags;
@@ -121,10 +127,10 @@ struct ngx_module_s {
ngx_int_t (*init_process)(ngx_cycle_t *cycle);
ngx_int_t (*init_thread)(ngx_cycle_t *cycle);
- ngx_int_t (*exit_thread)(ngx_cycle_t *cycle);
- ngx_int_t (*exit_process)(ngx_cycle_t *cycle);
+ void (*exit_thread)(ngx_cycle_t *cycle);
+ void (*exit_process)(ngx_cycle_t *cycle);
- ngx_int_t (*exit_master)(ngx_cycle_t *cycle);
+ void (*exit_master)(ngx_cycle_t *cycle);
uintptr_t spare_hook0;
uintptr_t spare_hook1;
diff --git a/src/core/ngx_cycle.c b/src/core/ngx_cycle.c
index 58679ed28..ab196112c 100644
--- a/src/core/ngx_cycle.c
+++ b/src/core/ngx_cycle.c
@@ -724,6 +724,12 @@ ngx_reopen_files(ngx_cycle_t *cycle, ngx_uid_t user)
continue;
}
+ if (file[i].buffer && file[i].pos - file[i].buffer != 0) {
+ ngx_write_fd(file[i].fd, file[i].buffer,
+ file[i].pos - file[i].buffer);
+ file[i].pos = file[i].buffer;
+ }
+
fd = ngx_open_file(file[i].name.data, NGX_FILE_RDWR,
NGX_FILE_CREATE_OR_OPEN|NGX_FILE_APPEND);
diff --git a/src/core/ngx_log.c b/src/core/ngx_log.c
index 905c8a165..444e943c5 100644
--- a/src/core/ngx_log.c
+++ b/src/core/ngx_log.c
@@ -8,7 +8,6 @@
#include <ngx_core.h>
-static void ngx_log_write(ngx_log_t *log, u_char *errstr, size_t len);
static char *ngx_set_error_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
@@ -152,42 +151,13 @@ ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
p = log->handler(log, p, last - p);
}
- ngx_log_write(log, errstr, p - errstr);
-}
-
-
-static void
-ngx_log_write(ngx_log_t *log, u_char *errstr, size_t len)
-{
-#if (NGX_WIN32)
- u_long written;
-
- if (len >= NGX_MAX_ERROR_STR - 1) {
- len = NGX_MAX_ERROR_STR - 2;
+ if (p > last - NGX_LINEFEED_SIZE) {
+ p = last - NGX_LINEFEED_SIZE;
}
- errstr[len++] = CR;
- errstr[len++] = LF;
-
- WriteFile(log->file->fd, errstr, len, &written, NULL);
+ ngx_linefeed(p);
-#if 0
- if (WriteFile(log->file->fd, errstr, len, &written, NULL) == 0) {
- ngx_message_box("nginx", MB_OK, ngx_errno, "WriteFile() failed");
- }
-#endif
-
-#else
-
- if (len == NGX_MAX_ERROR_STR) {
- len--;
- }
-
- errstr[len++] = LF;
-
- (void) write(log->file->fd, errstr, len);
-
-#endif
+ ngx_write_fd(log->file->fd, errstr, p - errstr);
}
diff --git a/src/event/ngx_event_openssl.c b/src/event/ngx_event_openssl.c
index 5e8e747dc..49e260ac5 100644
--- a/src/event/ngx_event_openssl.c
+++ b/src/event/ngx_event_openssl.c
@@ -22,6 +22,7 @@ static void ngx_ssl_connection_error(ngx_connection_t *c, int sslerr,
ngx_err_t err, char *text);
static void *ngx_openssl_create_conf(ngx_cycle_t *cycle);
static char *ngx_openssl_init_conf(ngx_cycle_t *cycle, void *conf);
+static void ngx_openssl_exit(ngx_cycle_t *cycle);
#if !(NGX_SSL_ENGINE)
static char *ngx_openssl_noengine(ngx_conf_t *cf, ngx_command_t *cmd,
@@ -64,7 +65,7 @@ ngx_module_t ngx_openssl_module = {
NULL, /* init thread */
NULL, /* exit thread */
NULL, /* exit process */
- NULL, /* exit master */
+ ngx_openssl_exit, /* exit master */
NGX_MODULE_V1_PADDING
};
@@ -908,7 +909,7 @@ ngx_openssl_init_conf(ngx_cycle_t *cycle, void *conf)
{
#if (NGX_SSL_ENGINE)
ngx_openssl_conf_t *oscf = conf;
-
+
ENGINE *engine;
if (oscf->engine.len == 0) {
@@ -951,3 +952,12 @@ ngx_openssl_noengine(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
}
#endif
+
+
+static void
+ngx_openssl_exit(ngx_cycle_t *cycle)
+{
+#if (NGX_SSL_ENGINE)
+ ENGINE_cleanup();
+#endif
+}
diff --git a/src/http/modules/ngx_http_log_module.c b/src/http/modules/ngx_http_log_module.c
index 6e7772e56..f4993b5a9 100644
--- a/src/http/modules/ngx_http_log_module.c
+++ b/src/http/modules/ngx_http_log_module.c
@@ -96,7 +96,7 @@ static ngx_command_t ngx_http_log_commands[] = {
NULL },
{ ngx_string("access_log"),
- NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE12,
+ NGX_HTTP_MAIN_CONF|NGX_HTTP_SRV_CONF|NGX_HTTP_LOC_CONF|NGX_CONF_TAKE123,
ngx_http_log_set_log,
NGX_HTTP_LOC_CONF_OFFSET,
0,
@@ -190,11 +190,9 @@ ngx_http_log_handler(ngx_http_request_t *r)
u_char *line, *p;
size_t len;
ngx_http_log_t *log;
+ ngx_open_file_t *file;
ngx_http_log_op_t *op;
ngx_http_log_loc_conf_t *lcf;
-#if (NGX_WIN32)
- u_long written;
-#endif
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
"http log handler");
@@ -219,11 +217,34 @@ ngx_http_log_handler(ngx_http_request_t *r)
}
}
-#if (NGX_WIN32)
- len += 2;
-#else
- len++;
-#endif
+ len += NGX_LINEFEED_SIZE;
+
+ file = log[l].file;
+
+ if (file->buffer) {
+
+ if (len > (size_t) (file->last - file->pos)) {
+
+ ngx_write_fd(file->fd, file->buffer, file->pos - file->buffer);
+
+ file->pos = file->buffer;
+ }
+
+ if (len <= (size_t) (file->last - file->pos)) {
+
+ p = file->pos;
+
+ for (i = 0; i < log[l].ops->nelts; i++) {
+ p = op[i].run(r, p, &op[i]);
+ }
+
+ ngx_linefeed(p);
+
+ file->pos = p;
+
+ continue;
+ }
+ }
line = ngx_palloc(r->pool, len);
if (line == NULL) {
@@ -236,13 +257,9 @@ ngx_http_log_handler(ngx_http_request_t *r)
p = op[i].run(r, p, &op[i]);
}
-#if (NGX_WIN32)
- *p++ = CR; *p++ = LF;
- WriteFile(log[l].file->fd, line, p - line, &written, NULL);
-#else
- *p++ = LF;
- write(log[l].file->fd, line, p - line);
-#endif
+ ngx_linefeed(p);
+
+ ngx_write_fd(file->fd, line, p - line);
}
return NGX_OK;
@@ -942,6 +959,7 @@ ngx_http_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
{
ngx_http_log_loc_conf_t *llcf = conf;
+ ssize_t buf;
ngx_uint_t i;
ngx_str_t *value, name;
ngx_http_log_t *log;
@@ -974,7 +992,7 @@ ngx_http_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
return NGX_CONF_ERROR;
}
- if (cf->args->nelts == 3) {
+ if (cf->args->nelts >= 3) {
name = value[2];
} else {
name.len = sizeof("combined") - 1;
@@ -987,14 +1005,51 @@ ngx_http_log_set_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
&& ngx_strcasecmp(fmt[i].name.data, name.data) == 0)
{
log->ops = fmt[i].ops;
- return NGX_CONF_OK;
+ goto buffer;
}
}
ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
"unknown log format \"%V\"", &name);
-
return NGX_CONF_ERROR;
+
+buffer:
+
+ if (cf->args->nelts == 4) {
+ if (ngx_strncmp(value[3].data, "buffer=", 7) != 0) {
+ ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
+ "invalid parameter \"%V\"", &value[3]);
+ return NGX_CONF_ERROR;
+ }
+
+ name.len = value[3].len - 7;
+ name.data = value[3].data + 7;
+
+ buf = ngx_parse_size(&name);
+
+ if (buf == NGX_ERROR) {
+ ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
+ "invalid parameter \"%V\"", &value[3]);
+ return NGX_CONF_ERROR;
+ }
+
+ if (log->file->buffer && log->file->last - log->file->pos != buf) {
+ ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
+ "access_log \"%V\" already defined "
+ "with different buffer size", &value[1]);
+ return NGX_CONF_ERROR;
+ }
+
+ log->file->buffer = ngx_palloc(cf->pool, buf);
+ if (log->file->buffer == NULL) {
+ return NGX_CONF_ERROR;
+ }
+
+ log->file->pos = log->file->buffer;
+ log->file->last = log->file->buffer + buf;
+ }
+
+ return NGX_CONF_OK;
}
diff --git a/src/http/ngx_http_variables.c b/src/http/ngx_http_variables.c
index 3cb3bdf5b..e3954009b 100644
--- a/src/http/ngx_http_variables.c
+++ b/src/http/ngx_http_variables.c
@@ -36,6 +36,8 @@ static ngx_http_variable_value_t *
ngx_http_variable_request_method(ngx_http_request_t *r, uintptr_t data);
static ngx_http_variable_value_t *
ngx_http_variable_remote_user(ngx_http_request_t *r, uintptr_t data);
+static ngx_http_variable_value_t *
+ ngx_http_variable_sent(ngx_http_request_t *r, uintptr_t data);
/*
@@ -44,8 +46,7 @@ static ngx_http_variable_value_t *
* REMOTE_HOST (null), REMOTE_IDENT (null),
* SERVER_SOFTWARE
*
- * Apache SSI: DATE_GMT, DOCUMENT_NAME, LAST_MODIFIED,
- * USER_NAME (file owner)
+ * Apache SSI: DOCUMENT_NAME, LAST_MODIFIED, USER_NAME (file owner)
*/
static ngx_http_variable_t ngx_http_core_variables[] = {
@@ -116,6 +117,10 @@ static ngx_http_variable_t ngx_http_core_variables[] = {
{ ngx_string("remote_user"), ngx_http_variable_remote_user, 0, 0, 0 },
+ { ngx_string("sent"), ngx_http_variable_sent, 0, 0, 0 },
+
+ { ngx_string("apache_sent"), ngx_http_variable_sent, 1, 0, 0 },
+
{ ngx_null_string, NULL, 0, 0, 0 }
};
@@ -699,6 +704,41 @@ ngx_http_variable_remote_user(ngx_http_request_t *r, uintptr_t data)
}
+static ngx_http_variable_value_t *
+ngx_http_variable_sent(ngx_http_request_t *r, uintptr_t data)
+{
+ off_t sent;
+ u_char *p;
+ ngx_http_variable_value_t *vv;
+
+ vv = ngx_palloc(r->pool, sizeof(ngx_http_variable_value_t));
+ if (vv == NULL) {
+ return NULL;
+ }
+
+ sent = r->connection->sent;
+
+ if (data) {
+ sent -= r->header_size;
+
+ if (sent < 0) {
+ sent = 0;
+ }
+ }
+
+ p = ngx_palloc(r->pool, NGX_OFF_T_LEN);
+ if (p == NULL) {
+ return NULL;
+ }
+
+ vv->value = 0;
+ vv->text.len = ngx_sprintf(p, "%O", sent) - p;
+ vv->text.data = p;
+
+ return vv;
+}
+
+
ngx_int_t
ngx_http_variables_add_core_vars(ngx_conf_t *cf)
{
diff --git a/src/imap/ngx_imap.h b/src/imap/ngx_imap.h
index c42324cf7..fed6852b1 100644
--- a/src/imap/ngx_imap.h
+++ b/src/imap/ngx_imap.h
@@ -157,10 +157,6 @@ typedef struct {
#define NGX_IMAP_PARSE_INVALID_COMMAND 20
-#define NGX_IMAP_PROXY_INVALID 10
-#define NGX_IMAP_PROXY_ERROR 11
-
-
#define NGX_IMAP_MODULE 0x50414D49 /* "IMAP" */
#define NGX_IMAP_MAIN_CONF 0x02000000
diff --git a/src/imap/ngx_imap_proxy_module.c b/src/imap/ngx_imap_proxy_module.c
index bfbcc1cbe..e1cccf122 100644
--- a/src/imap/ngx_imap_proxy_module.c
+++ b/src/imap/ngx_imap_proxy_module.c
@@ -32,8 +32,8 @@ static char *ngx_imap_proxy_merge_conf(ngx_conf_t *cf, void *parent,
void *child);
-#define NGX_IMAP_WAIT_OK 0
-#define NGX_IMAP_WAIT_NEXT 1
+#define NGX_IMAP_WAIT_OK 0
+#define NGX_IMAP_WAIT_NEXT 1
static ngx_command_t ngx_imap_proxy_commands[] = {
@@ -156,7 +156,6 @@ ngx_imap_proxy_block_read(ngx_event_t *rev)
static void
ngx_imap_proxy_imap_handler(ngx_event_t *rev)
{
- char *action;
u_char *p;
ngx_int_t rc;
ngx_str_t line;
@@ -194,21 +193,11 @@ ngx_imap_proxy_imap_handler(ngx_event_t *rev)
return;
}
- if (rc == NGX_ERROR || rc == NGX_IMAP_PROXY_INVALID) {
+ if (rc == NGX_ERROR) {
ngx_imap_proxy_internal_server_error(s);
return;
}
- if (rc == NGX_IMAP_PROXY_ERROR) {
- s->connection->read->handler = ngx_imap_proxy_handler;
- s->connection->write->handler = ngx_imap_proxy_handler;
- rev->handler = ngx_imap_proxy_handler;
- c->write->handler = ngx_imap_proxy_handler;
-
- ngx_imap_proxy_handler(c->read);
- return;
- }
-
switch (s->imap_state) {
case ngx_imap_start:
@@ -294,10 +283,8 @@ ngx_imap_proxy_imap_handler(ngx_event_t *rev)
ngx_add_timer(s->connection->read, pcf->timeout);
ngx_del_timer(c->read);
- action = c->log->action;
c->log->action = NULL;
ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
- c->log->action = action;
c->log->action = "proxying";
}
@@ -307,7 +294,6 @@ ngx_imap_proxy_imap_handler(ngx_event_t *rev)
static void
ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
{
- char *action;
u_char *p;
ngx_int_t rc;
ngx_str_t line;
@@ -344,21 +330,11 @@ ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
return;
}
- if (rc == NGX_ERROR || rc == NGX_IMAP_PROXY_INVALID) {
+ if (rc == NGX_ERROR) {
ngx_imap_proxy_internal_server_error(s);
return;
}
- if (rc == NGX_IMAP_PROXY_ERROR) {
- s->connection->read->handler = ngx_imap_proxy_handler;
- s->connection->write->handler = ngx_imap_proxy_handler;
- rev->handler = ngx_imap_proxy_handler;
- c->write->handler = ngx_imap_proxy_handler;
-
- ngx_imap_proxy_handler(c->read);
- return;
- }
-
switch (s->imap_state) {
case ngx_pop3_start:
@@ -425,10 +401,8 @@ ngx_imap_proxy_pop3_handler(ngx_event_t *rev)
ngx_add_timer(s->connection->read, pcf->timeout);
ngx_del_timer(c->read);
- action = c->log->action;
c->log->action = NULL;
ngx_log_error(NGX_LOG_INFO, c->log, 0, "client logged in");
- c->log->action = action;
c->log->action = "proxying";
}
@@ -474,7 +448,7 @@ ngx_imap_proxy_read_response(ngx_imap_session_t *s, ngx_uint_t what)
ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
"upstream sent too long response line: \"%s\"",
b->pos);
- return NGX_IMAP_PROXY_INVALID;
+ return NGX_ERROR;
}
return NGX_AGAIN;
@@ -487,15 +461,7 @@ ngx_imap_proxy_read_response(ngx_imap_session_t *s, ngx_uint_t what)
return NGX_OK;
}
- if (p[0] == '-' && p[1] == 'E' && p[2] == 'R' && p[3] == 'R') {
- return NGX_IMAP_PROXY_ERROR;
- }
-
} else {
- if (p[0] == 'N' && p[1] == 'O') {
- return NGX_IMAP_PROXY_ERROR;
- }
-
if (what == NGX_IMAP_WAIT_OK) {
if (p[0] == '*' && p[1] == ' ' && p[2] == 'O' && p[3] == 'K') {
return NGX_OK;
@@ -512,7 +478,7 @@ ngx_imap_proxy_read_response(ngx_imap_session_t *s, ngx_uint_t what)
ngx_log_error(NGX_LOG_ERR, s->connection->log, 0,
"upstream sent invalid response: \"%s\"", p);
- return NGX_IMAP_PROXY_INVALID;
+ return NGX_ERROR;
}
diff --git a/src/os/unix/ngx_atomic.h b/src/os/unix/ngx_atomic.h
index 3dfce74c4..50d6354d5 100644
--- a/src/os/unix/ngx_atomic.h
+++ b/src/os/unix/ngx_atomic.h
@@ -154,7 +154,7 @@ static ngx_inline ngx_atomic_uint_t
ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old,
ngx_atomic_uint_t set)
{
- if (*lock == old {
+ if (*lock == old) {
*lock = set;
return 1;
}
@@ -174,8 +174,9 @@ ngx_atomic_fetch_add(ngx_atomic_t *value, ngx_atomic_int_t add)
return old;
}
-#endif
+#define ngx_memory_barrier()
+#endif
void ngx_spinlock(ngx_atomic_t *lock, ngx_uint_t spin);
diff --git a/src/os/unix/ngx_files.h b/src/os/unix/ngx_files.h
index 57f53eb0e..a361fe4cd 100644
--- a/src/os/unix/ngx_files.h
+++ b/src/os/unix/ngx_files.h
@@ -44,7 +44,6 @@ ngx_fd_t ngx_open_tempfile(u_char *name, ngx_uint_t persistent);
ssize_t ngx_read_file(ngx_file_t *file, u_char *buf, size_t size, off_t offset);
#define ngx_read_file_n "read()"
-
ssize_t ngx_write_file(ngx_file_t *file, u_char *buf, size_t size,
off_t offset);
@@ -52,6 +51,11 @@ ssize_t ngx_write_chain_to_file(ngx_file_t *file, ngx_chain_t *ce,
off_t offset, ngx_pool_t *pool);
+#define ngx_write_fd write
+#define ngx_linefeed(p) *p++ = LF;
+#define NGX_LINEFEED_SIZE 1
+
+
#define ngx_rename_file rename
#define ngx_rename_file_n "rename"
diff --git a/src/os/unix/ngx_process_cycle.c b/src/os/unix/ngx_process_cycle.c
index f4ec06f9b..e0f967fc0 100644
--- a/src/os/unix/ngx_process_cycle.c
+++ b/src/os/unix/ngx_process_cycle.c
@@ -276,6 +276,13 @@ ngx_single_process_cycle(ngx_cycle_t *cycle)
ngx_process_events_and_timers(cycle);
if (ngx_terminate || ngx_quit) {
+
+ for (i = 0; ngx_modules[i]; i++) {
+ if (ngx_modules[i]->exit_process) {
+ ngx_modules[i]->exit_process(cycle);
+ }
+ }
+
ngx_master_exit(cycle);
}
@@ -623,10 +630,18 @@ ngx_reap_childs(ngx_cycle_t *cycle)
static void
ngx_master_exit(ngx_cycle_t *cycle)
{
+ ngx_uint_t i;
+
ngx_delete_pidfile(cycle);
ngx_log_error(NGX_LOG_NOTICE, cycle->log, 0, "exit");
+ for (i = 0; ngx_modules[i]; i++) {
+ if (ngx_modules[i]->exit_master) {
+ ngx_modules[i]->exit_master(cycle);
+ }
+ }
+
/*
* we do not destroy cycle->pool here because a signal handler
* that uses cycle->log can be called at this point
@@ -735,6 +750,12 @@ ngx_worker_process_cycle(ngx_cycle_t *cycle, void *data)
ngx_wakeup_worker_threads(cycle);
#endif
+ for (i = 0; ngx_modules[i]; i++) {
+ if (ngx_modules[i]->exit_process) {
+ ngx_modules[i]->exit_process(cycle);
+ }
+ }
+
c = cycle->connections;
for (i = 0; i < cycle->connection_n; i++) {
if (c[i].fd != -1