pgsql: Check for stack overflow in transformSetOperationTree().

Поиск
Список
Период
Сортировка
От Tom Lane
Тема pgsql: Check for stack overflow in transformSetOperationTree().
Дата
Msg-id E1TXiKn-0003tt-Pd@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Check for stack overflow in transformSetOperationTree().

Since transformSetOperationTree() recurses, it can be driven to stack
overflow with enough UNION/INTERSECT/EXCEPT clauses in a query.  Add a
check to ensure it fails cleanly instead of crashing.  Per report from
Matthew Gerber (though it's not clear whether this is the only thing
going wrong for him).

Historical note: I think the reasoning behind not putting a check here in
the beginning was that the check in transformExpr() ought to be sufficient
to guard the whole parser.  However, because transformSetOperationTree()
recurses all the way to the bottom of the set-operation tree before doing
any analysis of the statement's expressions, that check doesn't save it.

Branch
------
REL9_0_STABLE

Details
-------
http://git.postgresql.org/pg/commitdiff/fae09422fdb97ef2bfbfffcd2abc30060a9c1f51

Modified Files
--------------
src/backend/parser/analyze.c |    4 ++++
1 files changed, 4 insertions(+), 0 deletions(-)


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

Предыдущее
От: Tom Lane
Дата:
Сообщение: pgsql: Check for stack overflow in transformSetOperationTree().
Следующее
От: Tom Lane
Дата:
Сообщение: pgsql: Check for stack overflow in transformSetOperationTree().