mirror of https://github.com/citusdata/citus.git
92 lines
3.4 KiB
C
92 lines
3.4 KiB
C
/*-------------------------------------------------------------------------
|
|
*
|
|
* citus_nodefuncs.h
|
|
* Node (de-)serialization support for Citus.
|
|
*
|
|
* Copyright (c) 2012-2016, Citus Data, Inc.
|
|
*
|
|
*-------------------------------------------------------------------------
|
|
*/
|
|
|
|
#ifndef CITUS_NODEFUNCS_H
|
|
#define CITUS_NODEFUNCS_H
|
|
|
|
#include "distributed/multi_physical_planner.h"
|
|
#include "nodes/nodes.h"
|
|
#include "nodes/parsenodes.h"
|
|
|
|
/* citus_nodefuncs.c */
|
|
extern void SetRangeTblExtraData(RangeTblEntry *rte, CitusRTEKind rteKind,
|
|
char *fragmentSchemaName, char *fragmentTableName,
|
|
List *tableIdList);
|
|
extern void ModifyRangeTblExtraData(RangeTblEntry *rte, CitusRTEKind rteKind,
|
|
char *fragmentSchemaName, char *fragmentTableName,
|
|
List *tableIdList);
|
|
extern void ExtractRangeTblExtraData(RangeTblEntry *rte, CitusRTEKind *rteKind,
|
|
char **fragmentSchemaName, char **fragmentTableName,
|
|
List **tableIdList);
|
|
extern CitusRTEKind GetRangeTblKind(RangeTblEntry *rte);
|
|
|
|
extern void RegisterNodes(void);
|
|
|
|
/*
|
|
* Define read functions for citus nodes in a way they're usable across
|
|
* several major versions. That requires some macro-uglyness as 9.6+ is quite
|
|
* different from before.
|
|
*/
|
|
|
|
#define READFUNC_ARGS struct ExtensibleNode *node
|
|
#define READFUNC_RET void
|
|
|
|
#define OUTFUNC_ARGS StringInfo str, const struct ExtensibleNode *raw_node
|
|
#define COPYFUNC_ARGS struct ExtensibleNode *target_node, const struct \
|
|
ExtensibleNode *source_node
|
|
|
|
extern READFUNC_RET ReadJob(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadMultiPlan(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadShardInterval(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadMapMergeJob(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadShardPlacement(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadRelationShard(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadTask(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadTaskExecution(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadDeferredErrorMessage(READFUNC_ARGS);
|
|
extern READFUNC_RET ReadGroupShardPlacement(READFUNC_ARGS);
|
|
|
|
extern READFUNC_RET ReadUnsupportedCitusNode(READFUNC_ARGS);
|
|
|
|
extern void OutJob(OUTFUNC_ARGS);
|
|
extern void OutMultiPlan(OUTFUNC_ARGS);
|
|
extern void OutShardInterval(OUTFUNC_ARGS);
|
|
extern void OutMapMergeJob(OUTFUNC_ARGS);
|
|
extern void OutShardPlacement(OUTFUNC_ARGS);
|
|
extern void OutRelationShard(OUTFUNC_ARGS);
|
|
extern void OutTask(OUTFUNC_ARGS);
|
|
extern void OutTaskExecution(OUTFUNC_ARGS);
|
|
extern void OutDeferredErrorMessage(OUTFUNC_ARGS);
|
|
extern void OutGroupShardPlacement(OUTFUNC_ARGS);
|
|
|
|
extern void OutMultiNode(OUTFUNC_ARGS);
|
|
extern void OutMultiTreeRoot(OUTFUNC_ARGS);
|
|
extern void OutMultiProject(OUTFUNC_ARGS);
|
|
extern void OutMultiCollect(OUTFUNC_ARGS);
|
|
extern void OutMultiSelect(OUTFUNC_ARGS);
|
|
extern void OutMultiTable(OUTFUNC_ARGS);
|
|
extern void OutMultiJoin(OUTFUNC_ARGS);
|
|
extern void OutMultiPartition(OUTFUNC_ARGS);
|
|
extern void OutMultiCartesianProduct(OUTFUNC_ARGS);
|
|
extern void OutMultiExtendedOp(OUTFUNC_ARGS);
|
|
|
|
extern void CopyNodeJob(COPYFUNC_ARGS);
|
|
extern void CopyNodeMultiPlan(COPYFUNC_ARGS);
|
|
extern void CopyNodeShardInterval(COPYFUNC_ARGS);
|
|
extern void CopyNodeMapMergeJob(COPYFUNC_ARGS);
|
|
extern void CopyNodeShardPlacement(COPYFUNC_ARGS);
|
|
extern void CopyNodeGroupShardPlacement(COPYFUNC_ARGS);
|
|
extern void CopyNodeRelationShard(COPYFUNC_ARGS);
|
|
extern void CopyNodeTask(COPYFUNC_ARGS);
|
|
extern void CopyNodeTaskExecution(COPYFUNC_ARGS);
|
|
extern void CopyNodeDeferredErrorMessage(COPYFUNC_ARGS);
|
|
|
|
#endif /* CITUS_NODEFUNCS_H */
|