aboutsummaryrefslogtreecommitdiff
path: root/contrib/intarray/_int_bool.c
diff options
context:
space:
mode:
authorNoah Misch <noah@leadboat.com>2015-10-05 10:06:30 -0400
committerNoah Misch <noah@leadboat.com>2015-10-05 10:06:34 -0400
commitbed3f6d0354a7ca2fcd7d088ff271b422dbf9921 (patch)
tree1b1a0b14590eb9ee85894bea8a2c343ed147fe90 /contrib/intarray/_int_bool.c
parenta0c02ed5b4ef24d91a6fb22d447fc5cba8aeb146 (diff)
downloadpostgresql-bed3f6d0354a7ca2fcd7d088ff271b422dbf9921.tar.gz
postgresql-bed3f6d0354a7ca2fcd7d088ff271b422dbf9921.zip
Prevent stack overflow in query-type functions.
The tsquery, ltxtquery and query_int data types have a common ancestor. Having acquired check_stack_depth() calls independently, each was missing at least one call. Back-patch to 9.0 (all supported versions).
Diffstat (limited to 'contrib/intarray/_int_bool.c')
-rw-r--r--contrib/intarray/_int_bool.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/contrib/intarray/_int_bool.c b/contrib/intarray/_int_bool.c
index c3c39d194bc..5d9e676660f 100644
--- a/contrib/intarray/_int_bool.c
+++ b/contrib/intarray/_int_bool.c
@@ -564,6 +564,9 @@ typedef struct
static void
infix(INFIX *in, bool first)
{
+ /* since this function recurses, it could be driven to stack overflow. */
+ check_stack_depth();
+
if (in->curpol->type == VAL)
{
RESIZEBUF(in, 11);