init
This commit is contained in:
100
pg_include/foreign/fdwapi.h
Executable file
100
pg_include/foreign/fdwapi.h
Executable file
@@ -0,0 +1,100 @@
|
||||
/*-------------------------------------------------------------------------
|
||||
*
|
||||
* fdwapi.h
|
||||
* API for foreign-data wrappers
|
||||
*
|
||||
* Copyright (c) 2010-2012, PostgreSQL Global Development Group
|
||||
*
|
||||
* src/include/foreign/fdwapi.h
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
#ifndef FDWAPI_H
|
||||
#define FDWAPI_H
|
||||
|
||||
#include "nodes/execnodes.h"
|
||||
#include "nodes/relation.h"
|
||||
|
||||
/* To avoid including explain.h here, reference ExplainState thus: */
|
||||
struct ExplainState;
|
||||
|
||||
|
||||
/*
|
||||
* Callback function signatures --- see fdwhandler.sgml for more info.
|
||||
*/
|
||||
|
||||
typedef void (*GetForeignRelSize_function) (PlannerInfo *root,
|
||||
RelOptInfo *baserel,
|
||||
Oid foreigntableid);
|
||||
|
||||
typedef void (*GetForeignPaths_function) (PlannerInfo *root,
|
||||
RelOptInfo *baserel,
|
||||
Oid foreigntableid);
|
||||
|
||||
typedef ForeignScan *(*GetForeignPlan_function) (PlannerInfo *root,
|
||||
RelOptInfo *baserel,
|
||||
Oid foreigntableid,
|
||||
ForeignPath *best_path,
|
||||
List *tlist,
|
||||
List *scan_clauses);
|
||||
|
||||
typedef void (*ExplainForeignScan_function) (ForeignScanState *node,
|
||||
struct ExplainState *es);
|
||||
|
||||
typedef void (*BeginForeignScan_function) (ForeignScanState *node,
|
||||
int eflags);
|
||||
|
||||
typedef TupleTableSlot *(*IterateForeignScan_function) (ForeignScanState *node);
|
||||
|
||||
typedef void (*ReScanForeignScan_function) (ForeignScanState *node);
|
||||
|
||||
typedef void (*EndForeignScan_function) (ForeignScanState *node);
|
||||
|
||||
typedef int (*AcquireSampleRowsFunc) (Relation relation, int elevel,
|
||||
HeapTuple *rows, int targrows,
|
||||
double *totalrows,
|
||||
double *totaldeadrows);
|
||||
|
||||
typedef bool (*AnalyzeForeignTable_function) (Relation relation,
|
||||
AcquireSampleRowsFunc *func,
|
||||
BlockNumber *totalpages);
|
||||
|
||||
/*
|
||||
* FdwRoutine is the struct returned by a foreign-data wrapper's handler
|
||||
* function. It provides pointers to the callback functions needed by the
|
||||
* planner and executor.
|
||||
*
|
||||
* More function pointers are likely to be added in the future. Therefore
|
||||
* it's recommended that the handler initialize the struct with
|
||||
* makeNode(FdwRoutine) so that all fields are set to NULL. This will
|
||||
* ensure that no fields are accidentally left undefined.
|
||||
*/
|
||||
typedef struct FdwRoutine
|
||||
{
|
||||
NodeTag type;
|
||||
|
||||
/*
|
||||
* These functions are required.
|
||||
*/
|
||||
GetForeignRelSize_function GetForeignRelSize;
|
||||
GetForeignPaths_function GetForeignPaths;
|
||||
GetForeignPlan_function GetForeignPlan;
|
||||
ExplainForeignScan_function ExplainForeignScan;
|
||||
BeginForeignScan_function BeginForeignScan;
|
||||
IterateForeignScan_function IterateForeignScan;
|
||||
ReScanForeignScan_function ReScanForeignScan;
|
||||
EndForeignScan_function EndForeignScan;
|
||||
|
||||
/*
|
||||
* These functions are optional. Set the pointer to NULL for any that are
|
||||
* not provided.
|
||||
*/
|
||||
AnalyzeForeignTable_function AnalyzeForeignTable;
|
||||
} FdwRoutine;
|
||||
|
||||
|
||||
/* Functions in foreign/foreign.c */
|
||||
extern FdwRoutine *GetFdwRoutine(Oid fdwhandler);
|
||||
extern FdwRoutine *GetFdwRoutineByRelId(Oid relid);
|
||||
|
||||
#endif /* FDWAPI_H */
|
||||
84
pg_include/foreign/foreign.h
Executable file
84
pg_include/foreign/foreign.h
Executable file
@@ -0,0 +1,84 @@
|
||||
/*-------------------------------------------------------------------------
|
||||
*
|
||||
* foreign.h
|
||||
* support for foreign-data wrappers, servers and user mappings.
|
||||
*
|
||||
*
|
||||
* Portions Copyright (c) 1996-2012, PostgreSQL Global Development Group
|
||||
*
|
||||
* src/include/foreign/foreign.h
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
#ifndef FOREIGN_H
|
||||
#define FOREIGN_H
|
||||
|
||||
#include "nodes/parsenodes.h"
|
||||
|
||||
|
||||
/* Helper for obtaining username for user mapping */
|
||||
#define MappingUserName(userid) \
|
||||
(OidIsValid(userid) ? GetUserNameFromId(userid) : "public")
|
||||
|
||||
|
||||
/*
|
||||
* Generic option types for validation.
|
||||
* NB! Thes are treated as flags, so use only powers of two here.
|
||||
*/
|
||||
typedef enum
|
||||
{
|
||||
ServerOpt = 1, /* options applicable to SERVER */
|
||||
UserMappingOpt = 2, /* options for USER MAPPING */
|
||||
FdwOpt = 4 /* options for FOREIGN DATA WRAPPER */
|
||||
} GenericOptionFlags;
|
||||
|
||||
typedef struct ForeignDataWrapper
|
||||
{
|
||||
Oid fdwid; /* FDW Oid */
|
||||
Oid owner; /* FDW owner user Oid */
|
||||
char *fdwname; /* Name of the FDW */
|
||||
Oid fdwhandler; /* Oid of handler function, or 0 */
|
||||
Oid fdwvalidator; /* Oid of validator function, or 0 */
|
||||
List *options; /* fdwoptions as DefElem list */
|
||||
} ForeignDataWrapper;
|
||||
|
||||
typedef struct ForeignServer
|
||||
{
|
||||
Oid serverid; /* server Oid */
|
||||
Oid fdwid; /* foreign-data wrapper */
|
||||
Oid owner; /* server owner user Oid */
|
||||
char *servername; /* name of the server */
|
||||
char *servertype; /* server type, optional */
|
||||
char *serverversion; /* server version, optional */
|
||||
List *options; /* srvoptions as DefElem list */
|
||||
} ForeignServer;
|
||||
|
||||
typedef struct UserMapping
|
||||
{
|
||||
Oid userid; /* local user Oid */
|
||||
Oid serverid; /* server Oid */
|
||||
List *options; /* useoptions as DefElem list */
|
||||
} UserMapping;
|
||||
|
||||
typedef struct ForeignTable
|
||||
{
|
||||
Oid relid; /* relation Oid */
|
||||
Oid serverid; /* server Oid */
|
||||
List *options; /* ftoptions as DefElem list */
|
||||
} ForeignTable;
|
||||
|
||||
|
||||
extern ForeignServer *GetForeignServer(Oid serverid);
|
||||
extern ForeignServer *GetForeignServerByName(const char *name, bool missing_ok);
|
||||
extern UserMapping *GetUserMapping(Oid userid, Oid serverid);
|
||||
extern ForeignDataWrapper *GetForeignDataWrapper(Oid fdwid);
|
||||
extern ForeignDataWrapper *GetForeignDataWrapperByName(const char *name,
|
||||
bool missing_ok);
|
||||
extern ForeignTable *GetForeignTable(Oid relid);
|
||||
|
||||
extern List *GetForeignColumnOptions(Oid relid, AttrNumber attnum);
|
||||
|
||||
extern Oid get_foreign_data_wrapper_oid(const char *fdwname, bool missing_ok);
|
||||
extern Oid get_foreign_server_oid(const char *servername, bool missing_ok);
|
||||
|
||||
#endif /* FOREIGN_H */
|
||||
Reference in New Issue
Block a user