提交 5342e859 编写于 作者: dengyihao's avatar dengyihao

TD-2571

上级 72719cc6
...@@ -16,105 +16,106 @@ ...@@ -16,105 +16,106 @@
#ifndef TDENGINE_TTOKENDEF_H #ifndef TDENGINE_TTOKENDEF_H
#define TDENGINE_TTOKENDEF_H #define TDENGINE_TTOKENDEF_H
#define TK_ID 1
#define TK_BOOL 2 #define TK_ID 1
#define TK_TINYINT 3 #define TK_BOOL 2
#define TK_SMALLINT 4 #define TK_TINYINT 3
#define TK_INTEGER 5 #define TK_SMALLINT 4
#define TK_BIGINT 6 #define TK_INTEGER 5
#define TK_FLOAT 7 #define TK_BIGINT 6
#define TK_DOUBLE 8 #define TK_FLOAT 7
#define TK_STRING 9 #define TK_DOUBLE 8
#define TK_TIMESTAMP 10 #define TK_STRING 9
#define TK_BINARY 11 #define TK_TIMESTAMP 10
#define TK_NCHAR 12 #define TK_BINARY 11
#define TK_OR 13 #define TK_NCHAR 12
#define TK_AND 14 #define TK_OR 13
#define TK_NOT 15 #define TK_AND 14
#define TK_EQ 16 #define TK_NOT 15
#define TK_NE 17 #define TK_EQ 16
#define TK_ISNULL 18 #define TK_NE 17
#define TK_NOTNULL 19 #define TK_ISNULL 18
#define TK_IS 20 #define TK_NOTNULL 19
#define TK_LIKE 21 #define TK_IS 20
#define TK_GLOB 22 #define TK_LIKE 21
#define TK_BETWEEN 23 #define TK_GLOB 22
#define TK_IN 24 #define TK_BETWEEN 23
#define TK_GT 25 #define TK_IN 24
#define TK_GE 26 #define TK_GT 25
#define TK_LT 27 #define TK_GE 26
#define TK_LE 28 #define TK_LT 27
#define TK_BITAND 29 #define TK_LE 28
#define TK_BITOR 30 #define TK_BITAND 29
#define TK_LSHIFT 31 #define TK_BITOR 30
#define TK_RSHIFT 32 #define TK_LSHIFT 31
#define TK_PLUS 33 #define TK_RSHIFT 32
#define TK_MINUS 34 #define TK_PLUS 33
#define TK_DIVIDE 35 #define TK_MINUS 34
#define TK_TIMES 36 #define TK_DIVIDE 35
#define TK_STAR 37 #define TK_TIMES 36
#define TK_SLASH 38 #define TK_STAR 37
#define TK_REM 39 #define TK_SLASH 38
#define TK_CONCAT 40 #define TK_REM 39
#define TK_UMINUS 41 #define TK_CONCAT 40
#define TK_UPLUS 42 #define TK_UMINUS 41
#define TK_BITNOT 43 #define TK_UPLUS 42
#define TK_SHOW 44 #define TK_BITNOT 43
#define TK_DATABASES 45 #define TK_SHOW 44
#define TK_MNODES 46 #define TK_DATABASES 45
#define TK_DNODES 47 #define TK_MNODES 46
#define TK_ACCOUNTS 48 #define TK_DNODES 47
#define TK_USERS 49 #define TK_ACCOUNTS 48
#define TK_MODULES 50 #define TK_USERS 49
#define TK_QUERIES 51 #define TK_MODULES 50
#define TK_CONNECTIONS 52 #define TK_QUERIES 51
#define TK_STREAMS 53 #define TK_CONNECTIONS 52
#define TK_VARIABLES 54 #define TK_STREAMS 53
#define TK_SCORES 55 #define TK_VARIABLES 54
#define TK_GRANTS 56 #define TK_SCORES 55
#define TK_VNODES 57 #define TK_GRANTS 56
#define TK_IPTOKEN 58 #define TK_VNODES 57
#define TK_DOT 59 #define TK_IPTOKEN 58
#define TK_CREATE 60 #define TK_DOT 59
#define TK_TABLE 61 #define TK_CREATE 60
#define TK_DATABASE 62 #define TK_TABLE 61
#define TK_TABLES 63 #define TK_DATABASE 62
#define TK_STABLES 64 #define TK_TABLES 63
#define TK_VGROUPS 65 #define TK_STABLES 64
#define TK_DROP 66 #define TK_VGROUPS 65
#define TK_DNODE 67 #define TK_DROP 66
#define TK_USER 68 #define TK_DNODE 67
#define TK_ACCOUNT 69 #define TK_USER 68
#define TK_USE 70 #define TK_ACCOUNT 69
#define TK_DESCRIBE 71 #define TK_USE 70
#define TK_ALTER 72 #define TK_DESCRIBE 71
#define TK_PASS 73 #define TK_ALTER 72
#define TK_PRIVILEGE 74 #define TK_PASS 73
#define TK_LOCAL 75 #define TK_PRIVILEGE 74
#define TK_IF 76 #define TK_LOCAL 75
#define TK_EXISTS 77 #define TK_IF 76
#define TK_PPS 78 #define TK_EXISTS 77
#define TK_TSERIES 79 #define TK_PPS 78
#define TK_DBS 80 #define TK_TSERIES 79
#define TK_STORAGE 81 #define TK_DBS 80
#define TK_QTIME 82 #define TK_STORAGE 81
#define TK_CONNS 83 #define TK_QTIME 82
#define TK_STATE 84 #define TK_CONNS 83
#define TK_KEEP 85 #define TK_STATE 84
#define TK_CACHE 86 #define TK_KEEP 85
#define TK_REPLICA 87 #define TK_CACHE 86
#define TK_QUORUM 88 #define TK_REPLICA 87
#define TK_DAYS 89 #define TK_QUORUM 88
#define TK_MINROWS 90 #define TK_DAYS 89
#define TK_MAXROWS 91 #define TK_MINROWS 90
#define TK_BLOCKS 92 #define TK_MAXROWS 91
#define TK_CTIME 93 #define TK_BLOCKS 92
#define TK_WAL 94 #define TK_CTIME 93
#define TK_FSYNC 95 #define TK_WAL 94
#define TK_COMP 96 #define TK_FSYNC 95
#define TK_PRECISION 97 #define TK_COMP 96
#define TK_UPDATE 98 #define TK_PRECISION 97
#define TK_CACHELAST 99 #define TK_UPDATE 98
#define TK_CACHELAST 99
#define TK_LP 100 #define TK_LP 100
#define TK_RP 101 #define TK_RP 101
#define TK_UNSIGNED 102 #define TK_UNSIGNED 102
...@@ -126,105 +127,105 @@ ...@@ -126,105 +127,105 @@
#define TK_SELECT 108 #define TK_SELECT 108
#define TK_UNION 109 #define TK_UNION 109
#define TK_ALL 110 #define TK_ALL 110
#define TK_FROM 111 #define TK_DISTINCT 111
#define TK_VARIABLE 112 #define TK_FROM 112
#define TK_INTERVAL 113 #define TK_VARIABLE 113
#define TK_FILL 114 #define TK_INTERVAL 114
#define TK_SLIDING 115 #define TK_FILL 115
#define TK_ORDER 116 #define TK_SLIDING 116
#define TK_BY 117 #define TK_ORDER 117
#define TK_ASC 118 #define TK_BY 118
#define TK_DESC 119 #define TK_ASC 119
#define TK_GROUP 120 #define TK_DESC 120
#define TK_HAVING 121 #define TK_GROUP 121
#define TK_LIMIT 122 #define TK_HAVING 122
#define TK_OFFSET 123 #define TK_LIMIT 123
#define TK_SLIMIT 124 #define TK_OFFSET 124
#define TK_SOFFSET 125 #define TK_SLIMIT 125
#define TK_WHERE 126 #define TK_SOFFSET 126
#define TK_NOW 127 #define TK_WHERE 127
#define TK_RESET 128 #define TK_NOW 128
#define TK_QUERY 129 #define TK_RESET 129
#define TK_ADD 130 #define TK_QUERY 130
#define TK_COLUMN 131 #define TK_ADD 131
#define TK_TAG 132 #define TK_COLUMN 132
#define TK_CHANGE 133 #define TK_TAG 133
#define TK_SET 134 #define TK_CHANGE 134
#define TK_KILL 135 #define TK_SET 135
#define TK_CONNECTION 136 #define TK_KILL 136
#define TK_STREAM 137 #define TK_CONNECTION 137
#define TK_COLON 138 #define TK_STREAM 138
#define TK_ABORT 139 #define TK_COLON 139
#define TK_AFTER 140 #define TK_ABORT 140
#define TK_ATTACH 141 #define TK_AFTER 141
#define TK_BEFORE 142 #define TK_ATTACH 142
#define TK_BEGIN 143 #define TK_BEFORE 143
#define TK_CASCADE 144 #define TK_BEGIN 144
#define TK_CLUSTER 145 #define TK_CASCADE 145
#define TK_CONFLICT 146 #define TK_CLUSTER 146
#define TK_COPY 147 #define TK_CONFLICT 147
#define TK_DEFERRED 148 #define TK_COPY 148
#define TK_DELIMITERS 149 #define TK_DEFERRED 149
#define TK_DETACH 150 #define TK_DELIMITERS 150
#define TK_EACH 151 #define TK_DETACH 151
#define TK_END 152 #define TK_EACH 152
#define TK_EXPLAIN 153 #define TK_END 153
#define TK_FAIL 154 #define TK_EXPLAIN 154
#define TK_FOR 155 #define TK_FAIL 155
#define TK_IGNORE 156 #define TK_FOR 156
#define TK_IMMEDIATE 157 #define TK_IGNORE 157
#define TK_INITIALLY 158 #define TK_IMMEDIATE 158
#define TK_INSTEAD 159 #define TK_INITIALLY 159
#define TK_MATCH 160 #define TK_INSTEAD 160
#define TK_KEY 161 #define TK_MATCH 161
#define TK_OF 162 #define TK_KEY 162
#define TK_RAISE 163 #define TK_OF 163
#define TK_REPLACE 164 #define TK_RAISE 164
#define TK_RESTRICT 165 #define TK_REPLACE 165
#define TK_ROW 166 #define TK_RESTRICT 166
#define TK_STATEMENT 167 #define TK_ROW 167
#define TK_TRIGGER 168 #define TK_STATEMENT 168
#define TK_VIEW 169 #define TK_TRIGGER 169
#define TK_COUNT 170 #define TK_VIEW 170
#define TK_SUM 171 #define TK_COUNT 171
#define TK_AVG 172 #define TK_SUM 172
#define TK_MIN 173 #define TK_AVG 173
#define TK_MAX 174 #define TK_MIN 174
#define TK_FIRST 175 #define TK_MAX 175
#define TK_LAST 176 #define TK_FIRST 176
#define TK_TOP 177 #define TK_LAST 177
#define TK_BOTTOM 178 #define TK_TOP 178
#define TK_STDDEV 179 #define TK_BOTTOM 179
#define TK_PERCENTILE 180 #define TK_STDDEV 180
#define TK_APERCENTILE 181 #define TK_PERCENTILE 181
#define TK_LEASTSQUARES 182 #define TK_APERCENTILE 182
#define TK_HISTOGRAM 183 #define TK_LEASTSQUARES 183
#define TK_DIFF 184 #define TK_HISTOGRAM 184
#define TK_SPREAD 185 #define TK_DIFF 185
#define TK_TWA 186 #define TK_SPREAD 186
#define TK_INTERP 187 #define TK_TWA 187
#define TK_LAST_ROW 188 #define TK_INTERP 188
#define TK_RATE 189 #define TK_LAST_ROW 189
#define TK_IRATE 190 #define TK_RATE 190
#define TK_SUM_RATE 191 #define TK_IRATE 191
#define TK_SUM_IRATE 192 #define TK_SUM_RATE 192
#define TK_AVG_RATE 193 #define TK_SUM_IRATE 193
#define TK_AVG_IRATE 194 #define TK_AVG_RATE 194
#define TK_TBID 195 #define TK_AVG_IRATE 195
#define TK_SEMI 196 #define TK_TBID 196
#define TK_NONE 197 #define TK_SEMI 197
#define TK_PREV 198 #define TK_NONE 198
#define TK_LINEAR 199 #define TK_PREV 199
#define TK_IMPORT 200 #define TK_LINEAR 200
#define TK_METRIC 201 #define TK_IMPORT 201
#define TK_TBNAME 202 #define TK_METRIC 202
#define TK_JOIN 203 #define TK_TBNAME 203
#define TK_METRICS 204 #define TK_JOIN 204
#define TK_STABLE 205 #define TK_METRICS 205
#define TK_INSERT 206 #define TK_STABLE 206
#define TK_INTO 207 #define TK_INSERT 207
#define TK_VALUES 208 #define TK_INTO 208
#define TK_VALUES 209
#define TK_SPACE 300 #define TK_SPACE 300
......
...@@ -206,6 +206,7 @@ typedef struct tSQLExpr { ...@@ -206,6 +206,7 @@ typedef struct tSQLExpr {
typedef struct tSqlExprItem { typedef struct tSqlExprItem {
tSQLExpr *pNode; // The list of expressions tSQLExpr *pNode; // The list of expressions
char * aliasName; // alias name, null-terminated string char * aliasName; // alias name, null-terminated string
bool distinct;
} tSqlExprItem; } tSqlExprItem;
// todo refactor by using SArray // todo refactor by using SArray
...@@ -238,7 +239,7 @@ tSQLExpr *tSqlExprCreate(tSQLExpr *pLeft, tSQLExpr *pRight, int32_t optrType); ...@@ -238,7 +239,7 @@ tSQLExpr *tSqlExprCreate(tSQLExpr *pLeft, tSQLExpr *pRight, int32_t optrType);
void tSqlExprDestroy(tSQLExpr *pExpr); void tSqlExprDestroy(tSQLExpr *pExpr);
tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken *pToken); tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken *pDistinct, SStrToken *pToken);
void tSqlExprListDestroy(tSQLExprList *pList); void tSqlExprListDestroy(tSQLExprList *pList);
......
...@@ -448,13 +448,13 @@ select(A) ::= SELECT(T) selcollist(W). { ...@@ -448,13 +448,13 @@ select(A) ::= SELECT(T) selcollist(W). {
%destructor sclp {tSqlExprListDestroy($$);} %destructor sclp {tSqlExprListDestroy($$);}
sclp(A) ::= selcollist(X) COMMA. {A = X;} sclp(A) ::= selcollist(X) COMMA. {A = X;}
sclp(A) ::= . {A = 0;} sclp(A) ::= . {A = 0;}
selcollist(A) ::= sclp(P) expr(X) as(Y). { selcollist(A) ::= sclp(P) distinct(Z) expr(X) as(Y). {
A = tSqlExprListAppend(P, X, Y.n?&Y:0); A = tSqlExprListAppend(P, X, Z.n? &Z:0, Y.n?&Y:0);
} }
selcollist(A) ::= sclp(P) STAR. { selcollist(A) ::= sclp(P) STAR. {
tSQLExpr *pNode = tSqlExprIdValueCreate(NULL, TK_ALL); tSQLExpr *pNode = tSqlExprIdValueCreate(NULL, TK_ALL);
A = tSqlExprListAppend(P, pNode, 0); A = tSqlExprListAppend(P, pNode, 0, 0);
} }
// An option "AS <id>" phrase that can follow one of the expressions that // An option "AS <id>" phrase that can follow one of the expressions that
...@@ -465,6 +465,10 @@ as(X) ::= AS ids(Y). { X = Y; } ...@@ -465,6 +465,10 @@ as(X) ::= AS ids(Y). { X = Y; }
as(X) ::= ids(Y). { X = Y; } as(X) ::= ids(Y). { X = Y; }
as(X) ::= . { X.n = 0; } as(X) ::= . { X.n = 0; }
%type distinct {SStrToken}
distinct(X) ::= DISTINCT(Y). { X = Y; }
distinct(X) ::= . { X.n = 0;}
// A complete FROM clause. // A complete FROM clause.
%type from {SArray*} %type from {SArray*}
// current not support query from no-table // current not support query from no-table
...@@ -672,8 +676,8 @@ expr(A) ::= expr(X) IN LP exprlist(Y) RP. {A = tSqlExprCreate(X, (tSQLExpr*)Y, ...@@ -672,8 +676,8 @@ expr(A) ::= expr(X) IN LP exprlist(Y) RP. {A = tSqlExprCreate(X, (tSQLExpr*)Y,
%type expritem {tSQLExpr*} %type expritem {tSQLExpr*}
%destructor expritem {tSqlExprDestroy($$);} %destructor expritem {tSqlExprDestroy($$);}
exprlist(A) ::= exprlist(X) COMMA expritem(Y). {A = tSqlExprListAppend(X,Y,0);} exprlist(A) ::= exprlist(X) COMMA expritem(Y). {A = tSqlExprListAppend(X,Y,0, 0);}
exprlist(A) ::= expritem(X). {A = tSqlExprListAppend(0,X,0);} exprlist(A) ::= expritem(X). {A = tSqlExprListAppend(0,X,0, 0);}
expritem(A) ::= expr(X). {A = X;} expritem(A) ::= expr(X). {A = X;}
expritem(A) ::= . {A = 0;} expritem(A) ::= . {A = 0;}
......
...@@ -71,7 +71,7 @@ abort_parse: ...@@ -71,7 +71,7 @@ abort_parse:
return sqlInfo; return sqlInfo;
} }
tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken *pToken) { tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken *pDistinct, SStrToken *pToken) {
if (pList == NULL) { if (pList == NULL) {
pList = calloc(1, sizeof(tSQLExprList)); pList = calloc(1, sizeof(tSQLExprList));
} }
...@@ -97,6 +97,7 @@ tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken ...@@ -97,6 +97,7 @@ tSQLExprList *tSqlExprListAppend(tSQLExprList *pList, tSQLExpr *pNode, SStrToken
strdequote(pItem->aliasName); strdequote(pItem->aliasName);
} }
pItem->distinct = (pDistinct != NULL);
} }
return pList; return pList;
} }
......
...@@ -240,6 +240,7 @@ static SKeyword keywordTable[] = { ...@@ -240,6 +240,7 @@ static SKeyword keywordTable[] = {
{"AVG_RATE", TK_AVG_RATE}, {"AVG_RATE", TK_AVG_RATE},
{"AVG_IRATE", TK_AVG_IRATE}, {"AVG_IRATE", TK_AVG_IRATE},
{"CACHELAST", TK_CACHELAST}, {"CACHELAST", TK_CACHELAST},
{"DISTINCT", TK_DISTINCT},
}; };
static const char isIdChar[] = { static const char isIdChar[] = {
......
/* /* Driver template for the LEMON parser generator.
** 2000-05-29 ** The author disclaims copyright to this source code.
**
** The author disclaims copyright to this source code. In place of
** a legal notice, here is a blessing:
**
** May you do good and not evil.
** May you find forgiveness for yourself and forgive others.
** May you share freely, never taking more than you give.
**
*************************************************************************
** Driver template for the LEMON parser generator.
**
** The "lemon" program processes an LALR(1) input grammar file, then uses
** this template to construct a parser. The "lemon" program inserts text
** at each "%%" line. Also, any "P-a-r-s-e" identifer prefix (without the
** interstitial "-" characters) contained in this template is changed into
** the value of the %name directive from the grammar. Otherwise, the content
** of this template is copied straight through into the generate parser
** source file.
**
** The following is the concatenation of all %include directives from the
** input grammar file:
*/ */
/* First off, code is included that follows the "include" declaration
** in the input grammar file. */
#include <stdio.h> #include <stdio.h>
/************ Begin %include sections from the grammar ************************/ #line 23 "sql.y"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
...@@ -36,88 +17,78 @@ ...@@ -36,88 +17,78 @@
#include "ttokendef.h" #include "ttokendef.h"
#include "tutil.h" #include "tutil.h"
#include "tvariant.h" #include "tvariant.h"
/**************** End of %include directives **********************************/ #line 21 "sql.c"
/* These constants specify the various numeric values for terminal symbols /* Next is all token values, in a form suitable for use by makeheaders.
** in a format understandable to "makeheaders". This section is blank unless ** This section will be null unless lemon is run with the -m switch.
** "lemon" is run with the "-m" command-line option. */
***************** Begin makeheaders token definitions *************************/ /*
/**************** End makeheaders token definitions ***************************/ ** These constants (all generated automatically by the parser generator)
** specify the various kinds of tokens (terminals) that the parser
/* The next sections is a series of control #defines. ** understands.
**
** Each symbol here is a terminal symbol in the grammar.
*/
/* Make sure the INTERFACE macro is defined.
*/
#ifndef INTERFACE
# define INTERFACE 1
#endif
/* The next thing included is series of defines which control
** various aspects of the generated parser. ** various aspects of the generated parser.
** YYCODETYPE is the data type used to store the integer codes ** YYCODETYPE is the data type used for storing terminal
** that represent terminal and non-terminal symbols. ** and nonterminal numbers. "unsigned char" is
** "unsigned char" is used if there are fewer than ** used if there are fewer than 250 terminals
** 256 symbols. Larger types otherwise. ** and nonterminals. "int" is used otherwise.
** YYNOCODE is a number of type YYCODETYPE that is not used for ** YYNOCODE is a number of type YYCODETYPE which corresponds
** any terminal or nonterminal symbol. ** to no legal terminal or nonterminal number. This
** number is used to fill in empty slots of the hash
** table.
** YYFALLBACK If defined, this indicates that one or more tokens ** YYFALLBACK If defined, this indicates that one or more tokens
** (also known as: "terminal symbols") have fall-back ** have fall-back values which should be used if the
** values which should be used if the original symbol ** original value of the token will not parse.
** would not parse. This permits keywords to sometimes ** YYACTIONTYPE is the data type used for storing terminal
** be used as identifiers, for example. ** and nonterminal numbers. "unsigned char" is
** YYACTIONTYPE is the data type used for "action codes" - numbers ** used if there are fewer than 250 rules and
** that indicate what to do in response to the next ** states combined. "int" is used otherwise.
** token. ** ParseTOKENTYPE is the data type used for minor tokens given
** ParseTOKENTYPE is the data type used for minor type for terminal ** directly to the parser from the tokenizer.
** symbols. Background: A "minor type" is a semantic ** YYMINORTYPE is the data type used for all minor tokens.
** value associated with a terminal or non-terminal
** symbols. For example, for an "ID" terminal symbol,
** the minor type might be the name of the identifier.
** Each non-terminal can have a different minor type.
** Terminal symbols all have the same minor type, though.
** This macros defines the minor type for terminal
** symbols.
** YYMINORTYPE is the data type used for all minor types.
** This is typically a union of many types, one of ** This is typically a union of many types, one of
** which is ParseTOKENTYPE. The entry in the union ** which is ParseTOKENTYPE. The entry in the union
** for terminal symbols is called "yy0". ** for base tokens is called "yy0".
** YYSTACKDEPTH is the maximum depth of the parser's stack. If ** YYSTACKDEPTH is the maximum depth of the parser's stack. If
** zero the stack is dynamically sized using realloc() ** zero the stack is dynamically sized using realloc()
** ParseARG_SDECL A static variable declaration for the %extra_argument ** ParseARG_SDECL A static variable declaration for the %extra_argument
** ParseARG_PDECL A parameter declaration for the %extra_argument ** ParseARG_PDECL A parameter declaration for the %extra_argument
** ParseARG_STORE Code to store %extra_argument into yypParser ** ParseARG_STORE Code to store %extra_argument into yypParser
** ParseARG_FETCH Code to extract %extra_argument from yypParser ** ParseARG_FETCH Code to extract %extra_argument from yypParser
** YYERRORSYMBOL is the code number of the error symbol. If not
** defined, then do no error processing.
** YYNSTATE the combined number of states. ** YYNSTATE the combined number of states.
** YYNRULE the number of rules in the grammar ** YYNRULE the number of rules in the grammar
** YYNTOKEN Number of terminal symbols ** YYERRORSYMBOL is the code number of the error symbol. If not
** YY_MAX_SHIFT Maximum value for shift actions ** defined, then do no error processing.
** YY_MIN_SHIFTREDUCE Minimum value for shift-reduce actions
** YY_MAX_SHIFTREDUCE Maximum value for shift-reduce actions
** YY_ERROR_ACTION The yy_action[] code for syntax error
** YY_ACCEPT_ACTION The yy_action[] code for accept
** YY_NO_ACTION The yy_action[] code for no-op
** YY_MIN_REDUCE Minimum value for reduce actions
** YY_MAX_REDUCE Maximum value for reduce actions
*/ */
#ifndef INTERFACE
# define INTERFACE 1
#endif
/************* Begin control #defines *****************************************/
#define YYCODETYPE unsigned short int #define YYCODETYPE unsigned short int
#define YYNOCODE 279 #define YYNOCODE 281
#define YYACTIONTYPE unsigned short int #define YYACTIONTYPE unsigned short int
#define ParseTOKENTYPE SStrToken #define ParseTOKENTYPE SStrToken
typedef union { typedef union {
int yyinit; int yyinit;
ParseTOKENTYPE yy0; ParseTOKENTYPE yy0;
SCreateTableSQL* yy38; tSQLExpr* yy50;
SCreateAcctSQL yy71; SCreateAcctSQL yy79;
tSQLExpr* yy78; tVariant yy106;
int yy96; int64_t yy109;
SQuerySQL* yy148; int yy172;
SCreatedTableInfo yy152; tSQLExprList* yy178;
SSubclauseInfo* yy153; SArray* yy221;
tSQLExprList* yy166; SSubclauseInfo* yy273;
SLimitVal yy167; SIntervalVal yy280;
TAOS_FIELD yy183; SQuerySQL* yy344;
SCreateDBInfo yy234; SCreateTableSQL* yy358;
int64_t yy325; SCreatedTableInfo yy416;
SIntervalVal yy400; SLimitVal yy454;
SArray* yy421; SCreateDBInfo yy478;
tVariant yy430; TAOS_FIELD yy503;
} YYMINORTYPE; } YYMINORTYPE;
#ifndef YYSTACKDEPTH #ifndef YYSTACKDEPTH
#define YYSTACKDEPTH 100 #define YYSTACKDEPTH 100
...@@ -126,19 +97,16 @@ typedef union { ...@@ -126,19 +97,16 @@ typedef union {
#define ParseARG_PDECL ,SSqlInfo* pInfo #define ParseARG_PDECL ,SSqlInfo* pInfo
#define ParseARG_FETCH SSqlInfo* pInfo = yypParser->pInfo #define ParseARG_FETCH SSqlInfo* pInfo = yypParser->pInfo
#define ParseARG_STORE yypParser->pInfo = pInfo #define ParseARG_STORE yypParser->pInfo = pInfo
#define YYNSTATE 433
#define YYNRULE 242
#define YYFALLBACK 1 #define YYFALLBACK 1
#define YYNSTATE 258 #define YY_NO_ACTION (YYNSTATE+YYNRULE+2)
#define YYNRULE 240 #define YY_ACCEPT_ACTION (YYNSTATE+YYNRULE+1)
#define YYNTOKEN 209 #define YY_ERROR_ACTION (YYNSTATE+YYNRULE)
#define YY_MAX_SHIFT 257
#define YY_MIN_SHIFTREDUCE 431 /* The yyzerominor constant is used to initialize instances of
#define YY_MAX_SHIFTREDUCE 670 ** YYMINORTYPE objects to zero. */
#define YY_ERROR_ACTION 671 static const YYMINORTYPE yyzerominor = { 0 };
#define YY_ACCEPT_ACTION 672
#define YY_NO_ACTION 673
#define YY_MIN_REDUCE 674
#define YY_MAX_REDUCE 913
/************* End control #defines *******************************************/
/* Define the yytestcase() macro to be a no-op if is not already defined /* Define the yytestcase() macro to be a no-op if is not already defined
** otherwise. ** otherwise.
...@@ -161,35 +129,33 @@ typedef union { ...@@ -161,35 +129,33 @@ typedef union {
** Suppose the action integer is N. Then the action is determined as ** Suppose the action integer is N. Then the action is determined as
** follows ** follows
** **
** 0 <= N <= YY_MAX_SHIFT Shift N. That is, push the lookahead ** 0 <= N < YYNSTATE Shift N. That is, push the lookahead
** token onto the stack and goto state N. ** token onto the stack and goto state N.
** **
** N between YY_MIN_SHIFTREDUCE Shift to an arbitrary state then ** YYNSTATE <= N < YYNSTATE+YYNRULE Reduce by rule N-YYNSTATE.
** and YY_MAX_SHIFTREDUCE reduce by rule N-YY_MIN_SHIFTREDUCE.
** **
** N == YY_ERROR_ACTION A syntax error has occurred. ** N == YYNSTATE+YYNRULE A syntax error has occurred.
** **
** N == YY_ACCEPT_ACTION The parser accepts its input. ** N == YYNSTATE+YYNRULE+1 The parser accepts its input.
** **
** N == YY_NO_ACTION No such action. Denotes unused ** N == YYNSTATE+YYNRULE+2 No such action. Denotes unused
** slots in the yy_action[] table. ** slots in the yy_action[] table.
** **
** N between YY_MIN_REDUCE Reduce by rule N-YY_MIN_REDUCE
** and YY_MAX_REDUCE
**
** The action table is constructed as a single large table named yy_action[]. ** The action table is constructed as a single large table named yy_action[].
** Given state S and lookahead X, the action is computed as either: ** Given state S and lookahead X, the action is computed as
** **
** (A) N = yy_action[ yy_shift_ofst[S] + X ] ** yy_action[ yy_shift_ofst[S] + X ]
** (B) N = yy_default[S]
** **
** The (A) formula is preferred. The B formula is used instead if ** If the index value yy_shift_ofst[S]+X is out of range or if the value
** yy_lookahead[yy_shift_ofst[S]+X] is not equal to X. ** yy_lookahead[yy_shift_ofst[S]+X] is not equal to X or if yy_shift_ofst[S]
** is equal to YY_SHIFT_USE_DFLT, it means that the action is not in the table
** and that yy_default[S] should be used instead.
** **
** The formulas above are for computing the action when the lookahead is ** The formula above is for computing the action when the lookahead is
** a terminal symbol. If the lookahead is a non-terminal (as occurs after ** a terminal symbol. If the lookahead is a non-terminal (as occurs after
** a reduce action) then the yy_reduce_ofst[] array is used in place of ** a reduce action) then the yy_reduce_ofst[] array is used in place of
** the yy_shift_ofst[] array. ** the yy_shift_ofst[] array and YY_REDUCE_USE_DFLT is used in place of
** YY_SHIFT_USE_DFLT.
** **
** The following are the tables generated in this section: ** The following are the tables generated in this section:
** **
...@@ -201,235 +167,252 @@ typedef union { ...@@ -201,235 +167,252 @@ typedef union {
** yy_reduce_ofst[] For each state, the offset into yy_action for ** yy_reduce_ofst[] For each state, the offset into yy_action for
** shifting non-terminals after a reduce. ** shifting non-terminals after a reduce.
** yy_default[] Default action for each state. ** yy_default[] Default action for each state.
** */
*********** Begin parsing tables **********************************************/ #define YY_ACTTAB_COUNT (690)
#define YY_ACTTAB_COUNT (586)
static const YYACTIONTYPE yy_action[] = { static const YYACTIONTYPE yy_action[] = {
/* 0 */ 143, 474, 143, 23, 672, 257, 165, 547, 827, 475, /* 0 */ 417, 36, 35, 79, 83, 34, 33, 32, 416, 88,
/* 10 */ 900, 168, 901, 37, 38, 12, 39, 40, 816, 23, /* 10 */ 91, 82, 37, 38, 67, 39, 40, 85, 212, 174,
/* 20 */ 173, 31, 474, 474, 210, 43, 41, 45, 42, 805, /* 20 */ 31, 676, 258, 211, 43, 41, 45, 42, 255, 254,
/* 30 */ 475, 475, 163, 36, 35, 232, 231, 34, 33, 32, /* 30 */ 99, 172, 36, 35, 104, 102, 34, 33, 32, 37,
/* 40 */ 37, 38, 801, 39, 40, 816, 110, 173, 31, 162, /* 40 */ 38, 433, 39, 40, 9, 320, 174, 31, 66, 121,
/* 50 */ 255, 210, 43, 41, 45, 42, 176, 66, 802, 195, /* 50 */ 211, 43, 41, 45, 42, 34, 33, 32, 144, 36,
/* 60 */ 36, 35, 178, 824, 34, 33, 32, 432, 433, 434, /* 60 */ 35, 180, 266, 34, 33, 32, 37, 38, 289, 39,
/* 70 */ 435, 436, 437, 438, 439, 440, 441, 442, 443, 256, /* 70 */ 40, 356, 4, 174, 31, 144, 196, 211, 43, 41,
/* 80 */ 179, 225, 185, 37, 38, 805, 39, 40, 796, 242, /* 80 */ 45, 42, 65, 419, 168, 290, 36, 35, 417, 307,
/* 90 */ 173, 31, 143, 180, 210, 43, 41, 45, 42, 110, /* 90 */ 34, 33, 32, 90, 89, 38, 416, 39, 40, 233,
/* 100 */ 110, 167, 901, 36, 35, 57, 853, 34, 33, 32, /* 100 */ 232, 174, 31, 52, 57, 211, 43, 41, 45, 42,
/* 110 */ 17, 223, 250, 249, 222, 221, 220, 248, 219, 247, /* 110 */ 310, 321, 22, 318, 36, 35, 138, 136, 34, 33,
/* 120 */ 246, 245, 218, 244, 243, 803, 142, 774, 624, 762, /* 120 */ 32, 53, 96, 95, 94, 306, 182, 308, 369, 230,
/* 130 */ 763, 764, 765, 766, 767, 768, 769, 770, 771, 772, /* 130 */ 229, 134, 432, 431, 430, 429, 428, 427, 426, 425,
/* 140 */ 773, 775, 776, 38, 181, 39, 40, 229, 228, 173, /* 140 */ 424, 423, 422, 421, 257, 101, 325, 186, 337, 336,
/* 150 */ 31, 605, 606, 210, 43, 41, 45, 42, 207, 854, /* 150 */ 335, 334, 333, 332, 331, 330, 329, 328, 327, 326,
/* 160 */ 61, 205, 36, 35, 23, 110, 34, 33, 32, 188, /* 160 */ 324, 323, 420, 17, 224, 251, 250, 223, 222, 221,
/* 170 */ 39, 40, 23, 251, 173, 31, 192, 191, 210, 43, /* 170 */ 249, 220, 248, 247, 246, 219, 245, 244, 39, 40,
/* 180 */ 41, 45, 42, 34, 33, 32, 105, 36, 35, 104, /* 180 */ 23, 553, 174, 31, 189, 23, 211, 43, 41, 45,
/* 190 */ 147, 34, 33, 32, 172, 637, 805, 28, 628, 897, /* 190 */ 42, 193, 192, 11, 10, 36, 35, 111, 274, 34,
/* 200 */ 631, 177, 634, 802, 172, 637, 896, 13, 628, 230, /* 200 */ 33, 32, 173, 296, 19, 13, 305, 111, 300, 392,
/* 210 */ 631, 802, 634, 18, 172, 637, 794, 895, 628, 63, /* 210 */ 299, 391, 173, 296, 78, 77, 305, 235, 300, 351,
/* 220 */ 631, 28, 634, 155, 574, 62, 169, 170, 23, 156, /* 220 */ 299, 156, 231, 394, 351, 23, 397, 157, 396, 49,
/* 230 */ 209, 29, 197, 92, 91, 150, 169, 170, 77, 76, /* 230 */ 395, 93, 92, 151, 170, 171, 286, 285, 210, 43,
/* 240 */ 582, 17, 198, 250, 249, 159, 169, 170, 248, 626, /* 240 */ 41, 45, 42, 345, 170, 171, 134, 36, 35, 50,
/* 250 */ 247, 246, 245, 715, 244, 243, 133, 211, 780, 80, /* 250 */ 144, 34, 33, 32, 183, 184, 208, 226, 62, 169,
/* 260 */ 160, 778, 779, 18, 242, 234, 781, 802, 783, 784, /* 260 */ 290, 18, 178, 377, 351, 23, 379, 378, 281, 28,
/* 270 */ 782, 28, 785, 786, 43, 41, 45, 42, 724, 579, /* 270 */ 206, 376, 268, 374, 373, 375, 370, 372, 371, 134,
/* 280 */ 64, 133, 36, 35, 19, 627, 34, 33, 32, 3, /* 280 */ 3, 125, 17, 252, 251, 250, 73, 69, 72, 249,
/* 290 */ 124, 194, 225, 44, 910, 72, 68, 71, 158, 11, /* 290 */ 195, 248, 247, 246, 319, 245, 244, 159, 390, 48,
/* 300 */ 10, 566, 592, 44, 563, 636, 564, 107, 565, 793, /* 300 */ 389, 44, 177, 55, 351, 353, 388, 214, 317, 23,
/* 310 */ 22, 795, 630, 44, 633, 636, 716, 36, 35, 133, /* 310 */ 295, 44, 24, 24, 297, 14, 291, 304, 302, 303,
/* 320 */ 635, 34, 33, 32, 171, 636, 596, 49, 78, 82, /* 320 */ 301, 14, 181, 64, 297, 277, 278, 276, 393, 298,
/* 330 */ 635, 48, 182, 183, 87, 90, 81, 137, 135, 629, /* 330 */ 15, 48, 108, 265, 417, 58, 105, 266, 81, 298,
/* 340 */ 635, 632, 84, 95, 94, 93, 50, 9, 145, 640, /* 340 */ 111, 198, 416, 243, 28, 111, 267, 106, 358, 18,
/* 350 */ 52, 65, 120, 254, 253, 98, 597, 656, 638, 555, /* 350 */ 179, 164, 166, 269, 352, 163, 256, 28, 100, 409,
/* 360 */ 146, 15, 14, 14, 24, 4, 55, 53, 546, 213, /* 360 */ 48, 387, 386, 385, 384, 383, 382, 381, 380, 368,
/* 370 */ 556, 570, 148, 571, 24, 48, 568, 149, 569, 89, /* 370 */ 367, 366, 365, 388, 364, 388, 363, 362, 361, 24,
/* 380 */ 88, 103, 101, 153, 154, 152, 141, 151, 144, 804, /* 380 */ 357, 355, 354, 76, 74, 344, 47, 71, 343, 225,
/* 390 */ 864, 863, 818, 174, 860, 859, 175, 233, 826, 846, /* 390 */ 342, 341, 340, 339, 68, 66, 16, 215, 338, 8,
/* 400 */ 831, 833, 106, 121, 845, 122, 567, 119, 123, 726, /* 400 */ 213, 63, 309, 5, 199, 288, 282, 7, 21, 271,
/* 410 */ 217, 139, 26, 226, 102, 723, 28, 227, 909, 74, /* 410 */ 6, 20, 279, 167, 194, 110, 202, 109, 198, 275,
/* 420 */ 908, 906, 125, 744, 27, 25, 196, 140, 713, 591, /* 420 */ 56, 263, 262, 261, 191, 61, 190, 260, 188, 187,
/* 430 */ 83, 711, 85, 86, 199, 709, 708, 184, 54, 134, /* 430 */ 259, 253, 1, 2, 103, 415, 130, 131, 98, 97,
/* 440 */ 706, 164, 705, 704, 703, 702, 136, 700, 698, 696, /* 440 */ 133, 237, 410, 403, 240, 127, 316, 242, 28, 158,
/* 450 */ 694, 692, 138, 203, 58, 59, 51, 847, 815, 46, /* 450 */ 30, 117, 119, 129, 132, 217, 70, 216, 128, 241,
/* 460 */ 208, 206, 204, 202, 200, 30, 79, 235, 236, 237, /* 460 */ 238, 239, 359, 162, 236, 201, 80, 203, 116, 226,
/* 470 */ 238, 239, 240, 241, 161, 215, 216, 252, 670, 187, /* 470 */ 205, 207, 51, 284, 204, 46, 60, 165, 59, 677,
/* 480 */ 186, 669, 69, 189, 157, 190, 668, 193, 661, 707, /* 480 */ 139, 418, 414, 413, 412, 411, 137, 677, 408, 407,
/* 490 */ 197, 576, 60, 56, 593, 96, 128, 97, 127, 745, /* 490 */ 406, 405, 404, 677, 135, 185, 118, 402, 677, 197,
/* 500 */ 126, 130, 129, 131, 132, 701, 693, 113, 111, 118, /* 500 */ 115, 209, 401, 114, 234, 243, 113, 280, 112, 120,
/* 510 */ 116, 114, 112, 115, 800, 1, 117, 2, 166, 20, /* 510 */ 315, 264, 87, 54, 86, 400, 398, 677, 200, 677,
/* 520 */ 108, 201, 6, 598, 109, 7, 639, 5, 8, 21, /* 520 */ 84, 399, 677, 677, 29, 677, 677, 677, 287, 145,
/* 530 */ 16, 67, 212, 641, 214, 515, 65, 511, 509, 508, /* 530 */ 677, 283, 176, 314, 677, 677, 141, 677, 25, 27,
/* 540 */ 507, 504, 478, 224, 70, 47, 73, 75, 24, 549, /* 540 */ 360, 126, 350, 349, 75, 348, 228, 677, 346, 227,
/* 550 */ 548, 545, 499, 497, 489, 495, 491, 493, 487, 485, /* 550 */ 677, 677, 26, 140, 677, 218, 322, 124, 123, 122,
/* 560 */ 517, 516, 514, 513, 512, 510, 506, 505, 48, 476, /* 560 */ 107, 677, 273, 272, 677, 677, 677, 677, 677, 677,
/* 570 */ 447, 445, 674, 673, 673, 673, 673, 673, 673, 673, /* 570 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 580 */ 673, 673, 673, 673, 99, 100, /* 580 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 590 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 600 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 270,
/* 610 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 620 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 630 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 640 */ 677, 677, 677, 313, 175, 312, 311, 677, 677, 677,
/* 650 */ 677, 677, 677, 677, 347, 677, 677, 677, 677, 677,
/* 660 */ 677, 677, 677, 677, 677, 677, 677, 677, 677, 677,
/* 670 */ 152, 142, 153, 155, 154, 150, 149, 147, 146, 161,
/* 680 */ 160, 677, 294, 293, 292, 148, 143, 677, 677, 12,
}; };
static const YYCODETYPE yy_lookahead[] = { static const YYCODETYPE yy_lookahead[] = {
/* 0 */ 267, 1, 267, 213, 210, 211, 230, 5, 213, 9, /* 0 */ 1, 33, 34, 61, 62, 37, 38, 39, 9, 67,
/* 10 */ 277, 276, 277, 13, 14, 267, 16, 17, 251, 213, /* 10 */ 68, 69, 13, 14, 219, 16, 17, 75, 15, 20,
/* 20 */ 20, 21, 1, 1, 24, 25, 26, 27, 28, 253, /* 20 */ 21, 211, 212, 24, 25, 26, 27, 28, 63, 64,
/* 30 */ 9, 9, 265, 33, 34, 33, 34, 37, 38, 39, /* 30 */ 65, 59, 33, 34, 61, 62, 37, 38, 39, 13,
/* 40 */ 13, 14, 252, 16, 17, 251, 213, 20, 21, 212, /* 40 */ 14, 0, 16, 17, 100, 250, 20, 21, 104, 105,
/* 50 */ 213, 24, 25, 26, 27, 28, 250, 218, 252, 265, /* 50 */ 24, 25, 26, 27, 28, 37, 38, 39, 269, 33,
/* 60 */ 33, 34, 230, 268, 37, 38, 39, 45, 46, 47, /* 60 */ 34, 66, 252, 37, 38, 39, 13, 14, 279, 16,
/* 70 */ 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, /* 70 */ 17, 5, 100, 20, 21, 269, 266, 24, 25, 26,
/* 80 */ 66, 76, 60, 13, 14, 253, 16, 17, 249, 78, /* 80 */ 27, 28, 219, 59, 278, 279, 33, 34, 1, 1,
/* 90 */ 20, 21, 267, 213, 24, 25, 26, 27, 28, 213, /* 90 */ 37, 38, 39, 73, 74, 14, 9, 16, 17, 33,
/* 100 */ 213, 276, 277, 33, 34, 105, 273, 37, 38, 39, /* 100 */ 34, 20, 21, 106, 105, 24, 25, 26, 27, 28,
/* 110 */ 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, /* 110 */ 107, 248, 249, 250, 33, 34, 61, 62, 37, 38,
/* 120 */ 95, 96, 97, 98, 99, 245, 267, 229, 101, 231, /* 120 */ 39, 124, 67, 68, 69, 37, 131, 101, 218, 134,
/* 130 */ 232, 233, 234, 235, 236, 237, 238, 239, 240, 241, /* 130 */ 135, 221, 45, 46, 47, 48, 49, 50, 51, 52,
/* 140 */ 242, 243, 244, 14, 130, 16, 17, 133, 134, 20, /* 140 */ 53, 54, 55, 56, 57, 21, 230, 60, 232, 233,
/* 150 */ 21, 118, 119, 24, 25, 26, 27, 28, 271, 273, /* 150 */ 234, 235, 236, 237, 238, 239, 240, 241, 242, 243,
/* 160 */ 273, 275, 33, 34, 213, 213, 37, 38, 39, 129, /* 160 */ 244, 245, 58, 85, 86, 87, 88, 89, 90, 91,
/* 170 */ 16, 17, 213, 230, 20, 21, 136, 137, 24, 25, /* 170 */ 92, 93, 94, 95, 96, 97, 98, 99, 16, 17,
/* 180 */ 26, 27, 28, 37, 38, 39, 213, 33, 34, 100, /* 180 */ 214, 0, 20, 21, 130, 214, 24, 25, 26, 27,
/* 190 */ 267, 37, 38, 39, 1, 2, 253, 108, 5, 267, /* 190 */ 28, 137, 138, 132, 133, 33, 34, 214, 106, 37,
/* 200 */ 7, 250, 9, 252, 1, 2, 267, 44, 5, 250, /* 200 */ 38, 39, 1, 2, 112, 44, 5, 214, 7, 5,
/* 210 */ 7, 252, 9, 100, 1, 2, 0, 267, 5, 254, /* 210 */ 9, 7, 1, 2, 132, 133, 5, 251, 7, 253,
/* 220 */ 7, 108, 9, 60, 101, 273, 33, 34, 213, 66, /* 220 */ 9, 60, 251, 2, 253, 214, 5, 66, 7, 106,
/* 230 */ 37, 266, 109, 70, 71, 72, 33, 34, 131, 132, /* 230 */ 9, 70, 71, 72, 33, 34, 119, 120, 37, 25,
/* 240 */ 37, 85, 269, 87, 88, 267, 33, 34, 92, 1, /* 240 */ 26, 27, 28, 218, 33, 34, 221, 33, 34, 126,
/* 250 */ 94, 95, 96, 217, 98, 99, 220, 15, 229, 73, /* 250 */ 269, 37, 38, 39, 33, 34, 273, 76, 275, 278,
/* 260 */ 267, 232, 233, 100, 78, 250, 237, 252, 239, 240, /* 260 */ 279, 100, 251, 230, 253, 214, 233, 234, 275, 108,
/* 270 */ 241, 108, 243, 244, 25, 26, 27, 28, 217, 106, /* 270 */ 277, 238, 37, 240, 241, 242, 218, 244, 245, 221,
/* 280 */ 218, 220, 33, 34, 111, 37, 37, 38, 39, 61, /* 280 */ 61, 62, 85, 231, 87, 88, 67, 68, 69, 92,
/* 290 */ 62, 128, 76, 100, 253, 67, 68, 69, 135, 131, /* 290 */ 129, 94, 95, 96, 101, 98, 99, 136, 5, 106,
/* 300 */ 132, 2, 101, 100, 5, 112, 7, 106, 9, 247, /* 300 */ 7, 100, 251, 100, 253, 102, 254, 101, 101, 214,
/* 310 */ 248, 249, 5, 100, 7, 112, 217, 33, 34, 220, /* 310 */ 101, 100, 106, 106, 113, 106, 101, 5, 5, 7,
/* 320 */ 127, 37, 38, 39, 59, 112, 101, 106, 61, 62, /* 320 */ 7, 106, 214, 255, 113, 101, 101, 101, 107, 128,
/* 330 */ 127, 106, 33, 34, 67, 68, 69, 61, 62, 5, /* 330 */ 106, 106, 106, 101, 1, 267, 100, 252, 73, 128,
/* 340 */ 127, 7, 75, 67, 68, 69, 125, 100, 267, 107, /* 340 */ 214, 109, 9, 78, 108, 214, 111, 214, 253, 100,
/* 350 */ 106, 104, 105, 63, 64, 65, 101, 101, 101, 101, /* 350 */ 231, 266, 231, 214, 246, 213, 214, 108, 21, 77,
/* 360 */ 267, 106, 106, 106, 106, 100, 100, 123, 102, 101, /* 360 */ 106, 5, 5, 5, 5, 5, 5, 5, 5, 5,
/* 370 */ 101, 5, 267, 7, 106, 106, 5, 267, 7, 73, /* 370 */ 5, 5, 5, 254, 5, 254, 5, 5, 5, 106,
/* 380 */ 74, 61, 62, 267, 267, 267, 267, 267, 267, 253, /* 380 */ 101, 5, 5, 133, 133, 77, 16, 73, 5, 15,
/* 390 */ 246, 246, 251, 246, 246, 246, 246, 246, 213, 274, /* 390 */ 5, 5, 5, 5, 73, 104, 100, 103, 9, 100,
/* 400 */ 213, 213, 213, 213, 274, 213, 107, 255, 213, 213, /* 400 */ 103, 275, 107, 100, 271, 101, 275, 118, 106, 270,
/* 410 */ 213, 213, 213, 213, 59, 213, 108, 213, 213, 213, /* 410 */ 118, 106, 101, 1, 130, 100, 100, 100, 109, 101,
/* 420 */ 213, 213, 213, 213, 213, 213, 251, 213, 213, 112, /* 420 */ 110, 101, 86, 5, 5, 106, 139, 5, 5, 139,
/* 430 */ 213, 213, 213, 213, 270, 213, 213, 213, 122, 213, /* 430 */ 5, 76, 220, 217, 59, 215, 226, 224, 216, 216,
/* 440 */ 213, 270, 213, 213, 213, 213, 213, 213, 213, 213, /* 440 */ 222, 49, 215, 215, 53, 228, 252, 79, 108, 215,
/* 450 */ 213, 213, 213, 270, 214, 214, 124, 214, 264, 121, /* 450 */ 127, 259, 257, 223, 225, 215, 219, 215, 227, 81,
/* 460 */ 116, 120, 115, 114, 113, 126, 84, 83, 49, 80, /* 460 */ 80, 82, 229, 215, 83, 114, 84, 115, 260, 76,
/* 470 */ 82, 53, 81, 79, 214, 214, 214, 76, 5, 5, /* 470 */ 116, 121, 125, 215, 272, 122, 215, 272, 215, 280,
/* 480 */ 138, 5, 218, 138, 214, 5, 5, 129, 86, 214, /* 480 */ 214, 214, 214, 214, 214, 214, 214, 280, 214, 214,
/* 490 */ 109, 101, 106, 110, 101, 215, 222, 215, 226, 228, /* 490 */ 214, 214, 214, 280, 214, 214, 258, 214, 280, 252,
/* 500 */ 227, 223, 225, 224, 221, 214, 214, 261, 263, 256, /* 500 */ 261, 117, 214, 262, 247, 78, 263, 113, 264, 256,
/* 510 */ 258, 260, 262, 259, 251, 219, 257, 216, 1, 106, /* 510 */ 265, 252, 214, 123, 214, 214, 254, 280, 272, 280,
/* 520 */ 100, 100, 117, 101, 100, 117, 101, 100, 100, 106, /* 520 */ 214, 214, 280, 280, 268, 280, 280, 280, 276, 269,
/* 530 */ 100, 73, 103, 107, 103, 9, 104, 5, 5, 5, /* 530 */ 280, 276, 247, 247, 280, 280, 214, 280, 214, 214,
/* 540 */ 5, 5, 77, 15, 73, 16, 132, 132, 106, 5, /* 540 */ 214, 214, 214, 214, 214, 214, 214, 280, 214, 214,
/* 550 */ 5, 101, 5, 5, 5, 5, 5, 5, 5, 5, /* 550 */ 280, 280, 214, 214, 280, 214, 214, 214, 214, 214,
/* 560 */ 5, 5, 5, 5, 5, 5, 5, 5, 106, 77, /* 560 */ 214, 280, 214, 214, 280, 280, 280, 280, 280, 280,
/* 570 */ 59, 58, 0, 278, 278, 278, 278, 278, 278, 278, /* 570 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 580 */ 278, 278, 278, 278, 21, 21, 278, 278, 278, 278, /* 580 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 590 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 590 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 600 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 600 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 214,
/* 610 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 610 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 620 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 620 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 630 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 630 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 640 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 640 */ 280, 280, 280, 247, 247, 247, 247, 280, 280, 280,
/* 650 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 650 */ 280, 280, 280, 280, 254, 280, 280, 280, 280, 280,
/* 660 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 660 */ 280, 280, 280, 280, 280, 280, 280, 280, 280, 280,
/* 670 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 670 */ 269, 269, 269, 269, 269, 269, 269, 269, 269, 269,
/* 680 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278, /* 680 */ 269, 280, 269, 269, 269, 269, 269, 280, 280, 269,
/* 690 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 700 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 710 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 720 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 730 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 740 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 750 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 760 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 770 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 780 */ 278, 278, 278, 278, 278, 278, 278, 278, 278, 278,
/* 790 */ 278, 278, 278, 278, 278,
}; };
#define YY_SHIFT_COUNT (257) #define YY_SHIFT_USE_DFLT (-59)
#define YY_SHIFT_MIN (0) #define YY_SHIFT_COUNT (258)
#define YY_SHIFT_MAX (572) #define YY_SHIFT_MIN (-58)
static const unsigned short int yy_shift_ofst[] = { #define YY_SHIFT_MAX (427)
/* 0 */ 163, 25, 156, 5, 193, 213, 21, 21, 21, 21, static const short yy_shift_ofst[] = {
/* 10 */ 21, 21, 0, 22, 213, 299, 299, 299, 113, 21, /* 0 */ 161, 78, 197, 393, 201, 211, 333, 333, 333, 333,
/* 20 */ 21, 21, 216, 21, 21, 186, 11, 11, 586, 203, /* 10 */ 333, 333, -1, 87, 211, 221, 221, 221, 249, 333,
/* 30 */ 213, 213, 213, 213, 213, 213, 213, 213, 213, 213, /* 20 */ 333, 333, 181, 333, 333, 265, 427, 427, -59, 211,
/* 40 */ 213, 213, 213, 213, 213, 213, 213, 299, 299, 2, /* 30 */ 211, 211, 211, 211, 211, 211, 211, 211, 211, 211,
/* 50 */ 2, 2, 2, 2, 2, 2, 89, 21, 21, 21, /* 40 */ 211, 211, 211, 211, 211, 211, 211, 221, 221, 66,
/* 60 */ 21, 33, 33, 173, 21, 21, 21, 21, 21, 21, /* 50 */ 66, 66, 66, 66, 66, 66, 236, 333, 235, 333,
/* 70 */ 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, /* 60 */ 333, 333, 117, 117, 92, 333, 333, 333, 333, 333,
/* 80 */ 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, /* 70 */ 333, 333, 333, 333, 333, 333, 333, 333, 333, 333,
/* 90 */ 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, /* 80 */ 333, 333, 333, 333, 333, 333, 333, 333, 333, 333,
/* 100 */ 21, 21, 21, 21, 308, 355, 355, 317, 317, 317, /* 90 */ 333, 333, 333, 333, 333, 333, 333, 333, 333, 333,
/* 110 */ 355, 316, 332, 338, 344, 341, 347, 349, 351, 339, /* 100 */ 333, 333, 333, 333, 333, 340, 375, 375, 394, 394,
/* 120 */ 308, 355, 355, 355, 5, 355, 382, 384, 419, 389, /* 110 */ 394, 375, 390, 347, 353, 384, 350, 354, 352, 351,
/* 130 */ 388, 418, 391, 394, 355, 401, 355, 401, 355, 586, /* 120 */ 323, 340, 375, 375, 375, 393, 375, 382, 381, 392,
/* 140 */ 586, 27, 70, 70, 70, 129, 154, 249, 249, 249, /* 130 */ 380, 379, 391, 378, 368, 375, 355, 375, 355, 375,
/* 150 */ 267, 284, 284, 284, 284, 228, 276, 14, 40, 146, /* 140 */ -59, -59, 26, 53, 53, 53, 81, 162, 214, 214,
/* 160 */ 146, 247, 290, 123, 201, 225, 255, 256, 257, 307, /* 150 */ 214, -58, -32, -32, -32, -32, 219, 55, -5, 54,
/* 170 */ 334, 248, 265, 242, 221, 244, 258, 268, 269, 107, /* 160 */ 18, 18, -56, -35, 232, 226, 225, 224, 215, 209,
/* 180 */ 266, 168, 366, 371, 306, 320, 473, 342, 474, 476, /* 170 */ 313, 312, 88, -28, 3, 123, -3, 207, 206, 193,
/* 190 */ 345, 480, 481, 402, 358, 381, 390, 383, 386, 393, /* 180 */ 82, 203, 61, 293, 204, 20, -27, 425, 290, 423,
/* 200 */ 420, 517, 421, 422, 424, 413, 405, 423, 408, 425, /* 190 */ 422, 287, 419, 418, 336, 284, 309, 320, 310, 319,
/* 210 */ 427, 426, 428, 429, 430, 431, 432, 458, 526, 532, /* 200 */ 318, 317, 412, 316, 311, 315, 305, 292, 302, 289,
/* 220 */ 533, 534, 535, 536, 465, 528, 471, 529, 414, 415, /* 210 */ 304, 303, 295, 299, 297, 296, 294, 291, 321, 389,
/* 230 */ 442, 544, 545, 450, 442, 547, 548, 549, 550, 551, /* 220 */ 388, 387, 386, 385, 383, 308, 374, 314, 370, 251,
/* 240 */ 552, 553, 554, 555, 556, 557, 558, 559, 560, 561, /* 230 */ 250, 273, 377, 376, 279, 273, 373, 372, 371, 369,
/* 250 */ 562, 462, 492, 563, 564, 511, 513, 572, /* 240 */ 367, 366, 365, 364, 363, 362, 361, 360, 359, 358,
/* 250 */ 357, 356, 254, 282, 337, 124, 24, 104, 41,
}; };
#define YY_REDUCE_COUNT (140) #define YY_REDUCE_USE_DFLT (-212)
#define YY_REDUCE_MIN (-267) #define YY_REDUCE_COUNT (141)
#define YY_REDUCE_MAX (301) #define YY_REDUCE_MIN (-211)
#define YY_REDUCE_MAX (420)
static const short yy_reduce_ofst[] = { static const short yy_reduce_ofst[] = {
/* 0 */ -206, -102, 29, 62, -265, -175, -114, -113, -194, -49, /* 0 */ -190, -84, 33, -137, -19, -194, -7, -17, 51, 11,
/* 10 */ -41, 15, -205, -163, -267, -224, -168, -57, -233, -27, /* 10 */ -29, -34, 139, 142, -211, 121, 119, 52, 85, 133,
/* 20 */ -167, -48, -161, -120, -210, 36, 61, 99, -35, -252, /* 20 */ 131, 126, -205, 108, 95, 58, 25, -90, 68, 420,
/* 30 */ -141, -77, -68, -61, -50, -22, -7, 81, 93, 105, /* 30 */ 417, 416, 415, 414, 413, 411, 410, 409, 408, 407,
/* 40 */ 110, 116, 117, 118, 119, 120, 121, 41, 136, 144, /* 40 */ 406, 405, 404, 403, 402, 401, 260, 400, 262, 399,
/* 50 */ 145, 147, 148, 149, 150, 151, 141, 185, 187, 188, /* 50 */ 398, 397, 396, 286, 285, 257, 259, 395, 256, 349,
/* 60 */ 189, 125, 130, 152, 190, 192, 195, 196, 197, 198, /* 60 */ 348, 346, 255, 252, 253, 345, 344, 343, 342, 341,
/* 70 */ 199, 200, 202, 204, 205, 206, 207, 208, 209, 210, /* 70 */ 339, 338, 335, 334, 332, 331, 330, 329, 328, 327,
/* 80 */ 211, 212, 214, 215, 217, 218, 219, 220, 222, 223, /* 80 */ 326, 325, 324, 322, 307, 306, 301, 300, 298, 288,
/* 90 */ 224, 226, 227, 229, 230, 231, 232, 233, 234, 235, /* 90 */ 283, 281, 280, 278, 277, 276, 275, 274, 272, 271,
/* 100 */ 236, 237, 238, 239, 175, 240, 241, 164, 171, 183, /* 100 */ 270, 269, 268, 267, 266, 247, 263, 261, 246, 205,
/* 110 */ 243, 194, 245, 250, 246, 251, 254, 252, 259, 253, /* 110 */ 202, 258, 245, 244, 243, 241, 239, 208, 192, 238,
/* 120 */ 263, 260, 261, 262, 264, 270, 271, 273, 272, 274, /* 120 */ 195, 194, 248, 242, 240, 237, 234, 233, 217, 231,
/* 130 */ 277, 278, 279, 283, 275, 280, 291, 282, 292, 296, /* 130 */ 230, 210, 213, 229, 218, 228, 223, 227, 222, 220,
/* 140 */ 301, /* 140 */ 212, 216,
}; };
static const YYACTIONTYPE yy_default[] = { static const YYACTIONTYPE yy_default[] = {
/* 0 */ 671, 725, 714, 722, 903, 903, 671, 671, 671, 671, /* 0 */ 675, 484, 473, 481, 664, 664, 675, 675, 675, 675,
/* 10 */ 671, 671, 828, 689, 903, 671, 671, 671, 671, 671, /* 10 */ 675, 675, 587, 448, 664, 675, 675, 675, 675, 675,
/* 20 */ 671, 671, 722, 671, 671, 727, 727, 727, 823, 671, /* 20 */ 675, 675, 481, 675, 675, 486, 486, 486, 582, 675,
/* 30 */ 671, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 30 */ 675, 675, 675, 675, 675, 675, 675, 675, 675, 675,
/* 40 */ 671, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 40 */ 675, 675, 675, 675, 675, 675, 675, 675, 675, 675,
/* 50 */ 671, 671, 671, 671, 671, 671, 671, 671, 830, 832, /* 50 */ 675, 675, 675, 675, 675, 675, 675, 675, 589, 591,
/* 60 */ 671, 850, 850, 821, 671, 671, 671, 671, 671, 671, /* 60 */ 593, 675, 611, 611, 580, 675, 675, 675, 675, 675,
/* 70 */ 671, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 70 */ 675, 675, 675, 675, 675, 675, 675, 675, 675, 675,
/* 80 */ 671, 671, 671, 712, 671, 710, 671, 671, 671, 671, /* 80 */ 675, 675, 675, 675, 471, 675, 469, 675, 675, 675,
/* 90 */ 671, 671, 671, 671, 671, 671, 671, 671, 699, 671, /* 90 */ 675, 675, 675, 675, 675, 675, 675, 675, 675, 458,
/* 100 */ 671, 671, 671, 671, 671, 691, 691, 671, 671, 671, /* 100 */ 675, 675, 675, 675, 675, 675, 450, 450, 675, 675,
/* 110 */ 691, 857, 861, 855, 843, 851, 842, 838, 837, 865, /* 110 */ 675, 450, 618, 622, 616, 604, 612, 603, 599, 598,
/* 120 */ 671, 691, 691, 691, 722, 691, 743, 741, 739, 731, /* 120 */ 626, 675, 450, 450, 450, 481, 450, 502, 500, 498,
/* 130 */ 737, 733, 735, 729, 691, 720, 691, 720, 691, 761, /* 130 */ 490, 496, 492, 494, 488, 450, 479, 450, 479, 450,
/* 140 */ 777, 671, 866, 902, 856, 892, 891, 898, 890, 889, /* 140 */ 520, 536, 675, 627, 663, 617, 653, 652, 659, 651,
/* 150 */ 671, 885, 886, 888, 887, 671, 671, 671, 671, 894, /* 150 */ 650, 675, 646, 647, 649, 648, 675, 675, 675, 675,
/* 160 */ 893, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 160 */ 655, 654, 675, 675, 675, 675, 675, 675, 675, 675,
/* 170 */ 671, 671, 868, 671, 862, 858, 671, 671, 671, 671, /* 170 */ 675, 675, 675, 629, 675, 623, 619, 675, 675, 675,
/* 180 */ 787, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 180 */ 675, 546, 675, 675, 675, 675, 675, 675, 675, 675,
/* 190 */ 671, 671, 671, 671, 671, 820, 671, 671, 829, 671, /* 190 */ 675, 675, 675, 675, 675, 675, 579, 675, 675, 590,
/* 200 */ 671, 671, 671, 671, 671, 852, 671, 844, 671, 671, /* 200 */ 675, 675, 675, 675, 675, 675, 613, 675, 605, 675,
/* 210 */ 671, 671, 671, 797, 671, 671, 671, 671, 671, 671, /* 210 */ 675, 675, 675, 675, 556, 675, 675, 675, 675, 675,
/* 220 */ 671, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 220 */ 675, 675, 675, 675, 675, 675, 675, 675, 675, 675,
/* 230 */ 907, 671, 671, 671, 905, 671, 671, 671, 671, 671, /* 230 */ 675, 668, 675, 675, 675, 666, 675, 675, 675, 675,
/* 240 */ 671, 671, 671, 671, 671, 671, 671, 671, 671, 671, /* 240 */ 675, 675, 675, 675, 675, 675, 675, 675, 675, 675,
/* 250 */ 671, 746, 671, 697, 695, 671, 687, 671, /* 250 */ 675, 675, 505, 675, 456, 454, 675, 446, 675, 674,
/* 260 */ 673, 672, 665, 578, 577, 576, 575, 588, 584, 586,
/* 270 */ 585, 583, 592, 594, 581, 597, 596, 601, 600, 602,
/* 280 */ 595, 615, 614, 607, 608, 610, 609, 606, 643, 661,
/* 290 */ 662, 660, 658, 657, 656, 642, 641, 640, 639, 638,
/* 300 */ 635, 637, 634, 636, 633, 632, 631, 630, 628, 645,
/* 310 */ 644, 625, 624, 621, 620, 574, 559, 557, 554, 558,
/* 320 */ 555, 552, 485, 535, 534, 533, 532, 531, 530, 529,
/* 330 */ 528, 527, 526, 525, 524, 523, 522, 521, 517, 513,
/* 340 */ 511, 510, 509, 506, 480, 483, 482, 671, 670, 669,
/* 350 */ 667, 561, 562, 548, 551, 550, 549, 547, 560, 504,
/* 360 */ 503, 501, 499, 491, 497, 493, 495, 489, 487, 475,
/* 370 */ 474, 545, 544, 543, 542, 541, 540, 539, 538, 537,
/* 380 */ 519, 518, 516, 515, 514, 512, 508, 507, 564, 573,
/* 390 */ 572, 571, 570, 569, 568, 567, 566, 565, 563, 472,
/* 400 */ 470, 468, 467, 466, 465, 464, 463, 462, 461, 478,
/* 410 */ 460, 459, 457, 455, 453, 452, 477, 476, 451, 449,
/* 420 */ 447, 445, 444, 443, 442, 441, 440, 439, 438, 437,
/* 430 */ 436, 435, 434,
}; };
/********** End of lemon-generated parsing tables *****************************/
/* The next table maps tokens (terminal symbols) into fallback tokens. /* The next table maps tokens into fallback tokens. If a construct
** If a construct like the following: ** like the following:
** **
** %fallback ID X Y Z. ** %fallback ID X Y Z.
** **
...@@ -437,10 +420,6 @@ static const YYACTIONTYPE yy_default[] = { ...@@ -437,10 +420,6 @@ static const YYACTIONTYPE yy_default[] = {
** and Z. Whenever one of the tokens X, Y, or Z is input to the parser ** and Z. Whenever one of the tokens X, Y, or Z is input to the parser
** but it does not parse, the type of the token is changed to ID and ** but it does not parse, the type of the token is changed to ID and
** the parse is retried before an error is thrown. ** the parse is retried before an error is thrown.
**
** This feature can be used, for example, to cause some keywords in a language
** to revert to identifiers if they keyword does not apply in the context where
** it appears.
*/ */
#ifdef YYFALLBACK #ifdef YYFALLBACK
static const YYCODETYPE yyFallback[] = { static const YYCODETYPE yyFallback[] = {
...@@ -555,6 +534,7 @@ static const YYCODETYPE yyFallback[] = { ...@@ -555,6 +534,7 @@ static const YYCODETYPE yyFallback[] = {
0, /* SELECT => nothing */ 0, /* SELECT => nothing */
0, /* UNION => nothing */ 0, /* UNION => nothing */
1, /* ALL => ID */ 1, /* ALL => ID */
0, /* DISTINCT => nothing */
0, /* FROM => nothing */ 0, /* FROM => nothing */
0, /* VARIABLE => nothing */ 0, /* VARIABLE => nothing */
0, /* INTERVAL => nothing */ 0, /* INTERVAL => nothing */
...@@ -667,13 +647,9 @@ static const YYCODETYPE yyFallback[] = { ...@@ -667,13 +647,9 @@ static const YYCODETYPE yyFallback[] = {
** + The semantic value stored at this level of the stack. This is ** + The semantic value stored at this level of the stack. This is
** the information used by the action routines in the grammar. ** the information used by the action routines in the grammar.
** It is sometimes called the "minor" token. ** It is sometimes called the "minor" token.
**
** After the "shift" half of a SHIFTREDUCE action, the stateno field
** actually contains the reduce action for the second half of the
** SHIFTREDUCE.
*/ */
struct yyStackEntry { struct yyStackEntry {
YYACTIONTYPE stateno; /* The state-number, or reduce action in SHIFTREDUCE */ YYACTIONTYPE stateno; /* The state-number */
YYCODETYPE major; /* The major token value. This is the code YYCODETYPE major; /* The major token value. This is the code
** number for the token at this stack level */ ** number for the token at this stack level */
YYMINORTYPE minor; /* The user-supplied minor token value. This YYMINORTYPE minor; /* The user-supplied minor token value. This
...@@ -684,21 +660,17 @@ typedef struct yyStackEntry yyStackEntry; ...@@ -684,21 +660,17 @@ typedef struct yyStackEntry yyStackEntry;
/* The state of the parser is completely contained in an instance of /* The state of the parser is completely contained in an instance of
** the following structure */ ** the following structure */
struct yyParser { struct yyParser {
yyStackEntry *yytos; /* Pointer to top element of the stack */ int yyidx; /* Index of top element in stack */
#ifdef YYTRACKMAXSTACKDEPTH #ifdef YYTRACKMAXSTACKDEPTH
int yyhwm; /* High-water mark of the stack */ int yyidxMax; /* Maximum value of yyidx */
#endif #endif
#ifndef YYNOERRORRECOVERY
int yyerrcnt; /* Shifts left before out of the error */ int yyerrcnt; /* Shifts left before out of the error */
#endif
ParseARG_SDECL /* A place to hold %extra_argument */ ParseARG_SDECL /* A place to hold %extra_argument */
#if YYSTACKDEPTH<=0 #if YYSTACKDEPTH<=0
int yystksz; /* Current side of the stack */ int yystksz; /* Current side of the stack */
yyStackEntry *yystack; /* The parser's stack */ yyStackEntry *yystack; /* The parser's stack */
yyStackEntry yystk0; /* First stack entry */
#else #else
yyStackEntry yystack[YYSTACKDEPTH]; /* The parser's stack */ yyStackEntry yystack[YYSTACKDEPTH]; /* The parser's stack */
yyStackEntry *yystackEnd; /* Last entry in the stack */
#endif #endif
}; };
typedef struct yyParser yyParser; typedef struct yyParser yyParser;
...@@ -735,290 +707,82 @@ void ParseTrace(FILE *TraceFILE, char *zTracePrompt){ ...@@ -735,290 +707,82 @@ void ParseTrace(FILE *TraceFILE, char *zTracePrompt){
} }
#endif /* NDEBUG */ #endif /* NDEBUG */
#if defined(YYCOVERAGE) || !defined(NDEBUG) #ifndef NDEBUG
/* For tracing shifts, the names of all terminals and nonterminals /* For tracing shifts, the names of all terminals and nonterminals
** are required. The following table supplies these names */ ** are required. The following table supplies these names */
static const char *const yyTokenName[] = { static const char *const yyTokenName[] = {
/* 0 */ "$", "$", "ID", "BOOL", "TINYINT",
/* 1 */ "ID", "SMALLINT", "INTEGER", "BIGINT", "FLOAT",
/* 2 */ "BOOL", "DOUBLE", "STRING", "TIMESTAMP", "BINARY",
/* 3 */ "TINYINT", "NCHAR", "OR", "AND", "NOT",
/* 4 */ "SMALLINT", "EQ", "NE", "ISNULL", "NOTNULL",
/* 5 */ "INTEGER", "IS", "LIKE", "GLOB", "BETWEEN",
/* 6 */ "BIGINT", "IN", "GT", "GE", "LT",
/* 7 */ "FLOAT", "LE", "BITAND", "BITOR", "LSHIFT",
/* 8 */ "DOUBLE", "RSHIFT", "PLUS", "MINUS", "DIVIDE",
/* 9 */ "STRING", "TIMES", "STAR", "SLASH", "REM",
/* 10 */ "TIMESTAMP", "CONCAT", "UMINUS", "UPLUS", "BITNOT",
/* 11 */ "BINARY", "SHOW", "DATABASES", "MNODES", "DNODES",
/* 12 */ "NCHAR", "ACCOUNTS", "USERS", "MODULES", "QUERIES",
/* 13 */ "OR", "CONNECTIONS", "STREAMS", "VARIABLES", "SCORES",
/* 14 */ "AND", "GRANTS", "VNODES", "IPTOKEN", "DOT",
/* 15 */ "NOT", "CREATE", "TABLE", "DATABASE", "TABLES",
/* 16 */ "EQ", "STABLES", "VGROUPS", "DROP", "DNODE",
/* 17 */ "NE", "USER", "ACCOUNT", "USE", "DESCRIBE",
/* 18 */ "ISNULL", "ALTER", "PASS", "PRIVILEGE", "LOCAL",
/* 19 */ "NOTNULL", "IF", "EXISTS", "PPS", "TSERIES",
/* 20 */ "IS", "DBS", "STORAGE", "QTIME", "CONNS",
/* 21 */ "LIKE", "STATE", "KEEP", "CACHE", "REPLICA",
/* 22 */ "GLOB", "QUORUM", "DAYS", "MINROWS", "MAXROWS",
/* 23 */ "BETWEEN", "BLOCKS", "CTIME", "WAL", "FSYNC",
/* 24 */ "IN", "COMP", "PRECISION", "UPDATE", "CACHELAST",
/* 25 */ "GT", "LP", "RP", "UNSIGNED", "TAGS",
/* 26 */ "GE", "USING", "AS", "COMMA", "NULL",
/* 27 */ "LT", "SELECT", "UNION", "ALL", "DISTINCT",
/* 28 */ "LE", "FROM", "VARIABLE", "INTERVAL", "FILL",
/* 29 */ "BITAND", "SLIDING", "ORDER", "BY", "ASC",
/* 30 */ "BITOR", "DESC", "GROUP", "HAVING", "LIMIT",
/* 31 */ "LSHIFT", "OFFSET", "SLIMIT", "SOFFSET", "WHERE",
/* 32 */ "RSHIFT", "NOW", "RESET", "QUERY", "ADD",
/* 33 */ "PLUS", "COLUMN", "TAG", "CHANGE", "SET",
/* 34 */ "MINUS", "KILL", "CONNECTION", "STREAM", "COLON",
/* 35 */ "DIVIDE", "ABORT", "AFTER", "ATTACH", "BEFORE",
/* 36 */ "TIMES", "BEGIN", "CASCADE", "CLUSTER", "CONFLICT",
/* 37 */ "STAR", "COPY", "DEFERRED", "DELIMITERS", "DETACH",
/* 38 */ "SLASH", "EACH", "END", "EXPLAIN", "FAIL",
/* 39 */ "REM", "FOR", "IGNORE", "IMMEDIATE", "INITIALLY",
/* 40 */ "CONCAT", "INSTEAD", "MATCH", "KEY", "OF",
/* 41 */ "UMINUS", "RAISE", "REPLACE", "RESTRICT", "ROW",
/* 42 */ "UPLUS", "STATEMENT", "TRIGGER", "VIEW", "COUNT",
/* 43 */ "BITNOT", "SUM", "AVG", "MIN", "MAX",
/* 44 */ "SHOW", "FIRST", "LAST", "TOP", "BOTTOM",
/* 45 */ "DATABASES", "STDDEV", "PERCENTILE", "APERCENTILE", "LEASTSQUARES",
/* 46 */ "MNODES", "HISTOGRAM", "DIFF", "SPREAD", "TWA",
/* 47 */ "DNODES", "INTERP", "LAST_ROW", "RATE", "IRATE",
/* 48 */ "ACCOUNTS", "SUM_RATE", "SUM_IRATE", "AVG_RATE", "AVG_IRATE",
/* 49 */ "USERS", "TBID", "SEMI", "NONE", "PREV",
/* 50 */ "MODULES", "LINEAR", "IMPORT", "METRIC", "TBNAME",
/* 51 */ "QUERIES", "JOIN", "METRICS", "STABLE", "INSERT",
/* 52 */ "CONNECTIONS", "INTO", "VALUES", "error", "program",
/* 53 */ "STREAMS", "cmd", "dbPrefix", "ids", "cpxName",
/* 54 */ "VARIABLES", "ifexists", "alter_db_optr", "acct_optr", "ifnotexists",
/* 55 */ "SCORES", "db_optr", "pps", "tseries", "dbs",
/* 56 */ "GRANTS", "streams", "storage", "qtime", "users",
/* 57 */ "VNODES", "conns", "state", "keep", "tagitemlist",
/* 58 */ "IPTOKEN", "cache", "replica", "quorum", "days",
/* 59 */ "DOT", "minrows", "maxrows", "blocks", "ctime",
/* 60 */ "CREATE", "wal", "fsync", "comp", "prec",
/* 61 */ "TABLE", "update", "cachelast", "typename", "signed",
/* 62 */ "DATABASE", "create_table_args", "create_table_list", "create_from_stable", "columnlist",
/* 63 */ "TABLES", "select", "column", "tagitem", "selcollist",
/* 64 */ "STABLES", "from", "where_opt", "interval_opt", "fill_opt",
/* 65 */ "VGROUPS", "sliding_opt", "groupby_opt", "orderby_opt", "having_opt",
/* 66 */ "DROP", "slimit_opt", "limit_opt", "union", "sclp",
/* 67 */ "DNODE", "distinct", "expr", "as", "tablelist",
/* 68 */ "USER", "tmvar", "sortlist", "sortitem", "item",
/* 69 */ "ACCOUNT", "sortorder", "grouplist", "exprlist", "expritem",
/* 70 */ "USE",
/* 71 */ "DESCRIBE",
/* 72 */ "ALTER",
/* 73 */ "PASS",
/* 74 */ "PRIVILEGE",
/* 75 */ "LOCAL",
/* 76 */ "IF",
/* 77 */ "EXISTS",
/* 78 */ "PPS",
/* 79 */ "TSERIES",
/* 80 */ "DBS",
/* 81 */ "STORAGE",
/* 82 */ "QTIME",
/* 83 */ "CONNS",
/* 84 */ "STATE",
/* 85 */ "KEEP",
/* 86 */ "CACHE",
/* 87 */ "REPLICA",
/* 88 */ "QUORUM",
/* 89 */ "DAYS",
/* 90 */ "MINROWS",
/* 91 */ "MAXROWS",
/* 92 */ "BLOCKS",
/* 93 */ "CTIME",
/* 94 */ "WAL",
/* 95 */ "FSYNC",
/* 96 */ "COMP",
/* 97 */ "PRECISION",
/* 98 */ "UPDATE",
/* 99 */ "CACHELAST",
/* 100 */ "LP",
/* 101 */ "RP",
/* 102 */ "UNSIGNED",
/* 103 */ "TAGS",
/* 104 */ "USING",
/* 105 */ "AS",
/* 106 */ "COMMA",
/* 107 */ "NULL",
/* 108 */ "SELECT",
/* 109 */ "UNION",
/* 110 */ "ALL",
/* 111 */ "FROM",
/* 112 */ "VARIABLE",
/* 113 */ "INTERVAL",
/* 114 */ "FILL",
/* 115 */ "SLIDING",
/* 116 */ "ORDER",
/* 117 */ "BY",
/* 118 */ "ASC",
/* 119 */ "DESC",
/* 120 */ "GROUP",
/* 121 */ "HAVING",
/* 122 */ "LIMIT",
/* 123 */ "OFFSET",
/* 124 */ "SLIMIT",
/* 125 */ "SOFFSET",
/* 126 */ "WHERE",
/* 127 */ "NOW",
/* 128 */ "RESET",
/* 129 */ "QUERY",
/* 130 */ "ADD",
/* 131 */ "COLUMN",
/* 132 */ "TAG",
/* 133 */ "CHANGE",
/* 134 */ "SET",
/* 135 */ "KILL",
/* 136 */ "CONNECTION",
/* 137 */ "STREAM",
/* 138 */ "COLON",
/* 139 */ "ABORT",
/* 140 */ "AFTER",
/* 141 */ "ATTACH",
/* 142 */ "BEFORE",
/* 143 */ "BEGIN",
/* 144 */ "CASCADE",
/* 145 */ "CLUSTER",
/* 146 */ "CONFLICT",
/* 147 */ "COPY",
/* 148 */ "DEFERRED",
/* 149 */ "DELIMITERS",
/* 150 */ "DETACH",
/* 151 */ "EACH",
/* 152 */ "END",
/* 153 */ "EXPLAIN",
/* 154 */ "FAIL",
/* 155 */ "FOR",
/* 156 */ "IGNORE",
/* 157 */ "IMMEDIATE",
/* 158 */ "INITIALLY",
/* 159 */ "INSTEAD",
/* 160 */ "MATCH",
/* 161 */ "KEY",
/* 162 */ "OF",
/* 163 */ "RAISE",
/* 164 */ "REPLACE",
/* 165 */ "RESTRICT",
/* 166 */ "ROW",
/* 167 */ "STATEMENT",
/* 168 */ "TRIGGER",
/* 169 */ "VIEW",
/* 170 */ "COUNT",
/* 171 */ "SUM",
/* 172 */ "AVG",
/* 173 */ "MIN",
/* 174 */ "MAX",
/* 175 */ "FIRST",
/* 176 */ "LAST",
/* 177 */ "TOP",
/* 178 */ "BOTTOM",
/* 179 */ "STDDEV",
/* 180 */ "PERCENTILE",
/* 181 */ "APERCENTILE",
/* 182 */ "LEASTSQUARES",
/* 183 */ "HISTOGRAM",
/* 184 */ "DIFF",
/* 185 */ "SPREAD",
/* 186 */ "TWA",
/* 187 */ "INTERP",
/* 188 */ "LAST_ROW",
/* 189 */ "RATE",
/* 190 */ "IRATE",
/* 191 */ "SUM_RATE",
/* 192 */ "SUM_IRATE",
/* 193 */ "AVG_RATE",
/* 194 */ "AVG_IRATE",
/* 195 */ "TBID",
/* 196 */ "SEMI",
/* 197 */ "NONE",
/* 198 */ "PREV",
/* 199 */ "LINEAR",
/* 200 */ "IMPORT",
/* 201 */ "METRIC",
/* 202 */ "TBNAME",
/* 203 */ "JOIN",
/* 204 */ "METRICS",
/* 205 */ "STABLE",
/* 206 */ "INSERT",
/* 207 */ "INTO",
/* 208 */ "VALUES",
/* 209 */ "error",
/* 210 */ "program",
/* 211 */ "cmd",
/* 212 */ "dbPrefix",
/* 213 */ "ids",
/* 214 */ "cpxName",
/* 215 */ "ifexists",
/* 216 */ "alter_db_optr",
/* 217 */ "acct_optr",
/* 218 */ "ifnotexists",
/* 219 */ "db_optr",
/* 220 */ "pps",
/* 221 */ "tseries",
/* 222 */ "dbs",
/* 223 */ "streams",
/* 224 */ "storage",
/* 225 */ "qtime",
/* 226 */ "users",
/* 227 */ "conns",
/* 228 */ "state",
/* 229 */ "keep",
/* 230 */ "tagitemlist",
/* 231 */ "cache",
/* 232 */ "replica",
/* 233 */ "quorum",
/* 234 */ "days",
/* 235 */ "minrows",
/* 236 */ "maxrows",
/* 237 */ "blocks",
/* 238 */ "ctime",
/* 239 */ "wal",
/* 240 */ "fsync",
/* 241 */ "comp",
/* 242 */ "prec",
/* 243 */ "update",
/* 244 */ "cachelast",
/* 245 */ "typename",
/* 246 */ "signed",
/* 247 */ "create_table_args",
/* 248 */ "create_table_list",
/* 249 */ "create_from_stable",
/* 250 */ "columnlist",
/* 251 */ "select",
/* 252 */ "column",
/* 253 */ "tagitem",
/* 254 */ "selcollist",
/* 255 */ "from",
/* 256 */ "where_opt",
/* 257 */ "interval_opt",
/* 258 */ "fill_opt",
/* 259 */ "sliding_opt",
/* 260 */ "groupby_opt",
/* 261 */ "orderby_opt",
/* 262 */ "having_opt",
/* 263 */ "slimit_opt",
/* 264 */ "limit_opt",
/* 265 */ "union",
/* 266 */ "sclp",
/* 267 */ "expr",
/* 268 */ "as",
/* 269 */ "tablelist",
/* 270 */ "tmvar",
/* 271 */ "sortlist",
/* 272 */ "sortitem",
/* 273 */ "item",
/* 274 */ "sortorder",
/* 275 */ "grouplist",
/* 276 */ "exprlist",
/* 277 */ "expritem",
}; };
#endif /* defined(YYCOVERAGE) || !defined(NDEBUG) */ #endif /* NDEBUG */
#ifndef NDEBUG #ifndef NDEBUG
/* For tracing reduce actions, the names of all rules are required. /* For tracing reduce actions, the names of all rules are required.
...@@ -1174,170 +938,125 @@ static const char *const yyRuleName[] = { ...@@ -1174,170 +938,125 @@ static const char *const yyRuleName[] = {
/* 147 */ "select ::= SELECT selcollist", /* 147 */ "select ::= SELECT selcollist",
/* 148 */ "sclp ::= selcollist COMMA", /* 148 */ "sclp ::= selcollist COMMA",
/* 149 */ "sclp ::=", /* 149 */ "sclp ::=",
/* 150 */ "selcollist ::= sclp expr as", /* 150 */ "selcollist ::= sclp distinct expr as",
/* 151 */ "selcollist ::= sclp STAR", /* 151 */ "selcollist ::= sclp STAR",
/* 152 */ "as ::= AS ids", /* 152 */ "as ::= AS ids",
/* 153 */ "as ::= ids", /* 153 */ "as ::= ids",
/* 154 */ "as ::=", /* 154 */ "as ::=",
/* 155 */ "from ::= FROM tablelist", /* 155 */ "distinct ::= DISTINCT",
/* 156 */ "tablelist ::= ids cpxName", /* 156 */ "distinct ::=",
/* 157 */ "tablelist ::= ids cpxName ids", /* 157 */ "from ::= FROM tablelist",
/* 158 */ "tablelist ::= tablelist COMMA ids cpxName", /* 158 */ "tablelist ::= ids cpxName",
/* 159 */ "tablelist ::= tablelist COMMA ids cpxName ids", /* 159 */ "tablelist ::= ids cpxName ids",
/* 160 */ "tmvar ::= VARIABLE", /* 160 */ "tablelist ::= tablelist COMMA ids cpxName",
/* 161 */ "interval_opt ::= INTERVAL LP tmvar RP", /* 161 */ "tablelist ::= tablelist COMMA ids cpxName ids",
/* 162 */ "interval_opt ::= INTERVAL LP tmvar COMMA tmvar RP", /* 162 */ "tmvar ::= VARIABLE",
/* 163 */ "interval_opt ::=", /* 163 */ "interval_opt ::= INTERVAL LP tmvar RP",
/* 164 */ "fill_opt ::=", /* 164 */ "interval_opt ::= INTERVAL LP tmvar COMMA tmvar RP",
/* 165 */ "fill_opt ::= FILL LP ID COMMA tagitemlist RP", /* 165 */ "interval_opt ::=",
/* 166 */ "fill_opt ::= FILL LP ID RP", /* 166 */ "fill_opt ::=",
/* 167 */ "sliding_opt ::= SLIDING LP tmvar RP", /* 167 */ "fill_opt ::= FILL LP ID COMMA tagitemlist RP",
/* 168 */ "sliding_opt ::=", /* 168 */ "fill_opt ::= FILL LP ID RP",
/* 169 */ "orderby_opt ::=", /* 169 */ "sliding_opt ::= SLIDING LP tmvar RP",
/* 170 */ "orderby_opt ::= ORDER BY sortlist", /* 170 */ "sliding_opt ::=",
/* 171 */ "sortlist ::= sortlist COMMA item sortorder", /* 171 */ "orderby_opt ::=",
/* 172 */ "sortlist ::= item sortorder", /* 172 */ "orderby_opt ::= ORDER BY sortlist",
/* 173 */ "item ::= ids cpxName", /* 173 */ "sortlist ::= sortlist COMMA item sortorder",
/* 174 */ "sortorder ::= ASC", /* 174 */ "sortlist ::= item sortorder",
/* 175 */ "sortorder ::= DESC", /* 175 */ "item ::= ids cpxName",
/* 176 */ "sortorder ::=", /* 176 */ "sortorder ::= ASC",
/* 177 */ "groupby_opt ::=", /* 177 */ "sortorder ::= DESC",
/* 178 */ "groupby_opt ::= GROUP BY grouplist", /* 178 */ "sortorder ::=",
/* 179 */ "grouplist ::= grouplist COMMA item", /* 179 */ "groupby_opt ::=",
/* 180 */ "grouplist ::= item", /* 180 */ "groupby_opt ::= GROUP BY grouplist",
/* 181 */ "having_opt ::=", /* 181 */ "grouplist ::= grouplist COMMA item",
/* 182 */ "having_opt ::= HAVING expr", /* 182 */ "grouplist ::= item",
/* 183 */ "limit_opt ::=", /* 183 */ "having_opt ::=",
/* 184 */ "limit_opt ::= LIMIT signed", /* 184 */ "having_opt ::= HAVING expr",
/* 185 */ "limit_opt ::= LIMIT signed OFFSET signed", /* 185 */ "limit_opt ::=",
/* 186 */ "limit_opt ::= LIMIT signed COMMA signed", /* 186 */ "limit_opt ::= LIMIT signed",
/* 187 */ "slimit_opt ::=", /* 187 */ "limit_opt ::= LIMIT signed OFFSET signed",
/* 188 */ "slimit_opt ::= SLIMIT signed", /* 188 */ "limit_opt ::= LIMIT signed COMMA signed",
/* 189 */ "slimit_opt ::= SLIMIT signed SOFFSET signed", /* 189 */ "slimit_opt ::=",
/* 190 */ "slimit_opt ::= SLIMIT signed COMMA signed", /* 190 */ "slimit_opt ::= SLIMIT signed",
/* 191 */ "where_opt ::=", /* 191 */ "slimit_opt ::= SLIMIT signed SOFFSET signed",
/* 192 */ "where_opt ::= WHERE expr", /* 192 */ "slimit_opt ::= SLIMIT signed COMMA signed",
/* 193 */ "expr ::= LP expr RP", /* 193 */ "where_opt ::=",
/* 194 */ "expr ::= ID", /* 194 */ "where_opt ::= WHERE expr",
/* 195 */ "expr ::= ID DOT ID", /* 195 */ "expr ::= LP expr RP",
/* 196 */ "expr ::= ID DOT STAR", /* 196 */ "expr ::= ID",
/* 197 */ "expr ::= INTEGER", /* 197 */ "expr ::= ID DOT ID",
/* 198 */ "expr ::= MINUS INTEGER", /* 198 */ "expr ::= ID DOT STAR",
/* 199 */ "expr ::= PLUS INTEGER", /* 199 */ "expr ::= INTEGER",
/* 200 */ "expr ::= FLOAT", /* 200 */ "expr ::= MINUS INTEGER",
/* 201 */ "expr ::= MINUS FLOAT", /* 201 */ "expr ::= PLUS INTEGER",
/* 202 */ "expr ::= PLUS FLOAT", /* 202 */ "expr ::= FLOAT",
/* 203 */ "expr ::= STRING", /* 203 */ "expr ::= MINUS FLOAT",
/* 204 */ "expr ::= NOW", /* 204 */ "expr ::= PLUS FLOAT",
/* 205 */ "expr ::= VARIABLE", /* 205 */ "expr ::= STRING",
/* 206 */ "expr ::= BOOL", /* 206 */ "expr ::= NOW",
/* 207 */ "expr ::= ID LP exprlist RP", /* 207 */ "expr ::= VARIABLE",
/* 208 */ "expr ::= ID LP STAR RP", /* 208 */ "expr ::= BOOL",
/* 209 */ "expr ::= expr IS NULL", /* 209 */ "expr ::= ID LP exprlist RP",
/* 210 */ "expr ::= expr IS NOT NULL", /* 210 */ "expr ::= ID LP STAR RP",
/* 211 */ "expr ::= expr LT expr", /* 211 */ "expr ::= expr IS NULL",
/* 212 */ "expr ::= expr GT expr", /* 212 */ "expr ::= expr IS NOT NULL",
/* 213 */ "expr ::= expr LE expr", /* 213 */ "expr ::= expr LT expr",
/* 214 */ "expr ::= expr GE expr", /* 214 */ "expr ::= expr GT expr",
/* 215 */ "expr ::= expr NE expr", /* 215 */ "expr ::= expr LE expr",
/* 216 */ "expr ::= expr EQ expr", /* 216 */ "expr ::= expr GE expr",
/* 217 */ "expr ::= expr AND expr", /* 217 */ "expr ::= expr NE expr",
/* 218 */ "expr ::= expr OR expr", /* 218 */ "expr ::= expr EQ expr",
/* 219 */ "expr ::= expr PLUS expr", /* 219 */ "expr ::= expr AND expr",
/* 220 */ "expr ::= expr MINUS expr", /* 220 */ "expr ::= expr OR expr",
/* 221 */ "expr ::= expr STAR expr", /* 221 */ "expr ::= expr PLUS expr",
/* 222 */ "expr ::= expr SLASH expr", /* 222 */ "expr ::= expr MINUS expr",
/* 223 */ "expr ::= expr REM expr", /* 223 */ "expr ::= expr STAR expr",
/* 224 */ "expr ::= expr LIKE expr", /* 224 */ "expr ::= expr SLASH expr",
/* 225 */ "expr ::= expr IN LP exprlist RP", /* 225 */ "expr ::= expr REM expr",
/* 226 */ "exprlist ::= exprlist COMMA expritem", /* 226 */ "expr ::= expr LIKE expr",
/* 227 */ "exprlist ::= expritem", /* 227 */ "expr ::= expr IN LP exprlist RP",
/* 228 */ "expritem ::= expr", /* 228 */ "exprlist ::= exprlist COMMA expritem",
/* 229 */ "expritem ::=", /* 229 */ "exprlist ::= expritem",
/* 230 */ "cmd ::= RESET QUERY CACHE", /* 230 */ "expritem ::= expr",
/* 231 */ "cmd ::= ALTER TABLE ids cpxName ADD COLUMN columnlist", /* 231 */ "expritem ::=",
/* 232 */ "cmd ::= ALTER TABLE ids cpxName DROP COLUMN ids", /* 232 */ "cmd ::= RESET QUERY CACHE",
/* 233 */ "cmd ::= ALTER TABLE ids cpxName ADD TAG columnlist", /* 233 */ "cmd ::= ALTER TABLE ids cpxName ADD COLUMN columnlist",
/* 234 */ "cmd ::= ALTER TABLE ids cpxName DROP TAG ids", /* 234 */ "cmd ::= ALTER TABLE ids cpxName DROP COLUMN ids",
/* 235 */ "cmd ::= ALTER TABLE ids cpxName CHANGE TAG ids ids", /* 235 */ "cmd ::= ALTER TABLE ids cpxName ADD TAG columnlist",
/* 236 */ "cmd ::= ALTER TABLE ids cpxName SET TAG ids EQ tagitem", /* 236 */ "cmd ::= ALTER TABLE ids cpxName DROP TAG ids",
/* 237 */ "cmd ::= KILL CONNECTION INTEGER", /* 237 */ "cmd ::= ALTER TABLE ids cpxName CHANGE TAG ids ids",
/* 238 */ "cmd ::= KILL STREAM INTEGER COLON INTEGER", /* 238 */ "cmd ::= ALTER TABLE ids cpxName SET TAG ids EQ tagitem",
/* 239 */ "cmd ::= KILL QUERY INTEGER COLON INTEGER", /* 239 */ "cmd ::= KILL CONNECTION INTEGER",
/* 240 */ "cmd ::= KILL STREAM INTEGER COLON INTEGER",
/* 241 */ "cmd ::= KILL QUERY INTEGER COLON INTEGER",
}; };
#endif /* NDEBUG */ #endif /* NDEBUG */
#if YYSTACKDEPTH<=0 #if YYSTACKDEPTH<=0
/* /*
** Try to increase the size of the parser stack. Return the number ** Try to increase the size of the parser stack.
** of errors. Return 0 on success.
*/ */
static int yyGrowStack(yyParser *p){ static void yyGrowStack(yyParser *p){
int newSize; int newSize;
int idx;
yyStackEntry *pNew; yyStackEntry *pNew;
newSize = p->yystksz*2 + 100; newSize = p->yystksz*2 + 100;
idx = p->yytos ? (int)(p->yytos - p->yystack) : 0; pNew = realloc(p->yystack, newSize*sizeof(pNew[0]));
if( p->yystack==&p->yystk0 ){
pNew = malloc(newSize*sizeof(pNew[0]));
if( pNew ) pNew[0] = p->yystk0;
}else{
pNew = realloc(p->yystack, newSize*sizeof(pNew[0]));
}
if( pNew ){ if( pNew ){
p->yystack = pNew; p->yystack = pNew;
p->yytos = &p->yystack[idx]; p->yystksz = newSize;
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE ){ if( yyTraceFILE ){
fprintf(yyTraceFILE,"%sStack grows from %d to %d entries.\n", fprintf(yyTraceFILE,"%sStack grows to %d entries!\n",
yyTracePrompt, p->yystksz, newSize); yyTracePrompt, p->yystksz);
} }
#endif #endif
p->yystksz = newSize;
} }
return pNew==0;
} }
#endif #endif
/* Datatype of the argument to the memory allocated passed as the
** second argument to ParseAlloc() below. This can be changed by
** putting an appropriate #define in the %include section of the input
** grammar.
*/
#ifndef YYMALLOCARGTYPE
# define YYMALLOCARGTYPE size_t
#endif
/* Initialize a new parser that has already been allocated.
*/
void ParseInit(void *yypParser){
yyParser *pParser = (yyParser*)yypParser;
#ifdef YYTRACKMAXSTACKDEPTH
pParser->yyhwm = 0;
#endif
#if YYSTACKDEPTH<=0
pParser->yytos = NULL;
pParser->yystack = NULL;
pParser->yystksz = 0;
if( yyGrowStack(pParser) ){
pParser->yystack = &pParser->yystk0;
pParser->yystksz = 1;
}
#endif
#ifndef YYNOERRORRECOVERY
pParser->yyerrcnt = -1;
#endif
pParser->yytos = pParser->yystack;
pParser->yystack[0].stateno = 0;
pParser->yystack[0].major = 0;
#if YYSTACKDEPTH>0
pParser->yystackEnd = &pParser->yystack[YYSTACKDEPTH-1];
#endif
}
#ifndef Parse_ENGINEALWAYSONSTACK
/* /*
** This function allocates a new parser. ** This function allocates a new parser.
** The only argument is a pointer to a function which works like ** The only argument is a pointer to a function which works like
...@@ -1350,21 +1069,27 @@ void ParseInit(void *yypParser){ ...@@ -1350,21 +1069,27 @@ void ParseInit(void *yypParser){
** A pointer to a parser. This pointer is used in subsequent calls ** A pointer to a parser. This pointer is used in subsequent calls
** to Parse and ParseFree. ** to Parse and ParseFree.
*/ */
void *ParseAlloc(void *(*mallocProc)(YYMALLOCARGTYPE)){ void *ParseAlloc(void *(*mallocProc)(size_t)){
yyParser *pParser; yyParser *pParser;
pParser = (yyParser*)(*mallocProc)( (YYMALLOCARGTYPE)sizeof(yyParser) ); pParser = (yyParser*)(*mallocProc)( (size_t)sizeof(yyParser) );
if( pParser ) ParseInit(pParser); if( pParser ){
pParser->yyidx = -1;
#ifdef YYTRACKMAXSTACKDEPTH
pParser->yyidxMax = 0;
#endif
#if YYSTACKDEPTH<=0
pParser->yystack = NULL;
pParser->yystksz = 0;
yyGrowStack(pParser);
#endif
}
return pParser; return pParser;
} }
#endif /* Parse_ENGINEALWAYSONSTACK */
/* The following function deletes the "minor type" or semantic value /* The following function deletes the value associated with a
** associated with a symbol. The symbol can be either a terminal ** symbol. The symbol can be either a terminal or nonterminal.
** or nonterminal. "yymajor" is the symbol code, and "yypminor" is ** "yymajor" is the symbol code, and "yypminor" is a pointer to
** a pointer to the value to be deleted. The code used to do the ** the value.
** deletions is derived from the %destructor and/or %token_destructor
** directives of the input grammar.
*/ */
static void yy_destructor( static void yy_destructor(
yyParser *yypParser, /* The parser */ yyParser *yypParser, /* The parser */
...@@ -1380,58 +1105,70 @@ static void yy_destructor( ...@@ -1380,58 +1105,70 @@ static void yy_destructor(
** being destroyed before it is finished parsing. ** being destroyed before it is finished parsing.
** **
** Note: during a reduce, the only symbols destroyed are those ** Note: during a reduce, the only symbols destroyed are those
** which appear on the RHS of the rule, but which are *not* used ** which appear on the RHS of the rule, but which are not used
** inside the C code. ** inside the C code.
*/ */
/********* Begin destructor definitions ***************************************/ case 230: /* keep */
case 229: /* keep */ case 231: /* tagitemlist */
case 230: /* tagitemlist */ case 251: /* columnlist */
case 250: /* columnlist */ case 259: /* fill_opt */
case 258: /* fill_opt */ case 261: /* groupby_opt */
case 260: /* groupby_opt */ case 262: /* orderby_opt */
case 261: /* orderby_opt */ case 273: /* sortlist */
case 271: /* sortlist */ case 277: /* grouplist */
case 275: /* grouplist */
{ {
taosArrayDestroy((yypminor->yy421)); #line 227 "sql.y"
taosArrayDestroy((yypminor->yy221));
#line 1123 "sql.c"
} }
break; break;
case 248: /* create_table_list */ case 249: /* create_table_list */
{ {
destroyCreateTableSql((yypminor->yy38)); #line 311 "sql.y"
destroyCreateTableSql((yypminor->yy358));
#line 1130 "sql.c"
} }
break; break;
case 251: /* select */ case 252: /* select */
{ {
doDestroyQuerySql((yypminor->yy148)); #line 418 "sql.y"
doDestroyQuerySql((yypminor->yy344));
#line 1137 "sql.c"
} }
break; break;
case 254: /* selcollist */ case 255: /* selcollist */
case 266: /* sclp */ case 267: /* sclp */
case 276: /* exprlist */ case 278: /* exprlist */
{ {
tSqlExprListDestroy((yypminor->yy166)); #line 445 "sql.y"
tSqlExprListDestroy((yypminor->yy178));
#line 1146 "sql.c"
} }
break; break;
case 256: /* where_opt */ case 257: /* where_opt */
case 262: /* having_opt */ case 263: /* having_opt */
case 267: /* expr */ case 269: /* expr */
case 277: /* expritem */ case 279: /* expritem */
{ {
tSqlExprDestroy((yypminor->yy78)); #line 612 "sql.y"
tSqlExprDestroy((yypminor->yy50));
#line 1156 "sql.c"
} }
break; break;
case 265: /* union */ case 266: /* union */
{ {
destroyAllSelectClause((yypminor->yy153)); #line 424 "sql.y"
destroyAllSelectClause((yypminor->yy273));
#line 1163 "sql.c"
} }
break; break;
case 272: /* sortitem */ case 274: /* sortitem */
{ {
tVariantDestroy(&(yypminor->yy430)); #line 545 "sql.y"
tVariantDestroy(&(yypminor->yy106));
#line 1170 "sql.c"
} }
break; break;
/********* End destructor definitions *****************************************/
default: break; /* If no destructor action specified: do nothing */ default: break; /* If no destructor action specified: do nothing */
} }
} }
...@@ -1441,53 +1178,51 @@ tVariantDestroy(&(yypminor->yy430)); ...@@ -1441,53 +1178,51 @@ tVariantDestroy(&(yypminor->yy430));
** **
** If there is a destructor routine associated with the token which ** If there is a destructor routine associated with the token which
** is popped from the stack, then call it. ** is popped from the stack, then call it.
**
** Return the major token number for the symbol popped.
*/ */
static void yy_pop_parser_stack(yyParser *pParser){ static int yy_pop_parser_stack(yyParser *pParser){
yyStackEntry *yytos; YYCODETYPE yymajor;
assert( pParser->yytos!=0 ); yyStackEntry *yytos = &pParser->yystack[pParser->yyidx];
assert( pParser->yytos > pParser->yystack );
yytos = pParser->yytos--; if( pParser->yyidx<0 ) return 0;
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE ){ if( yyTraceFILE && pParser->yyidx>=0 ){
fprintf(yyTraceFILE,"%sPopping %s\n", fprintf(yyTraceFILE,"%sPopping %s\n",
yyTracePrompt, yyTracePrompt,
yyTokenName[yytos->major]); yyTokenName[yytos->major]);
} }
#endif #endif
yy_destructor(pParser, yytos->major, &yytos->minor); yymajor = yytos->major;
} yy_destructor(pParser, yymajor, &yytos->minor);
pParser->yyidx--;
/* return yymajor;
** Clear all secondary memory allocations from the parser
*/
void ParseFinalize(void *p){
yyParser *pParser = (yyParser*)p;
while( pParser->yytos>pParser->yystack ) yy_pop_parser_stack(pParser);
#if YYSTACKDEPTH<=0
if( pParser->yystack!=&pParser->yystk0 ) free(pParser->yystack);
#endif
} }
#ifndef Parse_ENGINEALWAYSONSTACK
/* /*
** Deallocate and destroy a parser. Destructors are called for ** Deallocate and destroy a parser. Destructors are all called for
** all stack elements before shutting the parser down. ** all stack elements before shutting the parser down.
** **
** If the YYPARSEFREENEVERNULL macro exists (for example because it ** Inputs:
** is defined in a %include section of the input grammar) then it is ** <ul>
** assumed that the input pointer is never NULL. ** <li> A pointer to the parser. This should be a pointer
** obtained from ParseAlloc.
** <li> A pointer to a function used to reclaim memory obtained
** from malloc.
** </ul>
*/ */
void ParseFree( void ParseFree(
void *p, /* The parser to be deleted */ void *p, /* The parser to be deleted */
void (*freeProc)(void*) /* Function used to reclaim memory */ void (*freeProc)(void*) /* Function used to reclaim memory */
){ ){
#ifndef YYPARSEFREENEVERNULL yyParser *pParser = (yyParser*)p;
if( p==0 ) return; if( pParser==0 ) return;
while( pParser->yyidx>=0 ) yy_pop_parser_stack(pParser);
#if YYSTACKDEPTH<=0
free(pParser->yystack);
#endif #endif
ParseFinalize(p); (*freeProc)((void*)pParser);
(*freeProc)(p);
} }
#endif /* Parse_ENGINEALWAYSONSTACK */
/* /*
** Return the peak depth of the stack for a parser. ** Return the peak depth of the stack for a parser.
...@@ -1495,70 +1230,33 @@ void ParseFree( ...@@ -1495,70 +1230,33 @@ void ParseFree(
#ifdef YYTRACKMAXSTACKDEPTH #ifdef YYTRACKMAXSTACKDEPTH
int ParseStackPeak(void *p){ int ParseStackPeak(void *p){
yyParser *pParser = (yyParser*)p; yyParser *pParser = (yyParser*)p;
return pParser->yyhwm; return pParser->yyidxMax;
}
#endif
/* This array of booleans keeps track of the parser statement
** coverage. The element yycoverage[X][Y] is set when the parser
** is in state X and has a lookahead token Y. In a well-tested
** systems, every element of this matrix should end up being set.
*/
#if defined(YYCOVERAGE)
static unsigned char yycoverage[YYNSTATE][YYNTOKEN];
#endif
/*
** Write into out a description of every state/lookahead combination that
**
** (1) has not been used by the parser, and
** (2) is not a syntax error.
**
** Return the number of missed state/lookahead combinations.
*/
#if defined(YYCOVERAGE)
int ParseCoverage(FILE *out){
int stateno, iLookAhead, i;
int nMissed = 0;
for(stateno=0; stateno<YYNSTATE; stateno++){
i = yy_shift_ofst[stateno];
for(iLookAhead=0; iLookAhead<YYNTOKEN; iLookAhead++){
if( yy_lookahead[i+iLookAhead]!=iLookAhead ) continue;
if( yycoverage[stateno][iLookAhead]==0 ) nMissed++;
if( out ){
fprintf(out,"State %d lookahead %s %s\n", stateno,
yyTokenName[iLookAhead],
yycoverage[stateno][iLookAhead] ? "ok" : "missed");
}
}
}
return nMissed;
} }
#endif #endif
/* /*
** Find the appropriate action for a parser given the terminal ** Find the appropriate action for a parser given the terminal
** look-ahead token iLookAhead. ** look-ahead token iLookAhead.
**
** If the look-ahead token is YYNOCODE, then check to see if the action is
** independent of the look-ahead. If it is, return the action, otherwise
** return YY_NO_ACTION.
*/ */
static unsigned int yy_find_shift_action( static int yy_find_shift_action(
yyParser *pParser, /* The parser */ yyParser *pParser, /* The parser */
YYCODETYPE iLookAhead /* The look-ahead token */ YYCODETYPE iLookAhead /* The look-ahead token */
){ ){
int i; int i;
int stateno = pParser->yytos->stateno; int stateno = pParser->yystack[pParser->yyidx].stateno;
if( stateno>YY_MAX_SHIFT ) return stateno; if( stateno>YY_SHIFT_COUNT
assert( stateno <= YY_SHIFT_COUNT ); || (i = yy_shift_ofst[stateno])==YY_SHIFT_USE_DFLT ){
#if defined(YYCOVERAGE) return yy_default[stateno];
yycoverage[stateno][iLookAhead] = 1; }
#endif assert( iLookAhead!=YYNOCODE );
do{ i += iLookAhead;
i = yy_shift_ofst[stateno]; if( i<0 || i>=YY_ACTTAB_COUNT || yy_lookahead[i]!=iLookAhead ){
assert( i>=0 && i+YYNTOKEN<=sizeof(yy_lookahead)/sizeof(yy_lookahead[0]) ); if( iLookAhead>0 ){
assert( iLookAhead!=YYNOCODE );
assert( iLookAhead < YYNTOKEN );
i += iLookAhead;
if( yy_lookahead[i]!=iLookAhead ){
#ifdef YYFALLBACK #ifdef YYFALLBACK
YYCODETYPE iFallback; /* Fallback token */ YYCODETYPE iFallback; /* Fallback token */
if( iLookAhead<sizeof(yyFallback)/sizeof(yyFallback[0]) if( iLookAhead<sizeof(yyFallback)/sizeof(yyFallback[0])
...@@ -1569,9 +1267,7 @@ static unsigned int yy_find_shift_action( ...@@ -1569,9 +1267,7 @@ static unsigned int yy_find_shift_action(
yyTracePrompt, yyTokenName[iLookAhead], yyTokenName[iFallback]); yyTracePrompt, yyTokenName[iLookAhead], yyTokenName[iFallback]);
} }
#endif #endif
assert( yyFallback[iFallback]==0 ); /* Fallback loop must terminate */ return yy_find_shift_action(pParser, iFallback);
iLookAhead = iFallback;
continue;
} }
#endif #endif
#ifdef YYWILDCARD #ifdef YYWILDCARD
...@@ -1584,29 +1280,32 @@ static unsigned int yy_find_shift_action( ...@@ -1584,29 +1280,32 @@ static unsigned int yy_find_shift_action(
#if YY_SHIFT_MAX+YYWILDCARD>=YY_ACTTAB_COUNT #if YY_SHIFT_MAX+YYWILDCARD>=YY_ACTTAB_COUNT
j<YY_ACTTAB_COUNT && j<YY_ACTTAB_COUNT &&
#endif #endif
yy_lookahead[j]==YYWILDCARD && iLookAhead>0 yy_lookahead[j]==YYWILDCARD
){ ){
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE ){ if( yyTraceFILE ){
fprintf(yyTraceFILE, "%sWILDCARD %s => %s\n", fprintf(yyTraceFILE, "%sWILDCARD %s => %s\n",
yyTracePrompt, yyTokenName[iLookAhead], yyTracePrompt, yyTokenName[iLookAhead], yyTokenName[YYWILDCARD]);
yyTokenName[YYWILDCARD]);
} }
#endif /* NDEBUG */ #endif /* NDEBUG */
return yy_action[j]; return yy_action[j];
} }
} }
#endif /* YYWILDCARD */ #endif /* YYWILDCARD */
return yy_default[stateno];
}else{
return yy_action[i];
} }
}while(1); return yy_default[stateno];
}else{
return yy_action[i];
}
} }
/* /*
** Find the appropriate action for a parser given the non-terminal ** Find the appropriate action for a parser given the non-terminal
** look-ahead token iLookAhead. ** look-ahead token iLookAhead.
**
** If the look-ahead token is YYNOCODE, then check to see if the action is
** independent of the look-ahead. If it is, return the action, otherwise
** return YY_NO_ACTION.
*/ */
static int yy_find_reduce_action( static int yy_find_reduce_action(
int stateno, /* Current state number */ int stateno, /* Current state number */
...@@ -1621,6 +1320,7 @@ static int yy_find_reduce_action( ...@@ -1621,6 +1320,7 @@ static int yy_find_reduce_action(
assert( stateno<=YY_REDUCE_COUNT ); assert( stateno<=YY_REDUCE_COUNT );
#endif #endif
i = yy_reduce_ofst[stateno]; i = yy_reduce_ofst[stateno];
assert( i!=YY_REDUCE_USE_DFLT );
assert( iLookAhead!=YYNOCODE ); assert( iLookAhead!=YYNOCODE );
i += iLookAhead; i += iLookAhead;
#ifdef YYERRORSYMBOL #ifdef YYERRORSYMBOL
...@@ -1637,42 +1337,20 @@ static int yy_find_reduce_action( ...@@ -1637,42 +1337,20 @@ static int yy_find_reduce_action(
/* /*
** The following routine is called if the stack overflows. ** The following routine is called if the stack overflows.
*/ */
static void yyStackOverflow(yyParser *yypParser){ static void yyStackOverflow(yyParser *yypParser, YYMINORTYPE *yypMinor){
ParseARG_FETCH; ParseARG_FETCH;
yypParser->yyidx--;
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE ){ if( yyTraceFILE ){
fprintf(yyTraceFILE,"%sStack Overflow!\n",yyTracePrompt); fprintf(yyTraceFILE,"%sStack Overflow!\n",yyTracePrompt);
} }
#endif #endif
while( yypParser->yytos>yypParser->yystack ) yy_pop_parser_stack(yypParser); while( yypParser->yyidx>=0 ) yy_pop_parser_stack(yypParser);
/* Here code is inserted which will execute if the parser /* Here code is inserted which will execute if the parser
** stack every overflows */ ** stack every overflows */
/******** Begin %stack_overflow code ******************************************/
/******** End %stack_overflow code ********************************************/
ParseARG_STORE; /* Suppress warning about unused %extra_argument var */ ParseARG_STORE; /* Suppress warning about unused %extra_argument var */
} }
/*
** Print tracing information for a SHIFT action
*/
#ifndef NDEBUG
static void yyTraceShift(yyParser *yypParser, int yyNewState, const char *zTag){
if( yyTraceFILE ){
if( yyNewState<YYNSTATE ){
fprintf(yyTraceFILE,"%s%s '%s', go to state %d\n",
yyTracePrompt, zTag, yyTokenName[yypParser->yytos->major],
yyNewState);
}else{
fprintf(yyTraceFILE,"%s%s '%s', pending reduce %d\n",
yyTracePrompt, zTag, yyTokenName[yypParser->yytos->major],
yyNewState - YY_MIN_REDUCE);
}
}
}
#else
# define yyTraceShift(X,Y,Z)
#endif
/* /*
** Perform a shift action. ** Perform a shift action.
*/ */
...@@ -1680,288 +1358,294 @@ static void yy_shift( ...@@ -1680,288 +1358,294 @@ static void yy_shift(
yyParser *yypParser, /* The parser to be shifted */ yyParser *yypParser, /* The parser to be shifted */
int yyNewState, /* The new state to shift in */ int yyNewState, /* The new state to shift in */
int yyMajor, /* The major token to shift in */ int yyMajor, /* The major token to shift in */
ParseTOKENTYPE yyMinor /* The minor token to shift in */ YYMINORTYPE *yypMinor /* Pointer to the minor token to shift in */
){ ){
yyStackEntry *yytos; yyStackEntry *yytos;
yypParser->yytos++; yypParser->yyidx++;
#ifdef YYTRACKMAXSTACKDEPTH #ifdef YYTRACKMAXSTACKDEPTH
if( (int)(yypParser->yytos - yypParser->yystack)>yypParser->yyhwm ){ if( yypParser->yyidx>yypParser->yyidxMax ){
yypParser->yyhwm++; yypParser->yyidxMax = yypParser->yyidx;
assert( yypParser->yyhwm == (int)(yypParser->yytos - yypParser->yystack) );
} }
#endif #endif
#if YYSTACKDEPTH>0 #if YYSTACKDEPTH>0
if( yypParser->yytos>yypParser->yystackEnd ){ if( yypParser->yyidx>=YYSTACKDEPTH ){
yypParser->yytos--; yyStackOverflow(yypParser, yypMinor);
yyStackOverflow(yypParser);
return; return;
} }
#else #else
if( yypParser->yytos>=&yypParser->yystack[yypParser->yystksz] ){ if( yypParser->yyidx>=yypParser->yystksz ){
if( yyGrowStack(yypParser) ){ yyGrowStack(yypParser);
yypParser->yytos--; if( yypParser->yyidx>=yypParser->yystksz ){
yyStackOverflow(yypParser); yyStackOverflow(yypParser, yypMinor);
return; return;
} }
} }
#endif #endif
if( yyNewState > YY_MAX_SHIFT ){ yytos = &yypParser->yystack[yypParser->yyidx];
yyNewState += YY_MIN_REDUCE - YY_MIN_SHIFTREDUCE;
}
yytos = yypParser->yytos;
yytos->stateno = (YYACTIONTYPE)yyNewState; yytos->stateno = (YYACTIONTYPE)yyNewState;
yytos->major = (YYCODETYPE)yyMajor; yytos->major = (YYCODETYPE)yyMajor;
yytos->minor.yy0 = yyMinor; yytos->minor = *yypMinor;
yyTraceShift(yypParser, yyNewState, "Shift"); #ifndef NDEBUG
if( yyTraceFILE && yypParser->yyidx>0 ){
int i;
fprintf(yyTraceFILE,"%sShift %d\n",yyTracePrompt,yyNewState);
fprintf(yyTraceFILE,"%sStack:",yyTracePrompt);
for(i=1; i<=yypParser->yyidx; i++)
fprintf(yyTraceFILE," %s",yyTokenName[yypParser->yystack[i].major]);
fprintf(yyTraceFILE,"\n");
}
#endif
} }
/* The following table contains information about every rule that /* The following table contains information about every rule that
** is used during the reduce. ** is used during the reduce.
*/ */
static const struct { static const struct {
YYCODETYPE lhs; /* Symbol on the left-hand side of the rule */ YYCODETYPE lhs; /* Symbol on the left-hand side of the rule */
signed char nrhs; /* Negative of the number of RHS symbols in the rule */ unsigned char nrhs; /* Number of right-hand side symbols in the rule */
} yyRuleInfo[] = { } yyRuleInfo[] = {
{ 210, -1 }, /* (0) program ::= cmd */ { 211, 1 },
{ 211, -2 }, /* (1) cmd ::= SHOW DATABASES */ { 212, 2 },
{ 211, -2 }, /* (2) cmd ::= SHOW MNODES */ { 212, 2 },
{ 211, -2 }, /* (3) cmd ::= SHOW DNODES */ { 212, 2 },
{ 211, -2 }, /* (4) cmd ::= SHOW ACCOUNTS */ { 212, 2 },
{ 211, -2 }, /* (5) cmd ::= SHOW USERS */ { 212, 2 },
{ 211, -2 }, /* (6) cmd ::= SHOW MODULES */ { 212, 2 },
{ 211, -2 }, /* (7) cmd ::= SHOW QUERIES */ { 212, 2 },
{ 211, -2 }, /* (8) cmd ::= SHOW CONNECTIONS */ { 212, 2 },
{ 211, -2 }, /* (9) cmd ::= SHOW STREAMS */ { 212, 2 },
{ 211, -2 }, /* (10) cmd ::= SHOW VARIABLES */ { 212, 2 },
{ 211, -2 }, /* (11) cmd ::= SHOW SCORES */ { 212, 2 },
{ 211, -2 }, /* (12) cmd ::= SHOW GRANTS */ { 212, 2 },
{ 211, -2 }, /* (13) cmd ::= SHOW VNODES */ { 212, 2 },
{ 211, -3 }, /* (14) cmd ::= SHOW VNODES IPTOKEN */ { 212, 3 },
{ 212, 0 }, /* (15) dbPrefix ::= */ { 213, 0 },
{ 212, -2 }, /* (16) dbPrefix ::= ids DOT */ { 213, 2 },
{ 214, 0 }, /* (17) cpxName ::= */ { 215, 0 },
{ 214, -2 }, /* (18) cpxName ::= DOT ids */ { 215, 2 },
{ 211, -5 }, /* (19) cmd ::= SHOW CREATE TABLE ids cpxName */ { 212, 5 },
{ 211, -4 }, /* (20) cmd ::= SHOW CREATE DATABASE ids */ { 212, 4 },
{ 211, -3 }, /* (21) cmd ::= SHOW dbPrefix TABLES */ { 212, 3 },
{ 211, -5 }, /* (22) cmd ::= SHOW dbPrefix TABLES LIKE ids */ { 212, 5 },
{ 211, -3 }, /* (23) cmd ::= SHOW dbPrefix STABLES */ { 212, 3 },
{ 211, -5 }, /* (24) cmd ::= SHOW dbPrefix STABLES LIKE ids */ { 212, 5 },
{ 211, -3 }, /* (25) cmd ::= SHOW dbPrefix VGROUPS */ { 212, 3 },
{ 211, -4 }, /* (26) cmd ::= SHOW dbPrefix VGROUPS ids */ { 212, 4 },
{ 211, -5 }, /* (27) cmd ::= DROP TABLE ifexists ids cpxName */ { 212, 5 },
{ 211, -4 }, /* (28) cmd ::= DROP DATABASE ifexists ids */ { 212, 4 },
{ 211, -3 }, /* (29) cmd ::= DROP DNODE ids */ { 212, 3 },
{ 211, -3 }, /* (30) cmd ::= DROP USER ids */ { 212, 3 },
{ 211, -3 }, /* (31) cmd ::= DROP ACCOUNT ids */ { 212, 3 },
{ 211, -2 }, /* (32) cmd ::= USE ids */ { 212, 2 },
{ 211, -3 }, /* (33) cmd ::= DESCRIBE ids cpxName */ { 212, 3 },
{ 211, -5 }, /* (34) cmd ::= ALTER USER ids PASS ids */ { 212, 5 },
{ 211, -5 }, /* (35) cmd ::= ALTER USER ids PRIVILEGE ids */ { 212, 5 },
{ 211, -4 }, /* (36) cmd ::= ALTER DNODE ids ids */ { 212, 4 },
{ 211, -5 }, /* (37) cmd ::= ALTER DNODE ids ids ids */ { 212, 5 },
{ 211, -3 }, /* (38) cmd ::= ALTER LOCAL ids */ { 212, 3 },
{ 211, -4 }, /* (39) cmd ::= ALTER LOCAL ids ids */ { 212, 4 },
{ 211, -4 }, /* (40) cmd ::= ALTER DATABASE ids alter_db_optr */ { 212, 4 },
{ 211, -4 }, /* (41) cmd ::= ALTER ACCOUNT ids acct_optr */ { 212, 4 },
{ 211, -6 }, /* (42) cmd ::= ALTER ACCOUNT ids PASS ids acct_optr */ { 212, 6 },
{ 213, -1 }, /* (43) ids ::= ID */ { 214, 1 },
{ 213, -1 }, /* (44) ids ::= STRING */ { 214, 1 },
{ 215, -2 }, /* (45) ifexists ::= IF EXISTS */ { 216, 2 },
{ 215, 0 }, /* (46) ifexists ::= */ { 216, 0 },
{ 218, -3 }, /* (47) ifnotexists ::= IF NOT EXISTS */ { 219, 3 },
{ 218, 0 }, /* (48) ifnotexists ::= */ { 219, 0 },
{ 211, -3 }, /* (49) cmd ::= CREATE DNODE ids */ { 212, 3 },
{ 211, -6 }, /* (50) cmd ::= CREATE ACCOUNT ids PASS ids acct_optr */ { 212, 6 },
{ 211, -5 }, /* (51) cmd ::= CREATE DATABASE ifnotexists ids db_optr */ { 212, 5 },
{ 211, -5 }, /* (52) cmd ::= CREATE USER ids PASS ids */ { 212, 5 },
{ 220, 0 }, /* (53) pps ::= */ { 221, 0 },
{ 220, -2 }, /* (54) pps ::= PPS INTEGER */ { 221, 2 },
{ 221, 0 }, /* (55) tseries ::= */ { 222, 0 },
{ 221, -2 }, /* (56) tseries ::= TSERIES INTEGER */ { 222, 2 },
{ 222, 0 }, /* (57) dbs ::= */ { 223, 0 },
{ 222, -2 }, /* (58) dbs ::= DBS INTEGER */ { 223, 2 },
{ 223, 0 }, /* (59) streams ::= */ { 224, 0 },
{ 223, -2 }, /* (60) streams ::= STREAMS INTEGER */ { 224, 2 },
{ 224, 0 }, /* (61) storage ::= */ { 225, 0 },
{ 224, -2 }, /* (62) storage ::= STORAGE INTEGER */ { 225, 2 },
{ 225, 0 }, /* (63) qtime ::= */ { 226, 0 },
{ 225, -2 }, /* (64) qtime ::= QTIME INTEGER */ { 226, 2 },
{ 226, 0 }, /* (65) users ::= */ { 227, 0 },
{ 226, -2 }, /* (66) users ::= USERS INTEGER */ { 227, 2 },
{ 227, 0 }, /* (67) conns ::= */ { 228, 0 },
{ 227, -2 }, /* (68) conns ::= CONNS INTEGER */ { 228, 2 },
{ 228, 0 }, /* (69) state ::= */ { 229, 0 },
{ 228, -2 }, /* (70) state ::= STATE ids */ { 229, 2 },
{ 217, -9 }, /* (71) acct_optr ::= pps tseries storage streams qtime dbs users conns state */ { 218, 9 },
{ 229, -2 }, /* (72) keep ::= KEEP tagitemlist */ { 230, 2 },
{ 231, -2 }, /* (73) cache ::= CACHE INTEGER */ { 232, 2 },
{ 232, -2 }, /* (74) replica ::= REPLICA INTEGER */ { 233, 2 },
{ 233, -2 }, /* (75) quorum ::= QUORUM INTEGER */ { 234, 2 },
{ 234, -2 }, /* (76) days ::= DAYS INTEGER */ { 235, 2 },
{ 235, -2 }, /* (77) minrows ::= MINROWS INTEGER */ { 236, 2 },
{ 236, -2 }, /* (78) maxrows ::= MAXROWS INTEGER */ { 237, 2 },
{ 237, -2 }, /* (79) blocks ::= BLOCKS INTEGER */ { 238, 2 },
{ 238, -2 }, /* (80) ctime ::= CTIME INTEGER */ { 239, 2 },
{ 239, -2 }, /* (81) wal ::= WAL INTEGER */ { 240, 2 },
{ 240, -2 }, /* (82) fsync ::= FSYNC INTEGER */ { 241, 2 },
{ 241, -2 }, /* (83) comp ::= COMP INTEGER */ { 242, 2 },
{ 242, -2 }, /* (84) prec ::= PRECISION STRING */ { 243, 2 },
{ 243, -2 }, /* (85) update ::= UPDATE INTEGER */ { 244, 2 },
{ 244, -2 }, /* (86) cachelast ::= CACHELAST INTEGER */ { 245, 2 },
{ 219, 0 }, /* (87) db_optr ::= */ { 220, 0 },
{ 219, -2 }, /* (88) db_optr ::= db_optr cache */ { 220, 2 },
{ 219, -2 }, /* (89) db_optr ::= db_optr replica */ { 220, 2 },
{ 219, -2 }, /* (90) db_optr ::= db_optr quorum */ { 220, 2 },
{ 219, -2 }, /* (91) db_optr ::= db_optr days */ { 220, 2 },
{ 219, -2 }, /* (92) db_optr ::= db_optr minrows */ { 220, 2 },
{ 219, -2 }, /* (93) db_optr ::= db_optr maxrows */ { 220, 2 },
{ 219, -2 }, /* (94) db_optr ::= db_optr blocks */ { 220, 2 },
{ 219, -2 }, /* (95) db_optr ::= db_optr ctime */ { 220, 2 },
{ 219, -2 }, /* (96) db_optr ::= db_optr wal */ { 220, 2 },
{ 219, -2 }, /* (97) db_optr ::= db_optr fsync */ { 220, 2 },
{ 219, -2 }, /* (98) db_optr ::= db_optr comp */ { 220, 2 },
{ 219, -2 }, /* (99) db_optr ::= db_optr prec */ { 220, 2 },
{ 219, -2 }, /* (100) db_optr ::= db_optr keep */ { 220, 2 },
{ 219, -2 }, /* (101) db_optr ::= db_optr update */ { 220, 2 },
{ 219, -2 }, /* (102) db_optr ::= db_optr cachelast */ { 220, 2 },
{ 216, 0 }, /* (103) alter_db_optr ::= */ { 217, 0 },
{ 216, -2 }, /* (104) alter_db_optr ::= alter_db_optr replica */ { 217, 2 },
{ 216, -2 }, /* (105) alter_db_optr ::= alter_db_optr quorum */ { 217, 2 },
{ 216, -2 }, /* (106) alter_db_optr ::= alter_db_optr keep */ { 217, 2 },
{ 216, -2 }, /* (107) alter_db_optr ::= alter_db_optr blocks */ { 217, 2 },
{ 216, -2 }, /* (108) alter_db_optr ::= alter_db_optr comp */ { 217, 2 },
{ 216, -2 }, /* (109) alter_db_optr ::= alter_db_optr wal */ { 217, 2 },
{ 216, -2 }, /* (110) alter_db_optr ::= alter_db_optr fsync */ { 217, 2 },
{ 216, -2 }, /* (111) alter_db_optr ::= alter_db_optr update */ { 217, 2 },
{ 216, -2 }, /* (112) alter_db_optr ::= alter_db_optr cachelast */ { 217, 2 },
{ 245, -1 }, /* (113) typename ::= ids */ { 246, 1 },
{ 245, -4 }, /* (114) typename ::= ids LP signed RP */ { 246, 4 },
{ 245, -2 }, /* (115) typename ::= ids UNSIGNED */ { 246, 2 },
{ 246, -1 }, /* (116) signed ::= INTEGER */ { 247, 1 },
{ 246, -2 }, /* (117) signed ::= PLUS INTEGER */ { 247, 2 },
{ 246, -2 }, /* (118) signed ::= MINUS INTEGER */ { 247, 2 },
{ 211, -3 }, /* (119) cmd ::= CREATE TABLE create_table_args */ { 212, 3 },
{ 211, -3 }, /* (120) cmd ::= CREATE TABLE create_table_list */ { 212, 3 },
{ 248, -1 }, /* (121) create_table_list ::= create_from_stable */ { 249, 1 },
{ 248, -2 }, /* (122) create_table_list ::= create_table_list create_from_stable */ { 249, 2 },
{ 247, -6 }, /* (123) create_table_args ::= ifnotexists ids cpxName LP columnlist RP */ { 248, 6 },
{ 247, -10 }, /* (124) create_table_args ::= ifnotexists ids cpxName LP columnlist RP TAGS LP columnlist RP */ { 248, 10 },
{ 249, -10 }, /* (125) create_from_stable ::= ifnotexists ids cpxName USING ids cpxName TAGS LP tagitemlist RP */ { 250, 10 },
{ 247, -5 }, /* (126) create_table_args ::= ifnotexists ids cpxName AS select */ { 248, 5 },
{ 250, -3 }, /* (127) columnlist ::= columnlist COMMA column */ { 251, 3 },
{ 250, -1 }, /* (128) columnlist ::= column */ { 251, 1 },
{ 252, -2 }, /* (129) column ::= ids typename */ { 253, 2 },
{ 230, -3 }, /* (130) tagitemlist ::= tagitemlist COMMA tagitem */ { 231, 3 },
{ 230, -1 }, /* (131) tagitemlist ::= tagitem */ { 231, 1 },
{ 253, -1 }, /* (132) tagitem ::= INTEGER */ { 254, 1 },
{ 253, -1 }, /* (133) tagitem ::= FLOAT */ { 254, 1 },
{ 253, -1 }, /* (134) tagitem ::= STRING */ { 254, 1 },
{ 253, -1 }, /* (135) tagitem ::= BOOL */ { 254, 1 },
{ 253, -1 }, /* (136) tagitem ::= NULL */ { 254, 1 },
{ 253, -2 }, /* (137) tagitem ::= MINUS INTEGER */ { 254, 2 },
{ 253, -2 }, /* (138) tagitem ::= MINUS FLOAT */ { 254, 2 },
{ 253, -2 }, /* (139) tagitem ::= PLUS INTEGER */ { 254, 2 },
{ 253, -2 }, /* (140) tagitem ::= PLUS FLOAT */ { 254, 2 },
{ 251, -12 }, /* (141) select ::= SELECT selcollist from where_opt interval_opt fill_opt sliding_opt groupby_opt orderby_opt having_opt slimit_opt limit_opt */ { 252, 12 },
{ 265, -1 }, /* (142) union ::= select */ { 266, 1 },
{ 265, -3 }, /* (143) union ::= LP union RP */ { 266, 3 },
{ 265, -4 }, /* (144) union ::= union UNION ALL select */ { 266, 4 },
{ 265, -6 }, /* (145) union ::= union UNION ALL LP select RP */ { 266, 6 },
{ 211, -1 }, /* (146) cmd ::= union */ { 212, 1 },
{ 251, -2 }, /* (147) select ::= SELECT selcollist */ { 252, 2 },
{ 266, -2 }, /* (148) sclp ::= selcollist COMMA */ { 267, 2 },
{ 266, 0 }, /* (149) sclp ::= */ { 267, 0 },
{ 254, -3 }, /* (150) selcollist ::= sclp expr as */ { 255, 4 },
{ 254, -2 }, /* (151) selcollist ::= sclp STAR */ { 255, 2 },
{ 268, -2 }, /* (152) as ::= AS ids */ { 270, 2 },
{ 268, -1 }, /* (153) as ::= ids */ { 270, 1 },
{ 268, 0 }, /* (154) as ::= */ { 270, 0 },
{ 255, -2 }, /* (155) from ::= FROM tablelist */ { 268, 1 },
{ 269, -2 }, /* (156) tablelist ::= ids cpxName */ { 268, 0 },
{ 269, -3 }, /* (157) tablelist ::= ids cpxName ids */ { 256, 2 },
{ 269, -4 }, /* (158) tablelist ::= tablelist COMMA ids cpxName */ { 271, 2 },
{ 269, -5 }, /* (159) tablelist ::= tablelist COMMA ids cpxName ids */ { 271, 3 },
{ 270, -1 }, /* (160) tmvar ::= VARIABLE */ { 271, 4 },
{ 257, -4 }, /* (161) interval_opt ::= INTERVAL LP tmvar RP */ { 271, 5 },
{ 257, -6 }, /* (162) interval_opt ::= INTERVAL LP tmvar COMMA tmvar RP */ { 272, 1 },
{ 257, 0 }, /* (163) interval_opt ::= */ { 258, 4 },
{ 258, 0 }, /* (164) fill_opt ::= */ { 258, 6 },
{ 258, -6 }, /* (165) fill_opt ::= FILL LP ID COMMA tagitemlist RP */ { 258, 0 },
{ 258, -4 }, /* (166) fill_opt ::= FILL LP ID RP */ { 259, 0 },
{ 259, -4 }, /* (167) sliding_opt ::= SLIDING LP tmvar RP */ { 259, 6 },
{ 259, 0 }, /* (168) sliding_opt ::= */ { 259, 4 },
{ 261, 0 }, /* (169) orderby_opt ::= */ { 260, 4 },
{ 261, -3 }, /* (170) orderby_opt ::= ORDER BY sortlist */ { 260, 0 },
{ 271, -4 }, /* (171) sortlist ::= sortlist COMMA item sortorder */ { 262, 0 },
{ 271, -2 }, /* (172) sortlist ::= item sortorder */ { 262, 3 },
{ 273, -2 }, /* (173) item ::= ids cpxName */ { 273, 4 },
{ 274, -1 }, /* (174) sortorder ::= ASC */ { 273, 2 },
{ 274, -1 }, /* (175) sortorder ::= DESC */ { 275, 2 },
{ 274, 0 }, /* (176) sortorder ::= */ { 276, 1 },
{ 260, 0 }, /* (177) groupby_opt ::= */ { 276, 1 },
{ 260, -3 }, /* (178) groupby_opt ::= GROUP BY grouplist */ { 276, 0 },
{ 275, -3 }, /* (179) grouplist ::= grouplist COMMA item */ { 261, 0 },
{ 275, -1 }, /* (180) grouplist ::= item */ { 261, 3 },
{ 262, 0 }, /* (181) having_opt ::= */ { 277, 3 },
{ 262, -2 }, /* (182) having_opt ::= HAVING expr */ { 277, 1 },
{ 264, 0 }, /* (183) limit_opt ::= */ { 263, 0 },
{ 264, -2 }, /* (184) limit_opt ::= LIMIT signed */ { 263, 2 },
{ 264, -4 }, /* (185) limit_opt ::= LIMIT signed OFFSET signed */ { 265, 0 },
{ 264, -4 }, /* (186) limit_opt ::= LIMIT signed COMMA signed */ { 265, 2 },
{ 263, 0 }, /* (187) slimit_opt ::= */ { 265, 4 },
{ 263, -2 }, /* (188) slimit_opt ::= SLIMIT signed */ { 265, 4 },
{ 263, -4 }, /* (189) slimit_opt ::= SLIMIT signed SOFFSET signed */ { 264, 0 },
{ 263, -4 }, /* (190) slimit_opt ::= SLIMIT signed COMMA signed */ { 264, 2 },
{ 256, 0 }, /* (191) where_opt ::= */ { 264, 4 },
{ 256, -2 }, /* (192) where_opt ::= WHERE expr */ { 264, 4 },
{ 267, -3 }, /* (193) expr ::= LP expr RP */ { 257, 0 },
{ 267, -1 }, /* (194) expr ::= ID */ { 257, 2 },
{ 267, -3 }, /* (195) expr ::= ID DOT ID */ { 269, 3 },
{ 267, -3 }, /* (196) expr ::= ID DOT STAR */ { 269, 1 },
{ 267, -1 }, /* (197) expr ::= INTEGER */ { 269, 3 },
{ 267, -2 }, /* (198) expr ::= MINUS INTEGER */ { 269, 3 },
{ 267, -2 }, /* (199) expr ::= PLUS INTEGER */ { 269, 1 },
{ 267, -1 }, /* (200) expr ::= FLOAT */ { 269, 2 },
{ 267, -2 }, /* (201) expr ::= MINUS FLOAT */ { 269, 2 },
{ 267, -2 }, /* (202) expr ::= PLUS FLOAT */ { 269, 1 },
{ 267, -1 }, /* (203) expr ::= STRING */ { 269, 2 },
{ 267, -1 }, /* (204) expr ::= NOW */ { 269, 2 },
{ 267, -1 }, /* (205) expr ::= VARIABLE */ { 269, 1 },
{ 267, -1 }, /* (206) expr ::= BOOL */ { 269, 1 },
{ 267, -4 }, /* (207) expr ::= ID LP exprlist RP */ { 269, 1 },
{ 267, -4 }, /* (208) expr ::= ID LP STAR RP */ { 269, 1 },
{ 267, -3 }, /* (209) expr ::= expr IS NULL */ { 269, 4 },
{ 267, -4 }, /* (210) expr ::= expr IS NOT NULL */ { 269, 4 },
{ 267, -3 }, /* (211) expr ::= expr LT expr */ { 269, 3 },
{ 267, -3 }, /* (212) expr ::= expr GT expr */ { 269, 4 },
{ 267, -3 }, /* (213) expr ::= expr LE expr */ { 269, 3 },
{ 267, -3 }, /* (214) expr ::= expr GE expr */ { 269, 3 },
{ 267, -3 }, /* (215) expr ::= expr NE expr */ { 269, 3 },
{ 267, -3 }, /* (216) expr ::= expr EQ expr */ { 269, 3 },
{ 267, -3 }, /* (217) expr ::= expr AND expr */ { 269, 3 },
{ 267, -3 }, /* (218) expr ::= expr OR expr */ { 269, 3 },
{ 267, -3 }, /* (219) expr ::= expr PLUS expr */ { 269, 3 },
{ 267, -3 }, /* (220) expr ::= expr MINUS expr */ { 269, 3 },
{ 267, -3 }, /* (221) expr ::= expr STAR expr */ { 269, 3 },
{ 267, -3 }, /* (222) expr ::= expr SLASH expr */ { 269, 3 },
{ 267, -3 }, /* (223) expr ::= expr REM expr */ { 269, 3 },
{ 267, -3 }, /* (224) expr ::= expr LIKE expr */ { 269, 3 },
{ 267, -5 }, /* (225) expr ::= expr IN LP exprlist RP */ { 269, 3 },
{ 276, -3 }, /* (226) exprlist ::= exprlist COMMA expritem */ { 269, 3 },
{ 276, -1 }, /* (227) exprlist ::= expritem */ { 269, 5 },
{ 277, -1 }, /* (228) expritem ::= expr */ { 278, 3 },
{ 277, 0 }, /* (229) expritem ::= */ { 278, 1 },
{ 211, -3 }, /* (230) cmd ::= RESET QUERY CACHE */ { 279, 1 },
{ 211, -7 }, /* (231) cmd ::= ALTER TABLE ids cpxName ADD COLUMN columnlist */ { 279, 0 },
{ 211, -7 }, /* (232) cmd ::= ALTER TABLE ids cpxName DROP COLUMN ids */ { 212, 3 },
{ 211, -7 }, /* (233) cmd ::= ALTER TABLE ids cpxName ADD TAG columnlist */ { 212, 7 },
{ 211, -7 }, /* (234) cmd ::= ALTER TABLE ids cpxName DROP TAG ids */ { 212, 7 },
{ 211, -8 }, /* (235) cmd ::= ALTER TABLE ids cpxName CHANGE TAG ids ids */ { 212, 7 },
{ 211, -9 }, /* (236) cmd ::= ALTER TABLE ids cpxName SET TAG ids EQ tagitem */ { 212, 7 },
{ 211, -3 }, /* (237) cmd ::= KILL CONNECTION INTEGER */ { 212, 8 },
{ 211, -5 }, /* (238) cmd ::= KILL STREAM INTEGER COLON INTEGER */ { 212, 9 },
{ 211, -5 }, /* (239) cmd ::= KILL QUERY INTEGER COLON INTEGER */ { 212, 3 },
{ 212, 5 },
{ 212, 5 },
}; };
static void yy_accept(yyParser*); /* Forward Declaration */ static void yy_accept(yyParser*); /* Forward Declaration */
...@@ -1969,66 +1653,43 @@ static void yy_accept(yyParser*); /* Forward Declaration */ ...@@ -1969,66 +1653,43 @@ static void yy_accept(yyParser*); /* Forward Declaration */
/* /*
** Perform a reduce action and the shift that must immediately ** Perform a reduce action and the shift that must immediately
** follow the reduce. ** follow the reduce.
**
** The yyLookahead and yyLookaheadToken parameters provide reduce actions
** access to the lookahead token (if any). The yyLookahead will be YYNOCODE
** if the lookahead token has already been consumed. As this procedure is
** only called from one place, optimizing compilers will in-line it, which
** means that the extra parameters have no performance impact.
*/ */
static void yy_reduce( static void yy_reduce(
yyParser *yypParser, /* The parser */ yyParser *yypParser, /* The parser */
unsigned int yyruleno, /* Number of the rule by which to reduce */ int yyruleno /* Number of the rule by which to reduce */
int yyLookahead, /* Lookahead token, or YYNOCODE if none */
ParseTOKENTYPE yyLookaheadToken /* Value of the lookahead token */
){ ){
int yygoto; /* The next state */ int yygoto; /* The next state */
int yyact; /* The next action */ int yyact; /* The next action */
YYMINORTYPE yygotominor; /* The LHS of the rule reduced */
yyStackEntry *yymsp; /* The top of the parser's stack */ yyStackEntry *yymsp; /* The top of the parser's stack */
int yysize; /* Amount to pop the stack */ int yysize; /* Amount to pop the stack */
ParseARG_FETCH; ParseARG_FETCH;
(void)yyLookahead; yymsp = &yypParser->yystack[yypParser->yyidx];
(void)yyLookaheadToken;
yymsp = yypParser->yytos;
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE && yyruleno<(int)(sizeof(yyRuleName)/sizeof(yyRuleName[0])) ){ if( yyTraceFILE && yyruleno>=0
yysize = yyRuleInfo[yyruleno].nrhs; && yyruleno<(int)(sizeof(yyRuleName)/sizeof(yyRuleName[0])) ){
if( yysize ){ fprintf(yyTraceFILE, "%sReduce [%s].\n", yyTracePrompt,
fprintf(yyTraceFILE, "%sReduce %d [%s], go to state %d.\n", yyRuleName[yyruleno]);
yyTracePrompt,
yyruleno, yyRuleName[yyruleno], yymsp[yysize].stateno);
}else{
fprintf(yyTraceFILE, "%sReduce %d [%s].\n",
yyTracePrompt, yyruleno, yyRuleName[yyruleno]);
}
} }
#endif /* NDEBUG */ #endif /* NDEBUG */
/* Check that the stack is large enough to grow by a single entry /* Silence complaints from purify about yygotominor being uninitialized
** if the RHS of the rule is empty. This ensures that there is room ** in some cases when it is copied into the stack after the following
** enough on the stack to push the LHS value */ ** switch. yygotominor is uninitialized when a rule reduces that does
if( yyRuleInfo[yyruleno].nrhs==0 ){ ** not set the value of its left-hand side nonterminal. Leaving the
#ifdef YYTRACKMAXSTACKDEPTH ** value of the nonterminal uninitialized is utterly harmless as long
if( (int)(yypParser->yytos - yypParser->yystack)>yypParser->yyhwm ){ ** as the value is never used. So really the only thing this code
yypParser->yyhwm++; ** accomplishes is to quieten purify.
assert( yypParser->yyhwm == (int)(yypParser->yytos - yypParser->yystack)); **
} ** 2007-01-16: The wireshark project (www.wireshark.org) reports that
#endif ** without this code, their parser segfaults. I'm not sure what there
#if YYSTACKDEPTH>0 ** parser is doing to make this happen. This is the second bug report
if( yypParser->yytos>=yypParser->yystackEnd ){ ** from wireshark this week. Clearly they are stressing Lemon in ways
yyStackOverflow(yypParser); ** that it has not been previously stressed... (SQLite ticket #2172)
return; */
} /*memset(&yygotominor, 0, sizeof(yygotominor));*/
#else yygotominor = yyzerominor;
if( yypParser->yytos>=&yypParser->yystack[yypParser->yystksz-1] ){
if( yyGrowStack(yypParser) ){
yyStackOverflow(yypParser);
return;
}
yymsp = yypParser->yytos;
}
#endif
}
switch( yyruleno ){ switch( yyruleno ){
/* Beginning here are the reduction cases. A typical example /* Beginning here are the reduction cases. A typical example
...@@ -2039,194 +1700,288 @@ static void yy_reduce( ...@@ -2039,194 +1700,288 @@ static void yy_reduce(
** #line <lineno> <thisfile> ** #line <lineno> <thisfile>
** break; ** break;
*/ */
/********** Begin reduce actions **********************************************/
YYMINORTYPE yylhsminor;
case 0: /* program ::= cmd */ case 0: /* program ::= cmd */
case 119: /* cmd ::= CREATE TABLE create_table_args */ yytestcase(yyruleno==119); #line 63 "sql.y"
{} {}
#line 1707 "sql.c"
break; break;
case 1: /* cmd ::= SHOW DATABASES */ case 1: /* cmd ::= SHOW DATABASES */
#line 66 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_DB, 0, 0);} { setShowOptions(pInfo, TSDB_MGMT_TABLE_DB, 0, 0);}
#line 1712 "sql.c"
break; break;
case 2: /* cmd ::= SHOW MNODES */ case 2: /* cmd ::= SHOW MNODES */
#line 67 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_MNODE, 0, 0);} { setShowOptions(pInfo, TSDB_MGMT_TABLE_MNODE, 0, 0);}
#line 1717 "sql.c"
break; break;
case 3: /* cmd ::= SHOW DNODES */ case 3: /* cmd ::= SHOW DNODES */
#line 68 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_DNODE, 0, 0);} { setShowOptions(pInfo, TSDB_MGMT_TABLE_DNODE, 0, 0);}
#line 1722 "sql.c"
break; break;
case 4: /* cmd ::= SHOW ACCOUNTS */ case 4: /* cmd ::= SHOW ACCOUNTS */
#line 69 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_ACCT, 0, 0);} { setShowOptions(pInfo, TSDB_MGMT_TABLE_ACCT, 0, 0);}
#line 1727 "sql.c"
break; break;
case 5: /* cmd ::= SHOW USERS */ case 5: /* cmd ::= SHOW USERS */
#line 70 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_USER, 0, 0);} { setShowOptions(pInfo, TSDB_MGMT_TABLE_USER, 0, 0);}
#line 1732 "sql.c"
break; break;
case 6: /* cmd ::= SHOW MODULES */ case 6: /* cmd ::= SHOW MODULES */
#line 72 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_MODULE, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_MODULE, 0, 0); }
#line 1737 "sql.c"
break; break;
case 7: /* cmd ::= SHOW QUERIES */ case 7: /* cmd ::= SHOW QUERIES */
#line 73 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_QUERIES, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_QUERIES, 0, 0); }
#line 1742 "sql.c"
break; break;
case 8: /* cmd ::= SHOW CONNECTIONS */ case 8: /* cmd ::= SHOW CONNECTIONS */
#line 74 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_CONNS, 0, 0);} { setShowOptions(pInfo, TSDB_MGMT_TABLE_CONNS, 0, 0);}
#line 1747 "sql.c"
break; break;
case 9: /* cmd ::= SHOW STREAMS */ case 9: /* cmd ::= SHOW STREAMS */
#line 75 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_STREAMS, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_STREAMS, 0, 0); }
#line 1752 "sql.c"
break; break;
case 10: /* cmd ::= SHOW VARIABLES */ case 10: /* cmd ::= SHOW VARIABLES */
#line 76 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_VARIABLES, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_VARIABLES, 0, 0); }
#line 1757 "sql.c"
break; break;
case 11: /* cmd ::= SHOW SCORES */ case 11: /* cmd ::= SHOW SCORES */
#line 77 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_SCORES, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_SCORES, 0, 0); }
#line 1762 "sql.c"
break; break;
case 12: /* cmd ::= SHOW GRANTS */ case 12: /* cmd ::= SHOW GRANTS */
#line 78 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_GRANTS, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_GRANTS, 0, 0); }
#line 1767 "sql.c"
break; break;
case 13: /* cmd ::= SHOW VNODES */ case 13: /* cmd ::= SHOW VNODES */
#line 80 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_VNODES, 0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_VNODES, 0, 0); }
#line 1772 "sql.c"
break; break;
case 14: /* cmd ::= SHOW VNODES IPTOKEN */ case 14: /* cmd ::= SHOW VNODES IPTOKEN */
#line 81 "sql.y"
{ setShowOptions(pInfo, TSDB_MGMT_TABLE_VNODES, &yymsp[0].minor.yy0, 0); } { setShowOptions(pInfo, TSDB_MGMT_TABLE_VNODES, &yymsp[0].minor.yy0, 0); }
#line 1777 "sql.c"
break; break;
case 15: /* dbPrefix ::= */ case 15: /* dbPrefix ::= */
{yymsp[1].minor.yy0.n = 0; yymsp[1].minor.yy0.type = 0;} #line 85 "sql.y"
{yygotominor.yy0.n = 0; yygotominor.yy0.type = 0;}
#line 1782 "sql.c"
break; break;
case 16: /* dbPrefix ::= ids DOT */ case 16: /* dbPrefix ::= ids DOT */
{yylhsminor.yy0 = yymsp[-1].minor.yy0; } #line 86 "sql.y"
yymsp[-1].minor.yy0 = yylhsminor.yy0; {yygotominor.yy0 = yymsp[-1].minor.yy0; }
#line 1787 "sql.c"
break; break;
case 17: /* cpxName ::= */ case 17: /* cpxName ::= */
{yymsp[1].minor.yy0.n = 0; } #line 89 "sql.y"
{yygotominor.yy0.n = 0; }
#line 1792 "sql.c"
break; break;
case 18: /* cpxName ::= DOT ids */ case 18: /* cpxName ::= DOT ids */
{yymsp[-1].minor.yy0 = yymsp[0].minor.yy0; yymsp[-1].minor.yy0.n += 1; } #line 90 "sql.y"
{yygotominor.yy0 = yymsp[0].minor.yy0; yygotominor.yy0.n += 1; }
#line 1797 "sql.c"
break; break;
case 19: /* cmd ::= SHOW CREATE TABLE ids cpxName */ case 19: /* cmd ::= SHOW CREATE TABLE ids cpxName */
#line 92 "sql.y"
{ {
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
setDCLSQLElems(pInfo, TSDB_SQL_SHOW_CREATE_TABLE, 1, &yymsp[-1].minor.yy0); setDCLSQLElems(pInfo, TSDB_SQL_SHOW_CREATE_TABLE, 1, &yymsp[-1].minor.yy0);
} }
#line 1805 "sql.c"
break; break;
case 20: /* cmd ::= SHOW CREATE DATABASE ids */ case 20: /* cmd ::= SHOW CREATE DATABASE ids */
#line 97 "sql.y"
{ {
setDCLSQLElems(pInfo, TSDB_SQL_SHOW_CREATE_DATABASE, 1, &yymsp[0].minor.yy0); setDCLSQLElems(pInfo, TSDB_SQL_SHOW_CREATE_DATABASE, 1, &yymsp[0].minor.yy0);
} }
#line 1812 "sql.c"
break; break;
case 21: /* cmd ::= SHOW dbPrefix TABLES */ case 21: /* cmd ::= SHOW dbPrefix TABLES */
#line 101 "sql.y"
{ {
setShowOptions(pInfo, TSDB_MGMT_TABLE_TABLE, &yymsp[-1].minor.yy0, 0); setShowOptions(pInfo, TSDB_MGMT_TABLE_TABLE, &yymsp[-1].minor.yy0, 0);
} }
#line 1819 "sql.c"
break; break;
case 22: /* cmd ::= SHOW dbPrefix TABLES LIKE ids */ case 22: /* cmd ::= SHOW dbPrefix TABLES LIKE ids */
#line 105 "sql.y"
{ {
setShowOptions(pInfo, TSDB_MGMT_TABLE_TABLE, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0); setShowOptions(pInfo, TSDB_MGMT_TABLE_TABLE, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0);
} }
#line 1826 "sql.c"
break; break;
case 23: /* cmd ::= SHOW dbPrefix STABLES */ case 23: /* cmd ::= SHOW dbPrefix STABLES */
#line 109 "sql.y"
{ {
setShowOptions(pInfo, TSDB_MGMT_TABLE_METRIC, &yymsp[-1].minor.yy0, 0); setShowOptions(pInfo, TSDB_MGMT_TABLE_METRIC, &yymsp[-1].minor.yy0, 0);
} }
#line 1833 "sql.c"
break; break;
case 24: /* cmd ::= SHOW dbPrefix STABLES LIKE ids */ case 24: /* cmd ::= SHOW dbPrefix STABLES LIKE ids */
#line 113 "sql.y"
{ {
SStrToken token; SStrToken token;
setDbName(&token, &yymsp[-3].minor.yy0); setDbName(&token, &yymsp[-3].minor.yy0);
setShowOptions(pInfo, TSDB_MGMT_TABLE_METRIC, &token, &yymsp[0].minor.yy0); setShowOptions(pInfo, TSDB_MGMT_TABLE_METRIC, &token, &yymsp[0].minor.yy0);
} }
#line 1842 "sql.c"
break; break;
case 25: /* cmd ::= SHOW dbPrefix VGROUPS */ case 25: /* cmd ::= SHOW dbPrefix VGROUPS */
#line 119 "sql.y"
{ {
SStrToken token; SStrToken token;
setDbName(&token, &yymsp[-1].minor.yy0); setDbName(&token, &yymsp[-1].minor.yy0);
setShowOptions(pInfo, TSDB_MGMT_TABLE_VGROUP, &token, 0); setShowOptions(pInfo, TSDB_MGMT_TABLE_VGROUP, &token, 0);
} }
#line 1851 "sql.c"
break; break;
case 26: /* cmd ::= SHOW dbPrefix VGROUPS ids */ case 26: /* cmd ::= SHOW dbPrefix VGROUPS ids */
#line 125 "sql.y"
{ {
SStrToken token; SStrToken token;
setDbName(&token, &yymsp[-2].minor.yy0); setDbName(&token, &yymsp[-2].minor.yy0);
setShowOptions(pInfo, TSDB_MGMT_TABLE_VGROUP, &token, &yymsp[0].minor.yy0); setShowOptions(pInfo, TSDB_MGMT_TABLE_VGROUP, &token, &yymsp[0].minor.yy0);
} }
#line 1860 "sql.c"
break; break;
case 27: /* cmd ::= DROP TABLE ifexists ids cpxName */ case 27: /* cmd ::= DROP TABLE ifexists ids cpxName */
#line 132 "sql.y"
{ {
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
setDropDbTableInfo(pInfo, TSDB_SQL_DROP_TABLE, &yymsp[-1].minor.yy0, &yymsp[-2].minor.yy0); setDropDbTableInfo(pInfo, TSDB_SQL_DROP_TABLE, &yymsp[-1].minor.yy0, &yymsp[-2].minor.yy0);
} }
#line 1868 "sql.c"
break; break;
case 28: /* cmd ::= DROP DATABASE ifexists ids */ case 28: /* cmd ::= DROP DATABASE ifexists ids */
#line 137 "sql.y"
{ setDropDbTableInfo(pInfo, TSDB_SQL_DROP_DB, &yymsp[0].minor.yy0, &yymsp[-1].minor.yy0); } { setDropDbTableInfo(pInfo, TSDB_SQL_DROP_DB, &yymsp[0].minor.yy0, &yymsp[-1].minor.yy0); }
#line 1873 "sql.c"
break; break;
case 29: /* cmd ::= DROP DNODE ids */ case 29: /* cmd ::= DROP DNODE ids */
#line 138 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_DROP_DNODE, 1, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_DROP_DNODE, 1, &yymsp[0].minor.yy0); }
#line 1878 "sql.c"
break; break;
case 30: /* cmd ::= DROP USER ids */ case 30: /* cmd ::= DROP USER ids */
#line 139 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_DROP_USER, 1, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_DROP_USER, 1, &yymsp[0].minor.yy0); }
#line 1883 "sql.c"
break; break;
case 31: /* cmd ::= DROP ACCOUNT ids */ case 31: /* cmd ::= DROP ACCOUNT ids */
#line 140 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_DROP_ACCT, 1, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_DROP_ACCT, 1, &yymsp[0].minor.yy0); }
#line 1888 "sql.c"
break; break;
case 32: /* cmd ::= USE ids */ case 32: /* cmd ::= USE ids */
#line 143 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_USE_DB, 1, &yymsp[0].minor.yy0);} { setDCLSQLElems(pInfo, TSDB_SQL_USE_DB, 1, &yymsp[0].minor.yy0);}
#line 1893 "sql.c"
break; break;
case 33: /* cmd ::= DESCRIBE ids cpxName */ case 33: /* cmd ::= DESCRIBE ids cpxName */
#line 146 "sql.y"
{ {
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
setDCLSQLElems(pInfo, TSDB_SQL_DESCRIBE_TABLE, 1, &yymsp[-1].minor.yy0); setDCLSQLElems(pInfo, TSDB_SQL_DESCRIBE_TABLE, 1, &yymsp[-1].minor.yy0);
} }
#line 1901 "sql.c"
break; break;
case 34: /* cmd ::= ALTER USER ids PASS ids */ case 34: /* cmd ::= ALTER USER ids PASS ids */
#line 152 "sql.y"
{ setAlterUserSql(pInfo, TSDB_ALTER_USER_PASSWD, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, NULL); } { setAlterUserSql(pInfo, TSDB_ALTER_USER_PASSWD, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0, NULL); }
#line 1906 "sql.c"
break; break;
case 35: /* cmd ::= ALTER USER ids PRIVILEGE ids */ case 35: /* cmd ::= ALTER USER ids PRIVILEGE ids */
#line 153 "sql.y"
{ setAlterUserSql(pInfo, TSDB_ALTER_USER_PRIVILEGES, &yymsp[-2].minor.yy0, NULL, &yymsp[0].minor.yy0);} { setAlterUserSql(pInfo, TSDB_ALTER_USER_PRIVILEGES, &yymsp[-2].minor.yy0, NULL, &yymsp[0].minor.yy0);}
#line 1911 "sql.c"
break; break;
case 36: /* cmd ::= ALTER DNODE ids ids */ case 36: /* cmd ::= ALTER DNODE ids ids */
#line 154 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_CFG_DNODE, 2, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_CFG_DNODE, 2, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); }
#line 1916 "sql.c"
break; break;
case 37: /* cmd ::= ALTER DNODE ids ids ids */ case 37: /* cmd ::= ALTER DNODE ids ids ids */
#line 155 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_CFG_DNODE, 3, &yymsp[-2].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_CFG_DNODE, 3, &yymsp[-2].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); }
#line 1921 "sql.c"
break; break;
case 38: /* cmd ::= ALTER LOCAL ids */ case 38: /* cmd ::= ALTER LOCAL ids */
#line 156 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_CFG_LOCAL, 1, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_CFG_LOCAL, 1, &yymsp[0].minor.yy0); }
#line 1926 "sql.c"
break; break;
case 39: /* cmd ::= ALTER LOCAL ids ids */ case 39: /* cmd ::= ALTER LOCAL ids ids */
#line 157 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_CFG_LOCAL, 2, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); } { setDCLSQLElems(pInfo, TSDB_SQL_CFG_LOCAL, 2, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy0); }
#line 1931 "sql.c"
break; break;
case 40: /* cmd ::= ALTER DATABASE ids alter_db_optr */ case 40: /* cmd ::= ALTER DATABASE ids alter_db_optr */
{ SStrToken t = {0}; setCreateDBSQL(pInfo, TSDB_SQL_ALTER_DB, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy234, &t);} #line 158 "sql.y"
{ SStrToken t = {0}; setCreateDBSQL(pInfo, TSDB_SQL_ALTER_DB, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy478, &t);}
#line 1936 "sql.c"
break; break;
case 41: /* cmd ::= ALTER ACCOUNT ids acct_optr */ case 41: /* cmd ::= ALTER ACCOUNT ids acct_optr */
{ setCreateAcctSql(pInfo, TSDB_SQL_ALTER_ACCT, &yymsp[-1].minor.yy0, NULL, &yymsp[0].minor.yy71);} #line 160 "sql.y"
{ setCreateAcctSql(pInfo, TSDB_SQL_ALTER_ACCT, &yymsp[-1].minor.yy0, NULL, &yymsp[0].minor.yy79);}
#line 1941 "sql.c"
break; break;
case 42: /* cmd ::= ALTER ACCOUNT ids PASS ids acct_optr */ case 42: /* cmd ::= ALTER ACCOUNT ids PASS ids acct_optr */
{ setCreateAcctSql(pInfo, TSDB_SQL_ALTER_ACCT, &yymsp[-3].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy71);} #line 161 "sql.y"
{ setCreateAcctSql(pInfo, TSDB_SQL_ALTER_ACCT, &yymsp[-3].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy79);}
#line 1946 "sql.c"
break; break;
case 43: /* ids ::= ID */ case 43: /* ids ::= ID */
case 44: /* ids ::= STRING */ yytestcase(yyruleno==44); case 44: /* ids ::= STRING */ yytestcase(yyruleno==44);
{yylhsminor.yy0 = yymsp[0].minor.yy0; } #line 167 "sql.y"
yymsp[0].minor.yy0 = yylhsminor.yy0; {yygotominor.yy0 = yymsp[0].minor.yy0; }
#line 1952 "sql.c"
break; break;
case 45: /* ifexists ::= IF EXISTS */ case 45: /* ifexists ::= IF EXISTS */
{ yymsp[-1].minor.yy0.n = 1;} case 47: /* ifnotexists ::= IF NOT EXISTS */ yytestcase(yyruleno==47);
#line 171 "sql.y"
{ yygotominor.yy0.n = 1;}
#line 1958 "sql.c"
break; break;
case 46: /* ifexists ::= */ case 46: /* ifexists ::= */
case 48: /* ifnotexists ::= */ yytestcase(yyruleno==48); case 48: /* ifnotexists ::= */ yytestcase(yyruleno==48);
{ yymsp[1].minor.yy0.n = 0;} case 156: /* distinct ::= */ yytestcase(yyruleno==156);
break; #line 172 "sql.y"
case 47: /* ifnotexists ::= IF NOT EXISTS */ { yygotominor.yy0.n = 0;}
{ yymsp[-2].minor.yy0.n = 1;} #line 1965 "sql.c"
break; break;
case 49: /* cmd ::= CREATE DNODE ids */ case 49: /* cmd ::= CREATE DNODE ids */
#line 180 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_CREATE_DNODE, 1, &yymsp[0].minor.yy0);} { setDCLSQLElems(pInfo, TSDB_SQL_CREATE_DNODE, 1, &yymsp[0].minor.yy0);}
#line 1970 "sql.c"
break; break;
case 50: /* cmd ::= CREATE ACCOUNT ids PASS ids acct_optr */ case 50: /* cmd ::= CREATE ACCOUNT ids PASS ids acct_optr */
{ setCreateAcctSql(pInfo, TSDB_SQL_CREATE_ACCT, &yymsp[-3].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy71);} #line 182 "sql.y"
{ setCreateAcctSql(pInfo, TSDB_SQL_CREATE_ACCT, &yymsp[-3].minor.yy0, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy79);}
#line 1975 "sql.c"
break; break;
case 51: /* cmd ::= CREATE DATABASE ifnotexists ids db_optr */ case 51: /* cmd ::= CREATE DATABASE ifnotexists ids db_optr */
{ setCreateDBSQL(pInfo, TSDB_SQL_CREATE_DB, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy234, &yymsp[-2].minor.yy0);} #line 183 "sql.y"
{ setCreateDBSQL(pInfo, TSDB_SQL_CREATE_DB, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy478, &yymsp[-2].minor.yy0);}
#line 1980 "sql.c"
break; break;
case 52: /* cmd ::= CREATE USER ids PASS ids */ case 52: /* cmd ::= CREATE USER ids PASS ids */
#line 184 "sql.y"
{ setCreateUserSql(pInfo, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0);} { setCreateUserSql(pInfo, &yymsp[-2].minor.yy0, &yymsp[0].minor.yy0);}
#line 1985 "sql.c"
break; break;
case 53: /* pps ::= */ case 53: /* pps ::= */
case 55: /* tseries ::= */ yytestcase(yyruleno==55); case 55: /* tseries ::= */ yytestcase(yyruleno==55);
...@@ -2237,7 +1992,9 @@ static void yy_reduce( ...@@ -2237,7 +1992,9 @@ static void yy_reduce(
case 65: /* users ::= */ yytestcase(yyruleno==65); case 65: /* users ::= */ yytestcase(yyruleno==65);
case 67: /* conns ::= */ yytestcase(yyruleno==67); case 67: /* conns ::= */ yytestcase(yyruleno==67);
case 69: /* state ::= */ yytestcase(yyruleno==69); case 69: /* state ::= */ yytestcase(yyruleno==69);
{ yymsp[1].minor.yy0.n = 0; } #line 186 "sql.y"
{ yygotominor.yy0.n = 0; }
#line 1998 "sql.c"
break; break;
case 54: /* pps ::= PPS INTEGER */ case 54: /* pps ::= PPS INTEGER */
case 56: /* tseries ::= TSERIES INTEGER */ yytestcase(yyruleno==56); case 56: /* tseries ::= TSERIES INTEGER */ yytestcase(yyruleno==56);
...@@ -2248,24 +2005,29 @@ static void yy_reduce( ...@@ -2248,24 +2005,29 @@ static void yy_reduce(
case 66: /* users ::= USERS INTEGER */ yytestcase(yyruleno==66); case 66: /* users ::= USERS INTEGER */ yytestcase(yyruleno==66);
case 68: /* conns ::= CONNS INTEGER */ yytestcase(yyruleno==68); case 68: /* conns ::= CONNS INTEGER */ yytestcase(yyruleno==68);
case 70: /* state ::= STATE ids */ yytestcase(yyruleno==70); case 70: /* state ::= STATE ids */ yytestcase(yyruleno==70);
{ yymsp[-1].minor.yy0 = yymsp[0].minor.yy0; } #line 187 "sql.y"
{ yygotominor.yy0 = yymsp[0].minor.yy0; }
#line 2011 "sql.c"
break; break;
case 71: /* acct_optr ::= pps tseries storage streams qtime dbs users conns state */ case 71: /* acct_optr ::= pps tseries storage streams qtime dbs users conns state */
#line 214 "sql.y"
{ {
yylhsminor.yy71.maxUsers = (yymsp[-2].minor.yy0.n>0)?atoi(yymsp[-2].minor.yy0.z):-1; yygotominor.yy79.maxUsers = (yymsp[-2].minor.yy0.n>0)?atoi(yymsp[-2].minor.yy0.z):-1;
yylhsminor.yy71.maxDbs = (yymsp[-3].minor.yy0.n>0)?atoi(yymsp[-3].minor.yy0.z):-1; yygotominor.yy79.maxDbs = (yymsp[-3].minor.yy0.n>0)?atoi(yymsp[-3].minor.yy0.z):-1;
yylhsminor.yy71.maxTimeSeries = (yymsp[-7].minor.yy0.n>0)?atoi(yymsp[-7].minor.yy0.z):-1; yygotominor.yy79.maxTimeSeries = (yymsp[-7].minor.yy0.n>0)?atoi(yymsp[-7].minor.yy0.z):-1;
yylhsminor.yy71.maxStreams = (yymsp[-5].minor.yy0.n>0)?atoi(yymsp[-5].minor.yy0.z):-1; yygotominor.yy79.maxStreams = (yymsp[-5].minor.yy0.n>0)?atoi(yymsp[-5].minor.yy0.z):-1;
yylhsminor.yy71.maxPointsPerSecond = (yymsp[-8].minor.yy0.n>0)?atoi(yymsp[-8].minor.yy0.z):-1; yygotominor.yy79.maxPointsPerSecond = (yymsp[-8].minor.yy0.n>0)?atoi(yymsp[-8].minor.yy0.z):-1;
yylhsminor.yy71.maxStorage = (yymsp[-6].minor.yy0.n>0)?strtoll(yymsp[-6].minor.yy0.z, NULL, 10):-1; yygotominor.yy79.maxStorage = (yymsp[-6].minor.yy0.n>0)?strtoll(yymsp[-6].minor.yy0.z, NULL, 10):-1;
yylhsminor.yy71.maxQueryTime = (yymsp[-4].minor.yy0.n>0)?strtoll(yymsp[-4].minor.yy0.z, NULL, 10):-1; yygotominor.yy79.maxQueryTime = (yymsp[-4].minor.yy0.n>0)?strtoll(yymsp[-4].minor.yy0.z, NULL, 10):-1;
yylhsminor.yy71.maxConnections = (yymsp[-1].minor.yy0.n>0)?atoi(yymsp[-1].minor.yy0.z):-1; yygotominor.yy79.maxConnections = (yymsp[-1].minor.yy0.n>0)?atoi(yymsp[-1].minor.yy0.z):-1;
yylhsminor.yy71.stat = yymsp[0].minor.yy0; yygotominor.yy79.stat = yymsp[0].minor.yy0;
} }
yymsp[-8].minor.yy71 = yylhsminor.yy71; #line 2026 "sql.c"
break; break;
case 72: /* keep ::= KEEP tagitemlist */ case 72: /* keep ::= KEEP tagitemlist */
{ yymsp[-1].minor.yy421 = yymsp[0].minor.yy421; } #line 228 "sql.y"
{ yygotominor.yy221 = yymsp[0].minor.yy221; }
#line 2031 "sql.c"
break; break;
case 73: /* cache ::= CACHE INTEGER */ case 73: /* cache ::= CACHE INTEGER */
case 74: /* replica ::= REPLICA INTEGER */ yytestcase(yyruleno==74); case 74: /* replica ::= REPLICA INTEGER */ yytestcase(yyruleno==74);
...@@ -2281,595 +2043,742 @@ static void yy_reduce( ...@@ -2281,595 +2043,742 @@ static void yy_reduce(
case 84: /* prec ::= PRECISION STRING */ yytestcase(yyruleno==84); case 84: /* prec ::= PRECISION STRING */ yytestcase(yyruleno==84);
case 85: /* update ::= UPDATE INTEGER */ yytestcase(yyruleno==85); case 85: /* update ::= UPDATE INTEGER */ yytestcase(yyruleno==85);
case 86: /* cachelast ::= CACHELAST INTEGER */ yytestcase(yyruleno==86); case 86: /* cachelast ::= CACHELAST INTEGER */ yytestcase(yyruleno==86);
{ yymsp[-1].minor.yy0 = yymsp[0].minor.yy0; } #line 230 "sql.y"
{ yygotominor.yy0 = yymsp[0].minor.yy0; }
#line 2049 "sql.c"
break; break;
case 87: /* db_optr ::= */ case 87: /* db_optr ::= */
{setDefaultCreateDbOption(&yymsp[1].minor.yy234);} #line 246 "sql.y"
{setDefaultCreateDbOption(&yygotominor.yy478);}
#line 2054 "sql.c"
break; break;
case 88: /* db_optr ::= db_optr cache */ case 88: /* db_optr ::= db_optr cache */
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.cacheBlockSize = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 248 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.cacheBlockSize = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2059 "sql.c"
break; break;
case 89: /* db_optr ::= db_optr replica */ case 89: /* db_optr ::= db_optr replica */
case 104: /* alter_db_optr ::= alter_db_optr replica */ yytestcase(yyruleno==104); case 104: /* alter_db_optr ::= alter_db_optr replica */ yytestcase(yyruleno==104);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.replica = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 249 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.replica = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2065 "sql.c"
break; break;
case 90: /* db_optr ::= db_optr quorum */ case 90: /* db_optr ::= db_optr quorum */
case 105: /* alter_db_optr ::= alter_db_optr quorum */ yytestcase(yyruleno==105); case 105: /* alter_db_optr ::= alter_db_optr quorum */ yytestcase(yyruleno==105);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.quorum = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 250 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.quorum = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2071 "sql.c"
break; break;
case 91: /* db_optr ::= db_optr days */ case 91: /* db_optr ::= db_optr days */
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.daysPerFile = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 251 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.daysPerFile = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2076 "sql.c"
break; break;
case 92: /* db_optr ::= db_optr minrows */ case 92: /* db_optr ::= db_optr minrows */
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.minRowsPerBlock = strtod(yymsp[0].minor.yy0.z, NULL); } #line 252 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.minRowsPerBlock = strtod(yymsp[0].minor.yy0.z, NULL); }
#line 2081 "sql.c"
break; break;
case 93: /* db_optr ::= db_optr maxrows */ case 93: /* db_optr ::= db_optr maxrows */
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.maxRowsPerBlock = strtod(yymsp[0].minor.yy0.z, NULL); } #line 253 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.maxRowsPerBlock = strtod(yymsp[0].minor.yy0.z, NULL); }
#line 2086 "sql.c"
break; break;
case 94: /* db_optr ::= db_optr blocks */ case 94: /* db_optr ::= db_optr blocks */
case 107: /* alter_db_optr ::= alter_db_optr blocks */ yytestcase(yyruleno==107); case 107: /* alter_db_optr ::= alter_db_optr blocks */ yytestcase(yyruleno==107);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.numOfBlocks = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 254 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.numOfBlocks = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2092 "sql.c"
break; break;
case 95: /* db_optr ::= db_optr ctime */ case 95: /* db_optr ::= db_optr ctime */
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.commitTime = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 255 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.commitTime = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2097 "sql.c"
break; break;
case 96: /* db_optr ::= db_optr wal */ case 96: /* db_optr ::= db_optr wal */
case 109: /* alter_db_optr ::= alter_db_optr wal */ yytestcase(yyruleno==109); case 109: /* alter_db_optr ::= alter_db_optr wal */ yytestcase(yyruleno==109);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.walLevel = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 256 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.walLevel = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2103 "sql.c"
break; break;
case 97: /* db_optr ::= db_optr fsync */ case 97: /* db_optr ::= db_optr fsync */
case 110: /* alter_db_optr ::= alter_db_optr fsync */ yytestcase(yyruleno==110); case 110: /* alter_db_optr ::= alter_db_optr fsync */ yytestcase(yyruleno==110);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.fsyncPeriod = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 257 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.fsyncPeriod = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2109 "sql.c"
break; break;
case 98: /* db_optr ::= db_optr comp */ case 98: /* db_optr ::= db_optr comp */
case 108: /* alter_db_optr ::= alter_db_optr comp */ yytestcase(yyruleno==108); case 108: /* alter_db_optr ::= alter_db_optr comp */ yytestcase(yyruleno==108);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.compressionLevel = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 258 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.compressionLevel = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2115 "sql.c"
break; break;
case 99: /* db_optr ::= db_optr prec */ case 99: /* db_optr ::= db_optr prec */
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.precision = yymsp[0].minor.yy0; } #line 259 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.precision = yymsp[0].minor.yy0; }
#line 2120 "sql.c"
break; break;
case 100: /* db_optr ::= db_optr keep */ case 100: /* db_optr ::= db_optr keep */
case 106: /* alter_db_optr ::= alter_db_optr keep */ yytestcase(yyruleno==106); case 106: /* alter_db_optr ::= alter_db_optr keep */ yytestcase(yyruleno==106);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.keep = yymsp[0].minor.yy421; } #line 260 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.keep = yymsp[0].minor.yy221; }
#line 2126 "sql.c"
break; break;
case 101: /* db_optr ::= db_optr update */ case 101: /* db_optr ::= db_optr update */
case 111: /* alter_db_optr ::= alter_db_optr update */ yytestcase(yyruleno==111); case 111: /* alter_db_optr ::= alter_db_optr update */ yytestcase(yyruleno==111);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.update = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 261 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.update = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2132 "sql.c"
break; break;
case 102: /* db_optr ::= db_optr cachelast */ case 102: /* db_optr ::= db_optr cachelast */
case 112: /* alter_db_optr ::= alter_db_optr cachelast */ yytestcase(yyruleno==112); case 112: /* alter_db_optr ::= alter_db_optr cachelast */ yytestcase(yyruleno==112);
{ yylhsminor.yy234 = yymsp[-1].minor.yy234; yylhsminor.yy234.cachelast = strtol(yymsp[0].minor.yy0.z, NULL, 10); } #line 262 "sql.y"
yymsp[-1].minor.yy234 = yylhsminor.yy234; { yygotominor.yy478 = yymsp[-1].minor.yy478; yygotominor.yy478.cachelast = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
#line 2138 "sql.c"
break; break;
case 103: /* alter_db_optr ::= */ case 103: /* alter_db_optr ::= */
{ setDefaultCreateDbOption(&yymsp[1].minor.yy234);} #line 265 "sql.y"
{ setDefaultCreateDbOption(&yygotominor.yy478);}
#line 2143 "sql.c"
break; break;
case 113: /* typename ::= ids */ case 113: /* typename ::= ids */
#line 278 "sql.y"
{ {
yymsp[0].minor.yy0.type = 0; yymsp[0].minor.yy0.type = 0;
tSqlSetColumnType (&yylhsminor.yy183, &yymsp[0].minor.yy0); tSqlSetColumnType (&yygotominor.yy503, &yymsp[0].minor.yy0);
} }
yymsp[0].minor.yy183 = yylhsminor.yy183; #line 2151 "sql.c"
break; break;
case 114: /* typename ::= ids LP signed RP */ case 114: /* typename ::= ids LP signed RP */
#line 284 "sql.y"
{ {
if (yymsp[-1].minor.yy325 <= 0) { if (yymsp[-1].minor.yy109 <= 0) {
yymsp[-3].minor.yy0.type = 0; yymsp[-3].minor.yy0.type = 0;
tSqlSetColumnType(&yylhsminor.yy183, &yymsp[-3].minor.yy0); tSqlSetColumnType(&yygotominor.yy503, &yymsp[-3].minor.yy0);
} else { } else {
yymsp[-3].minor.yy0.type = -yymsp[-1].minor.yy325; // negative value of name length yymsp[-3].minor.yy0.type = -yymsp[-1].minor.yy109; // negative value of name length
tSqlSetColumnType(&yylhsminor.yy183, &yymsp[-3].minor.yy0); tSqlSetColumnType(&yygotominor.yy503, &yymsp[-3].minor.yy0);
} }
} }
yymsp[-3].minor.yy183 = yylhsminor.yy183; #line 2164 "sql.c"
break; break;
case 115: /* typename ::= ids UNSIGNED */ case 115: /* typename ::= ids UNSIGNED */
#line 295 "sql.y"
{ {
yymsp[-1].minor.yy0.type = 0; yymsp[-1].minor.yy0.type = 0;
yymsp[-1].minor.yy0.n = ((yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z); yymsp[-1].minor.yy0.n = ((yymsp[0].minor.yy0.z + yymsp[0].minor.yy0.n) - yymsp[-1].minor.yy0.z);
tSqlSetColumnType (&yylhsminor.yy183, &yymsp[-1].minor.yy0); tSqlSetColumnType (&yygotominor.yy503, &yymsp[-1].minor.yy0);
} }
yymsp[-1].minor.yy183 = yylhsminor.yy183; #line 2173 "sql.c"
break; break;
case 116: /* signed ::= INTEGER */ case 116: /* signed ::= INTEGER */
{ yylhsminor.yy325 = strtol(yymsp[0].minor.yy0.z, NULL, 10); } case 117: /* signed ::= PLUS INTEGER */ yytestcase(yyruleno==117);
yymsp[0].minor.yy325 = yylhsminor.yy325; #line 302 "sql.y"
break; { yygotominor.yy109 = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
case 117: /* signed ::= PLUS INTEGER */ #line 2179 "sql.c"
{ yymsp[-1].minor.yy325 = strtol(yymsp[0].minor.yy0.z, NULL, 10); }
break; break;
case 118: /* signed ::= MINUS INTEGER */ case 118: /* signed ::= MINUS INTEGER */
{ yymsp[-1].minor.yy325 = -strtol(yymsp[0].minor.yy0.z, NULL, 10);} case 119: /* cmd ::= CREATE TABLE create_table_args */ yytestcase(yyruleno==119);
#line 304 "sql.y"
{ yygotominor.yy109 = -strtol(yymsp[0].minor.yy0.z, NULL, 10);}
#line 2185 "sql.c"
break; break;
case 120: /* cmd ::= CREATE TABLE create_table_list */ case 120: /* cmd ::= CREATE TABLE create_table_list */
{ pInfo->type = TSDB_SQL_CREATE_TABLE; pInfo->pCreateTableInfo = yymsp[0].minor.yy38;} #line 308 "sql.y"
{ pInfo->type = TSDB_SQL_CREATE_TABLE; pInfo->pCreateTableInfo = yymsp[0].minor.yy358;}
#line 2190 "sql.c"
break; break;
case 121: /* create_table_list ::= create_from_stable */ case 121: /* create_table_list ::= create_from_stable */
#line 312 "sql.y"
{ {
SCreateTableSQL* pCreateTable = calloc(1, sizeof(SCreateTableSQL)); SCreateTableSQL* pCreateTable = calloc(1, sizeof(SCreateTableSQL));
pCreateTable->childTableInfo = taosArrayInit(4, sizeof(SCreatedTableInfo)); pCreateTable->childTableInfo = taosArrayInit(4, sizeof(SCreatedTableInfo));
taosArrayPush(pCreateTable->childTableInfo, &yymsp[0].minor.yy152); taosArrayPush(pCreateTable->childTableInfo, &yymsp[0].minor.yy416);
pCreateTable->type = TSQL_CREATE_TABLE_FROM_STABLE; pCreateTable->type = TSQL_CREATE_TABLE_FROM_STABLE;
yylhsminor.yy38 = pCreateTable; yygotominor.yy358 = pCreateTable;
} }
yymsp[0].minor.yy38 = yylhsminor.yy38; #line 2202 "sql.c"
break; break;
case 122: /* create_table_list ::= create_table_list create_from_stable */ case 122: /* create_table_list ::= create_table_list create_from_stable */
#line 321 "sql.y"
{ {
taosArrayPush(yymsp[-1].minor.yy38->childTableInfo, &yymsp[0].minor.yy152); taosArrayPush(yymsp[-1].minor.yy358->childTableInfo, &yymsp[0].minor.yy416);
yylhsminor.yy38 = yymsp[-1].minor.yy38; yygotominor.yy358 = yymsp[-1].minor.yy358;
} }
yymsp[-1].minor.yy38 = yylhsminor.yy38; #line 2210 "sql.c"
break; break;
case 123: /* create_table_args ::= ifnotexists ids cpxName LP columnlist RP */ case 123: /* create_table_args ::= ifnotexists ids cpxName LP columnlist RP */
#line 327 "sql.y"
{ {
yylhsminor.yy38 = tSetCreateSqlElems(yymsp[-1].minor.yy421, NULL, NULL, TSQL_CREATE_TABLE); yygotominor.yy358 = tSetCreateSqlElems(yymsp[-1].minor.yy221, NULL, NULL, TSQL_CREATE_TABLE);
setSqlInfo(pInfo, yylhsminor.yy38, NULL, TSDB_SQL_CREATE_TABLE); setSqlInfo(pInfo, yygotominor.yy358, NULL, TSDB_SQL_CREATE_TABLE);
yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n; yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n;
setCreatedTableName(pInfo, &yymsp[-4].minor.yy0, &yymsp[-5].minor.yy0); setCreatedTableName(pInfo, &yymsp[-4].minor.yy0, &yymsp[-5].minor.yy0);
} }
yymsp[-5].minor.yy38 = yylhsminor.yy38; #line 2221 "sql.c"
break; break;
case 124: /* create_table_args ::= ifnotexists ids cpxName LP columnlist RP TAGS LP columnlist RP */ case 124: /* create_table_args ::= ifnotexists ids cpxName LP columnlist RP TAGS LP columnlist RP */
#line 336 "sql.y"
{ {
yylhsminor.yy38 = tSetCreateSqlElems(yymsp[-5].minor.yy421, yymsp[-1].minor.yy421, NULL, TSQL_CREATE_STABLE); yygotominor.yy358 = tSetCreateSqlElems(yymsp[-5].minor.yy221, yymsp[-1].minor.yy221, NULL, TSQL_CREATE_STABLE);
setSqlInfo(pInfo, yylhsminor.yy38, NULL, TSDB_SQL_CREATE_TABLE); setSqlInfo(pInfo, yygotominor.yy358, NULL, TSDB_SQL_CREATE_TABLE);
yymsp[-8].minor.yy0.n += yymsp[-7].minor.yy0.n; yymsp[-8].minor.yy0.n += yymsp[-7].minor.yy0.n;
setCreatedTableName(pInfo, &yymsp[-8].minor.yy0, &yymsp[-9].minor.yy0); setCreatedTableName(pInfo, &yymsp[-8].minor.yy0, &yymsp[-9].minor.yy0);
} }
yymsp[-9].minor.yy38 = yylhsminor.yy38; #line 2232 "sql.c"
break; break;
case 125: /* create_from_stable ::= ifnotexists ids cpxName USING ids cpxName TAGS LP tagitemlist RP */ case 125: /* create_from_stable ::= ifnotexists ids cpxName USING ids cpxName TAGS LP tagitemlist RP */
#line 347 "sql.y"
{ {
yymsp[-5].minor.yy0.n += yymsp[-4].minor.yy0.n; yymsp[-5].minor.yy0.n += yymsp[-4].minor.yy0.n;
yymsp[-8].minor.yy0.n += yymsp[-7].minor.yy0.n; yymsp[-8].minor.yy0.n += yymsp[-7].minor.yy0.n;
yylhsminor.yy152 = createNewChildTableInfo(&yymsp[-5].minor.yy0, yymsp[-1].minor.yy421, &yymsp[-8].minor.yy0, &yymsp[-9].minor.yy0); yygotominor.yy416 = createNewChildTableInfo(&yymsp[-5].minor.yy0, yymsp[-1].minor.yy221, &yymsp[-8].minor.yy0, &yymsp[-9].minor.yy0);
} }
yymsp[-9].minor.yy152 = yylhsminor.yy152; #line 2241 "sql.c"
break; break;
case 126: /* create_table_args ::= ifnotexists ids cpxName AS select */ case 126: /* create_table_args ::= ifnotexists ids cpxName AS select */
#line 355 "sql.y"
{ {
yylhsminor.yy38 = tSetCreateSqlElems(NULL, NULL, yymsp[0].minor.yy148, TSQL_CREATE_STREAM); yygotominor.yy358 = tSetCreateSqlElems(NULL, NULL, yymsp[0].minor.yy344, TSQL_CREATE_STREAM);
setSqlInfo(pInfo, yylhsminor.yy38, NULL, TSDB_SQL_CREATE_TABLE); setSqlInfo(pInfo, yygotominor.yy358, NULL, TSDB_SQL_CREATE_TABLE);
yymsp[-3].minor.yy0.n += yymsp[-2].minor.yy0.n; yymsp[-3].minor.yy0.n += yymsp[-2].minor.yy0.n;
setCreatedTableName(pInfo, &yymsp[-3].minor.yy0, &yymsp[-4].minor.yy0); setCreatedTableName(pInfo, &yymsp[-3].minor.yy0, &yymsp[-4].minor.yy0);
} }
yymsp[-4].minor.yy38 = yylhsminor.yy38; #line 2252 "sql.c"
break; break;
case 127: /* columnlist ::= columnlist COMMA column */ case 127: /* columnlist ::= columnlist COMMA column */
{taosArrayPush(yymsp[-2].minor.yy421, &yymsp[0].minor.yy183); yylhsminor.yy421 = yymsp[-2].minor.yy421; } #line 366 "sql.y"
yymsp[-2].minor.yy421 = yylhsminor.yy421; {taosArrayPush(yymsp[-2].minor.yy221, &yymsp[0].minor.yy503); yygotominor.yy221 = yymsp[-2].minor.yy221; }
#line 2257 "sql.c"
break; break;
case 128: /* columnlist ::= column */ case 128: /* columnlist ::= column */
{yylhsminor.yy421 = taosArrayInit(4, sizeof(TAOS_FIELD)); taosArrayPush(yylhsminor.yy421, &yymsp[0].minor.yy183);} #line 367 "sql.y"
yymsp[0].minor.yy421 = yylhsminor.yy421; {yygotominor.yy221 = taosArrayInit(4, sizeof(TAOS_FIELD)); taosArrayPush(yygotominor.yy221, &yymsp[0].minor.yy503);}
#line 2262 "sql.c"
break; break;
case 129: /* column ::= ids typename */ case 129: /* column ::= ids typename */
#line 371 "sql.y"
{ {
tSqlSetColumnInfo(&yylhsminor.yy183, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy183); tSqlSetColumnInfo(&yygotominor.yy503, &yymsp[-1].minor.yy0, &yymsp[0].minor.yy503);
} }
yymsp[-1].minor.yy183 = yylhsminor.yy183; #line 2269 "sql.c"
break; break;
case 130: /* tagitemlist ::= tagitemlist COMMA tagitem */ case 130: /* tagitemlist ::= tagitemlist COMMA tagitem */
{ yylhsminor.yy421 = tVariantListAppend(yymsp[-2].minor.yy421, &yymsp[0].minor.yy430, -1); } #line 379 "sql.y"
yymsp[-2].minor.yy421 = yylhsminor.yy421; { yygotominor.yy221 = tVariantListAppend(yymsp[-2].minor.yy221, &yymsp[0].minor.yy106, -1); }
#line 2274 "sql.c"
break; break;
case 131: /* tagitemlist ::= tagitem */ case 131: /* tagitemlist ::= tagitem */
{ yylhsminor.yy421 = tVariantListAppend(NULL, &yymsp[0].minor.yy430, -1); } #line 380 "sql.y"
yymsp[0].minor.yy421 = yylhsminor.yy421; { yygotominor.yy221 = tVariantListAppend(NULL, &yymsp[0].minor.yy106, -1); }
#line 2279 "sql.c"
break; break;
case 132: /* tagitem ::= INTEGER */ case 132: /* tagitem ::= INTEGER */
case 133: /* tagitem ::= FLOAT */ yytestcase(yyruleno==133); case 133: /* tagitem ::= FLOAT */ yytestcase(yyruleno==133);
case 134: /* tagitem ::= STRING */ yytestcase(yyruleno==134); case 134: /* tagitem ::= STRING */ yytestcase(yyruleno==134);
case 135: /* tagitem ::= BOOL */ yytestcase(yyruleno==135); case 135: /* tagitem ::= BOOL */ yytestcase(yyruleno==135);
{ toTSDBType(yymsp[0].minor.yy0.type); tVariantCreate(&yylhsminor.yy430, &yymsp[0].minor.yy0); } #line 382 "sql.y"
yymsp[0].minor.yy430 = yylhsminor.yy430; { toTSDBType(yymsp[0].minor.yy0.type); tVariantCreate(&yygotominor.yy106, &yymsp[0].minor.yy0); }
#line 2287 "sql.c"
break; break;
case 136: /* tagitem ::= NULL */ case 136: /* tagitem ::= NULL */
{ yymsp[0].minor.yy0.type = 0; tVariantCreate(&yylhsminor.yy430, &yymsp[0].minor.yy0); } #line 386 "sql.y"
yymsp[0].minor.yy430 = yylhsminor.yy430; { yymsp[0].minor.yy0.type = 0; tVariantCreate(&yygotominor.yy106, &yymsp[0].minor.yy0); }
#line 2292 "sql.c"
break; break;
case 137: /* tagitem ::= MINUS INTEGER */ case 137: /* tagitem ::= MINUS INTEGER */
case 138: /* tagitem ::= MINUS FLOAT */ yytestcase(yyruleno==138); case 138: /* tagitem ::= MINUS FLOAT */ yytestcase(yyruleno==138);
case 139: /* tagitem ::= PLUS INTEGER */ yytestcase(yyruleno==139); case 139: /* tagitem ::= PLUS INTEGER */ yytestcase(yyruleno==139);
case 140: /* tagitem ::= PLUS FLOAT */ yytestcase(yyruleno==140); case 140: /* tagitem ::= PLUS FLOAT */ yytestcase(yyruleno==140);
#line 388 "sql.y"
{ {
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
yymsp[-1].minor.yy0.type = yymsp[0].minor.yy0.type; yymsp[-1].minor.yy0.type = yymsp[0].minor.yy0.type;
toTSDBType(yymsp[-1].minor.yy0.type); toTSDBType(yymsp[-1].minor.yy0.type);
tVariantCreate(&yylhsminor.yy430, &yymsp[-1].minor.yy0); tVariantCreate(&yygotominor.yy106, &yymsp[-1].minor.yy0);
} }
yymsp[-1].minor.yy430 = yylhsminor.yy430; #line 2305 "sql.c"
break; break;
case 141: /* select ::= SELECT selcollist from where_opt interval_opt fill_opt sliding_opt groupby_opt orderby_opt having_opt slimit_opt limit_opt */ case 141: /* select ::= SELECT selcollist from where_opt interval_opt fill_opt sliding_opt groupby_opt orderby_opt having_opt slimit_opt limit_opt */
#line 419 "sql.y"
{ {
yylhsminor.yy148 = tSetQuerySqlElems(&yymsp[-11].minor.yy0, yymsp[-10].minor.yy166, yymsp[-9].minor.yy421, yymsp[-8].minor.yy78, yymsp[-4].minor.yy421, yymsp[-3].minor.yy421, &yymsp[-7].minor.yy400, &yymsp[-5].minor.yy0, yymsp[-6].minor.yy421, &yymsp[0].minor.yy167, &yymsp[-1].minor.yy167); yygotominor.yy344 = tSetQuerySqlElems(&yymsp[-11].minor.yy0, yymsp[-10].minor.yy178, yymsp[-9].minor.yy221, yymsp[-8].minor.yy50, yymsp[-4].minor.yy221, yymsp[-3].minor.yy221, &yymsp[-7].minor.yy280, &yymsp[-5].minor.yy0, yymsp[-6].minor.yy221, &yymsp[0].minor.yy454, &yymsp[-1].minor.yy454);
} }
yymsp[-11].minor.yy148 = yylhsminor.yy148; #line 2312 "sql.c"
break; break;
case 142: /* union ::= select */ case 142: /* union ::= select */
{ yylhsminor.yy153 = setSubclause(NULL, yymsp[0].minor.yy148); } #line 426 "sql.y"
yymsp[0].minor.yy153 = yylhsminor.yy153; { yygotominor.yy273 = setSubclause(NULL, yymsp[0].minor.yy344); }
#line 2317 "sql.c"
break; break;
case 143: /* union ::= LP union RP */ case 143: /* union ::= LP union RP */
{ yymsp[-2].minor.yy153 = yymsp[-1].minor.yy153; } #line 427 "sql.y"
{ yygotominor.yy273 = yymsp[-1].minor.yy273; }
#line 2322 "sql.c"
break; break;
case 144: /* union ::= union UNION ALL select */ case 144: /* union ::= union UNION ALL select */
{ yylhsminor.yy153 = appendSelectClause(yymsp[-3].minor.yy153, yymsp[0].minor.yy148); } #line 428 "sql.y"
yymsp[-3].minor.yy153 = yylhsminor.yy153; { yygotominor.yy273 = appendSelectClause(yymsp[-3].minor.yy273, yymsp[0].minor.yy344); }
#line 2327 "sql.c"
break; break;
case 145: /* union ::= union UNION ALL LP select RP */ case 145: /* union ::= union UNION ALL LP select RP */
{ yylhsminor.yy153 = appendSelectClause(yymsp[-5].minor.yy153, yymsp[-1].minor.yy148); } #line 429 "sql.y"
yymsp[-5].minor.yy153 = yylhsminor.yy153; { yygotominor.yy273 = appendSelectClause(yymsp[-5].minor.yy273, yymsp[-1].minor.yy344); }
#line 2332 "sql.c"
break; break;
case 146: /* cmd ::= union */ case 146: /* cmd ::= union */
{ setSqlInfo(pInfo, yymsp[0].minor.yy153, NULL, TSDB_SQL_SELECT); } #line 431 "sql.y"
{ setSqlInfo(pInfo, yymsp[0].minor.yy273, NULL, TSDB_SQL_SELECT); }
#line 2337 "sql.c"
break; break;
case 147: /* select ::= SELECT selcollist */ case 147: /* select ::= SELECT selcollist */
#line 437 "sql.y"
{ {
yylhsminor.yy148 = tSetQuerySqlElems(&yymsp[-1].minor.yy0, yymsp[0].minor.yy166, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL); yygotominor.yy344 = tSetQuerySqlElems(&yymsp[-1].minor.yy0, yymsp[0].minor.yy178, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
} }
yymsp[-1].minor.yy148 = yylhsminor.yy148; #line 2344 "sql.c"
break; break;
case 148: /* sclp ::= selcollist COMMA */ case 148: /* sclp ::= selcollist COMMA */
{yylhsminor.yy166 = yymsp[-1].minor.yy166;} #line 449 "sql.y"
yymsp[-1].minor.yy166 = yylhsminor.yy166; {yygotominor.yy178 = yymsp[-1].minor.yy178;}
#line 2349 "sql.c"
break; break;
case 149: /* sclp ::= */ case 149: /* sclp ::= */
{yymsp[1].minor.yy166 = 0;} #line 450 "sql.y"
{yygotominor.yy178 = 0;}
#line 2354 "sql.c"
break; break;
case 150: /* selcollist ::= sclp expr as */ case 150: /* selcollist ::= sclp distinct expr as */
#line 451 "sql.y"
{ {
yylhsminor.yy166 = tSqlExprListAppend(yymsp[-2].minor.yy166, yymsp[-1].minor.yy78, yymsp[0].minor.yy0.n?&yymsp[0].minor.yy0:0); yygotominor.yy178 = tSqlExprListAppend(yymsp[-3].minor.yy178, yymsp[-1].minor.yy50, yymsp[-2].minor.yy0.n? &yymsp[-2].minor.yy0:0, yymsp[0].minor.yy0.n?&yymsp[0].minor.yy0:0);
} }
yymsp[-2].minor.yy166 = yylhsminor.yy166; #line 2361 "sql.c"
break; break;
case 151: /* selcollist ::= sclp STAR */ case 151: /* selcollist ::= sclp STAR */
#line 455 "sql.y"
{ {
tSQLExpr *pNode = tSqlExprIdValueCreate(NULL, TK_ALL); tSQLExpr *pNode = tSqlExprIdValueCreate(NULL, TK_ALL);
yylhsminor.yy166 = tSqlExprListAppend(yymsp[-1].minor.yy166, pNode, 0); yygotominor.yy178 = tSqlExprListAppend(yymsp[-1].minor.yy178, pNode, 0, 0);
} }
yymsp[-1].minor.yy166 = yylhsminor.yy166; #line 2369 "sql.c"
break; break;
case 152: /* as ::= AS ids */ case 152: /* as ::= AS ids */
{ yymsp[-1].minor.yy0 = yymsp[0].minor.yy0; } case 153: /* as ::= ids */ yytestcase(yyruleno==153);
break; #line 464 "sql.y"
case 153: /* as ::= ids */ { yygotominor.yy0 = yymsp[0].minor.yy0; }
{ yylhsminor.yy0 = yymsp[0].minor.yy0; } #line 2375 "sql.c"
yymsp[0].minor.yy0 = yylhsminor.yy0;
break; break;
case 154: /* as ::= */ case 154: /* as ::= */
{ yymsp[1].minor.yy0.n = 0; } #line 466 "sql.y"
break; { yygotominor.yy0.n = 0; }
case 155: /* from ::= FROM tablelist */ #line 2380 "sql.c"
{yymsp[-1].minor.yy421 = yymsp[0].minor.yy421;} break;
break; case 155: /* distinct ::= DISTINCT */
case 156: /* tablelist ::= ids cpxName */ #line 469 "sql.y"
{ yygotominor.yy0 = yymsp[0].minor.yy0; }
#line 2385 "sql.c"
break;
case 157: /* from ::= FROM tablelist */
case 172: /* orderby_opt ::= ORDER BY sortlist */ yytestcase(yyruleno==172);
#line 475 "sql.y"
{yygotominor.yy221 = yymsp[0].minor.yy221;}
#line 2391 "sql.c"
break;
case 158: /* tablelist ::= ids cpxName */
#line 478 "sql.y"
{ {
toTSDBType(yymsp[-1].minor.yy0.type); toTSDBType(yymsp[-1].minor.yy0.type);
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
yylhsminor.yy421 = tVariantListAppendToken(NULL, &yymsp[-1].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(NULL, &yymsp[-1].minor.yy0, -1);
yylhsminor.yy421 = tVariantListAppendToken(yylhsminor.yy421, &yymsp[-1].minor.yy0, -1); // table alias name yygotominor.yy221 = tVariantListAppendToken(yygotominor.yy221, &yymsp[-1].minor.yy0, -1); // table alias name
} }
yymsp[-1].minor.yy421 = yylhsminor.yy421; #line 2401 "sql.c"
break; break;
case 157: /* tablelist ::= ids cpxName ids */ case 159: /* tablelist ::= ids cpxName ids */
#line 485 "sql.y"
{ {
toTSDBType(yymsp[-2].minor.yy0.type); toTSDBType(yymsp[-2].minor.yy0.type);
toTSDBType(yymsp[0].minor.yy0.type); toTSDBType(yymsp[0].minor.yy0.type);
yymsp[-2].minor.yy0.n += yymsp[-1].minor.yy0.n; yymsp[-2].minor.yy0.n += yymsp[-1].minor.yy0.n;
yylhsminor.yy421 = tVariantListAppendToken(NULL, &yymsp[-2].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(NULL, &yymsp[-2].minor.yy0, -1);
yylhsminor.yy421 = tVariantListAppendToken(yylhsminor.yy421, &yymsp[0].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(yygotominor.yy221, &yymsp[0].minor.yy0, -1);
} }
yymsp[-2].minor.yy421 = yylhsminor.yy421; #line 2412 "sql.c"
break; break;
case 158: /* tablelist ::= tablelist COMMA ids cpxName */ case 160: /* tablelist ::= tablelist COMMA ids cpxName */
#line 493 "sql.y"
{ {
toTSDBType(yymsp[-1].minor.yy0.type); toTSDBType(yymsp[-1].minor.yy0.type);
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
yylhsminor.yy421 = tVariantListAppendToken(yymsp[-3].minor.yy421, &yymsp[-1].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(yymsp[-3].minor.yy221, &yymsp[-1].minor.yy0, -1);
yylhsminor.yy421 = tVariantListAppendToken(yylhsminor.yy421, &yymsp[-1].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(yygotominor.yy221, &yymsp[-1].minor.yy0, -1);
} }
yymsp[-3].minor.yy421 = yylhsminor.yy421; #line 2422 "sql.c"
break; break;
case 159: /* tablelist ::= tablelist COMMA ids cpxName ids */ case 161: /* tablelist ::= tablelist COMMA ids cpxName ids */
#line 500 "sql.y"
{ {
toTSDBType(yymsp[-2].minor.yy0.type); toTSDBType(yymsp[-2].minor.yy0.type);
toTSDBType(yymsp[0].minor.yy0.type); toTSDBType(yymsp[0].minor.yy0.type);
yymsp[-2].minor.yy0.n += yymsp[-1].minor.yy0.n; yymsp[-2].minor.yy0.n += yymsp[-1].minor.yy0.n;
yylhsminor.yy421 = tVariantListAppendToken(yymsp[-4].minor.yy421, &yymsp[-2].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(yymsp[-4].minor.yy221, &yymsp[-2].minor.yy0, -1);
yylhsminor.yy421 = tVariantListAppendToken(yylhsminor.yy421, &yymsp[0].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(yygotominor.yy221, &yymsp[0].minor.yy0, -1);
} }
yymsp[-4].minor.yy421 = yylhsminor.yy421; #line 2433 "sql.c"
break; break;
case 160: /* tmvar ::= VARIABLE */ case 162: /* tmvar ::= VARIABLE */
{yylhsminor.yy0 = yymsp[0].minor.yy0;} #line 510 "sql.y"
yymsp[0].minor.yy0 = yylhsminor.yy0; {yygotominor.yy0 = yymsp[0].minor.yy0;}
break; #line 2438 "sql.c"
case 161: /* interval_opt ::= INTERVAL LP tmvar RP */ break;
{yymsp[-3].minor.yy400.interval = yymsp[-1].minor.yy0; yymsp[-3].minor.yy400.offset.n = 0; yymsp[-3].minor.yy400.offset.z = NULL; yymsp[-3].minor.yy400.offset.type = 0;} case 163: /* interval_opt ::= INTERVAL LP tmvar RP */
break; #line 513 "sql.y"
case 162: /* interval_opt ::= INTERVAL LP tmvar COMMA tmvar RP */ {yygotominor.yy280.interval = yymsp[-1].minor.yy0; yygotominor.yy280.offset.n = 0; yygotominor.yy280.offset.z = NULL; yygotominor.yy280.offset.type = 0;}
{yymsp[-5].minor.yy400.interval = yymsp[-3].minor.yy0; yymsp[-5].minor.yy400.offset = yymsp[-1].minor.yy0;} #line 2443 "sql.c"
break; break;
case 163: /* interval_opt ::= */ case 164: /* interval_opt ::= INTERVAL LP tmvar COMMA tmvar RP */
{memset(&yymsp[1].minor.yy400, 0, sizeof(yymsp[1].minor.yy400));} #line 514 "sql.y"
break; {yygotominor.yy280.interval = yymsp[-3].minor.yy0; yygotominor.yy280.offset = yymsp[-1].minor.yy0;}
case 164: /* fill_opt ::= */ #line 2448 "sql.c"
{yymsp[1].minor.yy421 = 0; } break;
break; case 165: /* interval_opt ::= */
case 165: /* fill_opt ::= FILL LP ID COMMA tagitemlist RP */ #line 515 "sql.y"
{memset(&yygotominor.yy280, 0, sizeof(yygotominor.yy280));}
#line 2453 "sql.c"
break;
case 166: /* fill_opt ::= */
#line 519 "sql.y"
{yygotominor.yy221 = 0; }
#line 2458 "sql.c"
break;
case 167: /* fill_opt ::= FILL LP ID COMMA tagitemlist RP */
#line 520 "sql.y"
{ {
tVariant A = {0}; tVariant A = {0};
toTSDBType(yymsp[-3].minor.yy0.type); toTSDBType(yymsp[-3].minor.yy0.type);
tVariantCreate(&A, &yymsp[-3].minor.yy0); tVariantCreate(&A, &yymsp[-3].minor.yy0);
tVariantListInsert(yymsp[-1].minor.yy421, &A, -1, 0); tVariantListInsert(yymsp[-1].minor.yy221, &A, -1, 0);
yymsp[-5].minor.yy421 = yymsp[-1].minor.yy421; yygotominor.yy221 = yymsp[-1].minor.yy221;
} }
#line 2470 "sql.c"
break; break;
case 166: /* fill_opt ::= FILL LP ID RP */ case 168: /* fill_opt ::= FILL LP ID RP */
#line 529 "sql.y"
{ {
toTSDBType(yymsp[-1].minor.yy0.type); toTSDBType(yymsp[-1].minor.yy0.type);
yymsp[-3].minor.yy421 = tVariantListAppendToken(NULL, &yymsp[-1].minor.yy0, -1); yygotominor.yy221 = tVariantListAppendToken(NULL, &yymsp[-1].minor.yy0, -1);
} }
#line 2478 "sql.c"
break; break;
case 167: /* sliding_opt ::= SLIDING LP tmvar RP */ case 169: /* sliding_opt ::= SLIDING LP tmvar RP */
{yymsp[-3].minor.yy0 = yymsp[-1].minor.yy0; } #line 535 "sql.y"
break; {yygotominor.yy0 = yymsp[-1].minor.yy0; }
case 168: /* sliding_opt ::= */ #line 2483 "sql.c"
{yymsp[1].minor.yy0.n = 0; yymsp[1].minor.yy0.z = NULL; yymsp[1].minor.yy0.type = 0; }
break; break;
case 169: /* orderby_opt ::= */ case 170: /* sliding_opt ::= */
{yymsp[1].minor.yy421 = 0;} #line 536 "sql.y"
{yygotominor.yy0.n = 0; yygotominor.yy0.z = NULL; yygotominor.yy0.type = 0; }
#line 2488 "sql.c"
break; break;
case 170: /* orderby_opt ::= ORDER BY sortlist */ case 171: /* orderby_opt ::= */
{yymsp[-2].minor.yy421 = yymsp[0].minor.yy421;} #line 547 "sql.y"
{yygotominor.yy221 = 0;}
#line 2493 "sql.c"
break; break;
case 171: /* sortlist ::= sortlist COMMA item sortorder */ case 173: /* sortlist ::= sortlist COMMA item sortorder */
#line 550 "sql.y"
{ {
yylhsminor.yy421 = tVariantListAppend(yymsp[-3].minor.yy421, &yymsp[-1].minor.yy430, yymsp[0].minor.yy96); yygotominor.yy221 = tVariantListAppend(yymsp[-3].minor.yy221, &yymsp[-1].minor.yy106, yymsp[0].minor.yy172);
} }
yymsp[-3].minor.yy421 = yylhsminor.yy421; #line 2500 "sql.c"
break; break;
case 172: /* sortlist ::= item sortorder */ case 174: /* sortlist ::= item sortorder */
#line 554 "sql.y"
{ {
yylhsminor.yy421 = tVariantListAppend(NULL, &yymsp[-1].minor.yy430, yymsp[0].minor.yy96); yygotominor.yy221 = tVariantListAppend(NULL, &yymsp[-1].minor.yy106, yymsp[0].minor.yy172);
} }
yymsp[-1].minor.yy421 = yylhsminor.yy421; #line 2507 "sql.c"
break; break;
case 173: /* item ::= ids cpxName */ case 175: /* item ::= ids cpxName */
#line 559 "sql.y"
{ {
toTSDBType(yymsp[-1].minor.yy0.type); toTSDBType(yymsp[-1].minor.yy0.type);
yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n;
tVariantCreate(&yylhsminor.yy430, &yymsp[-1].minor.yy0); tVariantCreate(&yygotominor.yy106, &yymsp[-1].minor.yy0);
} }
yymsp[-1].minor.yy430 = yylhsminor.yy430; #line 2517 "sql.c"
break;
case 174: /* sortorder ::= ASC */
{ yymsp[0].minor.yy96 = TSDB_ORDER_ASC; }
break; break;
case 175: /* sortorder ::= DESC */ case 176: /* sortorder ::= ASC */
{ yymsp[0].minor.yy96 = TSDB_ORDER_DESC;} case 178: /* sortorder ::= */ yytestcase(yyruleno==178);
#line 567 "sql.y"
{ yygotominor.yy172 = TSDB_ORDER_ASC; }
#line 2523 "sql.c"
break; break;
case 176: /* sortorder ::= */ case 177: /* sortorder ::= DESC */
{ yymsp[1].minor.yy96 = TSDB_ORDER_ASC; } #line 568 "sql.y"
{ yygotominor.yy172 = TSDB_ORDER_DESC;}
#line 2528 "sql.c"
break; break;
case 177: /* groupby_opt ::= */ case 179: /* groupby_opt ::= */
{ yymsp[1].minor.yy421 = 0;} #line 577 "sql.y"
{ yygotominor.yy221 = 0;}
#line 2533 "sql.c"
break; break;
case 178: /* groupby_opt ::= GROUP BY grouplist */ case 180: /* groupby_opt ::= GROUP BY grouplist */
{ yymsp[-2].minor.yy421 = yymsp[0].minor.yy421;} #line 578 "sql.y"
{ yygotominor.yy221 = yymsp[0].minor.yy221;}
#line 2538 "sql.c"
break; break;
case 179: /* grouplist ::= grouplist COMMA item */ case 181: /* grouplist ::= grouplist COMMA item */
#line 580 "sql.y"
{ {
yylhsminor.yy421 = tVariantListAppend(yymsp[-2].minor.yy421, &yymsp[0].minor.yy430, -1); yygotominor.yy221 = tVariantListAppend(yymsp[-2].minor.yy221, &yymsp[0].minor.yy106, -1);
} }
yymsp[-2].minor.yy421 = yylhsminor.yy421; #line 2545 "sql.c"
break; break;
case 180: /* grouplist ::= item */ case 182: /* grouplist ::= item */
#line 584 "sql.y"
{ {
yylhsminor.yy421 = tVariantListAppend(NULL, &yymsp[0].minor.yy430, -1); yygotominor.yy221 = tVariantListAppend(NULL, &yymsp[0].minor.yy106, -1);
} }
yymsp[0].minor.yy421 = yylhsminor.yy421; #line 2552 "sql.c"
break; break;
case 181: /* having_opt ::= */ case 183: /* having_opt ::= */
case 191: /* where_opt ::= */ yytestcase(yyruleno==191); case 193: /* where_opt ::= */ yytestcase(yyruleno==193);
case 229: /* expritem ::= */ yytestcase(yyruleno==229); case 231: /* expritem ::= */ yytestcase(yyruleno==231);
{yymsp[1].minor.yy78 = 0;} #line 591 "sql.y"
break; {yygotominor.yy50 = 0;}
case 182: /* having_opt ::= HAVING expr */ #line 2559 "sql.c"
case 192: /* where_opt ::= WHERE expr */ yytestcase(yyruleno==192); break;
{yymsp[-1].minor.yy78 = yymsp[0].minor.yy78;} case 184: /* having_opt ::= HAVING expr */
break; case 194: /* where_opt ::= WHERE expr */ yytestcase(yyruleno==194);
case 183: /* limit_opt ::= */ case 230: /* expritem ::= expr */ yytestcase(yyruleno==230);
case 187: /* slimit_opt ::= */ yytestcase(yyruleno==187); #line 592 "sql.y"
{yymsp[1].minor.yy167.limit = -1; yymsp[1].minor.yy167.offset = 0;} {yygotominor.yy50 = yymsp[0].minor.yy50;}
break; #line 2566 "sql.c"
case 184: /* limit_opt ::= LIMIT signed */ break;
case 188: /* slimit_opt ::= SLIMIT signed */ yytestcase(yyruleno==188); case 185: /* limit_opt ::= */
{yymsp[-1].minor.yy167.limit = yymsp[0].minor.yy325; yymsp[-1].minor.yy167.offset = 0;} case 189: /* slimit_opt ::= */ yytestcase(yyruleno==189);
break; #line 596 "sql.y"
case 185: /* limit_opt ::= LIMIT signed OFFSET signed */ {yygotominor.yy454.limit = -1; yygotominor.yy454.offset = 0;}
{ yymsp[-3].minor.yy167.limit = yymsp[-2].minor.yy325; yymsp[-3].minor.yy167.offset = yymsp[0].minor.yy325;} #line 2572 "sql.c"
break; break;
case 186: /* limit_opt ::= LIMIT signed COMMA signed */ case 186: /* limit_opt ::= LIMIT signed */
{ yymsp[-3].minor.yy167.limit = yymsp[0].minor.yy325; yymsp[-3].minor.yy167.offset = yymsp[-2].minor.yy325;} case 190: /* slimit_opt ::= SLIMIT signed */ yytestcase(yyruleno==190);
break; #line 597 "sql.y"
case 189: /* slimit_opt ::= SLIMIT signed SOFFSET signed */ {yygotominor.yy454.limit = yymsp[0].minor.yy109; yygotominor.yy454.offset = 0;}
{yymsp[-3].minor.yy167.limit = yymsp[-2].minor.yy325; yymsp[-3].minor.yy167.offset = yymsp[0].minor.yy325;} #line 2578 "sql.c"
break; break;
case 190: /* slimit_opt ::= SLIMIT signed COMMA signed */ case 187: /* limit_opt ::= LIMIT signed OFFSET signed */
{yymsp[-3].minor.yy167.limit = yymsp[0].minor.yy325; yymsp[-3].minor.yy167.offset = yymsp[-2].minor.yy325;} #line 599 "sql.y"
break; { yygotominor.yy454.limit = yymsp[-2].minor.yy109; yygotominor.yy454.offset = yymsp[0].minor.yy109;}
case 193: /* expr ::= LP expr RP */ #line 2583 "sql.c"
{yylhsminor.yy78 = yymsp[-1].minor.yy78; yylhsminor.yy78->token.z = yymsp[-2].minor.yy0.z; yylhsminor.yy78->token.n = (yymsp[0].minor.yy0.z - yymsp[-2].minor.yy0.z + 1);} break;
yymsp[-2].minor.yy78 = yylhsminor.yy78; case 188: /* limit_opt ::= LIMIT signed COMMA signed */
break; #line 601 "sql.y"
case 194: /* expr ::= ID */ { yygotominor.yy454.limit = yymsp[0].minor.yy109; yygotominor.yy454.offset = yymsp[-2].minor.yy109;}
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_ID);} #line 2588 "sql.c"
yymsp[0].minor.yy78 = yylhsminor.yy78; break;
break; case 191: /* slimit_opt ::= SLIMIT signed SOFFSET signed */
case 195: /* expr ::= ID DOT ID */ #line 607 "sql.y"
{ yymsp[-2].minor.yy0.n += (1+yymsp[0].minor.yy0.n); yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[-2].minor.yy0, TK_ID);} {yygotominor.yy454.limit = yymsp[-2].minor.yy109; yygotominor.yy454.offset = yymsp[0].minor.yy109;}
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 2593 "sql.c"
break; break;
case 196: /* expr ::= ID DOT STAR */ case 192: /* slimit_opt ::= SLIMIT signed COMMA signed */
{ yymsp[-2].minor.yy0.n += (1+yymsp[0].minor.yy0.n); yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[-2].minor.yy0, TK_ALL);} #line 609 "sql.y"
yymsp[-2].minor.yy78 = yylhsminor.yy78; {yygotominor.yy454.limit = yymsp[0].minor.yy109; yygotominor.yy454.offset = yymsp[-2].minor.yy109;}
break; #line 2598 "sql.c"
case 197: /* expr ::= INTEGER */ break;
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_INTEGER);} case 195: /* expr ::= LP expr RP */
yymsp[0].minor.yy78 = yylhsminor.yy78; #line 622 "sql.y"
break; {yygotominor.yy50 = yymsp[-1].minor.yy50; yygotominor.yy50->token.z = yymsp[-2].minor.yy0.z; yygotominor.yy50->token.n = (yymsp[0].minor.yy0.z - yymsp[-2].minor.yy0.z + 1);}
case 198: /* expr ::= MINUS INTEGER */ #line 2603 "sql.c"
case 199: /* expr ::= PLUS INTEGER */ yytestcase(yyruleno==199); break;
{ yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.type = TK_INTEGER; yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[-1].minor.yy0, TK_INTEGER);} case 196: /* expr ::= ID */
yymsp[-1].minor.yy78 = yylhsminor.yy78; #line 624 "sql.y"
break; { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_ID);}
case 200: /* expr ::= FLOAT */ #line 2608 "sql.c"
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_FLOAT);} break;
yymsp[0].minor.yy78 = yylhsminor.yy78; case 197: /* expr ::= ID DOT ID */
break; #line 625 "sql.y"
case 201: /* expr ::= MINUS FLOAT */ { yymsp[-2].minor.yy0.n += (1+yymsp[0].minor.yy0.n); yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[-2].minor.yy0, TK_ID);}
case 202: /* expr ::= PLUS FLOAT */ yytestcase(yyruleno==202); #line 2613 "sql.c"
{ yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.type = TK_FLOAT; yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[-1].minor.yy0, TK_FLOAT);} break;
yymsp[-1].minor.yy78 = yylhsminor.yy78; case 198: /* expr ::= ID DOT STAR */
break; #line 626 "sql.y"
case 203: /* expr ::= STRING */ { yymsp[-2].minor.yy0.n += (1+yymsp[0].minor.yy0.n); yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[-2].minor.yy0, TK_ALL);}
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_STRING);} #line 2618 "sql.c"
yymsp[0].minor.yy78 = yylhsminor.yy78; break;
break; case 199: /* expr ::= INTEGER */
case 204: /* expr ::= NOW */ #line 628 "sql.y"
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_NOW); } { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_INTEGER);}
yymsp[0].minor.yy78 = yylhsminor.yy78; #line 2623 "sql.c"
break; break;
case 205: /* expr ::= VARIABLE */ case 200: /* expr ::= MINUS INTEGER */
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_VARIABLE);} case 201: /* expr ::= PLUS INTEGER */ yytestcase(yyruleno==201);
yymsp[0].minor.yy78 = yylhsminor.yy78; #line 629 "sql.y"
break; { yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.type = TK_INTEGER; yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[-1].minor.yy0, TK_INTEGER);}
case 206: /* expr ::= BOOL */ #line 2629 "sql.c"
{ yylhsminor.yy78 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_BOOL);} break;
yymsp[0].minor.yy78 = yylhsminor.yy78; case 202: /* expr ::= FLOAT */
break; #line 631 "sql.y"
case 207: /* expr ::= ID LP exprlist RP */ { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_FLOAT);}
{ yylhsminor.yy78 = tSqlExprCreateFunction(yymsp[-1].minor.yy166, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0, yymsp[-3].minor.yy0.type); } #line 2634 "sql.c"
yymsp[-3].minor.yy78 = yylhsminor.yy78; break;
break; case 203: /* expr ::= MINUS FLOAT */
case 208: /* expr ::= ID LP STAR RP */ case 204: /* expr ::= PLUS FLOAT */ yytestcase(yyruleno==204);
{ yylhsminor.yy78 = tSqlExprCreateFunction(NULL, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0, yymsp[-3].minor.yy0.type); } #line 632 "sql.y"
yymsp[-3].minor.yy78 = yylhsminor.yy78; { yymsp[-1].minor.yy0.n += yymsp[0].minor.yy0.n; yymsp[-1].minor.yy0.type = TK_FLOAT; yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[-1].minor.yy0, TK_FLOAT);}
break; #line 2640 "sql.c"
case 209: /* expr ::= expr IS NULL */ break;
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, NULL, TK_ISNULL);} case 205: /* expr ::= STRING */
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 634 "sql.y"
break; { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_STRING);}
case 210: /* expr ::= expr IS NOT NULL */ #line 2645 "sql.c"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-3].minor.yy78, NULL, TK_NOTNULL);} break;
yymsp[-3].minor.yy78 = yylhsminor.yy78; case 206: /* expr ::= NOW */
break; #line 635 "sql.y"
case 211: /* expr ::= expr LT expr */ { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_NOW); }
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_LT);} #line 2650 "sql.c"
yymsp[-2].minor.yy78 = yylhsminor.yy78; break;
break; case 207: /* expr ::= VARIABLE */
case 212: /* expr ::= expr GT expr */ #line 636 "sql.y"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_GT);} { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_VARIABLE);}
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 2655 "sql.c"
break; break;
case 213: /* expr ::= expr LE expr */ case 208: /* expr ::= BOOL */
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_LE);} #line 637 "sql.y"
yymsp[-2].minor.yy78 = yylhsminor.yy78; { yygotominor.yy50 = tSqlExprIdValueCreate(&yymsp[0].minor.yy0, TK_BOOL);}
break; #line 2660 "sql.c"
case 214: /* expr ::= expr GE expr */ break;
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_GE);} case 209: /* expr ::= ID LP exprlist RP */
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 640 "sql.y"
break; { yygotominor.yy50 = tSqlExprCreateFunction(yymsp[-1].minor.yy178, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0, yymsp[-3].minor.yy0.type); }
case 215: /* expr ::= expr NE expr */ #line 2665 "sql.c"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_NE);} break;
yymsp[-2].minor.yy78 = yylhsminor.yy78; case 210: /* expr ::= ID LP STAR RP */
break; #line 643 "sql.y"
case 216: /* expr ::= expr EQ expr */ { yygotominor.yy50 = tSqlExprCreateFunction(NULL, &yymsp[-3].minor.yy0, &yymsp[0].minor.yy0, yymsp[-3].minor.yy0.type); }
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_EQ);} #line 2670 "sql.c"
yymsp[-2].minor.yy78 = yylhsminor.yy78; break;
break; case 211: /* expr ::= expr IS NULL */
case 217: /* expr ::= expr AND expr */ #line 646 "sql.y"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_AND);} {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, NULL, TK_ISNULL);}
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 2675 "sql.c"
break; break;
case 218: /* expr ::= expr OR expr */ case 212: /* expr ::= expr IS NOT NULL */
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_OR); } #line 647 "sql.y"
yymsp[-2].minor.yy78 = yylhsminor.yy78; {yygotominor.yy50 = tSqlExprCreate(yymsp[-3].minor.yy50, NULL, TK_NOTNULL);}
break; #line 2680 "sql.c"
case 219: /* expr ::= expr PLUS expr */ break;
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_PLUS); } case 213: /* expr ::= expr LT expr */
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 650 "sql.y"
break; {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_LT);}
case 220: /* expr ::= expr MINUS expr */ #line 2685 "sql.c"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_MINUS); } break;
yymsp[-2].minor.yy78 = yylhsminor.yy78; case 214: /* expr ::= expr GT expr */
break; #line 651 "sql.y"
case 221: /* expr ::= expr STAR expr */ {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_GT);}
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_STAR); } #line 2690 "sql.c"
yymsp[-2].minor.yy78 = yylhsminor.yy78; break;
break; case 215: /* expr ::= expr LE expr */
case 222: /* expr ::= expr SLASH expr */ #line 652 "sql.y"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_DIVIDE);} {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_LE);}
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 2695 "sql.c"
break; break;
case 223: /* expr ::= expr REM expr */ case 216: /* expr ::= expr GE expr */
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_REM); } #line 653 "sql.y"
yymsp[-2].minor.yy78 = yylhsminor.yy78; {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_GE);}
break; #line 2700 "sql.c"
case 224: /* expr ::= expr LIKE expr */ break;
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-2].minor.yy78, yymsp[0].minor.yy78, TK_LIKE); } case 217: /* expr ::= expr NE expr */
yymsp[-2].minor.yy78 = yylhsminor.yy78; #line 654 "sql.y"
break; {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_NE);}
case 225: /* expr ::= expr IN LP exprlist RP */ #line 2705 "sql.c"
{yylhsminor.yy78 = tSqlExprCreate(yymsp[-4].minor.yy78, (tSQLExpr*)yymsp[-1].minor.yy166, TK_IN); } break;
yymsp[-4].minor.yy78 = yylhsminor.yy78; case 218: /* expr ::= expr EQ expr */
break; #line 655 "sql.y"
case 226: /* exprlist ::= exprlist COMMA expritem */ {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_EQ);}
{yylhsminor.yy166 = tSqlExprListAppend(yymsp[-2].minor.yy166,yymsp[0].minor.yy78,0);} #line 2710 "sql.c"
yymsp[-2].minor.yy166 = yylhsminor.yy166; break;
break; case 219: /* expr ::= expr AND expr */
case 227: /* exprlist ::= expritem */ #line 657 "sql.y"
{yylhsminor.yy166 = tSqlExprListAppend(0,yymsp[0].minor.yy78,0);} {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_AND);}
yymsp[0].minor.yy166 = yylhsminor.yy166; #line 2715 "sql.c"
break; break;
case 228: /* expritem ::= expr */ case 220: /* expr ::= expr OR expr */
{yylhsminor.yy78 = yymsp[0].minor.yy78;} #line 658 "sql.y"
yymsp[0].minor.yy78 = yylhsminor.yy78; {yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_OR); }
break; #line 2720 "sql.c"
case 230: /* cmd ::= RESET QUERY CACHE */ break;
case 221: /* expr ::= expr PLUS expr */
#line 661 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_PLUS); }
#line 2725 "sql.c"
break;
case 222: /* expr ::= expr MINUS expr */
#line 662 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_MINUS); }
#line 2730 "sql.c"
break;
case 223: /* expr ::= expr STAR expr */
#line 663 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_STAR); }
#line 2735 "sql.c"
break;
case 224: /* expr ::= expr SLASH expr */
#line 664 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_DIVIDE);}
#line 2740 "sql.c"
break;
case 225: /* expr ::= expr REM expr */
#line 665 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_REM); }
#line 2745 "sql.c"
break;
case 226: /* expr ::= expr LIKE expr */
#line 668 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-2].minor.yy50, yymsp[0].minor.yy50, TK_LIKE); }
#line 2750 "sql.c"
break;
case 227: /* expr ::= expr IN LP exprlist RP */
#line 671 "sql.y"
{yygotominor.yy50 = tSqlExprCreate(yymsp[-4].minor.yy50, (tSQLExpr*)yymsp[-1].minor.yy178, TK_IN); }
#line 2755 "sql.c"
break;
case 228: /* exprlist ::= exprlist COMMA expritem */
#line 679 "sql.y"
{yygotominor.yy178 = tSqlExprListAppend(yymsp[-2].minor.yy178,yymsp[0].minor.yy50,0, 0);}
#line 2760 "sql.c"
break;
case 229: /* exprlist ::= expritem */
#line 680 "sql.y"
{yygotominor.yy178 = tSqlExprListAppend(0,yymsp[0].minor.yy50,0, 0);}
#line 2765 "sql.c"
break;
case 232: /* cmd ::= RESET QUERY CACHE */
#line 685 "sql.y"
{ setDCLSQLElems(pInfo, TSDB_SQL_RESET_CACHE, 0);} { setDCLSQLElems(pInfo, TSDB_SQL_RESET_CACHE, 0);}
#line 2770 "sql.c"
break; break;
case 231: /* cmd ::= ALTER TABLE ids cpxName ADD COLUMN columnlist */ case 233: /* cmd ::= ALTER TABLE ids cpxName ADD COLUMN columnlist */
#line 688 "sql.y"
{ {
yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n; yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n;
SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, yymsp[0].minor.yy421, NULL, TSDB_ALTER_TABLE_ADD_COLUMN); SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, yymsp[0].minor.yy221, NULL, TSDB_ALTER_TABLE_ADD_COLUMN);
setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE); setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE);
} }
#line 2779 "sql.c"
break; break;
case 232: /* cmd ::= ALTER TABLE ids cpxName DROP COLUMN ids */ case 234: /* cmd ::= ALTER TABLE ids cpxName DROP COLUMN ids */
#line 694 "sql.y"
{ {
yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n; yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n;
...@@ -2879,15 +2788,19 @@ static void yy_reduce( ...@@ -2879,15 +2788,19 @@ static void yy_reduce(
SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, NULL, K, TSDB_ALTER_TABLE_DROP_COLUMN); SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, NULL, K, TSDB_ALTER_TABLE_DROP_COLUMN);
setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE); setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE);
} }
#line 2792 "sql.c"
break; break;
case 233: /* cmd ::= ALTER TABLE ids cpxName ADD TAG columnlist */ case 235: /* cmd ::= ALTER TABLE ids cpxName ADD TAG columnlist */
#line 705 "sql.y"
{ {
yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n; yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n;
SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, yymsp[0].minor.yy421, NULL, TSDB_ALTER_TABLE_ADD_TAG_COLUMN); SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, yymsp[0].minor.yy221, NULL, TSDB_ALTER_TABLE_ADD_TAG_COLUMN);
setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE); setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE);
} }
#line 2801 "sql.c"
break; break;
case 234: /* cmd ::= ALTER TABLE ids cpxName DROP TAG ids */ case 236: /* cmd ::= ALTER TABLE ids cpxName DROP TAG ids */
#line 710 "sql.y"
{ {
yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n; yymsp[-4].minor.yy0.n += yymsp[-3].minor.yy0.n;
...@@ -2897,8 +2810,10 @@ static void yy_reduce( ...@@ -2897,8 +2810,10 @@ static void yy_reduce(
SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, NULL, A, TSDB_ALTER_TABLE_DROP_TAG_COLUMN); SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-4].minor.yy0, NULL, A, TSDB_ALTER_TABLE_DROP_TAG_COLUMN);
setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE); setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE);
} }
#line 2814 "sql.c"
break; break;
case 235: /* cmd ::= ALTER TABLE ids cpxName CHANGE TAG ids ids */ case 237: /* cmd ::= ALTER TABLE ids cpxName CHANGE TAG ids ids */
#line 720 "sql.y"
{ {
yymsp[-5].minor.yy0.n += yymsp[-4].minor.yy0.n; yymsp[-5].minor.yy0.n += yymsp[-4].minor.yy0.n;
...@@ -2911,49 +2826,65 @@ static void yy_reduce( ...@@ -2911,49 +2826,65 @@ static void yy_reduce(
SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-5].minor.yy0, NULL, A, TSDB_ALTER_TABLE_CHANGE_TAG_COLUMN); SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-5].minor.yy0, NULL, A, TSDB_ALTER_TABLE_CHANGE_TAG_COLUMN);
setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE); setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE);
} }
#line 2830 "sql.c"
break; break;
case 236: /* cmd ::= ALTER TABLE ids cpxName SET TAG ids EQ tagitem */ case 238: /* cmd ::= ALTER TABLE ids cpxName SET TAG ids EQ tagitem */
#line 733 "sql.y"
{ {
yymsp[-6].minor.yy0.n += yymsp[-5].minor.yy0.n; yymsp[-6].minor.yy0.n += yymsp[-5].minor.yy0.n;
toTSDBType(yymsp[-2].minor.yy0.type); toTSDBType(yymsp[-2].minor.yy0.type);
SArray* A = tVariantListAppendToken(NULL, &yymsp[-2].minor.yy0, -1); SArray* A = tVariantListAppendToken(NULL, &yymsp[-2].minor.yy0, -1);
A = tVariantListAppend(A, &yymsp[0].minor.yy430, -1); A = tVariantListAppend(A, &yymsp[0].minor.yy106, -1);
SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-6].minor.yy0, NULL, A, TSDB_ALTER_TABLE_UPDATE_TAG_VAL); SAlterTableSQL* pAlterTable = tAlterTableSqlElems(&yymsp[-6].minor.yy0, NULL, A, TSDB_ALTER_TABLE_UPDATE_TAG_VAL);
setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE); setSqlInfo(pInfo, pAlterTable, NULL, TSDB_SQL_ALTER_TABLE);
} }
#line 2844 "sql.c"
break; break;
case 237: /* cmd ::= KILL CONNECTION INTEGER */ case 239: /* cmd ::= KILL CONNECTION INTEGER */
#line 745 "sql.y"
{setKillSql(pInfo, TSDB_SQL_KILL_CONNECTION, &yymsp[0].minor.yy0);} {setKillSql(pInfo, TSDB_SQL_KILL_CONNECTION, &yymsp[0].minor.yy0);}
#line 2849 "sql.c"
break; break;
case 238: /* cmd ::= KILL STREAM INTEGER COLON INTEGER */ case 240: /* cmd ::= KILL STREAM INTEGER COLON INTEGER */
#line 746 "sql.y"
{yymsp[-2].minor.yy0.n += (yymsp[-1].minor.yy0.n + yymsp[0].minor.yy0.n); setKillSql(pInfo, TSDB_SQL_KILL_STREAM, &yymsp[-2].minor.yy0);} {yymsp[-2].minor.yy0.n += (yymsp[-1].minor.yy0.n + yymsp[0].minor.yy0.n); setKillSql(pInfo, TSDB_SQL_KILL_STREAM, &yymsp[-2].minor.yy0);}
#line 2854 "sql.c"
break; break;
case 239: /* cmd ::= KILL QUERY INTEGER COLON INTEGER */ case 241: /* cmd ::= KILL QUERY INTEGER COLON INTEGER */
#line 747 "sql.y"
{yymsp[-2].minor.yy0.n += (yymsp[-1].minor.yy0.n + yymsp[0].minor.yy0.n); setKillSql(pInfo, TSDB_SQL_KILL_QUERY, &yymsp[-2].minor.yy0);} {yymsp[-2].minor.yy0.n += (yymsp[-1].minor.yy0.n + yymsp[0].minor.yy0.n); setKillSql(pInfo, TSDB_SQL_KILL_QUERY, &yymsp[-2].minor.yy0);}
#line 2859 "sql.c"
break; break;
default: default:
break; break;
/********** End reduce actions ************************************************/
}; };
assert( yyruleno<sizeof(yyRuleInfo)/sizeof(yyRuleInfo[0]) );
yygoto = yyRuleInfo[yyruleno].lhs; yygoto = yyRuleInfo[yyruleno].lhs;
yysize = yyRuleInfo[yyruleno].nrhs; yysize = yyRuleInfo[yyruleno].nrhs;
yyact = yy_find_reduce_action(yymsp[yysize].stateno,(YYCODETYPE)yygoto); yypParser->yyidx -= yysize;
yyact = yy_find_reduce_action(yymsp[-yysize].stateno,(YYCODETYPE)yygoto);
/* There are no SHIFTREDUCE actions on nonterminals because the table if( yyact < YYNSTATE ){
** generator has simplified them to pure REDUCE actions. */ #ifdef NDEBUG
assert( !(yyact>YY_MAX_SHIFT && yyact<=YY_MAX_SHIFTREDUCE) ); /* If we are not debugging and the reduce action popped at least
** one element off the stack, then we can push the new element back
/* It is not possible for a REDUCE to be followed by an error */ ** onto the stack here, and skip the stack overflow test in yy_shift().
assert( yyact!=YY_ERROR_ACTION ); ** That gives a significant speed improvement. */
if( yysize ){
yymsp += yysize+1; yypParser->yyidx++;
yypParser->yytos = yymsp; yymsp -= yysize-1;
yymsp->stateno = (YYACTIONTYPE)yyact; yymsp->stateno = (YYACTIONTYPE)yyact;
yymsp->major = (YYCODETYPE)yygoto; yymsp->major = (YYCODETYPE)yygoto;
yyTraceShift(yypParser, yyact, "... then shift"); yymsp->minor = yygotominor;
}else
#endif
{
yy_shift(yypParser,yyact,yygoto,&yygotominor);
}
}else{
assert( yyact == YYNSTATE + YYNRULE + 1 );
yy_accept(yypParser);
}
} }
/* /*
...@@ -2969,11 +2900,9 @@ static void yy_parse_failed( ...@@ -2969,11 +2900,9 @@ static void yy_parse_failed(
fprintf(yyTraceFILE,"%sFail!\n",yyTracePrompt); fprintf(yyTraceFILE,"%sFail!\n",yyTracePrompt);
} }
#endif #endif
while( yypParser->yytos>yypParser->yystack ) yy_pop_parser_stack(yypParser); while( yypParser->yyidx>=0 ) yy_pop_parser_stack(yypParser);
/* Here code is inserted which will be executed whenever the /* Here code is inserted which will be executed whenever the
** parser fails */ ** parser fails */
/************ Begin %parse_failure code ***************************************/
/************ End %parse_failure code *****************************************/
ParseARG_STORE; /* Suppress warning about unused %extra_argument variable */ ParseARG_STORE; /* Suppress warning about unused %extra_argument variable */
} }
#endif /* YYNOERRORRECOVERY */ #endif /* YYNOERRORRECOVERY */
...@@ -2984,11 +2913,11 @@ static void yy_parse_failed( ...@@ -2984,11 +2913,11 @@ static void yy_parse_failed(
static void yy_syntax_error( static void yy_syntax_error(
yyParser *yypParser, /* The parser */ yyParser *yypParser, /* The parser */
int yymajor, /* The major type of the error token */ int yymajor, /* The major type of the error token */
ParseTOKENTYPE yyminor /* The minor type of the error token */ YYMINORTYPE yyminor /* The minor type of the error token */
){ ){
ParseARG_FETCH; ParseARG_FETCH;
#define TOKEN yyminor #define TOKEN (yyminor.yy0)
/************ Begin %syntax_error code ****************************************/ #line 37 "sql.y"
pInfo->valid = false; pInfo->valid = false;
int32_t outputBufLen = tListLen(pInfo->pzErrMsg); int32_t outputBufLen = tListLen(pInfo->pzErrMsg);
...@@ -3011,7 +2940,7 @@ static void yy_syntax_error( ...@@ -3011,7 +2940,7 @@ static void yy_syntax_error(
} }
assert(len <= outputBufLen); assert(len <= outputBufLen);
/************ End %syntax_error code ******************************************/ #line 2944 "sql.c"
ParseARG_STORE; /* Suppress warning about unused %extra_argument variable */ ParseARG_STORE; /* Suppress warning about unused %extra_argument variable */
} }
...@@ -3027,15 +2956,11 @@ static void yy_accept( ...@@ -3027,15 +2956,11 @@ static void yy_accept(
fprintf(yyTraceFILE,"%sAccept!\n",yyTracePrompt); fprintf(yyTraceFILE,"%sAccept!\n",yyTracePrompt);
} }
#endif #endif
#ifndef YYNOERRORRECOVERY while( yypParser->yyidx>=0 ) yy_pop_parser_stack(yypParser);
yypParser->yyerrcnt = -1;
#endif
assert( yypParser->yytos==yypParser->yystack );
/* Here code is inserted which will be executed whenever the /* Here code is inserted which will be executed whenever the
** parser accepts */ ** parser accepts */
/*********** Begin %parse_accept code *****************************************/ #line 61 "sql.y"
#line 2964 "sql.c"
/*********** End %parse_accept code *******************************************/
ParseARG_STORE; /* Suppress warning about unused %extra_argument variable */ ParseARG_STORE; /* Suppress warning about unused %extra_argument variable */
} }
...@@ -3065,52 +2990,50 @@ void Parse( ...@@ -3065,52 +2990,50 @@ void Parse(
ParseARG_PDECL /* Optional %extra_argument parameter */ ParseARG_PDECL /* Optional %extra_argument parameter */
){ ){
YYMINORTYPE yyminorunion; YYMINORTYPE yyminorunion;
unsigned int yyact; /* The parser action. */ int yyact; /* The parser action. */
#if !defined(YYERRORSYMBOL) && !defined(YYNOERRORRECOVERY)
int yyendofinput; /* True if we are at the end of input */ int yyendofinput; /* True if we are at the end of input */
#endif
#ifdef YYERRORSYMBOL #ifdef YYERRORSYMBOL
int yyerrorhit = 0; /* True if yymajor has invoked an error */ int yyerrorhit = 0; /* True if yymajor has invoked an error */
#endif #endif
yyParser *yypParser; /* The parser */ yyParser *yypParser; /* The parser */
/* (re)initialize the parser, if necessary */
yypParser = (yyParser*)yyp; yypParser = (yyParser*)yyp;
assert( yypParser->yytos!=0 ); if( yypParser->yyidx<0 ){
#if !defined(YYERRORSYMBOL) && !defined(YYNOERRORRECOVERY) #if YYSTACKDEPTH<=0
yyendofinput = (yymajor==0); if( yypParser->yystksz <=0 ){
/*memset(&yyminorunion, 0, sizeof(yyminorunion));*/
yyminorunion = yyzerominor;
yyStackOverflow(yypParser, &yyminorunion);
return;
}
#endif #endif
yypParser->yyidx = 0;
yypParser->yyerrcnt = -1;
yypParser->yystack[0].stateno = 0;
yypParser->yystack[0].major = 0;
}
yyminorunion.yy0 = yyminor;
yyendofinput = (yymajor==0);
ParseARG_STORE; ParseARG_STORE;
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE ){ if( yyTraceFILE ){
int stateno = yypParser->yytos->stateno; fprintf(yyTraceFILE,"%sInput %s\n",yyTracePrompt,yyTokenName[yymajor]);
if( stateno < YY_MIN_REDUCE ){
fprintf(yyTraceFILE,"%sInput '%s' in state %d\n",
yyTracePrompt,yyTokenName[yymajor],stateno);
}else{
fprintf(yyTraceFILE,"%sInput '%s' with pending reduce %d\n",
yyTracePrompt,yyTokenName[yymajor],stateno-YY_MIN_REDUCE);
}
} }
#endif #endif
do{ do{
yyact = yy_find_shift_action(yypParser,(YYCODETYPE)yymajor); yyact = yy_find_shift_action(yypParser,(YYCODETYPE)yymajor);
if( yyact >= YY_MIN_REDUCE ){ if( yyact<YYNSTATE ){
yy_reduce(yypParser,yyact-YY_MIN_REDUCE,yymajor,yyminor); assert( !yyendofinput ); /* Impossible to shift the $ token */
}else if( yyact <= YY_MAX_SHIFTREDUCE ){ yy_shift(yypParser,yyact,yymajor,&yyminorunion);
yy_shift(yypParser,yyact,yymajor,yyminor);
#ifndef YYNOERRORRECOVERY
yypParser->yyerrcnt--; yypParser->yyerrcnt--;
#endif
yymajor = YYNOCODE; yymajor = YYNOCODE;
}else if( yyact==YY_ACCEPT_ACTION ){ }else if( yyact < YYNSTATE + YYNRULE ){
yypParser->yytos--; yy_reduce(yypParser,yyact-YYNSTATE);
yy_accept(yypParser);
return;
}else{ }else{
assert( yyact == YY_ERROR_ACTION ); assert( yyact == YY_ERROR_ACTION );
yyminorunion.yy0 = yyminor;
#ifdef YYERRORSYMBOL #ifdef YYERRORSYMBOL
int yymx; int yymx;
#endif #endif
...@@ -3140,9 +3063,9 @@ void Parse( ...@@ -3140,9 +3063,9 @@ void Parse(
** **
*/ */
if( yypParser->yyerrcnt<0 ){ if( yypParser->yyerrcnt<0 ){
yy_syntax_error(yypParser,yymajor,yyminor); yy_syntax_error(yypParser,yymajor,yyminorunion);
} }
yymx = yypParser->yytos->major; yymx = yypParser->yystack[yypParser->yyidx].major;
if( yymx==YYERRORSYMBOL || yyerrorhit ){ if( yymx==YYERRORSYMBOL || yyerrorhit ){
#ifndef NDEBUG #ifndef NDEBUG
if( yyTraceFILE ){ if( yyTraceFILE ){
...@@ -3150,26 +3073,26 @@ void Parse( ...@@ -3150,26 +3073,26 @@ void Parse(
yyTracePrompt,yyTokenName[yymajor]); yyTracePrompt,yyTokenName[yymajor]);
} }
#endif #endif
yy_destructor(yypParser, (YYCODETYPE)yymajor, &yyminorunion); yy_destructor(yypParser, (YYCODETYPE)yymajor,&yyminorunion);
yymajor = YYNOCODE; yymajor = YYNOCODE;
}else{ }else{
while( yypParser->yytos >= yypParser->yystack while(
&& yymx != YYERRORSYMBOL yypParser->yyidx >= 0 &&
&& (yyact = yy_find_reduce_action( yymx != YYERRORSYMBOL &&
yypParser->yytos->stateno, (yyact = yy_find_reduce_action(
YYERRORSYMBOL)) >= YY_MIN_REDUCE yypParser->yystack[yypParser->yyidx].stateno,
YYERRORSYMBOL)) >= YYNSTATE
){ ){
yy_pop_parser_stack(yypParser); yy_pop_parser_stack(yypParser);
} }
if( yypParser->yytos < yypParser->yystack || yymajor==0 ){ if( yypParser->yyidx < 0 || yymajor==0 ){
yy_destructor(yypParser,(YYCODETYPE)yymajor,&yyminorunion); yy_destructor(yypParser,(YYCODETYPE)yymajor,&yyminorunion);
yy_parse_failed(yypParser); yy_parse_failed(yypParser);
#ifndef YYNOERRORRECOVERY
yypParser->yyerrcnt = -1;
#endif
yymajor = YYNOCODE; yymajor = YYNOCODE;
}else if( yymx!=YYERRORSYMBOL ){ }else if( yymx!=YYERRORSYMBOL ){
yy_shift(yypParser,yyact,YYERRORSYMBOL,yyminor); YYMINORTYPE u2;
u2.YYERRSYMDT = 0;
yy_shift(yypParser,yyact,YYERRORSYMBOL,&u2);
} }
} }
yypParser->yyerrcnt = 3; yypParser->yyerrcnt = 3;
...@@ -3182,7 +3105,7 @@ void Parse( ...@@ -3182,7 +3105,7 @@ void Parse(
** Applications can set this macro (for example inside %include) if ** Applications can set this macro (for example inside %include) if
** they intend to abandon the parse upon the first syntax error seen. ** they intend to abandon the parse upon the first syntax error seen.
*/ */
yy_syntax_error(yypParser,yymajor, yyminor); yy_syntax_error(yypParser,yymajor,yyminorunion);
yy_destructor(yypParser,(YYCODETYPE)yymajor,&yyminorunion); yy_destructor(yypParser,(YYCODETYPE)yymajor,&yyminorunion);
yymajor = YYNOCODE; yymajor = YYNOCODE;
...@@ -3197,31 +3120,16 @@ void Parse( ...@@ -3197,31 +3120,16 @@ void Parse(
** three input tokens have been successfully shifted. ** three input tokens have been successfully shifted.
*/ */
if( yypParser->yyerrcnt<=0 ){ if( yypParser->yyerrcnt<=0 ){
yy_syntax_error(yypParser,yymajor, yyminor); yy_syntax_error(yypParser,yymajor,yyminorunion);
} }
yypParser->yyerrcnt = 3; yypParser->yyerrcnt = 3;
yy_destructor(yypParser,(YYCODETYPE)yymajor,&yyminorunion); yy_destructor(yypParser,(YYCODETYPE)yymajor,&yyminorunion);
if( yyendofinput ){ if( yyendofinput ){
yy_parse_failed(yypParser); yy_parse_failed(yypParser);
#ifndef YYNOERRORRECOVERY
yypParser->yyerrcnt = -1;
#endif
} }
yymajor = YYNOCODE; yymajor = YYNOCODE;
#endif #endif
} }
}while( yymajor!=YYNOCODE && yypParser->yytos>yypParser->yystack ); }while( yymajor!=YYNOCODE && yypParser->yyidx>=0 );
#ifndef NDEBUG
if( yyTraceFILE ){
yyStackEntry *i;
char cDiv = '[';
fprintf(yyTraceFILE,"%sReturn. Stack=",yyTracePrompt);
for(i=&yypParser->yystack[1]; i<=yypParser->yytos; i++){
fprintf(yyTraceFILE,"%c%s", cDiv, yyTokenName[i->major]);
cDiv = ' ';
}
fprintf(yyTraceFILE,"]\n");
}
#endif
return; return;
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册