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.50 1999/07/15 15:21:17 momjian 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
	/*---------------------
	 * 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,
41
	T_Noname,
42 43 44 45 46 47 48
	T_Material,
	T_Sort,
	T_Agg,
	T_Unique,
	T_Hash,
	T_Choose,
	T_Group,
49
	T_SubPlan,
50

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

68 69 70 71
	/*---------------------
	 * TAGS FOR INNER PLAN NODES (relation.h)
	 *---------------------
	 */
B
Bruce Momjian 已提交
72
	T_RelOptInfo = 200,
73
	T_PathOrder,
74 75
	T_Path,
	T_IndexPath,
76
	T_NestPath,
77 78 79 80 81
	T_MergePath,
	T_HashPath,
	T_OrderKey,
	T_JoinKey,
	T_MergeOrder,
82
	T_RestrictInfo,
83
	T_JoinMethod,
84
	T_HashInfo,
B
Bruce Momjian 已提交
85
	T_MergeInfo,
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
	/*---------------------
	 * 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,
119

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

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

141 142 143 144 145
	/*---------------------
	 * TAGS FOR PARSE TREE NODES (parsenode.h)
	 *---------------------
	 */
	T_Query = 600,
B
Bruce Momjian 已提交
146
	T_InsertStmt,
147
	T_DeleteStmt,
B
Bruce Momjian 已提交
148 149
	T_UpdateStmt,
	T_SelectStmt,
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171
	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_RemoveAggrStmt,
	T_RemoveFuncStmt,
	T_RemoveOperStmt,
	T_RemoveStmt,
	T_RenameStmt,
	T_RuleStmt,
	T_NotifyStmt,
	T_ListenStmt,
M
 
Marc G. Fournier 已提交
172
	T_UnlistenStmt,
173 174 175 176 177 178 179 180 181 182 183 184 185
	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,
186 187
	T_CreatePLangStmt,
	T_DropPLangStmt,
188 189 190
	T_CreateUserStmt,
	T_AlterUserStmt,
	T_DropUserStmt,
191
	T_LockStmt,
192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207

	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 已提交
208
	T_Constraint,
209 210 211 212 213
	T_DefElem,
	T_TargetEntry,
	T_RangeTblEntry,
	T_SortClause,
	T_GroupClause,
M
 
Marc G. Fournier 已提交
214
	T_SubSelect,
215
	T_JoinExpr,
T
Thomas G. Lockhart 已提交
216
	T_CaseExpr,
217 218
	T_CaseWhen,
	T_RowMark
219
} NodeTag;
220 221

/*
T
Thomas G. Lockhart 已提交
222
 * The first field of a node of any type is guaranteed to be the NodeTag.
223 224 225 226
 * 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.
 */
227 228
typedef struct Node
{
229
	NodeTag		type;
230
} Node;
231

232
#define nodeTag(_node_)			((Node*)_node_)->type
233

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

237
#define IsA(_node_,_tag_)		(nodeTag(_node_) == T_##_tag_)
238 239

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

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

251 252
#define IsA_Noname(t) \
	(nodeTag(t)==T_Noname || nodeTag(t)==T_Material || nodeTag(t)==T_Sort || \
253
	 nodeTag(t)==T_Unique)
254 255

/* ----------------------------------------------------------------
256
 *					  extern declarations follow
257 258 259 260 261 262
 * ----------------------------------------------------------------
 */

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

265
extern char *nodeToString(void *obj);
266 267 268 269

/*
 * nodes/{readfuncs.c,read.c}
 */
270
extern void *stringToNode(char *str);
271 272 273 274

/*
 * nodes/copyfuncs.c
 */
275
extern void *copyObject(void *obj);
276 277 278 279

/*
 * nodes/equalfuncs.c
 */
280
extern bool equal(void *a, void *b);
281 282 283


/* ----------------
284 285
 *		I don't know why this is here.  Most likely a hack..
 *		-cim 6/3/90
286 287
 * ----------------
 */
288
typedef float Cost;
289 290 291

/*
 * CmdType -
292
 *	  enums for type of operation to aid debugging
293 294
 *
 * ??? could have put this in parsenodes.h but many files not in the
295
 *	  optimizer also need this...
296
 */
297 298 299 300 301 302 303
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,
304
	CMD_UTILITY,				/* cmds like create, destroy, copy,
305
								 * vacuum, etc. */
306 307
	CMD_NOTHING					/* dummy command for instead nothing rules
								 * with qual */
308
} CmdType;
309

310

311
#endif	 /* NODES_H */