Avoid use scoped block variable

Started by Ranier Vilela4 months ago4 messageshackers
Jump to latest
#1Ranier Vilela
ranier.vf@gmail.com

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
#2Andres Freund
andres@anarazel.de
In reply to: Ranier Vilela (#1)
Re: Avoid use scoped block variable

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

#3Tomas Vondra
tomas.vondra@2ndquadrant.com
In reply to: Ranier Vilela (#1)
Re: Avoid use scoped block variable

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

#4Ranier Vilela
ranier.vf@gmail.com
In reply to: Andres Freund (#2)
Re: Avoid use scoped block variable

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