Thread: build gcc warning
Hi
I got new warning
-o session.bc session.c
analyze.c: In function ‘transformStmt’:
analyze.c:550:21: warning: ‘sub_rteperminfos’ may be used uninitialized [-Wmaybe-uninitialized]
550 | List *sub_rteperminfos;
| ^~~~~~~~~~~~~~~~
analyze.c: In function ‘transformStmt’:
analyze.c:550:21: warning: ‘sub_rteperminfos’ may be used uninitialized [-Wmaybe-uninitialized]
550 | List *sub_rteperminfos;
| ^~~~~~~~~~~~~~~~
<-->if (isGeneralSelect)
<-->{
<--><-->sub_rtable = pstate->p_rtable;
<--><-->pstate->p_rtable = NIL;
<--><-->sub_rteperminfos = pstate->p_rteperminfos;
<--><-->pstate->p_rteperminfos = NIL;
<--><-->sub_namespace = pstate->p_namespace;
<--><-->pstate->p_namespace = NIL;
<-->}
<-->else
<-->{
<--><-->sub_rtable = NIL;<-><-->/* not used, but keep compiler quiet */
<--><-->sub_namespace = NIL;
<-->{
<--><-->sub_rtable = pstate->p_rtable;
<--><-->pstate->p_rtable = NIL;
<--><-->sub_rteperminfos = pstate->p_rteperminfos;
<--><-->pstate->p_rteperminfos = NIL;
<--><-->sub_namespace = pstate->p_namespace;
<--><-->pstate->p_namespace = NIL;
<-->}
<-->else
<-->{
<--><-->sub_rtable = NIL;<-><-->/* not used, but keep compiler quiet */
<--><-->sub_namespace = NIL;
--- missing sub_rteperminfos
<-->}
Regards
Pavel
Pavel Stehule <pavel.stehule@gmail.com> writes: > I got new warning > analyze.c: In function ‘transformStmt’: > analyze.c:550:21: warning: ‘sub_rteperminfos’ may be used uninitialized > [-Wmaybe-uninitialized] A couple of buildfarm animals are warning about that too ... but only a couple. regards, tom lane
Hi, On 2022-12-27 01:55:06 -0500, Tom Lane wrote: > Pavel Stehule <pavel.stehule@gmail.com> writes: > > I got new warning > > analyze.c: In function ‘transformStmt’: > > analyze.c:550:21: warning: ‘sub_rteperminfos’ may be used uninitialized > > [-Wmaybe-uninitialized] > > A couple of buildfarm animals are warning about that too ... but > only a couple. I'm a bit confused by gcc getting confused here - the condition for sub_rteperminfos getting initialized and used are the same. Most of the time the maybe-uninitialized logic seems to be better than this. Greetings, Andres Freund
Andres Freund <andres@anarazel.de> writes: > On 2022-12-27 01:55:06 -0500, Tom Lane wrote: >> A couple of buildfarm animals are warning about that too ... but >> only a couple. > I'm a bit confused by gcc getting confused here - the condition for > sub_rteperminfos getting initialized and used are the same. Most of the time > the maybe-uninitialized logic seems to be better than this. Apparently the key phrase there is "most of the time" ;-). I see that we've had an equally "unnecessary" initialization of the sibling variable sub_rtable for a long time, so the problem's been there for some people before. I made it initialize sub_rteperminfos the same way. regards, tom lane