Don't crash if cursor_to_xmlschema is used on a non-data-returning Portal.
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 18 Sep 2023 18:27:47 +0000 (14:27 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 18 Sep 2023 18:27:47 +0000 (14:27 -0400)
commit9baabfa38e005699fc21d76875f03cc2f204258c
tree07f383e810c32428abc3840eb9ba34fb17bb5b73
parentae13f8166dc372a94e596f423790a67abd7bf68c
Don't crash if cursor_to_xmlschema is used on a non-data-returning Portal.

cursor_to_xmlschema() assumed that any Portal must have a tupDesc,
which is not so.  Add a defensive check.

It's plausible that this mistake occurred because of the rather
poorly chosen name of the lookup function SPI_cursor_find(),
which in such cases is returning something that isn't very much
like a cursor.  Add some documentation to try to forestall future
errors of the same ilk.

Report and patch by Boyu Yang (docs changes by me).  Back-patch
to all supported branches.

Discussion: https://postgr.es/m/dd343010-c637-434c-a8cb-418f53bda3b8.yangboyu.yby@alibaba-inc.com
doc/src/sgml/spi.sgml
src/backend/utils/adt/xml.c