nodes.h 5.9 KB
Newer Older
1 2 3
/*-------------------------------------------------------------------------
 *
 * nodes.h--
4
 *	  Definitions for tagged nodes.
5 6 7 8
 *
 *
 * Copyright (c) 1994, Regents of the University of California
 *
9
 * $Id: nodes.h,v 1.31 1998/10/01 02:04:01 tgl Exp $
10 11 12 13
 *
 *-------------------------------------------------------------------------
 */
#ifndef NODES_H
14
#define NODES_H
15 16 17 18 19 20 21 22

/*
 * The first field of every node is NodeTag. Each node created (with makeNode)
 * will have one of the following tags as the value of its first field.
 *
 * Note that the number of the node tags are not contiguous. We left holes
 * here so that we can add more tags without changing the existing enum's.
 */
23 24 25
typedef enum NodeTag
{
	T_Invalid = 0,
26

27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
	/*---------------------
	 * TAGS FOR PLAN NODES (plannodes.h)
	 *---------------------
	 */
	T_Plan = 10,
	T_Result,
	T_Append,
	T_Scan,
	T_SeqScan,
	T_IndexScan,
	T_Join,
	T_NestLoop,
	T_MergeJoin,
	T_HashJoin,
	T_Temp,
	T_Material,
	T_Sort,
	T_Agg,
	T_Unique,
	T_Hash,
	T_Choose,
	T_Tee,
	T_Group,
50
	T_SubPlan,
51

52 53 54 55 56 57 58 59 60 61 62 63
	/*---------------------
	 * TAGS FOR PRIMITIVE NODES (primnodes.h)
	 *---------------------
	 */
	T_Resdom = 100,
	T_Fjoin,
	T_Expr,
	T_Var,
	T_Oper,
	T_Const,
	T_Param,
	T_Aggreg,
64
	T_SubLink,
65 66 67
	T_Func,
	T_Array,
	T_ArrayRef,
68

69 70 71 72
	/*---------------------
	 * TAGS FOR INNER PLAN NODES (relation.h)
	 *---------------------
	 */
B
Bruce Momjian 已提交
73
	T_RelOptInfo = 200,
74 75 76 77 78 79 80 81
	T_Path,
	T_IndexPath,
	T_JoinPath,
	T_MergePath,
	T_HashPath,
	T_OrderKey,
	T_JoinKey,
	T_MergeOrder,
82
	T_ClauseInfo,
83 84 85
	T_JoinMethod,
	T_HInfo,
	T_MInfo,
86
	T_JoinInfo,
87 88
	T_Iter,
	T_Stream,
89

90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
	/*---------------------
	 * TAGS FOR EXECUTOR NODES (execnodes.h)
	 *---------------------
	 */
	T_IndexInfo = 300,
	T_RelationInfo,
	T_TupleCount,
	T_TupleTableSlot,
	T_ExprContext,
	T_ProjectionInfo,
	T_JunkFilter,
	T_EState,
	T_BaseNode,
	T_CommonState,
	T_ResultState,
	T_AppendState,
	T_CommonScanState,
	T_ScanState,
	T_IndexScanState,
	T_JoinState,
	T_NestLoopState,
	T_MergeJoinState,
	T_HashJoinState,
	T_MaterialState,
	T_AggState,
	T_GroupState,
	T_SortState,
	T_UniqueState,
	T_HashState,
	T_TeeState,
120

121 122 123 124 125 126 127 128 129
	/*---------------------
	 * TAGS FOR MEMORY NODES (memnodes.h)
	 *---------------------
	 */
	T_MemoryContext = 400,
	T_GlobalMemory,
	T_PortalMemoryContext,
	T_PortalVariableMemory,
	T_PortalHeapMemory,
130

131 132 133 134 135 136 137 138 139 140
	/*---------------------
	 * TAGS FOR VALUE NODES (pg_list.h)
	 *---------------------
	 */
	T_Value = 500,
	T_List,
	T_Integer,
	T_Float,
	T_String,
	T_Null,
141

142 143 144 145 146
	/*---------------------
	 * TAGS FOR PARSE TREE NODES (parsenode.h)
	 *---------------------
	 */
	T_Query = 600,
B
Bruce Momjian 已提交
147
	T_InsertStmt,
148
	T_DeleteStmt,
B
Bruce Momjian 已提交
149 150
	T_UpdateStmt,
	T_SelectStmt,
151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173
	T_AddAttrStmt,
	T_AggregateStmt,
	T_ChangeACLStmt,
	T_ClosePortalStmt,
	T_ClusterStmt,
	T_CopyStmt,
	T_CreateStmt,
	T_VersionStmt,
	T_DefineStmt,
	T_DestroyStmt,
	T_ExtendStmt,
	T_FetchStmt,
	T_IndexStmt,
	T_ProcedureStmt,
	T_RecipeStmt,
	T_RemoveAggrStmt,
	T_RemoveFuncStmt,
	T_RemoveOperStmt,
	T_RemoveStmt,
	T_RenameStmt,
	T_RuleStmt,
	T_NotifyStmt,
	T_ListenStmt,
M
 
Marc G. Fournier 已提交
174
	T_UnlistenStmt,
175 176 177 178 179 180 181 182 183 184 185 186 187
	T_TransactionStmt,
	T_ViewStmt,
	T_LoadStmt,
	T_CreatedbStmt,
	T_DestroydbStmt,
	T_VacuumStmt,
	T_ExplainStmt,
	T_CreateSeqStmt,
	T_VariableSetStmt,
	T_VariableShowStmt,
	T_VariableResetStmt,
	T_CreateTrigStmt,
	T_DropTrigStmt,
188 189
	T_CreatePLangStmt,
	T_DropPLangStmt,
190 191 192
	T_CreateUserStmt,
	T_AlterUserStmt,
	T_DropUserStmt,
193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208

	T_A_Expr = 700,
	T_Attr,
	T_A_Const,
	T_ParamNo,
	T_Ident,
	T_FuncCall,
	T_A_Indices,
	T_ResTarget,
	T_ParamString,
	T_RelExpr,
	T_SortGroupBy,
	T_RangeVar,
	T_TypeName,
	T_IndexElem,
	T_ColumnDef,
T
Thomas G. Lockhart 已提交
209
	T_Constraint,
210 211 212 213 214
	T_DefElem,
	T_TargetEntry,
	T_RangeTblEntry,
	T_SortClause,
	T_GroupClause,
M
 
Marc G. Fournier 已提交
215 216
	T_SubSelect,
	T_JoinUsing
217
} NodeTag;
218 219 220 221 222 223 224

/*
 * The first field of a node of any type is gauranteed to be the NodeTag.
 * Hence the type of any node can be gotten by casting it to Node. Declaring
 * a variable to be of Node * (instead of void *) can also facilitate
 * debugging.
 */
225 226
typedef struct Node
{
227
	NodeTag		type;
228
} Node;
229

230
#define nodeTag(_node_)			((Node*)_node_)->type
231

232 233
#define makeNode(_node_)		(_node_*)newNode(sizeof(_node_),T_##_node_)
#define NodeSetTag(n, t)		((Node *)n)->type = t
234

235
#define IsA(_node_,_tag_)		(nodeTag(_node_) == T_##_tag_)
236 237

/* ----------------------------------------------------------------
238
 *					  IsA functions (no inheritence any more)
239 240 241
 * ----------------------------------------------------------------
 */
#define IsA_JoinPath(jp) \
242 243
	(nodeTag(jp)==T_JoinPath || nodeTag(jp)==T_MergePath || \
	 nodeTag(jp)==T_HashPath)
244 245

#define IsA_Join(j) \
246 247
	(nodeTag(j)==T_Join || nodeTag(j)==T_NestLoop || \
	 nodeTag(j)==T_MergeJoin || nodeTag(j)==T_HashJoin)
248 249

#define IsA_Temp(t) \
250 251
	(nodeTag(t)==T_Temp || nodeTag(t)==T_Material || nodeTag(t)==T_Sort || \
	 nodeTag(t)==T_Unique)
252 253

/* ----------------------------------------------------------------
254
 *					  extern declarations follow
255 256 257 258 259 260
 * ----------------------------------------------------------------
 */

/*
 * nodes/nodes.c
 */
261
extern Node *newNode(Size size, NodeTag tag);
262 263 264 265

/*
 * nodes/{outfuncs.c,print.c}
 */
266
#define nodeDisplay		pprint
267

268 269
extern char *nodeToString(void *obj);
extern void print(void *obj);
270 271 272 273

/*
 * nodes/{readfuncs.c,read.c}
 */
274
extern void *stringToNode(char *str);
275 276 277 278

/*
 * nodes/copyfuncs.c
 */
279
extern void *copyObject(void *obj);
280 281 282 283

/*
 * nodes/equalfuncs.c
 */
284
extern bool equal(void *a, void *b);
285 286 287


/* ----------------
288 289
 *		I don't know why this is here.  Most likely a hack..
 *		-cim 6/3/90
290 291
 * ----------------
 */
292
typedef float Cost;
293 294 295

/*
 * CmdType -
296
 *	  enums for type of operation to aid debugging
297 298
 *
 * ??? could have put this in parsenodes.h but many files not in the
299
 *	  optimizer also need this...
300
 */
301 302 303 304 305 306 307
typedef enum CmdType
{
	CMD_UNKNOWN,
	CMD_SELECT,					/* select stmt (formerly retrieve) */
	CMD_UPDATE,					/* update stmt (formerly replace) */
	CMD_INSERT,					/* insert stmt (formerly append) */
	CMD_DELETE,
308
	CMD_UTILITY,				/* cmds like create, destroy, copy,
309
								 * vacuum, etc. */
310 311
	CMD_NOTHING					/* dummy command for instead nothing rules
								 * with qual */
312
} CmdType;
313

314

315
#endif	 /* NODES_H */