Yigit Boyar | 19b4110 | 2016-11-20 10:46:32 -0800 | [diff] [blame] | 1 | /* |
| 2 | * The MIT License (MIT) |
| 3 | * |
| 4 | * Copyright (c) 2014 by Bart Kiers |
| 5 | * |
| 6 | * Permission is hereby granted, free of charge, to any person |
| 7 | * obtaining a copy of this software and associated documentation |
| 8 | * files (the "Software"), to deal in the Software without |
| 9 | * restriction, including without limitation the rights to use, |
| 10 | * copy, modify, merge, publish, distribute, sublicense, and/or sell |
| 11 | * copies of the Software, and to permit persons to whom the |
| 12 | * Software is furnished to do so, subject to the following |
| 13 | * conditions: |
| 14 | * |
| 15 | * The above copyright notice and this permission notice shall be |
| 16 | * included in all copies or substantial portions of the Software. |
| 17 | * |
| 18 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
| 19 | * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES |
| 20 | * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
| 21 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
| 22 | * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
| 23 | * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
| 24 | * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR |
| 25 | * OTHER DEALINGS IN THE SOFTWARE. |
| 26 | * |
| 27 | * Project : sqlite-parser; an ANTLR4 grammar for SQLite |
| 28 | * https://github.com/bkiers/sqlite-parser |
| 29 | * Developed by : Bart Kiers, [email protected] |
| 30 | */ |
| 31 | grammar SQLite; |
| 32 | |
| 33 | parse |
| 34 | : ( sql_stmt_list | error )* EOF |
| 35 | ; |
| 36 | |
| 37 | error |
| 38 | : UNEXPECTED_CHAR |
| 39 | { |
| 40 | throw new RuntimeException("UNEXPECTED_CHAR=" + $UNEXPECTED_CHAR.text); |
| 41 | } |
| 42 | ; |
| 43 | |
| 44 | sql_stmt_list |
| 45 | : ';'* sql_stmt ( ';'+ sql_stmt )* ';'* |
| 46 | ; |
| 47 | |
| 48 | sql_stmt |
| 49 | : ( K_EXPLAIN ( K_QUERY K_PLAN )? )? ( alter_table_stmt |
| 50 | | analyze_stmt |
| 51 | | attach_stmt |
| 52 | | begin_stmt |
| 53 | | commit_stmt |
| 54 | | compound_select_stmt |
| 55 | | create_index_stmt |
| 56 | | create_table_stmt |
| 57 | | create_trigger_stmt |
| 58 | | create_view_stmt |
| 59 | | create_virtual_table_stmt |
| 60 | | delete_stmt |
| 61 | | delete_stmt_limited |
| 62 | | detach_stmt |
| 63 | | drop_index_stmt |
| 64 | | drop_table_stmt |
| 65 | | drop_trigger_stmt |
| 66 | | drop_view_stmt |
| 67 | | factored_select_stmt |
| 68 | | insert_stmt |
| 69 | | pragma_stmt |
| 70 | | reindex_stmt |
| 71 | | release_stmt |
| 72 | | rollback_stmt |
| 73 | | savepoint_stmt |
| 74 | | simple_select_stmt |
| 75 | | select_stmt |
| 76 | | update_stmt |
| 77 | | update_stmt_limited |
| 78 | | vacuum_stmt ) |
| 79 | ; |
| 80 | |
| 81 | alter_table_stmt |
| 82 | : K_ALTER K_TABLE ( database_name '.' )? table_name |
| 83 | ( K_RENAME K_TO new_table_name |
| 84 | | K_ADD K_COLUMN? column_def |
| 85 | ) |
| 86 | ; |
| 87 | |
| 88 | analyze_stmt |
| 89 | : K_ANALYZE ( database_name | table_or_index_name | database_name '.' table_or_index_name )? |
| 90 | ; |
| 91 | |
| 92 | attach_stmt |
| 93 | : K_ATTACH K_DATABASE? expr K_AS database_name |
| 94 | ; |
| 95 | |
| 96 | begin_stmt |
| 97 | : K_BEGIN ( K_DEFERRED | K_IMMEDIATE | K_EXCLUSIVE )? ( K_TRANSACTION transaction_name? )? |
| 98 | ; |
| 99 | |
| 100 | commit_stmt |
| 101 | : ( K_COMMIT | K_END ) ( K_TRANSACTION transaction_name? )? |
| 102 | ; |
| 103 | |
| 104 | compound_select_stmt |
| 105 | : with_clause? |
| 106 | select_core ( ( K_UNION K_ALL? | K_INTERSECT | K_EXCEPT ) select_core )+ |
| 107 | ( K_ORDER K_BY ordering_term ( ',' ordering_term )* )? |
| 108 | ( K_LIMIT expr ( ( K_OFFSET | ',' ) expr )? )? |
| 109 | ; |
| 110 | |
| 111 | create_index_stmt |
| 112 | : K_CREATE K_UNIQUE? K_INDEX ( K_IF K_NOT K_EXISTS )? |
| 113 | ( database_name '.' )? index_name K_ON table_name '(' indexed_column ( ',' indexed_column )* ')' |
| 114 | ( K_WHERE expr )? |
| 115 | ; |
| 116 | |
| 117 | create_table_stmt |
| 118 | : K_CREATE ( K_TEMP | K_TEMPORARY )? K_TABLE ( K_IF K_NOT K_EXISTS )? |
| 119 | ( database_name '.' )? table_name |
| 120 | ( '(' column_def ( ',' column_def )*? ( ',' table_constraint )* ')' ( K_WITHOUT IDENTIFIER )? |
| 121 | | K_AS select_stmt |
| 122 | ) |
| 123 | ; |
| 124 | |
| 125 | create_trigger_stmt |
| 126 | : K_CREATE ( K_TEMP | K_TEMPORARY )? K_TRIGGER ( K_IF K_NOT K_EXISTS )? |
| 127 | ( database_name '.' )? trigger_name ( K_BEFORE | K_AFTER | K_INSTEAD K_OF )? |
| 128 | ( K_DELETE | K_INSERT | K_UPDATE ( K_OF column_name ( ',' column_name )* )? ) K_ON ( database_name '.' )? table_name |
| 129 | ( K_FOR K_EACH K_ROW )? ( K_WHEN expr )? |
| 130 | K_BEGIN ( ( update_stmt | insert_stmt | delete_stmt | select_stmt ) ';' )+ K_END |
| 131 | ; |
| 132 | |
| 133 | create_view_stmt |
| 134 | : K_CREATE ( K_TEMP | K_TEMPORARY )? K_VIEW ( K_IF K_NOT K_EXISTS )? |
| 135 | ( database_name '.' )? view_name K_AS select_stmt |
| 136 | ; |
| 137 | |
| 138 | create_virtual_table_stmt |
| 139 | : K_CREATE K_VIRTUAL K_TABLE ( K_IF K_NOT K_EXISTS )? |
| 140 | ( database_name '.' )? table_name |
| 141 | K_USING module_name ( '(' module_argument ( ',' module_argument )* ')' )? |
| 142 | ; |
| 143 | |
| 144 | delete_stmt |
| 145 | : with_clause? K_DELETE K_FROM qualified_table_name |
| 146 | ( K_WHERE expr )? |
| 147 | ; |
| 148 | |
| 149 | delete_stmt_limited |
| 150 | : with_clause? K_DELETE K_FROM qualified_table_name |
| 151 | ( K_WHERE expr )? |
| 152 | ( ( K_ORDER K_BY ordering_term ( ',' ordering_term )* )? |
| 153 | K_LIMIT expr ( ( K_OFFSET | ',' ) expr )? |
| 154 | )? |
| 155 | ; |
| 156 | |
| 157 | detach_stmt |
| 158 | : K_DETACH K_DATABASE? database_name |
| 159 | ; |
| 160 | |
| 161 | drop_index_stmt |
| 162 | : K_DROP K_INDEX ( K_IF K_EXISTS )? ( database_name '.' )? index_name |
| 163 | ; |
| 164 | |
| 165 | drop_table_stmt |
| 166 | : K_DROP K_TABLE ( K_IF K_EXISTS )? ( database_name '.' )? table_name |
| 167 | ; |
| 168 | |
| 169 | drop_trigger_stmt |
| 170 | : K_DROP K_TRIGGER ( K_IF K_EXISTS )? ( database_name '.' )? trigger_name |
| 171 | ; |
| 172 | |
| 173 | drop_view_stmt |
| 174 | : K_DROP K_VIEW ( K_IF K_EXISTS )? ( database_name '.' )? view_name |
| 175 | ; |
| 176 | |
| 177 | factored_select_stmt |
| 178 | : with_clause? |
| 179 | select_core ( compound_operator select_core )* |
| 180 | ( K_ORDER K_BY ordering_term ( ',' ordering_term )* )? |
| 181 | ( K_LIMIT expr ( ( K_OFFSET | ',' ) expr )? )? |
| 182 | ; |
| 183 | |
| 184 | insert_stmt |
| 185 | : with_clause? ( K_INSERT |
| 186 | | K_REPLACE |
| 187 | | K_INSERT K_OR K_REPLACE |
| 188 | | K_INSERT K_OR K_ROLLBACK |
| 189 | | K_INSERT K_OR K_ABORT |
| 190 | | K_INSERT K_OR K_FAIL |
| 191 | | K_INSERT K_OR K_IGNORE ) K_INTO |
| 192 | ( database_name '.' )? table_name ( '(' column_name ( ',' column_name )* ')' )? |
| 193 | ( K_VALUES '(' expr ( ',' expr )* ')' ( ',' '(' expr ( ',' expr )* ')' )* |
| 194 | | select_stmt |
| 195 | | K_DEFAULT K_VALUES |
| 196 | ) |
| 197 | ; |
| 198 | |
| 199 | pragma_stmt |
| 200 | : K_PRAGMA ( database_name '.' )? pragma_name ( '=' pragma_value |
| 201 | | '(' pragma_value ')' )? |
| 202 | ; |
| 203 | |
| 204 | reindex_stmt |
| 205 | : K_REINDEX ( collation_name |
| 206 | | ( database_name '.' )? ( table_name | index_name ) |
| 207 | )? |
| 208 | ; |
| 209 | |
| 210 | release_stmt |
| 211 | : K_RELEASE K_SAVEPOINT? savepoint_name |
| 212 | ; |
| 213 | |
| 214 | rollback_stmt |
| 215 | : K_ROLLBACK ( K_TRANSACTION transaction_name? )? ( K_TO K_SAVEPOINT? savepoint_name )? |
| 216 | ; |
| 217 | |
| 218 | savepoint_stmt |
| 219 | : K_SAVEPOINT savepoint_name |
| 220 | ; |
| 221 | |
| 222 | simple_select_stmt |
| 223 | : with_clause? |
| 224 | select_core ( K_ORDER K_BY ordering_term ( ',' ordering_term )* )? |
| 225 | ( K_LIMIT expr ( ( K_OFFSET | ',' ) expr )? )? |
| 226 | ; |
| 227 | |
| 228 | select_stmt |
| 229 | : with_clause? |
| 230 | select_or_values ( compound_operator select_or_values )* |
| 231 | ( K_ORDER K_BY ordering_term ( ',' ordering_term )* )? |
| 232 | ( K_LIMIT expr ( ( K_OFFSET | ',' ) expr )? )? |
| 233 | ; |
| 234 | |
| 235 | select_or_values |
| 236 | : K_SELECT ( K_DISTINCT | K_ALL )? result_column ( ',' result_column )* |
| 237 | ( K_FROM ( table_or_subquery ( ',' table_or_subquery )* | join_clause ) )? |
| 238 | ( K_WHERE expr )? |
| 239 | ( K_GROUP K_BY expr ( ',' expr )* ( K_HAVING expr )? )? |
| 240 | | K_VALUES '(' expr ( ',' expr )* ')' ( ',' '(' expr ( ',' expr )* ')' )* |
| 241 | ; |
| 242 | |
| 243 | update_stmt |
| 244 | : with_clause? K_UPDATE ( K_OR K_ROLLBACK |
| 245 | | K_OR K_ABORT |
| 246 | | K_OR K_REPLACE |
| 247 | | K_OR K_FAIL |
| 248 | | K_OR K_IGNORE )? qualified_table_name |
| 249 | K_SET column_name '=' expr ( ',' column_name '=' expr )* ( K_WHERE expr )? |
| 250 | ; |
| 251 | |
| 252 | update_stmt_limited |
| 253 | : with_clause? K_UPDATE ( K_OR K_ROLLBACK |
| 254 | | K_OR K_ABORT |
| 255 | | K_OR K_REPLACE |
| 256 | | K_OR K_FAIL |
| 257 | | K_OR K_IGNORE )? qualified_table_name |
| 258 | K_SET column_name '=' expr ( ',' column_name '=' expr )* ( K_WHERE expr )? |
| 259 | ( ( K_ORDER K_BY ordering_term ( ',' ordering_term )* )? |
| 260 | K_LIMIT expr ( ( K_OFFSET | ',' ) expr )? |
| 261 | )? |
| 262 | ; |
| 263 | |
| 264 | vacuum_stmt |
| 265 | : K_VACUUM |
| 266 | ; |
| 267 | |
| 268 | column_def |
| 269 | : column_name type_name? column_constraint* |
| 270 | ; |
| 271 | |
| 272 | type_name |
| 273 | : name+? ( '(' signed_number ')' |
| 274 | | '(' signed_number ',' signed_number ')' )? |
| 275 | ; |
| 276 | |
| 277 | column_constraint |
| 278 | : ( K_CONSTRAINT name )? |
| 279 | ( K_PRIMARY K_KEY ( K_ASC | K_DESC )? conflict_clause K_AUTOINCREMENT? |
| 280 | | K_NOT? K_NULL conflict_clause |
| 281 | | K_UNIQUE conflict_clause |
| 282 | | K_CHECK '(' expr ')' |
| 283 | | K_DEFAULT (signed_number | literal_value | '(' expr ')') |
| 284 | | K_COLLATE collation_name |
| 285 | | foreign_key_clause |
| 286 | ) |
| 287 | ; |
| 288 | |
| 289 | conflict_clause |
| 290 | : ( K_ON K_CONFLICT ( K_ROLLBACK |
| 291 | | K_ABORT |
| 292 | | K_FAIL |
| 293 | | K_IGNORE |
| 294 | | K_REPLACE |
| 295 | ) |
| 296 | )? |
| 297 | ; |
| 298 | |
| 299 | /* |
| 300 | SQLite understands the following binary operators, in order from highest to |
| 301 | lowest precedence: |
| 302 | |
| 303 | || |
| 304 | * / % |
| 305 | + - |
| 306 | << >> & | |
| 307 | < <= > >= |
| 308 | = == != <> IS IS NOT IN LIKE GLOB MATCH REGEXP |
| 309 | AND |
| 310 | OR |
| 311 | */ |
| 312 | expr |
| 313 | : literal_value |
| 314 | | BIND_PARAMETER |
| 315 | | ( ( database_name '.' )? table_name '.' )? column_name |
| 316 | | unary_operator expr |
| 317 | | expr '||' expr |
| 318 | | expr ( '*' | '/' | '%' ) expr |
| 319 | | expr ( '+' | '-' ) expr |
| 320 | | expr ( '<<' | '>>' | '&' | '|' ) expr |
| 321 | | expr ( '<' | '<=' | '>' | '>=' ) expr |
| 322 | | expr ( '=' | '==' | '!=' | '<>' ) expr |
| 323 | | expr K_AND expr |
| 324 | | expr K_OR expr |
| 325 | | function_name '(' ( K_DISTINCT? expr ( ',' expr )* | '*' )? ')' |
| 326 | | '(' expr ')' |
| 327 | | K_CAST '(' expr K_AS type_name ')' |
| 328 | | expr K_COLLATE collation_name |
| 329 | | expr K_NOT? ( K_LIKE | K_GLOB | K_REGEXP | K_MATCH ) expr ( K_ESCAPE expr )? |
| 330 | | expr ( K_ISNULL | K_NOTNULL | K_NOT K_NULL ) |
| 331 | | expr K_IS K_NOT? expr |
| 332 | | expr K_NOT? K_BETWEEN expr K_AND expr |
| 333 | | expr K_NOT? K_IN ( '(' ( select_stmt |
| 334 | | expr ( ',' expr )* |
| 335 | )? |
| 336 | ')' |
| 337 | | ( database_name '.' )? table_name ) |
| 338 | | ( ( K_NOT )? K_EXISTS )? '(' select_stmt ')' |
| 339 | | K_CASE expr? ( K_WHEN expr K_THEN expr )+ ( K_ELSE expr )? K_END |
| 340 | | raise_function |
| 341 | ; |
| 342 | |
| 343 | foreign_key_clause |
| 344 | : K_REFERENCES foreign_table ( '(' column_name ( ',' column_name )* ')' )? |
| 345 | ( ( K_ON ( K_DELETE | K_UPDATE ) ( K_SET K_NULL |
| 346 | | K_SET K_DEFAULT |
| 347 | | K_CASCADE |
| 348 | | K_RESTRICT |
| 349 | | K_NO K_ACTION ) |
| 350 | | K_MATCH name |
| 351 | ) |
| 352 | )* |
| 353 | ( K_NOT? K_DEFERRABLE ( K_INITIALLY K_DEFERRED | K_INITIALLY K_IMMEDIATE )? )? |
| 354 | ; |
| 355 | |
| 356 | raise_function |
| 357 | : K_RAISE '(' ( K_IGNORE |
| 358 | | ( K_ROLLBACK | K_ABORT | K_FAIL ) ',' error_message ) |
| 359 | ')' |
| 360 | ; |
| 361 | |
| 362 | indexed_column |
| 363 | : column_name ( K_COLLATE collation_name )? ( K_ASC | K_DESC )? |
| 364 | ; |
| 365 | |
| 366 | table_constraint |
| 367 | : ( K_CONSTRAINT name )? |
| 368 | ( ( K_PRIMARY K_KEY | K_UNIQUE ) '(' indexed_column ( ',' indexed_column )* ')' conflict_clause |
| 369 | | K_CHECK '(' expr ')' |
| 370 | | K_FOREIGN K_KEY '(' column_name ( ',' column_name )* ')' foreign_key_clause |
| 371 | ) |
| 372 | ; |
| 373 | |
| 374 | with_clause |
| 375 | : K_WITH K_RECURSIVE? common_table_expression ( ',' common_table_expression )* |
| 376 | ; |
| 377 | |
| 378 | qualified_table_name |
| 379 | : ( database_name '.' )? table_name ( K_INDEXED K_BY index_name |
| 380 | | K_NOT K_INDEXED )? |
| 381 | ; |
| 382 | |
| 383 | ordering_term |
| 384 | : expr ( K_COLLATE collation_name )? ( K_ASC | K_DESC )? |
| 385 | ; |
| 386 | |
| 387 | pragma_value |
| 388 | : signed_number |
| 389 | | name |
| 390 | | STRING_LITERAL |
| 391 | ; |
| 392 | |
| 393 | common_table_expression |
| 394 | : table_name ( '(' column_name ( ',' column_name )* ')' )? K_AS '(' select_stmt ')' |
| 395 | ; |
| 396 | |
| 397 | result_column |
| 398 | : '*' |
| 399 | | table_name '.' '*' |
| 400 | | expr ( K_AS? column_alias )? |
| 401 | ; |
| 402 | |
| 403 | table_or_subquery |
| 404 | : ( schema_name '.' )? table_name ( K_AS? table_alias )? |
| 405 | ( K_INDEXED K_BY index_name |
| 406 | | K_NOT K_INDEXED )? |
| 407 | | ( schema_name '.' )? table_function_name '(' ( expr ( ',' expr )* )? ')' ( K_AS? table_alias )? |
| 408 | | '(' ( table_or_subquery ( ',' table_or_subquery )* |
| 409 | | join_clause ) |
| 410 | ')' |
| 411 | | '(' select_stmt ')' ( K_AS? table_alias )? |
| 412 | ; |
| 413 | |
| 414 | join_clause |
| 415 | : table_or_subquery ( join_operator table_or_subquery join_constraint )* |
| 416 | ; |
| 417 | |
| 418 | join_operator |
| 419 | : ',' |
| 420 | | K_NATURAL? ( K_LEFT K_OUTER? | K_INNER | K_CROSS )? K_JOIN |
| 421 | ; |
| 422 | |
| 423 | join_constraint |
| 424 | : ( K_ON expr |
| 425 | | K_USING '(' column_name ( ',' column_name )* ')' )? |
| 426 | ; |
| 427 | |
| 428 | select_core |
| 429 | : K_SELECT ( K_DISTINCT | K_ALL )? result_column ( ',' result_column )* |
| 430 | ( K_FROM ( table_or_subquery ( ',' table_or_subquery )* | join_clause ) )? |
| 431 | ( K_WHERE expr )? |
| 432 | ( K_GROUP K_BY expr ( ',' expr )* ( K_HAVING expr )? )? |
| 433 | | K_VALUES '(' expr ( ',' expr )* ')' ( ',' '(' expr ( ',' expr )* ')' )* |
| 434 | ; |
| 435 | |
| 436 | compound_operator |
| 437 | : K_UNION |
| 438 | | K_UNION K_ALL |
| 439 | | K_INTERSECT |
| 440 | | K_EXCEPT |
| 441 | ; |
| 442 | |
| 443 | signed_number |
| 444 | : ( '+' | '-' )? NUMERIC_LITERAL |
| 445 | ; |
| 446 | |
| 447 | literal_value |
| 448 | : NUMERIC_LITERAL |
| 449 | | STRING_LITERAL |
| 450 | | BLOB_LITERAL |
| 451 | | K_NULL |
| 452 | | K_CURRENT_TIME |
| 453 | | K_CURRENT_DATE |
| 454 | | K_CURRENT_TIMESTAMP |
| 455 | ; |
| 456 | |
| 457 | unary_operator |
| 458 | : '-' |
| 459 | | '+' |
| 460 | | '~' |
| 461 | | K_NOT |
| 462 | ; |
| 463 | |
| 464 | error_message |
| 465 | : STRING_LITERAL |
| 466 | ; |
| 467 | |
| 468 | module_argument // TODO check what exactly is permitted here |
| 469 | : expr |
| 470 | | column_def |
| 471 | ; |
| 472 | |
| 473 | column_alias |
| 474 | : IDENTIFIER |
| 475 | | STRING_LITERAL |
| 476 | ; |
| 477 | |
| 478 | keyword |
| 479 | : K_ABORT |
| 480 | | K_ACTION |
| 481 | | K_ADD |
| 482 | | K_AFTER |
| 483 | | K_ALL |
| 484 | | K_ALTER |
| 485 | | K_ANALYZE |
| 486 | | K_AND |
| 487 | | K_AS |
| 488 | | K_ASC |
| 489 | | K_ATTACH |
| 490 | | K_AUTOINCREMENT |
| 491 | | K_BEFORE |
| 492 | | K_BEGIN |
| 493 | | K_BETWEEN |
| 494 | | K_BY |
| 495 | | K_CASCADE |
| 496 | | K_CASE |
| 497 | | K_CAST |
| 498 | | K_CHECK |
| 499 | | K_COLLATE |
| 500 | | K_COLUMN |
| 501 | | K_COMMIT |
| 502 | | K_CONFLICT |
| 503 | | K_CONSTRAINT |
| 504 | | K_CREATE |
| 505 | | K_CROSS |
| 506 | | K_CURRENT_DATE |
| 507 | | K_CURRENT_TIME |
| 508 | | K_CURRENT_TIMESTAMP |
| 509 | | K_DATABASE |
| 510 | | K_DEFAULT |
| 511 | | K_DEFERRABLE |
| 512 | | K_DEFERRED |
| 513 | | K_DELETE |
| 514 | | K_DESC |
| 515 | | K_DETACH |
| 516 | | K_DISTINCT |
| 517 | | K_DROP |
| 518 | | K_EACH |
| 519 | | K_ELSE |
| 520 | | K_END |
| 521 | | K_ESCAPE |
| 522 | | K_EXCEPT |
| 523 | | K_EXCLUSIVE |
| 524 | | K_EXISTS |
| 525 | | K_EXPLAIN |
| 526 | | K_FAIL |
| 527 | | K_FOR |
| 528 | | K_FOREIGN |
| 529 | | K_FROM |
| 530 | | K_FULL |
| 531 | | K_GLOB |
| 532 | | K_GROUP |
| 533 | | K_HAVING |
| 534 | | K_IF |
| 535 | | K_IGNORE |
| 536 | | K_IMMEDIATE |
| 537 | | K_IN |
| 538 | | K_INDEX |
| 539 | | K_INDEXED |
| 540 | | K_INITIALLY |
| 541 | | K_INNER |
| 542 | | K_INSERT |
| 543 | | K_INSTEAD |
| 544 | | K_INTERSECT |
| 545 | | K_INTO |
| 546 | | K_IS |
| 547 | | K_ISNULL |
| 548 | | K_JOIN |
| 549 | | K_KEY |
| 550 | | K_LEFT |
| 551 | | K_LIKE |
| 552 | | K_LIMIT |
| 553 | | K_MATCH |
| 554 | | K_NATURAL |
| 555 | | K_NO |
| 556 | | K_NOT |
| 557 | | K_NOTNULL |
| 558 | | K_NULL |
| 559 | | K_OF |
| 560 | | K_OFFSET |
| 561 | | K_ON |
| 562 | | K_OR |
| 563 | | K_ORDER |
| 564 | | K_OUTER |
| 565 | | K_PLAN |
| 566 | | K_PRAGMA |
| 567 | | K_PRIMARY |
| 568 | | K_QUERY |
| 569 | | K_RAISE |
| 570 | | K_RECURSIVE |
| 571 | | K_REFERENCES |
| 572 | | K_REGEXP |
| 573 | | K_REINDEX |
| 574 | | K_RELEASE |
| 575 | | K_RENAME |
| 576 | | K_REPLACE |
| 577 | | K_RESTRICT |
| 578 | | K_RIGHT |
| 579 | | K_ROLLBACK |
| 580 | | K_ROW |
| 581 | | K_SAVEPOINT |
| 582 | | K_SELECT |
| 583 | | K_SET |
| 584 | | K_TABLE |
| 585 | | K_TEMP |
| 586 | | K_TEMPORARY |
| 587 | | K_THEN |
| 588 | | K_TO |
| 589 | | K_TRANSACTION |
| 590 | | K_TRIGGER |
| 591 | | K_UNION |
| 592 | | K_UNIQUE |
| 593 | | K_UPDATE |
| 594 | | K_USING |
| 595 | | K_VACUUM |
| 596 | | K_VALUES |
| 597 | | K_VIEW |
| 598 | | K_VIRTUAL |
| 599 | | K_WHEN |
| 600 | | K_WHERE |
| 601 | | K_WITH |
| 602 | | K_WITHOUT |
| 603 | ; |
| 604 | |
| 605 | // TODO check all names below |
| 606 | |
| 607 | name |
| 608 | : any_name |
| 609 | ; |
| 610 | |
| 611 | function_name |
| 612 | : any_name |
| 613 | ; |
| 614 | |
| 615 | database_name |
| 616 | : any_name |
| 617 | ; |
| 618 | |
| 619 | schema_name |
| 620 | : any_name |
| 621 | ; |
| 622 | |
| 623 | table_function_name |
| 624 | : any_name |
| 625 | ; |
| 626 | |
| 627 | table_name |
| 628 | : any_name |
| 629 | ; |
| 630 | |
| 631 | table_or_index_name |
| 632 | : any_name |
| 633 | ; |
| 634 | |
| 635 | new_table_name |
| 636 | : any_name |
| 637 | ; |
| 638 | |
| 639 | column_name |
| 640 | : any_name |
| 641 | ; |
| 642 | |
| 643 | collation_name |
| 644 | : any_name |
| 645 | ; |
| 646 | |
| 647 | foreign_table |
| 648 | : any_name |
| 649 | ; |
| 650 | |
| 651 | index_name |
| 652 | : any_name |
| 653 | ; |
| 654 | |
| 655 | trigger_name |
| 656 | : any_name |
| 657 | ; |
| 658 | |
| 659 | view_name |
| 660 | : any_name |
| 661 | ; |
| 662 | |
| 663 | module_name |
| 664 | : any_name |
| 665 | ; |
| 666 | |
| 667 | pragma_name |
| 668 | : any_name |
| 669 | ; |
| 670 | |
| 671 | savepoint_name |
| 672 | : any_name |
| 673 | ; |
| 674 | |
| 675 | table_alias |
| 676 | : IDENTIFIER |
| 677 | | STRING_LITERAL |
| 678 | | '(' table_alias ')' |
| 679 | ; |
| 680 | |
| 681 | transaction_name |
| 682 | : any_name |
| 683 | ; |
| 684 | |
| 685 | any_name |
| 686 | : IDENTIFIER |
| 687 | | keyword |
| 688 | | STRING_LITERAL |
| 689 | | '(' any_name ')' |
| 690 | ; |
| 691 | |
| 692 | SCOL : ';'; |
| 693 | DOT : '.'; |
| 694 | OPEN_PAR : '('; |
| 695 | CLOSE_PAR : ')'; |
| 696 | COMMA : ','; |
| 697 | ASSIGN : '='; |
| 698 | STAR : '*'; |
| 699 | PLUS : '+'; |
| 700 | MINUS : '-'; |
| 701 | TILDE : '~'; |
| 702 | PIPE2 : '||'; |
| 703 | DIV : '/'; |
| 704 | MOD : '%'; |
| 705 | LT2 : '<<'; |
| 706 | GT2 : '>>'; |
| 707 | AMP : '&'; |
| 708 | PIPE : '|'; |
| 709 | LT : '<'; |
| 710 | LT_EQ : '<='; |
| 711 | GT : '>'; |
| 712 | GT_EQ : '>='; |
| 713 | EQ : '=='; |
| 714 | NOT_EQ1 : '!='; |
| 715 | NOT_EQ2 : '<>'; |
| 716 | |
| 717 | // http://www.sqlite.org/lang_keywords.html |
| 718 | K_ABORT : A B O R T; |
| 719 | K_ACTION : A C T I O N; |
| 720 | K_ADD : A D D; |
| 721 | K_AFTER : A F T E R; |
| 722 | K_ALL : A L L; |
| 723 | K_ALTER : A L T E R; |
| 724 | K_ANALYZE : A N A L Y Z E; |
| 725 | K_AND : A N D; |
| 726 | K_AS : A S; |
| 727 | K_ASC : A S C; |
| 728 | K_ATTACH : A T T A C H; |
| 729 | K_AUTOINCREMENT : A U T O I N C R E M E N T; |
| 730 | K_BEFORE : B E F O R E; |
| 731 | K_BEGIN : B E G I N; |
| 732 | K_BETWEEN : B E T W E E N; |
| 733 | K_BY : B Y; |
| 734 | K_CASCADE : C A S C A D E; |
| 735 | K_CASE : C A S E; |
| 736 | K_CAST : C A S T; |
| 737 | K_CHECK : C H E C K; |
| 738 | K_COLLATE : C O L L A T E; |
| 739 | K_COLUMN : C O L U M N; |
| 740 | K_COMMIT : C O M M I T; |
| 741 | K_CONFLICT : C O N F L I C T; |
| 742 | K_CONSTRAINT : C O N S T R A I N T; |
| 743 | K_CREATE : C R E A T E; |
| 744 | K_CROSS : C R O S S; |
| 745 | K_CURRENT_DATE : C U R R E N T '_' D A T E; |
| 746 | K_CURRENT_TIME : C U R R E N T '_' T I M E; |
| 747 | K_CURRENT_TIMESTAMP : C U R R E N T '_' T I M E S T A M P; |
| 748 | K_DATABASE : D A T A B A S E; |
| 749 | K_DEFAULT : D E F A U L T; |
| 750 | K_DEFERRABLE : D E F E R R A B L E; |
| 751 | K_DEFERRED : D E F E R R E D; |
| 752 | K_DELETE : D E L E T E; |
| 753 | K_DESC : D E S C; |
| 754 | K_DETACH : D E T A C H; |
| 755 | K_DISTINCT : D I S T I N C T; |
| 756 | K_DROP : D R O P; |
| 757 | K_EACH : E A C H; |
| 758 | K_ELSE : E L S E; |
| 759 | K_END : E N D; |
| 760 | K_ESCAPE : E S C A P E; |
| 761 | K_EXCEPT : E X C E P T; |
| 762 | K_EXCLUSIVE : E X C L U S I V E; |
| 763 | K_EXISTS : E X I S T S; |
| 764 | K_EXPLAIN : E X P L A I N; |
| 765 | K_FAIL : F A I L; |
| 766 | K_FOR : F O R; |
| 767 | K_FOREIGN : F O R E I G N; |
| 768 | K_FROM : F R O M; |
| 769 | K_FULL : F U L L; |
| 770 | K_GLOB : G L O B; |
| 771 | K_GROUP : G R O U P; |
| 772 | K_HAVING : H A V I N G; |
| 773 | K_IF : I F; |
| 774 | K_IGNORE : I G N O R E; |
| 775 | K_IMMEDIATE : I M M E D I A T E; |
| 776 | K_IN : I N; |
| 777 | K_INDEX : I N D E X; |
| 778 | K_INDEXED : I N D E X E D; |
| 779 | K_INITIALLY : I N I T I A L L Y; |
| 780 | K_INNER : I N N E R; |
| 781 | K_INSERT : I N S E R T; |
| 782 | K_INSTEAD : I N S T E A D; |
| 783 | K_INTERSECT : I N T E R S E C T; |
| 784 | K_INTO : I N T O; |
| 785 | K_IS : I S; |
| 786 | K_ISNULL : I S N U L L; |
| 787 | K_JOIN : J O I N; |
| 788 | K_KEY : K E Y; |
| 789 | K_LEFT : L E F T; |
| 790 | K_LIKE : L I K E; |
| 791 | K_LIMIT : L I M I T; |
| 792 | K_MATCH : M A T C H; |
| 793 | K_NATURAL : N A T U R A L; |
| 794 | K_NO : N O; |
| 795 | K_NOT : N O T; |
| 796 | K_NOTNULL : N O T N U L L; |
| 797 | K_NULL : N U L L; |
| 798 | K_OF : O F; |
| 799 | K_OFFSET : O F F S E T; |
| 800 | K_ON : O N; |
| 801 | K_OR : O R; |
| 802 | K_ORDER : O R D E R; |
| 803 | K_OUTER : O U T E R; |
| 804 | K_PLAN : P L A N; |
| 805 | K_PRAGMA : P R A G M A; |
| 806 | K_PRIMARY : P R I M A R Y; |
| 807 | K_QUERY : Q U E R Y; |
| 808 | K_RAISE : R A I S E; |
| 809 | K_RECURSIVE : R E C U R S I V E; |
| 810 | K_REFERENCES : R E F E R E N C E S; |
| 811 | K_REGEXP : R E G E X P; |
| 812 | K_REINDEX : R E I N D E X; |
| 813 | K_RELEASE : R E L E A S E; |
| 814 | K_RENAME : R E N A M E; |
| 815 | K_REPLACE : R E P L A C E; |
| 816 | K_RESTRICT : R E S T R I C T; |
| 817 | K_RIGHT : R I G H T; |
| 818 | K_ROLLBACK : R O L L B A C K; |
| 819 | K_ROW : R O W; |
| 820 | K_SAVEPOINT : S A V E P O I N T; |
| 821 | K_SELECT : S E L E C T; |
| 822 | K_SET : S E T; |
| 823 | K_TABLE : T A B L E; |
| 824 | K_TEMP : T E M P; |
| 825 | K_TEMPORARY : T E M P O R A R Y; |
| 826 | K_THEN : T H E N; |
| 827 | K_TO : T O; |
| 828 | K_TRANSACTION : T R A N S A C T I O N; |
| 829 | K_TRIGGER : T R I G G E R; |
| 830 | K_UNION : U N I O N; |
| 831 | K_UNIQUE : U N I Q U E; |
| 832 | K_UPDATE : U P D A T E; |
| 833 | K_USING : U S I N G; |
| 834 | K_VACUUM : V A C U U M; |
| 835 | K_VALUES : V A L U E S; |
| 836 | K_VIEW : V I E W; |
| 837 | K_VIRTUAL : V I R T U A L; |
| 838 | K_WHEN : W H E N; |
| 839 | K_WHERE : W H E R E; |
| 840 | K_WITH : W I T H; |
| 841 | K_WITHOUT : W I T H O U T; |
| 842 | |
| 843 | IDENTIFIER |
| 844 | : '"' (~'"' | '""')* '"' |
| 845 | | '`' (~'`' | '``')* '`' |
| 846 | | '[' ~']'* ']' |
| 847 | | [a-zA-Z_] [a-zA-Z_0-9]* // TODO check: needs more chars in set |
| 848 | ; |
| 849 | |
| 850 | NUMERIC_LITERAL |
| 851 | : DIGIT+ ( '.' DIGIT* )? ( E [-+]? DIGIT+ )? |
| 852 | | '.' DIGIT+ ( E [-+]? DIGIT+ )? |
| 853 | ; |
| 854 | |
| 855 | BIND_PARAMETER |
| 856 | : '?' DIGIT* |
| 857 | | [:@$] IDENTIFIER |
| 858 | ; |
| 859 | |
| 860 | STRING_LITERAL |
| 861 | : '\'' ( ~'\'' | '\'\'' )* '\'' |
| 862 | ; |
| 863 | |
| 864 | BLOB_LITERAL |
| 865 | : X STRING_LITERAL |
| 866 | ; |
| 867 | |
| 868 | SINGLE_LINE_COMMENT |
| 869 | : '--' ~[\r\n]* -> channel(HIDDEN) |
| 870 | ; |
| 871 | |
| 872 | MULTILINE_COMMENT |
| 873 | : '/*' .*? ( '*/' | EOF ) -> channel(HIDDEN) |
| 874 | ; |
| 875 | |
| 876 | SPACES |
| 877 | : [ \u000B\t\r\n] -> channel(HIDDEN) |
| 878 | ; |
| 879 | |
| 880 | UNEXPECTED_CHAR |
| 881 | : . |
| 882 | ; |
| 883 | |
| 884 | fragment DIGIT : [0-9]; |
| 885 | |
| 886 | fragment A : [aA]; |
| 887 | fragment B : [bB]; |
| 888 | fragment C : [cC]; |
| 889 | fragment D : [dD]; |
| 890 | fragment E : [eE]; |
| 891 | fragment F : [fF]; |
| 892 | fragment G : [gG]; |
| 893 | fragment H : [hH]; |
| 894 | fragment I : [iI]; |
| 895 | fragment J : [jJ]; |
| 896 | fragment K : [kK]; |
| 897 | fragment L : [lL]; |
| 898 | fragment M : [mM]; |
| 899 | fragment N : [nN]; |
| 900 | fragment O : [oO]; |
| 901 | fragment P : [pP]; |
| 902 | fragment Q : [qQ]; |
| 903 | fragment R : [rR]; |
| 904 | fragment S : [sS]; |
| 905 | fragment T : [tT]; |
| 906 | fragment U : [uU]; |
| 907 | fragment V : [vV]; |
| 908 | fragment W : [wW]; |
| 909 | fragment X : [xX]; |
| 910 | fragment Y : [yY]; |
| 911 | fragment Z : [zZ]; |