make var_copy_regions not leaak (coverity)

This commit is contained in:
Enno Rehling 2020-08-16 21:17:23 +02:00
parent 740f4a568b
commit b4fb721db4
2 changed files with 34 additions and 18 deletions

View file

@ -1434,24 +1434,17 @@ enum {
TRAVEL_RUNNING TRAVEL_RUNNING
}; };
static arg_regions *var_copy_regions(const region_list * begin, int size) static void var_create_regions(arg_regions *dst, const region_list * begin, int size)
{ {
const region_list *rsrc; const region_list *rsrc;
int i;
if (size > 0) { dst->nregions = size;
int i = 0; dst->regions = (region **) malloc(sizeof(region *) * (size_t)size);
arg_regions *dst; assert_alloc(dst->regions);
assert(size > 0); for (i = 0, rsrc = begin; i != size; rsrc = rsrc->next, ++i) {
dst = (arg_regions *)malloc(sizeof(arg_regions) + sizeof(region *) * (size_t)size); dst->regions[i] = rsrc->data;
assert_alloc(dst);
dst->nregions = size;
dst->regions = (region **)(dst + 1);
for (rsrc = begin; i != size; rsrc = rsrc->next) {
dst->regions[i++] = rsrc->data;
}
return dst;
} }
return NULL;
} }
static const region_list *travel_route(unit * u, static const region_list *travel_route(unit * u,
@ -1612,9 +1605,14 @@ static const region_list *travel_route(unit * u,
/* Berichte ueber Durchreiseregionen */ /* Berichte ueber Durchreiseregionen */
if (mode != TRAVEL_TRANSPORTED) { if (mode != TRAVEL_TRANSPORTED) {
arg_regions *ar = var_copy_regions(route_begin, steps - 1); arg_regions *arp = NULL;
if (steps > 1) {
arg_regions ar;
arp = &ar;
var_create_regions(arp, route_begin, steps - 1);
}
ADDMSG(&u->faction->msgs, msg_message("travel", ADDMSG(&u->faction->msgs, msg_message("travel",
"unit mode start end regions", u, walkmode, r, current, ar)); "unit mode start end regions", u, walkmode, r, current, arp));
} }
mark_travelthru(u, r, route_begin, iroute); mark_travelthru(u, r, route_begin, iroute);

View file

@ -1761,9 +1761,27 @@ static void var_free_resources(variant x)
x.v = 0; x.v = 0;
} }
static variant var_copy_regions(variant x)
{
arg_regions *src = (arg_regions *)x.v;
if (src) {
arg_regions *dst;
x.v = dst = malloc(sizeof(arg_regions));
dst->nregions = src->nregions;
src->nregions = 0;
dst->regions = src->regions;
src->regions = NULL;
}
return x;
}
static void var_free_regions(variant x) /*-V524 */ static void var_free_regions(variant x) /*-V524 */
{ {
free(x.v); arg_regions *arg = (arg_regions *)x.v;
if (arg) {
free(arg->regions);
}
} }
const char *trailinto(const region * r, const struct locale *lang) const char *trailinto(const region * r, const struct locale *lang)
@ -2388,7 +2406,7 @@ void register_reports(void)
register_argtype("order", var_free_order, var_copy_order, VAR_VOIDPTR); register_argtype("order", var_free_order, var_copy_order, VAR_VOIDPTR);
register_argtype("resources", var_free_resources, var_copy_resources, VAR_VOIDPTR); register_argtype("resources", var_free_resources, var_copy_resources, VAR_VOIDPTR);
register_argtype("items", var_free_resources, var_copy_items, VAR_VOIDPTR); register_argtype("items", var_free_resources, var_copy_items, VAR_VOIDPTR);
register_argtype("regions", var_free_regions, NULL, VAR_VOIDPTR); register_argtype("regions", var_free_regions, var_copy_regions, VAR_VOIDPTR);
/* register functions that turn message contents to readable strings */ /* register functions that turn message contents to readable strings */
add_function("alliance", &eval_alliance); add_function("alliance", &eval_alliance);