summaryrefslogtreecommitdiffstatshomepage
path: root/validate.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2009-01-08 15:59:58 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2009-01-08 15:59:58 +0000
commit1b6424e34de2a96aaa28ac28d0b0d83c0b46bdf4 (patch)
tree4b17e7e7f59e83a634a02c562e87124551d4dacb /validate.c
parent78fb27b169aa25dd8d35291418167dc39d560865 (diff)
downloadmandoc-1b6424e34de2a96aaa28ac28d0b0d83c0b46bdf4.tar.gz
mandoc-1b6424e34de2a96aaa28ac28d0b0d83c0b46bdf4.tar.zst
mandoc-1b6424e34de2a96aaa28ac28d0b0d83c0b46bdf4.zip
*** empty log message ***
Diffstat (limited to 'validate.c')
-rw-r--r--validate.c71
1 files changed, 63 insertions, 8 deletions
diff --git a/validate.c b/validate.c
index a9d787c1..0fe1045b 100644
--- a/validate.c
+++ b/validate.c
@@ -1,4 +1,4 @@
-/* $Id: validate.c,v 1.19 2009/01/08 15:05:50 kristaps Exp $ */
+/* $Id: validate.c,v 1.20 2009/01/08 15:59:58 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -33,6 +33,9 @@ struct valids {
static int pre_sh(struct mdoc *, struct mdoc_node *);
+static int pre_prologue(struct mdoc *, struct mdoc_node *);
+static int pre_prologue(struct mdoc *, struct mdoc_node *);
+static int pre_prologue(struct mdoc *, struct mdoc_node *);
static int post_headchild_err_ge1(struct mdoc *);
static int post_headchild_err_le8(struct mdoc *);
static int post_bodychild_warn_ge1(struct mdoc *);
@@ -44,9 +47,9 @@ static v_post posts_sh[] = { post_headchild_err_ge1,
const struct valids mdoc_valids[MDOC_MAX] = {
{ NULL, NULL }, /* \" */
- { NULL, NULL }, /* Dd */ /* TODO: pre: ordering, repetition */
- { NULL, NULL }, /* Dt */ /* TODO ... */
- { NULL, NULL }, /* Os */ /* TODO ... */
+ { pre_prologue, NULL }, /* Dd */ /* TODO: pre: ordering, repetition */
+ { pre_prologue, NULL }, /* Dt */ /* TODO ... */
+ { pre_prologue, NULL }, /* Os */ /* TODO ... */
{ pre_sh, posts_sh }, /* Sh */ /* FIXME: preceding Pp. */
{ NULL, NULL }, /* Ss */ /* FIXME: preceding Pp. */
{ NULL, NULL }, /* Pp */
@@ -194,6 +197,58 @@ post_headchild_err_le8(struct mdoc *mdoc)
static int
+pre_prologue(struct mdoc *mdoc, struct mdoc_node *node)
+{
+
+ if (SEC_PROLOGUE != mdoc->sec_lastn)
+ return(mdoc_verr(mdoc, node, ERR_SEC_NPROLOGUE));
+ assert(MDOC_ELEM == node->type);
+
+ /* Check for ordering. */
+
+ switch (node->data.elem.tok) {
+ case (MDOC_Os):
+ if (mdoc->meta.title[0] && mdoc->meta.date)
+ break;
+ return(mdoc_verr(mdoc, node, ERR_SEC_PROLOGUE_OO));
+ case (MDOC_Dt):
+ if (0 == mdoc->meta.title[0] && mdoc->meta.date)
+ break;
+ return(mdoc_verr(mdoc, node, ERR_SEC_PROLOGUE_OO));
+ case (MDOC_Dd):
+ if (0 == mdoc->meta.title[0] && 0 == mdoc->meta.date)
+ break;
+ return(mdoc_verr(mdoc, node, ERR_SEC_PROLOGUE_OO));
+ default:
+ abort();
+ /* NOTREACHED */
+ }
+
+ /* Check for repetition. */
+
+ switch (node->data.elem.tok) {
+ case (MDOC_Os):
+ if (0 == mdoc->meta.os[0])
+ return(1);
+ break;
+ case (MDOC_Dd):
+ if (0 == mdoc->meta.date)
+ return(1);
+ break;
+ case (MDOC_Dt):
+ if (0 == mdoc->meta.title[0])
+ return(1);
+ break;
+ default:
+ abort();
+ /* NOTREACHED */
+ }
+
+ return(mdoc_verr(mdoc, node, ERR_SEC_PROLOGUE_REP));
+}
+
+
+static int
pre_sh(struct mdoc *mdoc, struct mdoc_node *node)
{
@@ -208,16 +263,16 @@ mdoc_valid_pre(struct mdoc *mdoc, struct mdoc_node *node)
switch (node->type) {
case (MDOC_BODY):
- t = mdoc->last->data.body.tok;
+ t = node->data.body.tok;
break;
case (MDOC_ELEM):
- t = mdoc->last->data.elem.tok;
+ t = node->data.elem.tok;
break;
case (MDOC_BLOCK):
- t = mdoc->last->data.block.tok;
+ t = node->data.block.tok;
break;
case (MDOC_HEAD):
- t = mdoc->last->data.head.tok;
+ t = node->data.head.tok;
break;
default:
return(1);