[dovecot-cvs] dovecot/src/lib failures.c,1.13,1.14
cras at procontrol.fi
cras at procontrol.fi
Sun Dec 22 10:03:05 EET 2002
- Previous message: [dovecot-cvs] dovecot/src/auth auth-digest-md5.c,1.12,1.13
- Next message: [dovecot-cvs] dovecot/src/auth auth-digest-md5.c,1.13,1.14 auth.c,1.5,1.6 auth.h,1.3,1.4 userinfo-passwd-file.c,1.19,1.20
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /home/cvs/dovecot/src/lib
In directory danu:/tmp/cvs-serv20891/lib
Modified Files:
failures.c
Log Message:
info log was broken
Index: failures.c
===================================================================
RCS file: /home/cvs/dovecot/src/lib/failures.c,v
retrieving revision 1.13
retrieving revision 1.14
diff -u -d -r1.13 -r1.14
--- failures.c 22 Dec 2002 07:06:16 -0000 1.13
+++ failures.c 22 Dec 2002 08:03:03 -0000 1.14
@@ -79,8 +79,8 @@
}
}
-static void default_handler(const char *prefix, const char *format,
- va_list args)
+static void default_handler(const char *prefix, FILE *f,
+ const char *format, va_list args)
{
static int recursed = 0;
int old_errno = errno;
@@ -93,8 +93,12 @@
recursed++;
- if (log_fd == NULL)
- log_fd = stderr;
+ if (f == NULL) {
+ f = stderr;
+
+ if (log_fd == NULL)
+ log_fd = stderr;
+ }
t_push();
if (recursed == 2) {
@@ -103,19 +107,19 @@
/* make sure there's no %n in there */
(void)printf_string_upper_bound(format, args);
- vfprintf(log_fd, format, args);
- fputs(" - recursed!", log_fd);
+ vfprintf(f, format, args);
+ fputs(" - recursed!", f);
} else {
- write_prefix(log_fd);
+ write_prefix(f);
- fputs(prefix, log_fd);
+ fputs(prefix, f);
format = printf_string_fix_format(format);
/* make sure there's no %n in there */
(void)printf_string_upper_bound(format, args);
- vfprintf(log_fd, format, args);
+ vfprintf(f, format, args);
}
- fputc('\n', log_fd);
+ fputc('\n', f);
t_pop();
@@ -125,13 +129,13 @@
static void default_panic_handler(const char *format, va_list args)
{
- default_handler("Panic: ", format, args);
+ default_handler("Panic: ", log_fd, format, args);
abort();
}
static void default_fatal_handler(int status, const char *format, va_list args)
{
- default_handler("Fatal: ", format, args);
+ default_handler("Fatal: ", log_fd, format, args);
if (fflush(log_fd) < 0 && status == FATAL_DEFAULT)
status = FATAL_LOGWRITE;
@@ -143,7 +147,7 @@
{
int old_errno = errno;
- default_handler("Error: ", format, args);
+ default_handler("Error: ", log_fd, format, args);
if (fflush(log_fd) < 0)
exit(FATAL_LOGWRITE);
@@ -155,7 +159,7 @@
{
int old_errno = errno;
- default_handler("Warning: ", format, args);
+ default_handler("Warning: ", log_fd, format, args);
if (fflush(log_fd) < 0)
exit(FATAL_LOGWRITE);
@@ -167,9 +171,9 @@
{
int old_errno = errno;
- default_handler("Info: ", format, args);
+ default_handler("Info: ", log_info_fd, format, args);
- if (fflush(log_fd) < 0)
+ if (fflush(log_info_fd) < 0)
exit(FATAL_LOGWRITE);
errno = old_errno;
@@ -342,10 +346,9 @@
open_log_file(&log_fd, path);
- if (log_info_fd != NULL && log_info_fd != stderr) {
+ if (log_info_fd != NULL && log_info_fd != stderr)
(void)fclose(log_info_fd);
- log_info_fd = log_fd;
- }
+ log_info_fd = log_fd;
}
void i_set_info_file(const char *path)
- Previous message: [dovecot-cvs] dovecot/src/auth auth-digest-md5.c,1.12,1.13
- Next message: [dovecot-cvs] dovecot/src/auth auth-digest-md5.c,1.13,1.14 auth.c,1.5,1.6 auth.h,1.3,1.4 userinfo-passwd-file.c,1.19,1.20
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the dovecot-cvs
mailing list