aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2016-05-23 19:23:36 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2016-05-23 19:23:36 -0400
commite504d915bbf352ecfc4ed335af934e799bf01053 (patch)
tree8d164cf4ac442d59be6aa96b213fe73b222b8116
parent9d91cd865bdc52ee2ebe70447be582fabfe88664 (diff)
downloadpostgresql-e504d915bbf352ecfc4ed335af934e799bf01053.tar.gz
postgresql-e504d915bbf352ecfc4ed335af934e799bf01053.zip
Support IndexElem in raw_expression_tree_walker().
Needed for cases in which INSERT ... ON CONFLICT appears inside a recursive CTE item. Per bug #14153 from Thomas Alton. Patch by Peter Geoghegan, slightly adjusted by me Report: <20160521232802.22598.13537@wrigleys.postgresql.org>
-rw-r--r--src/backend/nodes/nodeFuncs.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/backend/nodes/nodeFuncs.c b/src/backend/nodes/nodeFuncs.c
index c517dfd9d69..ce4f3707e43 100644
--- a/src/backend/nodes/nodeFuncs.c
+++ b/src/backend/nodes/nodeFuncs.c
@@ -3365,6 +3365,15 @@ raw_expression_tree_walker(Node *node,
/* for now, constraints are ignored */
}
break;
+ case T_IndexElem:
+ {
+ IndexElem *indelem = (IndexElem *) node;
+
+ if (walker(indelem->expr, context))
+ return true;
+ /* collation and opclass names are deemed uninteresting */
+ }
+ break;
case T_GroupingSet:
return walker(((GroupingSet *) node)->content, context);
case T_LockingClause: