1 --- a/src/screen.c Fri Jan 25 18:46:56 2008 +0200
2 +++ b/src/screen.c Sat Jan 26 01:28:53 2008 +0200
3 @@ -228,10 +228,29 @@ static void
5 flag_vputf(DCDisplayFlag flag, const char *format, va_list args)
8 + if (log_fh != NULL && log_flags & flag) {
10 + time_t now = time(NULL);
11 + struct tm _tm = {0};
14 - //va_copy(args2, args);
15 + if (NULL != localtime_r(&now, &_tm) && 0 != strftime(c_time, 1023, "%d.%m.%Y %H:%M:%S", &_tm)) {
16 + fprintf(log_fh, "%s ", c_time);
19 + // args would become undefined after xvasprintf() call, so make a copy
20 + // of args to use it later below.
21 + va_copy(args_dup, args);
22 + char* msg = xvasprintf(format, args_dup);
25 + char* log_msg = main_to_log_string(msg);
27 + fprintf(log_fh, log_msg);
32 if (display_flags & flag) {
33 if (screen_state == SCREEN_SUSPENDED) {
34 ptrv_append(suspend_msgs, xvasprintf(format, args));
35 @@ -243,21 +262,6 @@ flag_vputf(DCDisplayFlag flag, const cha
36 vprintf(format, args);
40 - if (log_fh != NULL && log_flags & flag) {
42 - time_t now = time(NULL);
43 - struct tm _tm = {0};
44 - if (NULL != localtime_r(&now, &_tm) && 0 != strftime(c_time, 1023, "%d.%m.%Y %H:%M:%S", &_tm)) {
45 - fprintf(log_fh, "%s ", c_time);
47 - char* msg = xvasprintf(format, args);
49 - char* log_msg = main_to_log_string(msg);
51 - fprintf(log_fh, log_msg);