Skip to content

Commit 43f40de

Browse files
committed
Merge branch 'md/list-objects-filter-memfix' into maint
The filter_data used in the list-objects-filter (which manages a lazily sparse clone repository) did not use the dynamic array API correctly---'nr' is supposed to point at one past the last element of the array in use. This has been corrected. * md/list-objects-filter-memfix: list-objects-filter: correct usage of ALLOC_GROW
2 parents f54a2a8 + 7140600 commit 43f40de

File tree

1 file changed

+8
-8
lines changed

1 file changed

+8
-8
lines changed

list-objects-filter.c

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -356,13 +356,13 @@ static enum list_objects_filter_result filter_sparse(
356356
filename, &dtype, &filter_data->el,
357357
r->index);
358358
if (val < 0)
359-
val = filter_data->array_frame[filter_data->nr].defval;
359+
val = filter_data->array_frame[filter_data->nr - 1].defval;
360360

361361
ALLOC_GROW(filter_data->array_frame, filter_data->nr + 1,
362362
filter_data->alloc);
363-
filter_data->nr++;
364363
filter_data->array_frame[filter_data->nr].defval = val;
365364
filter_data->array_frame[filter_data->nr].child_prov_omit = 0;
365+
filter_data->nr++;
366366

367367
/*
368368
* A directory with this tree OID may appear in multiple
@@ -387,16 +387,15 @@ static enum list_objects_filter_result filter_sparse(
387387

388388
case LOFS_END_TREE:
389389
assert(obj->type == OBJ_TREE);
390-
assert(filter_data->nr > 0);
390+
assert(filter_data->nr > 1);
391391

392-
frame = &filter_data->array_frame[filter_data->nr];
393-
filter_data->nr--;
392+
frame = &filter_data->array_frame[--filter_data->nr];
394393

395394
/*
396395
* Tell our parent directory if any of our children were
397396
* provisionally omitted.
398397
*/
399-
filter_data->array_frame[filter_data->nr].child_prov_omit |=
398+
filter_data->array_frame[filter_data->nr - 1].child_prov_omit |=
400399
frame->child_prov_omit;
401400

402401
/*
@@ -412,7 +411,7 @@ static enum list_objects_filter_result filter_sparse(
412411
assert(obj->type == OBJ_BLOB);
413412
assert((obj->flags & SEEN) == 0);
414413

415-
frame = &filter_data->array_frame[filter_data->nr];
414+
frame = &filter_data->array_frame[filter_data->nr - 1];
416415

417416
dtype = DT_REG;
418417
val = is_excluded_from_list(pathname, strlen(pathname),
@@ -453,7 +452,7 @@ static enum list_objects_filter_result filter_sparse(
453452
static void filter_sparse_free(void *filter_data)
454453
{
455454
struct filter_sparse_data *d = filter_data;
456-
/* TODO free contents of 'd' */
455+
free(d->array_frame);
457456
free(d);
458457
}
459458

@@ -472,6 +471,7 @@ static void *filter_sparse_oid__init(
472471
ALLOC_GROW(d->array_frame, d->nr + 1, d->alloc);
473472
d->array_frame[d->nr].defval = 0; /* default to include */
474473
d->array_frame[d->nr].child_prov_omit = 0;
474+
d->nr++;
475475

476476
*filter_fn = filter_sparse;
477477
*filter_free_fn = filter_sparse_free;

0 commit comments

Comments
 (0)