Fix plpgsql's exec_move_row() to supply valid type OIDs to exec_assign_value()
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 1 Sep 2008 22:30:55 +0000 (22:30 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 1 Sep 2008 22:30:55 +0000 (22:30 +0000)
commit0df74714a0282c055b94b62084cec64bd550c5ef
treeb15366a6340a74e63a35af7111470a369a984510
parent25637273360ae69b128263017061d2e34a4db3ef
Fix plpgsql's exec_move_row() to supply valid type OIDs to exec_assign_value()
whenever possible, as per bug report from Oleg Serov.  While at it, reorder
the operations in the RECORD case to avoid possible palloc failure while the
variable update is only partly complete.

Back-patch as far as 8.1.  Although the code of the particular function is
similar in 8.0, 8.0's support for composite fields in rows is sufficiently
broken elsewhere that it doesn't seem worth fixing this.
src/pl/plpgsql/src/pl_exec.c