44 elog(
ERROR,
"BitmapAnd node does not support ExecProcNode call convention");
78 bitmapandstate->
ps.
state = estate;
81 bitmapandstate->
nplans = nplans;
102 return bitmapandstate;
130 for (
i = 0;
i < nplans;
i++)
138 elog(
ERROR,
"unrecognized result from subplan");
160 elog(
ERROR,
"BitmapAnd doesn't support zero inputs");
166 return (
Node *) result;
193 for (
i = 0;
i < nplans;
i++)
#define Assert(condition)
void ExecReScan(PlanState *node)
Node * MultiExecProcNode(PlanState *node)
void ExecEndNode(PlanState *node)
PlanState * ExecInitNode(Plan *node, EState *estate, int eflags)
void UpdateChangedParamSet(PlanState *node, Bitmapset *newchg)
#define EXEC_FLAG_BACKWARD
void InstrStartNode(Instrumentation *instr)
void InstrStopNode(Instrumentation *instr, double nTuples)
void * palloc0(Size size)
BitmapAndState * ExecInitBitmapAnd(BitmapAnd *node, EState *estate, int eflags)
Node * MultiExecBitmapAnd(BitmapAndState *node)
void ExecEndBitmapAnd(BitmapAndState *node)
static TupleTableSlot * ExecBitmapAnd(PlanState *pstate)
void ExecReScanBitmapAnd(BitmapAndState *node)
#define IsA(nodeptr, _type_)
static int list_length(const List *l)
Instrumentation * instrument
ExecProcNodeMtd ExecProcNode
void tbm_free(TIDBitmap *tbm)
bool tbm_is_empty(const TIDBitmap *tbm)
void tbm_intersect(TIDBitmap *a, const TIDBitmap *b)