=================================================================== RCS file: /cvs/mandoc/Attic/argv.c,v retrieving revision 1.46 retrieving revision 1.49 diff -u -p -r1.46 -r1.49 --- mandoc/Attic/argv.c 2009/03/10 15:01:54 1.46 +++ mandoc/Attic/argv.c 2009/03/12 02:57:35 1.49 @@ -1,4 +1,4 @@ -/* $Id: argv.c,v 1.46 2009/03/10 15:01:54 kristaps Exp $ */ +/* $Id: argv.c,v 1.49 2009/03/12 02:57:35 kristaps Exp $ */ /* * Copyright (c) 2008 Kristaps Dzonsons * @@ -213,6 +213,9 @@ static int mdoc_argflags[MDOC_MAX] = { ARGS_DELIM, /* Lp */ ARGS_DELIM | ARGS_QUOTED, /* Lk */ ARGS_DELIM | ARGS_QUOTED, /* Mt */ + ARGS_DELIM, /* Brq */ + 0, /* Bro */ + ARGS_DELIM, /* Brc */ }; @@ -253,9 +256,11 @@ mdoc_argv(struct mdoc *mdoc, int line, int tok, /* * XXX: save the nullified byte as we'll restore it if this - * doesn't end up being a command after all. + * doesn't end up being a command after all. This is a little + * bit hacky. I don't like it, but it works for now. */ + sv = 0; if (buf[*pos]) { sv = buf[*pos]; buf[(*pos)++] = 0; @@ -272,8 +277,9 @@ mdoc_argv(struct mdoc *mdoc, int line, int tok, */ if (MDOC_ARG_MAX == (tmp.arg = argv_a2arg(tok, p))) { - /* Restore saved byte. */ - buf[*pos - 1] = sv; + /* XXX - restore saved byte. */ + if (sv) + buf[*pos - 1] = sv; if ( ! pwarn(mdoc, line, i, WARGVPARM)) return(ARGV_ERROR); return(ARGV_WORD); @@ -570,7 +576,7 @@ args(struct mdoc *mdoc, int line, return(0); if (p) - return(ARGS_WORD); + return(ARGS_PHRASE); /* Configure the eoln case, too. */ @@ -582,7 +588,7 @@ args(struct mdoc *mdoc, int line, return(0); *pos += (int)(p - *v); - return(ARGS_WORD); + return(ARGS_PHRASE); } /* Do non-tabsep look-ahead here. */ @@ -682,6 +688,8 @@ argv_a2arg(int tok, const char *argv) return(MDOC_File); else if (xstrcmp(argv, "offset")) return(MDOC_Offset); + else if (xstrcmp(argv, "compact")) + return(MDOC_Compact); break; case (MDOC_Bf):