Avoid use scoped block variable
Hi.
I noticed a possible violation of C rules.
Some functions rely on local block variables,
but this are a mistake.
Once that block exits, the memory of the variable is released.
Fix by moving the declaration variables.
best regards,
Ranier Vilela
Attachments:
avoid-use-scoped-block-variable-lockfuncs.patchapplication/octet-stream; name=avoid-use-scoped-block-variable-lockfuncs.patchDownload+1-4
avoid-use-scoped-block-variable-rawpage.patchapplication/octet-stream; name=avoid-use-scoped-block-variable-rawpage.patchDownload+1-2
avoid-use-scoped-block-variable-walsender.patchapplication/octet-stream; name=avoid-use-scoped-block-variable-walsender.patchDownload+1-2
Hi,
On 2025-12-09 13:06:35 -0300, Ranier Vilela wrote:
I noticed a possible violation of C rules.
Some functions rely on local block variables,
but this are a mistake.
Once that block exits, the memory of the variable is released.
CStringGetTextDatum() copies its input to a fresh allocation. So there's no
longer-lived references to the local memory, unless I miss something?
Greetings,
Andres Freund
On 12/9/25 17:06, Ranier Vilela wrote:
Hi.
I noticed a possible violation of C rules.
Some functions rely on local block variables,
but this are a mistake.
Once that block exits, the memory of the variable is released.Fix by moving the declaration variables.
When you say "possible violation", did you check the issue is real?
All these places call CStringGetTextDatum, which calls cstring_to_text,
which allocates a new varlena copy of the string. So why is this an
issue, exactly?
regards
--
Tomas Vondra
Em ter., 9 de dez. de 2025 às 13:19, Andres Freund <andres@anarazel.de>
escreveu:
Hi,
On 2025-12-09 13:06:35 -0300, Ranier Vilela wrote:
I noticed a possible violation of C rules.
Some functions rely on local block variables,
but this are a mistake.
Once that block exits, the memory of the variable is released.CStringGetTextDatum() copies its input to a fresh allocation. So there's no
longer-lived references to the local memory, unless I miss something?
Yeah. My bad.
cstring_to_text use palloc.
Sorry for the noise.
best regards,
Ranier Vilela