view src/os/unix/ngx_time.c @ 60:df7d3fff122b NGINX_0_1_30

nginx 0.1.30 *) Bugfix: the worker process may got caught in an endless loop if the SSI was used. *) Bugfix: the response encrypted by SSL may not transferred complete. *) Bugfix: if the length of the response part received at once from proxied or FastCGI server was equal to 500, then nginx returns the 500 response code; in proxy mode the bug appeared in 0.1.29 only. *) Bugfix: nginx did not consider the directives with 8 or 9 parameters as invalid. *) Feature: the "return" directive can return the 204 response code. *) Feature: the "ignore_invalid_headers" directive.
author Igor Sysoev <http://sysoev.ru>
date Sat, 14 May 2005 00:00:00 +0400
parents b55cbf18157e
children 818201e5a553
line wrap: on
line source


/*
 * Copyright (C) Igor Sysoev
 */


#include <ngx_config.h>
#include <ngx_core.h>


void ngx_localtime(ngx_tm_t *tm)
{
#if (NGX_HAVE_LOCALTIME_R)
    time_t     now;

    now = ngx_time();
    localtime_r(&now, tm);

#else
    time_t     now;
    ngx_tm_t  *t;

    now = ngx_time();
    t = localtime(&now);
    *tm = *t;

#endif

    tm->ngx_tm_mon++;
    tm->ngx_tm_year += 1900;
}


void ngx_libc_localtime(struct tm *tm)
{
#if (NGX_HAVE_LOCALTIME_R)
    time_t      now;

    now = ngx_time();
    localtime_r(&now, tm);

#else
    time_t      now;
    struct tm  *t;

    now = ngx_time();
    t = localtime(&now);
    *tm = *t;

#endif
}


void ngx_libc_gmtime(struct tm *tm)
{
#if (NGX_HAVE_LOCALTIME_R)
    time_t      now;

    now = ngx_time();
    gmtime_r(&now, tm);

#else
    time_t      now;
    struct tm  *t;

    now = ngx_time();
    t = gmtime(&now);
    *tm = *t;

#endif
}