mirror of
https://github.com/postgres/postgres.git
synced 2025-07-15 19:21:59 +03:00
Move strip_implicit_coercions() from optimizer to nodeFuncs.c.
Use of this function has spread into the parser and rewriter, so it seems like time to pull it out of the optimizer and put it into the more central nodeFuncs module. This eliminates the need to #include optimizer/clauses.h in most of the calling files, demonstrating that this function was indeed a bit outside the normal code reference patterns.
This commit is contained in:
@ -2070,62 +2070,6 @@ CommuteRowCompareExpr(RowCompareExpr *clause)
|
||||
clause->rargs = temp;
|
||||
}
|
||||
|
||||
/*
|
||||
* strip_implicit_coercions: remove implicit coercions at top level of tree
|
||||
*
|
||||
* Note: there isn't any useful thing we can do with a RowExpr here, so
|
||||
* just return it unchanged, even if it's marked as an implicit coercion.
|
||||
*/
|
||||
Node *
|
||||
strip_implicit_coercions(Node *node)
|
||||
{
|
||||
if (node == NULL)
|
||||
return NULL;
|
||||
if (IsA(node, FuncExpr))
|
||||
{
|
||||
FuncExpr *f = (FuncExpr *) node;
|
||||
|
||||
if (f->funcformat == COERCE_IMPLICIT_CAST)
|
||||
return strip_implicit_coercions(linitial(f->args));
|
||||
}
|
||||
else if (IsA(node, RelabelType))
|
||||
{
|
||||
RelabelType *r = (RelabelType *) node;
|
||||
|
||||
if (r->relabelformat == COERCE_IMPLICIT_CAST)
|
||||
return strip_implicit_coercions((Node *) r->arg);
|
||||
}
|
||||
else if (IsA(node, CoerceViaIO))
|
||||
{
|
||||
CoerceViaIO *c = (CoerceViaIO *) node;
|
||||
|
||||
if (c->coerceformat == COERCE_IMPLICIT_CAST)
|
||||
return strip_implicit_coercions((Node *) c->arg);
|
||||
}
|
||||
else if (IsA(node, ArrayCoerceExpr))
|
||||
{
|
||||
ArrayCoerceExpr *c = (ArrayCoerceExpr *) node;
|
||||
|
||||
if (c->coerceformat == COERCE_IMPLICIT_CAST)
|
||||
return strip_implicit_coercions((Node *) c->arg);
|
||||
}
|
||||
else if (IsA(node, ConvertRowtypeExpr))
|
||||
{
|
||||
ConvertRowtypeExpr *c = (ConvertRowtypeExpr *) node;
|
||||
|
||||
if (c->convertformat == COERCE_IMPLICIT_CAST)
|
||||
return strip_implicit_coercions((Node *) c->arg);
|
||||
}
|
||||
else if (IsA(node, CoerceToDomain))
|
||||
{
|
||||
CoerceToDomain *c = (CoerceToDomain *) node;
|
||||
|
||||
if (c->coercionformat == COERCE_IMPLICIT_CAST)
|
||||
return strip_implicit_coercions((Node *) c->arg);
|
||||
}
|
||||
return node;
|
||||
}
|
||||
|
||||
/*
|
||||
* Helper for eval_const_expressions: check that datatype of an attribute
|
||||
* is still what it was when the expression was parsed. This is needed to
|
||||
|
Reference in New Issue
Block a user