mirror of
https://github.com/nginx/nginx.git
synced 2025-06-07 17:52:38 +08:00
nginx-0.0.1-2003-11-11-21:13:43 import
This commit is contained in:
parent
d59a047a70
commit
27c30f9919
@ -322,9 +322,10 @@ static int ngx_devpoll_set_event(ngx_event_t *ev, int event, u_int flags)
|
|||||||
int ngx_devpoll_process_events(ngx_log_t *log)
|
int ngx_devpoll_process_events(ngx_log_t *log)
|
||||||
{
|
{
|
||||||
int events, n, i, j;
|
int events, n, i, j;
|
||||||
ngx_msec_t timer, delta;
|
ngx_msec_t timer;
|
||||||
ngx_err_t err;
|
ngx_err_t err;
|
||||||
ngx_cycle_t **cycle;
|
ngx_cycle_t **cycle;
|
||||||
|
ngx_epoch_msec_t delta;
|
||||||
ngx_connection_t *c;
|
ngx_connection_t *c;
|
||||||
struct dvpoll dvp;
|
struct dvpoll dvp;
|
||||||
struct timeval tv;
|
struct timeval tv;
|
||||||
@ -332,7 +333,7 @@ int ngx_devpoll_process_events(ngx_log_t *log)
|
|||||||
timer = ngx_event_find_timer();
|
timer = ngx_event_find_timer();
|
||||||
|
|
||||||
if (timer) {
|
if (timer) {
|
||||||
gettimeofday(&tv, NULL);
|
ngx_gettimeofday(&tv);
|
||||||
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -366,7 +367,7 @@ int ngx_devpoll_process_events(ngx_log_t *log)
|
|||||||
|
|
||||||
nchanges = 0;
|
nchanges = 0;
|
||||||
|
|
||||||
gettimeofday(&tv, NULL);
|
ngx_gettimeofday(&tv);
|
||||||
|
|
||||||
if (ngx_cached_time != tv.tv_sec) {
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
ngx_cached_time = tv.tv_sec;
|
ngx_cached_time = tv.tv_sec;
|
||||||
@ -377,9 +378,9 @@ int ngx_devpoll_process_events(ngx_log_t *log)
|
|||||||
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "devpoll timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "devpoll timer: %d, delta: %d" _ timer _ (int)delta);
|
||||||
#endif
|
#endif
|
||||||
ngx_event_expire_timers(delta);
|
ngx_event_expire_timers((ngx_msec_t) delta);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (events == 0) {
|
if (events == 0) {
|
||||||
@ -389,7 +390,7 @@ int ngx_devpoll_process_events(ngx_log_t *log)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "devpoll timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "devpoll timer: %d, delta: %d" _ timer _ (int)delta);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -162,14 +162,16 @@ static int ngx_iocp_process_events(ngx_log_t *log)
|
|||||||
u_int key;
|
u_int key;
|
||||||
size_t bytes;
|
size_t bytes;
|
||||||
ngx_err_t err;
|
ngx_err_t err;
|
||||||
ngx_msec_t timer, delta;
|
ngx_msec_t timer;
|
||||||
ngx_event_t *ev;
|
ngx_event_t *ev;
|
||||||
|
ngx_epoch_msec_t delta;
|
||||||
ngx_event_ovlp_t *ovlp;
|
ngx_event_ovlp_t *ovlp;
|
||||||
|
|
||||||
timer = ngx_event_find_timer();
|
timer = ngx_event_find_timer();
|
||||||
|
|
||||||
if (timer) {
|
if (timer) {
|
||||||
delta = ngx_msec();
|
ngx_gettimeofday(&tv);
|
||||||
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
timer = INFINITE;
|
timer = INFINITE;
|
||||||
@ -189,11 +191,16 @@ static int ngx_iocp_process_events(ngx_log_t *log)
|
|||||||
err = 0;
|
err = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* TODO: timer */
|
ngx_gettimeofday(&tv);
|
||||||
|
|
||||||
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
|
ngx_cached_time = tv.tv_sec;
|
||||||
|
ngx_time_update();
|
||||||
|
}
|
||||||
|
|
||||||
if (timer != INFINITE) {
|
if (timer != INFINITE) {
|
||||||
delta = ngx_msec() - delta;
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
||||||
ngx_event_expire_timers(delta);
|
ngx_event_expire_timers((ngx_msec_t) delta);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
|
@ -311,12 +311,13 @@ static int ngx_kqueue_set_event(ngx_event_t *ev, int filter, u_int flags)
|
|||||||
|
|
||||||
static int ngx_kqueue_process_events(ngx_log_t *log)
|
static int ngx_kqueue_process_events(ngx_log_t *log)
|
||||||
{
|
{
|
||||||
int events, instance, i;
|
int events, instance, i;
|
||||||
ngx_err_t err;
|
ngx_err_t err;
|
||||||
ngx_msec_t timer, delta;
|
ngx_msec_t timer;
|
||||||
ngx_event_t *ev;
|
ngx_event_t *ev;
|
||||||
struct timeval tv;
|
ngx_epoch_msec_t delta;
|
||||||
struct timespec ts, *tp;
|
struct timeval tv;
|
||||||
|
struct timespec ts, *tp;
|
||||||
|
|
||||||
timer = ngx_event_find_timer();
|
timer = ngx_event_find_timer();
|
||||||
|
|
||||||
@ -324,11 +325,11 @@ static int ngx_kqueue_process_events(ngx_log_t *log)
|
|||||||
ts.tv_sec = timer / 1000;
|
ts.tv_sec = timer / 1000;
|
||||||
ts.tv_nsec = (timer % 1000) * 1000000;
|
ts.tv_nsec = (timer % 1000) * 1000000;
|
||||||
tp = &ts;
|
tp = &ts;
|
||||||
gettimeofday(&tv, NULL);
|
|
||||||
|
ngx_gettimeofday(&tv);
|
||||||
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
timer = 0;
|
|
||||||
delta = 0;
|
delta = 0;
|
||||||
tp = NULL;
|
tp = NULL;
|
||||||
}
|
}
|
||||||
@ -347,7 +348,7 @@ static int ngx_kqueue_process_events(ngx_log_t *log)
|
|||||||
|
|
||||||
nchanges = 0;
|
nchanges = 0;
|
||||||
|
|
||||||
gettimeofday(&tv, NULL);
|
ngx_gettimeofday(&tv);
|
||||||
|
|
||||||
if (ngx_cached_time != tv.tv_sec) {
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
ngx_cached_time = tv.tv_sec;
|
ngx_cached_time = tv.tv_sec;
|
||||||
@ -358,7 +359,7 @@ static int ngx_kqueue_process_events(ngx_log_t *log)
|
|||||||
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "kevent timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "kevent timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -366,7 +367,7 @@ static int ngx_kqueue_process_events(ngx_log_t *log)
|
|||||||
* because the new timers can be added during a processing
|
* because the new timers can be added during a processing
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ngx_event_expire_timers(delta);
|
ngx_event_expire_timers((ngx_msec_t) delta);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (events == 0) {
|
if (events == 0) {
|
||||||
@ -376,7 +377,7 @@ static int ngx_kqueue_process_events(ngx_log_t *log)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "kevent timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "kevent timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -224,16 +224,19 @@ static int ngx_poll_process_events(ngx_log_t *log)
|
|||||||
{
|
{
|
||||||
int ready, found, j;
|
int ready, found, j;
|
||||||
u_int nready, i;
|
u_int nready, i;
|
||||||
ngx_msec_t timer, delta;
|
ngx_msec_t timer;
|
||||||
ngx_err_t err;
|
ngx_err_t err;
|
||||||
ngx_cycle_t **cycle;
|
ngx_cycle_t **cycle;
|
||||||
ngx_event_t *ev;
|
ngx_event_t *ev;
|
||||||
|
ngx_epoch_msec_t delta;
|
||||||
ngx_connection_t *c;
|
ngx_connection_t *c;
|
||||||
|
struct timeval tv;
|
||||||
|
|
||||||
timer = ngx_event_find_timer();
|
timer = ngx_event_find_timer();
|
||||||
|
|
||||||
if (timer) {
|
if (timer) {
|
||||||
delta = ngx_msec();
|
ngx_gettimeofday(&tv);
|
||||||
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
timer = INFTIM;
|
timer = INFTIM;
|
||||||
@ -259,15 +262,20 @@ static int ngx_poll_process_events(ngx_log_t *log)
|
|||||||
|
|
||||||
ngx_log_debug(log, "poll ready %d" _ ready);
|
ngx_log_debug(log, "poll ready %d" _ ready);
|
||||||
|
|
||||||
/* TODO: time */
|
ngx_gettimeofday(&tv);
|
||||||
|
|
||||||
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
|
ngx_cached_time = tv.tv_sec;
|
||||||
|
ngx_time_update();
|
||||||
|
}
|
||||||
|
|
||||||
if ((int) timer != INFTIM) {
|
if ((int) timer != INFTIM) {
|
||||||
delta = ngx_msec() - delta;
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "poll timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "poll timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
#endif
|
#endif
|
||||||
ngx_event_expire_timers(delta);
|
ngx_event_expire_timers((ngx_msec_t) delta);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (ready == 0) {
|
if (ready == 0) {
|
||||||
@ -277,7 +285,7 @@ static int ngx_poll_process_events(ngx_log_t *log)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "poll timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "poll timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,6 +148,7 @@ static int ngx_select_add_event(ngx_event_t *ev, int event, u_int flags)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if (WIN32)
|
#if (WIN32)
|
||||||
|
|
||||||
if ((event == NGX_READ_EVENT) && (max_read >= FD_SETSIZE)
|
if ((event == NGX_READ_EVENT) && (max_read >= FD_SETSIZE)
|
||||||
|| (event == NGX_WRITE_EVENT) && (max_write >= FD_SETSIZE))
|
|| (event == NGX_WRITE_EVENT) && (max_write >= FD_SETSIZE))
|
||||||
{
|
{
|
||||||
@ -165,7 +166,9 @@ static int ngx_select_add_event(ngx_event_t *ev, int event, u_int flags)
|
|||||||
FD_SET(c->fd, &master_write_fd_set);
|
FD_SET(c->fd, &master_write_fd_set);
|
||||||
max_write++;
|
max_write++;
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
if (event == NGX_READ_EVENT) {
|
if (event == NGX_READ_EVENT) {
|
||||||
FD_SET(c->fd, &master_read_fd_set);
|
FD_SET(c->fd, &master_read_fd_set);
|
||||||
|
|
||||||
@ -247,10 +250,14 @@ static int ngx_select_process_events(ngx_log_t *log)
|
|||||||
int ready, found;
|
int ready, found;
|
||||||
u_int i, nready;
|
u_int i, nready;
|
||||||
ngx_err_t err;
|
ngx_err_t err;
|
||||||
ngx_msec_t timer, delta;
|
ngx_msec_t timer;
|
||||||
ngx_event_t *ev;
|
ngx_event_t *ev;
|
||||||
ngx_connection_t *c;
|
ngx_connection_t *c;
|
||||||
|
ngx_epoch_msec_t delta;
|
||||||
struct timeval tv, *tp;
|
struct timeval tv, *tp;
|
||||||
|
#if (HAVE_SELECT_CHANGE_TIMEOUT)
|
||||||
|
static ngx_epoch_msec_t deltas = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
work_read_fd_set = master_read_fd_set;
|
work_read_fd_set = master_read_fd_set;
|
||||||
work_write_fd_set = master_write_fd_set;
|
work_write_fd_set = master_write_fd_set;
|
||||||
@ -264,7 +271,8 @@ static int ngx_select_process_events(ngx_log_t *log)
|
|||||||
#if (HAVE_SELECT_CHANGE_TIMEOUT)
|
#if (HAVE_SELECT_CHANGE_TIMEOUT)
|
||||||
delta = 0;
|
delta = 0;
|
||||||
#else
|
#else
|
||||||
delta = ngx_msec();
|
ngx_gettimeofday(&tv);
|
||||||
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -314,32 +322,69 @@ static int ngx_select_process_events(ngx_log_t *log)
|
|||||||
ngx_log_debug(log, "select ready %d" _ ready);
|
ngx_log_debug(log, "select ready %d" _ ready);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* TODO: time */
|
#if (HAVE_SELECT_CHANGE_TIMEOUT)
|
||||||
|
|
||||||
if (timer) {
|
if (timer) {
|
||||||
#if (HAVE_SELECT_CHANGE_TIMEOUT)
|
|
||||||
delta = timer - (tv.tv_sec * 1000 + tv.tv_usec / 1000);
|
delta = timer - (tv.tv_sec * 1000 + tv.tv_usec / 1000);
|
||||||
|
|
||||||
#if 0
|
|
||||||
/*
|
/*
|
||||||
* update the cached time if the sum of the last deltas
|
* learn the real time and update the cached time
|
||||||
* is more than 0.5 seconds
|
* if the sum of the last deltas overcomes 1 second
|
||||||
*/
|
*/
|
||||||
deltas += delta;
|
|
||||||
if (deltas > 500000) {
|
|
||||||
ngx_cached_time = ngx_real_time();
|
|
||||||
deltas = 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#else
|
deltas += delta;
|
||||||
delta = ngx_msec() - delta;
|
if (deltas > 1000) {
|
||||||
#endif
|
ngx_gettimeofday(&tv);
|
||||||
|
deltas = tv.tv_usec / 1000;
|
||||||
|
|
||||||
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
|
ngx_cached_time = tv.tv_sec;
|
||||||
|
ngx_time_update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "select timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "select timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
#endif
|
#endif
|
||||||
ngx_event_expire_timers(delta);
|
|
||||||
|
ngx_event_expire_timers((ngx_msec_t) delta);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
ngx_gettimeofday(&tv);
|
||||||
|
|
||||||
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
|
ngx_cached_time = tv.tv_sec;
|
||||||
|
ngx_time_update();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ready == 0) {
|
||||||
|
ngx_log_error(NGX_LOG_ALERT, log, 0,
|
||||||
|
"select() returned no events without timeout");
|
||||||
|
return NGX_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if (NGX_DEBUG_EVENT)
|
||||||
|
ngx_log_debug(log, "select timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* HAVE_SELECT_CHANGE_TIMEOUT */
|
||||||
|
|
||||||
|
ngx_gettimeofday(&tv);
|
||||||
|
|
||||||
|
if (ngx_cached_time != tv.tv_sec) {
|
||||||
|
ngx_cached_time = tv.tv_sec;
|
||||||
|
ngx_time_update();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (timer) {
|
||||||
|
delta = tv.tv_sec * 1000 + tv.tv_usec / 1000 - delta;
|
||||||
|
|
||||||
|
#if (NGX_DEBUG_EVENT)
|
||||||
|
ngx_log_debug(log, "select timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ngx_event_expire_timers((ngx_msec_t) delta);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (ready == 0) {
|
if (ready == 0) {
|
||||||
@ -349,11 +394,12 @@ static int ngx_select_process_events(ngx_log_t *log)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if (NGX_DEBUG_EVENT)
|
#if (NGX_DEBUG_EVENT)
|
||||||
ngx_log_debug(log, "select timer: %d, delta: %d" _ timer _ delta);
|
ngx_log_debug(log, "select timer: %d, delta: %d" _ timer _ (int) delta);
|
||||||
#endif
|
#endif
|
||||||
ngx_event_expire_timers(delta);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif /* HAVE_SELECT_CHANGE_TIMEOUT */
|
||||||
|
|
||||||
if (err) {
|
if (err) {
|
||||||
ngx_log_error(NGX_LOG_ALERT, log, err, "select() failed");
|
ngx_log_error(NGX_LOG_ALERT, log, err, "select() failed");
|
||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
|
@ -429,7 +429,7 @@ int ngx_http_send_header(ngx_http_request_t *r)
|
|||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (r->err_status) {
|
if (r->err_ctx) {
|
||||||
r->headers_out.status = r->err_status;
|
r->headers_out.status = r->err_status;
|
||||||
r->headers_out.status_line.len = 0;
|
r->headers_out.status_line.len = 0;
|
||||||
}
|
}
|
||||||
@ -499,17 +499,19 @@ int ngx_http_internal_redirect(ngx_http_request_t *r,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* clear the modules contexts */
|
if (r->err_ctx) {
|
||||||
|
|
||||||
|
/* allocate the new modules contexts */
|
||||||
|
|
||||||
if (r->error_page) {
|
|
||||||
r->err_status = r->headers_out.status;
|
|
||||||
r->err_ctx = r->ctx;
|
|
||||||
r->ctx = ngx_pcalloc(r->pool, sizeof(void *) * ngx_http_max_module);
|
r->ctx = ngx_pcalloc(r->pool, sizeof(void *) * ngx_http_max_module);
|
||||||
if (r->ctx == NULL) {
|
if (r->ctx == NULL) {
|
||||||
return NGX_HTTP_INTERNAL_SERVER_ERROR;
|
return NGX_HTTP_INTERNAL_SERVER_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
/* clear the modules contexts */
|
||||||
|
|
||||||
ngx_memzero(r->ctx, sizeof(void *) * ngx_http_max_module);
|
ngx_memzero(r->ctx, sizeof(void *) * ngx_http_max_module);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,16 +232,22 @@ time_t ngx_http_parse_time(char *value, size_t len)
|
|||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* shift new year to 1st March, needed for Gauss's formula */
|
/* shift new year to March 1, needed for Gauss's formula */
|
||||||
|
|
||||||
if (--month <= 0) {
|
if (--month <= 0) {
|
||||||
month += 12;
|
month += 12;
|
||||||
year -= 1;
|
year -= 1;
|
||||||
}
|
}
|
||||||
/* Gauss's formula for Grigorian days from 1 March 1 BC */
|
|
||||||
|
/* Gauss's formula for Grigorian days from 1 March 1 BC */
|
||||||
|
|
||||||
return (365 * year + year / 4 - year / 100 + year / 400
|
return (365 * year + year / 4 - year / 100 + year / 400
|
||||||
+ 367 * month / 12 + day - 31
|
+ 367 * month / 12 + day - 31
|
||||||
/* 719527 days are between 1 March 1 BC and 1 March 1970,
|
/*
|
||||||
31 and 28 days in Jan and Feb 1970 */
|
* 719527 days are between March 1, 1 BC and March 1, 1970,
|
||||||
|
* 31 and 28 days in January and February 1970
|
||||||
|
*/
|
||||||
|
|
||||||
- 719527 + 31 + 28) * 86400 + hour * 3600 + min * 60 + sec;
|
- 719527 + 31 + 28) * 86400 + hour * 3600 + min * 60 + sec;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -205,8 +205,6 @@ struct ngx_http_request_s {
|
|||||||
unsigned bypass_cache:1;
|
unsigned bypass_cache:1;
|
||||||
unsigned no_cache:1;
|
unsigned no_cache:1;
|
||||||
|
|
||||||
unsigned error_page:1;
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
unsigned cachable:1;
|
unsigned cachable:1;
|
||||||
#endif
|
#endif
|
||||||
|
@ -203,11 +203,12 @@ int ngx_http_special_response_handler(ngx_http_request_t *r, int error)
|
|||||||
|
|
||||||
clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
|
clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
|
||||||
|
|
||||||
if (!r->error_page && clcf->error_pages) {
|
if (r->err_ctx == NULL && clcf->error_pages) {
|
||||||
err_page = clcf->error_pages->elts;
|
err_page = clcf->error_pages->elts;
|
||||||
for (i = 0; i < clcf->error_pages->nelts; i++) {
|
for (i = 0; i < clcf->error_pages->nelts; i++) {
|
||||||
if (err_page[i].code == error) {
|
if (err_page[i].code == error) {
|
||||||
r->error_page = 1;
|
r->err_status = error;
|
||||||
|
r->err_ctx = r->ctx;
|
||||||
return ngx_http_internal_redirect(r, &err_page[i].uri, NULL);
|
return ngx_http_internal_redirect(r, &err_page[i].uri, NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
#define SIZE_FMT "%d"
|
#define SIZE_FMT "%d"
|
||||||
#define SIZEX_FMT "%x"
|
#define SIZEX_FMT "%x"
|
||||||
#define PID_FMT "%d"
|
#define PID_FMT "%d"
|
||||||
|
#define TIME_FMT "%lu"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@ typedef uint32_t u_int32_t;
|
|||||||
#define SIZE_FMT "%d"
|
#define SIZE_FMT "%d"
|
||||||
#define SIZEX_FMT "%x"
|
#define SIZEX_FMT "%x"
|
||||||
#define PID_FMT "%ld"
|
#define PID_FMT "%ld"
|
||||||
|
#define TIME_FMT "%lu"
|
||||||
|
|
||||||
|
|
||||||
#ifndef HAVE_SELECT
|
#ifndef HAVE_SELECT
|
||||||
|
@ -5,20 +5,22 @@
|
|||||||
|
|
||||||
void ngx_localtime(ngx_tm_t *tm)
|
void ngx_localtime(ngx_tm_t *tm)
|
||||||
{
|
{
|
||||||
|
#if (HAVE_LOCALTIME_R)
|
||||||
|
|
||||||
localtime_r(&ngx_cached_time, tm);
|
localtime_r(&ngx_cached_time, tm);
|
||||||
|
|
||||||
|
#else
|
||||||
|
ngx_tm_t *t;
|
||||||
|
|
||||||
|
t = localtime(&ngx_cached_time);
|
||||||
|
*tm = *t;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
tm->ngx_tm_mon++;
|
tm->ngx_tm_mon++;
|
||||||
tm->ngx_tm_year += 1900;
|
tm->ngx_tm_year += 1900;
|
||||||
}
|
}
|
||||||
|
|
||||||
u_int ngx_msec(void)
|
|
||||||
{
|
|
||||||
struct timeval tv;
|
|
||||||
|
|
||||||
gettimeofday(&tv, NULL);
|
|
||||||
|
|
||||||
return tv.tv_sec * 1000 + tv.tv_usec / 1000;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -3,9 +3,13 @@
|
|||||||
|
|
||||||
|
|
||||||
#include <ngx_config.h>
|
#include <ngx_config.h>
|
||||||
|
#include <ngx_core.h>
|
||||||
|
|
||||||
|
|
||||||
|
typedef uint64_t ngx_epoch_msec_t;
|
||||||
|
|
||||||
typedef u_int ngx_msec_t;
|
typedef u_int ngx_msec_t;
|
||||||
#define NGX_MAX_MSEC (u_int) -1
|
#define NGX_MAX_MSEC (ngx_msec_t) -1
|
||||||
|
|
||||||
typedef struct tm ngx_tm_t;
|
typedef struct tm ngx_tm_t;
|
||||||
|
|
||||||
@ -17,16 +21,14 @@ typedef struct tm ngx_tm_t;
|
|||||||
#define ngx_tm_year tm_year
|
#define ngx_tm_year tm_year
|
||||||
#define ngx_tm_wday tm_wday
|
#define ngx_tm_wday tm_wday
|
||||||
|
|
||||||
#define ngx_msleep(ms) usleep(ms * 1000)
|
|
||||||
|
|
||||||
void ngx_localtime(ngx_tm_t *tm);
|
void ngx_localtime(ngx_tm_t *tm);
|
||||||
|
|
||||||
ngx_msec_t ngx_msec(void);
|
#define ngx_gettimeofday(tp) gettimeofday(tp, NULL);
|
||||||
|
#define ngx_msleep(ms) usleep(ms * 1000)
|
||||||
|
|
||||||
time_t ngx_time();
|
|
||||||
|
|
||||||
extern time_t ngx_cached_time;
|
extern time_t ngx_cached_time;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* _NGX_TIME_H_INCLUDED_ */
|
#endif /* _NGX_TIME_H_INCLUDED_ */
|
||||||
|
@ -69,8 +69,8 @@ int ngx_file_type(char *filename, ngx_file_info_t *fi);
|
|||||||
|
|
||||||
#define ngx_file_uniq(fi) (*(ngx_file_uniq_t *) &fi.nFileIndexHigh)
|
#define ngx_file_uniq(fi) (*(ngx_file_uniq_t *) &fi.nFileIndexHigh)
|
||||||
|
|
||||||
/* There are 134774 days between 1 Jan 1970 and 1 Jan 1601,
|
|
||||||
11644473600 seconds or 11644473600,000,000,0 100-nanosecond intervals */
|
/* 116444736000000000 is commented in src/os/win32/ngx_time.c */
|
||||||
|
|
||||||
#define ngx_file_mtime(fi) \
|
#define ngx_file_mtime(fi) \
|
||||||
(time_t) (((((unsigned __int64) fi.ftLastWriteTime.dwHighDateTime << 32) \
|
(time_t) (((((unsigned __int64) fi.ftLastWriteTime.dwHighDateTime << 32) \
|
||||||
|
29
src/os/win32/ngx_time.c
Normal file
29
src/os/win32/ngx_time.c
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
|
||||||
|
#include <ngx_config.h>
|
||||||
|
#include <ngx_core.h>
|
||||||
|
|
||||||
|
|
||||||
|
void ngx_gettimeofday(struct timeval *tp)
|
||||||
|
{
|
||||||
|
uint64_t intervals;
|
||||||
|
FILETIME ft;
|
||||||
|
|
||||||
|
GetSystemTimeAsFileTime(&ft);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A file time is a 64-bit value that represents the number
|
||||||
|
* of 100-nanosecond intervals that have elapsed since
|
||||||
|
* 12:00 A.M. January 1, 1601 (UTC).
|
||||||
|
*
|
||||||
|
* Between January 1, 1970 (Epoch) and January 1, 1601 there are
|
||||||
|
* 134744 days,
|
||||||
|
* 11644473600 seconds or
|
||||||
|
* 11644473600,000,000,0 100-nanosecond intervals.
|
||||||
|
*/
|
||||||
|
|
||||||
|
intervals = ((uint64_t) ft.dwHighDateTime << 32) | ft.dwLowDateTime;
|
||||||
|
intervals -= 116444736000000000;
|
||||||
|
|
||||||
|
tp->tv_sec = intervals / 10000000;
|
||||||
|
tp->tv_usec = (intervals % 10000000) / 10;
|
||||||
|
}
|
@ -6,8 +6,10 @@
|
|||||||
#include <ngx_core.h>
|
#include <ngx_core.h>
|
||||||
|
|
||||||
|
|
||||||
typedef unsigned int ngx_msec_t;
|
typedef uint64_t ngx_epoch_msec_t;
|
||||||
#define NGX_MAX_MSEC ~0
|
|
||||||
|
typedef u_int ngx_msec_t;
|
||||||
|
#define NGX_MAX_MSEC (ngx_msec_t) -1
|
||||||
|
|
||||||
|
|
||||||
typedef SYSTEMTIME ngx_tm_t;
|
typedef SYSTEMTIME ngx_tm_t;
|
||||||
@ -23,10 +25,16 @@ typedef FILETIME ngx_mtime_t;
|
|||||||
|
|
||||||
#define ngx_msleep Sleep
|
#define ngx_msleep Sleep
|
||||||
#define ngx_localtime GetLocalTime
|
#define ngx_localtime GetLocalTime
|
||||||
#define ngx_msec GetTickCount
|
|
||||||
|
|
||||||
/* STUB */
|
|
||||||
#define ngx_time() time(NULL)
|
struct timeval {
|
||||||
|
long tv_sec;
|
||||||
|
long tv_usec;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
void ngx_gettimeofday(struct timeval *tp);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* _NGX_TIME_H_INCLUDED_ */
|
#endif /* _NGX_TIME_H_INCLUDED_ */
|
||||||
|
Loading…
Reference in New Issue
Block a user