From a92eb03490ddb10755d39b4006afdfee3ba71b67 Mon Sep 17 00:00:00 2001 From: Kristaps Dzonsons Date: Fri, 28 Nov 2008 15:25:49 +0000 Subject: [PATCH 1/1] Removed superfluous structures from rofftree. Added roffdata for generalised text processing. --- libmdocml.c | 5 +- private.h | 26 +++++----- roff.c | 141 ++++++++++++++++++---------------------------------- 3 files changed, 62 insertions(+), 110 deletions(-) diff --git a/libmdocml.c b/libmdocml.c index 03011b0a..d4bf1d4e 100644 --- a/libmdocml.c +++ b/libmdocml.c @@ -1,4 +1,4 @@ -/* $Id: libmdocml.c,v 1.12 2008/11/28 11:21:12 kristaps Exp $ */ +/* $Id: libmdocml.c,v 1.13 2008/11/28 15:25:49 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -56,8 +56,7 @@ md_buf_fill(struct md_rbuf *in) } -static int -md_buf_flush(struct md_mbuf *buf) +static int md_buf_flush(struct md_mbuf *buf) { ssize_t sz; diff --git a/private.h b/private.h index 47691ba6..eb32c8fd 100644 --- a/private.h +++ b/private.h @@ -1,4 +1,4 @@ -/* $Id: private.h,v 1.14 2008/11/28 11:21:12 kristaps Exp $ */ +/* $Id: private.h,v 1.15 2008/11/28 15:25:49 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -209,16 +209,16 @@ extern const char *const *tokargnames; enum roffmsg { ROFF_WARN, ROFF_ERROR }; struct roffcb { - void (*roffmsg)(const struct md_args *, enum roffmsg, - const char *, const char *, const char *, - int, char *); - int (*roffhead)(const struct md_args *); - int (*rofftail)(const struct md_args *); - int (*roffin)(const struct md_args *, int, int *, char **); - int (*roffout)(const struct md_args *, int); - int (*roffblkin)(const struct md_args *, int); - int (*roffblkout)(const struct md_args *, int); - int (*roffspecial)(const struct md_args *, int); + void (*roffmsg)(void *, enum roffmsg, + const char *, const char *, char *); + int (*roffhead)(void *); + int (*rofftail)(void *); + int (*roffin)(void *, int, int *, char **); + int (*roffdata)(void *, const char *); + int (*roffout)(void *, int); + int (*roffblkin)(void *, int); + int (*roffblkout)(void *, int); + int (*roffspecial)(void *, int); }; __BEGIN_DECLS @@ -244,9 +244,7 @@ int md_buf_putstring(struct md_mbuf *, const char *); struct rofftree; -struct rofftree *roff_alloc(const struct md_args *, - struct md_mbuf *, const struct md_rbuf *, - const struct roffcb *); +struct rofftree *roff_alloc(const struct roffcb *, void *); int roff_engine(struct rofftree *, char *, size_t); int roff_free(struct rofftree *, int); diff --git a/roff.c b/roff.c index f6a48327..b00d32c1 100644 --- a/roff.c +++ b/roff.c @@ -1,4 +1,4 @@ -/* $Id: roff.c,v 1.14 2008/11/28 11:21:12 kristaps Exp $ */ +/* $Id: roff.c,v 1.15 2008/11/28 15:25:49 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -80,7 +80,6 @@ struct roffarg { struct roffnode { int tok; /* Token id. */ struct roffnode *parent; /* Parent (or NULL). */ - size_t line; /* Parsed at line. */ }; struct rofftree { @@ -100,10 +99,8 @@ struct rofftree { #define ROFF_PRELUDE_Dd (1 << 4) /* `Dd' is parsed. */ #define ROFF_BODY (1 << 5) /* In roff body. */ - struct md_mbuf *mbuf; /* Output (or NULL). */ - const struct md_args *args; /* Global args. */ - const struct md_rbuf *rbuf; /* Input. */ - const struct roffcb *cb; + struct roffcb cb; + void *arg; }; static int roff_Dd(ROFFCALL_ARGS); @@ -117,7 +114,7 @@ static int roff_close(ROFFCALL_ARGS); static int roff_special(ROFFCALL_ARGS); static struct roffnode *roffnode_new(int, struct rofftree *); -static void roffnode_free(int, struct rofftree *); +static void roffnode_free(struct rofftree *); static void roff_warn(const struct rofftree *, const char *, char *, ...); @@ -360,47 +357,33 @@ const char *const *tokargnames = tokargnamesp; int roff_free(struct rofftree *tree, int flush) { - int error, tok; + int error; + struct roffnode *n; - assert(tree->mbuf); - if ( ! flush) - tree->mbuf = NULL; + error = 0; - /* LINTED */ - while (tree->last) { - if (tree->last->parent) { - tok = tree->last->tok; - if (tokens[tok].ctx == 0) { - warnx("%s: closing out explicit scope " - "of `%s' from line %zu", - tree->rbuf->name, - toknames[tok], - tree->last->line); - tree->mbuf = NULL; - } + for (n = tree->last; n->parent; n = n->parent) + if (tokens[n->tok].ctx == 0) { + roff_warn(tree, NULL, "closing explicit scope " + "of `%s'", toknames[n->tok]); + error = 1; } - if ( ! (*tokens[tree->last->tok].cb) - (tree->last->tok, tree, NULL, ROFF_EXIT)) - /* Disallow flushing. */ - tree->mbuf = NULL; - } - error = tree->mbuf ? 0 : 1; - - if (tree->mbuf && (ROFF_PRELUDE & tree->state)) { - warnx("%s: prelude never finished", - tree->rbuf->name); + if (0 == error && (ROFF_PRELUDE & tree->state)) { + roff_warn(tree, NULL, "prelude never finished"); error = 1; } + while (tree->last) + roffnode_free(tree); + free(tree); return(error ? 0 : 1); } struct rofftree * -roff_alloc(const struct md_args *args, struct md_mbuf *out, - const struct md_rbuf *in, const struct roffcb *cb) +roff_alloc(const struct roffcb *cb, void *args) { struct rofftree *tree; @@ -408,10 +391,9 @@ roff_alloc(const struct md_args *args, struct md_mbuf *out, err(1, "calloc"); tree->state = ROFF_PRELUDE; - tree->args = args; - tree->mbuf = out; - tree->rbuf = in; - tree->cb = cb; + tree->arg = args; + + (void)memcpy(&tree->cb, cb, sizeof(struct roffcb)); return(tree); } @@ -550,18 +532,16 @@ roffparse(struct rofftree *tree, char *buf, size_t sz) */ if ( ! roffscan(tree->last->tok, tokens[tok].parents)) { - roff_err(tree, *argvp, "`%s' has invalid parent `%s' " - "from line %zu", toknames[tok], - toknames[tree->rbuf->line], - tree->rbuf->line); + roff_err(tree, *argvp, "`%s' has invalid parent `%s'", + toknames[tok], + toknames[tree->last->tok]); return(0); } if ( ! roffscan(tok, tokens[tree->last->tok].children)) { - roff_err(tree, *argvp, "`%s' is invalid child for " - "`%s' from line %zu", toknames[tok], - toknames[tree->rbuf->line], - tree->rbuf->line); + roff_err(tree, *argvp, "`%s' is invalid child `%s'", + toknames[tree->last->tok], + toknames[tok]); return(0); } @@ -717,7 +697,6 @@ roffnode_new(int tokid, struct rofftree *tree) if (NULL == (p = malloc(sizeof(struct roffnode)))) err(1, "malloc"); - p->line = tree->rbuf->line; p->tok = tokid; p->parent = tree->last; tree->last = p; @@ -743,12 +722,11 @@ roffargok(int tokid, int argid) static void -roffnode_free(int tokid, struct rofftree *tree) +roffnode_free(struct rofftree *tree) { struct roffnode *p; assert(tree->last); - assert(tree->last->tok == tokid); p = tree->last; tree->last = tree->last->parent; @@ -908,12 +886,10 @@ roff_layout(ROFFCALL_ARGS) } if (ROFF_EXIT == type) { - roffnode_free(tok, tree); - return((*tree->cb->roffblkout)(tree->args, tok)); + roffnode_free(tree); + return((*tree->cb.roffblkout)(tree->arg, tok)); } - assert(tree->mbuf); - i = 0; argv++; @@ -933,23 +909,19 @@ roff_layout(ROFFCALL_ARGS) if (NULL == roffnode_new(tok, tree)) return(0); - if ( ! (*tree->cb->roffin)(tree->args, tok, argcp, argvp)) + if ( ! (*tree->cb.roffin)(tree->arg, tok, argcp, argvp)) return(0); if ( ! (ROFF_PARSED & tokens[tok].flags)) { while (*argv) { - if ( ! md_buf_putstring(tree->mbuf, *argv++)) - return(0); - if ( ! md_buf_putchar(tree->mbuf, ' ')) + if ( ! (*tree->cb.roffdata) + (tree->arg, *argv++)) return(0); } - if ( ! md_buf_putchar(tree->mbuf, '\n')) - return(0); - - if ( ! ((*tree->cb->roffout)(tree->args, tok))) + if ( ! ((*tree->cb.roffout)(tree->arg, tok))) return(0); - return((*tree->cb->roffblkin)(tree->args, tok)); + return((*tree->cb.roffblkin)(tree->arg, tok)); } while (*argv) { @@ -965,18 +937,13 @@ roff_layout(ROFFCALL_ARGS) break; } - if ( ! md_buf_putstring(tree->mbuf, *argv++)) - return(0); - if ( ! md_buf_putchar(tree->mbuf, ' ')) + if ( ! (*tree->cb.roffdata)(tree->arg, *argv++)) return(0); } - if (NULL == *argv && ! md_buf_putchar(tree->mbuf, '\n')) - return(0); - - if ( ! ((*tree->cb->roffout)(tree->args, tok))) + if ( ! ((*tree->cb.roffout)(tree->arg, tok))) return(0); - return((*tree->cb->roffblkin)(tree->args, tok)); + return((*tree->cb.roffblkin)(tree->arg, tok)); } @@ -987,8 +954,6 @@ roff_text(ROFFCALL_ARGS) int i, c, argcp[ROFF_MAXARG]; char *v, *argvp[ROFF_MAXARG]; - assert(tree->mbuf); - if (ROFF_PRELUDE & tree->state) { roff_err(tree, *argv, "`%s' disallowed in prelude", toknames[tok]); @@ -1011,19 +976,15 @@ roff_text(ROFFCALL_ARGS) argcp[i] = ROFF_ARGMAX; argvp[i] = NULL; - if ( ! (*tree->cb->roffin)(tree->args, tok, argcp, argvp)) + if ( ! (*tree->cb.roffin)(tree->arg, tok, argcp, argvp)) return(0); if ( ! (ROFF_PARSED & tokens[tok].flags)) { while (*argv) { - if ( ! md_buf_putstring(tree->mbuf, *argv++)) - return(0); - if ( ! md_buf_putchar(tree->mbuf, ' ')) + if ( ! (*tree->cb.roffdata)(tree->arg, *argv++)) return(0); } - if ( ! md_buf_putchar(tree->mbuf, '\n')) - return(0); - return((*tree->cb->roffout)(tree->args, tok)); + return((*tree->cb.roffout)(tree->arg, tok)); } while (*argv) { @@ -1039,17 +1000,11 @@ roff_text(ROFFCALL_ARGS) return(0); break; } - - if ( ! md_buf_putstring(tree->mbuf, *argv++)) - return(0); - if ( ! md_buf_putchar(tree->mbuf, ' ')) + if ( ! (*tree->cb.roffdata)(tree->arg, *argv++)) return(0); } - if (NULL == *argv && ! md_buf_putchar(tree->mbuf, '\n')) - return(0); - - return((*tree->cb->roffout)(tree->args, tok)); + return((*tree->cb.roffout)(tree->arg, tok)); } @@ -1076,7 +1031,7 @@ static int roff_special(ROFFCALL_ARGS) { - return((*tree->cb->roffspecial)(tree->args, tok)); + return((*tree->cb.roffspecial)(tree->arg, tok)); } @@ -1090,8 +1045,8 @@ roff_warn(const struct rofftree *tree, const char *pos, char *fmt, ...) (void)vsnprintf(buf, sizeof(buf), fmt, ap); va_end(ap); - (*tree->cb->roffmsg)(tree->args, ROFF_WARN, tree->cur, pos, - tree->rbuf->name, tree->rbuf->line, buf); + (*tree->cb.roffmsg)(tree->arg, + ROFF_WARN, tree->cur, pos, buf); } @@ -1105,6 +1060,6 @@ roff_err(const struct rofftree *tree, const char *pos, char *fmt, ...) (void)vsnprintf(buf, sizeof(buf), fmt, ap); va_end(ap); - (*tree->cb->roffmsg)(tree->args, ROFF_ERROR, tree->cur, pos, - tree->rbuf->name, tree->rbuf->line, buf); + (*tree->cb.roffmsg)(tree->arg, + ROFF_ERROR, tree->cur, pos, buf); } -- 2.47.1