mirror of
https://github.com/postgres/postgres.git
synced 2026-02-03 20:40:14 -05:00
This patch doesn't put the new infrastructure to use anywhere, and indeed it's not clear how it could ever be used for something like postgres_fdw which has to send an SQL query and wait for a reply, but there might be FDWs or custom scan providers that are CPU-bound, so let's give them a way to join club parallel. KaiGai Kohei, reviewed by me.
40 lines
1.2 KiB
C
40 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"
|
|
|
|
/*
|
|
* 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 */
|