]> git.cameronkatri.com Git - mandoc.git/blobdiff - demandoc.c
make the path to ar(1) configurable, needed by NixOS;
[mandoc.git] / demandoc.c
index f515931d8b91e8742129e65f2eccabad6ab2bcfd..57d0cc5f4120dee213091c638803161c87948ea2 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: demandoc.c,v 1.15 2015/02/10 08:05:30 schwarze Exp $ */
+/*     $Id: demandoc.c,v 1.33 2019/03/03 11:01:15 schwarze Exp $ */
 /*
  * Copyright (c) 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  *
 
 #include <assert.h>
 #include <ctype.h>
-#include <getopt.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <unistd.h>
 
+#include "mandoc.h"
+#include "roff.h"
 #include "man.h"
 #include "mdoc.h"
-#include "mandoc.h"
+#include "mandoc_parse.h"
 
 static void     pline(int, int *, int *, int);
-static void     pman(const struct man_node *, int *, int *, int);
+static void     pman(const struct roff_node *, int *, int *, int);
 static void     pmandoc(struct mparse *, int, const char *, int);
-static void     pmdoc(const struct mdoc_node *, int *, int *, int);
+static void     pmdoc(const struct roff_node *, int *, int *, int);
 static void     pstring(const char *, int, int *, int);
 static void     usage(void);
 
@@ -43,7 +44,6 @@ int
 main(int argc, char *argv[])
 {
        struct mparse   *mp;
-       struct mchars   *mchars;
        int              ch, fd, i, list;
        extern int       optind;
 
@@ -72,14 +72,15 @@ main(int argc, char *argv[])
                        break;
                default:
                        usage();
-                       return((int)MANDOCLEVEL_BADARG);
+                       return (int)MANDOCLEVEL_BADARG;
                }
 
        argc -= optind;
        argv += optind;
 
-       mchars = mchars_alloc();
-       mp = mparse_alloc(MPARSE_SO, MANDOCLEVEL_BADARG, NULL, mchars, NULL);
+       mchars_alloc();
+       mp = mparse_alloc(MPARSE_SO | MPARSE_UTF8 | MPARSE_LATIN1 |
+           MPARSE_VALIDATE, MANDOC_OS_OTHER, NULL);
        assert(mp);
 
        if (argc < 1)
@@ -87,7 +88,7 @@ main(int argc, char *argv[])
 
        for (i = 0; i < argc; i++) {
                mparse_reset(mp);
-               if (mparse_open(mp, &fd, argv[i]) != MANDOCLEVEL_OK) {
+               if ((fd = mparse_open(mp, argv[i])) == -1) {
                        perror(argv[i]);
                        continue;
                }
@@ -95,8 +96,8 @@ main(int argc, char *argv[])
        }
 
        mparse_free(mp);
-       mchars_free(mchars);
-       return((int)MANDOCLEVEL_OK);
+       mchars_free();
+       return (int)MANDOCLEVEL_OK;
 }
 
 static void
@@ -109,21 +110,19 @@ usage(void)
 static void
 pmandoc(struct mparse *mp, int fd, const char *fn, int list)
 {
-       struct mdoc     *mdoc;
-       struct man      *man;
+       struct roff_meta        *meta;
        int              line, col;
 
        mparse_readfd(mp, fd, fn);
-       mparse_result(mp, &mdoc, &man, NULL);
+       close(fd);
+       meta = mparse_result(mp);
        line = 1;
        col = 0;
 
-       if (mdoc)
-               pmdoc(mdoc_node(mdoc), &line, &col, list);
-       else if (man)
-               pman(man_node(man), &line, &col, list);
+       if (meta->macroset == MACROSET_MDOC)
+               pmdoc(meta->first->child, &line, &col, list);
        else
-               return;
+               pman(meta->first->child, &line, &col, list);
 
        if ( ! list)
                putchar('\n');
@@ -233,13 +232,13 @@ pline(int line, int *linep, int *col, int list)
 }
 
 static void
-pmdoc(const struct mdoc_node *p, int *line, int *col, int list)
+pmdoc(const struct roff_node *p, int *line, int *col, int list)
 {
 
        for ( ; p; p = p->next) {
-               if (MDOC_LINE & p->flags)
+               if (NODE_LINE & p->flags)
                        pline(p->line, line, col, list);
-               if (MDOC_TEXT == p->type)
+               if (ROFFT_TEXT == p->type)
                        pstring(p->string, p->pos, col, list);
                if (p->child)
                        pmdoc(p->child, line, col, list);
@@ -247,13 +246,13 @@ pmdoc(const struct mdoc_node *p, int *line, int *col, int list)
 }
 
 static void
-pman(const struct man_node *p, int *line, int *col, int list)
+pman(const struct roff_node *p, int *line, int *col, int list)
 {
 
        for ( ; p; p = p->next) {
-               if (MAN_LINE & p->flags)
+               if (NODE_LINE & p->flags)
                        pline(p->line, line, col, list);
-               if (MAN_TEXT == p->type)
+               if (ROFFT_TEXT == p->type)
                        pstring(p->string, p->pos, col, list);
                if (p->child)
                        pman(p->child, line, col, list);