forked from github/server
make var_copy_regions not leaak (coverity)
This commit is contained in:
parent
740f4a568b
commit
b4fb721db4
2 changed files with 34 additions and 18 deletions
30
src/move.c
30
src/move.c
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in a new issue