X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=sbr%2Freadconfig.c;h=0f38fdfb2a4b01f2efc3bfc5add8ceff553735d8;hb=d4850ff231bec8513dcd106bdb93bc61d179d8f6;hp=2a6801920be7e3c736a428570577c266fbc21877;hpb=5dd6771b28c257af405d7248639ed0e3bcdce38b;p=mmh diff --git a/sbr/readconfig.c b/sbr/readconfig.c index 2a68019..0f38fdf 100644 --- a/sbr/readconfig.c +++ b/sbr/readconfig.c @@ -20,8 +20,8 @@ static struct procstr procs[] = { { "context", &context }, { "mh-sequences", &mh_seq }, { "buildmimeproc", &buildmimeproc }, - { "faceproc", &faceproc }, { "fileproc", &fileproc }, + { "formatproc", &formatproc }, { "incproc", &incproc }, { "installproc", &installproc }, { "lproc", &lproc }, @@ -31,7 +31,6 @@ static struct procstr procs[] = { { "mshproc", &mshproc }, { "packproc", &packproc }, { "postproc", &postproc }, - { "rmfproc", &rmfproc }, { "rmmproc", &rmmproc }, { "sendproc", &sendproc }, { "showmimeproc", &showmimeproc }, @@ -107,5 +106,30 @@ readconfig (struct node **npp, FILE *ib, char *file, int ctx) break; } + if (opp == NULL) { + /* Check for duplicated non-null profile entries. Also ignore + profile entries that are just "#", because that's what the + mh-profile man page suggests using for comments. Only do + this check on the very first call from context_read(), when + opp is + NULL. */ + + 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)) { + struct node *np2; + for (np2 = np->n_next; np2; np2 = np2->n_next) { + if (! mh_strcasecmp (np->n_name, np2->n_name)) { + printf ("%d\n", strlen (np->n_name)); + admonish (NULL, "multiple \"%s\" profile components " + "in %s, ignoring \"%s\"", + np->n_name, defpath, np2->n_field); + } + } + } + } + } + opp = npp; }