]> git.cameronkatri.com Git - mandoc.git/commitdiff
Move -column list validation and normal-formisation from mdoc_action.c
authorKristaps Dzonsons <kristaps@bsd.lv>
Tue, 30 Nov 2010 10:32:05 +0000 (10:32 +0000)
committerKristaps Dzonsons <kristaps@bsd.lv>
Tue, 30 Nov 2010 10:32:05 +0000 (10:32 +0000)
into mdoc_validate.c.

mdoc_action.c
mdoc_validate.c

index 4bd8203a6b9c73043cf8d2e3eaa1937435a463a4..f4cff48694c5b9f5921a3b79f82465167bae13d4 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: mdoc_action.c,v 1.85 2010/11/29 16:06:46 kristaps Exp $ */
+/*     $Id: mdoc_action.c,v 1.86 2010/11/30 10:32:05 kristaps Exp $ */
 /*
  * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
  *
@@ -52,7 +52,6 @@ static        int       concat(struct mdoc *, char *,
                        const struct mdoc_node *, size_t);
 
 static int       post_bl(POST_ARGS);
-static int       post_bl_head(POST_ARGS);
 static int       post_bl_tagwidth(POST_ARGS);
 static int       post_bl_width(POST_ARGS);
 static int       post_dd(POST_ARGS);
@@ -550,65 +549,10 @@ post_bl_width(POST_ARGS)
 }
 
 
-/*
- * Do processing for -column lists, which can have two distinct styles
- * of invocation.  Merge this two styles into a consistent form.
- */
-/* ARGSUSED */
-static int
-post_bl_head(POST_ARGS)
-{
-       int                      i, c;
-       struct mdoc_node        *np, *nn, *nnp;
-
-       if (LIST_column != n->data.Bl->type)
-               return(1);
-       else if (NULL == n->child)
-               return(1);
-
-       np = n->parent;
-       assert(np->args);
-
-       for (c = 0; c < (int)np->args->argc; c++) 
-               if (MDOC_Column == np->args->argv[c].arg)
-                       break;
-
-       assert(c < (int)np->args->argc);
-       assert(0 == np->args->argv[c].sz);
-
-       /*
-        * Accomodate for new-style groff column syntax.  Shuffle the
-        * child nodes, all of which must be TEXT, as arguments for the
-        * column field.  Then, delete the head children.
-        */
-
-       np->args->argv[c].sz = (size_t)n->nchild;
-       np->args->argv[c].value = mandoc_malloc
-               ((size_t)n->nchild * sizeof(char *));
-
-       n->data.Bl->ncols = np->args->argv[c].sz;
-       n->data.Bl->cols = (const char **)np->args->argv[c].value;
-
-       for (i = 0, nn = n->child; nn; i++) {
-               np->args->argv[c].value[i] = nn->string;
-               nn->string = NULL;
-               nnp = nn;
-               nn = nn->next;
-               mdoc_node_delete(NULL, nnp);
-       }
-
-       n->nchild = 0;
-       n->child = NULL;
-       return(1);
-}
-
-
 static int
 post_bl(POST_ARGS)
 {
 
-       if (MDOC_HEAD == n->type)
-               return(post_bl_head(m, n));
        if (MDOC_BLOCK != n->type)
                return(1);
 
index be4d747c6b3ac74066b9bc26a5a8f5baae1efeca..4bc9d861885602cc695631f0b4a7473dd3ad9244 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: mdoc_validate.c,v 1.129 2010/11/29 16:06:46 kristaps Exp $ */
+/*     $Id: mdoc_validate.c,v 1.130 2010/11/30 10:32:05 kristaps Exp $ */
 /*
  * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
  *
@@ -1402,23 +1402,68 @@ post_it(POST_ARGS)
 static int
 post_bl_head(POST_ARGS) 
 {
-       struct mdoc_node *n;
+       struct mdoc_node *np, *nn, *nnp;
+       int               i, j;
 
-       assert(mdoc->last->parent);
-       n = mdoc->last->parent;
+       if (LIST_column != mdoc->last->data.Bl->type)
+               /* FIXME: this should be ERROR class... */
+               return(hwarn_eq0(mdoc));
 
-       if (LIST_column == n->data.Bl->type) {
-               if (n->data.Bl->ncols && mdoc->last->nchild) {
-                       mdoc_nmsg(mdoc, n, MANDOCERR_COLUMNS);
-                       return(0);
-               }
+       /*
+        * Convert old-style lists, where the column width specifiers
+        * trail as macro parameters, to the new-style ("normal-form")
+        * lists where they're argument values following -column.
+        */
+
+       /* First, disallow both types and allow normal-form. */
+
+       /* 
+        * TODO: technically, we can accept both and just merge the two
+        * lists, but I'll leave that for another day.
+        */
+
+       if (mdoc->last->data.Bl->ncols && mdoc->last->nchild) {
+               mdoc_nmsg(mdoc, mdoc->last, MANDOCERR_COLUMNS);
+               return(0);
+       } else if (NULL == mdoc->last->child)
                return(1);
+
+       np = mdoc->last->parent;
+       assert(np->args);
+
+       for (j = 0; j < (int)np->args->argc; j++) 
+               if (MDOC_Column == np->args->argv[j].arg)
+                       break;
+
+       assert(j < (int)np->args->argc);
+       assert(0 == np->args->argv[j].sz);
+
+       /*
+        * Accomodate for new-style groff column syntax.  Shuffle the
+        * child nodes, all of which must be TEXT, as arguments for the
+        * column field.  Then, delete the head children.
+        */
+
+       np->args->argv[j].sz = (size_t)mdoc->last->nchild;
+       np->args->argv[j].value = mandoc_malloc
+               ((size_t)mdoc->last->nchild * sizeof(char *));
+
+       mdoc->last->data.Bl->ncols = np->args->argv[j].sz;
+       mdoc->last->data.Bl->cols = (const char **)np->args->argv[j].value;
+
+       for (i = 0, nn = mdoc->last->child; nn; i++) {
+               np->args->argv[j].value[i] = nn->string;
+               nn->string = NULL;
+               nnp = nn;
+               nn = nn->next;
+               mdoc_node_delete(NULL, nnp);
        }
 
-       /* FIXME: should be ERROR class. */
-       return(hwarn_eq0(mdoc));
-}
+       mdoc->last->nchild = 0;
+       mdoc->last->child = NULL;
 
+       return(1);
+}
 
 static int
 post_bl(POST_ARGS)