Re: Похоже на багу в date_local в ssi
Igor Sysoev
igor на sysoev.ru
Вт Мар 30 20:16:18 MSD 2010
On Fri, Feb 19, 2010 at 04:02:34PM +0300, Maxim Dounin wrote:
> On Fri, Feb 19, 2010 at 03:13:24PM +0300, Oleg Motienko wrote:
>
> > Привет всем.
> >
> > В ssi вот такая конструкция выдаёт время на 180 секунд вперед.
> > <!--# config timefmt="%s" --><!--# echo var="date_local" -->
> >
> > А такая - верное.
> > <!--# config timefmt="%s" --><!--# echo var="date_gmt" -->
> >
> > Почему-то возникает предположение, что 180 - это моя таймзона (GMT +3)* 60.
> > Только, почему-то 180 секунд, а не минут.
>
> Патч.
>
> Maxim Dounin
> # HG changeset patch
> # User Maxim Dounin <mdounin at mdounin.ru>
> # Date 1266584382 -10800
> # Node ID 843f000d1b37757c0753853d671c94192dcb8dcc
> # Parent 9009f1982e02d6f0614d4ddeae0672042442775a
> SSI: time format "%s" means seconds since the Epoch in UTC
>
> Adding local timezone offset is wrong here at all.
>
> diff --git a/src/http/modules/ngx_http_ssi_filter_module.c b/src/http/modules/ngx_http_ssi_filter_module.c
> --- a/src/http/modules/ngx_http_ssi_filter_module.c
> +++ b/src/http/modules/ngx_http_ssi_filter_module.c
> @@ -2615,8 +2615,7 @@ ngx_http_ssi_date_gmt_local_variable(ngx
> return NGX_ERROR;
> }
>
> - v->len = ngx_sprintf(v->data, "%T", tp->sec + (gmt ? 0 : tp->gmtoff))
> - - v->data;
> + v->len = ngx_sprintf(v->data, "%T", tp->sec) - v->data;
>
> return NGX_OK;
> }
С этим strftime(%s) не просто: под FreeBSD 8.0 такая программка
----------
#include <time.h>
#include <sys/time.h>
#include <stdio.h>
main()
{
time_t t;
struct timeval tv;
struct tm *tm;
char buf[20];
gettimeofday(&tv, NULL);
printf("GToD: %d\n", tv.tv_sec);
t = time(NULL);
printf("TIME: %d\n", t);
tm = gmtime(&t);
strftime(buf, 20, "GMTM: %s", tm);
printf("%s\n", buf);
tm = localtime(&t);
strftime(buf, 20, "LOCT: %s", tm);
printf("%s\n", buf);
}
----------
выдаёт
GToD: 1269965127
TIME: 1269965127
GMTM: 1269954327
LOCT: 1269965127
При том, что date и date +%s выдают соответственно
Tue Mar 30 20:05:27 MSD 2010
1269965127
То есть, strftime(%s) для GMT выдаёт время на 3 часа меньше UTC (даже не 4).
--
Игорь Сысоев
http://sysoev.ru
Подробная информация о списке рассылки nginx-ru