Undo unintentional ABI break in struct ResultRelInfo.
commit6bfacd368bb4ae3bd53b2692fee98797a771082a
authorTom Lane <tgl@sss.pgh.pa.us>
Sat, 16 Nov 2024 17:58:26 +0000 (16 12:58 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Sat, 16 Nov 2024 17:58:26 +0000 (16 12:58 -0500)
treec341e08fa8eec310f10d3ae9d6ea491b1a653e7f
parent1c05004a895308da10ec000ba6b92f72f4f5b8e2
Undo unintentional ABI break in struct ResultRelInfo.

Commits aac2c9b4f et al. added a bool field to struct ResultRelInfo.
That's no problem in the master branch, but in released branches
care must be taken when modifying publicly-visible structs to avoid
an ABI break for extensions.  Frequently we solve that by adding the
new field at the end of the struct, and that's what was done here.
But ResultRelInfo has stricter constraints than just about any other
node type in Postgres.  Some executor APIs require extensions to index
into arrays of ResultRelInfo, which means that any change whatever in
sizeof(ResultRelInfo) causes a fatal ABI break.

Fortunately, this is easy to fix, because the new field can be
squeezed into available padding space instead --- indeed, that's where
it was put in master, so this fix also removes a cross-branch coding
variation.

Per report from Pavan Deolasee.  Patch v14-v17 only; earlier versions
did not gain the extra field, nor is there any problem in master.

Discussion: https://postgr.es/m/CABOikdNmVBC1LL6pY26dyxAS2f+gLZvTsNt=2XbcyG7WxXVBBQ@mail.gmail.com
src/include/nodes/execnodes.h