xref: /sqlite-3.40.0/src/parse.y (revision adbca9cf)
1348784efSdrh /*
2b19a2bc6Sdrh ** 2001 September 15
3348784efSdrh **
4b19a2bc6Sdrh ** The author disclaims copyright to this source code.  In place of
5b19a2bc6Sdrh ** a legal notice, here is a blessing:
6348784efSdrh **
7b19a2bc6Sdrh **    May you do good and not evil.
8b19a2bc6Sdrh **    May you find forgiveness for yourself and forgive others.
9b19a2bc6Sdrh **    May you share freely, never taking more than you give.
10348784efSdrh **
11348784efSdrh *************************************************************************
12348784efSdrh ** This file contains SQLite's grammar for SQL.  Process this file
13348784efSdrh ** using the lemon parser generator to generate C code that runs
14348784efSdrh ** the parser.  Lemon will also generate a header file containing
15348784efSdrh ** numeric codes for all of the tokens.
16348784efSdrh **
17*adbca9cfSdrh ** @(#) $Id: parse.y,v 1.32 2001/09/27 15:11:54 drh Exp $
18348784efSdrh */
19348784efSdrh %token_prefix TK_
20348784efSdrh %token_type {Token}
21f57b14a6Sdrh %default_type {Token}
22348784efSdrh %extra_argument {Parse *pParse}
23348784efSdrh %syntax_error {
24c837e709Sdrh   sqliteSetString(&pParse->zErrMsg,"syntax error",0);
25348784efSdrh   pParse->sErrToken = TOKEN;
26348784efSdrh }
27348784efSdrh %name sqliteParser
28348784efSdrh %include {
29348784efSdrh #include "sqliteInt.h"
30348784efSdrh #include "parse.h"
31348784efSdrh }
32348784efSdrh 
33348784efSdrh // These are extra tokens used by the lexer but never seen by the
34348784efSdrh // parser.  We put them in a rule so that the parser generator will
356206d50aSdrh // add them to the parse.h output file.
36348784efSdrh //
37c4a3c779Sdrh %nonassoc END_OF_FILE ILLEGAL SPACE UNCLOSED_STRING COMMENT FUNCTION
38c4a3c779Sdrh           COLUMN AGG_FUNCTION.
39c4a3c779Sdrh 
40c4a3c779Sdrh // Input is zero or more commands.
41c4a3c779Sdrh input ::= cmdlist.
42348784efSdrh 
43348784efSdrh // A list of commands is zero or more commands
44348784efSdrh //
45348784efSdrh cmdlist ::= ecmd.
46348784efSdrh cmdlist ::= cmdlist SEMI ecmd.
47348784efSdrh ecmd ::= explain cmd.  {sqliteExec(pParse);}
48348784efSdrh ecmd ::= cmd.          {sqliteExec(pParse);}
49348784efSdrh ecmd ::= .
50348784efSdrh explain ::= EXPLAIN.    {pParse->explain = 1;}
51348784efSdrh 
52c4a3c779Sdrh // Begin and end transactions.  Transaction support is sparse.
53c4a3c779Sdrh // Some backends support only COMMIT and not ROLLBACK.  There can
54c4a3c779Sdrh // be only a single active transaction at a time.
55c4a3c779Sdrh //
56c4a3c779Sdrh cmd ::= BEGIN trans_opt.       {sqliteBeginTransaction(pParse);}
57c4a3c779Sdrh trans_opt ::= .
58c4a3c779Sdrh trans_opt ::= TRANSACTION.
59c4a3c779Sdrh trans_opt ::= TRANSACTION ids.
60c4a3c779Sdrh cmd ::= COMMIT trans_opt.      {sqliteCommitTransaction(pParse);}
61c4a3c779Sdrh cmd ::= END trans_opt.         {sqliteCommitTransaction(pParse);}
62c4a3c779Sdrh cmd ::= ROLLBACK trans_opt.    {sqliteRollbackTransaction(pParse);}
63c4a3c779Sdrh 
64348784efSdrh // The first form of a command is a CREATE TABLE statement.
65348784efSdrh //
66348784efSdrh cmd ::= create_table create_table_args.
67c4a3c779Sdrh create_table ::= CREATE(X) TABLE ids(Y).   {sqliteStartTable(pParse,&X,&Y);}
68348784efSdrh create_table_args ::= LP columnlist conslist_opt RP(X).
69348784efSdrh                                            {sqliteEndTable(pParse,&X);}
70348784efSdrh columnlist ::= columnlist COMMA column.
71348784efSdrh columnlist ::= column.
72348784efSdrh 
73348784efSdrh // About the only information used for a column is the name of the
74348784efSdrh // column.  The type is always just "text".  But the code will accept
75348784efSdrh // an elaborate typename.  Perhaps someday we'll do something with it.
76348784efSdrh //
77348784efSdrh column ::= columnid type carglist.
78c4a3c779Sdrh columnid ::= ids(X).                {sqliteAddColumn(pParse,&X);}
79c4a3c779Sdrh 
80c4a3c779Sdrh // An IDENTIFIER can be a generic identifier, or one of several
81c4a3c779Sdrh // keywords.  Any non-standard keyword can also be an identifier.
82c4a3c779Sdrh // We also make DESC and identifier since it comes up so often.
83c4a3c779Sdrh //
84982cef7eSdrh %type id {Token}
85c4a3c779Sdrh id(A) ::= DESC(X).       {A = X;}
86c4a3c779Sdrh id(A) ::= ASC(X).        {A = X;}
87c4a3c779Sdrh id(A) ::= DELIMITERS(X). {A = X;}
88c4a3c779Sdrh id(A) ::= EXPLAIN(X).    {A = X;}
89c4a3c779Sdrh id(A) ::= VACUUM(X).     {A = X;}
90c4a3c779Sdrh id(A) ::= BEGIN(X).      {A = X;}
91c4a3c779Sdrh id(A) ::= END(X).        {A = X;}
92f57b14a6Sdrh id(A) ::= PRAGMA(X).     {A = X;}
93f57b14a6Sdrh id(A) ::= CLUSTER(X).    {A = X;}
94982cef7eSdrh id(A) ::= ID(X).         {A = X;}
95c4a3c779Sdrh 
96c4a3c779Sdrh // And "ids" is an identifer-or-string.
97c4a3c779Sdrh //
98c4a3c779Sdrh %type ids {Token}
99c4a3c779Sdrh ids(A) ::= id(X).        {A = X;}
100c4a3c779Sdrh ids(A) ::= STRING(X).    {A = X;}
101c4a3c779Sdrh 
102348784efSdrh type ::= typename.
103348784efSdrh type ::= typename LP signed RP.
104348784efSdrh type ::= typename LP signed COMMA signed RP.
105c4a3c779Sdrh typename ::= ids.
106c4a3c779Sdrh typename ::= typename ids.
107348784efSdrh signed ::= INTEGER.
108348784efSdrh signed ::= PLUS INTEGER.
109348784efSdrh signed ::= MINUS INTEGER.
110348784efSdrh carglist ::= carglist carg.
111348784efSdrh carglist ::= .
112c4a3c779Sdrh carg ::= CONSTRAINT ids ccons.
113348784efSdrh carg ::= ccons.
1147020f651Sdrh carg ::= DEFAULT STRING(X).          {sqliteAddDefaultValue(pParse,&X,0);}
1157020f651Sdrh carg ::= DEFAULT ID(X).              {sqliteAddDefaultValue(pParse,&X,0);}
1167020f651Sdrh carg ::= DEFAULT INTEGER(X).         {sqliteAddDefaultValue(pParse,&X,0);}
1177020f651Sdrh carg ::= DEFAULT PLUS INTEGER(X).    {sqliteAddDefaultValue(pParse,&X,0);}
1187020f651Sdrh carg ::= DEFAULT MINUS INTEGER(X).   {sqliteAddDefaultValue(pParse,&X,1);}
1197020f651Sdrh carg ::= DEFAULT FLOAT(X).           {sqliteAddDefaultValue(pParse,&X,0);}
1207020f651Sdrh carg ::= DEFAULT PLUS FLOAT(X).      {sqliteAddDefaultValue(pParse,&X,0);}
1217020f651Sdrh carg ::= DEFAULT MINUS FLOAT(X).     {sqliteAddDefaultValue(pParse,&X,1);}
1227020f651Sdrh carg ::= DEFAULT NULL.
123348784efSdrh 
124348784efSdrh // In addition to the type name, we also care about the primary key.
125348784efSdrh //
126348784efSdrh ccons ::= NOT NULL.
127717e6402Sdrh ccons ::= PRIMARY KEY sortorder.     {sqliteCreateIndex(pParse,0,0,0,1,0,0);}
128*adbca9cfSdrh ccons ::= UNIQUE.                    {sqliteCreateIndex(pParse,0,0,0,1,0,0);}
1294794b980Sdrh ccons ::= CHECK LP expr RP.
130348784efSdrh 
131348784efSdrh // For the time being, the only constraint we care about is the primary
132348784efSdrh // key.
133348784efSdrh //
134348784efSdrh conslist_opt ::= .
135348784efSdrh conslist_opt ::= COMMA conslist.
136348784efSdrh conslist ::= conslist COMMA tcons.
137a2e1bb5aSdrh conslist ::= conslist tcons.
138348784efSdrh conslist ::= tcons.
139c4a3c779Sdrh tcons ::= CONSTRAINT ids.
140717e6402Sdrh tcons ::= PRIMARY KEY LP idxlist(X) RP. {sqliteCreateIndex(pParse,0,0,X,1,0,0);}
141*adbca9cfSdrh tcons ::= UNIQUE LP idxlist(X) RP.      {sqliteCreateIndex(pParse,0,0,X,1,0,0);}
142a2e1bb5aSdrh tcons ::= CHECK expr.
143*adbca9cfSdrh // idlist ::= idlist COMMA ids.
144*adbca9cfSdrh // idlist ::= ids.
145348784efSdrh 
146348784efSdrh // The next command format is dropping tables.
147348784efSdrh //
148c4a3c779Sdrh cmd ::= DROP TABLE ids(X).          {sqliteDropTable(pParse,&X);}
149348784efSdrh 
150348784efSdrh // The select statement
151348784efSdrh //
1529bb61fe7Sdrh cmd ::= select(X).  {
153fef5208cSdrh   sqliteSelect(pParse, X, SRT_Callback, 0);
1549bb61fe7Sdrh   sqliteSelectDelete(X);
1559bb61fe7Sdrh }
156efb7251dSdrh 
1579bb61fe7Sdrh %type select {Select*}
1589bb61fe7Sdrh %destructor select {sqliteSelectDelete($$);}
15982c3d636Sdrh %type oneselect {Select*}
16082c3d636Sdrh %destructor oneselect {sqliteSelectDelete($$);}
1619bb61fe7Sdrh 
16282c3d636Sdrh select(A) ::= oneselect(X).                      {A = X;}
16382c3d636Sdrh select(A) ::= select(X) joinop(Y) oneselect(Z).  {
164daffd0e5Sdrh   if( Z ){
16582c3d636Sdrh     Z->op = Y;
16682c3d636Sdrh     Z->pPrior = X;
167daffd0e5Sdrh   }
16882c3d636Sdrh   A = Z;
16982c3d636Sdrh }
17082c3d636Sdrh %type joinop {int}
17182c3d636Sdrh joinop(A) ::= UNION.      {A = TK_UNION;}
17282c3d636Sdrh joinop(A) ::= UNION ALL.  {A = TK_ALL;}
17382c3d636Sdrh joinop(A) ::= INTERSECT.  {A = TK_INTERSECT;}
17482c3d636Sdrh joinop(A) ::= EXCEPT.     {A = TK_EXCEPT;}
17582c3d636Sdrh oneselect(A) ::= SELECT distinct(D) selcollist(W) from(X) where_opt(Y)
1762282792aSdrh                  groupby_opt(P) having_opt(Q) orderby_opt(Z). {
1772282792aSdrh   A = sqliteSelectNew(W,X,Y,P,Q,Z,D);
1789bb61fe7Sdrh }
1799bb61fe7Sdrh 
1809bb61fe7Sdrh // The "distinct" nonterminal is true (1) if the DISTINCT keyword is
1819bb61fe7Sdrh // present and false (0) if it is not.
1829bb61fe7Sdrh //
183efb7251dSdrh %type distinct {int}
184efb7251dSdrh distinct(A) ::= DISTINCT.   {A = 1;}
185fef5208cSdrh distinct(A) ::= ALL.        {A = 0;}
186efb7251dSdrh distinct(A) ::= .           {A = 0;}
187348784efSdrh 
1889bb61fe7Sdrh // selcollist is a list of expressions that are to become the return
1899bb61fe7Sdrh // values of the SELECT statement.  In the case of "SELECT * FROM ..."
1909bb61fe7Sdrh // the selcollist value is NULL.
1919bb61fe7Sdrh //
192348784efSdrh %type selcollist {ExprList*}
193348784efSdrh %destructor selcollist {sqliteExprListDelete($$);}
194348784efSdrh %type sclp {ExprList*}
195348784efSdrh %destructor sclp {sqliteExprListDelete($$);}
196348784efSdrh sclp(A) ::= selcollist(X) COMMA.             {A = X;}
197348784efSdrh sclp(A) ::= .                                {A = 0;}
1989bb61fe7Sdrh selcollist(A) ::= STAR.                      {A = 0;}
199348784efSdrh selcollist(A) ::= sclp(P) expr(X).           {A = sqliteExprListAppend(P,X,0);}
200c4a3c779Sdrh selcollist(A) ::= sclp(P) expr(X) as ids(Y). {A = sqliteExprListAppend(P,X,&Y);}
2019bb61fe7Sdrh as ::= .
2029bb61fe7Sdrh as ::= AS.
2039bb61fe7Sdrh 
204348784efSdrh 
205348784efSdrh %type seltablist {IdList*}
206348784efSdrh %destructor seltablist {sqliteIdListDelete($$);}
207348784efSdrh %type stl_prefix {IdList*}
208348784efSdrh %destructor stl_prefix {sqliteIdListDelete($$);}
209348784efSdrh %type from {IdList*}
210348784efSdrh %destructor from {sqliteIdListDelete($$);}
211348784efSdrh 
212348784efSdrh from(A) ::= FROM seltablist(X).               {A = X;}
213348784efSdrh stl_prefix(A) ::= seltablist(X) COMMA.        {A = X;}
214348784efSdrh stl_prefix(A) ::= .                           {A = 0;}
215c4a3c779Sdrh seltablist(A) ::= stl_prefix(X) ids(Y).       {A = sqliteIdListAppend(X,&Y);}
216c4a3c779Sdrh seltablist(A) ::= stl_prefix(X) ids(Y) as ids(Z). {
217c4a3c779Sdrh   A = sqliteIdListAppend(X,&Y);
218c4a3c779Sdrh   sqliteIdListAddAlias(A,&Z);
219c4a3c779Sdrh }
220348784efSdrh 
221348784efSdrh %type orderby_opt {ExprList*}
222348784efSdrh %destructor orderby_opt {sqliteExprListDelete($$);}
223348784efSdrh %type sortlist {ExprList*}
224348784efSdrh %destructor sortlist {sqliteExprListDelete($$);}
225348784efSdrh %type sortitem {Expr*}
226348784efSdrh %destructor sortitem {sqliteExprDelete($$);}
227348784efSdrh 
228348784efSdrh orderby_opt(A) ::= .                          {A = 0;}
229348784efSdrh orderby_opt(A) ::= ORDER BY sortlist(X).      {A = X;}
2309bb61fe7Sdrh sortlist(A) ::= sortlist(X) COMMA sortitem(Y) sortorder(Z). {
231348784efSdrh   A = sqliteExprListAppend(X,Y,0);
232daffd0e5Sdrh   if( A ) A->a[A->nExpr-1].sortOrder = Z;  /* 0=ascending, 1=decending */
233348784efSdrh }
2349bb61fe7Sdrh sortlist(A) ::= sortitem(Y) sortorder(Z). {
235348784efSdrh   A = sqliteExprListAppend(0,Y,0);
236daffd0e5Sdrh   if( A ) A->a[0].sortOrder = Z;
237348784efSdrh }
238da9d6c45Sdrh sortitem(A) ::= expr(X).   {A = X;}
239348784efSdrh 
240348784efSdrh %type sortorder {int}
241348784efSdrh 
242348784efSdrh sortorder(A) ::= ASC.      {A = 0;}
243348784efSdrh sortorder(A) ::= DESC.     {A = 1;}
244348784efSdrh sortorder(A) ::= .         {A = 0;}
245348784efSdrh 
2462282792aSdrh %type groupby_opt {ExprList*}
2472282792aSdrh %destructor groupby_opt {sqliteExprListDelete($$);}
2482282792aSdrh groupby_opt(A) ::= .                      {A = 0;}
2492282792aSdrh groupby_opt(A) ::= GROUP BY exprlist(X).  {A = X;}
2502282792aSdrh 
2512282792aSdrh %type having_opt {Expr*}
2522282792aSdrh %destructor having_opt {sqliteExprDelete($$);}
2532282792aSdrh having_opt(A) ::= .                {A = 0;}
2542282792aSdrh having_opt(A) ::= HAVING expr(X).  {A = X;}
2552282792aSdrh 
25682c3d636Sdrh 
257c4a3c779Sdrh cmd ::= DELETE FROM ids(X) where_opt(Y).
258348784efSdrh     {sqliteDeleteFrom(pParse, &X, Y);}
259348784efSdrh 
260348784efSdrh %type where_opt {Expr*}
261348784efSdrh %destructor where_opt {sqliteExprDelete($$);}
262348784efSdrh 
263348784efSdrh where_opt(A) ::= .                    {A = 0;}
264348784efSdrh where_opt(A) ::= WHERE expr(X).       {A = X;}
265348784efSdrh 
266348784efSdrh %type setlist {ExprList*}
267348784efSdrh %destructor setlist {sqliteExprListDelete($$);}
268348784efSdrh 
269c4a3c779Sdrh cmd ::= UPDATE ids(X) SET setlist(Y) where_opt(Z).
270348784efSdrh     {sqliteUpdate(pParse,&X,Y,Z);}
271348784efSdrh 
272c4a3c779Sdrh setlist(A) ::= setlist(Z) COMMA ids(X) EQ expr(Y).
273348784efSdrh     {A = sqliteExprListAppend(Z,Y,&X);}
274c4a3c779Sdrh setlist(A) ::= ids(X) EQ expr(Y).   {A = sqliteExprListAppend(0,Y,&X);}
275348784efSdrh 
276c4a3c779Sdrh cmd ::= INSERT INTO ids(X) inscollist_opt(F) VALUES LP itemlist(Y) RP.
2775974a30fSdrh                {sqliteInsert(pParse, &X, Y, 0, F);}
278c4a3c779Sdrh cmd ::= INSERT INTO ids(X) inscollist_opt(F) select(S).
2795974a30fSdrh                {sqliteInsert(pParse, &X, 0, S, F);}
280348784efSdrh 
281348784efSdrh 
282348784efSdrh %type itemlist {ExprList*}
283348784efSdrh %destructor itemlist {sqliteExprListDelete($$);}
284348784efSdrh %type item {Expr*}
285348784efSdrh %destructor item {sqliteExprDelete($$);}
286348784efSdrh 
287348784efSdrh itemlist(A) ::= itemlist(X) COMMA item(Y).  {A = sqliteExprListAppend(X,Y,0);}
288348784efSdrh itemlist(A) ::= item(X).     {A = sqliteExprListAppend(0,X,0);}
289348784efSdrh item(A) ::= INTEGER(X).      {A = sqliteExpr(TK_INTEGER, 0, 0, &X);}
2907020f651Sdrh item(A) ::= PLUS INTEGER(X). {A = sqliteExpr(TK_INTEGER, 0, 0, &X);}
2917020f651Sdrh item(A) ::= MINUS INTEGER(X). {
2926e142f54Sdrh   A = sqliteExpr(TK_UMINUS, 0, 0, 0);
293daffd0e5Sdrh   if( A ) A->pLeft = sqliteExpr(TK_INTEGER, 0, 0, &X);
2947020f651Sdrh }
295348784efSdrh item(A) ::= FLOAT(X).        {A = sqliteExpr(TK_FLOAT, 0, 0, &X);}
2967020f651Sdrh item(A) ::= PLUS FLOAT(X).   {A = sqliteExpr(TK_FLOAT, 0, 0, &X);}
2977020f651Sdrh item(A) ::= MINUS FLOAT(X).  {
2986e142f54Sdrh   A = sqliteExpr(TK_UMINUS, 0, 0, 0);
299daffd0e5Sdrh   if( A ) A->pLeft = sqliteExpr(TK_FLOAT, 0, 0, &X);
3007020f651Sdrh }
301348784efSdrh item(A) ::= STRING(X).       {A = sqliteExpr(TK_STRING, 0, 0, &X);}
3028be51133Sdrh item(A) ::= NULL.            {A = sqliteExpr(TK_NULL, 0, 0, 0);}
303348784efSdrh 
304967e8b73Sdrh %type inscollist_opt {IdList*}
305967e8b73Sdrh %destructor inscollist_opt {sqliteIdListDelete($$);}
306967e8b73Sdrh %type inscollist {IdList*}
307967e8b73Sdrh %destructor inscollist {sqliteIdListDelete($$);}
308348784efSdrh 
309967e8b73Sdrh inscollist_opt(A) ::= .                       {A = 0;}
310967e8b73Sdrh inscollist_opt(A) ::= LP inscollist(X) RP.    {A = X;}
311c4a3c779Sdrh inscollist(A) ::= inscollist(X) COMMA ids(Y). {A = sqliteIdListAppend(X,&Y);}
312c4a3c779Sdrh inscollist(A) ::= ids(Y).                     {A = sqliteIdListAppend(0,&Y);}
313348784efSdrh 
314348784efSdrh %left OR.
315348784efSdrh %left AND.
3168be51133Sdrh %right NOT.
317fef5208cSdrh %left EQ NE ISNULL NOTNULL IS LIKE GLOB BETWEEN IN.
318348784efSdrh %left GT GE LT LE.
319348784efSdrh %left PLUS MINUS.
32031884b0bSdrh %left STAR SLASH.
3210040077dSdrh %left CONCAT.
3228be51133Sdrh %right UMINUS.
323348784efSdrh 
324348784efSdrh %type expr {Expr*}
325348784efSdrh %destructor expr {sqliteExprDelete($$);}
326348784efSdrh 
327e1b6a5b8Sdrh expr(A) ::= LP(B) expr(X) RP(E). {A = X; sqliteExprSpan(A,&B,&E);}
328e1b6a5b8Sdrh expr(A) ::= NULL(X).             {A = sqliteExpr(TK_NULL, 0, 0, &X);}
329c4a3c779Sdrh expr(A) ::= id(X).               {A = sqliteExpr(TK_ID, 0, 0, &X);}
330c4a3c779Sdrh expr(A) ::= ids(X) DOT ids(Y). {
331e1b6a5b8Sdrh   Expr *temp1 = sqliteExpr(TK_ID, 0, 0, &X);
332348784efSdrh   Expr *temp2 = sqliteExpr(TK_ID, 0, 0, &Y);
333e1b6a5b8Sdrh   A = sqliteExpr(TK_DOT, temp1, temp2, 0);
334e1b6a5b8Sdrh }
335348784efSdrh expr(A) ::= INTEGER(X).      {A = sqliteExpr(TK_INTEGER, 0, 0, &X);}
336348784efSdrh expr(A) ::= FLOAT(X).        {A = sqliteExpr(TK_FLOAT, 0, 0, &X);}
337348784efSdrh expr(A) ::= STRING(X).       {A = sqliteExpr(TK_STRING, 0, 0, &X);}
338e1b6a5b8Sdrh expr(A) ::= ID(X) LP exprlist(Y) RP(E). {
339e1b6a5b8Sdrh   A = sqliteExprFunction(Y, &X);
340e1b6a5b8Sdrh   sqliteExprSpan(A,&X,&E);
341e1b6a5b8Sdrh }
342e1b6a5b8Sdrh expr(A) ::= ID(X) LP STAR RP(E). {
343e1b6a5b8Sdrh   A = sqliteExprFunction(0, &X);
344e1b6a5b8Sdrh   sqliteExprSpan(A,&X,&E);
345e1b6a5b8Sdrh }
346348784efSdrh expr(A) ::= expr(X) AND expr(Y).   {A = sqliteExpr(TK_AND, X, Y, 0);}
347348784efSdrh expr(A) ::= expr(X) OR expr(Y).    {A = sqliteExpr(TK_OR, X, Y, 0);}
348348784efSdrh expr(A) ::= expr(X) LT expr(Y).    {A = sqliteExpr(TK_LT, X, Y, 0);}
349348784efSdrh expr(A) ::= expr(X) GT expr(Y).    {A = sqliteExpr(TK_GT, X, Y, 0);}
350348784efSdrh expr(A) ::= expr(X) LE expr(Y).    {A = sqliteExpr(TK_LE, X, Y, 0);}
351348784efSdrh expr(A) ::= expr(X) GE expr(Y).    {A = sqliteExpr(TK_GE, X, Y, 0);}
352348784efSdrh expr(A) ::= expr(X) NE expr(Y).    {A = sqliteExpr(TK_NE, X, Y, 0);}
353348784efSdrh expr(A) ::= expr(X) EQ expr(Y).    {A = sqliteExpr(TK_EQ, X, Y, 0);}
354dce2cbe6Sdrh expr(A) ::= expr(X) LIKE expr(Y).  {A = sqliteExpr(TK_LIKE, X, Y, 0);}
3554794b980Sdrh expr(A) ::= expr(X) NOT LIKE expr(Y).  {
3564794b980Sdrh   A = sqliteExpr(TK_LIKE, X, Y, 0);
3574794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
358e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&Y->span);
3594794b980Sdrh }
360dce2cbe6Sdrh expr(A) ::= expr(X) GLOB expr(Y).  {A = sqliteExpr(TK_GLOB,X,Y,0);}
3614794b980Sdrh expr(A) ::= expr(X) NOT GLOB expr(Y).  {
3624794b980Sdrh   A = sqliteExpr(TK_GLOB, X, Y, 0);
3634794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
364e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&Y->span);
3654794b980Sdrh }
366348784efSdrh expr(A) ::= expr(X) PLUS expr(Y).  {A = sqliteExpr(TK_PLUS, X, Y, 0);}
367348784efSdrh expr(A) ::= expr(X) MINUS expr(Y). {A = sqliteExpr(TK_MINUS, X, Y, 0);}
368348784efSdrh expr(A) ::= expr(X) STAR expr(Y).  {A = sqliteExpr(TK_STAR, X, Y, 0);}
369348784efSdrh expr(A) ::= expr(X) SLASH expr(Y). {A = sqliteExpr(TK_SLASH, X, Y, 0);}
3700040077dSdrh expr(A) ::= expr(X) CONCAT expr(Y). {A = sqliteExpr(TK_CONCAT, X, Y, 0);}
371e1b6a5b8Sdrh expr(A) ::= expr(X) ISNULL(E). {
372e1b6a5b8Sdrh   A = sqliteExpr(TK_ISNULL, X, 0, 0);
373e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
374e1b6a5b8Sdrh }
375e1b6a5b8Sdrh expr(A) ::= expr(X) NOTNULL(E). {
376e1b6a5b8Sdrh   A = sqliteExpr(TK_NOTNULL, X, 0, 0);
377e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
378e1b6a5b8Sdrh }
379e1b6a5b8Sdrh expr(A) ::= NOT(B) expr(X). {
380e1b6a5b8Sdrh   A = sqliteExpr(TK_NOT, X, 0, 0);
381e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&X->span);
382e1b6a5b8Sdrh }
383e1b6a5b8Sdrh expr(A) ::= MINUS(B) expr(X). [UMINUS] {
384e1b6a5b8Sdrh   A = sqliteExpr(TK_UMINUS, X, 0, 0);
385e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&X->span);
386e1b6a5b8Sdrh }
387e1b6a5b8Sdrh expr(A) ::= PLUS(B) expr(X). [UMINUS] {
388e1b6a5b8Sdrh   A = X;
389e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&X->span);
390e1b6a5b8Sdrh }
391e1b6a5b8Sdrh expr(A) ::= LP(B) select(X) RP(E). {
39219a775c2Sdrh   A = sqliteExpr(TK_SELECT, 0, 0, 0);
393daffd0e5Sdrh   if( A ) A->pSelect = X;
394e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&E);
39519a775c2Sdrh }
396fef5208cSdrh expr(A) ::= expr(W) BETWEEN expr(X) AND expr(Y). {
397fef5208cSdrh   ExprList *pList = sqliteExprListAppend(0, X, 0);
398fef5208cSdrh   pList = sqliteExprListAppend(pList, Y, 0);
399fef5208cSdrh   A = sqliteExpr(TK_BETWEEN, W, 0, 0);
400daffd0e5Sdrh   if( A ) A->pList = pList;
401e1b6a5b8Sdrh   sqliteExprSpan(A,&W->span,&Y->span);
402fef5208cSdrh }
4034794b980Sdrh expr(A) ::= expr(W) NOT BETWEEN expr(X) AND expr(Y). {
4044794b980Sdrh   ExprList *pList = sqliteExprListAppend(0, X, 0);
4054794b980Sdrh   pList = sqliteExprListAppend(pList, Y, 0);
4064794b980Sdrh   A = sqliteExpr(TK_BETWEEN, W, 0, 0);
407daffd0e5Sdrh   if( A ) A->pList = pList;
4084794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
409e1b6a5b8Sdrh   sqliteExprSpan(A,&W->span,&Y->span);
4104794b980Sdrh }
411e1b6a5b8Sdrh expr(A) ::= expr(X) IN LP exprlist(Y) RP(E).  {
412fef5208cSdrh   A = sqliteExpr(TK_IN, X, 0, 0);
413daffd0e5Sdrh   if( A ) A->pList = Y;
414e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
415fef5208cSdrh }
416e1b6a5b8Sdrh expr(A) ::= expr(X) IN LP select(Y) RP(E).  {
417fef5208cSdrh   A = sqliteExpr(TK_IN, X, 0, 0);
418daffd0e5Sdrh   if( A ) A->pSelect = Y;
419e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
420fef5208cSdrh }
421e1b6a5b8Sdrh expr(A) ::= expr(X) NOT IN LP exprlist(Y) RP(E).  {
4224794b980Sdrh   A = sqliteExpr(TK_IN, X, 0, 0);
423daffd0e5Sdrh   if( A ) A->pList = Y;
4244794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
425e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
4264794b980Sdrh }
427e1b6a5b8Sdrh expr(A) ::= expr(X) NOT IN LP select(Y) RP(E).  {
4284794b980Sdrh   A = sqliteExpr(TK_IN, X, 0, 0);
429daffd0e5Sdrh   if( A ) A->pSelect = Y;
4304794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
431e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
4324794b980Sdrh }
433fef5208cSdrh 
434fef5208cSdrh 
435348784efSdrh 
436348784efSdrh %type exprlist {ExprList*}
437348784efSdrh %destructor exprlist {sqliteExprListDelete($$);}
438348784efSdrh %type expritem {Expr*}
439348784efSdrh %destructor expritem {sqliteExprDelete($$);}
440348784efSdrh 
441348784efSdrh exprlist(A) ::= exprlist(X) COMMA expritem(Y).
442348784efSdrh    {A = sqliteExprListAppend(X,Y,0);}
443348784efSdrh exprlist(A) ::= expritem(X).            {A = sqliteExprListAppend(0,X,0);}
444348784efSdrh expritem(A) ::= expr(X).                {A = X;}
445348784efSdrh expritem(A) ::= .                       {A = 0;}
446cce7d176Sdrh 
447348784efSdrh 
448717e6402Sdrh cmd ::= CREATE(S) uniqueflag(U) INDEX ids(X) ON ids(Y) LP idxlist(Z) RP(E).
449717e6402Sdrh     {sqliteCreateIndex(pParse, &X, &Y, Z, U, &S, &E);}
450717e6402Sdrh 
451717e6402Sdrh %type uniqueflag {int}
452717e6402Sdrh uniqueflag(A) ::= UNIQUE.   { A = 1; }
453717e6402Sdrh uniqueflag(A) ::= .         { A = 0; }
454348784efSdrh 
455348784efSdrh %type idxlist {IdList*}
456348784efSdrh %destructor idxlist {sqliteIdListDelete($$);}
457348784efSdrh %type idxitem {Token}
458348784efSdrh 
459348784efSdrh idxlist(A) ::= idxlist(X) COMMA idxitem(Y).
460348784efSdrh      {A = sqliteIdListAppend(X,&Y);}
461348784efSdrh idxlist(A) ::= idxitem(Y).
462348784efSdrh      {A = sqliteIdListAppend(0,&Y);}
463c4a3c779Sdrh idxitem(A) ::= ids(X).          {A = X;}
464348784efSdrh 
465c4a3c779Sdrh cmd ::= DROP INDEX ids(X).      {sqliteDropIndex(pParse, &X);}
466982cef7eSdrh 
467c4a3c779Sdrh cmd ::= COPY ids(X) FROM ids(Y) USING DELIMITERS STRING(Z).
468982cef7eSdrh     {sqliteCopy(pParse,&X,&Y,&Z);}
469c4a3c779Sdrh cmd ::= COPY ids(X) FROM ids(Y).
470982cef7eSdrh     {sqliteCopy(pParse,&X,&Y,0);}
471dce2cbe6Sdrh 
472dce2cbe6Sdrh cmd ::= VACUUM.                {sqliteVacuum(pParse,0);}
473c4a3c779Sdrh cmd ::= VACUUM ids(X).         {sqliteVacuum(pParse,&X);}
474f57b14a6Sdrh 
475f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ ids(Y).         {sqlitePragma(pParse,&X,&Y,0);}
476f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ ON(Y).          {sqlitePragma(pParse,&X,&Y,0);}
477f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ plus_num(Y).    {sqlitePragma(pParse,&X,&Y,0);}
478f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ minus_num(Y).   {sqlitePragma(pParse,&X,&Y,1);}
479f57b14a6Sdrh plus_num(A) ::= plus_opt number(X).   {A = X;}
480f57b14a6Sdrh minus_num(A) ::= MINUS number(X).     {A = X;}
481f57b14a6Sdrh number(A) ::= INTEGER(X).  {A = X;}
482f57b14a6Sdrh number(A) ::= FLOAT(X).    {A = X;}
483f57b14a6Sdrh plus_opt ::= PLUS.
484f57b14a6Sdrh plus_opt ::= .
485