aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/mdoc_macro.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2012-01-02 15:48:05 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2012-01-02 15:48:05 +0000
commit0063d2a7bca693266f0e8bf45e0bb7790a356048 (patch)
tree8d7b6d986a4ac112e081f011e22a24d9db190637 /mdoc_macro.c
parent95486df829fe5c6101c46a06f073c025f0f27170 (diff)
downloadmandoc-0063d2a7bca693266f0e8bf45e0bb7790a356048.tar.gz
mandoc-0063d2a7bca693266f0e8bf45e0bb7790a356048.tar.zst
mandoc-0063d2a7bca693266f0e8bf45e0bb7790a356048.zip
`-diag' lists aren't parsed, unlike other list types. This fixes a TODO
entry raised by deraadt@.
Diffstat (limited to 'mdoc_macro.c')
-rw-r--r--mdoc_macro.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/mdoc_macro.c b/mdoc_macro.c
index c1ab436a..6b818754 100644
--- a/mdoc_macro.c
+++ b/mdoc_macro.c
@@ -1,4 +1,4 @@
-/* $Id: mdoc_macro.c,v 1.113 2011/12/03 23:59:14 schwarze Exp $ */
+/* $Id: mdoc_macro.c,v 1.114 2012/01/02 15:48:05 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2010 Ingo Schwarze <schwarze@openbsd.org>
@@ -228,7 +228,6 @@ mdoc_macroend(struct mdoc *m)
static enum mdoct
lookup(enum mdoct from, const char *p)
{
- /* FIXME: make -diag lists be un-PARSED. */
if ( ! (MDOC_PARSED & mdoc_macros[from].flags))
return(MDOC_MAX);
@@ -984,7 +983,7 @@ in_line(MACRO_PROT_ARGS)
static int
blk_full(MACRO_PROT_ARGS)
{
- int la, nl;
+ int la, nl, nparsed;
struct mdoc_arg *arg;
struct mdoc_node *head; /* save of head macro */
struct mdoc_node *body; /* save of body macro */
@@ -995,6 +994,16 @@ blk_full(MACRO_PROT_ARGS)
enum margverr av;
char *p;
+ /*
+ * Exception: `-diag' lists are not parsed, but lists in general
+ * are parsed.
+ */
+ nparsed = 0;
+ if (MDOC_It == tok && NULL != m->last &&
+ MDOC_Bl == m->last->tok &&
+ LIST_diag == m->last->norm->Bl.type)
+ nparsed = 1;
+
nl = MDOC_NEWLINE & m->flags;
/* Close out prior implicit scope. */
@@ -1146,7 +1155,8 @@ blk_full(MACRO_PROT_ARGS)
continue;
}
- ntok = ARGS_QWORD == ac ? MDOC_MAX : lookup(tok, p);
+ ntok = nparsed || ARGS_QWORD == ac ?
+ MDOC_MAX : lookup(tok, p);
if (MDOC_MAX == ntok) {
if ( ! dword(m, line, la, p, DELIM_MAX))