aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/argv.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2009-03-08 12:40:27 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2009-03-08 12:40:27 +0000
commit1969953cea0d27525c0c0b227d2021bd99952969 (patch)
tree214a5fda9483317024a70880bf3255df5594593b /argv.c
parentd53f3eea978ab62538513a30e29ca8c1da6f9c45 (diff)
downloadmandoc-1969953cea0d27525c0c0b227d2021bd99952969.tar.gz
mandoc-1969953cea0d27525c0c0b227d2021bd99952969.tar.zst
mandoc-1969953cea0d27525c0c0b227d2021bd99952969.zip
Memory fixes in new dynamic schema.
Diffstat (limited to 'argv.c')
-rw-r--r--argv.c27
1 files changed, 16 insertions, 11 deletions
diff --git a/argv.c b/argv.c
index e0ca69b9..9cd53503 100644
--- a/argv.c
+++ b/argv.c
@@ -1,4 +1,4 @@
-/* $Id: argv.c,v 1.39 2009/03/08 11:41:22 kristaps Exp $ */
+/* $Id: argv.c,v 1.40 2009/03/08 12:40:27 kristaps Exp $ */
/*
* Copyright (c) 2008 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -273,13 +273,13 @@ mdoc_argv(struct mdoc *mdoc, int line, int tok,
return(ARGV_ERROR);
if (NULL == (arg = *v)) {
- v = xcalloc(1, sizeof(struct mdoc_arg));
+ *v = xcalloc(1, sizeof(struct mdoc_arg));
arg = *v;
- }
+ }
arg->argc++;
arg->argv = xrealloc(arg->argv, arg->argc *
- sizeof(struct mdoc_arg));
+ sizeof(struct mdoc_argv));
(void)memcpy(&arg->argv[(int)arg->argc - 1],
&tmp, sizeof(struct mdoc_argv));
@@ -293,8 +293,13 @@ mdoc_argv_free(struct mdoc_arg *p)
{
int i, j;
- if (p->refcnt && --(p->refcnt) > 0)
- return;
+ if (p->refcnt) {
+ --(p->refcnt);
+ if (p->refcnt)
+ return;
+ }
+
+ assert(p->argc);
/* LINTED */
for (i = 0; i < (int)p->argc; i++) {
@@ -303,11 +308,11 @@ mdoc_argv_free(struct mdoc_arg *p)
/* LINTED */
for (j = 0; j < (int)p->argv[i].sz; j++)
free(p->argv[i].value[j]);
+
free(p->argv[i].value);
}
- if (p->argc)
- free(p->argv);
+ free(p->argv);
free(p);
}
@@ -742,7 +747,7 @@ argv_multi(struct mdoc *mdoc, int line,
v->value = xrealloc(v->value,
(v->sz + 5) * sizeof(char *));
- v->value[(int)v->sz] = p;
+ v->value[(int)v->sz] = xstrdup(p);
}
if (v->sz)
@@ -770,7 +775,7 @@ argv_opt_single(struct mdoc *mdoc, int line,
v->sz = 1;
v->value = xcalloc(1, sizeof(char *));
- v->value[0] = p;
+ v->value[0] = xstrdup(p);
return(1);
}
@@ -795,7 +800,7 @@ argv_single(struct mdoc *mdoc, int line,
v->sz = 1;
v->value = xcalloc(1, sizeof(char *));
- v->value[0] = p;
+ v->value[0] = xstrdup(p);
return(1);
}