Commit 5d3fcc4c authored by Tom Lane's avatar Tom Lane

Bend parse location rules for the convenience of pg_stat_statements.

Generally, the parse location assigned to a multiple-token construct is
the location of its leftmost token.  This commit breaks that rule for
the syntaxes TYPENAME 'LITERAL' and CAST(CONSTANT AS TYPENAME) --- the
resulting Const will have the location of the literal string, not the
typename or CAST keyword.  The cases where this matters are pretty thin on
the ground (no error messages in the regression tests change, for example),
and it's unlikely that any user would be confused anyway by an error cursor
pointing at the literal.  But still it's less than consistent.  The reason
for changing it is that contrib/pg_stat_statements wants to know the parse
location of the original literal, and it was agreed that this is the least
unpleasant way to preserve that information through parse analysis.

Peter Geoghegan
parent a40fa613
...@@ -280,13 +280,13 @@ coerce_type(ParseState *pstate, Node *node, ...@@ -280,13 +280,13 @@ coerce_type(ParseState *pstate, Node *node,
newcon->constlen = typeLen(targetType); newcon->constlen = typeLen(targetType);
newcon->constbyval = typeByVal(targetType); newcon->constbyval = typeByVal(targetType);
newcon->constisnull = con->constisnull; newcon->constisnull = con->constisnull;
/* Use the leftmost of the constant's and coercion's locations */
if (location < 0) /*
newcon->location = con->location; * We use the original literal's location regardless of the position
else if (con->location >= 0 && con->location < location) * of the coercion. This is a change from pre-9.2 behavior, meant to
newcon->location = con->location; * simplify life for pg_stat_statements.
else */
newcon->location = location; newcon->location = con->location;
/* /*
* Set up to point at the constant's text if the input routine throws * Set up to point at the constant's text if the input routine throws
......
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