Re: Why does exprCollation reject List node?

From: Shigeru Hanada <shigeru(dot)hanada(at)gmail(dot)com>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Cc: "pgsql-hackers >> PostgreSQL-development" <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: Why does exprCollation reject List node?
Date: 2012-03-19 04:44:18
Message-ID: CAEZqfEf1g78aP5BeENk57MknJN0pim9zHyLCo=BghuzLB8syxg@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Fri, Mar 16, 2012 at 10:17 PM, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
> Shigeru HANADA <shigeru(dot)hanada(at)gmail(dot)com> writes:
>> During writing pgsql_fdw codes, I noticed that exprCollation rejects
>> non-Expr nodes with error "unrecognized node type: %d".  Is this
>> intentional behavior, or can it return InvalidOid for unrecognized nodes
>> like exprInputCollation?
>
> Doesn't seem to me that asking for the collation of a list is very
> sensible, so I don't see a problem with that.

Oh, I've used the function wrongly. It returns the collation of the
result of the expression, so passing a list doesn't make any sense.
The comment of expression_tree_walker clearly says that it can handle
List as well, so handling List in foreign_expr_walker by calilng
itself recursively for each element in the list seems necessary.

Regards,
--
Shigeru Hanada

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Etsuro Fujita 2012-03-19 05:34:01 Re: Proposal: Create index on foreign table
Previous Message Joachim Wieland 2012-03-19 03:31:47 Re: patch for parallel pg_dump