Make ExecGetInsertedCols() and friends more robust and improve comments.
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>
Mon, 15 Feb 2021 07:28:08 +0000 (09:28 +0200)
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>
Mon, 15 Feb 2021 07:28:08 +0000 (09:28 +0200)
commit54e51dcde03e5c746e8de6243c69fafdc8d0ec7a
tree527e7c66032792e3936b8637dd2e6a903a27b407
parent46d6e5f567906389c31c4fb3a2653da1885c18ee
Make ExecGetInsertedCols() and friends more robust and improve comments.

If ExecGetInsertedCols(), ExecGetUpdatedCols() or ExecGetExtraUpdatedCols()
were called with a ResultRelInfo that's not in the range table and isn't a
partition routing target, the functions would dereference a NULL pointer,
relinfo->ri_RootResultRelInfo. Such ResultRelInfos are created when firing
RI triggers in tables that are not modified directly. None of the current
callers of these functions pass such relations, so this isn't a live bug,
but let's make them more robust.

Also update comment in ResultRelInfo; after commit 6214e2b228,
ri_RangeTableIndex is zero for ResultRelInfos created for partition tuple
routing.

Noted by Coverity. Backpatch down to v11, like commit 6214e2b228.

Reviewed-by: Tom Lane, Amit Langote
src/backend/executor/execUtils.c
src/include/nodes/execnodes.h