mirror of
https://github.com/postgres/postgres.git
synced 2025-07-27 12:41:57 +03:00
Extend the parser location infrastructure to include a location field in
most node types used in expression trees (both before and after parse analysis). This allows us to place an error cursor in many situations where we formerly could not, because the information wasn't available beyond the very first level of parse analysis. There's a fair amount of work still to be done to persuade individual ereport() calls to actually include an error location, but this gets the initdb-forcing part of the work out of the way; and the situation is already markedly better than before for complaints about unimplementable implicit casts, such as CASE and UNION constructs with incompatible alternative data types. Per my proposal of a few days ago.
This commit is contained in:
@ -10,7 +10,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/plan/createplan.c,v 1.246 2008/08/25 22:42:33 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/plan/createplan.c,v 1.247 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -1949,6 +1949,7 @@ get_switched_clauses(List *clauses, Relids outerrelids)
|
||||
temp->opresulttype = clause->opresulttype;
|
||||
temp->opretset = clause->opretset;
|
||||
temp->args = list_copy(clause->args);
|
||||
temp->location = clause->location;
|
||||
/* Commute it --- note this modifies the temp node in-place. */
|
||||
CommuteOpExpr(temp);
|
||||
t_list = lappend(t_list, temp);
|
||||
|
@ -7,7 +7,7 @@
|
||||
* Portions Copyright (c) 1994, Regents of the University of California
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/plan/subselect.c,v 1.139 2008/08/25 22:42:33 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/plan/subselect.c,v 1.140 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -140,6 +140,7 @@ replace_outer_var(PlannerInfo *root, Var *var)
|
||||
retval->paramid = i;
|
||||
retval->paramtype = var->vartype;
|
||||
retval->paramtypmod = var->vartypmod;
|
||||
retval->location = -1;
|
||||
|
||||
return retval;
|
||||
}
|
||||
@ -179,6 +180,7 @@ replace_outer_agg(PlannerInfo *root, Aggref *agg)
|
||||
retval->paramid = i;
|
||||
retval->paramtype = agg->aggtype;
|
||||
retval->paramtypmod = -1;
|
||||
retval->location = -1;
|
||||
|
||||
return retval;
|
||||
}
|
||||
@ -199,6 +201,7 @@ generate_new_param(PlannerInfo *root, Oid paramtype, int32 paramtypmod)
|
||||
retval->paramid = list_length(root->glob->paramlist);
|
||||
retval->paramtype = paramtype;
|
||||
retval->paramtypmod = paramtypmod;
|
||||
retval->location = -1;
|
||||
|
||||
pitem = makeNode(PlannerParamItem);
|
||||
pitem->item = (Node *) retval;
|
||||
|
@ -25,7 +25,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/prep/prepqual.c,v 1.58 2008/01/01 19:45:50 momjian Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/prep/prepqual.c,v 1.59 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -219,6 +219,7 @@ push_nots(Expr *qual)
|
||||
newopexpr->opresulttype = opexpr->opresulttype;
|
||||
newopexpr->opretset = opexpr->opretset;
|
||||
newopexpr->args = opexpr->args;
|
||||
newopexpr->location = opexpr->location;
|
||||
return (Expr *) newopexpr;
|
||||
}
|
||||
else
|
||||
@ -243,6 +244,7 @@ push_nots(Expr *qual)
|
||||
newopexpr->opfuncid = InvalidOid;
|
||||
newopexpr->useOr = !saopexpr->useOr;
|
||||
newopexpr->args = saopexpr->args;
|
||||
newopexpr->location = saopexpr->location;
|
||||
return (Expr *) newopexpr;
|
||||
}
|
||||
else
|
||||
|
@ -16,7 +16,7 @@
|
||||
* Portions Copyright (c) 1994, Regents of the University of California
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/prep/preptlist.c,v 1.90 2008/06/19 00:46:04 alvherre Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/prep/preptlist.c,v 1.91 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -292,6 +292,7 @@ expand_targetlist(List *tlist, int command_type,
|
||||
InvalidOid, -1,
|
||||
atttype,
|
||||
COERCE_IMPLICIT_CAST,
|
||||
-1,
|
||||
false,
|
||||
false);
|
||||
}
|
||||
|
@ -22,7 +22,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/prep/prepunion.c,v 1.154 2008/08/25 22:42:33 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/prep/prepunion.c,v 1.155 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -1410,6 +1410,7 @@ adjust_appendrel_attrs_mutator(Node *node, AppendRelInfo *context)
|
||||
r->arg = (Expr *) var;
|
||||
r->resulttype = context->parent_reltype;
|
||||
r->convertformat = COERCE_IMPLICIT_CAST;
|
||||
r->location = -1;
|
||||
/* Make sure the Var node has the right type ID, too */
|
||||
var->vartype = context->child_reltype;
|
||||
return (Node *) r;
|
||||
@ -1428,6 +1429,8 @@ adjust_appendrel_attrs_mutator(Node *node, AppendRelInfo *context)
|
||||
rowexpr->args = fields;
|
||||
rowexpr->row_typeid = var->vartype;
|
||||
rowexpr->row_format = COERCE_IMPLICIT_CAST;
|
||||
rowexpr->location = -1;
|
||||
|
||||
return (Node *) rowexpr;
|
||||
}
|
||||
}
|
||||
|
@ -8,7 +8,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/util/clauses.c,v 1.265 2008/08/26 02:16:31 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/util/clauses.c,v 1.266 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
* HISTORY
|
||||
* AUTHOR DATE MAJOR EVENT
|
||||
@ -135,6 +135,7 @@ make_opclause(Oid opno, Oid opresulttype, bool opretset,
|
||||
expr->args = list_make2(leftop, rightop);
|
||||
else
|
||||
expr->args = list_make1(leftop);
|
||||
expr->location = -1;
|
||||
return (Expr *) expr;
|
||||
}
|
||||
|
||||
@ -201,6 +202,7 @@ make_notclause(Expr *notclause)
|
||||
|
||||
expr->boolop = NOT_EXPR;
|
||||
expr->args = list_make1(notclause);
|
||||
expr->location = -1;
|
||||
return (Expr *) expr;
|
||||
}
|
||||
|
||||
@ -244,6 +246,7 @@ make_orclause(List *orclauses)
|
||||
|
||||
expr->boolop = OR_EXPR;
|
||||
expr->args = orclauses;
|
||||
expr->location = -1;
|
||||
return (Expr *) expr;
|
||||
}
|
||||
|
||||
@ -277,6 +280,7 @@ make_andclause(List *andclauses)
|
||||
|
||||
expr->boolop = AND_EXPR;
|
||||
expr->args = andclauses;
|
||||
expr->location = -1;
|
||||
return (Expr *) expr;
|
||||
}
|
||||
|
||||
@ -2014,6 +2018,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newexpr->funcretset = expr->funcretset;
|
||||
newexpr->funcformat = expr->funcformat;
|
||||
newexpr->args = args;
|
||||
newexpr->location = expr->location;
|
||||
return (Node *) newexpr;
|
||||
}
|
||||
if (IsA(node, OpExpr))
|
||||
@ -2071,6 +2076,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newexpr->opresulttype = expr->opresulttype;
|
||||
newexpr->opretset = expr->opretset;
|
||||
newexpr->args = args;
|
||||
newexpr->location = expr->location;
|
||||
return (Node *) newexpr;
|
||||
}
|
||||
if (IsA(node, DistinctExpr))
|
||||
@ -2162,6 +2168,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newexpr->opresulttype = expr->opresulttype;
|
||||
newexpr->opretset = expr->opretset;
|
||||
newexpr->args = args;
|
||||
newexpr->location = expr->location;
|
||||
return (Node *) newexpr;
|
||||
}
|
||||
if (IsA(node, BoolExpr))
|
||||
@ -2291,6 +2298,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newrelabel->resulttype = relabel->resulttype;
|
||||
newrelabel->resulttypmod = relabel->resulttypmod;
|
||||
newrelabel->relabelformat = relabel->relabelformat;
|
||||
newrelabel->location = relabel->location;
|
||||
return (Node *) newrelabel;
|
||||
}
|
||||
}
|
||||
@ -2357,6 +2365,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newexpr->arg = arg;
|
||||
newexpr->resulttype = expr->resulttype;
|
||||
newexpr->coerceformat = expr->coerceformat;
|
||||
newexpr->location = expr->location;
|
||||
return (Node *) newexpr;
|
||||
}
|
||||
if (IsA(node, ArrayCoerceExpr))
|
||||
@ -2379,6 +2388,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newexpr->resulttypmod = expr->resulttypmod;
|
||||
newexpr->isExplicit = expr->isExplicit;
|
||||
newexpr->coerceformat = expr->coerceformat;
|
||||
newexpr->location = expr->location;
|
||||
|
||||
/*
|
||||
* If constant argument and it's a binary-coercible or immutable
|
||||
@ -2477,6 +2487,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
|
||||
newcasewhen->expr = (Expr *) casecond;
|
||||
newcasewhen->result = (Expr *) caseresult;
|
||||
newcasewhen->location = oldcasewhen->location;
|
||||
newargs = lappend(newargs, newcasewhen);
|
||||
continue;
|
||||
}
|
||||
@ -2506,6 +2517,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newcase->arg = (Expr *) newarg;
|
||||
newcase->args = newargs;
|
||||
newcase->defresult = (Expr *) defresult;
|
||||
newcase->location = caseexpr->location;
|
||||
return (Node *) newcase;
|
||||
}
|
||||
if (IsA(node, CaseTestExpr))
|
||||
@ -2545,6 +2557,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newarray->element_typeid = arrayexpr->element_typeid;
|
||||
newarray->elements = newelems;
|
||||
newarray->multidims = arrayexpr->multidims;
|
||||
newarray->location = arrayexpr->location;
|
||||
|
||||
if (all_const)
|
||||
return (Node *) evaluate_expr((Expr *) newarray,
|
||||
@ -2590,6 +2603,7 @@ eval_const_expressions_mutator(Node *node,
|
||||
newcoalesce = makeNode(CoalesceExpr);
|
||||
newcoalesce->coalescetype = coalesceexpr->coalescetype;
|
||||
newcoalesce->args = newargs;
|
||||
newcoalesce->location = coalesceexpr->location;
|
||||
return (Node *) newcoalesce;
|
||||
}
|
||||
if (IsA(node, FieldSelect))
|
||||
@ -3206,6 +3220,7 @@ evaluate_function(Oid funcid, Oid result_type, int32 result_typmod, List *args,
|
||||
newexpr->funcretset = false;
|
||||
newexpr->funcformat = COERCE_DONTCARE; /* doesn't matter */
|
||||
newexpr->args = args;
|
||||
newexpr->location = -1;
|
||||
|
||||
return evaluate_expr((Expr *) newexpr, result_type, result_typmod);
|
||||
}
|
||||
|
@ -8,7 +8,7 @@
|
||||
*
|
||||
*
|
||||
* IDENTIFICATION
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/util/var.c,v 1.77 2008/08/25 22:42:33 tgl Exp $
|
||||
* $PostgreSQL: pgsql/src/backend/optimizer/util/var.c,v 1.78 2008/08/28 23:09:46 tgl Exp $
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -624,6 +624,7 @@ flatten_join_alias_vars_mutator(Node *node,
|
||||
rowexpr->args = fields;
|
||||
rowexpr->row_typeid = var->vartype;
|
||||
rowexpr->row_format = COERCE_IMPLICIT_CAST;
|
||||
rowexpr->location = -1;
|
||||
|
||||
return (Node *) rowexpr;
|
||||
}
|
||||
|
Reference in New Issue
Block a user