forked from sqldef/sqldef
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparser.go
9722 lines (9651 loc) · 277 KB
/
parser.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
// Code generated by goyacc -o parser.go parser.y. DO NOT EDIT.
//line parser.y:18
package parser
import __yyfmt__ "fmt"
//line parser.y:18
func setParseTree(yylex interface{}, stmt Statement) {
yylex.(*Tokenizer).ParseTree = stmt
}
func setAllowComments(yylex interface{}, allow bool) {
yylex.(*Tokenizer).AllowComments = allow
}
func setDDL(yylex interface{}, ddl *DDL) {
yylex.(*Tokenizer).partialDDL = ddl
}
func incNesting(yylex interface{}) bool {
yylex.(*Tokenizer).nesting++
if yylex.(*Tokenizer).nesting == 200 {
return true
}
return false
}
func decNesting(yylex interface{}) {
yylex.(*Tokenizer).nesting--
}
// forceEOF forces the lexer to end prematurely. Not all SQL statements
// are supported by the Parser, thus calling forceEOF will make the lexer
// return EOF early.
func forceEOF(yylex interface{}) {
yylex.(*Tokenizer).ForceEOF = true
}
//line parser.y:53
type yySymType struct {
yys int
empty struct{}
statement Statement
selStmt SelectStatement
ddl *DDL
ins *Insert
byt byte
bytes []byte
bytes2 [][]byte
str string
strs []string
selectExprs SelectExprs
selectExpr SelectExpr
columns Columns
partitions Partitions
colName *ColName
newQualifierColName *NewQualifierColName
tableExprs TableExprs
tableExpr TableExpr
joinCondition JoinCondition
tableName TableName
tableNames TableNames
indexHints *IndexHints
expr Expr
exprs Exprs
boolVal BoolVal
colTuple ColTuple
values Values
valTuple ValTuple
subquery *Subquery
whens []*When
when *When
orderBy OrderBy
order *Order
limit *Limit
updateExprs UpdateExprs
setExprs SetExprs
updateExpr *UpdateExpr
setExpr *SetExpr
colIdent ColIdent
colIdents []ColIdent
tableIdent TableIdent
convertType *ConvertType
aliasedTableName *AliasedTableExpr
TableSpec *TableSpec
columnType ColumnType
colKeyOpt ColumnKeyOption
optVal *SQLVal
LengthScaleOption LengthScaleOption
columnDefinition *ColumnDefinition
checkDefinition *CheckDefinition
indexDefinition *IndexDefinition
indexInfo *IndexInfo
indexOption *IndexOption
indexOptions []*IndexOption
indexPartition *IndexPartition
indexColumn IndexColumn
indexColumns []IndexColumn
indexColumnsOrExpression IndexColumnsOrExpression
foreignKeyDefinition *ForeignKeyDefinition
partDefs []*PartitionDefinition
partDef *PartitionDefinition
partSpec *PartitionSpec
vindexParam VindexParam
vindexParams []VindexParam
showFilter *ShowFilter
sequence *Sequence
blockStatement []Statement
localVariable *LocalVariable
localVariables []*LocalVariable
arrayConstructor *ArrayConstructor
arrayElements ArrayElements
arrayElement ArrayElement
tableOptions map[string]string
}
const LEX_ERROR = 57346
const UNION = 57347
const SELECT = 57348
const STREAM = 57349
const INSERT = 57350
const UPDATE = 57351
const DELETE = 57352
const FROM = 57353
const WHERE = 57354
const GROUP = 57355
const HAVING = 57356
const ORDER = 57357
const BY = 57358
const LIMIT = 57359
const OFFSET = 57360
const FOR = 57361
const DECLARE = 57362
const ALL = 57363
const DISTINCT = 57364
const AS = 57365
const EXISTS = 57366
const ASC = 57367
const DESC = 57368
const INTO = 57369
const DUPLICATE = 57370
const DEFAULT = 57371
const SRID = 57372
const SET = 57373
const LOCK = 57374
const KEYS = 57375
const ROWID = 57376
const STRICT = 57377
const VALUES = 57378
const LAST_INSERT_ID = 57379
const NEXT = 57380
const VALUE = 57381
const SHARE = 57382
const MODE = 57383
const SQL_NO_CACHE = 57384
const SQL_CACHE = 57385
const JOIN = 57386
const STRAIGHT_JOIN = 57387
const LEFT = 57388
const RIGHT = 57389
const INNER = 57390
const OUTER = 57391
const CROSS = 57392
const NATURAL = 57393
const USE = 57394
const FORCE = 57395
const ON = 57396
const USING = 57397
const ID = 57398
const HEX = 57399
const STRING = 57400
const INTEGRAL = 57401
const FLOAT = 57402
const HEXNUM = 57403
const VALUE_ARG = 57404
const LIST_ARG = 57405
const COMMENT = 57406
const COMMENT_KEYWORD = 57407
const BIT_LITERAL = 57408
const NULL = 57409
const TRUE = 57410
const FALSE = 57411
const OFF = 57412
const OR = 57413
const AND = 57414
const NOT = 57415
const BETWEEN = 57416
const CASE = 57417
const WHEN = 57418
const THEN = 57419
const ELSE = 57420
const END = 57421
const LE = 57422
const GE = 57423
const NE = 57424
const NULL_SAFE_EQUAL = 57425
const IS = 57426
const LIKE = 57427
const REGEXP = 57428
const IN = 57429
const POSIX_REGEX = 57430
const POSIX_REGEX_CI = 57431
const POSIX_NOT_REGEX = 57432
const POSIX_NOT_REGEX_CI = 57433
const SHIFT_LEFT = 57434
const SHIFT_RIGHT = 57435
const DIV = 57436
const MOD = 57437
const UNARY = 57438
const COLLATE = 57439
const BINARY = 57440
const UNDERSCORE_BINARY = 57441
const INTERVAL = 57442
const JSON_EXTRACT_OP = 57443
const JSON_UNQUOTE_EXTRACT_OP = 57444
const CREATE = 57445
const ALTER = 57446
const DROP = 57447
const RENAME = 57448
const ANALYZE = 57449
const ADD = 57450
const SCHEMA = 57451
const TABLE = 57452
const INDEX = 57453
const MATERIALIZED = 57454
const VIEW = 57455
const TO = 57456
const IGNORE = 57457
const IF = 57458
const PRIMARY = 57459
const COLUMN = 57460
const CONSTRAINT = 57461
const REFERENCES = 57462
const SPATIAL = 57463
const FULLTEXT = 57464
const FOREIGN = 57465
const KEY_BLOCK_SIZE = 57466
const POLICY = 57467
const WHILE = 57468
const UNIQUE = 57469
const KEY = 57470
const SHOW = 57471
const DESCRIBE = 57472
const EXPLAIN = 57473
const DATE = 57474
const ESCAPE = 57475
const REPAIR = 57476
const OPTIMIZE = 57477
const TRUNCATE = 57478
const MAXVALUE = 57479
const PARTITION = 57480
const REORGANIZE = 57481
const LESS = 57482
const THAN = 57483
const PROCEDURE = 57484
const TRIGGER = 57485
const TYPE = 57486
const VINDEX = 57487
const VINDEXES = 57488
const STATUS = 57489
const VARIABLES = 57490
const RESTRICT = 57491
const CASCADE = 57492
const NO = 57493
const ACTION = 57494
const PERMISSIVE = 57495
const RESTRICTIVE = 57496
const PUBLIC = 57497
const CURRENT_USER = 57498
const SESSION_USER = 57499
const PAD_INDEX = 57500
const FILLFACTOR = 57501
const IGNORE_DUP_KEY = 57502
const STATISTICS_NORECOMPUTE = 57503
const STATISTICS_INCREMENTAL = 57504
const ALLOW_ROW_LOCKS = 57505
const ALLOW_PAGE_LOCKS = 57506
const BEFORE = 57507
const AFTER = 57508
const EACH = 57509
const ROW = 57510
const SCROLL = 57511
const CURSOR = 57512
const OPEN = 57513
const CLOSE = 57514
const FETCH = 57515
const PRIOR = 57516
const FIRST = 57517
const LAST = 57518
const DEALLOCATE = 57519
const DEFERRABLE = 57520
const INITIALLY = 57521
const IMMEDIATE = 57522
const DEFERRED = 57523
const CONCURRENTLY = 57524
const BEGIN = 57525
const START = 57526
const TRANSACTION = 57527
const COMMIT = 57528
const ROLLBACK = 57529
const BIT = 57530
const TINYINT = 57531
const SMALLINT = 57532
const SMALLSERIAL = 57533
const MEDIUMINT = 57534
const INT = 57535
const INTEGER = 57536
const SERIAL = 57537
const BIGINT = 57538
const BIGSERIAL = 57539
const INTNUM = 57540
const REAL = 57541
const DOUBLE = 57542
const PRECISION = 57543
const FLOAT_TYPE = 57544
const DECIMAL = 57545
const NUMERIC = 57546
const SMALLMONEY = 57547
const MONEY = 57548
const TIME = 57549
const TIMESTAMP = 57550
const DATETIME = 57551
const YEAR = 57552
const DATETIMEOFFSET = 57553
const DATETIME2 = 57554
const SMALLDATETIME = 57555
const CHAR = 57556
const VARCHAR = 57557
const VARYING = 57558
const BOOL = 57559
const CHARACTER = 57560
const VARBINARY = 57561
const NCHAR = 57562
const NVARCHAR = 57563
const NTEXT = 57564
const UUID = 57565
const TEXT = 57566
const TINYTEXT = 57567
const MEDIUMTEXT = 57568
const LONGTEXT = 57569
const CITEXT = 57570
const BLOB = 57571
const TINYBLOB = 57572
const MEDIUMBLOB = 57573
const LONGBLOB = 57574
const JSON = 57575
const JSONB = 57576
const ENUM = 57577
const GEOMETRY = 57578
const POINT = 57579
const LINESTRING = 57580
const POLYGON = 57581
const GEOMETRYCOLLECTION = 57582
const MULTIPOINT = 57583
const MULTILINESTRING = 57584
const MULTIPOLYGON = 57585
const VARIADIC = 57586
const ARRAY = 57587
const NOW = 57588
const GETDATE = 57589
const BPCHAR = 57590
const TEXT_PATTERN_OPS = 57591
const NULLX = 57592
const AUTO_INCREMENT = 57593
const APPROXNUM = 57594
const SIGNED = 57595
const UNSIGNED = 57596
const ZEROFILL = 57597
const ZONE = 57598
const AUTOINCREMENT = 57599
const DATABASES = 57600
const TABLES = 57601
const VITESS_KEYSPACES = 57602
const VITESS_SHARDS = 57603
const VITESS_TABLETS = 57604
const VSCHEMA_TABLES = 57605
const EXTENDED = 57606
const FULL = 57607
const PROCESSLIST = 57608
const NAMES = 57609
const CHARSET = 57610
const GLOBAL = 57611
const SESSION = 57612
const ISOLATION = 57613
const LEVEL = 57614
const READ = 57615
const WRITE = 57616
const ONLY = 57617
const REPEATABLE = 57618
const COMMITTED = 57619
const UNCOMMITTED = 57620
const SERIALIZABLE = 57621
const NEW = 57622
const CURRENT_TIMESTAMP = 57623
const DATABASE = 57624
const CURRENT_DATE = 57625
const CURRENT_TIME = 57626
const LOCALTIME = 57627
const LOCALTIMESTAMP = 57628
const UTC_DATE = 57629
const UTC_TIME = 57630
const UTC_TIMESTAMP = 57631
const REPLACE = 57632
const CONVERT = 57633
const CAST = 57634
const SUBSTR = 57635
const SUBSTRING = 57636
const GROUP_CONCAT = 57637
const SEPARATOR = 57638
const INHERIT = 57639
const MATCH = 57640
const AGAINST = 57641
const BOOLEAN = 57642
const LANGUAGE = 57643
const WITH = 57644
const WITHOUT = 57645
const PARSER = 57646
const QUERY = 57647
const EXPANSION = 57648
const UNUSED = 57649
const VIRTUAL = 57650
const STORED = 57651
const GENERATED = 57652
const ALWAYS = 57653
const IDENTITY = 57654
const SEQUENCE = 57655
const INCREMENT = 57656
const MINVALUE = 57657
const CACHE = 57658
const CYCLE = 57659
const OWNED = 57660
const NONE = 57661
const CLUSTERED = 57662
const NONCLUSTERED = 57663
const REPLICATION = 57664
const INCLUDE = 57665
const HOLDLOCK = 57666
const NOLOCK = 57667
const NOWAIT = 57668
const PAGLOCK = 57669
const ROWLOCK = 57670
const TABLELOCK = 57671
const TYPECAST = 57672
const CHECK = 57673
var yyToknames = [...]string{
"$end",
"error",
"$unk",
"LEX_ERROR",
"UNION",
"SELECT",
"STREAM",
"INSERT",
"UPDATE",
"DELETE",
"FROM",
"WHERE",
"GROUP",
"HAVING",
"ORDER",
"BY",
"LIMIT",
"OFFSET",
"FOR",
"DECLARE",
"ALL",
"DISTINCT",
"AS",
"EXISTS",
"ASC",
"DESC",
"INTO",
"DUPLICATE",
"DEFAULT",
"SRID",
"SET",
"LOCK",
"KEYS",
"ROWID",
"STRICT",
"VALUES",
"LAST_INSERT_ID",
"NEXT",
"VALUE",
"SHARE",
"MODE",
"SQL_NO_CACHE",
"SQL_CACHE",
"JOIN",
"STRAIGHT_JOIN",
"LEFT",
"RIGHT",
"INNER",
"OUTER",
"CROSS",
"NATURAL",
"USE",
"FORCE",
"ON",
"USING",
"'('",
"','",
"')'",
"ID",
"HEX",
"STRING",
"INTEGRAL",
"FLOAT",
"HEXNUM",
"VALUE_ARG",
"LIST_ARG",
"COMMENT",
"COMMENT_KEYWORD",
"BIT_LITERAL",
"NULL",
"TRUE",
"FALSE",
"OFF",
"OR",
"AND",
"NOT",
"'!'",
"BETWEEN",
"CASE",
"WHEN",
"THEN",
"ELSE",
"END",
"'='",
"'<'",
"'>'",
"LE",
"GE",
"NE",
"NULL_SAFE_EQUAL",
"IS",
"LIKE",
"REGEXP",
"IN",
"POSIX_REGEX",
"POSIX_REGEX_CI",
"POSIX_NOT_REGEX",
"POSIX_NOT_REGEX_CI",
"'|'",
"'&'",
"SHIFT_LEFT",
"SHIFT_RIGHT",
"'+'",
"'-'",
"'*'",
"'/'",
"DIV",
"'%'",
"MOD",
"'^'",
"'~'",
"UNARY",
"COLLATE",
"BINARY",
"UNDERSCORE_BINARY",
"INTERVAL",
"'.'",
"JSON_EXTRACT_OP",
"JSON_UNQUOTE_EXTRACT_OP",
"CREATE",
"ALTER",
"DROP",
"RENAME",
"ANALYZE",
"ADD",
"SCHEMA",
"TABLE",
"INDEX",
"MATERIALIZED",
"VIEW",
"TO",
"IGNORE",
"IF",
"PRIMARY",
"COLUMN",
"CONSTRAINT",
"REFERENCES",
"SPATIAL",
"FULLTEXT",
"FOREIGN",
"KEY_BLOCK_SIZE",
"POLICY",
"WHILE",
"UNIQUE",
"KEY",
"SHOW",
"DESCRIBE",
"EXPLAIN",
"DATE",
"ESCAPE",
"REPAIR",
"OPTIMIZE",
"TRUNCATE",
"MAXVALUE",
"PARTITION",
"REORGANIZE",
"LESS",
"THAN",
"PROCEDURE",
"TRIGGER",
"TYPE",
"VINDEX",
"VINDEXES",
"STATUS",
"VARIABLES",
"RESTRICT",
"CASCADE",
"NO",
"ACTION",
"PERMISSIVE",
"RESTRICTIVE",
"PUBLIC",
"CURRENT_USER",
"SESSION_USER",
"PAD_INDEX",
"FILLFACTOR",
"IGNORE_DUP_KEY",
"STATISTICS_NORECOMPUTE",
"STATISTICS_INCREMENTAL",
"ALLOW_ROW_LOCKS",
"ALLOW_PAGE_LOCKS",
"BEFORE",
"AFTER",
"EACH",
"ROW",
"SCROLL",
"CURSOR",
"OPEN",
"CLOSE",
"FETCH",
"PRIOR",
"FIRST",
"LAST",
"DEALLOCATE",
"DEFERRABLE",
"INITIALLY",
"IMMEDIATE",
"DEFERRED",
"CONCURRENTLY",
"BEGIN",
"START",
"TRANSACTION",
"COMMIT",
"ROLLBACK",
"BIT",
"TINYINT",
"SMALLINT",
"SMALLSERIAL",
"MEDIUMINT",
"INT",
"INTEGER",
"SERIAL",
"BIGINT",
"BIGSERIAL",
"INTNUM",
"REAL",
"DOUBLE",
"PRECISION",
"FLOAT_TYPE",
"DECIMAL",
"NUMERIC",
"SMALLMONEY",
"MONEY",
"TIME",
"TIMESTAMP",
"DATETIME",
"YEAR",
"DATETIMEOFFSET",
"DATETIME2",
"SMALLDATETIME",
"CHAR",
"VARCHAR",
"VARYING",
"BOOL",
"CHARACTER",
"VARBINARY",
"NCHAR",
"NVARCHAR",
"NTEXT",
"UUID",
"TEXT",
"TINYTEXT",
"MEDIUMTEXT",
"LONGTEXT",
"CITEXT",
"BLOB",
"TINYBLOB",
"MEDIUMBLOB",
"LONGBLOB",
"JSON",
"JSONB",
"ENUM",
"GEOMETRY",
"POINT",
"LINESTRING",
"POLYGON",
"GEOMETRYCOLLECTION",
"MULTIPOINT",
"MULTILINESTRING",
"MULTIPOLYGON",
"VARIADIC",
"ARRAY",
"NOW",
"GETDATE",
"BPCHAR",
"TEXT_PATTERN_OPS",
"NULLX",
"AUTO_INCREMENT",
"APPROXNUM",
"SIGNED",
"UNSIGNED",
"ZEROFILL",
"ZONE",
"AUTOINCREMENT",
"DATABASES",
"TABLES",
"VITESS_KEYSPACES",
"VITESS_SHARDS",
"VITESS_TABLETS",
"VSCHEMA_TABLES",
"EXTENDED",
"FULL",
"PROCESSLIST",
"NAMES",
"CHARSET",
"GLOBAL",
"SESSION",
"ISOLATION",
"LEVEL",
"READ",
"WRITE",
"ONLY",
"REPEATABLE",
"COMMITTED",
"UNCOMMITTED",
"SERIALIZABLE",
"NEW",
"CURRENT_TIMESTAMP",
"DATABASE",
"CURRENT_DATE",
"CURRENT_TIME",
"LOCALTIME",
"LOCALTIMESTAMP",
"UTC_DATE",
"UTC_TIME",
"UTC_TIMESTAMP",
"REPLACE",
"CONVERT",
"CAST",
"SUBSTR",
"SUBSTRING",
"GROUP_CONCAT",
"SEPARATOR",
"INHERIT",
"MATCH",
"AGAINST",
"BOOLEAN",
"LANGUAGE",
"WITH",
"WITHOUT",
"PARSER",
"QUERY",
"EXPANSION",
"UNUSED",
"VIRTUAL",
"STORED",
"GENERATED",
"ALWAYS",
"IDENTITY",
"SEQUENCE",
"INCREMENT",
"MINVALUE",
"CACHE",
"CYCLE",
"OWNED",
"NONE",
"CLUSTERED",
"NONCLUSTERED",
"REPLICATION",
"INCLUDE",
"HOLDLOCK",
"NOLOCK",
"NOWAIT",
"PAGLOCK",
"ROWLOCK",
"TABLELOCK",
"TYPECAST",
"CHECK",
"';'",
"'['",
"']'",
}
var yyStatenames = [...]string{}
const yyEofCode = 1
const yyErrCode = 2
const yyInitialStackSize = 16
//line yacctab:1
var yyExca = [...]int16{
-1, 1,
1, -1,
-2, 0,
-1, 3,
5, 27,
-2, 4,
-1, 30,
130, 153,
-2, 143,
-1, 36,
164, 492,
165, 492,
-2, 482,
-1, 278,
117, 850,
-2, 846,
-1, 279,
117, 851,
-2, 847,
-1, 280,
117, 852,
-2, 239,
-1, 321,
262, 861,
-2, 744,
-1, 353,
84, 1076,
-2, 82,
-1, 354,
84, 1026,
-2, 83,
-1, 360,
84, 1005,
-2, 817,
-1, 362,
84, 1050,
-2, 819,
-1, 618,
262, 861,
-2, 520,
-1, 667,
262, 861,
-2, 520,
-1, 696,
55, 41,
57, 41,
-2, 43,
-1, 728,
114, 1000,
245, 1000,
251, 1000,
-2, 275,
-1, 729,
114, 1001,
245, 1001,
251, 1001,
-2, 276,
-1, 730,
245, 1003,
251, 1003,
-2, 310,
-1, 731,
245, 1004,
251, 1004,
-2, 310,
-1, 732,
245, 1103,
251, 1103,
-2, 310,
-1, 733,
245, 1051,
251, 1051,
-2, 310,
-1, 734,
245, 1056,
251, 1056,
-2, 310,
-1, 735,
114, 1054,
245, 1054,
251, 1054,
-2, 282,
-1, 737,
114, 1102,
245, 1102,
251, 1102,
-2, 310,
-1, 738,
245, 1088,
251, 1088,
-2, 327,
-1, 739,
245, 1094,
251, 1094,
-2, 327,
-1, 740,
245, 1044,
251, 1044,
-2, 327,
-1, 741,
245, 1040,
251, 1040,
-2, 327,
-1, 743,
114, 999,
245, 999,
251, 999,
-2, 291,
-1, 744,
114, 1092,
245, 1092,
251, 1092,
-2, 292,
-1, 745,
114, 1042,
245, 1042,
251, 1042,
-2, 293,
-1, 746,
114, 1039,
245, 1039,
251, 1039,
-2, 294,
-1, 747,
114, 1031,
245, 1031,
251, 1031,
-2, 295,
-1, 749,
114, 1101,
245, 1101,
251, 1101,
-2, 297,
-1, 752,
114, 1012,
245, 1012,
251, 1012,
-2, 267,
-1, 753,
114, 1090,
245, 1090,
251, 1090,
-2, 310,
-1, 754,
114, 1091,
245, 1091,
251, 1091,
-2, 310,
-1, 755,
114, 1013,
245, 1013,
251, 1013,
-2, 310,
-1, 756,
114, 1014,
245, 1014,
251, 1014,
-2, 271,
-1, 757,
114, 1015,
245, 1015,
251, 1015,
-2, 310,
-1, 758,
114, 1081,
245, 1081,
251, 1081,
-2, 273,
-1, 759,
114, 1115,
245, 1115,
251, 1115,
-2, 274,
-1, 760,
114, 1023,
245, 1023,
251, 1023,
-2, 300,
-1, 761,
114, 1060,
245, 1060,
251, 1060,
-2, 301,
-1, 762,
114, 1038,
245, 1038,
251, 1038,
-2, 302,
-1, 763,
114, 1061,
245, 1061,