Re: Remove extraneous break condition in logical slot advance function - Mailing list pgsql-hackers

From Tom Lane
Subject Re: Remove extraneous break condition in logical slot advance function
Date
Msg-id 33858.1697911809@sss.pgh.pa.us
Whole thread Raw
In response to Re: Remove extraneous break condition in logical slot advance function  (Gurjeet Singh <gurjeet@singh.im>)
Responses Re: Remove extraneous break condition in logical slot advance function
List pgsql-hackers
Gurjeet Singh <gurjeet@singh.im> writes:
> On Fri, Oct 20, 2023 at 7:30 PM Bharath Rupireddy
> <bharath.rupireddyforpostgres@gmail.com> wrote:
>> There exists an extraneous break condition in
>> pg_logical_replication_slot_advance(). When the end of WAL or moveto
>> LSN is reached, the main while condition helps to exit the loop, so no
>> separate break condition is needed. Attached patch removes it.

> The only advantage I see of the code as it stands right now is that it
> avoids one last call to CHECK_FOR_INTERRUPTS() by break'ing early. I
> don't think we'd lose much in terms of performance by making one (very
> cheap, in common case) extra call of this macro.

Agreed, bypassing the last CHECK_FOR_INTERRUPTS() shouldn't save
anything noticeable.  Could there be a correctness argument for it
though?  Can't see what.  We should assume that CFIs might happen
down inside LogicalDecodingProcessRecord.

I wondered why the code looks like this, and whether there used
to be more of a reason for it.  "git blame" reveals the probable
answer: when this code was added, in 9c7d06d60, the loop
condition was different so the break was necessary.
38a957316 simplified the loop condition to what we see today,
but didn't notice that the break was thereby made pointless.

While we're here ... the comment above the loop seems wrong
already, and this makes it more so.  I suggest something like

-        /* Decode at least one record, until we run out of records */
+        /* Decode records until we reach the requested target */
        while (ctx->reader->EndRecPtr < moveto)

            regards, tom lane



pgsql-hackers by date:

Previous
From: Gurjeet Singh
Date:
Subject: Re: Remove extraneous break condition in logical slot advance function
Next
From: Bharath Rupireddy
Date:
Subject: Re: Switching XLog source from archive to streaming when primary available