On Tue, Mar 2, 2021 at 12:10 PM Mark Dilger
<mark.dil...@enterprisedb.com> wrote:
> On further reflection, I decided to implement these changes and not worry 
> about the behavioral change.

Thanks.

> I skipped this part.  The initcmd argument is only handed to 
> ParallelSlotsGetIdle().  Doing as you suggest would not really be simpler, it 
> would just move that argument to ParallelSlotsSetup().  But I don't feel 
> strongly about it, so I can move this, too, if you like.
>
> I didn't do this either, and for the same reason.  It's just a parameter to 
> ParallelSlotsGetIdle(), so nothing is really gained by moving it to 
> ParallelSlotsSetup().

OK. I thought it was more natural to pass a bunch of arguments at
setup time rather than passing a bunch of arguments at get-idle time,
but I don't feel strongly enough about it to insist, and somebody else
can always change it later if they decide I had the right idea.

> Rather than the slots user tweak the slot's ConnParams, 
> ParallelSlotsGetIdle() takes a dbname argument, and uses it as 
> ConnParams->override_dbname.

OK, but you forgot to update the comments. ParallelSlotsGetIdle()
still talks about a cparams argument that it no longer has.

The usual idiom for sizing a memory allocation involving
FLEXIBLE_ARRAY_MEMBER is something like offsetof(ParallelSlotArray,
slots) + numslots * sizeof(ParallelSlot). Your version uses sizeof();
don't.

Other than that 0001 looks to me to be in pretty good shape now.

-- 
Robert Haas
EDB: http://www.enterprisedb.com


Reply via email to