nodes.h 5.8 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.51 1999/08/16 02:17:39 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
	/*---------------------
	 * 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
	T_Iter,
68

69
	/*---------------------
70
	 * TAGS FOR PLANNER NODES (relation.h)
71 72
	 *---------------------
	 */
B
Bruce Momjian 已提交
73
	T_RelOptInfo = 200,
74 75
	T_Path,
	T_IndexPath,
76
	T_NestPath,
77 78
	T_MergePath,
	T_HashPath,
79
	T_PathKeyItem,
80
	T_RestrictInfo,
81
	T_JoinInfo,
82
	T_Stream,
83

84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
	/*---------------------
	 * 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,
113

114 115 116 117 118 119 120 121 122
	/*---------------------
	 * TAGS FOR MEMORY NODES (memnodes.h)
	 *---------------------
	 */
	T_MemoryContext = 400,
	T_GlobalMemory,
	T_PortalMemoryContext,
	T_PortalVariableMemory,
	T_PortalHeapMemory,
123

124 125 126 127 128 129 130 131 132 133
	/*---------------------
	 * TAGS FOR VALUE NODES (pg_list.h)
	 *---------------------
	 */
	T_Value = 500,
	T_List,
	T_Integer,
	T_Float,
	T_String,
	T_Null,
134

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

	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 已提交
202
	T_Constraint,
203 204 205 206 207
	T_DefElem,
	T_TargetEntry,
	T_RangeTblEntry,
	T_SortClause,
	T_GroupClause,
M
 
Marc G. Fournier 已提交
208
	T_SubSelect,
209
	T_JoinExpr,
T
Thomas G. Lockhart 已提交
210
	T_CaseExpr,
211 212
	T_CaseWhen,
	T_RowMark
213
} NodeTag;
214 215

/*
T
Thomas G. Lockhart 已提交
216
 * The first field of a node of any type is guaranteed to be the NodeTag.
217 218 219 220
 * 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.
 */
221 222
typedef struct Node
{
223
	NodeTag		type;
224
} Node;
225

226
#define nodeTag(nodeptr)		(((Node*)(nodeptr))->type)
227

228 229
#define makeNode(_type_)		((_type_ *) newNode(sizeof(_type_),T_##_type_))
#define NodeSetTag(nodeptr,t)	(((Node*)(nodeptr))->type = (t))
230

231
#define IsA(nodeptr,_type_)		(nodeTag(nodeptr) == T_##_type_)
232 233

/* ----------------------------------------------------------------
234
 *					  IsA functions (no inheritance any more)
235 236 237
 * ----------------------------------------------------------------
 */
#define IsA_JoinPath(jp) \
238
	(IsA(jp, NestPath) || IsA(jp, MergePath) || IsA(jp, HashPath))
239

240 241 242
#define IsA_Join(jp) \
	(IsA(jp, Join) || IsA(jp, NestLoop) || \
	 IsA(jp, MergeJoin) || IsA(jp, HashJoin))
243

244
#define IsA_Noname(t) \
245 246
	(IsA(t, Noname) || IsA(t, Material) || IsA(t, Sort) || \
	 IsA(t, Unique))
247 248

/* ----------------------------------------------------------------
249
 *					  extern declarations follow
250 251 252 253 254 255
 * ----------------------------------------------------------------
 */

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

258 259 260
/*
 * nodes/{outfuncs.c,print.c}
 */
261
extern char *nodeToString(void *obj);
262 263 264 265

/*
 * nodes/{readfuncs.c,read.c}
 */
266
extern void *stringToNode(char *str);
267 268 269 270

/*
 * nodes/copyfuncs.c
 */
271
extern void *copyObject(void *obj);
272 273 274 275

/*
 * nodes/equalfuncs.c
 */
276
extern bool equal(void *a, void *b);
277 278 279


/* ----------------
280 281
 *		I don't know why this is here.  Most likely a hack..
 *		-cim 6/3/90
282 283
 * ----------------
 */
284
typedef float Cost;
285 286 287

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

306

307
#endif	 /* NODES_H */