postgresql/src/include/executor/nodeCustom.h

42 lines
1.2 KiB
C
Raw Normal View History

/* ------------------------------------------------------------------------
*
* nodeCustom.h
*
* prototypes for CustomScan nodes
*
2017-01-03 13:48:53 -05:00
* Portions Copyright (c) 1996-2017, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* ------------------------------------------------------------------------
*/
#ifndef NODECUSTOM_H
#define NODECUSTOM_H
#include "access/parallel.h"
#include "nodes/execnodes.h"
#include "nodes/extensible.h"
/*
* General executor code
*/
extern CustomScanState *ExecInitCustomScan(CustomScan *custom_scan,
EState *estate, int eflags);
extern TupleTableSlot *ExecCustomScan(CustomScanState *node);
extern void ExecEndCustomScan(CustomScanState *node);
extern void ExecReScanCustomScan(CustomScanState *node);
extern void ExecCustomMarkPos(CustomScanState *node);
extern void ExecCustomRestrPos(CustomScanState *node);
/*
* Parallel execution support
*/
extern void ExecCustomScanEstimate(CustomScanState *node,
2016-06-09 18:02:36 -04:00
ParallelContext *pcxt);
extern void ExecCustomScanInitializeDSM(CustomScanState *node,
2016-06-09 18:02:36 -04:00
ParallelContext *pcxt);
extern void ExecCustomScanInitializeWorker(CustomScanState *node,
2016-06-09 18:02:36 -04:00
shm_toc *toc);
#endif /* NODECUSTOM_H */