diff options
| author | Patrick Steinhardt <ps@pks.im> | 2024-05-13 10:47:47 +0200 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2024-05-13 17:04:18 -0700 |
| commit | d76f0d3f57184e05eeabbe7bb382ae87149f0dd9 (patch) | |
| tree | d106fb7cc206d617f33d3e2a36f0a05a4ff2fcb2 /reftable/iter.c | |
| parent | 5bf96e0c393827481afab55d3b73ae09ec1ea0de (diff) | |
| download | git-d76f0d3f57184e05eeabbe7bb382ae87149f0dd9.tar.gz | |
reftable/generic: adapt interface to allow reuse of iterators
Refactor the interfaces exposed by `struct reftable_table` and `struct
reftable_iterator` such that they support iterator reuse. This is done
by separating initialization of the iterator and seeking on it.
Signed-off-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'reftable/iter.c')
| -rw-r--r-- | reftable/iter.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/reftable/iter.c b/reftable/iter.c index b4528fab47..fddea31e51 100644 --- a/reftable/iter.c +++ b/reftable/iter.c @@ -45,11 +45,11 @@ static int filtering_ref_iterator_next(void *iter_arg, if (fri->double_check) { struct reftable_iterator it = { NULL }; - err = reftable_table_seek_ref(&fri->tab, &it, - ref->refname); - if (err == 0) { + reftable_table_init_ref_iter(&fri->tab, &it); + + err = reftable_iterator_seek_ref(&it, ref->refname); + if (err == 0) err = reftable_iterator_next_ref(&it, ref); - } reftable_iterator_destroy(&it); |
