X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/177f020f122827214159c46dcfe7ded1e3c8d1c3..9f1e781a5c2beb9df943c832300a3f5bee1e4ed3:/sbr/readconfig.c?ds=sidebyside diff --git a/sbr/readconfig.c b/sbr/readconfig.c index 21b40c73..5a850b04 100644 --- a/sbr/readconfig.c +++ b/sbr/readconfig.c @@ -6,8 +6,9 @@ * complete copyright information. */ -#include -#include +#include "h/mh.h" +#include "error.h" +#include "h/utils.h" struct procstr { char *procname; @@ -44,19 +45,20 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) { int state; char *cp; - char name[NAMESZ], field[BUFSIZ]; + char name[NAMESZ], field[NMH_BUFSIZ]; struct node *np; struct procstr *ps; - m_getfld_state_t gstate = 0; + m_getfld_state_t gstate; if (npp == NULL && (npp = opp) == NULL) { inform("bug: readconfig called but pump not primed, continuing..."); return; } + gstate = m_getfld_state_init(ib); for (;;) { int fieldsz = sizeof field; - switch (state = m_getfld (&gstate, name, field, &fieldsz, ib)) { + switch (state = m_getfld2(&gstate, name, field, &fieldsz)) { case FLD: case FLDPLUS: NEW(np); @@ -67,7 +69,7 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) cp = mh_xstrdup(field); while (state == FLDPLUS) { fieldsz = sizeof field; - state = m_getfld (&gstate, name, field, &fieldsz, ib); + state = m_getfld2(&gstate, name, field, &fieldsz); cp = add (field, cp); } np->n_field = trimcpy (cp); @@ -89,13 +91,13 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) continue; case BODY: - adios (NULL, "no blank lines are permitted in %s", file); + die("no blank lines are permitted in %s", file); case FILEEOF: break; default: - adios (NULL, "%s is poorly formatted", file); + die("%s is poorly formatted", file); } break; } @@ -121,7 +123,7 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) if (opp == NULL) { /* Check for duplicated non-null profile entries. Except allow multiple profile entries named "#", because that's - what the mh-profile man page suggests using for comments. + what mh-profile(5) suggests using for comments. Only do this check on the very first call from context_read(), when opp is NULL. That way, entries in @@ -154,7 +156,8 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) void -add_profile_entry (const char *key, const char *value) { +add_profile_entry (const char *key, const char *value) +{ struct node *newnode; /* This inserts the new node at the beginning of m_defs because