diff options
| author | Tom Lane <tgl@sss.pgh.pa.us> | 2015-11-15 14:41:09 -0500 | 
|---|---|---|
| committer | Tom Lane <tgl@sss.pgh.pa.us> | 2015-11-15 14:41:09 -0500 | 
| commit | 7745bc352a82bd588be986479c7aabc3b076a375 (patch) | |
| tree | a28738fdb4642a256be9068694d347c944535eb0 /src/backend/utils/fmgr/funcapi.c | |
| parent | 7d9a4737c268f61fb8800957631f12d3f13be218 (diff) | |
Fix ruleutils.c's dumping of whole-row Vars in ROW() and VALUES() contexts.
Normally ruleutils prints a whole-row Var as "foo.*".  We already knew that
that doesn't work at top level of a SELECT list, because the parser would
treat the "*" as a directive to expand the reference into separate columns,
not a whole-row Var.  However, Joshua Yanovski points out in bug #13776
that the same thing happens at top level of a ROW() construct; and some
nosing around in the parser shows that the same is true in VALUES().
Hence, apply the same workaround already devised for the SELECT-list case,
namely to add a forced cast to the appropriate rowtype in these cases.
(The alternative of just printing "foo" was rejected because it is
difficult to avoid ambiguity against plain columns named "foo".)
Back-patch to all supported branches.
Diffstat (limited to 'src/backend/utils/fmgr/funcapi.c')
0 files changed, 0 insertions, 0 deletions
