Commit cf402ba7 authored by Robert Haas's avatar Robert Haas

Tighten up sanity checks for parallel aggregate in execQual.c.

David Rowley
parent b33dc776
...@@ -4510,28 +4510,35 @@ ExecInitExpr(Expr *node, PlanState *parent) ...@@ -4510,28 +4510,35 @@ ExecInitExpr(Expr *node, PlanState *parent)
case T_Aggref: case T_Aggref:
{ {
AggrefExprState *astate = makeNode(AggrefExprState); AggrefExprState *astate = makeNode(AggrefExprState);
astate->xprstate.evalfunc = (ExprStateEvalFunc) ExecEvalAggref;
if (parent && IsA(parent, AggState))
{
AggState *aggstate = (AggState *) parent; AggState *aggstate = (AggState *) parent;
Aggref *aggref = (Aggref *) node; Aggref *aggref = (Aggref *) node;
if (aggstate->finalizeAggs && astate->xprstate.evalfunc = (ExprStateEvalFunc) ExecEvalAggref;
aggref->aggoutputtype != aggref->aggtype) if (!aggstate || !IsA(aggstate, AggState))
{ {
/* planner messed up */ /* planner messed up */
elog(ERROR, "Aggref aggoutputtype must match aggtype"); elog(ERROR, "Aggref found in non-Agg plan node");
}
aggstate->aggs = lcons(astate, aggstate->aggs);
aggstate->numaggs++;
} }
if (aggref->aggpartial == aggstate->finalizeAggs)
{
/* planner messed up */
if (aggref->aggpartial)
elog(ERROR, "partial Aggref found in finalize agg plan node");
else else
elog(ERROR, "non-partial Aggref found in non-finalize agg plan node");
}
if (aggref->aggcombine != aggstate->combineStates)
{ {
/* planner messed up */ /* planner messed up */
elog(ERROR, "Aggref found in non-Agg plan node"); if (aggref->aggcombine)
elog(ERROR, "combine Aggref found in non-combine agg plan node");
else
elog(ERROR, "non-combine Aggref found in combine agg plan node");
} }
aggstate->aggs = lcons(astate, aggstate->aggs);
aggstate->numaggs++;
state = (ExprState *) astate; state = (ExprState *) astate;
} }
break; break;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment