xref: /sqlite-3.40.0/src/parse.y (revision 4ff6dfa7)
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*4ff6dfa7Sdrh ** @(#) $Id: parse.y,v 1.55 2002/03/03 23:06:01 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"
319bbca4c1Sdrh 
329bbca4c1Sdrh /*
339bbca4c1Sdrh ** A structure for holding two integers
349bbca4c1Sdrh */
359bbca4c1Sdrh struct twoint { int a,b; };
36348784efSdrh }
37348784efSdrh 
38348784efSdrh // These are extra tokens used by the lexer but never seen by the
39348784efSdrh // parser.  We put them in a rule so that the parser generator will
406206d50aSdrh // add them to the parse.h output file.
41348784efSdrh //
42c4a3c779Sdrh %nonassoc END_OF_FILE ILLEGAL SPACE UNCLOSED_STRING COMMENT FUNCTION
43c4a3c779Sdrh           COLUMN AGG_FUNCTION.
44c4a3c779Sdrh 
45c4a3c779Sdrh // Input is zero or more commands.
46c4a3c779Sdrh input ::= cmdlist.
47348784efSdrh 
48348784efSdrh // A list of commands is zero or more commands
49348784efSdrh //
50348784efSdrh cmdlist ::= ecmd.
51348784efSdrh cmdlist ::= cmdlist SEMI ecmd.
52348784efSdrh ecmd ::= explain cmd.  {sqliteExec(pParse);}
53348784efSdrh ecmd ::= cmd.          {sqliteExec(pParse);}
54348784efSdrh ecmd ::= .
55348784efSdrh explain ::= EXPLAIN.    {pParse->explain = 1;}
56348784efSdrh 
57382c0247Sdrh ///////////////////// Begin and end transactions. ////////////////////////////
58c4a3c779Sdrh //
59fa86c412Sdrh 
600d65dc0eSdrh cmd ::= BEGIN trans_opt onconf(R).  {sqliteBeginTransaction(pParse,R);}
61c4a3c779Sdrh trans_opt ::= .
62c4a3c779Sdrh trans_opt ::= TRANSACTION.
63c4a3c779Sdrh trans_opt ::= TRANSACTION ids.
64c4a3c779Sdrh cmd ::= COMMIT trans_opt.      {sqliteCommitTransaction(pParse);}
65c4a3c779Sdrh cmd ::= END trans_opt.         {sqliteCommitTransaction(pParse);}
66c4a3c779Sdrh cmd ::= ROLLBACK trans_opt.    {sqliteRollbackTransaction(pParse);}
67c4a3c779Sdrh 
68382c0247Sdrh ///////////////////// The CREATE TABLE statement ////////////////////////////
69348784efSdrh //
70348784efSdrh cmd ::= create_table create_table_args.
71969fa7c1Sdrh create_table ::= CREATE(X) temp(T) TABLE ids(Y). {
72969fa7c1Sdrh    sqliteStartTable(pParse,&X,&Y,T);
73969fa7c1Sdrh }
74f57b3399Sdrh %type temp {int}
75f57b3399Sdrh temp(A) ::= TEMP.  {A = 1;}
76f57b3399Sdrh temp(A) ::= .      {A = 0;}
77969fa7c1Sdrh create_table_args ::= LP columnlist conslist_opt RP(X). {
78969fa7c1Sdrh   sqliteEndTable(pParse,&X,0);
79969fa7c1Sdrh }
80969fa7c1Sdrh create_table_args ::= AS select(S). {
81969fa7c1Sdrh   sqliteEndTable(pParse,0,S);
82969fa7c1Sdrh   sqliteSelectDelete(S);
83969fa7c1Sdrh }
84348784efSdrh columnlist ::= columnlist COMMA column.
85348784efSdrh columnlist ::= column.
86348784efSdrh 
87348784efSdrh // About the only information used for a column is the name of the
88348784efSdrh // column.  The type is always just "text".  But the code will accept
89348784efSdrh // an elaborate typename.  Perhaps someday we'll do something with it.
90348784efSdrh //
91348784efSdrh column ::= columnid type carglist.
92c4a3c779Sdrh columnid ::= ids(X).                {sqliteAddColumn(pParse,&X);}
93c4a3c779Sdrh 
94c4a3c779Sdrh // An IDENTIFIER can be a generic identifier, or one of several
95c4a3c779Sdrh // keywords.  Any non-standard keyword can also be an identifier.
96382c0247Sdrh // We also make DESC and identifier since it comes up so often (as
97382c0247Sdrh // an abbreviation of "description").
98c4a3c779Sdrh //
99982cef7eSdrh %type id {Token}
100c4a3c779Sdrh id(A) ::= DESC(X).       {A = X;}
101c4a3c779Sdrh id(A) ::= ASC(X).        {A = X;}
102c4a3c779Sdrh id(A) ::= DELIMITERS(X). {A = X;}
103c4a3c779Sdrh id(A) ::= EXPLAIN(X).    {A = X;}
104c4a3c779Sdrh id(A) ::= VACUUM(X).     {A = X;}
105c4a3c779Sdrh id(A) ::= BEGIN(X).      {A = X;}
106c4a3c779Sdrh id(A) ::= END(X).        {A = X;}
107f57b14a6Sdrh id(A) ::= PRAGMA(X).     {A = X;}
108f57b14a6Sdrh id(A) ::= CLUSTER(X).    {A = X;}
109982cef7eSdrh id(A) ::= ID(X).         {A = X;}
110f57b3399Sdrh id(A) ::= TEMP(X).       {A = X;}
1119bbca4c1Sdrh id(A) ::= OFFSET(X).     {A = X;}
112aacc543eSdrh id(A) ::= KEY(X).        {A = X;}
1139cfcf5d4Sdrh id(A) ::= ABORT(X).      {A = X;}
1149cfcf5d4Sdrh id(A) ::= IGNORE(X).     {A = X;}
1159cfcf5d4Sdrh id(A) ::= REPLACE(X).    {A = X;}
1161c92853dSdrh id(A) ::= FAIL(X).       {A = X;}
1179cfcf5d4Sdrh id(A) ::= CONFLICT(X).   {A = X;}
118c4a3c779Sdrh 
119c4a3c779Sdrh // And "ids" is an identifer-or-string.
120c4a3c779Sdrh //
121c4a3c779Sdrh %type ids {Token}
122c4a3c779Sdrh ids(A) ::= id(X).        {A = X;}
123c4a3c779Sdrh ids(A) ::= STRING(X).    {A = X;}
124c4a3c779Sdrh 
125382c0247Sdrh type ::= .
126382c0247Sdrh type ::= typename(X).                    {sqliteAddColumnType(pParse,&X,&X);}
127382c0247Sdrh type ::= typename(X) LP signed RP(Y).    {sqliteAddColumnType(pParse,&X,&Y);}
128382c0247Sdrh type ::= typename(X) LP signed COMMA signed RP(Y).
129382c0247Sdrh                                          {sqliteAddColumnType(pParse,&X,&Y);}
130382c0247Sdrh %type typename {Token}
131382c0247Sdrh typename(A) ::= ids(X).           {A = X;}
132382c0247Sdrh typename(A) ::= typename(X) ids.  {A = X;}
133348784efSdrh signed ::= INTEGER.
134348784efSdrh signed ::= PLUS INTEGER.
135348784efSdrh signed ::= MINUS INTEGER.
136348784efSdrh carglist ::= carglist carg.
137348784efSdrh carglist ::= .
138c4a3c779Sdrh carg ::= CONSTRAINT ids ccons.
139348784efSdrh carg ::= ccons.
1407020f651Sdrh carg ::= DEFAULT STRING(X).          {sqliteAddDefaultValue(pParse,&X,0);}
1417020f651Sdrh carg ::= DEFAULT ID(X).              {sqliteAddDefaultValue(pParse,&X,0);}
1427020f651Sdrh carg ::= DEFAULT INTEGER(X).         {sqliteAddDefaultValue(pParse,&X,0);}
1437020f651Sdrh carg ::= DEFAULT PLUS INTEGER(X).    {sqliteAddDefaultValue(pParse,&X,0);}
1447020f651Sdrh carg ::= DEFAULT MINUS INTEGER(X).   {sqliteAddDefaultValue(pParse,&X,1);}
1457020f651Sdrh carg ::= DEFAULT FLOAT(X).           {sqliteAddDefaultValue(pParse,&X,0);}
1467020f651Sdrh carg ::= DEFAULT PLUS FLOAT(X).      {sqliteAddDefaultValue(pParse,&X,0);}
1477020f651Sdrh carg ::= DEFAULT MINUS FLOAT(X).     {sqliteAddDefaultValue(pParse,&X,1);}
1487020f651Sdrh carg ::= DEFAULT NULL.
149348784efSdrh 
150382c0247Sdrh // In addition to the type name, we also care about the primary key and
151382c0247Sdrh // UNIQUE constraints.
152348784efSdrh //
1539cfcf5d4Sdrh ccons ::= NOT NULL onconf(R).               {sqliteAddNotNull(pParse, R);}
1549cfcf5d4Sdrh ccons ::= PRIMARY KEY sortorder onconf(R).  {sqliteAddPrimaryKey(pParse,0,R);}
1559cfcf5d4Sdrh ccons ::= UNIQUE onconf(R).            {sqliteCreateIndex(pParse,0,0,0,R,0,0);}
1569cfcf5d4Sdrh ccons ::= CHECK LP expr RP onconf.
157348784efSdrh 
158348784efSdrh // For the time being, the only constraint we care about is the primary
159382c0247Sdrh // key and UNIQUE.  Both create indices.
160348784efSdrh //
161348784efSdrh conslist_opt ::= .
162348784efSdrh conslist_opt ::= COMMA conslist.
163348784efSdrh conslist ::= conslist COMMA tcons.
164a2e1bb5aSdrh conslist ::= conslist tcons.
165348784efSdrh conslist ::= tcons.
166c4a3c779Sdrh tcons ::= CONSTRAINT ids.
1679cfcf5d4Sdrh tcons ::= PRIMARY KEY LP idxlist(X) RP onconf(R).
1689cfcf5d4Sdrh                                              {sqliteAddPrimaryKey(pParse,X,R);}
1699cfcf5d4Sdrh tcons ::= UNIQUE LP idxlist(X) RP onconf(R).
1709cfcf5d4Sdrh                                        {sqliteCreateIndex(pParse,0,0,X,R,0,0);}
1719cfcf5d4Sdrh tcons ::= CHECK expr onconf.
1729cfcf5d4Sdrh 
1739cfcf5d4Sdrh // The following is a non-standard extension that allows us to declare the
1749cfcf5d4Sdrh // default behavior when there is a constraint conflict.
1759cfcf5d4Sdrh //
1769cfcf5d4Sdrh %type onconf {int}
1771c92853dSdrh %type orconf {int}
1781c92853dSdrh %type resolvetype {int}
1791c92853dSdrh onconf(A) ::= .                              { A = OE_Default; }
1801c92853dSdrh onconf(A) ::= ON CONFLICT resolvetype(X).    { A = X; }
1811c92853dSdrh orconf(A) ::= .                              { A = OE_Default; }
1821c92853dSdrh orconf(A) ::= OR resolvetype(X).             { A = X; }
1831c92853dSdrh resolvetype(A) ::= ROLLBACK.                 { A = OE_Rollback; }
1841c92853dSdrh resolvetype(A) ::= ABORT.                    { A = OE_Abort; }
1851c92853dSdrh resolvetype(A) ::= FAIL.                     { A = OE_Fail; }
1861c92853dSdrh resolvetype(A) ::= IGNORE.                   { A = OE_Ignore; }
1871c92853dSdrh resolvetype(A) ::= REPLACE.                  { A = OE_Replace; }
188348784efSdrh 
189382c0247Sdrh ////////////////////////// The DROP TABLE /////////////////////////////////////
190348784efSdrh //
191*4ff6dfa7Sdrh cmd ::= DROP TABLE ids(X).          {sqliteDropTable(pParse,&X,0);}
192348784efSdrh 
193a76b5dfcSdrh ///////////////////// The CREATE VIEW statement /////////////////////////////
194a76b5dfcSdrh //
195a76b5dfcSdrh cmd ::= CREATE(X) VIEW ids(Y) AS select(S). {
196a76b5dfcSdrh   sqliteCreateView(pParse, &X, &Y, S);
197a76b5dfcSdrh }
198a76b5dfcSdrh cmd ::= DROP VIEW ids(X). {
199*4ff6dfa7Sdrh   sqliteDropTable(pParse, &X, 1);
200a76b5dfcSdrh }
201a76b5dfcSdrh 
202382c0247Sdrh //////////////////////// The SELECT statement /////////////////////////////////
203348784efSdrh //
2049bb61fe7Sdrh cmd ::= select(X).  {
205832508b7Sdrh   sqliteSelect(pParse, X, SRT_Callback, 0, 0, 0, 0);
2069bb61fe7Sdrh   sqliteSelectDelete(X);
2079bb61fe7Sdrh }
208efb7251dSdrh 
2099bb61fe7Sdrh %type select {Select*}
2109bb61fe7Sdrh %destructor select {sqliteSelectDelete($$);}
21182c3d636Sdrh %type oneselect {Select*}
21282c3d636Sdrh %destructor oneselect {sqliteSelectDelete($$);}
2139bb61fe7Sdrh 
21482c3d636Sdrh select(A) ::= oneselect(X).                      {A = X;}
2150a36c57eSdrh select(A) ::= select(X) multiselect_op(Y) oneselect(Z).  {
216daffd0e5Sdrh   if( Z ){
21782c3d636Sdrh     Z->op = Y;
21882c3d636Sdrh     Z->pPrior = X;
219daffd0e5Sdrh   }
22082c3d636Sdrh   A = Z;
22182c3d636Sdrh }
2220a36c57eSdrh %type multiselect_op {int}
2230a36c57eSdrh multiselect_op(A) ::= UNION.      {A = TK_UNION;}
2240a36c57eSdrh multiselect_op(A) ::= UNION ALL.  {A = TK_ALL;}
2250a36c57eSdrh multiselect_op(A) ::= INTERSECT.  {A = TK_INTERSECT;}
2260a36c57eSdrh multiselect_op(A) ::= EXCEPT.     {A = TK_EXCEPT;}
22782c3d636Sdrh oneselect(A) ::= SELECT distinct(D) selcollist(W) from(X) where_opt(Y)
2289bbca4c1Sdrh                  groupby_opt(P) having_opt(Q) orderby_opt(Z) limit_opt(L). {
2299bbca4c1Sdrh   A = sqliteSelectNew(W,X,Y,P,Q,Z,D,L.a,L.b);
2309bb61fe7Sdrh }
2319bb61fe7Sdrh 
2329bb61fe7Sdrh // The "distinct" nonterminal is true (1) if the DISTINCT keyword is
2339bb61fe7Sdrh // present and false (0) if it is not.
2349bb61fe7Sdrh //
235efb7251dSdrh %type distinct {int}
236efb7251dSdrh distinct(A) ::= DISTINCT.   {A = 1;}
237fef5208cSdrh distinct(A) ::= ALL.        {A = 0;}
238efb7251dSdrh distinct(A) ::= .           {A = 0;}
239348784efSdrh 
2409bb61fe7Sdrh // selcollist is a list of expressions that are to become the return
2417c917d19Sdrh // values of the SELECT statement.  The "*" in statements like
2427c917d19Sdrh // "SELECT * FROM ..." is encoded as a special expression with an
2437c917d19Sdrh // opcode of TK_ALL.
2449bb61fe7Sdrh //
245348784efSdrh %type selcollist {ExprList*}
246348784efSdrh %destructor selcollist {sqliteExprListDelete($$);}
247348784efSdrh %type sclp {ExprList*}
248348784efSdrh %destructor sclp {sqliteExprListDelete($$);}
249348784efSdrh sclp(A) ::= selcollist(X) COMMA.             {A = X;}
250348784efSdrh sclp(A) ::= .                                {A = 0;}
251348784efSdrh selcollist(A) ::= sclp(P) expr(X).           {A = sqliteExprListAppend(P,X,0);}
252c4a3c779Sdrh selcollist(A) ::= sclp(P) expr(X) as ids(Y). {A = sqliteExprListAppend(P,X,&Y);}
2537c917d19Sdrh selcollist(A) ::= sclp(P) STAR. {
2547c917d19Sdrh   A = sqliteExprListAppend(P, sqliteExpr(TK_ALL, 0, 0, 0), 0);
2557c917d19Sdrh }
2569bb61fe7Sdrh as ::= .
2579bb61fe7Sdrh as ::= AS.
2589bb61fe7Sdrh 
259348784efSdrh 
260348784efSdrh %type seltablist {IdList*}
261348784efSdrh %destructor seltablist {sqliteIdListDelete($$);}
262348784efSdrh %type stl_prefix {IdList*}
263348784efSdrh %destructor stl_prefix {sqliteIdListDelete($$);}
264348784efSdrh %type from {IdList*}
265348784efSdrh %destructor from {sqliteIdListDelete($$);}
266348784efSdrh 
267348784efSdrh from(A) ::= FROM seltablist(X).               {A = X;}
268348784efSdrh stl_prefix(A) ::= seltablist(X) COMMA.        {A = X;}
269348784efSdrh stl_prefix(A) ::= .                           {A = 0;}
270c4a3c779Sdrh seltablist(A) ::= stl_prefix(X) ids(Y).       {A = sqliteIdListAppend(X,&Y);}
271c4a3c779Sdrh seltablist(A) ::= stl_prefix(X) ids(Y) as ids(Z). {
272c4a3c779Sdrh   A = sqliteIdListAppend(X,&Y);
273c4a3c779Sdrh   sqliteIdListAddAlias(A,&Z);
274c4a3c779Sdrh }
27522f70c32Sdrh seltablist(A) ::= stl_prefix(X) LP select(S) RP. {
27622f70c32Sdrh   A = sqliteIdListAppend(X,0);
27722f70c32Sdrh   A->a[A->nId-1].pSelect = S;
27822f70c32Sdrh }
27922f70c32Sdrh seltablist(A) ::= stl_prefix(X) LP select(S) RP as ids(Z). {
28022f70c32Sdrh   A = sqliteIdListAppend(X,0);
28122f70c32Sdrh   A->a[A->nId-1].pSelect = S;
28222f70c32Sdrh   sqliteIdListAddAlias(A,&Z);
28322f70c32Sdrh }
284348784efSdrh 
285348784efSdrh %type orderby_opt {ExprList*}
286348784efSdrh %destructor orderby_opt {sqliteExprListDelete($$);}
287348784efSdrh %type sortlist {ExprList*}
288348784efSdrh %destructor sortlist {sqliteExprListDelete($$);}
289348784efSdrh %type sortitem {Expr*}
290348784efSdrh %destructor sortitem {sqliteExprDelete($$);}
291348784efSdrh 
292348784efSdrh orderby_opt(A) ::= .                          {A = 0;}
293348784efSdrh orderby_opt(A) ::= ORDER BY sortlist(X).      {A = X;}
2949bb61fe7Sdrh sortlist(A) ::= sortlist(X) COMMA sortitem(Y) sortorder(Z). {
295348784efSdrh   A = sqliteExprListAppend(X,Y,0);
296daffd0e5Sdrh   if( A ) A->a[A->nExpr-1].sortOrder = Z;  /* 0=ascending, 1=decending */
297348784efSdrh }
2989bb61fe7Sdrh sortlist(A) ::= sortitem(Y) sortorder(Z). {
299348784efSdrh   A = sqliteExprListAppend(0,Y,0);
300daffd0e5Sdrh   if( A ) A->a[0].sortOrder = Z;
301348784efSdrh }
302da9d6c45Sdrh sortitem(A) ::= expr(X).   {A = X;}
303348784efSdrh 
304348784efSdrh %type sortorder {int}
305348784efSdrh 
306348784efSdrh sortorder(A) ::= ASC.      {A = 0;}
307348784efSdrh sortorder(A) ::= DESC.     {A = 1;}
308348784efSdrh sortorder(A) ::= .         {A = 0;}
309348784efSdrh 
3102282792aSdrh %type groupby_opt {ExprList*}
3112282792aSdrh %destructor groupby_opt {sqliteExprListDelete($$);}
3122282792aSdrh groupby_opt(A) ::= .                      {A = 0;}
3132282792aSdrh groupby_opt(A) ::= GROUP BY exprlist(X).  {A = X;}
3142282792aSdrh 
3152282792aSdrh %type having_opt {Expr*}
3162282792aSdrh %destructor having_opt {sqliteExprDelete($$);}
3172282792aSdrh having_opt(A) ::= .                {A = 0;}
3182282792aSdrh having_opt(A) ::= HAVING expr(X).  {A = X;}
3192282792aSdrh 
3209bbca4c1Sdrh %type limit_opt {struct twoint}
3219bbca4c1Sdrh limit_opt(A) ::= .                  {A.a = -1; A.b = 0;}
3229bbca4c1Sdrh limit_opt(A) ::= LIMIT INTEGER(X).  {A.a = atoi(X.z); A.b = 0;}
3239bbca4c1Sdrh limit_opt(A) ::= LIMIT INTEGER(X) limit_sep INTEGER(Y).
3249bbca4c1Sdrh                                     {A.a = atoi(X.z); A.b = atoi(Y.z);}
3259bbca4c1Sdrh limit_sep ::= OFFSET.
3269bbca4c1Sdrh limit_sep ::= COMMA.
3279bbca4c1Sdrh 
328382c0247Sdrh /////////////////////////// The DELETE statement /////////////////////////////
329382c0247Sdrh //
330c4a3c779Sdrh cmd ::= DELETE FROM ids(X) where_opt(Y).
331348784efSdrh     {sqliteDeleteFrom(pParse, &X, Y);}
332348784efSdrh 
333348784efSdrh %type where_opt {Expr*}
334348784efSdrh %destructor where_opt {sqliteExprDelete($$);}
335348784efSdrh 
336348784efSdrh where_opt(A) ::= .                    {A = 0;}
337348784efSdrh where_opt(A) ::= WHERE expr(X).       {A = X;}
338348784efSdrh 
339348784efSdrh %type setlist {ExprList*}
340348784efSdrh %destructor setlist {sqliteExprListDelete($$);}
341348784efSdrh 
342382c0247Sdrh ////////////////////////// The UPDATE command ////////////////////////////////
343382c0247Sdrh //
3441c92853dSdrh cmd ::= UPDATE orconf(R) ids(X) SET setlist(Y) where_opt(Z).
3459cfcf5d4Sdrh     {sqliteUpdate(pParse,&X,Y,Z,R);}
346348784efSdrh 
347c4a3c779Sdrh setlist(A) ::= setlist(Z) COMMA ids(X) EQ expr(Y).
348348784efSdrh     {A = sqliteExprListAppend(Z,Y,&X);}
349c4a3c779Sdrh setlist(A) ::= ids(X) EQ expr(Y).   {A = sqliteExprListAppend(0,Y,&X);}
350348784efSdrh 
351382c0247Sdrh ////////////////////////// The INSERT command /////////////////////////////////
352382c0247Sdrh //
353fa86c412Sdrh cmd ::= insert_cmd(R) INTO ids(X) inscollist_opt(F) VALUES LP itemlist(Y) RP.
3549cfcf5d4Sdrh                {sqliteInsert(pParse, &X, Y, 0, F, R);}
355fa86c412Sdrh cmd ::= insert_cmd(R) INTO ids(X) inscollist_opt(F) select(S).
3569cfcf5d4Sdrh                {sqliteInsert(pParse, &X, 0, S, F, R);}
357348784efSdrh 
358fa86c412Sdrh %type insert_cmd {int}
359fa86c412Sdrh insert_cmd(A) ::= INSERT orconf(R).   {A = R;}
360fa86c412Sdrh insert_cmd(A) ::= REPLACE.            {A = OE_Replace;}
361fa86c412Sdrh 
362348784efSdrh 
363348784efSdrh %type itemlist {ExprList*}
364348784efSdrh %destructor itemlist {sqliteExprListDelete($$);}
365348784efSdrh 
366e64e7b20Sdrh itemlist(A) ::= itemlist(X) COMMA expr(Y).  {A = sqliteExprListAppend(X,Y,0);}
367e64e7b20Sdrh itemlist(A) ::= expr(X).                    {A = sqliteExprListAppend(0,X,0);}
368348784efSdrh 
369967e8b73Sdrh %type inscollist_opt {IdList*}
370967e8b73Sdrh %destructor inscollist_opt {sqliteIdListDelete($$);}
371967e8b73Sdrh %type inscollist {IdList*}
372967e8b73Sdrh %destructor inscollist {sqliteIdListDelete($$);}
373348784efSdrh 
374967e8b73Sdrh inscollist_opt(A) ::= .                       {A = 0;}
375967e8b73Sdrh inscollist_opt(A) ::= LP inscollist(X) RP.    {A = X;}
376c4a3c779Sdrh inscollist(A) ::= inscollist(X) COMMA ids(Y). {A = sqliteIdListAppend(X,&Y);}
377c4a3c779Sdrh inscollist(A) ::= ids(Y).                     {A = sqliteIdListAppend(0,&Y);}
378348784efSdrh 
379382c0247Sdrh /////////////////////////// Expression Processing /////////////////////////////
380382c0247Sdrh //
381348784efSdrh %left OR.
382348784efSdrh %left AND.
3838be51133Sdrh %right NOT.
384fef5208cSdrh %left EQ NE ISNULL NOTNULL IS LIKE GLOB BETWEEN IN.
385348784efSdrh %left GT GE LT LE.
38681a20f21Sdrh %left BITAND BITOR LSHIFT RSHIFT.
387348784efSdrh %left PLUS MINUS.
388bf4133cbSdrh %left STAR SLASH REM.
3890040077dSdrh %left CONCAT.
39081a20f21Sdrh %right UMINUS BITNOT.
391348784efSdrh 
392348784efSdrh %type expr {Expr*}
393348784efSdrh %destructor expr {sqliteExprDelete($$);}
394348784efSdrh 
395e1b6a5b8Sdrh expr(A) ::= LP(B) expr(X) RP(E). {A = X; sqliteExprSpan(A,&B,&E);}
396e1b6a5b8Sdrh expr(A) ::= NULL(X).             {A = sqliteExpr(TK_NULL, 0, 0, &X);}
397c4a3c779Sdrh expr(A) ::= id(X).               {A = sqliteExpr(TK_ID, 0, 0, &X);}
398c4a3c779Sdrh expr(A) ::= ids(X) DOT ids(Y). {
399e1b6a5b8Sdrh   Expr *temp1 = sqliteExpr(TK_ID, 0, 0, &X);
400348784efSdrh   Expr *temp2 = sqliteExpr(TK_ID, 0, 0, &Y);
401e1b6a5b8Sdrh   A = sqliteExpr(TK_DOT, temp1, temp2, 0);
402e1b6a5b8Sdrh }
403348784efSdrh expr(A) ::= INTEGER(X).      {A = sqliteExpr(TK_INTEGER, 0, 0, &X);}
404348784efSdrh expr(A) ::= FLOAT(X).        {A = sqliteExpr(TK_FLOAT, 0, 0, &X);}
405348784efSdrh expr(A) ::= STRING(X).       {A = sqliteExpr(TK_STRING, 0, 0, &X);}
406e1b6a5b8Sdrh expr(A) ::= ID(X) LP exprlist(Y) RP(E). {
407e1b6a5b8Sdrh   A = sqliteExprFunction(Y, &X);
408e1b6a5b8Sdrh   sqliteExprSpan(A,&X,&E);
409e1b6a5b8Sdrh }
410e1b6a5b8Sdrh expr(A) ::= ID(X) LP STAR RP(E). {
411e1b6a5b8Sdrh   A = sqliteExprFunction(0, &X);
412e1b6a5b8Sdrh   sqliteExprSpan(A,&X,&E);
413e1b6a5b8Sdrh }
414348784efSdrh expr(A) ::= expr(X) AND expr(Y).   {A = sqliteExpr(TK_AND, X, Y, 0);}
415348784efSdrh expr(A) ::= expr(X) OR expr(Y).    {A = sqliteExpr(TK_OR, X, Y, 0);}
416348784efSdrh expr(A) ::= expr(X) LT expr(Y).    {A = sqliteExpr(TK_LT, X, Y, 0);}
417348784efSdrh expr(A) ::= expr(X) GT expr(Y).    {A = sqliteExpr(TK_GT, X, Y, 0);}
418348784efSdrh expr(A) ::= expr(X) LE expr(Y).    {A = sqliteExpr(TK_LE, X, Y, 0);}
419348784efSdrh expr(A) ::= expr(X) GE expr(Y).    {A = sqliteExpr(TK_GE, X, Y, 0);}
420348784efSdrh expr(A) ::= expr(X) NE expr(Y).    {A = sqliteExpr(TK_NE, X, Y, 0);}
421348784efSdrh expr(A) ::= expr(X) EQ expr(Y).    {A = sqliteExpr(TK_EQ, X, Y, 0);}
42281a20f21Sdrh expr(A) ::= expr(X) BITAND expr(Y). {A = sqliteExpr(TK_BITAND, X, Y, 0);}
42381a20f21Sdrh expr(A) ::= expr(X) BITOR expr(Y).  {A = sqliteExpr(TK_BITOR, X, Y, 0);}
42481a20f21Sdrh expr(A) ::= expr(X) LSHIFT expr(Y). {A = sqliteExpr(TK_LSHIFT, X, Y, 0);}
42581a20f21Sdrh expr(A) ::= expr(X) RSHIFT expr(Y). {A = sqliteExpr(TK_RSHIFT, X, Y, 0);}
426dce2cbe6Sdrh expr(A) ::= expr(X) LIKE expr(Y).   {A = sqliteExpr(TK_LIKE, X, Y, 0);}
4274794b980Sdrh expr(A) ::= expr(X) NOT LIKE expr(Y).  {
4284794b980Sdrh   A = sqliteExpr(TK_LIKE, X, Y, 0);
4294794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
430e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&Y->span);
4314794b980Sdrh }
432dce2cbe6Sdrh expr(A) ::= expr(X) GLOB expr(Y).  {A = sqliteExpr(TK_GLOB,X,Y,0);}
4334794b980Sdrh expr(A) ::= expr(X) NOT GLOB expr(Y).  {
4344794b980Sdrh   A = sqliteExpr(TK_GLOB, X, Y, 0);
4354794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
436e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&Y->span);
4374794b980Sdrh }
438348784efSdrh expr(A) ::= expr(X) PLUS expr(Y).  {A = sqliteExpr(TK_PLUS, X, Y, 0);}
439348784efSdrh expr(A) ::= expr(X) MINUS expr(Y). {A = sqliteExpr(TK_MINUS, X, Y, 0);}
440348784efSdrh expr(A) ::= expr(X) STAR expr(Y).  {A = sqliteExpr(TK_STAR, X, Y, 0);}
441348784efSdrh expr(A) ::= expr(X) SLASH expr(Y). {A = sqliteExpr(TK_SLASH, X, Y, 0);}
442bf4133cbSdrh expr(A) ::= expr(X) REM expr(Y).   {A = sqliteExpr(TK_REM, X, Y, 0);}
4430040077dSdrh expr(A) ::= expr(X) CONCAT expr(Y). {A = sqliteExpr(TK_CONCAT, X, Y, 0);}
444e1b6a5b8Sdrh expr(A) ::= expr(X) ISNULL(E). {
445e1b6a5b8Sdrh   A = sqliteExpr(TK_ISNULL, X, 0, 0);
446e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
447e1b6a5b8Sdrh }
44833048c0bSdrh expr(A) ::= expr(X) IS NULL(E). {
44933048c0bSdrh   A = sqliteExpr(TK_ISNULL, X, 0, 0);
45033048c0bSdrh   sqliteExprSpan(A,&X->span,&E);
45133048c0bSdrh }
45233048c0bSdrh expr(A) ::= expr(X) NOTNULL(E). {
45333048c0bSdrh   A = sqliteExpr(TK_NOTNULL, X, 0, 0);
45433048c0bSdrh   sqliteExprSpan(A,&X->span,&E);
45533048c0bSdrh }
456e1b6a5b8Sdrh expr(A) ::= expr(X) NOT NULL(E). {
457e1b6a5b8Sdrh   A = sqliteExpr(TK_NOTNULL, X, 0, 0);
458e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
459e1b6a5b8Sdrh }
46081a20f21Sdrh expr(A) ::= expr(X) IS NOT NULL(E). {
46181a20f21Sdrh   A = sqliteExpr(TK_NOTNULL, X, 0, 0);
46281a20f21Sdrh   sqliteExprSpan(A,&X->span,&E);
46381a20f21Sdrh }
464e1b6a5b8Sdrh expr(A) ::= NOT(B) expr(X). {
465e1b6a5b8Sdrh   A = sqliteExpr(TK_NOT, X, 0, 0);
466e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&X->span);
467e1b6a5b8Sdrh }
46881a20f21Sdrh expr(A) ::= BITNOT(B) expr(X). {
46981a20f21Sdrh   A = sqliteExpr(TK_BITNOT, X, 0, 0);
47081a20f21Sdrh   sqliteExprSpan(A,&B,&X->span);
47181a20f21Sdrh }
472e1b6a5b8Sdrh expr(A) ::= MINUS(B) expr(X). [UMINUS] {
473e1b6a5b8Sdrh   A = sqliteExpr(TK_UMINUS, X, 0, 0);
474e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&X->span);
475e1b6a5b8Sdrh }
476e1b6a5b8Sdrh expr(A) ::= PLUS(B) expr(X). [UMINUS] {
477e1b6a5b8Sdrh   A = X;
478e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&X->span);
479e1b6a5b8Sdrh }
480e1b6a5b8Sdrh expr(A) ::= LP(B) select(X) RP(E). {
48119a775c2Sdrh   A = sqliteExpr(TK_SELECT, 0, 0, 0);
482daffd0e5Sdrh   if( A ) A->pSelect = X;
483e1b6a5b8Sdrh   sqliteExprSpan(A,&B,&E);
48419a775c2Sdrh }
485fef5208cSdrh expr(A) ::= expr(W) BETWEEN expr(X) AND expr(Y). {
486fef5208cSdrh   ExprList *pList = sqliteExprListAppend(0, X, 0);
487fef5208cSdrh   pList = sqliteExprListAppend(pList, Y, 0);
488fef5208cSdrh   A = sqliteExpr(TK_BETWEEN, W, 0, 0);
489daffd0e5Sdrh   if( A ) A->pList = pList;
490e1b6a5b8Sdrh   sqliteExprSpan(A,&W->span,&Y->span);
491fef5208cSdrh }
4924794b980Sdrh expr(A) ::= expr(W) NOT BETWEEN expr(X) AND expr(Y). {
4934794b980Sdrh   ExprList *pList = sqliteExprListAppend(0, X, 0);
4944794b980Sdrh   pList = sqliteExprListAppend(pList, Y, 0);
4954794b980Sdrh   A = sqliteExpr(TK_BETWEEN, W, 0, 0);
496daffd0e5Sdrh   if( A ) A->pList = pList;
4974794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
498e1b6a5b8Sdrh   sqliteExprSpan(A,&W->span,&Y->span);
4994794b980Sdrh }
500e1b6a5b8Sdrh expr(A) ::= expr(X) IN LP exprlist(Y) RP(E).  {
501fef5208cSdrh   A = sqliteExpr(TK_IN, X, 0, 0);
502daffd0e5Sdrh   if( A ) A->pList = Y;
503e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
504fef5208cSdrh }
505e1b6a5b8Sdrh expr(A) ::= expr(X) IN LP select(Y) RP(E).  {
506fef5208cSdrh   A = sqliteExpr(TK_IN, X, 0, 0);
507daffd0e5Sdrh   if( A ) A->pSelect = Y;
508e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
509fef5208cSdrh }
510e1b6a5b8Sdrh expr(A) ::= expr(X) NOT IN LP exprlist(Y) RP(E).  {
5114794b980Sdrh   A = sqliteExpr(TK_IN, X, 0, 0);
512daffd0e5Sdrh   if( A ) A->pList = Y;
5134794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
514e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
5154794b980Sdrh }
516e1b6a5b8Sdrh expr(A) ::= expr(X) NOT IN LP select(Y) RP(E).  {
5174794b980Sdrh   A = sqliteExpr(TK_IN, X, 0, 0);
518daffd0e5Sdrh   if( A ) A->pSelect = Y;
5194794b980Sdrh   A = sqliteExpr(TK_NOT, A, 0, 0);
520e1b6a5b8Sdrh   sqliteExprSpan(A,&X->span,&E);
5214794b980Sdrh }
522fef5208cSdrh 
523fef5208cSdrh 
524348784efSdrh 
525348784efSdrh %type exprlist {ExprList*}
526348784efSdrh %destructor exprlist {sqliteExprListDelete($$);}
527348784efSdrh %type expritem {Expr*}
528348784efSdrh %destructor expritem {sqliteExprDelete($$);}
529348784efSdrh 
530348784efSdrh exprlist(A) ::= exprlist(X) COMMA expritem(Y).
531348784efSdrh    {A = sqliteExprListAppend(X,Y,0);}
532348784efSdrh exprlist(A) ::= expritem(X).            {A = sqliteExprListAppend(0,X,0);}
533348784efSdrh expritem(A) ::= expr(X).                {A = X;}
534348784efSdrh expritem(A) ::= .                       {A = 0;}
535cce7d176Sdrh 
536382c0247Sdrh ///////////////////////////// The CREATE INDEX command ///////////////////////
537382c0247Sdrh //
5389cfcf5d4Sdrh cmd ::= CREATE(S) uniqueflag(U) INDEX ids(X)
5399cfcf5d4Sdrh         ON ids(Y) LP idxlist(Z) RP(E) onconf(R). {
5409cfcf5d4Sdrh   if( U!=OE_None ) U = R;
5419cfcf5d4Sdrh   if( U==OE_Default) U = OE_Abort;
5429cfcf5d4Sdrh   sqliteCreateIndex(pParse, &X, &Y, Z, U, &S, &E);
5439cfcf5d4Sdrh }
544717e6402Sdrh 
545717e6402Sdrh %type uniqueflag {int}
5469cfcf5d4Sdrh uniqueflag(A) ::= UNIQUE.  { A = OE_Abort; }
5479cfcf5d4Sdrh uniqueflag(A) ::= .        { A = OE_None; }
548348784efSdrh 
549348784efSdrh %type idxlist {IdList*}
550348784efSdrh %destructor idxlist {sqliteIdListDelete($$);}
551348784efSdrh %type idxitem {Token}
552348784efSdrh 
553348784efSdrh idxlist(A) ::= idxlist(X) COMMA idxitem(Y).
554348784efSdrh      {A = sqliteIdListAppend(X,&Y);}
555348784efSdrh idxlist(A) ::= idxitem(Y).
556348784efSdrh      {A = sqliteIdListAppend(0,&Y);}
557c4a3c779Sdrh idxitem(A) ::= ids(X).          {A = X;}
558348784efSdrh 
5598aff1015Sdrh ///////////////////////////// The DROP INDEX command /////////////////////////
560382c0247Sdrh //
561382c0247Sdrh 
562c4a3c779Sdrh cmd ::= DROP INDEX ids(X).      {sqliteDropIndex(pParse, &X);}
563982cef7eSdrh 
564382c0247Sdrh 
5658aff1015Sdrh ///////////////////////////// The COPY command ///////////////////////////////
566382c0247Sdrh //
5671c92853dSdrh cmd ::= COPY orconf(R) ids(X) FROM ids(Y) USING DELIMITERS STRING(Z).
568b419a926Sdrh     {sqliteCopy(pParse,&X,&Y,&Z,R);}
5691c92853dSdrh cmd ::= COPY orconf(R) ids(X) FROM ids(Y).
570b419a926Sdrh     {sqliteCopy(pParse,&X,&Y,0,R);}
571dce2cbe6Sdrh 
572382c0247Sdrh ///////////////////////////// The VACUUM command /////////////////////////////
573382c0247Sdrh //
574dce2cbe6Sdrh cmd ::= VACUUM.                {sqliteVacuum(pParse,0);}
575c4a3c779Sdrh cmd ::= VACUUM ids(X).         {sqliteVacuum(pParse,&X);}
576f57b14a6Sdrh 
577382c0247Sdrh ///////////////////////////// The PRAGMA command /////////////////////////////
578382c0247Sdrh //
579f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ ids(Y).         {sqlitePragma(pParse,&X,&Y,0);}
580f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ ON(Y).          {sqlitePragma(pParse,&X,&Y,0);}
581f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ plus_num(Y).    {sqlitePragma(pParse,&X,&Y,0);}
582f57b14a6Sdrh cmd ::= PRAGMA ids(X) EQ minus_num(Y).   {sqlitePragma(pParse,&X,&Y,1);}
583382c0247Sdrh cmd ::= PRAGMA ids(X) LP ids(Y) RP.      {sqlitePragma(pParse,&X,&Y,0);}
5841bffb9c8Sdrh cmd ::= PRAGMA(Y) ids(X).                {sqlitePragma(pParse,&X,&Y,0);}
585f57b14a6Sdrh plus_num(A) ::= plus_opt number(X).   {A = X;}
586f57b14a6Sdrh minus_num(A) ::= MINUS number(X).     {A = X;}
587f57b14a6Sdrh number(A) ::= INTEGER(X).  {A = X;}
588f57b14a6Sdrh number(A) ::= FLOAT(X).    {A = X;}
589f57b14a6Sdrh plus_opt ::= PLUS.
590f57b14a6Sdrh plus_opt ::= .
591