aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/man_macro.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2015-02-06 11:54:36 +0000
committerIngo Schwarze <schwarze@openbsd.org>2015-02-06 11:54:36 +0000
commit70a62057d81d665dae089691140a2714bd510348 (patch)
treeb185288c4c94bfce1a688ffe35c19fe8813d2099 /man_macro.c
parent21757403990ffaeb488a62351a28bc9c74eef267 (diff)
downloadmandoc-70a62057d81d665dae089691140a2714bd510348.tar.gz
mandoc-70a62057d81d665dae089691140a2714bd510348.tar.zst
mandoc-70a62057d81d665dae089691140a2714bd510348.zip
better error reporting regarding .OP .RS .UR .TH arguments
Diffstat (limited to 'man_macro.c')
-rw-r--r--man_macro.c28
1 files changed, 11 insertions, 17 deletions
diff --git a/man_macro.c b/man_macro.c
index 96f3f581..c86ab6f1 100644
--- a/man_macro.c
+++ b/man_macro.c
@@ -1,4 +1,4 @@
-/* $Id: man_macro.c,v 1.97 2015/02/06 09:38:43 schwarze Exp $ */
+/* $Id: man_macro.c,v 1.98 2015/02/06 11:54:36 schwarze Exp $ */
/*
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2012, 2013, 2014, 2015 Ingo Schwarze <schwarze@openbsd.org>
@@ -337,31 +337,25 @@ blk_close(MACRO_PROT_ARGS)
void
blk_exp(MACRO_PROT_ARGS)
{
- struct man_node *n;
- int la;
+ struct man_node *head;
char *p;
+ int la;
rew_scope(MAN_BLOCK, man, tok);
man_block_alloc(man, line, ppos, tok);
man_head_alloc(man, line, ppos, tok);
+ head = man->last;
- for (;;) {
- la = *pos;
- if ( ! man_args(man, line, pos, buf, &p))
- break;
+ la = *pos;
+ if (man_args(man, line, pos, buf, &p))
man_word_alloc(man, line, la, p);
- }
-
- assert(man);
- assert(tok != MAN_MAX);
- for (n = man->last; n; n = n->parent)
- if (n->tok == tok) {
- assert(n->type == MAN_HEAD);
- man_unscope(man, n);
- break;
- }
+ if (buf[*pos] != '\0')
+ mandoc_vmsg(MANDOCERR_ARG_EXCESS,
+ man->parse, line, *pos, "%s ... %s",
+ man_macronames[tok], buf + *pos);
+ man_unscope(man, head);
man_body_alloc(man, line, ppos, tok);
}