Commit c8e99350 authored by Tom Lane's avatar Tom Lane

Fix failure to propagate collation in negate_clause().

Turns out it was this, and not so much plpgsql, that was at fault in Stefan
Huehner's collation-error-in-a-trigger bug report of a couple weeks ago.
parent 9b19c12e
...@@ -104,6 +104,8 @@ negate_clause(Node *node) ...@@ -104,6 +104,8 @@ negate_clause(Node *node)
newopexpr->opfuncid = InvalidOid; newopexpr->opfuncid = InvalidOid;
newopexpr->opresulttype = opexpr->opresulttype; newopexpr->opresulttype = opexpr->opresulttype;
newopexpr->opretset = opexpr->opretset; newopexpr->opretset = opexpr->opretset;
newopexpr->opcollid = opexpr->opcollid;
newopexpr->inputcollid = opexpr->inputcollid;
newopexpr->args = opexpr->args; newopexpr->args = opexpr->args;
newopexpr->location = opexpr->location; newopexpr->location = opexpr->location;
return (Node *) newopexpr; return (Node *) newopexpr;
...@@ -126,6 +128,7 @@ negate_clause(Node *node) ...@@ -126,6 +128,7 @@ negate_clause(Node *node)
newopexpr->opno = negator; newopexpr->opno = negator;
newopexpr->opfuncid = InvalidOid; newopexpr->opfuncid = InvalidOid;
newopexpr->useOr = !saopexpr->useOr; newopexpr->useOr = !saopexpr->useOr;
newopexpr->inputcollid = saopexpr->inputcollid;
newopexpr->args = saopexpr->args; newopexpr->args = saopexpr->args;
newopexpr->location = saopexpr->location; newopexpr->location = saopexpr->location;
return (Node *) newopexpr; return (Node *) newopexpr;
......
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