From: Tom Lane Date: Fri, 7 Apr 2017 16:54:17 +0000 (-0400) Subject: Ensure that ExecPrepareExprList's result is all in one memory context. X-Git-Tag: REL_10_BETA1~341 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=dbb2a931478a397a2b655eb77e8be8c1ca136f63;p=postgresql Ensure that ExecPrepareExprList's result is all in one memory context. Noted by Amit Langote. Discussion: https://postgr.es/m/aad31672-4983-d95d-d24e-6b42fee9b985@lab.ntt.co.jp --- diff --git a/src/backend/executor/execExpr.c b/src/backend/executor/execExpr.c index cd0dce150d..97ec8fb033 100644 --- a/src/backend/executor/execExpr.c +++ b/src/backend/executor/execExpr.c @@ -511,8 +511,12 @@ List * ExecPrepareExprList(List *nodes, EState *estate) { List *result = NIL; + MemoryContext oldcontext; ListCell *lc; + /* Ensure that the list cell nodes are in the right context too */ + oldcontext = MemoryContextSwitchTo(estate->es_query_cxt); + foreach(lc, nodes) { Expr *e = (Expr *) lfirst(lc); @@ -520,6 +524,8 @@ ExecPrepareExprList(List *nodes, EState *estate) result = lappend(result, ExecPrepareExpr(e, estate)); } + MemoryContextSwitchTo(oldcontext); + return result; }