aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/mdoc_macro.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2010-05-30 21:28:30 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2010-05-30 21:28:30 +0000
commita09ab3c573cd4f51a974cccf58ffaaab60d080ef (patch)
tree7669d5b0eb2951eeadda5834dc967564fc9b0d90 /mdoc_macro.c
parent89acde071c972b5d612dcc42dd85d1d8ae6c3597 (diff)
downloadmandoc-a09ab3c573cd4f51a974cccf58ffaaab60d080ef.tar.gz
mandoc-a09ab3c573cd4f51a974cccf58ffaaab60d080ef.tar.zst
mandoc-a09ab3c573cd4f51a974cccf58ffaaab60d080ef.zip
First in several iterative patches in getting complex -column lists
supported (which works but is tricky enough that it should be broken down into digestable parts). This simply moves around the propogation of ARGS_PEND into one recognised by phrase(). Added a few regressions for simple -column lists.
Diffstat (limited to 'mdoc_macro.c')
-rw-r--r--mdoc_macro.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/mdoc_macro.c b/mdoc_macro.c
index a19bdd32..af3467a5 100644
--- a/mdoc_macro.c
+++ b/mdoc_macro.c
@@ -1,4 +1,4 @@
-/* $Id: mdoc_macro.c,v 1.70 2010/05/29 18:47:54 kristaps Exp $ */
+/* $Id: mdoc_macro.c,v 1.71 2010/05/30 21:28:30 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -1002,6 +1002,7 @@ blk_full(MACRO_PROT_ARGS)
}
ac = ARGS_ERROR;
+ lac = ARGS_PHRASE;
for ( ; ; ) {
la = *pos;
@@ -1013,16 +1014,10 @@ blk_full(MACRO_PROT_ARGS)
if (ARGS_EOLN == ac)
break;
- if (ARGS_PEND == ac) {
- if (ARGS_PPHRASE == lac)
- ac = ARGS_PPHRASE;
- else
- ac = ARGS_PHRASE;
- }
-
/* Don't emit leading punct. for phrases. */
if (NULL == head &&
+ ARGS_PEND != ac &&
ARGS_PHRASE != ac &&
ARGS_PPHRASE != ac &&
ARGS_QWORD != ac &&
@@ -1035,6 +1030,7 @@ blk_full(MACRO_PROT_ARGS)
/* Always re-open head for phrases. */
if (NULL == head ||
+ ARGS_PEND == ac ||
ARGS_PHRASE == ac ||
ARGS_PPHRASE == ac) {
if ( ! mdoc_head_alloc(m, line, ppos, tok))
@@ -1045,9 +1041,17 @@ blk_full(MACRO_PROT_ARGS)
if (ARGS_PHRASE == ac || ARGS_PPHRASE == ac) {
if (ARGS_PPHRASE == ac)
m->flags |= MDOC_PPHRASE;
- if ( ! phrase(m, line, la, buf, ac))
+ if (ARGS_PEND == ac && ARGS_PPHRASE == lac)
+ m->flags |= MDOC_PPHRASE;
+
+ if (ARGS_PEND == ac) {
+ if ( ! phrase(m, line, la, buf, lac))
+ return(0);
+ } else if ( ! phrase(m, line, la, buf, ac))
return(0);
+
m->flags &= ~MDOC_PPHRASE;
+
if ( ! rew_sub(MDOC_HEAD, m, tok, line, ppos))
return(0);
continue;