From: Tom Lane Date: Thu, 27 Jan 2005 21:50:06 +0000 (+0000) Subject: Now that I look at it, int_array_enum() didn't work either. X-Git-Tag: REL8_0_1~17 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=5f0962a23387a3d9c5e9fc693f3c3f28df49c3b7;p=postgresql Now that I look at it, int_array_enum() didn't work either. --- diff --git a/contrib/intagg/int_aggregate.c b/contrib/intagg/int_aggregate.c index 67056af8ed..cb0f1f3a45 100644 --- a/contrib/intagg/int_aggregate.c +++ b/contrib/intagg/int_aggregate.c @@ -201,6 +201,10 @@ int_enum(PG_FUNCTION_ARGS) if (!fcinfo->context) { /* Allocate a working context */ + MemoryContext oldcontext; + + oldcontext = MemoryContextSwitchTo(fcinfo->flinfo->fn_mcxt); + pc = (CTX *) palloc(sizeof(CTX)); /* Don't copy attribute if you don't need to */ @@ -218,6 +222,7 @@ int_enum(PG_FUNCTION_ARGS) } pc->num = 0; fcinfo->context = (Node *) pc; + MemoryContextSwitchTo(oldcontext); } else /* use an existing one */ pc = (CTX *) fcinfo->context;