diff --git a/include/common/tdataformat.h b/include/common/tdataformat.h index 6c8a39caf6..3f3ec30569 100644 --- a/include/common/tdataformat.h +++ b/include/common/tdataformat.h @@ -126,7 +126,7 @@ int32_t tRowMerge(SArray *aRowP, STSchema *pTSchema, int8_t flag); int32_t tRowUpsertColData(SRow *pRow, STSchema *pTSchema, SColData *aColData, int32_t nColData, int32_t flag); void tRowGetKey(SRow *pRow, SRowKey *key); int32_t tRowKeyCompare(const void *p1, const void *p2); -int32_t tRowKeyAssign(SRowKey* pDst, SRowKey* pSrc); +int32_t tRowKeyAssign(SRowKey *pDst, SRowKey *pSrc); // SRowIter ================================ int32_t tRowIterOpen(SRow *pRow, STSchema *pTSchema, SRowIter **ppIter); @@ -174,6 +174,7 @@ int32_t tColDataUpdateValue(SColData *pColData, SColVal *pColVal, bool forward); void tColDataGetValue(SColData *pColData, int32_t iVal, SColVal *pColVal); uint8_t tColDataGetBitValue(const SColData *pColData, int32_t iVal); int32_t tColDataCopy(SColData *pColDataFrom, SColData *pColData, xMallocFn xMalloc, void *arg); +void tColDataArrGetRowKey(SColData *aColData, int32_t nColData, int32_t iRow, SRowKey *key); extern void (*tColDataCalcSMA[])(SColData *pColData, int64_t *sum, int64_t *max, int64_t *min, int16_t *numOfNull); @@ -188,8 +189,8 @@ void tColDataSortMerge(SArray *colDataArr); int32_t tColDataAddValueByDataBlock(SColData *pColData, int8_t type, int32_t bytes, int32_t nRows, char *lengthOrbitmap, char *data); // for encode/decode -int32_t tPutColData(uint8_t *pBuf, SColData *pColData); -int32_t tGetColData(uint8_t *pBuf, SColData *pColData); +int32_t tPutColData(uint8_t version, uint8_t *pBuf, SColData *pColData); +int32_t tGetColData(uint8_t version, uint8_t *pBuf, SColData *pColData); // STRUCT ================================ struct STColumn { diff --git a/include/common/tmsg.h b/include/common/tmsg.h index c00989bcf4..090f2806e3 100644 --- a/include/common/tmsg.h +++ b/include/common/tmsg.h @@ -4065,6 +4065,7 @@ int32_t tDeserializeSMqSeekReq(void* buf, int32_t bufLen, SMqSeekReq* pReq); #define SUBMIT_REQ_COLUMN_DATA_FORMAT 0x2 #define SUBMIT_REQ_FROM_FILE 0x4 #define TD_REQ_FROM_TAOX 0x8 +#define SUBMIT_REQUEST_VERSION (1) #define TD_REQ_FROM_TAOX_OLD 0x1 // for compatibility diff --git a/include/common/ttokendef.h b/include/common/ttokendef.h index 2b426266a8..cb55248c27 100644 --- a/include/common/ttokendef.h +++ b/include/common/ttokendef.h @@ -16,368 +16,369 @@ #ifndef _TD_COMMON_TOKEN_H_ #define _TD_COMMON_TOKEN_H_ -#define TK_OR 1 -#define TK_AND 2 -#define TK_UNION 3 -#define TK_ALL 4 -#define TK_MINUS 5 -#define TK_EXCEPT 6 -#define TK_INTERSECT 7 -#define TK_NK_BITAND 8 -#define TK_NK_BITOR 9 -#define TK_NK_LSHIFT 10 -#define TK_NK_RSHIFT 11 -#define TK_NK_PLUS 12 -#define TK_NK_MINUS 13 -#define TK_NK_STAR 14 -#define TK_NK_SLASH 15 -#define TK_NK_REM 16 -#define TK_NK_CONCAT 17 -#define TK_CREATE 18 -#define TK_ACCOUNT 19 -#define TK_NK_ID 20 -#define TK_PASS 21 -#define TK_NK_STRING 22 -#define TK_ALTER 23 -#define TK_PPS 24 -#define TK_TSERIES 25 -#define TK_STORAGE 26 -#define TK_STREAMS 27 -#define TK_QTIME 28 -#define TK_DBS 29 -#define TK_USERS 30 -#define TK_CONNS 31 -#define TK_STATE 32 -#define TK_NK_COMMA 33 -#define TK_HOST 34 -#define TK_USER 35 -#define TK_ENABLE 36 -#define TK_NK_INTEGER 37 -#define TK_SYSINFO 38 -#define TK_ADD 39 -#define TK_DROP 40 -#define TK_GRANT 41 -#define TK_ON 42 -#define TK_TO 43 -#define TK_REVOKE 44 -#define TK_FROM 45 -#define TK_SUBSCRIBE 46 -#define TK_READ 47 -#define TK_WRITE 48 -#define TK_NK_DOT 49 -#define TK_WITH 50 -#define TK_DNODE 51 -#define TK_PORT 52 -#define TK_DNODES 53 -#define TK_RESTORE 54 -#define TK_NK_IPTOKEN 55 -#define TK_FORCE 56 -#define TK_UNSAFE 57 -#define TK_CLUSTER 58 -#define TK_LOCAL 59 -#define TK_QNODE 60 -#define TK_BNODE 61 -#define TK_SNODE 62 -#define TK_MNODE 63 -#define TK_VNODE 64 -#define TK_DATABASE 65 -#define TK_USE 66 -#define TK_FLUSH 67 -#define TK_TRIM 68 -#define TK_S3MIGRATE 69 -#define TK_COMPACT 70 -#define TK_IF 71 -#define TK_NOT 72 -#define TK_EXISTS 73 -#define TK_BUFFER 74 -#define TK_CACHEMODEL 75 -#define TK_CACHESIZE 76 -#define TK_COMP 77 -#define TK_DURATION 78 -#define TK_NK_VARIABLE 79 -#define TK_MAXROWS 80 -#define TK_MINROWS 81 -#define TK_KEEP 82 -#define TK_PAGES 83 -#define TK_PAGESIZE 84 -#define TK_TSDB_PAGESIZE 85 -#define TK_PRECISION 86 -#define TK_REPLICA 87 -#define TK_VGROUPS 88 -#define TK_SINGLE_STABLE 89 -#define TK_RETENTIONS 90 -#define TK_SCHEMALESS 91 -#define TK_WAL_LEVEL 92 -#define TK_WAL_FSYNC_PERIOD 93 -#define TK_WAL_RETENTION_PERIOD 94 -#define TK_WAL_RETENTION_SIZE 95 -#define TK_WAL_ROLL_PERIOD 96 -#define TK_WAL_SEGMENT_SIZE 97 -#define TK_STT_TRIGGER 98 -#define TK_TABLE_PREFIX 99 -#define TK_TABLE_SUFFIX 100 -#define TK_S3_CHUNKSIZE 101 -#define TK_S3_KEEPLOCAL 102 -#define TK_S3_COMPACT 103 -#define TK_KEEP_TIME_OFFSET 104 -#define TK_NK_COLON 105 -#define TK_BWLIMIT 106 -#define TK_START 107 -#define TK_TIMESTAMP 108 -#define TK_END 109 -#define TK_TABLE 110 -#define TK_NK_LP 111 -#define TK_NK_RP 112 -#define TK_STABLE 113 -#define TK_COLUMN 114 -#define TK_MODIFY 115 -#define TK_RENAME 116 -#define TK_TAG 117 -#define TK_SET 118 -#define TK_NK_EQ 119 -#define TK_USING 120 -#define TK_TAGS 121 -#define TK_PRIMARY 122 -#define TK_KEY 123 -#define TK_BOOL 124 -#define TK_TINYINT 125 -#define TK_SMALLINT 126 -#define TK_INT 127 -#define TK_INTEGER 128 -#define TK_BIGINT 129 -#define TK_FLOAT 130 -#define TK_DOUBLE 131 -#define TK_BINARY 132 -#define TK_NCHAR 133 -#define TK_UNSIGNED 134 -#define TK_JSON 135 -#define TK_VARCHAR 136 -#define TK_MEDIUMBLOB 137 -#define TK_BLOB 138 -#define TK_VARBINARY 139 -#define TK_GEOMETRY 140 -#define TK_DECIMAL 141 -#define TK_COMMENT 142 -#define TK_MAX_DELAY 143 -#define TK_WATERMARK 144 -#define TK_ROLLUP 145 -#define TK_TTL 146 -#define TK_SMA 147 -#define TK_DELETE_MARK 148 -#define TK_FIRST 149 -#define TK_LAST 150 -#define TK_SHOW 151 -#define TK_PRIVILEGES 152 -#define TK_DATABASES 153 -#define TK_TABLES 154 -#define TK_STABLES 155 -#define TK_MNODES 156 -#define TK_QNODES 157 -#define TK_ARBGROUPS 158 -#define TK_FUNCTIONS 159 -#define TK_INDEXES 160 -#define TK_ACCOUNTS 161 -#define TK_APPS 162 -#define TK_CONNECTIONS 163 -#define TK_LICENCES 164 -#define TK_GRANTS 165 -#define TK_FULL 166 -#define TK_LOGS 167 -#define TK_MACHINES 168 -#define TK_QUERIES 169 -#define TK_SCORES 170 -#define TK_TOPICS 171 -#define TK_VARIABLES 172 -#define TK_BNODES 173 -#define TK_SNODES 174 -#define TK_TRANSACTIONS 175 -#define TK_DISTRIBUTED 176 -#define TK_CONSUMERS 177 -#define TK_SUBSCRIPTIONS 178 -#define TK_VNODES 179 -#define TK_ALIVE 180 -#define TK_VIEWS 181 -#define TK_VIEW 182 -#define TK_COMPACTS 183 -#define TK_NORMAL 184 -#define TK_CHILD 185 -#define TK_LIKE 186 -#define TK_TBNAME 187 -#define TK_QTAGS 188 -#define TK_AS 189 -#define TK_SYSTEM 190 -#define TK_INDEX 191 -#define TK_FUNCTION 192 -#define TK_INTERVAL 193 -#define TK_COUNT 194 -#define TK_LAST_ROW 195 -#define TK_META 196 -#define TK_ONLY 197 -#define TK_TOPIC 198 -#define TK_CONSUMER 199 -#define TK_GROUP 200 -#define TK_DESC 201 -#define TK_DESCRIBE 202 -#define TK_RESET 203 -#define TK_QUERY 204 -#define TK_CACHE 205 -#define TK_EXPLAIN 206 -#define TK_ANALYZE 207 -#define TK_VERBOSE 208 -#define TK_NK_BOOL 209 -#define TK_RATIO 210 -#define TK_NK_FLOAT 211 -#define TK_OUTPUTTYPE 212 -#define TK_AGGREGATE 213 -#define TK_BUFSIZE 214 -#define TK_LANGUAGE 215 -#define TK_REPLACE 216 -#define TK_STREAM 217 -#define TK_INTO 218 -#define TK_PAUSE 219 -#define TK_RESUME 220 -#define TK_TRIGGER 221 -#define TK_AT_ONCE 222 -#define TK_WINDOW_CLOSE 223 -#define TK_IGNORE 224 -#define TK_EXPIRED 225 -#define TK_FILL_HISTORY 226 -#define TK_UPDATE 227 -#define TK_SUBTABLE 228 -#define TK_UNTREATED 229 -#define TK_KILL 230 -#define TK_CONNECTION 231 -#define TK_TRANSACTION 232 -#define TK_BALANCE 233 -#define TK_VGROUP 234 -#define TK_LEADER 235 -#define TK_MERGE 236 -#define TK_REDISTRIBUTE 237 -#define TK_SPLIT 238 -#define TK_DELETE 239 -#define TK_INSERT 240 -#define TK_NK_BIN 241 -#define TK_NK_HEX 242 -#define TK_NULL 243 -#define TK_NK_QUESTION 244 -#define TK_NK_ALIAS 245 -#define TK_NK_ARROW 246 -#define TK_ROWTS 247 -#define TK_QSTART 248 -#define TK_QEND 249 -#define TK_QDURATION 250 -#define TK_WSTART 251 -#define TK_WEND 252 -#define TK_WDURATION 253 -#define TK_IROWTS 254 -#define TK_ISFILLED 255 -#define TK_CAST 256 -#define TK_NOW 257 -#define TK_TODAY 258 -#define TK_TIMEZONE 259 -#define TK_CLIENT_VERSION 260 -#define TK_SERVER_VERSION 261 -#define TK_SERVER_STATUS 262 -#define TK_CURRENT_USER 263 -#define TK_CASE 264 -#define TK_WHEN 265 -#define TK_THEN 266 -#define TK_ELSE 267 -#define TK_BETWEEN 268 -#define TK_IS 269 -#define TK_NK_LT 270 -#define TK_NK_GT 271 -#define TK_NK_LE 272 -#define TK_NK_GE 273 -#define TK_NK_NE 274 -#define TK_MATCH 275 -#define TK_NMATCH 276 -#define TK_CONTAINS 277 -#define TK_IN 278 -#define TK_JOIN 279 -#define TK_INNER 280 -#define TK_SELECT 281 -#define TK_NK_HINT 282 -#define TK_DISTINCT 283 -#define TK_WHERE 284 -#define TK_PARTITION 285 -#define TK_BY 286 -#define TK_SESSION 287 -#define TK_STATE_WINDOW 288 -#define TK_EVENT_WINDOW 289 -#define TK_COUNT_WINDOW 290 -#define TK_SLIDING 291 -#define TK_FILL 292 -#define TK_VALUE 293 -#define TK_VALUE_F 294 -#define TK_NONE 295 -#define TK_PREV 296 -#define TK_NULL_F 297 -#define TK_LINEAR 298 -#define TK_NEXT 299 -#define TK_HAVING 300 -#define TK_RANGE 301 -#define TK_EVERY 302 -#define TK_ORDER 303 -#define TK_SLIMIT 304 -#define TK_SOFFSET 305 -#define TK_LIMIT 306 -#define TK_OFFSET 307 -#define TK_ASC 308 -#define TK_NULLS 309 -#define TK_ABORT 310 -#define TK_AFTER 311 -#define TK_ATTACH 312 -#define TK_BEFORE 313 -#define TK_BEGIN 314 -#define TK_BITAND 315 -#define TK_BITNOT 316 -#define TK_BITOR 317 -#define TK_BLOCKS 318 -#define TK_CHANGE 319 -#define TK_COMMA 320 -#define TK_CONCAT 321 -#define TK_CONFLICT 322 -#define TK_COPY 323 -#define TK_DEFERRED 324 -#define TK_DELIMITERS 325 -#define TK_DETACH 326 -#define TK_DIVIDE 327 -#define TK_DOT 328 -#define TK_EACH 329 -#define TK_FAIL 330 -#define TK_FILE 331 -#define TK_FOR 332 -#define TK_GLOB 333 -#define TK_ID 334 -#define TK_IMMEDIATE 335 -#define TK_IMPORT 336 -#define TK_INITIALLY 337 -#define TK_INSTEAD 338 -#define TK_ISNULL 339 -#define TK_MODULES 340 -#define TK_NK_BITNOT 341 -#define TK_NK_SEMI 342 -#define TK_NOTNULL 343 -#define TK_OF 344 -#define TK_PLUS 345 -#define TK_PRIVILEGE 346 -#define TK_RAISE 347 -#define TK_RESTRICT 348 -#define TK_ROW 349 -#define TK_SEMI 350 -#define TK_STAR 351 -#define TK_STATEMENT 352 -#define TK_STRICT 353 -#define TK_STRING 354 -#define TK_TIMES 355 -#define TK_VALUES 356 -#define TK_VARIABLE 357 -#define TK_WAL 358 +#define TK_OR 1 +#define TK_AND 2 +#define TK_UNION 3 +#define TK_ALL 4 +#define TK_MINUS 5 +#define TK_EXCEPT 6 +#define TK_INTERSECT 7 +#define TK_NK_BITAND 8 +#define TK_NK_BITOR 9 +#define TK_NK_LSHIFT 10 +#define TK_NK_RSHIFT 11 +#define TK_NK_PLUS 12 +#define TK_NK_MINUS 13 +#define TK_NK_STAR 14 +#define TK_NK_SLASH 15 +#define TK_NK_REM 16 +#define TK_NK_CONCAT 17 +#define TK_CREATE 18 +#define TK_ACCOUNT 19 +#define TK_NK_ID 20 +#define TK_PASS 21 +#define TK_NK_STRING 22 +#define TK_ALTER 23 +#define TK_PPS 24 +#define TK_TSERIES 25 +#define TK_STORAGE 26 +#define TK_STREAMS 27 +#define TK_QTIME 28 +#define TK_DBS 29 +#define TK_USERS 30 +#define TK_CONNS 31 +#define TK_STATE 32 +#define TK_NK_COMMA 33 +#define TK_HOST 34 +#define TK_USER 35 +#define TK_ENABLE 36 +#define TK_NK_INTEGER 37 +#define TK_SYSINFO 38 +#define TK_ADD 39 +#define TK_DROP 40 +#define TK_GRANT 41 +#define TK_ON 42 +#define TK_TO 43 +#define TK_REVOKE 44 +#define TK_FROM 45 +#define TK_SUBSCRIBE 46 +#define TK_READ 47 +#define TK_WRITE 48 +#define TK_NK_DOT 49 +#define TK_WITH 50 +#define TK_DNODE 51 +#define TK_PORT 52 +#define TK_DNODES 53 +#define TK_RESTORE 54 +#define TK_NK_IPTOKEN 55 +#define TK_FORCE 56 +#define TK_UNSAFE 57 +#define TK_CLUSTER 58 +#define TK_LOCAL 59 +#define TK_QNODE 60 +#define TK_BNODE 61 +#define TK_SNODE 62 +#define TK_MNODE 63 +#define TK_VNODE 64 +#define TK_DATABASE 65 +#define TK_USE 66 +#define TK_FLUSH 67 +#define TK_TRIM 68 +#define TK_S3MIGRATE 69 +#define TK_COMPACT 70 +#define TK_IF 71 +#define TK_NOT 72 +#define TK_EXISTS 73 +#define TK_BUFFER 74 +#define TK_CACHEMODEL 75 +#define TK_CACHESIZE 76 +#define TK_COMP 77 +#define TK_DURATION 78 +#define TK_NK_VARIABLE 79 +#define TK_MAXROWS 80 +#define TK_MINROWS 81 +#define TK_KEEP 82 +#define TK_PAGES 83 +#define TK_PAGESIZE 84 +#define TK_TSDB_PAGESIZE 85 +#define TK_PRECISION 86 +#define TK_REPLICA 87 +#define TK_VGROUPS 88 +#define TK_SINGLE_STABLE 89 +#define TK_RETENTIONS 90 +#define TK_SCHEMALESS 91 +#define TK_WAL_LEVEL 92 +#define TK_WAL_FSYNC_PERIOD 93 +#define TK_WAL_RETENTION_PERIOD 94 +#define TK_WAL_RETENTION_SIZE 95 +#define TK_WAL_ROLL_PERIOD 96 +#define TK_WAL_SEGMENT_SIZE 97 +#define TK_STT_TRIGGER 98 +#define TK_TABLE_PREFIX 99 +#define TK_TABLE_SUFFIX 100 +#define TK_S3_CHUNKSIZE 101 +#define TK_S3_KEEPLOCAL 102 +#define TK_S3_COMPACT 103 +#define TK_KEEP_TIME_OFFSET 104 +#define TK_NK_COLON 105 +#define TK_BWLIMIT 106 +#define TK_START 107 +#define TK_TIMESTAMP 108 +#define TK_END 109 +#define TK_TABLE 110 +#define TK_NK_LP 111 +#define TK_NK_RP 112 +#define TK_STABLE 113 +#define TK_COLUMN 114 +#define TK_MODIFY 115 +#define TK_RENAME 116 +#define TK_TAG 117 +#define TK_SET 118 +#define TK_NK_EQ 119 +#define TK_USING 120 +#define TK_TAGS 121 +#define TK_PRIMARY 122 +#define TK_KEY 123 +#define TK_BOOL 124 +#define TK_TINYINT 125 +#define TK_SMALLINT 126 +#define TK_INT 127 +#define TK_INTEGER 128 +#define TK_BIGINT 129 +#define TK_FLOAT 130 +#define TK_DOUBLE 131 +#define TK_BINARY 132 +#define TK_NCHAR 133 +#define TK_UNSIGNED 134 +#define TK_JSON 135 +#define TK_VARCHAR 136 +#define TK_MEDIUMBLOB 137 +#define TK_BLOB 138 +#define TK_VARBINARY 139 +#define TK_GEOMETRY 140 +#define TK_DECIMAL 141 +#define TK_COMMENT 142 +#define TK_MAX_DELAY 143 +#define TK_WATERMARK 144 +#define TK_ROLLUP 145 +#define TK_TTL 146 +#define TK_SMA 147 +#define TK_DELETE_MARK 148 +#define TK_FIRST 149 +#define TK_LAST 150 +#define TK_SHOW 151 +#define TK_PRIVILEGES 152 +#define TK_DATABASES 153 +#define TK_TABLES 154 +#define TK_STABLES 155 +#define TK_MNODES 156 +#define TK_QNODES 157 +#define TK_ARBGROUPS 158 +#define TK_FUNCTIONS 159 +#define TK_INDEXES 160 +#define TK_ACCOUNTS 161 +#define TK_APPS 162 +#define TK_CONNECTIONS 163 +#define TK_LICENCES 164 +#define TK_GRANTS 165 +#define TK_FULL 166 +#define TK_LOGS 167 +#define TK_MACHINES 168 +#define TK_QUERIES 169 +#define TK_SCORES 170 +#define TK_TOPICS 171 +#define TK_VARIABLES 172 +#define TK_BNODES 173 +#define TK_SNODES 174 +#define TK_TRANSACTIONS 175 +#define TK_DISTRIBUTED 176 +#define TK_CONSUMERS 177 +#define TK_SUBSCRIPTIONS 178 +#define TK_VNODES 179 +#define TK_ALIVE 180 +#define TK_VIEWS 181 +#define TK_VIEW 182 +#define TK_COMPACTS 183 +#define TK_NORMAL 184 +#define TK_CHILD 185 +#define TK_LIKE 186 +#define TK_TBNAME 187 +#define TK_QTAGS 188 +#define TK_AS 189 +#define TK_SYSTEM 190 +#define TK_INDEX 191 +#define TK_FUNCTION 192 +#define TK_INTERVAL 193 +#define TK_COUNT 194 +#define TK_LAST_ROW 195 +#define TK_META 196 +#define TK_ONLY 197 +#define TK_TOPIC 198 +#define TK_CONSUMER 199 +#define TK_GROUP 200 +#define TK_DESC 201 +#define TK_DESCRIBE 202 +#define TK_RESET 203 +#define TK_QUERY 204 +#define TK_CACHE 205 +#define TK_EXPLAIN 206 +#define TK_ANALYZE 207 +#define TK_VERBOSE 208 +#define TK_NK_BOOL 209 +#define TK_RATIO 210 +#define TK_NK_FLOAT 211 +#define TK_OUTPUTTYPE 212 +#define TK_AGGREGATE 213 +#define TK_BUFSIZE 214 +#define TK_LANGUAGE 215 +#define TK_REPLACE 216 +#define TK_STREAM 217 +#define TK_INTO 218 +#define TK_PAUSE 219 +#define TK_RESUME 220 +#define TK_TRIGGER 221 +#define TK_AT_ONCE 222 +#define TK_WINDOW_CLOSE 223 +#define TK_IGNORE 224 +#define TK_EXPIRED 225 +#define TK_FILL_HISTORY 226 +#define TK_UPDATE 227 +#define TK_SUBTABLE 228 +#define TK_UNTREATED 229 +#define TK_KILL 230 +#define TK_CONNECTION 231 +#define TK_TRANSACTION 232 +#define TK_BALANCE 233 +#define TK_VGROUP 234 +#define TK_LEADER 235 +#define TK_MERGE 236 +#define TK_REDISTRIBUTE 237 +#define TK_SPLIT 238 +#define TK_DELETE 239 +#define TK_INSERT 240 +#define TK_NK_BIN 241 +#define TK_NK_HEX 242 +#define TK_NULL 243 +#define TK_NK_QUESTION 244 +#define TK_NK_ALIAS 245 +#define TK_NK_ARROW 246 +#define TK_ROWTS 247 +#define TK_QSTART 248 +#define TK_QEND 249 +#define TK_QDURATION 250 +#define TK_WSTART 251 +#define TK_WEND 252 +#define TK_WDURATION 253 +#define TK_IROWTS 254 +#define TK_ISFILLED 255 +#define TK_CAST 256 +#define TK_NOW 257 +#define TK_TODAY 258 +#define TK_TIMEZONE 259 +#define TK_CLIENT_VERSION 260 +#define TK_SERVER_VERSION 261 +#define TK_SERVER_STATUS 262 +#define TK_CURRENT_USER 263 +#define TK_CASE 264 +#define TK_WHEN 265 +#define TK_THEN 266 +#define TK_ELSE 267 +#define TK_BETWEEN 268 +#define TK_IS 269 +#define TK_NK_LT 270 +#define TK_NK_GT 271 +#define TK_NK_LE 272 +#define TK_NK_GE 273 +#define TK_NK_NE 274 +#define TK_MATCH 275 +#define TK_NMATCH 276 +#define TK_CONTAINS 277 +#define TK_IN 278 +#define TK_JOIN 279 +#define TK_INNER 280 +#define TK_SELECT 281 +#define TK_NK_HINT 282 +#define TK_DISTINCT 283 +#define TK_WHERE 284 +#define TK_PARTITION 285 +#define TK_BY 286 +#define TK_SESSION 287 +#define TK_STATE_WINDOW 288 +#define TK_EVENT_WINDOW 289 +#define TK_COUNT_WINDOW 290 +#define TK_SLIDING 291 +#define TK_FILL 292 +#define TK_VALUE 293 +#define TK_VALUE_F 294 +#define TK_NONE 295 +#define TK_PREV 296 +#define TK_NULL_F 297 +#define TK_LINEAR 298 +#define TK_NEXT 299 +#define TK_HAVING 300 +#define TK_RANGE 301 +#define TK_EVERY 302 +#define TK_ORDER 303 +#define TK_SLIMIT 304 +#define TK_SOFFSET 305 +#define TK_LIMIT 306 +#define TK_OFFSET 307 +#define TK_ASC 308 +#define TK_NULLS 309 +#define TK_ABORT 310 +#define TK_AFTER 311 +#define TK_ATTACH 312 +#define TK_BEFORE 313 +#define TK_BEGIN 314 +#define TK_BITAND 315 +#define TK_BITNOT 316 +#define TK_BITOR 317 +#define TK_BLOCKS 318 +#define TK_CHANGE 319 +#define TK_COMMA 320 +#define TK_CONCAT 321 +#define TK_CONFLICT 322 +#define TK_COPY 323 +#define TK_DEFERRED 324 +#define TK_DELIMITERS 325 +#define TK_DETACH 326 +#define TK_DIVIDE 327 +#define TK_DOT 328 +#define TK_EACH 329 +#define TK_FAIL 330 +#define TK_FILE 331 +#define TK_FOR 332 +#define TK_GLOB 333 +#define TK_ID 334 +#define TK_IMMEDIATE 335 +#define TK_IMPORT 336 +#define TK_INITIALLY 337 +#define TK_INSTEAD 338 +#define TK_ISNULL 339 +#define TK_MODULES 340 +#define TK_NK_BITNOT 341 +#define TK_NK_SEMI 342 +#define TK_NOTNULL 343 +#define TK_OF 344 +#define TK_PLUS 345 +#define TK_PRIVILEGE 346 +#define TK_RAISE 347 +#define TK_RESTRICT 348 +#define TK_ROW 349 +#define TK_SEMI 350 +#define TK_STAR 351 +#define TK_STATEMENT 352 +#define TK_STRICT 353 +#define TK_STRING 354 +#define TK_TIMES 355 +#define TK_VALUES 356 +#define TK_VARIABLE 357 +#define TK_WAL 358 -#define TK_NK_SPACE 600 -#define TK_NK_COMMENT 601 -#define TK_NK_ILLEGAL 602 + +#define TK_NK_SPACE 600 +#define TK_NK_COMMENT 601 +#define TK_NK_ILLEGAL 602 // #define TK_NK_HEX 603 // hex number 0x123 #define TK_NK_OCT 604 // oct number // #define TK_NK_BIN 605 // bin format data 0b111 diff --git a/source/common/src/tdataformat.c b/source/common/src/tdataformat.c index 1585c12ac1..f13a0a0825 100644 --- a/source/common/src/tdataformat.c +++ b/source/common/src/tdataformat.c @@ -3111,7 +3111,7 @@ static int32_t tColDataCopyRowAppend(SColData *aFromColData, int32_t iFromRow, S return code; } -static FORCE_INLINE void tColDataArrGetRowKey(SColData *aColData, int32_t nColData, int32_t iRow, SRowKey *key) { +void tColDataArrGetRowKey(SColData *aColData, int32_t nColData, int32_t iRow, SRowKey *key) { SColVal cv; key->ts = ((TSKEY *)aColData[0].pData)[iRow]; @@ -3490,7 +3490,7 @@ _exit: return; } -int32_t tPutColData(uint8_t *pBuf, SColData *pColData) { +static int32_t tPutColDataVersion0(uint8_t *pBuf, SColData *pColData) { int32_t n = 0; n += tPutI16v(pBuf ? pBuf + n : NULL, pColData->cid); @@ -3532,7 +3532,7 @@ int32_t tPutColData(uint8_t *pBuf, SColData *pColData) { return n; } -int32_t tGetColData(uint8_t *pBuf, SColData *pColData) { +static int32_t tGetColDataVersion0(uint8_t *pBuf, SColData *pColData) { int32_t n = 0; n += tGetI16v(pBuf + n, &pColData->cid); @@ -3571,10 +3571,45 @@ int32_t tGetColData(uint8_t *pBuf, SColData *pColData) { n += pColData->nData; } } + pColData->cflag = 0; return n; } +static int32_t tPutColDataVersion1(uint8_t *pBuf, SColData *pColData) { + int32_t n = tPutColDataVersion0(pBuf, pColData); + n += tPutI8(pBuf ? pBuf + n : NULL, pColData->cflag); + return n; +} + +static int32_t tGetColDataVersion1(uint8_t *pBuf, SColData *pColData) { + int32_t n = tGetColDataVersion0(pBuf, pColData); + n += tGetI8(pBuf ? pBuf + n : NULL, &pColData->cflag); + return n; +} + +int32_t tPutColData(uint8_t version, uint8_t *pBuf, SColData *pColData) { + if (version == 0) { + return tPutColDataVersion0(pBuf, pColData); + } else if (version == 1) { + return tPutColDataVersion1(pBuf, pColData); + } else { + ASSERT(0); + return -1; + } +} + +int32_t tGetColData(uint8_t version, uint8_t *pBuf, SColData *pColData) { + if (version == 0) { + return tGetColDataVersion0(pBuf, pColData); + } else if (version == 1) { + return tGetColDataVersion1(pBuf, pColData); + } else { + ASSERT(0); + return -1; + } +} + #define CALC_SUM_MAX_MIN(SUM, MAX, MIN, VAL) \ do { \ (SUM) += (VAL); \ diff --git a/source/common/src/tmsg.c b/source/common/src/tmsg.c index 963b99c104..b5f51e7797 100644 --- a/source/common/src/tmsg.c +++ b/source/common/src/tmsg.c @@ -9181,7 +9181,8 @@ int32_t tDecodeSBatchDeleteReqSetCtime(SDecoder *pDecoder, SBatchDeleteReq *pReq static int32_t tEncodeSSubmitTbData(SEncoder *pCoder, const SSubmitTbData *pSubmitTbData) { if (tStartEncode(pCoder) < 0) return -1; - if (tEncodeI32v(pCoder, pSubmitTbData->flags) < 0) return -1; + int32_t flags = pSubmitTbData->flags | ((SUBMIT_REQUEST_VERSION) << 8); + if (tEncodeI32v(pCoder, flags) < 0) return -1; // auto create table if (pSubmitTbData->flags & SUBMIT_REQ_AUTO_CREATE_TABLE) { @@ -9201,7 +9202,8 @@ static int32_t tEncodeSSubmitTbData(SEncoder *pCoder, const SSubmitTbData *pSubm if (tEncodeU64v(pCoder, nColData) < 0) return -1; for (uint64_t i = 0; i < nColData; i++) { - pCoder->pos += tPutColData(pCoder->data ? pCoder->data + pCoder->pos : NULL, &aColData[i]); + pCoder->pos += + tPutColData(SUBMIT_REQUEST_VERSION, pCoder->data ? pCoder->data + pCoder->pos : NULL, &aColData[i]); } } else { if (tEncodeU64v(pCoder, TARRAY_SIZE(pSubmitTbData->aRowP)) < 0) return -1; @@ -9220,13 +9222,18 @@ static int32_t tEncodeSSubmitTbData(SEncoder *pCoder, const SSubmitTbData *pSubm static int32_t tDecodeSSubmitTbData(SDecoder *pCoder, SSubmitTbData *pSubmitTbData) { int32_t code = 0; + int32_t flags; + uint8_t version; if (tStartDecode(pCoder) < 0) { code = TSDB_CODE_INVALID_MSG; goto _exit; } - if (tDecodeI32v(pCoder, &pSubmitTbData->flags) < 0) return -1; + if (tDecodeI32v(pCoder, &flags) < 0) return -1; + + pSubmitTbData->flags = flags & 0xff; + version = (flags >> 8) & 0xff; if (pSubmitTbData->flags & SUBMIT_REQ_AUTO_CREATE_TABLE) { pSubmitTbData->pCreateTbReq = taosMemoryCalloc(1, sizeof(SVCreateTbReq)); @@ -9270,7 +9277,7 @@ static int32_t tDecodeSSubmitTbData(SDecoder *pCoder, SSubmitTbData *pSubmitTbDa } for (int32_t i = 0; i < nColData; ++i) { - pCoder->pos += tGetColData(pCoder->data + pCoder->pos, taosArrayReserve(pSubmitTbData->aCol, 1)); + pCoder->pos += tGetColData(version, pCoder->data + pCoder->pos, taosArrayReserve(pSubmitTbData->aCol, 1)); } } else { uint64_t nRow; diff --git a/source/dnode/vnode/src/vnd/vnodeSvr.c b/source/dnode/vnode/src/vnd/vnodeSvr.c index 8ddaa79d6f..69934aa3d2 100644 --- a/source/dnode/vnode/src/vnd/vnodeSvr.c +++ b/source/dnode/vnode/src/vnd/vnodeSvr.c @@ -241,10 +241,13 @@ static int32_t vnodePreProcessSubmitTbData(SVnode *pVnode, SDecoder *pCoder, int } SSubmitTbData submitTbData; + uint8_t version; if (tDecodeI32v(pCoder, &submitTbData.flags) < 0) { code = TSDB_CODE_INVALID_MSG; TSDB_CHECK_CODE(code, lino, _exit); } + version = (submitTbData.flags >> 8) & 0xff; + submitTbData.flags = submitTbData.flags & 0xff; if (submitTbData.flags & SUBMIT_REQ_FROM_FILE) { code = grantCheck(TSDB_GRANT_CSV); @@ -308,7 +311,7 @@ static int32_t vnodePreProcessSubmitTbData(SVnode *pVnode, SDecoder *pCoder, int } SColData colData = {0}; - pCoder->pos += tGetColData(pCoder->data + pCoder->pos, &colData); + pCoder->pos += tGetColData(version, pCoder->data + pCoder->pos, &colData); if (colData.flag != HAS_VALUE) { code = TSDB_CODE_INVALID_MSG; goto _exit; @@ -322,7 +325,7 @@ static int32_t vnodePreProcessSubmitTbData(SVnode *pVnode, SDecoder *pCoder, int } for (uint64_t i = 1; i < nColData; i++) { - pCoder->pos += tGetColData(pCoder->data + pCoder->pos, &colData); + pCoder->pos += tGetColData(version, pCoder->data + pCoder->pos, &colData); } } else { uint64_t nRow; @@ -1596,17 +1599,18 @@ static int32_t vnodeProcessSubmitReq(SVnode *pVnode, int64_t ver, void *pReq, in goto _exit; } - SColData *pColData = (SColData *)taosArrayGet(pSubmitTbData->aCol, 0); - TSKEY *aKey = (TSKEY *)(pColData->pData); - - for (int32_t iRow = 0; iRow < pColData->nVal; iRow++) { - if (aKey[iRow] < minKey || aKey[iRow] > maxKey || (iRow > 0 && aKey[iRow] <= aKey[iRow - 1])) { + SColData *colDataArr = TARRAY_DATA(pSubmitTbData->aCol); + SRowKey lastKey; + tColDataArrGetRowKey(colDataArr, TARRAY_SIZE(pSubmitTbData->aCol), 0, &lastKey); + for (int32_t iRow = 1; iRow < colDataArr[0].nVal; iRow++) { + SRowKey key; + tColDataArrGetRowKey(TARRAY_DATA(pSubmitTbData->aCol), TARRAY_SIZE(pSubmitTbData->aCol), iRow, &key); + if (tRowKeyCompare(&lastKey, &key) >= 0) { code = TSDB_CODE_INVALID_MSG; vError("vgId:%d %s failed since %s, version:%" PRId64, TD_VID(pVnode), __func__, tstrerror(terrno), ver); goto _exit; } } - } else { int32_t nRow = TARRAY_SIZE(pSubmitTbData->aRowP); SRow **aRow = (SRow **)TARRAY_DATA(pSubmitTbData->aRowP); diff --git a/source/libs/function/src/builtins.c b/source/libs/function/src/builtins.c index 2476449383..df992d1b55 100644 --- a/source/libs/function/src/builtins.c +++ b/source/libs/function/src/builtins.c @@ -2018,9 +2018,17 @@ static int32_t translateCast(SFunctionNode* pFunc, char* pErrBuf, int32_t len) { if (IS_STR_DATA_TYPE(para2Type)) { para2Bytes -= VARSTR_HEADER_SIZE; } - if (para2Bytes <= 0 || para2Bytes > 4096) { // cast dst var type length limits to 4096 bytes - return buildFuncErrMsg(pErrBuf, len, TSDB_CODE_FUNC_FUNTION_ERROR, - "CAST function converted length should be in range (0, 4096] bytes"); + if (para2Bytes <= 0 || + para2Bytes > TSDB_MAX_BINARY_LEN - VARSTR_HEADER_SIZE) { // cast dst var type length limits to 4096 bytes + if (TSDB_DATA_TYPE_NCHAR == para2Type) { + return buildFuncErrMsg(pErrBuf, len, TSDB_CODE_FUNC_FUNTION_ERROR, + "CAST function converted length should be in range (0, %d] NCHARS", + (TSDB_MAX_BINARY_LEN - VARSTR_HEADER_SIZE)/TSDB_NCHAR_SIZE); + } else { + return buildFuncErrMsg(pErrBuf, len, TSDB_CODE_FUNC_FUNTION_ERROR, + "CAST function converted length should be in range (0, %d] bytes", + TSDB_MAX_BINARY_LEN - VARSTR_HEADER_SIZE); + } } // add database precision as param diff --git a/source/libs/parser/inc/sql.y b/source/libs/parser/inc/sql.y index 1506a45536..5fced82df2 100755 --- a/source/libs/parser/inc/sql.y +++ b/source/libs/parser/inc/sql.y @@ -424,6 +424,13 @@ type_name(A) ::= DECIMAL. type_name(A) ::= DECIMAL NK_LP NK_INTEGER NK_RP. { A = createDataType(TSDB_DATA_TYPE_DECIMAL); } type_name(A) ::= DECIMAL NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP. { A = createDataType(TSDB_DATA_TYPE_DECIMAL); } +%type type_name_default_len { SDataType } +%destructor type_name_default_len { } +type_name_default_len(A) ::= BINARY. { A = createVarLenDataType(TSDB_DATA_TYPE_BINARY, NULL); } +type_name_default_len(A) ::= NCHAR. { A = createVarLenDataType(TSDB_DATA_TYPE_NCHAR, NULL); } +type_name_default_len(A) ::= VARCHAR. { A = createVarLenDataType(TSDB_DATA_TYPE_VARCHAR, NULL); } +type_name_default_len(A) ::= VARBINARY. { A = createVarLenDataType(TSDB_DATA_TYPE_VARBINARY, NULL); } + %type tags_def_opt { SNodeList* } %destructor tags_def_opt { nodesDestroyList($$); } tags_def_opt(A) ::= . { A = NULL; } @@ -1130,6 +1137,9 @@ function_expression(A) ::= function_name(B) NK_LP expression_list(C) NK_RP(D). function_expression(A) ::= star_func(B) NK_LP star_func_para_list(C) NK_RP(D). { A = createRawExprNodeExt(pCxt, &B, &D, createFunctionNode(pCxt, &B, C)); } function_expression(A) ::= CAST(B) NK_LP expr_or_subquery(C) AS type_name(D) NK_RP(E). { A = createRawExprNodeExt(pCxt, &B, &E, createCastFunctionNode(pCxt, releaseRawExprNode(pCxt, C), D)); } +function_expression(A) ::= + CAST(B) NK_LP expr_or_subquery(C) AS type_name_default_len(D) NK_RP(E). { A = createRawExprNodeExt(pCxt, &B, &E, createCastFunctionNode(pCxt, releaseRawExprNode(pCxt, C), D)); } + function_expression(A) ::= literal_func(B). { A = B; } literal_func(A) ::= noarg_func(B) NK_LP NK_RP(C). { A = createRawExprNodeExt(pCxt, &B, &C, createFunctionNode(pCxt, &B, NULL)); } diff --git a/source/libs/parser/src/parAstCreater.c b/source/libs/parser/src/parAstCreater.c index e84545408a..4687f492c2 100644 --- a/source/libs/parser/src/parAstCreater.c +++ b/source/libs/parser/src/parAstCreater.c @@ -1632,7 +1632,10 @@ SDataType createDataType(uint8_t type) { } SDataType createVarLenDataType(uint8_t type, const SToken* pLen) { - SDataType dt = {.type = type, .precision = 0, .scale = 0, .bytes = taosStr2Int32(pLen->z, NULL, 10)}; + int32_t len = TSDB_MAX_BINARY_LEN - VARSTR_HEADER_SIZE; + if (type == TSDB_DATA_TYPE_NCHAR) len /= TSDB_NCHAR_SIZE; + if(pLen) len = taosStr2Int32(pLen->z, NULL, 10); + SDataType dt = {.type = type, .precision = 0, .scale = 0, .bytes = len}; return dt; } diff --git a/source/libs/parser/src/parTranslater.c b/source/libs/parser/src/parTranslater.c index ae4263b2f9..650c2565e0 100644 --- a/source/libs/parser/src/parTranslater.c +++ b/source/libs/parser/src/parTranslater.c @@ -8240,6 +8240,7 @@ static int32_t adjustOrderOfProjections(STranslateContext* pCxt, SNodeList** ppC } int32_t code = TSDB_CODE_SUCCESS; + bool hasTsKey = false; bool hasPrimaryKey = false; SNode* pCol = NULL; SNode* pProj = NULL; @@ -8255,13 +8256,22 @@ static int32_t adjustOrderOfProjections(STranslateContext* pCxt, SNodeList** ppC break; } if (PRIMARYKEY_TIMESTAMP_COL_ID == pSchema->colId) { + hasTsKey = true; + } + + if (pSchema->flags & COL_IS_KEY) { hasPrimaryKey = true; } } - if (TSDB_CODE_SUCCESS == code && !hasPrimaryKey) { + if (TSDB_CODE_SUCCESS == code && !hasTsKey) { code = generateSyntaxErrMsgExt(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_COLUMNS_NUM, - "primary timestamp column can not be null"); + "Primary timestamp column of dest table can not be null"); + } + + if (TSDB_CODE_SUCCESS == code && !hasPrimaryKey && hasPkInTable(pMeta)) { + code = generateSyntaxErrMsgExt(&pCxt->msgBuf, TSDB_CODE_PAR_INVALID_COLUMNS_NUM, + "Primary key column of dest table can not be null"); } SNodeList* pNewProjections = NULL; diff --git a/source/libs/parser/src/sql.c b/source/libs/parser/src/sql.c index 0537959ea6..fd69090907 100644 --- a/source/libs/parser/src/sql.c +++ b/source/libs/parser/src/sql.c @@ -464,29 +464,29 @@ #endif /************* Begin control #defines *****************************************/ #define YYCODETYPE unsigned short int -#define YYNOCODE 524 +#define YYNOCODE 525 #define YYACTIONTYPE unsigned short int #define ParseTOKENTYPE SToken typedef union { int yyinit; ParseTOKENTYPE yy0; - SDataType yy56; - SNodeList* yy72; - EOrder yy130; - SToken yy305; - EOperatorType yy324; - int8_t yy359; - STokenPair yy361; - int32_t yy444; - SShowTablesOption yy517; - ENullOrder yy681; - EShowKind yy761; - EJoinType yy828; - EFillMode yy926; - SAlterOption yy941; - bool yy985; - SNode* yy1000; - int64_t yy1005; + SToken yy29; + SAlterOption yy95; + SNodeList* yy124; + EFillMode yy144; + STokenPair yy147; + EJoinType yy162; + int64_t yy459; + EOperatorType yy590; + EOrder yy638; + SShowTablesOption yy667; + int32_t yy760; + SDataType yy784; + EShowKind yy789; + int8_t yy803; + SNode* yy812; + bool yy887; + ENullOrder yy907; } YYMINORTYPE; #ifndef YYSTACKDEPTH #define YYSTACKDEPTH 100 @@ -502,18 +502,18 @@ typedef union { #define ParseCTX_FETCH #define ParseCTX_STORE #define YYFALLBACK 1 -#define YYNSTATE 903 -#define YYNRULE 704 -#define YYNRULE_WITH_ACTION 704 +#define YYNSTATE 908 +#define YYNRULE 709 +#define YYNRULE_WITH_ACTION 709 #define YYNTOKEN 359 -#define YY_MAX_SHIFT 902 -#define YY_MIN_SHIFTREDUCE 1345 -#define YY_MAX_SHIFTREDUCE 2048 -#define YY_ERROR_ACTION 2049 -#define YY_ACCEPT_ACTION 2050 -#define YY_NO_ACTION 2051 -#define YY_MIN_REDUCE 2052 -#define YY_MAX_REDUCE 2755 +#define YY_MAX_SHIFT 907 +#define YY_MIN_SHIFTREDUCE 1351 +#define YY_MAX_SHIFTREDUCE 2059 +#define YY_ERROR_ACTION 2060 +#define YY_ACCEPT_ACTION 2061 +#define YY_NO_ACTION 2062 +#define YY_MIN_REDUCE 2063 +#define YY_MAX_REDUCE 2771 /************* End control #defines *******************************************/ #define YY_NLOOKAHEAD ((int)(sizeof(yy_lookahead)/sizeof(yy_lookahead[0]))) @@ -580,633 +580,654 @@ typedef union { ** yy_default[] Default action for each state. ** *********** Begin parsing tables **********************************************/ -#define YY_ACTTAB_COUNT (3007) +#define YY_ACTTAB_COUNT (3212) static const YYACTIONTYPE yy_action[] = { - /* 0 */ 2390, 446, 2530, 2075, 610, 800, 2250, 611, 2095, 173, - /* 10 */ 524, 2366, 47, 45, 1970, 445, 515, 2252, 2387, 787, - /* 20 */ 442, 2241, 1810, 40, 39, 138, 2534, 46, 44, 43, - /* 30 */ 42, 41, 653, 37, 312, 1896, 2390, 1808, 2138, 46, - /* 40 */ 44, 43, 42, 41, 40, 39, 2074, 2554, 46, 44, - /* 50 */ 43, 42, 41, 744, 2388, 787, 2520, 762, 147, 221, - /* 60 */ 765, 575, 573, 1835, 392, 1891, 2053, 66, 219, 29, - /* 70 */ 2304, 492, 19, 2536, 2538, 439, 241, 410, 448, 1816, - /* 80 */ 613, 2572, 2103, 750, 804, 2302, 2726, 128, 2572, 804, - /* 90 */ 127, 126, 125, 124, 123, 122, 121, 120, 119, 2520, - /* 100 */ 2520, 1835, 782, 618, 749, 205, 611, 2095, 899, 2727, - /* 110 */ 751, 15, 874, 873, 872, 871, 471, 799, 870, 869, - /* 120 */ 152, 864, 863, 862, 861, 860, 859, 858, 151, 852, - /* 130 */ 851, 850, 470, 469, 847, 846, 845, 185, 184, 844, - /* 140 */ 466, 843, 842, 454, 2553, 2541, 743, 2591, 2015, 1898, - /* 150 */ 1899, 115, 2555, 786, 2557, 2558, 781, 463, 804, 750, - /* 160 */ 2297, 2299, 2726, 188, 176, 2645, 2064, 161, 680, 438, - /* 170 */ 2641, 304, 2653, 761, 62, 139, 760, 1411, 2726, 1410, - /* 180 */ 749, 205, 186, 692, 207, 2727, 751, 1870, 1880, 704, - /* 190 */ 1836, 2050, 2675, 2304, 1897, 1900, 749, 205, 799, 274, - /* 200 */ 437, 2727, 751, 2304, 412, 496, 2370, 2543, 2302, 1811, - /* 210 */ 447, 1809, 1412, 243, 569, 683, 2045, 613, 2302, 2103, - /* 220 */ 40, 39, 677, 675, 46, 44, 43, 42, 41, 271, - /* 230 */ 2073, 128, 498, 494, 127, 126, 125, 124, 123, 122, - /* 240 */ 121, 120, 119, 1814, 1815, 1867, 54, 1869, 1872, 1873, - /* 250 */ 1874, 1875, 1876, 1877, 1878, 1879, 778, 802, 801, 1890, - /* 260 */ 1892, 1893, 1894, 1895, 2, 47, 45, 2052, 1871, 457, - /* 270 */ 390, 474, 1833, 442, 71, 1810, 473, 70, 2660, 558, - /* 280 */ 508, 230, 578, 2520, 402, 507, 1995, 577, 1896, 50, - /* 290 */ 1808, 137, 136, 135, 134, 133, 132, 131, 130, 129, - /* 300 */ 1839, 1996, 33, 538, 2657, 579, 568, 229, 40, 39, - /* 310 */ 391, 540, 46, 44, 43, 42, 41, 1779, 1891, 1593, - /* 320 */ 1594, 745, 518, 2044, 721, 19, 1868, 2726, 2323, 800, - /* 330 */ 2250, 1925, 1816, 721, 40, 39, 2726, 799, 46, 44, - /* 340 */ 43, 42, 41, 1994, 308, 2732, 205, 453, 452, 138, - /* 350 */ 2727, 751, 762, 147, 2732, 205, 658, 705, 1558, 2727, - /* 360 */ 751, 899, 413, 1838, 15, 839, 163, 162, 836, 835, - /* 370 */ 834, 160, 701, 526, 1549, 829, 828, 827, 1553, 826, - /* 380 */ 1555, 1556, 825, 822, 626, 1564, 819, 1566, 1567, 816, - /* 390 */ 813, 810, 2227, 2339, 62, 530, 2366, 854, 1926, 800, - /* 400 */ 2250, 700, 1898, 1899, 2513, 2377, 2356, 459, 566, 565, - /* 410 */ 564, 563, 562, 557, 556, 555, 554, 396, 12, 210, - /* 420 */ 10, 544, 543, 542, 541, 535, 534, 533, 50, 528, - /* 430 */ 527, 411, 620, 2429, 630, 519, 1653, 1654, 2014, 2072, - /* 440 */ 1870, 1880, 1672, 1778, 223, 40, 39, 1897, 1900, 46, - /* 450 */ 44, 43, 42, 41, 841, 427, 2437, 1839, 2225, 800, - /* 460 */ 2250, 448, 1811, 856, 1809, 764, 203, 2653, 2654, 196, - /* 470 */ 145, 2658, 804, 456, 455, 762, 147, 418, 417, 55, - /* 480 */ 36, 440, 1920, 1921, 1922, 1923, 1924, 1928, 1929, 1930, - /* 490 */ 1931, 506, 2520, 505, 553, 552, 1814, 1815, 1867, 1967, - /* 500 */ 1869, 1872, 1873, 1874, 1875, 1876, 1877, 1878, 1879, 778, - /* 510 */ 802, 801, 1890, 1892, 1893, 1894, 1895, 2, 12, 47, - /* 520 */ 45, 198, 174, 504, 1385, 1840, 175, 442, 2554, 1810, - /* 530 */ 2186, 366, 306, 2291, 839, 163, 162, 836, 835, 834, - /* 540 */ 160, 783, 1896, 1392, 1808, 1835, 1867, 276, 364, 75, - /* 550 */ 2730, 275, 74, 416, 415, 771, 655, 2617, 2554, 560, - /* 560 */ 2366, 551, 393, 62, 308, 550, 1387, 1390, 1391, 2572, - /* 570 */ 1835, 765, 1891, 549, 239, 592, 590, 587, 585, 19, - /* 580 */ 657, 2520, 702, 782, 656, 186, 1816, 468, 467, 204, - /* 590 */ 2653, 2654, 1810, 145, 2658, 14, 13, 1824, 308, 2572, - /* 600 */ 839, 163, 162, 836, 835, 834, 160, 1808, 228, 2371, - /* 610 */ 1896, 2520, 1817, 782, 12, 899, 762, 147, 15, 62, - /* 620 */ 857, 99, 461, 2211, 399, 2553, 201, 426, 2591, 693, - /* 630 */ 166, 2731, 115, 2555, 786, 2557, 2558, 781, 2252, 804, - /* 640 */ 1891, 695, 149, 694, 157, 2616, 2645, 1974, 1838, 1816, - /* 650 */ 438, 2641, 461, 1835, 1816, 2553, 1898, 1899, 2591, 63, - /* 660 */ 173, 62, 115, 2555, 786, 2557, 2558, 781, 2252, 804, - /* 670 */ 2003, 691, 316, 317, 188, 1816, 2645, 315, 899, 1836, - /* 680 */ 438, 2641, 1840, 775, 428, 2437, 689, 2106, 687, 273, - /* 690 */ 272, 96, 40, 39, 1870, 1880, 46, 44, 43, 42, - /* 700 */ 41, 1897, 1900, 2676, 832, 2530, 1939, 1500, 414, 85, - /* 710 */ 84, 511, 1665, 1666, 218, 657, 1811, 2245, 1809, 656, - /* 720 */ 737, 736, 2001, 2002, 2004, 2005, 2006, 503, 501, 2534, - /* 730 */ 206, 2653, 2654, 308, 145, 2658, 700, 615, 389, 892, - /* 740 */ 2038, 490, 51, 612, 487, 483, 479, 476, 504, 1502, - /* 750 */ 1814, 1815, 1867, 2514, 1869, 1872, 1873, 1874, 1875, 1876, - /* 760 */ 1877, 1878, 1879, 778, 802, 801, 1890, 1892, 1893, 1894, - /* 770 */ 1895, 2, 47, 45, 1901, 2554, 2536, 2539, 1966, 1811, - /* 780 */ 442, 1809, 1810, 705, 1825, 2442, 1820, 804, 783, 308, - /* 790 */ 2105, 2438, 35, 740, 277, 1896, 1986, 1808, 40, 39, - /* 800 */ 2304, 2349, 46, 44, 43, 42, 41, 462, 1685, 1686, - /* 810 */ 448, 2554, 2071, 1814, 1815, 2302, 2572, 306, 1828, 1830, - /* 820 */ 1871, 804, 225, 2226, 783, 1891, 2683, 1411, 2520, 1410, - /* 830 */ 782, 308, 802, 801, 1890, 1892, 1893, 1894, 1895, 1816, - /* 840 */ 278, 40, 39, 522, 143, 46, 44, 43, 42, 41, - /* 850 */ 753, 2473, 2572, 1684, 1687, 831, 800, 2250, 707, 2429, - /* 860 */ 351, 2070, 1412, 1906, 2520, 2520, 782, 91, 899, 1835, - /* 870 */ 90, 48, 2553, 1738, 1739, 2591, 512, 1512, 1868, 115, - /* 880 */ 2555, 786, 2557, 2558, 781, 2474, 804, 746, 741, 734, - /* 890 */ 730, 2746, 1511, 2645, 841, 40, 39, 438, 2641, 46, - /* 900 */ 44, 43, 42, 41, 721, 464, 1839, 2726, 2553, 1898, - /* 910 */ 1899, 2591, 308, 173, 2520, 115, 2555, 786, 2557, 2558, - /* 920 */ 781, 2252, 804, 607, 2187, 2732, 205, 2746, 1392, 2645, - /* 930 */ 2727, 751, 605, 438, 2641, 601, 597, 173, 721, 89, - /* 940 */ 2731, 2726, 627, 2726, 2069, 2253, 2731, 1870, 1880, 2726, - /* 950 */ 800, 2250, 1390, 1391, 1897, 1900, 43, 42, 41, 2732, - /* 960 */ 205, 1558, 2730, 580, 2727, 751, 2727, 2729, 2730, 1811, - /* 970 */ 513, 1809, 2727, 2728, 2068, 468, 467, 1549, 829, 828, - /* 980 */ 827, 1553, 826, 1555, 1556, 825, 822, 199, 1564, 819, - /* 990 */ 1566, 1567, 816, 813, 810, 2298, 2299, 2520, 628, 2383, - /* 1000 */ 1817, 1414, 1415, 1814, 1815, 1867, 2239, 1869, 1872, 1873, - /* 1010 */ 1874, 1875, 1876, 1877, 1878, 1879, 778, 802, 801, 1890, - /* 1020 */ 1892, 1893, 1894, 1895, 2, 47, 45, 2520, 2554, 800, - /* 1030 */ 2250, 2067, 698, 442, 766, 1810, 1871, 800, 2250, 800, - /* 1040 */ 2250, 783, 720, 2696, 96, 800, 2250, 1394, 1896, 532, - /* 1050 */ 1808, 800, 2250, 1834, 800, 2250, 2660, 545, 2235, 546, - /* 1060 */ 800, 2250, 1839, 1927, 2554, 547, 800, 2250, 1835, 2572, - /* 1070 */ 2246, 629, 113, 706, 2247, 200, 172, 783, 1891, 732, - /* 1080 */ 279, 2520, 2656, 782, 2520, 721, 287, 721, 2726, 150, - /* 1090 */ 2726, 773, 1816, 2617, 1868, 800, 2250, 2242, 800, 2250, - /* 1100 */ 800, 2250, 800, 2250, 3, 2572, 2732, 205, 2732, 205, - /* 1110 */ 757, 2727, 751, 2727, 751, 768, 53, 2520, 320, 782, - /* 1120 */ 797, 899, 798, 1516, 48, 2553, 721, 2461, 2591, 2726, - /* 1130 */ 2066, 1840, 115, 2555, 786, 2557, 2558, 781, 1515, 804, - /* 1140 */ 800, 2250, 2063, 2554, 2746, 34, 2645, 2732, 205, 2062, - /* 1150 */ 438, 2641, 2727, 751, 2237, 1932, 783, 800, 2250, 2061, - /* 1160 */ 347, 2553, 1898, 1899, 2591, 2060, 2059, 2058, 115, 2555, - /* 1170 */ 786, 2557, 2558, 781, 1820, 804, 2057, 465, 2056, 2055, - /* 1180 */ 2746, 60, 2645, 2520, 2572, 148, 438, 2641, 2616, 718, - /* 1190 */ 649, 648, 651, 650, 100, 2520, 2520, 2660, 782, 2304, - /* 1200 */ 1870, 1880, 2520, 669, 668, 107, 9, 1897, 1900, 582, - /* 1210 */ 868, 866, 2520, 2304, 769, 2080, 894, 2125, 2520, 2520, - /* 1220 */ 2520, 2065, 1811, 2655, 1809, 1713, 2665, 1959, 795, 2520, - /* 1230 */ 2243, 2520, 2520, 833, 360, 154, 2295, 2281, 2304, 674, - /* 1240 */ 2553, 837, 2554, 2591, 2295, 2233, 154, 177, 2555, 786, - /* 1250 */ 2557, 2558, 781, 2303, 804, 783, 1814, 1815, 1867, 2464, - /* 1260 */ 1869, 1872, 1873, 1874, 1875, 1876, 1877, 1878, 1879, 778, - /* 1270 */ 802, 801, 1890, 1892, 1893, 1894, 1895, 2, 47, 45, - /* 1280 */ 77, 2554, 838, 2572, 754, 2295, 442, 1840, 1810, 722, - /* 1290 */ 2686, 2228, 661, 1868, 783, 2520, 2719, 782, 1496, 264, - /* 1300 */ 140, 1896, 262, 1808, 266, 268, 270, 265, 267, 269, - /* 1310 */ 481, 2123, 87, 662, 1729, 288, 1494, 2554, 284, 2047, - /* 1320 */ 2048, 728, 2572, 49, 153, 1736, 49, 189, 161, 64, - /* 1330 */ 783, 1891, 2664, 676, 2520, 88, 782, 1492, 777, 2553, - /* 1340 */ 1497, 2554, 2591, 14, 13, 1816, 116, 2555, 786, 2557, - /* 1350 */ 2558, 781, 2689, 804, 783, 49, 301, 49, 2572, 738, - /* 1360 */ 2645, 2114, 212, 101, 2644, 2641, 326, 325, 328, 327, - /* 1370 */ 2520, 112, 782, 2112, 899, 330, 329, 15, 2553, 314, - /* 1380 */ 109, 2591, 2572, 678, 758, 115, 2555, 786, 2557, 2558, - /* 1390 */ 781, 76, 804, 295, 2520, 681, 782, 2746, 2141, 2645, - /* 1400 */ 1990, 1475, 2000, 438, 2641, 1999, 293, 767, 1933, 776, - /* 1410 */ 142, 332, 331, 1819, 2553, 1898, 1899, 2591, 334, 333, - /* 1420 */ 1818, 115, 2555, 786, 2557, 2558, 781, 848, 804, 159, - /* 1430 */ 336, 335, 2573, 2746, 1881, 2645, 1682, 2180, 2553, 438, - /* 1440 */ 2641, 2591, 2554, 1476, 1959, 116, 2555, 786, 2557, 2558, - /* 1450 */ 781, 1467, 804, 1870, 1880, 783, 161, 73, 318, 2645, - /* 1460 */ 1897, 1900, 808, 774, 2641, 338, 337, 340, 339, 2179, - /* 1470 */ 792, 2375, 673, 672, 671, 1811, 2096, 1809, 159, 663, - /* 1480 */ 144, 667, 161, 2572, 141, 666, 342, 341, 344, 343, - /* 1490 */ 665, 670, 421, 420, 159, 2520, 664, 782, 2679, 2554, - /* 1500 */ 419, 660, 659, 346, 345, 735, 433, 742, 322, 1814, - /* 1510 */ 1815, 1867, 783, 1869, 1872, 1873, 1874, 1875, 1876, 1877, - /* 1520 */ 1878, 1879, 778, 802, 801, 1890, 1892, 1893, 1894, 1895, - /* 1530 */ 2, 2554, 1448, 429, 789, 1542, 359, 2376, 849, 2553, - /* 1540 */ 2572, 1571, 2591, 472, 783, 2292, 115, 2555, 786, 2557, - /* 1550 */ 2558, 781, 2520, 804, 782, 2102, 755, 1575, 2620, 714, - /* 1560 */ 2645, 1582, 1465, 1580, 438, 2641, 395, 394, 2680, 2690, - /* 1570 */ 2554, 303, 2572, 164, 1449, 763, 449, 300, 475, 307, - /* 1580 */ 1917, 2212, 5, 783, 2520, 480, 782, 1822, 488, 1896, - /* 1590 */ 408, 458, 489, 1843, 1821, 500, 2553, 214, 499, 2591, - /* 1600 */ 502, 213, 216, 115, 2555, 786, 2557, 2558, 781, 1706, - /* 1610 */ 804, 2572, 1833, 354, 516, 2618, 1834, 2645, 523, 1891, - /* 1620 */ 227, 438, 2641, 2520, 525, 782, 571, 529, 2553, 531, - /* 1630 */ 2554, 2591, 536, 559, 561, 115, 2555, 786, 2557, 2558, - /* 1640 */ 781, 567, 804, 780, 548, 2368, 570, 772, 572, 2645, - /* 1650 */ 583, 584, 581, 438, 2641, 232, 233, 586, 588, 589, - /* 1660 */ 236, 591, 1841, 593, 608, 4, 616, 784, 244, 619, - /* 1670 */ 2591, 2572, 609, 617, 116, 2555, 786, 2557, 2558, 781, - /* 1680 */ 1836, 804, 621, 2520, 1842, 782, 93, 247, 2645, 622, - /* 1690 */ 1844, 250, 401, 2641, 623, 625, 673, 672, 671, 252, - /* 1700 */ 1845, 94, 631, 663, 144, 667, 2384, 652, 95, 666, - /* 1710 */ 257, 697, 654, 2240, 665, 670, 421, 420, 261, 117, - /* 1720 */ 664, 2451, 684, 2236, 419, 660, 659, 2553, 699, 263, - /* 1730 */ 2591, 685, 167, 2554, 382, 2555, 786, 2557, 2558, 781, - /* 1740 */ 779, 804, 770, 2610, 168, 386, 783, 2238, 2554, 2448, - /* 1750 */ 2234, 169, 170, 2447, 98, 1837, 280, 2430, 155, 709, - /* 1760 */ 710, 783, 708, 1801, 716, 1777, 285, 713, 355, 739, - /* 1770 */ 283, 715, 790, 8, 2572, 725, 290, 748, 2667, 2554, - /* 1780 */ 2695, 2694, 726, 296, 292, 294, 2520, 180, 782, 2572, - /* 1790 */ 724, 723, 783, 297, 434, 451, 450, 1802, 759, 299, - /* 1800 */ 756, 2520, 1959, 782, 1838, 2554, 146, 1964, 1962, 192, - /* 1810 */ 61, 802, 801, 1890, 1892, 1893, 1894, 1895, 783, 309, - /* 1820 */ 2572, 298, 156, 788, 356, 2398, 2397, 2661, 1, 793, - /* 1830 */ 2553, 2725, 2520, 2591, 782, 208, 2626, 178, 2555, 786, - /* 1840 */ 2557, 2558, 781, 2396, 804, 2553, 2572, 444, 2591, 302, - /* 1850 */ 794, 158, 116, 2555, 786, 2557, 2558, 781, 2520, 804, - /* 1860 */ 782, 358, 2554, 357, 108, 106, 2645, 2512, 2251, 2511, - /* 1870 */ 806, 2642, 2507, 2506, 2498, 783, 2553, 1369, 2749, 2591, - /* 1880 */ 431, 2554, 2497, 177, 2555, 786, 2557, 2558, 781, 893, - /* 1890 */ 804, 752, 2747, 2489, 783, 361, 896, 2488, 165, 52, - /* 1900 */ 898, 2504, 2553, 2572, 349, 2591, 406, 365, 373, 383, - /* 1910 */ 2555, 786, 2557, 2558, 781, 2520, 804, 782, 2503, 2495, - /* 1920 */ 2494, 385, 2572, 2483, 2482, 2501, 2687, 2500, 2492, 2491, - /* 1930 */ 2480, 2479, 2477, 2476, 2520, 2296, 782, 432, 363, 384, - /* 1940 */ 374, 407, 2472, 2471, 2470, 82, 2465, 477, 478, 1761, - /* 1950 */ 1762, 211, 2554, 482, 2463, 484, 485, 486, 1760, 2553, - /* 1960 */ 2462, 409, 2591, 2460, 491, 783, 383, 2555, 786, 2557, - /* 1970 */ 2558, 781, 2459, 804, 493, 2458, 2457, 495, 2553, 1749, - /* 1980 */ 2434, 2591, 2554, 215, 497, 376, 2555, 786, 2557, 2558, - /* 1990 */ 781, 2433, 804, 2572, 217, 780, 83, 1709, 1708, 2411, - /* 2000 */ 2410, 2409, 509, 510, 2408, 2520, 2407, 782, 2358, 2355, - /* 2010 */ 514, 1652, 2554, 220, 517, 2354, 2348, 521, 520, 2345, - /* 2020 */ 2344, 2343, 2342, 2572, 86, 783, 2347, 222, 2346, 2341, - /* 2030 */ 2554, 747, 2340, 2338, 2337, 2520, 2336, 782, 224, 537, - /* 2040 */ 2335, 539, 2333, 783, 2332, 2331, 2330, 2353, 2329, 2553, - /* 2050 */ 2328, 2554, 2591, 2572, 2327, 2351, 178, 2555, 786, 2557, - /* 2060 */ 2558, 781, 2334, 804, 783, 2520, 2326, 782, 2325, 2324, - /* 2070 */ 2322, 2572, 2321, 2320, 2319, 2318, 2317, 2316, 2315, 2553, - /* 2080 */ 226, 2314, 2591, 2520, 92, 782, 382, 2555, 786, 2557, - /* 2090 */ 2558, 781, 2572, 804, 2313, 2611, 2312, 2352, 2350, 2311, - /* 2100 */ 2310, 1658, 2309, 231, 2520, 441, 782, 2308, 2307, 696, - /* 2110 */ 574, 2748, 2591, 703, 1513, 397, 378, 2555, 786, 2557, - /* 2120 */ 2558, 781, 576, 804, 2306, 2305, 443, 2553, 1517, 2145, - /* 2130 */ 2591, 902, 398, 2144, 383, 2555, 786, 2557, 2558, 781, - /* 2140 */ 1509, 804, 2143, 2142, 2140, 234, 2137, 353, 2553, 2136, - /* 2150 */ 235, 2591, 237, 238, 594, 383, 2555, 786, 2557, 2558, - /* 2160 */ 781, 595, 804, 195, 596, 598, 2554, 259, 600, 599, - /* 2170 */ 2129, 602, 890, 886, 882, 878, 2116, 350, 603, 783, - /* 2180 */ 604, 2091, 606, 181, 240, 187, 2540, 1393, 2090, 79, - /* 2190 */ 197, 242, 647, 643, 639, 635, 80, 258, 2432, 614, - /* 2200 */ 2554, 2428, 2418, 2406, 249, 251, 2405, 2572, 254, 2382, - /* 2210 */ 2229, 2139, 2135, 783, 632, 633, 2133, 634, 637, 2520, - /* 2220 */ 636, 782, 114, 2131, 1441, 323, 638, 640, 642, 641, - /* 2230 */ 2128, 645, 644, 646, 2111, 2109, 2110, 2108, 2087, 2554, - /* 2240 */ 2231, 2572, 97, 1586, 1587, 256, 2230, 2126, 260, 72, - /* 2250 */ 1499, 1498, 783, 2520, 1495, 782, 1493, 1491, 2124, 796, - /* 2260 */ 56, 1490, 1489, 2553, 1488, 1487, 2591, 2115, 1484, 1483, - /* 2270 */ 368, 2555, 786, 2557, 2558, 781, 865, 804, 867, 1482, - /* 2280 */ 2572, 1481, 422, 2113, 423, 2554, 424, 425, 682, 2086, - /* 2290 */ 2085, 2084, 2520, 690, 782, 679, 686, 2553, 783, 2083, - /* 2300 */ 2591, 2082, 118, 311, 367, 2555, 786, 2557, 2558, 781, - /* 2310 */ 310, 804, 688, 1743, 246, 2554, 1745, 1742, 2431, 701, - /* 2320 */ 1747, 1719, 1733, 255, 248, 2427, 2572, 282, 783, 281, - /* 2330 */ 253, 624, 1715, 28, 1717, 2417, 2553, 67, 2520, 2591, - /* 2340 */ 782, 711, 57, 369, 2555, 786, 2557, 2558, 781, 245, - /* 2350 */ 804, 2404, 171, 286, 712, 2403, 2572, 1694, 2554, 717, - /* 2360 */ 1693, 2731, 719, 20, 30, 727, 2017, 1991, 2520, 17, - /* 2370 */ 782, 783, 289, 430, 729, 2554, 6, 731, 291, 7, - /* 2380 */ 21, 733, 2553, 22, 1998, 2591, 191, 202, 783, 375, - /* 2390 */ 2555, 786, 2557, 2558, 781, 179, 804, 190, 31, 2572, - /* 2400 */ 1985, 2541, 32, 81, 65, 23, 2037, 24, 2038, 18, - /* 2410 */ 2032, 2520, 2553, 782, 2031, 2591, 2572, 435, 2036, 379, - /* 2420 */ 2555, 786, 2557, 2558, 781, 2035, 804, 436, 2520, 1956, - /* 2430 */ 782, 305, 1955, 59, 58, 182, 2402, 2381, 102, 103, - /* 2440 */ 25, 1908, 1907, 13, 1826, 11, 2554, 1918, 183, 1883, - /* 2450 */ 38, 193, 1882, 16, 26, 2553, 1852, 1860, 2591, 783, - /* 2460 */ 27, 785, 370, 2555, 786, 2557, 2558, 781, 313, 804, - /* 2470 */ 791, 1993, 2553, 194, 319, 2591, 2554, 69, 2380, 380, - /* 2480 */ 2555, 786, 2557, 2558, 781, 104, 804, 2572, 321, 783, - /* 2490 */ 105, 109, 807, 324, 2596, 2595, 805, 1885, 803, 2520, - /* 2500 */ 68, 782, 460, 1572, 809, 811, 1569, 812, 814, 817, - /* 2510 */ 1568, 820, 823, 348, 815, 1577, 1565, 2572, 1559, 2554, - /* 2520 */ 818, 821, 1581, 1557, 824, 1439, 840, 110, 111, 2520, - /* 2530 */ 78, 782, 783, 1478, 1477, 1548, 2554, 830, 1474, 1563, - /* 2540 */ 1471, 1470, 1562, 2553, 1469, 1468, 2591, 1466, 1561, 783, - /* 2550 */ 371, 2555, 786, 2557, 2558, 781, 2554, 804, 1560, 1464, - /* 2560 */ 2572, 1463, 1462, 1507, 853, 1506, 855, 209, 1460, 783, - /* 2570 */ 1457, 1503, 2520, 2553, 782, 1459, 2591, 2572, 1458, 1456, - /* 2580 */ 381, 2555, 786, 2557, 2558, 781, 1455, 804, 1454, 2520, - /* 2590 */ 1501, 782, 1451, 1450, 1447, 1446, 1445, 2572, 1444, 2134, - /* 2600 */ 875, 876, 877, 2132, 879, 880, 881, 2130, 883, 2520, - /* 2610 */ 884, 782, 885, 2127, 887, 889, 2553, 888, 2554, 2591, - /* 2620 */ 2107, 891, 1382, 372, 2555, 786, 2557, 2558, 781, 2081, - /* 2630 */ 804, 783, 1370, 2553, 895, 2554, 2591, 352, 897, 900, - /* 2640 */ 387, 2555, 786, 2557, 2558, 781, 1812, 804, 783, 362, - /* 2650 */ 901, 2051, 2051, 2553, 2051, 2554, 2591, 2051, 2051, 2572, - /* 2660 */ 388, 2555, 786, 2557, 2558, 781, 2051, 804, 783, 2051, - /* 2670 */ 2051, 2520, 2051, 782, 2051, 2051, 2572, 2051, 2554, 2051, - /* 2680 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2520, 2051, - /* 2690 */ 782, 783, 2051, 2051, 2051, 2051, 2572, 2051, 2051, 2051, - /* 2700 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2520, 2051, - /* 2710 */ 782, 2051, 2051, 2051, 2051, 2553, 2051, 2051, 2591, 2572, - /* 2720 */ 2051, 2051, 2566, 2555, 786, 2557, 2558, 781, 2051, 804, - /* 2730 */ 2051, 2520, 2553, 782, 2051, 2591, 2051, 2051, 2554, 2565, - /* 2740 */ 2555, 786, 2557, 2558, 781, 2051, 804, 2051, 2051, 2051, - /* 2750 */ 2051, 783, 2553, 2051, 2554, 2591, 2051, 2051, 2051, 2564, - /* 2760 */ 2555, 786, 2557, 2558, 781, 2051, 804, 783, 2051, 2051, - /* 2770 */ 2051, 2051, 2051, 2051, 2051, 2553, 2051, 2051, 2591, 2572, - /* 2780 */ 2051, 2051, 403, 2555, 786, 2557, 2558, 781, 2051, 804, - /* 2790 */ 2051, 2520, 2051, 782, 2051, 2572, 2051, 2051, 2051, 2051, - /* 2800 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2520, 2051, 782, - /* 2810 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, - /* 2820 */ 2051, 2051, 2051, 2051, 2051, 2051, 2554, 2051, 2051, 2051, - /* 2830 */ 2051, 2051, 2051, 2051, 2051, 2553, 2051, 2051, 2591, 783, - /* 2840 */ 2051, 2051, 404, 2555, 786, 2557, 2558, 781, 2051, 804, - /* 2850 */ 2051, 2553, 2051, 2051, 2591, 2051, 2051, 2051, 400, 2555, - /* 2860 */ 786, 2557, 2558, 781, 2554, 804, 2051, 2572, 2051, 2051, - /* 2870 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 783, 2051, 2520, - /* 2880 */ 2051, 782, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, - /* 2890 */ 2051, 2051, 2051, 2051, 2051, 2554, 2051, 2051, 2051, 2051, - /* 2900 */ 2051, 2051, 2051, 2051, 2051, 2572, 2051, 2051, 783, 2051, - /* 2910 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2520, 2051, 782, - /* 2920 */ 2051, 2051, 2051, 2553, 2051, 2051, 2591, 2051, 2051, 2051, - /* 2930 */ 405, 2555, 786, 2557, 2558, 781, 2572, 804, 2051, 2051, - /* 2940 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2520, 2051, - /* 2950 */ 782, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, - /* 2960 */ 2051, 784, 2051, 2051, 2591, 2051, 2051, 2051, 378, 2555, - /* 2970 */ 786, 2557, 2558, 781, 2051, 804, 2051, 2051, 2051, 2051, - /* 2980 */ 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, 2051, - /* 2990 */ 2051, 2051, 2553, 2051, 2051, 2591, 2051, 2051, 2051, 377, - /* 3000 */ 2555, 786, 2557, 2558, 781, 2051, 804, + /* 0 */ 610, 2545, 2528, 611, 2106, 459, 750, 618, 2676, 2742, + /* 10 */ 611, 2106, 47, 45, 1981, 515, 2545, 524, 2381, 2676, + /* 20 */ 442, 2405, 1820, 2064, 2405, 241, 2549, 749, 205, 613, + /* 30 */ 2488, 2114, 2743, 751, 2673, 1907, 445, 1818, 2149, 2402, + /* 40 */ 792, 2549, 2403, 792, 129, 2672, 2569, 128, 127, 126, + /* 50 */ 125, 124, 123, 122, 121, 120, 762, 148, 1829, 765, + /* 60 */ 448, 575, 573, 691, 392, 1902, 2063, 221, 219, 2319, + /* 70 */ 2238, 809, 19, 2551, 2553, 439, 410, 630, 689, 1826, + /* 80 */ 687, 273, 272, 721, 809, 2317, 2742, 2587, 2551, 2554, + /* 90 */ 138, 137, 136, 135, 134, 133, 132, 131, 130, 809, + /* 100 */ 2535, 2319, 787, 463, 2748, 205, 2312, 2314, 904, 2743, + /* 110 */ 751, 15, 879, 878, 877, 876, 471, 769, 875, 874, + /* 120 */ 153, 869, 868, 867, 866, 865, 864, 863, 152, 857, + /* 130 */ 856, 855, 470, 469, 852, 851, 850, 185, 184, 849, + /* 140 */ 466, 848, 847, 454, 2568, 62, 705, 2607, 607, 1909, + /* 150 */ 1910, 115, 2570, 791, 2572, 2573, 786, 605, 809, 750, + /* 160 */ 601, 597, 2742, 188, 198, 2661, 461, 720, 186, 438, + /* 170 */ 2657, 304, 2669, 761, 167, 140, 760, 2306, 2742, 745, + /* 180 */ 749, 205, 2263, 1518, 207, 2743, 751, 1880, 1890, 1845, + /* 190 */ 2061, 412, 2691, 2385, 1908, 1911, 749, 205, 1517, 40, + /* 200 */ 39, 2743, 751, 46, 44, 43, 42, 41, 176, 1821, + /* 210 */ 2075, 1819, 844, 164, 163, 841, 840, 839, 161, 804, + /* 220 */ 40, 39, 620, 2444, 46, 44, 43, 42, 41, 428, + /* 230 */ 2452, 129, 1832, 2489, 128, 127, 126, 125, 124, 123, + /* 240 */ 122, 121, 120, 1824, 1825, 1877, 1828, 1879, 1882, 1883, + /* 250 */ 1884, 1885, 1886, 1887, 1888, 1889, 783, 807, 806, 1901, + /* 260 */ 1903, 1904, 1905, 1906, 2, 47, 45, 705, 2252, 580, + /* 270 */ 390, 474, 1843, 442, 657, 1820, 473, 243, 656, 558, + /* 280 */ 508, 613, 578, 2114, 402, 507, 721, 577, 1907, 2742, + /* 290 */ 1818, 40, 39, 2319, 66, 46, 44, 43, 42, 41, + /* 300 */ 437, 805, 2261, 538, 569, 579, 60, 2748, 205, 2317, + /* 310 */ 391, 540, 2743, 751, 718, 308, 29, 1789, 1902, 37, + /* 320 */ 312, 139, 518, 704, 721, 19, 448, 2742, 653, 805, + /* 330 */ 2261, 1936, 1826, 721, 40, 39, 2742, 809, 46, 44, + /* 340 */ 43, 42, 41, 707, 2444, 2748, 205, 453, 452, 139, + /* 350 */ 2743, 751, 762, 148, 2748, 205, 658, 626, 1564, 2743, + /* 360 */ 751, 904, 413, 1846, 15, 744, 62, 418, 417, 468, + /* 370 */ 467, 230, 701, 526, 1555, 834, 833, 832, 1559, 831, + /* 380 */ 1561, 1562, 830, 827, 846, 1570, 824, 1572, 1573, 821, + /* 390 */ 818, 815, 2056, 2587, 1827, 2026, 568, 229, 1937, 492, + /* 400 */ 804, 62, 1909, 1910, 1877, 2392, 2371, 702, 566, 565, + /* 410 */ 564, 563, 562, 557, 556, 555, 554, 396, 1506, 2086, + /* 420 */ 1831, 544, 543, 542, 541, 535, 534, 533, 740, 528, + /* 430 */ 527, 411, 43, 42, 41, 519, 1663, 1664, 2025, 1985, + /* 440 */ 1880, 1890, 1682, 416, 415, 1845, 655, 1908, 1911, 40, + /* 450 */ 39, 1846, 1845, 46, 44, 43, 42, 41, 2747, 743, + /* 460 */ 1508, 1849, 1821, 506, 1819, 505, 764, 203, 2669, 2670, + /* 470 */ 657, 146, 2674, 2535, 656, 1848, 2529, 14, 13, 698, + /* 480 */ 36, 440, 1931, 1932, 1933, 1934, 1935, 1939, 1940, 1941, + /* 490 */ 1942, 50, 1695, 1696, 162, 504, 1824, 1825, 1877, 2055, + /* 500 */ 1879, 1882, 1883, 1884, 1885, 1886, 1887, 1888, 1889, 783, + /* 510 */ 807, 806, 1901, 1903, 1904, 1905, 1906, 2, 12, 47, + /* 520 */ 45, 1391, 746, 741, 734, 730, 175, 442, 2569, 1820, + /* 530 */ 12, 366, 721, 496, 448, 2742, 308, 1694, 1697, 2014, + /* 540 */ 1398, 788, 1907, 62, 1818, 809, 805, 2261, 364, 75, + /* 550 */ 804, 225, 74, 2748, 205, 2085, 51, 2569, 2743, 751, + /* 560 */ 498, 494, 393, 1393, 1396, 1397, 210, 2049, 1830, 2587, + /* 570 */ 765, 308, 1902, 54, 239, 592, 590, 587, 585, 19, + /* 580 */ 1603, 1604, 2535, 12, 787, 10, 1826, 2236, 1950, 737, + /* 590 */ 736, 2012, 2013, 2015, 2016, 2017, 91, 615, 2587, 90, + /* 600 */ 40, 39, 457, 612, 46, 44, 43, 42, 41, 2535, + /* 610 */ 33, 2535, 1881, 787, 627, 904, 40, 39, 15, 62, + /* 620 */ 46, 44, 43, 42, 41, 1417, 2568, 1416, 2084, 2607, + /* 630 */ 201, 2083, 2319, 115, 2570, 791, 2572, 2573, 786, 447, + /* 640 */ 809, 50, 144, 150, 306, 158, 2632, 2661, 2317, 2676, + /* 650 */ 1845, 438, 2657, 2556, 1398, 2568, 1909, 1910, 2607, 63, + /* 660 */ 1418, 308, 115, 2570, 791, 2572, 2573, 786, 89, 809, + /* 670 */ 1878, 628, 2398, 1848, 188, 2671, 2661, 35, 1396, 1397, + /* 680 */ 438, 2657, 2535, 40, 39, 2535, 1850, 46, 44, 43, + /* 690 */ 42, 41, 40, 39, 1880, 1890, 46, 44, 43, 42, + /* 700 */ 41, 1908, 1911, 2692, 1997, 2313, 2314, 762, 148, 85, + /* 710 */ 84, 511, 186, 308, 218, 2558, 1821, 2152, 1819, 844, + /* 720 */ 164, 163, 841, 840, 839, 161, 308, 503, 501, 844, + /* 730 */ 164, 163, 841, 840, 839, 161, 862, 2386, 389, 2222, + /* 740 */ 2569, 490, 1420, 1421, 487, 483, 479, 476, 504, 1826, + /* 750 */ 1824, 1825, 1877, 788, 1879, 1882, 1883, 1884, 1885, 1886, + /* 760 */ 1887, 1888, 1889, 783, 807, 806, 1901, 1903, 1904, 1905, + /* 770 */ 1906, 2, 47, 45, 1912, 2569, 1788, 100, 530, 2381, + /* 780 */ 442, 2587, 1820, 805, 2261, 805, 2261, 706, 788, 308, + /* 790 */ 2116, 673, 672, 671, 2535, 1907, 787, 1818, 663, 145, + /* 800 */ 667, 560, 2381, 55, 666, 512, 456, 455, 1723, 665, + /* 810 */ 670, 421, 420, 649, 648, 664, 2587, 1675, 1676, 419, + /* 820 */ 660, 659, 204, 2669, 2670, 1902, 146, 2674, 223, 2535, + /* 830 */ 96, 787, 46, 44, 43, 42, 41, 837, 2568, 1826, + /* 840 */ 721, 2607, 306, 2742, 351, 115, 2570, 791, 2572, 2573, + /* 850 */ 786, 228, 809, 96, 805, 2261, 2257, 2636, 836, 2661, + /* 860 */ 1849, 2748, 205, 438, 2657, 661, 2743, 751, 904, 2747, + /* 870 */ 414, 48, 2742, 2568, 513, 2569, 2607, 805, 2261, 2256, + /* 880 */ 115, 2570, 791, 2572, 2573, 786, 2319, 809, 788, 1500, + /* 890 */ 2699, 2746, 2762, 462, 2661, 2743, 2745, 532, 438, 2657, + /* 900 */ 805, 2261, 2317, 2006, 673, 672, 671, 805, 2261, 1909, + /* 910 */ 1910, 663, 145, 667, 2082, 1849, 2587, 666, 2007, 2250, + /* 920 */ 545, 766, 665, 670, 421, 420, 2246, 546, 664, 2535, + /* 930 */ 2198, 787, 419, 660, 659, 2354, 2747, 40, 39, 2742, + /* 940 */ 107, 46, 44, 43, 42, 41, 149, 1880, 1890, 2632, + /* 950 */ 762, 148, 1522, 1917, 1908, 1911, 446, 276, 2746, 1845, + /* 960 */ 2005, 275, 2743, 2744, 173, 2254, 2136, 1521, 2535, 1821, + /* 970 */ 461, 1819, 2263, 2568, 721, 859, 2607, 2742, 173, 2076, + /* 980 */ 115, 2570, 791, 2572, 2573, 786, 2263, 809, 674, 2569, + /* 990 */ 1845, 700, 2762, 2746, 2661, 2748, 205, 277, 438, 2657, + /* 1000 */ 2743, 751, 788, 1824, 1825, 1877, 2248, 1879, 1882, 1883, + /* 1010 */ 1884, 1885, 1886, 1887, 1888, 1889, 783, 807, 806, 1901, + /* 1020 */ 1903, 1904, 1905, 1906, 2, 47, 45, 2569, 464, 196, + /* 1030 */ 2587, 99, 113, 442, 399, 1820, 173, 426, 582, 693, + /* 1040 */ 788, 861, 2712, 2535, 2263, 787, 427, 2452, 1907, 151, + /* 1050 */ 1818, 805, 2261, 316, 317, 805, 2261, 2253, 315, 805, + /* 1060 */ 2261, 1978, 805, 2261, 2338, 206, 2669, 2670, 2587, 146, + /* 1070 */ 2674, 547, 778, 2569, 9, 629, 1748, 1749, 1902, 2258, + /* 1080 */ 777, 2535, 279, 787, 200, 1850, 788, 2568, 732, 2081, + /* 1090 */ 2607, 771, 1826, 2633, 115, 2570, 791, 2572, 2573, 786, + /* 1100 */ 773, 809, 2633, 551, 2569, 2237, 2634, 550, 2661, 2244, + /* 1110 */ 805, 2261, 438, 2657, 2587, 549, 700, 788, 117, 2735, + /* 1120 */ 199, 904, 805, 2261, 48, 2568, 1881, 2535, 2607, 787, + /* 1130 */ 287, 2476, 115, 2570, 791, 2572, 2573, 786, 77, 809, + /* 1140 */ 1850, 174, 768, 2535, 2762, 2587, 2661, 805, 2261, 2197, + /* 1150 */ 438, 2657, 2080, 805, 2261, 805, 2261, 1881, 2535, 1938, + /* 1160 */ 787, 259, 1909, 1910, 651, 650, 2079, 320, 1417, 1849, + /* 1170 */ 1416, 2568, 2453, 802, 2607, 803, 846, 181, 115, 2570, + /* 1180 */ 791, 2572, 2573, 786, 1878, 809, 647, 643, 639, 635, + /* 1190 */ 2762, 258, 2661, 88, 395, 394, 438, 2657, 805, 2261, + /* 1200 */ 1880, 1890, 2568, 1418, 449, 2607, 2535, 1908, 1911, 115, + /* 1210 */ 2570, 791, 2572, 2573, 786, 1878, 809, 1907, 347, 458, + /* 1220 */ 2535, 2762, 1821, 2661, 1819, 805, 2261, 438, 2657, 2078, + /* 1230 */ 553, 552, 669, 668, 2457, 2077, 97, 2074, 2073, 256, + /* 1240 */ 838, 34, 1845, 2310, 2072, 465, 2569, 1902, 873, 871, + /* 1250 */ 2071, 1943, 842, 2681, 1970, 2310, 1824, 1825, 1877, 788, + /* 1260 */ 1879, 1882, 1883, 1884, 1885, 1886, 1887, 1888, 1889, 783, + /* 1270 */ 807, 806, 1901, 1903, 1904, 1905, 1906, 2, 47, 45, + /* 1280 */ 2070, 1820, 284, 2535, 754, 2069, 442, 2587, 1820, 2535, + /* 1290 */ 278, 2535, 2535, 753, 2569, 2068, 1818, 2319, 2535, 2319, + /* 1300 */ 2535, 1907, 787, 1818, 2535, 2067, 2066, 788, 246, 2680, + /* 1310 */ 1400, 173, 1970, 800, 3, 2318, 1844, 255, 248, 2264, + /* 1320 */ 843, 2091, 899, 2310, 253, 624, 53, 2479, 757, 264, + /* 1330 */ 360, 1902, 262, 2296, 2535, 2587, 2058, 2059, 1826, 2535, + /* 1340 */ 1977, 2364, 2239, 245, 2568, 1826, 2134, 2607, 2535, 2535, + /* 1350 */ 787, 115, 2570, 791, 2572, 2573, 786, 662, 809, 2535, + /* 1360 */ 2535, 468, 467, 772, 141, 2661, 212, 904, 676, 438, + /* 1370 */ 2657, 1834, 155, 155, 904, 154, 87, 15, 481, 266, + /* 1380 */ 1502, 1498, 265, 522, 1907, 268, 1827, 270, 267, 288, + /* 1390 */ 269, 1811, 2568, 1787, 1850, 2607, 695, 728, 694, 115, + /* 1400 */ 2570, 791, 2572, 2573, 786, 2125, 809, 2123, 1481, 49, + /* 1410 */ 853, 2762, 854, 2661, 1902, 1909, 1910, 438, 2657, 49, + /* 1420 */ 189, 162, 1503, 451, 450, 1812, 64, 678, 1826, 681, + /* 1430 */ 14, 13, 776, 49, 1473, 2705, 1471, 101, 301, 807, + /* 1440 */ 806, 1901, 1903, 1904, 1905, 1906, 326, 325, 738, 143, + /* 1450 */ 1482, 1739, 1746, 1880, 1890, 49, 314, 775, 76, 160, + /* 1460 */ 1908, 1911, 1564, 162, 328, 327, 295, 1878, 1821, 2588, + /* 1470 */ 1819, 330, 329, 332, 331, 1821, 2001, 1819, 1555, 834, + /* 1480 */ 833, 832, 1559, 831, 1561, 1562, 782, 781, 2011, 1570, + /* 1490 */ 780, 1572, 1573, 779, 818, 815, 334, 333, 2010, 293, + /* 1500 */ 767, 2191, 1824, 1825, 73, 1944, 813, 336, 335, 1824, + /* 1510 */ 1825, 1877, 1891, 1879, 1882, 1883, 1884, 1885, 1886, 1887, + /* 1520 */ 1888, 1889, 783, 807, 806, 1901, 1903, 1904, 1905, 1906, + /* 1530 */ 2, 338, 337, 2190, 1692, 318, 2117, 797, 322, 340, + /* 1540 */ 339, 2569, 1548, 342, 341, 344, 343, 160, 1564, 1454, + /* 1550 */ 346, 345, 112, 162, 788, 142, 755, 160, 1835, 2390, + /* 1560 */ 1830, 109, 2107, 2695, 1555, 834, 833, 832, 1559, 831, + /* 1570 */ 1561, 1562, 830, 827, 2569, 1570, 824, 1572, 1573, 821, + /* 1580 */ 818, 815, 2587, 359, 735, 1577, 433, 788, 897, 742, + /* 1590 */ 429, 1455, 1838, 1840, 794, 2535, 472, 787, 2391, 2113, + /* 1600 */ 2307, 714, 758, 1928, 2696, 2706, 807, 806, 1901, 1903, + /* 1610 */ 1904, 1905, 1906, 763, 303, 2587, 300, 307, 2223, 5, + /* 1620 */ 2569, 475, 480, 408, 488, 489, 1585, 1853, 2535, 500, + /* 1630 */ 787, 213, 1592, 788, 1590, 499, 165, 214, 502, 2568, + /* 1640 */ 216, 354, 2607, 1716, 1843, 1844, 116, 2570, 791, 2572, + /* 1650 */ 2573, 786, 516, 809, 680, 523, 227, 525, 529, 531, + /* 1660 */ 2661, 2587, 571, 536, 2660, 2657, 548, 561, 559, 692, + /* 1670 */ 567, 2383, 2568, 583, 2535, 2607, 787, 570, 572, 116, + /* 1680 */ 2570, 791, 2572, 2573, 786, 274, 809, 584, 581, 232, + /* 1690 */ 233, 586, 588, 2661, 2569, 589, 236, 774, 2657, 591, + /* 1700 */ 593, 683, 1851, 608, 4, 609, 244, 785, 677, 675, + /* 1710 */ 1846, 93, 616, 619, 1852, 271, 621, 1854, 789, 617, + /* 1720 */ 247, 2607, 1855, 622, 2569, 116, 2570, 791, 2572, 2573, + /* 1730 */ 786, 623, 809, 250, 625, 2587, 252, 788, 2399, 2661, + /* 1740 */ 2569, 631, 94, 401, 2657, 2466, 95, 652, 2535, 257, + /* 1750 */ 787, 118, 386, 788, 654, 2251, 2569, 684, 261, 2247, + /* 1760 */ 71, 685, 697, 70, 263, 2587, 98, 699, 168, 788, + /* 1770 */ 355, 169, 2249, 2245, 156, 170, 171, 1847, 2535, 280, + /* 1780 */ 787, 2587, 709, 708, 2445, 285, 716, 710, 739, 2711, + /* 1790 */ 2463, 2462, 2568, 795, 2535, 2607, 787, 2587, 715, 382, + /* 1800 */ 2570, 791, 2572, 2573, 786, 784, 809, 770, 2626, 713, + /* 1810 */ 2535, 725, 787, 2710, 2683, 290, 292, 8, 748, 294, + /* 1820 */ 726, 302, 2568, 180, 296, 2607, 724, 283, 723, 177, + /* 1830 */ 2570, 791, 2572, 2573, 786, 434, 809, 1970, 2568, 2765, + /* 1840 */ 2569, 2607, 299, 759, 756, 178, 2570, 791, 2572, 2573, + /* 1850 */ 786, 1848, 809, 788, 2568, 147, 2569, 2607, 1975, 1973, + /* 1860 */ 309, 116, 2570, 791, 2572, 2573, 786, 192, 809, 788, + /* 1870 */ 157, 722, 2702, 61, 2677, 2661, 356, 2569, 793, 2413, + /* 1880 */ 2658, 2587, 2412, 2411, 357, 297, 2642, 798, 1, 159, + /* 1890 */ 788, 298, 358, 444, 2535, 799, 787, 2587, 2527, 752, + /* 1900 */ 2763, 2526, 2741, 208, 106, 2262, 2522, 108, 2521, 1375, + /* 1910 */ 2535, 898, 787, 2513, 2512, 2504, 2503, 2569, 2587, 2519, + /* 1920 */ 2518, 2510, 2509, 2498, 361, 2497, 2516, 2515, 349, 2507, + /* 1930 */ 788, 2535, 431, 787, 901, 903, 811, 2506, 2568, 385, + /* 1940 */ 166, 2607, 363, 373, 2495, 177, 2570, 791, 2572, 2573, + /* 1950 */ 786, 2494, 809, 432, 2568, 2492, 384, 2607, 2587, 374, + /* 1960 */ 2491, 383, 2570, 791, 2572, 2573, 786, 2311, 809, 365, + /* 1970 */ 2487, 2535, 2486, 787, 2485, 2568, 52, 406, 2607, 82, + /* 1980 */ 407, 2480, 383, 2570, 791, 2572, 2573, 786, 2703, 809, + /* 1990 */ 477, 2569, 478, 1771, 1772, 211, 2478, 482, 484, 485, + /* 2000 */ 486, 1770, 2477, 409, 788, 2475, 491, 2474, 493, 2473, + /* 2010 */ 495, 2472, 497, 1759, 2449, 2568, 215, 2448, 2607, 217, + /* 2020 */ 1719, 83, 376, 2570, 791, 2572, 2573, 786, 2569, 809, + /* 2030 */ 1718, 2426, 2587, 2425, 2424, 509, 510, 2423, 2422, 2373, + /* 2040 */ 514, 785, 1662, 2370, 2369, 2535, 2363, 787, 521, 517, + /* 2050 */ 520, 2360, 220, 2359, 2358, 86, 2357, 2362, 2361, 2356, + /* 2060 */ 2355, 2353, 2352, 2351, 222, 224, 537, 2350, 747, 2587, + /* 2070 */ 539, 2348, 2347, 2346, 2345, 2368, 2344, 2343, 2342, 2366, + /* 2080 */ 2349, 2341, 2535, 2340, 787, 2339, 2337, 2336, 2335, 2568, + /* 2090 */ 2334, 2569, 2607, 2333, 2332, 2331, 178, 2570, 791, 2572, + /* 2100 */ 2573, 786, 2330, 809, 788, 2329, 2328, 2569, 574, 703, + /* 2110 */ 92, 2327, 2367, 226, 2365, 2326, 2325, 2324, 1668, 231, + /* 2120 */ 788, 2323, 2322, 2321, 2320, 576, 2568, 907, 2156, 2607, + /* 2130 */ 2155, 1519, 2587, 382, 2570, 791, 2572, 2573, 786, 397, + /* 2140 */ 809, 1523, 2627, 353, 1515, 2535, 2154, 787, 2587, 398, + /* 2150 */ 2153, 2764, 2151, 2148, 595, 594, 234, 235, 2147, 195, + /* 2160 */ 251, 2535, 596, 787, 599, 237, 2569, 441, 895, 891, + /* 2170 */ 887, 883, 598, 350, 600, 238, 2140, 602, 604, 788, + /* 2180 */ 603, 2127, 606, 443, 2102, 1399, 240, 187, 2555, 2568, + /* 2190 */ 79, 197, 2607, 614, 2101, 2447, 383, 2570, 791, 2572, + /* 2200 */ 2573, 786, 242, 809, 80, 2568, 2443, 2587, 2607, 2433, + /* 2210 */ 2421, 249, 383, 2570, 791, 2572, 2573, 786, 114, 809, + /* 2220 */ 2535, 323, 787, 2420, 254, 2569, 2397, 2240, 1447, 2150, + /* 2230 */ 2146, 633, 634, 632, 2144, 636, 637, 2142, 788, 638, + /* 2240 */ 640, 642, 641, 2139, 2569, 644, 646, 2122, 2120, 2121, + /* 2250 */ 2119, 645, 2098, 2242, 1597, 801, 72, 788, 1596, 2241, + /* 2260 */ 1488, 1505, 1504, 2137, 696, 1501, 2587, 2607, 260, 1499, + /* 2270 */ 1497, 378, 2570, 791, 2572, 2573, 786, 1496, 809, 2535, + /* 2280 */ 2135, 787, 1495, 1494, 422, 2587, 423, 870, 1493, 872, + /* 2290 */ 2126, 424, 1490, 2124, 1489, 1487, 425, 679, 2535, 311, + /* 2300 */ 787, 2097, 682, 2096, 2095, 686, 310, 2094, 688, 2093, + /* 2310 */ 690, 119, 1753, 1755, 1752, 2446, 2569, 1757, 28, 282, + /* 2320 */ 56, 2442, 67, 2568, 701, 281, 2607, 57, 1727, 788, + /* 2330 */ 368, 2570, 791, 2572, 2573, 786, 1743, 809, 2432, 1725, + /* 2340 */ 711, 1729, 2568, 2419, 2418, 2607, 2569, 20, 286, 367, + /* 2350 */ 2570, 791, 2572, 2573, 786, 712, 809, 2587, 2747, 788, + /* 2360 */ 717, 172, 1704, 1703, 719, 727, 430, 6, 17, 7, + /* 2370 */ 2535, 30, 787, 2028, 21, 22, 202, 289, 2569, 2002, + /* 2380 */ 191, 32, 2556, 729, 23, 733, 65, 2587, 731, 24, + /* 2390 */ 18, 788, 59, 291, 2009, 179, 190, 31, 2043, 1996, + /* 2400 */ 2535, 2048, 787, 81, 2042, 435, 2049, 2047, 2046, 436, + /* 2410 */ 1967, 305, 1966, 58, 2568, 182, 2417, 2607, 2396, 2587, + /* 2420 */ 103, 369, 2570, 791, 2572, 2573, 786, 102, 809, 25, + /* 2430 */ 13, 1919, 2535, 11, 787, 1918, 1836, 1894, 183, 193, + /* 2440 */ 2395, 1870, 1893, 1892, 2568, 820, 823, 2607, 826, 104, + /* 2450 */ 829, 375, 2570, 791, 2572, 2573, 786, 1929, 809, 2569, + /* 2460 */ 38, 16, 26, 812, 1862, 790, 313, 810, 27, 324, + /* 2470 */ 2004, 194, 788, 109, 319, 69, 2568, 1896, 460, 2607, + /* 2480 */ 105, 816, 819, 379, 2570, 791, 2572, 2573, 786, 2569, + /* 2490 */ 809, 2612, 2611, 808, 822, 68, 825, 1578, 796, 321, + /* 2500 */ 2587, 828, 788, 814, 817, 2569, 1575, 1574, 1569, 1571, + /* 2510 */ 1565, 1563, 110, 2535, 348, 787, 111, 1591, 788, 78, + /* 2520 */ 1568, 1567, 2569, 1554, 835, 1566, 1587, 1445, 845, 1484, + /* 2530 */ 2587, 1483, 1480, 1477, 1476, 788, 1475, 1474, 1472, 1470, + /* 2540 */ 1469, 1513, 1468, 2535, 858, 787, 2587, 1512, 860, 209, + /* 2550 */ 1466, 1465, 1464, 1463, 1462, 1461, 1460, 2568, 1509, 2535, + /* 2560 */ 2607, 787, 1507, 2587, 370, 2570, 791, 2572, 2573, 786, + /* 2570 */ 1457, 809, 1456, 1453, 1452, 1451, 2535, 1450, 787, 2145, + /* 2580 */ 880, 881, 2143, 882, 884, 885, 886, 2568, 888, 889, + /* 2590 */ 2607, 2141, 890, 2138, 380, 2570, 791, 2572, 2573, 786, + /* 2600 */ 892, 809, 894, 2568, 896, 893, 2607, 2118, 1388, 2092, + /* 2610 */ 371, 2570, 791, 2572, 2573, 786, 1376, 809, 900, 352, + /* 2620 */ 2568, 902, 905, 2607, 1822, 362, 906, 381, 2570, 791, + /* 2630 */ 2572, 2573, 786, 2062, 809, 2569, 2062, 2062, 2062, 2062, + /* 2640 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 788, 2062, + /* 2650 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2660 */ 2062, 2569, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2670 */ 2062, 2062, 2062, 2062, 788, 2062, 2587, 2062, 2062, 2062, + /* 2680 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2535, + /* 2690 */ 2062, 787, 2062, 2062, 2569, 2062, 2062, 2062, 2062, 2062, + /* 2700 */ 2062, 2062, 2587, 2062, 2062, 2062, 2062, 788, 2062, 2062, + /* 2710 */ 2062, 2062, 2062, 2062, 2062, 2535, 2062, 787, 2062, 2062, + /* 2720 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2730 */ 2062, 2062, 2062, 2568, 2062, 2587, 2607, 2062, 2062, 2062, + /* 2740 */ 372, 2570, 791, 2572, 2573, 786, 2062, 809, 2535, 2062, + /* 2750 */ 787, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2568, + /* 2760 */ 2062, 2062, 2607, 2062, 2062, 2062, 387, 2570, 791, 2572, + /* 2770 */ 2573, 786, 2062, 809, 2062, 2062, 2062, 2569, 2062, 2062, + /* 2780 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2790 */ 788, 2062, 2568, 2062, 2062, 2607, 2062, 2569, 2062, 388, + /* 2800 */ 2570, 791, 2572, 2573, 786, 2062, 809, 2062, 2062, 2062, + /* 2810 */ 788, 2062, 2062, 2062, 2569, 2062, 2062, 2062, 2587, 2062, + /* 2820 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 788, 2062, 2062, + /* 2830 */ 2062, 2535, 2062, 787, 2062, 2062, 2062, 2062, 2587, 2062, + /* 2840 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2850 */ 2062, 2535, 2062, 787, 2062, 2587, 2062, 2062, 2062, 2062, + /* 2860 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2535, 2062, + /* 2870 */ 787, 2062, 2062, 2062, 2062, 2568, 2062, 2062, 2607, 2062, + /* 2880 */ 2062, 2062, 2581, 2570, 791, 2572, 2573, 786, 2062, 809, + /* 2890 */ 2062, 2062, 2062, 2062, 2062, 2568, 2062, 2062, 2607, 2062, + /* 2900 */ 2062, 2062, 2580, 2570, 791, 2572, 2573, 786, 2062, 809, + /* 2910 */ 2062, 2062, 2568, 2062, 2062, 2607, 2062, 2062, 2062, 2579, + /* 2920 */ 2570, 791, 2572, 2573, 786, 2062, 809, 2569, 2062, 2062, + /* 2930 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2940 */ 788, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2950 */ 2569, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 2960 */ 2062, 2062, 2062, 788, 2062, 2062, 2569, 2062, 2587, 2062, + /* 2970 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 788, + /* 2980 */ 2062, 2535, 2062, 787, 2062, 2062, 2569, 2062, 2062, 2062, + /* 2990 */ 2062, 2587, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 788, + /* 3000 */ 2062, 2062, 2062, 2062, 2535, 2062, 787, 2587, 2062, 2062, + /* 3010 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 3020 */ 2535, 2062, 787, 2062, 2062, 2568, 2062, 2587, 2607, 2062, + /* 3030 */ 2062, 2062, 403, 2570, 791, 2572, 2573, 786, 2062, 809, + /* 3040 */ 2535, 2062, 787, 2062, 2062, 2062, 2062, 2062, 2568, 2062, + /* 3050 */ 2062, 2607, 2062, 2062, 2062, 404, 2570, 791, 2572, 2573, + /* 3060 */ 786, 2062, 809, 2062, 2568, 2062, 2062, 2607, 2062, 2062, + /* 3070 */ 2569, 400, 2570, 791, 2572, 2573, 786, 2062, 809, 2062, + /* 3080 */ 2062, 2062, 2062, 788, 2568, 2062, 2062, 2607, 2062, 2062, + /* 3090 */ 2062, 405, 2570, 791, 2572, 2573, 786, 2062, 809, 2569, + /* 3100 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 3110 */ 2062, 2587, 788, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 3120 */ 2062, 2062, 2062, 2062, 2535, 2062, 787, 2062, 2062, 2062, + /* 3130 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 3140 */ 2587, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 3150 */ 2062, 2062, 2062, 2535, 2062, 787, 2062, 2062, 2062, 2062, + /* 3160 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2062, 789, 2062, + /* 3170 */ 2062, 2607, 2062, 2062, 2062, 378, 2570, 791, 2572, 2573, + /* 3180 */ 786, 2062, 809, 2062, 2062, 2062, 2062, 2062, 2062, 2062, + /* 3190 */ 2062, 2062, 2062, 2062, 2062, 2062, 2062, 2568, 2062, 2062, + /* 3200 */ 2607, 2062, 2062, 2062, 377, 2570, 791, 2572, 2573, 786, + /* 3210 */ 2062, 809, }; static const YYCODETYPE yy_lookahead[] = { - /* 0 */ 417, 395, 391, 362, 369, 374, 375, 372, 373, 403, - /* 10 */ 374, 375, 12, 13, 14, 432, 374, 411, 435, 436, - /* 20 */ 20, 405, 22, 8, 9, 394, 415, 12, 13, 14, - /* 30 */ 15, 16, 401, 481, 482, 35, 417, 37, 0, 12, - /* 40 */ 13, 14, 15, 16, 8, 9, 362, 362, 12, 13, - /* 50 */ 14, 15, 16, 375, 435, 436, 415, 374, 375, 423, - /* 60 */ 375, 419, 420, 20, 422, 65, 0, 4, 426, 33, - /* 70 */ 403, 70, 72, 462, 463, 464, 370, 410, 462, 79, - /* 80 */ 374, 403, 376, 492, 473, 418, 495, 21, 403, 473, - /* 90 */ 24, 25, 26, 27, 28, 29, 30, 31, 32, 415, - /* 100 */ 415, 20, 417, 369, 513, 514, 372, 373, 108, 518, - /* 110 */ 519, 111, 74, 75, 76, 77, 78, 20, 80, 81, + /* 0 */ 369, 391, 405, 372, 373, 408, 493, 369, 466, 496, + /* 10 */ 372, 373, 12, 13, 14, 374, 391, 374, 375, 466, + /* 20 */ 20, 418, 22, 0, 418, 370, 416, 514, 515, 374, + /* 30 */ 440, 376, 519, 520, 492, 35, 433, 37, 0, 436, + /* 40 */ 437, 416, 436, 437, 21, 492, 362, 24, 25, 26, + /* 50 */ 27, 28, 29, 30, 31, 32, 374, 375, 37, 375, + /* 60 */ 463, 420, 421, 21, 423, 65, 0, 424, 427, 403, + /* 70 */ 0, 474, 72, 463, 464, 465, 410, 71, 36, 79, + /* 80 */ 38, 39, 40, 493, 474, 419, 496, 403, 463, 464, + /* 90 */ 24, 25, 26, 27, 28, 29, 30, 31, 32, 474, + /* 100 */ 416, 403, 418, 414, 514, 515, 417, 418, 108, 519, + /* 110 */ 520, 111, 74, 75, 76, 77, 78, 419, 80, 81, /* 120 */ 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, /* 130 */ 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, - /* 140 */ 102, 103, 104, 37, 459, 49, 468, 462, 112, 149, - /* 150 */ 150, 466, 467, 468, 469, 470, 471, 413, 473, 492, - /* 160 */ 416, 417, 495, 478, 361, 480, 363, 33, 4, 484, - /* 170 */ 485, 488, 489, 490, 111, 492, 493, 20, 495, 22, - /* 180 */ 513, 514, 403, 19, 499, 518, 519, 187, 188, 20, - /* 190 */ 20, 359, 507, 403, 194, 195, 513, 514, 20, 35, - /* 200 */ 410, 518, 519, 403, 425, 204, 427, 111, 418, 209, - /* 210 */ 410, 211, 55, 370, 88, 51, 201, 374, 418, 376, - /* 220 */ 8, 9, 58, 59, 12, 13, 14, 15, 16, 65, - /* 230 */ 362, 21, 231, 232, 24, 25, 26, 27, 28, 29, - /* 240 */ 30, 31, 32, 243, 244, 245, 112, 247, 248, 249, + /* 140 */ 102, 103, 104, 37, 460, 111, 374, 463, 51, 149, + /* 150 */ 150, 467, 468, 469, 470, 471, 472, 60, 474, 493, + /* 160 */ 63, 64, 496, 479, 402, 481, 395, 50, 403, 485, + /* 170 */ 486, 489, 490, 491, 403, 493, 494, 415, 496, 20, + /* 180 */ 514, 515, 411, 22, 500, 519, 520, 187, 188, 20, + /* 190 */ 359, 426, 508, 428, 194, 195, 514, 515, 37, 8, + /* 200 */ 9, 519, 520, 12, 13, 14, 15, 16, 361, 209, + /* 210 */ 363, 211, 142, 143, 144, 145, 146, 147, 148, 20, + /* 220 */ 8, 9, 450, 451, 12, 13, 14, 15, 16, 458, + /* 230 */ 459, 21, 211, 440, 24, 25, 26, 27, 28, 29, + /* 240 */ 30, 31, 32, 243, 244, 245, 37, 247, 248, 249, /* 250 */ 250, 251, 252, 253, 254, 255, 256, 257, 258, 259, - /* 260 */ 260, 261, 262, 263, 264, 12, 13, 0, 187, 37, - /* 270 */ 18, 439, 20, 20, 110, 22, 444, 113, 465, 27, - /* 280 */ 439, 155, 30, 415, 72, 444, 22, 35, 35, 111, - /* 290 */ 37, 24, 25, 26, 27, 28, 29, 30, 31, 32, - /* 300 */ 20, 37, 2, 51, 491, 53, 180, 181, 8, 9, - /* 310 */ 58, 59, 12, 13, 14, 15, 16, 211, 65, 149, - /* 320 */ 150, 20, 70, 308, 492, 72, 245, 495, 0, 374, - /* 330 */ 375, 119, 79, 492, 8, 9, 495, 20, 12, 13, - /* 340 */ 14, 15, 16, 79, 281, 513, 514, 241, 242, 394, - /* 350 */ 518, 519, 374, 375, 513, 514, 401, 374, 108, 518, - /* 360 */ 519, 108, 110, 20, 111, 142, 143, 144, 145, 146, - /* 370 */ 147, 148, 122, 121, 124, 125, 126, 127, 128, 129, - /* 380 */ 130, 131, 132, 133, 20, 135, 136, 137, 138, 139, - /* 390 */ 140, 141, 0, 0, 111, 374, 375, 13, 186, 374, - /* 400 */ 375, 403, 149, 150, 405, 153, 154, 408, 156, 157, - /* 410 */ 158, 159, 160, 161, 162, 163, 164, 165, 265, 394, - /* 420 */ 267, 169, 170, 171, 172, 173, 174, 175, 111, 177, - /* 430 */ 178, 179, 449, 450, 71, 183, 184, 185, 112, 362, - /* 440 */ 187, 188, 190, 211, 423, 8, 9, 194, 195, 12, - /* 450 */ 13, 14, 15, 16, 71, 457, 458, 20, 0, 374, - /* 460 */ 375, 462, 209, 79, 211, 487, 488, 489, 490, 189, - /* 470 */ 492, 493, 473, 241, 242, 374, 375, 39, 40, 394, + /* 260 */ 260, 261, 262, 263, 264, 12, 13, 374, 405, 108, + /* 270 */ 18, 440, 20, 20, 142, 22, 445, 370, 146, 27, + /* 280 */ 440, 374, 30, 376, 72, 445, 493, 35, 35, 496, + /* 290 */ 37, 8, 9, 403, 4, 12, 13, 14, 15, 16, + /* 300 */ 410, 374, 375, 51, 88, 53, 189, 514, 515, 419, + /* 310 */ 58, 59, 519, 520, 197, 281, 33, 211, 65, 482, + /* 320 */ 483, 394, 70, 20, 493, 72, 463, 496, 401, 374, + /* 330 */ 375, 119, 79, 493, 8, 9, 496, 474, 12, 13, + /* 340 */ 14, 15, 16, 450, 451, 514, 515, 241, 242, 394, + /* 350 */ 519, 520, 374, 375, 514, 515, 401, 20, 108, 519, + /* 360 */ 520, 108, 110, 20, 111, 375, 111, 39, 40, 12, + /* 370 */ 13, 155, 122, 121, 124, 125, 126, 127, 128, 129, + /* 380 */ 130, 131, 132, 133, 71, 135, 136, 137, 138, 139, + /* 390 */ 140, 141, 201, 403, 37, 112, 180, 181, 186, 70, + /* 400 */ 20, 111, 149, 150, 245, 153, 154, 121, 156, 157, + /* 410 */ 158, 159, 160, 161, 162, 163, 164, 165, 37, 362, + /* 420 */ 211, 169, 170, 171, 172, 173, 174, 175, 193, 177, + /* 430 */ 178, 179, 14, 15, 16, 183, 184, 185, 112, 14, + /* 440 */ 187, 188, 190, 115, 116, 20, 118, 194, 195, 8, + /* 450 */ 9, 20, 20, 12, 13, 14, 15, 16, 3, 469, + /* 460 */ 79, 20, 209, 208, 211, 210, 488, 489, 490, 491, + /* 470 */ 142, 493, 494, 416, 146, 20, 405, 1, 2, 440, /* 480 */ 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, - /* 490 */ 278, 208, 415, 210, 166, 167, 243, 244, 245, 4, + /* 490 */ 278, 111, 149, 150, 33, 240, 243, 244, 245, 308, /* 500 */ 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, /* 510 */ 257, 258, 259, 260, 261, 262, 263, 264, 265, 12, - /* 520 */ 13, 402, 384, 240, 4, 245, 18, 20, 362, 22, - /* 530 */ 392, 23, 189, 414, 142, 143, 144, 145, 146, 147, - /* 540 */ 148, 375, 35, 23, 37, 20, 245, 144, 40, 41, - /* 550 */ 3, 148, 44, 115, 116, 477, 118, 479, 362, 374, - /* 560 */ 375, 168, 54, 111, 281, 172, 46, 47, 48, 403, - /* 570 */ 20, 375, 65, 180, 66, 67, 68, 69, 70, 72, - /* 580 */ 142, 415, 121, 417, 146, 403, 79, 12, 13, 488, - /* 590 */ 489, 490, 22, 492, 493, 1, 2, 22, 281, 403, - /* 600 */ 142, 143, 144, 145, 146, 147, 148, 37, 423, 427, - /* 610 */ 35, 415, 37, 417, 265, 108, 374, 375, 111, 111, - /* 620 */ 390, 218, 395, 393, 221, 459, 189, 224, 462, 226, - /* 630 */ 403, 3, 466, 467, 468, 469, 470, 471, 411, 473, - /* 640 */ 65, 225, 476, 227, 478, 479, 480, 14, 20, 79, - /* 650 */ 484, 485, 395, 20, 79, 459, 149, 150, 462, 151, - /* 660 */ 403, 111, 466, 467, 468, 469, 470, 471, 411, 473, - /* 670 */ 243, 21, 143, 144, 478, 79, 480, 148, 108, 20, - /* 680 */ 484, 485, 245, 108, 457, 458, 36, 0, 38, 39, - /* 690 */ 40, 383, 8, 9, 187, 188, 12, 13, 14, 15, - /* 700 */ 16, 194, 195, 507, 121, 391, 112, 37, 400, 201, - /* 710 */ 202, 203, 187, 188, 206, 142, 209, 409, 211, 146, - /* 720 */ 293, 294, 295, 296, 297, 298, 299, 219, 220, 415, - /* 730 */ 488, 489, 490, 281, 492, 493, 403, 14, 230, 52, - /* 740 */ 112, 233, 111, 20, 236, 237, 238, 239, 240, 79, - /* 750 */ 243, 244, 245, 405, 247, 248, 249, 250, 251, 252, + /* 520 */ 13, 4, 287, 288, 289, 290, 18, 20, 362, 22, + /* 530 */ 265, 23, 493, 204, 463, 496, 281, 194, 195, 243, + /* 540 */ 23, 375, 35, 111, 37, 474, 374, 375, 40, 41, + /* 550 */ 20, 65, 44, 514, 515, 362, 111, 362, 519, 520, + /* 560 */ 231, 232, 54, 46, 47, 48, 394, 112, 211, 403, + /* 570 */ 375, 281, 65, 112, 66, 67, 68, 69, 70, 72, + /* 580 */ 149, 150, 416, 265, 418, 267, 79, 0, 112, 293, + /* 590 */ 294, 295, 296, 297, 298, 299, 110, 14, 403, 113, + /* 600 */ 8, 9, 37, 20, 12, 13, 14, 15, 16, 416, + /* 610 */ 2, 416, 187, 418, 374, 108, 8, 9, 111, 111, + /* 620 */ 12, 13, 14, 15, 16, 20, 460, 22, 362, 463, + /* 630 */ 189, 362, 403, 467, 468, 469, 470, 471, 472, 410, + /* 640 */ 474, 111, 37, 477, 189, 479, 480, 481, 419, 466, + /* 650 */ 20, 485, 486, 49, 23, 460, 149, 150, 463, 151, + /* 660 */ 55, 281, 467, 468, 469, 470, 471, 472, 182, 474, + /* 670 */ 245, 431, 432, 20, 479, 492, 481, 2, 47, 48, + /* 680 */ 485, 486, 416, 8, 9, 416, 245, 12, 13, 14, + /* 690 */ 15, 16, 8, 9, 187, 188, 12, 13, 14, 15, + /* 700 */ 16, 194, 195, 508, 112, 417, 418, 374, 375, 201, + /* 710 */ 202, 203, 403, 281, 206, 111, 209, 0, 211, 142, + /* 720 */ 143, 144, 145, 146, 147, 148, 281, 219, 220, 142, + /* 730 */ 143, 144, 145, 146, 147, 148, 390, 428, 230, 393, + /* 740 */ 362, 233, 56, 57, 236, 237, 238, 239, 240, 79, + /* 750 */ 243, 244, 245, 375, 247, 248, 249, 250, 251, 252, /* 760 */ 253, 254, 255, 256, 257, 258, 259, 260, 261, 262, - /* 770 */ 263, 264, 12, 13, 14, 362, 462, 463, 283, 209, - /* 780 */ 20, 211, 22, 374, 209, 399, 211, 473, 375, 281, - /* 790 */ 377, 458, 2, 193, 143, 35, 112, 37, 8, 9, - /* 800 */ 403, 0, 12, 13, 14, 15, 16, 410, 149, 150, - /* 810 */ 462, 362, 362, 243, 244, 418, 403, 189, 243, 244, - /* 820 */ 187, 473, 65, 0, 375, 65, 377, 20, 415, 22, - /* 830 */ 417, 281, 257, 258, 259, 260, 261, 262, 263, 79, - /* 840 */ 454, 8, 9, 42, 37, 12, 13, 14, 15, 16, - /* 850 */ 303, 439, 403, 194, 195, 404, 374, 375, 449, 450, - /* 860 */ 34, 362, 55, 14, 415, 415, 417, 110, 108, 20, - /* 870 */ 113, 111, 459, 222, 223, 462, 394, 22, 245, 466, - /* 880 */ 467, 468, 469, 470, 471, 439, 473, 287, 288, 289, - /* 890 */ 290, 478, 37, 480, 71, 8, 9, 484, 485, 12, - /* 900 */ 13, 14, 15, 16, 492, 395, 20, 495, 459, 149, - /* 910 */ 150, 462, 281, 403, 415, 466, 467, 468, 469, 470, - /* 920 */ 471, 411, 473, 51, 392, 513, 514, 478, 23, 480, - /* 930 */ 518, 519, 60, 484, 485, 63, 64, 403, 492, 182, - /* 940 */ 492, 495, 374, 495, 362, 411, 492, 187, 188, 495, - /* 950 */ 374, 375, 47, 48, 194, 195, 14, 15, 16, 513, - /* 960 */ 514, 108, 514, 108, 518, 519, 518, 519, 514, 209, - /* 970 */ 394, 211, 518, 519, 362, 12, 13, 124, 125, 126, - /* 980 */ 127, 128, 129, 130, 131, 132, 133, 445, 135, 136, - /* 990 */ 137, 138, 139, 140, 141, 416, 417, 415, 430, 431, - /* 1000 */ 37, 56, 57, 243, 244, 245, 404, 247, 248, 249, + /* 770 */ 263, 264, 12, 13, 14, 362, 211, 182, 374, 375, + /* 780 */ 20, 403, 22, 374, 375, 374, 375, 440, 375, 281, + /* 790 */ 377, 74, 75, 76, 416, 35, 418, 37, 81, 82, + /* 800 */ 83, 374, 375, 394, 87, 394, 241, 242, 213, 92, + /* 810 */ 93, 94, 95, 379, 380, 98, 403, 187, 188, 102, + /* 820 */ 103, 104, 489, 490, 491, 65, 493, 494, 424, 416, + /* 830 */ 383, 418, 12, 13, 14, 15, 16, 121, 460, 79, + /* 840 */ 493, 463, 189, 496, 34, 467, 468, 469, 470, 471, + /* 850 */ 472, 424, 474, 383, 374, 375, 409, 479, 404, 481, + /* 860 */ 20, 514, 515, 485, 486, 13, 519, 520, 108, 493, + /* 870 */ 400, 111, 496, 460, 394, 362, 463, 374, 375, 409, + /* 880 */ 467, 468, 469, 470, 471, 472, 403, 474, 375, 37, + /* 890 */ 377, 515, 479, 410, 481, 519, 520, 394, 485, 486, + /* 900 */ 374, 375, 419, 22, 74, 75, 76, 374, 375, 149, + /* 910 */ 150, 81, 82, 83, 362, 20, 403, 87, 37, 404, + /* 920 */ 394, 440, 92, 93, 94, 95, 404, 394, 98, 416, + /* 930 */ 392, 418, 102, 103, 104, 0, 493, 8, 9, 496, + /* 940 */ 381, 12, 13, 14, 15, 16, 477, 187, 188, 480, + /* 950 */ 374, 375, 22, 14, 194, 195, 395, 144, 515, 20, + /* 960 */ 79, 148, 519, 520, 403, 406, 0, 37, 416, 209, + /* 970 */ 395, 211, 411, 460, 493, 13, 463, 496, 403, 363, + /* 980 */ 467, 468, 469, 470, 471, 472, 411, 474, 22, 362, + /* 990 */ 20, 403, 479, 3, 481, 514, 515, 143, 485, 486, + /* 1000 */ 519, 520, 375, 243, 244, 245, 404, 247, 248, 249, /* 1010 */ 250, 251, 252, 253, 254, 255, 256, 257, 258, 259, - /* 1020 */ 260, 261, 262, 263, 264, 12, 13, 415, 362, 374, - /* 1030 */ 375, 362, 439, 20, 439, 22, 187, 374, 375, 374, - /* 1040 */ 375, 375, 50, 377, 383, 374, 375, 14, 35, 394, - /* 1050 */ 37, 374, 375, 20, 374, 375, 465, 394, 404, 394, - /* 1060 */ 374, 375, 20, 186, 362, 394, 374, 375, 20, 403, - /* 1070 */ 409, 394, 381, 439, 394, 189, 189, 375, 65, 377, - /* 1080 */ 394, 415, 491, 417, 415, 492, 394, 492, 495, 398, - /* 1090 */ 495, 477, 79, 479, 245, 374, 375, 406, 374, 375, - /* 1100 */ 374, 375, 374, 375, 33, 403, 513, 514, 513, 514, - /* 1110 */ 33, 518, 519, 518, 519, 394, 45, 415, 394, 417, - /* 1120 */ 394, 108, 394, 22, 111, 459, 492, 0, 462, 495, - /* 1130 */ 362, 245, 466, 467, 468, 469, 470, 471, 37, 473, - /* 1140 */ 374, 375, 362, 362, 478, 268, 480, 513, 514, 362, - /* 1150 */ 484, 485, 518, 519, 404, 278, 375, 374, 375, 362, - /* 1160 */ 394, 459, 149, 150, 462, 362, 362, 362, 466, 467, - /* 1170 */ 468, 469, 470, 471, 211, 473, 362, 394, 362, 362, - /* 1180 */ 478, 189, 480, 415, 403, 476, 484, 485, 479, 197, - /* 1190 */ 379, 380, 379, 380, 182, 415, 415, 465, 417, 403, - /* 1200 */ 187, 188, 415, 388, 389, 381, 42, 194, 195, 108, - /* 1210 */ 388, 389, 415, 403, 418, 365, 366, 0, 415, 415, - /* 1220 */ 415, 363, 209, 491, 211, 213, 279, 280, 418, 415, - /* 1230 */ 406, 415, 415, 412, 396, 33, 415, 399, 403, 22, - /* 1240 */ 459, 412, 362, 462, 415, 404, 33, 466, 467, 468, - /* 1250 */ 469, 470, 471, 418, 473, 375, 243, 244, 245, 0, + /* 1020 */ 260, 261, 262, 263, 264, 12, 13, 362, 395, 189, + /* 1030 */ 403, 218, 381, 20, 221, 22, 403, 224, 108, 226, + /* 1040 */ 375, 79, 377, 416, 411, 418, 458, 459, 35, 398, + /* 1050 */ 37, 374, 375, 143, 144, 374, 375, 406, 148, 374, + /* 1060 */ 375, 4, 374, 375, 0, 489, 490, 491, 403, 493, + /* 1070 */ 494, 394, 404, 362, 42, 394, 222, 223, 65, 394, + /* 1080 */ 412, 416, 394, 418, 189, 245, 375, 460, 377, 362, + /* 1090 */ 463, 478, 79, 480, 467, 468, 469, 470, 471, 472, + /* 1100 */ 478, 474, 480, 168, 362, 0, 479, 172, 481, 404, + /* 1110 */ 374, 375, 485, 486, 403, 180, 403, 375, 189, 377, + /* 1120 */ 446, 108, 374, 375, 111, 460, 187, 416, 463, 418, + /* 1130 */ 394, 0, 467, 468, 469, 470, 471, 472, 121, 474, + /* 1140 */ 245, 384, 394, 416, 479, 403, 481, 374, 375, 392, + /* 1150 */ 485, 486, 362, 374, 375, 374, 375, 187, 416, 186, + /* 1160 */ 418, 35, 149, 150, 379, 380, 362, 394, 20, 20, + /* 1170 */ 22, 460, 459, 394, 463, 394, 71, 51, 467, 468, + /* 1180 */ 469, 470, 471, 472, 245, 474, 60, 61, 62, 63, + /* 1190 */ 479, 65, 481, 176, 12, 13, 485, 486, 374, 375, + /* 1200 */ 187, 188, 460, 55, 22, 463, 416, 194, 195, 467, + /* 1210 */ 468, 469, 470, 471, 472, 245, 474, 35, 394, 37, + /* 1220 */ 416, 479, 209, 481, 211, 374, 375, 485, 486, 362, + /* 1230 */ 166, 167, 388, 389, 399, 362, 110, 362, 362, 113, + /* 1240 */ 413, 268, 20, 416, 362, 394, 362, 65, 388, 389, + /* 1250 */ 362, 278, 413, 279, 280, 416, 243, 244, 245, 375, /* 1260 */ 247, 248, 249, 250, 251, 252, 253, 254, 255, 256, /* 1270 */ 257, 258, 259, 260, 261, 262, 263, 264, 12, 13, - /* 1280 */ 121, 362, 412, 403, 33, 415, 20, 245, 22, 508, - /* 1290 */ 509, 0, 13, 245, 375, 415, 377, 417, 37, 114, - /* 1300 */ 33, 35, 117, 37, 114, 114, 114, 117, 117, 117, - /* 1310 */ 51, 0, 45, 13, 112, 65, 37, 362, 404, 149, - /* 1320 */ 150, 33, 403, 33, 33, 112, 33, 33, 33, 33, - /* 1330 */ 375, 65, 377, 22, 415, 176, 417, 37, 404, 459, - /* 1340 */ 79, 362, 462, 1, 2, 79, 466, 467, 468, 469, - /* 1350 */ 470, 471, 428, 473, 375, 33, 522, 33, 403, 511, - /* 1360 */ 480, 0, 235, 113, 484, 485, 12, 13, 12, 13, - /* 1370 */ 415, 111, 417, 0, 108, 12, 13, 111, 459, 33, - /* 1380 */ 120, 462, 403, 22, 307, 466, 467, 468, 469, 470, - /* 1390 */ 471, 33, 473, 504, 415, 22, 417, 478, 0, 480, - /* 1400 */ 112, 37, 112, 484, 485, 112, 112, 112, 112, 72, - /* 1410 */ 378, 12, 13, 37, 459, 149, 150, 462, 12, 13, - /* 1420 */ 37, 466, 467, 468, 469, 470, 471, 13, 473, 33, - /* 1430 */ 12, 13, 403, 478, 112, 480, 112, 391, 459, 484, - /* 1440 */ 485, 462, 362, 79, 280, 466, 467, 468, 469, 470, - /* 1450 */ 471, 37, 473, 187, 188, 375, 33, 33, 112, 480, - /* 1460 */ 194, 195, 33, 484, 485, 12, 13, 12, 13, 391, - /* 1470 */ 112, 428, 74, 75, 76, 209, 373, 211, 33, 81, - /* 1480 */ 82, 83, 33, 403, 33, 87, 12, 13, 12, 13, - /* 1490 */ 92, 93, 94, 95, 33, 415, 98, 417, 428, 362, - /* 1500 */ 102, 103, 104, 12, 13, 510, 510, 510, 112, 243, - /* 1510 */ 244, 245, 375, 247, 248, 249, 250, 251, 252, 253, + /* 1280 */ 362, 22, 404, 416, 33, 362, 20, 403, 22, 416, + /* 1290 */ 455, 416, 416, 303, 362, 362, 37, 403, 416, 403, + /* 1300 */ 416, 35, 418, 37, 416, 362, 362, 375, 182, 377, + /* 1310 */ 14, 403, 280, 419, 33, 419, 20, 191, 192, 411, + /* 1320 */ 413, 365, 366, 416, 198, 199, 45, 0, 33, 114, + /* 1330 */ 396, 65, 117, 399, 416, 403, 149, 150, 79, 416, + /* 1340 */ 283, 0, 0, 217, 460, 79, 0, 463, 416, 416, + /* 1350 */ 418, 467, 468, 469, 470, 471, 472, 13, 474, 416, + /* 1360 */ 416, 12, 13, 479, 33, 481, 235, 108, 22, 485, + /* 1370 */ 486, 22, 33, 33, 108, 33, 45, 111, 51, 114, + /* 1380 */ 37, 37, 117, 42, 35, 114, 37, 114, 117, 65, + /* 1390 */ 117, 209, 460, 211, 245, 463, 225, 33, 227, 467, + /* 1400 */ 468, 469, 470, 471, 472, 0, 474, 0, 37, 33, + /* 1410 */ 13, 479, 13, 481, 65, 149, 150, 485, 486, 33, + /* 1420 */ 33, 33, 79, 241, 242, 243, 33, 22, 79, 22, + /* 1430 */ 1, 2, 72, 33, 37, 429, 37, 113, 523, 257, + /* 1440 */ 258, 259, 260, 261, 262, 263, 12, 13, 512, 378, + /* 1450 */ 79, 112, 112, 187, 188, 33, 33, 108, 33, 33, + /* 1460 */ 194, 195, 108, 33, 12, 13, 505, 245, 209, 403, + /* 1470 */ 211, 12, 13, 12, 13, 209, 112, 211, 124, 125, + /* 1480 */ 126, 127, 128, 129, 130, 131, 132, 133, 112, 135, + /* 1490 */ 136, 137, 138, 139, 140, 141, 12, 13, 112, 112, + /* 1500 */ 112, 391, 243, 244, 33, 112, 33, 12, 13, 243, + /* 1510 */ 244, 245, 112, 247, 248, 249, 250, 251, 252, 253, /* 1520 */ 254, 255, 256, 257, 258, 259, 260, 261, 262, 263, - /* 1530 */ 264, 362, 37, 438, 510, 112, 112, 428, 13, 459, - /* 1540 */ 403, 112, 462, 378, 375, 414, 466, 467, 468, 469, - /* 1550 */ 470, 471, 415, 473, 417, 375, 305, 112, 478, 446, - /* 1560 */ 480, 112, 37, 112, 484, 485, 12, 13, 428, 428, - /* 1570 */ 362, 515, 403, 112, 79, 494, 22, 486, 440, 497, - /* 1580 */ 243, 393, 284, 375, 415, 51, 417, 211, 42, 35, - /* 1590 */ 461, 37, 460, 20, 211, 451, 459, 383, 224, 462, - /* 1600 */ 451, 456, 383, 466, 467, 468, 469, 470, 471, 207, - /* 1610 */ 473, 403, 20, 442, 374, 478, 20, 480, 375, 65, - /* 1620 */ 45, 484, 485, 415, 424, 417, 186, 375, 459, 424, - /* 1630 */ 362, 462, 421, 375, 424, 466, 467, 468, 469, 470, - /* 1640 */ 471, 421, 473, 375, 374, 374, 421, 478, 421, 480, - /* 1650 */ 109, 387, 107, 484, 485, 386, 374, 374, 106, 385, - /* 1660 */ 374, 374, 20, 374, 367, 50, 367, 459, 383, 451, - /* 1670 */ 462, 403, 371, 371, 466, 467, 468, 469, 470, 471, - /* 1680 */ 20, 473, 417, 415, 20, 417, 383, 383, 480, 376, - /* 1690 */ 20, 383, 484, 485, 441, 376, 74, 75, 76, 383, - /* 1700 */ 20, 383, 374, 81, 82, 83, 431, 367, 383, 87, - /* 1710 */ 383, 228, 403, 403, 92, 93, 94, 95, 403, 374, - /* 1720 */ 98, 415, 365, 403, 102, 103, 104, 459, 455, 403, - /* 1730 */ 462, 365, 403, 362, 466, 467, 468, 469, 470, 471, - /* 1740 */ 472, 473, 474, 475, 403, 367, 375, 403, 362, 415, - /* 1750 */ 403, 403, 403, 415, 111, 20, 381, 450, 453, 215, - /* 1760 */ 448, 375, 214, 209, 374, 211, 381, 417, 451, 292, - /* 1770 */ 447, 440, 291, 300, 403, 415, 433, 200, 506, 362, - /* 1780 */ 503, 503, 302, 502, 433, 505, 415, 503, 417, 403, - /* 1790 */ 301, 285, 375, 501, 309, 241, 242, 243, 306, 440, - /* 1800 */ 304, 415, 280, 417, 20, 362, 375, 121, 282, 376, - /* 1810 */ 111, 257, 258, 259, 260, 261, 262, 263, 375, 381, - /* 1820 */ 403, 500, 381, 415, 433, 415, 415, 465, 498, 192, - /* 1830 */ 459, 517, 415, 462, 417, 496, 483, 466, 467, 468, - /* 1840 */ 469, 470, 471, 415, 473, 459, 403, 415, 462, 516, - /* 1850 */ 429, 381, 466, 467, 468, 469, 470, 471, 415, 473, - /* 1860 */ 417, 399, 362, 433, 111, 381, 480, 415, 375, 415, - /* 1870 */ 407, 485, 415, 415, 415, 375, 459, 22, 523, 462, - /* 1880 */ 437, 362, 415, 466, 467, 468, 469, 470, 471, 38, - /* 1890 */ 473, 520, 521, 415, 375, 374, 364, 415, 368, 443, - /* 1900 */ 367, 415, 459, 403, 381, 462, 434, 360, 397, 466, - /* 1910 */ 467, 468, 469, 470, 471, 415, 473, 417, 415, 415, - /* 1920 */ 415, 452, 403, 415, 415, 415, 509, 415, 415, 415, - /* 1930 */ 415, 415, 415, 415, 415, 415, 417, 437, 382, 397, - /* 1940 */ 397, 434, 0, 0, 0, 45, 0, 37, 234, 37, - /* 1950 */ 37, 37, 362, 234, 0, 37, 37, 234, 37, 459, - /* 1960 */ 0, 234, 462, 0, 37, 375, 466, 467, 468, 469, - /* 1970 */ 470, 471, 0, 473, 37, 0, 0, 22, 459, 229, - /* 1980 */ 0, 462, 362, 217, 37, 466, 467, 468, 469, 470, - /* 1990 */ 471, 0, 473, 403, 217, 375, 218, 211, 209, 0, - /* 2000 */ 0, 0, 205, 204, 0, 415, 0, 417, 154, 0, - /* 2010 */ 49, 49, 362, 49, 37, 0, 0, 51, 37, 0, - /* 2020 */ 0, 0, 0, 403, 45, 375, 0, 49, 0, 0, - /* 2030 */ 362, 512, 0, 0, 0, 415, 0, 417, 172, 37, - /* 2040 */ 0, 172, 0, 375, 0, 0, 0, 0, 0, 459, - /* 2050 */ 0, 362, 462, 403, 0, 0, 466, 467, 468, 469, - /* 2060 */ 470, 471, 0, 473, 375, 415, 0, 417, 0, 0, - /* 2070 */ 0, 403, 0, 0, 0, 0, 0, 0, 0, 459, - /* 2080 */ 49, 0, 462, 415, 45, 417, 466, 467, 468, 469, - /* 2090 */ 470, 471, 403, 473, 0, 475, 0, 0, 0, 0, - /* 2100 */ 0, 22, 0, 154, 415, 437, 417, 0, 0, 459, - /* 2110 */ 153, 521, 462, 1, 22, 50, 466, 467, 468, 469, - /* 2120 */ 470, 471, 152, 473, 0, 0, 437, 459, 22, 0, - /* 2130 */ 462, 19, 50, 0, 466, 467, 468, 469, 470, 471, - /* 2140 */ 37, 473, 0, 0, 0, 65, 0, 35, 459, 0, - /* 2150 */ 65, 462, 65, 65, 37, 466, 467, 468, 469, 470, - /* 2160 */ 471, 51, 473, 51, 42, 37, 362, 35, 42, 51, - /* 2170 */ 0, 37, 60, 61, 62, 63, 0, 65, 51, 375, - /* 2180 */ 42, 0, 37, 51, 45, 33, 49, 14, 0, 42, - /* 2190 */ 49, 43, 60, 61, 62, 63, 42, 65, 0, 49, - /* 2200 */ 362, 0, 0, 0, 42, 200, 0, 403, 49, 0, - /* 2210 */ 0, 0, 0, 375, 37, 51, 0, 42, 51, 415, - /* 2220 */ 37, 417, 110, 0, 73, 113, 42, 37, 42, 51, - /* 2230 */ 0, 51, 37, 42, 0, 0, 0, 0, 0, 362, - /* 2240 */ 0, 403, 110, 22, 37, 113, 0, 0, 117, 119, - /* 2250 */ 37, 37, 375, 415, 37, 417, 37, 37, 0, 147, - /* 2260 */ 189, 37, 37, 459, 37, 37, 462, 0, 37, 37, - /* 2270 */ 466, 467, 468, 469, 470, 471, 33, 473, 33, 22, - /* 2280 */ 403, 37, 22, 0, 22, 362, 22, 22, 37, 0, - /* 2290 */ 0, 0, 415, 22, 417, 53, 37, 459, 375, 0, - /* 2300 */ 462, 0, 20, 191, 466, 467, 468, 469, 470, 471, - /* 2310 */ 198, 473, 37, 37, 182, 362, 37, 37, 0, 122, - /* 2320 */ 112, 216, 123, 191, 192, 0, 403, 49, 375, 217, - /* 2330 */ 198, 199, 37, 111, 22, 0, 459, 111, 415, 462, - /* 2340 */ 417, 22, 189, 466, 467, 468, 469, 470, 471, 217, - /* 2350 */ 473, 0, 212, 192, 189, 0, 403, 189, 362, 196, - /* 2360 */ 189, 3, 196, 33, 111, 37, 112, 112, 415, 286, - /* 2370 */ 417, 375, 111, 37, 111, 362, 50, 109, 112, 50, - /* 2380 */ 33, 107, 459, 33, 112, 462, 33, 49, 375, 466, - /* 2390 */ 467, 468, 469, 470, 471, 111, 473, 111, 111, 403, - /* 2400 */ 112, 49, 33, 111, 3, 286, 112, 33, 112, 286, - /* 2410 */ 37, 415, 459, 417, 37, 462, 403, 37, 37, 466, - /* 2420 */ 467, 468, 469, 470, 471, 37, 473, 37, 415, 112, - /* 2430 */ 417, 49, 112, 33, 279, 49, 0, 0, 111, 42, - /* 2440 */ 33, 109, 109, 2, 22, 266, 362, 243, 49, 112, - /* 2450 */ 111, 49, 112, 111, 111, 459, 112, 22, 462, 375, - /* 2460 */ 111, 246, 466, 467, 468, 469, 470, 471, 112, 473, - /* 2470 */ 193, 112, 459, 111, 111, 462, 362, 111, 0, 466, - /* 2480 */ 467, 468, 469, 470, 471, 42, 473, 403, 191, 375, - /* 2490 */ 111, 120, 37, 49, 111, 111, 121, 112, 111, 415, - /* 2500 */ 111, 417, 37, 112, 111, 37, 112, 111, 37, 37, - /* 2510 */ 112, 37, 37, 33, 111, 22, 112, 403, 112, 362, - /* 2520 */ 111, 111, 37, 112, 111, 73, 72, 111, 111, 415, - /* 2530 */ 111, 417, 375, 37, 37, 123, 362, 122, 37, 134, - /* 2540 */ 37, 37, 134, 459, 37, 37, 462, 37, 134, 375, - /* 2550 */ 466, 467, 468, 469, 470, 471, 362, 473, 134, 37, - /* 2560 */ 403, 37, 37, 79, 105, 79, 105, 33, 37, 375, - /* 2570 */ 22, 79, 415, 459, 417, 37, 462, 403, 37, 37, - /* 2580 */ 466, 467, 468, 469, 470, 471, 37, 473, 37, 415, - /* 2590 */ 37, 417, 37, 37, 37, 37, 22, 403, 37, 0, - /* 2600 */ 37, 51, 42, 0, 37, 51, 42, 0, 37, 415, - /* 2610 */ 51, 417, 42, 0, 37, 42, 459, 51, 362, 462, - /* 2620 */ 0, 37, 37, 466, 467, 468, 469, 470, 471, 0, - /* 2630 */ 473, 375, 22, 459, 33, 362, 462, 22, 21, 21, - /* 2640 */ 466, 467, 468, 469, 470, 471, 22, 473, 375, 22, - /* 2650 */ 20, 524, 524, 459, 524, 362, 462, 524, 524, 403, - /* 2660 */ 466, 467, 468, 469, 470, 471, 524, 473, 375, 524, - /* 2670 */ 524, 415, 524, 417, 524, 524, 403, 524, 362, 524, - /* 2680 */ 524, 524, 524, 524, 524, 524, 524, 524, 415, 524, - /* 2690 */ 417, 375, 524, 524, 524, 524, 403, 524, 524, 524, - /* 2700 */ 524, 524, 524, 524, 524, 524, 524, 524, 415, 524, - /* 2710 */ 417, 524, 524, 524, 524, 459, 524, 524, 462, 403, - /* 2720 */ 524, 524, 466, 467, 468, 469, 470, 471, 524, 473, - /* 2730 */ 524, 415, 459, 417, 524, 462, 524, 524, 362, 466, - /* 2740 */ 467, 468, 469, 470, 471, 524, 473, 524, 524, 524, - /* 2750 */ 524, 375, 459, 524, 362, 462, 524, 524, 524, 466, - /* 2760 */ 467, 468, 469, 470, 471, 524, 473, 375, 524, 524, - /* 2770 */ 524, 524, 524, 524, 524, 459, 524, 524, 462, 403, - /* 2780 */ 524, 524, 466, 467, 468, 469, 470, 471, 524, 473, - /* 2790 */ 524, 415, 524, 417, 524, 403, 524, 524, 524, 524, - /* 2800 */ 524, 524, 524, 524, 524, 524, 524, 415, 524, 417, - /* 2810 */ 524, 524, 524, 524, 524, 524, 524, 524, 524, 524, - /* 2820 */ 524, 524, 524, 524, 524, 524, 362, 524, 524, 524, - /* 2830 */ 524, 524, 524, 524, 524, 459, 524, 524, 462, 375, - /* 2840 */ 524, 524, 466, 467, 468, 469, 470, 471, 524, 473, - /* 2850 */ 524, 459, 524, 524, 462, 524, 524, 524, 466, 467, - /* 2860 */ 468, 469, 470, 471, 362, 473, 524, 403, 524, 524, - /* 2870 */ 524, 524, 524, 524, 524, 524, 524, 375, 524, 415, - /* 2880 */ 524, 417, 524, 524, 524, 524, 524, 524, 524, 524, - /* 2890 */ 524, 524, 524, 524, 524, 362, 524, 524, 524, 524, - /* 2900 */ 524, 524, 524, 524, 524, 403, 524, 524, 375, 524, - /* 2910 */ 524, 524, 524, 524, 524, 524, 524, 415, 524, 417, - /* 2920 */ 524, 524, 524, 459, 524, 524, 462, 524, 524, 524, - /* 2930 */ 466, 467, 468, 469, 470, 471, 403, 473, 524, 524, - /* 2940 */ 524, 524, 524, 524, 524, 524, 524, 524, 415, 524, - /* 2950 */ 417, 524, 524, 524, 524, 524, 524, 524, 524, 524, - /* 2960 */ 524, 459, 524, 524, 462, 524, 524, 524, 466, 467, - /* 2970 */ 468, 469, 470, 471, 524, 473, 524, 524, 524, 524, - /* 2980 */ 524, 524, 524, 524, 524, 524, 524, 524, 524, 524, - /* 2990 */ 524, 524, 459, 524, 524, 462, 524, 524, 524, 466, - /* 3000 */ 467, 468, 469, 470, 471, 524, 473, 524, 524, 524, - /* 3010 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3020 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3030 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3040 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3050 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3060 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3070 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3080 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3090 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3100 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3110 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3120 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3130 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3140 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3150 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3160 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3170 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3180 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3190 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3200 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3210 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 1530 */ 264, 12, 13, 391, 112, 112, 0, 112, 112, 12, + /* 1540 */ 13, 362, 112, 12, 13, 12, 13, 33, 108, 37, + /* 1550 */ 12, 13, 111, 33, 375, 33, 305, 33, 209, 429, + /* 1560 */ 211, 120, 373, 429, 124, 125, 126, 127, 128, 129, + /* 1570 */ 130, 131, 132, 133, 362, 135, 136, 137, 138, 139, + /* 1580 */ 140, 141, 403, 112, 511, 112, 511, 375, 52, 511, + /* 1590 */ 439, 79, 243, 244, 511, 416, 378, 418, 429, 375, + /* 1600 */ 415, 447, 307, 243, 429, 429, 257, 258, 259, 260, + /* 1610 */ 261, 262, 263, 495, 516, 403, 487, 498, 393, 284, + /* 1620 */ 362, 441, 51, 462, 42, 461, 112, 20, 416, 452, + /* 1630 */ 418, 457, 112, 375, 112, 224, 112, 383, 452, 460, + /* 1640 */ 383, 443, 463, 207, 20, 20, 467, 468, 469, 470, + /* 1650 */ 471, 472, 374, 474, 4, 375, 45, 425, 375, 425, + /* 1660 */ 481, 403, 186, 422, 485, 486, 374, 425, 375, 19, + /* 1670 */ 422, 374, 460, 109, 416, 463, 418, 422, 422, 467, + /* 1680 */ 468, 469, 470, 471, 472, 35, 474, 387, 107, 386, + /* 1690 */ 374, 374, 106, 481, 362, 385, 374, 485, 486, 374, + /* 1700 */ 374, 51, 20, 367, 50, 371, 383, 375, 58, 59, + /* 1710 */ 20, 383, 367, 452, 20, 65, 418, 20, 460, 371, + /* 1720 */ 383, 463, 20, 376, 362, 467, 468, 469, 470, 471, + /* 1730 */ 472, 442, 474, 383, 376, 403, 383, 375, 432, 481, + /* 1740 */ 362, 374, 383, 485, 486, 416, 383, 367, 416, 383, + /* 1750 */ 418, 374, 367, 375, 403, 403, 362, 365, 403, 403, + /* 1760 */ 110, 365, 228, 113, 403, 403, 111, 456, 403, 375, + /* 1770 */ 452, 403, 403, 403, 454, 403, 403, 20, 416, 381, + /* 1780 */ 418, 403, 215, 214, 451, 381, 374, 449, 292, 504, + /* 1790 */ 416, 416, 460, 291, 416, 463, 418, 403, 441, 467, + /* 1800 */ 468, 469, 470, 471, 472, 473, 474, 475, 476, 418, + /* 1810 */ 416, 416, 418, 504, 507, 434, 434, 300, 200, 506, + /* 1820 */ 302, 517, 460, 504, 503, 463, 301, 448, 285, 467, + /* 1830 */ 468, 469, 470, 471, 472, 309, 474, 280, 460, 524, + /* 1840 */ 362, 463, 441, 306, 304, 467, 468, 469, 470, 471, + /* 1850 */ 472, 20, 474, 375, 460, 375, 362, 463, 121, 282, + /* 1860 */ 381, 467, 468, 469, 470, 471, 472, 376, 474, 375, + /* 1870 */ 381, 509, 510, 111, 466, 481, 434, 362, 416, 416, + /* 1880 */ 486, 403, 416, 416, 434, 502, 484, 192, 499, 381, + /* 1890 */ 375, 501, 399, 416, 416, 430, 418, 403, 416, 521, + /* 1900 */ 522, 416, 518, 497, 381, 375, 416, 111, 416, 22, + /* 1910 */ 416, 38, 418, 416, 416, 416, 416, 362, 403, 416, + /* 1920 */ 416, 416, 416, 416, 374, 416, 416, 416, 381, 416, + /* 1930 */ 375, 416, 438, 418, 364, 367, 407, 416, 460, 453, + /* 1940 */ 368, 463, 382, 397, 416, 467, 468, 469, 470, 471, + /* 1950 */ 472, 416, 474, 438, 460, 416, 397, 463, 403, 397, + /* 1960 */ 416, 467, 468, 469, 470, 471, 472, 416, 474, 360, + /* 1970 */ 0, 416, 0, 418, 0, 460, 444, 435, 463, 45, + /* 1980 */ 435, 0, 467, 468, 469, 470, 471, 472, 510, 474, + /* 1990 */ 37, 362, 234, 37, 37, 37, 0, 234, 37, 37, + /* 2000 */ 234, 37, 0, 234, 375, 0, 37, 0, 37, 0, + /* 2010 */ 22, 0, 37, 229, 0, 460, 217, 0, 463, 217, + /* 2020 */ 211, 218, 467, 468, 469, 470, 471, 472, 362, 474, + /* 2030 */ 209, 0, 403, 0, 0, 205, 204, 0, 0, 154, + /* 2040 */ 49, 375, 49, 0, 0, 416, 0, 418, 51, 37, + /* 2050 */ 37, 0, 49, 0, 0, 45, 0, 0, 0, 0, + /* 2060 */ 0, 0, 0, 0, 49, 172, 37, 0, 513, 403, + /* 2070 */ 172, 0, 0, 0, 0, 0, 0, 0, 0, 0, + /* 2080 */ 0, 0, 416, 0, 418, 0, 0, 0, 0, 460, + /* 2090 */ 0, 362, 463, 0, 0, 0, 467, 468, 469, 470, + /* 2100 */ 471, 472, 0, 474, 375, 0, 0, 362, 153, 1, + /* 2110 */ 45, 0, 0, 49, 0, 0, 0, 0, 22, 154, + /* 2120 */ 375, 0, 0, 0, 0, 152, 460, 19, 0, 463, + /* 2130 */ 0, 22, 403, 467, 468, 469, 470, 471, 472, 50, + /* 2140 */ 474, 22, 476, 35, 37, 416, 0, 418, 403, 50, + /* 2150 */ 0, 522, 0, 0, 51, 37, 65, 65, 0, 51, + /* 2160 */ 200, 416, 42, 418, 51, 65, 362, 438, 60, 61, + /* 2170 */ 62, 63, 37, 65, 42, 65, 0, 37, 42, 375, + /* 2180 */ 51, 0, 37, 438, 0, 14, 45, 33, 49, 460, + /* 2190 */ 42, 49, 463, 49, 0, 0, 467, 468, 469, 470, + /* 2200 */ 471, 472, 43, 474, 42, 460, 0, 403, 463, 0, + /* 2210 */ 0, 42, 467, 468, 469, 470, 471, 472, 110, 474, + /* 2220 */ 416, 113, 418, 0, 49, 362, 0, 0, 73, 0, + /* 2230 */ 0, 51, 42, 37, 0, 37, 51, 0, 375, 42, + /* 2240 */ 37, 42, 51, 0, 362, 37, 42, 0, 0, 0, + /* 2250 */ 0, 51, 0, 0, 37, 147, 119, 375, 22, 0, + /* 2260 */ 22, 37, 37, 0, 460, 37, 403, 463, 117, 37, + /* 2270 */ 37, 467, 468, 469, 470, 471, 472, 37, 474, 416, + /* 2280 */ 0, 418, 37, 37, 22, 403, 22, 33, 37, 33, + /* 2290 */ 0, 22, 37, 0, 37, 37, 22, 53, 416, 191, + /* 2300 */ 418, 0, 37, 0, 0, 37, 198, 0, 37, 0, + /* 2310 */ 22, 20, 37, 37, 37, 0, 362, 112, 111, 49, + /* 2320 */ 189, 0, 111, 460, 122, 217, 463, 189, 22, 375, + /* 2330 */ 467, 468, 469, 470, 471, 472, 123, 474, 0, 37, + /* 2340 */ 22, 216, 460, 0, 0, 463, 362, 33, 192, 467, + /* 2350 */ 468, 469, 470, 471, 472, 189, 474, 403, 3, 375, + /* 2360 */ 196, 212, 189, 189, 196, 37, 37, 50, 286, 50, + /* 2370 */ 416, 111, 418, 112, 33, 33, 49, 111, 362, 112, + /* 2380 */ 33, 33, 49, 111, 286, 107, 3, 403, 109, 33, + /* 2390 */ 286, 375, 33, 112, 112, 111, 111, 111, 37, 112, + /* 2400 */ 416, 112, 418, 111, 37, 37, 112, 37, 37, 37, + /* 2410 */ 112, 49, 112, 279, 460, 49, 0, 463, 0, 403, + /* 2420 */ 42, 467, 468, 469, 470, 471, 472, 111, 474, 33, + /* 2430 */ 2, 109, 416, 266, 418, 109, 22, 112, 49, 49, + /* 2440 */ 0, 22, 112, 112, 460, 111, 111, 463, 111, 42, + /* 2450 */ 111, 467, 468, 469, 470, 471, 472, 243, 474, 362, + /* 2460 */ 111, 111, 111, 37, 112, 246, 112, 121, 111, 49, + /* 2470 */ 112, 111, 375, 120, 111, 111, 460, 112, 37, 463, + /* 2480 */ 111, 37, 37, 467, 468, 469, 470, 471, 472, 362, + /* 2490 */ 474, 111, 111, 111, 37, 111, 37, 112, 193, 191, + /* 2500 */ 403, 37, 375, 111, 111, 362, 112, 112, 134, 112, + /* 2510 */ 112, 112, 111, 416, 33, 418, 111, 37, 375, 111, + /* 2520 */ 134, 134, 362, 123, 122, 134, 22, 73, 72, 37, + /* 2530 */ 403, 37, 37, 37, 37, 375, 37, 37, 37, 37, + /* 2540 */ 37, 79, 37, 416, 105, 418, 403, 79, 105, 33, + /* 2550 */ 37, 37, 37, 22, 37, 37, 37, 460, 79, 416, + /* 2560 */ 463, 418, 37, 403, 467, 468, 469, 470, 471, 472, + /* 2570 */ 37, 474, 37, 37, 37, 22, 416, 37, 418, 0, + /* 2580 */ 37, 51, 0, 42, 37, 51, 42, 460, 37, 51, + /* 2590 */ 463, 0, 42, 0, 467, 468, 469, 470, 471, 472, + /* 2600 */ 37, 474, 42, 460, 37, 51, 463, 0, 37, 0, + /* 2610 */ 467, 468, 469, 470, 471, 472, 22, 474, 33, 22, + /* 2620 */ 460, 21, 21, 463, 22, 22, 20, 467, 468, 469, + /* 2630 */ 470, 471, 472, 525, 474, 362, 525, 525, 525, 525, + /* 2640 */ 525, 525, 525, 525, 525, 525, 525, 525, 375, 525, + /* 2650 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2660 */ 525, 362, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2670 */ 525, 525, 525, 525, 375, 525, 403, 525, 525, 525, + /* 2680 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 416, + /* 2690 */ 525, 418, 525, 525, 362, 525, 525, 525, 525, 525, + /* 2700 */ 525, 525, 403, 525, 525, 525, 525, 375, 525, 525, + /* 2710 */ 525, 525, 525, 525, 525, 416, 525, 418, 525, 525, + /* 2720 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2730 */ 525, 525, 525, 460, 525, 403, 463, 525, 525, 525, + /* 2740 */ 467, 468, 469, 470, 471, 472, 525, 474, 416, 525, + /* 2750 */ 418, 525, 525, 525, 525, 525, 525, 525, 525, 460, + /* 2760 */ 525, 525, 463, 525, 525, 525, 467, 468, 469, 470, + /* 2770 */ 471, 472, 525, 474, 525, 525, 525, 362, 525, 525, + /* 2780 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2790 */ 375, 525, 460, 525, 525, 463, 525, 362, 525, 467, + /* 2800 */ 468, 469, 470, 471, 472, 525, 474, 525, 525, 525, + /* 2810 */ 375, 525, 525, 525, 362, 525, 525, 525, 403, 525, + /* 2820 */ 525, 525, 525, 525, 525, 525, 525, 375, 525, 525, + /* 2830 */ 525, 416, 525, 418, 525, 525, 525, 525, 403, 525, + /* 2840 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2850 */ 525, 416, 525, 418, 525, 403, 525, 525, 525, 525, + /* 2860 */ 525, 525, 525, 525, 525, 525, 525, 525, 416, 525, + /* 2870 */ 418, 525, 525, 525, 525, 460, 525, 525, 463, 525, + /* 2880 */ 525, 525, 467, 468, 469, 470, 471, 472, 525, 474, + /* 2890 */ 525, 525, 525, 525, 525, 460, 525, 525, 463, 525, + /* 2900 */ 525, 525, 467, 468, 469, 470, 471, 472, 525, 474, + /* 2910 */ 525, 525, 460, 525, 525, 463, 525, 525, 525, 467, + /* 2920 */ 468, 469, 470, 471, 472, 525, 474, 362, 525, 525, + /* 2930 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2940 */ 375, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2950 */ 362, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 2960 */ 525, 525, 525, 375, 525, 525, 362, 525, 403, 525, + /* 2970 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 375, + /* 2980 */ 525, 416, 525, 418, 525, 525, 362, 525, 525, 525, + /* 2990 */ 525, 403, 525, 525, 525, 525, 525, 525, 525, 375, + /* 3000 */ 525, 525, 525, 525, 416, 525, 418, 403, 525, 525, + /* 3010 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 3020 */ 416, 525, 418, 525, 525, 460, 525, 403, 463, 525, + /* 3030 */ 525, 525, 467, 468, 469, 470, 471, 472, 525, 474, + /* 3040 */ 416, 525, 418, 525, 525, 525, 525, 525, 460, 525, + /* 3050 */ 525, 463, 525, 525, 525, 467, 468, 469, 470, 471, + /* 3060 */ 472, 525, 474, 525, 460, 525, 525, 463, 525, 525, + /* 3070 */ 362, 467, 468, 469, 470, 471, 472, 525, 474, 525, + /* 3080 */ 525, 525, 525, 375, 460, 525, 525, 463, 525, 525, + /* 3090 */ 525, 467, 468, 469, 470, 471, 472, 525, 474, 362, + /* 3100 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 3110 */ 525, 403, 375, 525, 525, 525, 525, 525, 525, 525, + /* 3120 */ 525, 525, 525, 525, 416, 525, 418, 525, 525, 525, + /* 3130 */ 525, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 3140 */ 403, 525, 525, 525, 525, 525, 525, 525, 525, 525, + /* 3150 */ 525, 525, 525, 416, 525, 418, 525, 525, 525, 525, + /* 3160 */ 525, 525, 525, 525, 525, 525, 525, 525, 460, 525, + /* 3170 */ 525, 463, 525, 525, 525, 467, 468, 469, 470, 471, + /* 3180 */ 472, 525, 474, 525, 525, 525, 525, 525, 525, 525, + /* 3190 */ 525, 525, 525, 525, 525, 525, 525, 460, 525, 525, + /* 3200 */ 463, 525, 525, 525, 467, 468, 469, 470, 471, 472, + /* 3210 */ 525, 474, 359, 359, 359, 359, 359, 359, 359, 359, /* 3220 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, /* 3230 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, /* 3240 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, @@ -1221,238 +1242,259 @@ static const YYCODETYPE yy_lookahead[] = { /* 3330 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, /* 3340 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, /* 3350 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, - /* 3360 */ 359, 359, 359, 359, 359, 359, + /* 3360 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3370 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3380 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3390 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3400 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3410 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3420 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3430 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3440 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3450 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3460 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3470 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3480 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3490 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3500 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3510 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3520 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3530 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3540 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3550 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3560 */ 359, 359, 359, 359, 359, 359, 359, 359, 359, 359, + /* 3570 */ 359, }; -#define YY_SHIFT_COUNT (902) +#define YY_SHIFT_COUNT (907) #define YY_SHIFT_MIN (0) -#define YY_SHIFT_MAX (2630) +#define YY_SHIFT_MAX (2609) static const unsigned short int yy_shift_ofst[] = { /* 0 */ 508, 0, 253, 0, 507, 507, 507, 507, 507, 507, /* 10 */ 507, 507, 507, 507, 507, 507, 760, 1013, 1013, 1266, /* 20 */ 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, /* 30 */ 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, /* 40 */ 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, 1013, - /* 50 */ 317, 550, 283, 178, 452, 631, 452, 452, 178, 178, - /* 60 */ 452, 575, 452, 252, 575, 63, 452, 43, 1554, 659, - /* 70 */ 97, 97, 1554, 1554, 520, 520, 659, 525, 170, 723, - /* 80 */ 723, 301, 97, 97, 97, 97, 97, 97, 97, 97, - /* 90 */ 97, 97, 97, 169, 364, 97, 97, 363, 43, 97, - /* 100 */ 169, 97, 43, 97, 97, 43, 97, 97, 43, 97, - /* 110 */ 43, 43, 43, 97, 383, 212, 212, 1622, 210, 570, - /* 120 */ 570, 570, 570, 570, 570, 570, 570, 570, 570, 570, - /* 130 */ 570, 570, 570, 570, 570, 570, 570, 570, 438, 628, - /* 140 */ 525, 170, 945, 945, 670, 343, 343, 343, 153, 153, - /* 150 */ 823, 384, 670, 363, 43, 461, 43, 349, 43, 43, - /* 160 */ 596, 43, 596, 596, 583, 826, 250, 853, 853, 853, - /* 170 */ 853, 853, 853, 853, 1398, 2112, 66, 437, 15, 427, - /* 180 */ 600, 807, 633, 849, 963, 963, 280, 905, 886, 264, - /* 190 */ 264, 264, 992, 81, 264, 157, 1042, 1033, 573, 1012, - /* 200 */ 1042, 1042, 1048, 947, 1164, 547, 947, 1071, 495, 384, - /* 210 */ 1298, 1534, 1546, 1573, 1374, 363, 1573, 363, 1402, 1592, - /* 220 */ 1596, 1575, 1596, 1575, 1440, 1592, 1596, 1592, 1575, 1440, - /* 230 */ 1440, 1440, 1541, 1545, 1592, 1592, 1552, 1592, 1592, 1592, - /* 240 */ 1642, 1615, 1642, 1615, 1573, 363, 363, 1660, 363, 1664, - /* 250 */ 1670, 363, 1664, 363, 1680, 363, 363, 1592, 363, 1642, - /* 260 */ 43, 43, 43, 43, 43, 43, 43, 43, 43, 43, - /* 270 */ 43, 1592, 826, 826, 1642, 596, 596, 596, 1483, 1643, - /* 280 */ 1573, 383, 1735, 1544, 1548, 1660, 383, 1298, 1592, 596, - /* 290 */ 1477, 1481, 1477, 1481, 1473, 1577, 1477, 1480, 1489, 1506, - /* 300 */ 1298, 1485, 1492, 1496, 1522, 1596, 1784, 1686, 1526, 1664, - /* 310 */ 383, 383, 1699, 1481, 596, 596, 596, 596, 1481, 596, - /* 320 */ 1637, 383, 583, 383, 1596, 596, 596, 596, 596, 596, - /* 330 */ 596, 596, 596, 596, 596, 596, 596, 596, 596, 596, - /* 340 */ 596, 596, 596, 596, 596, 596, 596, 1753, 596, 1592, - /* 350 */ 383, 1855, 1851, 1642, 3007, 3007, 3007, 3007, 3007, 3007, - /* 360 */ 3007, 3007, 3007, 38, 2132, 267, 164, 36, 326, 684, - /* 370 */ 300, 790, 887, 392, 458, 833, 833, 833, 833, 833, - /* 380 */ 833, 833, 833, 833, 223, 403, 650, 27, 27, 1, - /* 390 */ 757, 393, 126, 872, 106, 232, 328, 855, 1101, 651, - /* 400 */ 942, 594, 877, 942, 942, 942, 529, 529, 1259, 1127, - /* 410 */ 134, 801, 1267, 1159, 1291, 1185, 1190, 1191, 1192, 1261, - /* 420 */ 1279, 1300, 1217, 1311, 1361, 1373, 416, 1202, 1213, 1250, - /* 430 */ 1288, 1290, 1293, 1294, 1170, 1251, 1077, 1295, 1342, 1296, - /* 440 */ 1337, 1322, 96, 1324, 1346, 1358, 1396, 1423, 1354, 1356, - /* 450 */ 1363, 1399, 1406, 1418, 1453, 1455, 1474, 1476, 1491, 1424, - /* 460 */ 1429, 1445, 1449, 1451, 1461, 1260, 1364, 1376, 1383, 1414, - /* 470 */ 1525, 1495, 687, 1942, 1943, 1944, 1900, 1946, 1910, 1714, - /* 480 */ 1912, 1913, 1914, 1719, 1954, 1918, 1919, 1723, 1921, 1960, - /* 490 */ 1727, 1963, 1927, 1972, 1937, 1975, 1955, 1976, 1947, 1750, - /* 500 */ 1980, 1766, 1991, 1777, 1778, 1786, 1789, 1999, 2000, 2001, - /* 510 */ 1797, 1799, 2004, 2006, 1854, 1961, 1962, 2009, 1977, 2015, - /* 520 */ 2016, 1981, 1966, 2019, 1964, 2020, 1979, 2021, 2022, 2026, - /* 530 */ 1978, 2028, 2029, 2032, 2033, 2034, 2036, 1866, 2002, 2040, - /* 540 */ 1869, 2042, 2044, 2045, 2046, 2047, 2048, 2050, 2054, 2055, - /* 550 */ 2062, 2066, 2068, 2069, 2070, 2072, 2073, 2074, 2075, 2076, - /* 560 */ 2031, 2077, 2039, 2078, 2081, 2094, 2096, 2097, 2098, 2099, - /* 570 */ 2100, 2079, 2102, 1949, 2107, 1957, 2108, 1970, 2124, 2125, - /* 580 */ 2092, 2065, 2106, 2082, 2129, 2080, 2133, 2085, 2103, 2142, - /* 590 */ 2087, 2143, 2088, 2144, 2146, 2117, 2110, 2122, 2149, 2128, - /* 600 */ 2118, 2126, 2170, 2134, 2127, 2138, 2176, 2145, 2181, 2139, - /* 610 */ 2147, 2152, 2137, 2141, 2173, 2150, 2188, 2148, 2154, 2198, - /* 620 */ 2201, 2202, 2203, 2162, 2005, 2206, 2137, 2159, 2209, 2210, - /* 630 */ 2151, 2211, 2212, 2177, 2164, 2175, 2216, 2183, 2167, 2184, - /* 640 */ 2223, 2190, 2178, 2186, 2230, 2195, 2180, 2191, 2234, 2235, - /* 650 */ 2236, 2237, 2238, 2240, 2130, 2131, 2207, 2221, 2246, 2213, - /* 660 */ 2214, 2217, 2219, 2220, 2224, 2225, 2227, 2228, 2243, 2245, - /* 670 */ 2231, 2232, 2257, 2244, 2247, 2260, 2258, 2262, 2267, 2264, - /* 680 */ 2242, 2283, 2265, 2251, 2289, 2290, 2291, 2259, 2299, 2275, - /* 690 */ 2301, 2271, 2282, 2276, 2279, 2280, 2208, 2222, 2318, 2071, - /* 700 */ 2197, 2199, 2226, 2105, 2137, 2278, 2325, 2153, 2295, 2312, - /* 710 */ 2335, 2140, 2319, 2165, 2161, 2351, 2355, 2168, 2163, 2171, - /* 720 */ 2166, 2358, 2330, 2083, 2253, 2254, 2261, 2255, 2328, 2336, - /* 730 */ 2263, 2326, 2268, 2329, 2274, 2266, 2347, 2350, 2272, 2284, - /* 740 */ 2286, 2287, 2288, 2353, 2338, 2352, 2292, 2369, 2119, 2294, - /* 750 */ 2296, 2401, 2374, 2123, 2373, 2377, 2380, 2381, 2388, 2390, - /* 760 */ 2317, 2320, 2382, 2155, 2400, 2386, 2436, 2437, 2327, 2397, - /* 770 */ 2407, 2332, 2179, 2333, 2441, 2422, 2204, 2337, 2339, 2340, - /* 780 */ 2399, 2342, 2343, 2402, 2344, 2435, 2215, 2349, 2356, 2359, - /* 790 */ 2362, 2363, 2277, 2366, 2478, 2443, 2297, 2379, 2371, 2137, - /* 800 */ 2444, 2383, 2384, 2385, 2387, 2389, 2375, 2391, 2455, 2465, - /* 810 */ 2393, 2394, 2468, 2396, 2398, 2471, 2403, 2404, 2472, 2409, - /* 820 */ 2406, 2474, 2410, 2411, 2475, 2413, 2405, 2408, 2414, 2424, - /* 830 */ 2412, 2415, 2416, 2480, 2417, 2485, 2419, 2480, 2480, 2493, - /* 840 */ 2452, 2454, 2496, 2497, 2501, 2503, 2504, 2507, 2508, 2510, - /* 850 */ 2522, 2524, 2525, 2484, 2459, 2486, 2461, 2534, 2531, 2538, - /* 860 */ 2541, 2548, 2542, 2549, 2551, 2492, 2243, 2553, 2245, 2555, - /* 870 */ 2556, 2557, 2558, 2574, 2561, 2599, 2563, 2550, 2560, 2603, - /* 880 */ 2567, 2554, 2564, 2607, 2571, 2559, 2570, 2613, 2577, 2566, - /* 890 */ 2573, 2620, 2584, 2585, 2629, 2610, 2601, 2615, 2617, 2624, - /* 900 */ 2627, 2618, 2630, + /* 50 */ 380, 432, 255, 530, 34, 445, 34, 34, 530, 530, + /* 60 */ 34, 1349, 34, 252, 1349, 290, 34, 169, 1182, 343, + /* 70 */ 199, 199, 1182, 1182, 517, 517, 343, 630, 431, 583, + /* 80 */ 583, 159, 199, 199, 199, 199, 199, 199, 199, 199, + /* 90 */ 199, 199, 199, 303, 337, 199, 199, 6, 169, 199, + /* 100 */ 303, 199, 169, 199, 199, 169, 199, 199, 169, 199, + /* 110 */ 169, 169, 169, 199, 313, 212, 212, 1354, 830, 210, + /* 120 */ 1259, 1259, 1259, 1259, 1259, 1259, 1259, 1259, 1259, 1259, + /* 130 */ 1259, 1259, 1259, 1259, 1259, 1259, 1259, 1259, 1259, 328, + /* 140 */ 455, 630, 431, 686, 686, 381, 653, 653, 653, 318, + /* 150 */ 318, 1105, 962, 381, 6, 169, 286, 169, 265, 169, + /* 160 */ 169, 670, 169, 670, 670, 716, 810, 250, 1440, 1440, + /* 170 */ 1440, 1440, 1440, 1440, 717, 2108, 23, 441, 191, 296, + /* 180 */ 235, 605, 425, 939, 357, 357, 840, 631, 895, 881, + /* 190 */ 881, 881, 117, 970, 881, 1148, 1149, 1296, 132, 595, + /* 200 */ 1149, 1149, 1222, 974, 1032, 990, 974, 1281, 1057, 962, + /* 210 */ 1335, 1571, 1582, 1607, 1411, 6, 1607, 6, 1436, 1624, + /* 220 */ 1625, 1611, 1625, 1611, 1476, 1624, 1625, 1624, 1611, 1476, + /* 230 */ 1476, 1476, 1564, 1581, 1624, 1624, 1586, 1624, 1624, 1624, + /* 240 */ 1682, 1654, 1682, 1654, 1607, 6, 6, 1690, 6, 1694, + /* 250 */ 1697, 6, 1694, 6, 1702, 6, 6, 1624, 6, 1682, + /* 260 */ 169, 169, 169, 169, 169, 169, 169, 169, 169, 169, + /* 270 */ 169, 1624, 810, 810, 1682, 670, 670, 670, 1534, 1655, + /* 280 */ 1607, 313, 1757, 1567, 1569, 1690, 313, 1335, 1624, 670, + /* 290 */ 1496, 1502, 1496, 1502, 1517, 1618, 1496, 1518, 1525, 1543, + /* 300 */ 1335, 1526, 1537, 1540, 1557, 1625, 1831, 1737, 1577, 1694, + /* 310 */ 313, 313, 1762, 1502, 670, 670, 670, 670, 1502, 670, + /* 320 */ 1695, 313, 716, 313, 1625, 670, 670, 670, 670, 670, + /* 330 */ 670, 670, 670, 670, 670, 670, 670, 670, 670, 670, + /* 340 */ 670, 670, 670, 670, 670, 670, 670, 1796, 670, 1624, + /* 350 */ 313, 1887, 1873, 1682, 3212, 3212, 3212, 3212, 3212, 3212, + /* 360 */ 3212, 3212, 3212, 38, 1126, 66, 1650, 283, 326, 592, + /* 370 */ 608, 675, 929, 70, 587, 684, 684, 684, 684, 684, + /* 380 */ 684, 684, 684, 684, 577, 813, 42, 820, 820, 329, + /* 390 */ 486, 935, 216, 97, 106, 565, 1064, 161, 930, 854, + /* 400 */ 418, 476, 973, 418, 418, 418, 910, 910, 1327, 1131, + /* 410 */ 461, 1341, 1331, 1017, 1342, 1215, 1265, 1271, 1273, 1343, + /* 420 */ 852, 1344, 966, 1346, 1405, 1407, 1171, 1339, 1340, 1324, + /* 430 */ 1364, 1376, 1386, 1387, 1187, 1251, 1295, 1388, 1429, 1393, + /* 440 */ 1360, 1400, 604, 1422, 1423, 1425, 1426, 1430, 1434, 1452, + /* 450 */ 1459, 1461, 1484, 1495, 1519, 1527, 1531, 1533, 1538, 1471, + /* 460 */ 1473, 1514, 1520, 1522, 1524, 1441, 1371, 21, 209, 1397, + /* 470 */ 1399, 1512, 1536, 1970, 1972, 1974, 1934, 1981, 1953, 1758, + /* 480 */ 1956, 1957, 1958, 1763, 1996, 1961, 1962, 1766, 1964, 2002, + /* 490 */ 1769, 2005, 1969, 2007, 1971, 2009, 1988, 2011, 1975, 1784, + /* 500 */ 2014, 1799, 2017, 1802, 1803, 1809, 1821, 2031, 2033, 2034, + /* 510 */ 1830, 1832, 2037, 2038, 1885, 1991, 1993, 2043, 2012, 2044, + /* 520 */ 2046, 2013, 1997, 2051, 2003, 2053, 2010, 2054, 2056, 2057, + /* 530 */ 2015, 2058, 2059, 2060, 2061, 2062, 2063, 1893, 2029, 2067, + /* 540 */ 1898, 2071, 2072, 2073, 2074, 2075, 2076, 2077, 2078, 2079, + /* 550 */ 2080, 2081, 2083, 2085, 2086, 2087, 2088, 2090, 2093, 2094, + /* 560 */ 2064, 2095, 2065, 2102, 2105, 2106, 2111, 2112, 2114, 2115, + /* 570 */ 2116, 2096, 2117, 1965, 2121, 1955, 2122, 1973, 2123, 2124, + /* 580 */ 2109, 2089, 2119, 2099, 2128, 2091, 2130, 2092, 2107, 2146, + /* 590 */ 2100, 2150, 2110, 2152, 2153, 2118, 2103, 2120, 2158, 2135, + /* 600 */ 2113, 2132, 2176, 2140, 2129, 2136, 2181, 2145, 2184, 2141, + /* 610 */ 2148, 2154, 2139, 2142, 2171, 2144, 2194, 2159, 2162, 2195, + /* 620 */ 2206, 2209, 2210, 2169, 1960, 2223, 2139, 2175, 2226, 2227, + /* 630 */ 2155, 2229, 2230, 2196, 2180, 2190, 2234, 2198, 2185, 2197, + /* 640 */ 2237, 2203, 2191, 2199, 2243, 2208, 2200, 2204, 2247, 2248, + /* 650 */ 2249, 2250, 2252, 2253, 2137, 2151, 2217, 2236, 2259, 2224, + /* 660 */ 2225, 2228, 2232, 2233, 2240, 2245, 2246, 2251, 2254, 2256, + /* 670 */ 2255, 2257, 2238, 2258, 2263, 2262, 2280, 2264, 2290, 2269, + /* 680 */ 2244, 2293, 2274, 2265, 2301, 2303, 2304, 2268, 2307, 2271, + /* 690 */ 2309, 2288, 2291, 2275, 2276, 2277, 2205, 2207, 2315, 2131, + /* 700 */ 2202, 2213, 2211, 2125, 2139, 2270, 2321, 2138, 2302, 2306, + /* 710 */ 2338, 2149, 2318, 2166, 2156, 2343, 2344, 2173, 2164, 2174, + /* 720 */ 2168, 2355, 2314, 2082, 2260, 2261, 2266, 2267, 2328, 2329, + /* 730 */ 2272, 2317, 2279, 2319, 2278, 2281, 2341, 2342, 2282, 2284, + /* 740 */ 2285, 2286, 2287, 2347, 2327, 2333, 2292, 2348, 2098, 2289, + /* 750 */ 2294, 2383, 2356, 2104, 2361, 2367, 2368, 2370, 2371, 2372, + /* 760 */ 2298, 2300, 2362, 2134, 2359, 2366, 2416, 2418, 2316, 2378, + /* 770 */ 2396, 2322, 2167, 2326, 2428, 2414, 2214, 2325, 2330, 2334, + /* 780 */ 2335, 2337, 2339, 2349, 2331, 2389, 2350, 2351, 2390, 2352, + /* 790 */ 2419, 2219, 2357, 2354, 2358, 2360, 2363, 2305, 2364, 2440, + /* 800 */ 2407, 2308, 2369, 2353, 2139, 2420, 2380, 2381, 2365, 2382, + /* 810 */ 2384, 2346, 2385, 2426, 2441, 2392, 2394, 2444, 2393, 2395, + /* 820 */ 2445, 2334, 2397, 2457, 2335, 2398, 2459, 2337, 2399, 2464, + /* 830 */ 2339, 2374, 2386, 2387, 2391, 2400, 2402, 2401, 2481, 2405, + /* 840 */ 2480, 2408, 2481, 2481, 2504, 2454, 2456, 2492, 2494, 2495, + /* 850 */ 2496, 2497, 2499, 2500, 2501, 2502, 2503, 2505, 2462, 2439, + /* 860 */ 2468, 2443, 2516, 2513, 2514, 2515, 2531, 2517, 2518, 2519, + /* 870 */ 2479, 2254, 2525, 2256, 2533, 2535, 2536, 2537, 2553, 2540, + /* 880 */ 2579, 2543, 2530, 2541, 2582, 2547, 2534, 2544, 2591, 2551, + /* 890 */ 2538, 2550, 2593, 2563, 2554, 2560, 2607, 2567, 2571, 2609, + /* 900 */ 2594, 2585, 2597, 2600, 2602, 2603, 2601, 2606, }; #define YY_REDUCE_COUNT (362) -#define YY_REDUCE_MIN (-448) -#define YY_REDUCE_MAX (2533) +#define YY_REDUCE_MIN (-487) +#define YY_REDUCE_MAX (2737) static const short yy_reduce_ofst[] = { - /* 0 */ -168, -315, 166, 196, 413, 449, 666, 702, 919, 955, - /* 10 */ 1080, 1137, 1169, 880, 979, 1208, 1268, 781, 1371, 1386, - /* 20 */ 1417, 1443, 1500, 1519, 1590, 1620, 1668, 1689, 1650, 1804, - /* 30 */ 1838, 1877, 1923, 1953, 1996, 2013, 2084, 2114, 2157, 2174, - /* 40 */ 2194, 2256, 2273, 2293, 2316, 2376, 2392, 2464, 2502, 2533, - /* 50 */ -317, -333, -159, -22, 412, 446, 593, 634, 101, 242, - /* 60 */ 595, -389, -409, -358, 314, 448, 454, 227, -1, -417, - /* 70 */ -369, -45, -384, 348, -365, -266, -381, -221, -256, -294, - /* 80 */ -157, -322, 25, 85, 482, 576, -364, 21, 655, 663, - /* 90 */ 665, 671, 185, -17, 568, 677, 680, 308, -2, 686, - /* 100 */ 409, 692, -210, 721, 724, -394, 726, 728, -200, 766, - /* 110 */ 257, 397, 510, 783, 691, -448, -448, 138, -197, -359, - /* 120 */ -316, -132, 77, 450, 499, 582, 612, 669, 768, 780, - /* 130 */ 787, 797, 803, 804, 805, 814, 816, 817, 119, -187, - /* 140 */ 182, 579, 811, 813, 815, -187, 591, 732, 78, 614, - /* 150 */ 824, 230, 822, 661, 333, 386, 796, 709, 810, 534, - /* 160 */ 821, 835, 829, 870, 838, 850, 451, 602, 654, 750, - /* 170 */ 841, 914, 934, 451, 532, 542, 858, 924, 834, 848, - /* 180 */ 889, 1032, 1029, 1029, 1046, 1078, 1043, 1103, 1070, 995, - /* 190 */ 996, 997, 1095, 1029, 1024, 1165, 1109, 1180, 1131, 1113, - /* 200 */ 1140, 1141, 1029, 1081, 1081, 1056, 1081, 1091, 1082, 1188, - /* 210 */ 1138, 1129, 1132, 1144, 1145, 1214, 1149, 1219, 1171, 1240, - /* 220 */ 1243, 1200, 1252, 1205, 1211, 1270, 1258, 1271, 1210, 1220, - /* 230 */ 1225, 1227, 1264, 1269, 1282, 1283, 1274, 1286, 1287, 1289, - /* 240 */ 1297, 1301, 1299, 1302, 1218, 1285, 1303, 1265, 1304, 1313, - /* 250 */ 1253, 1308, 1319, 1316, 1275, 1318, 1325, 1328, 1327, 1340, - /* 260 */ 1309, 1310, 1315, 1320, 1326, 1329, 1341, 1344, 1347, 1348, - /* 270 */ 1349, 1345, 1357, 1366, 1378, 1306, 1334, 1338, 1273, 1305, - /* 280 */ 1317, 1375, 1307, 1312, 1323, 1350, 1385, 1331, 1390, 1360, - /* 290 */ 1277, 1343, 1278, 1351, 1272, 1280, 1284, 1281, 1292, 1321, - /* 300 */ 1359, 1355, 1314, 1333, 1081, 1431, 1362, 1330, 1339, 1433, - /* 310 */ 1438, 1441, 1353, 1391, 1408, 1410, 1411, 1428, 1430, 1432, - /* 320 */ 1421, 1470, 1462, 1484, 1493, 1452, 1454, 1457, 1458, 1459, - /* 330 */ 1467, 1478, 1482, 1486, 1503, 1504, 1505, 1508, 1509, 1510, - /* 340 */ 1512, 1513, 1514, 1515, 1516, 1517, 1518, 1463, 1520, 1521, - /* 350 */ 1523, 1532, 1530, 1533, 1456, 1469, 1472, 1507, 1511, 1542, - /* 360 */ 1543, 1556, 1547, + /* 0 */ -169, -316, 166, 195, 413, 513, 665, 711, 742, 932, + /* 10 */ 378, 627, 884, 1179, 1212, 1258, 1332, 1362, 1378, 1394, + /* 20 */ 1478, 1494, 1515, 1555, 1629, 1666, 1729, 1745, 1804, 1863, + /* 30 */ 1882, 1954, 1984, 2016, 2097, 2127, 2143, 2160, 2273, 2299, + /* 40 */ 2332, 2415, 2435, 2452, 2565, 2588, 2604, 2624, 2708, 2737, + /* 50 */ -318, -334, -160, -22, -410, -207, 39, 347, 333, 576, + /* 60 */ 481, -390, -487, -359, -375, 376, 443, -229, -403, -397, + /* 70 */ -73, -45, -137, 71, -369, -362, -394, -235, -311, -345, + /* 80 */ -93, -10, 172, 409, 411, 480, -357, 404, 503, 526, + /* 90 */ 533, 677, 427, -228, 240, 681, 685, 470, 588, 688, + /* 100 */ -107, 736, -110, 748, 773, 561, 779, 781, 229, 824, + /* 110 */ 575, 483, 633, 851, 651, -163, -163, 668, 757, -153, + /* 120 */ 57, 193, 266, 269, 552, 727, 790, 804, 867, 873, + /* 130 */ 875, 876, 882, 888, 918, 923, 933, 943, 944, -238, + /* 140 */ -458, 309, 288, 434, 785, 844, -458, -447, 183, 613, + /* 150 */ 622, 559, 346, 860, 447, 713, 835, -302, 469, 894, + /* 160 */ 908, 827, 896, 839, 907, 934, 956, 454, 515, 522, + /* 170 */ 602, 705, 878, 454, 538, 674, 616, 1006, 915, 936, + /* 180 */ 961, 1071, 1066, 1066, 1110, 1142, 1130, 1189, 1134, 1073, + /* 190 */ 1075, 1078, 1151, 1066, 1083, 1218, 1169, 1224, 1185, 1154, + /* 200 */ 1175, 1176, 1066, 1118, 1118, 1098, 1118, 1129, 1119, 1225, + /* 210 */ 1180, 1161, 1164, 1177, 1174, 1254, 1186, 1257, 1198, 1278, + /* 220 */ 1280, 1232, 1283, 1234, 1241, 1292, 1293, 1297, 1242, 1248, + /* 230 */ 1255, 1256, 1300, 1303, 1316, 1317, 1310, 1322, 1325, 1326, + /* 240 */ 1336, 1334, 1345, 1348, 1261, 1323, 1328, 1298, 1337, 1347, + /* 250 */ 1289, 1350, 1358, 1353, 1306, 1359, 1363, 1367, 1366, 1380, + /* 260 */ 1351, 1352, 1355, 1356, 1361, 1365, 1368, 1369, 1370, 1372, + /* 270 */ 1373, 1377, 1392, 1396, 1385, 1329, 1374, 1375, 1311, 1320, + /* 280 */ 1318, 1398, 1333, 1338, 1379, 1391, 1404, 1357, 1412, 1395, + /* 290 */ 1285, 1381, 1309, 1382, 1307, 1313, 1319, 1321, 1383, 1390, + /* 300 */ 1401, 1315, 1384, 1304, 1118, 1480, 1408, 1389, 1406, 1491, + /* 310 */ 1479, 1489, 1402, 1442, 1462, 1463, 1466, 1467, 1450, 1477, + /* 320 */ 1465, 1508, 1493, 1523, 1530, 1482, 1485, 1490, 1492, 1497, + /* 330 */ 1498, 1499, 1500, 1503, 1504, 1505, 1506, 1507, 1509, 1510, + /* 340 */ 1511, 1513, 1521, 1528, 1535, 1539, 1544, 1529, 1551, 1550, + /* 350 */ 1547, 1570, 1572, 1568, 1532, 1486, 1542, 1545, 1546, 1559, + /* 360 */ 1562, 1560, 1609, }; static const YYACTIONTYPE yy_default[] = { - /* 0 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 10 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 20 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 30 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 40 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 50 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 60 */ 2399, 2049, 2049, 2362, 2049, 2049, 2049, 2049, 2049, 2049, - /* 70 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2369, 2049, 2049, - /* 80 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 90 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2149, 2049, 2049, - /* 100 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 110 */ 2049, 2049, 2049, 2049, 2147, 2647, 2049, 2049, 2049, 2049, - /* 120 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 130 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2659, - /* 140 */ 2049, 2049, 2120, 2120, 2049, 2659, 2659, 2659, 2619, 2619, - /* 150 */ 2147, 2049, 2049, 2149, 2049, 2441, 2049, 2049, 2049, 2049, - /* 160 */ 2049, 2049, 2049, 2049, 2280, 2079, 2439, 2049, 2049, 2049, - /* 170 */ 2049, 2049, 2049, 2049, 2049, 2425, 2049, 2688, 2750, 2049, - /* 180 */ 2691, 2049, 2049, 2049, 2049, 2049, 2374, 2049, 2678, 2049, - /* 190 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2232, 2419, - /* 200 */ 2049, 2049, 2049, 2651, 2665, 2734, 2652, 2649, 2672, 2049, - /* 210 */ 2682, 2049, 2466, 2049, 2455, 2149, 2049, 2149, 2412, 2357, - /* 220 */ 2049, 2367, 2049, 2367, 2364, 2049, 2049, 2049, 2367, 2364, - /* 230 */ 2364, 2364, 2221, 2217, 2049, 2049, 2215, 2049, 2049, 2049, - /* 240 */ 2049, 2104, 2049, 2104, 2049, 2149, 2149, 2049, 2149, 2049, - /* 250 */ 2049, 2149, 2049, 2149, 2049, 2149, 2149, 2049, 2149, 2049, - /* 260 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 270 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2453, 2435, - /* 280 */ 2049, 2147, 2049, 2423, 2421, 2049, 2147, 2682, 2049, 2049, - /* 290 */ 2704, 2699, 2704, 2699, 2718, 2714, 2704, 2723, 2720, 2684, - /* 300 */ 2682, 2753, 2740, 2736, 2665, 2049, 2049, 2670, 2668, 2049, - /* 310 */ 2147, 2147, 2049, 2699, 2049, 2049, 2049, 2049, 2699, 2049, - /* 320 */ 2049, 2147, 2049, 2147, 2049, 2049, 2049, 2049, 2049, 2049, - /* 330 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 340 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2248, 2049, 2049, - /* 350 */ 2147, 2049, 2088, 2049, 2414, 2444, 2395, 2395, 2283, 2283, - /* 360 */ 2283, 2150, 2054, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 370 */ 2049, 2049, 2049, 2049, 2049, 2717, 2716, 2571, 2049, 2623, - /* 380 */ 2622, 2621, 2612, 2570, 2244, 2049, 2049, 2569, 2568, 2049, - /* 390 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 400 */ 2562, 2049, 2049, 2563, 2561, 2560, 2386, 2385, 2049, 2049, - /* 410 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 420 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 430 */ 2049, 2049, 2049, 2049, 2049, 2737, 2741, 2049, 2648, 2049, - /* 440 */ 2049, 2049, 2542, 2049, 2049, 2049, 2049, 2049, 2510, 2505, - /* 450 */ 2496, 2487, 2502, 2493, 2481, 2499, 2490, 2478, 2475, 2049, - /* 460 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 470 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 480 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 490 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 500 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 510 */ 2049, 2049, 2049, 2049, 2363, 2049, 2049, 2049, 2049, 2049, - /* 520 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 530 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 540 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 550 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 560 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 570 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2378, 2049, 2049, - /* 580 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 590 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 600 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 610 */ 2049, 2093, 2549, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 620 */ 2049, 2049, 2049, 2049, 2049, 2049, 2552, 2049, 2049, 2049, - /* 630 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 640 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 650 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 660 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2193, 2192, - /* 670 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 680 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 690 */ 2049, 2049, 2049, 2049, 2049, 2049, 2553, 2049, 2049, 2049, - /* 700 */ 2439, 2049, 2049, 2049, 2544, 2049, 2049, 2049, 2049, 2049, - /* 710 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 720 */ 2049, 2733, 2685, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 730 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 740 */ 2049, 2049, 2049, 2049, 2049, 2542, 2049, 2715, 2049, 2049, - /* 750 */ 2731, 2049, 2735, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 760 */ 2658, 2654, 2049, 2049, 2650, 2049, 2049, 2049, 2049, 2049, - /* 770 */ 2609, 2049, 2049, 2049, 2643, 2049, 2049, 2049, 2049, 2049, - /* 780 */ 2049, 2049, 2049, 2049, 2553, 2049, 2556, 2049, 2049, 2049, - /* 790 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2541, - /* 800 */ 2049, 2594, 2593, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 810 */ 2277, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 820 */ 2049, 2049, 2049, 2049, 2049, 2049, 2261, 2259, 2258, 2257, - /* 830 */ 2049, 2254, 2049, 2290, 2049, 2049, 2049, 2286, 2285, 2049, - /* 840 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 850 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2168, 2049, 2049, - /* 860 */ 2049, 2049, 2049, 2049, 2049, 2049, 2160, 2049, 2159, 2049, - /* 870 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 880 */ 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, 2049, - /* 890 */ 2049, 2049, 2049, 2049, 2049, 2049, 2078, 2049, 2049, 2049, - /* 900 */ 2049, 2049, 2049, + /* 0 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 10 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 20 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 30 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 40 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 50 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 60 */ 2414, 2060, 2060, 2377, 2060, 2060, 2060, 2060, 2060, 2060, + /* 70 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2384, 2060, 2060, + /* 80 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 90 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2160, 2060, 2060, + /* 100 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 110 */ 2060, 2060, 2060, 2060, 2158, 2663, 2060, 2060, 2060, 2060, + /* 120 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 130 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 140 */ 2675, 2060, 2060, 2131, 2131, 2060, 2675, 2675, 2675, 2635, + /* 150 */ 2635, 2158, 2060, 2060, 2160, 2060, 2456, 2060, 2060, 2060, + /* 160 */ 2060, 2060, 2060, 2060, 2060, 2295, 2090, 2454, 2060, 2060, + /* 170 */ 2060, 2060, 2060, 2060, 2060, 2440, 2060, 2704, 2766, 2060, + /* 180 */ 2707, 2060, 2060, 2060, 2060, 2060, 2389, 2060, 2694, 2060, + /* 190 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2243, 2434, + /* 200 */ 2060, 2060, 2060, 2667, 2681, 2750, 2668, 2665, 2688, 2060, + /* 210 */ 2698, 2060, 2481, 2060, 2470, 2160, 2060, 2160, 2427, 2372, + /* 220 */ 2060, 2382, 2060, 2382, 2379, 2060, 2060, 2060, 2382, 2379, + /* 230 */ 2379, 2379, 2232, 2228, 2060, 2060, 2226, 2060, 2060, 2060, + /* 240 */ 2060, 2115, 2060, 2115, 2060, 2160, 2160, 2060, 2160, 2060, + /* 250 */ 2060, 2160, 2060, 2160, 2060, 2160, 2160, 2060, 2160, 2060, + /* 260 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 270 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2468, 2450, + /* 280 */ 2060, 2158, 2060, 2438, 2436, 2060, 2158, 2698, 2060, 2060, + /* 290 */ 2720, 2715, 2720, 2715, 2734, 2730, 2720, 2739, 2736, 2700, + /* 300 */ 2698, 2769, 2756, 2752, 2681, 2060, 2060, 2686, 2684, 2060, + /* 310 */ 2158, 2158, 2060, 2715, 2060, 2060, 2060, 2060, 2715, 2060, + /* 320 */ 2060, 2158, 2060, 2158, 2060, 2060, 2060, 2060, 2060, 2060, + /* 330 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 340 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2259, 2060, 2060, + /* 350 */ 2158, 2060, 2099, 2060, 2429, 2459, 2410, 2410, 2298, 2298, + /* 360 */ 2298, 2161, 2065, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 370 */ 2060, 2060, 2060, 2060, 2060, 2733, 2732, 2586, 2060, 2639, + /* 380 */ 2638, 2637, 2628, 2585, 2255, 2060, 2060, 2584, 2583, 2060, + /* 390 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 400 */ 2577, 2060, 2060, 2578, 2576, 2575, 2401, 2400, 2060, 2060, + /* 410 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 420 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 430 */ 2060, 2060, 2060, 2060, 2060, 2753, 2757, 2060, 2664, 2060, + /* 440 */ 2060, 2060, 2557, 2060, 2060, 2060, 2060, 2060, 2525, 2520, + /* 450 */ 2511, 2502, 2517, 2508, 2496, 2514, 2505, 2493, 2490, 2060, + /* 460 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 470 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 480 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 490 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 500 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 510 */ 2060, 2060, 2060, 2060, 2378, 2060, 2060, 2060, 2060, 2060, + /* 520 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 530 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 540 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 550 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 560 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 570 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2393, 2060, 2060, + /* 580 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 590 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 600 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 610 */ 2060, 2104, 2564, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 620 */ 2060, 2060, 2060, 2060, 2060, 2060, 2567, 2060, 2060, 2060, + /* 630 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 640 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 650 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 660 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2204, 2203, + /* 670 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 680 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 690 */ 2060, 2060, 2060, 2060, 2060, 2060, 2568, 2060, 2060, 2060, + /* 700 */ 2454, 2060, 2060, 2060, 2559, 2060, 2060, 2060, 2060, 2060, + /* 710 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 720 */ 2060, 2749, 2701, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 730 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 740 */ 2060, 2060, 2060, 2060, 2060, 2557, 2060, 2731, 2060, 2060, + /* 750 */ 2747, 2060, 2751, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 760 */ 2674, 2670, 2060, 2060, 2666, 2060, 2060, 2060, 2060, 2060, + /* 770 */ 2625, 2060, 2060, 2060, 2659, 2060, 2060, 2060, 2060, 2294, + /* 780 */ 2293, 2292, 2291, 2060, 2060, 2060, 2060, 2060, 2060, 2568, + /* 790 */ 2060, 2571, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 800 */ 2060, 2060, 2060, 2060, 2556, 2060, 2610, 2609, 2060, 2060, + /* 810 */ 2060, 2060, 2060, 2060, 2060, 2288, 2060, 2060, 2060, 2060, + /* 820 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 830 */ 2060, 2272, 2270, 2269, 2268, 2060, 2265, 2060, 2305, 2060, + /* 840 */ 2060, 2060, 2301, 2300, 2060, 2060, 2060, 2060, 2060, 2060, + /* 850 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 860 */ 2060, 2060, 2179, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 870 */ 2060, 2171, 2060, 2170, 2060, 2060, 2060, 2060, 2060, 2060, + /* 880 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 890 */ 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, 2060, + /* 900 */ 2060, 2089, 2060, 2060, 2060, 2060, 2060, 2060, }; /********** End of lemon-generated parsing tables *****************************/ @@ -2331,118 +2373,119 @@ static const char *const yyTokenName[] = { /* 409 */ "drop_table_clause", /* 410 */ "col_name_list", /* 411 */ "column_def", - /* 412 */ "duration_list", - /* 413 */ "rollup_func_list", - /* 414 */ "alter_table_option", - /* 415 */ "duration_literal", - /* 416 */ "rollup_func_name", - /* 417 */ "function_name", - /* 418 */ "col_name", - /* 419 */ "db_kind_opt", - /* 420 */ "table_kind_db_name_cond_opt", - /* 421 */ "like_pattern_opt", - /* 422 */ "db_name_cond_opt", - /* 423 */ "table_name_cond", - /* 424 */ "from_db_opt", - /* 425 */ "tag_list_opt", - /* 426 */ "table_kind", - /* 427 */ "tag_item", - /* 428 */ "column_alias", - /* 429 */ "index_options", - /* 430 */ "full_index_name", - /* 431 */ "index_name", - /* 432 */ "func_list", - /* 433 */ "sliding_opt", - /* 434 */ "sma_stream_opt", - /* 435 */ "func", - /* 436 */ "sma_func_name", - /* 437 */ "expression_list", - /* 438 */ "with_meta", - /* 439 */ "query_or_subquery", - /* 440 */ "where_clause_opt", - /* 441 */ "cgroup_name", - /* 442 */ "analyze_opt", - /* 443 */ "explain_options", - /* 444 */ "insert_query", - /* 445 */ "or_replace_opt", - /* 446 */ "agg_func_opt", - /* 447 */ "bufsize_opt", - /* 448 */ "language_opt", - /* 449 */ "full_view_name", - /* 450 */ "view_name", - /* 451 */ "stream_name", - /* 452 */ "stream_options", - /* 453 */ "col_list_opt", - /* 454 */ "tag_def_or_ref_opt", - /* 455 */ "subtable_opt", - /* 456 */ "ignore_opt", - /* 457 */ "column_stream_def_list", - /* 458 */ "column_stream_def", - /* 459 */ "expression", - /* 460 */ "on_vgroup_id", - /* 461 */ "dnode_list", - /* 462 */ "literal_func", - /* 463 */ "signed_literal", - /* 464 */ "literal_list", - /* 465 */ "table_alias", - /* 466 */ "expr_or_subquery", - /* 467 */ "pseudo_column", - /* 468 */ "column_reference", - /* 469 */ "function_expression", - /* 470 */ "case_when_expression", - /* 471 */ "star_func", - /* 472 */ "star_func_para_list", - /* 473 */ "noarg_func", - /* 474 */ "other_para_list", - /* 475 */ "star_func_para", - /* 476 */ "when_then_list", - /* 477 */ "case_when_else_opt", - /* 478 */ "common_expression", - /* 479 */ "when_then_expr", - /* 480 */ "predicate", - /* 481 */ "compare_op", - /* 482 */ "in_op", - /* 483 */ "in_predicate_value", - /* 484 */ "boolean_value_expression", - /* 485 */ "boolean_primary", - /* 486 */ "from_clause_opt", - /* 487 */ "table_reference_list", - /* 488 */ "table_reference", - /* 489 */ "table_primary", - /* 490 */ "joined_table", - /* 491 */ "alias_opt", - /* 492 */ "subquery", - /* 493 */ "parenthesized_joined_table", - /* 494 */ "join_type", - /* 495 */ "query_specification", - /* 496 */ "hint_list", - /* 497 */ "set_quantifier_opt", - /* 498 */ "tag_mode_opt", - /* 499 */ "select_list", - /* 500 */ "partition_by_clause_opt", - /* 501 */ "range_opt", - /* 502 */ "every_opt", - /* 503 */ "fill_opt", - /* 504 */ "twindow_clause_opt", - /* 505 */ "group_by_clause_opt", - /* 506 */ "having_clause_opt", - /* 507 */ "select_item", - /* 508 */ "partition_list", - /* 509 */ "partition_item", - /* 510 */ "interval_sliding_duration_literal", - /* 511 */ "fill_mode", - /* 512 */ "group_by_list", - /* 513 */ "query_expression", - /* 514 */ "query_simple", - /* 515 */ "order_by_clause_opt", - /* 516 */ "slimit_clause_opt", - /* 517 */ "limit_clause_opt", - /* 518 */ "union_query_expression", - /* 519 */ "query_simple_or_subquery", - /* 520 */ "sort_specification_list", - /* 521 */ "sort_specification", - /* 522 */ "ordering_specification_opt", - /* 523 */ "null_ordering_opt", + /* 412 */ "type_name_default_len", + /* 413 */ "duration_list", + /* 414 */ "rollup_func_list", + /* 415 */ "alter_table_option", + /* 416 */ "duration_literal", + /* 417 */ "rollup_func_name", + /* 418 */ "function_name", + /* 419 */ "col_name", + /* 420 */ "db_kind_opt", + /* 421 */ "table_kind_db_name_cond_opt", + /* 422 */ "like_pattern_opt", + /* 423 */ "db_name_cond_opt", + /* 424 */ "table_name_cond", + /* 425 */ "from_db_opt", + /* 426 */ "tag_list_opt", + /* 427 */ "table_kind", + /* 428 */ "tag_item", + /* 429 */ "column_alias", + /* 430 */ "index_options", + /* 431 */ "full_index_name", + /* 432 */ "index_name", + /* 433 */ "func_list", + /* 434 */ "sliding_opt", + /* 435 */ "sma_stream_opt", + /* 436 */ "func", + /* 437 */ "sma_func_name", + /* 438 */ "expression_list", + /* 439 */ "with_meta", + /* 440 */ "query_or_subquery", + /* 441 */ "where_clause_opt", + /* 442 */ "cgroup_name", + /* 443 */ "analyze_opt", + /* 444 */ "explain_options", + /* 445 */ "insert_query", + /* 446 */ "or_replace_opt", + /* 447 */ "agg_func_opt", + /* 448 */ "bufsize_opt", + /* 449 */ "language_opt", + /* 450 */ "full_view_name", + /* 451 */ "view_name", + /* 452 */ "stream_name", + /* 453 */ "stream_options", + /* 454 */ "col_list_opt", + /* 455 */ "tag_def_or_ref_opt", + /* 456 */ "subtable_opt", + /* 457 */ "ignore_opt", + /* 458 */ "column_stream_def_list", + /* 459 */ "column_stream_def", + /* 460 */ "expression", + /* 461 */ "on_vgroup_id", + /* 462 */ "dnode_list", + /* 463 */ "literal_func", + /* 464 */ "signed_literal", + /* 465 */ "literal_list", + /* 466 */ "table_alias", + /* 467 */ "expr_or_subquery", + /* 468 */ "pseudo_column", + /* 469 */ "column_reference", + /* 470 */ "function_expression", + /* 471 */ "case_when_expression", + /* 472 */ "star_func", + /* 473 */ "star_func_para_list", + /* 474 */ "noarg_func", + /* 475 */ "other_para_list", + /* 476 */ "star_func_para", + /* 477 */ "when_then_list", + /* 478 */ "case_when_else_opt", + /* 479 */ "common_expression", + /* 480 */ "when_then_expr", + /* 481 */ "predicate", + /* 482 */ "compare_op", + /* 483 */ "in_op", + /* 484 */ "in_predicate_value", + /* 485 */ "boolean_value_expression", + /* 486 */ "boolean_primary", + /* 487 */ "from_clause_opt", + /* 488 */ "table_reference_list", + /* 489 */ "table_reference", + /* 490 */ "table_primary", + /* 491 */ "joined_table", + /* 492 */ "alias_opt", + /* 493 */ "subquery", + /* 494 */ "parenthesized_joined_table", + /* 495 */ "join_type", + /* 496 */ "query_specification", + /* 497 */ "hint_list", + /* 498 */ "set_quantifier_opt", + /* 499 */ "tag_mode_opt", + /* 500 */ "select_list", + /* 501 */ "partition_by_clause_opt", + /* 502 */ "range_opt", + /* 503 */ "every_opt", + /* 504 */ "fill_opt", + /* 505 */ "twindow_clause_opt", + /* 506 */ "group_by_clause_opt", + /* 507 */ "having_clause_opt", + /* 508 */ "select_item", + /* 509 */ "partition_list", + /* 510 */ "partition_item", + /* 511 */ "interval_sliding_duration_literal", + /* 512 */ "fill_mode", + /* 513 */ "group_by_list", + /* 514 */ "query_expression", + /* 515 */ "query_simple", + /* 516 */ "order_by_clause_opt", + /* 517 */ "slimit_clause_opt", + /* 518 */ "limit_clause_opt", + /* 519 */ "union_query_expression", + /* 520 */ "query_simple_or_subquery", + /* 521 */ "sort_specification_list", + /* 522 */ "sort_specification", + /* 523 */ "ordering_specification_opt", + /* 524 */ "null_ordering_opt", }; #endif /* defined(YYCOVERAGE) || !defined(NDEBUG) */ @@ -2678,482 +2721,487 @@ static const char *const yyRuleName[] = { /* 225 */ "type_name ::= DECIMAL", /* 226 */ "type_name ::= DECIMAL NK_LP NK_INTEGER NK_RP", /* 227 */ "type_name ::= DECIMAL NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP", - /* 228 */ "tags_def_opt ::=", - /* 229 */ "tags_def_opt ::= tags_def", - /* 230 */ "tags_def ::= TAGS NK_LP column_def_list NK_RP", - /* 231 */ "table_options ::=", - /* 232 */ "table_options ::= table_options COMMENT NK_STRING", - /* 233 */ "table_options ::= table_options MAX_DELAY duration_list", - /* 234 */ "table_options ::= table_options WATERMARK duration_list", - /* 235 */ "table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP", - /* 236 */ "table_options ::= table_options TTL NK_INTEGER", - /* 237 */ "table_options ::= table_options SMA NK_LP col_name_list NK_RP", - /* 238 */ "table_options ::= table_options DELETE_MARK duration_list", - /* 239 */ "alter_table_options ::= alter_table_option", - /* 240 */ "alter_table_options ::= alter_table_options alter_table_option", - /* 241 */ "alter_table_option ::= COMMENT NK_STRING", - /* 242 */ "alter_table_option ::= TTL NK_INTEGER", - /* 243 */ "duration_list ::= duration_literal", - /* 244 */ "duration_list ::= duration_list NK_COMMA duration_literal", - /* 245 */ "rollup_func_list ::= rollup_func_name", - /* 246 */ "rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name", - /* 247 */ "rollup_func_name ::= function_name", - /* 248 */ "rollup_func_name ::= FIRST", - /* 249 */ "rollup_func_name ::= LAST", - /* 250 */ "col_name_list ::= col_name", - /* 251 */ "col_name_list ::= col_name_list NK_COMMA col_name", - /* 252 */ "col_name ::= column_name", - /* 253 */ "cmd ::= SHOW DNODES", - /* 254 */ "cmd ::= SHOW USERS", - /* 255 */ "cmd ::= SHOW USER PRIVILEGES", - /* 256 */ "cmd ::= SHOW db_kind_opt DATABASES", - /* 257 */ "cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt", - /* 258 */ "cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt", - /* 259 */ "cmd ::= SHOW db_name_cond_opt VGROUPS", - /* 260 */ "cmd ::= SHOW MNODES", - /* 261 */ "cmd ::= SHOW QNODES", - /* 262 */ "cmd ::= SHOW ARBGROUPS", - /* 263 */ "cmd ::= SHOW FUNCTIONS", - /* 264 */ "cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt", - /* 265 */ "cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name", - /* 266 */ "cmd ::= SHOW STREAMS", - /* 267 */ "cmd ::= SHOW ACCOUNTS", - /* 268 */ "cmd ::= SHOW APPS", - /* 269 */ "cmd ::= SHOW CONNECTIONS", - /* 270 */ "cmd ::= SHOW LICENCES", - /* 271 */ "cmd ::= SHOW GRANTS", - /* 272 */ "cmd ::= SHOW GRANTS FULL", - /* 273 */ "cmd ::= SHOW GRANTS LOGS", - /* 274 */ "cmd ::= SHOW CLUSTER MACHINES", - /* 275 */ "cmd ::= SHOW CREATE DATABASE db_name", - /* 276 */ "cmd ::= SHOW CREATE TABLE full_table_name", - /* 277 */ "cmd ::= SHOW CREATE STABLE full_table_name", - /* 278 */ "cmd ::= SHOW QUERIES", - /* 279 */ "cmd ::= SHOW SCORES", - /* 280 */ "cmd ::= SHOW TOPICS", - /* 281 */ "cmd ::= SHOW VARIABLES", - /* 282 */ "cmd ::= SHOW CLUSTER VARIABLES", - /* 283 */ "cmd ::= SHOW LOCAL VARIABLES", - /* 284 */ "cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt", - /* 285 */ "cmd ::= SHOW BNODES", - /* 286 */ "cmd ::= SHOW SNODES", - /* 287 */ "cmd ::= SHOW CLUSTER", - /* 288 */ "cmd ::= SHOW TRANSACTIONS", - /* 289 */ "cmd ::= SHOW TABLE DISTRIBUTED full_table_name", - /* 290 */ "cmd ::= SHOW CONSUMERS", - /* 291 */ "cmd ::= SHOW SUBSCRIPTIONS", - /* 292 */ "cmd ::= SHOW TAGS FROM table_name_cond from_db_opt", - /* 293 */ "cmd ::= SHOW TAGS FROM db_name NK_DOT table_name", - /* 294 */ "cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt", - /* 295 */ "cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name", - /* 296 */ "cmd ::= SHOW VNODES ON DNODE NK_INTEGER", - /* 297 */ "cmd ::= SHOW VNODES", - /* 298 */ "cmd ::= SHOW db_name_cond_opt ALIVE", - /* 299 */ "cmd ::= SHOW CLUSTER ALIVE", - /* 300 */ "cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt", - /* 301 */ "cmd ::= SHOW CREATE VIEW full_table_name", - /* 302 */ "cmd ::= SHOW COMPACTS", - /* 303 */ "cmd ::= SHOW COMPACT NK_INTEGER", - /* 304 */ "table_kind_db_name_cond_opt ::=", - /* 305 */ "table_kind_db_name_cond_opt ::= table_kind", - /* 306 */ "table_kind_db_name_cond_opt ::= db_name NK_DOT", - /* 307 */ "table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT", - /* 308 */ "table_kind ::= NORMAL", - /* 309 */ "table_kind ::= CHILD", - /* 310 */ "db_name_cond_opt ::=", - /* 311 */ "db_name_cond_opt ::= db_name NK_DOT", - /* 312 */ "like_pattern_opt ::=", - /* 313 */ "like_pattern_opt ::= LIKE NK_STRING", - /* 314 */ "table_name_cond ::= table_name", - /* 315 */ "from_db_opt ::=", - /* 316 */ "from_db_opt ::= FROM db_name", - /* 317 */ "tag_list_opt ::=", - /* 318 */ "tag_list_opt ::= tag_item", - /* 319 */ "tag_list_opt ::= tag_list_opt NK_COMMA tag_item", - /* 320 */ "tag_item ::= TBNAME", - /* 321 */ "tag_item ::= QTAGS", - /* 322 */ "tag_item ::= column_name", - /* 323 */ "tag_item ::= column_name column_alias", - /* 324 */ "tag_item ::= column_name AS column_alias", - /* 325 */ "db_kind_opt ::=", - /* 326 */ "db_kind_opt ::= USER", - /* 327 */ "db_kind_opt ::= SYSTEM", - /* 328 */ "cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options", - /* 329 */ "cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP", - /* 330 */ "cmd ::= DROP INDEX exists_opt full_index_name", - /* 331 */ "full_index_name ::= index_name", - /* 332 */ "full_index_name ::= db_name NK_DOT index_name", - /* 333 */ "index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt", - /* 334 */ "index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt", - /* 335 */ "func_list ::= func", - /* 336 */ "func_list ::= func_list NK_COMMA func", - /* 337 */ "func ::= sma_func_name NK_LP expression_list NK_RP", - /* 338 */ "sma_func_name ::= function_name", - /* 339 */ "sma_func_name ::= COUNT", - /* 340 */ "sma_func_name ::= FIRST", - /* 341 */ "sma_func_name ::= LAST", - /* 342 */ "sma_func_name ::= LAST_ROW", - /* 343 */ "sma_stream_opt ::=", - /* 344 */ "sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal", - /* 345 */ "sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal", - /* 346 */ "sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal", - /* 347 */ "with_meta ::= AS", - /* 348 */ "with_meta ::= WITH META AS", - /* 349 */ "with_meta ::= ONLY META AS", - /* 350 */ "cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery", - /* 351 */ "cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name", - /* 352 */ "cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt", - /* 353 */ "cmd ::= DROP TOPIC exists_opt topic_name", - /* 354 */ "cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name", - /* 355 */ "cmd ::= DESC full_table_name", - /* 356 */ "cmd ::= DESCRIBE full_table_name", - /* 357 */ "cmd ::= RESET QUERY CACHE", - /* 358 */ "cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery", - /* 359 */ "cmd ::= EXPLAIN analyze_opt explain_options insert_query", - /* 360 */ "analyze_opt ::=", - /* 361 */ "analyze_opt ::= ANALYZE", - /* 362 */ "explain_options ::=", - /* 363 */ "explain_options ::= explain_options VERBOSE NK_BOOL", - /* 364 */ "explain_options ::= explain_options RATIO NK_FLOAT", - /* 365 */ "cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt", - /* 366 */ "cmd ::= DROP FUNCTION exists_opt function_name", - /* 367 */ "agg_func_opt ::=", - /* 368 */ "agg_func_opt ::= AGGREGATE", - /* 369 */ "bufsize_opt ::=", - /* 370 */ "bufsize_opt ::= BUFSIZE NK_INTEGER", - /* 371 */ "language_opt ::=", - /* 372 */ "language_opt ::= LANGUAGE NK_STRING", - /* 373 */ "or_replace_opt ::=", - /* 374 */ "or_replace_opt ::= OR REPLACE", - /* 375 */ "cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery", - /* 376 */ "cmd ::= DROP VIEW exists_opt full_view_name", - /* 377 */ "full_view_name ::= view_name", - /* 378 */ "full_view_name ::= db_name NK_DOT view_name", - /* 379 */ "cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery", - /* 380 */ "cmd ::= DROP STREAM exists_opt stream_name", - /* 381 */ "cmd ::= PAUSE STREAM exists_opt stream_name", - /* 382 */ "cmd ::= RESUME STREAM exists_opt ignore_opt stream_name", - /* 383 */ "col_list_opt ::=", - /* 384 */ "col_list_opt ::= NK_LP column_stream_def_list NK_RP", - /* 385 */ "column_stream_def_list ::= column_stream_def", - /* 386 */ "column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def", - /* 387 */ "column_stream_def ::= column_name", - /* 388 */ "column_stream_def ::= column_name PRIMARY KEY", - /* 389 */ "tag_def_or_ref_opt ::=", - /* 390 */ "tag_def_or_ref_opt ::= tags_def", - /* 391 */ "tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP", - /* 392 */ "stream_options ::=", - /* 393 */ "stream_options ::= stream_options TRIGGER AT_ONCE", - /* 394 */ "stream_options ::= stream_options TRIGGER WINDOW_CLOSE", - /* 395 */ "stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal", - /* 396 */ "stream_options ::= stream_options WATERMARK duration_literal", - /* 397 */ "stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER", - /* 398 */ "stream_options ::= stream_options FILL_HISTORY NK_INTEGER", - /* 399 */ "stream_options ::= stream_options DELETE_MARK duration_literal", - /* 400 */ "stream_options ::= stream_options IGNORE UPDATE NK_INTEGER", - /* 401 */ "subtable_opt ::=", - /* 402 */ "subtable_opt ::= SUBTABLE NK_LP expression NK_RP", - /* 403 */ "ignore_opt ::=", - /* 404 */ "ignore_opt ::= IGNORE UNTREATED", - /* 405 */ "cmd ::= KILL CONNECTION NK_INTEGER", - /* 406 */ "cmd ::= KILL QUERY NK_STRING", - /* 407 */ "cmd ::= KILL TRANSACTION NK_INTEGER", - /* 408 */ "cmd ::= KILL COMPACT NK_INTEGER", - /* 409 */ "cmd ::= BALANCE VGROUP", - /* 410 */ "cmd ::= BALANCE VGROUP LEADER on_vgroup_id", - /* 411 */ "cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER", - /* 412 */ "cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list", - /* 413 */ "cmd ::= SPLIT VGROUP NK_INTEGER", - /* 414 */ "on_vgroup_id ::=", - /* 415 */ "on_vgroup_id ::= ON NK_INTEGER", - /* 416 */ "dnode_list ::= DNODE NK_INTEGER", - /* 417 */ "dnode_list ::= dnode_list DNODE NK_INTEGER", - /* 418 */ "cmd ::= DELETE FROM full_table_name where_clause_opt", - /* 419 */ "cmd ::= query_or_subquery", - /* 420 */ "cmd ::= insert_query", - /* 421 */ "insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery", - /* 422 */ "insert_query ::= INSERT INTO full_table_name query_or_subquery", - /* 423 */ "tags_literal ::= NK_INTEGER", - /* 424 */ "tags_literal ::= NK_INTEGER NK_PLUS duration_literal", - /* 425 */ "tags_literal ::= NK_INTEGER NK_MINUS duration_literal", - /* 426 */ "tags_literal ::= NK_PLUS NK_INTEGER", - /* 427 */ "tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal", - /* 428 */ "tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal", - /* 429 */ "tags_literal ::= NK_MINUS NK_INTEGER", - /* 430 */ "tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal", - /* 431 */ "tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal", - /* 432 */ "tags_literal ::= NK_FLOAT", - /* 433 */ "tags_literal ::= NK_PLUS NK_FLOAT", - /* 434 */ "tags_literal ::= NK_MINUS NK_FLOAT", - /* 435 */ "tags_literal ::= NK_BIN", - /* 436 */ "tags_literal ::= NK_BIN NK_PLUS duration_literal", - /* 437 */ "tags_literal ::= NK_BIN NK_MINUS duration_literal", - /* 438 */ "tags_literal ::= NK_PLUS NK_BIN", - /* 439 */ "tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal", - /* 440 */ "tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal", - /* 441 */ "tags_literal ::= NK_MINUS NK_BIN", - /* 442 */ "tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal", - /* 443 */ "tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal", - /* 444 */ "tags_literal ::= NK_HEX", - /* 445 */ "tags_literal ::= NK_HEX NK_PLUS duration_literal", - /* 446 */ "tags_literal ::= NK_HEX NK_MINUS duration_literal", - /* 447 */ "tags_literal ::= NK_PLUS NK_HEX", - /* 448 */ "tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal", - /* 449 */ "tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal", - /* 450 */ "tags_literal ::= NK_MINUS NK_HEX", - /* 451 */ "tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal", - /* 452 */ "tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal", - /* 453 */ "tags_literal ::= NK_STRING", - /* 454 */ "tags_literal ::= NK_STRING NK_PLUS duration_literal", - /* 455 */ "tags_literal ::= NK_STRING NK_MINUS duration_literal", - /* 456 */ "tags_literal ::= NK_BOOL", - /* 457 */ "tags_literal ::= NULL", - /* 458 */ "tags_literal ::= literal_func", - /* 459 */ "tags_literal ::= literal_func NK_PLUS duration_literal", - /* 460 */ "tags_literal ::= literal_func NK_MINUS duration_literal", - /* 461 */ "tags_literal_list ::= tags_literal", - /* 462 */ "tags_literal_list ::= tags_literal_list NK_COMMA tags_literal", - /* 463 */ "literal ::= NK_INTEGER", - /* 464 */ "literal ::= NK_FLOAT", - /* 465 */ "literal ::= NK_STRING", - /* 466 */ "literal ::= NK_BOOL", - /* 467 */ "literal ::= TIMESTAMP NK_STRING", - /* 468 */ "literal ::= duration_literal", - /* 469 */ "literal ::= NULL", - /* 470 */ "literal ::= NK_QUESTION", - /* 471 */ "duration_literal ::= NK_VARIABLE", - /* 472 */ "signed ::= NK_INTEGER", - /* 473 */ "signed ::= NK_PLUS NK_INTEGER", - /* 474 */ "signed ::= NK_MINUS NK_INTEGER", - /* 475 */ "signed ::= NK_FLOAT", - /* 476 */ "signed ::= NK_PLUS NK_FLOAT", - /* 477 */ "signed ::= NK_MINUS NK_FLOAT", - /* 478 */ "signed_literal ::= signed", - /* 479 */ "signed_literal ::= NK_STRING", - /* 480 */ "signed_literal ::= NK_BOOL", - /* 481 */ "signed_literal ::= TIMESTAMP NK_STRING", - /* 482 */ "signed_literal ::= duration_literal", - /* 483 */ "signed_literal ::= NULL", - /* 484 */ "signed_literal ::= literal_func", - /* 485 */ "signed_literal ::= NK_QUESTION", - /* 486 */ "literal_list ::= signed_literal", - /* 487 */ "literal_list ::= literal_list NK_COMMA signed_literal", - /* 488 */ "db_name ::= NK_ID", - /* 489 */ "table_name ::= NK_ID", - /* 490 */ "column_name ::= NK_ID", - /* 491 */ "function_name ::= NK_ID", - /* 492 */ "view_name ::= NK_ID", - /* 493 */ "table_alias ::= NK_ID", - /* 494 */ "column_alias ::= NK_ID", - /* 495 */ "column_alias ::= NK_ALIAS", - /* 496 */ "user_name ::= NK_ID", - /* 497 */ "topic_name ::= NK_ID", - /* 498 */ "stream_name ::= NK_ID", - /* 499 */ "cgroup_name ::= NK_ID", - /* 500 */ "index_name ::= NK_ID", - /* 501 */ "expr_or_subquery ::= expression", - /* 502 */ "expression ::= literal", - /* 503 */ "expression ::= pseudo_column", - /* 504 */ "expression ::= column_reference", - /* 505 */ "expression ::= function_expression", - /* 506 */ "expression ::= case_when_expression", - /* 507 */ "expression ::= NK_LP expression NK_RP", - /* 508 */ "expression ::= NK_PLUS expr_or_subquery", - /* 509 */ "expression ::= NK_MINUS expr_or_subquery", - /* 510 */ "expression ::= expr_or_subquery NK_PLUS expr_or_subquery", - /* 511 */ "expression ::= expr_or_subquery NK_MINUS expr_or_subquery", - /* 512 */ "expression ::= expr_or_subquery NK_STAR expr_or_subquery", - /* 513 */ "expression ::= expr_or_subquery NK_SLASH expr_or_subquery", - /* 514 */ "expression ::= expr_or_subquery NK_REM expr_or_subquery", - /* 515 */ "expression ::= column_reference NK_ARROW NK_STRING", - /* 516 */ "expression ::= expr_or_subquery NK_BITAND expr_or_subquery", - /* 517 */ "expression ::= expr_or_subquery NK_BITOR expr_or_subquery", - /* 518 */ "expression_list ::= expr_or_subquery", - /* 519 */ "expression_list ::= expression_list NK_COMMA expr_or_subquery", - /* 520 */ "column_reference ::= column_name", - /* 521 */ "column_reference ::= table_name NK_DOT column_name", - /* 522 */ "column_reference ::= NK_ALIAS", - /* 523 */ "column_reference ::= table_name NK_DOT NK_ALIAS", - /* 524 */ "pseudo_column ::= ROWTS", - /* 525 */ "pseudo_column ::= TBNAME", - /* 526 */ "pseudo_column ::= table_name NK_DOT TBNAME", - /* 527 */ "pseudo_column ::= QSTART", - /* 528 */ "pseudo_column ::= QEND", - /* 529 */ "pseudo_column ::= QDURATION", - /* 530 */ "pseudo_column ::= WSTART", - /* 531 */ "pseudo_column ::= WEND", - /* 532 */ "pseudo_column ::= WDURATION", - /* 533 */ "pseudo_column ::= IROWTS", - /* 534 */ "pseudo_column ::= ISFILLED", - /* 535 */ "pseudo_column ::= QTAGS", - /* 536 */ "function_expression ::= function_name NK_LP expression_list NK_RP", - /* 537 */ "function_expression ::= star_func NK_LP star_func_para_list NK_RP", - /* 538 */ "function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP", - /* 539 */ "function_expression ::= literal_func", - /* 540 */ "literal_func ::= noarg_func NK_LP NK_RP", - /* 541 */ "literal_func ::= NOW", - /* 542 */ "literal_func ::= TODAY", - /* 543 */ "noarg_func ::= NOW", - /* 544 */ "noarg_func ::= TODAY", - /* 545 */ "noarg_func ::= TIMEZONE", - /* 546 */ "noarg_func ::= DATABASE", - /* 547 */ "noarg_func ::= CLIENT_VERSION", - /* 548 */ "noarg_func ::= SERVER_VERSION", - /* 549 */ "noarg_func ::= SERVER_STATUS", - /* 550 */ "noarg_func ::= CURRENT_USER", - /* 551 */ "noarg_func ::= USER", - /* 552 */ "star_func ::= COUNT", - /* 553 */ "star_func ::= FIRST", - /* 554 */ "star_func ::= LAST", - /* 555 */ "star_func ::= LAST_ROW", - /* 556 */ "star_func_para_list ::= NK_STAR", - /* 557 */ "star_func_para_list ::= other_para_list", - /* 558 */ "other_para_list ::= star_func_para", - /* 559 */ "other_para_list ::= other_para_list NK_COMMA star_func_para", - /* 560 */ "star_func_para ::= expr_or_subquery", - /* 561 */ "star_func_para ::= table_name NK_DOT NK_STAR", - /* 562 */ "case_when_expression ::= CASE when_then_list case_when_else_opt END", - /* 563 */ "case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END", - /* 564 */ "when_then_list ::= when_then_expr", - /* 565 */ "when_then_list ::= when_then_list when_then_expr", - /* 566 */ "when_then_expr ::= WHEN common_expression THEN common_expression", - /* 567 */ "case_when_else_opt ::=", - /* 568 */ "case_when_else_opt ::= ELSE common_expression", - /* 569 */ "predicate ::= expr_or_subquery compare_op expr_or_subquery", - /* 570 */ "predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery", - /* 571 */ "predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery", - /* 572 */ "predicate ::= expr_or_subquery IS NULL", - /* 573 */ "predicate ::= expr_or_subquery IS NOT NULL", - /* 574 */ "predicate ::= expr_or_subquery in_op in_predicate_value", - /* 575 */ "compare_op ::= NK_LT", - /* 576 */ "compare_op ::= NK_GT", - /* 577 */ "compare_op ::= NK_LE", - /* 578 */ "compare_op ::= NK_GE", - /* 579 */ "compare_op ::= NK_NE", - /* 580 */ "compare_op ::= NK_EQ", - /* 581 */ "compare_op ::= LIKE", - /* 582 */ "compare_op ::= NOT LIKE", - /* 583 */ "compare_op ::= MATCH", - /* 584 */ "compare_op ::= NMATCH", - /* 585 */ "compare_op ::= CONTAINS", - /* 586 */ "in_op ::= IN", - /* 587 */ "in_op ::= NOT IN", - /* 588 */ "in_predicate_value ::= NK_LP literal_list NK_RP", - /* 589 */ "boolean_value_expression ::= boolean_primary", - /* 590 */ "boolean_value_expression ::= NOT boolean_primary", - /* 591 */ "boolean_value_expression ::= boolean_value_expression OR boolean_value_expression", - /* 592 */ "boolean_value_expression ::= boolean_value_expression AND boolean_value_expression", - /* 593 */ "boolean_primary ::= predicate", - /* 594 */ "boolean_primary ::= NK_LP boolean_value_expression NK_RP", - /* 595 */ "common_expression ::= expr_or_subquery", - /* 596 */ "common_expression ::= boolean_value_expression", - /* 597 */ "from_clause_opt ::=", - /* 598 */ "from_clause_opt ::= FROM table_reference_list", - /* 599 */ "table_reference_list ::= table_reference", - /* 600 */ "table_reference_list ::= table_reference_list NK_COMMA table_reference", - /* 601 */ "table_reference ::= table_primary", - /* 602 */ "table_reference ::= joined_table", - /* 603 */ "table_primary ::= table_name alias_opt", - /* 604 */ "table_primary ::= db_name NK_DOT table_name alias_opt", - /* 605 */ "table_primary ::= subquery alias_opt", - /* 606 */ "table_primary ::= parenthesized_joined_table", - /* 607 */ "alias_opt ::=", - /* 608 */ "alias_opt ::= table_alias", - /* 609 */ "alias_opt ::= AS table_alias", - /* 610 */ "parenthesized_joined_table ::= NK_LP joined_table NK_RP", - /* 611 */ "parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP", - /* 612 */ "joined_table ::= table_reference join_type JOIN table_reference ON search_condition", - /* 613 */ "join_type ::=", - /* 614 */ "join_type ::= INNER", - /* 615 */ "query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt", - /* 616 */ "hint_list ::=", - /* 617 */ "hint_list ::= NK_HINT", - /* 618 */ "tag_mode_opt ::=", - /* 619 */ "tag_mode_opt ::= TAGS", - /* 620 */ "set_quantifier_opt ::=", - /* 621 */ "set_quantifier_opt ::= DISTINCT", - /* 622 */ "set_quantifier_opt ::= ALL", - /* 623 */ "select_list ::= select_item", - /* 624 */ "select_list ::= select_list NK_COMMA select_item", - /* 625 */ "select_item ::= NK_STAR", - /* 626 */ "select_item ::= common_expression", - /* 627 */ "select_item ::= common_expression column_alias", - /* 628 */ "select_item ::= common_expression AS column_alias", - /* 629 */ "select_item ::= table_name NK_DOT NK_STAR", - /* 630 */ "where_clause_opt ::=", - /* 631 */ "where_clause_opt ::= WHERE search_condition", - /* 632 */ "partition_by_clause_opt ::=", - /* 633 */ "partition_by_clause_opt ::= PARTITION BY partition_list", - /* 634 */ "partition_list ::= partition_item", - /* 635 */ "partition_list ::= partition_list NK_COMMA partition_item", - /* 636 */ "partition_item ::= expr_or_subquery", - /* 637 */ "partition_item ::= expr_or_subquery column_alias", - /* 638 */ "partition_item ::= expr_or_subquery AS column_alias", - /* 639 */ "twindow_clause_opt ::=", - /* 640 */ "twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP", - /* 641 */ "twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP", - /* 642 */ "twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt", - /* 643 */ "twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt", - /* 644 */ "twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition", - /* 645 */ "twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP", - /* 646 */ "twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP", - /* 647 */ "sliding_opt ::=", - /* 648 */ "sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP", - /* 649 */ "interval_sliding_duration_literal ::= NK_VARIABLE", - /* 650 */ "interval_sliding_duration_literal ::= NK_STRING", - /* 651 */ "interval_sliding_duration_literal ::= NK_INTEGER", - /* 652 */ "fill_opt ::=", - /* 653 */ "fill_opt ::= FILL NK_LP fill_mode NK_RP", - /* 654 */ "fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP", - /* 655 */ "fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP", - /* 656 */ "fill_mode ::= NONE", - /* 657 */ "fill_mode ::= PREV", - /* 658 */ "fill_mode ::= NULL", - /* 659 */ "fill_mode ::= NULL_F", - /* 660 */ "fill_mode ::= LINEAR", - /* 661 */ "fill_mode ::= NEXT", - /* 662 */ "group_by_clause_opt ::=", - /* 663 */ "group_by_clause_opt ::= GROUP BY group_by_list", - /* 664 */ "group_by_list ::= expr_or_subquery", - /* 665 */ "group_by_list ::= group_by_list NK_COMMA expr_or_subquery", - /* 666 */ "having_clause_opt ::=", - /* 667 */ "having_clause_opt ::= HAVING search_condition", - /* 668 */ "range_opt ::=", - /* 669 */ "range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP", - /* 670 */ "range_opt ::= RANGE NK_LP expr_or_subquery NK_RP", - /* 671 */ "every_opt ::=", - /* 672 */ "every_opt ::= EVERY NK_LP duration_literal NK_RP", - /* 673 */ "query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt", - /* 674 */ "query_simple ::= query_specification", - /* 675 */ "query_simple ::= union_query_expression", - /* 676 */ "union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery", - /* 677 */ "union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery", - /* 678 */ "query_simple_or_subquery ::= query_simple", - /* 679 */ "query_simple_or_subquery ::= subquery", - /* 680 */ "query_or_subquery ::= query_expression", - /* 681 */ "query_or_subquery ::= subquery", - /* 682 */ "order_by_clause_opt ::=", - /* 683 */ "order_by_clause_opt ::= ORDER BY sort_specification_list", - /* 684 */ "slimit_clause_opt ::=", - /* 685 */ "slimit_clause_opt ::= SLIMIT NK_INTEGER", - /* 686 */ "slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER", - /* 687 */ "slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER", - /* 688 */ "limit_clause_opt ::=", - /* 689 */ "limit_clause_opt ::= LIMIT NK_INTEGER", - /* 690 */ "limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER", - /* 691 */ "limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER", - /* 692 */ "subquery ::= NK_LP query_expression NK_RP", - /* 693 */ "subquery ::= NK_LP subquery NK_RP", - /* 694 */ "search_condition ::= common_expression", - /* 695 */ "sort_specification_list ::= sort_specification", - /* 696 */ "sort_specification_list ::= sort_specification_list NK_COMMA sort_specification", - /* 697 */ "sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt", - /* 698 */ "ordering_specification_opt ::=", - /* 699 */ "ordering_specification_opt ::= ASC", - /* 700 */ "ordering_specification_opt ::= DESC", - /* 701 */ "null_ordering_opt ::=", - /* 702 */ "null_ordering_opt ::= NULLS FIRST", - /* 703 */ "null_ordering_opt ::= NULLS LAST", + /* 228 */ "type_name_default_len ::= BINARY", + /* 229 */ "type_name_default_len ::= NCHAR", + /* 230 */ "type_name_default_len ::= VARCHAR", + /* 231 */ "type_name_default_len ::= VARBINARY", + /* 232 */ "tags_def_opt ::=", + /* 233 */ "tags_def_opt ::= tags_def", + /* 234 */ "tags_def ::= TAGS NK_LP column_def_list NK_RP", + /* 235 */ "table_options ::=", + /* 236 */ "table_options ::= table_options COMMENT NK_STRING", + /* 237 */ "table_options ::= table_options MAX_DELAY duration_list", + /* 238 */ "table_options ::= table_options WATERMARK duration_list", + /* 239 */ "table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP", + /* 240 */ "table_options ::= table_options TTL NK_INTEGER", + /* 241 */ "table_options ::= table_options SMA NK_LP col_name_list NK_RP", + /* 242 */ "table_options ::= table_options DELETE_MARK duration_list", + /* 243 */ "alter_table_options ::= alter_table_option", + /* 244 */ "alter_table_options ::= alter_table_options alter_table_option", + /* 245 */ "alter_table_option ::= COMMENT NK_STRING", + /* 246 */ "alter_table_option ::= TTL NK_INTEGER", + /* 247 */ "duration_list ::= duration_literal", + /* 248 */ "duration_list ::= duration_list NK_COMMA duration_literal", + /* 249 */ "rollup_func_list ::= rollup_func_name", + /* 250 */ "rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name", + /* 251 */ "rollup_func_name ::= function_name", + /* 252 */ "rollup_func_name ::= FIRST", + /* 253 */ "rollup_func_name ::= LAST", + /* 254 */ "col_name_list ::= col_name", + /* 255 */ "col_name_list ::= col_name_list NK_COMMA col_name", + /* 256 */ "col_name ::= column_name", + /* 257 */ "cmd ::= SHOW DNODES", + /* 258 */ "cmd ::= SHOW USERS", + /* 259 */ "cmd ::= SHOW USER PRIVILEGES", + /* 260 */ "cmd ::= SHOW db_kind_opt DATABASES", + /* 261 */ "cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt", + /* 262 */ "cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt", + /* 263 */ "cmd ::= SHOW db_name_cond_opt VGROUPS", + /* 264 */ "cmd ::= SHOW MNODES", + /* 265 */ "cmd ::= SHOW QNODES", + /* 266 */ "cmd ::= SHOW ARBGROUPS", + /* 267 */ "cmd ::= SHOW FUNCTIONS", + /* 268 */ "cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt", + /* 269 */ "cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name", + /* 270 */ "cmd ::= SHOW STREAMS", + /* 271 */ "cmd ::= SHOW ACCOUNTS", + /* 272 */ "cmd ::= SHOW APPS", + /* 273 */ "cmd ::= SHOW CONNECTIONS", + /* 274 */ "cmd ::= SHOW LICENCES", + /* 275 */ "cmd ::= SHOW GRANTS", + /* 276 */ "cmd ::= SHOW GRANTS FULL", + /* 277 */ "cmd ::= SHOW GRANTS LOGS", + /* 278 */ "cmd ::= SHOW CLUSTER MACHINES", + /* 279 */ "cmd ::= SHOW CREATE DATABASE db_name", + /* 280 */ "cmd ::= SHOW CREATE TABLE full_table_name", + /* 281 */ "cmd ::= SHOW CREATE STABLE full_table_name", + /* 282 */ "cmd ::= SHOW QUERIES", + /* 283 */ "cmd ::= SHOW SCORES", + /* 284 */ "cmd ::= SHOW TOPICS", + /* 285 */ "cmd ::= SHOW VARIABLES", + /* 286 */ "cmd ::= SHOW CLUSTER VARIABLES", + /* 287 */ "cmd ::= SHOW LOCAL VARIABLES", + /* 288 */ "cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt", + /* 289 */ "cmd ::= SHOW BNODES", + /* 290 */ "cmd ::= SHOW SNODES", + /* 291 */ "cmd ::= SHOW CLUSTER", + /* 292 */ "cmd ::= SHOW TRANSACTIONS", + /* 293 */ "cmd ::= SHOW TABLE DISTRIBUTED full_table_name", + /* 294 */ "cmd ::= SHOW CONSUMERS", + /* 295 */ "cmd ::= SHOW SUBSCRIPTIONS", + /* 296 */ "cmd ::= SHOW TAGS FROM table_name_cond from_db_opt", + /* 297 */ "cmd ::= SHOW TAGS FROM db_name NK_DOT table_name", + /* 298 */ "cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt", + /* 299 */ "cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name", + /* 300 */ "cmd ::= SHOW VNODES ON DNODE NK_INTEGER", + /* 301 */ "cmd ::= SHOW VNODES", + /* 302 */ "cmd ::= SHOW db_name_cond_opt ALIVE", + /* 303 */ "cmd ::= SHOW CLUSTER ALIVE", + /* 304 */ "cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt", + /* 305 */ "cmd ::= SHOW CREATE VIEW full_table_name", + /* 306 */ "cmd ::= SHOW COMPACTS", + /* 307 */ "cmd ::= SHOW COMPACT NK_INTEGER", + /* 308 */ "table_kind_db_name_cond_opt ::=", + /* 309 */ "table_kind_db_name_cond_opt ::= table_kind", + /* 310 */ "table_kind_db_name_cond_opt ::= db_name NK_DOT", + /* 311 */ "table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT", + /* 312 */ "table_kind ::= NORMAL", + /* 313 */ "table_kind ::= CHILD", + /* 314 */ "db_name_cond_opt ::=", + /* 315 */ "db_name_cond_opt ::= db_name NK_DOT", + /* 316 */ "like_pattern_opt ::=", + /* 317 */ "like_pattern_opt ::= LIKE NK_STRING", + /* 318 */ "table_name_cond ::= table_name", + /* 319 */ "from_db_opt ::=", + /* 320 */ "from_db_opt ::= FROM db_name", + /* 321 */ "tag_list_opt ::=", + /* 322 */ "tag_list_opt ::= tag_item", + /* 323 */ "tag_list_opt ::= tag_list_opt NK_COMMA tag_item", + /* 324 */ "tag_item ::= TBNAME", + /* 325 */ "tag_item ::= QTAGS", + /* 326 */ "tag_item ::= column_name", + /* 327 */ "tag_item ::= column_name column_alias", + /* 328 */ "tag_item ::= column_name AS column_alias", + /* 329 */ "db_kind_opt ::=", + /* 330 */ "db_kind_opt ::= USER", + /* 331 */ "db_kind_opt ::= SYSTEM", + /* 332 */ "cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options", + /* 333 */ "cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP", + /* 334 */ "cmd ::= DROP INDEX exists_opt full_index_name", + /* 335 */ "full_index_name ::= index_name", + /* 336 */ "full_index_name ::= db_name NK_DOT index_name", + /* 337 */ "index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt", + /* 338 */ "index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt", + /* 339 */ "func_list ::= func", + /* 340 */ "func_list ::= func_list NK_COMMA func", + /* 341 */ "func ::= sma_func_name NK_LP expression_list NK_RP", + /* 342 */ "sma_func_name ::= function_name", + /* 343 */ "sma_func_name ::= COUNT", + /* 344 */ "sma_func_name ::= FIRST", + /* 345 */ "sma_func_name ::= LAST", + /* 346 */ "sma_func_name ::= LAST_ROW", + /* 347 */ "sma_stream_opt ::=", + /* 348 */ "sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal", + /* 349 */ "sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal", + /* 350 */ "sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal", + /* 351 */ "with_meta ::= AS", + /* 352 */ "with_meta ::= WITH META AS", + /* 353 */ "with_meta ::= ONLY META AS", + /* 354 */ "cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery", + /* 355 */ "cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name", + /* 356 */ "cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt", + /* 357 */ "cmd ::= DROP TOPIC exists_opt topic_name", + /* 358 */ "cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name", + /* 359 */ "cmd ::= DESC full_table_name", + /* 360 */ "cmd ::= DESCRIBE full_table_name", + /* 361 */ "cmd ::= RESET QUERY CACHE", + /* 362 */ "cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery", + /* 363 */ "cmd ::= EXPLAIN analyze_opt explain_options insert_query", + /* 364 */ "analyze_opt ::=", + /* 365 */ "analyze_opt ::= ANALYZE", + /* 366 */ "explain_options ::=", + /* 367 */ "explain_options ::= explain_options VERBOSE NK_BOOL", + /* 368 */ "explain_options ::= explain_options RATIO NK_FLOAT", + /* 369 */ "cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt", + /* 370 */ "cmd ::= DROP FUNCTION exists_opt function_name", + /* 371 */ "agg_func_opt ::=", + /* 372 */ "agg_func_opt ::= AGGREGATE", + /* 373 */ "bufsize_opt ::=", + /* 374 */ "bufsize_opt ::= BUFSIZE NK_INTEGER", + /* 375 */ "language_opt ::=", + /* 376 */ "language_opt ::= LANGUAGE NK_STRING", + /* 377 */ "or_replace_opt ::=", + /* 378 */ "or_replace_opt ::= OR REPLACE", + /* 379 */ "cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery", + /* 380 */ "cmd ::= DROP VIEW exists_opt full_view_name", + /* 381 */ "full_view_name ::= view_name", + /* 382 */ "full_view_name ::= db_name NK_DOT view_name", + /* 383 */ "cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery", + /* 384 */ "cmd ::= DROP STREAM exists_opt stream_name", + /* 385 */ "cmd ::= PAUSE STREAM exists_opt stream_name", + /* 386 */ "cmd ::= RESUME STREAM exists_opt ignore_opt stream_name", + /* 387 */ "col_list_opt ::=", + /* 388 */ "col_list_opt ::= NK_LP column_stream_def_list NK_RP", + /* 389 */ "column_stream_def_list ::= column_stream_def", + /* 390 */ "column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def", + /* 391 */ "column_stream_def ::= column_name", + /* 392 */ "column_stream_def ::= column_name PRIMARY KEY", + /* 393 */ "tag_def_or_ref_opt ::=", + /* 394 */ "tag_def_or_ref_opt ::= tags_def", + /* 395 */ "tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP", + /* 396 */ "stream_options ::=", + /* 397 */ "stream_options ::= stream_options TRIGGER AT_ONCE", + /* 398 */ "stream_options ::= stream_options TRIGGER WINDOW_CLOSE", + /* 399 */ "stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal", + /* 400 */ "stream_options ::= stream_options WATERMARK duration_literal", + /* 401 */ "stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER", + /* 402 */ "stream_options ::= stream_options FILL_HISTORY NK_INTEGER", + /* 403 */ "stream_options ::= stream_options DELETE_MARK duration_literal", + /* 404 */ "stream_options ::= stream_options IGNORE UPDATE NK_INTEGER", + /* 405 */ "subtable_opt ::=", + /* 406 */ "subtable_opt ::= SUBTABLE NK_LP expression NK_RP", + /* 407 */ "ignore_opt ::=", + /* 408 */ "ignore_opt ::= IGNORE UNTREATED", + /* 409 */ "cmd ::= KILL CONNECTION NK_INTEGER", + /* 410 */ "cmd ::= KILL QUERY NK_STRING", + /* 411 */ "cmd ::= KILL TRANSACTION NK_INTEGER", + /* 412 */ "cmd ::= KILL COMPACT NK_INTEGER", + /* 413 */ "cmd ::= BALANCE VGROUP", + /* 414 */ "cmd ::= BALANCE VGROUP LEADER on_vgroup_id", + /* 415 */ "cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER", + /* 416 */ "cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list", + /* 417 */ "cmd ::= SPLIT VGROUP NK_INTEGER", + /* 418 */ "on_vgroup_id ::=", + /* 419 */ "on_vgroup_id ::= ON NK_INTEGER", + /* 420 */ "dnode_list ::= DNODE NK_INTEGER", + /* 421 */ "dnode_list ::= dnode_list DNODE NK_INTEGER", + /* 422 */ "cmd ::= DELETE FROM full_table_name where_clause_opt", + /* 423 */ "cmd ::= query_or_subquery", + /* 424 */ "cmd ::= insert_query", + /* 425 */ "insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery", + /* 426 */ "insert_query ::= INSERT INTO full_table_name query_or_subquery", + /* 427 */ "tags_literal ::= NK_INTEGER", + /* 428 */ "tags_literal ::= NK_INTEGER NK_PLUS duration_literal", + /* 429 */ "tags_literal ::= NK_INTEGER NK_MINUS duration_literal", + /* 430 */ "tags_literal ::= NK_PLUS NK_INTEGER", + /* 431 */ "tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal", + /* 432 */ "tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal", + /* 433 */ "tags_literal ::= NK_MINUS NK_INTEGER", + /* 434 */ "tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal", + /* 435 */ "tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal", + /* 436 */ "tags_literal ::= NK_FLOAT", + /* 437 */ "tags_literal ::= NK_PLUS NK_FLOAT", + /* 438 */ "tags_literal ::= NK_MINUS NK_FLOAT", + /* 439 */ "tags_literal ::= NK_BIN", + /* 440 */ "tags_literal ::= NK_BIN NK_PLUS duration_literal", + /* 441 */ "tags_literal ::= NK_BIN NK_MINUS duration_literal", + /* 442 */ "tags_literal ::= NK_PLUS NK_BIN", + /* 443 */ "tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal", + /* 444 */ "tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal", + /* 445 */ "tags_literal ::= NK_MINUS NK_BIN", + /* 446 */ "tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal", + /* 447 */ "tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal", + /* 448 */ "tags_literal ::= NK_HEX", + /* 449 */ "tags_literal ::= NK_HEX NK_PLUS duration_literal", + /* 450 */ "tags_literal ::= NK_HEX NK_MINUS duration_literal", + /* 451 */ "tags_literal ::= NK_PLUS NK_HEX", + /* 452 */ "tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal", + /* 453 */ "tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal", + /* 454 */ "tags_literal ::= NK_MINUS NK_HEX", + /* 455 */ "tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal", + /* 456 */ "tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal", + /* 457 */ "tags_literal ::= NK_STRING", + /* 458 */ "tags_literal ::= NK_STRING NK_PLUS duration_literal", + /* 459 */ "tags_literal ::= NK_STRING NK_MINUS duration_literal", + /* 460 */ "tags_literal ::= NK_BOOL", + /* 461 */ "tags_literal ::= NULL", + /* 462 */ "tags_literal ::= literal_func", + /* 463 */ "tags_literal ::= literal_func NK_PLUS duration_literal", + /* 464 */ "tags_literal ::= literal_func NK_MINUS duration_literal", + /* 465 */ "tags_literal_list ::= tags_literal", + /* 466 */ "tags_literal_list ::= tags_literal_list NK_COMMA tags_literal", + /* 467 */ "literal ::= NK_INTEGER", + /* 468 */ "literal ::= NK_FLOAT", + /* 469 */ "literal ::= NK_STRING", + /* 470 */ "literal ::= NK_BOOL", + /* 471 */ "literal ::= TIMESTAMP NK_STRING", + /* 472 */ "literal ::= duration_literal", + /* 473 */ "literal ::= NULL", + /* 474 */ "literal ::= NK_QUESTION", + /* 475 */ "duration_literal ::= NK_VARIABLE", + /* 476 */ "signed ::= NK_INTEGER", + /* 477 */ "signed ::= NK_PLUS NK_INTEGER", + /* 478 */ "signed ::= NK_MINUS NK_INTEGER", + /* 479 */ "signed ::= NK_FLOAT", + /* 480 */ "signed ::= NK_PLUS NK_FLOAT", + /* 481 */ "signed ::= NK_MINUS NK_FLOAT", + /* 482 */ "signed_literal ::= signed", + /* 483 */ "signed_literal ::= NK_STRING", + /* 484 */ "signed_literal ::= NK_BOOL", + /* 485 */ "signed_literal ::= TIMESTAMP NK_STRING", + /* 486 */ "signed_literal ::= duration_literal", + /* 487 */ "signed_literal ::= NULL", + /* 488 */ "signed_literal ::= literal_func", + /* 489 */ "signed_literal ::= NK_QUESTION", + /* 490 */ "literal_list ::= signed_literal", + /* 491 */ "literal_list ::= literal_list NK_COMMA signed_literal", + /* 492 */ "db_name ::= NK_ID", + /* 493 */ "table_name ::= NK_ID", + /* 494 */ "column_name ::= NK_ID", + /* 495 */ "function_name ::= NK_ID", + /* 496 */ "view_name ::= NK_ID", + /* 497 */ "table_alias ::= NK_ID", + /* 498 */ "column_alias ::= NK_ID", + /* 499 */ "column_alias ::= NK_ALIAS", + /* 500 */ "user_name ::= NK_ID", + /* 501 */ "topic_name ::= NK_ID", + /* 502 */ "stream_name ::= NK_ID", + /* 503 */ "cgroup_name ::= NK_ID", + /* 504 */ "index_name ::= NK_ID", + /* 505 */ "expr_or_subquery ::= expression", + /* 506 */ "expression ::= literal", + /* 507 */ "expression ::= pseudo_column", + /* 508 */ "expression ::= column_reference", + /* 509 */ "expression ::= function_expression", + /* 510 */ "expression ::= case_when_expression", + /* 511 */ "expression ::= NK_LP expression NK_RP", + /* 512 */ "expression ::= NK_PLUS expr_or_subquery", + /* 513 */ "expression ::= NK_MINUS expr_or_subquery", + /* 514 */ "expression ::= expr_or_subquery NK_PLUS expr_or_subquery", + /* 515 */ "expression ::= expr_or_subquery NK_MINUS expr_or_subquery", + /* 516 */ "expression ::= expr_or_subquery NK_STAR expr_or_subquery", + /* 517 */ "expression ::= expr_or_subquery NK_SLASH expr_or_subquery", + /* 518 */ "expression ::= expr_or_subquery NK_REM expr_or_subquery", + /* 519 */ "expression ::= column_reference NK_ARROW NK_STRING", + /* 520 */ "expression ::= expr_or_subquery NK_BITAND expr_or_subquery", + /* 521 */ "expression ::= expr_or_subquery NK_BITOR expr_or_subquery", + /* 522 */ "expression_list ::= expr_or_subquery", + /* 523 */ "expression_list ::= expression_list NK_COMMA expr_or_subquery", + /* 524 */ "column_reference ::= column_name", + /* 525 */ "column_reference ::= table_name NK_DOT column_name", + /* 526 */ "column_reference ::= NK_ALIAS", + /* 527 */ "column_reference ::= table_name NK_DOT NK_ALIAS", + /* 528 */ "pseudo_column ::= ROWTS", + /* 529 */ "pseudo_column ::= TBNAME", + /* 530 */ "pseudo_column ::= table_name NK_DOT TBNAME", + /* 531 */ "pseudo_column ::= QSTART", + /* 532 */ "pseudo_column ::= QEND", + /* 533 */ "pseudo_column ::= QDURATION", + /* 534 */ "pseudo_column ::= WSTART", + /* 535 */ "pseudo_column ::= WEND", + /* 536 */ "pseudo_column ::= WDURATION", + /* 537 */ "pseudo_column ::= IROWTS", + /* 538 */ "pseudo_column ::= ISFILLED", + /* 539 */ "pseudo_column ::= QTAGS", + /* 540 */ "function_expression ::= function_name NK_LP expression_list NK_RP", + /* 541 */ "function_expression ::= star_func NK_LP star_func_para_list NK_RP", + /* 542 */ "function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP", + /* 543 */ "function_expression ::= CAST NK_LP expr_or_subquery AS type_name_default_len NK_RP", + /* 544 */ "function_expression ::= literal_func", + /* 545 */ "literal_func ::= noarg_func NK_LP NK_RP", + /* 546 */ "literal_func ::= NOW", + /* 547 */ "literal_func ::= TODAY", + /* 548 */ "noarg_func ::= NOW", + /* 549 */ "noarg_func ::= TODAY", + /* 550 */ "noarg_func ::= TIMEZONE", + /* 551 */ "noarg_func ::= DATABASE", + /* 552 */ "noarg_func ::= CLIENT_VERSION", + /* 553 */ "noarg_func ::= SERVER_VERSION", + /* 554 */ "noarg_func ::= SERVER_STATUS", + /* 555 */ "noarg_func ::= CURRENT_USER", + /* 556 */ "noarg_func ::= USER", + /* 557 */ "star_func ::= COUNT", + /* 558 */ "star_func ::= FIRST", + /* 559 */ "star_func ::= LAST", + /* 560 */ "star_func ::= LAST_ROW", + /* 561 */ "star_func_para_list ::= NK_STAR", + /* 562 */ "star_func_para_list ::= other_para_list", + /* 563 */ "other_para_list ::= star_func_para", + /* 564 */ "other_para_list ::= other_para_list NK_COMMA star_func_para", + /* 565 */ "star_func_para ::= expr_or_subquery", + /* 566 */ "star_func_para ::= table_name NK_DOT NK_STAR", + /* 567 */ "case_when_expression ::= CASE when_then_list case_when_else_opt END", + /* 568 */ "case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END", + /* 569 */ "when_then_list ::= when_then_expr", + /* 570 */ "when_then_list ::= when_then_list when_then_expr", + /* 571 */ "when_then_expr ::= WHEN common_expression THEN common_expression", + /* 572 */ "case_when_else_opt ::=", + /* 573 */ "case_when_else_opt ::= ELSE common_expression", + /* 574 */ "predicate ::= expr_or_subquery compare_op expr_or_subquery", + /* 575 */ "predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery", + /* 576 */ "predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery", + /* 577 */ "predicate ::= expr_or_subquery IS NULL", + /* 578 */ "predicate ::= expr_or_subquery IS NOT NULL", + /* 579 */ "predicate ::= expr_or_subquery in_op in_predicate_value", + /* 580 */ "compare_op ::= NK_LT", + /* 581 */ "compare_op ::= NK_GT", + /* 582 */ "compare_op ::= NK_LE", + /* 583 */ "compare_op ::= NK_GE", + /* 584 */ "compare_op ::= NK_NE", + /* 585 */ "compare_op ::= NK_EQ", + /* 586 */ "compare_op ::= LIKE", + /* 587 */ "compare_op ::= NOT LIKE", + /* 588 */ "compare_op ::= MATCH", + /* 589 */ "compare_op ::= NMATCH", + /* 590 */ "compare_op ::= CONTAINS", + /* 591 */ "in_op ::= IN", + /* 592 */ "in_op ::= NOT IN", + /* 593 */ "in_predicate_value ::= NK_LP literal_list NK_RP", + /* 594 */ "boolean_value_expression ::= boolean_primary", + /* 595 */ "boolean_value_expression ::= NOT boolean_primary", + /* 596 */ "boolean_value_expression ::= boolean_value_expression OR boolean_value_expression", + /* 597 */ "boolean_value_expression ::= boolean_value_expression AND boolean_value_expression", + /* 598 */ "boolean_primary ::= predicate", + /* 599 */ "boolean_primary ::= NK_LP boolean_value_expression NK_RP", + /* 600 */ "common_expression ::= expr_or_subquery", + /* 601 */ "common_expression ::= boolean_value_expression", + /* 602 */ "from_clause_opt ::=", + /* 603 */ "from_clause_opt ::= FROM table_reference_list", + /* 604 */ "table_reference_list ::= table_reference", + /* 605 */ "table_reference_list ::= table_reference_list NK_COMMA table_reference", + /* 606 */ "table_reference ::= table_primary", + /* 607 */ "table_reference ::= joined_table", + /* 608 */ "table_primary ::= table_name alias_opt", + /* 609 */ "table_primary ::= db_name NK_DOT table_name alias_opt", + /* 610 */ "table_primary ::= subquery alias_opt", + /* 611 */ "table_primary ::= parenthesized_joined_table", + /* 612 */ "alias_opt ::=", + /* 613 */ "alias_opt ::= table_alias", + /* 614 */ "alias_opt ::= AS table_alias", + /* 615 */ "parenthesized_joined_table ::= NK_LP joined_table NK_RP", + /* 616 */ "parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP", + /* 617 */ "joined_table ::= table_reference join_type JOIN table_reference ON search_condition", + /* 618 */ "join_type ::=", + /* 619 */ "join_type ::= INNER", + /* 620 */ "query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt", + /* 621 */ "hint_list ::=", + /* 622 */ "hint_list ::= NK_HINT", + /* 623 */ "tag_mode_opt ::=", + /* 624 */ "tag_mode_opt ::= TAGS", + /* 625 */ "set_quantifier_opt ::=", + /* 626 */ "set_quantifier_opt ::= DISTINCT", + /* 627 */ "set_quantifier_opt ::= ALL", + /* 628 */ "select_list ::= select_item", + /* 629 */ "select_list ::= select_list NK_COMMA select_item", + /* 630 */ "select_item ::= NK_STAR", + /* 631 */ "select_item ::= common_expression", + /* 632 */ "select_item ::= common_expression column_alias", + /* 633 */ "select_item ::= common_expression AS column_alias", + /* 634 */ "select_item ::= table_name NK_DOT NK_STAR", + /* 635 */ "where_clause_opt ::=", + /* 636 */ "where_clause_opt ::= WHERE search_condition", + /* 637 */ "partition_by_clause_opt ::=", + /* 638 */ "partition_by_clause_opt ::= PARTITION BY partition_list", + /* 639 */ "partition_list ::= partition_item", + /* 640 */ "partition_list ::= partition_list NK_COMMA partition_item", + /* 641 */ "partition_item ::= expr_or_subquery", + /* 642 */ "partition_item ::= expr_or_subquery column_alias", + /* 643 */ "partition_item ::= expr_or_subquery AS column_alias", + /* 644 */ "twindow_clause_opt ::=", + /* 645 */ "twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP", + /* 646 */ "twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP", + /* 647 */ "twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt", + /* 648 */ "twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt", + /* 649 */ "twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition", + /* 650 */ "twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP", + /* 651 */ "twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP", + /* 652 */ "sliding_opt ::=", + /* 653 */ "sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP", + /* 654 */ "interval_sliding_duration_literal ::= NK_VARIABLE", + /* 655 */ "interval_sliding_duration_literal ::= NK_STRING", + /* 656 */ "interval_sliding_duration_literal ::= NK_INTEGER", + /* 657 */ "fill_opt ::=", + /* 658 */ "fill_opt ::= FILL NK_LP fill_mode NK_RP", + /* 659 */ "fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP", + /* 660 */ "fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP", + /* 661 */ "fill_mode ::= NONE", + /* 662 */ "fill_mode ::= PREV", + /* 663 */ "fill_mode ::= NULL", + /* 664 */ "fill_mode ::= NULL_F", + /* 665 */ "fill_mode ::= LINEAR", + /* 666 */ "fill_mode ::= NEXT", + /* 667 */ "group_by_clause_opt ::=", + /* 668 */ "group_by_clause_opt ::= GROUP BY group_by_list", + /* 669 */ "group_by_list ::= expr_or_subquery", + /* 670 */ "group_by_list ::= group_by_list NK_COMMA expr_or_subquery", + /* 671 */ "having_clause_opt ::=", + /* 672 */ "having_clause_opt ::= HAVING search_condition", + /* 673 */ "range_opt ::=", + /* 674 */ "range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP", + /* 675 */ "range_opt ::= RANGE NK_LP expr_or_subquery NK_RP", + /* 676 */ "every_opt ::=", + /* 677 */ "every_opt ::= EVERY NK_LP duration_literal NK_RP", + /* 678 */ "query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt", + /* 679 */ "query_simple ::= query_specification", + /* 680 */ "query_simple ::= union_query_expression", + /* 681 */ "union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery", + /* 682 */ "union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery", + /* 683 */ "query_simple_or_subquery ::= query_simple", + /* 684 */ "query_simple_or_subquery ::= subquery", + /* 685 */ "query_or_subquery ::= query_expression", + /* 686 */ "query_or_subquery ::= subquery", + /* 687 */ "order_by_clause_opt ::=", + /* 688 */ "order_by_clause_opt ::= ORDER BY sort_specification_list", + /* 689 */ "slimit_clause_opt ::=", + /* 690 */ "slimit_clause_opt ::= SLIMIT NK_INTEGER", + /* 691 */ "slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER", + /* 692 */ "slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER", + /* 693 */ "limit_clause_opt ::=", + /* 694 */ "limit_clause_opt ::= LIMIT NK_INTEGER", + /* 695 */ "limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER", + /* 696 */ "limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER", + /* 697 */ "subquery ::= NK_LP query_expression NK_RP", + /* 698 */ "subquery ::= NK_LP subquery NK_RP", + /* 699 */ "search_condition ::= common_expression", + /* 700 */ "sort_specification_list ::= sort_specification", + /* 701 */ "sort_specification_list ::= sort_specification_list NK_COMMA sort_specification", + /* 702 */ "sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt", + /* 703 */ "ordering_specification_opt ::=", + /* 704 */ "ordering_specification_opt ::= ASC", + /* 705 */ "ordering_specification_opt ::= DESC", + /* 706 */ "null_ordering_opt ::=", + /* 707 */ "null_ordering_opt ::= NULLS FIRST", + /* 708 */ "null_ordering_opt ::= NULLS LAST", }; #endif /* NDEBUG */ @@ -3298,82 +3346,82 @@ static void yy_destructor( case 406: /* create_subtable_clause */ case 409: /* drop_table_clause */ case 411: /* column_def */ - case 415: /* duration_literal */ - case 416: /* rollup_func_name */ - case 418: /* col_name */ - case 421: /* like_pattern_opt */ - case 422: /* db_name_cond_opt */ - case 423: /* table_name_cond */ - case 424: /* from_db_opt */ - case 427: /* tag_item */ - case 429: /* index_options */ - case 430: /* full_index_name */ - case 433: /* sliding_opt */ - case 434: /* sma_stream_opt */ - case 435: /* func */ - case 439: /* query_or_subquery */ - case 440: /* where_clause_opt */ - case 443: /* explain_options */ - case 444: /* insert_query */ - case 449: /* full_view_name */ - case 452: /* stream_options */ - case 455: /* subtable_opt */ - case 458: /* column_stream_def */ - case 459: /* expression */ - case 462: /* literal_func */ - case 463: /* signed_literal */ - case 466: /* expr_or_subquery */ - case 467: /* pseudo_column */ - case 468: /* column_reference */ - case 469: /* function_expression */ - case 470: /* case_when_expression */ - case 475: /* star_func_para */ - case 477: /* case_when_else_opt */ - case 478: /* common_expression */ - case 479: /* when_then_expr */ - case 480: /* predicate */ - case 483: /* in_predicate_value */ - case 484: /* boolean_value_expression */ - case 485: /* boolean_primary */ - case 486: /* from_clause_opt */ - case 487: /* table_reference_list */ - case 488: /* table_reference */ - case 489: /* table_primary */ - case 490: /* joined_table */ - case 492: /* subquery */ - case 493: /* parenthesized_joined_table */ - case 495: /* query_specification */ - case 501: /* range_opt */ - case 502: /* every_opt */ - case 503: /* fill_opt */ - case 504: /* twindow_clause_opt */ - case 506: /* having_clause_opt */ - case 507: /* select_item */ - case 509: /* partition_item */ - case 510: /* interval_sliding_duration_literal */ - case 513: /* query_expression */ - case 514: /* query_simple */ - case 516: /* slimit_clause_opt */ - case 517: /* limit_clause_opt */ - case 518: /* union_query_expression */ - case 519: /* query_simple_or_subquery */ - case 521: /* sort_specification */ + case 416: /* duration_literal */ + case 417: /* rollup_func_name */ + case 419: /* col_name */ + case 422: /* like_pattern_opt */ + case 423: /* db_name_cond_opt */ + case 424: /* table_name_cond */ + case 425: /* from_db_opt */ + case 428: /* tag_item */ + case 430: /* index_options */ + case 431: /* full_index_name */ + case 434: /* sliding_opt */ + case 435: /* sma_stream_opt */ + case 436: /* func */ + case 440: /* query_or_subquery */ + case 441: /* where_clause_opt */ + case 444: /* explain_options */ + case 445: /* insert_query */ + case 450: /* full_view_name */ + case 453: /* stream_options */ + case 456: /* subtable_opt */ + case 459: /* column_stream_def */ + case 460: /* expression */ + case 463: /* literal_func */ + case 464: /* signed_literal */ + case 467: /* expr_or_subquery */ + case 468: /* pseudo_column */ + case 469: /* column_reference */ + case 470: /* function_expression */ + case 471: /* case_when_expression */ + case 476: /* star_func_para */ + case 478: /* case_when_else_opt */ + case 479: /* common_expression */ + case 480: /* when_then_expr */ + case 481: /* predicate */ + case 484: /* in_predicate_value */ + case 485: /* boolean_value_expression */ + case 486: /* boolean_primary */ + case 487: /* from_clause_opt */ + case 488: /* table_reference_list */ + case 489: /* table_reference */ + case 490: /* table_primary */ + case 491: /* joined_table */ + case 493: /* subquery */ + case 494: /* parenthesized_joined_table */ + case 496: /* query_specification */ + case 502: /* range_opt */ + case 503: /* every_opt */ + case 504: /* fill_opt */ + case 505: /* twindow_clause_opt */ + case 507: /* having_clause_opt */ + case 508: /* select_item */ + case 510: /* partition_item */ + case 511: /* interval_sliding_duration_literal */ + case 514: /* query_expression */ + case 515: /* query_simple */ + case 517: /* slimit_clause_opt */ + case 518: /* limit_clause_opt */ + case 519: /* union_query_expression */ + case 520: /* query_simple_or_subquery */ + case 522: /* sort_specification */ { #line 7 "sql.y" - nodesDestroyNode((yypminor->yy1000)); -#line 3364 "sql.c" + nodesDestroyNode((yypminor->yy812)); +#line 3412 "sql.c" } break; case 360: /* account_options */ case 361: /* alter_account_options */ case 363: /* alter_account_option */ case 385: /* speed_opt */ - case 438: /* with_meta */ - case 447: /* bufsize_opt */ + case 439: /* with_meta */ + case 448: /* bufsize_opt */ { #line 54 "sql.y" -#line 3376 "sql.c" +#line 3424 "sql.c" } break; case 364: /* ip_range_list */ @@ -3390,31 +3438,31 @@ static void yy_destructor( case 407: /* specific_cols_opt */ case 408: /* tags_literal_list */ case 410: /* col_name_list */ - case 412: /* duration_list */ - case 413: /* rollup_func_list */ - case 425: /* tag_list_opt */ - case 432: /* func_list */ - case 437: /* expression_list */ - case 453: /* col_list_opt */ - case 454: /* tag_def_or_ref_opt */ - case 457: /* column_stream_def_list */ - case 461: /* dnode_list */ - case 464: /* literal_list */ - case 472: /* star_func_para_list */ - case 474: /* other_para_list */ - case 476: /* when_then_list */ - case 496: /* hint_list */ - case 499: /* select_list */ - case 500: /* partition_by_clause_opt */ - case 505: /* group_by_clause_opt */ - case 508: /* partition_list */ - case 512: /* group_by_list */ - case 515: /* order_by_clause_opt */ - case 520: /* sort_specification_list */ + case 413: /* duration_list */ + case 414: /* rollup_func_list */ + case 426: /* tag_list_opt */ + case 433: /* func_list */ + case 438: /* expression_list */ + case 454: /* col_list_opt */ + case 455: /* tag_def_or_ref_opt */ + case 458: /* column_stream_def_list */ + case 462: /* dnode_list */ + case 465: /* literal_list */ + case 473: /* star_func_para_list */ + case 475: /* other_para_list */ + case 477: /* when_then_list */ + case 497: /* hint_list */ + case 500: /* select_list */ + case 501: /* partition_by_clause_opt */ + case 506: /* group_by_clause_opt */ + case 509: /* partition_list */ + case 513: /* group_by_list */ + case 516: /* order_by_clause_opt */ + case 521: /* sort_specification_list */ { #line 85 "sql.y" - nodesDestroyList((yypminor->yy72)); -#line 3417 "sql.c" + nodesDestroyList((yypminor->yy124)); +#line 3465 "sql.c" } break; case 367: /* user_name */ @@ -3423,30 +3471,30 @@ static void yy_destructor( case 376: /* topic_name */ case 378: /* dnode_endpoint */ case 403: /* column_name */ - case 417: /* function_name */ - case 428: /* column_alias */ - case 431: /* index_name */ - case 436: /* sma_func_name */ - case 441: /* cgroup_name */ - case 448: /* language_opt */ - case 450: /* view_name */ - case 451: /* stream_name */ - case 460: /* on_vgroup_id */ - case 465: /* table_alias */ - case 471: /* star_func */ - case 473: /* noarg_func */ - case 491: /* alias_opt */ + case 418: /* function_name */ + case 429: /* column_alias */ + case 432: /* index_name */ + case 437: /* sma_func_name */ + case 442: /* cgroup_name */ + case 449: /* language_opt */ + case 451: /* view_name */ + case 452: /* stream_name */ + case 461: /* on_vgroup_id */ + case 466: /* table_alias */ + case 472: /* star_func */ + case 474: /* noarg_func */ + case 492: /* alias_opt */ { -#line 1029 "sql.y" +#line 1036 "sql.y" -#line 3442 "sql.c" +#line 3490 "sql.c" } break; case 368: /* sysinfo_opt */ { #line 112 "sql.y" -#line 3449 "sql.c" +#line 3497 "sql.c" } break; case 369: /* privileges */ @@ -3455,96 +3503,97 @@ static void yy_destructor( { #line 121 "sql.y" -#line 3458 "sql.c" +#line 3506 "sql.c" } break; case 370: /* priv_level */ { #line 138 "sql.y" -#line 3465 "sql.c" +#line 3513 "sql.c" } break; case 379: /* force_opt */ case 380: /* unsafe_opt */ case 381: /* not_exists_opt */ case 383: /* exists_opt */ - case 442: /* analyze_opt */ - case 445: /* or_replace_opt */ - case 446: /* agg_func_opt */ - case 456: /* ignore_opt */ - case 497: /* set_quantifier_opt */ - case 498: /* tag_mode_opt */ + case 443: /* analyze_opt */ + case 446: /* or_replace_opt */ + case 447: /* agg_func_opt */ + case 457: /* ignore_opt */ + case 498: /* set_quantifier_opt */ + case 499: /* tag_mode_opt */ { #line 167 "sql.y" -#line 3481 "sql.c" +#line 3529 "sql.c" } break; case 392: /* alter_db_option */ - case 414: /* alter_table_option */ + case 415: /* alter_table_option */ { #line 274 "sql.y" -#line 3489 "sql.c" +#line 3537 "sql.c" } break; case 404: /* type_name */ + case 412: /* type_name_default_len */ { #line 401 "sql.y" -#line 3496 "sql.c" +#line 3545 "sql.c" } break; - case 419: /* db_kind_opt */ - case 426: /* table_kind */ + case 420: /* db_kind_opt */ + case 427: /* table_kind */ { -#line 570 "sql.y" +#line 577 "sql.y" -#line 3504 "sql.c" +#line 3553 "sql.c" } break; - case 420: /* table_kind_db_name_cond_opt */ + case 421: /* table_kind_db_name_cond_opt */ { -#line 535 "sql.y" +#line 542 "sql.y" -#line 3511 "sql.c" +#line 3560 "sql.c" } break; - case 481: /* compare_op */ - case 482: /* in_op */ + case 482: /* compare_op */ + case 483: /* in_op */ { -#line 1220 "sql.y" +#line 1230 "sql.y" -#line 3519 "sql.c" +#line 3568 "sql.c" } break; - case 494: /* join_type */ + case 495: /* join_type */ { -#line 1296 "sql.y" +#line 1306 "sql.y" -#line 3526 "sql.c" +#line 3575 "sql.c" } break; - case 511: /* fill_mode */ + case 512: /* fill_mode */ { -#line 1391 "sql.y" +#line 1401 "sql.y" -#line 3533 "sql.c" +#line 3582 "sql.c" } break; - case 522: /* ordering_specification_opt */ + case 523: /* ordering_specification_opt */ { -#line 1476 "sql.y" +#line 1486 "sql.y" -#line 3540 "sql.c" +#line 3589 "sql.c" } break; - case 523: /* null_ordering_opt */ + case 524: /* null_ordering_opt */ { -#line 1482 "sql.y" +#line 1492 "sql.y" -#line 3547 "sql.c" +#line 3596 "sql.c" } break; /********* End destructor definitions *****************************************/ @@ -4061,482 +4110,487 @@ static const YYCODETYPE yyRuleInfoLhs[] = { 404, /* (225) type_name ::= DECIMAL */ 404, /* (226) type_name ::= DECIMAL NK_LP NK_INTEGER NK_RP */ 404, /* (227) type_name ::= DECIMAL NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ - 396, /* (228) tags_def_opt ::= */ - 396, /* (229) tags_def_opt ::= tags_def */ - 399, /* (230) tags_def ::= TAGS NK_LP column_def_list NK_RP */ - 397, /* (231) table_options ::= */ - 397, /* (232) table_options ::= table_options COMMENT NK_STRING */ - 397, /* (233) table_options ::= table_options MAX_DELAY duration_list */ - 397, /* (234) table_options ::= table_options WATERMARK duration_list */ - 397, /* (235) table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP */ - 397, /* (236) table_options ::= table_options TTL NK_INTEGER */ - 397, /* (237) table_options ::= table_options SMA NK_LP col_name_list NK_RP */ - 397, /* (238) table_options ::= table_options DELETE_MARK duration_list */ - 402, /* (239) alter_table_options ::= alter_table_option */ - 402, /* (240) alter_table_options ::= alter_table_options alter_table_option */ - 414, /* (241) alter_table_option ::= COMMENT NK_STRING */ - 414, /* (242) alter_table_option ::= TTL NK_INTEGER */ - 412, /* (243) duration_list ::= duration_literal */ - 412, /* (244) duration_list ::= duration_list NK_COMMA duration_literal */ - 413, /* (245) rollup_func_list ::= rollup_func_name */ - 413, /* (246) rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name */ - 416, /* (247) rollup_func_name ::= function_name */ - 416, /* (248) rollup_func_name ::= FIRST */ - 416, /* (249) rollup_func_name ::= LAST */ - 410, /* (250) col_name_list ::= col_name */ - 410, /* (251) col_name_list ::= col_name_list NK_COMMA col_name */ - 418, /* (252) col_name ::= column_name */ - 359, /* (253) cmd ::= SHOW DNODES */ - 359, /* (254) cmd ::= SHOW USERS */ - 359, /* (255) cmd ::= SHOW USER PRIVILEGES */ - 359, /* (256) cmd ::= SHOW db_kind_opt DATABASES */ - 359, /* (257) cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt */ - 359, /* (258) cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt */ - 359, /* (259) cmd ::= SHOW db_name_cond_opt VGROUPS */ - 359, /* (260) cmd ::= SHOW MNODES */ - 359, /* (261) cmd ::= SHOW QNODES */ - 359, /* (262) cmd ::= SHOW ARBGROUPS */ - 359, /* (263) cmd ::= SHOW FUNCTIONS */ - 359, /* (264) cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt */ - 359, /* (265) cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name */ - 359, /* (266) cmd ::= SHOW STREAMS */ - 359, /* (267) cmd ::= SHOW ACCOUNTS */ - 359, /* (268) cmd ::= SHOW APPS */ - 359, /* (269) cmd ::= SHOW CONNECTIONS */ - 359, /* (270) cmd ::= SHOW LICENCES */ - 359, /* (271) cmd ::= SHOW GRANTS */ - 359, /* (272) cmd ::= SHOW GRANTS FULL */ - 359, /* (273) cmd ::= SHOW GRANTS LOGS */ - 359, /* (274) cmd ::= SHOW CLUSTER MACHINES */ - 359, /* (275) cmd ::= SHOW CREATE DATABASE db_name */ - 359, /* (276) cmd ::= SHOW CREATE TABLE full_table_name */ - 359, /* (277) cmd ::= SHOW CREATE STABLE full_table_name */ - 359, /* (278) cmd ::= SHOW QUERIES */ - 359, /* (279) cmd ::= SHOW SCORES */ - 359, /* (280) cmd ::= SHOW TOPICS */ - 359, /* (281) cmd ::= SHOW VARIABLES */ - 359, /* (282) cmd ::= SHOW CLUSTER VARIABLES */ - 359, /* (283) cmd ::= SHOW LOCAL VARIABLES */ - 359, /* (284) cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt */ - 359, /* (285) cmd ::= SHOW BNODES */ - 359, /* (286) cmd ::= SHOW SNODES */ - 359, /* (287) cmd ::= SHOW CLUSTER */ - 359, /* (288) cmd ::= SHOW TRANSACTIONS */ - 359, /* (289) cmd ::= SHOW TABLE DISTRIBUTED full_table_name */ - 359, /* (290) cmd ::= SHOW CONSUMERS */ - 359, /* (291) cmd ::= SHOW SUBSCRIPTIONS */ - 359, /* (292) cmd ::= SHOW TAGS FROM table_name_cond from_db_opt */ - 359, /* (293) cmd ::= SHOW TAGS FROM db_name NK_DOT table_name */ - 359, /* (294) cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt */ - 359, /* (295) cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name */ - 359, /* (296) cmd ::= SHOW VNODES ON DNODE NK_INTEGER */ - 359, /* (297) cmd ::= SHOW VNODES */ - 359, /* (298) cmd ::= SHOW db_name_cond_opt ALIVE */ - 359, /* (299) cmd ::= SHOW CLUSTER ALIVE */ - 359, /* (300) cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt */ - 359, /* (301) cmd ::= SHOW CREATE VIEW full_table_name */ - 359, /* (302) cmd ::= SHOW COMPACTS */ - 359, /* (303) cmd ::= SHOW COMPACT NK_INTEGER */ - 420, /* (304) table_kind_db_name_cond_opt ::= */ - 420, /* (305) table_kind_db_name_cond_opt ::= table_kind */ - 420, /* (306) table_kind_db_name_cond_opt ::= db_name NK_DOT */ - 420, /* (307) table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT */ - 426, /* (308) table_kind ::= NORMAL */ - 426, /* (309) table_kind ::= CHILD */ - 422, /* (310) db_name_cond_opt ::= */ - 422, /* (311) db_name_cond_opt ::= db_name NK_DOT */ - 421, /* (312) like_pattern_opt ::= */ - 421, /* (313) like_pattern_opt ::= LIKE NK_STRING */ - 423, /* (314) table_name_cond ::= table_name */ - 424, /* (315) from_db_opt ::= */ - 424, /* (316) from_db_opt ::= FROM db_name */ - 425, /* (317) tag_list_opt ::= */ - 425, /* (318) tag_list_opt ::= tag_item */ - 425, /* (319) tag_list_opt ::= tag_list_opt NK_COMMA tag_item */ - 427, /* (320) tag_item ::= TBNAME */ - 427, /* (321) tag_item ::= QTAGS */ - 427, /* (322) tag_item ::= column_name */ - 427, /* (323) tag_item ::= column_name column_alias */ - 427, /* (324) tag_item ::= column_name AS column_alias */ - 419, /* (325) db_kind_opt ::= */ - 419, /* (326) db_kind_opt ::= USER */ - 419, /* (327) db_kind_opt ::= SYSTEM */ - 359, /* (328) cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options */ - 359, /* (329) cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP */ - 359, /* (330) cmd ::= DROP INDEX exists_opt full_index_name */ - 430, /* (331) full_index_name ::= index_name */ - 430, /* (332) full_index_name ::= db_name NK_DOT index_name */ - 429, /* (333) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt */ - 429, /* (334) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt */ - 432, /* (335) func_list ::= func */ - 432, /* (336) func_list ::= func_list NK_COMMA func */ - 435, /* (337) func ::= sma_func_name NK_LP expression_list NK_RP */ - 436, /* (338) sma_func_name ::= function_name */ - 436, /* (339) sma_func_name ::= COUNT */ - 436, /* (340) sma_func_name ::= FIRST */ - 436, /* (341) sma_func_name ::= LAST */ - 436, /* (342) sma_func_name ::= LAST_ROW */ - 434, /* (343) sma_stream_opt ::= */ - 434, /* (344) sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal */ - 434, /* (345) sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal */ - 434, /* (346) sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal */ - 438, /* (347) with_meta ::= AS */ - 438, /* (348) with_meta ::= WITH META AS */ - 438, /* (349) with_meta ::= ONLY META AS */ - 359, /* (350) cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery */ - 359, /* (351) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name */ - 359, /* (352) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt */ - 359, /* (353) cmd ::= DROP TOPIC exists_opt topic_name */ - 359, /* (354) cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name */ - 359, /* (355) cmd ::= DESC full_table_name */ - 359, /* (356) cmd ::= DESCRIBE full_table_name */ - 359, /* (357) cmd ::= RESET QUERY CACHE */ - 359, /* (358) cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery */ - 359, /* (359) cmd ::= EXPLAIN analyze_opt explain_options insert_query */ - 442, /* (360) analyze_opt ::= */ - 442, /* (361) analyze_opt ::= ANALYZE */ - 443, /* (362) explain_options ::= */ - 443, /* (363) explain_options ::= explain_options VERBOSE NK_BOOL */ - 443, /* (364) explain_options ::= explain_options RATIO NK_FLOAT */ - 359, /* (365) cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt */ - 359, /* (366) cmd ::= DROP FUNCTION exists_opt function_name */ - 446, /* (367) agg_func_opt ::= */ - 446, /* (368) agg_func_opt ::= AGGREGATE */ - 447, /* (369) bufsize_opt ::= */ - 447, /* (370) bufsize_opt ::= BUFSIZE NK_INTEGER */ - 448, /* (371) language_opt ::= */ - 448, /* (372) language_opt ::= LANGUAGE NK_STRING */ - 445, /* (373) or_replace_opt ::= */ - 445, /* (374) or_replace_opt ::= OR REPLACE */ - 359, /* (375) cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery */ - 359, /* (376) cmd ::= DROP VIEW exists_opt full_view_name */ - 449, /* (377) full_view_name ::= view_name */ - 449, /* (378) full_view_name ::= db_name NK_DOT view_name */ - 359, /* (379) cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery */ - 359, /* (380) cmd ::= DROP STREAM exists_opt stream_name */ - 359, /* (381) cmd ::= PAUSE STREAM exists_opt stream_name */ - 359, /* (382) cmd ::= RESUME STREAM exists_opt ignore_opt stream_name */ - 453, /* (383) col_list_opt ::= */ - 453, /* (384) col_list_opt ::= NK_LP column_stream_def_list NK_RP */ - 457, /* (385) column_stream_def_list ::= column_stream_def */ - 457, /* (386) column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def */ - 458, /* (387) column_stream_def ::= column_name */ - 458, /* (388) column_stream_def ::= column_name PRIMARY KEY */ - 454, /* (389) tag_def_or_ref_opt ::= */ - 454, /* (390) tag_def_or_ref_opt ::= tags_def */ - 454, /* (391) tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP */ - 452, /* (392) stream_options ::= */ - 452, /* (393) stream_options ::= stream_options TRIGGER AT_ONCE */ - 452, /* (394) stream_options ::= stream_options TRIGGER WINDOW_CLOSE */ - 452, /* (395) stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal */ - 452, /* (396) stream_options ::= stream_options WATERMARK duration_literal */ - 452, /* (397) stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER */ - 452, /* (398) stream_options ::= stream_options FILL_HISTORY NK_INTEGER */ - 452, /* (399) stream_options ::= stream_options DELETE_MARK duration_literal */ - 452, /* (400) stream_options ::= stream_options IGNORE UPDATE NK_INTEGER */ - 455, /* (401) subtable_opt ::= */ - 455, /* (402) subtable_opt ::= SUBTABLE NK_LP expression NK_RP */ - 456, /* (403) ignore_opt ::= */ - 456, /* (404) ignore_opt ::= IGNORE UNTREATED */ - 359, /* (405) cmd ::= KILL CONNECTION NK_INTEGER */ - 359, /* (406) cmd ::= KILL QUERY NK_STRING */ - 359, /* (407) cmd ::= KILL TRANSACTION NK_INTEGER */ - 359, /* (408) cmd ::= KILL COMPACT NK_INTEGER */ - 359, /* (409) cmd ::= BALANCE VGROUP */ - 359, /* (410) cmd ::= BALANCE VGROUP LEADER on_vgroup_id */ - 359, /* (411) cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER */ - 359, /* (412) cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list */ - 359, /* (413) cmd ::= SPLIT VGROUP NK_INTEGER */ - 460, /* (414) on_vgroup_id ::= */ - 460, /* (415) on_vgroup_id ::= ON NK_INTEGER */ - 461, /* (416) dnode_list ::= DNODE NK_INTEGER */ - 461, /* (417) dnode_list ::= dnode_list DNODE NK_INTEGER */ - 359, /* (418) cmd ::= DELETE FROM full_table_name where_clause_opt */ - 359, /* (419) cmd ::= query_or_subquery */ - 359, /* (420) cmd ::= insert_query */ - 444, /* (421) insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery */ - 444, /* (422) insert_query ::= INSERT INTO full_table_name query_or_subquery */ - 405, /* (423) tags_literal ::= NK_INTEGER */ - 405, /* (424) tags_literal ::= NK_INTEGER NK_PLUS duration_literal */ - 405, /* (425) tags_literal ::= NK_INTEGER NK_MINUS duration_literal */ - 405, /* (426) tags_literal ::= NK_PLUS NK_INTEGER */ - 405, /* (427) tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal */ - 405, /* (428) tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal */ - 405, /* (429) tags_literal ::= NK_MINUS NK_INTEGER */ - 405, /* (430) tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal */ - 405, /* (431) tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal */ - 405, /* (432) tags_literal ::= NK_FLOAT */ - 405, /* (433) tags_literal ::= NK_PLUS NK_FLOAT */ - 405, /* (434) tags_literal ::= NK_MINUS NK_FLOAT */ - 405, /* (435) tags_literal ::= NK_BIN */ - 405, /* (436) tags_literal ::= NK_BIN NK_PLUS duration_literal */ - 405, /* (437) tags_literal ::= NK_BIN NK_MINUS duration_literal */ - 405, /* (438) tags_literal ::= NK_PLUS NK_BIN */ - 405, /* (439) tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal */ - 405, /* (440) tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal */ - 405, /* (441) tags_literal ::= NK_MINUS NK_BIN */ - 405, /* (442) tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal */ - 405, /* (443) tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal */ - 405, /* (444) tags_literal ::= NK_HEX */ - 405, /* (445) tags_literal ::= NK_HEX NK_PLUS duration_literal */ - 405, /* (446) tags_literal ::= NK_HEX NK_MINUS duration_literal */ - 405, /* (447) tags_literal ::= NK_PLUS NK_HEX */ - 405, /* (448) tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal */ - 405, /* (449) tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal */ - 405, /* (450) tags_literal ::= NK_MINUS NK_HEX */ - 405, /* (451) tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal */ - 405, /* (452) tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal */ - 405, /* (453) tags_literal ::= NK_STRING */ - 405, /* (454) tags_literal ::= NK_STRING NK_PLUS duration_literal */ - 405, /* (455) tags_literal ::= NK_STRING NK_MINUS duration_literal */ - 405, /* (456) tags_literal ::= NK_BOOL */ - 405, /* (457) tags_literal ::= NULL */ - 405, /* (458) tags_literal ::= literal_func */ - 405, /* (459) tags_literal ::= literal_func NK_PLUS duration_literal */ - 405, /* (460) tags_literal ::= literal_func NK_MINUS duration_literal */ - 408, /* (461) tags_literal_list ::= tags_literal */ - 408, /* (462) tags_literal_list ::= tags_literal_list NK_COMMA tags_literal */ - 362, /* (463) literal ::= NK_INTEGER */ - 362, /* (464) literal ::= NK_FLOAT */ - 362, /* (465) literal ::= NK_STRING */ - 362, /* (466) literal ::= NK_BOOL */ - 362, /* (467) literal ::= TIMESTAMP NK_STRING */ - 362, /* (468) literal ::= duration_literal */ - 362, /* (469) literal ::= NULL */ - 362, /* (470) literal ::= NK_QUESTION */ - 415, /* (471) duration_literal ::= NK_VARIABLE */ - 391, /* (472) signed ::= NK_INTEGER */ - 391, /* (473) signed ::= NK_PLUS NK_INTEGER */ - 391, /* (474) signed ::= NK_MINUS NK_INTEGER */ - 391, /* (475) signed ::= NK_FLOAT */ - 391, /* (476) signed ::= NK_PLUS NK_FLOAT */ - 391, /* (477) signed ::= NK_MINUS NK_FLOAT */ - 463, /* (478) signed_literal ::= signed */ - 463, /* (479) signed_literal ::= NK_STRING */ - 463, /* (480) signed_literal ::= NK_BOOL */ - 463, /* (481) signed_literal ::= TIMESTAMP NK_STRING */ - 463, /* (482) signed_literal ::= duration_literal */ - 463, /* (483) signed_literal ::= NULL */ - 463, /* (484) signed_literal ::= literal_func */ - 463, /* (485) signed_literal ::= NK_QUESTION */ - 464, /* (486) literal_list ::= signed_literal */ - 464, /* (487) literal_list ::= literal_list NK_COMMA signed_literal */ - 374, /* (488) db_name ::= NK_ID */ - 375, /* (489) table_name ::= NK_ID */ - 403, /* (490) column_name ::= NK_ID */ - 417, /* (491) function_name ::= NK_ID */ - 450, /* (492) view_name ::= NK_ID */ - 465, /* (493) table_alias ::= NK_ID */ - 428, /* (494) column_alias ::= NK_ID */ - 428, /* (495) column_alias ::= NK_ALIAS */ - 367, /* (496) user_name ::= NK_ID */ - 376, /* (497) topic_name ::= NK_ID */ - 451, /* (498) stream_name ::= NK_ID */ - 441, /* (499) cgroup_name ::= NK_ID */ - 431, /* (500) index_name ::= NK_ID */ - 466, /* (501) expr_or_subquery ::= expression */ - 459, /* (502) expression ::= literal */ - 459, /* (503) expression ::= pseudo_column */ - 459, /* (504) expression ::= column_reference */ - 459, /* (505) expression ::= function_expression */ - 459, /* (506) expression ::= case_when_expression */ - 459, /* (507) expression ::= NK_LP expression NK_RP */ - 459, /* (508) expression ::= NK_PLUS expr_or_subquery */ - 459, /* (509) expression ::= NK_MINUS expr_or_subquery */ - 459, /* (510) expression ::= expr_or_subquery NK_PLUS expr_or_subquery */ - 459, /* (511) expression ::= expr_or_subquery NK_MINUS expr_or_subquery */ - 459, /* (512) expression ::= expr_or_subquery NK_STAR expr_or_subquery */ - 459, /* (513) expression ::= expr_or_subquery NK_SLASH expr_or_subquery */ - 459, /* (514) expression ::= expr_or_subquery NK_REM expr_or_subquery */ - 459, /* (515) expression ::= column_reference NK_ARROW NK_STRING */ - 459, /* (516) expression ::= expr_or_subquery NK_BITAND expr_or_subquery */ - 459, /* (517) expression ::= expr_or_subquery NK_BITOR expr_or_subquery */ - 437, /* (518) expression_list ::= expr_or_subquery */ - 437, /* (519) expression_list ::= expression_list NK_COMMA expr_or_subquery */ - 468, /* (520) column_reference ::= column_name */ - 468, /* (521) column_reference ::= table_name NK_DOT column_name */ - 468, /* (522) column_reference ::= NK_ALIAS */ - 468, /* (523) column_reference ::= table_name NK_DOT NK_ALIAS */ - 467, /* (524) pseudo_column ::= ROWTS */ - 467, /* (525) pseudo_column ::= TBNAME */ - 467, /* (526) pseudo_column ::= table_name NK_DOT TBNAME */ - 467, /* (527) pseudo_column ::= QSTART */ - 467, /* (528) pseudo_column ::= QEND */ - 467, /* (529) pseudo_column ::= QDURATION */ - 467, /* (530) pseudo_column ::= WSTART */ - 467, /* (531) pseudo_column ::= WEND */ - 467, /* (532) pseudo_column ::= WDURATION */ - 467, /* (533) pseudo_column ::= IROWTS */ - 467, /* (534) pseudo_column ::= ISFILLED */ - 467, /* (535) pseudo_column ::= QTAGS */ - 469, /* (536) function_expression ::= function_name NK_LP expression_list NK_RP */ - 469, /* (537) function_expression ::= star_func NK_LP star_func_para_list NK_RP */ - 469, /* (538) function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP */ - 469, /* (539) function_expression ::= literal_func */ - 462, /* (540) literal_func ::= noarg_func NK_LP NK_RP */ - 462, /* (541) literal_func ::= NOW */ - 462, /* (542) literal_func ::= TODAY */ - 473, /* (543) noarg_func ::= NOW */ - 473, /* (544) noarg_func ::= TODAY */ - 473, /* (545) noarg_func ::= TIMEZONE */ - 473, /* (546) noarg_func ::= DATABASE */ - 473, /* (547) noarg_func ::= CLIENT_VERSION */ - 473, /* (548) noarg_func ::= SERVER_VERSION */ - 473, /* (549) noarg_func ::= SERVER_STATUS */ - 473, /* (550) noarg_func ::= CURRENT_USER */ - 473, /* (551) noarg_func ::= USER */ - 471, /* (552) star_func ::= COUNT */ - 471, /* (553) star_func ::= FIRST */ - 471, /* (554) star_func ::= LAST */ - 471, /* (555) star_func ::= LAST_ROW */ - 472, /* (556) star_func_para_list ::= NK_STAR */ - 472, /* (557) star_func_para_list ::= other_para_list */ - 474, /* (558) other_para_list ::= star_func_para */ - 474, /* (559) other_para_list ::= other_para_list NK_COMMA star_func_para */ - 475, /* (560) star_func_para ::= expr_or_subquery */ - 475, /* (561) star_func_para ::= table_name NK_DOT NK_STAR */ - 470, /* (562) case_when_expression ::= CASE when_then_list case_when_else_opt END */ - 470, /* (563) case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END */ - 476, /* (564) when_then_list ::= when_then_expr */ - 476, /* (565) when_then_list ::= when_then_list when_then_expr */ - 479, /* (566) when_then_expr ::= WHEN common_expression THEN common_expression */ - 477, /* (567) case_when_else_opt ::= */ - 477, /* (568) case_when_else_opt ::= ELSE common_expression */ - 480, /* (569) predicate ::= expr_or_subquery compare_op expr_or_subquery */ - 480, /* (570) predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery */ - 480, /* (571) predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery */ - 480, /* (572) predicate ::= expr_or_subquery IS NULL */ - 480, /* (573) predicate ::= expr_or_subquery IS NOT NULL */ - 480, /* (574) predicate ::= expr_or_subquery in_op in_predicate_value */ - 481, /* (575) compare_op ::= NK_LT */ - 481, /* (576) compare_op ::= NK_GT */ - 481, /* (577) compare_op ::= NK_LE */ - 481, /* (578) compare_op ::= NK_GE */ - 481, /* (579) compare_op ::= NK_NE */ - 481, /* (580) compare_op ::= NK_EQ */ - 481, /* (581) compare_op ::= LIKE */ - 481, /* (582) compare_op ::= NOT LIKE */ - 481, /* (583) compare_op ::= MATCH */ - 481, /* (584) compare_op ::= NMATCH */ - 481, /* (585) compare_op ::= CONTAINS */ - 482, /* (586) in_op ::= IN */ - 482, /* (587) in_op ::= NOT IN */ - 483, /* (588) in_predicate_value ::= NK_LP literal_list NK_RP */ - 484, /* (589) boolean_value_expression ::= boolean_primary */ - 484, /* (590) boolean_value_expression ::= NOT boolean_primary */ - 484, /* (591) boolean_value_expression ::= boolean_value_expression OR boolean_value_expression */ - 484, /* (592) boolean_value_expression ::= boolean_value_expression AND boolean_value_expression */ - 485, /* (593) boolean_primary ::= predicate */ - 485, /* (594) boolean_primary ::= NK_LP boolean_value_expression NK_RP */ - 478, /* (595) common_expression ::= expr_or_subquery */ - 478, /* (596) common_expression ::= boolean_value_expression */ - 486, /* (597) from_clause_opt ::= */ - 486, /* (598) from_clause_opt ::= FROM table_reference_list */ - 487, /* (599) table_reference_list ::= table_reference */ - 487, /* (600) table_reference_list ::= table_reference_list NK_COMMA table_reference */ - 488, /* (601) table_reference ::= table_primary */ - 488, /* (602) table_reference ::= joined_table */ - 489, /* (603) table_primary ::= table_name alias_opt */ - 489, /* (604) table_primary ::= db_name NK_DOT table_name alias_opt */ - 489, /* (605) table_primary ::= subquery alias_opt */ - 489, /* (606) table_primary ::= parenthesized_joined_table */ - 491, /* (607) alias_opt ::= */ - 491, /* (608) alias_opt ::= table_alias */ - 491, /* (609) alias_opt ::= AS table_alias */ - 493, /* (610) parenthesized_joined_table ::= NK_LP joined_table NK_RP */ - 493, /* (611) parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP */ - 490, /* (612) joined_table ::= table_reference join_type JOIN table_reference ON search_condition */ - 494, /* (613) join_type ::= */ - 494, /* (614) join_type ::= INNER */ - 495, /* (615) query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt */ - 496, /* (616) hint_list ::= */ - 496, /* (617) hint_list ::= NK_HINT */ - 498, /* (618) tag_mode_opt ::= */ - 498, /* (619) tag_mode_opt ::= TAGS */ - 497, /* (620) set_quantifier_opt ::= */ - 497, /* (621) set_quantifier_opt ::= DISTINCT */ - 497, /* (622) set_quantifier_opt ::= ALL */ - 499, /* (623) select_list ::= select_item */ - 499, /* (624) select_list ::= select_list NK_COMMA select_item */ - 507, /* (625) select_item ::= NK_STAR */ - 507, /* (626) select_item ::= common_expression */ - 507, /* (627) select_item ::= common_expression column_alias */ - 507, /* (628) select_item ::= common_expression AS column_alias */ - 507, /* (629) select_item ::= table_name NK_DOT NK_STAR */ - 440, /* (630) where_clause_opt ::= */ - 440, /* (631) where_clause_opt ::= WHERE search_condition */ - 500, /* (632) partition_by_clause_opt ::= */ - 500, /* (633) partition_by_clause_opt ::= PARTITION BY partition_list */ - 508, /* (634) partition_list ::= partition_item */ - 508, /* (635) partition_list ::= partition_list NK_COMMA partition_item */ - 509, /* (636) partition_item ::= expr_or_subquery */ - 509, /* (637) partition_item ::= expr_or_subquery column_alias */ - 509, /* (638) partition_item ::= expr_or_subquery AS column_alias */ - 504, /* (639) twindow_clause_opt ::= */ - 504, /* (640) twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP */ - 504, /* (641) twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP */ - 504, /* (642) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ - 504, /* (643) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ - 504, /* (644) twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition */ - 504, /* (645) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP */ - 504, /* (646) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ - 433, /* (647) sliding_opt ::= */ - 433, /* (648) sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP */ - 510, /* (649) interval_sliding_duration_literal ::= NK_VARIABLE */ - 510, /* (650) interval_sliding_duration_literal ::= NK_STRING */ - 510, /* (651) interval_sliding_duration_literal ::= NK_INTEGER */ - 503, /* (652) fill_opt ::= */ - 503, /* (653) fill_opt ::= FILL NK_LP fill_mode NK_RP */ - 503, /* (654) fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP */ - 503, /* (655) fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP */ - 511, /* (656) fill_mode ::= NONE */ - 511, /* (657) fill_mode ::= PREV */ - 511, /* (658) fill_mode ::= NULL */ - 511, /* (659) fill_mode ::= NULL_F */ - 511, /* (660) fill_mode ::= LINEAR */ - 511, /* (661) fill_mode ::= NEXT */ - 505, /* (662) group_by_clause_opt ::= */ - 505, /* (663) group_by_clause_opt ::= GROUP BY group_by_list */ - 512, /* (664) group_by_list ::= expr_or_subquery */ - 512, /* (665) group_by_list ::= group_by_list NK_COMMA expr_or_subquery */ - 506, /* (666) having_clause_opt ::= */ - 506, /* (667) having_clause_opt ::= HAVING search_condition */ - 501, /* (668) range_opt ::= */ - 501, /* (669) range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP */ - 501, /* (670) range_opt ::= RANGE NK_LP expr_or_subquery NK_RP */ - 502, /* (671) every_opt ::= */ - 502, /* (672) every_opt ::= EVERY NK_LP duration_literal NK_RP */ - 513, /* (673) query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt */ - 514, /* (674) query_simple ::= query_specification */ - 514, /* (675) query_simple ::= union_query_expression */ - 518, /* (676) union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery */ - 518, /* (677) union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery */ - 519, /* (678) query_simple_or_subquery ::= query_simple */ - 519, /* (679) query_simple_or_subquery ::= subquery */ - 439, /* (680) query_or_subquery ::= query_expression */ - 439, /* (681) query_or_subquery ::= subquery */ - 515, /* (682) order_by_clause_opt ::= */ - 515, /* (683) order_by_clause_opt ::= ORDER BY sort_specification_list */ - 516, /* (684) slimit_clause_opt ::= */ - 516, /* (685) slimit_clause_opt ::= SLIMIT NK_INTEGER */ - 516, /* (686) slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER */ - 516, /* (687) slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER */ - 517, /* (688) limit_clause_opt ::= */ - 517, /* (689) limit_clause_opt ::= LIMIT NK_INTEGER */ - 517, /* (690) limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER */ - 517, /* (691) limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER */ - 492, /* (692) subquery ::= NK_LP query_expression NK_RP */ - 492, /* (693) subquery ::= NK_LP subquery NK_RP */ - 377, /* (694) search_condition ::= common_expression */ - 520, /* (695) sort_specification_list ::= sort_specification */ - 520, /* (696) sort_specification_list ::= sort_specification_list NK_COMMA sort_specification */ - 521, /* (697) sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt */ - 522, /* (698) ordering_specification_opt ::= */ - 522, /* (699) ordering_specification_opt ::= ASC */ - 522, /* (700) ordering_specification_opt ::= DESC */ - 523, /* (701) null_ordering_opt ::= */ - 523, /* (702) null_ordering_opt ::= NULLS FIRST */ - 523, /* (703) null_ordering_opt ::= NULLS LAST */ + 412, /* (228) type_name_default_len ::= BINARY */ + 412, /* (229) type_name_default_len ::= NCHAR */ + 412, /* (230) type_name_default_len ::= VARCHAR */ + 412, /* (231) type_name_default_len ::= VARBINARY */ + 396, /* (232) tags_def_opt ::= */ + 396, /* (233) tags_def_opt ::= tags_def */ + 399, /* (234) tags_def ::= TAGS NK_LP column_def_list NK_RP */ + 397, /* (235) table_options ::= */ + 397, /* (236) table_options ::= table_options COMMENT NK_STRING */ + 397, /* (237) table_options ::= table_options MAX_DELAY duration_list */ + 397, /* (238) table_options ::= table_options WATERMARK duration_list */ + 397, /* (239) table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP */ + 397, /* (240) table_options ::= table_options TTL NK_INTEGER */ + 397, /* (241) table_options ::= table_options SMA NK_LP col_name_list NK_RP */ + 397, /* (242) table_options ::= table_options DELETE_MARK duration_list */ + 402, /* (243) alter_table_options ::= alter_table_option */ + 402, /* (244) alter_table_options ::= alter_table_options alter_table_option */ + 415, /* (245) alter_table_option ::= COMMENT NK_STRING */ + 415, /* (246) alter_table_option ::= TTL NK_INTEGER */ + 413, /* (247) duration_list ::= duration_literal */ + 413, /* (248) duration_list ::= duration_list NK_COMMA duration_literal */ + 414, /* (249) rollup_func_list ::= rollup_func_name */ + 414, /* (250) rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name */ + 417, /* (251) rollup_func_name ::= function_name */ + 417, /* (252) rollup_func_name ::= FIRST */ + 417, /* (253) rollup_func_name ::= LAST */ + 410, /* (254) col_name_list ::= col_name */ + 410, /* (255) col_name_list ::= col_name_list NK_COMMA col_name */ + 419, /* (256) col_name ::= column_name */ + 359, /* (257) cmd ::= SHOW DNODES */ + 359, /* (258) cmd ::= SHOW USERS */ + 359, /* (259) cmd ::= SHOW USER PRIVILEGES */ + 359, /* (260) cmd ::= SHOW db_kind_opt DATABASES */ + 359, /* (261) cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt */ + 359, /* (262) cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt */ + 359, /* (263) cmd ::= SHOW db_name_cond_opt VGROUPS */ + 359, /* (264) cmd ::= SHOW MNODES */ + 359, /* (265) cmd ::= SHOW QNODES */ + 359, /* (266) cmd ::= SHOW ARBGROUPS */ + 359, /* (267) cmd ::= SHOW FUNCTIONS */ + 359, /* (268) cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt */ + 359, /* (269) cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name */ + 359, /* (270) cmd ::= SHOW STREAMS */ + 359, /* (271) cmd ::= SHOW ACCOUNTS */ + 359, /* (272) cmd ::= SHOW APPS */ + 359, /* (273) cmd ::= SHOW CONNECTIONS */ + 359, /* (274) cmd ::= SHOW LICENCES */ + 359, /* (275) cmd ::= SHOW GRANTS */ + 359, /* (276) cmd ::= SHOW GRANTS FULL */ + 359, /* (277) cmd ::= SHOW GRANTS LOGS */ + 359, /* (278) cmd ::= SHOW CLUSTER MACHINES */ + 359, /* (279) cmd ::= SHOW CREATE DATABASE db_name */ + 359, /* (280) cmd ::= SHOW CREATE TABLE full_table_name */ + 359, /* (281) cmd ::= SHOW CREATE STABLE full_table_name */ + 359, /* (282) cmd ::= SHOW QUERIES */ + 359, /* (283) cmd ::= SHOW SCORES */ + 359, /* (284) cmd ::= SHOW TOPICS */ + 359, /* (285) cmd ::= SHOW VARIABLES */ + 359, /* (286) cmd ::= SHOW CLUSTER VARIABLES */ + 359, /* (287) cmd ::= SHOW LOCAL VARIABLES */ + 359, /* (288) cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt */ + 359, /* (289) cmd ::= SHOW BNODES */ + 359, /* (290) cmd ::= SHOW SNODES */ + 359, /* (291) cmd ::= SHOW CLUSTER */ + 359, /* (292) cmd ::= SHOW TRANSACTIONS */ + 359, /* (293) cmd ::= SHOW TABLE DISTRIBUTED full_table_name */ + 359, /* (294) cmd ::= SHOW CONSUMERS */ + 359, /* (295) cmd ::= SHOW SUBSCRIPTIONS */ + 359, /* (296) cmd ::= SHOW TAGS FROM table_name_cond from_db_opt */ + 359, /* (297) cmd ::= SHOW TAGS FROM db_name NK_DOT table_name */ + 359, /* (298) cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt */ + 359, /* (299) cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name */ + 359, /* (300) cmd ::= SHOW VNODES ON DNODE NK_INTEGER */ + 359, /* (301) cmd ::= SHOW VNODES */ + 359, /* (302) cmd ::= SHOW db_name_cond_opt ALIVE */ + 359, /* (303) cmd ::= SHOW CLUSTER ALIVE */ + 359, /* (304) cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt */ + 359, /* (305) cmd ::= SHOW CREATE VIEW full_table_name */ + 359, /* (306) cmd ::= SHOW COMPACTS */ + 359, /* (307) cmd ::= SHOW COMPACT NK_INTEGER */ + 421, /* (308) table_kind_db_name_cond_opt ::= */ + 421, /* (309) table_kind_db_name_cond_opt ::= table_kind */ + 421, /* (310) table_kind_db_name_cond_opt ::= db_name NK_DOT */ + 421, /* (311) table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT */ + 427, /* (312) table_kind ::= NORMAL */ + 427, /* (313) table_kind ::= CHILD */ + 423, /* (314) db_name_cond_opt ::= */ + 423, /* (315) db_name_cond_opt ::= db_name NK_DOT */ + 422, /* (316) like_pattern_opt ::= */ + 422, /* (317) like_pattern_opt ::= LIKE NK_STRING */ + 424, /* (318) table_name_cond ::= table_name */ + 425, /* (319) from_db_opt ::= */ + 425, /* (320) from_db_opt ::= FROM db_name */ + 426, /* (321) tag_list_opt ::= */ + 426, /* (322) tag_list_opt ::= tag_item */ + 426, /* (323) tag_list_opt ::= tag_list_opt NK_COMMA tag_item */ + 428, /* (324) tag_item ::= TBNAME */ + 428, /* (325) tag_item ::= QTAGS */ + 428, /* (326) tag_item ::= column_name */ + 428, /* (327) tag_item ::= column_name column_alias */ + 428, /* (328) tag_item ::= column_name AS column_alias */ + 420, /* (329) db_kind_opt ::= */ + 420, /* (330) db_kind_opt ::= USER */ + 420, /* (331) db_kind_opt ::= SYSTEM */ + 359, /* (332) cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options */ + 359, /* (333) cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP */ + 359, /* (334) cmd ::= DROP INDEX exists_opt full_index_name */ + 431, /* (335) full_index_name ::= index_name */ + 431, /* (336) full_index_name ::= db_name NK_DOT index_name */ + 430, /* (337) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt */ + 430, /* (338) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt */ + 433, /* (339) func_list ::= func */ + 433, /* (340) func_list ::= func_list NK_COMMA func */ + 436, /* (341) func ::= sma_func_name NK_LP expression_list NK_RP */ + 437, /* (342) sma_func_name ::= function_name */ + 437, /* (343) sma_func_name ::= COUNT */ + 437, /* (344) sma_func_name ::= FIRST */ + 437, /* (345) sma_func_name ::= LAST */ + 437, /* (346) sma_func_name ::= LAST_ROW */ + 435, /* (347) sma_stream_opt ::= */ + 435, /* (348) sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal */ + 435, /* (349) sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal */ + 435, /* (350) sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal */ + 439, /* (351) with_meta ::= AS */ + 439, /* (352) with_meta ::= WITH META AS */ + 439, /* (353) with_meta ::= ONLY META AS */ + 359, /* (354) cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery */ + 359, /* (355) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name */ + 359, /* (356) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt */ + 359, /* (357) cmd ::= DROP TOPIC exists_opt topic_name */ + 359, /* (358) cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name */ + 359, /* (359) cmd ::= DESC full_table_name */ + 359, /* (360) cmd ::= DESCRIBE full_table_name */ + 359, /* (361) cmd ::= RESET QUERY CACHE */ + 359, /* (362) cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery */ + 359, /* (363) cmd ::= EXPLAIN analyze_opt explain_options insert_query */ + 443, /* (364) analyze_opt ::= */ + 443, /* (365) analyze_opt ::= ANALYZE */ + 444, /* (366) explain_options ::= */ + 444, /* (367) explain_options ::= explain_options VERBOSE NK_BOOL */ + 444, /* (368) explain_options ::= explain_options RATIO NK_FLOAT */ + 359, /* (369) cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt */ + 359, /* (370) cmd ::= DROP FUNCTION exists_opt function_name */ + 447, /* (371) agg_func_opt ::= */ + 447, /* (372) agg_func_opt ::= AGGREGATE */ + 448, /* (373) bufsize_opt ::= */ + 448, /* (374) bufsize_opt ::= BUFSIZE NK_INTEGER */ + 449, /* (375) language_opt ::= */ + 449, /* (376) language_opt ::= LANGUAGE NK_STRING */ + 446, /* (377) or_replace_opt ::= */ + 446, /* (378) or_replace_opt ::= OR REPLACE */ + 359, /* (379) cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery */ + 359, /* (380) cmd ::= DROP VIEW exists_opt full_view_name */ + 450, /* (381) full_view_name ::= view_name */ + 450, /* (382) full_view_name ::= db_name NK_DOT view_name */ + 359, /* (383) cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery */ + 359, /* (384) cmd ::= DROP STREAM exists_opt stream_name */ + 359, /* (385) cmd ::= PAUSE STREAM exists_opt stream_name */ + 359, /* (386) cmd ::= RESUME STREAM exists_opt ignore_opt stream_name */ + 454, /* (387) col_list_opt ::= */ + 454, /* (388) col_list_opt ::= NK_LP column_stream_def_list NK_RP */ + 458, /* (389) column_stream_def_list ::= column_stream_def */ + 458, /* (390) column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def */ + 459, /* (391) column_stream_def ::= column_name */ + 459, /* (392) column_stream_def ::= column_name PRIMARY KEY */ + 455, /* (393) tag_def_or_ref_opt ::= */ + 455, /* (394) tag_def_or_ref_opt ::= tags_def */ + 455, /* (395) tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP */ + 453, /* (396) stream_options ::= */ + 453, /* (397) stream_options ::= stream_options TRIGGER AT_ONCE */ + 453, /* (398) stream_options ::= stream_options TRIGGER WINDOW_CLOSE */ + 453, /* (399) stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal */ + 453, /* (400) stream_options ::= stream_options WATERMARK duration_literal */ + 453, /* (401) stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER */ + 453, /* (402) stream_options ::= stream_options FILL_HISTORY NK_INTEGER */ + 453, /* (403) stream_options ::= stream_options DELETE_MARK duration_literal */ + 453, /* (404) stream_options ::= stream_options IGNORE UPDATE NK_INTEGER */ + 456, /* (405) subtable_opt ::= */ + 456, /* (406) subtable_opt ::= SUBTABLE NK_LP expression NK_RP */ + 457, /* (407) ignore_opt ::= */ + 457, /* (408) ignore_opt ::= IGNORE UNTREATED */ + 359, /* (409) cmd ::= KILL CONNECTION NK_INTEGER */ + 359, /* (410) cmd ::= KILL QUERY NK_STRING */ + 359, /* (411) cmd ::= KILL TRANSACTION NK_INTEGER */ + 359, /* (412) cmd ::= KILL COMPACT NK_INTEGER */ + 359, /* (413) cmd ::= BALANCE VGROUP */ + 359, /* (414) cmd ::= BALANCE VGROUP LEADER on_vgroup_id */ + 359, /* (415) cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER */ + 359, /* (416) cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list */ + 359, /* (417) cmd ::= SPLIT VGROUP NK_INTEGER */ + 461, /* (418) on_vgroup_id ::= */ + 461, /* (419) on_vgroup_id ::= ON NK_INTEGER */ + 462, /* (420) dnode_list ::= DNODE NK_INTEGER */ + 462, /* (421) dnode_list ::= dnode_list DNODE NK_INTEGER */ + 359, /* (422) cmd ::= DELETE FROM full_table_name where_clause_opt */ + 359, /* (423) cmd ::= query_or_subquery */ + 359, /* (424) cmd ::= insert_query */ + 445, /* (425) insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery */ + 445, /* (426) insert_query ::= INSERT INTO full_table_name query_or_subquery */ + 405, /* (427) tags_literal ::= NK_INTEGER */ + 405, /* (428) tags_literal ::= NK_INTEGER NK_PLUS duration_literal */ + 405, /* (429) tags_literal ::= NK_INTEGER NK_MINUS duration_literal */ + 405, /* (430) tags_literal ::= NK_PLUS NK_INTEGER */ + 405, /* (431) tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal */ + 405, /* (432) tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal */ + 405, /* (433) tags_literal ::= NK_MINUS NK_INTEGER */ + 405, /* (434) tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal */ + 405, /* (435) tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal */ + 405, /* (436) tags_literal ::= NK_FLOAT */ + 405, /* (437) tags_literal ::= NK_PLUS NK_FLOAT */ + 405, /* (438) tags_literal ::= NK_MINUS NK_FLOAT */ + 405, /* (439) tags_literal ::= NK_BIN */ + 405, /* (440) tags_literal ::= NK_BIN NK_PLUS duration_literal */ + 405, /* (441) tags_literal ::= NK_BIN NK_MINUS duration_literal */ + 405, /* (442) tags_literal ::= NK_PLUS NK_BIN */ + 405, /* (443) tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal */ + 405, /* (444) tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal */ + 405, /* (445) tags_literal ::= NK_MINUS NK_BIN */ + 405, /* (446) tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal */ + 405, /* (447) tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal */ + 405, /* (448) tags_literal ::= NK_HEX */ + 405, /* (449) tags_literal ::= NK_HEX NK_PLUS duration_literal */ + 405, /* (450) tags_literal ::= NK_HEX NK_MINUS duration_literal */ + 405, /* (451) tags_literal ::= NK_PLUS NK_HEX */ + 405, /* (452) tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal */ + 405, /* (453) tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal */ + 405, /* (454) tags_literal ::= NK_MINUS NK_HEX */ + 405, /* (455) tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal */ + 405, /* (456) tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal */ + 405, /* (457) tags_literal ::= NK_STRING */ + 405, /* (458) tags_literal ::= NK_STRING NK_PLUS duration_literal */ + 405, /* (459) tags_literal ::= NK_STRING NK_MINUS duration_literal */ + 405, /* (460) tags_literal ::= NK_BOOL */ + 405, /* (461) tags_literal ::= NULL */ + 405, /* (462) tags_literal ::= literal_func */ + 405, /* (463) tags_literal ::= literal_func NK_PLUS duration_literal */ + 405, /* (464) tags_literal ::= literal_func NK_MINUS duration_literal */ + 408, /* (465) tags_literal_list ::= tags_literal */ + 408, /* (466) tags_literal_list ::= tags_literal_list NK_COMMA tags_literal */ + 362, /* (467) literal ::= NK_INTEGER */ + 362, /* (468) literal ::= NK_FLOAT */ + 362, /* (469) literal ::= NK_STRING */ + 362, /* (470) literal ::= NK_BOOL */ + 362, /* (471) literal ::= TIMESTAMP NK_STRING */ + 362, /* (472) literal ::= duration_literal */ + 362, /* (473) literal ::= NULL */ + 362, /* (474) literal ::= NK_QUESTION */ + 416, /* (475) duration_literal ::= NK_VARIABLE */ + 391, /* (476) signed ::= NK_INTEGER */ + 391, /* (477) signed ::= NK_PLUS NK_INTEGER */ + 391, /* (478) signed ::= NK_MINUS NK_INTEGER */ + 391, /* (479) signed ::= NK_FLOAT */ + 391, /* (480) signed ::= NK_PLUS NK_FLOAT */ + 391, /* (481) signed ::= NK_MINUS NK_FLOAT */ + 464, /* (482) signed_literal ::= signed */ + 464, /* (483) signed_literal ::= NK_STRING */ + 464, /* (484) signed_literal ::= NK_BOOL */ + 464, /* (485) signed_literal ::= TIMESTAMP NK_STRING */ + 464, /* (486) signed_literal ::= duration_literal */ + 464, /* (487) signed_literal ::= NULL */ + 464, /* (488) signed_literal ::= literal_func */ + 464, /* (489) signed_literal ::= NK_QUESTION */ + 465, /* (490) literal_list ::= signed_literal */ + 465, /* (491) literal_list ::= literal_list NK_COMMA signed_literal */ + 374, /* (492) db_name ::= NK_ID */ + 375, /* (493) table_name ::= NK_ID */ + 403, /* (494) column_name ::= NK_ID */ + 418, /* (495) function_name ::= NK_ID */ + 451, /* (496) view_name ::= NK_ID */ + 466, /* (497) table_alias ::= NK_ID */ + 429, /* (498) column_alias ::= NK_ID */ + 429, /* (499) column_alias ::= NK_ALIAS */ + 367, /* (500) user_name ::= NK_ID */ + 376, /* (501) topic_name ::= NK_ID */ + 452, /* (502) stream_name ::= NK_ID */ + 442, /* (503) cgroup_name ::= NK_ID */ + 432, /* (504) index_name ::= NK_ID */ + 467, /* (505) expr_or_subquery ::= expression */ + 460, /* (506) expression ::= literal */ + 460, /* (507) expression ::= pseudo_column */ + 460, /* (508) expression ::= column_reference */ + 460, /* (509) expression ::= function_expression */ + 460, /* (510) expression ::= case_when_expression */ + 460, /* (511) expression ::= NK_LP expression NK_RP */ + 460, /* (512) expression ::= NK_PLUS expr_or_subquery */ + 460, /* (513) expression ::= NK_MINUS expr_or_subquery */ + 460, /* (514) expression ::= expr_or_subquery NK_PLUS expr_or_subquery */ + 460, /* (515) expression ::= expr_or_subquery NK_MINUS expr_or_subquery */ + 460, /* (516) expression ::= expr_or_subquery NK_STAR expr_or_subquery */ + 460, /* (517) expression ::= expr_or_subquery NK_SLASH expr_or_subquery */ + 460, /* (518) expression ::= expr_or_subquery NK_REM expr_or_subquery */ + 460, /* (519) expression ::= column_reference NK_ARROW NK_STRING */ + 460, /* (520) expression ::= expr_or_subquery NK_BITAND expr_or_subquery */ + 460, /* (521) expression ::= expr_or_subquery NK_BITOR expr_or_subquery */ + 438, /* (522) expression_list ::= expr_or_subquery */ + 438, /* (523) expression_list ::= expression_list NK_COMMA expr_or_subquery */ + 469, /* (524) column_reference ::= column_name */ + 469, /* (525) column_reference ::= table_name NK_DOT column_name */ + 469, /* (526) column_reference ::= NK_ALIAS */ + 469, /* (527) column_reference ::= table_name NK_DOT NK_ALIAS */ + 468, /* (528) pseudo_column ::= ROWTS */ + 468, /* (529) pseudo_column ::= TBNAME */ + 468, /* (530) pseudo_column ::= table_name NK_DOT TBNAME */ + 468, /* (531) pseudo_column ::= QSTART */ + 468, /* (532) pseudo_column ::= QEND */ + 468, /* (533) pseudo_column ::= QDURATION */ + 468, /* (534) pseudo_column ::= WSTART */ + 468, /* (535) pseudo_column ::= WEND */ + 468, /* (536) pseudo_column ::= WDURATION */ + 468, /* (537) pseudo_column ::= IROWTS */ + 468, /* (538) pseudo_column ::= ISFILLED */ + 468, /* (539) pseudo_column ::= QTAGS */ + 470, /* (540) function_expression ::= function_name NK_LP expression_list NK_RP */ + 470, /* (541) function_expression ::= star_func NK_LP star_func_para_list NK_RP */ + 470, /* (542) function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP */ + 470, /* (543) function_expression ::= CAST NK_LP expr_or_subquery AS type_name_default_len NK_RP */ + 470, /* (544) function_expression ::= literal_func */ + 463, /* (545) literal_func ::= noarg_func NK_LP NK_RP */ + 463, /* (546) literal_func ::= NOW */ + 463, /* (547) literal_func ::= TODAY */ + 474, /* (548) noarg_func ::= NOW */ + 474, /* (549) noarg_func ::= TODAY */ + 474, /* (550) noarg_func ::= TIMEZONE */ + 474, /* (551) noarg_func ::= DATABASE */ + 474, /* (552) noarg_func ::= CLIENT_VERSION */ + 474, /* (553) noarg_func ::= SERVER_VERSION */ + 474, /* (554) noarg_func ::= SERVER_STATUS */ + 474, /* (555) noarg_func ::= CURRENT_USER */ + 474, /* (556) noarg_func ::= USER */ + 472, /* (557) star_func ::= COUNT */ + 472, /* (558) star_func ::= FIRST */ + 472, /* (559) star_func ::= LAST */ + 472, /* (560) star_func ::= LAST_ROW */ + 473, /* (561) star_func_para_list ::= NK_STAR */ + 473, /* (562) star_func_para_list ::= other_para_list */ + 475, /* (563) other_para_list ::= star_func_para */ + 475, /* (564) other_para_list ::= other_para_list NK_COMMA star_func_para */ + 476, /* (565) star_func_para ::= expr_or_subquery */ + 476, /* (566) star_func_para ::= table_name NK_DOT NK_STAR */ + 471, /* (567) case_when_expression ::= CASE when_then_list case_when_else_opt END */ + 471, /* (568) case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END */ + 477, /* (569) when_then_list ::= when_then_expr */ + 477, /* (570) when_then_list ::= when_then_list when_then_expr */ + 480, /* (571) when_then_expr ::= WHEN common_expression THEN common_expression */ + 478, /* (572) case_when_else_opt ::= */ + 478, /* (573) case_when_else_opt ::= ELSE common_expression */ + 481, /* (574) predicate ::= expr_or_subquery compare_op expr_or_subquery */ + 481, /* (575) predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery */ + 481, /* (576) predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery */ + 481, /* (577) predicate ::= expr_or_subquery IS NULL */ + 481, /* (578) predicate ::= expr_or_subquery IS NOT NULL */ + 481, /* (579) predicate ::= expr_or_subquery in_op in_predicate_value */ + 482, /* (580) compare_op ::= NK_LT */ + 482, /* (581) compare_op ::= NK_GT */ + 482, /* (582) compare_op ::= NK_LE */ + 482, /* (583) compare_op ::= NK_GE */ + 482, /* (584) compare_op ::= NK_NE */ + 482, /* (585) compare_op ::= NK_EQ */ + 482, /* (586) compare_op ::= LIKE */ + 482, /* (587) compare_op ::= NOT LIKE */ + 482, /* (588) compare_op ::= MATCH */ + 482, /* (589) compare_op ::= NMATCH */ + 482, /* (590) compare_op ::= CONTAINS */ + 483, /* (591) in_op ::= IN */ + 483, /* (592) in_op ::= NOT IN */ + 484, /* (593) in_predicate_value ::= NK_LP literal_list NK_RP */ + 485, /* (594) boolean_value_expression ::= boolean_primary */ + 485, /* (595) boolean_value_expression ::= NOT boolean_primary */ + 485, /* (596) boolean_value_expression ::= boolean_value_expression OR boolean_value_expression */ + 485, /* (597) boolean_value_expression ::= boolean_value_expression AND boolean_value_expression */ + 486, /* (598) boolean_primary ::= predicate */ + 486, /* (599) boolean_primary ::= NK_LP boolean_value_expression NK_RP */ + 479, /* (600) common_expression ::= expr_or_subquery */ + 479, /* (601) common_expression ::= boolean_value_expression */ + 487, /* (602) from_clause_opt ::= */ + 487, /* (603) from_clause_opt ::= FROM table_reference_list */ + 488, /* (604) table_reference_list ::= table_reference */ + 488, /* (605) table_reference_list ::= table_reference_list NK_COMMA table_reference */ + 489, /* (606) table_reference ::= table_primary */ + 489, /* (607) table_reference ::= joined_table */ + 490, /* (608) table_primary ::= table_name alias_opt */ + 490, /* (609) table_primary ::= db_name NK_DOT table_name alias_opt */ + 490, /* (610) table_primary ::= subquery alias_opt */ + 490, /* (611) table_primary ::= parenthesized_joined_table */ + 492, /* (612) alias_opt ::= */ + 492, /* (613) alias_opt ::= table_alias */ + 492, /* (614) alias_opt ::= AS table_alias */ + 494, /* (615) parenthesized_joined_table ::= NK_LP joined_table NK_RP */ + 494, /* (616) parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP */ + 491, /* (617) joined_table ::= table_reference join_type JOIN table_reference ON search_condition */ + 495, /* (618) join_type ::= */ + 495, /* (619) join_type ::= INNER */ + 496, /* (620) query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt */ + 497, /* (621) hint_list ::= */ + 497, /* (622) hint_list ::= NK_HINT */ + 499, /* (623) tag_mode_opt ::= */ + 499, /* (624) tag_mode_opt ::= TAGS */ + 498, /* (625) set_quantifier_opt ::= */ + 498, /* (626) set_quantifier_opt ::= DISTINCT */ + 498, /* (627) set_quantifier_opt ::= ALL */ + 500, /* (628) select_list ::= select_item */ + 500, /* (629) select_list ::= select_list NK_COMMA select_item */ + 508, /* (630) select_item ::= NK_STAR */ + 508, /* (631) select_item ::= common_expression */ + 508, /* (632) select_item ::= common_expression column_alias */ + 508, /* (633) select_item ::= common_expression AS column_alias */ + 508, /* (634) select_item ::= table_name NK_DOT NK_STAR */ + 441, /* (635) where_clause_opt ::= */ + 441, /* (636) where_clause_opt ::= WHERE search_condition */ + 501, /* (637) partition_by_clause_opt ::= */ + 501, /* (638) partition_by_clause_opt ::= PARTITION BY partition_list */ + 509, /* (639) partition_list ::= partition_item */ + 509, /* (640) partition_list ::= partition_list NK_COMMA partition_item */ + 510, /* (641) partition_item ::= expr_or_subquery */ + 510, /* (642) partition_item ::= expr_or_subquery column_alias */ + 510, /* (643) partition_item ::= expr_or_subquery AS column_alias */ + 505, /* (644) twindow_clause_opt ::= */ + 505, /* (645) twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP */ + 505, /* (646) twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP */ + 505, /* (647) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ + 505, /* (648) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ + 505, /* (649) twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition */ + 505, /* (650) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP */ + 505, /* (651) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ + 434, /* (652) sliding_opt ::= */ + 434, /* (653) sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP */ + 511, /* (654) interval_sliding_duration_literal ::= NK_VARIABLE */ + 511, /* (655) interval_sliding_duration_literal ::= NK_STRING */ + 511, /* (656) interval_sliding_duration_literal ::= NK_INTEGER */ + 504, /* (657) fill_opt ::= */ + 504, /* (658) fill_opt ::= FILL NK_LP fill_mode NK_RP */ + 504, /* (659) fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP */ + 504, /* (660) fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP */ + 512, /* (661) fill_mode ::= NONE */ + 512, /* (662) fill_mode ::= PREV */ + 512, /* (663) fill_mode ::= NULL */ + 512, /* (664) fill_mode ::= NULL_F */ + 512, /* (665) fill_mode ::= LINEAR */ + 512, /* (666) fill_mode ::= NEXT */ + 506, /* (667) group_by_clause_opt ::= */ + 506, /* (668) group_by_clause_opt ::= GROUP BY group_by_list */ + 513, /* (669) group_by_list ::= expr_or_subquery */ + 513, /* (670) group_by_list ::= group_by_list NK_COMMA expr_or_subquery */ + 507, /* (671) having_clause_opt ::= */ + 507, /* (672) having_clause_opt ::= HAVING search_condition */ + 502, /* (673) range_opt ::= */ + 502, /* (674) range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP */ + 502, /* (675) range_opt ::= RANGE NK_LP expr_or_subquery NK_RP */ + 503, /* (676) every_opt ::= */ + 503, /* (677) every_opt ::= EVERY NK_LP duration_literal NK_RP */ + 514, /* (678) query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt */ + 515, /* (679) query_simple ::= query_specification */ + 515, /* (680) query_simple ::= union_query_expression */ + 519, /* (681) union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery */ + 519, /* (682) union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery */ + 520, /* (683) query_simple_or_subquery ::= query_simple */ + 520, /* (684) query_simple_or_subquery ::= subquery */ + 440, /* (685) query_or_subquery ::= query_expression */ + 440, /* (686) query_or_subquery ::= subquery */ + 516, /* (687) order_by_clause_opt ::= */ + 516, /* (688) order_by_clause_opt ::= ORDER BY sort_specification_list */ + 517, /* (689) slimit_clause_opt ::= */ + 517, /* (690) slimit_clause_opt ::= SLIMIT NK_INTEGER */ + 517, /* (691) slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER */ + 517, /* (692) slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER */ + 518, /* (693) limit_clause_opt ::= */ + 518, /* (694) limit_clause_opt ::= LIMIT NK_INTEGER */ + 518, /* (695) limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER */ + 518, /* (696) limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER */ + 493, /* (697) subquery ::= NK_LP query_expression NK_RP */ + 493, /* (698) subquery ::= NK_LP subquery NK_RP */ + 377, /* (699) search_condition ::= common_expression */ + 521, /* (700) sort_specification_list ::= sort_specification */ + 521, /* (701) sort_specification_list ::= sort_specification_list NK_COMMA sort_specification */ + 522, /* (702) sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt */ + 523, /* (703) ordering_specification_opt ::= */ + 523, /* (704) ordering_specification_opt ::= ASC */ + 523, /* (705) ordering_specification_opt ::= DESC */ + 524, /* (706) null_ordering_opt ::= */ + 524, /* (707) null_ordering_opt ::= NULLS FIRST */ + 524, /* (708) null_ordering_opt ::= NULLS LAST */ }; /* For rule J, yyRuleInfoNRhs[J] contains the negative of the number @@ -4770,482 +4824,487 @@ static const signed char yyRuleInfoNRhs[] = { -1, /* (225) type_name ::= DECIMAL */ -4, /* (226) type_name ::= DECIMAL NK_LP NK_INTEGER NK_RP */ -6, /* (227) type_name ::= DECIMAL NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ - 0, /* (228) tags_def_opt ::= */ - -1, /* (229) tags_def_opt ::= tags_def */ - -4, /* (230) tags_def ::= TAGS NK_LP column_def_list NK_RP */ - 0, /* (231) table_options ::= */ - -3, /* (232) table_options ::= table_options COMMENT NK_STRING */ - -3, /* (233) table_options ::= table_options MAX_DELAY duration_list */ - -3, /* (234) table_options ::= table_options WATERMARK duration_list */ - -5, /* (235) table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP */ - -3, /* (236) table_options ::= table_options TTL NK_INTEGER */ - -5, /* (237) table_options ::= table_options SMA NK_LP col_name_list NK_RP */ - -3, /* (238) table_options ::= table_options DELETE_MARK duration_list */ - -1, /* (239) alter_table_options ::= alter_table_option */ - -2, /* (240) alter_table_options ::= alter_table_options alter_table_option */ - -2, /* (241) alter_table_option ::= COMMENT NK_STRING */ - -2, /* (242) alter_table_option ::= TTL NK_INTEGER */ - -1, /* (243) duration_list ::= duration_literal */ - -3, /* (244) duration_list ::= duration_list NK_COMMA duration_literal */ - -1, /* (245) rollup_func_list ::= rollup_func_name */ - -3, /* (246) rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name */ - -1, /* (247) rollup_func_name ::= function_name */ - -1, /* (248) rollup_func_name ::= FIRST */ - -1, /* (249) rollup_func_name ::= LAST */ - -1, /* (250) col_name_list ::= col_name */ - -3, /* (251) col_name_list ::= col_name_list NK_COMMA col_name */ - -1, /* (252) col_name ::= column_name */ - -2, /* (253) cmd ::= SHOW DNODES */ - -2, /* (254) cmd ::= SHOW USERS */ - -3, /* (255) cmd ::= SHOW USER PRIVILEGES */ - -3, /* (256) cmd ::= SHOW db_kind_opt DATABASES */ - -4, /* (257) cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt */ - -4, /* (258) cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt */ - -3, /* (259) cmd ::= SHOW db_name_cond_opt VGROUPS */ - -2, /* (260) cmd ::= SHOW MNODES */ - -2, /* (261) cmd ::= SHOW QNODES */ - -2, /* (262) cmd ::= SHOW ARBGROUPS */ - -2, /* (263) cmd ::= SHOW FUNCTIONS */ - -5, /* (264) cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt */ - -6, /* (265) cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name */ - -2, /* (266) cmd ::= SHOW STREAMS */ - -2, /* (267) cmd ::= SHOW ACCOUNTS */ - -2, /* (268) cmd ::= SHOW APPS */ - -2, /* (269) cmd ::= SHOW CONNECTIONS */ - -2, /* (270) cmd ::= SHOW LICENCES */ - -2, /* (271) cmd ::= SHOW GRANTS */ - -3, /* (272) cmd ::= SHOW GRANTS FULL */ - -3, /* (273) cmd ::= SHOW GRANTS LOGS */ - -3, /* (274) cmd ::= SHOW CLUSTER MACHINES */ - -4, /* (275) cmd ::= SHOW CREATE DATABASE db_name */ - -4, /* (276) cmd ::= SHOW CREATE TABLE full_table_name */ - -4, /* (277) cmd ::= SHOW CREATE STABLE full_table_name */ - -2, /* (278) cmd ::= SHOW QUERIES */ - -2, /* (279) cmd ::= SHOW SCORES */ - -2, /* (280) cmd ::= SHOW TOPICS */ - -2, /* (281) cmd ::= SHOW VARIABLES */ - -3, /* (282) cmd ::= SHOW CLUSTER VARIABLES */ - -3, /* (283) cmd ::= SHOW LOCAL VARIABLES */ - -5, /* (284) cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt */ - -2, /* (285) cmd ::= SHOW BNODES */ - -2, /* (286) cmd ::= SHOW SNODES */ - -2, /* (287) cmd ::= SHOW CLUSTER */ - -2, /* (288) cmd ::= SHOW TRANSACTIONS */ - -4, /* (289) cmd ::= SHOW TABLE DISTRIBUTED full_table_name */ - -2, /* (290) cmd ::= SHOW CONSUMERS */ - -2, /* (291) cmd ::= SHOW SUBSCRIPTIONS */ - -5, /* (292) cmd ::= SHOW TAGS FROM table_name_cond from_db_opt */ - -6, /* (293) cmd ::= SHOW TAGS FROM db_name NK_DOT table_name */ - -7, /* (294) cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt */ - -8, /* (295) cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name */ - -5, /* (296) cmd ::= SHOW VNODES ON DNODE NK_INTEGER */ - -2, /* (297) cmd ::= SHOW VNODES */ - -3, /* (298) cmd ::= SHOW db_name_cond_opt ALIVE */ - -3, /* (299) cmd ::= SHOW CLUSTER ALIVE */ - -4, /* (300) cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt */ - -4, /* (301) cmd ::= SHOW CREATE VIEW full_table_name */ - -2, /* (302) cmd ::= SHOW COMPACTS */ - -3, /* (303) cmd ::= SHOW COMPACT NK_INTEGER */ - 0, /* (304) table_kind_db_name_cond_opt ::= */ - -1, /* (305) table_kind_db_name_cond_opt ::= table_kind */ - -2, /* (306) table_kind_db_name_cond_opt ::= db_name NK_DOT */ - -3, /* (307) table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT */ - -1, /* (308) table_kind ::= NORMAL */ - -1, /* (309) table_kind ::= CHILD */ - 0, /* (310) db_name_cond_opt ::= */ - -2, /* (311) db_name_cond_opt ::= db_name NK_DOT */ - 0, /* (312) like_pattern_opt ::= */ - -2, /* (313) like_pattern_opt ::= LIKE NK_STRING */ - -1, /* (314) table_name_cond ::= table_name */ - 0, /* (315) from_db_opt ::= */ - -2, /* (316) from_db_opt ::= FROM db_name */ - 0, /* (317) tag_list_opt ::= */ - -1, /* (318) tag_list_opt ::= tag_item */ - -3, /* (319) tag_list_opt ::= tag_list_opt NK_COMMA tag_item */ - -1, /* (320) tag_item ::= TBNAME */ - -1, /* (321) tag_item ::= QTAGS */ - -1, /* (322) tag_item ::= column_name */ - -2, /* (323) tag_item ::= column_name column_alias */ - -3, /* (324) tag_item ::= column_name AS column_alias */ - 0, /* (325) db_kind_opt ::= */ - -1, /* (326) db_kind_opt ::= USER */ - -1, /* (327) db_kind_opt ::= SYSTEM */ - -8, /* (328) cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options */ - -9, /* (329) cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP */ - -4, /* (330) cmd ::= DROP INDEX exists_opt full_index_name */ - -1, /* (331) full_index_name ::= index_name */ - -3, /* (332) full_index_name ::= db_name NK_DOT index_name */ - -10, /* (333) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt */ - -12, /* (334) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt */ - -1, /* (335) func_list ::= func */ - -3, /* (336) func_list ::= func_list NK_COMMA func */ - -4, /* (337) func ::= sma_func_name NK_LP expression_list NK_RP */ - -1, /* (338) sma_func_name ::= function_name */ - -1, /* (339) sma_func_name ::= COUNT */ - -1, /* (340) sma_func_name ::= FIRST */ - -1, /* (341) sma_func_name ::= LAST */ - -1, /* (342) sma_func_name ::= LAST_ROW */ - 0, /* (343) sma_stream_opt ::= */ - -3, /* (344) sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal */ - -3, /* (345) sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal */ - -3, /* (346) sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal */ - -1, /* (347) with_meta ::= AS */ - -3, /* (348) with_meta ::= WITH META AS */ - -3, /* (349) with_meta ::= ONLY META AS */ - -6, /* (350) cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery */ - -7, /* (351) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name */ - -8, /* (352) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt */ - -4, /* (353) cmd ::= DROP TOPIC exists_opt topic_name */ - -7, /* (354) cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name */ - -2, /* (355) cmd ::= DESC full_table_name */ - -2, /* (356) cmd ::= DESCRIBE full_table_name */ - -3, /* (357) cmd ::= RESET QUERY CACHE */ - -4, /* (358) cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery */ - -4, /* (359) cmd ::= EXPLAIN analyze_opt explain_options insert_query */ - 0, /* (360) analyze_opt ::= */ - -1, /* (361) analyze_opt ::= ANALYZE */ - 0, /* (362) explain_options ::= */ - -3, /* (363) explain_options ::= explain_options VERBOSE NK_BOOL */ - -3, /* (364) explain_options ::= explain_options RATIO NK_FLOAT */ - -12, /* (365) cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt */ - -4, /* (366) cmd ::= DROP FUNCTION exists_opt function_name */ - 0, /* (367) agg_func_opt ::= */ - -1, /* (368) agg_func_opt ::= AGGREGATE */ - 0, /* (369) bufsize_opt ::= */ - -2, /* (370) bufsize_opt ::= BUFSIZE NK_INTEGER */ - 0, /* (371) language_opt ::= */ - -2, /* (372) language_opt ::= LANGUAGE NK_STRING */ - 0, /* (373) or_replace_opt ::= */ - -2, /* (374) or_replace_opt ::= OR REPLACE */ - -6, /* (375) cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery */ - -4, /* (376) cmd ::= DROP VIEW exists_opt full_view_name */ - -1, /* (377) full_view_name ::= view_name */ - -3, /* (378) full_view_name ::= db_name NK_DOT view_name */ - -12, /* (379) cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery */ - -4, /* (380) cmd ::= DROP STREAM exists_opt stream_name */ - -4, /* (381) cmd ::= PAUSE STREAM exists_opt stream_name */ - -5, /* (382) cmd ::= RESUME STREAM exists_opt ignore_opt stream_name */ - 0, /* (383) col_list_opt ::= */ - -3, /* (384) col_list_opt ::= NK_LP column_stream_def_list NK_RP */ - -1, /* (385) column_stream_def_list ::= column_stream_def */ - -3, /* (386) column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def */ - -1, /* (387) column_stream_def ::= column_name */ - -3, /* (388) column_stream_def ::= column_name PRIMARY KEY */ - 0, /* (389) tag_def_or_ref_opt ::= */ - -1, /* (390) tag_def_or_ref_opt ::= tags_def */ - -4, /* (391) tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP */ - 0, /* (392) stream_options ::= */ - -3, /* (393) stream_options ::= stream_options TRIGGER AT_ONCE */ - -3, /* (394) stream_options ::= stream_options TRIGGER WINDOW_CLOSE */ - -4, /* (395) stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal */ - -3, /* (396) stream_options ::= stream_options WATERMARK duration_literal */ - -4, /* (397) stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER */ - -3, /* (398) stream_options ::= stream_options FILL_HISTORY NK_INTEGER */ - -3, /* (399) stream_options ::= stream_options DELETE_MARK duration_literal */ - -4, /* (400) stream_options ::= stream_options IGNORE UPDATE NK_INTEGER */ - 0, /* (401) subtable_opt ::= */ - -4, /* (402) subtable_opt ::= SUBTABLE NK_LP expression NK_RP */ - 0, /* (403) ignore_opt ::= */ - -2, /* (404) ignore_opt ::= IGNORE UNTREATED */ - -3, /* (405) cmd ::= KILL CONNECTION NK_INTEGER */ - -3, /* (406) cmd ::= KILL QUERY NK_STRING */ - -3, /* (407) cmd ::= KILL TRANSACTION NK_INTEGER */ - -3, /* (408) cmd ::= KILL COMPACT NK_INTEGER */ - -2, /* (409) cmd ::= BALANCE VGROUP */ - -4, /* (410) cmd ::= BALANCE VGROUP LEADER on_vgroup_id */ - -4, /* (411) cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER */ - -4, /* (412) cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list */ - -3, /* (413) cmd ::= SPLIT VGROUP NK_INTEGER */ - 0, /* (414) on_vgroup_id ::= */ - -2, /* (415) on_vgroup_id ::= ON NK_INTEGER */ - -2, /* (416) dnode_list ::= DNODE NK_INTEGER */ - -3, /* (417) dnode_list ::= dnode_list DNODE NK_INTEGER */ - -4, /* (418) cmd ::= DELETE FROM full_table_name where_clause_opt */ - -1, /* (419) cmd ::= query_or_subquery */ - -1, /* (420) cmd ::= insert_query */ - -7, /* (421) insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery */ - -4, /* (422) insert_query ::= INSERT INTO full_table_name query_or_subquery */ - -1, /* (423) tags_literal ::= NK_INTEGER */ - -3, /* (424) tags_literal ::= NK_INTEGER NK_PLUS duration_literal */ - -3, /* (425) tags_literal ::= NK_INTEGER NK_MINUS duration_literal */ - -2, /* (426) tags_literal ::= NK_PLUS NK_INTEGER */ - -4, /* (427) tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal */ - -4, /* (428) tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal */ - -2, /* (429) tags_literal ::= NK_MINUS NK_INTEGER */ - -4, /* (430) tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal */ - -4, /* (431) tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal */ - -1, /* (432) tags_literal ::= NK_FLOAT */ - -2, /* (433) tags_literal ::= NK_PLUS NK_FLOAT */ - -2, /* (434) tags_literal ::= NK_MINUS NK_FLOAT */ - -1, /* (435) tags_literal ::= NK_BIN */ - -3, /* (436) tags_literal ::= NK_BIN NK_PLUS duration_literal */ - -3, /* (437) tags_literal ::= NK_BIN NK_MINUS duration_literal */ - -2, /* (438) tags_literal ::= NK_PLUS NK_BIN */ - -4, /* (439) tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal */ - -4, /* (440) tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal */ - -2, /* (441) tags_literal ::= NK_MINUS NK_BIN */ - -4, /* (442) tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal */ - -4, /* (443) tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal */ - -1, /* (444) tags_literal ::= NK_HEX */ - -3, /* (445) tags_literal ::= NK_HEX NK_PLUS duration_literal */ - -3, /* (446) tags_literal ::= NK_HEX NK_MINUS duration_literal */ - -2, /* (447) tags_literal ::= NK_PLUS NK_HEX */ - -4, /* (448) tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal */ - -4, /* (449) tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal */ - -2, /* (450) tags_literal ::= NK_MINUS NK_HEX */ - -4, /* (451) tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal */ - -4, /* (452) tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal */ - -1, /* (453) tags_literal ::= NK_STRING */ - -3, /* (454) tags_literal ::= NK_STRING NK_PLUS duration_literal */ - -3, /* (455) tags_literal ::= NK_STRING NK_MINUS duration_literal */ - -1, /* (456) tags_literal ::= NK_BOOL */ - -1, /* (457) tags_literal ::= NULL */ - -1, /* (458) tags_literal ::= literal_func */ - -3, /* (459) tags_literal ::= literal_func NK_PLUS duration_literal */ - -3, /* (460) tags_literal ::= literal_func NK_MINUS duration_literal */ - -1, /* (461) tags_literal_list ::= tags_literal */ - -3, /* (462) tags_literal_list ::= tags_literal_list NK_COMMA tags_literal */ - -1, /* (463) literal ::= NK_INTEGER */ - -1, /* (464) literal ::= NK_FLOAT */ - -1, /* (465) literal ::= NK_STRING */ - -1, /* (466) literal ::= NK_BOOL */ - -2, /* (467) literal ::= TIMESTAMP NK_STRING */ - -1, /* (468) literal ::= duration_literal */ - -1, /* (469) literal ::= NULL */ - -1, /* (470) literal ::= NK_QUESTION */ - -1, /* (471) duration_literal ::= NK_VARIABLE */ - -1, /* (472) signed ::= NK_INTEGER */ - -2, /* (473) signed ::= NK_PLUS NK_INTEGER */ - -2, /* (474) signed ::= NK_MINUS NK_INTEGER */ - -1, /* (475) signed ::= NK_FLOAT */ - -2, /* (476) signed ::= NK_PLUS NK_FLOAT */ - -2, /* (477) signed ::= NK_MINUS NK_FLOAT */ - -1, /* (478) signed_literal ::= signed */ - -1, /* (479) signed_literal ::= NK_STRING */ - -1, /* (480) signed_literal ::= NK_BOOL */ - -2, /* (481) signed_literal ::= TIMESTAMP NK_STRING */ - -1, /* (482) signed_literal ::= duration_literal */ - -1, /* (483) signed_literal ::= NULL */ - -1, /* (484) signed_literal ::= literal_func */ - -1, /* (485) signed_literal ::= NK_QUESTION */ - -1, /* (486) literal_list ::= signed_literal */ - -3, /* (487) literal_list ::= literal_list NK_COMMA signed_literal */ - -1, /* (488) db_name ::= NK_ID */ - -1, /* (489) table_name ::= NK_ID */ - -1, /* (490) column_name ::= NK_ID */ - -1, /* (491) function_name ::= NK_ID */ - -1, /* (492) view_name ::= NK_ID */ - -1, /* (493) table_alias ::= NK_ID */ - -1, /* (494) column_alias ::= NK_ID */ - -1, /* (495) column_alias ::= NK_ALIAS */ - -1, /* (496) user_name ::= NK_ID */ - -1, /* (497) topic_name ::= NK_ID */ - -1, /* (498) stream_name ::= NK_ID */ - -1, /* (499) cgroup_name ::= NK_ID */ - -1, /* (500) index_name ::= NK_ID */ - -1, /* (501) expr_or_subquery ::= expression */ - -1, /* (502) expression ::= literal */ - -1, /* (503) expression ::= pseudo_column */ - -1, /* (504) expression ::= column_reference */ - -1, /* (505) expression ::= function_expression */ - -1, /* (506) expression ::= case_when_expression */ - -3, /* (507) expression ::= NK_LP expression NK_RP */ - -2, /* (508) expression ::= NK_PLUS expr_or_subquery */ - -2, /* (509) expression ::= NK_MINUS expr_or_subquery */ - -3, /* (510) expression ::= expr_or_subquery NK_PLUS expr_or_subquery */ - -3, /* (511) expression ::= expr_or_subquery NK_MINUS expr_or_subquery */ - -3, /* (512) expression ::= expr_or_subquery NK_STAR expr_or_subquery */ - -3, /* (513) expression ::= expr_or_subquery NK_SLASH expr_or_subquery */ - -3, /* (514) expression ::= expr_or_subquery NK_REM expr_or_subquery */ - -3, /* (515) expression ::= column_reference NK_ARROW NK_STRING */ - -3, /* (516) expression ::= expr_or_subquery NK_BITAND expr_or_subquery */ - -3, /* (517) expression ::= expr_or_subquery NK_BITOR expr_or_subquery */ - -1, /* (518) expression_list ::= expr_or_subquery */ - -3, /* (519) expression_list ::= expression_list NK_COMMA expr_or_subquery */ - -1, /* (520) column_reference ::= column_name */ - -3, /* (521) column_reference ::= table_name NK_DOT column_name */ - -1, /* (522) column_reference ::= NK_ALIAS */ - -3, /* (523) column_reference ::= table_name NK_DOT NK_ALIAS */ - -1, /* (524) pseudo_column ::= ROWTS */ - -1, /* (525) pseudo_column ::= TBNAME */ - -3, /* (526) pseudo_column ::= table_name NK_DOT TBNAME */ - -1, /* (527) pseudo_column ::= QSTART */ - -1, /* (528) pseudo_column ::= QEND */ - -1, /* (529) pseudo_column ::= QDURATION */ - -1, /* (530) pseudo_column ::= WSTART */ - -1, /* (531) pseudo_column ::= WEND */ - -1, /* (532) pseudo_column ::= WDURATION */ - -1, /* (533) pseudo_column ::= IROWTS */ - -1, /* (534) pseudo_column ::= ISFILLED */ - -1, /* (535) pseudo_column ::= QTAGS */ - -4, /* (536) function_expression ::= function_name NK_LP expression_list NK_RP */ - -4, /* (537) function_expression ::= star_func NK_LP star_func_para_list NK_RP */ - -6, /* (538) function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP */ - -1, /* (539) function_expression ::= literal_func */ - -3, /* (540) literal_func ::= noarg_func NK_LP NK_RP */ - -1, /* (541) literal_func ::= NOW */ - -1, /* (542) literal_func ::= TODAY */ - -1, /* (543) noarg_func ::= NOW */ - -1, /* (544) noarg_func ::= TODAY */ - -1, /* (545) noarg_func ::= TIMEZONE */ - -1, /* (546) noarg_func ::= DATABASE */ - -1, /* (547) noarg_func ::= CLIENT_VERSION */ - -1, /* (548) noarg_func ::= SERVER_VERSION */ - -1, /* (549) noarg_func ::= SERVER_STATUS */ - -1, /* (550) noarg_func ::= CURRENT_USER */ - -1, /* (551) noarg_func ::= USER */ - -1, /* (552) star_func ::= COUNT */ - -1, /* (553) star_func ::= FIRST */ - -1, /* (554) star_func ::= LAST */ - -1, /* (555) star_func ::= LAST_ROW */ - -1, /* (556) star_func_para_list ::= NK_STAR */ - -1, /* (557) star_func_para_list ::= other_para_list */ - -1, /* (558) other_para_list ::= star_func_para */ - -3, /* (559) other_para_list ::= other_para_list NK_COMMA star_func_para */ - -1, /* (560) star_func_para ::= expr_or_subquery */ - -3, /* (561) star_func_para ::= table_name NK_DOT NK_STAR */ - -4, /* (562) case_when_expression ::= CASE when_then_list case_when_else_opt END */ - -5, /* (563) case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END */ - -1, /* (564) when_then_list ::= when_then_expr */ - -2, /* (565) when_then_list ::= when_then_list when_then_expr */ - -4, /* (566) when_then_expr ::= WHEN common_expression THEN common_expression */ - 0, /* (567) case_when_else_opt ::= */ - -2, /* (568) case_when_else_opt ::= ELSE common_expression */ - -3, /* (569) predicate ::= expr_or_subquery compare_op expr_or_subquery */ - -5, /* (570) predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery */ - -6, /* (571) predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery */ - -3, /* (572) predicate ::= expr_or_subquery IS NULL */ - -4, /* (573) predicate ::= expr_or_subquery IS NOT NULL */ - -3, /* (574) predicate ::= expr_or_subquery in_op in_predicate_value */ - -1, /* (575) compare_op ::= NK_LT */ - -1, /* (576) compare_op ::= NK_GT */ - -1, /* (577) compare_op ::= NK_LE */ - -1, /* (578) compare_op ::= NK_GE */ - -1, /* (579) compare_op ::= NK_NE */ - -1, /* (580) compare_op ::= NK_EQ */ - -1, /* (581) compare_op ::= LIKE */ - -2, /* (582) compare_op ::= NOT LIKE */ - -1, /* (583) compare_op ::= MATCH */ - -1, /* (584) compare_op ::= NMATCH */ - -1, /* (585) compare_op ::= CONTAINS */ - -1, /* (586) in_op ::= IN */ - -2, /* (587) in_op ::= NOT IN */ - -3, /* (588) in_predicate_value ::= NK_LP literal_list NK_RP */ - -1, /* (589) boolean_value_expression ::= boolean_primary */ - -2, /* (590) boolean_value_expression ::= NOT boolean_primary */ - -3, /* (591) boolean_value_expression ::= boolean_value_expression OR boolean_value_expression */ - -3, /* (592) boolean_value_expression ::= boolean_value_expression AND boolean_value_expression */ - -1, /* (593) boolean_primary ::= predicate */ - -3, /* (594) boolean_primary ::= NK_LP boolean_value_expression NK_RP */ - -1, /* (595) common_expression ::= expr_or_subquery */ - -1, /* (596) common_expression ::= boolean_value_expression */ - 0, /* (597) from_clause_opt ::= */ - -2, /* (598) from_clause_opt ::= FROM table_reference_list */ - -1, /* (599) table_reference_list ::= table_reference */ - -3, /* (600) table_reference_list ::= table_reference_list NK_COMMA table_reference */ - -1, /* (601) table_reference ::= table_primary */ - -1, /* (602) table_reference ::= joined_table */ - -2, /* (603) table_primary ::= table_name alias_opt */ - -4, /* (604) table_primary ::= db_name NK_DOT table_name alias_opt */ - -2, /* (605) table_primary ::= subquery alias_opt */ - -1, /* (606) table_primary ::= parenthesized_joined_table */ - 0, /* (607) alias_opt ::= */ - -1, /* (608) alias_opt ::= table_alias */ - -2, /* (609) alias_opt ::= AS table_alias */ - -3, /* (610) parenthesized_joined_table ::= NK_LP joined_table NK_RP */ - -3, /* (611) parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP */ - -6, /* (612) joined_table ::= table_reference join_type JOIN table_reference ON search_condition */ - 0, /* (613) join_type ::= */ - -1, /* (614) join_type ::= INNER */ - -14, /* (615) query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt */ - 0, /* (616) hint_list ::= */ - -1, /* (617) hint_list ::= NK_HINT */ - 0, /* (618) tag_mode_opt ::= */ - -1, /* (619) tag_mode_opt ::= TAGS */ - 0, /* (620) set_quantifier_opt ::= */ - -1, /* (621) set_quantifier_opt ::= DISTINCT */ - -1, /* (622) set_quantifier_opt ::= ALL */ - -1, /* (623) select_list ::= select_item */ - -3, /* (624) select_list ::= select_list NK_COMMA select_item */ - -1, /* (625) select_item ::= NK_STAR */ - -1, /* (626) select_item ::= common_expression */ - -2, /* (627) select_item ::= common_expression column_alias */ - -3, /* (628) select_item ::= common_expression AS column_alias */ - -3, /* (629) select_item ::= table_name NK_DOT NK_STAR */ - 0, /* (630) where_clause_opt ::= */ - -2, /* (631) where_clause_opt ::= WHERE search_condition */ - 0, /* (632) partition_by_clause_opt ::= */ - -3, /* (633) partition_by_clause_opt ::= PARTITION BY partition_list */ - -1, /* (634) partition_list ::= partition_item */ - -3, /* (635) partition_list ::= partition_list NK_COMMA partition_item */ - -1, /* (636) partition_item ::= expr_or_subquery */ - -2, /* (637) partition_item ::= expr_or_subquery column_alias */ - -3, /* (638) partition_item ::= expr_or_subquery AS column_alias */ - 0, /* (639) twindow_clause_opt ::= */ - -6, /* (640) twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP */ - -4, /* (641) twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP */ - -6, /* (642) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ - -8, /* (643) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ - -7, /* (644) twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition */ - -4, /* (645) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP */ - -6, /* (646) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ - 0, /* (647) sliding_opt ::= */ - -4, /* (648) sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP */ - -1, /* (649) interval_sliding_duration_literal ::= NK_VARIABLE */ - -1, /* (650) interval_sliding_duration_literal ::= NK_STRING */ - -1, /* (651) interval_sliding_duration_literal ::= NK_INTEGER */ - 0, /* (652) fill_opt ::= */ - -4, /* (653) fill_opt ::= FILL NK_LP fill_mode NK_RP */ - -6, /* (654) fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP */ - -6, /* (655) fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP */ - -1, /* (656) fill_mode ::= NONE */ - -1, /* (657) fill_mode ::= PREV */ - -1, /* (658) fill_mode ::= NULL */ - -1, /* (659) fill_mode ::= NULL_F */ - -1, /* (660) fill_mode ::= LINEAR */ - -1, /* (661) fill_mode ::= NEXT */ - 0, /* (662) group_by_clause_opt ::= */ - -3, /* (663) group_by_clause_opt ::= GROUP BY group_by_list */ - -1, /* (664) group_by_list ::= expr_or_subquery */ - -3, /* (665) group_by_list ::= group_by_list NK_COMMA expr_or_subquery */ - 0, /* (666) having_clause_opt ::= */ - -2, /* (667) having_clause_opt ::= HAVING search_condition */ - 0, /* (668) range_opt ::= */ - -6, /* (669) range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP */ - -4, /* (670) range_opt ::= RANGE NK_LP expr_or_subquery NK_RP */ - 0, /* (671) every_opt ::= */ - -4, /* (672) every_opt ::= EVERY NK_LP duration_literal NK_RP */ - -4, /* (673) query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt */ - -1, /* (674) query_simple ::= query_specification */ - -1, /* (675) query_simple ::= union_query_expression */ - -4, /* (676) union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery */ - -3, /* (677) union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery */ - -1, /* (678) query_simple_or_subquery ::= query_simple */ - -1, /* (679) query_simple_or_subquery ::= subquery */ - -1, /* (680) query_or_subquery ::= query_expression */ - -1, /* (681) query_or_subquery ::= subquery */ - 0, /* (682) order_by_clause_opt ::= */ - -3, /* (683) order_by_clause_opt ::= ORDER BY sort_specification_list */ - 0, /* (684) slimit_clause_opt ::= */ - -2, /* (685) slimit_clause_opt ::= SLIMIT NK_INTEGER */ - -4, /* (686) slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER */ - -4, /* (687) slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER */ - 0, /* (688) limit_clause_opt ::= */ - -2, /* (689) limit_clause_opt ::= LIMIT NK_INTEGER */ - -4, /* (690) limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER */ - -4, /* (691) limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER */ - -3, /* (692) subquery ::= NK_LP query_expression NK_RP */ - -3, /* (693) subquery ::= NK_LP subquery NK_RP */ - -1, /* (694) search_condition ::= common_expression */ - -1, /* (695) sort_specification_list ::= sort_specification */ - -3, /* (696) sort_specification_list ::= sort_specification_list NK_COMMA sort_specification */ - -3, /* (697) sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt */ - 0, /* (698) ordering_specification_opt ::= */ - -1, /* (699) ordering_specification_opt ::= ASC */ - -1, /* (700) ordering_specification_opt ::= DESC */ - 0, /* (701) null_ordering_opt ::= */ - -2, /* (702) null_ordering_opt ::= NULLS FIRST */ - -2, /* (703) null_ordering_opt ::= NULLS LAST */ + -1, /* (228) type_name_default_len ::= BINARY */ + -1, /* (229) type_name_default_len ::= NCHAR */ + -1, /* (230) type_name_default_len ::= VARCHAR */ + -1, /* (231) type_name_default_len ::= VARBINARY */ + 0, /* (232) tags_def_opt ::= */ + -1, /* (233) tags_def_opt ::= tags_def */ + -4, /* (234) tags_def ::= TAGS NK_LP column_def_list NK_RP */ + 0, /* (235) table_options ::= */ + -3, /* (236) table_options ::= table_options COMMENT NK_STRING */ + -3, /* (237) table_options ::= table_options MAX_DELAY duration_list */ + -3, /* (238) table_options ::= table_options WATERMARK duration_list */ + -5, /* (239) table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP */ + -3, /* (240) table_options ::= table_options TTL NK_INTEGER */ + -5, /* (241) table_options ::= table_options SMA NK_LP col_name_list NK_RP */ + -3, /* (242) table_options ::= table_options DELETE_MARK duration_list */ + -1, /* (243) alter_table_options ::= alter_table_option */ + -2, /* (244) alter_table_options ::= alter_table_options alter_table_option */ + -2, /* (245) alter_table_option ::= COMMENT NK_STRING */ + -2, /* (246) alter_table_option ::= TTL NK_INTEGER */ + -1, /* (247) duration_list ::= duration_literal */ + -3, /* (248) duration_list ::= duration_list NK_COMMA duration_literal */ + -1, /* (249) rollup_func_list ::= rollup_func_name */ + -3, /* (250) rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name */ + -1, /* (251) rollup_func_name ::= function_name */ + -1, /* (252) rollup_func_name ::= FIRST */ + -1, /* (253) rollup_func_name ::= LAST */ + -1, /* (254) col_name_list ::= col_name */ + -3, /* (255) col_name_list ::= col_name_list NK_COMMA col_name */ + -1, /* (256) col_name ::= column_name */ + -2, /* (257) cmd ::= SHOW DNODES */ + -2, /* (258) cmd ::= SHOW USERS */ + -3, /* (259) cmd ::= SHOW USER PRIVILEGES */ + -3, /* (260) cmd ::= SHOW db_kind_opt DATABASES */ + -4, /* (261) cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt */ + -4, /* (262) cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt */ + -3, /* (263) cmd ::= SHOW db_name_cond_opt VGROUPS */ + -2, /* (264) cmd ::= SHOW MNODES */ + -2, /* (265) cmd ::= SHOW QNODES */ + -2, /* (266) cmd ::= SHOW ARBGROUPS */ + -2, /* (267) cmd ::= SHOW FUNCTIONS */ + -5, /* (268) cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt */ + -6, /* (269) cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name */ + -2, /* (270) cmd ::= SHOW STREAMS */ + -2, /* (271) cmd ::= SHOW ACCOUNTS */ + -2, /* (272) cmd ::= SHOW APPS */ + -2, /* (273) cmd ::= SHOW CONNECTIONS */ + -2, /* (274) cmd ::= SHOW LICENCES */ + -2, /* (275) cmd ::= SHOW GRANTS */ + -3, /* (276) cmd ::= SHOW GRANTS FULL */ + -3, /* (277) cmd ::= SHOW GRANTS LOGS */ + -3, /* (278) cmd ::= SHOW CLUSTER MACHINES */ + -4, /* (279) cmd ::= SHOW CREATE DATABASE db_name */ + -4, /* (280) cmd ::= SHOW CREATE TABLE full_table_name */ + -4, /* (281) cmd ::= SHOW CREATE STABLE full_table_name */ + -2, /* (282) cmd ::= SHOW QUERIES */ + -2, /* (283) cmd ::= SHOW SCORES */ + -2, /* (284) cmd ::= SHOW TOPICS */ + -2, /* (285) cmd ::= SHOW VARIABLES */ + -3, /* (286) cmd ::= SHOW CLUSTER VARIABLES */ + -3, /* (287) cmd ::= SHOW LOCAL VARIABLES */ + -5, /* (288) cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt */ + -2, /* (289) cmd ::= SHOW BNODES */ + -2, /* (290) cmd ::= SHOW SNODES */ + -2, /* (291) cmd ::= SHOW CLUSTER */ + -2, /* (292) cmd ::= SHOW TRANSACTIONS */ + -4, /* (293) cmd ::= SHOW TABLE DISTRIBUTED full_table_name */ + -2, /* (294) cmd ::= SHOW CONSUMERS */ + -2, /* (295) cmd ::= SHOW SUBSCRIPTIONS */ + -5, /* (296) cmd ::= SHOW TAGS FROM table_name_cond from_db_opt */ + -6, /* (297) cmd ::= SHOW TAGS FROM db_name NK_DOT table_name */ + -7, /* (298) cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt */ + -8, /* (299) cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name */ + -5, /* (300) cmd ::= SHOW VNODES ON DNODE NK_INTEGER */ + -2, /* (301) cmd ::= SHOW VNODES */ + -3, /* (302) cmd ::= SHOW db_name_cond_opt ALIVE */ + -3, /* (303) cmd ::= SHOW CLUSTER ALIVE */ + -4, /* (304) cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt */ + -4, /* (305) cmd ::= SHOW CREATE VIEW full_table_name */ + -2, /* (306) cmd ::= SHOW COMPACTS */ + -3, /* (307) cmd ::= SHOW COMPACT NK_INTEGER */ + 0, /* (308) table_kind_db_name_cond_opt ::= */ + -1, /* (309) table_kind_db_name_cond_opt ::= table_kind */ + -2, /* (310) table_kind_db_name_cond_opt ::= db_name NK_DOT */ + -3, /* (311) table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT */ + -1, /* (312) table_kind ::= NORMAL */ + -1, /* (313) table_kind ::= CHILD */ + 0, /* (314) db_name_cond_opt ::= */ + -2, /* (315) db_name_cond_opt ::= db_name NK_DOT */ + 0, /* (316) like_pattern_opt ::= */ + -2, /* (317) like_pattern_opt ::= LIKE NK_STRING */ + -1, /* (318) table_name_cond ::= table_name */ + 0, /* (319) from_db_opt ::= */ + -2, /* (320) from_db_opt ::= FROM db_name */ + 0, /* (321) tag_list_opt ::= */ + -1, /* (322) tag_list_opt ::= tag_item */ + -3, /* (323) tag_list_opt ::= tag_list_opt NK_COMMA tag_item */ + -1, /* (324) tag_item ::= TBNAME */ + -1, /* (325) tag_item ::= QTAGS */ + -1, /* (326) tag_item ::= column_name */ + -2, /* (327) tag_item ::= column_name column_alias */ + -3, /* (328) tag_item ::= column_name AS column_alias */ + 0, /* (329) db_kind_opt ::= */ + -1, /* (330) db_kind_opt ::= USER */ + -1, /* (331) db_kind_opt ::= SYSTEM */ + -8, /* (332) cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options */ + -9, /* (333) cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP */ + -4, /* (334) cmd ::= DROP INDEX exists_opt full_index_name */ + -1, /* (335) full_index_name ::= index_name */ + -3, /* (336) full_index_name ::= db_name NK_DOT index_name */ + -10, /* (337) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt */ + -12, /* (338) index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt */ + -1, /* (339) func_list ::= func */ + -3, /* (340) func_list ::= func_list NK_COMMA func */ + -4, /* (341) func ::= sma_func_name NK_LP expression_list NK_RP */ + -1, /* (342) sma_func_name ::= function_name */ + -1, /* (343) sma_func_name ::= COUNT */ + -1, /* (344) sma_func_name ::= FIRST */ + -1, /* (345) sma_func_name ::= LAST */ + -1, /* (346) sma_func_name ::= LAST_ROW */ + 0, /* (347) sma_stream_opt ::= */ + -3, /* (348) sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal */ + -3, /* (349) sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal */ + -3, /* (350) sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal */ + -1, /* (351) with_meta ::= AS */ + -3, /* (352) with_meta ::= WITH META AS */ + -3, /* (353) with_meta ::= ONLY META AS */ + -6, /* (354) cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery */ + -7, /* (355) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name */ + -8, /* (356) cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt */ + -4, /* (357) cmd ::= DROP TOPIC exists_opt topic_name */ + -7, /* (358) cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name */ + -2, /* (359) cmd ::= DESC full_table_name */ + -2, /* (360) cmd ::= DESCRIBE full_table_name */ + -3, /* (361) cmd ::= RESET QUERY CACHE */ + -4, /* (362) cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery */ + -4, /* (363) cmd ::= EXPLAIN analyze_opt explain_options insert_query */ + 0, /* (364) analyze_opt ::= */ + -1, /* (365) analyze_opt ::= ANALYZE */ + 0, /* (366) explain_options ::= */ + -3, /* (367) explain_options ::= explain_options VERBOSE NK_BOOL */ + -3, /* (368) explain_options ::= explain_options RATIO NK_FLOAT */ + -12, /* (369) cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt */ + -4, /* (370) cmd ::= DROP FUNCTION exists_opt function_name */ + 0, /* (371) agg_func_opt ::= */ + -1, /* (372) agg_func_opt ::= AGGREGATE */ + 0, /* (373) bufsize_opt ::= */ + -2, /* (374) bufsize_opt ::= BUFSIZE NK_INTEGER */ + 0, /* (375) language_opt ::= */ + -2, /* (376) language_opt ::= LANGUAGE NK_STRING */ + 0, /* (377) or_replace_opt ::= */ + -2, /* (378) or_replace_opt ::= OR REPLACE */ + -6, /* (379) cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery */ + -4, /* (380) cmd ::= DROP VIEW exists_opt full_view_name */ + -1, /* (381) full_view_name ::= view_name */ + -3, /* (382) full_view_name ::= db_name NK_DOT view_name */ + -12, /* (383) cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery */ + -4, /* (384) cmd ::= DROP STREAM exists_opt stream_name */ + -4, /* (385) cmd ::= PAUSE STREAM exists_opt stream_name */ + -5, /* (386) cmd ::= RESUME STREAM exists_opt ignore_opt stream_name */ + 0, /* (387) col_list_opt ::= */ + -3, /* (388) col_list_opt ::= NK_LP column_stream_def_list NK_RP */ + -1, /* (389) column_stream_def_list ::= column_stream_def */ + -3, /* (390) column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def */ + -1, /* (391) column_stream_def ::= column_name */ + -3, /* (392) column_stream_def ::= column_name PRIMARY KEY */ + 0, /* (393) tag_def_or_ref_opt ::= */ + -1, /* (394) tag_def_or_ref_opt ::= tags_def */ + -4, /* (395) tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP */ + 0, /* (396) stream_options ::= */ + -3, /* (397) stream_options ::= stream_options TRIGGER AT_ONCE */ + -3, /* (398) stream_options ::= stream_options TRIGGER WINDOW_CLOSE */ + -4, /* (399) stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal */ + -3, /* (400) stream_options ::= stream_options WATERMARK duration_literal */ + -4, /* (401) stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER */ + -3, /* (402) stream_options ::= stream_options FILL_HISTORY NK_INTEGER */ + -3, /* (403) stream_options ::= stream_options DELETE_MARK duration_literal */ + -4, /* (404) stream_options ::= stream_options IGNORE UPDATE NK_INTEGER */ + 0, /* (405) subtable_opt ::= */ + -4, /* (406) subtable_opt ::= SUBTABLE NK_LP expression NK_RP */ + 0, /* (407) ignore_opt ::= */ + -2, /* (408) ignore_opt ::= IGNORE UNTREATED */ + -3, /* (409) cmd ::= KILL CONNECTION NK_INTEGER */ + -3, /* (410) cmd ::= KILL QUERY NK_STRING */ + -3, /* (411) cmd ::= KILL TRANSACTION NK_INTEGER */ + -3, /* (412) cmd ::= KILL COMPACT NK_INTEGER */ + -2, /* (413) cmd ::= BALANCE VGROUP */ + -4, /* (414) cmd ::= BALANCE VGROUP LEADER on_vgroup_id */ + -4, /* (415) cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER */ + -4, /* (416) cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list */ + -3, /* (417) cmd ::= SPLIT VGROUP NK_INTEGER */ + 0, /* (418) on_vgroup_id ::= */ + -2, /* (419) on_vgroup_id ::= ON NK_INTEGER */ + -2, /* (420) dnode_list ::= DNODE NK_INTEGER */ + -3, /* (421) dnode_list ::= dnode_list DNODE NK_INTEGER */ + -4, /* (422) cmd ::= DELETE FROM full_table_name where_clause_opt */ + -1, /* (423) cmd ::= query_or_subquery */ + -1, /* (424) cmd ::= insert_query */ + -7, /* (425) insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery */ + -4, /* (426) insert_query ::= INSERT INTO full_table_name query_or_subquery */ + -1, /* (427) tags_literal ::= NK_INTEGER */ + -3, /* (428) tags_literal ::= NK_INTEGER NK_PLUS duration_literal */ + -3, /* (429) tags_literal ::= NK_INTEGER NK_MINUS duration_literal */ + -2, /* (430) tags_literal ::= NK_PLUS NK_INTEGER */ + -4, /* (431) tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal */ + -4, /* (432) tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal */ + -2, /* (433) tags_literal ::= NK_MINUS NK_INTEGER */ + -4, /* (434) tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal */ + -4, /* (435) tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal */ + -1, /* (436) tags_literal ::= NK_FLOAT */ + -2, /* (437) tags_literal ::= NK_PLUS NK_FLOAT */ + -2, /* (438) tags_literal ::= NK_MINUS NK_FLOAT */ + -1, /* (439) tags_literal ::= NK_BIN */ + -3, /* (440) tags_literal ::= NK_BIN NK_PLUS duration_literal */ + -3, /* (441) tags_literal ::= NK_BIN NK_MINUS duration_literal */ + -2, /* (442) tags_literal ::= NK_PLUS NK_BIN */ + -4, /* (443) tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal */ + -4, /* (444) tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal */ + -2, /* (445) tags_literal ::= NK_MINUS NK_BIN */ + -4, /* (446) tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal */ + -4, /* (447) tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal */ + -1, /* (448) tags_literal ::= NK_HEX */ + -3, /* (449) tags_literal ::= NK_HEX NK_PLUS duration_literal */ + -3, /* (450) tags_literal ::= NK_HEX NK_MINUS duration_literal */ + -2, /* (451) tags_literal ::= NK_PLUS NK_HEX */ + -4, /* (452) tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal */ + -4, /* (453) tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal */ + -2, /* (454) tags_literal ::= NK_MINUS NK_HEX */ + -4, /* (455) tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal */ + -4, /* (456) tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal */ + -1, /* (457) tags_literal ::= NK_STRING */ + -3, /* (458) tags_literal ::= NK_STRING NK_PLUS duration_literal */ + -3, /* (459) tags_literal ::= NK_STRING NK_MINUS duration_literal */ + -1, /* (460) tags_literal ::= NK_BOOL */ + -1, /* (461) tags_literal ::= NULL */ + -1, /* (462) tags_literal ::= literal_func */ + -3, /* (463) tags_literal ::= literal_func NK_PLUS duration_literal */ + -3, /* (464) tags_literal ::= literal_func NK_MINUS duration_literal */ + -1, /* (465) tags_literal_list ::= tags_literal */ + -3, /* (466) tags_literal_list ::= tags_literal_list NK_COMMA tags_literal */ + -1, /* (467) literal ::= NK_INTEGER */ + -1, /* (468) literal ::= NK_FLOAT */ + -1, /* (469) literal ::= NK_STRING */ + -1, /* (470) literal ::= NK_BOOL */ + -2, /* (471) literal ::= TIMESTAMP NK_STRING */ + -1, /* (472) literal ::= duration_literal */ + -1, /* (473) literal ::= NULL */ + -1, /* (474) literal ::= NK_QUESTION */ + -1, /* (475) duration_literal ::= NK_VARIABLE */ + -1, /* (476) signed ::= NK_INTEGER */ + -2, /* (477) signed ::= NK_PLUS NK_INTEGER */ + -2, /* (478) signed ::= NK_MINUS NK_INTEGER */ + -1, /* (479) signed ::= NK_FLOAT */ + -2, /* (480) signed ::= NK_PLUS NK_FLOAT */ + -2, /* (481) signed ::= NK_MINUS NK_FLOAT */ + -1, /* (482) signed_literal ::= signed */ + -1, /* (483) signed_literal ::= NK_STRING */ + -1, /* (484) signed_literal ::= NK_BOOL */ + -2, /* (485) signed_literal ::= TIMESTAMP NK_STRING */ + -1, /* (486) signed_literal ::= duration_literal */ + -1, /* (487) signed_literal ::= NULL */ + -1, /* (488) signed_literal ::= literal_func */ + -1, /* (489) signed_literal ::= NK_QUESTION */ + -1, /* (490) literal_list ::= signed_literal */ + -3, /* (491) literal_list ::= literal_list NK_COMMA signed_literal */ + -1, /* (492) db_name ::= NK_ID */ + -1, /* (493) table_name ::= NK_ID */ + -1, /* (494) column_name ::= NK_ID */ + -1, /* (495) function_name ::= NK_ID */ + -1, /* (496) view_name ::= NK_ID */ + -1, /* (497) table_alias ::= NK_ID */ + -1, /* (498) column_alias ::= NK_ID */ + -1, /* (499) column_alias ::= NK_ALIAS */ + -1, /* (500) user_name ::= NK_ID */ + -1, /* (501) topic_name ::= NK_ID */ + -1, /* (502) stream_name ::= NK_ID */ + -1, /* (503) cgroup_name ::= NK_ID */ + -1, /* (504) index_name ::= NK_ID */ + -1, /* (505) expr_or_subquery ::= expression */ + -1, /* (506) expression ::= literal */ + -1, /* (507) expression ::= pseudo_column */ + -1, /* (508) expression ::= column_reference */ + -1, /* (509) expression ::= function_expression */ + -1, /* (510) expression ::= case_when_expression */ + -3, /* (511) expression ::= NK_LP expression NK_RP */ + -2, /* (512) expression ::= NK_PLUS expr_or_subquery */ + -2, /* (513) expression ::= NK_MINUS expr_or_subquery */ + -3, /* (514) expression ::= expr_or_subquery NK_PLUS expr_or_subquery */ + -3, /* (515) expression ::= expr_or_subquery NK_MINUS expr_or_subquery */ + -3, /* (516) expression ::= expr_or_subquery NK_STAR expr_or_subquery */ + -3, /* (517) expression ::= expr_or_subquery NK_SLASH expr_or_subquery */ + -3, /* (518) expression ::= expr_or_subquery NK_REM expr_or_subquery */ + -3, /* (519) expression ::= column_reference NK_ARROW NK_STRING */ + -3, /* (520) expression ::= expr_or_subquery NK_BITAND expr_or_subquery */ + -3, /* (521) expression ::= expr_or_subquery NK_BITOR expr_or_subquery */ + -1, /* (522) expression_list ::= expr_or_subquery */ + -3, /* (523) expression_list ::= expression_list NK_COMMA expr_or_subquery */ + -1, /* (524) column_reference ::= column_name */ + -3, /* (525) column_reference ::= table_name NK_DOT column_name */ + -1, /* (526) column_reference ::= NK_ALIAS */ + -3, /* (527) column_reference ::= table_name NK_DOT NK_ALIAS */ + -1, /* (528) pseudo_column ::= ROWTS */ + -1, /* (529) pseudo_column ::= TBNAME */ + -3, /* (530) pseudo_column ::= table_name NK_DOT TBNAME */ + -1, /* (531) pseudo_column ::= QSTART */ + -1, /* (532) pseudo_column ::= QEND */ + -1, /* (533) pseudo_column ::= QDURATION */ + -1, /* (534) pseudo_column ::= WSTART */ + -1, /* (535) pseudo_column ::= WEND */ + -1, /* (536) pseudo_column ::= WDURATION */ + -1, /* (537) pseudo_column ::= IROWTS */ + -1, /* (538) pseudo_column ::= ISFILLED */ + -1, /* (539) pseudo_column ::= QTAGS */ + -4, /* (540) function_expression ::= function_name NK_LP expression_list NK_RP */ + -4, /* (541) function_expression ::= star_func NK_LP star_func_para_list NK_RP */ + -6, /* (542) function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP */ + -6, /* (543) function_expression ::= CAST NK_LP expr_or_subquery AS type_name_default_len NK_RP */ + -1, /* (544) function_expression ::= literal_func */ + -3, /* (545) literal_func ::= noarg_func NK_LP NK_RP */ + -1, /* (546) literal_func ::= NOW */ + -1, /* (547) literal_func ::= TODAY */ + -1, /* (548) noarg_func ::= NOW */ + -1, /* (549) noarg_func ::= TODAY */ + -1, /* (550) noarg_func ::= TIMEZONE */ + -1, /* (551) noarg_func ::= DATABASE */ + -1, /* (552) noarg_func ::= CLIENT_VERSION */ + -1, /* (553) noarg_func ::= SERVER_VERSION */ + -1, /* (554) noarg_func ::= SERVER_STATUS */ + -1, /* (555) noarg_func ::= CURRENT_USER */ + -1, /* (556) noarg_func ::= USER */ + -1, /* (557) star_func ::= COUNT */ + -1, /* (558) star_func ::= FIRST */ + -1, /* (559) star_func ::= LAST */ + -1, /* (560) star_func ::= LAST_ROW */ + -1, /* (561) star_func_para_list ::= NK_STAR */ + -1, /* (562) star_func_para_list ::= other_para_list */ + -1, /* (563) other_para_list ::= star_func_para */ + -3, /* (564) other_para_list ::= other_para_list NK_COMMA star_func_para */ + -1, /* (565) star_func_para ::= expr_or_subquery */ + -3, /* (566) star_func_para ::= table_name NK_DOT NK_STAR */ + -4, /* (567) case_when_expression ::= CASE when_then_list case_when_else_opt END */ + -5, /* (568) case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END */ + -1, /* (569) when_then_list ::= when_then_expr */ + -2, /* (570) when_then_list ::= when_then_list when_then_expr */ + -4, /* (571) when_then_expr ::= WHEN common_expression THEN common_expression */ + 0, /* (572) case_when_else_opt ::= */ + -2, /* (573) case_when_else_opt ::= ELSE common_expression */ + -3, /* (574) predicate ::= expr_or_subquery compare_op expr_or_subquery */ + -5, /* (575) predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery */ + -6, /* (576) predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery */ + -3, /* (577) predicate ::= expr_or_subquery IS NULL */ + -4, /* (578) predicate ::= expr_or_subquery IS NOT NULL */ + -3, /* (579) predicate ::= expr_or_subquery in_op in_predicate_value */ + -1, /* (580) compare_op ::= NK_LT */ + -1, /* (581) compare_op ::= NK_GT */ + -1, /* (582) compare_op ::= NK_LE */ + -1, /* (583) compare_op ::= NK_GE */ + -1, /* (584) compare_op ::= NK_NE */ + -1, /* (585) compare_op ::= NK_EQ */ + -1, /* (586) compare_op ::= LIKE */ + -2, /* (587) compare_op ::= NOT LIKE */ + -1, /* (588) compare_op ::= MATCH */ + -1, /* (589) compare_op ::= NMATCH */ + -1, /* (590) compare_op ::= CONTAINS */ + -1, /* (591) in_op ::= IN */ + -2, /* (592) in_op ::= NOT IN */ + -3, /* (593) in_predicate_value ::= NK_LP literal_list NK_RP */ + -1, /* (594) boolean_value_expression ::= boolean_primary */ + -2, /* (595) boolean_value_expression ::= NOT boolean_primary */ + -3, /* (596) boolean_value_expression ::= boolean_value_expression OR boolean_value_expression */ + -3, /* (597) boolean_value_expression ::= boolean_value_expression AND boolean_value_expression */ + -1, /* (598) boolean_primary ::= predicate */ + -3, /* (599) boolean_primary ::= NK_LP boolean_value_expression NK_RP */ + -1, /* (600) common_expression ::= expr_or_subquery */ + -1, /* (601) common_expression ::= boolean_value_expression */ + 0, /* (602) from_clause_opt ::= */ + -2, /* (603) from_clause_opt ::= FROM table_reference_list */ + -1, /* (604) table_reference_list ::= table_reference */ + -3, /* (605) table_reference_list ::= table_reference_list NK_COMMA table_reference */ + -1, /* (606) table_reference ::= table_primary */ + -1, /* (607) table_reference ::= joined_table */ + -2, /* (608) table_primary ::= table_name alias_opt */ + -4, /* (609) table_primary ::= db_name NK_DOT table_name alias_opt */ + -2, /* (610) table_primary ::= subquery alias_opt */ + -1, /* (611) table_primary ::= parenthesized_joined_table */ + 0, /* (612) alias_opt ::= */ + -1, /* (613) alias_opt ::= table_alias */ + -2, /* (614) alias_opt ::= AS table_alias */ + -3, /* (615) parenthesized_joined_table ::= NK_LP joined_table NK_RP */ + -3, /* (616) parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP */ + -6, /* (617) joined_table ::= table_reference join_type JOIN table_reference ON search_condition */ + 0, /* (618) join_type ::= */ + -1, /* (619) join_type ::= INNER */ + -14, /* (620) query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt */ + 0, /* (621) hint_list ::= */ + -1, /* (622) hint_list ::= NK_HINT */ + 0, /* (623) tag_mode_opt ::= */ + -1, /* (624) tag_mode_opt ::= TAGS */ + 0, /* (625) set_quantifier_opt ::= */ + -1, /* (626) set_quantifier_opt ::= DISTINCT */ + -1, /* (627) set_quantifier_opt ::= ALL */ + -1, /* (628) select_list ::= select_item */ + -3, /* (629) select_list ::= select_list NK_COMMA select_item */ + -1, /* (630) select_item ::= NK_STAR */ + -1, /* (631) select_item ::= common_expression */ + -2, /* (632) select_item ::= common_expression column_alias */ + -3, /* (633) select_item ::= common_expression AS column_alias */ + -3, /* (634) select_item ::= table_name NK_DOT NK_STAR */ + 0, /* (635) where_clause_opt ::= */ + -2, /* (636) where_clause_opt ::= WHERE search_condition */ + 0, /* (637) partition_by_clause_opt ::= */ + -3, /* (638) partition_by_clause_opt ::= PARTITION BY partition_list */ + -1, /* (639) partition_list ::= partition_item */ + -3, /* (640) partition_list ::= partition_list NK_COMMA partition_item */ + -1, /* (641) partition_item ::= expr_or_subquery */ + -2, /* (642) partition_item ::= expr_or_subquery column_alias */ + -3, /* (643) partition_item ::= expr_or_subquery AS column_alias */ + 0, /* (644) twindow_clause_opt ::= */ + -6, /* (645) twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP */ + -4, /* (646) twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP */ + -6, /* (647) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ + -8, /* (648) twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ + -7, /* (649) twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition */ + -4, /* (650) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP */ + -6, /* (651) twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ + 0, /* (652) sliding_opt ::= */ + -4, /* (653) sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP */ + -1, /* (654) interval_sliding_duration_literal ::= NK_VARIABLE */ + -1, /* (655) interval_sliding_duration_literal ::= NK_STRING */ + -1, /* (656) interval_sliding_duration_literal ::= NK_INTEGER */ + 0, /* (657) fill_opt ::= */ + -4, /* (658) fill_opt ::= FILL NK_LP fill_mode NK_RP */ + -6, /* (659) fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP */ + -6, /* (660) fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP */ + -1, /* (661) fill_mode ::= NONE */ + -1, /* (662) fill_mode ::= PREV */ + -1, /* (663) fill_mode ::= NULL */ + -1, /* (664) fill_mode ::= NULL_F */ + -1, /* (665) fill_mode ::= LINEAR */ + -1, /* (666) fill_mode ::= NEXT */ + 0, /* (667) group_by_clause_opt ::= */ + -3, /* (668) group_by_clause_opt ::= GROUP BY group_by_list */ + -1, /* (669) group_by_list ::= expr_or_subquery */ + -3, /* (670) group_by_list ::= group_by_list NK_COMMA expr_or_subquery */ + 0, /* (671) having_clause_opt ::= */ + -2, /* (672) having_clause_opt ::= HAVING search_condition */ + 0, /* (673) range_opt ::= */ + -6, /* (674) range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP */ + -4, /* (675) range_opt ::= RANGE NK_LP expr_or_subquery NK_RP */ + 0, /* (676) every_opt ::= */ + -4, /* (677) every_opt ::= EVERY NK_LP duration_literal NK_RP */ + -4, /* (678) query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt */ + -1, /* (679) query_simple ::= query_specification */ + -1, /* (680) query_simple ::= union_query_expression */ + -4, /* (681) union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery */ + -3, /* (682) union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery */ + -1, /* (683) query_simple_or_subquery ::= query_simple */ + -1, /* (684) query_simple_or_subquery ::= subquery */ + -1, /* (685) query_or_subquery ::= query_expression */ + -1, /* (686) query_or_subquery ::= subquery */ + 0, /* (687) order_by_clause_opt ::= */ + -3, /* (688) order_by_clause_opt ::= ORDER BY sort_specification_list */ + 0, /* (689) slimit_clause_opt ::= */ + -2, /* (690) slimit_clause_opt ::= SLIMIT NK_INTEGER */ + -4, /* (691) slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER */ + -4, /* (692) slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER */ + 0, /* (693) limit_clause_opt ::= */ + -2, /* (694) limit_clause_opt ::= LIMIT NK_INTEGER */ + -4, /* (695) limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER */ + -4, /* (696) limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER */ + -3, /* (697) subquery ::= NK_LP query_expression NK_RP */ + -3, /* (698) subquery ::= NK_LP subquery NK_RP */ + -1, /* (699) search_condition ::= common_expression */ + -1, /* (700) sort_specification_list ::= sort_specification */ + -3, /* (701) sort_specification_list ::= sort_specification_list NK_COMMA sort_specification */ + -3, /* (702) sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt */ + 0, /* (703) ordering_specification_opt ::= */ + -1, /* (704) ordering_specification_opt ::= ASC */ + -1, /* (705) ordering_specification_opt ::= DESC */ + 0, /* (706) null_ordering_opt ::= */ + -2, /* (707) null_ordering_opt ::= NULLS FIRST */ + -2, /* (708) null_ordering_opt ::= NULLS LAST */ }; static void yy_accept(yyParser*); /* Forward Declaration */ @@ -5339,19 +5398,19 @@ static YYACTIONTYPE yy_reduce( case 0: /* cmd ::= CREATE ACCOUNT NK_ID PASS NK_STRING account_options */ #line 50 "sql.y" { pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_EXPRIE_STATEMENT); } -#line 5342 "sql.c" +#line 5401 "sql.c" yy_destructor(yypParser,360,&yymsp[0].minor); break; case 1: /* cmd ::= ALTER ACCOUNT NK_ID alter_account_options */ #line 51 "sql.y" { pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_EXPRIE_STATEMENT); } -#line 5348 "sql.c" +#line 5407 "sql.c" yy_destructor(yypParser,361,&yymsp[0].minor); break; case 2: /* account_options ::= */ #line 55 "sql.y" { } -#line 5354 "sql.c" +#line 5413 "sql.c" break; case 3: /* account_options ::= account_options PPS literal */ case 4: /* account_options ::= account_options TSERIES literal */ yytestcase(yyruleno==4); @@ -5365,7 +5424,7 @@ static YYACTIONTYPE yy_reduce( { yy_destructor(yypParser,360,&yymsp[-2].minor); #line 56 "sql.y" { } -#line 5368 "sql.c" +#line 5427 "sql.c" yy_destructor(yypParser,362,&yymsp[0].minor); } break; @@ -5373,14 +5432,14 @@ static YYACTIONTYPE yy_reduce( { yy_destructor(yypParser,363,&yymsp[0].minor); #line 68 "sql.y" { } -#line 5376 "sql.c" +#line 5435 "sql.c" } break; case 13: /* alter_account_options ::= alter_account_options alter_account_option */ { yy_destructor(yypParser,361,&yymsp[-1].minor); #line 69 "sql.y" { } -#line 5383 "sql.c" +#line 5442 "sql.c" yy_destructor(yypParser,363,&yymsp[0].minor); } break; @@ -5396,2845 +5455,2866 @@ static YYACTIONTYPE yy_reduce( case 23: /* alter_account_option ::= STATE literal */ yytestcase(yyruleno==23); #line 73 "sql.y" { } -#line 5399 "sql.c" +#line 5458 "sql.c" yy_destructor(yypParser,362,&yymsp[0].minor); break; case 24: /* ip_range_list ::= NK_STRING */ #line 86 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0)); } -#line 5405 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0)); } +#line 5464 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; case 25: /* ip_range_list ::= ip_range_list NK_COMMA NK_STRING */ #line 87 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-2].minor.yy72, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0)); } -#line 5411 "sql.c" - yymsp[-2].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-2].minor.yy124, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0)); } +#line 5470 "sql.c" + yymsp[-2].minor.yy124 = yylhsminor.yy124; break; case 26: /* white_list ::= HOST ip_range_list */ #line 91 "sql.y" -{ yymsp[-1].minor.yy72 = yymsp[0].minor.yy72; } -#line 5417 "sql.c" +{ yymsp[-1].minor.yy124 = yymsp[0].minor.yy124; } +#line 5476 "sql.c" break; case 27: /* white_list_opt ::= */ case 196: /* specific_cols_opt ::= */ yytestcase(yyruleno==196); - case 228: /* tags_def_opt ::= */ yytestcase(yyruleno==228); - case 317: /* tag_list_opt ::= */ yytestcase(yyruleno==317); - case 383: /* col_list_opt ::= */ yytestcase(yyruleno==383); - case 389: /* tag_def_or_ref_opt ::= */ yytestcase(yyruleno==389); - case 632: /* partition_by_clause_opt ::= */ yytestcase(yyruleno==632); - case 662: /* group_by_clause_opt ::= */ yytestcase(yyruleno==662); - case 682: /* order_by_clause_opt ::= */ yytestcase(yyruleno==682); + case 232: /* tags_def_opt ::= */ yytestcase(yyruleno==232); + case 321: /* tag_list_opt ::= */ yytestcase(yyruleno==321); + case 387: /* col_list_opt ::= */ yytestcase(yyruleno==387); + case 393: /* tag_def_or_ref_opt ::= */ yytestcase(yyruleno==393); + case 637: /* partition_by_clause_opt ::= */ yytestcase(yyruleno==637); + case 667: /* group_by_clause_opt ::= */ yytestcase(yyruleno==667); + case 687: /* order_by_clause_opt ::= */ yytestcase(yyruleno==687); #line 95 "sql.y" -{ yymsp[1].minor.yy72 = NULL; } -#line 5430 "sql.c" +{ yymsp[1].minor.yy124 = NULL; } +#line 5489 "sql.c" break; case 28: /* white_list_opt ::= white_list */ - case 229: /* tags_def_opt ::= tags_def */ yytestcase(yyruleno==229); - case 390: /* tag_def_or_ref_opt ::= tags_def */ yytestcase(yyruleno==390); - case 557: /* star_func_para_list ::= other_para_list */ yytestcase(yyruleno==557); + case 233: /* tags_def_opt ::= tags_def */ yytestcase(yyruleno==233); + case 394: /* tag_def_or_ref_opt ::= tags_def */ yytestcase(yyruleno==394); + case 562: /* star_func_para_list ::= other_para_list */ yytestcase(yyruleno==562); #line 96 "sql.y" -{ yylhsminor.yy72 = yymsp[0].minor.yy72; } -#line 5438 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = yymsp[0].minor.yy124; } +#line 5497 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; case 29: /* cmd ::= CREATE USER user_name PASS NK_STRING sysinfo_opt white_list_opt */ #line 100 "sql.y" { - pCxt->pRootNode = createCreateUserStmt(pCxt, &yymsp[-4].minor.yy305, &yymsp[-2].minor.yy0, yymsp[-1].minor.yy359); - pCxt->pRootNode = addCreateUserStmtWhiteList(pCxt, pCxt->pRootNode, yymsp[0].minor.yy72); + pCxt->pRootNode = createCreateUserStmt(pCxt, &yymsp[-4].minor.yy29, &yymsp[-2].minor.yy0, yymsp[-1].minor.yy803); + pCxt->pRootNode = addCreateUserStmtWhiteList(pCxt, pCxt->pRootNode, yymsp[0].minor.yy124); } -#line 5447 "sql.c" +#line 5506 "sql.c" break; case 30: /* cmd ::= ALTER USER user_name PASS NK_STRING */ #line 104 "sql.y" -{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy305, TSDB_ALTER_USER_PASSWD, &yymsp[0].minor.yy0); } -#line 5452 "sql.c" +{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy29, TSDB_ALTER_USER_PASSWD, &yymsp[0].minor.yy0); } +#line 5511 "sql.c" break; case 31: /* cmd ::= ALTER USER user_name ENABLE NK_INTEGER */ #line 105 "sql.y" -{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy305, TSDB_ALTER_USER_ENABLE, &yymsp[0].minor.yy0); } -#line 5457 "sql.c" +{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy29, TSDB_ALTER_USER_ENABLE, &yymsp[0].minor.yy0); } +#line 5516 "sql.c" break; case 32: /* cmd ::= ALTER USER user_name SYSINFO NK_INTEGER */ #line 106 "sql.y" -{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy305, TSDB_ALTER_USER_SYSINFO, &yymsp[0].minor.yy0); } -#line 5462 "sql.c" +{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy29, TSDB_ALTER_USER_SYSINFO, &yymsp[0].minor.yy0); } +#line 5521 "sql.c" break; case 33: /* cmd ::= ALTER USER user_name ADD white_list */ #line 107 "sql.y" -{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy305, TSDB_ALTER_USER_ADD_WHITE_LIST, yymsp[0].minor.yy72); } -#line 5467 "sql.c" +{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy29, TSDB_ALTER_USER_ADD_WHITE_LIST, yymsp[0].minor.yy124); } +#line 5526 "sql.c" break; case 34: /* cmd ::= ALTER USER user_name DROP white_list */ #line 108 "sql.y" -{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy305, TSDB_ALTER_USER_DROP_WHITE_LIST, yymsp[0].minor.yy72); } -#line 5472 "sql.c" +{ pCxt->pRootNode = createAlterUserStmt(pCxt, &yymsp[-2].minor.yy29, TSDB_ALTER_USER_DROP_WHITE_LIST, yymsp[0].minor.yy124); } +#line 5531 "sql.c" break; case 35: /* cmd ::= DROP USER user_name */ #line 109 "sql.y" -{ pCxt->pRootNode = createDropUserStmt(pCxt, &yymsp[0].minor.yy305); } -#line 5477 "sql.c" +{ pCxt->pRootNode = createDropUserStmt(pCxt, &yymsp[0].minor.yy29); } +#line 5536 "sql.c" break; case 36: /* sysinfo_opt ::= */ #line 113 "sql.y" -{ yymsp[1].minor.yy359 = 1; } -#line 5482 "sql.c" +{ yymsp[1].minor.yy803 = 1; } +#line 5541 "sql.c" break; case 37: /* sysinfo_opt ::= SYSINFO NK_INTEGER */ #line 114 "sql.y" -{ yymsp[-1].minor.yy359 = taosStr2Int8(yymsp[0].minor.yy0.z, NULL, 10); } -#line 5487 "sql.c" +{ yymsp[-1].minor.yy803 = taosStr2Int8(yymsp[0].minor.yy0.z, NULL, 10); } +#line 5546 "sql.c" break; case 38: /* cmd ::= GRANT privileges ON priv_level with_opt TO user_name */ #line 117 "sql.y" -{ pCxt->pRootNode = createGrantStmt(pCxt, yymsp[-5].minor.yy1005, &yymsp[-3].minor.yy361, &yymsp[0].minor.yy305, yymsp[-2].minor.yy1000); } -#line 5492 "sql.c" +{ pCxt->pRootNode = createGrantStmt(pCxt, yymsp[-5].minor.yy459, &yymsp[-3].minor.yy147, &yymsp[0].minor.yy29, yymsp[-2].minor.yy812); } +#line 5551 "sql.c" break; case 39: /* cmd ::= REVOKE privileges ON priv_level with_opt FROM user_name */ #line 118 "sql.y" -{ pCxt->pRootNode = createRevokeStmt(pCxt, yymsp[-5].minor.yy1005, &yymsp[-3].minor.yy361, &yymsp[0].minor.yy305, yymsp[-2].minor.yy1000); } -#line 5497 "sql.c" +{ pCxt->pRootNode = createRevokeStmt(pCxt, yymsp[-5].minor.yy459, &yymsp[-3].minor.yy147, &yymsp[0].minor.yy29, yymsp[-2].minor.yy812); } +#line 5556 "sql.c" break; case 40: /* privileges ::= ALL */ #line 122 "sql.y" -{ yymsp[0].minor.yy1005 = PRIVILEGE_TYPE_ALL; } -#line 5502 "sql.c" +{ yymsp[0].minor.yy459 = PRIVILEGE_TYPE_ALL; } +#line 5561 "sql.c" break; case 41: /* privileges ::= priv_type_list */ case 43: /* priv_type_list ::= priv_type */ yytestcase(yyruleno==43); #line 123 "sql.y" -{ yylhsminor.yy1005 = yymsp[0].minor.yy1005; } -#line 5508 "sql.c" - yymsp[0].minor.yy1005 = yylhsminor.yy1005; +{ yylhsminor.yy459 = yymsp[0].minor.yy459; } +#line 5567 "sql.c" + yymsp[0].minor.yy459 = yylhsminor.yy459; break; case 42: /* privileges ::= SUBSCRIBE */ #line 124 "sql.y" -{ yymsp[0].minor.yy1005 = PRIVILEGE_TYPE_SUBSCRIBE; } -#line 5514 "sql.c" +{ yymsp[0].minor.yy459 = PRIVILEGE_TYPE_SUBSCRIBE; } +#line 5573 "sql.c" break; case 44: /* priv_type_list ::= priv_type_list NK_COMMA priv_type */ #line 129 "sql.y" -{ yylhsminor.yy1005 = yymsp[-2].minor.yy1005 | yymsp[0].minor.yy1005; } -#line 5519 "sql.c" - yymsp[-2].minor.yy1005 = yylhsminor.yy1005; +{ yylhsminor.yy459 = yymsp[-2].minor.yy459 | yymsp[0].minor.yy459; } +#line 5578 "sql.c" + yymsp[-2].minor.yy459 = yylhsminor.yy459; break; case 45: /* priv_type ::= READ */ #line 133 "sql.y" -{ yymsp[0].minor.yy1005 = PRIVILEGE_TYPE_READ; } -#line 5525 "sql.c" +{ yymsp[0].minor.yy459 = PRIVILEGE_TYPE_READ; } +#line 5584 "sql.c" break; case 46: /* priv_type ::= WRITE */ #line 134 "sql.y" -{ yymsp[0].minor.yy1005 = PRIVILEGE_TYPE_WRITE; } -#line 5530 "sql.c" +{ yymsp[0].minor.yy459 = PRIVILEGE_TYPE_WRITE; } +#line 5589 "sql.c" break; case 47: /* priv_type ::= ALTER */ #line 135 "sql.y" -{ yymsp[0].minor.yy1005 = PRIVILEGE_TYPE_ALTER; } -#line 5535 "sql.c" +{ yymsp[0].minor.yy459 = PRIVILEGE_TYPE_ALTER; } +#line 5594 "sql.c" break; case 48: /* priv_level ::= NK_STAR NK_DOT NK_STAR */ #line 139 "sql.y" -{ yylhsminor.yy361.first = yymsp[-2].minor.yy0; yylhsminor.yy361.second = yymsp[0].minor.yy0; } -#line 5540 "sql.c" - yymsp[-2].minor.yy361 = yylhsminor.yy361; +{ yylhsminor.yy147.first = yymsp[-2].minor.yy0; yylhsminor.yy147.second = yymsp[0].minor.yy0; } +#line 5599 "sql.c" + yymsp[-2].minor.yy147 = yylhsminor.yy147; break; case 49: /* priv_level ::= db_name NK_DOT NK_STAR */ #line 140 "sql.y" -{ yylhsminor.yy361.first = yymsp[-2].minor.yy305; yylhsminor.yy361.second = yymsp[0].minor.yy0; } -#line 5546 "sql.c" - yymsp[-2].minor.yy361 = yylhsminor.yy361; +{ yylhsminor.yy147.first = yymsp[-2].minor.yy29; yylhsminor.yy147.second = yymsp[0].minor.yy0; } +#line 5605 "sql.c" + yymsp[-2].minor.yy147 = yylhsminor.yy147; break; case 50: /* priv_level ::= db_name NK_DOT table_name */ #line 141 "sql.y" -{ yylhsminor.yy361.first = yymsp[-2].minor.yy305; yylhsminor.yy361.second = yymsp[0].minor.yy305; } -#line 5552 "sql.c" - yymsp[-2].minor.yy361 = yylhsminor.yy361; +{ yylhsminor.yy147.first = yymsp[-2].minor.yy29; yylhsminor.yy147.second = yymsp[0].minor.yy29; } +#line 5611 "sql.c" + yymsp[-2].minor.yy147 = yylhsminor.yy147; break; case 51: /* priv_level ::= topic_name */ #line 142 "sql.y" -{ yylhsminor.yy361.first = yymsp[0].minor.yy305; yylhsminor.yy361.second = nil_token; } -#line 5558 "sql.c" - yymsp[0].minor.yy361 = yylhsminor.yy361; +{ yylhsminor.yy147.first = yymsp[0].minor.yy29; yylhsminor.yy147.second = nil_token; } +#line 5617 "sql.c" + yymsp[0].minor.yy147 = yylhsminor.yy147; break; case 52: /* with_opt ::= */ case 165: /* start_opt ::= */ yytestcase(yyruleno==165); case 169: /* end_opt ::= */ yytestcase(yyruleno==169); - case 312: /* like_pattern_opt ::= */ yytestcase(yyruleno==312); - case 401: /* subtable_opt ::= */ yytestcase(yyruleno==401); - case 567: /* case_when_else_opt ::= */ yytestcase(yyruleno==567); - case 597: /* from_clause_opt ::= */ yytestcase(yyruleno==597); - case 630: /* where_clause_opt ::= */ yytestcase(yyruleno==630); - case 639: /* twindow_clause_opt ::= */ yytestcase(yyruleno==639); - case 647: /* sliding_opt ::= */ yytestcase(yyruleno==647); - case 652: /* fill_opt ::= */ yytestcase(yyruleno==652); - case 666: /* having_clause_opt ::= */ yytestcase(yyruleno==666); - case 668: /* range_opt ::= */ yytestcase(yyruleno==668); - case 671: /* every_opt ::= */ yytestcase(yyruleno==671); - case 684: /* slimit_clause_opt ::= */ yytestcase(yyruleno==684); - case 688: /* limit_clause_opt ::= */ yytestcase(yyruleno==688); + case 316: /* like_pattern_opt ::= */ yytestcase(yyruleno==316); + case 405: /* subtable_opt ::= */ yytestcase(yyruleno==405); + case 572: /* case_when_else_opt ::= */ yytestcase(yyruleno==572); + case 602: /* from_clause_opt ::= */ yytestcase(yyruleno==602); + case 635: /* where_clause_opt ::= */ yytestcase(yyruleno==635); + case 644: /* twindow_clause_opt ::= */ yytestcase(yyruleno==644); + case 652: /* sliding_opt ::= */ yytestcase(yyruleno==652); + case 657: /* fill_opt ::= */ yytestcase(yyruleno==657); + case 671: /* having_clause_opt ::= */ yytestcase(yyruleno==671); + case 673: /* range_opt ::= */ yytestcase(yyruleno==673); + case 676: /* every_opt ::= */ yytestcase(yyruleno==676); + case 689: /* slimit_clause_opt ::= */ yytestcase(yyruleno==689); + case 693: /* limit_clause_opt ::= */ yytestcase(yyruleno==693); #line 144 "sql.y" -{ yymsp[1].minor.yy1000 = NULL; } -#line 5579 "sql.c" +{ yymsp[1].minor.yy812 = NULL; } +#line 5638 "sql.c" break; case 53: /* with_opt ::= WITH search_condition */ - case 598: /* from_clause_opt ::= FROM table_reference_list */ yytestcase(yyruleno==598); - case 631: /* where_clause_opt ::= WHERE search_condition */ yytestcase(yyruleno==631); - case 667: /* having_clause_opt ::= HAVING search_condition */ yytestcase(yyruleno==667); + case 603: /* from_clause_opt ::= FROM table_reference_list */ yytestcase(yyruleno==603); + case 636: /* where_clause_opt ::= WHERE search_condition */ yytestcase(yyruleno==636); + case 672: /* having_clause_opt ::= HAVING search_condition */ yytestcase(yyruleno==672); #line 145 "sql.y" -{ yymsp[-1].minor.yy1000 = yymsp[0].minor.yy1000; } -#line 5587 "sql.c" +{ yymsp[-1].minor.yy812 = yymsp[0].minor.yy812; } +#line 5646 "sql.c" break; case 54: /* cmd ::= CREATE DNODE dnode_endpoint */ #line 148 "sql.y" -{ pCxt->pRootNode = createCreateDnodeStmt(pCxt, &yymsp[0].minor.yy305, NULL); } -#line 5592 "sql.c" +{ pCxt->pRootNode = createCreateDnodeStmt(pCxt, &yymsp[0].minor.yy29, NULL); } +#line 5651 "sql.c" break; case 55: /* cmd ::= CREATE DNODE dnode_endpoint PORT NK_INTEGER */ #line 149 "sql.y" -{ pCxt->pRootNode = createCreateDnodeStmt(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy0); } -#line 5597 "sql.c" +{ pCxt->pRootNode = createCreateDnodeStmt(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy0); } +#line 5656 "sql.c" break; case 56: /* cmd ::= DROP DNODE NK_INTEGER force_opt */ #line 150 "sql.y" -{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy0, yymsp[0].minor.yy985, false); } -#line 5602 "sql.c" +{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy0, yymsp[0].minor.yy887, false); } +#line 5661 "sql.c" break; case 57: /* cmd ::= DROP DNODE dnode_endpoint force_opt */ #line 151 "sql.y" -{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy305, yymsp[0].minor.yy985, false); } -#line 5607 "sql.c" +{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy29, yymsp[0].minor.yy887, false); } +#line 5666 "sql.c" break; case 58: /* cmd ::= DROP DNODE NK_INTEGER unsafe_opt */ #line 152 "sql.y" -{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy0, false, yymsp[0].minor.yy985); } -#line 5612 "sql.c" +{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy0, false, yymsp[0].minor.yy887); } +#line 5671 "sql.c" break; case 59: /* cmd ::= DROP DNODE dnode_endpoint unsafe_opt */ #line 153 "sql.y" -{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy305, false, yymsp[0].minor.yy985); } -#line 5617 "sql.c" +{ pCxt->pRootNode = createDropDnodeStmt(pCxt, &yymsp[-1].minor.yy29, false, yymsp[0].minor.yy887); } +#line 5676 "sql.c" break; case 60: /* cmd ::= ALTER DNODE NK_INTEGER NK_STRING */ #line 154 "sql.y" { pCxt->pRootNode = createAlterDnodeStmt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0, NULL); } -#line 5622 "sql.c" +#line 5681 "sql.c" break; case 61: /* cmd ::= ALTER DNODE NK_INTEGER NK_STRING NK_STRING */ #line 155 "sql.y" { pCxt->pRootNode = createAlterDnodeStmt(pCxt, &yymsp[-2].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } -#line 5627 "sql.c" +#line 5686 "sql.c" break; case 62: /* cmd ::= ALTER ALL DNODES NK_STRING */ #line 156 "sql.y" { pCxt->pRootNode = createAlterDnodeStmt(pCxt, NULL, &yymsp[0].minor.yy0, NULL); } -#line 5632 "sql.c" +#line 5691 "sql.c" break; case 63: /* cmd ::= ALTER ALL DNODES NK_STRING NK_STRING */ #line 157 "sql.y" { pCxt->pRootNode = createAlterDnodeStmt(pCxt, NULL, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } -#line 5637 "sql.c" +#line 5696 "sql.c" break; case 64: /* cmd ::= RESTORE DNODE NK_INTEGER */ #line 158 "sql.y" { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_DNODE_STMT, &yymsp[0].minor.yy0); } -#line 5642 "sql.c" +#line 5701 "sql.c" break; case 65: /* dnode_endpoint ::= NK_STRING */ case 66: /* dnode_endpoint ::= NK_ID */ yytestcase(yyruleno==66); case 67: /* dnode_endpoint ::= NK_IPTOKEN */ yytestcase(yyruleno==67); - case 339: /* sma_func_name ::= COUNT */ yytestcase(yyruleno==339); - case 340: /* sma_func_name ::= FIRST */ yytestcase(yyruleno==340); - case 341: /* sma_func_name ::= LAST */ yytestcase(yyruleno==341); - case 342: /* sma_func_name ::= LAST_ROW */ yytestcase(yyruleno==342); - case 488: /* db_name ::= NK_ID */ yytestcase(yyruleno==488); - case 489: /* table_name ::= NK_ID */ yytestcase(yyruleno==489); - case 490: /* column_name ::= NK_ID */ yytestcase(yyruleno==490); - case 491: /* function_name ::= NK_ID */ yytestcase(yyruleno==491); - case 492: /* view_name ::= NK_ID */ yytestcase(yyruleno==492); - case 493: /* table_alias ::= NK_ID */ yytestcase(yyruleno==493); - case 494: /* column_alias ::= NK_ID */ yytestcase(yyruleno==494); - case 495: /* column_alias ::= NK_ALIAS */ yytestcase(yyruleno==495); - case 496: /* user_name ::= NK_ID */ yytestcase(yyruleno==496); - case 497: /* topic_name ::= NK_ID */ yytestcase(yyruleno==497); - case 498: /* stream_name ::= NK_ID */ yytestcase(yyruleno==498); - case 499: /* cgroup_name ::= NK_ID */ yytestcase(yyruleno==499); - case 500: /* index_name ::= NK_ID */ yytestcase(yyruleno==500); - case 543: /* noarg_func ::= NOW */ yytestcase(yyruleno==543); - case 544: /* noarg_func ::= TODAY */ yytestcase(yyruleno==544); - case 545: /* noarg_func ::= TIMEZONE */ yytestcase(yyruleno==545); - case 546: /* noarg_func ::= DATABASE */ yytestcase(yyruleno==546); - case 547: /* noarg_func ::= CLIENT_VERSION */ yytestcase(yyruleno==547); - case 548: /* noarg_func ::= SERVER_VERSION */ yytestcase(yyruleno==548); - case 549: /* noarg_func ::= SERVER_STATUS */ yytestcase(yyruleno==549); - case 550: /* noarg_func ::= CURRENT_USER */ yytestcase(yyruleno==550); - case 551: /* noarg_func ::= USER */ yytestcase(yyruleno==551); - case 552: /* star_func ::= COUNT */ yytestcase(yyruleno==552); - case 553: /* star_func ::= FIRST */ yytestcase(yyruleno==553); - case 554: /* star_func ::= LAST */ yytestcase(yyruleno==554); - case 555: /* star_func ::= LAST_ROW */ yytestcase(yyruleno==555); + case 343: /* sma_func_name ::= COUNT */ yytestcase(yyruleno==343); + case 344: /* sma_func_name ::= FIRST */ yytestcase(yyruleno==344); + case 345: /* sma_func_name ::= LAST */ yytestcase(yyruleno==345); + case 346: /* sma_func_name ::= LAST_ROW */ yytestcase(yyruleno==346); + case 492: /* db_name ::= NK_ID */ yytestcase(yyruleno==492); + case 493: /* table_name ::= NK_ID */ yytestcase(yyruleno==493); + case 494: /* column_name ::= NK_ID */ yytestcase(yyruleno==494); + case 495: /* function_name ::= NK_ID */ yytestcase(yyruleno==495); + case 496: /* view_name ::= NK_ID */ yytestcase(yyruleno==496); + case 497: /* table_alias ::= NK_ID */ yytestcase(yyruleno==497); + case 498: /* column_alias ::= NK_ID */ yytestcase(yyruleno==498); + case 499: /* column_alias ::= NK_ALIAS */ yytestcase(yyruleno==499); + case 500: /* user_name ::= NK_ID */ yytestcase(yyruleno==500); + case 501: /* topic_name ::= NK_ID */ yytestcase(yyruleno==501); + case 502: /* stream_name ::= NK_ID */ yytestcase(yyruleno==502); + case 503: /* cgroup_name ::= NK_ID */ yytestcase(yyruleno==503); + case 504: /* index_name ::= NK_ID */ yytestcase(yyruleno==504); + case 548: /* noarg_func ::= NOW */ yytestcase(yyruleno==548); + case 549: /* noarg_func ::= TODAY */ yytestcase(yyruleno==549); + case 550: /* noarg_func ::= TIMEZONE */ yytestcase(yyruleno==550); + case 551: /* noarg_func ::= DATABASE */ yytestcase(yyruleno==551); + case 552: /* noarg_func ::= CLIENT_VERSION */ yytestcase(yyruleno==552); + case 553: /* noarg_func ::= SERVER_VERSION */ yytestcase(yyruleno==553); + case 554: /* noarg_func ::= SERVER_STATUS */ yytestcase(yyruleno==554); + case 555: /* noarg_func ::= CURRENT_USER */ yytestcase(yyruleno==555); + case 556: /* noarg_func ::= USER */ yytestcase(yyruleno==556); + case 557: /* star_func ::= COUNT */ yytestcase(yyruleno==557); + case 558: /* star_func ::= FIRST */ yytestcase(yyruleno==558); + case 559: /* star_func ::= LAST */ yytestcase(yyruleno==559); + case 560: /* star_func ::= LAST_ROW */ yytestcase(yyruleno==560); #line 162 "sql.y" -{ yylhsminor.yy305 = yymsp[0].minor.yy0; } -#line 5679 "sql.c" - yymsp[0].minor.yy305 = yylhsminor.yy305; +{ yylhsminor.yy29 = yymsp[0].minor.yy0; } +#line 5738 "sql.c" + yymsp[0].minor.yy29 = yylhsminor.yy29; break; case 68: /* force_opt ::= */ case 95: /* not_exists_opt ::= */ yytestcase(yyruleno==95); case 97: /* exists_opt ::= */ yytestcase(yyruleno==97); - case 360: /* analyze_opt ::= */ yytestcase(yyruleno==360); - case 367: /* agg_func_opt ::= */ yytestcase(yyruleno==367); - case 373: /* or_replace_opt ::= */ yytestcase(yyruleno==373); - case 403: /* ignore_opt ::= */ yytestcase(yyruleno==403); - case 618: /* tag_mode_opt ::= */ yytestcase(yyruleno==618); - case 620: /* set_quantifier_opt ::= */ yytestcase(yyruleno==620); + case 364: /* analyze_opt ::= */ yytestcase(yyruleno==364); + case 371: /* agg_func_opt ::= */ yytestcase(yyruleno==371); + case 377: /* or_replace_opt ::= */ yytestcase(yyruleno==377); + case 407: /* ignore_opt ::= */ yytestcase(yyruleno==407); + case 623: /* tag_mode_opt ::= */ yytestcase(yyruleno==623); + case 625: /* set_quantifier_opt ::= */ yytestcase(yyruleno==625); #line 168 "sql.y" -{ yymsp[1].minor.yy985 = false; } -#line 5693 "sql.c" +{ yymsp[1].minor.yy887 = false; } +#line 5752 "sql.c" break; case 69: /* force_opt ::= FORCE */ case 70: /* unsafe_opt ::= UNSAFE */ yytestcase(yyruleno==70); - case 361: /* analyze_opt ::= ANALYZE */ yytestcase(yyruleno==361); - case 368: /* agg_func_opt ::= AGGREGATE */ yytestcase(yyruleno==368); - case 619: /* tag_mode_opt ::= TAGS */ yytestcase(yyruleno==619); - case 621: /* set_quantifier_opt ::= DISTINCT */ yytestcase(yyruleno==621); + case 365: /* analyze_opt ::= ANALYZE */ yytestcase(yyruleno==365); + case 372: /* agg_func_opt ::= AGGREGATE */ yytestcase(yyruleno==372); + case 624: /* tag_mode_opt ::= TAGS */ yytestcase(yyruleno==624); + case 626: /* set_quantifier_opt ::= DISTINCT */ yytestcase(yyruleno==626); #line 169 "sql.y" -{ yymsp[0].minor.yy985 = true; } -#line 5703 "sql.c" +{ yymsp[0].minor.yy887 = true; } +#line 5762 "sql.c" break; case 71: /* cmd ::= ALTER CLUSTER NK_STRING */ #line 176 "sql.y" { pCxt->pRootNode = createAlterClusterStmt(pCxt, &yymsp[0].minor.yy0, NULL); } -#line 5708 "sql.c" +#line 5767 "sql.c" break; case 72: /* cmd ::= ALTER CLUSTER NK_STRING NK_STRING */ #line 177 "sql.y" { pCxt->pRootNode = createAlterClusterStmt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } -#line 5713 "sql.c" +#line 5772 "sql.c" break; case 73: /* cmd ::= ALTER LOCAL NK_STRING */ #line 180 "sql.y" { pCxt->pRootNode = createAlterLocalStmt(pCxt, &yymsp[0].minor.yy0, NULL); } -#line 5718 "sql.c" +#line 5777 "sql.c" break; case 74: /* cmd ::= ALTER LOCAL NK_STRING NK_STRING */ #line 181 "sql.y" { pCxt->pRootNode = createAlterLocalStmt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } -#line 5723 "sql.c" +#line 5782 "sql.c" break; case 75: /* cmd ::= CREATE QNODE ON DNODE NK_INTEGER */ #line 184 "sql.y" { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_QNODE_STMT, &yymsp[0].minor.yy0); } -#line 5728 "sql.c" +#line 5787 "sql.c" break; case 76: /* cmd ::= DROP QNODE ON DNODE NK_INTEGER */ #line 185 "sql.y" { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_QNODE_STMT, &yymsp[0].minor.yy0); } -#line 5733 "sql.c" +#line 5792 "sql.c" break; case 77: /* cmd ::= RESTORE QNODE ON DNODE NK_INTEGER */ #line 186 "sql.y" { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_QNODE_STMT, &yymsp[0].minor.yy0); } -#line 5738 "sql.c" +#line 5797 "sql.c" break; case 78: /* cmd ::= CREATE BNODE ON DNODE NK_INTEGER */ #line 189 "sql.y" { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_BNODE_STMT, &yymsp[0].minor.yy0); } -#line 5743 "sql.c" +#line 5802 "sql.c" break; case 79: /* cmd ::= DROP BNODE ON DNODE NK_INTEGER */ #line 190 "sql.y" { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_BNODE_STMT, &yymsp[0].minor.yy0); } -#line 5748 "sql.c" +#line 5807 "sql.c" break; case 80: /* cmd ::= CREATE SNODE ON DNODE NK_INTEGER */ #line 193 "sql.y" { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_SNODE_STMT, &yymsp[0].minor.yy0); } -#line 5753 "sql.c" +#line 5812 "sql.c" break; case 81: /* cmd ::= DROP SNODE ON DNODE NK_INTEGER */ #line 194 "sql.y" { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_SNODE_STMT, &yymsp[0].minor.yy0); } -#line 5758 "sql.c" +#line 5817 "sql.c" break; case 82: /* cmd ::= CREATE MNODE ON DNODE NK_INTEGER */ #line 197 "sql.y" { pCxt->pRootNode = createCreateComponentNodeStmt(pCxt, QUERY_NODE_CREATE_MNODE_STMT, &yymsp[0].minor.yy0); } -#line 5763 "sql.c" +#line 5822 "sql.c" break; case 83: /* cmd ::= DROP MNODE ON DNODE NK_INTEGER */ #line 198 "sql.y" { pCxt->pRootNode = createDropComponentNodeStmt(pCxt, QUERY_NODE_DROP_MNODE_STMT, &yymsp[0].minor.yy0); } -#line 5768 "sql.c" +#line 5827 "sql.c" break; case 84: /* cmd ::= RESTORE MNODE ON DNODE NK_INTEGER */ #line 199 "sql.y" { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_MNODE_STMT, &yymsp[0].minor.yy0); } -#line 5773 "sql.c" +#line 5832 "sql.c" break; case 85: /* cmd ::= RESTORE VNODE ON DNODE NK_INTEGER */ #line 202 "sql.y" { pCxt->pRootNode = createRestoreComponentNodeStmt(pCxt, QUERY_NODE_RESTORE_VNODE_STMT, &yymsp[0].minor.yy0); } -#line 5778 "sql.c" +#line 5837 "sql.c" break; case 86: /* cmd ::= CREATE DATABASE not_exists_opt db_name db_options */ #line 205 "sql.y" -{ pCxt->pRootNode = createCreateDatabaseStmt(pCxt, yymsp[-2].minor.yy985, &yymsp[-1].minor.yy305, yymsp[0].minor.yy1000); } -#line 5783 "sql.c" +{ pCxt->pRootNode = createCreateDatabaseStmt(pCxt, yymsp[-2].minor.yy887, &yymsp[-1].minor.yy29, yymsp[0].minor.yy812); } +#line 5842 "sql.c" break; case 87: /* cmd ::= DROP DATABASE exists_opt db_name */ #line 206 "sql.y" -{ pCxt->pRootNode = createDropDatabaseStmt(pCxt, yymsp[-1].minor.yy985, &yymsp[0].minor.yy305); } -#line 5788 "sql.c" +{ pCxt->pRootNode = createDropDatabaseStmt(pCxt, yymsp[-1].minor.yy887, &yymsp[0].minor.yy29); } +#line 5847 "sql.c" break; case 88: /* cmd ::= USE db_name */ #line 207 "sql.y" -{ pCxt->pRootNode = createUseDatabaseStmt(pCxt, &yymsp[0].minor.yy305); } -#line 5793 "sql.c" +{ pCxt->pRootNode = createUseDatabaseStmt(pCxt, &yymsp[0].minor.yy29); } +#line 5852 "sql.c" break; case 89: /* cmd ::= ALTER DATABASE db_name alter_db_options */ #line 208 "sql.y" -{ pCxt->pRootNode = createAlterDatabaseStmt(pCxt, &yymsp[-1].minor.yy305, yymsp[0].minor.yy1000); } -#line 5798 "sql.c" +{ pCxt->pRootNode = createAlterDatabaseStmt(pCxt, &yymsp[-1].minor.yy29, yymsp[0].minor.yy812); } +#line 5857 "sql.c" break; case 90: /* cmd ::= FLUSH DATABASE db_name */ #line 209 "sql.y" -{ pCxt->pRootNode = createFlushDatabaseStmt(pCxt, &yymsp[0].minor.yy305); } -#line 5803 "sql.c" +{ pCxt->pRootNode = createFlushDatabaseStmt(pCxt, &yymsp[0].minor.yy29); } +#line 5862 "sql.c" break; case 91: /* cmd ::= TRIM DATABASE db_name speed_opt */ #line 210 "sql.y" -{ pCxt->pRootNode = createTrimDatabaseStmt(pCxt, &yymsp[-1].minor.yy305, yymsp[0].minor.yy444); } -#line 5808 "sql.c" +{ pCxt->pRootNode = createTrimDatabaseStmt(pCxt, &yymsp[-1].minor.yy29, yymsp[0].minor.yy760); } +#line 5867 "sql.c" break; case 92: /* cmd ::= S3MIGRATE DATABASE db_name */ #line 211 "sql.y" -{ pCxt->pRootNode = createS3MigrateDatabaseStmt(pCxt, &yymsp[0].minor.yy305); } -#line 5813 "sql.c" +{ pCxt->pRootNode = createS3MigrateDatabaseStmt(pCxt, &yymsp[0].minor.yy29); } +#line 5872 "sql.c" break; case 93: /* cmd ::= COMPACT DATABASE db_name start_opt end_opt */ #line 212 "sql.y" -{ pCxt->pRootNode = createCompactStmt(pCxt, &yymsp[-2].minor.yy305, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 5818 "sql.c" +{ pCxt->pRootNode = createCompactStmt(pCxt, &yymsp[-2].minor.yy29, yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 5877 "sql.c" break; case 94: /* not_exists_opt ::= IF NOT EXISTS */ #line 216 "sql.y" -{ yymsp[-2].minor.yy985 = true; } -#line 5823 "sql.c" +{ yymsp[-2].minor.yy887 = true; } +#line 5882 "sql.c" break; case 96: /* exists_opt ::= IF EXISTS */ - case 374: /* or_replace_opt ::= OR REPLACE */ yytestcase(yyruleno==374); - case 404: /* ignore_opt ::= IGNORE UNTREATED */ yytestcase(yyruleno==404); + case 378: /* or_replace_opt ::= OR REPLACE */ yytestcase(yyruleno==378); + case 408: /* ignore_opt ::= IGNORE UNTREATED */ yytestcase(yyruleno==408); #line 221 "sql.y" -{ yymsp[-1].minor.yy985 = true; } -#line 5830 "sql.c" +{ yymsp[-1].minor.yy887 = true; } +#line 5889 "sql.c" break; case 98: /* db_options ::= */ #line 224 "sql.y" -{ yymsp[1].minor.yy1000 = createDefaultDatabaseOptions(pCxt); } -#line 5835 "sql.c" +{ yymsp[1].minor.yy812 = createDefaultDatabaseOptions(pCxt); } +#line 5894 "sql.c" break; case 99: /* db_options ::= db_options BUFFER NK_INTEGER */ #line 225 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_BUFFER, &yymsp[0].minor.yy0); } -#line 5840 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_BUFFER, &yymsp[0].minor.yy0); } +#line 5899 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 100: /* db_options ::= db_options CACHEMODEL NK_STRING */ #line 226 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_CACHEMODEL, &yymsp[0].minor.yy0); } -#line 5846 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_CACHEMODEL, &yymsp[0].minor.yy0); } +#line 5905 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 101: /* db_options ::= db_options CACHESIZE NK_INTEGER */ #line 227 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_CACHESIZE, &yymsp[0].minor.yy0); } -#line 5852 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_CACHESIZE, &yymsp[0].minor.yy0); } +#line 5911 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 102: /* db_options ::= db_options COMP NK_INTEGER */ #line 228 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_COMP, &yymsp[0].minor.yy0); } -#line 5858 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_COMP, &yymsp[0].minor.yy0); } +#line 5917 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 103: /* db_options ::= db_options DURATION NK_INTEGER */ case 104: /* db_options ::= db_options DURATION NK_VARIABLE */ yytestcase(yyruleno==104); #line 229 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_DAYS, &yymsp[0].minor.yy0); } -#line 5865 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_DAYS, &yymsp[0].minor.yy0); } +#line 5924 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 105: /* db_options ::= db_options MAXROWS NK_INTEGER */ #line 231 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_MAXROWS, &yymsp[0].minor.yy0); } -#line 5871 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_MAXROWS, &yymsp[0].minor.yy0); } +#line 5930 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 106: /* db_options ::= db_options MINROWS NK_INTEGER */ #line 232 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_MINROWS, &yymsp[0].minor.yy0); } -#line 5877 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_MINROWS, &yymsp[0].minor.yy0); } +#line 5936 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 107: /* db_options ::= db_options KEEP integer_list */ case 108: /* db_options ::= db_options KEEP variable_list */ yytestcase(yyruleno==108); #line 233 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_KEEP, yymsp[0].minor.yy72); } -#line 5884 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_KEEP, yymsp[0].minor.yy124); } +#line 5943 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 109: /* db_options ::= db_options PAGES NK_INTEGER */ #line 235 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_PAGES, &yymsp[0].minor.yy0); } -#line 5890 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_PAGES, &yymsp[0].minor.yy0); } +#line 5949 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 110: /* db_options ::= db_options PAGESIZE NK_INTEGER */ #line 236 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_PAGESIZE, &yymsp[0].minor.yy0); } -#line 5896 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_PAGESIZE, &yymsp[0].minor.yy0); } +#line 5955 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 111: /* db_options ::= db_options TSDB_PAGESIZE NK_INTEGER */ #line 237 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_TSDB_PAGESIZE, &yymsp[0].minor.yy0); } -#line 5902 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_TSDB_PAGESIZE, &yymsp[0].minor.yy0); } +#line 5961 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 112: /* db_options ::= db_options PRECISION NK_STRING */ #line 238 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_PRECISION, &yymsp[0].minor.yy0); } -#line 5908 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_PRECISION, &yymsp[0].minor.yy0); } +#line 5967 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 113: /* db_options ::= db_options REPLICA NK_INTEGER */ #line 239 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_REPLICA, &yymsp[0].minor.yy0); } -#line 5914 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_REPLICA, &yymsp[0].minor.yy0); } +#line 5973 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 114: /* db_options ::= db_options VGROUPS NK_INTEGER */ #line 241 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_VGROUPS, &yymsp[0].minor.yy0); } -#line 5920 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_VGROUPS, &yymsp[0].minor.yy0); } +#line 5979 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 115: /* db_options ::= db_options SINGLE_STABLE NK_INTEGER */ #line 242 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_SINGLE_STABLE, &yymsp[0].minor.yy0); } -#line 5926 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_SINGLE_STABLE, &yymsp[0].minor.yy0); } +#line 5985 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 116: /* db_options ::= db_options RETENTIONS retention_list */ #line 243 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_RETENTIONS, yymsp[0].minor.yy72); } -#line 5932 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_RETENTIONS, yymsp[0].minor.yy124); } +#line 5991 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 117: /* db_options ::= db_options SCHEMALESS NK_INTEGER */ #line 244 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_SCHEMALESS, &yymsp[0].minor.yy0); } -#line 5938 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_SCHEMALESS, &yymsp[0].minor.yy0); } +#line 5997 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 118: /* db_options ::= db_options WAL_LEVEL NK_INTEGER */ #line 245 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_WAL, &yymsp[0].minor.yy0); } -#line 5944 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_WAL, &yymsp[0].minor.yy0); } +#line 6003 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 119: /* db_options ::= db_options WAL_FSYNC_PERIOD NK_INTEGER */ #line 246 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_FSYNC, &yymsp[0].minor.yy0); } -#line 5950 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_FSYNC, &yymsp[0].minor.yy0); } +#line 6009 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 120: /* db_options ::= db_options WAL_RETENTION_PERIOD NK_INTEGER */ #line 247 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_WAL_RETENTION_PERIOD, &yymsp[0].minor.yy0); } -#line 5956 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_WAL_RETENTION_PERIOD, &yymsp[0].minor.yy0); } +#line 6015 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 121: /* db_options ::= db_options WAL_RETENTION_PERIOD NK_MINUS NK_INTEGER */ #line 248 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-3].minor.yy1000, DB_OPTION_WAL_RETENTION_PERIOD, &t); + yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-3].minor.yy812, DB_OPTION_WAL_RETENTION_PERIOD, &t); } -#line 5966 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; +#line 6025 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; case 122: /* db_options ::= db_options WAL_RETENTION_SIZE NK_INTEGER */ #line 253 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_WAL_RETENTION_SIZE, &yymsp[0].minor.yy0); } -#line 5972 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_WAL_RETENTION_SIZE, &yymsp[0].minor.yy0); } +#line 6031 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 123: /* db_options ::= db_options WAL_RETENTION_SIZE NK_MINUS NK_INTEGER */ #line 254 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-3].minor.yy1000, DB_OPTION_WAL_RETENTION_SIZE, &t); + yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-3].minor.yy812, DB_OPTION_WAL_RETENTION_SIZE, &t); } -#line 5982 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; +#line 6041 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; case 124: /* db_options ::= db_options WAL_ROLL_PERIOD NK_INTEGER */ #line 259 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_WAL_ROLL_PERIOD, &yymsp[0].minor.yy0); } -#line 5988 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_WAL_ROLL_PERIOD, &yymsp[0].minor.yy0); } +#line 6047 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 125: /* db_options ::= db_options WAL_SEGMENT_SIZE NK_INTEGER */ #line 260 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_WAL_SEGMENT_SIZE, &yymsp[0].minor.yy0); } -#line 5994 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_WAL_SEGMENT_SIZE, &yymsp[0].minor.yy0); } +#line 6053 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 126: /* db_options ::= db_options STT_TRIGGER NK_INTEGER */ #line 261 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_STT_TRIGGER, &yymsp[0].minor.yy0); } -#line 6000 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_STT_TRIGGER, &yymsp[0].minor.yy0); } +#line 6059 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 127: /* db_options ::= db_options TABLE_PREFIX signed */ #line 262 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_TABLE_PREFIX, yymsp[0].minor.yy1000); } -#line 6006 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_TABLE_PREFIX, yymsp[0].minor.yy812); } +#line 6065 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 128: /* db_options ::= db_options TABLE_SUFFIX signed */ #line 263 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_TABLE_SUFFIX, yymsp[0].minor.yy1000); } -#line 6012 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_TABLE_SUFFIX, yymsp[0].minor.yy812); } +#line 6071 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 129: /* db_options ::= db_options S3_CHUNKSIZE NK_INTEGER */ #line 264 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_S3_CHUNKSIZE, &yymsp[0].minor.yy0); } -#line 6018 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_S3_CHUNKSIZE, &yymsp[0].minor.yy0); } +#line 6077 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 130: /* db_options ::= db_options S3_KEEPLOCAL NK_INTEGER */ case 131: /* db_options ::= db_options S3_KEEPLOCAL NK_VARIABLE */ yytestcase(yyruleno==131); #line 265 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_S3_KEEPLOCAL, &yymsp[0].minor.yy0); } -#line 6025 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_S3_KEEPLOCAL, &yymsp[0].minor.yy0); } +#line 6084 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 132: /* db_options ::= db_options S3_COMPACT NK_INTEGER */ #line 267 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_S3_COMPACT, &yymsp[0].minor.yy0); } -#line 6031 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_S3_COMPACT, &yymsp[0].minor.yy0); } +#line 6090 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 133: /* db_options ::= db_options KEEP_TIME_OFFSET NK_INTEGER */ #line 268 "sql.y" -{ yylhsminor.yy1000 = setDatabaseOption(pCxt, yymsp[-2].minor.yy1000, DB_OPTION_KEEP_TIME_OFFSET, &yymsp[0].minor.yy0); } -#line 6037 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setDatabaseOption(pCxt, yymsp[-2].minor.yy812, DB_OPTION_KEEP_TIME_OFFSET, &yymsp[0].minor.yy0); } +#line 6096 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 134: /* alter_db_options ::= alter_db_option */ #line 270 "sql.y" -{ yylhsminor.yy1000 = createAlterDatabaseOptions(pCxt); yylhsminor.yy1000 = setAlterDatabaseOption(pCxt, yylhsminor.yy1000, &yymsp[0].minor.yy941); } -#line 6043 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterDatabaseOptions(pCxt); yylhsminor.yy812 = setAlterDatabaseOption(pCxt, yylhsminor.yy812, &yymsp[0].minor.yy95); } +#line 6102 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; case 135: /* alter_db_options ::= alter_db_options alter_db_option */ #line 271 "sql.y" -{ yylhsminor.yy1000 = setAlterDatabaseOption(pCxt, yymsp[-1].minor.yy1000, &yymsp[0].minor.yy941); } -#line 6049 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = setAlterDatabaseOption(pCxt, yymsp[-1].minor.yy812, &yymsp[0].minor.yy95); } +#line 6108 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; case 136: /* alter_db_option ::= BUFFER NK_INTEGER */ #line 275 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_BUFFER; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6055 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_BUFFER; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6114 "sql.c" break; case 137: /* alter_db_option ::= CACHEMODEL NK_STRING */ #line 276 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_CACHEMODEL; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6060 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_CACHEMODEL; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6119 "sql.c" break; case 138: /* alter_db_option ::= CACHESIZE NK_INTEGER */ #line 277 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_CACHESIZE; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6065 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_CACHESIZE; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6124 "sql.c" break; case 139: /* alter_db_option ::= WAL_FSYNC_PERIOD NK_INTEGER */ #line 278 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_FSYNC; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6070 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_FSYNC; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6129 "sql.c" break; case 140: /* alter_db_option ::= KEEP integer_list */ case 141: /* alter_db_option ::= KEEP variable_list */ yytestcase(yyruleno==141); #line 279 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_KEEP; yymsp[-1].minor.yy941.pList = yymsp[0].minor.yy72; } -#line 6076 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_KEEP; yymsp[-1].minor.yy95.pList = yymsp[0].minor.yy124; } +#line 6135 "sql.c" break; case 142: /* alter_db_option ::= PAGES NK_INTEGER */ #line 281 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_PAGES; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6081 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_PAGES; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6140 "sql.c" break; case 143: /* alter_db_option ::= REPLICA NK_INTEGER */ #line 282 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_REPLICA; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6086 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_REPLICA; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6145 "sql.c" break; case 144: /* alter_db_option ::= WAL_LEVEL NK_INTEGER */ #line 284 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_WAL; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6091 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_WAL; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6150 "sql.c" break; case 145: /* alter_db_option ::= STT_TRIGGER NK_INTEGER */ #line 285 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_STT_TRIGGER; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6096 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_STT_TRIGGER; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6155 "sql.c" break; case 146: /* alter_db_option ::= MINROWS NK_INTEGER */ #line 286 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_MINROWS; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6101 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_MINROWS; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6160 "sql.c" break; case 147: /* alter_db_option ::= WAL_RETENTION_PERIOD NK_INTEGER */ #line 287 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_WAL_RETENTION_PERIOD; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6106 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_WAL_RETENTION_PERIOD; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6165 "sql.c" break; case 148: /* alter_db_option ::= WAL_RETENTION_PERIOD NK_MINUS NK_INTEGER */ #line 288 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yymsp[-2].minor.yy941.type = DB_OPTION_WAL_RETENTION_PERIOD; yymsp[-2].minor.yy941.val = t; + yymsp[-2].minor.yy95.type = DB_OPTION_WAL_RETENTION_PERIOD; yymsp[-2].minor.yy95.val = t; } -#line 6115 "sql.c" +#line 6174 "sql.c" break; case 149: /* alter_db_option ::= WAL_RETENTION_SIZE NK_INTEGER */ #line 293 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_WAL_RETENTION_SIZE; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6120 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_WAL_RETENTION_SIZE; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6179 "sql.c" break; case 150: /* alter_db_option ::= WAL_RETENTION_SIZE NK_MINUS NK_INTEGER */ #line 294 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yymsp[-2].minor.yy941.type = DB_OPTION_WAL_RETENTION_SIZE; yymsp[-2].minor.yy941.val = t; + yymsp[-2].minor.yy95.type = DB_OPTION_WAL_RETENTION_SIZE; yymsp[-2].minor.yy95.val = t; } -#line 6129 "sql.c" +#line 6188 "sql.c" break; case 151: /* alter_db_option ::= S3_KEEPLOCAL NK_INTEGER */ case 152: /* alter_db_option ::= S3_KEEPLOCAL NK_VARIABLE */ yytestcase(yyruleno==152); #line 299 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_S3_KEEPLOCAL; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6135 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_S3_KEEPLOCAL; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6194 "sql.c" break; case 153: /* alter_db_option ::= S3_COMPACT NK_INTEGER */ #line 301 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_S3_COMPACT, yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6140 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_S3_COMPACT, yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6199 "sql.c" break; case 154: /* alter_db_option ::= KEEP_TIME_OFFSET NK_INTEGER */ #line 302 "sql.y" -{ yymsp[-1].minor.yy941.type = DB_OPTION_KEEP_TIME_OFFSET; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6145 "sql.c" +{ yymsp[-1].minor.yy95.type = DB_OPTION_KEEP_TIME_OFFSET; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6204 "sql.c" break; case 155: /* integer_list ::= NK_INTEGER */ #line 306 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } -#line 6150 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } +#line 6209 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; case 156: /* integer_list ::= integer_list NK_COMMA NK_INTEGER */ - case 417: /* dnode_list ::= dnode_list DNODE NK_INTEGER */ yytestcase(yyruleno==417); + case 421: /* dnode_list ::= dnode_list DNODE NK_INTEGER */ yytestcase(yyruleno==421); #line 307 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-2].minor.yy72, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } -#line 6157 "sql.c" - yymsp[-2].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-2].minor.yy124, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } +#line 6216 "sql.c" + yymsp[-2].minor.yy124 = yylhsminor.yy124; break; case 157: /* variable_list ::= NK_VARIABLE */ #line 311 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } -#line 6163 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = createNodeList(pCxt, createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } +#line 6222 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; case 158: /* variable_list ::= variable_list NK_COMMA NK_VARIABLE */ #line 312 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-2].minor.yy72, createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } -#line 6169 "sql.c" - yymsp[-2].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-2].minor.yy124, createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } +#line 6228 "sql.c" + yymsp[-2].minor.yy124 = yylhsminor.yy124; break; case 159: /* retention_list ::= retention */ case 190: /* multi_create_clause ::= create_subtable_clause */ yytestcase(yyruleno==190); case 193: /* multi_drop_clause ::= drop_table_clause */ yytestcase(yyruleno==193); case 200: /* column_def_list ::= column_def */ yytestcase(yyruleno==200); - case 245: /* rollup_func_list ::= rollup_func_name */ yytestcase(yyruleno==245); - case 250: /* col_name_list ::= col_name */ yytestcase(yyruleno==250); - case 318: /* tag_list_opt ::= tag_item */ yytestcase(yyruleno==318); - case 335: /* func_list ::= func */ yytestcase(yyruleno==335); - case 385: /* column_stream_def_list ::= column_stream_def */ yytestcase(yyruleno==385); - case 461: /* tags_literal_list ::= tags_literal */ yytestcase(yyruleno==461); - case 486: /* literal_list ::= signed_literal */ yytestcase(yyruleno==486); - case 558: /* other_para_list ::= star_func_para */ yytestcase(yyruleno==558); - case 564: /* when_then_list ::= when_then_expr */ yytestcase(yyruleno==564); - case 623: /* select_list ::= select_item */ yytestcase(yyruleno==623); - case 634: /* partition_list ::= partition_item */ yytestcase(yyruleno==634); - case 695: /* sort_specification_list ::= sort_specification */ yytestcase(yyruleno==695); + case 249: /* rollup_func_list ::= rollup_func_name */ yytestcase(yyruleno==249); + case 254: /* col_name_list ::= col_name */ yytestcase(yyruleno==254); + case 322: /* tag_list_opt ::= tag_item */ yytestcase(yyruleno==322); + case 339: /* func_list ::= func */ yytestcase(yyruleno==339); + case 389: /* column_stream_def_list ::= column_stream_def */ yytestcase(yyruleno==389); + case 465: /* tags_literal_list ::= tags_literal */ yytestcase(yyruleno==465); + case 490: /* literal_list ::= signed_literal */ yytestcase(yyruleno==490); + case 563: /* other_para_list ::= star_func_para */ yytestcase(yyruleno==563); + case 569: /* when_then_list ::= when_then_expr */ yytestcase(yyruleno==569); + case 628: /* select_list ::= select_item */ yytestcase(yyruleno==628); + case 639: /* partition_list ::= partition_item */ yytestcase(yyruleno==639); + case 700: /* sort_specification_list ::= sort_specification */ yytestcase(yyruleno==700); #line 316 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, yymsp[0].minor.yy1000); } -#line 6190 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = createNodeList(pCxt, yymsp[0].minor.yy812); } +#line 6249 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; case 160: /* retention_list ::= retention_list NK_COMMA retention */ case 194: /* multi_drop_clause ::= multi_drop_clause NK_COMMA drop_table_clause */ yytestcase(yyruleno==194); case 201: /* column_def_list ::= column_def_list NK_COMMA column_def */ yytestcase(yyruleno==201); - case 246: /* rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name */ yytestcase(yyruleno==246); - case 251: /* col_name_list ::= col_name_list NK_COMMA col_name */ yytestcase(yyruleno==251); - case 319: /* tag_list_opt ::= tag_list_opt NK_COMMA tag_item */ yytestcase(yyruleno==319); - case 336: /* func_list ::= func_list NK_COMMA func */ yytestcase(yyruleno==336); - case 386: /* column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def */ yytestcase(yyruleno==386); - case 462: /* tags_literal_list ::= tags_literal_list NK_COMMA tags_literal */ yytestcase(yyruleno==462); - case 487: /* literal_list ::= literal_list NK_COMMA signed_literal */ yytestcase(yyruleno==487); - case 559: /* other_para_list ::= other_para_list NK_COMMA star_func_para */ yytestcase(yyruleno==559); - case 624: /* select_list ::= select_list NK_COMMA select_item */ yytestcase(yyruleno==624); - case 635: /* partition_list ::= partition_list NK_COMMA partition_item */ yytestcase(yyruleno==635); - case 696: /* sort_specification_list ::= sort_specification_list NK_COMMA sort_specification */ yytestcase(yyruleno==696); + case 250: /* rollup_func_list ::= rollup_func_list NK_COMMA rollup_func_name */ yytestcase(yyruleno==250); + case 255: /* col_name_list ::= col_name_list NK_COMMA col_name */ yytestcase(yyruleno==255); + case 323: /* tag_list_opt ::= tag_list_opt NK_COMMA tag_item */ yytestcase(yyruleno==323); + case 340: /* func_list ::= func_list NK_COMMA func */ yytestcase(yyruleno==340); + case 390: /* column_stream_def_list ::= column_stream_def_list NK_COMMA column_stream_def */ yytestcase(yyruleno==390); + case 466: /* tags_literal_list ::= tags_literal_list NK_COMMA tags_literal */ yytestcase(yyruleno==466); + case 491: /* literal_list ::= literal_list NK_COMMA signed_literal */ yytestcase(yyruleno==491); + case 564: /* other_para_list ::= other_para_list NK_COMMA star_func_para */ yytestcase(yyruleno==564); + case 629: /* select_list ::= select_list NK_COMMA select_item */ yytestcase(yyruleno==629); + case 640: /* partition_list ::= partition_list NK_COMMA partition_item */ yytestcase(yyruleno==640); + case 701: /* sort_specification_list ::= sort_specification_list NK_COMMA sort_specification */ yytestcase(yyruleno==701); #line 317 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-2].minor.yy72, yymsp[0].minor.yy1000); } -#line 6209 "sql.c" - yymsp[-2].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-2].minor.yy124, yymsp[0].minor.yy812); } +#line 6268 "sql.c" + yymsp[-2].minor.yy124 = yylhsminor.yy124; break; case 161: /* retention ::= NK_VARIABLE NK_COLON NK_VARIABLE */ case 162: /* retention ::= NK_MINUS NK_COLON NK_VARIABLE */ yytestcase(yyruleno==162); #line 319 "sql.y" -{ yylhsminor.yy1000 = createNodeListNodeEx(pCxt, createDurationValueNode(pCxt, &yymsp[-2].minor.yy0), createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } -#line 6216 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createNodeListNodeEx(pCxt, createDurationValueNode(pCxt, &yymsp[-2].minor.yy0), createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } +#line 6275 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 163: /* speed_opt ::= */ - case 369: /* bufsize_opt ::= */ yytestcase(yyruleno==369); + case 373: /* bufsize_opt ::= */ yytestcase(yyruleno==373); #line 324 "sql.y" -{ yymsp[1].minor.yy444 = 0; } -#line 6223 "sql.c" +{ yymsp[1].minor.yy760 = 0; } +#line 6282 "sql.c" break; case 164: /* speed_opt ::= BWLIMIT NK_INTEGER */ - case 370: /* bufsize_opt ::= BUFSIZE NK_INTEGER */ yytestcase(yyruleno==370); + case 374: /* bufsize_opt ::= BUFSIZE NK_INTEGER */ yytestcase(yyruleno==374); #line 325 "sql.y" -{ yymsp[-1].minor.yy444 = taosStr2Int32(yymsp[0].minor.yy0.z, NULL, 10); } -#line 6229 "sql.c" +{ yymsp[-1].minor.yy760 = taosStr2Int32(yymsp[0].minor.yy0.z, NULL, 10); } +#line 6288 "sql.c" break; case 166: /* start_opt ::= START WITH NK_INTEGER */ case 170: /* end_opt ::= END WITH NK_INTEGER */ yytestcase(yyruleno==170); #line 328 "sql.y" -{ yymsp[-2].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0); } -#line 6235 "sql.c" +{ yymsp[-2].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0); } +#line 6294 "sql.c" break; case 167: /* start_opt ::= START WITH NK_STRING */ case 171: /* end_opt ::= END WITH NK_STRING */ yytestcase(yyruleno==171); #line 329 "sql.y" -{ yymsp[-2].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0); } -#line 6241 "sql.c" +{ yymsp[-2].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0); } +#line 6300 "sql.c" break; case 168: /* start_opt ::= START WITH TIMESTAMP NK_STRING */ case 172: /* end_opt ::= END WITH TIMESTAMP NK_STRING */ yytestcase(yyruleno==172); #line 330 "sql.y" -{ yymsp[-3].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0); } -#line 6247 "sql.c" +{ yymsp[-3].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0); } +#line 6306 "sql.c" break; case 173: /* cmd ::= CREATE TABLE not_exists_opt full_table_name NK_LP column_def_list NK_RP tags_def_opt table_options */ case 175: /* cmd ::= CREATE STABLE not_exists_opt full_table_name NK_LP column_def_list NK_RP tags_def table_options */ yytestcase(yyruleno==175); #line 339 "sql.y" -{ pCxt->pRootNode = createCreateTableStmt(pCxt, yymsp[-6].minor.yy985, yymsp[-5].minor.yy1000, yymsp[-3].minor.yy72, yymsp[-1].minor.yy72, yymsp[0].minor.yy1000); } -#line 6253 "sql.c" +{ pCxt->pRootNode = createCreateTableStmt(pCxt, yymsp[-6].minor.yy887, yymsp[-5].minor.yy812, yymsp[-3].minor.yy124, yymsp[-1].minor.yy124, yymsp[0].minor.yy812); } +#line 6312 "sql.c" break; case 174: /* cmd ::= CREATE TABLE multi_create_clause */ #line 340 "sql.y" -{ pCxt->pRootNode = createCreateMultiTableStmt(pCxt, yymsp[0].minor.yy72); } -#line 6258 "sql.c" +{ pCxt->pRootNode = createCreateMultiTableStmt(pCxt, yymsp[0].minor.yy124); } +#line 6317 "sql.c" break; case 176: /* cmd ::= DROP TABLE multi_drop_clause */ #line 343 "sql.y" -{ pCxt->pRootNode = createDropTableStmt(pCxt, yymsp[0].minor.yy72); } -#line 6263 "sql.c" +{ pCxt->pRootNode = createDropTableStmt(pCxt, yymsp[0].minor.yy124); } +#line 6322 "sql.c" break; case 177: /* cmd ::= DROP STABLE exists_opt full_table_name */ #line 344 "sql.y" -{ pCxt->pRootNode = createDropSuperTableStmt(pCxt, yymsp[-1].minor.yy985, yymsp[0].minor.yy1000); } -#line 6268 "sql.c" +{ pCxt->pRootNode = createDropSuperTableStmt(pCxt, yymsp[-1].minor.yy887, yymsp[0].minor.yy812); } +#line 6327 "sql.c" break; case 178: /* cmd ::= ALTER TABLE alter_table_clause */ - case 419: /* cmd ::= query_or_subquery */ yytestcase(yyruleno==419); - case 420: /* cmd ::= insert_query */ yytestcase(yyruleno==420); + case 423: /* cmd ::= query_or_subquery */ yytestcase(yyruleno==423); + case 424: /* cmd ::= insert_query */ yytestcase(yyruleno==424); #line 346 "sql.y" -{ pCxt->pRootNode = yymsp[0].minor.yy1000; } -#line 6275 "sql.c" +{ pCxt->pRootNode = yymsp[0].minor.yy812; } +#line 6334 "sql.c" break; case 179: /* cmd ::= ALTER STABLE alter_table_clause */ #line 347 "sql.y" -{ pCxt->pRootNode = setAlterSuperTableType(yymsp[0].minor.yy1000); } -#line 6280 "sql.c" +{ pCxt->pRootNode = setAlterSuperTableType(yymsp[0].minor.yy812); } +#line 6339 "sql.c" break; case 180: /* alter_table_clause ::= full_table_name alter_table_options */ #line 349 "sql.y" -{ yylhsminor.yy1000 = createAlterTableModifyOptions(pCxt, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 6285 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableModifyOptions(pCxt, yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 6344 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; case 181: /* alter_table_clause ::= full_table_name ADD COLUMN column_name type_name */ #line 351 "sql.y" -{ yylhsminor.yy1000 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy1000, TSDB_ALTER_TABLE_ADD_COLUMN, &yymsp[-1].minor.yy305, yymsp[0].minor.yy56); } -#line 6291 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy812, TSDB_ALTER_TABLE_ADD_COLUMN, &yymsp[-1].minor.yy29, yymsp[0].minor.yy784); } +#line 6350 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; case 182: /* alter_table_clause ::= full_table_name DROP COLUMN column_name */ #line 352 "sql.y" -{ yylhsminor.yy1000 = createAlterTableDropCol(pCxt, yymsp[-3].minor.yy1000, TSDB_ALTER_TABLE_DROP_COLUMN, &yymsp[0].minor.yy305); } -#line 6297 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableDropCol(pCxt, yymsp[-3].minor.yy812, TSDB_ALTER_TABLE_DROP_COLUMN, &yymsp[0].minor.yy29); } +#line 6356 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; case 183: /* alter_table_clause ::= full_table_name MODIFY COLUMN column_name type_name */ #line 354 "sql.y" -{ yylhsminor.yy1000 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy1000, TSDB_ALTER_TABLE_UPDATE_COLUMN_BYTES, &yymsp[-1].minor.yy305, yymsp[0].minor.yy56); } -#line 6303 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy812, TSDB_ALTER_TABLE_UPDATE_COLUMN_BYTES, &yymsp[-1].minor.yy29, yymsp[0].minor.yy784); } +#line 6362 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; case 184: /* alter_table_clause ::= full_table_name RENAME COLUMN column_name column_name */ #line 356 "sql.y" -{ yylhsminor.yy1000 = createAlterTableRenameCol(pCxt, yymsp[-4].minor.yy1000, TSDB_ALTER_TABLE_UPDATE_COLUMN_NAME, &yymsp[-1].minor.yy305, &yymsp[0].minor.yy305); } -#line 6309 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableRenameCol(pCxt, yymsp[-4].minor.yy812, TSDB_ALTER_TABLE_UPDATE_COLUMN_NAME, &yymsp[-1].minor.yy29, &yymsp[0].minor.yy29); } +#line 6368 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; case 185: /* alter_table_clause ::= full_table_name ADD TAG column_name type_name */ #line 358 "sql.y" -{ yylhsminor.yy1000 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy1000, TSDB_ALTER_TABLE_ADD_TAG, &yymsp[-1].minor.yy305, yymsp[0].minor.yy56); } -#line 6315 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy812, TSDB_ALTER_TABLE_ADD_TAG, &yymsp[-1].minor.yy29, yymsp[0].minor.yy784); } +#line 6374 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; case 186: /* alter_table_clause ::= full_table_name DROP TAG column_name */ #line 359 "sql.y" -{ yylhsminor.yy1000 = createAlterTableDropCol(pCxt, yymsp[-3].minor.yy1000, TSDB_ALTER_TABLE_DROP_TAG, &yymsp[0].minor.yy305); } -#line 6321 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableDropCol(pCxt, yymsp[-3].minor.yy812, TSDB_ALTER_TABLE_DROP_TAG, &yymsp[0].minor.yy29); } +#line 6380 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; case 187: /* alter_table_clause ::= full_table_name MODIFY TAG column_name type_name */ #line 361 "sql.y" -{ yylhsminor.yy1000 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy1000, TSDB_ALTER_TABLE_UPDATE_TAG_BYTES, &yymsp[-1].minor.yy305, yymsp[0].minor.yy56); } -#line 6327 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableAddModifyCol(pCxt, yymsp[-4].minor.yy812, TSDB_ALTER_TABLE_UPDATE_TAG_BYTES, &yymsp[-1].minor.yy29, yymsp[0].minor.yy784); } +#line 6386 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; case 188: /* alter_table_clause ::= full_table_name RENAME TAG column_name column_name */ #line 363 "sql.y" -{ yylhsminor.yy1000 = createAlterTableRenameCol(pCxt, yymsp[-4].minor.yy1000, TSDB_ALTER_TABLE_UPDATE_TAG_NAME, &yymsp[-1].minor.yy305, &yymsp[0].minor.yy305); } -#line 6333 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableRenameCol(pCxt, yymsp[-4].minor.yy812, TSDB_ALTER_TABLE_UPDATE_TAG_NAME, &yymsp[-1].minor.yy29, &yymsp[0].minor.yy29); } +#line 6392 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; case 189: /* alter_table_clause ::= full_table_name SET TAG column_name NK_EQ tags_literal */ #line 365 "sql.y" -{ yylhsminor.yy1000 = createAlterTableSetTag(pCxt, yymsp[-5].minor.yy1000, &yymsp[-2].minor.yy305, yymsp[0].minor.yy1000); } -#line 6339 "sql.c" - yymsp[-5].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createAlterTableSetTag(pCxt, yymsp[-5].minor.yy812, &yymsp[-2].minor.yy29, yymsp[0].minor.yy812); } +#line 6398 "sql.c" + yymsp[-5].minor.yy812 = yylhsminor.yy812; break; case 191: /* multi_create_clause ::= multi_create_clause create_subtable_clause */ - case 565: /* when_then_list ::= when_then_list when_then_expr */ yytestcase(yyruleno==565); + case 570: /* when_then_list ::= when_then_list when_then_expr */ yytestcase(yyruleno==570); #line 370 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-1].minor.yy72, yymsp[0].minor.yy1000); } -#line 6346 "sql.c" - yymsp[-1].minor.yy72 = yylhsminor.yy72; +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-1].minor.yy124, yymsp[0].minor.yy812); } +#line 6405 "sql.c" + yymsp[-1].minor.yy124 = yylhsminor.yy124; break; case 192: /* create_subtable_clause ::= not_exists_opt full_table_name USING full_table_name specific_cols_opt TAGS NK_LP tags_literal_list NK_RP table_options */ #line 374 "sql.y" -{ yylhsminor.yy1000 = createCreateSubTableClause(pCxt, yymsp[-9].minor.yy985, yymsp[-8].minor.yy1000, yymsp[-6].minor.yy1000, yymsp[-5].minor.yy72, yymsp[-2].minor.yy72, yymsp[0].minor.yy1000); } -#line 6352 "sql.c" - yymsp[-9].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createCreateSubTableClause(pCxt, yymsp[-9].minor.yy887, yymsp[-8].minor.yy812, yymsp[-6].minor.yy812, yymsp[-5].minor.yy124, yymsp[-2].minor.yy124, yymsp[0].minor.yy812); } +#line 6411 "sql.c" + yymsp[-9].minor.yy812 = yylhsminor.yy812; break; case 195: /* drop_table_clause ::= exists_opt full_table_name */ #line 381 "sql.y" -{ yylhsminor.yy1000 = createDropTableClause(pCxt, yymsp[-1].minor.yy985, yymsp[0].minor.yy1000); } -#line 6358 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createDropTableClause(pCxt, yymsp[-1].minor.yy887, yymsp[0].minor.yy812); } +#line 6417 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; case 197: /* specific_cols_opt ::= NK_LP col_name_list NK_RP */ - case 384: /* col_list_opt ::= NK_LP column_stream_def_list NK_RP */ yytestcase(yyruleno==384); + case 388: /* col_list_opt ::= NK_LP column_stream_def_list NK_RP */ yytestcase(yyruleno==388); #line 386 "sql.y" -{ yymsp[-2].minor.yy72 = yymsp[-1].minor.yy72; } -#line 6365 "sql.c" +{ yymsp[-2].minor.yy124 = yymsp[-1].minor.yy124; } +#line 6424 "sql.c" break; case 198: /* full_table_name ::= table_name */ #line 388 "sql.y" -{ yylhsminor.yy1000 = createRealTableNode(pCxt, NULL, &yymsp[0].minor.yy305, NULL); } -#line 6370 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createRealTableNode(pCxt, NULL, &yymsp[0].minor.yy29, NULL); } +#line 6429 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; case 199: /* full_table_name ::= db_name NK_DOT table_name */ #line 389 "sql.y" -{ yylhsminor.yy1000 = createRealTableNode(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy305, NULL); } -#line 6376 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createRealTableNode(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy29, NULL); } +#line 6435 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; case 202: /* column_def ::= column_name type_name */ #line 396 "sql.y" -{ yylhsminor.yy1000 = createColumnDefNode(pCxt, &yymsp[-1].minor.yy305, yymsp[0].minor.yy56, NULL, false); } -#line 6382 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createColumnDefNode(pCxt, &yymsp[-1].minor.yy29, yymsp[0].minor.yy784, NULL, false); } +#line 6441 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; case 203: /* column_def ::= column_name type_name PRIMARY KEY */ #line 397 "sql.y" -{ yylhsminor.yy1000 = createColumnDefNode(pCxt, &yymsp[-3].minor.yy305, yymsp[-2].minor.yy56, NULL, true); } -#line 6388 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createColumnDefNode(pCxt, &yymsp[-3].minor.yy29, yymsp[-2].minor.yy784, NULL, true); } +#line 6447 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; case 204: /* type_name ::= BOOL */ #line 402 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_BOOL); } -#line 6394 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_BOOL); } +#line 6453 "sql.c" break; case 205: /* type_name ::= TINYINT */ #line 403 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_TINYINT); } -#line 6399 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_TINYINT); } +#line 6458 "sql.c" break; case 206: /* type_name ::= SMALLINT */ #line 404 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_SMALLINT); } -#line 6404 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_SMALLINT); } +#line 6463 "sql.c" break; case 207: /* type_name ::= INT */ case 208: /* type_name ::= INTEGER */ yytestcase(yyruleno==208); #line 405 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_INT); } -#line 6410 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_INT); } +#line 6469 "sql.c" break; case 209: /* type_name ::= BIGINT */ #line 407 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_BIGINT); } -#line 6415 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_BIGINT); } +#line 6474 "sql.c" break; case 210: /* type_name ::= FLOAT */ #line 408 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_FLOAT); } -#line 6420 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_FLOAT); } +#line 6479 "sql.c" break; case 211: /* type_name ::= DOUBLE */ #line 409 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_DOUBLE); } -#line 6425 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_DOUBLE); } +#line 6484 "sql.c" break; case 212: /* type_name ::= BINARY NK_LP NK_INTEGER NK_RP */ #line 410 "sql.y" -{ yymsp[-3].minor.yy56 = createVarLenDataType(TSDB_DATA_TYPE_BINARY, &yymsp[-1].minor.yy0); } -#line 6430 "sql.c" +{ yymsp[-3].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_BINARY, &yymsp[-1].minor.yy0); } +#line 6489 "sql.c" break; case 213: /* type_name ::= TIMESTAMP */ #line 411 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_TIMESTAMP); } -#line 6435 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_TIMESTAMP); } +#line 6494 "sql.c" break; case 214: /* type_name ::= NCHAR NK_LP NK_INTEGER NK_RP */ #line 412 "sql.y" -{ yymsp[-3].minor.yy56 = createVarLenDataType(TSDB_DATA_TYPE_NCHAR, &yymsp[-1].minor.yy0); } -#line 6440 "sql.c" +{ yymsp[-3].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_NCHAR, &yymsp[-1].minor.yy0); } +#line 6499 "sql.c" break; case 215: /* type_name ::= TINYINT UNSIGNED */ #line 413 "sql.y" -{ yymsp[-1].minor.yy56 = createDataType(TSDB_DATA_TYPE_UTINYINT); } -#line 6445 "sql.c" +{ yymsp[-1].minor.yy784 = createDataType(TSDB_DATA_TYPE_UTINYINT); } +#line 6504 "sql.c" break; case 216: /* type_name ::= SMALLINT UNSIGNED */ #line 414 "sql.y" -{ yymsp[-1].minor.yy56 = createDataType(TSDB_DATA_TYPE_USMALLINT); } -#line 6450 "sql.c" +{ yymsp[-1].minor.yy784 = createDataType(TSDB_DATA_TYPE_USMALLINT); } +#line 6509 "sql.c" break; case 217: /* type_name ::= INT UNSIGNED */ #line 415 "sql.y" -{ yymsp[-1].minor.yy56 = createDataType(TSDB_DATA_TYPE_UINT); } -#line 6455 "sql.c" +{ yymsp[-1].minor.yy784 = createDataType(TSDB_DATA_TYPE_UINT); } +#line 6514 "sql.c" break; case 218: /* type_name ::= BIGINT UNSIGNED */ #line 416 "sql.y" -{ yymsp[-1].minor.yy56 = createDataType(TSDB_DATA_TYPE_UBIGINT); } -#line 6460 "sql.c" +{ yymsp[-1].minor.yy784 = createDataType(TSDB_DATA_TYPE_UBIGINT); } +#line 6519 "sql.c" break; case 219: /* type_name ::= JSON */ #line 417 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_JSON); } -#line 6465 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_JSON); } +#line 6524 "sql.c" break; case 220: /* type_name ::= VARCHAR NK_LP NK_INTEGER NK_RP */ #line 418 "sql.y" -{ yymsp[-3].minor.yy56 = createVarLenDataType(TSDB_DATA_TYPE_VARCHAR, &yymsp[-1].minor.yy0); } -#line 6470 "sql.c" +{ yymsp[-3].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_VARCHAR, &yymsp[-1].minor.yy0); } +#line 6529 "sql.c" break; case 221: /* type_name ::= MEDIUMBLOB */ #line 419 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_MEDIUMBLOB); } -#line 6475 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_MEDIUMBLOB); } +#line 6534 "sql.c" break; case 222: /* type_name ::= BLOB */ #line 420 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_BLOB); } -#line 6480 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_BLOB); } +#line 6539 "sql.c" break; case 223: /* type_name ::= VARBINARY NK_LP NK_INTEGER NK_RP */ #line 421 "sql.y" -{ yymsp[-3].minor.yy56 = createVarLenDataType(TSDB_DATA_TYPE_VARBINARY, &yymsp[-1].minor.yy0); } -#line 6485 "sql.c" +{ yymsp[-3].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_VARBINARY, &yymsp[-1].minor.yy0); } +#line 6544 "sql.c" break; case 224: /* type_name ::= GEOMETRY NK_LP NK_INTEGER NK_RP */ #line 422 "sql.y" -{ yymsp[-3].minor.yy56 = createVarLenDataType(TSDB_DATA_TYPE_GEOMETRY, &yymsp[-1].minor.yy0); } -#line 6490 "sql.c" +{ yymsp[-3].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_GEOMETRY, &yymsp[-1].minor.yy0); } +#line 6549 "sql.c" break; case 225: /* type_name ::= DECIMAL */ #line 423 "sql.y" -{ yymsp[0].minor.yy56 = createDataType(TSDB_DATA_TYPE_DECIMAL); } -#line 6495 "sql.c" +{ yymsp[0].minor.yy784 = createDataType(TSDB_DATA_TYPE_DECIMAL); } +#line 6554 "sql.c" break; case 226: /* type_name ::= DECIMAL NK_LP NK_INTEGER NK_RP */ #line 424 "sql.y" -{ yymsp[-3].minor.yy56 = createDataType(TSDB_DATA_TYPE_DECIMAL); } -#line 6500 "sql.c" +{ yymsp[-3].minor.yy784 = createDataType(TSDB_DATA_TYPE_DECIMAL); } +#line 6559 "sql.c" break; case 227: /* type_name ::= DECIMAL NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ #line 425 "sql.y" -{ yymsp[-5].minor.yy56 = createDataType(TSDB_DATA_TYPE_DECIMAL); } -#line 6505 "sql.c" +{ yymsp[-5].minor.yy784 = createDataType(TSDB_DATA_TYPE_DECIMAL); } +#line 6564 "sql.c" break; - case 230: /* tags_def ::= TAGS NK_LP column_def_list NK_RP */ - case 391: /* tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP */ yytestcase(yyruleno==391); -#line 434 "sql.y" -{ yymsp[-3].minor.yy72 = yymsp[-1].minor.yy72; } -#line 6511 "sql.c" - break; - case 231: /* table_options ::= */ -#line 436 "sql.y" -{ yymsp[1].minor.yy1000 = createDefaultTableOptions(pCxt); } -#line 6516 "sql.c" - break; - case 232: /* table_options ::= table_options COMMENT NK_STRING */ -#line 437 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-2].minor.yy1000, TABLE_OPTION_COMMENT, &yymsp[0].minor.yy0); } -#line 6521 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 233: /* table_options ::= table_options MAX_DELAY duration_list */ -#line 438 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-2].minor.yy1000, TABLE_OPTION_MAXDELAY, yymsp[0].minor.yy72); } -#line 6527 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 234: /* table_options ::= table_options WATERMARK duration_list */ -#line 439 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-2].minor.yy1000, TABLE_OPTION_WATERMARK, yymsp[0].minor.yy72); } -#line 6533 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 235: /* table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP */ -#line 440 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-4].minor.yy1000, TABLE_OPTION_ROLLUP, yymsp[-1].minor.yy72); } -#line 6539 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; - break; - case 236: /* table_options ::= table_options TTL NK_INTEGER */ -#line 441 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-2].minor.yy1000, TABLE_OPTION_TTL, &yymsp[0].minor.yy0); } -#line 6545 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 237: /* table_options ::= table_options SMA NK_LP col_name_list NK_RP */ -#line 442 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-4].minor.yy1000, TABLE_OPTION_SMA, yymsp[-1].minor.yy72); } -#line 6551 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; - break; - case 238: /* table_options ::= table_options DELETE_MARK duration_list */ -#line 443 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-2].minor.yy1000, TABLE_OPTION_DELETE_MARK, yymsp[0].minor.yy72); } -#line 6557 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 239: /* alter_table_options ::= alter_table_option */ -#line 445 "sql.y" -{ yylhsminor.yy1000 = createAlterTableOptions(pCxt); yylhsminor.yy1000 = setTableOption(pCxt, yylhsminor.yy1000, yymsp[0].minor.yy941.type, &yymsp[0].minor.yy941.val); } -#line 6563 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 240: /* alter_table_options ::= alter_table_options alter_table_option */ -#line 446 "sql.y" -{ yylhsminor.yy1000 = setTableOption(pCxt, yymsp[-1].minor.yy1000, yymsp[0].minor.yy941.type, &yymsp[0].minor.yy941.val); } + case 228: /* type_name_default_len ::= BINARY */ +#line 429 "sql.y" +{ yymsp[0].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_BINARY, NULL); } #line 6569 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; break; - case 241: /* alter_table_option ::= COMMENT NK_STRING */ -#line 450 "sql.y" -{ yymsp[-1].minor.yy941.type = TABLE_OPTION_COMMENT; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6575 "sql.c" + case 229: /* type_name_default_len ::= NCHAR */ +#line 430 "sql.y" +{ yymsp[0].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_NCHAR, NULL); } +#line 6574 "sql.c" break; - case 242: /* alter_table_option ::= TTL NK_INTEGER */ -#line 451 "sql.y" -{ yymsp[-1].minor.yy941.type = TABLE_OPTION_TTL; yymsp[-1].minor.yy941.val = yymsp[0].minor.yy0; } -#line 6580 "sql.c" + case 230: /* type_name_default_len ::= VARCHAR */ +#line 431 "sql.y" +{ yymsp[0].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_VARCHAR, NULL); } +#line 6579 "sql.c" break; - case 243: /* duration_list ::= duration_literal */ - case 518: /* expression_list ::= expr_or_subquery */ yytestcase(yyruleno==518); -#line 455 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); } -#line 6586 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; + case 231: /* type_name_default_len ::= VARBINARY */ +#line 432 "sql.y" +{ yymsp[0].minor.yy784 = createVarLenDataType(TSDB_DATA_TYPE_VARBINARY, NULL); } +#line 6584 "sql.c" break; - case 244: /* duration_list ::= duration_list NK_COMMA duration_literal */ - case 519: /* expression_list ::= expression_list NK_COMMA expr_or_subquery */ yytestcase(yyruleno==519); -#line 456 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-2].minor.yy72, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); } -#line 6593 "sql.c" - yymsp[-2].minor.yy72 = yylhsminor.yy72; + case 234: /* tags_def ::= TAGS NK_LP column_def_list NK_RP */ + case 395: /* tag_def_or_ref_opt ::= TAGS NK_LP column_stream_def_list NK_RP */ yytestcase(yyruleno==395); +#line 441 "sql.y" +{ yymsp[-3].minor.yy124 = yymsp[-1].minor.yy124; } +#line 6590 "sql.c" break; - case 247: /* rollup_func_name ::= function_name */ -#line 463 "sql.y" -{ yylhsminor.yy1000 = createFunctionNode(pCxt, &yymsp[0].minor.yy305, NULL); } -#line 6599 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 235: /* table_options ::= */ +#line 443 "sql.y" +{ yymsp[1].minor.yy812 = createDefaultTableOptions(pCxt); } +#line 6595 "sql.c" break; - case 248: /* rollup_func_name ::= FIRST */ - case 249: /* rollup_func_name ::= LAST */ yytestcase(yyruleno==249); - case 321: /* tag_item ::= QTAGS */ yytestcase(yyruleno==321); -#line 464 "sql.y" -{ yylhsminor.yy1000 = createFunctionNode(pCxt, &yymsp[0].minor.yy0, NULL); } -#line 6607 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 236: /* table_options ::= table_options COMMENT NK_STRING */ +#line 444 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-2].minor.yy812, TABLE_OPTION_COMMENT, &yymsp[0].minor.yy0); } +#line 6600 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 252: /* col_name ::= column_name */ - case 322: /* tag_item ::= column_name */ yytestcase(yyruleno==322); -#line 472 "sql.y" -{ yylhsminor.yy1000 = createColumnNode(pCxt, NULL, &yymsp[0].minor.yy305); } -#line 6614 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 237: /* table_options ::= table_options MAX_DELAY duration_list */ +#line 445 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-2].minor.yy812, TABLE_OPTION_MAXDELAY, yymsp[0].minor.yy124); } +#line 6606 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 253: /* cmd ::= SHOW DNODES */ -#line 475 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_DNODES_STMT); } -#line 6620 "sql.c" + case 238: /* table_options ::= table_options WATERMARK duration_list */ +#line 446 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-2].minor.yy812, TABLE_OPTION_WATERMARK, yymsp[0].minor.yy124); } +#line 6612 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 254: /* cmd ::= SHOW USERS */ -#line 476 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_USERS_STMT); } -#line 6625 "sql.c" + case 239: /* table_options ::= table_options ROLLUP NK_LP rollup_func_list NK_RP */ +#line 447 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-4].minor.yy812, TABLE_OPTION_ROLLUP, yymsp[-1].minor.yy124); } +#line 6618 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; - case 255: /* cmd ::= SHOW USER PRIVILEGES */ -#line 477 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_USER_PRIVILEGES_STMT); } + case 240: /* table_options ::= table_options TTL NK_INTEGER */ +#line 448 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-2].minor.yy812, TABLE_OPTION_TTL, &yymsp[0].minor.yy0); } +#line 6624 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 241: /* table_options ::= table_options SMA NK_LP col_name_list NK_RP */ +#line 449 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-4].minor.yy812, TABLE_OPTION_SMA, yymsp[-1].minor.yy124); } #line 6630 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; - case 256: /* cmd ::= SHOW db_kind_opt DATABASES */ -#line 478 "sql.y" + case 242: /* table_options ::= table_options DELETE_MARK duration_list */ +#line 450 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-2].minor.yy812, TABLE_OPTION_DELETE_MARK, yymsp[0].minor.yy124); } +#line 6636 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 243: /* alter_table_options ::= alter_table_option */ +#line 452 "sql.y" +{ yylhsminor.yy812 = createAlterTableOptions(pCxt); yylhsminor.yy812 = setTableOption(pCxt, yylhsminor.yy812, yymsp[0].minor.yy95.type, &yymsp[0].minor.yy95.val); } +#line 6642 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 244: /* alter_table_options ::= alter_table_options alter_table_option */ +#line 453 "sql.y" +{ yylhsminor.yy812 = setTableOption(pCxt, yymsp[-1].minor.yy812, yymsp[0].minor.yy95.type, &yymsp[0].minor.yy95.val); } +#line 6648 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; + break; + case 245: /* alter_table_option ::= COMMENT NK_STRING */ +#line 457 "sql.y" +{ yymsp[-1].minor.yy95.type = TABLE_OPTION_COMMENT; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6654 "sql.c" + break; + case 246: /* alter_table_option ::= TTL NK_INTEGER */ +#line 458 "sql.y" +{ yymsp[-1].minor.yy95.type = TABLE_OPTION_TTL; yymsp[-1].minor.yy95.val = yymsp[0].minor.yy0; } +#line 6659 "sql.c" + break; + case 247: /* duration_list ::= duration_literal */ + case 522: /* expression_list ::= expr_or_subquery */ yytestcase(yyruleno==522); +#line 462 "sql.y" +{ yylhsminor.yy124 = createNodeList(pCxt, releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } +#line 6665 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; + break; + case 248: /* duration_list ::= duration_list NK_COMMA duration_literal */ + case 523: /* expression_list ::= expression_list NK_COMMA expr_or_subquery */ yytestcase(yyruleno==523); +#line 463 "sql.y" +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-2].minor.yy124, releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } +#line 6672 "sql.c" + yymsp[-2].minor.yy124 = yylhsminor.yy124; + break; + case 251: /* rollup_func_name ::= function_name */ +#line 470 "sql.y" +{ yylhsminor.yy812 = createFunctionNode(pCxt, &yymsp[0].minor.yy29, NULL); } +#line 6678 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 252: /* rollup_func_name ::= FIRST */ + case 253: /* rollup_func_name ::= LAST */ yytestcase(yyruleno==253); + case 325: /* tag_item ::= QTAGS */ yytestcase(yyruleno==325); +#line 471 "sql.y" +{ yylhsminor.yy812 = createFunctionNode(pCxt, &yymsp[0].minor.yy0, NULL); } +#line 6686 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 256: /* col_name ::= column_name */ + case 326: /* tag_item ::= column_name */ yytestcase(yyruleno==326); +#line 479 "sql.y" +{ yylhsminor.yy812 = createColumnNode(pCxt, NULL, &yymsp[0].minor.yy29); } +#line 6693 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 257: /* cmd ::= SHOW DNODES */ +#line 482 "sql.y" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_DNODES_STMT); } +#line 6699 "sql.c" + break; + case 258: /* cmd ::= SHOW USERS */ +#line 483 "sql.y" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_USERS_STMT); } +#line 6704 "sql.c" + break; + case 259: /* cmd ::= SHOW USER PRIVILEGES */ +#line 484 "sql.y" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_USER_PRIVILEGES_STMT); } +#line 6709 "sql.c" + break; + case 260: /* cmd ::= SHOW db_kind_opt DATABASES */ +#line 485 "sql.y" { pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_DATABASES_STMT); - setShowKind(pCxt, pCxt->pRootNode, yymsp[-1].minor.yy761); + setShowKind(pCxt, pCxt->pRootNode, yymsp[-1].minor.yy789); } -#line 6638 "sql.c" +#line 6717 "sql.c" break; - case 257: /* cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt */ -#line 482 "sql.y" -{ - pCxt->pRootNode = createShowTablesStmt(pCxt, yymsp[-2].minor.yy517, yymsp[0].minor.yy1000, OP_TYPE_LIKE); - } -#line 6645 "sql.c" - break; - case 258: /* cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt */ -#line 485 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_STABLES_STMT, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000, OP_TYPE_LIKE); } -#line 6650 "sql.c" - break; - case 259: /* cmd ::= SHOW db_name_cond_opt VGROUPS */ -#line 486 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_VGROUPS_STMT, yymsp[-1].minor.yy1000, NULL, OP_TYPE_LIKE); } -#line 6655 "sql.c" - break; - case 260: /* cmd ::= SHOW MNODES */ -#line 487 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_MNODES_STMT); } -#line 6660 "sql.c" - break; - case 261: /* cmd ::= SHOW QNODES */ + case 261: /* cmd ::= SHOW table_kind_db_name_cond_opt TABLES like_pattern_opt */ #line 489 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_QNODES_STMT); } -#line 6665 "sql.c" +{ + pCxt->pRootNode = createShowTablesStmt(pCxt, yymsp[-2].minor.yy667, yymsp[0].minor.yy812, OP_TYPE_LIKE); + } +#line 6724 "sql.c" break; - case 262: /* cmd ::= SHOW ARBGROUPS */ -#line 490 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_ARBGROUPS_STMT); } -#line 6670 "sql.c" - break; - case 263: /* cmd ::= SHOW FUNCTIONS */ -#line 491 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_FUNCTIONS_STMT); } -#line 6675 "sql.c" - break; - case 264: /* cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt */ + case 262: /* cmd ::= SHOW db_name_cond_opt STABLES like_pattern_opt */ #line 492 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_INDEXES_STMT, yymsp[0].minor.yy1000, yymsp[-1].minor.yy1000, OP_TYPE_EQUAL); } -#line 6680 "sql.c" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_STABLES_STMT, yymsp[-2].minor.yy812, yymsp[0].minor.yy812, OP_TYPE_LIKE); } +#line 6729 "sql.c" break; - case 265: /* cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name */ + case 263: /* cmd ::= SHOW db_name_cond_opt VGROUPS */ #line 493 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_INDEXES_STMT, createIdentifierValueNode(pCxt, &yymsp[-2].minor.yy305), createIdentifierValueNode(pCxt, &yymsp[0].minor.yy305), OP_TYPE_EQUAL); } -#line 6685 "sql.c" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_VGROUPS_STMT, yymsp[-1].minor.yy812, NULL, OP_TYPE_LIKE); } +#line 6734 "sql.c" break; - case 266: /* cmd ::= SHOW STREAMS */ + case 264: /* cmd ::= SHOW MNODES */ #line 494 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_STREAMS_STMT); } -#line 6690 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_MNODES_STMT); } +#line 6739 "sql.c" break; - case 267: /* cmd ::= SHOW ACCOUNTS */ -#line 495 "sql.y" -{ pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_EXPRIE_STATEMENT); } -#line 6695 "sql.c" - break; - case 268: /* cmd ::= SHOW APPS */ + case 265: /* cmd ::= SHOW QNODES */ #line 496 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_APPS_STMT); } -#line 6700 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_QNODES_STMT); } +#line 6744 "sql.c" break; - case 269: /* cmd ::= SHOW CONNECTIONS */ + case 266: /* cmd ::= SHOW ARBGROUPS */ #line 497 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CONNECTIONS_STMT); } -#line 6705 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_ARBGROUPS_STMT); } +#line 6749 "sql.c" break; - case 270: /* cmd ::= SHOW LICENCES */ - case 271: /* cmd ::= SHOW GRANTS */ yytestcase(yyruleno==271); + case 267: /* cmd ::= SHOW FUNCTIONS */ #line 498 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_LICENCES_STMT); } -#line 6711 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_FUNCTIONS_STMT); } +#line 6754 "sql.c" break; - case 272: /* cmd ::= SHOW GRANTS FULL */ + case 268: /* cmd ::= SHOW INDEXES FROM table_name_cond from_db_opt */ +#line 499 "sql.y" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_INDEXES_STMT, yymsp[0].minor.yy812, yymsp[-1].minor.yy812, OP_TYPE_EQUAL); } +#line 6759 "sql.c" + break; + case 269: /* cmd ::= SHOW INDEXES FROM db_name NK_DOT table_name */ #line 500 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_GRANTS_FULL_STMT); } -#line 6716 "sql.c" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_INDEXES_STMT, createIdentifierValueNode(pCxt, &yymsp[-2].minor.yy29), createIdentifierValueNode(pCxt, &yymsp[0].minor.yy29), OP_TYPE_EQUAL); } +#line 6764 "sql.c" break; - case 273: /* cmd ::= SHOW GRANTS LOGS */ + case 270: /* cmd ::= SHOW STREAMS */ #line 501 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_GRANTS_LOGS_STMT); } -#line 6721 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_STREAMS_STMT); } +#line 6769 "sql.c" break; - case 274: /* cmd ::= SHOW CLUSTER MACHINES */ + case 271: /* cmd ::= SHOW ACCOUNTS */ #line 502 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CLUSTER_MACHINES_STMT); } -#line 6726 "sql.c" +{ pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_EXPRIE_STATEMENT); } +#line 6774 "sql.c" break; - case 275: /* cmd ::= SHOW CREATE DATABASE db_name */ + case 272: /* cmd ::= SHOW APPS */ #line 503 "sql.y" -{ pCxt->pRootNode = createShowCreateDatabaseStmt(pCxt, &yymsp[0].minor.yy305); } -#line 6731 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_APPS_STMT); } +#line 6779 "sql.c" break; - case 276: /* cmd ::= SHOW CREATE TABLE full_table_name */ + case 273: /* cmd ::= SHOW CONNECTIONS */ #line 504 "sql.y" -{ pCxt->pRootNode = createShowCreateTableStmt(pCxt, QUERY_NODE_SHOW_CREATE_TABLE_STMT, yymsp[0].minor.yy1000); } -#line 6736 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CONNECTIONS_STMT); } +#line 6784 "sql.c" break; - case 277: /* cmd ::= SHOW CREATE STABLE full_table_name */ + case 274: /* cmd ::= SHOW LICENCES */ + case 275: /* cmd ::= SHOW GRANTS */ yytestcase(yyruleno==275); #line 505 "sql.y" -{ pCxt->pRootNode = createShowCreateTableStmt(pCxt, QUERY_NODE_SHOW_CREATE_STABLE_STMT, yymsp[0].minor.yy1000); } -#line 6741 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_LICENCES_STMT); } +#line 6790 "sql.c" break; - case 278: /* cmd ::= SHOW QUERIES */ -#line 506 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_QUERIES_STMT); } -#line 6746 "sql.c" - break; - case 279: /* cmd ::= SHOW SCORES */ + case 276: /* cmd ::= SHOW GRANTS FULL */ #line 507 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_SCORES_STMT); } -#line 6751 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_GRANTS_FULL_STMT); } +#line 6795 "sql.c" break; - case 280: /* cmd ::= SHOW TOPICS */ + case 277: /* cmd ::= SHOW GRANTS LOGS */ #line 508 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_TOPICS_STMT); } -#line 6756 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_GRANTS_LOGS_STMT); } +#line 6800 "sql.c" break; - case 281: /* cmd ::= SHOW VARIABLES */ - case 282: /* cmd ::= SHOW CLUSTER VARIABLES */ yytestcase(yyruleno==282); + case 278: /* cmd ::= SHOW CLUSTER MACHINES */ #line 509 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_VARIABLES_STMT); } -#line 6762 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CLUSTER_MACHINES_STMT); } +#line 6805 "sql.c" break; - case 283: /* cmd ::= SHOW LOCAL VARIABLES */ + case 279: /* cmd ::= SHOW CREATE DATABASE db_name */ +#line 510 "sql.y" +{ pCxt->pRootNode = createShowCreateDatabaseStmt(pCxt, &yymsp[0].minor.yy29); } +#line 6810 "sql.c" + break; + case 280: /* cmd ::= SHOW CREATE TABLE full_table_name */ #line 511 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_LOCAL_VARIABLES_STMT); } -#line 6767 "sql.c" +{ pCxt->pRootNode = createShowCreateTableStmt(pCxt, QUERY_NODE_SHOW_CREATE_TABLE_STMT, yymsp[0].minor.yy812); } +#line 6815 "sql.c" break; - case 284: /* cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt */ + case 281: /* cmd ::= SHOW CREATE STABLE full_table_name */ #line 512 "sql.y" -{ pCxt->pRootNode = createShowDnodeVariablesStmt(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[-2].minor.yy0), yymsp[0].minor.yy1000); } -#line 6772 "sql.c" +{ pCxt->pRootNode = createShowCreateTableStmt(pCxt, QUERY_NODE_SHOW_CREATE_STABLE_STMT, yymsp[0].minor.yy812); } +#line 6820 "sql.c" break; - case 285: /* cmd ::= SHOW BNODES */ + case 282: /* cmd ::= SHOW QUERIES */ #line 513 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_BNODES_STMT); } -#line 6777 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_QUERIES_STMT); } +#line 6825 "sql.c" break; - case 286: /* cmd ::= SHOW SNODES */ + case 283: /* cmd ::= SHOW SCORES */ #line 514 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_SNODES_STMT); } -#line 6782 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_SCORES_STMT); } +#line 6830 "sql.c" break; - case 287: /* cmd ::= SHOW CLUSTER */ + case 284: /* cmd ::= SHOW TOPICS */ #line 515 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CLUSTER_STMT); } -#line 6787 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_TOPICS_STMT); } +#line 6835 "sql.c" break; - case 288: /* cmd ::= SHOW TRANSACTIONS */ + case 285: /* cmd ::= SHOW VARIABLES */ + case 286: /* cmd ::= SHOW CLUSTER VARIABLES */ yytestcase(yyruleno==286); #line 516 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_TRANSACTIONS_STMT); } -#line 6792 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_VARIABLES_STMT); } +#line 6841 "sql.c" break; - case 289: /* cmd ::= SHOW TABLE DISTRIBUTED full_table_name */ -#line 517 "sql.y" -{ pCxt->pRootNode = createShowTableDistributedStmt(pCxt, yymsp[0].minor.yy1000); } -#line 6797 "sql.c" - break; - case 290: /* cmd ::= SHOW CONSUMERS */ + case 287: /* cmd ::= SHOW LOCAL VARIABLES */ #line 518 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CONSUMERS_STMT); } -#line 6802 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_LOCAL_VARIABLES_STMT); } +#line 6846 "sql.c" break; - case 291: /* cmd ::= SHOW SUBSCRIPTIONS */ + case 288: /* cmd ::= SHOW DNODE NK_INTEGER VARIABLES like_pattern_opt */ #line 519 "sql.y" -{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_SUBSCRIPTIONS_STMT); } -#line 6807 "sql.c" +{ pCxt->pRootNode = createShowDnodeVariablesStmt(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[-2].minor.yy0), yymsp[0].minor.yy812); } +#line 6851 "sql.c" break; - case 292: /* cmd ::= SHOW TAGS FROM table_name_cond from_db_opt */ + case 289: /* cmd ::= SHOW BNODES */ #line 520 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_TAGS_STMT, yymsp[0].minor.yy1000, yymsp[-1].minor.yy1000, OP_TYPE_EQUAL); } -#line 6812 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_BNODES_STMT); } +#line 6856 "sql.c" break; - case 293: /* cmd ::= SHOW TAGS FROM db_name NK_DOT table_name */ + case 290: /* cmd ::= SHOW SNODES */ #line 521 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_TAGS_STMT, createIdentifierValueNode(pCxt, &yymsp[-2].minor.yy305), createIdentifierValueNode(pCxt, &yymsp[0].minor.yy305), OP_TYPE_EQUAL); } -#line 6817 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_SNODES_STMT); } +#line 6861 "sql.c" break; - case 294: /* cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt */ + case 291: /* cmd ::= SHOW CLUSTER */ #line 522 "sql.y" -{ pCxt->pRootNode = createShowTableTagsStmt(pCxt, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000, yymsp[-3].minor.yy72); } -#line 6822 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CLUSTER_STMT); } +#line 6866 "sql.c" break; - case 295: /* cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name */ + case 292: /* cmd ::= SHOW TRANSACTIONS */ #line 523 "sql.y" -{ pCxt->pRootNode = createShowTableTagsStmt(pCxt, createIdentifierValueNode(pCxt, &yymsp[0].minor.yy305), createIdentifierValueNode(pCxt, &yymsp[-2].minor.yy305), yymsp[-4].minor.yy72); } -#line 6827 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_TRANSACTIONS_STMT); } +#line 6871 "sql.c" break; - case 296: /* cmd ::= SHOW VNODES ON DNODE NK_INTEGER */ + case 293: /* cmd ::= SHOW TABLE DISTRIBUTED full_table_name */ #line 524 "sql.y" -{ pCxt->pRootNode = createShowVnodesStmt(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0), NULL); } -#line 6832 "sql.c" +{ pCxt->pRootNode = createShowTableDistributedStmt(pCxt, yymsp[0].minor.yy812); } +#line 6876 "sql.c" break; - case 297: /* cmd ::= SHOW VNODES */ + case 294: /* cmd ::= SHOW CONSUMERS */ #line 525 "sql.y" -{ pCxt->pRootNode = createShowVnodesStmt(pCxt, NULL, NULL); } -#line 6837 "sql.c" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_CONSUMERS_STMT); } +#line 6881 "sql.c" break; - case 298: /* cmd ::= SHOW db_name_cond_opt ALIVE */ + case 295: /* cmd ::= SHOW SUBSCRIPTIONS */ +#line 526 "sql.y" +{ pCxt->pRootNode = createShowStmt(pCxt, QUERY_NODE_SHOW_SUBSCRIPTIONS_STMT); } +#line 6886 "sql.c" + break; + case 296: /* cmd ::= SHOW TAGS FROM table_name_cond from_db_opt */ #line 527 "sql.y" -{ pCxt->pRootNode = createShowAliveStmt(pCxt, yymsp[-1].minor.yy1000, QUERY_NODE_SHOW_DB_ALIVE_STMT); } -#line 6842 "sql.c" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_TAGS_STMT, yymsp[0].minor.yy812, yymsp[-1].minor.yy812, OP_TYPE_EQUAL); } +#line 6891 "sql.c" break; - case 299: /* cmd ::= SHOW CLUSTER ALIVE */ + case 297: /* cmd ::= SHOW TAGS FROM db_name NK_DOT table_name */ #line 528 "sql.y" -{ pCxt->pRootNode = createShowAliveStmt(pCxt, NULL, QUERY_NODE_SHOW_CLUSTER_ALIVE_STMT); } -#line 6847 "sql.c" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_TAGS_STMT, createIdentifierValueNode(pCxt, &yymsp[-2].minor.yy29), createIdentifierValueNode(pCxt, &yymsp[0].minor.yy29), OP_TYPE_EQUAL); } +#line 6896 "sql.c" break; - case 300: /* cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt */ + case 298: /* cmd ::= SHOW TABLE TAGS tag_list_opt FROM table_name_cond from_db_opt */ #line 529 "sql.y" -{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_VIEWS_STMT, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000, OP_TYPE_LIKE); } -#line 6852 "sql.c" +{ pCxt->pRootNode = createShowTableTagsStmt(pCxt, yymsp[-1].minor.yy812, yymsp[0].minor.yy812, yymsp[-3].minor.yy124); } +#line 6901 "sql.c" break; - case 301: /* cmd ::= SHOW CREATE VIEW full_table_name */ + case 299: /* cmd ::= SHOW TABLE TAGS tag_list_opt FROM db_name NK_DOT table_name */ #line 530 "sql.y" -{ pCxt->pRootNode = createShowCreateViewStmt(pCxt, QUERY_NODE_SHOW_CREATE_VIEW_STMT, yymsp[0].minor.yy1000); } -#line 6857 "sql.c" - break; - case 302: /* cmd ::= SHOW COMPACTS */ -#line 531 "sql.y" -{ pCxt->pRootNode = createShowCompactsStmt(pCxt, QUERY_NODE_SHOW_COMPACTS_STMT); } -#line 6862 "sql.c" - break; - case 303: /* cmd ::= SHOW COMPACT NK_INTEGER */ -#line 532 "sql.y" -{ pCxt->pRootNode = createShowCompactDetailsStmt(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } -#line 6867 "sql.c" - break; - case 304: /* table_kind_db_name_cond_opt ::= */ -#line 536 "sql.y" -{ yymsp[1].minor.yy517.kind = SHOW_KIND_ALL; yymsp[1].minor.yy517.dbName = nil_token; } -#line 6872 "sql.c" - break; - case 305: /* table_kind_db_name_cond_opt ::= table_kind */ -#line 537 "sql.y" -{ yylhsminor.yy517.kind = yymsp[0].minor.yy761; yylhsminor.yy517.dbName = nil_token; } -#line 6877 "sql.c" - yymsp[0].minor.yy517 = yylhsminor.yy517; - break; - case 306: /* table_kind_db_name_cond_opt ::= db_name NK_DOT */ -#line 538 "sql.y" -{ yylhsminor.yy517.kind = SHOW_KIND_ALL; yylhsminor.yy517.dbName = yymsp[-1].minor.yy305; } -#line 6883 "sql.c" - yymsp[-1].minor.yy517 = yylhsminor.yy517; - break; - case 307: /* table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT */ -#line 539 "sql.y" -{ yylhsminor.yy517.kind = yymsp[-2].minor.yy761; yylhsminor.yy517.dbName = yymsp[-1].minor.yy305; } -#line 6889 "sql.c" - yymsp[-2].minor.yy517 = yylhsminor.yy517; - break; - case 308: /* table_kind ::= NORMAL */ -#line 543 "sql.y" -{ yymsp[0].minor.yy761 = SHOW_KIND_TABLES_NORMAL; } -#line 6895 "sql.c" - break; - case 309: /* table_kind ::= CHILD */ -#line 544 "sql.y" -{ yymsp[0].minor.yy761 = SHOW_KIND_TABLES_CHILD; } -#line 6900 "sql.c" - break; - case 310: /* db_name_cond_opt ::= */ - case 315: /* from_db_opt ::= */ yytestcase(yyruleno==315); -#line 546 "sql.y" -{ yymsp[1].minor.yy1000 = createDefaultDatabaseCondValue(pCxt); } +{ pCxt->pRootNode = createShowTableTagsStmt(pCxt, createIdentifierValueNode(pCxt, &yymsp[0].minor.yy29), createIdentifierValueNode(pCxt, &yymsp[-2].minor.yy29), yymsp[-4].minor.yy124); } #line 6906 "sql.c" break; - case 311: /* db_name_cond_opt ::= db_name NK_DOT */ -#line 547 "sql.y" -{ yylhsminor.yy1000 = createIdentifierValueNode(pCxt, &yymsp[-1].minor.yy305); } + case 300: /* cmd ::= SHOW VNODES ON DNODE NK_INTEGER */ +#line 531 "sql.y" +{ pCxt->pRootNode = createShowVnodesStmt(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0), NULL); } #line 6911 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; break; - case 313: /* like_pattern_opt ::= LIKE NK_STRING */ -#line 550 "sql.y" -{ yymsp[-1].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0); } -#line 6917 "sql.c" + case 301: /* cmd ::= SHOW VNODES */ +#line 532 "sql.y" +{ pCxt->pRootNode = createShowVnodesStmt(pCxt, NULL, NULL); } +#line 6916 "sql.c" break; - case 314: /* table_name_cond ::= table_name */ -#line 552 "sql.y" -{ yylhsminor.yy1000 = createIdentifierValueNode(pCxt, &yymsp[0].minor.yy305); } -#line 6922 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 302: /* cmd ::= SHOW db_name_cond_opt ALIVE */ +#line 534 "sql.y" +{ pCxt->pRootNode = createShowAliveStmt(pCxt, yymsp[-1].minor.yy812, QUERY_NODE_SHOW_DB_ALIVE_STMT); } +#line 6921 "sql.c" break; - case 316: /* from_db_opt ::= FROM db_name */ -#line 555 "sql.y" -{ yymsp[-1].minor.yy1000 = createIdentifierValueNode(pCxt, &yymsp[0].minor.yy305); } -#line 6928 "sql.c" + case 303: /* cmd ::= SHOW CLUSTER ALIVE */ +#line 535 "sql.y" +{ pCxt->pRootNode = createShowAliveStmt(pCxt, NULL, QUERY_NODE_SHOW_CLUSTER_ALIVE_STMT); } +#line 6926 "sql.c" break; - case 320: /* tag_item ::= TBNAME */ -#line 563 "sql.y" -{ yylhsminor.yy1000 = setProjectionAlias(pCxt, createFunctionNode(pCxt, &yymsp[0].minor.yy0, NULL), &yymsp[0].minor.yy0); } -#line 6933 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 304: /* cmd ::= SHOW db_name_cond_opt VIEWS like_pattern_opt */ +#line 536 "sql.y" +{ pCxt->pRootNode = createShowStmtWithCond(pCxt, QUERY_NODE_SHOW_VIEWS_STMT, yymsp[-2].minor.yy812, yymsp[0].minor.yy812, OP_TYPE_LIKE); } +#line 6931 "sql.c" break; - case 323: /* tag_item ::= column_name column_alias */ -#line 566 "sql.y" -{ yylhsminor.yy1000 = setProjectionAlias(pCxt, createColumnNode(pCxt, NULL, &yymsp[-1].minor.yy305), &yymsp[0].minor.yy305); } -#line 6939 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; + case 305: /* cmd ::= SHOW CREATE VIEW full_table_name */ +#line 537 "sql.y" +{ pCxt->pRootNode = createShowCreateViewStmt(pCxt, QUERY_NODE_SHOW_CREATE_VIEW_STMT, yymsp[0].minor.yy812); } +#line 6936 "sql.c" break; - case 324: /* tag_item ::= column_name AS column_alias */ -#line 567 "sql.y" -{ yylhsminor.yy1000 = setProjectionAlias(pCxt, createColumnNode(pCxt, NULL, &yymsp[-2].minor.yy305), &yymsp[0].minor.yy305); } -#line 6945 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 306: /* cmd ::= SHOW COMPACTS */ +#line 538 "sql.y" +{ pCxt->pRootNode = createShowCompactsStmt(pCxt, QUERY_NODE_SHOW_COMPACTS_STMT); } +#line 6941 "sql.c" break; - case 325: /* db_kind_opt ::= */ -#line 571 "sql.y" -{ yymsp[1].minor.yy761 = SHOW_KIND_ALL; } + case 307: /* cmd ::= SHOW COMPACT NK_INTEGER */ +#line 539 "sql.y" +{ pCxt->pRootNode = createShowCompactDetailsStmt(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } +#line 6946 "sql.c" + break; + case 308: /* table_kind_db_name_cond_opt ::= */ +#line 543 "sql.y" +{ yymsp[1].minor.yy667.kind = SHOW_KIND_ALL; yymsp[1].minor.yy667.dbName = nil_token; } #line 6951 "sql.c" break; - case 326: /* db_kind_opt ::= USER */ -#line 572 "sql.y" -{ yymsp[0].minor.yy761 = SHOW_KIND_DATABASES_USER; } + case 309: /* table_kind_db_name_cond_opt ::= table_kind */ +#line 544 "sql.y" +{ yylhsminor.yy667.kind = yymsp[0].minor.yy789; yylhsminor.yy667.dbName = nil_token; } #line 6956 "sql.c" + yymsp[0].minor.yy667 = yylhsminor.yy667; break; - case 327: /* db_kind_opt ::= SYSTEM */ + case 310: /* table_kind_db_name_cond_opt ::= db_name NK_DOT */ +#line 545 "sql.y" +{ yylhsminor.yy667.kind = SHOW_KIND_ALL; yylhsminor.yy667.dbName = yymsp[-1].minor.yy29; } +#line 6962 "sql.c" + yymsp[-1].minor.yy667 = yylhsminor.yy667; + break; + case 311: /* table_kind_db_name_cond_opt ::= table_kind db_name NK_DOT */ +#line 546 "sql.y" +{ yylhsminor.yy667.kind = yymsp[-2].minor.yy789; yylhsminor.yy667.dbName = yymsp[-1].minor.yy29; } +#line 6968 "sql.c" + yymsp[-2].minor.yy667 = yylhsminor.yy667; + break; + case 312: /* table_kind ::= NORMAL */ +#line 550 "sql.y" +{ yymsp[0].minor.yy789 = SHOW_KIND_TABLES_NORMAL; } +#line 6974 "sql.c" + break; + case 313: /* table_kind ::= CHILD */ +#line 551 "sql.y" +{ yymsp[0].minor.yy789 = SHOW_KIND_TABLES_CHILD; } +#line 6979 "sql.c" + break; + case 314: /* db_name_cond_opt ::= */ + case 319: /* from_db_opt ::= */ yytestcase(yyruleno==319); +#line 553 "sql.y" +{ yymsp[1].minor.yy812 = createDefaultDatabaseCondValue(pCxt); } +#line 6985 "sql.c" + break; + case 315: /* db_name_cond_opt ::= db_name NK_DOT */ +#line 554 "sql.y" +{ yylhsminor.yy812 = createIdentifierValueNode(pCxt, &yymsp[-1].minor.yy29); } +#line 6990 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; + break; + case 317: /* like_pattern_opt ::= LIKE NK_STRING */ +#line 557 "sql.y" +{ yymsp[-1].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0); } +#line 6996 "sql.c" + break; + case 318: /* table_name_cond ::= table_name */ +#line 559 "sql.y" +{ yylhsminor.yy812 = createIdentifierValueNode(pCxt, &yymsp[0].minor.yy29); } +#line 7001 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 320: /* from_db_opt ::= FROM db_name */ +#line 562 "sql.y" +{ yymsp[-1].minor.yy812 = createIdentifierValueNode(pCxt, &yymsp[0].minor.yy29); } +#line 7007 "sql.c" + break; + case 324: /* tag_item ::= TBNAME */ +#line 570 "sql.y" +{ yylhsminor.yy812 = setProjectionAlias(pCxt, createFunctionNode(pCxt, &yymsp[0].minor.yy0, NULL), &yymsp[0].minor.yy0); } +#line 7012 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 327: /* tag_item ::= column_name column_alias */ #line 573 "sql.y" -{ yymsp[0].minor.yy761 = SHOW_KIND_DATABASES_SYSTEM; } -#line 6961 "sql.c" +{ yylhsminor.yy812 = setProjectionAlias(pCxt, createColumnNode(pCxt, NULL, &yymsp[-1].minor.yy29), &yymsp[0].minor.yy29); } +#line 7018 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 328: /* cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options */ -#line 577 "sql.y" -{ pCxt->pRootNode = createCreateIndexStmt(pCxt, INDEX_TYPE_SMA, yymsp[-4].minor.yy985, yymsp[-3].minor.yy1000, yymsp[-1].minor.yy1000, NULL, yymsp[0].minor.yy1000); } -#line 6966 "sql.c" + case 328: /* tag_item ::= column_name AS column_alias */ +#line 574 "sql.y" +{ yylhsminor.yy812 = setProjectionAlias(pCxt, createColumnNode(pCxt, NULL, &yymsp[-2].minor.yy29), &yymsp[0].minor.yy29); } +#line 7024 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 329: /* cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP */ + case 329: /* db_kind_opt ::= */ +#line 578 "sql.y" +{ yymsp[1].minor.yy789 = SHOW_KIND_ALL; } +#line 7030 "sql.c" + break; + case 330: /* db_kind_opt ::= USER */ #line 579 "sql.y" -{ pCxt->pRootNode = createCreateIndexStmt(pCxt, INDEX_TYPE_NORMAL, yymsp[-6].minor.yy985, yymsp[-5].minor.yy1000, yymsp[-3].minor.yy1000, yymsp[-1].minor.yy72, NULL); } -#line 6971 "sql.c" +{ yymsp[0].minor.yy789 = SHOW_KIND_DATABASES_USER; } +#line 7035 "sql.c" break; - case 330: /* cmd ::= DROP INDEX exists_opt full_index_name */ + case 331: /* db_kind_opt ::= SYSTEM */ #line 580 "sql.y" -{ pCxt->pRootNode = createDropIndexStmt(pCxt, yymsp[-1].minor.yy985, yymsp[0].minor.yy1000); } -#line 6976 "sql.c" - break; - case 331: /* full_index_name ::= index_name */ -#line 582 "sql.y" -{ yylhsminor.yy1000 = createRealTableNodeForIndexName(pCxt, NULL, &yymsp[0].minor.yy305); } -#line 6981 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 332: /* full_index_name ::= db_name NK_DOT index_name */ -#line 583 "sql.y" -{ yylhsminor.yy1000 = createRealTableNodeForIndexName(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy305); } -#line 6987 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 333: /* index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt */ -#line 586 "sql.y" -{ yymsp[-9].minor.yy1000 = createIndexOption(pCxt, yymsp[-7].minor.yy72, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), NULL, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 6993 "sql.c" - break; - case 334: /* index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt */ -#line 589 "sql.y" -{ yymsp[-11].minor.yy1000 = createIndexOption(pCxt, yymsp[-9].minor.yy72, releaseRawExprNode(pCxt, yymsp[-5].minor.yy1000), releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 6998 "sql.c" - break; - case 337: /* func ::= sma_func_name NK_LP expression_list NK_RP */ -#line 596 "sql.y" -{ yylhsminor.yy1000 = createFunctionNode(pCxt, &yymsp[-3].minor.yy305, yymsp[-1].minor.yy72); } -#line 7003 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; - break; - case 338: /* sma_func_name ::= function_name */ - case 608: /* alias_opt ::= table_alias */ yytestcase(yyruleno==608); -#line 600 "sql.y" -{ yylhsminor.yy305 = yymsp[0].minor.yy305; } -#line 7010 "sql.c" - yymsp[0].minor.yy305 = yylhsminor.yy305; - break; - case 343: /* sma_stream_opt ::= */ - case 392: /* stream_options ::= */ yytestcase(yyruleno==392); -#line 606 "sql.y" -{ yymsp[1].minor.yy1000 = createStreamOptions(pCxt); } -#line 7017 "sql.c" - break; - case 344: /* sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal */ -#line 607 "sql.y" -{ ((SStreamOptions*)yymsp[-2].minor.yy1000)->pWatermark = releaseRawExprNode(pCxt, yymsp[0].minor.yy1000); yylhsminor.yy1000 = yymsp[-2].minor.yy1000; } -#line 7022 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 345: /* sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal */ -#line 608 "sql.y" -{ ((SStreamOptions*)yymsp[-2].minor.yy1000)->pDelay = releaseRawExprNode(pCxt, yymsp[0].minor.yy1000); yylhsminor.yy1000 = yymsp[-2].minor.yy1000; } -#line 7028 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 346: /* sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal */ -#line 609 "sql.y" -{ ((SStreamOptions*)yymsp[-2].minor.yy1000)->pDeleteMark = releaseRawExprNode(pCxt, yymsp[0].minor.yy1000); yylhsminor.yy1000 = yymsp[-2].minor.yy1000; } -#line 7034 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 347: /* with_meta ::= AS */ -#line 614 "sql.y" -{ yymsp[0].minor.yy444 = 0; } +{ yymsp[0].minor.yy789 = SHOW_KIND_DATABASES_SYSTEM; } #line 7040 "sql.c" break; - case 348: /* with_meta ::= WITH META AS */ -#line 615 "sql.y" -{ yymsp[-2].minor.yy444 = 1; } + case 332: /* cmd ::= CREATE SMA INDEX not_exists_opt col_name ON full_table_name index_options */ +#line 584 "sql.y" +{ pCxt->pRootNode = createCreateIndexStmt(pCxt, INDEX_TYPE_SMA, yymsp[-4].minor.yy887, yymsp[-3].minor.yy812, yymsp[-1].minor.yy812, NULL, yymsp[0].minor.yy812); } #line 7045 "sql.c" break; - case 349: /* with_meta ::= ONLY META AS */ -#line 616 "sql.y" -{ yymsp[-2].minor.yy444 = 2; } + case 333: /* cmd ::= CREATE INDEX not_exists_opt col_name ON full_table_name NK_LP col_name_list NK_RP */ +#line 586 "sql.y" +{ pCxt->pRootNode = createCreateIndexStmt(pCxt, INDEX_TYPE_NORMAL, yymsp[-6].minor.yy887, yymsp[-5].minor.yy812, yymsp[-3].minor.yy812, yymsp[-1].minor.yy124, NULL); } #line 7050 "sql.c" break; - case 350: /* cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery */ -#line 618 "sql.y" -{ pCxt->pRootNode = createCreateTopicStmtUseQuery(pCxt, yymsp[-3].minor.yy985, &yymsp[-2].minor.yy305, yymsp[0].minor.yy1000); } + case 334: /* cmd ::= DROP INDEX exists_opt full_index_name */ +#line 587 "sql.y" +{ pCxt->pRootNode = createDropIndexStmt(pCxt, yymsp[-1].minor.yy887, yymsp[0].minor.yy812); } #line 7055 "sql.c" break; - case 351: /* cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name */ -#line 620 "sql.y" -{ pCxt->pRootNode = createCreateTopicStmtUseDb(pCxt, yymsp[-4].minor.yy985, &yymsp[-3].minor.yy305, &yymsp[0].minor.yy305, yymsp[-2].minor.yy444); } + case 335: /* full_index_name ::= index_name */ +#line 589 "sql.y" +{ yylhsminor.yy812 = createRealTableNodeForIndexName(pCxt, NULL, &yymsp[0].minor.yy29); } #line 7060 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 352: /* cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt */ -#line 622 "sql.y" -{ pCxt->pRootNode = createCreateTopicStmtUseTable(pCxt, yymsp[-5].minor.yy985, &yymsp[-4].minor.yy305, yymsp[-1].minor.yy1000, yymsp[-3].minor.yy444, yymsp[0].minor.yy1000); } -#line 7065 "sql.c" + case 336: /* full_index_name ::= db_name NK_DOT index_name */ +#line 590 "sql.y" +{ yylhsminor.yy812 = createRealTableNodeForIndexName(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy29); } +#line 7066 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 353: /* cmd ::= DROP TOPIC exists_opt topic_name */ -#line 624 "sql.y" -{ pCxt->pRootNode = createDropTopicStmt(pCxt, yymsp[-1].minor.yy985, &yymsp[0].minor.yy305); } -#line 7070 "sql.c" + case 337: /* index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_RP sliding_opt sma_stream_opt */ +#line 593 "sql.y" +{ yymsp[-9].minor.yy812 = createIndexOption(pCxt, yymsp[-7].minor.yy124, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), NULL, yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 7072 "sql.c" break; - case 354: /* cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name */ -#line 625 "sql.y" -{ pCxt->pRootNode = createDropCGroupStmt(pCxt, yymsp[-3].minor.yy985, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy305); } -#line 7075 "sql.c" + case 338: /* index_options ::= FUNCTION NK_LP func_list NK_RP INTERVAL NK_LP duration_literal NK_COMMA duration_literal NK_RP sliding_opt sma_stream_opt */ +#line 596 "sql.y" +{ yymsp[-11].minor.yy812 = createIndexOption(pCxt, yymsp[-9].minor.yy124, releaseRawExprNode(pCxt, yymsp[-5].minor.yy812), releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 7077 "sql.c" break; - case 355: /* cmd ::= DESC full_table_name */ - case 356: /* cmd ::= DESCRIBE full_table_name */ yytestcase(yyruleno==356); -#line 628 "sql.y" -{ pCxt->pRootNode = createDescribeStmt(pCxt, yymsp[0].minor.yy1000); } -#line 7081 "sql.c" + case 341: /* func ::= sma_func_name NK_LP expression_list NK_RP */ +#line 603 "sql.y" +{ yylhsminor.yy812 = createFunctionNode(pCxt, &yymsp[-3].minor.yy29, yymsp[-1].minor.yy124); } +#line 7082 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 357: /* cmd ::= RESET QUERY CACHE */ -#line 632 "sql.y" -{ pCxt->pRootNode = createResetQueryCacheStmt(pCxt); } -#line 7086 "sql.c" + case 342: /* sma_func_name ::= function_name */ + case 613: /* alias_opt ::= table_alias */ yytestcase(yyruleno==613); +#line 607 "sql.y" +{ yylhsminor.yy29 = yymsp[0].minor.yy29; } +#line 7089 "sql.c" + yymsp[0].minor.yy29 = yylhsminor.yy29; break; - case 358: /* cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery */ - case 359: /* cmd ::= EXPLAIN analyze_opt explain_options insert_query */ yytestcase(yyruleno==359); -#line 635 "sql.y" -{ pCxt->pRootNode = createExplainStmt(pCxt, yymsp[-2].minor.yy985, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 7092 "sql.c" + case 347: /* sma_stream_opt ::= */ + case 396: /* stream_options ::= */ yytestcase(yyruleno==396); +#line 613 "sql.y" +{ yymsp[1].minor.yy812 = createStreamOptions(pCxt); } +#line 7096 "sql.c" break; - case 362: /* explain_options ::= */ -#line 643 "sql.y" -{ yymsp[1].minor.yy1000 = createDefaultExplainOptions(pCxt); } -#line 7097 "sql.c" + case 348: /* sma_stream_opt ::= sma_stream_opt WATERMARK duration_literal */ +#line 614 "sql.y" +{ ((SStreamOptions*)yymsp[-2].minor.yy812)->pWatermark = releaseRawExprNode(pCxt, yymsp[0].minor.yy812); yylhsminor.yy812 = yymsp[-2].minor.yy812; } +#line 7101 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 363: /* explain_options ::= explain_options VERBOSE NK_BOOL */ -#line 644 "sql.y" -{ yylhsminor.yy1000 = setExplainVerbose(pCxt, yymsp[-2].minor.yy1000, &yymsp[0].minor.yy0); } -#line 7102 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 349: /* sma_stream_opt ::= sma_stream_opt MAX_DELAY duration_literal */ +#line 615 "sql.y" +{ ((SStreamOptions*)yymsp[-2].minor.yy812)->pDelay = releaseRawExprNode(pCxt, yymsp[0].minor.yy812); yylhsminor.yy812 = yymsp[-2].minor.yy812; } +#line 7107 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 364: /* explain_options ::= explain_options RATIO NK_FLOAT */ -#line 645 "sql.y" -{ yylhsminor.yy1000 = setExplainRatio(pCxt, yymsp[-2].minor.yy1000, &yymsp[0].minor.yy0); } -#line 7108 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 350: /* sma_stream_opt ::= sma_stream_opt DELETE_MARK duration_literal */ +#line 616 "sql.y" +{ ((SStreamOptions*)yymsp[-2].minor.yy812)->pDeleteMark = releaseRawExprNode(pCxt, yymsp[0].minor.yy812); yylhsminor.yy812 = yymsp[-2].minor.yy812; } +#line 7113 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 365: /* cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt */ -#line 650 "sql.y" -{ pCxt->pRootNode = createCreateFunctionStmt(pCxt, yymsp[-7].minor.yy985, yymsp[-9].minor.yy985, &yymsp[-6].minor.yy305, &yymsp[-4].minor.yy0, yymsp[-2].minor.yy56, yymsp[-1].minor.yy444, &yymsp[0].minor.yy305, yymsp[-10].minor.yy985); } -#line 7114 "sql.c" - break; - case 366: /* cmd ::= DROP FUNCTION exists_opt function_name */ -#line 651 "sql.y" -{ pCxt->pRootNode = createDropFunctionStmt(pCxt, yymsp[-1].minor.yy985, &yymsp[0].minor.yy305); } + case 351: /* with_meta ::= AS */ +#line 621 "sql.y" +{ yymsp[0].minor.yy760 = 0; } #line 7119 "sql.c" break; - case 371: /* language_opt ::= */ - case 414: /* on_vgroup_id ::= */ yytestcase(yyruleno==414); -#line 665 "sql.y" -{ yymsp[1].minor.yy305 = nil_token; } -#line 7125 "sql.c" + case 352: /* with_meta ::= WITH META AS */ +#line 622 "sql.y" +{ yymsp[-2].minor.yy760 = 1; } +#line 7124 "sql.c" break; - case 372: /* language_opt ::= LANGUAGE NK_STRING */ - case 415: /* on_vgroup_id ::= ON NK_INTEGER */ yytestcase(yyruleno==415); -#line 666 "sql.y" -{ yymsp[-1].minor.yy305 = yymsp[0].minor.yy0; } -#line 7131 "sql.c" + case 353: /* with_meta ::= ONLY META AS */ +#line 623 "sql.y" +{ yymsp[-2].minor.yy760 = 2; } +#line 7129 "sql.c" break; - case 375: /* cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery */ -#line 675 "sql.y" -{ pCxt->pRootNode = createCreateViewStmt(pCxt, yymsp[-4].minor.yy985, yymsp[-2].minor.yy1000, &yymsp[-1].minor.yy0, yymsp[0].minor.yy1000); } -#line 7136 "sql.c" + case 354: /* cmd ::= CREATE TOPIC not_exists_opt topic_name AS query_or_subquery */ +#line 625 "sql.y" +{ pCxt->pRootNode = createCreateTopicStmtUseQuery(pCxt, yymsp[-3].minor.yy887, &yymsp[-2].minor.yy29, yymsp[0].minor.yy812); } +#line 7134 "sql.c" break; - case 376: /* cmd ::= DROP VIEW exists_opt full_view_name */ -#line 676 "sql.y" -{ pCxt->pRootNode = createDropViewStmt(pCxt, yymsp[-1].minor.yy985, yymsp[0].minor.yy1000); } -#line 7141 "sql.c" + case 355: /* cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta DATABASE db_name */ +#line 627 "sql.y" +{ pCxt->pRootNode = createCreateTopicStmtUseDb(pCxt, yymsp[-4].minor.yy887, &yymsp[-3].minor.yy29, &yymsp[0].minor.yy29, yymsp[-2].minor.yy760); } +#line 7139 "sql.c" break; - case 377: /* full_view_name ::= view_name */ -#line 678 "sql.y" -{ yylhsminor.yy1000 = createViewNode(pCxt, NULL, &yymsp[0].minor.yy305); } -#line 7146 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 356: /* cmd ::= CREATE TOPIC not_exists_opt topic_name with_meta STABLE full_table_name where_clause_opt */ +#line 629 "sql.y" +{ pCxt->pRootNode = createCreateTopicStmtUseTable(pCxt, yymsp[-5].minor.yy887, &yymsp[-4].minor.yy29, yymsp[-1].minor.yy812, yymsp[-3].minor.yy760, yymsp[0].minor.yy812); } +#line 7144 "sql.c" break; - case 378: /* full_view_name ::= db_name NK_DOT view_name */ -#line 679 "sql.y" -{ yylhsminor.yy1000 = createViewNode(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy305); } -#line 7152 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 357: /* cmd ::= DROP TOPIC exists_opt topic_name */ +#line 631 "sql.y" +{ pCxt->pRootNode = createDropTopicStmt(pCxt, yymsp[-1].minor.yy887, &yymsp[0].minor.yy29); } +#line 7149 "sql.c" break; - case 379: /* cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery */ -#line 684 "sql.y" -{ pCxt->pRootNode = createCreateStreamStmt(pCxt, yymsp[-9].minor.yy985, &yymsp[-8].minor.yy305, yymsp[-5].minor.yy1000, yymsp[-7].minor.yy1000, yymsp[-3].minor.yy72, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000, yymsp[-4].minor.yy72); } -#line 7158 "sql.c" + case 358: /* cmd ::= DROP CONSUMER GROUP exists_opt cgroup_name ON topic_name */ +#line 632 "sql.y" +{ pCxt->pRootNode = createDropCGroupStmt(pCxt, yymsp[-3].minor.yy887, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy29); } +#line 7154 "sql.c" break; - case 380: /* cmd ::= DROP STREAM exists_opt stream_name */ -#line 685 "sql.y" -{ pCxt->pRootNode = createDropStreamStmt(pCxt, yymsp[-1].minor.yy985, &yymsp[0].minor.yy305); } -#line 7163 "sql.c" + case 359: /* cmd ::= DESC full_table_name */ + case 360: /* cmd ::= DESCRIBE full_table_name */ yytestcase(yyruleno==360); +#line 635 "sql.y" +{ pCxt->pRootNode = createDescribeStmt(pCxt, yymsp[0].minor.yy812); } +#line 7160 "sql.c" break; - case 381: /* cmd ::= PAUSE STREAM exists_opt stream_name */ -#line 686 "sql.y" -{ pCxt->pRootNode = createPauseStreamStmt(pCxt, yymsp[-1].minor.yy985, &yymsp[0].minor.yy305); } -#line 7168 "sql.c" + case 361: /* cmd ::= RESET QUERY CACHE */ +#line 639 "sql.y" +{ pCxt->pRootNode = createResetQueryCacheStmt(pCxt); } +#line 7165 "sql.c" break; - case 382: /* cmd ::= RESUME STREAM exists_opt ignore_opt stream_name */ -#line 687 "sql.y" -{ pCxt->pRootNode = createResumeStreamStmt(pCxt, yymsp[-2].minor.yy985, yymsp[-1].minor.yy985, &yymsp[0].minor.yy305); } -#line 7173 "sql.c" + case 362: /* cmd ::= EXPLAIN analyze_opt explain_options query_or_subquery */ + case 363: /* cmd ::= EXPLAIN analyze_opt explain_options insert_query */ yytestcase(yyruleno==363); +#line 642 "sql.y" +{ pCxt->pRootNode = createExplainStmt(pCxt, yymsp[-2].minor.yy887, yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 7171 "sql.c" break; - case 387: /* column_stream_def ::= column_name */ -#line 700 "sql.y" -{ yylhsminor.yy1000 = createColumnDefNode(pCxt, &yymsp[0].minor.yy305, createDataType(TSDB_DATA_TYPE_NULL), NULL, false); } -#line 7178 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 366: /* explain_options ::= */ +#line 650 "sql.y" +{ yymsp[1].minor.yy812 = createDefaultExplainOptions(pCxt); } +#line 7176 "sql.c" break; - case 388: /* column_stream_def ::= column_name PRIMARY KEY */ -#line 701 "sql.y" -{ yylhsminor.yy1000 = createColumnDefNode(pCxt, &yymsp[-2].minor.yy305, createDataType(TSDB_DATA_TYPE_NULL), NULL, true); } -#line 7184 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 367: /* explain_options ::= explain_options VERBOSE NK_BOOL */ +#line 651 "sql.y" +{ yylhsminor.yy812 = setExplainVerbose(pCxt, yymsp[-2].minor.yy812, &yymsp[0].minor.yy0); } +#line 7181 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 393: /* stream_options ::= stream_options TRIGGER AT_ONCE */ - case 394: /* stream_options ::= stream_options TRIGGER WINDOW_CLOSE */ yytestcase(yyruleno==394); -#line 711 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-2].minor.yy1000, SOPT_TRIGGER_TYPE_SET, &yymsp[0].minor.yy0, NULL); } -#line 7191 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 368: /* explain_options ::= explain_options RATIO NK_FLOAT */ +#line 652 "sql.y" +{ yylhsminor.yy812 = setExplainRatio(pCxt, yymsp[-2].minor.yy812, &yymsp[0].minor.yy0); } +#line 7187 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 395: /* stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal */ -#line 713 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-3].minor.yy1000, SOPT_TRIGGER_TYPE_SET, &yymsp[-1].minor.yy0, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); } -#line 7197 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 369: /* cmd ::= CREATE or_replace_opt agg_func_opt FUNCTION not_exists_opt function_name AS NK_STRING OUTPUTTYPE type_name bufsize_opt language_opt */ +#line 657 "sql.y" +{ pCxt->pRootNode = createCreateFunctionStmt(pCxt, yymsp[-7].minor.yy887, yymsp[-9].minor.yy887, &yymsp[-6].minor.yy29, &yymsp[-4].minor.yy0, yymsp[-2].minor.yy784, yymsp[-1].minor.yy760, &yymsp[0].minor.yy29, yymsp[-10].minor.yy887); } +#line 7193 "sql.c" break; - case 396: /* stream_options ::= stream_options WATERMARK duration_literal */ -#line 714 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-2].minor.yy1000, SOPT_WATERMARK_SET, NULL, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); } -#line 7203 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 370: /* cmd ::= DROP FUNCTION exists_opt function_name */ +#line 658 "sql.y" +{ pCxt->pRootNode = createDropFunctionStmt(pCxt, yymsp[-1].minor.yy887, &yymsp[0].minor.yy29); } +#line 7198 "sql.c" break; - case 397: /* stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER */ -#line 715 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-3].minor.yy1000, SOPT_IGNORE_EXPIRED_SET, &yymsp[0].minor.yy0, NULL); } -#line 7209 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 375: /* language_opt ::= */ + case 418: /* on_vgroup_id ::= */ yytestcase(yyruleno==418); +#line 672 "sql.y" +{ yymsp[1].minor.yy29 = nil_token; } +#line 7204 "sql.c" break; - case 398: /* stream_options ::= stream_options FILL_HISTORY NK_INTEGER */ -#line 716 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-2].minor.yy1000, SOPT_FILL_HISTORY_SET, &yymsp[0].minor.yy0, NULL); } + case 376: /* language_opt ::= LANGUAGE NK_STRING */ + case 419: /* on_vgroup_id ::= ON NK_INTEGER */ yytestcase(yyruleno==419); +#line 673 "sql.y" +{ yymsp[-1].minor.yy29 = yymsp[0].minor.yy0; } +#line 7210 "sql.c" + break; + case 379: /* cmd ::= CREATE or_replace_opt VIEW full_view_name AS query_or_subquery */ +#line 682 "sql.y" +{ pCxt->pRootNode = createCreateViewStmt(pCxt, yymsp[-4].minor.yy887, yymsp[-2].minor.yy812, &yymsp[-1].minor.yy0, yymsp[0].minor.yy812); } #line 7215 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; break; - case 399: /* stream_options ::= stream_options DELETE_MARK duration_literal */ -#line 717 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-2].minor.yy1000, SOPT_DELETE_MARK_SET, NULL, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); } -#line 7221 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 380: /* cmd ::= DROP VIEW exists_opt full_view_name */ +#line 683 "sql.y" +{ pCxt->pRootNode = createDropViewStmt(pCxt, yymsp[-1].minor.yy887, yymsp[0].minor.yy812); } +#line 7220 "sql.c" break; - case 400: /* stream_options ::= stream_options IGNORE UPDATE NK_INTEGER */ + case 381: /* full_view_name ::= view_name */ +#line 685 "sql.y" +{ yylhsminor.yy812 = createViewNode(pCxt, NULL, &yymsp[0].minor.yy29); } +#line 7225 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 382: /* full_view_name ::= db_name NK_DOT view_name */ +#line 686 "sql.y" +{ yylhsminor.yy812 = createViewNode(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy29); } +#line 7231 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 383: /* cmd ::= CREATE STREAM not_exists_opt stream_name stream_options INTO full_table_name col_list_opt tag_def_or_ref_opt subtable_opt AS query_or_subquery */ +#line 691 "sql.y" +{ pCxt->pRootNode = createCreateStreamStmt(pCxt, yymsp[-9].minor.yy887, &yymsp[-8].minor.yy29, yymsp[-5].minor.yy812, yymsp[-7].minor.yy812, yymsp[-3].minor.yy124, yymsp[-2].minor.yy812, yymsp[0].minor.yy812, yymsp[-4].minor.yy124); } +#line 7237 "sql.c" + break; + case 384: /* cmd ::= DROP STREAM exists_opt stream_name */ +#line 692 "sql.y" +{ pCxt->pRootNode = createDropStreamStmt(pCxt, yymsp[-1].minor.yy887, &yymsp[0].minor.yy29); } +#line 7242 "sql.c" + break; + case 385: /* cmd ::= PAUSE STREAM exists_opt stream_name */ +#line 693 "sql.y" +{ pCxt->pRootNode = createPauseStreamStmt(pCxt, yymsp[-1].minor.yy887, &yymsp[0].minor.yy29); } +#line 7247 "sql.c" + break; + case 386: /* cmd ::= RESUME STREAM exists_opt ignore_opt stream_name */ +#line 694 "sql.y" +{ pCxt->pRootNode = createResumeStreamStmt(pCxt, yymsp[-2].minor.yy887, yymsp[-1].minor.yy887, &yymsp[0].minor.yy29); } +#line 7252 "sql.c" + break; + case 391: /* column_stream_def ::= column_name */ +#line 707 "sql.y" +{ yylhsminor.yy812 = createColumnDefNode(pCxt, &yymsp[0].minor.yy29, createDataType(TSDB_DATA_TYPE_NULL), NULL, false); } +#line 7257 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 392: /* column_stream_def ::= column_name PRIMARY KEY */ +#line 708 "sql.y" +{ yylhsminor.yy812 = createColumnDefNode(pCxt, &yymsp[-2].minor.yy29, createDataType(TSDB_DATA_TYPE_NULL), NULL, true); } +#line 7263 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 397: /* stream_options ::= stream_options TRIGGER AT_ONCE */ + case 398: /* stream_options ::= stream_options TRIGGER WINDOW_CLOSE */ yytestcase(yyruleno==398); #line 718 "sql.y" -{ yylhsminor.yy1000 = setStreamOptions(pCxt, yymsp[-3].minor.yy1000, SOPT_IGNORE_UPDATE_SET, &yymsp[0].minor.yy0, NULL); } -#line 7227 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; - break; - case 402: /* subtable_opt ::= SUBTABLE NK_LP expression NK_RP */ - case 648: /* sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP */ yytestcase(yyruleno==648); - case 672: /* every_opt ::= EVERY NK_LP duration_literal NK_RP */ yytestcase(yyruleno==672); -#line 721 "sql.y" -{ yymsp[-3].minor.yy1000 = releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000); } -#line 7235 "sql.c" - break; - case 405: /* cmd ::= KILL CONNECTION NK_INTEGER */ -#line 729 "sql.y" -{ pCxt->pRootNode = createKillStmt(pCxt, QUERY_NODE_KILL_CONNECTION_STMT, &yymsp[0].minor.yy0); } -#line 7240 "sql.c" - break; - case 406: /* cmd ::= KILL QUERY NK_STRING */ -#line 730 "sql.y" -{ pCxt->pRootNode = createKillQueryStmt(pCxt, &yymsp[0].minor.yy0); } -#line 7245 "sql.c" - break; - case 407: /* cmd ::= KILL TRANSACTION NK_INTEGER */ -#line 731 "sql.y" -{ pCxt->pRootNode = createKillStmt(pCxt, QUERY_NODE_KILL_TRANSACTION_STMT, &yymsp[0].minor.yy0); } -#line 7250 "sql.c" - break; - case 408: /* cmd ::= KILL COMPACT NK_INTEGER */ -#line 732 "sql.y" -{ pCxt->pRootNode = createKillStmt(pCxt, QUERY_NODE_KILL_COMPACT_STMT, &yymsp[0].minor.yy0); } -#line 7255 "sql.c" - break; - case 409: /* cmd ::= BALANCE VGROUP */ -#line 735 "sql.y" -{ pCxt->pRootNode = createBalanceVgroupStmt(pCxt); } -#line 7260 "sql.c" - break; - case 410: /* cmd ::= BALANCE VGROUP LEADER on_vgroup_id */ -#line 736 "sql.y" -{ pCxt->pRootNode = createBalanceVgroupLeaderStmt(pCxt, &yymsp[0].minor.yy305); } -#line 7265 "sql.c" - break; - case 411: /* cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER */ -#line 737 "sql.y" -{ pCxt->pRootNode = createMergeVgroupStmt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-2].minor.yy812, SOPT_TRIGGER_TYPE_SET, &yymsp[0].minor.yy0, NULL); } #line 7270 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 412: /* cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list */ -#line 738 "sql.y" -{ pCxt->pRootNode = createRedistributeVgroupStmt(pCxt, &yymsp[-1].minor.yy0, yymsp[0].minor.yy72); } -#line 7275 "sql.c" + case 399: /* stream_options ::= stream_options TRIGGER MAX_DELAY duration_literal */ +#line 720 "sql.y" +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-3].minor.yy812, SOPT_TRIGGER_TYPE_SET, &yymsp[-1].minor.yy0, releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } +#line 7276 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 413: /* cmd ::= SPLIT VGROUP NK_INTEGER */ -#line 739 "sql.y" -{ pCxt->pRootNode = createSplitVgroupStmt(pCxt, &yymsp[0].minor.yy0); } -#line 7280 "sql.c" + case 400: /* stream_options ::= stream_options WATERMARK duration_literal */ +#line 721 "sql.y" +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-2].minor.yy812, SOPT_WATERMARK_SET, NULL, releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } +#line 7282 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 416: /* dnode_list ::= DNODE NK_INTEGER */ -#line 748 "sql.y" -{ yymsp[-1].minor.yy72 = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } -#line 7285 "sql.c" + case 401: /* stream_options ::= stream_options IGNORE EXPIRED NK_INTEGER */ +#line 722 "sql.y" +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-3].minor.yy812, SOPT_IGNORE_EXPIRED_SET, &yymsp[0].minor.yy0, NULL); } +#line 7288 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 418: /* cmd ::= DELETE FROM full_table_name where_clause_opt */ -#line 755 "sql.y" -{ pCxt->pRootNode = createDeleteStmt(pCxt, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 7290 "sql.c" + case 402: /* stream_options ::= stream_options FILL_HISTORY NK_INTEGER */ +#line 723 "sql.y" +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-2].minor.yy812, SOPT_FILL_HISTORY_SET, &yymsp[0].minor.yy0, NULL); } +#line 7294 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 421: /* insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery */ -#line 764 "sql.y" -{ yymsp[-6].minor.yy1000 = createInsertStmt(pCxt, yymsp[-4].minor.yy1000, yymsp[-2].minor.yy72, yymsp[0].minor.yy1000); } -#line 7295 "sql.c" - break; - case 422: /* insert_query ::= INSERT INTO full_table_name query_or_subquery */ -#line 765 "sql.y" -{ yymsp[-3].minor.yy1000 = createInsertStmt(pCxt, yymsp[-1].minor.yy1000, NULL, yymsp[0].minor.yy1000); } + case 403: /* stream_options ::= stream_options DELETE_MARK duration_literal */ +#line 724 "sql.y" +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-2].minor.yy812, SOPT_DELETE_MARK_SET, NULL, releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } #line 7300 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 423: /* tags_literal ::= NK_INTEGER */ - case 435: /* tags_literal ::= NK_BIN */ yytestcase(yyruleno==435); - case 444: /* tags_literal ::= NK_HEX */ yytestcase(yyruleno==444); -#line 768 "sql.y" -{ yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0, NULL); } -#line 7307 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 404: /* stream_options ::= stream_options IGNORE UPDATE NK_INTEGER */ +#line 725 "sql.y" +{ yylhsminor.yy812 = setStreamOptions(pCxt, yymsp[-3].minor.yy812, SOPT_IGNORE_UPDATE_SET, &yymsp[0].minor.yy0, NULL); } +#line 7306 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 424: /* tags_literal ::= NK_INTEGER NK_PLUS duration_literal */ - case 425: /* tags_literal ::= NK_INTEGER NK_MINUS duration_literal */ yytestcase(yyruleno==425); - case 436: /* tags_literal ::= NK_BIN NK_PLUS duration_literal */ yytestcase(yyruleno==436); - case 437: /* tags_literal ::= NK_BIN NK_MINUS duration_literal */ yytestcase(yyruleno==437); - case 445: /* tags_literal ::= NK_HEX NK_PLUS duration_literal */ yytestcase(yyruleno==445); - case 446: /* tags_literal ::= NK_HEX NK_MINUS duration_literal */ yytestcase(yyruleno==446); - case 454: /* tags_literal ::= NK_STRING NK_PLUS duration_literal */ yytestcase(yyruleno==454); - case 455: /* tags_literal ::= NK_STRING NK_MINUS duration_literal */ yytestcase(yyruleno==455); -#line 769 "sql.y" + case 406: /* subtable_opt ::= SUBTABLE NK_LP expression NK_RP */ + case 653: /* sliding_opt ::= SLIDING NK_LP interval_sliding_duration_literal NK_RP */ yytestcase(yyruleno==653); + case 677: /* every_opt ::= EVERY NK_LP duration_literal NK_RP */ yytestcase(yyruleno==677); +#line 728 "sql.y" +{ yymsp[-3].minor.yy812 = releaseRawExprNode(pCxt, yymsp[-1].minor.yy812); } +#line 7314 "sql.c" + break; + case 409: /* cmd ::= KILL CONNECTION NK_INTEGER */ +#line 736 "sql.y" +{ pCxt->pRootNode = createKillStmt(pCxt, QUERY_NODE_KILL_CONNECTION_STMT, &yymsp[0].minor.yy0); } +#line 7319 "sql.c" + break; + case 410: /* cmd ::= KILL QUERY NK_STRING */ +#line 737 "sql.y" +{ pCxt->pRootNode = createKillQueryStmt(pCxt, &yymsp[0].minor.yy0); } +#line 7324 "sql.c" + break; + case 411: /* cmd ::= KILL TRANSACTION NK_INTEGER */ +#line 738 "sql.y" +{ pCxt->pRootNode = createKillStmt(pCxt, QUERY_NODE_KILL_TRANSACTION_STMT, &yymsp[0].minor.yy0); } +#line 7329 "sql.c" + break; + case 412: /* cmd ::= KILL COMPACT NK_INTEGER */ +#line 739 "sql.y" +{ pCxt->pRootNode = createKillStmt(pCxt, QUERY_NODE_KILL_COMPACT_STMT, &yymsp[0].minor.yy0); } +#line 7334 "sql.c" + break; + case 413: /* cmd ::= BALANCE VGROUP */ +#line 742 "sql.y" +{ pCxt->pRootNode = createBalanceVgroupStmt(pCxt); } +#line 7339 "sql.c" + break; + case 414: /* cmd ::= BALANCE VGROUP LEADER on_vgroup_id */ +#line 743 "sql.y" +{ pCxt->pRootNode = createBalanceVgroupLeaderStmt(pCxt, &yymsp[0].minor.yy29); } +#line 7344 "sql.c" + break; + case 415: /* cmd ::= MERGE VGROUP NK_INTEGER NK_INTEGER */ +#line 744 "sql.y" +{ pCxt->pRootNode = createMergeVgroupStmt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } +#line 7349 "sql.c" + break; + case 416: /* cmd ::= REDISTRIBUTE VGROUP NK_INTEGER dnode_list */ +#line 745 "sql.y" +{ pCxt->pRootNode = createRedistributeVgroupStmt(pCxt, &yymsp[-1].minor.yy0, yymsp[0].minor.yy124); } +#line 7354 "sql.c" + break; + case 417: /* cmd ::= SPLIT VGROUP NK_INTEGER */ +#line 746 "sql.y" +{ pCxt->pRootNode = createSplitVgroupStmt(pCxt, &yymsp[0].minor.yy0); } +#line 7359 "sql.c" + break; + case 420: /* dnode_list ::= DNODE NK_INTEGER */ +#line 755 "sql.y" +{ yymsp[-1].minor.yy124 = createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &yymsp[0].minor.yy0)); } +#line 7364 "sql.c" + break; + case 422: /* cmd ::= DELETE FROM full_table_name where_clause_opt */ +#line 762 "sql.y" +{ pCxt->pRootNode = createDeleteStmt(pCxt, yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 7369 "sql.c" + break; + case 425: /* insert_query ::= INSERT INTO full_table_name NK_LP col_name_list NK_RP query_or_subquery */ +#line 771 "sql.y" +{ yymsp[-6].minor.yy812 = createInsertStmt(pCxt, yymsp[-4].minor.yy812, yymsp[-2].minor.yy124, yymsp[0].minor.yy812); } +#line 7374 "sql.c" + break; + case 426: /* insert_query ::= INSERT INTO full_table_name query_or_subquery */ +#line 772 "sql.y" +{ yymsp[-3].minor.yy812 = createInsertStmt(pCxt, yymsp[-1].minor.yy812, NULL, yymsp[0].minor.yy812); } +#line 7379 "sql.c" + break; + case 427: /* tags_literal ::= NK_INTEGER */ + case 439: /* tags_literal ::= NK_BIN */ yytestcase(yyruleno==439); + case 448: /* tags_literal ::= NK_HEX */ yytestcase(yyruleno==448); +#line 775 "sql.y" +{ yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0, NULL); } +#line 7386 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 428: /* tags_literal ::= NK_INTEGER NK_PLUS duration_literal */ + case 429: /* tags_literal ::= NK_INTEGER NK_MINUS duration_literal */ yytestcase(yyruleno==429); + case 440: /* tags_literal ::= NK_BIN NK_PLUS duration_literal */ yytestcase(yyruleno==440); + case 441: /* tags_literal ::= NK_BIN NK_MINUS duration_literal */ yytestcase(yyruleno==441); + case 449: /* tags_literal ::= NK_HEX NK_PLUS duration_literal */ yytestcase(yyruleno==449); + case 450: /* tags_literal ::= NK_HEX NK_MINUS duration_literal */ yytestcase(yyruleno==450); + case 458: /* tags_literal ::= NK_STRING NK_PLUS duration_literal */ yytestcase(yyruleno==458); + case 459: /* tags_literal ::= NK_STRING NK_MINUS duration_literal */ yytestcase(yyruleno==459); +#line 776 "sql.y" { SToken l = yymsp[-2].minor.yy0; - SToken r = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); + SToken r = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); l.n = (r.z + r.n) - l.z; - yylhsminor.yy1000 = createRawValueNodeExt(pCxt, TSDB_DATA_TYPE_BINARY, &l, NULL, yymsp[0].minor.yy1000); + yylhsminor.yy812 = createRawValueNodeExt(pCxt, TSDB_DATA_TYPE_BINARY, &l, NULL, yymsp[0].minor.yy812); } -#line 7325 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +#line 7404 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 426: /* tags_literal ::= NK_PLUS NK_INTEGER */ - case 429: /* tags_literal ::= NK_MINUS NK_INTEGER */ yytestcase(yyruleno==429); - case 438: /* tags_literal ::= NK_PLUS NK_BIN */ yytestcase(yyruleno==438); - case 441: /* tags_literal ::= NK_MINUS NK_BIN */ yytestcase(yyruleno==441); - case 447: /* tags_literal ::= NK_PLUS NK_HEX */ yytestcase(yyruleno==447); - case 450: /* tags_literal ::= NK_MINUS NK_HEX */ yytestcase(yyruleno==450); -#line 781 "sql.y" + case 430: /* tags_literal ::= NK_PLUS NK_INTEGER */ + case 433: /* tags_literal ::= NK_MINUS NK_INTEGER */ yytestcase(yyruleno==433); + case 442: /* tags_literal ::= NK_PLUS NK_BIN */ yytestcase(yyruleno==442); + case 445: /* tags_literal ::= NK_MINUS NK_BIN */ yytestcase(yyruleno==445); + case 451: /* tags_literal ::= NK_PLUS NK_HEX */ yytestcase(yyruleno==451); + case 454: /* tags_literal ::= NK_MINUS NK_HEX */ yytestcase(yyruleno==454); +#line 788 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &t, NULL); + yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &t, NULL); } -#line 7340 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +#line 7419 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 427: /* tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal */ - case 428: /* tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal */ yytestcase(yyruleno==428); - case 430: /* tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal */ yytestcase(yyruleno==430); - case 431: /* tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal */ yytestcase(yyruleno==431); - case 439: /* tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal */ yytestcase(yyruleno==439); - case 440: /* tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal */ yytestcase(yyruleno==440); - case 442: /* tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal */ yytestcase(yyruleno==442); - case 443: /* tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal */ yytestcase(yyruleno==443); - case 448: /* tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal */ yytestcase(yyruleno==448); - case 449: /* tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal */ yytestcase(yyruleno==449); - case 451: /* tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal */ yytestcase(yyruleno==451); - case 452: /* tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal */ yytestcase(yyruleno==452); -#line 786 "sql.y" + case 431: /* tags_literal ::= NK_PLUS NK_INTEGER NK_PLUS duration_literal */ + case 432: /* tags_literal ::= NK_PLUS NK_INTEGER NK_MINUS duration_literal */ yytestcase(yyruleno==432); + case 434: /* tags_literal ::= NK_MINUS NK_INTEGER NK_PLUS duration_literal */ yytestcase(yyruleno==434); + case 435: /* tags_literal ::= NK_MINUS NK_INTEGER NK_MINUS duration_literal */ yytestcase(yyruleno==435); + case 443: /* tags_literal ::= NK_PLUS NK_BIN NK_PLUS duration_literal */ yytestcase(yyruleno==443); + case 444: /* tags_literal ::= NK_PLUS NK_BIN NK_MINUS duration_literal */ yytestcase(yyruleno==444); + case 446: /* tags_literal ::= NK_MINUS NK_BIN NK_PLUS duration_literal */ yytestcase(yyruleno==446); + case 447: /* tags_literal ::= NK_MINUS NK_BIN NK_MINUS duration_literal */ yytestcase(yyruleno==447); + case 452: /* tags_literal ::= NK_PLUS NK_HEX NK_PLUS duration_literal */ yytestcase(yyruleno==452); + case 453: /* tags_literal ::= NK_PLUS NK_HEX NK_MINUS duration_literal */ yytestcase(yyruleno==453); + case 455: /* tags_literal ::= NK_MINUS NK_HEX NK_PLUS duration_literal */ yytestcase(yyruleno==455); + case 456: /* tags_literal ::= NK_MINUS NK_HEX NK_MINUS duration_literal */ yytestcase(yyruleno==456); +#line 793 "sql.y" { SToken l = yymsp[-3].minor.yy0; - SToken r = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); + SToken r = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); l.n = (r.z + r.n) - l.z; - yylhsminor.yy1000 = createRawValueNodeExt(pCxt, TSDB_DATA_TYPE_BINARY, &l, NULL, yymsp[0].minor.yy1000); + yylhsminor.yy812 = createRawValueNodeExt(pCxt, TSDB_DATA_TYPE_BINARY, &l, NULL, yymsp[0].minor.yy812); } -#line 7362 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; +#line 7441 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 432: /* tags_literal ::= NK_FLOAT */ -#line 815 "sql.y" -{ yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0, NULL); } -#line 7368 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 436: /* tags_literal ::= NK_FLOAT */ +#line 822 "sql.y" +{ yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0, NULL); } +#line 7447 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 433: /* tags_literal ::= NK_PLUS NK_FLOAT */ - case 434: /* tags_literal ::= NK_MINUS NK_FLOAT */ yytestcase(yyruleno==434); -#line 816 "sql.y" + case 437: /* tags_literal ::= NK_PLUS NK_FLOAT */ + case 438: /* tags_literal ::= NK_MINUS NK_FLOAT */ yytestcase(yyruleno==438); +#line 823 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &t, NULL); + yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &t, NULL); } -#line 7379 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +#line 7458 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 453: /* tags_literal ::= NK_STRING */ -#line 922 "sql.y" -{ yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0, NULL); } -#line 7385 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 457: /* tags_literal ::= NK_STRING */ +#line 929 "sql.y" +{ yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0, NULL); } +#line 7464 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 456: /* tags_literal ::= NK_BOOL */ -#line 935 "sql.y" -{ yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_BOOL, &yymsp[0].minor.yy0, NULL); } -#line 7391 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 457: /* tags_literal ::= NULL */ -#line 936 "sql.y" -{ yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_NULL, &yymsp[0].minor.yy0, NULL); } -#line 7397 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 458: /* tags_literal ::= literal_func */ -#line 938 "sql.y" -{ yylhsminor.yy1000 = createRawValueNode(pCxt, TSDB_DATA_TYPE_BINARY, NULL, yymsp[0].minor.yy1000); } -#line 7403 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 459: /* tags_literal ::= literal_func NK_PLUS duration_literal */ - case 460: /* tags_literal ::= literal_func NK_MINUS duration_literal */ yytestcase(yyruleno==460); -#line 939 "sql.y" -{ - SToken l = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken r = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - l.n = (r.z + r.n) - l.z; - yylhsminor.yy1000 = createRawValueNodeExt(pCxt, TSDB_DATA_TYPE_BINARY, &l, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000); - } -#line 7415 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 463: /* literal ::= NK_INTEGER */ -#line 958 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0)); } -#line 7421 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 464: /* literal ::= NK_FLOAT */ -#line 959 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0)); } -#line 7427 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 465: /* literal ::= NK_STRING */ -#line 960 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0)); } -#line 7433 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 466: /* literal ::= NK_BOOL */ -#line 961 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_BOOL, &yymsp[0].minor.yy0)); } -#line 7439 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 467: /* literal ::= TIMESTAMP NK_STRING */ -#line 962 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0)); } -#line 7445 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; - break; - case 468: /* literal ::= duration_literal */ - case 478: /* signed_literal ::= signed */ yytestcase(yyruleno==478); - case 501: /* expr_or_subquery ::= expression */ yytestcase(yyruleno==501); - case 502: /* expression ::= literal */ yytestcase(yyruleno==502); - case 504: /* expression ::= column_reference */ yytestcase(yyruleno==504); - case 505: /* expression ::= function_expression */ yytestcase(yyruleno==505); - case 506: /* expression ::= case_when_expression */ yytestcase(yyruleno==506); - case 539: /* function_expression ::= literal_func */ yytestcase(yyruleno==539); - case 589: /* boolean_value_expression ::= boolean_primary */ yytestcase(yyruleno==589); - case 593: /* boolean_primary ::= predicate */ yytestcase(yyruleno==593); - case 595: /* common_expression ::= expr_or_subquery */ yytestcase(yyruleno==595); - case 596: /* common_expression ::= boolean_value_expression */ yytestcase(yyruleno==596); - case 599: /* table_reference_list ::= table_reference */ yytestcase(yyruleno==599); - case 601: /* table_reference ::= table_primary */ yytestcase(yyruleno==601); - case 602: /* table_reference ::= joined_table */ yytestcase(yyruleno==602); - case 606: /* table_primary ::= parenthesized_joined_table */ yytestcase(yyruleno==606); - case 674: /* query_simple ::= query_specification */ yytestcase(yyruleno==674); - case 675: /* query_simple ::= union_query_expression */ yytestcase(yyruleno==675); - case 678: /* query_simple_or_subquery ::= query_simple */ yytestcase(yyruleno==678); - case 680: /* query_or_subquery ::= query_expression */ yytestcase(yyruleno==680); -#line 963 "sql.y" -{ yylhsminor.yy1000 = yymsp[0].minor.yy1000; } + case 460: /* tags_literal ::= NK_BOOL */ +#line 942 "sql.y" +{ yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_BOOL, &yymsp[0].minor.yy0, NULL); } #line 7470 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 469: /* literal ::= NULL */ -#line 964 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_NULL, &yymsp[0].minor.yy0)); } + case 461: /* tags_literal ::= NULL */ +#line 943 "sql.y" +{ yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_NULL, &yymsp[0].minor.yy0, NULL); } #line 7476 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 470: /* literal ::= NK_QUESTION */ -#line 965 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createPlaceholderValueNode(pCxt, &yymsp[0].minor.yy0)); } + case 462: /* tags_literal ::= literal_func */ +#line 945 "sql.y" +{ yylhsminor.yy812 = createRawValueNode(pCxt, TSDB_DATA_TYPE_BINARY, NULL, yymsp[0].minor.yy812); } #line 7482 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 471: /* duration_literal ::= NK_VARIABLE */ - case 649: /* interval_sliding_duration_literal ::= NK_VARIABLE */ yytestcase(yyruleno==649); - case 650: /* interval_sliding_duration_literal ::= NK_STRING */ yytestcase(yyruleno==650); - case 651: /* interval_sliding_duration_literal ::= NK_INTEGER */ yytestcase(yyruleno==651); -#line 967 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } -#line 7491 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 472: /* signed ::= NK_INTEGER */ -#line 969 "sql.y" -{ yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0); } -#line 7497 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 473: /* signed ::= NK_PLUS NK_INTEGER */ -#line 970 "sql.y" -{ yymsp[-1].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0); } -#line 7503 "sql.c" - break; - case 474: /* signed ::= NK_MINUS NK_INTEGER */ -#line 971 "sql.y" + case 463: /* tags_literal ::= literal_func NK_PLUS duration_literal */ + case 464: /* tags_literal ::= literal_func NK_MINUS duration_literal */ yytestcase(yyruleno==464); +#line 946 "sql.y" { - SToken t = yymsp[-1].minor.yy0; - t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &t); + SToken l = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken r = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + l.n = (r.z + r.n) - l.z; + yylhsminor.yy812 = createRawValueNodeExt(pCxt, TSDB_DATA_TYPE_BINARY, &l, yymsp[-2].minor.yy812, yymsp[0].minor.yy812); } +#line 7494 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 467: /* literal ::= NK_INTEGER */ +#line 965 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0)); } +#line 7500 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 468: /* literal ::= NK_FLOAT */ +#line 966 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0)); } +#line 7506 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 469: /* literal ::= NK_STRING */ +#line 967 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0)); } #line 7512 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 475: /* signed ::= NK_FLOAT */ -#line 976 "sql.y" -{ yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0); } + case 470: /* literal ::= NK_BOOL */ +#line 968 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_BOOL, &yymsp[0].minor.yy0)); } #line 7518 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 476: /* signed ::= NK_PLUS NK_FLOAT */ -#line 977 "sql.y" -{ yymsp[-1].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0); } + case 471: /* literal ::= TIMESTAMP NK_STRING */ +#line 969 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0)); } #line 7524 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 477: /* signed ::= NK_MINUS NK_FLOAT */ + case 472: /* literal ::= duration_literal */ + case 482: /* signed_literal ::= signed */ yytestcase(yyruleno==482); + case 505: /* expr_or_subquery ::= expression */ yytestcase(yyruleno==505); + case 506: /* expression ::= literal */ yytestcase(yyruleno==506); + case 508: /* expression ::= column_reference */ yytestcase(yyruleno==508); + case 509: /* expression ::= function_expression */ yytestcase(yyruleno==509); + case 510: /* expression ::= case_when_expression */ yytestcase(yyruleno==510); + case 544: /* function_expression ::= literal_func */ yytestcase(yyruleno==544); + case 594: /* boolean_value_expression ::= boolean_primary */ yytestcase(yyruleno==594); + case 598: /* boolean_primary ::= predicate */ yytestcase(yyruleno==598); + case 600: /* common_expression ::= expr_or_subquery */ yytestcase(yyruleno==600); + case 601: /* common_expression ::= boolean_value_expression */ yytestcase(yyruleno==601); + case 604: /* table_reference_list ::= table_reference */ yytestcase(yyruleno==604); + case 606: /* table_reference ::= table_primary */ yytestcase(yyruleno==606); + case 607: /* table_reference ::= joined_table */ yytestcase(yyruleno==607); + case 611: /* table_primary ::= parenthesized_joined_table */ yytestcase(yyruleno==611); + case 679: /* query_simple ::= query_specification */ yytestcase(yyruleno==679); + case 680: /* query_simple ::= union_query_expression */ yytestcase(yyruleno==680); + case 683: /* query_simple_or_subquery ::= query_simple */ yytestcase(yyruleno==683); + case 685: /* query_or_subquery ::= query_expression */ yytestcase(yyruleno==685); +#line 970 "sql.y" +{ yylhsminor.yy812 = yymsp[0].minor.yy812; } +#line 7549 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 473: /* literal ::= NULL */ +#line 971 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createValueNode(pCxt, TSDB_DATA_TYPE_NULL, &yymsp[0].minor.yy0)); } +#line 7555 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 474: /* literal ::= NK_QUESTION */ +#line 972 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createPlaceholderValueNode(pCxt, &yymsp[0].minor.yy0)); } +#line 7561 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 475: /* duration_literal ::= NK_VARIABLE */ + case 654: /* interval_sliding_duration_literal ::= NK_VARIABLE */ yytestcase(yyruleno==654); + case 655: /* interval_sliding_duration_literal ::= NK_STRING */ yytestcase(yyruleno==655); + case 656: /* interval_sliding_duration_literal ::= NK_INTEGER */ yytestcase(yyruleno==656); +#line 974 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createDurationValueNode(pCxt, &yymsp[0].minor.yy0)); } +#line 7570 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 476: /* signed ::= NK_INTEGER */ +#line 976 "sql.y" +{ yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0); } +#line 7576 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 477: /* signed ::= NK_PLUS NK_INTEGER */ +#line 977 "sql.y" +{ yymsp[-1].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_UBIGINT, &yymsp[0].minor.yy0); } +#line 7582 "sql.c" + break; + case 478: /* signed ::= NK_MINUS NK_INTEGER */ #line 978 "sql.y" { SToken t = yymsp[-1].minor.yy0; t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; - yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &t); + yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_BIGINT, &t); } -#line 7533 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +#line 7591 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 479: /* signed_literal ::= NK_STRING */ + case 479: /* signed ::= NK_FLOAT */ +#line 983 "sql.y" +{ yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0); } +#line 7597 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 480: /* signed ::= NK_PLUS NK_FLOAT */ +#line 984 "sql.y" +{ yymsp[-1].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &yymsp[0].minor.yy0); } +#line 7603 "sql.c" + break; + case 481: /* signed ::= NK_MINUS NK_FLOAT */ #line 985 "sql.y" -{ yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0); } -#line 7539 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 480: /* signed_literal ::= NK_BOOL */ -#line 986 "sql.y" -{ yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_BOOL, &yymsp[0].minor.yy0); } -#line 7545 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 481: /* signed_literal ::= TIMESTAMP NK_STRING */ -#line 987 "sql.y" -{ yymsp[-1].minor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0); } -#line 7551 "sql.c" - break; - case 482: /* signed_literal ::= duration_literal */ - case 484: /* signed_literal ::= literal_func */ yytestcase(yyruleno==484); - case 560: /* star_func_para ::= expr_or_subquery */ yytestcase(yyruleno==560); - case 626: /* select_item ::= common_expression */ yytestcase(yyruleno==626); - case 636: /* partition_item ::= expr_or_subquery */ yytestcase(yyruleno==636); - case 679: /* query_simple_or_subquery ::= subquery */ yytestcase(yyruleno==679); - case 681: /* query_or_subquery ::= subquery */ yytestcase(yyruleno==681); - case 694: /* search_condition ::= common_expression */ yytestcase(yyruleno==694); -#line 988 "sql.y" -{ yylhsminor.yy1000 = releaseRawExprNode(pCxt, yymsp[0].minor.yy1000); } -#line 7563 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 483: /* signed_literal ::= NULL */ -#line 989 "sql.y" -{ yylhsminor.yy1000 = createValueNode(pCxt, TSDB_DATA_TYPE_NULL, &yymsp[0].minor.yy0); } -#line 7569 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 485: /* signed_literal ::= NK_QUESTION */ -#line 991 "sql.y" -{ yylhsminor.yy1000 = createPlaceholderValueNode(pCxt, &yymsp[0].minor.yy0); } -#line 7575 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 503: /* expression ::= pseudo_column */ -#line 1053 "sql.y" -{ yylhsminor.yy1000 = yymsp[0].minor.yy1000; setRawExprNodeIsPseudoColumn(pCxt, yylhsminor.yy1000, true); } -#line 7581 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; - break; - case 507: /* expression ::= NK_LP expression NK_RP */ - case 594: /* boolean_primary ::= NK_LP boolean_value_expression NK_RP */ yytestcase(yyruleno==594); - case 693: /* subquery ::= NK_LP subquery NK_RP */ yytestcase(yyruleno==693); -#line 1057 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000)); } -#line 7589 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 508: /* expression ::= NK_PLUS expr_or_subquery */ -#line 1058 "sql.y" { - SToken t = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &t, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); + SToken t = yymsp[-1].minor.yy0; + t.n = (yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z; + yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_DOUBLE, &t); } -#line 7598 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +#line 7612 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 509: /* expression ::= NK_MINUS expr_or_subquery */ -#line 1062 "sql.y" + case 483: /* signed_literal ::= NK_STRING */ +#line 992 "sql.y" +{ yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0); } +#line 7618 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 484: /* signed_literal ::= NK_BOOL */ +#line 993 "sql.y" +{ yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_BOOL, &yymsp[0].minor.yy0); } +#line 7624 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 485: /* signed_literal ::= TIMESTAMP NK_STRING */ +#line 994 "sql.y" +{ yymsp[-1].minor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_TIMESTAMP, &yymsp[0].minor.yy0); } +#line 7630 "sql.c" + break; + case 486: /* signed_literal ::= duration_literal */ + case 488: /* signed_literal ::= literal_func */ yytestcase(yyruleno==488); + case 565: /* star_func_para ::= expr_or_subquery */ yytestcase(yyruleno==565); + case 631: /* select_item ::= common_expression */ yytestcase(yyruleno==631); + case 641: /* partition_item ::= expr_or_subquery */ yytestcase(yyruleno==641); + case 684: /* query_simple_or_subquery ::= subquery */ yytestcase(yyruleno==684); + case 686: /* query_or_subquery ::= subquery */ yytestcase(yyruleno==686); + case 699: /* search_condition ::= common_expression */ yytestcase(yyruleno==699); +#line 995 "sql.y" +{ yylhsminor.yy812 = releaseRawExprNode(pCxt, yymsp[0].minor.yy812); } +#line 7642 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 487: /* signed_literal ::= NULL */ +#line 996 "sql.y" +{ yylhsminor.yy812 = createValueNode(pCxt, TSDB_DATA_TYPE_NULL, &yymsp[0].minor.yy0); } +#line 7648 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 489: /* signed_literal ::= NK_QUESTION */ +#line 998 "sql.y" +{ yylhsminor.yy812 = createPlaceholderValueNode(pCxt, &yymsp[0].minor.yy0); } +#line 7654 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 507: /* expression ::= pseudo_column */ +#line 1060 "sql.y" +{ yylhsminor.yy812 = yymsp[0].minor.yy812; setRawExprNodeIsPseudoColumn(pCxt, yylhsminor.yy812, true); } +#line 7660 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; + break; + case 511: /* expression ::= NK_LP expression NK_RP */ + case 599: /* boolean_primary ::= NK_LP boolean_value_expression NK_RP */ yytestcase(yyruleno==599); + case 698: /* subquery ::= NK_LP subquery NK_RP */ yytestcase(yyruleno==698); +#line 1064 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, releaseRawExprNode(pCxt, yymsp[-1].minor.yy812)); } +#line 7668 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 512: /* expression ::= NK_PLUS expr_or_subquery */ +#line 1065 "sql.y" { - SToken t = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &t, createOperatorNode(pCxt, OP_TYPE_MINUS, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000), NULL)); + SToken t = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &t, releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } -#line 7607 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; +#line 7677 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 510: /* expression ::= expr_or_subquery NK_PLUS expr_or_subquery */ -#line 1066 "sql.y" + case 513: /* expression ::= NK_MINUS expr_or_subquery */ +#line 1069 "sql.y" { - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_ADD, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7617 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 511: /* expression ::= expr_or_subquery NK_MINUS expr_or_subquery */ -#line 1071 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_SUB, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7627 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 512: /* expression ::= expr_or_subquery NK_STAR expr_or_subquery */ -#line 1076 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_MULTI, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7637 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 513: /* expression ::= expr_or_subquery NK_SLASH expr_or_subquery */ -#line 1081 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_DIV, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7647 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 514: /* expression ::= expr_or_subquery NK_REM expr_or_subquery */ -#line 1086 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_REM, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7657 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 515: /* expression ::= column_reference NK_ARROW NK_STRING */ -#line 1091 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &yymsp[0].minor.yy0, createOperatorNode(pCxt, OP_TYPE_JSON_GET_VALUE, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0))); - } -#line 7666 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 516: /* expression ::= expr_or_subquery NK_BITAND expr_or_subquery */ -#line 1095 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_BIT_AND, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7676 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 517: /* expression ::= expr_or_subquery NK_BITOR expr_or_subquery */ -#line 1100 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_BIT_OR, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); + SToken t = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &t, createOperatorNode(pCxt, OP_TYPE_MINUS, releaseRawExprNode(pCxt, yymsp[0].minor.yy812), NULL)); } #line 7686 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 520: /* column_reference ::= column_name */ -#line 1111 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy305, createColumnNode(pCxt, NULL, &yymsp[0].minor.yy305)); } -#line 7692 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 514: /* expression ::= expr_or_subquery NK_PLUS expr_or_subquery */ +#line 1073 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_ADD, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7696 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 521: /* column_reference ::= table_name NK_DOT column_name */ -#line 1112 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy305, createColumnNode(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy305)); } -#line 7698 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 515: /* expression ::= expr_or_subquery NK_MINUS expr_or_subquery */ +#line 1078 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_SUB, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7706 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 522: /* column_reference ::= NK_ALIAS */ -#line 1113 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createColumnNode(pCxt, NULL, &yymsp[0].minor.yy0)); } -#line 7704 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 516: /* expression ::= expr_or_subquery NK_STAR expr_or_subquery */ +#line 1083 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_MULTI, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7716 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 523: /* column_reference ::= table_name NK_DOT NK_ALIAS */ -#line 1114 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy0, createColumnNode(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy0)); } -#line 7710 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 517: /* expression ::= expr_or_subquery NK_SLASH expr_or_subquery */ +#line 1088 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_DIV, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7726 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 524: /* pseudo_column ::= ROWTS */ - case 525: /* pseudo_column ::= TBNAME */ yytestcase(yyruleno==525); - case 527: /* pseudo_column ::= QSTART */ yytestcase(yyruleno==527); - case 528: /* pseudo_column ::= QEND */ yytestcase(yyruleno==528); - case 529: /* pseudo_column ::= QDURATION */ yytestcase(yyruleno==529); - case 530: /* pseudo_column ::= WSTART */ yytestcase(yyruleno==530); - case 531: /* pseudo_column ::= WEND */ yytestcase(yyruleno==531); - case 532: /* pseudo_column ::= WDURATION */ yytestcase(yyruleno==532); - case 533: /* pseudo_column ::= IROWTS */ yytestcase(yyruleno==533); - case 534: /* pseudo_column ::= ISFILLED */ yytestcase(yyruleno==534); - case 535: /* pseudo_column ::= QTAGS */ yytestcase(yyruleno==535); - case 541: /* literal_func ::= NOW */ yytestcase(yyruleno==541); - case 542: /* literal_func ::= TODAY */ yytestcase(yyruleno==542); -#line 1116 "sql.y" -{ yylhsminor.yy1000 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[0].minor.yy0, NULL)); } -#line 7728 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 518: /* expression ::= expr_or_subquery NK_REM expr_or_subquery */ +#line 1093 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_REM, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7736 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 526: /* pseudo_column ::= table_name NK_DOT TBNAME */ + case 519: /* expression ::= column_reference NK_ARROW NK_STRING */ +#line 1098 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &yymsp[0].minor.yy0, createOperatorNode(pCxt, OP_TYPE_JSON_GET_VALUE, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[0].minor.yy0))); + } +#line 7745 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 520: /* expression ::= expr_or_subquery NK_BITAND expr_or_subquery */ +#line 1102 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_BIT_AND, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7755 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 521: /* expression ::= expr_or_subquery NK_BITOR expr_or_subquery */ +#line 1107 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, OP_TYPE_BIT_OR, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7765 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 524: /* column_reference ::= column_name */ #line 1118 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[0].minor.yy0, createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[-2].minor.yy305)))); } -#line 7734 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy29, createColumnNode(pCxt, NULL, &yymsp[0].minor.yy29)); } +#line 7771 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 536: /* function_expression ::= function_name NK_LP expression_list NK_RP */ - case 537: /* function_expression ::= star_func NK_LP star_func_para_list NK_RP */ yytestcase(yyruleno==537); -#line 1129 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-3].minor.yy305, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[-3].minor.yy305, yymsp[-1].minor.yy72)); } -#line 7741 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 525: /* column_reference ::= table_name NK_DOT column_name */ +#line 1119 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy29, createColumnNode(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy29)); } +#line 7777 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 538: /* function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP */ -#line 1132 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-5].minor.yy0, &yymsp[0].minor.yy0, createCastFunctionNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), yymsp[-1].minor.yy56)); } -#line 7747 "sql.c" - yymsp[-5].minor.yy1000 = yylhsminor.yy1000; + case 526: /* column_reference ::= NK_ALIAS */ +#line 1120 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createColumnNode(pCxt, NULL, &yymsp[0].minor.yy0)); } +#line 7783 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 540: /* literal_func ::= noarg_func NK_LP NK_RP */ -#line 1135 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[-2].minor.yy305, NULL)); } -#line 7753 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 556: /* star_func_para_list ::= NK_STAR */ -#line 1160 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, createColumnNode(pCxt, NULL, &yymsp[0].minor.yy0)); } -#line 7759 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; - break; - case 561: /* star_func_para ::= table_name NK_DOT NK_STAR */ - case 629: /* select_item ::= table_name NK_DOT NK_STAR */ yytestcase(yyruleno==629); -#line 1169 "sql.y" -{ yylhsminor.yy1000 = createColumnNode(pCxt, &yymsp[-2].minor.yy305, &yymsp[0].minor.yy0); } -#line 7766 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 562: /* case_when_expression ::= CASE when_then_list case_when_else_opt END */ -#line 1172 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0, createCaseWhenNode(pCxt, NULL, yymsp[-2].minor.yy72, yymsp[-1].minor.yy1000)); } -#line 7772 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; - break; - case 563: /* case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END */ -#line 1174 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-4].minor.yy0, &yymsp[0].minor.yy0, createCaseWhenNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), yymsp[-2].minor.yy72, yymsp[-1].minor.yy1000)); } -#line 7778 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; - break; - case 566: /* when_then_expr ::= WHEN common_expression THEN common_expression */ -#line 1181 "sql.y" -{ yymsp[-3].minor.yy1000 = createWhenThenNode(pCxt, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000)); } -#line 7784 "sql.c" - break; - case 568: /* case_when_else_opt ::= ELSE common_expression */ -#line 1184 "sql.y" -{ yymsp[-1].minor.yy1000 = releaseRawExprNode(pCxt, yymsp[0].minor.yy1000); } + case 527: /* column_reference ::= table_name NK_DOT NK_ALIAS */ +#line 1121 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy0, createColumnNode(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy0)); } #line 7789 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 569: /* predicate ::= expr_or_subquery compare_op expr_or_subquery */ - case 574: /* predicate ::= expr_or_subquery in_op in_predicate_value */ yytestcase(yyruleno==574); -#line 1187 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, yymsp[-1].minor.yy324, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7799 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 528: /* pseudo_column ::= ROWTS */ + case 529: /* pseudo_column ::= TBNAME */ yytestcase(yyruleno==529); + case 531: /* pseudo_column ::= QSTART */ yytestcase(yyruleno==531); + case 532: /* pseudo_column ::= QEND */ yytestcase(yyruleno==532); + case 533: /* pseudo_column ::= QDURATION */ yytestcase(yyruleno==533); + case 534: /* pseudo_column ::= WSTART */ yytestcase(yyruleno==534); + case 535: /* pseudo_column ::= WEND */ yytestcase(yyruleno==535); + case 536: /* pseudo_column ::= WDURATION */ yytestcase(yyruleno==536); + case 537: /* pseudo_column ::= IROWTS */ yytestcase(yyruleno==537); + case 538: /* pseudo_column ::= ISFILLED */ yytestcase(yyruleno==538); + case 539: /* pseudo_column ::= QTAGS */ yytestcase(yyruleno==539); + case 546: /* literal_func ::= NOW */ yytestcase(yyruleno==546); + case 547: /* literal_func ::= TODAY */ yytestcase(yyruleno==547); +#line 1123 "sql.y" +{ yylhsminor.yy812 = createRawExprNode(pCxt, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[0].minor.yy0, NULL)); } +#line 7807 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 570: /* predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery */ -#line 1194 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-4].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createBetweenAnd(pCxt, releaseRawExprNode(pCxt, yymsp[-4].minor.yy1000), releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7809 "sql.c" - yymsp[-4].minor.yy1000 = yylhsminor.yy1000; + case 530: /* pseudo_column ::= table_name NK_DOT TBNAME */ +#line 1125 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[0].minor.yy0, createNodeList(pCxt, createValueNode(pCxt, TSDB_DATA_TYPE_BINARY, &yymsp[-2].minor.yy29)))); } +#line 7813 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 571: /* predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery */ -#line 1200 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-5].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createNotBetweenAnd(pCxt, releaseRawExprNode(pCxt, yymsp[-5].minor.yy1000), releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7819 "sql.c" - yymsp[-5].minor.yy1000 = yylhsminor.yy1000; + case 540: /* function_expression ::= function_name NK_LP expression_list NK_RP */ + case 541: /* function_expression ::= star_func NK_LP star_func_para_list NK_RP */ yytestcase(yyruleno==541); +#line 1136 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-3].minor.yy29, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[-3].minor.yy29, yymsp[-1].minor.yy124)); } +#line 7820 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 572: /* predicate ::= expr_or_subquery IS NULL */ -#line 1205 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &yymsp[0].minor.yy0, createOperatorNode(pCxt, OP_TYPE_IS_NULL, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), NULL)); - } -#line 7828 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 542: /* function_expression ::= CAST NK_LP expr_or_subquery AS type_name NK_RP */ + case 543: /* function_expression ::= CAST NK_LP expr_or_subquery AS type_name_default_len NK_RP */ yytestcase(yyruleno==543); +#line 1139 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-5].minor.yy0, &yymsp[0].minor.yy0, createCastFunctionNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), yymsp[-1].minor.yy784)); } +#line 7827 "sql.c" + yymsp[-5].minor.yy812 = yylhsminor.yy812; break; - case 573: /* predicate ::= expr_or_subquery IS NOT NULL */ -#line 1209 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-3].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &yymsp[0].minor.yy0, createOperatorNode(pCxt, OP_TYPE_IS_NOT_NULL, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), NULL)); - } -#line 7837 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 545: /* literal_func ::= noarg_func NK_LP NK_RP */ +#line 1145 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy0, createFunctionNode(pCxt, &yymsp[-2].minor.yy29, NULL)); } +#line 7833 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 575: /* compare_op ::= NK_LT */ -#line 1221 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_LOWER_THAN; } -#line 7843 "sql.c" + case 561: /* star_func_para_list ::= NK_STAR */ +#line 1170 "sql.y" +{ yylhsminor.yy124 = createNodeList(pCxt, createColumnNode(pCxt, NULL, &yymsp[0].minor.yy0)); } +#line 7839 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; - case 576: /* compare_op ::= NK_GT */ -#line 1222 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_GREATER_THAN; } -#line 7848 "sql.c" + case 566: /* star_func_para ::= table_name NK_DOT NK_STAR */ + case 634: /* select_item ::= table_name NK_DOT NK_STAR */ yytestcase(yyruleno==634); +#line 1179 "sql.y" +{ yylhsminor.yy812 = createColumnNode(pCxt, &yymsp[-2].minor.yy29, &yymsp[0].minor.yy0); } +#line 7846 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 577: /* compare_op ::= NK_LE */ -#line 1223 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_LOWER_EQUAL; } -#line 7853 "sql.c" + case 567: /* case_when_expression ::= CASE when_then_list case_when_else_opt END */ +#line 1182 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0, createCaseWhenNode(pCxt, NULL, yymsp[-2].minor.yy124, yymsp[-1].minor.yy812)); } +#line 7852 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 578: /* compare_op ::= NK_GE */ -#line 1224 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_GREATER_EQUAL; } + case 568: /* case_when_expression ::= CASE common_expression when_then_list case_when_else_opt END */ +#line 1184 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-4].minor.yy0, &yymsp[0].minor.yy0, createCaseWhenNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), yymsp[-2].minor.yy124, yymsp[-1].minor.yy812)); } #line 7858 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; break; - case 579: /* compare_op ::= NK_NE */ -#line 1225 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_NOT_EQUAL; } -#line 7863 "sql.c" + case 571: /* when_then_expr ::= WHEN common_expression THEN common_expression */ +#line 1191 "sql.y" +{ yymsp[-3].minor.yy812 = createWhenThenNode(pCxt, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812)); } +#line 7864 "sql.c" break; - case 580: /* compare_op ::= NK_EQ */ -#line 1226 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_EQUAL; } -#line 7868 "sql.c" + case 573: /* case_when_else_opt ::= ELSE common_expression */ +#line 1194 "sql.y" +{ yymsp[-1].minor.yy812 = releaseRawExprNode(pCxt, yymsp[0].minor.yy812); } +#line 7869 "sql.c" break; - case 581: /* compare_op ::= LIKE */ -#line 1227 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_LIKE; } -#line 7873 "sql.c" - break; - case 582: /* compare_op ::= NOT LIKE */ -#line 1228 "sql.y" -{ yymsp[-1].minor.yy324 = OP_TYPE_NOT_LIKE; } -#line 7878 "sql.c" - break; - case 583: /* compare_op ::= MATCH */ -#line 1229 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_MATCH; } -#line 7883 "sql.c" - break; - case 584: /* compare_op ::= NMATCH */ -#line 1230 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_NMATCH; } -#line 7888 "sql.c" - break; - case 585: /* compare_op ::= CONTAINS */ -#line 1231 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_JSON_CONTAINS; } -#line 7893 "sql.c" - break; - case 586: /* in_op ::= IN */ -#line 1235 "sql.y" -{ yymsp[0].minor.yy324 = OP_TYPE_IN; } -#line 7898 "sql.c" - break; - case 587: /* in_op ::= NOT IN */ -#line 1236 "sql.y" -{ yymsp[-1].minor.yy324 = OP_TYPE_NOT_IN; } -#line 7903 "sql.c" - break; - case 588: /* in_predicate_value ::= NK_LP literal_list NK_RP */ -#line 1238 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, createNodeListNode(pCxt, yymsp[-1].minor.yy72)); } -#line 7908 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; - break; - case 590: /* boolean_value_expression ::= NOT boolean_primary */ -#line 1242 "sql.y" + case 574: /* predicate ::= expr_or_subquery compare_op expr_or_subquery */ + case 579: /* predicate ::= expr_or_subquery in_op in_predicate_value */ yytestcase(yyruleno==579); +#line 1197 "sql.y" { - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &e, createLogicConditionNode(pCxt, LOGIC_COND_TYPE_NOT, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000), NULL)); + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createOperatorNode(pCxt, yymsp[-1].minor.yy590, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7879 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 575: /* predicate ::= expr_or_subquery BETWEEN expr_or_subquery AND expr_or_subquery */ +#line 1204 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-4].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createBetweenAnd(pCxt, releaseRawExprNode(pCxt, yymsp[-4].minor.yy812), releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7889 "sql.c" + yymsp[-4].minor.yy812 = yylhsminor.yy812; + break; + case 576: /* predicate ::= expr_or_subquery NOT BETWEEN expr_or_subquery AND expr_or_subquery */ +#line 1210 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-5].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createNotBetweenAnd(pCxt, releaseRawExprNode(pCxt, yymsp[-5].minor.yy812), releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 7899 "sql.c" + yymsp[-5].minor.yy812 = yylhsminor.yy812; + break; + case 577: /* predicate ::= expr_or_subquery IS NULL */ +#line 1215 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &yymsp[0].minor.yy0, createOperatorNode(pCxt, OP_TYPE_IS_NULL, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), NULL)); + } +#line 7908 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 578: /* predicate ::= expr_or_subquery IS NOT NULL */ +#line 1219 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-3].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &yymsp[0].minor.yy0, createOperatorNode(pCxt, OP_TYPE_IS_NOT_NULL, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), NULL)); } #line 7917 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 591: /* boolean_value_expression ::= boolean_value_expression OR boolean_value_expression */ -#line 1247 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createLogicConditionNode(pCxt, LOGIC_COND_TYPE_OR, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7927 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 580: /* compare_op ::= NK_LT */ +#line 1231 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_LOWER_THAN; } +#line 7923 "sql.c" break; - case 592: /* boolean_value_expression ::= boolean_value_expression AND boolean_value_expression */ -#line 1253 "sql.y" -{ - SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy1000); - SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy1000); - yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &s, &e, createLogicConditionNode(pCxt, LOGIC_COND_TYPE_AND, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); - } -#line 7937 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 581: /* compare_op ::= NK_GT */ +#line 1232 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_GREATER_THAN; } +#line 7928 "sql.c" break; - case 600: /* table_reference_list ::= table_reference_list NK_COMMA table_reference */ -#line 1271 "sql.y" -{ yylhsminor.yy1000 = createJoinTableNode(pCxt, JOIN_TYPE_INNER, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000, NULL); } + case 582: /* compare_op ::= NK_LE */ +#line 1233 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_LOWER_EQUAL; } +#line 7933 "sql.c" + break; + case 583: /* compare_op ::= NK_GE */ +#line 1234 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_GREATER_EQUAL; } +#line 7938 "sql.c" + break; + case 584: /* compare_op ::= NK_NE */ +#line 1235 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_NOT_EQUAL; } #line 7943 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; break; - case 603: /* table_primary ::= table_name alias_opt */ -#line 1277 "sql.y" -{ yylhsminor.yy1000 = createRealTableNode(pCxt, NULL, &yymsp[-1].minor.yy305, &yymsp[0].minor.yy305); } -#line 7949 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; + case 585: /* compare_op ::= NK_EQ */ +#line 1236 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_EQUAL; } +#line 7948 "sql.c" break; - case 604: /* table_primary ::= db_name NK_DOT table_name alias_opt */ -#line 1278 "sql.y" -{ yylhsminor.yy1000 = createRealTableNode(pCxt, &yymsp[-3].minor.yy305, &yymsp[-1].minor.yy305, &yymsp[0].minor.yy305); } -#line 7955 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 586: /* compare_op ::= LIKE */ +#line 1237 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_LIKE; } +#line 7953 "sql.c" break; - case 605: /* table_primary ::= subquery alias_opt */ -#line 1279 "sql.y" -{ yylhsminor.yy1000 = createTempTableNode(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000), &yymsp[0].minor.yy305); } -#line 7961 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; + case 587: /* compare_op ::= NOT LIKE */ +#line 1238 "sql.y" +{ yymsp[-1].minor.yy590 = OP_TYPE_NOT_LIKE; } +#line 7958 "sql.c" break; - case 607: /* alias_opt ::= */ -#line 1284 "sql.y" -{ yymsp[1].minor.yy305 = nil_token; } -#line 7967 "sql.c" + case 588: /* compare_op ::= MATCH */ +#line 1239 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_MATCH; } +#line 7963 "sql.c" break; - case 609: /* alias_opt ::= AS table_alias */ -#line 1286 "sql.y" -{ yymsp[-1].minor.yy305 = yymsp[0].minor.yy305; } -#line 7972 "sql.c" + case 589: /* compare_op ::= NMATCH */ +#line 1240 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_NMATCH; } +#line 7968 "sql.c" break; - case 610: /* parenthesized_joined_table ::= NK_LP joined_table NK_RP */ - case 611: /* parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP */ yytestcase(yyruleno==611); -#line 1288 "sql.y" -{ yymsp[-2].minor.yy1000 = yymsp[-1].minor.yy1000; } + case 590: /* compare_op ::= CONTAINS */ +#line 1241 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_JSON_CONTAINS; } +#line 7973 "sql.c" + break; + case 591: /* in_op ::= IN */ +#line 1245 "sql.y" +{ yymsp[0].minor.yy590 = OP_TYPE_IN; } #line 7978 "sql.c" break; - case 612: /* joined_table ::= table_reference join_type JOIN table_reference ON search_condition */ -#line 1293 "sql.y" -{ yylhsminor.yy1000 = createJoinTableNode(pCxt, yymsp[-4].minor.yy828, yymsp[-5].minor.yy1000, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000); } + case 592: /* in_op ::= NOT IN */ +#line 1246 "sql.y" +{ yymsp[-1].minor.yy590 = OP_TYPE_NOT_IN; } #line 7983 "sql.c" - yymsp[-5].minor.yy1000 = yylhsminor.yy1000; break; - case 613: /* join_type ::= */ -#line 1297 "sql.y" -{ yymsp[1].minor.yy828 = JOIN_TYPE_INNER; } -#line 7989 "sql.c" + case 593: /* in_predicate_value ::= NK_LP literal_list NK_RP */ +#line 1248 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, createNodeListNode(pCxt, yymsp[-1].minor.yy124)); } +#line 7988 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 614: /* join_type ::= INNER */ -#line 1298 "sql.y" -{ yymsp[0].minor.yy828 = JOIN_TYPE_INNER; } -#line 7994 "sql.c" - break; - case 615: /* query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt */ -#line 1304 "sql.y" + case 595: /* boolean_value_expression ::= NOT boolean_primary */ +#line 1252 "sql.y" { - yymsp[-13].minor.yy1000 = createSelectStmt(pCxt, yymsp[-11].minor.yy985, yymsp[-9].minor.yy72, yymsp[-8].minor.yy1000, yymsp[-12].minor.yy72); - yymsp[-13].minor.yy1000 = setSelectStmtTagMode(pCxt, yymsp[-13].minor.yy1000, yymsp[-10].minor.yy985); - yymsp[-13].minor.yy1000 = addWhereClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-7].minor.yy1000); - yymsp[-13].minor.yy1000 = addPartitionByClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-6].minor.yy72); - yymsp[-13].minor.yy1000 = addWindowClauseClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-2].minor.yy1000); - yymsp[-13].minor.yy1000 = addGroupByClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-1].minor.yy72); - yymsp[-13].minor.yy1000 = addHavingClause(pCxt, yymsp[-13].minor.yy1000, yymsp[0].minor.yy1000); - yymsp[-13].minor.yy1000 = addRangeClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-5].minor.yy1000); - yymsp[-13].minor.yy1000 = addEveryClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-4].minor.yy1000); - yymsp[-13].minor.yy1000 = addFillClause(pCxt, yymsp[-13].minor.yy1000, yymsp[-3].minor.yy1000); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-1].minor.yy0, &e, createLogicConditionNode(pCxt, LOGIC_COND_TYPE_NOT, releaseRawExprNode(pCxt, yymsp[0].minor.yy812), NULL)); } -#line 8010 "sql.c" +#line 7997 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 616: /* hint_list ::= */ -#line 1319 "sql.y" -{ yymsp[1].minor.yy72 = createHintNodeList(pCxt, NULL); } -#line 8015 "sql.c" + case 596: /* boolean_value_expression ::= boolean_value_expression OR boolean_value_expression */ +#line 1257 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createLogicConditionNode(pCxt, LOGIC_COND_TYPE_OR, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 8007 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 617: /* hint_list ::= NK_HINT */ -#line 1320 "sql.y" -{ yylhsminor.yy72 = createHintNodeList(pCxt, &yymsp[0].minor.yy0); } -#line 8020 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; + case 597: /* boolean_value_expression ::= boolean_value_expression AND boolean_value_expression */ +#line 1263 "sql.y" +{ + SToken s = getTokenFromRawExprNode(pCxt, yymsp[-2].minor.yy812); + SToken e = getTokenFromRawExprNode(pCxt, yymsp[0].minor.yy812); + yylhsminor.yy812 = createRawExprNodeExt(pCxt, &s, &e, createLogicConditionNode(pCxt, LOGIC_COND_TYPE_AND, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); + } +#line 8017 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 622: /* set_quantifier_opt ::= ALL */ -#line 1331 "sql.y" -{ yymsp[0].minor.yy985 = false; } -#line 8026 "sql.c" + case 605: /* table_reference_list ::= table_reference_list NK_COMMA table_reference */ +#line 1281 "sql.y" +{ yylhsminor.yy812 = createJoinTableNode(pCxt, JOIN_TYPE_INNER, yymsp[-2].minor.yy812, yymsp[0].minor.yy812, NULL); } +#line 8023 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 625: /* select_item ::= NK_STAR */ -#line 1338 "sql.y" -{ yylhsminor.yy1000 = createColumnNode(pCxt, NULL, &yymsp[0].minor.yy0); } -#line 8031 "sql.c" - yymsp[0].minor.yy1000 = yylhsminor.yy1000; + case 608: /* table_primary ::= table_name alias_opt */ +#line 1287 "sql.y" +{ yylhsminor.yy812 = createRealTableNode(pCxt, NULL, &yymsp[-1].minor.yy29, &yymsp[0].minor.yy29); } +#line 8029 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 627: /* select_item ::= common_expression column_alias */ - case 637: /* partition_item ::= expr_or_subquery column_alias */ yytestcase(yyruleno==637); -#line 1340 "sql.y" -{ yylhsminor.yy1000 = setProjectionAlias(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000), &yymsp[0].minor.yy305); } -#line 8038 "sql.c" - yymsp[-1].minor.yy1000 = yylhsminor.yy1000; + case 609: /* table_primary ::= db_name NK_DOT table_name alias_opt */ +#line 1288 "sql.y" +{ yylhsminor.yy812 = createRealTableNode(pCxt, &yymsp[-3].minor.yy29, &yymsp[-1].minor.yy29, &yymsp[0].minor.yy29); } +#line 8035 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; break; - case 628: /* select_item ::= common_expression AS column_alias */ - case 638: /* partition_item ::= expr_or_subquery AS column_alias */ yytestcase(yyruleno==638); -#line 1341 "sql.y" -{ yylhsminor.yy1000 = setProjectionAlias(pCxt, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), &yymsp[0].minor.yy305); } -#line 8045 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 610: /* table_primary ::= subquery alias_opt */ +#line 1289 "sql.y" +{ yylhsminor.yy812 = createTempTableNode(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy812), &yymsp[0].minor.yy29); } +#line 8041 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 633: /* partition_by_clause_opt ::= PARTITION BY partition_list */ - case 663: /* group_by_clause_opt ::= GROUP BY group_by_list */ yytestcase(yyruleno==663); - case 683: /* order_by_clause_opt ::= ORDER BY sort_specification_list */ yytestcase(yyruleno==683); -#line 1350 "sql.y" -{ yymsp[-2].minor.yy72 = yymsp[0].minor.yy72; } -#line 8053 "sql.c" + case 612: /* alias_opt ::= */ +#line 1294 "sql.y" +{ yymsp[1].minor.yy29 = nil_token; } +#line 8047 "sql.c" break; - case 640: /* twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP */ -#line 1363 "sql.y" -{ yymsp[-5].minor.yy1000 = createSessionWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000)); } + case 614: /* alias_opt ::= AS table_alias */ +#line 1296 "sql.y" +{ yymsp[-1].minor.yy29 = yymsp[0].minor.yy29; } +#line 8052 "sql.c" + break; + case 615: /* parenthesized_joined_table ::= NK_LP joined_table NK_RP */ + case 616: /* parenthesized_joined_table ::= NK_LP parenthesized_joined_table NK_RP */ yytestcase(yyruleno==616); +#line 1298 "sql.y" +{ yymsp[-2].minor.yy812 = yymsp[-1].minor.yy812; } #line 8058 "sql.c" break; - case 641: /* twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP */ -#line 1364 "sql.y" -{ yymsp[-3].minor.yy1000 = createStateWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000)); } + case 617: /* joined_table ::= table_reference join_type JOIN table_reference ON search_condition */ +#line 1303 "sql.y" +{ yylhsminor.yy812 = createJoinTableNode(pCxt, yymsp[-4].minor.yy162, yymsp[-5].minor.yy812, yymsp[-2].minor.yy812, yymsp[0].minor.yy812); } #line 8063 "sql.c" + yymsp[-5].minor.yy812 = yylhsminor.yy812; break; - case 642: /* twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ -#line 1366 "sql.y" -{ yymsp[-5].minor.yy1000 = createIntervalWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), NULL, yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 8068 "sql.c" + case 618: /* join_type ::= */ +#line 1307 "sql.y" +{ yymsp[1].minor.yy162 = JOIN_TYPE_INNER; } +#line 8069 "sql.c" break; - case 643: /* twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ -#line 1370 "sql.y" -{ yymsp[-7].minor.yy1000 = createIntervalWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-5].minor.yy1000), releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), yymsp[-1].minor.yy1000, yymsp[0].minor.yy1000); } -#line 8073 "sql.c" + case 619: /* join_type ::= INNER */ +#line 1308 "sql.y" +{ yymsp[0].minor.yy162 = JOIN_TYPE_INNER; } +#line 8074 "sql.c" break; - case 644: /* twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition */ -#line 1372 "sql.y" -{ yymsp[-6].minor.yy1000 = createEventWindowNode(pCxt, yymsp[-3].minor.yy1000, yymsp[0].minor.yy1000); } -#line 8078 "sql.c" + case 620: /* query_specification ::= SELECT hint_list set_quantifier_opt tag_mode_opt select_list from_clause_opt where_clause_opt partition_by_clause_opt range_opt every_opt fill_opt twindow_clause_opt group_by_clause_opt having_clause_opt */ +#line 1314 "sql.y" +{ + yymsp[-13].minor.yy812 = createSelectStmt(pCxt, yymsp[-11].minor.yy887, yymsp[-9].minor.yy124, yymsp[-8].minor.yy812, yymsp[-12].minor.yy124); + yymsp[-13].minor.yy812 = setSelectStmtTagMode(pCxt, yymsp[-13].minor.yy812, yymsp[-10].minor.yy887); + yymsp[-13].minor.yy812 = addWhereClause(pCxt, yymsp[-13].minor.yy812, yymsp[-7].minor.yy812); + yymsp[-13].minor.yy812 = addPartitionByClause(pCxt, yymsp[-13].minor.yy812, yymsp[-6].minor.yy124); + yymsp[-13].minor.yy812 = addWindowClauseClause(pCxt, yymsp[-13].minor.yy812, yymsp[-2].minor.yy812); + yymsp[-13].minor.yy812 = addGroupByClause(pCxt, yymsp[-13].minor.yy812, yymsp[-1].minor.yy124); + yymsp[-13].minor.yy812 = addHavingClause(pCxt, yymsp[-13].minor.yy812, yymsp[0].minor.yy812); + yymsp[-13].minor.yy812 = addRangeClause(pCxt, yymsp[-13].minor.yy812, yymsp[-5].minor.yy812); + yymsp[-13].minor.yy812 = addEveryClause(pCxt, yymsp[-13].minor.yy812, yymsp[-4].minor.yy812); + yymsp[-13].minor.yy812 = addFillClause(pCxt, yymsp[-13].minor.yy812, yymsp[-3].minor.yy812); + } +#line 8090 "sql.c" break; - case 645: /* twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP */ -#line 1374 "sql.y" -{ yymsp[-3].minor.yy1000 = createCountWindowNode(pCxt, &yymsp[-1].minor.yy0, &yymsp[-1].minor.yy0); } -#line 8083 "sql.c" + case 621: /* hint_list ::= */ +#line 1329 "sql.y" +{ yymsp[1].minor.yy124 = createHintNodeList(pCxt, NULL); } +#line 8095 "sql.c" break; - case 646: /* twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ -#line 1376 "sql.y" -{ yymsp[-5].minor.yy1000 = createCountWindowNode(pCxt, &yymsp[-3].minor.yy0, &yymsp[-1].minor.yy0); } -#line 8088 "sql.c" + case 622: /* hint_list ::= NK_HINT */ +#line 1330 "sql.y" +{ yylhsminor.yy124 = createHintNodeList(pCxt, &yymsp[0].minor.yy0); } +#line 8100 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; break; - case 653: /* fill_opt ::= FILL NK_LP fill_mode NK_RP */ -#line 1386 "sql.y" -{ yymsp[-3].minor.yy1000 = createFillNode(pCxt, yymsp[-1].minor.yy926, NULL); } -#line 8093 "sql.c" + case 627: /* set_quantifier_opt ::= ALL */ +#line 1341 "sql.y" +{ yymsp[0].minor.yy887 = false; } +#line 8106 "sql.c" break; - case 654: /* fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP */ -#line 1387 "sql.y" -{ yymsp[-5].minor.yy1000 = createFillNode(pCxt, FILL_MODE_VALUE, createNodeListNode(pCxt, yymsp[-1].minor.yy72)); } -#line 8098 "sql.c" + case 630: /* select_item ::= NK_STAR */ +#line 1348 "sql.y" +{ yylhsminor.yy812 = createColumnNode(pCxt, NULL, &yymsp[0].minor.yy0); } +#line 8111 "sql.c" + yymsp[0].minor.yy812 = yylhsminor.yy812; break; - case 655: /* fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP */ -#line 1388 "sql.y" -{ yymsp[-5].minor.yy1000 = createFillNode(pCxt, FILL_MODE_VALUE_F, createNodeListNode(pCxt, yymsp[-1].minor.yy72)); } -#line 8103 "sql.c" - break; - case 656: /* fill_mode ::= NONE */ -#line 1392 "sql.y" -{ yymsp[0].minor.yy926 = FILL_MODE_NONE; } -#line 8108 "sql.c" - break; - case 657: /* fill_mode ::= PREV */ -#line 1393 "sql.y" -{ yymsp[0].minor.yy926 = FILL_MODE_PREV; } -#line 8113 "sql.c" - break; - case 658: /* fill_mode ::= NULL */ -#line 1394 "sql.y" -{ yymsp[0].minor.yy926 = FILL_MODE_NULL; } + case 632: /* select_item ::= common_expression column_alias */ + case 642: /* partition_item ::= expr_or_subquery column_alias */ yytestcase(yyruleno==642); +#line 1350 "sql.y" +{ yylhsminor.yy812 = setProjectionAlias(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy812), &yymsp[0].minor.yy29); } #line 8118 "sql.c" + yymsp[-1].minor.yy812 = yylhsminor.yy812; break; - case 659: /* fill_mode ::= NULL_F */ -#line 1395 "sql.y" -{ yymsp[0].minor.yy926 = FILL_MODE_NULL_F; } -#line 8123 "sql.c" + case 633: /* select_item ::= common_expression AS column_alias */ + case 643: /* partition_item ::= expr_or_subquery AS column_alias */ yytestcase(yyruleno==643); +#line 1351 "sql.y" +{ yylhsminor.yy812 = setProjectionAlias(pCxt, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), &yymsp[0].minor.yy29); } +#line 8125 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 660: /* fill_mode ::= LINEAR */ -#line 1396 "sql.y" -{ yymsp[0].minor.yy926 = FILL_MODE_LINEAR; } -#line 8128 "sql.c" - break; - case 661: /* fill_mode ::= NEXT */ -#line 1397 "sql.y" -{ yymsp[0].minor.yy926 = FILL_MODE_NEXT; } + case 638: /* partition_by_clause_opt ::= PARTITION BY partition_list */ + case 668: /* group_by_clause_opt ::= GROUP BY group_by_list */ yytestcase(yyruleno==668); + case 688: /* order_by_clause_opt ::= ORDER BY sort_specification_list */ yytestcase(yyruleno==688); +#line 1360 "sql.y" +{ yymsp[-2].minor.yy124 = yymsp[0].minor.yy124; } #line 8133 "sql.c" break; - case 664: /* group_by_list ::= expr_or_subquery */ -#line 1406 "sql.y" -{ yylhsminor.yy72 = createNodeList(pCxt, createGroupingSetNode(pCxt, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); } + case 645: /* twindow_clause_opt ::= SESSION NK_LP column_reference NK_COMMA interval_sliding_duration_literal NK_RP */ +#line 1373 "sql.y" +{ yymsp[-5].minor.yy812 = createSessionWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), releaseRawExprNode(pCxt, yymsp[-1].minor.yy812)); } #line 8138 "sql.c" - yymsp[0].minor.yy72 = yylhsminor.yy72; break; - case 665: /* group_by_list ::= group_by_list NK_COMMA expr_or_subquery */ -#line 1407 "sql.y" -{ yylhsminor.yy72 = addNodeToList(pCxt, yymsp[-2].minor.yy72, createGroupingSetNode(pCxt, releaseRawExprNode(pCxt, yymsp[0].minor.yy1000))); } -#line 8144 "sql.c" - yymsp[-2].minor.yy72 = yylhsminor.yy72; + case 646: /* twindow_clause_opt ::= STATE_WINDOW NK_LP expr_or_subquery NK_RP */ +#line 1374 "sql.y" +{ yymsp[-3].minor.yy812 = createStateWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy812)); } +#line 8143 "sql.c" break; - case 669: /* range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP */ -#line 1414 "sql.y" -{ yymsp[-5].minor.yy1000 = createInterpTimeRange(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy1000), releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000)); } -#line 8150 "sql.c" + case 647: /* twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ +#line 1376 "sql.y" +{ yymsp[-5].minor.yy812 = createIntervalWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), NULL, yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 8148 "sql.c" break; - case 670: /* range_opt ::= RANGE NK_LP expr_or_subquery NK_RP */ -#line 1416 "sql.y" -{ yymsp[-3].minor.yy1000 = createInterpTimePoint(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy1000)); } -#line 8155 "sql.c" + case 648: /* twindow_clause_opt ::= INTERVAL NK_LP interval_sliding_duration_literal NK_COMMA interval_sliding_duration_literal NK_RP sliding_opt fill_opt */ +#line 1380 "sql.y" +{ yymsp[-7].minor.yy812 = createIntervalWindowNode(pCxt, releaseRawExprNode(pCxt, yymsp[-5].minor.yy812), releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), yymsp[-1].minor.yy812, yymsp[0].minor.yy812); } +#line 8153 "sql.c" break; - case 673: /* query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt */ -#line 1423 "sql.y" -{ - yylhsminor.yy1000 = addOrderByClause(pCxt, yymsp[-3].minor.yy1000, yymsp[-2].minor.yy72); - yylhsminor.yy1000 = addSlimitClause(pCxt, yylhsminor.yy1000, yymsp[-1].minor.yy1000); - yylhsminor.yy1000 = addLimitClause(pCxt, yylhsminor.yy1000, yymsp[0].minor.yy1000); - } -#line 8164 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 649: /* twindow_clause_opt ::= EVENT_WINDOW START WITH search_condition END WITH search_condition */ +#line 1382 "sql.y" +{ yymsp[-6].minor.yy812 = createEventWindowNode(pCxt, yymsp[-3].minor.yy812, yymsp[0].minor.yy812); } +#line 8158 "sql.c" break; - case 676: /* union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery */ -#line 1433 "sql.y" -{ yylhsminor.yy1000 = createSetOperator(pCxt, SET_OP_TYPE_UNION_ALL, yymsp[-3].minor.yy1000, yymsp[0].minor.yy1000); } -#line 8170 "sql.c" - yymsp[-3].minor.yy1000 = yylhsminor.yy1000; + case 650: /* twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_RP */ +#line 1384 "sql.y" +{ yymsp[-3].minor.yy812 = createCountWindowNode(pCxt, &yymsp[-1].minor.yy0, &yymsp[-1].minor.yy0); } +#line 8163 "sql.c" break; - case 677: /* union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery */ -#line 1435 "sql.y" -{ yylhsminor.yy1000 = createSetOperator(pCxt, SET_OP_TYPE_UNION, yymsp[-2].minor.yy1000, yymsp[0].minor.yy1000); } -#line 8176 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 651: /* twindow_clause_opt ::= COUNT_WINDOW NK_LP NK_INTEGER NK_COMMA NK_INTEGER NK_RP */ +#line 1386 "sql.y" +{ yymsp[-5].minor.yy812 = createCountWindowNode(pCxt, &yymsp[-3].minor.yy0, &yymsp[-1].minor.yy0); } +#line 8168 "sql.c" break; - case 685: /* slimit_clause_opt ::= SLIMIT NK_INTEGER */ - case 689: /* limit_clause_opt ::= LIMIT NK_INTEGER */ yytestcase(yyruleno==689); -#line 1449 "sql.y" -{ yymsp[-1].minor.yy1000 = createLimitNode(pCxt, &yymsp[0].minor.yy0, NULL); } + case 658: /* fill_opt ::= FILL NK_LP fill_mode NK_RP */ +#line 1396 "sql.y" +{ yymsp[-3].minor.yy812 = createFillNode(pCxt, yymsp[-1].minor.yy144, NULL); } +#line 8173 "sql.c" + break; + case 659: /* fill_opt ::= FILL NK_LP VALUE NK_COMMA expression_list NK_RP */ +#line 1397 "sql.y" +{ yymsp[-5].minor.yy812 = createFillNode(pCxt, FILL_MODE_VALUE, createNodeListNode(pCxt, yymsp[-1].minor.yy124)); } +#line 8178 "sql.c" + break; + case 660: /* fill_opt ::= FILL NK_LP VALUE_F NK_COMMA expression_list NK_RP */ +#line 1398 "sql.y" +{ yymsp[-5].minor.yy812 = createFillNode(pCxt, FILL_MODE_VALUE_F, createNodeListNode(pCxt, yymsp[-1].minor.yy124)); } #line 8183 "sql.c" break; - case 686: /* slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER */ - case 690: /* limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER */ yytestcase(yyruleno==690); -#line 1450 "sql.y" -{ yymsp[-3].minor.yy1000 = createLimitNode(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0); } -#line 8189 "sql.c" + case 661: /* fill_mode ::= NONE */ +#line 1402 "sql.y" +{ yymsp[0].minor.yy144 = FILL_MODE_NONE; } +#line 8188 "sql.c" break; - case 687: /* slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER */ - case 691: /* limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER */ yytestcase(yyruleno==691); -#line 1451 "sql.y" -{ yymsp[-3].minor.yy1000 = createLimitNode(pCxt, &yymsp[0].minor.yy0, &yymsp[-2].minor.yy0); } -#line 8195 "sql.c" + case 662: /* fill_mode ::= PREV */ +#line 1403 "sql.y" +{ yymsp[0].minor.yy144 = FILL_MODE_PREV; } +#line 8193 "sql.c" break; - case 692: /* subquery ::= NK_LP query_expression NK_RP */ + case 663: /* fill_mode ::= NULL */ +#line 1404 "sql.y" +{ yymsp[0].minor.yy144 = FILL_MODE_NULL; } +#line 8198 "sql.c" + break; + case 664: /* fill_mode ::= NULL_F */ +#line 1405 "sql.y" +{ yymsp[0].minor.yy144 = FILL_MODE_NULL_F; } +#line 8203 "sql.c" + break; + case 665: /* fill_mode ::= LINEAR */ +#line 1406 "sql.y" +{ yymsp[0].minor.yy144 = FILL_MODE_LINEAR; } +#line 8208 "sql.c" + break; + case 666: /* fill_mode ::= NEXT */ +#line 1407 "sql.y" +{ yymsp[0].minor.yy144 = FILL_MODE_NEXT; } +#line 8213 "sql.c" + break; + case 669: /* group_by_list ::= expr_or_subquery */ +#line 1416 "sql.y" +{ yylhsminor.yy124 = createNodeList(pCxt, createGroupingSetNode(pCxt, releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); } +#line 8218 "sql.c" + yymsp[0].minor.yy124 = yylhsminor.yy124; + break; + case 670: /* group_by_list ::= group_by_list NK_COMMA expr_or_subquery */ +#line 1417 "sql.y" +{ yylhsminor.yy124 = addNodeToList(pCxt, yymsp[-2].minor.yy124, createGroupingSetNode(pCxt, releaseRawExprNode(pCxt, yymsp[0].minor.yy812))); } +#line 8224 "sql.c" + yymsp[-2].minor.yy124 = yylhsminor.yy124; + break; + case 674: /* range_opt ::= RANGE NK_LP expr_or_subquery NK_COMMA expr_or_subquery NK_RP */ +#line 1424 "sql.y" +{ yymsp[-5].minor.yy812 = createInterpTimeRange(pCxt, releaseRawExprNode(pCxt, yymsp[-3].minor.yy812), releaseRawExprNode(pCxt, yymsp[-1].minor.yy812)); } +#line 8230 "sql.c" + break; + case 675: /* range_opt ::= RANGE NK_LP expr_or_subquery NK_RP */ +#line 1426 "sql.y" +{ yymsp[-3].minor.yy812 = createInterpTimePoint(pCxt, releaseRawExprNode(pCxt, yymsp[-1].minor.yy812)); } +#line 8235 "sql.c" + break; + case 678: /* query_expression ::= query_simple order_by_clause_opt slimit_clause_opt limit_clause_opt */ +#line 1433 "sql.y" +{ + yylhsminor.yy812 = addOrderByClause(pCxt, yymsp[-3].minor.yy812, yymsp[-2].minor.yy124); + yylhsminor.yy812 = addSlimitClause(pCxt, yylhsminor.yy812, yymsp[-1].minor.yy812); + yylhsminor.yy812 = addLimitClause(pCxt, yylhsminor.yy812, yymsp[0].minor.yy812); + } +#line 8244 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; + break; + case 681: /* union_query_expression ::= query_simple_or_subquery UNION ALL query_simple_or_subquery */ +#line 1443 "sql.y" +{ yylhsminor.yy812 = createSetOperator(pCxt, SET_OP_TYPE_UNION_ALL, yymsp[-3].minor.yy812, yymsp[0].minor.yy812); } +#line 8250 "sql.c" + yymsp[-3].minor.yy812 = yylhsminor.yy812; + break; + case 682: /* union_query_expression ::= query_simple_or_subquery UNION query_simple_or_subquery */ +#line 1445 "sql.y" +{ yylhsminor.yy812 = createSetOperator(pCxt, SET_OP_TYPE_UNION, yymsp[-2].minor.yy812, yymsp[0].minor.yy812); } +#line 8256 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; + break; + case 690: /* slimit_clause_opt ::= SLIMIT NK_INTEGER */ + case 694: /* limit_clause_opt ::= LIMIT NK_INTEGER */ yytestcase(yyruleno==694); #line 1459 "sql.y" -{ yylhsminor.yy1000 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, yymsp[-1].minor.yy1000); } -#line 8200 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; +{ yymsp[-1].minor.yy812 = createLimitNode(pCxt, &yymsp[0].minor.yy0, NULL); } +#line 8263 "sql.c" break; - case 697: /* sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt */ -#line 1473 "sql.y" -{ yylhsminor.yy1000 = createOrderByExprNode(pCxt, releaseRawExprNode(pCxt, yymsp[-2].minor.yy1000), yymsp[-1].minor.yy130, yymsp[0].minor.yy681); } -#line 8206 "sql.c" - yymsp[-2].minor.yy1000 = yylhsminor.yy1000; + case 691: /* slimit_clause_opt ::= SLIMIT NK_INTEGER SOFFSET NK_INTEGER */ + case 695: /* limit_clause_opt ::= LIMIT NK_INTEGER OFFSET NK_INTEGER */ yytestcase(yyruleno==695); +#line 1460 "sql.y" +{ yymsp[-3].minor.yy812 = createLimitNode(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0); } +#line 8269 "sql.c" break; - case 698: /* ordering_specification_opt ::= */ -#line 1477 "sql.y" -{ yymsp[1].minor.yy130 = ORDER_ASC; } -#line 8212 "sql.c" + case 692: /* slimit_clause_opt ::= SLIMIT NK_INTEGER NK_COMMA NK_INTEGER */ + case 696: /* limit_clause_opt ::= LIMIT NK_INTEGER NK_COMMA NK_INTEGER */ yytestcase(yyruleno==696); +#line 1461 "sql.y" +{ yymsp[-3].minor.yy812 = createLimitNode(pCxt, &yymsp[0].minor.yy0, &yymsp[-2].minor.yy0); } +#line 8275 "sql.c" break; - case 699: /* ordering_specification_opt ::= ASC */ -#line 1478 "sql.y" -{ yymsp[0].minor.yy130 = ORDER_ASC; } -#line 8217 "sql.c" + case 697: /* subquery ::= NK_LP query_expression NK_RP */ +#line 1469 "sql.y" +{ yylhsminor.yy812 = createRawExprNodeExt(pCxt, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, yymsp[-1].minor.yy812); } +#line 8280 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 700: /* ordering_specification_opt ::= DESC */ -#line 1479 "sql.y" -{ yymsp[0].minor.yy130 = ORDER_DESC; } -#line 8222 "sql.c" - break; - case 701: /* null_ordering_opt ::= */ + case 702: /* sort_specification ::= expr_or_subquery ordering_specification_opt null_ordering_opt */ #line 1483 "sql.y" -{ yymsp[1].minor.yy681 = NULL_ORDER_DEFAULT; } -#line 8227 "sql.c" +{ yylhsminor.yy812 = createOrderByExprNode(pCxt, releaseRawExprNode(pCxt, yymsp[-2].minor.yy812), yymsp[-1].minor.yy638, yymsp[0].minor.yy907); } +#line 8286 "sql.c" + yymsp[-2].minor.yy812 = yylhsminor.yy812; break; - case 702: /* null_ordering_opt ::= NULLS FIRST */ -#line 1484 "sql.y" -{ yymsp[-1].minor.yy681 = NULL_ORDER_FIRST; } -#line 8232 "sql.c" + case 703: /* ordering_specification_opt ::= */ +#line 1487 "sql.y" +{ yymsp[1].minor.yy638 = ORDER_ASC; } +#line 8292 "sql.c" break; - case 703: /* null_ordering_opt ::= NULLS LAST */ -#line 1485 "sql.y" -{ yymsp[-1].minor.yy681 = NULL_ORDER_LAST; } -#line 8237 "sql.c" + case 704: /* ordering_specification_opt ::= ASC */ +#line 1488 "sql.y" +{ yymsp[0].minor.yy638 = ORDER_ASC; } +#line 8297 "sql.c" + break; + case 705: /* ordering_specification_opt ::= DESC */ +#line 1489 "sql.y" +{ yymsp[0].minor.yy638 = ORDER_DESC; } +#line 8302 "sql.c" + break; + case 706: /* null_ordering_opt ::= */ +#line 1493 "sql.y" +{ yymsp[1].minor.yy907 = NULL_ORDER_DEFAULT; } +#line 8307 "sql.c" + break; + case 707: /* null_ordering_opt ::= NULLS FIRST */ +#line 1494 "sql.y" +{ yymsp[-1].minor.yy907 = NULL_ORDER_FIRST; } +#line 8312 "sql.c" + break; + case 708: /* null_ordering_opt ::= NULLS LAST */ +#line 1495 "sql.y" +{ yymsp[-1].minor.yy907 = NULL_ORDER_LAST; } +#line 8317 "sql.c" break; default: break; @@ -8307,7 +8387,7 @@ static void yy_syntax_error( } else if (TSDB_CODE_PAR_DB_NOT_SPECIFIED == pCxt->errCode && TK_NK_FLOAT == TOKEN.type) { pCxt->errCode = generateSyntaxErrMsg(&pCxt->msgBuf, TSDB_CODE_PAR_SYNTAX_ERROR, TOKEN.z); } -#line 8310 "sql.c" +#line 8390 "sql.c" /************ End %syntax_error code ******************************************/ ParseARG_STORE /* Suppress warning about unused %extra_argument variable */ ParseCTX_STORE diff --git a/source/libs/transport/src/transComm.c b/source/libs/transport/src/transComm.c index 27099c76fc..fff13e7ebb 100644 --- a/source/libs/transport/src/transComm.c +++ b/source/libs/transport/src/transComm.c @@ -70,7 +70,7 @@ int32_t transDecompressMsg(char** msg, int32_t len) { char* buf = taosMemoryCalloc(1, oriLen + sizeof(STransMsgHead)); STransMsgHead* pNewHead = (STransMsgHead*)buf; int32_t decompLen = LZ4_decompress_safe(pCont + sizeof(STransCompMsg), (char*)pNewHead->content, - len - sizeof(STransMsgHead) - sizeof(STransCompMsg), oriLen); + len - sizeof(STransMsgHead) - sizeof(STransCompMsg), oriLen); memcpy((char*)pNewHead, (char*)pHead, sizeof(STransMsgHead)); pNewHead->msgLen = htonl(oriLen + sizeof(STransMsgHead)); @@ -158,6 +158,10 @@ int transResetBuffer(SConnBuffer* connBuf) { p->left = -1; p->total = 0; p->len = 0; + if (p->cap > BUFFER_CAP) { + p->cap = BUFFER_CAP; + p->buf = taosMemoryRealloc(p->buf, p->cap); + } } else { ASSERTS(0, "invalid read from sock buf"); return -1; diff --git a/source/util/src/tlog.c b/source/util/src/tlog.c index 16ca1b64c3..0c09174970 100644 --- a/source/util/src/tlog.c +++ b/source/util/src/tlog.c @@ -242,6 +242,7 @@ void taosCloseLog() { taosMemoryFreeClear(tsLogObj.logHandle->buffer); taosThreadMutexDestroy(&tsLogObj.logMutex); taosMemoryFreeClear(tsLogObj.logHandle); + tsLogObj.logHandle = NULL; } } @@ -285,8 +286,11 @@ static void taosKeepOldLog(char *oldName) { taosRemoveOldFiles(tsLogDir, tsLogKeepDays); } } - -static void *taosThreadToOpenNewFile(void *param) { +typedef struct { + TdFilePtr pOldFile; + char keepName[LOG_FILE_NAME_LEN + 20]; +} OldFileKeeper; +static OldFileKeeper *taosOpenNewFile() { char keepName[LOG_FILE_NAME_LEN + 20]; sprintf(keepName, "%s.%d", tsLogObj.logName, tsLogObj.flag); @@ -312,13 +316,26 @@ static void *taosThreadToOpenNewFile(void *param) { tsLogObj.logHandle->pFile = pFile; tsLogObj.lines = 0; tsLogObj.openInProgress = 0; - taosSsleep(20); - taosCloseLogByFd(pOldFile); + OldFileKeeper* oldFileKeeper = taosMemoryMalloc(sizeof(OldFileKeeper)); + if (oldFileKeeper == NULL) { + uError("create old log keep info faild! mem is not enough."); + return NULL; + } + oldFileKeeper->pOldFile = pOldFile; + memcpy(oldFileKeeper->keepName, keepName, LOG_FILE_NAME_LEN + 20); uInfo(" new log file:%d is opened", tsLogObj.flag); uInfo("=================================="); - taosKeepOldLog(keepName); + return oldFileKeeper; +} +static void *taosThreadToCloseOldFile(void* param) { + if(!param) return NULL; + OldFileKeeper* oldFileKeeper = (OldFileKeeper*)param; + taosSsleep(20); + taosCloseLogByFd(oldFileKeeper->pOldFile); + taosKeepOldLog(oldFileKeeper->keepName); + taosMemoryFree(oldFileKeeper); return NULL; } @@ -334,7 +351,8 @@ static int32_t taosOpenNewLogFile() { taosThreadAttrInit(&attr); taosThreadAttrSetDetachState(&attr, PTHREAD_CREATE_DETACHED); - taosThreadCreate(&thread, &attr, taosThreadToOpenNewFile, NULL); + OldFileKeeper* oldFileKeeper = taosOpenNewFile(); + taosThreadCreate(&thread, &attr, taosThreadToCloseOldFile, oldFileKeeper); taosThreadAttrDestroy(&attr); } @@ -347,10 +365,11 @@ void taosResetLog() { // force create a new log file tsLogObj.lines = tsNumOfLogLines + 10; - taosOpenNewLogFile(); - - uInfo("=================================="); - uInfo(" reset log file "); + if (tsLogObj.logHandle) { + taosOpenNewLogFile(); + uInfo("=================================="); + uInfo(" reset log file "); + } } static bool taosCheckFileIsOpen(char *logFileName) { diff --git a/tests/system-test/2-query/cast.py b/tests/system-test/2-query/cast.py index ede1f28324..352395b830 100644 --- a/tests/system-test/2-query/cast.py +++ b/tests/system-test/2-query/cast.py @@ -79,6 +79,10 @@ class TDTestCase: tdSql.query(f"select cast(c1 as binary(32)) as b from {self.dbname}.t1") for i in range(len(data_t1_c1)): tdSql.checkData( i, 0, str(data_t1_c1[i]) ) + + tdSql.query(f"select cast(c1 as binary) as b from {self.dbname}.t1") + for i in range(len(data_t1_c1)): + tdSql.checkData( i, 0, str(data_t1_c1[i]) ) tdLog.printNoPrefix("==========step6: cast int to nchar, expect changes to str(int) ") @@ -130,6 +134,13 @@ class TDTestCase: tdSql.query(f"select cast(c2 as binary(32)) as b from {self.dbname}.t1") for i in range(len(data_t1_c2)): tdSql.checkData( i, 0, str(data_t1_c2[i]) ) + + tdSql.query(f"select cast(c2 as binary) as b from {self.dbname}.ct4") + for i in range(len(data_ct4_c2)): + tdSql.checkData( i, 0, str(data_ct4_c2[i]) ) + tdSql.query(f"select cast(c2 as binary) as b from {self.dbname}.t1") + for i in range(len(data_t1_c2)): + tdSql.checkData( i, 0, str(data_t1_c2[i]) ) tdLog.printNoPrefix("==========step10: cast bigint to nchar, expect changes to str(int) ") @@ -184,6 +195,13 @@ class TDTestCase: tdSql.query(f"select cast(c3 as binary(32)) as b from {self.dbname}.t1") for i in range(len(data_t1_c3)): tdSql.checkData( i, 0, str(data_t1_c3[i]) ) + + tdSql.query(f"select cast(c3 as binary) as b from {self.dbname}.ct4") + for i in range(len(data_ct4_c3)): + tdSql.checkData( i, 0, str(data_ct4_c3[i]) ) + tdSql.query(f"select cast(c3 as binary) as b from {self.dbname}.t1") + for i in range(len(data_t1_c3)): + tdSql.checkData( i, 0, str(data_t1_c3[i]) ) tdLog.printNoPrefix("==========step14: cast smallint to nchar, expect changes to str(int) ") @@ -235,6 +253,13 @@ class TDTestCase: tdSql.query(f"select cast(c4 as binary(32)) as b from {self.dbname}.t1") for i in range(len(data_t1_c4)): tdSql.checkData( i, 0, str(data_t1_c4[i]) ) + + tdSql.query(f"select cast(c4 as binary) as b from {self.dbname}.ct4") + for i in range(len(data_ct4_c4)): + tdSql.checkData( i, 0, str(data_ct4_c4[i]) ) + tdSql.query(f"select cast(c4 as binary) as b from {self.dbname}.t1") + for i in range(len(data_t1_c4)): + tdSql.checkData( i, 0, str(data_t1_c4[i]) ) tdLog.printNoPrefix("==========step18: cast tinyint to nchar, expect changes to str(int) ") @@ -282,6 +307,12 @@ class TDTestCase: for i in range(len(data_ct4_c5)): tdSql.checkData( i, 0, str(data_ct4_c5[i]) ) if data_ct4_c5[i] is None else tdSql.checkData( i, 0, f'{data_ct4_c5[i]:.6f}' ) tdSql.query(f"select cast(c5 as binary(32)) as b from {self.dbname}.t1") + for i in range(len(data_t1_c5)): + tdSql.checkData( i, 0, str(data_t1_c5[i]) ) if data_t1_c5[i] is None else tdSql.checkData( i, 0, f'{data_t1_c5[i]:.6f}' ) + tdSql.query(f"select cast(c5 as binary) as b from {self.dbname}.ct4") + for i in range(len(data_ct4_c5)): + tdSql.checkData( i, 0, str(data_ct4_c5[i]) ) if data_ct4_c5[i] is None else tdSql.checkData( i, 0, f'{data_ct4_c5[i]:.6f}' ) + tdSql.query(f"select cast(c5 as binary) as b from {self.dbname}.t1") for i in range(len(data_t1_c5)): tdSql.checkData( i, 0, str(data_t1_c5[i]) ) if data_t1_c5[i] is None else tdSql.checkData( i, 0, f'{data_t1_c5[i]:.6f}' ) @@ -290,6 +321,12 @@ class TDTestCase: for i in range(len(data_ct4_c5)): tdSql.checkData( i, 0, None ) if data_ct4_c5[i] is None else tdSql.checkData( i, 0, f'{data_ct4_c5[i]:.6f}' ) tdSql.query(f"select cast(c5 as nchar(32)) as b from {self.dbname}.t1") + for i in range(len(data_t1_c5)): + tdSql.checkData( i, 0, None ) if data_t1_c5[i] is None else tdSql.checkData( i, 0, f'{data_t1_c5[i]:.6f}' ) + tdSql.query(f"select cast(c5 as nchar) as b from {self.dbname}.t1") + for i in range(len(data_t1_c5)): + tdSql.checkData( i, 0, None ) if data_t1_c5[i] is None else tdSql.checkData( i, 0, f'{data_t1_c5[i]:.6f}' ) + tdSql.query(f"select cast(c5 as varchar) as b from {self.dbname}.t1") for i in range(len(data_t1_c5)): tdSql.checkData( i, 0, None ) if data_t1_c5[i] is None else tdSql.checkData( i, 0, f'{data_t1_c5[i]:.6f}' ) @@ -580,6 +617,10 @@ class TDTestCase: ( tdSql.checkData(i, 0, '12121.233231') for i in range(tdSql.queryRows) ) tdSql.query(f"select cast(12121.23323131 + 'test~!@`#$%^&*(){'}'}{'{'}][;><.,' as binary(2)) as b from {self.dbname}.ct4") ( tdSql.checkData(i, 0, '12') for i in range(tdSql.queryRows) ) + tdSql.query(f"select cast(12121.23323131 + 'test~!@`#$%^&*(){'}'}{'{'}][;><.,' as binary) as b from {self.dbname}.ct4") + ( tdSql.checkData(i, 0, '12121.233231') for i in range(tdSql.queryRows) ) + tdSql.query(f"select cast(12121.23323131 + 'test~!@`#$%^&*(){'}'}{'{'}][;><.,' as binary) as b from {self.dbname}.ct4") + ( tdSql.checkData(i, 0, '12') for i in range(tdSql.queryRows) ) tdSql.query(f"select cast(12121.23323131 + 'test~!@`#$%^&*(){'}'}{'{'}][;><.,' as nchar(16)) as b from {self.dbname}.ct4") ( tdSql.checkData(i, 0, '12121.233231') for i in range(tdSql.queryRows) ) tdSql.query(f"select cast(12121.23323131 + 'test~!@`#$%^&*(){'}'}{'{'}][;><.,' as nchar(2)) as b from {self.dbname}.ct4")