]> git.cameronkatri.com Git - mandoc.git/blobdiff - mdoc_macro.c
`Cd' in -Thtml -mdoc correctly breaks lines.
[mandoc.git] / mdoc_macro.c
index e6daa86b7f0d1b722d7496568007603440159abf..66e5faf0728275ee199bbcb5ba1f218849db6904 100644 (file)
@@ -1,4 +1,4 @@
-/*     $Id: mdoc_macro.c,v 1.32 2009/08/19 14:09:33 kristaps Exp $ */
+/*     $Id: mdoc_macro.c,v 1.36 2009/09/20 17:24:57 kristaps Exp $ */
 /*
  * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
  *
 /*
  * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
  *
@@ -46,8 +46,8 @@ static        int       rew_sub(enum mdoc_type, struct mdoc *,
 static int       rew_last(struct mdoc *, 
                        const struct mdoc_node *);
 static int       append_delims(struct mdoc *, int, int *, char *);
 static int       rew_last(struct mdoc *, 
                        const struct mdoc_node *);
 static int       append_delims(struct mdoc *, int, int *, char *);
-static int       lookup(struct mdoc *, int, const char *);
-static int       lookup_raw(struct mdoc *, const char *);
+static int       lookup(int, const char *);
+static int       lookup_raw(const char *);
 static int       swarn(struct mdoc *, enum mdoc_type, int, int, 
                        const struct mdoc_node *);
 
 static int       swarn(struct mdoc *, enum mdoc_type, int, int, 
                        const struct mdoc_node *);
 
@@ -258,12 +258,13 @@ mdoc_macroend(struct mdoc *m)
  * Look up a macro from within a subsequent context.
  */
 static int
  * Look up a macro from within a subsequent context.
  */
 static int
-lookup(struct mdoc *mdoc, int from, const char *p)
+lookup(int from, const char *p)
 {
 {
+       /* FIXME: make -diag lists be un-PARSED. */
 
        if ( ! (MDOC_PARSED & mdoc_macros[from].flags))
                return(MDOC_MAX);
 
        if ( ! (MDOC_PARSED & mdoc_macros[from].flags))
                return(MDOC_MAX);
-       return(lookup_raw(mdoc, p));
+       return(lookup_raw(p));
 }
 
 
 }
 
 
@@ -271,11 +272,11 @@ lookup(struct mdoc *mdoc, int from, const char *p)
  * Lookup a macro following the initial line macro.
  */
 static int
  * Lookup a macro following the initial line macro.
  */
 static int
-lookup_raw(struct mdoc *mdoc, const char *p)
+lookup_raw(const char *p)
 {
        int              res;
 
 {
        int              res;
 
-       if (MDOC_MAX == (res = mdoc_hash_find(mdoc->htab, p)))
+       if (MDOC_MAX == (res = mdoc_hash_find(p)))
                return(MDOC_MAX);
        if (MDOC_CALLABLE & mdoc_macros[res].flags)
                return(res);
                return(MDOC_MAX);
        if (MDOC_CALLABLE & mdoc_macros[res].flags)
                return(res);
@@ -600,7 +601,7 @@ append_delims(struct mdoc *mdoc, int line, int *pos, char *buf)
 
        for (;;) {
                lastarg = *pos;
 
        for (;;) {
                lastarg = *pos;
-               c = mdoc_args(mdoc, line, pos, buf, 0, &p);
+               c = mdoc_zargs(mdoc, line, pos, buf, ARGS_NOWARN, &p);
                assert(ARGS_PHRASE != c);
 
                if (ARGS_ERROR == c)
                assert(ARGS_PHRASE != c);
 
                if (ARGS_ERROR == c)
@@ -669,7 +670,7 @@ blk_exp_close(MACRO_PROT_ARGS)
                if (ARGS_EOLN == c)
                        break;
 
                if (ARGS_EOLN == c)
                        break;
 
-               if (MDOC_MAX != (c = lookup(m, tok, p))) {
+               if (MDOC_MAX != (c = lookup(tok, p))) {
                        if ( ! flushed) {
                                if ( ! rew_sub(MDOC_BLOCK, m, tok, line, ppos))
                                        return(0);
                        if ( ! flushed) {
                                if ( ! rew_sub(MDOC_BLOCK, m, tok, line, ppos))
                                        return(0);
@@ -753,7 +754,7 @@ in_line(MACRO_PROT_ARGS)
 
                /* Quoted words shouldn't be looked-up. */
 
 
                /* Quoted words shouldn't be looked-up. */
 
-               c = ARGS_QWORD == w ? MDOC_MAX : lookup(m, tok, p);
+               c = ARGS_QWORD == w ? MDOC_MAX : lookup(tok, p);
 
                /* 
                 * In this case, we've located a submacro and must
 
                /* 
                 * In this case, we've located a submacro and must
@@ -932,7 +933,7 @@ blk_full(MACRO_PROT_ARGS)
                        continue;
                }
 
                        continue;
                }
 
-               if (MDOC_MAX == (c = lookup(m, tok, p))) {
+               if (MDOC_MAX == (c = lookup(tok, p))) {
                        if ( ! mdoc_word_alloc(m, line, lastarg, p))
                                return(0);
                        continue;
                        if ( ! mdoc_word_alloc(m, line, lastarg, p))
                                return(0);
                        continue;
@@ -995,7 +996,7 @@ blk_part_imp(MACRO_PROT_ARGS)
                if (ARGS_EOLN == c)
                        break;
 
                if (ARGS_EOLN == c)
                        break;
 
-               if (MDOC_MAX == (c = lookup(m, tok, p))) {
+               if (MDOC_MAX == (c = lookup(tok, p))) {
                        if ( ! mdoc_word_alloc(m, line, la, p))
                                return(0);
                        continue;
                        if ( ! mdoc_word_alloc(m, line, la, p))
                                return(0);
                        continue;
@@ -1098,7 +1099,7 @@ blk_part_exp(MACRO_PROT_ARGS)
                if (ARGS_EOLN == c)
                        break;
 
                if (ARGS_EOLN == c)
                        break;
 
-               if (MDOC_MAX != (c = lookup(m, tok, p))) {
+               if (MDOC_MAX != (c = lookup(tok, p))) {
                        if ( ! flushed) {
                                if ( ! rew_sub(MDOC_HEAD, m, tok, line, ppos))
                                        return(0);
                        if ( ! flushed) {
                                if ( ! rew_sub(MDOC_HEAD, m, tok, line, ppos))
                                        return(0);
@@ -1209,7 +1210,7 @@ in_line_argn(MACRO_PROT_ARGS)
                if (ARGS_EOLN == c)
                        break;
 
                if (ARGS_EOLN == c)
                        break;
 
-               if (MDOC_MAX != (c = lookup(m, tok, p))) {
+               if (MDOC_MAX != (c = lookup(tok, p))) {
                        if ( ! flushed && ! rew_elem(m, tok))
                                return(0);
                        flushed = 1;
                        if ( ! flushed && ! rew_elem(m, tok))
                                return(0);
                        flushed = 1;
@@ -1284,7 +1285,7 @@ in_line_eoln(MACRO_PROT_ARGS)
                if (ARGS_EOLN == w)
                        break;
 
                if (ARGS_EOLN == w)
                        break;
 
-               c = ARGS_QWORD == w ? MDOC_MAX : lookup(m, tok, p);
+               c = ARGS_QWORD == w ? MDOC_MAX : lookup(tok, p);
 
                if (MDOC_MAX != c) {
                        if ( ! rew_elem(m, tok))
 
                if (MDOC_MAX != c) {
                        if ( ! rew_elem(m, tok))
@@ -1326,14 +1327,14 @@ phrase(struct mdoc *m, int line, int ppos, char *buf)
                la = pos;
 
                /* Note: no calling context! */
                la = pos;
 
                /* Note: no calling context! */
-               w = mdoc_zargs(m, line, &pos, buf, &p);
+               w = mdoc_zargs(m, line, &pos, buf, 0, &p);
 
                if (ARGS_ERROR == w)
                        return(0);
                if (ARGS_EOLN == w)
                        break;
 
 
                if (ARGS_ERROR == w)
                        return(0);
                if (ARGS_EOLN == w)
                        break;
 
-               c = ARGS_QWORD == w ? MDOC_MAX : lookup_raw(m, p);
+               c = ARGS_QWORD == w ? MDOC_MAX : lookup_raw(p);
 
                if (MDOC_MAX != c) {
                        if ( ! mdoc_macro(m, c, line, la, &pos, buf))
 
                if (MDOC_MAX != c) {
                        if ( ! mdoc_macro(m, c, line, la, &pos, buf))