summaryrefslogtreecommitdiffstats
path: root/mdoc_argv.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2009-08-20 08:59:12 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2009-08-20 08:59:12 +0000
commit715664aab2d78bfca25251802a317ec3d515ddf3 (patch)
treea31f6a986b9b1346b4afc83b2ce05ed14084c00f /mdoc_argv.c
parent077b83403c555a1a2160ae7dfb7439e5ae84c96d (diff)
downloadmandoc-715664aab2d78bfca25251802a317ec3d515ddf3.tar.gz
Delimiter whitespace is correctly flagged (required some special handling).
Diffstat (limited to 'mdoc_argv.c')
-rw-r--r--mdoc_argv.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/mdoc_argv.c b/mdoc_argv.c
index 0cb36ff9..adafc7b1 100644
--- a/mdoc_argv.c
+++ b/mdoc_argv.c
@@ -32,9 +32,6 @@
* There's no limit to the number or arguments that may be allocated.
*/
-#define ARGS_DELIM (1 << 1)
-#define ARGS_TABSEP (1 << 2)
-
#define ARGV_NONE (1 << 0)
#define ARGV_SINGLE (1 << 1)
#define ARGV_MULTI (1 << 2)
@@ -325,10 +322,11 @@ mdoc_argv_free(struct mdoc_arg *p)
int
-mdoc_zargs(struct mdoc *m, int line, int *pos, char *buf, char **v)
+mdoc_zargs(struct mdoc *m, int line, int *pos,
+ char *buf, int flags, char **v)
{
- return(args(m, line, pos, buf, 0, v));
+ return(args(m, line, pos, buf, flags, v));
}
@@ -401,10 +399,14 @@ args(struct mdoc *m, int line, int *pos,
i++;
}
- /* FIXME: warn about trailing whitespace. */
-
if (0 == buf[i]) {
*v = &buf[*pos];
+ if (' ' != buf[i - 1])
+ return(ARGS_PUNCT);
+ if (ARGS_NOWARN & fl)
+ return(ARGS_PUNCT);
+ if ( ! mdoc_pwarn(m, line, *pos, ETAILWS))
+ return(ARGS_ERROR);
return(ARGS_PUNCT);
}
}
@@ -448,7 +450,7 @@ args(struct mdoc *m, int line, int *pos,
p = strchr(*v, 0);
/* Whitespace check for eoln case... */
- if (0 == *p && ' ' == *(p - 1))
+ if (0 == *p && ' ' == *(p - 1) && ! (ARGS_NOWARN & fl))
if ( ! mdoc_pwarn(m, line, *pos, ETAILWS))
return(ARGS_ERROR);
@@ -488,6 +490,8 @@ args(struct mdoc *m, int line, int *pos,
}
if (0 == buf[*pos]) {
+ if (ARGS_NOWARN & fl)
+ return(ARGS_QWORD);
if ( ! mdoc_pwarn(m, line, *pos, EQUOTTERM))
return(ARGS_ERROR);
return(ARGS_QWORD);
@@ -501,7 +505,7 @@ args(struct mdoc *m, int line, int *pos,
while (' ' == buf[*pos])
(*pos)++;
- if (0 == buf[*pos])
+ if (0 == buf[*pos] && ! (ARGS_NOWARN & fl))
if ( ! mdoc_pwarn(m, line, *pos, ETAILWS))
return(ARGS_ERROR);
@@ -525,7 +529,7 @@ args(struct mdoc *m, int line, int *pos,
while (' ' == buf[*pos])
(*pos)++;
- if (0 == buf[*pos])
+ if (0 == buf[*pos] && ! (ARGS_NOWARN & fl))
if ( ! mdoc_pwarn(m, line, *pos, ETAILWS))
return(ARGS_ERROR);