diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 2002-12-23 00:09:53 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 2002-12-23 00:09:53 +0000 |
commit | 547181efe216860231db2838f9f37584665e969f (patch) | |
tree | 4fbd70ea50976476dc22c56e397f6dbbbd79a9bc | |
parent | 731343fd3119f24ca29b40e8babfae1fdf38c887 (diff) |
Display offending line number in error messages.
Based on a patch from Sam Smith.
-rw-r--r-- | usr.bin/newsyslog/newsyslog.c | 60 |
1 files changed, 35 insertions, 25 deletions
diff --git a/usr.bin/newsyslog/newsyslog.c b/usr.bin/newsyslog/newsyslog.c index f67ce7de48f..8e839972d08 100644 --- a/usr.bin/newsyslog/newsyslog.c +++ b/usr.bin/newsyslog/newsyslog.c @@ -1,4 +1,4 @@ -/* $OpenBSD: newsyslog.c,v 1.59 2002/11/27 22:56:16 millert Exp $ */ +/* $OpenBSD: newsyslog.c,v 1.60 2002/12/23 00:09:52 millert Exp $ */ /* * Copyright (c) 1999, 2002 Todd C. Miller <Todd.Miller@courtesan.com> @@ -86,7 +86,7 @@ */ #ifndef lint -static const char rcsid[] = "$OpenBSD: newsyslog.c,v 1.59 2002/11/27 22:56:16 millert Exp $"; +static const char rcsid[] = "$OpenBSD: newsyslog.c,v 1.60 2002/12/23 00:09:52 millert Exp $"; #endif /* not lint */ #ifndef CONF @@ -176,7 +176,7 @@ void do_entry(struct conf_entry *); void parse_args(int, char **); void usage(void); struct conf_entry *parse_file(int *); -char *missing_field(char *, char *); +char *missing_field(char *, char *, int); void dotrim(struct conf_entry *); int log_trim(char *); void compress_log(struct conf_entry *); @@ -226,10 +226,10 @@ main(int argc, char **argv) break; } if (q == NULL) - warnx("%s is not listed in %s", *av, conf); + warnx("%s: %s not found", conf, *av); } if (x == NULL) - errx(1, "no specified log files found in %s", conf); + errx(1, "%s: no specified log files", conf); y->next = NULL; p = x; } @@ -471,6 +471,7 @@ parse_file(int *nentries) { FILE *f; char line[BUFSIZ], *parse, *q, *errline, *group, *tmp; + int lineno; struct conf_entry *first = NULL; struct conf_entry *working = NULL; struct passwd *pwd; @@ -483,7 +484,7 @@ parse_file(int *nentries) err(1, "can't open %s", conf); *nentries = 0; - while (fgets(line, sizeof(line), f)) { + for (lineno = 0; fgets(line, sizeof(line), f); lineno++) { tmp = sob(line); if (*tmp == '\0' || *tmp == '#') continue; @@ -503,7 +504,7 @@ parse_file(int *nentries) working = working->next; } - q = parse = missing_field(sob(line), errline); + q = parse = missing_field(sob(line), errline, lineno); *(parse = son(line)) = '\0'; working->log = strdup(q); if (working->log == NULL) @@ -512,14 +513,15 @@ parse_file(int *nentries) if ((working->logbase = strrchr(working->log, '/')) != NULL) working->logbase++; - q = parse = missing_field(sob(++parse), errline); + q = parse = missing_field(sob(++parse), errline, lineno); *(parse = son(parse)) = '\0'; if ((group = strchr(q, '.')) != NULL) { *group++ = '\0'; if (*q) { if (!(isnumberstr(q))) { if ((pwd = getpwnam(q)) == NULL) - errx(1, "Error in config file; unknown user: %s", q); + errx(1, "%s:%d: unknown user: %s", + conf, lineno, q); working->uid = pwd->pw_uid; } else working->uid = atoi(q); @@ -530,14 +532,16 @@ parse_file(int *nentries) if (*q) { if (!(isnumberstr(q))) { if ((grp = getgrnam(q)) == NULL) - errx(1, "Error in config file; unknown group: %s", q); + + errx(1, "%s:%d: unknown group: %s", + conf, lineno, q); working->gid = grp->gr_gid; } else working->gid = atoi(q); } else working->gid = (gid_t)-1; - q = parse = missing_field(sob(++parse), errline); + q = parse = missing_field(sob(++parse), errline, lineno); *(parse = son(parse)) = '\0'; } else { working->uid = (uid_t)-1; @@ -545,21 +549,21 @@ parse_file(int *nentries) } if (!sscanf(q, "%o", &working->permissions)) - errx(1, "Error in config file; bad permissions: %s", q); + errx(1, "%s:%d: bad permissions: %s", conf, lineno, q); - q = parse = missing_field(sob(++parse), errline); + q = parse = missing_field(sob(++parse), errline, lineno); *(parse = son(parse)) = '\0'; if (!sscanf(q, "%d", &working->numlogs) || working->numlogs < 0) - errx(1, "Error in config file; bad number: %s", q); + errx(1, "%s:%d: bad number: %s", conf, lineno, q); - q = parse = missing_field(sob(++parse), errline); + q = parse = missing_field(sob(++parse), errline, lineno); *(parse = son(parse)) = '\0'; if (isdigit(*q)) working->size = atoi(q) * 1024; else working->size = -1; - q = parse = missing_field(sob(++parse), errline); + q = parse = missing_field(sob(++parse), errline, lineno); *(parse = son(parse)) = '\0'; if (isdigit(*q)) working->hours = atoi(q); @@ -590,7 +594,8 @@ parse_file(int *nentries) working->flags |= CE_FOLLOW; break; default: - errx(1, "Illegal flag in config file: %c", *q); + errx(1, "%s:%d: illegal flag: `%c'", + conf, lineno, *q); break; } q++; @@ -618,7 +623,8 @@ parse_file(int *nentries) if (*q == '/') { *(parse = son(parse)) = '\0'; if (strlen(q) >= MAXPATHLEN) - errx(1, "%s: pathname too long", q); + errx(1, "%s:%d: pathname too long: %s", + conf, lineno, q); working->pidfile = strdup(q); if (working->pidfile == NULL) err(1, "strdup"); @@ -642,9 +648,11 @@ parse_file(int *nentries) } } if (i == NSIG) - errx(1, "unknown signal: %s", q); + errx(1, "%s:%d: unknown signal: %s", + conf, lineno, q); } else - errx(1, "unrecognized field: %s", q); + errx(1, "%s:%d: unrecognized field: %s", + conf, lineno, q); } free(errline); @@ -676,12 +684,14 @@ parse_file(int *nentries) if (snprintf(line, sizeof(line), "%s/%s.%d%s", working->backdir, working->logbase, working->numlogs, COMPRESS_POSTFIX) >= MAXPATHLEN) - errx(1, "%s: pathname too long", working->log); + errx(1, "%s:%d: pathname too long: %s", + conf, lineno, q); } else { if (snprintf(line, sizeof(line), "%s.%d%s", working->log, working->numlogs, COMPRESS_POSTFIX) >= MAXPATHLEN) - errx(1, "%s: pathname too long", working->log); + errx(1, "%s:%d: pathname too long: %s", + conf, lineno, working->log); } } if (working) @@ -691,10 +701,10 @@ parse_file(int *nentries) } char * -missing_field(char *p, char *errline) +missing_field(char *p, char *errline, int lineno) { - if (!p || !*p) { - warnx("Missing field in config file line:"); + if (p == NULL || *p == '\0') { + warnx("%s:%d: missing field", conf, lineno); fputs(errline, stderr); exit(1); } |