X-Git-Url: https://git.ozlabs.org/?p=ppp.git;a=blobdiff_plain;f=pppd%2Futils.c;h=b176fbb4da6c6618edbbc730ba3291698da5289a;hp=131429d59a7081f3efb5e5daaeaed036d3a3b025;hb=37a8acc7ee2527693d0c8ba82b2eaea249abde34;hpb=1924cd095160dc3fdd6e21a3506e5e5d225a650c diff --git a/pppd/utils.c b/pppd/utils.c index 131429d..b176fbb 100644 --- a/pppd/utils.c +++ b/pppd/utils.c @@ -16,9 +16,8 @@ * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ -#ifndef lint -static char rcsid[] = "$Id: utils.c,v 1.6 1999/06/24 00:17:48 paulus Exp $"; -#endif + +#define RCSID "$Id: utils.c,v 1.11 2001/03/08 05:11:16 paulus Exp $" #include #include @@ -46,12 +45,14 @@ static char rcsid[] = "$Id: utils.c,v 1.6 1999/06/24 00:17:48 paulus Exp $"; #include "pppd.h" +static const char rcsid[] = RCSID; + #if defined(SUNOS4) extern char *strerror(); #endif -static void pr_log __P((void *, char *, ...)); static void logit __P((int, char *, va_list)); +static void log_write __P((int, char *)); static void vslp_printer __P((void *, char *, ...)); static void format_packet __P((u_char *, int, void (*) (void *, char *, ...), void *)); @@ -114,7 +115,7 @@ slprintf __V((char *buf, int buflen, char *fmt, ...)) va_list args; int n; -#if __STDC__ +#if defined(__STDC__) va_start(args, fmt); #else char *buf; @@ -388,7 +389,7 @@ vslp_printer __V((void *arg, char *fmt, ...)) va_list pvar; struct buffer_info *bi; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else void *arg; @@ -406,13 +407,11 @@ vslp_printer __V((void *arg, char *fmt, ...)) bi->len -= n; } +#ifdef unused /* * log_packet - format a packet and log it. */ -char line[256]; /* line to be logged accumulated here */ -char *linep; - void log_packet(p, len, prefix, level) u_char *p; @@ -420,12 +419,11 @@ log_packet(p, len, prefix, level) char *prefix; int level; { - strlcpy(line, prefix, sizeof(line)); - linep = line + strlen(line); - format_packet(p, len, pr_log, NULL); - if (linep != line) - syslog(level, "%s", line); + init_pr_log(prefix, level); + format_packet(p, len, pr_log, &level); + end_pr_log(); } +#endif /* unused */ /* * format_packet - make a readable representation of a packet, @@ -477,32 +475,91 @@ format_packet(p, len, printer, arg) printer(arg, "%.*B", len, p); } -static void +/* + * init_pr_log, end_pr_log - initialize and finish use of pr_log. + */ + +static char line[256]; /* line to be logged accumulated here */ +static char *linep; /* current pointer within line */ +static int llevel; /* level for logging */ + +void +init_pr_log(prefix, level) + char *prefix; + int level; +{ + linep = line; + if (prefix != NULL) { + strlcpy(line, prefix, sizeof(line)); + linep = line + strlen(line); + } + llevel = level; +} + +void +end_pr_log() +{ + if (linep != line) { + *linep = 0; + log_write(llevel, line); + } +} + +/* + * pr_log - printer routine for outputting to syslog + */ +void pr_log __V((void *arg, char *fmt, ...)) { - int n; - va_list pvar; - char buf[256]; + int l, n; + va_list pvar; + char *p, *eol; + char buf[256]; -#if __STDC__ - va_start(pvar, fmt); +#if defined(__STDC__) + va_start(pvar, fmt); #else - void *arg; - char *fmt; - va_start(pvar); - arg = va_arg(pvar, void *); - fmt = va_arg(pvar, char *); + void *arg; + char *fmt; + va_start(pvar); + arg = va_arg(pvar, void *); + fmt = va_arg(pvar, char *); #endif - n = vslprintf(buf, sizeof(buf), fmt, pvar); - va_end(pvar); + n = vslprintf(buf, sizeof(buf), fmt, pvar); + va_end(pvar); + + p = buf; + eol = strchr(buf, '\n'); + if (linep != line) { + l = (eol == NULL)? n: eol - buf; + if (linep + l < line + sizeof(line)) { + if (l > 0) { + memcpy(linep, buf, l); + linep += l; + } + if (eol == NULL) + return; + p = eol + 1; + eol = strchr(p, '\n'); + } + *linep = 0; + log_write(llevel, line); + linep = line; + } - if (linep + n + 1 > line + sizeof(line)) { - syslog(LOG_DEBUG, "%s", line); - linep = line; - } - strlcpy(linep, buf, line + sizeof(line) - linep); - linep += n; + while (eol != NULL) { + *eol = 0; + log_write(llevel, p); + p = eol + 1; + } + + /* assumes sizeof(buf) <= sizeof(line) */ + l = buf + n - p; + if (l > 0) { + memcpy(line, p, n); + linep = line + l; + } } /* @@ -554,14 +611,25 @@ logit(level, fmt, args) va_list args; { int n; - char buf[256]; + char buf[1024]; n = vslprintf(buf, sizeof(buf), fmt, args); + log_write(level, buf); +} + +static void +log_write(level, buf) + int level; + char *buf; +{ syslog(level, "%s", buf); if (log_to_fd >= 0 && (level != LOG_DEBUG || debug)) { - if (buf[n-1] != '\n') - buf[n++] = '\n'; - if (write(log_to_fd, buf, n) != n) + int n = strlen(buf); + + if (n > 0 && buf[n-1] == '\n') + --n; + if (write(log_to_fd, buf, n) != n + || write(log_to_fd, "\n", 1) != 1) log_to_fd = -1; } } @@ -574,7 +642,7 @@ fatal __V((char *fmt, ...)) { va_list pvar; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else char *fmt; @@ -596,7 +664,7 @@ error __V((char *fmt, ...)) { va_list pvar; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else char *fmt; @@ -616,7 +684,7 @@ warn __V((char *fmt, ...)) { va_list pvar; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else char *fmt; @@ -636,7 +704,7 @@ notice __V((char *fmt, ...)) { va_list pvar; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else char *fmt; @@ -656,7 +724,7 @@ info __V((char *fmt, ...)) { va_list pvar; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else char *fmt; @@ -676,7 +744,7 @@ dbglog __V((char *fmt, ...)) { va_list pvar; -#if __STDC__ +#if defined(__STDC__) va_start(pvar, fmt); #else char *fmt;