mirror of
https://github.com/postgres/postgres.git
synced 2026-02-03 20:40:14 -05:00
Per discussion, the new extensible node framework is thought to be better designed than the custom path/scan/scanstate stuff we added in PostgreSQL 9.5. Rework the latter to be more like the former. This is not backward-compatible, but we generally don't promise that for C APIs, and there probably aren't many people using this yet anyway. KaiGai Kohei, reviewed by Petr Jelinek and me. Some further cosmetic changes by me.
41 lines
1.2 KiB
C
41 lines
1.2 KiB
C
/* ------------------------------------------------------------------------
|
|
*
|
|
* nodeCustom.h
|
|
*
|
|
* prototypes for CustomScan nodes
|
|
*
|
|
* Portions Copyright (c) 1996-2016, 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,
|
|
ParallelContext *pcxt);
|
|
extern void ExecCustomScanInitializeDSM(CustomScanState *node,
|
|
ParallelContext *pcxt);
|
|
extern void ExecCustomScanInitializeWorker(CustomScanState *node,
|
|
shm_toc *toc);
|
|
|
|
#endif /* NODECUSTOM_H */
|