nodes.h 9.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef _TD_NODES_H_
#define _TD_NODES_H_

#ifdef __cplusplus
extern "C" {
#endif

#include "tdef.h"

25 26 27 28 29 30 31 32
#define nodeType(nodeptr) (((const SNode*)(nodeptr))->type)
#define setNodeType(nodeptr, type) (((SNode*)(nodeptr))->type = (type))

#define LIST_LENGTH(l) (NULL != (l) ? (l)->length : 0)

#define FOREACH(node, list)	\
  for (SListCell* cell = (NULL != (list) ? (list)->pHead : NULL); (NULL != cell ? (node = cell->pNode, true) : (node = NULL, false)); cell = cell->pNext)

33 34
#define REPLACE_NODE(newNode) cell->pNode = (SNode*)(newNode)

X
Xiaoyu Wang 已提交
35 36 37 38 39 40 41 42 43 44 45
#define INSERT_LIST(target, src) nodesListInsertList((target), cell, src)

#define WHERE_EACH(node, list) \
  SListCell* cell = (NULL != (list) ? (list)->pHead : NULL); \
  while (NULL != cell ? (node = cell->pNode, true) : (node = NULL, false))

#define WHERE_NEXT cell = cell->pNext

// only be use in WHERE_EACH
#define ERASE_NODE(list) cell = nodesListErase((list), cell)

46 47 48 49 50
#define FORBOTH(node1, list1, node2, list2) \
  for (SListCell* cell1 = (NULL != (list1) ? (list1)->pHead : NULL), *cell2 = (NULL != (list2) ? (list2)->pHead : NULL); \
    (NULL == cell1 ? (node1 = NULL, false) : (node1 = cell1->pNode, true)), (NULL == cell2 ? (node2 = NULL, false) : (node2 = cell2->pNode, true)), (node1 != NULL && node2 != NULL); \
    cell1 = cell1->pNext, cell2 = cell2->pNext)

51 52 53
#define FOREACH_FOR_REWRITE(node, list)	\
  for (SListCell* cell = (NULL != (list) ? (list)->pHead : NULL); (NULL != cell ? (node = &(cell->pNode), true) : (node = NULL, false)); cell = cell->pNext)

54
typedef enum ENodeType {
55 56
  // Syntax nodes are used in parser and planner module, and some are also used in executor module, such as COLUMN,
  // VALUE, OPERATOR, FUNCTION and so on.
57 58 59 60 61 62 63 64 65 66
  QUERY_NODE_COLUMN = 1,
  QUERY_NODE_VALUE,
  QUERY_NODE_OPERATOR,
  QUERY_NODE_LOGIC_CONDITION,
  QUERY_NODE_FUNCTION,
  QUERY_NODE_REAL_TABLE,
  QUERY_NODE_TEMP_TABLE,
  QUERY_NODE_JOIN_TABLE,
  QUERY_NODE_GROUPING_SET,
  QUERY_NODE_ORDER_BY_EXPR,
67
  QUERY_NODE_LIMIT,
68 69 70
  QUERY_NODE_STATE_WINDOW,
  QUERY_NODE_SESSION_WINDOW,
  QUERY_NODE_INTERVAL_WINDOW,
71 72
  QUERY_NODE_NODE_LIST,
  QUERY_NODE_FILL,
73
  QUERY_NODE_RAW_EXPR,  // Only be used in parser module.
X
Xiaoyu Wang 已提交
74
  QUERY_NODE_TARGET,
X
Xiaoyu Wang 已提交
75
  QUERY_NODE_DATABLOCK_DESC,
X
Xiaoyu Wang 已提交
76
  QUERY_NODE_SLOT_DESC,
X
Xiaoyu Wang 已提交
77
  QUERY_NODE_COLUMN_DEF,
X
Xiaoyu Wang 已提交
78
  QUERY_NODE_DOWNSTREAM_SOURCE,
X
Xiaoyu Wang 已提交
79 80 81
  QUERY_NODE_DATABASE_OPTIONS,
  QUERY_NODE_TABLE_OPTIONS,
  QUERY_NODE_INDEX_OPTIONS,
82
  QUERY_NODE_EXPLAIN_OPTIONS,
83

84
  // Statement nodes are used in parser and planner module.
85
  QUERY_NODE_SET_OPERATOR,
86
  QUERY_NODE_SELECT_STMT,
X
Xiaoyu Wang 已提交
87
  QUERY_NODE_VNODE_MODIF_STMT,
88
  QUERY_NODE_CREATE_DATABASE_STMT,
89
  QUERY_NODE_DROP_DATABASE_STMT,
90
  QUERY_NODE_ALTER_DATABASE_STMT,
X
Xiaoyu Wang 已提交
91
  QUERY_NODE_CREATE_TABLE_STMT,
92
  QUERY_NODE_CREATE_SUBTABLE_CLAUSE,
93
  QUERY_NODE_CREATE_MULTI_TABLE_STMT,
94 95
  QUERY_NODE_DROP_TABLE_CLAUSE,
  QUERY_NODE_DROP_TABLE_STMT,
96
  QUERY_NODE_DROP_SUPER_TABLE_STMT,
97
  QUERY_NODE_ALTER_TABLE_STMT,
98 99 100 101 102 103
  QUERY_NODE_CREATE_USER_STMT,
  QUERY_NODE_ALTER_USER_STMT,
  QUERY_NODE_DROP_USER_STMT,
  QUERY_NODE_USE_DATABASE_STMT,
  QUERY_NODE_CREATE_DNODE_STMT,
  QUERY_NODE_DROP_DNODE_STMT,
104
  QUERY_NODE_ALTER_DNODE_STMT,
X
Xiaoyu Wang 已提交
105
  QUERY_NODE_CREATE_INDEX_STMT,
106
  QUERY_NODE_DROP_INDEX_STMT,
X
Xiaoyu Wang 已提交
107
  QUERY_NODE_CREATE_QNODE_STMT,
108
  QUERY_NODE_DROP_QNODE_STMT,
109 110 111 112 113 114
  QUERY_NODE_CREATE_BNODE_STMT,
  QUERY_NODE_DROP_BNODE_STMT,
  QUERY_NODE_CREATE_SNODE_STMT,
  QUERY_NODE_DROP_SNODE_STMT,
  QUERY_NODE_CREATE_MNODE_STMT,
  QUERY_NODE_DROP_MNODE_STMT,
115 116
  QUERY_NODE_CREATE_TOPIC_STMT,
  QUERY_NODE_DROP_TOPIC_STMT,
117
  QUERY_NODE_ALTER_LOCAL_STMT,
118
  QUERY_NODE_EXPLAIN_STMT,
119 120
  QUERY_NODE_DESCRIBE_STMT,
  QUERY_NODE_RESET_QUERY_CACHE_STMT,
121 122 123 124 125 126 127 128 129
  QUERY_NODE_COMPACT_STMT,
  QUERY_NODE_CREATE_FUNCTION_STMT,
  QUERY_NODE_DROP_FUNCTION_STMT,
  QUERY_NODE_CREATE_STREAM_STMT,
  QUERY_NODE_DROP_STREAM_STMT,
  QUERY_NODE_MERGE_VGROUP_STMT,
  QUERY_NODE_REDISTRIBUTE_VGROUP_STMT,
  QUERY_NODE_SPLIT_VGROUP_STMT,
  QUERY_NODE_SYNCDB_STMT,
130
  QUERY_NODE_SHOW_DNODES_STMT,
X
Xiaoyu Wang 已提交
131
  QUERY_NODE_SHOW_MNODES_STMT,
X
Xiaoyu Wang 已提交
132 133
  QUERY_NODE_SHOW_MODULES_STMT,
  QUERY_NODE_SHOW_QNODES_STMT,
134 135 136
  QUERY_NODE_SHOW_SNODES_STMT,
  QUERY_NODE_SHOW_BNODES_STMT,
  QUERY_NODE_SHOW_DATABASES_STMT,
X
Xiaoyu Wang 已提交
137 138
  QUERY_NODE_SHOW_FUNCTIONS_STMT,
  QUERY_NODE_SHOW_INDEXES_STMT,
139
  QUERY_NODE_SHOW_STABLES_STMT,
X
Xiaoyu Wang 已提交
140
  QUERY_NODE_SHOW_STREAMS_STMT,
141 142
  QUERY_NODE_SHOW_TABLES_STMT,
  QUERY_NODE_SHOW_USERS_STMT,
143
  QUERY_NODE_SHOW_LICENCE_STMT,
144
  QUERY_NODE_SHOW_VGROUPS_STMT,
145
  QUERY_NODE_SHOW_TOPICS_STMT,
146 147 148 149 150 151 152 153
  QUERY_NODE_SHOW_CONSUMERS_STMT,
  QUERY_NODE_SHOW_SUBSCRIBES_STMT,
  QUERY_NODE_SHOW_TRANS_STMT,
  QUERY_NODE_SHOW_SMAS_STMT,
  QUERY_NODE_SHOW_CONFIGS_STMT,
  QUERY_NODE_SHOW_CONNECTIONS_STMT,
  QUERY_NODE_SHOW_QUERIES_STMT,
  QUERY_NODE_SHOW_VNODES_STMT,
154 155
  QUERY_NODE_KILL_CONNECTION_STMT,
  QUERY_NODE_KILL_QUERY_STMT,
X
Xiaoyu Wang 已提交
156

X
Xiaoyu Wang 已提交
157
  // logic plan node
X
Xiaoyu Wang 已提交
158
  QUERY_NODE_LOGIC_PLAN_SCAN,
X
Xiaoyu Wang 已提交
159 160
  QUERY_NODE_LOGIC_PLAN_JOIN,
  QUERY_NODE_LOGIC_PLAN_AGG,
X
Xiaoyu Wang 已提交
161
  QUERY_NODE_LOGIC_PLAN_PROJECT,
162
  QUERY_NODE_LOGIC_PLAN_VNODE_MODIF,
X
Xiaoyu Wang 已提交
163
  QUERY_NODE_LOGIC_PLAN_EXCHANGE,
X
Xiaoyu Wang 已提交
164
  QUERY_NODE_LOGIC_PLAN_WINDOW,
X
Xiaoyu Wang 已提交
165
  QUERY_NODE_LOGIC_PLAN_SORT,
166
  QUERY_NODE_LOGIC_PLAN_PARTITION,
X
Xiaoyu Wang 已提交
167 168
  QUERY_NODE_LOGIC_SUBPLAN,
  QUERY_NODE_LOGIC_PLAN,
X
Xiaoyu Wang 已提交
169 170 171 172

  // physical plan node
  QUERY_NODE_PHYSICAL_PLAN_TAG_SCAN,
  QUERY_NODE_PHYSICAL_PLAN_TABLE_SCAN,
X
Xiaoyu Wang 已提交
173 174
  QUERY_NODE_PHYSICAL_PLAN_TABLE_SEQ_SCAN,
  QUERY_NODE_PHYSICAL_PLAN_STREAM_SCAN,
175
  QUERY_NODE_PHYSICAL_PLAN_SYSTABLE_SCAN,
X
Xiaoyu Wang 已提交
176 177
  QUERY_NODE_PHYSICAL_PLAN_PROJECT,
  QUERY_NODE_PHYSICAL_PLAN_JOIN,
X
Xiaoyu Wang 已提交
178 179 180
  QUERY_NODE_PHYSICAL_PLAN_AGG,
  QUERY_NODE_PHYSICAL_PLAN_EXCHANGE,
  QUERY_NODE_PHYSICAL_PLAN_SORT,
X
Xiaoyu Wang 已提交
181
  QUERY_NODE_PHYSICAL_PLAN_INTERVAL,
X
Xiaoyu Wang 已提交
182
  QUERY_NODE_PHYSICAL_PLAN_SESSION_WINDOW,
183 184
  QUERY_NODE_PHYSICAL_PLAN_STATE_WINDOW,
  QUERY_NODE_PHYSICAL_PLAN_PARTITION,
X
Xiaoyu Wang 已提交
185
  QUERY_NODE_PHYSICAL_PLAN_DISPATCH,
186
  QUERY_NODE_PHYSICAL_PLAN_INSERT,
X
Xiaoyu Wang 已提交
187 188
  QUERY_NODE_PHYSICAL_SUBPLAN,
  QUERY_NODE_PHYSICAL_PLAN
189 190 191 192 193 194 195 196 197 198
} ENodeType;

/**
 * The first field of a node of any type is guaranteed to be the ENodeType.
 * Hence the type of any node can be gotten by casting it to SNode. 
 */
typedef struct SNode {
  ENodeType type;
} SNode;

199
typedef struct SListCell {
200
  struct SListCell* pPrev;
201
  struct SListCell* pNext;
202
  SNode* pNode;
203 204 205
} SListCell;

typedef struct SNodeList {
X
Xiaoyu Wang 已提交
206
  int32_t length;
207 208
  SListCell* pHead;
  SListCell* pTail;
209 210
} SNodeList;

X
Xiaoyu Wang 已提交
211 212 213 214
#define SNodeptr void*  

SNodeptr nodesMakeNode(ENodeType type);
void nodesDestroyNode(SNodeptr pNode);
215 216

SNodeList* nodesMakeList();
X
Xiaoyu Wang 已提交
217
int32_t nodesListAppend(SNodeList* pList, SNodeptr pNode);
218
int32_t nodesListStrictAppend(SNodeList* pList, SNodeptr pNode);
X
Xiaoyu Wang 已提交
219
int32_t nodesListMakeAppend(SNodeList** pList, SNodeptr pNode);
220
int32_t nodesListMakeStrictAppend(SNodeList** pList, SNodeptr pNode);
X
Xiaoyu Wang 已提交
221
int32_t nodesListAppendList(SNodeList* pTarget, SNodeList* pSrc);
222
int32_t nodesListStrictAppendList(SNodeList* pTarget, SNodeList* pSrc);
X
Xiaoyu Wang 已提交
223
int32_t nodesListPushFront(SNodeList* pList, SNodeptr pNode);
224
SListCell* nodesListErase(SNodeList* pList, SListCell* pCell);
X
Xiaoyu Wang 已提交
225
void nodesListInsertList(SNodeList* pTarget, SListCell* pPos, SNodeList* pSrc);
X
Xiaoyu Wang 已提交
226
SNodeptr nodesListGetNode(SNodeList* pList, int32_t index);
227
void nodesDestroyList(SNodeList* pList);
X
Xiaoyu Wang 已提交
228 229
// Only clear the linked list structure, without releasing the elements inside
void nodesClearList(SNodeList* pList);
230

231 232 233 234
typedef enum EDealRes {
  DEAL_RES_CONTINUE = 1,
  DEAL_RES_IGNORE_CHILD,
  DEAL_RES_ERROR,
235
  DEAL_RES_END
236
} EDealRes;
237

238
typedef EDealRes (*FNodeWalker)(SNode* pNode, void* pContext);
X
Xiaoyu Wang 已提交
239 240 241 242
void nodesWalkExpr(SNodeptr pNode, FNodeWalker walker, void* pContext);
void nodesWalkExprs(SNodeList* pList, FNodeWalker walker, void* pContext);
void nodesWalkExprPostOrder(SNodeptr pNode, FNodeWalker walker, void* pContext);
void nodesWalkExprsPostOrder(SNodeList* pList, FNodeWalker walker, void* pContext);
243 244

typedef EDealRes (*FNodeRewriter)(SNode** pNode, void* pContext);
X
Xiaoyu Wang 已提交
245 246 247 248
void nodesRewriteExpr(SNode** pNode, FNodeRewriter rewriter, void* pContext);
void nodesRewriteExprs(SNodeList* pList, FNodeRewriter rewriter, void* pContext);
void nodesRewriteExprPostOrder(SNode** pNode, FNodeRewriter rewriter, void* pContext);
void nodesRewriteExprsPostOrder(SNodeList* pList, FNodeRewriter rewriter, void* pContext);
249

X
Xiaoyu Wang 已提交
250
bool nodesEqualNode(const SNodeptr a, const SNodeptr b);
251

X
Xiaoyu Wang 已提交
252
SNodeptr nodesCloneNode(const SNodeptr pNode);
X
Xiaoyu Wang 已提交
253
SNodeList* nodesCloneList(const SNodeList* pList);
254

255
const char* nodesNodeName(ENodeType type);
X
Xiaoyu Wang 已提交
256
int32_t nodesNodeToString(const SNodeptr pNode, bool format, char** pStr, int32_t* pLen);
257
int32_t nodesStringToNode(const char* pStr, SNode** pNode);
258

X
Xiaoyu Wang 已提交
259 260 261
int32_t nodesListToString(const SNodeList* pList, bool format, char** pStr, int32_t* pLen);
int32_t nodesStringToList(const char* pStr, SNodeList** pList);

D
dapan1121 已提交
262
int32_t nodesNodeToSQL(SNode *pNode, char *buf, int32_t bufSize, int32_t *len);
D
dapan1121 已提交
263
char *nodesGetNameFromColumnNode(SNode *pNode);
D
dapan1121 已提交
264
int32_t nodesGetOutputNumFromSlotList(SNodeList* pSlots);
D
dapan1121 已提交
265

266 267 268 269 270
#ifdef __cplusplus
}
#endif

#endif /*_TD_NODES_H_*/