]> git.cameronkatri.com Git - mandoc.git/blobdiff - man_validate.c
Clean up warnings related to macros and nesting.
[mandoc.git] / man_validate.c
index 647dbcca3ba075dba04180c17d0edfc31fd9ac71..61f8ef811a4fefd9dde18e72d3e36d31ac419375 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: man_validate.c,v 1.89 2014/03/23 11:25:26 schwarze Exp $ */
+/*     $Id: man_validate.c,v 1.96 2014/07/02 11:43:20 schwarze Exp $ */
 /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010, 2012, 2013, 2014 Ingo Schwarze <schwarze@openbsd.org>
 /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010, 2012, 2013, 2014 Ingo Schwarze <schwarze@openbsd.org>
@@ -124,6 +124,7 @@ static      const struct man_valid man_valids[MAN_MAX] = {
        { NULL, posts_fi }, /* EE */
        { NULL, posts_ur }, /* UR */
        { NULL, NULL }, /* UE */
        { NULL, posts_fi }, /* EE */
        { NULL, posts_ur }, /* UR */
        { NULL, NULL }, /* UE */
+       { NULL, NULL }, /* ll */
 };
 
 
 };
 
 
@@ -133,13 +134,13 @@ man_valid_pre(struct man *man, struct man_node *n)
        v_check         *cp;
 
        switch (n->type) {
        v_check         *cp;
 
        switch (n->type) {
-       case (MAN_TEXT):
+       case MAN_TEXT:
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case (MAN_ROOT):
+       case MAN_ROOT:
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case (MAN_EQN):
+       case MAN_EQN:
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case (MAN_TBL):
+       case MAN_TBL:
                return(1);
        default:
                break;
                return(1);
        default:
                break;
@@ -148,12 +149,11 @@ man_valid_pre(struct man *man, struct man_node *n)
        if (NULL == (cp = man_valids[n->tok].pres))
                return(1);
        for ( ; *cp; cp++)
        if (NULL == (cp = man_valids[n->tok].pres))
                return(1);
        for ( ; *cp; cp++)
-               if ( ! (*cp)(man, n)) 
+               if ( ! (*cp)(man, n))
                        return(0);
        return(1);
 }
 
                        return(0);
        return(1);
 }
 
-
 int
 man_valid_post(struct man *man)
 {
 int
 man_valid_post(struct man *man)
 {
@@ -164,14 +164,14 @@ man_valid_post(struct man *man)
        man->last->flags |= MAN_VALID;
 
        switch (man->last->type) {
        man->last->flags |= MAN_VALID;
 
        switch (man->last->type) {
-       case (MAN_TEXT): 
+       case MAN_TEXT:
                check_text(man, man->last);
                return(1);
                check_text(man, man->last);
                return(1);
-       case (MAN_ROOT):
+       case MAN_ROOT:
                return(check_root(man, man->last));
                return(check_root(man, man->last));
-       case (MAN_EQN):
+       case MAN_EQN:
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case (MAN_TBL):
+       case MAN_TBL:
                return(1);
        default:
                break;
                return(1);
        default:
                break;
@@ -186,9 +186,8 @@ man_valid_post(struct man *man)
        return(1);
 }
 
        return(1);
 }
 
-
 static int
 static int
-check_root(CHKARGS) 
+check_root(CHKARGS)
 {
 
        if (MAN_BLINE & man->flags)
 {
 
        if (MAN_BLINE & man->flags)
@@ -199,18 +198,20 @@ check_root(CHKARGS)
        man->flags &= ~MAN_BLINE;
        man->flags &= ~MAN_ELINE;
 
        man->flags &= ~MAN_BLINE;
        man->flags &= ~MAN_ELINE;
 
-       if (NULL == man->first->child) {
-               man_nmsg(man, n, MANDOCERR_NODOCBODY);
-               return(0);
-       } else if (NULL == man->meta.title) {
-               man_nmsg(man, n, MANDOCERR_NOTITLE);
+       if (NULL == man->first->child)
+               man_nmsg(man, n, MANDOCERR_DOC_EMPTY);
+       else
+               man->meta.hasbody = 1;
+
+       if (NULL == man->meta.title) {
+               man_nmsg(man, n, MANDOCERR_TH_MISSING);
 
                /*
                 * If a title hasn't been set, do so now (by
                 * implication, date and section also aren't set).
                 */
 
 
                /*
                 * If a title hasn't been set, do so now (by
                 * implication, date and section also aren't set).
                 */
 
-               man->meta.title = mandoc_strdup("unknown");
+               man->meta.title = mandoc_strdup("unknown");
                man->meta.msec = mandoc_strdup("1");
                man->meta.date = man->quick ? mandoc_strdup("") :
                    mandoc_normdate(man->parse, NULL, n->line, n->pos);
                man->meta.msec = mandoc_strdup("1");
                man->meta.date = man->quick ? mandoc_strdup("") :
                    mandoc_normdate(man->parse, NULL, n->line, n->pos);
@@ -239,8 +240,8 @@ check_##name(CHKARGS) \
        if (n->nchild ineq (x)) \
                return(1); \
        mandoc_vmsg(MANDOCERR_ARGCOUNT, man->parse, n->line, n->pos, \
        if (n->nchild ineq (x)) \
                return(1); \
        mandoc_vmsg(MANDOCERR_ARGCOUNT, man->parse, n->line, n->pos, \
-                       "line arguments %s %d (have %d)", \
-                       #ineq, (x), n->nchild); \
+           "line arguments %s %d (have %d)", \
+           #ineq, (x), n->nchild); \
        return(1); \
 }
 
        return(1); \
 }
 
@@ -273,27 +274,27 @@ post_ft(CHKARGS)
        ok = 0;
        cp = n->child->string;
        switch (*cp) {
        ok = 0;
        cp = n->child->string;
        switch (*cp) {
-       case ('1'):
+       case '1':
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case ('2'):
+       case '2':
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case ('3'):
+       case '3':
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case ('4'):
+       case '4':
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case ('I'):
+       case 'I':
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case ('P'):
+       case 'P':
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case ('R'):
+       case 'R':
                if ('\0' == cp[1])
                        ok = 1;
                break;
                if ('\0' == cp[1])
                        ok = 1;
                break;
-       case ('B'):
+       case 'B':
                if ('\0' == cp[1] || ('I' == cp[1] && '\0' == cp[2]))
                        ok = 1;
                break;
                if ('\0' == cp[1] || ('I' == cp[1] && '\0' == cp[2]))
                        ok = 1;
                break;
-       case ('C'):
+       case 'C':
                if ('W' == cp[1] && '\0' == cp[2])
                        ok = 1;
                break;
                if ('W' == cp[1] && '\0' == cp[2])
                        ok = 1;
                break;
@@ -302,17 +303,14 @@ post_ft(CHKARGS)
        }
 
        if (0 == ok) {
        }
 
        if (0 == ok) {
-               mandoc_vmsg
-                       (MANDOCERR_BADFONT, man->parse,
-                        n->line, n->pos, "%s", cp);
+               mandoc_vmsg(MANDOCERR_BADFONT, man->parse, n->line,
+                   n->pos, "%s", cp);
                *cp = '\0';
        }
 
        if (1 < n->nchild)
                *cp = '\0';
        }
 
        if (1 < n->nchild)
-               mandoc_vmsg
-                       (MANDOCERR_ARGCOUNT, man->parse, n->line, 
-                        n->pos, "want one child (have %d)", 
-                        n->nchild);
+               mandoc_vmsg(MANDOCERR_ARGCOUNT, man->parse, n->line,
+                   n->pos, "want one child (have %d)", n->nchild);
 
        return(1);
 }
 
        return(1);
 }
@@ -330,7 +328,7 @@ static int
 post_sec(CHKARGS)
 {
 
 post_sec(CHKARGS)
 {
 
-       if ( ! (MAN_HEAD == n->type && 0 == n->nchild)) 
+       if ( ! (MAN_HEAD == n->type && 0 == n->nchild))
                return(1);
 
        man_nmsg(man, n, MANDOCERR_SYNTARGCOUNT);
                return(1);
 
        man_nmsg(man, n, MANDOCERR_SYNTARGCOUNT);
@@ -342,27 +340,28 @@ check_part(CHKARGS)
 {
 
        if (MAN_BODY == n->type && 0 == n->nchild)
 {
 
        if (MAN_BODY == n->type && 0 == n->nchild)
-               mandoc_msg(MANDOCERR_ARGCWARN, man->parse, n->line, 
-                               n->pos, "want children (have none)");
+               mandoc_msg(MANDOCERR_ARGCWARN, man->parse, n->line,
+                   n->pos, "want children (have none)");
 
        return(1);
 }
 
 
        return(1);
 }
 
-
 static int
 check_par(CHKARGS)
 {
 
        switch (n->type) {
 static int
 check_par(CHKARGS)
 {
 
        switch (n->type) {
-       case (MAN_BLOCK):
+       case MAN_BLOCK:
                if (0 == n->body->nchild)
                        man_node_delete(man, n);
                break;
                if (0 == n->body->nchild)
                        man_node_delete(man, n);
                break;
-       case (MAN_BODY):
+       case MAN_BODY:
                if (0 == n->nchild)
                if (0 == n->nchild)
-                       man_nmsg(man, n, MANDOCERR_IGNPAR);
+                       mandoc_vmsg(MANDOCERR_PAR_SKIP,
+                           man->parse, n->line, n->pos,
+                           "%s empty", man_macronames[n->tok]);
                break;
                break;
-       case (MAN_HEAD):
+       case MAN_HEAD:
                if (n->nchild)
                        man_nmsg(man, n, MANDOCERR_ARGSLOST);
                break;
                if (n->nchild)
                        man_nmsg(man, n, MANDOCERR_ARGSLOST);
                break;
@@ -378,13 +377,15 @@ post_IP(CHKARGS)
 {
 
        switch (n->type) {
 {
 
        switch (n->type) {
-       case (MAN_BLOCK):
+       case MAN_BLOCK:
                if (0 == n->head->nchild && 0 == n->body->nchild)
                        man_node_delete(man, n);
                break;
                if (0 == n->head->nchild && 0 == n->body->nchild)
                        man_node_delete(man, n);
                break;
-       case (MAN_BODY):
+       case MAN_BODY:
                if (0 == n->parent->head->nchild && 0 == n->nchild)
                if (0 == n->parent->head->nchild && 0 == n->nchild)
-                       man_nmsg(man, n, MANDOCERR_IGNPAR);
+                       mandoc_vmsg(MANDOCERR_PAR_SKIP,
+                           man->parse, n->line, n->pos,
+                           "%s empty", man_macronames[n->tok]);
                break;
        default:
                break;
                break;
        default:
                break;
@@ -395,6 +396,7 @@ post_IP(CHKARGS)
 static int
 post_TH(CHKARGS)
 {
 static int
 post_TH(CHKARGS)
 {
+       struct man_node *nb;
        const char      *p;
 
        free(man->meta.title);
        const char      *p;
 
        free(man->meta.title);
@@ -404,7 +406,9 @@ post_TH(CHKARGS)
        free(man->meta.date);
 
        man->meta.title = man->meta.vol = man->meta.date =
        free(man->meta.date);
 
        man->meta.title = man->meta.vol = man->meta.date =
-               man->meta.msec = man->meta.source = NULL;
+           man->meta.msec = man->meta.source = NULL;
+
+       nb = n;
 
        /* ->TITLE<- MSEC DATE SOURCE VOL */
 
 
        /* ->TITLE<- MSEC DATE SOURCE VOL */
 
@@ -412,9 +416,12 @@ post_TH(CHKARGS)
        if (n && n->string) {
                for (p = n->string; '\0' != *p; p++) {
                        /* Only warn about this once... */
        if (n && n->string) {
                for (p = n->string; '\0' != *p; p++) {
                        /* Only warn about this once... */
-                       if (isalpha((unsigned char)*p) && 
-                                       ! isupper((unsigned char)*p)) {
-                               man_nmsg(man, n, MANDOCERR_UPPERCASE);
+                       if (isalpha((unsigned char)*p) &&
+                           ! isupper((unsigned char)*p)) {
+                               mandoc_msg(MANDOCERR_TITLE_CASE,
+                                   man->parse, n->line,
+                                   n->pos + (p - n->string),
+                                   n->string);
                                break;
                        }
                }
                                break;
                        }
                }
@@ -440,8 +447,10 @@ post_TH(CHKARGS)
                    mandoc_strdup(n->string) :
                    mandoc_normdate(man->parse, n->string,
                        n->line, n->pos);
                    mandoc_strdup(n->string) :
                    mandoc_normdate(man->parse, n->string,
                        n->line, n->pos);
-       } else
+       } else {
                man->meta.date = mandoc_strdup("");
                man->meta.date = mandoc_strdup("");
+               man_nmsg(man, n ? n : nb, MANDOCERR_DATE_MISSING);
+       }
 
        /* TITLE MSEC DATE ->SOURCE<- VOL */
 
 
        /* TITLE MSEC DATE ->SOURCE<- VOL */
 
@@ -470,7 +479,7 @@ post_nf(CHKARGS)
 {
 
        if (MAN_LITERAL & man->flags)
 {
 
        if (MAN_LITERAL & man->flags)
-               man_nmsg(man, n, MANDOCERR_SCOPEREP);
+               man_nmsg(man, n, MANDOCERR_NF_SKIP);
 
        man->flags |= MAN_LITERAL;
        return(1);
 
        man->flags |= MAN_LITERAL;
        return(1);
@@ -481,7 +490,7 @@ post_fi(CHKARGS)
 {
 
        if ( ! (MAN_LITERAL & man->flags))
 {
 
        if ( ! (MAN_LITERAL & man->flags))
-               man_nmsg(man, n, MANDOCERR_WNOSCOPE);
+               man_nmsg(man, n, MANDOCERR_FI_SKIP);
 
        man->flags &= ~MAN_LITERAL;
        return(1);
 
        man->flags &= ~MAN_LITERAL;
        return(1);
@@ -571,13 +580,15 @@ post_vs(CHKARGS)
                return(1);
 
        switch (n->parent->tok) {
                return(1);
 
        switch (n->parent->tok) {
-       case (MAN_SH):
+       case MAN_SH:
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case (MAN_SS):
-               man_nmsg(man, n, MANDOCERR_IGNPAR);
+       case MAN_SS:
+               mandoc_vmsg(MANDOCERR_PAR_SKIP, man->parse, n->line, n->pos,
+                   "%s after %s", man_macronames[n->tok],
+                   man_macronames[n->parent->tok]);
                /* FALLTHROUGH */
                /* FALLTHROUGH */
-       case (MAN_MAX):
-               /* 
+       case MAN_MAX:
+               /*
                 * Don't warn about this because it occurs in pod2man
                 * and would cause considerable (unfixable) warnage.
                 */
                 * Don't warn about this because it occurs in pod2man
                 * and would cause considerable (unfixable) warnage.
                 */