@ -208,4 +208,14 @@
#include <lighttpd/sys-process.h>
#include <lighttpd/sys-socket.h>
#if( 2 < __GNUC__ )
#pragma GCC poison strtok asctime ctime tmpnam strerror
#ifdef HAVE_LOCALTIME_R
#pragma GCC poison localtime
#endif
#ifdef HAVE_GMTIME_R
#pragma GCC poison gmtime
@ -48,8 +48,14 @@ void li_log_write(liServer *srv, liLogLevel log_level, guint flags, const gchar
if (cur_ts != srv->log.last_ts) {
gsize s;
struct tm tm;
g_string_set_size(log_ts, 255);
s = strftime(log_ts->str, log_ts->allocated_len, "%Y-%m-%d %H:%M:%S %Z: ", localtime_r(&cur_ts, &tm));
#else
s = strftime(log_ts->str, log_ts->allocated_len, "%Y-%m-%d %H:%M:%S %Z: ", localtime(&cur_ts));
g_string_set_size(log_ts, s);
@ -106,9 +106,15 @@ gboolean li_log_write_(liServer *srv, liVRequest *vr, liLogLevel log_level, guin
if (cur_ts != ts->last_ts) {
g_string_set_size(ts->cached, 255);
s = strftime(ts->cached->str, ts->cached->allocated_len,
ts->format->str, localtime_r(&cur_ts, &tm));
ts->format->str, localtime(&cur_ts));
g_string_set_size(ts->cached, s);
@ -414,10 +414,16 @@ GString *li_server_current_timestamp() {
if (cur_ts != *last_ts) {
g_string_set_size(ts_str, 255);
s = strftime(ts_str->str, ts_str->allocated_len,
"%a, %d %b %Y %H:%M:%S GMT", gmtime_r(&cur_ts, &tm));
"%a, %d %b %Y %H:%M:%S GMT", gmtime(&cur_ts));
g_string_set_size(ts_str, s);
*last_ts = cur_ts;
}