=================================================================== RCS file: /cvs/mandoc/Attic/macro.c,v retrieving revision 1.72 retrieving revision 1.76 diff -u -p -r1.72 -r1.76 --- mandoc/Attic/macro.c 2009/03/16 22:19:19 1.72 +++ mandoc/Attic/macro.c 2009/03/21 09:42:07 1.76 @@ -1,6 +1,6 @@ -/* $Id: macro.c,v 1.72 2009/03/16 22:19:19 kristaps Exp $ */ +/* $Id: macro.c,v 1.76 2009/03/21 09:42:07 kristaps Exp $ */ /* - * Copyright (c) 2008 Kristaps Dzonsons + * Copyright (c) 2008, 2009 Kristaps Dzonsons * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the @@ -197,6 +197,8 @@ const struct mdoc_macro __mdoc_macros[MDOC_MAX] = { { in_line_eoln, 0 }, /* %C */ { obsolete, 0 }, /* Es */ { obsolete, 0 }, /* En */ + { in_line_argn, MDOC_CALLABLE | MDOC_PARSED }, /* Dx */ + { in_line_eoln, 0 }, /* %Q */ }; const struct mdoc_macro * const mdoc_macros = __mdoc_macros; @@ -405,7 +407,13 @@ rew_alt(int tok) } -static int +/* + * Rewind rules. This indicates whether to stop rewinding + * (REWIND_HALT) without touching our current scope, stop rewinding and + * close our current scope (REWIND_REWIND), or continue (REWIND_NOHALT). + * The scope-closing and so on occurs in the various rew_* routines. + */ +static int rew_dohalt(int tok, enum mdoc_type type, const struct mdoc_node *p) { @@ -415,7 +423,6 @@ rew_dohalt(int tok, enum mdoc_type type, const struct return(REWIND_NOHALT); switch (tok) { - /* One-liner implicit-scope. */ case (MDOC_Aq): /* FALLTHROUGH */ case (MDOC_Bq): @@ -442,8 +449,6 @@ rew_dohalt(int tok, enum mdoc_type type, const struct if (type == p->type && tok == p->tok) return(REWIND_REWIND); break; - - /* Multi-line implicit-scope. */ case (MDOC_It): assert(MDOC_TAIL != type); if (type == p->type && tok == p->tok) @@ -462,8 +467,6 @@ rew_dohalt(int tok, enum mdoc_type type, const struct if (MDOC_BODY == p->type && MDOC_Sh == p->tok) return(REWIND_HALT); break; - - /* Multi-line explicit scope start. */ case (MDOC_Ao): /* FALLTHROUGH */ case (MDOC_Bd): @@ -543,6 +546,10 @@ rew_dohalt(int tok, enum mdoc_type type, const struct } +/* + * See if we can break an encountered scope (the rew_dohalt has returned + * REWIND_NOHALT). + */ static int rew_dobreak(int tok, const struct mdoc_node *p) { @@ -556,7 +563,6 @@ rew_dobreak(int tok, const struct mdoc_node *p) return(1); switch (tok) { - /* Implicit rules. */ case (MDOC_It): return(MDOC_It == p->tok); case (MDOC_Ss): @@ -565,12 +571,15 @@ rew_dobreak(int tok, const struct mdoc_node *p) if (MDOC_Ss == p->tok) return(1); return(MDOC_Sh == p->tok); - - /* Extra scope rules. */ case (MDOC_El): if (MDOC_It == p->tok) return(1); break; + case (MDOC_Oc): + /* XXX - experimental! */ + if (MDOC_Op == p->tok) + return(1); + break; default: break; } @@ -994,18 +1003,22 @@ static int blk_part_imp(MACRO_PROT_ARGS) { int lastarg, c; - char *p; + char *p; + struct mdoc_node *blk, *body, *n; if ( ! mdoc_block_alloc(mdoc, line, ppos, tok, NULL)) return(0); mdoc->next = MDOC_NEXT_CHILD; + blk = mdoc->last; if ( ! mdoc_head_alloc(mdoc, line, ppos, tok)) return(0); mdoc->next = MDOC_NEXT_SIBLING; + if ( ! mdoc_body_alloc(mdoc, line, ppos, tok)) return(0); mdoc->next = MDOC_NEXT_CHILD; + body = mdoc->last; /* XXX - no known argument macros. */ @@ -1035,14 +1048,26 @@ blk_part_imp(MACRO_PROT_ARGS) break; } - if (1 == ppos) { - if ( ! rew_subblock(MDOC_BODY, mdoc, tok, line, ppos)) - return(0); - if ( ! append_delims(mdoc, line, pos, buf)) - return(0); - } else if ( ! rew_subblock(MDOC_BODY, mdoc, tok, line, ppos)) + /* + * Since we know what our context is, we can rewind directly to + * it. This allows us to accomodate for our scope being + * violated by another token. + */ + + for (n = mdoc->last; n; n = n->parent) + if (body == n) + break; + + if (n && ! rew_last(mdoc, body)) return(0); - return(rew_impblock(mdoc, tok, line, ppos)); + + if (1 == ppos && ! append_delims(mdoc, line, pos, buf)) + return(0); + + if (n && ! rew_last(mdoc, blk)) + return(0); + + return(1); }