Commit 4d02eb01 authored by Tom Lane's avatar Tom Lane

Fix collation exposed for scalar function in FROM.

One code path in addRangeTableEntryForFunction() neglected to assign
a collation to the tupdesc entry it constructs (which is a bit odd
considering the other path did do so).  This didn't matter before commit
5815696b, because nothing would look at the type data in this tupdesc;
but now it does.

While at it, make sure we assign the correct typmod as well.  Most
function expressions don't have a determinate typmod, but some do.

Per buildfarm, which showed failures in non-C collations, a case
I'd not thought to test for this patch :-(
parent 5815696b
...@@ -1781,8 +1781,11 @@ addRangeTableEntryForFunction(ParseState *pstate, ...@@ -1781,8 +1781,11 @@ addRangeTableEntryForFunction(ParseState *pstate,
chooseScalarFunctionAlias(funcexpr, funcname, chooseScalarFunctionAlias(funcexpr, funcname,
alias, nfuncs), alias, nfuncs),
funcrettype, funcrettype,
-1, exprTypmod(funcexpr),
0); 0);
TupleDescInitEntryCollation(tupdesc,
(AttrNumber) 1,
exprCollation(funcexpr));
} }
else if (functypclass == TYPEFUNC_RECORD) else if (functypclass == TYPEFUNC_RECORD)
{ {
...@@ -1882,12 +1885,15 @@ addRangeTableEntryForFunction(ParseState *pstate, ...@@ -1882,12 +1885,15 @@ addRangeTableEntryForFunction(ParseState *pstate,
/* Add the ordinality column if needed */ /* Add the ordinality column if needed */
if (rangefunc->ordinality) if (rangefunc->ordinality)
{
TupleDescInitEntry(tupdesc, TupleDescInitEntry(tupdesc,
(AttrNumber) ++natts, (AttrNumber) ++natts,
"ordinality", "ordinality",
INT8OID, INT8OID,
-1, -1,
0); 0);
/* no need to set collation */
}
Assert(natts == totalatts); Assert(natts == totalatts);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment