pgsql: Further tweaking of raw grammar output to distinguish different

Поиск
Список
Период
Сортировка
От Tom Lane
Тема pgsql: Further tweaking of raw grammar output to distinguish different
Дата
Msg-id E1YPx5z-0007nA-NE@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Further tweaking of raw grammar output to distinguish different inputs.

Use a different A_Expr_Kind for LIKE/ILIKE/SIMILAR TO constructs, so that
they can be distinguished from direct invocation of the underlying
operators.  Also, postpone selection of the operator name when transforming
"x IN (select)" to "x = ANY (select)", so that those syntaxes can be told
apart at parse analysis time.

I had originally thought I'd also have to do something special for the
syntaxes IS NOT DISTINCT FROM, IS NOT DOCUMENT, and x NOT IN (SELECT...),
which the grammar translates as though they were NOT (construct).
On reflection though, we can distinguish those cases reliably by noting
whether the parse location shown for the NOT is the same as for its child
node.  This only requires tweaking the parse locations for NOT IN, which
I've done here.

These changes should have no effect outside the parser; they're just in
support of being able to give accurate warnings for planned operator
precedence changes.

Branch
------
master

Details
-------
http://git.postgresql.org/pg/commitdiff/56be925e4b8f5b1c0e6716ca5cbe0360d1229f50

Modified Files
--------------
src/backend/nodes/outfuncs.c    |   12 +++++++++
src/backend/parser/gram.y       |   52 +++++++++++++++++++++++++++------------
src/backend/parser/parse_expr.c |   12 +++++++++
src/include/nodes/parsenodes.h  |    3 +++
src/include/nodes/primnodes.h   |    1 -
5 files changed, 63 insertions(+), 17 deletions(-)


В списке pgsql-committers по дате отправления:

Предыдущее
От: Alvaro Herrera
Дата:
Сообщение: pgsql: Support more commands in event triggers
Следующее
От: Alvaro Herrera
Дата:
Сообщение: pgsql: Fix stupid merge errors in previous commit