]> git.cameronkatri.com Git - mandoc.git/blobdiff - man_validate.c
Clean up warnings related to macros and nesting.
[mandoc.git] / man_validate.c
index 7a9deede11459a853e254fb9db4bfca5ed1f0778..61f8ef811a4fefd9dde18e72d3e36d31ac419375 100644 (file)
@@ -1,7 +1,7 @@
-/*     $Id: man_validate.c,v 1.85 2012/11/17 00:26:33 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) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
- * Copyright (c) 2010, 2012 Ingo Schwarze <schwarze@openbsd.org>
+ * Copyright (c) 2010, 2012, 2013, 2014 Ingo Schwarze <schwarze@openbsd.org>
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
  *
  * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above
@@ -32,6 +32,7 @@
 
 #include "man.h"
 #include "mandoc.h"
 
 #include "man.h"
 #include "mandoc.h"
+#include "mandoc_aux.h"
 #include "libman.h"
 #include "libmandoc.h"
 
 #include "libman.h"
 #include "libmandoc.h"
 
@@ -49,6 +50,7 @@ static        int       check_eq2(CHKARGS);
 static int       check_le1(CHKARGS);
 static int       check_ge2(CHKARGS);
 static int       check_le5(CHKARGS);
 static int       check_le1(CHKARGS);
 static int       check_ge2(CHKARGS);
 static int       check_le5(CHKARGS);
+static int       check_head1(CHKARGS);
 static int       check_par(CHKARGS);
 static int       check_part(CHKARGS);
 static int       check_root(CHKARGS);
 static int       check_par(CHKARGS);
 static int       check_part(CHKARGS);
 static int       check_root(CHKARGS);
@@ -80,6 +82,7 @@ static        v_check   posts_sec[] = { post_sec, NULL };
 static v_check   posts_sp[] = { post_vs, check_le1, NULL };
 static v_check   posts_th[] = { check_ge2, check_le5, post_TH, NULL };
 static v_check   posts_uc[] = { post_UC, NULL };
 static v_check   posts_sp[] = { post_vs, check_le1, NULL };
 static v_check   posts_th[] = { check_ge2, check_le5, post_TH, NULL };
 static v_check   posts_uc[] = { post_UC, NULL };
+static v_check   posts_ur[] = { check_head1, check_part, NULL };
 static v_check   pres_sec[] = { pre_sec, NULL };
 
 static const struct man_valid man_valids[MAN_MAX] = {
 static v_check   pres_sec[] = { pre_sec, NULL };
 
 static const struct man_valid man_valids[MAN_MAX] = {
@@ -119,6 +122,9 @@ static      const struct man_valid man_valids[MAN_MAX] = {
        { NULL, posts_eq2 }, /* OP */
        { NULL, posts_nf }, /* EX */
        { NULL, posts_fi }, /* EE */
        { NULL, posts_eq2 }, /* OP */
        { NULL, posts_nf }, /* EX */
        { NULL, posts_fi }, /* EE */
+       { NULL, posts_ur }, /* UR */
+       { NULL, NULL }, /* UE */
+       { NULL, NULL }, /* ll */
 };
 
 
 };
 
 
@@ -128,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;
@@ -143,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)
 {
@@ -159,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;
@@ -181,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)
@@ -194,21 +198,23 @@ 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.msec = mandoc_strdup("1");
-               man->meta.date = mandoc_normdate
-                       (man->parse, NULL, n->line, n->pos);
+               man->meta.date = man->quick ? mandoc_strdup("") :
+                   mandoc_normdate(man->parse, NULL, n->line, n->pos);
        }
 
        return(1);
        }
 
        return(1);
@@ -234,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); \
 }
 
@@ -245,6 +251,17 @@ INEQ_DEFINE(1, <=, le1)
 INEQ_DEFINE(2, >=, ge2)
 INEQ_DEFINE(5, <=, le5)
 
 INEQ_DEFINE(2, >=, ge2)
 INEQ_DEFINE(5, <=, le5)
 
+static int
+check_head1(CHKARGS)
+{
+
+       if (MAN_HEAD == n->type && 1 != n->nchild)
+               mandoc_vmsg(MANDOCERR_ARGCOUNT, man->parse, n->line,
+                   n->pos, "line arguments eq 1 (have %d)", n->nchild);
+
+       return(1);
+}
+
 static int
 post_ft(CHKARGS)
 {
 static int
 post_ft(CHKARGS)
 {
@@ -257,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;
@@ -286,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);
 }
@@ -314,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);
@@ -326,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;
@@ -362,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;
@@ -379,8 +396,8 @@ post_IP(CHKARGS)
 static int
 post_TH(CHKARGS)
 {
 static int
 post_TH(CHKARGS)
 {
+       struct man_node *nb;
        const char      *p;
        const char      *p;
-       int              line, pos;
 
        free(man->meta.title);
        free(man->meta.vol);
 
        free(man->meta.title);
        free(man->meta.vol);
@@ -388,10 +405,10 @@ post_TH(CHKARGS)
        free(man->meta.msec);
        free(man->meta.date);
 
        free(man->meta.msec);
        free(man->meta.date);
 
-       line = n->line;
-       pos = n->pos;
        man->meta.title = man->meta.vol = 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 */
 
@@ -399,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;
                        }
                }
@@ -423,11 +443,14 @@ post_TH(CHKARGS)
        if (n)
                n = n->next;
        if (n && n->string && '\0' != n->string[0]) {
        if (n)
                n = n->next;
        if (n && n->string && '\0' != n->string[0]) {
-               pos = n->pos;
-               man->meta.date = mandoc_normdate
-                   (man->parse, n->string, line, pos);
-       } else
+               man->meta.date = man->quick ?
+                   mandoc_strdup(n->string) :
+                   mandoc_normdate(man->parse, n->string,
+                       n->line, n->pos);
+       } 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 */
 
@@ -456,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);
@@ -467,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);
@@ -557,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.
                 */