]> git.ipfire.org Git - thirdparty/git.git/commitdiff
reftable: adapt writer_add_record() to propagate block_writer_add() errors
authorMeet Soni <meetsoni3017@gmail.com>
Wed, 19 Mar 2025 15:29:26 +0000 (20:59 +0530)
committerJunio C Hamano <gitster@pobox.com>
Fri, 21 Mar 2025 08:51:07 +0000 (01:51 -0700)
Previously, writer_add_record() would flush the current block and retry
appending the record whenever block_writer_add() returned any nonzero
error. This forced an assumption that every failure meant the block was
full, even when errors such as memory allocation or I/O failures occurred.

Update the writer_add_record() to inspect the error code returned by
block_writer_add() and only flush and reinitialize the writer when the
error is REFTABLE_ENTRY_TOO_BIG_ERROR. For any other error, immediately
propagate it.

Signed-off-by: Meet Soni <meetsoni3017@gmail.com>
Acked-by: Patrick Steinhardt <ps@pks.im>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
reftable/writer.c

index f3ab1035d61d96f5234a2bbaef4f8f0341255ecb..94c97b7ac0505989f46478c090e995cc80db6443 100644 (file)
@@ -310,11 +310,12 @@ static int writer_add_record(struct reftable_writer *w,
         * done. Otherwise the block writer may have hit the block size limit
         * and needs to be flushed.
         */
-       if (!block_writer_add(w->block_writer, rec)) {
-               err = 0;
+       err = block_writer_add(w->block_writer, rec);
+       if (err == 0)
                goto done;
-       }
 
+       if (err != REFTABLE_ENTRY_TOO_BIG_ERROR)
+               goto done;
        /*
         * The current block is full, so we need to flush and reinitialize the
         * writer to start writing the next block.
@@ -329,16 +330,10 @@ static int writer_add_record(struct reftable_writer *w,
        /*
         * Try to add the record to the writer again. If this still fails then
         * the record does not fit into the block size.
-        *
-        * TODO: it would be great to have `block_writer_add()` return proper
-        *       error codes so that we don't have to second-guess the failure
-        *       mode here.
         */
        err = block_writer_add(w->block_writer, rec);
-       if (err) {
-               err = REFTABLE_ENTRY_TOO_BIG_ERROR;
+       if (err)
                goto done;
-       }
 
 done:
        return err;