summaryrefslogtreecommitdiff
path: root/log.c
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2003-05-25 14:38:02 +1000
committerDamien Miller <djm@mindrot.org>2003-05-25 14:38:02 +1000
commitc11fe255ab45b8cf7783cedbcd688b00ed5308aa (patch)
tree77652962b77cf40acd1f800d0745c0f97a4a5df1 /log.c
parent6014578b90a6cad5104b05c4449aec07756be033 (diff)
- (djm) OpenBSD CVS Sync
- djm@cvs.openbsd.org 2003/05/24 09:02:22 [log.c] pass logged data through strnvis; ok markus
Diffstat (limited to 'log.c')
-rw-r--r--log.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/log.c b/log.c
index 5a28438f9..fb89a965b 100644
--- a/log.c
+++ b/log.c
@@ -34,12 +34,13 @@
34 */ 34 */
35 35
36#include "includes.h" 36#include "includes.h"
37RCSID("$OpenBSD: log.c,v 1.27 2003/05/18 23:22:01 deraadt Exp $"); 37RCSID("$OpenBSD: log.c,v 1.28 2003/05/24 09:02:22 djm Exp $");
38 38
39#include "log.h" 39#include "log.h"
40#include "xmalloc.h" 40#include "xmalloc.h"
41 41
42#include <syslog.h> 42#include <syslog.h>
43#include <vis.h>
43 44
44static LogLevel log_level = SYSLOG_LEVEL_INFO; 45static LogLevel log_level = SYSLOG_LEVEL_INFO;
45static int log_on_stderr = 1; 46static int log_on_stderr = 1;
@@ -390,16 +391,14 @@ do_log(LogLevel level, const char *fmt, va_list args)
390 } else { 391 } else {
391 vsnprintf(msgbuf, sizeof(msgbuf), fmt, args); 392 vsnprintf(msgbuf, sizeof(msgbuf), fmt, args);
392 } 393 }
393 /* Escape magic chars in output. */
394 strnvis(fmtbuf, msgbuf, sizeof(fmtbuf), VIS_SAFE|VIS_OCTAL); 394 strnvis(fmtbuf, msgbuf, sizeof(fmtbuf), VIS_SAFE|VIS_OCTAL);
395
396 if (log_on_stderr) { 395 if (log_on_stderr) {
397 snprintf(fmtbuf, sizeof fmtbuf, "%s\r\n", msgbuf); 396 snprintf(msgbuf, sizeof msgbuf, "%s\r\n", fmtbuf);
398 write(STDERR_FILENO, fmtbuf, strlen(fmtbuf)); 397 write(STDERR_FILENO, msgbuf, strlen(msgbuf));
399 } else { 398 } else {
400#ifdef OPENLOG_R 399#ifdef OPENLOG_R
401 openlog_r(argv0 ? argv0 : __progname, LOG_PID, log_facility, &sdata); 400 openlog_r(argv0 ? argv0 : __progname, LOG_PID, log_facility, &sdata);
402 syslog_r(pri, &sdata, "%.500s", msgbuf); 401 syslog_r(pri, &sdata, "%.500s", fmtbuf);
403 closelog_r(&sdata); 402 closelog_r(&sdata);
404#else 403#else
405 openlog(argv0 ? argv0 : __progname, LOG_PID, log_facility); 404 openlog(argv0 ? argv0 : __progname, LOG_PID, log_facility);