-/* $Id: mdoc_argv.c,v 1.1 2009/03/27 15:00:15 kristaps Exp $ */
+/* $Id: mdoc_argv.c,v 1.2 2009/03/31 13:50:19 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@openbsd.org>
*
#include <assert.h>
#include <ctype.h>
-#include <err.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
enum merr {
EQUOTTERM,
+ EMALLOC,
EARGVAL
};
static int pwarn(struct mdoc *, int, int, enum mwarn);
static int perr(struct mdoc *, int, int, enum merr);
+#define verr(m, t) perr((m), (m)->last->line, (m)->last->pos, (t))
+
/* Per-argument flags. */
static int mdoc_argvflags[MDOC_ARG_MAX] = {
return(ARGV_ERROR);
if (NULL == (arg = *v)) {
- if (NULL == (*v = calloc(1, sizeof(struct mdoc_arg))))
- err(1, "calloc");
+ *v = calloc(1, sizeof(struct mdoc_arg));
+ if (NULL == *v) {
+ (void)verr(mdoc, EMALLOC);
+ return(ARGV_ERROR);
+ }
arg = *v;
}
arg->argc++;
- arg->argv = xrealloc(arg->argv, arg->argc *
+ arg->argv = realloc(arg->argv, arg->argc *
sizeof(struct mdoc_argv));
+ if (NULL == arg->argv) {
+ (void)verr(mdoc, EMALLOC);
+ return(ARGV_ERROR);
+ }
+
(void)memcpy(&arg->argv[(int)arg->argc - 1],
&tmp, sizeof(struct mdoc_argv));
if (p->refcnt)
return;
}
-
assert(p->argc);
/* LINTED */
char *p;
p = NULL;
-
switch (code) {
+ case (EMALLOC):
+ p = "memory exhausted";
+ break;
case (EQUOTTERM):
p = "unterminated quoted parameter";
break;
p = "argument requires a value";
break;
}
-
assert(p);
return(mdoc_perr(mdoc, line, pos, p));
}
p = NULL;
c = WARN_SYNTAX;
-
switch (code) {
case (WQUOTPARM):
p = "unexpected quoted parameter";
c = WARN_COMPAT;
break;
}
-
assert(p);
return(mdoc_pwarn(mdoc, line, pos, c, p));
}
switch (tok) {
case (MDOC_An):
- if (xstrcmp(argv, "split"))
+ if (0 == strcmp(argv, "split"))
return(MDOC_Split);
- else if (xstrcmp(argv, "nosplit"))
+ else if (0 == strcmp(argv, "nosplit"))
return(MDOC_Nosplit);
break;
case (MDOC_Bd):
- if (xstrcmp(argv, "ragged"))
+ if (0 == strcmp(argv, "ragged"))
return(MDOC_Ragged);
- else if (xstrcmp(argv, "unfilled"))
+ else if (0 == strcmp(argv, "unfilled"))
return(MDOC_Unfilled);
- else if (xstrcmp(argv, "filled"))
+ else if (0 == strcmp(argv, "filled"))
return(MDOC_Filled);
- else if (xstrcmp(argv, "literal"))
+ else if (0 == strcmp(argv, "literal"))
return(MDOC_Literal);
- else if (xstrcmp(argv, "file"))
+ else if (0 == strcmp(argv, "file"))
return(MDOC_File);
- else if (xstrcmp(argv, "offset"))
+ else if (0 == strcmp(argv, "offset"))
return(MDOC_Offset);
- else if (xstrcmp(argv, "compact"))
+ else if (0 == strcmp(argv, "compact"))
return(MDOC_Compact);
break;
case (MDOC_Bf):
- if (xstrcmp(argv, "emphasis"))
+ if (0 == strcmp(argv, "emphasis"))
return(MDOC_Emphasis);
- else if (xstrcmp(argv, "literal"))
+ else if (0 == strcmp(argv, "literal"))
return(MDOC_Literal);
- else if (xstrcmp(argv, "symbolic"))
+ else if (0 == strcmp(argv, "symbolic"))
return(MDOC_Symbolic);
break;
case (MDOC_Bk):
- if (xstrcmp(argv, "words"))
+ if (0 == strcmp(argv, "words"))
return(MDOC_Words);
break;
case (MDOC_Bl):
- if (xstrcmp(argv, "bullet"))
+ if (0 == strcmp(argv, "bullet"))
return(MDOC_Bullet);
- else if (xstrcmp(argv, "dash"))
+ else if (0 == strcmp(argv, "dash"))
return(MDOC_Dash);
- else if (xstrcmp(argv, "hyphen"))
+ else if (0 == strcmp(argv, "hyphen"))
return(MDOC_Hyphen);
- else if (xstrcmp(argv, "item"))
+ else if (0 == strcmp(argv, "item"))
return(MDOC_Item);
- else if (xstrcmp(argv, "enum"))
+ else if (0 == strcmp(argv, "enum"))
return(MDOC_Enum);
- else if (xstrcmp(argv, "tag"))
+ else if (0 == strcmp(argv, "tag"))
return(MDOC_Tag);
- else if (xstrcmp(argv, "diag"))
+ else if (0 == strcmp(argv, "diag"))
return(MDOC_Diag);
- else if (xstrcmp(argv, "hang"))
+ else if (0 == strcmp(argv, "hang"))
return(MDOC_Hang);
- else if (xstrcmp(argv, "ohang"))
+ else if (0 == strcmp(argv, "ohang"))
return(MDOC_Ohang);
- else if (xstrcmp(argv, "inset"))
+ else if (0 == strcmp(argv, "inset"))
return(MDOC_Inset);
- else if (xstrcmp(argv, "column"))
+ else if (0 == strcmp(argv, "column"))
return(MDOC_Column);
- else if (xstrcmp(argv, "width"))
+ else if (0 == strcmp(argv, "width"))
return(MDOC_Width);
- else if (xstrcmp(argv, "offset"))
+ else if (0 == strcmp(argv, "offset"))
return(MDOC_Offset);
- else if (xstrcmp(argv, "compact"))
+ else if (0 == strcmp(argv, "compact"))
return(MDOC_Compact);
- else if (xstrcmp(argv, "nested"))
+ else if (0 == strcmp(argv, "nested"))
return(MDOC_Nested);
break;
case (MDOC_Rv):
/* FALLTHROUGH */
case (MDOC_Ex):
- if (xstrcmp(argv, "std"))
+ if (0 == strcmp(argv, "std"))
return(MDOC_Std);
break;
default:
else if (ARGS_EOLN == c)
break;
- if (0 == v->sz % MULTI_STEP)
- v->value = xrealloc(v->value,
+ if (0 == v->sz % MULTI_STEP) {
+ v->value = realloc(v->value,
(v->sz + MULTI_STEP) * sizeof(char *));
+ if (NULL == v->value) {
+ (void)verr(mdoc, EMALLOC);
+ return(ARGV_ERROR);
+ }
+ }
if (NULL == (v->value[(int)v->sz] = strdup(p)))
- err(1, "strdup");
+ return(verr(mdoc, EMALLOC));
}
if (v->sz)
v->sz = 1;
if (NULL == (v->value = calloc(1, sizeof(char *))))
- err(1, "calloc");
+ return(verr(mdoc, EMALLOC));
if (NULL == (v->value[0] = strdup(p)))
- err(1, "strdup");
+ return(verr(mdoc, EMALLOC));
+
return(1);
}
v->sz = 1;
if (NULL == (v->value = calloc(1, sizeof(char *))))
- err(1, "calloc");
+ return(verr(mdoc, EMALLOC));
if (NULL == (v->value[0] = strdup(p)))
- err(1, "strdup");
+ return(verr(mdoc, EMALLOC));
+
return(1);
}