Skip to content

Commit 7140600

Browse files
matvoregitster
authored andcommitted
list-objects-filter: correct usage of ALLOC_GROW
In the sparse filter data, array_frame array is used in a way such that nr is the index of the last element. Fix this so that nr is actually the number of elements in the array. The filter_sparse_free function also has an unaddressed TODO to free the memory associated with the sparse filter data. Address that TODO and fix the memory leak. Signed-off-by: Matthew DeVore <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 8b10a20 commit 7140600

File tree

1 file changed

+9
-8
lines changed

1 file changed

+9
-8
lines changed

list-objects-filter.c

Lines changed: 9 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -270,13 +270,13 @@ static enum list_objects_filter_result filter_sparse(
270270
filename, &dtype, &filter_data->el,
271271
&the_index);
272272
if (val < 0)
273-
val = filter_data->array_frame[filter_data->nr].defval;
273+
val = filter_data->array_frame[filter_data->nr - 1].defval;
274274

275275
ALLOC_GROW(filter_data->array_frame, filter_data->nr + 1,
276276
filter_data->alloc);
277-
filter_data->nr++;
278277
filter_data->array_frame[filter_data->nr].defval = val;
279278
filter_data->array_frame[filter_data->nr].child_prov_omit = 0;
279+
filter_data->nr++;
280280

281281
/*
282282
* A directory with this tree OID may appear in multiple
@@ -301,16 +301,15 @@ static enum list_objects_filter_result filter_sparse(
301301

302302
case LOFS_END_TREE:
303303
assert(obj->type == OBJ_TREE);
304-
assert(filter_data->nr > 0);
304+
assert(filter_data->nr > 1);
305305

306-
frame = &filter_data->array_frame[filter_data->nr];
307-
filter_data->nr--;
306+
frame = &filter_data->array_frame[--filter_data->nr];
308307

309308
/*
310309
* Tell our parent directory if any of our children were
311310
* provisionally omitted.
312311
*/
313-
filter_data->array_frame[filter_data->nr].child_prov_omit |=
312+
filter_data->array_frame[filter_data->nr - 1].child_prov_omit |=
314313
frame->child_prov_omit;
315314

316315
/*
@@ -326,7 +325,7 @@ static enum list_objects_filter_result filter_sparse(
326325
assert(obj->type == OBJ_BLOB);
327326
assert((obj->flags & SEEN) == 0);
328327

329-
frame = &filter_data->array_frame[filter_data->nr];
328+
frame = &filter_data->array_frame[filter_data->nr - 1];
330329

331330
dtype = DT_REG;
332331
val = is_excluded_from_list(pathname, strlen(pathname),
@@ -367,7 +366,7 @@ static enum list_objects_filter_result filter_sparse(
367366
static void filter_sparse_free(void *filter_data)
368367
{
369368
struct filter_sparse_data *d = filter_data;
370-
/* TODO free contents of 'd' */
369+
free(d->array_frame);
371370
free(d);
372371
}
373372

@@ -386,6 +385,7 @@ static void *filter_sparse_oid__init(
386385
ALLOC_GROW(d->array_frame, d->nr + 1, d->alloc);
387386
d->array_frame[d->nr].defval = 0; /* default to include */
388387
d->array_frame[d->nr].child_prov_omit = 0;
388+
d->nr++;
389389

390390
*filter_fn = filter_sparse;
391391
*filter_free_fn = filter_sparse_free;
@@ -407,6 +407,7 @@ static void *filter_sparse_path__init(
407407
ALLOC_GROW(d->array_frame, d->nr + 1, d->alloc);
408408
d->array_frame[d->nr].defval = 0; /* default to include */
409409
d->array_frame[d->nr].child_prov_omit = 0;
410+
d->nr++;
410411

411412
*filter_fn = filter_sparse;
412413
*filter_free_fn = filter_sparse_free;

0 commit comments

Comments
 (0)