X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/b9e0388a118e84f002ae0da6c7a31bdbd89a73bb..4ac978448:/sbr/readconfig.c?ds=sidebyside diff --git a/sbr/readconfig.c b/sbr/readconfig.c index 5d116893..5b72113c 100644 --- a/sbr/readconfig.c +++ b/sbr/readconfig.c @@ -44,11 +44,11 @@ static struct node **opp = NULL; void readconfig (struct node **npp, FILE *ib, const char *file, int ctx) { - register int state; - register char *cp; + int state; + char *cp; char name[NAMESZ], field[BUFSIZ]; - register struct node *np; - register struct procstr *ps; + struct node *np; + struct procstr *ps; m_getfld_state_t gstate = 0; if (npp == NULL && (npp = opp) == NULL) { @@ -61,12 +61,12 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) switch (state = m_getfld (&gstate, name, field, &fieldsz, ib)) { case FLD: case FLDPLUS: - np = (struct node *) mh_xmalloc (sizeof(*np)); + NEW(np); *npp = np; *(npp = &np->n_next) = NULL; - np->n_name = getcpy (name); + np->n_name = mh_xstrdup(name); if (state == FLDPLUS) { - cp = getcpy (field); + cp = mh_xstrdup(field); while (state == FLDPLUS) { fieldsz = sizeof field; state = m_getfld (&gstate, name, field, &fieldsz, ib); @@ -138,7 +138,7 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) for (np = m_defs; np; np = np->n_next) { /* Yes, this is O(N^2). The profile should be small enough so that's not a performance problem. */ - if (strlen (np->n_name) > 0 && strcmp ("#", np->n_name)) { + if (*np->n_name && strcmp("#", np->n_name)) { struct node *np2; for (np2 = np->n_next; np2; np2 = np2->n_next) { if (! strcasecmp (np->n_name, np2->n_name)) { @@ -157,11 +157,12 @@ readconfig (struct node **npp, FILE *ib, const char *file, int ctx) void add_profile_entry (const char *key, const char *value) { - struct node *newnode = (struct node *) mh_xmalloc (sizeof *newnode); + struct node *newnode; /* This inserts the new node at the beginning of m_defs because that doesn't require traversing it or checking to see if it's empty. */ + NEW(newnode); newnode->n_name = getcpy (key); newnode->n_field = getcpy (value); newnode->n_context = 0;