]> git.ipfire.org Git - thirdparty/git.git/commitdiff
reftable/merged: handle subiter cleanup on close only
authorPatrick Steinhardt <ps@pks.im>
Mon, 4 Mar 2024 10:49:08 +0000 (11:49 +0100)
committerJunio C Hamano <gitster@pobox.com>
Mon, 4 Mar 2024 18:19:39 +0000 (10:19 -0800)
When advancing one of the subiters fails we immediately release
resources associated with that subiter. This is not necessary though as
we will release these resources when closing the merged iterator anyway.

Drop the logic and only release resources when the merged iterator is
done. This is a mere cleanup that should help reduce the cognitive load
when reading through the code.

Signed-off-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
reftable/merged.c

index 29ad09f3d87c12c94405ee8899ea371ea642ff11..d9ed4a19dd689ffefdaba0f95c3a516d15921bf2 100644 (file)
@@ -46,11 +46,8 @@ static int merged_iter_init(struct merged_iter *mi)
                                    &mi->subiters[i].rec);
                if (err < 0)
                        return err;
-               if (err > 0) {
-                       reftable_iterator_destroy(&mi->subiters[i].iter);
-                       reftable_record_release(&mi->subiters[i].rec);
+               if (err > 0)
                        continue;
-               }
 
                merged_iter_pqueue_add(&mi->pq, &e);
        }
@@ -79,13 +76,8 @@ static int merged_iter_advance_subiter(struct merged_iter *mi, size_t idx)
        int err;
 
        err = iterator_next(&mi->subiters[idx].iter, &mi->subiters[idx].rec);
-       if (err < 0)
+       if (err)
                return err;
-       if (err > 0) {
-               reftable_iterator_destroy(&mi->subiters[idx].iter);
-               reftable_record_release(&mi->subiters[idx].rec);
-               return 0;
-       }
 
        merged_iter_pqueue_add(&mi->pq, &e);
        return 0;