Em ter., 21 de set. de 2021 às 20:12, Ranier Vilela <ranier...@gmail.com> escreveu:
> Em ter., 21 de set. de 2021 às 19:21, Tom Lane <t...@sss.pgh.pa.us> > escreveu: > >> Andres Freund <and...@anarazel.de> writes: >> > On 2021-09-21 15:09:11 -0300, Ranier Vilela wrote: >> >> Currently when determining where CoerceToDomainValue can be read, >> >> it evaluates every step in a loop. >> >> But, I think that the expression is immutable and should be solved only >> >> once. >> >> > What is immutable here? >> >> I think Ranier has a point here. The clear intent of this bit: >> >> /* >> * If first time through, determine where >> CoerceToDomainValue >> * nodes should read from. >> */ >> if (domainval == NULL) >> { >> >> is that we only need to emit the EEOP_MAKE_READONLY once when there are >> multiple CHECK constraints. But because domainval has the wrong lifespan, >> that test is constant-true, and we'll do it over each time to little >> purpose. >> > Exactly, thanks for the clear explanation. > > >> > And it has to, the allocation intentionally is separate for each >> > constraint. As the comment even explicitly says: >> > /* >> > * Since value might be read multiple times, force >> to R/O >> > * - but only if it could be an expanded datum. >> > */ >> >> No, what that's on about is that each constraint might contain multiple >> VALUE symbols. But once we've R/O-ified the datum, we can keep using >> it across VALUE symbols in different CHECK expressions, not just one. >> >> (AFAICS anyway) >> >> I'm unexcited by the proposed move of the save_innermost_domainval/null >> variables, though. It adds no correctness and it forces an additional >> level of indentation of a good deal of code, as the patch fails to show. >> > Ok, but I think that still has a value in reducing the scope. > save_innermost_domainval and save_innermost_domainnull, > only are needed with DOM_CONSTRAINT_CHECK expressions, > and both are declared even when they will not be used. > > Anyway, the v1 patch fixes only the expression eval. > Created a new entry at next CF. https://commitfest.postgresql.org/35/3327/ regards, Ranier Vilela