=================================================================== RCS file: /cvs/mandoc/Attic/dummy.c,v retrieving revision 1.7 retrieving revision 1.10 diff -u -p -r1.7 -r1.10 --- mandoc/Attic/dummy.c 2008/11/26 16:50:34 1.7 +++ mandoc/Attic/dummy.c 2008/11/27 17:27:50 1.10 @@ -1,4 +1,4 @@ -/* $Id: dummy.c,v 1.7 2008/11/26 16:50:34 kristaps Exp $ */ +/* $Id: dummy.c,v 1.10 2008/11/27 17:27:50 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -29,10 +29,18 @@ #define strlcat strncat #endif -static int md_dummy_blk_in(int); -static int md_dummy_blk_out(int); -static int md_dummy_text_in(int, int *, char **); -static int md_dummy_text_out(int); +static int md_dummy_blk_in(const struct md_args *, int); +static int md_dummy_blk_out(const struct md_args *, int); +static int md_dummy_text_in(const struct md_args *, int, + int *, char **); +static int md_dummy_text_out(const struct md_args *, int); +static int md_dummy_special(int); +static int md_dummy_head(void); +static int md_dummy_tail(void); +static void md_dummy_msg(const struct md_args *, + enum roffmsg, const char *, + const char *, const char *, + int, char *); static void dbg_prologue(const char *); static void dbg_epilogue(void); @@ -45,6 +53,62 @@ struct md_dummy { struct roffcb cb; }; + +int +md_line_dummy(void *arg, char *buf, size_t sz) +{ + struct md_dummy *p; + + p = (struct md_dummy *)arg; + return(roff_engine(p->tree, buf, sz)); +} + + +int +md_exit_dummy(void *data, int flush) +{ + int c; + struct md_dummy *p; + + p = (struct md_dummy *)data; + c = roff_free(p->tree, flush); + free(p); + + return(c); +} + + +void * +md_init_dummy(const struct md_args *args, + struct md_mbuf *mbuf, const struct md_rbuf *rbuf) +{ + struct md_dummy *p; + + if (NULL == (p = malloc(sizeof(struct md_dummy)))) { + warn("malloc"); + return(NULL); + } + + p->cb.roffhead = md_dummy_head; + p->cb.rofftail = md_dummy_tail; + p->cb.roffin = md_dummy_text_in; + p->cb.roffout = md_dummy_text_out; + p->cb.roffblkin = md_dummy_blk_in; + p->cb.roffblkout = md_dummy_blk_out; + p->cb.roffspecial = md_dummy_special; + p->cb.roffmsg = md_dummy_msg; + + p->tree = roff_alloc(args, mbuf, rbuf, &p->cb); + + if (NULL == p->tree) { + free(p); + return(NULL); + } + + return(p); +} + + static void dbg_prologue(const char *p) { @@ -68,9 +132,40 @@ dbg_epilogue(void) static int -md_dummy_blk_in(int tok) +md_dummy_head(void) { + return(1); +} + + +static int +md_dummy_tail(void) +{ + + return(1); +} + + +static int +md_dummy_special(int tok) +{ + + dbg_prologue("noop"); + (void)strlcat(dbg_line, toknames[tok], sizeof(dbg_line) - 1); + dbg_epilogue(); + + return(1); +} + + +static int +md_dummy_blk_in(const struct md_args *args, int tok) +{ + + if (args->verbosity < 1) + return(1); + dbg_prologue("blk"); (void)strlcat(dbg_line, toknames[tok], sizeof(dbg_line) - 1); dbg_epilogue(); @@ -81,19 +176,25 @@ md_dummy_blk_in(int tok) static int -md_dummy_blk_out(int tok) +md_dummy_blk_out(const struct md_args *args, int tok) { + if (args->verbosity < 1) + return(1); + dbg_lvl--; return(1); } -/* ARGSUSED */ static int -md_dummy_text_in(int tok, int *argcp, char **argvp) +md_dummy_text_in(const struct md_args *args, + int tok, int *argcp, char **argvp) { + if (args->verbosity < 1) + return(1); + dbg_prologue("text"); (void)strlcat(dbg_line, toknames[tok], sizeof(dbg_line) - 1); (void)strlcat(dbg_line, " ", sizeof(dbg_line) - 1); @@ -119,61 +220,32 @@ md_dummy_text_in(int tok, int *argcp, char **argvp) static int -md_dummy_text_out(int tok) +md_dummy_text_out(const struct md_args *args, int tok) { return(1); } -int -md_line_dummy(void *arg, char *buf, size_t sz) +static void +md_dummy_msg(const struct md_args *args, enum roffmsg lvl, + const char *buf, const char *pos, + const char *name, int line, char *msg) { - struct md_dummy *p; + char *p; - p = (struct md_dummy *)arg; - return(roff_engine(p->tree, buf, sz)); -} - - -int -md_exit_dummy(void *data, int flush) -{ - int c; - struct md_dummy *p; - - p = (struct md_dummy *)data; - c = roff_free(p->tree, flush); - free(p); - - return(c); -} - - -void * -md_init_dummy(const struct md_args *args, - struct md_mbuf *mbuf, const struct md_rbuf *rbuf) -{ - struct md_dummy *p; - - if (NULL == (p = malloc(sizeof(struct md_dummy)))) { - warn("malloc"); - return(NULL); + switch (lvl) { + case (ROFF_WARN): + if ( ! (MD_WARN_ALL & args->warnings)) + return; + p = "warning"; + break; + case (ROFF_ERROR): + p = "error"; + break; } - p->cb.roffhead = NULL; - p->cb.rofftail = NULL; - p->cb.roffin = md_dummy_text_in; - p->cb.roffout = md_dummy_text_out; - p->cb.roffblkin = md_dummy_blk_in; - p->cb.roffblkout = md_dummy_blk_out; - - p->tree = roff_alloc(args, mbuf, rbuf, &p->cb); - - if (NULL == p->tree) { - free(p); - return(NULL); - } - - return(p); + assert(pos >= buf); + (void)fprintf(stderr, "%s:%d: %s: %s\n", name, line, p, msg); } +