6137 lines
169 KiB
Go
Raw Normal View History

//line sql.y:18
package sqlparser
import __yyfmt__ "fmt"
//line sql.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 sql.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
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
tableIdent TableIdent
convertType *ConvertType
aliasedTableName *AliasedTableExpr
TableSpec *TableSpec
columnType ColumnType
colKeyOpt ColumnKeyOption
optVal *SQLVal
LengthScaleOption LengthScaleOption
columnDefinition *ColumnDefinition
indexDefinition *IndexDefinition
indexInfo *IndexInfo
indexOption *IndexOption
indexOptions []*IndexOption
indexColumn *IndexColumn
indexColumns []*IndexColumn
partDefs []*PartitionDefinition
partDef *PartitionDefinition
partSpec *PartitionSpec
vindexParam VindexParam
vindexParams []VindexParam
showFilter *ShowFilter
}
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 ALL = 57362
const DISTINCT = 57363
const AS = 57364
const EXISTS = 57365
const ASC = 57366
const DESC = 57367
const INTO = 57368
const DUPLICATE = 57369
const KEY = 57370
const DEFAULT = 57371
const SET = 57372
const LOCK = 57373
const KEYS = 57374
const VALUES = 57375
const LAST_INSERT_ID = 57376
const NEXT = 57377
const VALUE = 57378
const SHARE = 57379
const MODE = 57380
const SQL_NO_CACHE = 57381
const SQL_CACHE = 57382
const JOIN = 57383
const STRAIGHT_JOIN = 57384
const LEFT = 57385
const RIGHT = 57386
const INNER = 57387
const OUTER = 57388
const CROSS = 57389
const NATURAL = 57390
const USE = 57391
const FORCE = 57392
const ON = 57393
const USING = 57394
const ID = 57395
const HEX = 57396
const STRING = 57397
const INTEGRAL = 57398
const FLOAT = 57399
const HEXNUM = 57400
const VALUE_ARG = 57401
const LIST_ARG = 57402
const COMMENT = 57403
const COMMENT_KEYWORD = 57404
const BIT_LITERAL = 57405
const NULL = 57406
const TRUE = 57407
const FALSE = 57408
const OR = 57409
const AND = 57410
const NOT = 57411
const BETWEEN = 57412
const CASE = 57413
const WHEN = 57414
const THEN = 57415
const ELSE = 57416
const END = 57417
const LE = 57418
const GE = 57419
const NE = 57420
const NULL_SAFE_EQUAL = 57421
const IS = 57422
const LIKE = 57423
const REGEXP = 57424
const IN = 57425
const SHIFT_LEFT = 57426
const SHIFT_RIGHT = 57427
const DIV = 57428
const MOD = 57429
const UNARY = 57430
const COLLATE = 57431
const BINARY = 57432
const UNDERSCORE_BINARY = 57433
const INTERVAL = 57434
const JSON_EXTRACT_OP = 57435
const JSON_UNQUOTE_EXTRACT_OP = 57436
const CREATE = 57437
const ALTER = 57438
const DROP = 57439
const RENAME = 57440
const ANALYZE = 57441
const ADD = 57442
const SCHEMA = 57443
const TABLE = 57444
const INDEX = 57445
const VIEW = 57446
const TO = 57447
const IGNORE = 57448
const IF = 57449
const UNIQUE = 57450
const PRIMARY = 57451
const COLUMN = 57452
const CONSTRAINT = 57453
const SPATIAL = 57454
const FULLTEXT = 57455
const FOREIGN = 57456
const KEY_BLOCK_SIZE = 57457
const SHOW = 57458
const DESCRIBE = 57459
const EXPLAIN = 57460
const DATE = 57461
const ESCAPE = 57462
const REPAIR = 57463
const OPTIMIZE = 57464
const TRUNCATE = 57465
const MAXVALUE = 57466
const PARTITION = 57467
const REORGANIZE = 57468
const LESS = 57469
const THAN = 57470
const PROCEDURE = 57471
const TRIGGER = 57472
const VINDEX = 57473
const VINDEXES = 57474
const STATUS = 57475
const VARIABLES = 57476
const BEGIN = 57477
const START = 57478
const TRANSACTION = 57479
const COMMIT = 57480
const ROLLBACK = 57481
const BIT = 57482
const TINYINT = 57483
const SMALLINT = 57484
const MEDIUMINT = 57485
const INT = 57486
const INTEGER = 57487
const BIGINT = 57488
const INTNUM = 57489
const REAL = 57490
const DOUBLE = 57491
const FLOAT_TYPE = 57492
const DECIMAL = 57493
const NUMERIC = 57494
const TIME = 57495
const TIMESTAMP = 57496
const DATETIME = 57497
const YEAR = 57498
const CHAR = 57499
const VARCHAR = 57500
const BOOL = 57501
const CHARACTER = 57502
const VARBINARY = 57503
const NCHAR = 57504
const TEXT = 57505
const TINYTEXT = 57506
const MEDIUMTEXT = 57507
const LONGTEXT = 57508
const BLOB = 57509
const TINYBLOB = 57510
const MEDIUMBLOB = 57511
const LONGBLOB = 57512
const JSON = 57513
const ENUM = 57514
const GEOMETRY = 57515
const POINT = 57516
const LINESTRING = 57517
const POLYGON = 57518
const GEOMETRYCOLLECTION = 57519
const MULTIPOINT = 57520
const MULTILINESTRING = 57521
const MULTIPOLYGON = 57522
const NULLX = 57523
const AUTO_INCREMENT = 57524
const APPROXNUM = 57525
const SIGNED = 57526
const UNSIGNED = 57527
const ZEROFILL = 57528
const DATABASES = 57529
const TABLES = 57530
const VITESS_KEYSPACES = 57531
const VITESS_SHARDS = 57532
const VITESS_TABLETS = 57533
const VSCHEMA_TABLES = 57534
const EXTENDED = 57535
const FULL = 57536
const PROCESSLIST = 57537
const NAMES = 57538
const CHARSET = 57539
const GLOBAL = 57540
const SESSION = 57541
const ISOLATION = 57542
const LEVEL = 57543
const READ = 57544
const WRITE = 57545
const ONLY = 57546
const REPEATABLE = 57547
const COMMITTED = 57548
const UNCOMMITTED = 57549
const SERIALIZABLE = 57550
const CURRENT_TIMESTAMP = 57551
const DATABASE = 57552
const CURRENT_DATE = 57553
const CURRENT_TIME = 57554
const LOCALTIME = 57555
const LOCALTIMESTAMP = 57556
const UTC_DATE = 57557
const UTC_TIME = 57558
const UTC_TIMESTAMP = 57559
const REPLACE = 57560
const CONVERT = 57561
const CAST = 57562
const SUBSTR = 57563
const SUBSTRING = 57564
const GROUP_CONCAT = 57565
const SEPARATOR = 57566
const MATCH = 57567
const AGAINST = 57568
const BOOLEAN = 57569
const LANGUAGE = 57570
const WITH = 57571
const QUERY = 57572
const EXPANSION = 57573
const UNUSED = 57574
var yyToknames = [...]string{
"$end",
"error",
"$unk",
"LEX_ERROR",
"UNION",
"SELECT",
"STREAM",
"INSERT",
"UPDATE",
"DELETE",
"FROM",
"WHERE",
"GROUP",
"HAVING",
"ORDER",
"BY",
"LIMIT",
"OFFSET",
"FOR",
"ALL",
"DISTINCT",
"AS",
"EXISTS",
"ASC",
"DESC",
"INTO",
"DUPLICATE",
"KEY",
"DEFAULT",
"SET",
"LOCK",
"KEYS",
"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",
"OR",
"AND",
"NOT",
"'!'",
"BETWEEN",
"CASE",
"WHEN",
"THEN",
"ELSE",
"END",
"'='",
"'<'",
"'>'",
"LE",
"GE",
"NE",
"NULL_SAFE_EQUAL",
"IS",
"LIKE",
"REGEXP",
"IN",
"'|'",
"'&'",
"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",
"VIEW",
"TO",
"IGNORE",
"IF",
"UNIQUE",
"PRIMARY",
"COLUMN",
"CONSTRAINT",
"SPATIAL",
"FULLTEXT",
"FOREIGN",
"KEY_BLOCK_SIZE",
"SHOW",
"DESCRIBE",
"EXPLAIN",
"DATE",
"ESCAPE",
"REPAIR",
"OPTIMIZE",
"TRUNCATE",
"MAXVALUE",
"PARTITION",
"REORGANIZE",
"LESS",
"THAN",
"PROCEDURE",
"TRIGGER",
"VINDEX",
"VINDEXES",
"STATUS",
"VARIABLES",
"BEGIN",
"START",
"TRANSACTION",
"COMMIT",
"ROLLBACK",
"BIT",
"TINYINT",
"SMALLINT",
"MEDIUMINT",
"INT",
"INTEGER",
"BIGINT",
"INTNUM",
"REAL",
"DOUBLE",
"FLOAT_TYPE",
"DECIMAL",
"NUMERIC",
"TIME",
"TIMESTAMP",
"DATETIME",
"YEAR",
"CHAR",
"VARCHAR",
"BOOL",
"CHARACTER",
"VARBINARY",
"NCHAR",
"TEXT",
"TINYTEXT",
"MEDIUMTEXT",
"LONGTEXT",
"BLOB",
"TINYBLOB",
"MEDIUMBLOB",
"LONGBLOB",
"JSON",
"ENUM",
"GEOMETRY",
"POINT",
"LINESTRING",
"POLYGON",
"GEOMETRYCOLLECTION",
"MULTIPOINT",
"MULTILINESTRING",
"MULTIPOLYGON",
"NULLX",
"AUTO_INCREMENT",
"APPROXNUM",
"SIGNED",
"UNSIGNED",
"ZEROFILL",
"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",
"CURRENT_TIMESTAMP",
"DATABASE",
"CURRENT_DATE",
"CURRENT_TIME",
"LOCALTIME",
"LOCALTIMESTAMP",
"UTC_DATE",
"UTC_TIME",
"UTC_TIMESTAMP",
"REPLACE",
"CONVERT",
"CAST",
"SUBSTR",
"SUBSTRING",
"GROUP_CONCAT",
"SEPARATOR",
"MATCH",
"AGAINST",
"BOOLEAN",
"LANGUAGE",
"WITH",
"QUERY",
"EXPANSION",
"UNUSED",
"';'",
}
var yyStatenames = [...]string{}
const yyEofCode = 1
const yyErrCode = 2
const yyInitialStackSize = 16
//line yacctab:1
var yyExca = [...]int{
-1, 1,
1, -1,
-2, 0,
-1, 3,
5, 27,
-2, 4,
-1, 36,
150, 263,
151, 263,
-2, 253,
-1, 238,
109, 587,
-2, 583,
-1, 239,
109, 588,
-2, 584,
-1, 308,
80, 746,
-2, 58,
-1, 309,
80, 707,
-2, 59,
-1, 314,
80, 691,
-2, 549,
-1, 316,
80, 728,
-2, 551,
-1, 575,
52, 41,
54, 41,
-2, 43,
-1, 708,
109, 590,
-2, 586,
-1, 912,
5, 28,
-2, 395,
-1, 937,
5, 27,
-2, 524,
-1, 1161,
5, 28,
-2, 525,
-1, 1205,
5, 27,
-2, 527,
-1, 1267,
5, 28,
-2, 528,
}
const yyPrivate = 57344
const yyLast = 10949
var yyAct = [...]int{
269, 47, 770, 854, 1258, 522, 646, 1069, 1216, 1097,
810, 1070, 268, 521, 3, 243, 1167, 834, 998, 788,
806, 217, 569, 1066, 809, 53, 848, 771, 956, 1043,
743, 567, 313, 904, 989, 945, 211, 410, 585, 710,
455, 940, 733, 1001, 820, 740, 461, 584, 47, 844,
307, 556, 571, 767, 294, 759, 222, 467, 475, 886,
241, 216, 299, 226, 52, 304, 1287, 1277, 1285, 1265,
302, 1283, 855, 442, 1276, 1061, 1155, 414, 435, 1225,
212, 213, 214, 215, 295, 871, 1103, 1104, 1105, 1091,
230, 1092, 1093, 293, 1108, 1106, 586, 1264, 587, 870,
181, 177, 178, 179, 57, 536, 1240, 488, 487, 497,
498, 490, 491, 492, 493, 494, 495, 496, 489, 964,
801, 499, 963, 802, 803, 965, 875, 245, 450, 59,
60, 61, 62, 63, 980, 869, 827, 310, 675, 1179,
423, 437, 1194, 439, 835, 676, 1144, 1142, 210, 1284,
232, 446, 447, 1282, 1259, 1022, 768, 424, 417, 1217,
1044, 1223, 174, 175, 175, 822, 654, 239, 436, 438,
420, 645, 1219, 822, 789, 791, 955, 954, 953, 412,
189, 176, 1245, 866, 863, 864, 1164, 862, 1030, 298,
1046, 511, 512, 974, 441, 441, 441, 441, 76, 441,
920, 1019, 186, 898, 682, 186, 441, 1021, 479, 180,
430, 1112, 873, 876, 489, 807, 822, 499, 499, 881,
679, 1026, 1048, 47, 1052, 742, 1047, 472, 1045, 186,
186, 76, 1009, 1050, 474, 186, 464, 76, 508, 1218,
1250, 510, 1049, 474, 411, 1122, 463, 868, 790, 434,
473, 472, 943, 588, 1107, 1051, 1053, 821, 1224, 1222,
1007, 1113, 1241, 835, 828, 821, 1063, 474, 520, 867,
524, 525, 526, 527, 528, 529, 530, 531, 532, 760,
535, 537, 537, 537, 537, 537, 537, 537, 537, 545,
546, 547, 548, 1263, 760, 649, 927, 1025, 882, 1020,
568, 1018, 685, 686, 1253, 978, 872, 469, 821, 416,
1009, 717, 236, 819, 817, 1269, 1185, 818, 1184, 874,
426, 427, 428, 453, 1008, 715, 716, 714, 465, 1013,
1010, 1003, 1004, 1011, 1006, 1005, 993, 50, 1007, 992,
824, 916, 186, 915, 186, 825, 1012, 713, 473, 472,
186, 981, 1015, 700, 702, 703, 917, 186, 701, 473,
472, 76, 76, 76, 76, 474, 76, 173, 509, 458,
462, 582, 576, 76, 1270, 1251, 474, 473, 472, 310,
1201, 418, 419, 734, 1065, 735, 480, 538, 539, 540,
541, 542, 543, 544, 474, 895, 896, 897, 1182, 1130,
76, 990, 1008, 1248, 473, 472, 1100, 1013, 1010, 1003,
1004, 1011, 1006, 1005, 441, 1273, 454, 1209, 1256, 454,
523, 474, 441, 1099, 1012, 1209, 454, 298, 292, 534,
1002, 1209, 1210, 441, 441, 441, 441, 441, 441, 441,
441, 1176, 1175, 1088, 454, 1163, 454, 441, 441, 487,
497, 498, 490, 491, 492, 493, 494, 495, 496, 489,
186, 1229, 499, 663, 1119, 1118, 267, 186, 186, 186,
1115, 1116, 1228, 76, 1115, 1114, 1151, 454, 1109, 76,
910, 454, 50, 975, 966, 687, 857, 553, 454, 941,
661, 745, 454, 21, 736, 711, 660, 74, 497, 498,
490, 491, 492, 493, 494, 495, 496, 489, 659, 650,
499, 47, 708, 488, 487, 497, 498, 490, 491, 492,
493, 494, 495, 496, 489, 524, 648, 499, 643, 689,
312, 595, 594, 942, 432, 704, 415, 425, 747, 706,
411, 1067, 579, 681, 941, 752, 755, 54, 745, 221,
23, 761, 1159, 707, 299, 299, 299, 299, 299, 513,
514, 515, 516, 517, 518, 519, 23, 553, 772, 568,
1121, 792, 737, 738, 935, 553, 942, 936, 299, 680,
1117, 76, 747, 580, 967, 578, 910, 186, 186, 76,
757, 186, 764, 1204, 186, 473, 472, 50, 186, 23,
76, 76, 76, 76, 76, 76, 76, 76, 773, 796,
712, 776, 474, 50, 76, 76, 785, 552, 941, 186,
795, 1033, 578, 697, 698, 793, 836, 837, 838, 794,
922, 799, 798, 814, 76, 800, 910, 919, 186, 774,
775, 553, 777, 581, 76, 683, 50, 1189, 829, 441,
849, 441, 1082, 223, 970, 310, 946, 947, 647, 441,
312, 312, 312, 312, 910, 312, 845, 840, 811, 850,
839, 65, 312, 921, 852, 523, 1102, 952, 750, 751,
918, 298, 298, 298, 298, 298, 1067, 76, 994, 846,
847, 558, 561, 562, 563, 559, 298, 560, 564, 477,
50, 946, 947, 949, 657, 298, 451, 695, 899, 492,
493, 494, 495, 496, 489, 708, 951, 499, 186, 779,
778, 186, 186, 186, 186, 186, 782, 711, 888, 780,
887, 783, 883, 186, 781, 784, 186, 562, 563, 805,
186, 227, 228, 1281, 1275, 186, 186, 1029, 1280, 76,
468, 748, 749, 893, 900, 892, 707, 756, 456, 1157,
985, 593, 76, 433, 466, 977, 1255, 1190, 938, 939,
457, 763, 312, 765, 766, 1254, 1202, 971, 590, 859,
656, 937, 258, 257, 260, 261, 262, 263, 688, 566,
468, 259, 264, 218, 709, 1234, 299, 718, 719, 720,
721, 722, 723, 724, 725, 726, 727, 728, 729, 730,
731, 732, 950, 186, 926, 219, 76, 54, 76, 1233,
968, 891, 186, 224, 225, 186, 76, 959, 1192, 890,
942, 884, 885, 470, 462, 1242, 958, 1180, 960, 961,
678, 56, 712, 58, 577, 744, 746, 51, 982, 983,
1, 856, 997, 865, 441, 984, 1257, 986, 987, 988,
1215, 762, 1096, 972, 973, 816, 808, 409, 830, 831,
832, 833, 64, 1249, 815, 991, 1221, 1178, 823, 441,
312, 979, 826, 811, 841, 842, 843, 1101, 312, 1252,
976, 787, 600, 598, 599, 597, 911, 602, 1000, 312,
312, 312, 312, 312, 312, 312, 312, 1014, 601, 596,
197, 928, 305, 312, 312, 558, 561, 562, 563, 559,
894, 560, 564, 298, 565, 589, 851, 471, 66, 999,
1017, 1016, 861, 691, 1024, 1037, 674, 1072, 1068, 47,
880, 1042, 449, 477, 199, 1036, 312, 1055, 507, 1071,
1062, 772, 1073, 708, 1084, 1085, 1086, 772, 889, 1054,
76, 962, 311, 186, 1074, 684, 1077, 909, 1076, 1078,
460, 1232, 1035, 1191, 925, 533, 758, 76, 244, 699,
1095, 256, 253, 924, 1089, 255, 739, 254, 690, 934,
481, 242, 1094, 234, 1058, 297, 753, 753, 549, 557,
555, 1090, 753, 1110, 1111, 490, 491, 492, 493, 494,
495, 496, 489, 554, 948, 499, 944, 296, 1032, 753,
76, 76, 1154, 76, 1239, 694, 25, 55, 901, 902,
903, 229, 19, 18, 299, 17, 20, 16, 1123, 15,
14, 811, 29, 811, 13, 12, 76, 11, 312, 186,
186, 1125, 10, 9, 1128, 8, 7, 186, 6, 5,
907, 312, 1153, 4, 908, 1133, 76, 220, 22, 2,
0, 912, 913, 914, 1132, 1140, 0, 0, 1064, 0,
923, 0, 0, 0, 0, 929, 0, 930, 931, 932,
933, 0, 1158, 1079, 1080, 0, 0, 1081, 0, 1166,
1083, 1169, 1170, 1171, 1035, 968, 76, 76, 0, 0,
1172, 1174, 0, 0, 0, 312, 0, 312, 0, 0,
0, 441, 0, 0, 0, 312, 0, 0, 0, 0,
0, 0, 1181, 1188, 1183, 76, 0, 76, 76, 0,
1187, 0, 0, 0, 0, 0, 0, 0, 0, 312,
0, 0, 0, 0, 0, 0, 1193, 0, 0, 0,
1072, 298, 186, 1206, 0, 0, 0, 0, 811, 0,
76, 1203, 1071, 0, 0, 0, 1205, 1131, 0, 0,
0, 0, 0, 76, 186, 0, 1220, 0, 0, 0,
76, 1231, 1214, 0, 0, 999, 811, 0, 76, 0,
0, 186, 1226, 0, 1227, 1072, 1230, 47, 0, 0,
0, 0, 1243, 0, 0, 0, 1156, 1071, 1039, 1040,
1244, 0, 0, 523, 1247, 0, 0, 0, 0, 0,
0, 1056, 1057, 1041, 1059, 1060, 0, 0, 0, 459,
1261, 0, 0, 0, 0, 1266, 0, 440, 0, 0,
76, 0, 76, 76, 76, 186, 76, 0, 772, 957,
0, 0, 76, 1271, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 184, 1278, 312, 209, 1279, 0,
1087, 0, 0, 0, 0, 1286, 0, 0, 76, 76,
76, 0, 0, 300, 0, 0, 0, 0, 0, 233,
0, 184, 184, 0, 0, 0, 0, 184, 0, 1137,
1138, 0, 1139, 0, 0, 1141, 0, 1143, 0, 995,
312, 0, 312, 0, 0, 0, 0, 0, 183, 0,
0, 76, 76, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 76, 312, 0, 0, 0, 0,
0, 1135, 0, 0, 0, 0, 303, 76, 0, 0,
1134, 413, 0, 1177, 0, 312, 0, 1136, 0, 0,
0, 0, 0, 0, 0, 0, 0, 76, 1145, 1146,
1147, 0, 0, 1150, 1260, 523, 0, 312, 0, 0,
0, 0, 0, 0, 0, 0, 1160, 1161, 1162, 195,
1165, 0, 753, 0, 0, 1075, 957, 0, 753, 0,
0, 0, 0, 76, 184, 0, 184, 0, 0, 0,
0, 0, 184, 205, 0, 0, 0, 76, 0, 184,
0, 0, 0, 0, 312, 0, 312, 1098, 0, 0,
0, 0, 443, 444, 445, 0, 448, 0, 0, 0,
0, 0, 0, 452, 0, 0, 0, 0, 0, 0,
0, 1195, 1196, 0, 1197, 1198, 1199, 0, 421, 1124,
422, 0, 0, 190, 0, 0, 429, 0, 1200, 192,
0, 0, 1126, 431, 0, 0, 198, 194, 0, 1129,
0, 0, 0, 1211, 1212, 1213, 0, 312, 0, 0,
488, 487, 497, 498, 490, 491, 492, 493, 494, 495,
496, 489, 0, 196, 499, 0, 200, 0, 0, 1235,
1236, 1237, 1238, 0, 0, 0, 0, 0, 0, 0,
0, 0, 184, 0, 0, 0, 0, 0, 0, 184,
573, 184, 0, 0, 191, 0, 905, 0, 0, 1168,
0, 1168, 1168, 1168, 0, 1173, 0, 0, 0, 0,
0, 312, 0, 1262, 454, 0, 0, 0, 1267, 0,
0, 193, 1152, 201, 202, 203, 204, 208, 1148, 454,
0, 1272, 207, 206, 0, 0, 551, 312, 312, 312,
0, 0, 0, 0, 0, 575, 0, 0, 0, 1288,
488, 487, 497, 498, 490, 491, 492, 493, 494, 495,
496, 489, 1290, 1291, 499, 488, 487, 497, 498, 490,
491, 492, 493, 494, 495, 496, 489, 0, 0, 499,
1207, 1208, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 1098, 488, 487, 497, 498, 490, 491,
492, 493, 494, 495, 496, 489, 1168, 0, 499, 184,
184, 644, 0, 184, 0, 0, 184, 0, 0, 653,
662, 0, 0, 0, 0, 0, 1246, 1038, 0, 0,
664, 665, 666, 667, 668, 669, 670, 671, 0, 0,
0, 184, 0, 0, 672, 673, 0, 488, 487, 497,
498, 490, 491, 492, 493, 494, 495, 496, 489, 753,
184, 499, 1268, 651, 652, 0, 0, 655, 0, 662,
658, 0, 0, 0, 0, 0, 1274, 0, 0, 23,
24, 48, 26, 27, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 677, 0, 1149, 42, 0,
0, 0, 0, 28, 0, 0, 0, 0, 0, 0,
233, 0, 0, 0, 696, 233, 233, 0, 0, 754,
754, 233, 37, 0, 0, 754, 50, 0, 0, 0,
0, 0, 0, 0, 0, 233, 233, 233, 233, 0,
184, 0, 754, 184, 184, 184, 184, 184, 0, 0,
0, 0, 0, 0, 0, 786, 0, 0, 184, 0,
0, 0, 573, 0, 0, 0, 0, 184, 184, 488,
487, 497, 498, 490, 491, 492, 493, 494, 495, 496,
489, 0, 0, 499, 0, 30, 31, 33, 32, 35,
0, 0, 0, 0, 769, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 36, 43, 44, 0,
0, 45, 46, 34, 0, 0, 0, 0, 0, 0,
0, 0, 797, 0, 0, 38, 39, 0, 40, 41,
0, 0, 0, 0, 0, 184, 617, 0, 0, 0,
0, 483, 0, 486, 184, 0, 858, 184, 860, 500,
501, 502, 503, 504, 505, 506, 879, 484, 485, 482,
488, 487, 497, 498, 490, 491, 492, 493, 494, 495,
496, 489, 662, 0, 499, 0, 0, 0, 0, 0,
0, 0, 0, 0, 233, 0, 0, 0, 0, 853,
0, 0, 0, 906, 0, 0, 0, 0, 877, 0,
0, 878, 0, 0, 0, 0, 0, 0, 49, 0,
0, 0, 605, 488, 487, 497, 498, 490, 491, 492,
493, 494, 495, 496, 489, 0, 0, 499, 0, 0,
0, 233, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 618, 0, 0, 0, 0, 233, 488, 487,
497, 498, 490, 491, 492, 493, 494, 495, 496, 489,
0, 0, 499, 631, 632, 633, 634, 635, 636, 637,
0, 638, 639, 640, 641, 642, 619, 620, 621, 622,
603, 604, 0, 0, 606, 184, 607, 608, 609, 610,
611, 612, 613, 614, 615, 616, 623, 624, 625, 626,
627, 628, 629, 630, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 996, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 1027, 1028, 0, 0, 0, 1023, 0, 0, 184,
0, 0, 0, 0, 0, 0, 0, 0, 0, 233,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
233, 0, 0, 0, 0, 0, 0, 0, 0, 0,
662, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 754, 0, 0, 0, 0,
0, 754, 0, 1031, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 184, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 184, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 184, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1120, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
1127, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 573, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 1186, 0,
0, 398, 388, 0, 360, 400, 338, 352, 408, 353,
354, 381, 324, 368, 125, 350, 0, 341, 319, 347,
320, 339, 362, 93, 365, 337, 390, 371, 107, 406,
109, 376, 0, 142, 118, 0, 0, 364, 392, 366,
386, 359, 382, 329, 375, 401, 351, 379, 402, 0,
0, 0, 75, 0, 812, 813, 0, 0, 0, 0,
0, 86, 0, 378, 397, 349, 380, 318, 377, 0,
322, 325, 407, 395, 344, 345, 969, 0, 0, 0,
0, 0, 0, 363, 367, 383, 357, 0, 0, 0,
0, 0, 0, 0, 0, 342, 0, 374, 0, 0,
0, 326, 323, 0, 361, 0, 0, 0, 328, 0,
343, 384, 754, 317, 387, 393, 358, 187, 396, 356,
355, 399, 131, 0, 0, 145, 98, 97, 106, 391,
340, 348, 89, 346, 137, 127, 157, 373, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 321, 0, 143, 159, 172,
336, 394, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 332, 335, 330, 331, 369, 370, 403, 404,
405, 385, 327, 0, 333, 334, 0, 389, 372, 77,
0, 108, 169, 133, 95, 160, 398, 388, 0, 360,
400, 338, 352, 408, 353, 354, 381, 324, 368, 125,
350, 0, 341, 319, 347, 320, 339, 362, 93, 365,
337, 390, 371, 107, 406, 109, 376, 0, 142, 118,
0, 0, 364, 392, 366, 386, 359, 382, 329, 375,
401, 351, 379, 402, 0, 0, 0, 75, 0, 812,
813, 0, 0, 0, 0, 0, 86, 0, 378, 397,
349, 380, 318, 377, 0, 322, 325, 407, 395, 344,
345, 0, 0, 0, 0, 0, 0, 0, 363, 367,
383, 357, 0, 0, 0, 0, 0, 0, 0, 0,
342, 0, 374, 0, 0, 0, 326, 323, 0, 361,
0, 0, 0, 328, 0, 343, 384, 0, 317, 387,
393, 358, 187, 396, 356, 355, 399, 131, 0, 0,
145, 98, 97, 106, 391, 340, 348, 89, 346, 137,
127, 157, 373, 128, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 155, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 84, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
321, 0, 143, 159, 172, 336, 394, 165, 166, 167,
168, 0, 0, 0, 122, 85, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 332, 335, 330,
331, 369, 370, 403, 404, 405, 385, 327, 0, 333,
334, 0, 389, 372, 77, 0, 108, 169, 133, 95,
160, 398, 388, 0, 360, 400, 338, 352, 408, 353,
354, 381, 324, 368, 125, 350, 0, 341, 319, 347,
320, 339, 362, 93, 365, 337, 390, 371, 107, 406,
109, 376, 0, 142, 118, 0, 0, 364, 392, 366,
386, 359, 382, 329, 375, 401, 351, 379, 402, 50,
0, 0, 75, 0, 0, 0, 0, 0, 0, 0,
0, 86, 0, 378, 397, 349, 380, 318, 377, 0,
322, 325, 407, 395, 344, 345, 0, 0, 0, 0,
0, 0, 0, 363, 367, 383, 357, 0, 0, 0,
0, 0, 0, 0, 0, 342, 0, 374, 0, 0,
0, 326, 323, 0, 361, 0, 0, 0, 328, 0,
343, 384, 0, 317, 387, 393, 358, 187, 396, 356,
355, 399, 131, 0, 0, 145, 98, 97, 106, 391,
340, 348, 89, 346, 137, 127, 157, 373, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 321, 0, 143, 159, 172,
336, 394, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 332, 335, 330, 331, 369, 370, 403, 404,
405, 385, 327, 0, 333, 334, 0, 389, 372, 77,
0, 108, 169, 133, 95, 160, 398, 388, 0, 360,
400, 338, 352, 408, 353, 354, 381, 324, 368, 125,
350, 0, 341, 319, 347, 320, 339, 362, 93, 365,
337, 390, 371, 107, 406, 109, 376, 0, 142, 118,
0, 0, 364, 392, 366, 386, 359, 382, 329, 375,
401, 351, 379, 402, 0, 0, 0, 75, 0, 0,
0, 0, 0, 0, 0, 0, 86, 0, 378, 397,
349, 380, 318, 377, 0, 322, 325, 407, 395, 344,
345, 0, 0, 0, 0, 0, 0, 0, 363, 367,
383, 357, 0, 0, 0, 0, 0, 0, 1034, 0,
342, 0, 374, 0, 0, 0, 326, 323, 0, 361,
0, 0, 0, 328, 0, 343, 384, 0, 317, 387,
393, 358, 187, 396, 356, 355, 399, 131, 0, 0,
145, 98, 97, 106, 391, 340, 348, 89, 346, 137,
127, 157, 373, 128, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 155, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 84, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
321, 0, 143, 159, 172, 336, 394, 165, 166, 167,
168, 0, 0, 0, 122, 85, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 332, 335, 330,
331, 369, 370, 403, 404, 405, 385, 327, 0, 333,
334, 0, 389, 372, 77, 0, 108, 169, 133, 95,
160, 398, 388, 0, 360, 400, 338, 352, 408, 353,
354, 381, 324, 368, 125, 350, 0, 341, 319, 347,
320, 339, 362, 93, 365, 337, 390, 371, 107, 406,
109, 376, 0, 142, 118, 0, 0, 364, 392, 366,
386, 359, 382, 329, 375, 401, 351, 379, 402, 0,
0, 0, 238, 0, 0, 0, 0, 0, 0, 0,
0, 86, 0, 378, 397, 349, 380, 318, 377, 0,
322, 325, 407, 395, 344, 345, 0, 0, 0, 0,
0, 0, 0, 363, 367, 383, 357, 0, 0, 0,
0, 0, 0, 705, 0, 342, 0, 374, 0, 0,
0, 326, 323, 0, 361, 0, 0, 0, 328, 0,
343, 384, 0, 317, 387, 393, 358, 187, 396, 356,
355, 399, 131, 0, 0, 145, 98, 97, 106, 391,
340, 348, 89, 346, 137, 127, 157, 373, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 321, 0, 143, 159, 172,
336, 394, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 332, 335, 330, 331, 369, 370, 403, 404,
405, 385, 327, 0, 333, 334, 0, 389, 372, 77,
0, 108, 169, 133, 95, 160, 398, 388, 0, 360,
400, 338, 352, 408, 353, 354, 381, 324, 368, 125,
350, 0, 341, 319, 347, 320, 339, 362, 93, 365,
337, 390, 371, 107, 406, 109, 376, 0, 142, 118,
0, 0, 364, 392, 366, 386, 359, 382, 329, 375,
401, 351, 379, 402, 0, 0, 0, 75, 0, 0,
0, 0, 0, 0, 0, 0, 86, 0, 378, 397,
349, 380, 318, 377, 0, 322, 325, 407, 395, 344,
345, 0, 0, 0, 0, 0, 0, 0, 363, 367,
383, 357, 0, 0, 0, 0, 0, 0, 0, 0,
342, 0, 374, 0, 0, 0, 326, 323, 0, 361,
0, 0, 0, 328, 0, 343, 384, 0, 317, 387,
393, 358, 187, 396, 356, 355, 399, 131, 0, 0,
145, 98, 97, 106, 391, 340, 348, 89, 346, 137,
127, 157, 373, 128, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 155, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 84, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
321, 0, 143, 159, 172, 336, 394, 165, 166, 167,
168, 0, 0, 0, 122, 85, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 332, 335, 330,
331, 369, 370, 403, 404, 405, 385, 327, 0, 333,
334, 0, 389, 372, 77, 0, 108, 169, 133, 95,
160, 398, 388, 0, 360, 400, 338, 352, 408, 353,
354, 381, 324, 368, 125, 350, 0, 341, 319, 347,
320, 339, 362, 93, 365, 337, 390, 371, 107, 406,
109, 376, 0, 142, 118, 0, 0, 364, 392, 366,
386, 359, 382, 329, 375, 401, 351, 379, 402, 0,
0, 0, 238, 0, 0, 0, 0, 0, 0, 0,
0, 86, 0, 378, 397, 349, 380, 318, 377, 0,
322, 325, 407, 395, 344, 345, 0, 0, 0, 0,
0, 0, 0, 363, 367, 383, 357, 0, 0, 0,
0, 0, 0, 0, 0, 342, 0, 374, 0, 0,
0, 326, 323, 0, 361, 0, 0, 0, 328, 0,
343, 384, 0, 317, 387, 393, 358, 187, 396, 356,
355, 399, 131, 0, 0, 145, 98, 97, 106, 391,
340, 348, 89, 346, 137, 127, 157, 373, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 321, 0, 143, 159, 172,
336, 394, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 332, 335, 330, 331, 369, 370, 403, 404,
405, 385, 327, 0, 333, 334, 0, 389, 372, 77,
0, 108, 169, 133, 95, 160, 398, 388, 0, 360,
400, 338, 352, 408, 353, 354, 381, 324, 368, 125,
350, 0, 341, 319, 347, 320, 339, 362, 93, 365,
337, 390, 371, 107, 406, 109, 376, 0, 142, 118,
0, 0, 364, 392, 366, 386, 359, 382, 329, 375,
401, 351, 379, 402, 0, 0, 0, 75, 0, 0,
0, 0, 0, 0, 0, 0, 86, 0, 378, 397,
349, 380, 318, 377, 0, 322, 325, 407, 395, 344,
345, 0, 0, 0, 0, 0, 0, 0, 363, 367,
383, 357, 0, 0, 0, 0, 0, 0, 0, 0,
342, 0, 374, 0, 0, 0, 326, 323, 0, 361,
0, 0, 0, 328, 0, 343, 384, 0, 317, 387,
393, 358, 187, 396, 356, 355, 399, 131, 0, 0,
145, 98, 97, 106, 391, 340, 348, 89, 346, 137,
127, 157, 373, 128, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 155, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 315, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
321, 0, 143, 159, 172, 336, 394, 165, 166, 167,
168, 0, 0, 0, 316, 314, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 332, 335, 330,
331, 369, 370, 403, 404, 405, 385, 327, 0, 333,
334, 0, 389, 372, 77, 0, 108, 169, 133, 95,
160, 398, 388, 0, 360, 400, 338, 352, 408, 353,
354, 381, 324, 368, 125, 350, 0, 341, 319, 347,
320, 339, 362, 93, 365, 337, 390, 371, 107, 406,
109, 376, 0, 142, 118, 0, 0, 364, 392, 366,
386, 359, 382, 329, 375, 401, 351, 379, 402, 0,
0, 0, 185, 0, 0, 0, 0, 0, 0, 0,
0, 86, 0, 378, 397, 349, 380, 318, 377, 0,
322, 325, 407, 395, 344, 345, 0, 0, 0, 0,
0, 0, 0, 363, 367, 383, 357, 0, 0, 0,
0, 0, 0, 0, 0, 342, 0, 374, 0, 0,
0, 326, 323, 0, 361, 0, 0, 0, 328, 0,
343, 384, 0, 317, 387, 393, 358, 187, 396, 356,
355, 399, 131, 0, 0, 145, 98, 97, 106, 391,
340, 348, 89, 346, 137, 127, 157, 373, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 321, 0, 143, 159, 172,
336, 394, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 332, 335, 330, 331, 369, 370, 403, 404,
405, 385, 327, 0, 333, 334, 0, 389, 372, 77,
0, 108, 169, 133, 95, 160, 398, 388, 0, 360,
400, 338, 352, 408, 353, 354, 381, 324, 368, 125,
350, 0, 341, 319, 347, 320, 339, 362, 93, 365,
337, 390, 371, 107, 406, 109, 376, 0, 142, 118,
0, 0, 364, 392, 366, 386, 359, 382, 329, 375,
401, 351, 379, 402, 0, 0, 0, 75, 0, 0,
0, 0, 0, 0, 0, 0, 86, 0, 378, 397,
349, 380, 318, 377, 0, 322, 325, 407, 395, 344,
345, 0, 0, 0, 0, 0, 0, 0, 363, 367,
383, 357, 0, 0, 0, 0, 0, 0, 0, 0,
342, 0, 374, 0, 0, 0, 326, 323, 0, 361,
0, 0, 0, 328, 0, 343, 384, 0, 317, 387,
393, 358, 187, 396, 356, 355, 399, 131, 0, 0,
145, 98, 97, 106, 391, 340, 348, 89, 346, 137,
127, 157, 373, 128, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 583, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 315, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
321, 0, 143, 159, 172, 336, 394, 165, 166, 167,
168, 0, 0, 0, 316, 314, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 332, 335, 330,
331, 369, 370, 403, 404, 405, 385, 327, 0, 333,
334, 0, 389, 372, 77, 0, 108, 169, 133, 95,
160, 398, 388, 0, 360, 400, 338, 352, 408, 353,
354, 381, 324, 368, 125, 350, 0, 341, 319, 347,
320, 339, 362, 93, 365, 337, 390, 371, 107, 406,
109, 376, 0, 142, 118, 0, 0, 364, 392, 366,
386, 359, 382, 329, 375, 401, 351, 379, 402, 0,
0, 0, 75, 0, 0, 0, 0, 0, 0, 0,
0, 86, 0, 378, 397, 349, 380, 318, 377, 0,
322, 325, 407, 395, 344, 345, 0, 0, 0, 0,
0, 0, 0, 363, 367, 383, 357, 0, 0, 0,
0, 0, 0, 0, 0, 342, 0, 374, 0, 0,
0, 326, 323, 0, 361, 0, 0, 0, 328, 0,
343, 384, 0, 317, 387, 393, 358, 187, 396, 356,
355, 399, 131, 0, 0, 145, 98, 97, 106, 391,
340, 348, 89, 346, 137, 127, 157, 373, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
306, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 315, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 321, 0, 143, 159, 172,
336, 394, 165, 166, 167, 168, 0, 0, 0, 316,
314, 309, 308, 104, 111, 134, 170, 126, 138, 88,
158, 141, 332, 335, 330, 331, 369, 370, 403, 404,
405, 385, 327, 0, 333, 334, 0, 389, 372, 77,
0, 108, 169, 133, 95, 160, 125, 0, 0, 741,
0, 240, 0, 0, 0, 93, 0, 237, 0, 0,
107, 279, 109, 0, 0, 142, 118, 0, 0, 0,
0, 270, 271, 0, 0, 0, 0, 0, 0, 0,
0, 50, 0, 0, 238, 258, 257, 260, 261, 262,
263, 0, 0, 86, 259, 264, 265, 266, 0, 0,
235, 251, 0, 278, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 248, 249, 231, 0, 0, 0, 290,
0, 250, 0, 0, 246, 247, 252, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 187,
0, 0, 288, 0, 131, 0, 0, 145, 98, 97,
106, 0, 0, 0, 89, 0, 137, 127, 157, 0,
128, 136, 110, 149, 132, 156, 188, 164, 147, 163,
78, 146, 155, 87, 139, 80, 153, 144, 116, 102,
103, 79, 0, 135, 92, 96, 91, 124, 150, 151,
90, 171, 83, 162, 82, 84, 161, 123, 148, 154,
117, 114, 81, 152, 115, 113, 105, 94, 99, 129,
112, 130, 100, 120, 119, 121, 0, 0, 0, 143,
159, 172, 0, 0, 165, 166, 167, 168, 0, 0,
0, 122, 85, 101, 140, 104, 111, 134, 170, 126,
138, 88, 158, 141, 280, 289, 286, 287, 284, 285,
283, 282, 281, 291, 272, 273, 274, 275, 277, 0,
276, 77, 0, 108, 169, 133, 95, 160, 125, 0,
0, 0, 0, 240, 0, 0, 0, 93, 0, 237,
0, 0, 107, 279, 109, 0, 0, 142, 118, 0,
0, 0, 0, 270, 271, 0, 0, 0, 0, 0,
0, 0, 0, 50, 0, 454, 238, 258, 257, 260,
261, 262, 263, 0, 0, 86, 259, 264, 265, 266,
0, 0, 235, 251, 0, 278, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 248, 249, 0, 0, 0,
0, 290, 0, 250, 0, 0, 246, 247, 252, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 187, 0, 0, 288, 0, 131, 0, 0, 145,
98, 97, 106, 0, 0, 0, 89, 0, 137, 127,
157, 0, 128, 136, 110, 149, 132, 156, 188, 164,
147, 163, 78, 146, 155, 87, 139, 80, 153, 144,
116, 102, 103, 79, 0, 135, 92, 96, 91, 124,
150, 151, 90, 171, 83, 162, 82, 84, 161, 123,
148, 154, 117, 114, 81, 152, 115, 113, 105, 94,
99, 129, 112, 130, 100, 120, 119, 121, 0, 0,
0, 143, 159, 172, 0, 0, 165, 166, 167, 168,
0, 0, 0, 122, 85, 101, 140, 104, 111, 134,
170, 126, 138, 88, 158, 141, 280, 289, 286, 287,
284, 285, 283, 282, 281, 291, 272, 273, 274, 275,
277, 0, 276, 77, 0, 108, 169, 133, 95, 160,
125, 0, 0, 0, 0, 240, 0, 0, 0, 93,
0, 237, 0, 0, 107, 279, 109, 0, 0, 142,
118, 0, 0, 0, 0, 270, 271, 0, 0, 0,
0, 0, 0, 0, 0, 50, 0, 0, 238, 258,
257, 260, 261, 262, 263, 0, 0, 86, 259, 264,
265, 266, 0, 0, 235, 251, 0, 278, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 248, 249, 231,
0, 0, 0, 290, 0, 250, 0, 0, 246, 247,
252, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 187, 0, 0, 288, 0, 131, 0,
0, 145, 98, 97, 106, 0, 0, 0, 89, 0,
137, 127, 157, 0, 128, 136, 110, 149, 132, 156,
188, 164, 147, 163, 78, 146, 155, 87, 139, 80,
153, 144, 116, 102, 103, 79, 0, 135, 92, 96,
91, 124, 150, 151, 90, 171, 83, 162, 82, 84,
161, 123, 148, 154, 117, 114, 81, 152, 115, 113,
105, 94, 99, 129, 112, 130, 100, 120, 119, 121,
0, 0, 0, 143, 159, 172, 0, 0, 165, 166,
167, 168, 0, 0, 0, 122, 85, 101, 140, 104,
111, 134, 170, 126, 138, 88, 158, 141, 280, 289,
286, 287, 284, 285, 283, 282, 281, 291, 272, 273,
274, 275, 277, 0, 276, 77, 0, 108, 169, 133,
95, 160, 125, 0, 0, 0, 0, 240, 0, 0,
0, 93, 0, 237, 0, 0, 107, 279, 109, 0,
0, 142, 118, 0, 0, 0, 0, 270, 271, 0,
0, 0, 0, 0, 0, 804, 0, 50, 0, 0,
238, 258, 257, 260, 261, 262, 263, 0, 0, 86,
259, 264, 265, 266, 0, 0, 235, 251, 0, 278,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 248,
249, 0, 0, 0, 0, 290, 0, 250, 0, 0,
246, 247, 252, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 187, 0, 0, 288, 0,
131, 0, 0, 145, 98, 97, 106, 0, 0, 0,
89, 0, 137, 127, 157, 0, 128, 136, 110, 149,
132, 156, 188, 164, 147, 163, 78, 146, 155, 87,
139, 80, 153, 144, 116, 102, 103, 79, 0, 135,
92, 96, 91, 124, 150, 151, 90, 171, 83, 162,
82, 84, 161, 123, 148, 154, 117, 114, 81, 152,
115, 113, 105, 94, 99, 129, 112, 130, 100, 120,
119, 121, 0, 0, 0, 143, 159, 172, 0, 0,
165, 166, 167, 168, 0, 0, 0, 122, 85, 101,
140, 104, 111, 134, 170, 126, 138, 88, 158, 141,
280, 289, 286, 287, 284, 285, 283, 282, 281, 291,
272, 273, 274, 275, 277, 23, 276, 77, 0, 108,
169, 133, 95, 160, 0, 0, 0, 125, 0, 0,
0, 0, 240, 0, 0, 0, 93, 0, 237, 0,
0, 107, 279, 109, 0, 0, 142, 118, 0, 0,
0, 0, 270, 271, 0, 0, 0, 0, 0, 0,
0, 0, 50, 0, 0, 238, 258, 257, 260, 261,
262, 263, 0, 0, 86, 259, 264, 265, 266, 0,
0, 235, 251, 0, 278, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 248, 249, 0, 0, 0, 0,
290, 0, 250, 0, 0, 246, 247, 252, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
187, 0, 0, 288, 0, 131, 0, 0, 145, 98,
97, 106, 0, 0, 0, 89, 0, 137, 127, 157,
0, 128, 136, 110, 149, 132, 156, 188, 164, 147,
163, 78, 146, 155, 87, 139, 80, 153, 144, 116,
102, 103, 79, 0, 135, 92, 96, 91, 124, 150,
151, 90, 171, 83, 162, 82, 84, 161, 123, 148,
154, 117, 114, 81, 152, 115, 113, 105, 94, 99,
129, 112, 130, 100, 120, 119, 121, 0, 0, 0,
143, 159, 172, 0, 0, 165, 166, 167, 168, 0,
0, 0, 122, 85, 101, 140, 104, 111, 134, 170,
126, 138, 88, 158, 141, 280, 289, 286, 287, 284,
285, 283, 282, 281, 291, 272, 273, 274, 275, 277,
0, 276, 77, 0, 108, 169, 133, 95, 160, 125,
0, 0, 0, 0, 240, 0, 0, 0, 93, 0,
237, 0, 0, 107, 279, 109, 0, 0, 142, 118,
0, 0, 0, 0, 270, 271, 0, 0, 0, 0,
0, 0, 0, 0, 50, 0, 0, 238, 258, 257,
260, 261, 262, 263, 0, 0, 86, 259, 264, 265,
266, 0, 0, 235, 251, 0, 278, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 248, 249, 0, 0,
0, 0, 290, 0, 250, 0, 0, 246, 247, 252,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 187, 0, 0, 288, 0, 131, 0, 0,
145, 98, 97, 106, 0, 0, 0, 89, 0, 137,
127, 157, 0, 128, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 155, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 84, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
0, 0, 143, 159, 172, 0, 0, 165, 166, 167,
168, 0, 0, 0, 122, 85, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 280, 289, 286,
287, 284, 285, 283, 282, 281, 291, 272, 273, 274,
275, 277, 125, 276, 77, 0, 108, 169, 133, 95,
160, 93, 0, 0, 0, 0, 107, 279, 109, 0,
0, 142, 118, 0, 0, 0, 0, 270, 271, 0,
0, 0, 0, 0, 0, 0, 0, 50, 0, 0,
238, 258, 257, 260, 261, 262, 263, 0, 0, 86,
259, 264, 265, 266, 0, 0, 0, 251, 0, 278,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 248,
249, 0, 0, 0, 0, 290, 0, 250, 0, 0,
246, 247, 252, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 187, 0, 0, 288, 0,
131, 0, 0, 145, 98, 97, 106, 0, 0, 0,
89, 0, 137, 127, 157, 1289, 128, 136, 110, 149,
132, 156, 188, 164, 147, 163, 78, 146, 155, 87,
139, 80, 153, 144, 116, 102, 103, 79, 0, 135,
92, 96, 91, 124, 150, 151, 90, 171, 83, 162,
82, 84, 161, 123, 148, 154, 117, 114, 81, 152,
115, 113, 105, 94, 99, 129, 112, 130, 100, 120,
119, 121, 0, 0, 0, 143, 159, 172, 0, 0,
165, 166, 167, 168, 0, 0, 0, 122, 85, 101,
140, 104, 111, 134, 170, 126, 138, 88, 158, 141,
280, 289, 286, 287, 284, 285, 283, 282, 281, 291,
272, 273, 274, 275, 277, 125, 276, 77, 0, 108,
169, 133, 95, 160, 93, 0, 0, 0, 0, 107,
279, 109, 0, 0, 142, 118, 0, 0, 0, 0,
270, 271, 0, 0, 0, 0, 0, 0, 0, 0,
50, 0, 0, 238, 258, 257, 260, 261, 262, 263,
0, 0, 86, 259, 264, 265, 266, 0, 0, 0,
251, 0, 278, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 248, 249, 0, 0, 0, 0, 290, 0,
250, 0, 0, 246, 247, 252, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 187, 0,
0, 288, 0, 131, 0, 0, 145, 98, 97, 106,
0, 0, 0, 89, 0, 137, 127, 157, 0, 128,
136, 110, 149, 132, 156, 188, 164, 147, 163, 78,
146, 155, 87, 139, 80, 153, 144, 116, 102, 103,
79, 0, 135, 92, 96, 91, 124, 150, 151, 90,
171, 83, 162, 82, 84, 161, 123, 148, 154, 117,
114, 81, 152, 115, 113, 105, 94, 99, 129, 112,
130, 100, 120, 119, 121, 0, 0, 0, 143, 159,
172, 0, 0, 165, 166, 167, 168, 0, 0, 0,
122, 85, 101, 140, 104, 111, 134, 170, 126, 138,
88, 158, 141, 280, 289, 286, 287, 284, 285, 283,
282, 281, 291, 272, 273, 274, 275, 277, 125, 276,
77, 0, 108, 169, 133, 95, 160, 93, 0, 0,
0, 0, 107, 0, 109, 0, 0, 142, 118, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 75, 0, 0, 0,
0, 0, 0, 0, 0, 86, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 488, 487, 497, 498, 490, 491, 492, 493, 494,
495, 496, 489, 0, 0, 499, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 187, 0, 0, 0, 0, 131, 0, 0, 145,
98, 97, 106, 0, 0, 0, 89, 0, 137, 127,
157, 0, 128, 136, 110, 149, 132, 156, 188, 164,
147, 163, 78, 146, 155, 87, 139, 80, 153, 144,
116, 102, 103, 79, 0, 135, 92, 96, 91, 124,
150, 151, 90, 171, 83, 162, 82, 84, 161, 123,
148, 154, 117, 114, 81, 152, 115, 113, 105, 94,
99, 129, 112, 130, 100, 120, 119, 121, 0, 0,
0, 143, 159, 172, 0, 0, 165, 166, 167, 168,
0, 0, 0, 122, 85, 101, 140, 104, 111, 134,
170, 126, 138, 88, 158, 141, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 77, 0, 108, 169, 133, 95, 160,
125, 0, 0, 0, 476, 0, 0, 0, 0, 93,
0, 0, 0, 0, 107, 0, 109, 0, 0, 142,
118, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 75, 0,
478, 0, 0, 0, 0, 0, 0, 86, 0, 0,
0, 0, 473, 472, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 474,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 187, 0, 0, 0, 0, 131, 0,
0, 145, 98, 97, 106, 0, 0, 0, 89, 0,
137, 127, 157, 0, 128, 136, 110, 149, 132, 156,
188, 164, 147, 163, 78, 146, 155, 87, 139, 80,
153, 144, 116, 102, 103, 79, 0, 135, 92, 96,
91, 124, 150, 151, 90, 171, 83, 162, 82, 84,
161, 123, 148, 154, 117, 114, 81, 152, 115, 113,
105, 94, 99, 129, 112, 130, 100, 120, 119, 121,
0, 0, 0, 143, 159, 172, 0, 0, 165, 166,
167, 168, 0, 0, 0, 122, 85, 101, 140, 104,
111, 134, 170, 126, 138, 88, 158, 141, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 125, 0, 77, 0, 108, 169, 133,
95, 160, 93, 0, 0, 0, 0, 107, 0, 109,
0, 0, 142, 118, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 75, 0, 0, 0, 0, 0, 0, 0, 0,
86, 0, 0, 0, 0, 68, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 71, 72, 0, 67, 0, 0, 0,
73, 131, 0, 0, 145, 98, 97, 106, 0, 0,
0, 89, 0, 137, 127, 157, 0, 128, 136, 110,
149, 132, 156, 69, 164, 147, 163, 78, 146, 155,
87, 139, 80, 153, 144, 116, 102, 103, 79, 0,
135, 92, 96, 91, 124, 150, 151, 90, 171, 83,
162, 82, 84, 161, 123, 148, 154, 117, 114, 81,
152, 115, 113, 105, 94, 99, 129, 112, 130, 100,
120, 119, 121, 0, 0, 0, 143, 159, 172, 0,
0, 165, 166, 167, 168, 0, 0, 0, 122, 85,
101, 140, 104, 111, 134, 170, 126, 138, 88, 158,
141, 0, 70, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 77, 0,
108, 169, 133, 95, 160, 125, 0, 0, 0, 572,
0, 0, 0, 0, 93, 0, 0, 0, 0, 107,
0, 109, 0, 0, 142, 118, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 185, 0, 574, 0, 0, 0, 0,
0, 0, 86, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 187, 0,
0, 0, 0, 131, 0, 0, 145, 98, 97, 106,
0, 0, 0, 89, 0, 137, 127, 157, 0, 128,
136, 110, 149, 132, 156, 188, 164, 147, 163, 78,
146, 155, 87, 139, 80, 153, 144, 116, 102, 103,
79, 0, 135, 92, 96, 91, 124, 150, 151, 90,
171, 83, 162, 82, 84, 161, 123, 148, 154, 117,
114, 81, 152, 115, 113, 105, 94, 99, 129, 112,
130, 100, 120, 119, 121, 0, 0, 0, 143, 159,
172, 0, 0, 165, 166, 167, 168, 0, 0, 0,
122, 85, 101, 140, 104, 111, 134, 170, 126, 138,
88, 158, 141, 0, 0, 0, 23, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 125, 0,
77, 0, 108, 169, 133, 95, 160, 93, 0, 0,
0, 0, 107, 0, 109, 0, 0, 142, 118, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 50, 0, 0, 75, 0, 0, 0,
0, 0, 0, 0, 0, 86, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 187, 0, 0, 0, 0, 131, 0, 0, 145,
98, 97, 106, 0, 0, 0, 89, 0, 137, 127,
157, 0, 128, 136, 110, 149, 132, 156, 188, 164,
147, 163, 78, 146, 155, 87, 139, 80, 153, 144,
116, 102, 103, 79, 0, 135, 92, 96, 91, 124,
150, 151, 90, 171, 83, 162, 82, 84, 161, 123,
148, 154, 117, 114, 81, 152, 115, 113, 105, 94,
99, 129, 112, 130, 100, 120, 119, 121, 0, 0,
0, 143, 159, 172, 0, 0, 165, 166, 167, 168,
0, 0, 0, 122, 85, 101, 140, 104, 111, 134,
170, 126, 138, 88, 158, 141, 0, 0, 0, 23,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 125, 0, 77, 0, 108, 169, 133, 95, 160,
93, 0, 0, 0, 0, 107, 0, 109, 0, 0,
142, 118, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 50, 0, 0, 185,
0, 0, 0, 0, 0, 0, 0, 0, 86, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 187, 0, 0, 0, 0, 131,
0, 0, 145, 98, 97, 106, 0, 0, 0, 89,
0, 137, 127, 157, 0, 128, 136, 110, 149, 132,
156, 188, 164, 147, 163, 78, 146, 155, 87, 139,
80, 153, 144, 116, 102, 103, 79, 0, 135, 92,
96, 91, 124, 150, 151, 90, 171, 83, 162, 82,
84, 161, 123, 148, 154, 117, 114, 81, 152, 115,
113, 105, 94, 99, 129, 112, 130, 100, 120, 119,
121, 0, 0, 0, 143, 159, 172, 0, 0, 165,
166, 167, 168, 0, 0, 0, 122, 85, 101, 140,
104, 111, 134, 170, 126, 138, 88, 158, 141, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 125, 0, 77, 0, 108, 169,
133, 95, 160, 93, 0, 0, 0, 0, 107, 0,
109, 0, 0, 142, 118, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 75, 0, 0, 692, 0, 0, 693, 0,
0, 86, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 187, 0, 0,
0, 0, 131, 0, 0, 145, 98, 97, 106, 0,
0, 0, 89, 0, 137, 127, 157, 0, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 0, 0, 143, 159, 172,
0, 0, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 125, 0, 77,
0, 108, 169, 133, 95, 160, 93, 0, 592, 0,
0, 107, 0, 109, 0, 0, 142, 118, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 75, 0, 591, 0, 0,
0, 0, 0, 0, 86, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
187, 0, 0, 0, 0, 131, 0, 0, 145, 98,
97, 106, 0, 0, 0, 89, 0, 137, 127, 157,
0, 128, 136, 110, 149, 132, 156, 188, 164, 147,
163, 78, 146, 155, 87, 139, 80, 153, 144, 116,
102, 103, 79, 0, 135, 92, 96, 91, 124, 150,
151, 90, 171, 83, 162, 82, 84, 161, 123, 148,
154, 117, 114, 81, 152, 115, 113, 105, 94, 99,
129, 112, 130, 100, 120, 119, 121, 0, 0, 0,
143, 159, 172, 0, 0, 165, 166, 167, 168, 0,
0, 0, 122, 85, 101, 140, 104, 111, 134, 170,
126, 138, 88, 158, 141, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 77, 0, 108, 169, 133, 95, 160, 125,
0, 0, 0, 572, 0, 0, 0, 0, 93, 0,
0, 0, 0, 107, 0, 109, 0, 0, 142, 118,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 185, 0, 574,
0, 0, 0, 0, 0, 0, 86, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 187, 0, 0, 0, 0, 131, 0, 0,
145, 98, 97, 106, 0, 0, 0, 89, 0, 137,
127, 157, 0, 570, 136, 110, 149, 132, 156, 188,
164, 147, 163, 78, 146, 155, 87, 139, 80, 153,
144, 116, 102, 103, 79, 0, 135, 92, 96, 91,
124, 150, 151, 90, 171, 83, 162, 82, 84, 161,
123, 148, 154, 117, 114, 81, 152, 115, 113, 105,
94, 99, 129, 112, 130, 100, 120, 119, 121, 0,
0, 0, 143, 159, 172, 0, 0, 165, 166, 167,
168, 0, 0, 0, 122, 85, 101, 140, 104, 111,
134, 170, 126, 138, 88, 158, 141, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 125, 0, 77, 0, 108, 169, 133, 95,
160, 93, 0, 0, 0, 0, 107, 0, 109, 0,
0, 142, 118, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 50, 0, 0,
185, 0, 0, 0, 0, 0, 0, 0, 0, 86,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 187, 0, 0, 0, 0,
131, 0, 0, 145, 98, 97, 106, 0, 0, 0,
89, 0, 137, 127, 157, 0, 128, 136, 110, 149,
132, 156, 188, 164, 147, 163, 78, 146, 155, 87,
139, 80, 153, 144, 116, 102, 103, 79, 0, 135,
92, 96, 91, 124, 150, 151, 90, 171, 83, 162,
82, 84, 161, 123, 148, 154, 117, 114, 81, 152,
115, 113, 105, 94, 99, 129, 112, 130, 100, 120,
119, 121, 0, 0, 0, 143, 159, 172, 0, 0,
165, 166, 167, 168, 0, 0, 0, 122, 85, 101,
140, 104, 111, 134, 170, 126, 138, 88, 158, 141,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 125, 0, 77, 0, 108,
169, 133, 95, 160, 93, 0, 0, 0, 0, 107,
0, 109, 0, 0, 142, 118, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 185, 0, 574, 0, 0, 0, 0,
0, 0, 86, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 187, 0,
0, 0, 0, 131, 0, 0, 145, 98, 97, 106,
0, 0, 0, 89, 0, 137, 127, 157, 0, 128,
136, 110, 149, 132, 156, 188, 164, 147, 163, 78,
146, 155, 87, 139, 80, 153, 144, 116, 102, 103,
79, 0, 135, 92, 96, 91, 124, 150, 151, 90,
171, 83, 162, 82, 84, 161, 123, 148, 154, 117,
114, 81, 152, 115, 113, 105, 94, 99, 129, 112,
130, 100, 120, 119, 121, 0, 0, 0, 143, 159,
172, 0, 0, 165, 166, 167, 168, 0, 0, 0,
122, 85, 101, 140, 104, 111, 134, 170, 126, 138,
88, 158, 141, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 125, 0,
77, 0, 108, 169, 133, 95, 160, 93, 0, 0,
0, 0, 107, 0, 109, 0, 0, 142, 118, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 75, 0, 478, 0,
0, 0, 0, 0, 0, 86, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 187, 0, 0, 0, 0, 131, 0, 0, 145,
98, 97, 106, 0, 0, 0, 89, 0, 137, 127,
157, 0, 128, 136, 110, 149, 132, 156, 188, 164,
147, 163, 78, 146, 155, 87, 139, 80, 153, 144,
116, 102, 103, 79, 0, 135, 92, 96, 91, 124,
150, 151, 90, 171, 83, 162, 82, 84, 161, 123,
148, 154, 117, 114, 81, 152, 115, 113, 105, 94,
99, 129, 112, 130, 100, 120, 119, 121, 0, 0,
0, 143, 159, 172, 0, 0, 165, 166, 167, 168,
0, 0, 0, 122, 85, 101, 140, 104, 111, 134,
170, 126, 138, 88, 158, 141, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 125, 77, 0, 108, 169, 133, 95, 160,
550, 93, 0, 0, 0, 0, 107, 0, 109, 0,
0, 142, 118, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
185, 0, 0, 0, 0, 0, 0, 0, 0, 86,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 187, 0, 0, 0, 0,
131, 0, 0, 145, 98, 97, 106, 0, 0, 0,
89, 0, 137, 127, 157, 0, 128, 136, 110, 149,
132, 156, 188, 164, 147, 163, 78, 146, 155, 87,
139, 80, 153, 144, 116, 102, 103, 79, 0, 135,
92, 96, 91, 124, 150, 151, 90, 171, 83, 162,
82, 84, 161, 123, 148, 154, 117, 114, 81, 152,
115, 113, 105, 94, 99, 129, 112, 130, 100, 120,
119, 121, 0, 0, 0, 143, 159, 172, 0, 0,
165, 166, 167, 168, 0, 0, 0, 122, 85, 101,
140, 104, 111, 134, 170, 126, 138, 88, 158, 141,
0, 0, 0, 0, 0, 0, 0, 0, 301, 0,
0, 0, 0, 0, 0, 125, 0, 77, 0, 108,
169, 133, 95, 160, 93, 0, 0, 0, 0, 107,
0, 109, 0, 0, 142, 118, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 185, 0, 0, 0, 0, 0, 0,
0, 0, 86, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 187, 0,
0, 0, 0, 131, 0, 0, 145, 98, 97, 106,
0, 0, 0, 89, 0, 137, 127, 157, 0, 128,
136, 110, 149, 132, 156, 188, 164, 147, 163, 78,
146, 155, 87, 139, 80, 153, 144, 116, 102, 103,
79, 0, 135, 92, 96, 91, 124, 150, 151, 90,
171, 83, 162, 82, 84, 161, 123, 148, 154, 117,
114, 81, 152, 115, 113, 105, 94, 99, 129, 112,
130, 100, 120, 119, 121, 0, 0, 0, 143, 159,
172, 0, 0, 165, 166, 167, 168, 0, 0, 0,
122, 85, 101, 140, 104, 111, 134, 170, 126, 138,
88, 158, 141, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 125, 0,
77, 0, 108, 169, 133, 95, 160, 93, 0, 0,
0, 0, 107, 0, 109, 0, 0, 142, 118, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 185, 0, 0, 0,
0, 0, 0, 0, 0, 86, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 182,
0, 187, 0, 0, 0, 0, 131, 0, 0, 145,
98, 97, 106, 0, 0, 0, 89, 0, 137, 127,
157, 0, 128, 136, 110, 149, 132, 156, 188, 164,
147, 163, 78, 146, 155, 87, 139, 80, 153, 144,
116, 102, 103, 79, 0, 135, 92, 96, 91, 124,
150, 151, 90, 171, 83, 162, 82, 84, 161, 123,
148, 154, 117, 114, 81, 152, 115, 113, 105, 94,
99, 129, 112, 130, 100, 120, 119, 121, 0, 0,
0, 143, 159, 172, 0, 0, 165, 166, 167, 168,
0, 0, 0, 122, 85, 101, 140, 104, 111, 134,
170, 126, 138, 88, 158, 141, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 125, 0, 77, 0, 108, 169, 133, 95, 160,
93, 0, 0, 0, 0, 107, 0, 109, 0, 0,
142, 118, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 75,
0, 0, 0, 0, 0, 0, 0, 0, 86, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 187, 0, 0, 0, 0, 131,
0, 0, 145, 98, 97, 106, 0, 0, 0, 89,
0, 137, 127, 157, 0, 128, 136, 110, 149, 132,
156, 188, 164, 147, 163, 78, 146, 155, 87, 139,
80, 153, 144, 116, 102, 103, 79, 0, 135, 92,
96, 91, 124, 150, 151, 90, 171, 83, 162, 82,
84, 161, 123, 148, 154, 117, 114, 81, 152, 115,
113, 105, 94, 99, 129, 112, 130, 100, 120, 119,
121, 0, 0, 0, 143, 159, 172, 0, 0, 165,
166, 167, 168, 0, 0, 0, 122, 85, 101, 140,
104, 111, 134, 170, 126, 138, 88, 158, 141, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 125, 0, 77, 0, 108, 169,
133, 95, 160, 93, 0, 0, 0, 0, 107, 0,
109, 0, 0, 142, 118, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 238, 0, 0, 0, 0, 0, 0, 0,
0, 86, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 187, 0, 0,
0, 0, 131, 0, 0, 145, 98, 97, 106, 0,
0, 0, 89, 0, 137, 127, 157, 0, 128, 136,
110, 149, 132, 156, 188, 164, 147, 163, 78, 146,
155, 87, 139, 80, 153, 144, 116, 102, 103, 79,
0, 135, 92, 96, 91, 124, 150, 151, 90, 171,
83, 162, 82, 84, 161, 123, 148, 154, 117, 114,
81, 152, 115, 113, 105, 94, 99, 129, 112, 130,
100, 120, 119, 121, 0, 0, 0, 143, 159, 172,
0, 0, 165, 166, 167, 168, 0, 0, 0, 122,
85, 101, 140, 104, 111, 134, 170, 126, 138, 88,
158, 141, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 125, 0, 77,
0, 108, 169, 133, 95, 160, 93, 0, 0, 0,
0, 107, 0, 109, 0, 0, 142, 118, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 185, 0, 0, 0, 0,
0, 0, 0, 0, 86, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
187, 0, 0, 0, 0, 131, 0, 0, 145, 98,
97, 106, 0, 0, 0, 89, 0, 137, 127, 157,
0, 128, 136, 110, 149, 132, 156, 188, 164, 147,
163, 78, 146, 155, 87, 139, 80, 153, 144, 116,
102, 103, 79, 0, 135, 92, 96, 91, 124, 150,
151, 90, 171, 83, 162, 82, 84, 161, 123, 148,
154, 117, 114, 81, 152, 115, 113, 105, 94, 99,
129, 112, 130, 100, 120, 119, 121, 0, 0, 0,
143, 159, 172, 0, 0, 165, 166, 167, 168, 0,
0, 0, 122, 85, 101, 140, 104, 111, 134, 170,
126, 138, 88, 158, 141, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 77, 0, 108, 169, 133, 95, 160,
}
var yyPact = [...]int{
1723, -1000, -186, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, 802, 836, -1000, -1000, -1000, -1000, -1000, -1000, 618,
7335, 41, 62, -18, 10030, 61, 1367, 10699, -1000, -6,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, 593, -1000, -1000,
-1000, -1000, -1000, 776, 799, 647, 803, 702, -1000, 5512,
40, 8914, 9807, 4816, -1000, 484, 59, 10699, -158, 10253,
34, 34, 34, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, 51, 10699, -1000, 10699, 33, 481, 33,
33, 33, 10699, -1000, 101, -1000, -1000, -1000, -1000, 10699,
478, 733, 22, 2856, 2856, 2856, 2856, 1, 2856, -83,
655, -1000, -1000, -1000, -1000, 2856, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, 364, 739, 6211, 6211,
802, -1000, 593, -1000, -1000, -1000, 729, -1000, -1000, 243,
822, -1000, 7112, 99, -1000, 6211, 1819, 429, -1000, -1000,
429, -1000, -1000, 81, -1000, -1000, 6657, 6657, 6657, 6657,
6657, 6657, 6657, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, 429, -1000, 5979,
429, 429, 429, 429, 429, 429, 429, 429, 6211, 429,
429, 429, 429, 429, 429, 429, 429, 429, 429, 429,
429, 429, 9584, 587, 874, -1000, -1000, -1000, 767, 8013,
8691, 10699, 531, -1000, 589, 4571, -121, -1000, -1000, -1000,
173, 8459, -1000, -1000, -1000, 731, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 477,
-1000, 1856, 472, 2856, 50, 606, 470, 223, 453, 10699,
10699, 2856, 44, 10699, 757, 653, 10699, 452, 440, -1000,
4326, -1000, 2856, 2856, 2856, 2856, 2856, 2856, 2856, 2856,
-1000, -1000, -1000, -1000, -1000, -1000, 2856, 2856, -1000, -67,
-1000, 10699, -1000, -1000, -1000, -1000, 831, 130, 525, 95,
591, -1000, 278, 776, 364, 702, 8236, 665, -1000, -1000,
10699, -1000, 6211, 6211, 286, -1000, 9360, -1000, -1000, 3346,
147, 6657, 284, 237, 6657, 6657, 6657, 6657, 6657, 6657,
6657, 6657, 6657, 6657, 6657, 6657, 6657, 6657, 6657, 327,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 438, -1000,
593, 725, 725, 113, 113, 113, 113, 113, 113, 6880,
5048, 364, 437, 180, 5979, 5512, 5512, 6211, 6211, 10476,
10476, 5512, 769, 203, 180, 10476, -1000, 364, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, 5512, 5512, 5512, 5512, 14,
10699, -1000, 10476, 8914, 8914, 8914, 8914, 8914, -1000, 679,
678, -1000, 688, 685, 694, 10699, -1000, 433, 8013, 125,
429, -1000, 9137, -1000, -1000, 14, 568, 8914, 10699, -1000,
-1000, 4081, 589, -121, 581, -1000, -98, -97, 5744, 110,
-1000, -1000, -1000, -1000, 2611, 188, 273, -66, -1000, -1000,
-1000, 595, -1000, 595, 595, 595, 595, -33, -33, -33,
-33, -1000, -1000, -1000, -1000, -1000, 617, 614, -1000, 595,
595, 595, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 613, 613,
613, 597, 597, 622, -1000, 10699, -174, 430, 2856, 756,
2856, -1000, 70, -1000, 10699, -1000, -1000, 10699, 2856, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, 208, -1000, -1000, -1000, -1000, 695,
6211, 6211, 3836, 6211, -1000, -1000, -1000, 739, -1000, 769,
810, -1000, 722, 720, 5512, -1000, -1000, 147, 156, -1000,
-1000, 328, -1000, -1000, -1000, -1000, 94, 429, -1000, 1907,
-1000, -1000, -1000, -1000, 284, 6657, 6657, 6657, 1409, 1907,
1872, 405, 357, 113, 612, 612, 112, 112, 112, 112,
112, 910, 910, -1000, -1000, -1000, 364, -1000, -1000, -1000,
364, 5512, 582, -1000, -1000, 6211, -1000, 364, 426, 426,
289, 334, 626, -1000, 91, 619, 426, 5512, 218, -1000,
6211, 364, -1000, 426, 364, 426, 426, 544, 429, -1000,
564, -1000, 172, 874, 605, 652, 650, -1000, -1000, -1000,
-1000, 675, -1000, 636, -1000, -1000, -1000, -1000, -1000, 58,
57, 56, 10253, -1000, 818, 8914, 521, -1000, -1000, 581,
-121, -100, -1000, -1000, -1000, 180, -1000, 428, 530, 2366,
-1000, -1000, -1000, -1000, -1000, -1000, 601, 749, 145, 137,
427, -1000, -1000, 736, -1000, 238, -69, -1000, -1000, 292,
-33, -33, -1000, -1000, 110, 730, 110, 110, 110, 343,
343, -1000, -1000, -1000, -1000, 280, -1000, -1000, -1000, 277,
-1000, 637, 10253, 2856, -1000, 3591, -1000, -1000, -1000, -1000,
-1000, -1000, 282, 204, 179, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, 13, -1000, 2856, -1000,
209, 10699, 10699, 709, 180, 180, 79, -1000, -1000, 10699,
-1000, -1000, -1000, -1000, 610, -1000, -1000, -1000, 3101, 5512,
-1000, 1409, 1907, 1606, -1000, 6657, 6657, -1000, -1000, 426,
5512, 180, -1000, -1000, -1000, 54, 327, 54, 6657, 6657,
3836, 6657, 6657, -168, 532, 187, -1000, 6211, 307, -1000,
-1000, -1000, -1000, -1000, 635, 10476, 429, -1000, 7790, 10253,
802, 10476, 6211, 6211, -1000, -1000, 6211, 599, -1000, 6211,
-1000, -1000, -1000, 429, 429, 429, 389, -1000, 802, 521,
-1000, -1000, -1000, -130, -132, -1000, -1000, 2611, -1000, 2611,
10253, -1000, 367, 350, -1000, -1000, 625, 28, -1000, -1000,
-1000, 423, 110, 110, -1000, 155, -1000, -1000, -1000, 420,
-1000, 416, 526, 410, 10699, -1000, -1000, 516, -1000, 165,
-1000, -1000, 10253, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -1000, 10253, 10699, -1000, -1000, -1000,
-1000, -1000, 10253, -1000, -1000, 341, 6211, -1000, -1000, -1000,
3591, -1000, 818, 8914, -1000, -1000, 364, -1000, 6657, 1907,
1907, -1000, -1000, 364, 595, 595, -1000, 595, 597, -1000,
595, -15, 595, -16, 364, 364, 1524, 1728, -1000, 422,
1553, 429, -165, -1000, 180, 6211, -1000, 732, 490, 498,
-1000, -1000, 5280, 364, 391, 77, 389, 776, -1000, 180,
180, 180, 10253, 180, 10253, 10253, 10253, 7567, 10253, 776,
-1000, -1000, -1000, -1000, 2366, -1000, 387, -1000, 595, -1000,
-1000, -60, 828, -1000, -1000, -1000, -1000, -1000, -1000, -1000,
-1000, -1000, -1000, -1000, -33, 340, -33, 259, -1000, 257,
2856, 3591, 2611, -1000, 594, -1000, -1000, -1000, -1000, 741,
-1000, 180, 815, 513, -1000, 1907, -1000, -1000, 86, -1000,
-1000, -1000, -1000, -1000, -1000, -1000, -1000, -1000, 6657, 6657,
-1000, 6657, 6657, 6657, 364, 322, 180, 748, -1000, 429,
-1000, -1000, 560, 10253, 10253, -1000, -1000, 377, -1000, 371,
371, 371, 125, -1000, -1000, 107, 10253, -1000, 133, -1000,
-147, 110, -1000, 110, 417, 406, -1000, -1000, -1000, 10253,
429, 805, 779, -1000, -1000, 1509, 1509, 1509, 1509, 16,
-1000, -1000, 826, -1000, 429, -1000, 593, 73, -1000, 10253,
-1000, -1000, -1000, -1000, -1000, 107, -1000, 347, 160, 317,
-1000, 239, 747, -1000, 738, -1000, -1000, -1000, -1000, -1000,
363, 12, -1000, 6211, 6211, -1000, -1000, -1000, -1000, 364,
49, -178, 10476, 498, 364, 10253, -1000, -1000, -1000, 256,
-1000, -1000, -1000, 316, -1000, -1000, 606, 361, -1000, 10253,
180, 494, -1000, 706, -171, -181, 435, -1000, -1000, -1000,
-1000, -174, -1000, 12, 715, -1000, 705, -1000, -1000, -1000,
9, -175, 4, -179, 429, -182, 6434, -1000, 1509, 364,
-1000, -1000,
}
var yyPgo = [...]int{
0, 1069, 13, 493, 1068, 1067, 1063, 1059, 1058, 1056,
1055, 1053, 1052, 1047, 1045, 1044, 1042, 1040, 1039, 1037,
1036, 1035, 1033, 1032, 104, 1031, 1027, 1026, 57, 1025,
63, 1024, 1022, 33, 225, 45, 30, 150, 1018, 31,
54, 84, 1017, 35, 1016, 1014, 70, 1013, 51, 1000,
999, 1293, 998, 995, 19, 41, 993, 991, 990, 989,
60, 312, 988, 987, 985, 982, 981, 979, 39, 5,
7, 12, 11, 978, 127, 15, 976, 55, 975, 974,
973, 971, 25, 970, 46, 965, 21, 40, 964, 16,
53, 28, 23, 2, 65, 47, 962, 27, 50, 38,
961, 958, 367, 948, 944, 942, 940, 936, 934, 140,
309, 932, 931, 930, 928, 32, 167, 466, 73, 58,
927, 926, 925, 1239, 59, 52, 22, 924, 36, 1247,
42, 912, 910, 29, 909, 908, 897, 895, 894, 893,
892, 264, 890, 889, 887, 17, 20, 882, 881, 49,
26, 878, 877, 876, 34, 37, 874, 44, 873, 872,
867, 866, 24, 10, 865, 9, 862, 8, 860, 856,
4, 853, 18, 852, 3, 851, 6, 43, 850, 847,
0, 323, 844, 843, 105,
}
var yyR1 = [...]int{
0, 178, 179, 179, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 2, 2, 2, 6, 3, 4, 4, 5,
5, 7, 7, 27, 27, 8, 9, 9, 9, 182,
182, 46, 46, 90, 90, 10, 10, 10, 10, 95,
95, 99, 99, 99, 100, 100, 100, 100, 131, 131,
11, 11, 11, 11, 11, 11, 11, 176, 176, 175,
174, 174, 173, 173, 172, 16, 159, 160, 160, 160,
155, 134, 134, 134, 134, 137, 137, 135, 135, 135,
135, 135, 135, 135, 136, 136, 136, 136, 136, 138,
138, 138, 138, 138, 139, 139, 139, 139, 139, 139,
139, 139, 139, 139, 139, 139, 139, 139, 139, 140,
140, 140, 140, 140, 140, 140, 140, 154, 154, 141,
141, 149, 149, 150, 150, 150, 147, 147, 148, 148,
151, 151, 151, 142, 142, 142, 142, 142, 142, 142,
144, 144, 152, 152, 145, 145, 145, 146, 146, 153,
153, 153, 153, 153, 143, 143, 156, 156, 168, 168,
167, 167, 167, 158, 158, 164, 164, 164, 164, 164,
157, 157, 166, 166, 165, 161, 161, 161, 162, 162,
162, 163, 163, 163, 12, 12, 12, 12, 12, 12,
12, 12, 12, 177, 177, 177, 177, 177, 177, 177,
177, 177, 177, 177, 171, 169, 169, 170, 170, 13,
14, 14, 14, 14, 14, 15, 15, 17, 18, 18,
18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
18, 18, 18, 18, 18, 18, 18, 18, 18, 18,
18, 107, 107, 104, 104, 105, 105, 106, 106, 106,
108, 108, 108, 132, 132, 132, 19, 19, 21, 21,
22, 23, 20, 20, 20, 20, 20, 183, 24, 25,
25, 26, 26, 26, 30, 30, 30, 28, 28, 29,
29, 35, 35, 34, 34, 36, 36, 36, 36, 120,
120, 120, 119, 119, 38, 38, 39, 39, 40, 40,
41, 41, 41, 53, 53, 89, 89, 91, 91, 42,
42, 42, 42, 43, 43, 44, 44, 45, 45, 127,
127, 126, 126, 126, 125, 125, 47, 47, 47, 49,
48, 48, 48, 48, 50, 50, 52, 52, 51, 51,
54, 54, 54, 54, 55, 55, 37, 37, 37, 37,
37, 37, 37, 103, 103, 57, 57, 56, 56, 56,
56, 56, 56, 56, 56, 56, 56, 67, 67, 67,
67, 67, 67, 58, 58, 58, 58, 58, 58, 58,
33, 33, 68, 68, 68, 74, 69, 69, 61, 61,
61, 61, 61, 61, 61, 61, 61, 61, 61, 61,
61, 61, 61, 61, 61, 61, 61, 61, 61, 61,
61, 61, 61, 61, 61, 61, 61, 61, 61, 65,
65, 65, 63, 63, 63, 63, 63, 63, 63, 63,
63, 63, 63, 63, 63, 63, 63, 64, 64, 64,
64, 64, 64, 64, 64, 184, 184, 66, 66, 66,
66, 31, 31, 31, 31, 31, 130, 130, 133, 133,
133, 133, 133, 133, 133, 133, 133, 133, 133, 133,
133, 78, 78, 32, 32, 76, 76, 77, 79, 79,
75, 75, 75, 60, 60, 60, 60, 60, 60, 60,
60, 62, 62, 62, 80, 80, 81, 81, 82, 82,
83, 83, 84, 85, 85, 85, 86, 86, 86, 86,
87, 87, 87, 59, 59, 59, 59, 59, 59, 88,
88, 88, 88, 92, 92, 70, 70, 72, 72, 71,
73, 93, 93, 97, 94, 94, 98, 98, 98, 96,
96, 96, 122, 122, 122, 101, 101, 109, 109, 110,
110, 102, 102, 111, 111, 111, 111, 111, 111, 111,
111, 111, 111, 112, 112, 112, 113, 113, 114, 114,
114, 121, 121, 117, 117, 118, 118, 123, 123, 124,
124, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 115, 115, 115, 115, 115, 115, 115,
115, 115, 115, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 116, 116, 116, 116, 116, 116, 116, 116, 116,
116, 180, 181, 128, 129, 129, 129,
}
var yyR2 = [...]int{
0, 2, 0, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 4, 6, 7, 5, 10, 1, 3, 1,
3, 7, 8, 1, 1, 8, 8, 7, 6, 1,
1, 1, 3, 0, 4, 3, 4, 5, 4, 1,
3, 3, 2, 2, 2, 2, 2, 1, 1, 1,
2, 8, 4, 6, 5, 5, 5, 0, 2, 1,
0, 2, 1, 3, 3, 4, 4, 1, 3, 3,
8, 3, 1, 1, 1, 2, 1, 1, 1, 1,
1, 1, 1, 1, 2, 2, 2, 2, 2, 1,
2, 2, 2, 1, 4, 4, 2, 2, 3, 3,
3, 3, 1, 1, 1, 1, 1, 6, 6, 1,
1, 1, 1, 1, 1, 1, 1, 1, 3, 0,
3, 0, 5, 0, 3, 5, 0, 1, 0, 1,
0, 1, 2, 0, 2, 2, 2, 2, 2, 2,
0, 3, 0, 1, 0, 3, 3, 0, 2, 0,
2, 1, 2, 1, 0, 2, 5, 4, 1, 2,
2, 3, 2, 0, 1, 2, 3, 3, 2, 2,
1, 1, 1, 3, 2, 0, 1, 3, 1, 2,
3, 1, 1, 1, 6, 7, 7, 12, 7, 7,
7, 4, 5, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 7, 1, 3, 8, 8, 5,
4, 6, 5, 4, 4, 3, 2, 3, 4, 4,
4, 4, 4, 4, 4, 4, 3, 3, 3, 3,
4, 3, 6, 4, 2, 4, 2, 2, 2, 2,
3, 1, 1, 0, 1, 0, 1, 0, 2, 2,
0, 2, 2, 0, 1, 1, 2, 1, 1, 2,
1, 1, 2, 2, 2, 2, 2, 0, 2, 0,
2, 1, 2, 2, 0, 1, 1, 0, 1, 0,
1, 0, 1, 1, 3, 1, 2, 3, 5, 0,
1, 2, 1, 1, 0, 2, 1, 3, 1, 1,
1, 3, 3, 3, 7, 1, 3, 1, 3, 4,
4, 4, 3, 2, 4, 0, 1, 0, 2, 0,
1, 0, 1, 2, 1, 1, 1, 2, 2, 1,
2, 3, 2, 3, 2, 2, 2, 1, 1, 3,
0, 5, 5, 5, 0, 2, 1, 3, 3, 2,
3, 1, 2, 0, 3, 1, 1, 3, 3, 4,
4, 5, 3, 4, 5, 6, 2, 1, 2, 1,
2, 1, 2, 1, 1, 1, 1, 1, 1, 1,
0, 2, 1, 1, 1, 3, 1, 3, 1, 1,
1, 1, 1, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 2, 2,
2, 2, 2, 2, 3, 1, 1, 1, 1, 4,
5, 6, 4, 4, 6, 6, 6, 6, 8, 8,
6, 8, 8, 9, 7, 5, 4, 2, 2, 2,
2, 2, 2, 2, 2, 0, 2, 4, 4, 4,
4, 0, 3, 4, 7, 3, 1, 1, 2, 3,
3, 1, 2, 2, 1, 2, 1, 2, 2, 1,
2, 0, 1, 0, 2, 1, 2, 4, 0, 2,
1, 3, 5, 1, 1, 1, 1, 1, 1, 1,
1, 1, 2, 2, 0, 3, 0, 2, 0, 3,
1, 3, 2, 0, 1, 1, 0, 2, 4, 4,
0, 2, 4, 2, 1, 3, 5, 4, 6, 1,
3, 3, 5, 0, 5, 1, 3, 1, 2, 3,
1, 1, 3, 3, 1, 3, 3, 3, 3, 1,
2, 1, 1, 1, 1, 1, 1, 0, 2, 0,
3, 0, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 0, 1, 1, 1, 1, 0, 1,
1, 0, 2, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
1, 1, 1, 0, 0, 1, 1,
}
var yyChk = [...]int{
-1000, -178, -1, -2, -6, -7, -8, -9, -10, -11,
-12, -13, -14, -15, -17, -18, -19, -21, -22, -23,
-20, -3, -4, 6, 7, -27, 9, 10, 30, -16,
112, 113, 115, 114, 140, 116, 133, 49, 152, 153,
155, 156, 25, 134, 135, 138, 139, -180, 8, 235,
53, -179, 250, -82, 15, -26, 5, -24, -183, -24,
-24, -24, -24, -24, -159, 53, -114, 121, 70, 148,
227, 118, 119, 125, -117, 56, -116, 243, 152, 163,
157, 184, 176, 174, 177, 214, 65, 155, 223, 136,
172, 168, 166, 27, 189, 248, 167, 131, 130, 190,
194, 215, 161, 162, 217, 188, 132, 32, 245, 34,
144, 218, 192, 187, 183, 186, 160, 182, 38, 196,
195, 197, 213, 179, 169, 18, 221, 139, 142, 191,
193, 126, 146, 247, 219, 165, 143, 138, 222, 156,
216, 225, 37, 201, 159, 129, 153, 150, 180, 145,
170, 171, 185, 158, 181, 154, 147, 140, 224, 202,
249, 178, 175, 151, 149, 206, 207, 208, 209, 246,
220, 173, 203, -102, 121, 123, 119, 119, 120, 121,
227, 118, 119, -51, -123, 56, -116, 121, 148, 119,
106, 177, 112, 204, 120, 32, 146, -132, 119, -104,
149, 206, 207, 208, 209, 56, 216, 215, 210, -123,
154, -128, -128, -128, -128, -128, -2, -86, 17, 16,
-5, -3, -180, 6, 20, 21, -30, 39, 40, -25,
-36, 97, -37, -123, -56, 72, -61, 29, 56, -116,
23, -60, -57, -75, -73, -74, 106, 107, 95, 96,
103, 73, 108, -65, -63, -64, -66, 58, 57, 66,
59, 60, 61, 62, 67, 68, 69, -117, -71, -180,
43, 44, 236, 237, 238, 239, 242, 240, 75, 33,
226, 234, 233, 232, 230, 231, 228, 229, 124, 227,
101, 235, -102, -39, -40, -41, -42, -53, -74, -180,
-51, 11, -46, -51, -94, -131, 154, -98, 216, 215,
-118, -96, -117, -115, 214, 177, 213, 117, 71, 22,
24, 199, 74, 106, 16, 75, 105, 236, 112, 47,
228, 229, 226, 238, 239, 227, 204, 29, 10, 25,
134, 21, 99, 114, 78, 79, 137, 23, 135, 69,
19, 50, 11, 13, 14, 124, 123, 90, 120, 45,
8, 108, 26, 87, 41, 28, 43, 88, 17, 230,
231, 31, 242, 141, 101, 48, 35, 72, 67, 51,
70, 15, 46, 89, 115, 235, 44, 118, 6, 241,
30, 133, 42, 119, 205, 77, 122, 68, 5, 125,
9, 49, 52, 232, 233, 234, 33, 76, 12, -160,
-155, 56, 120, -51, 235, -117, -110, 124, -110, -110,
119, -51, -51, -109, 124, 56, -109, -109, -109, -51,
109, -51, 56, 30, 227, 56, 146, 119, 147, 121,
-129, -180, -118, -129, -129, -129, 150, 151, -129, -105,
211, 51, -129, -181, 55, -87, 19, 31, -37, -123,
-83, -84, -37, -82, -2, -24, 35, -28, 21, 64,
11, -120, 71, 70, 87, -119, 22, -117, 58, 109,
-37, -58, 90, 72, 88, 89, 74, 92, 91, 102,
95, 96, 97, 98, 99, 100, 101, 93, 94, 105,
80, 81, 82, 83, 84, 85, 86, -103, -180, -74,
-180, 110, 111, -61, -61, -61, -61, -61, -61, -61,
-180, -2, -69, -37, -180, -180, -180, -180, -180, -180,
-180, -180, -180, -78, -37, -180, -184, -180, -184, -184,
-184, -184, -184, -184, -184, -180, -180, -180, -180, -52,
26, -51, 30, 54, -47, -49, -48, -50, 41, 45,
47, 42, 43, 44, 48, -127, 22, -39, -180, -126,
142, -125, 22, -123, 58, -51, -46, -182, 54, 11,
52, 54, -94, 154, -95, -99, 217, 219, 80, -122,
-117, 58, 29, 30, 55, 54, -134, -137, -139, -138,
-140, -135, -136, 174, 175, 106, 178, 180, 181, 182,
183, 184, 185, 186, 187, 188, 189, 30, 136, 170,
171, 172, 173, 190, 191, 192, 193, 194, 195, 196,
197, 157, 158, 159, 160, 161, 162, 163, 165, 166,
167, 168, 169, 56, -129, 121, -176, 52, 56, 72,
56, -51, -51, -129, 122, -51, 23, 51, -51, 56,
56, -124, -123, -115, -129, -129, -129, -129, -129, -129,
-129, -129, -129, -129, -107, 205, 212, -51, 9, 90,
54, 18, 109, 54, -85, 24, 25, -86, -181, -30,
-62, -117, 59, 62, -29, 42, -51, -37, -37, -67,
67, 72, 68, 69, -119, 97, -124, -118, -115, -61,
-68, -71, -74, 63, 90, 88, 89, 74, -61, -61,
-61, -61, -61, -61, -61, -61, -61, -61, -61, -61,
-61, -61, -61, -130, 56, 58, 56, -60, -60, -117,
-35, 21, -34, -36, -181, 54, -181, -2, -34, -34,
-37, -37, -75, -117, -123, -75, -34, -28, -76, -77,
76, -75, -181, -34, -35, -34, -34, -90, 142, -51,
-93, -97, -75, -40, -41, -41, -40, -41, 41, 41,
41, 46, 41, 46, 41, -48, -123, -181, -54, 49,
123, 50, -180, -125, -90, 52, -39, -51, -98, -95,
54, 218, 220, 221, 51, -37, -146, 105, -161, -162,
-163, -118, 58, 59, -155, -156, -164, 126, 129, 125,
-157, 120, 28, -151, 67, 72, -147, 202, -141, 53,
-141, -141, -141, -141, -145, 177, -145, -145, -145, 53,
53, -141, -141, -141, -149, 53, -149, -149, -150, 53,
-150, -121, 52, -51, -174, 246, -175, 56, -129, 23,
-129, -111, 117, 114, 115, -171, 113, 199, 177, 65,
29, 15, 236, 142, 249, 56, 143, -51, -51, -129,
-106, 11, 90, 37, -37, -37, -124, -84, -87, -101,
19, 11, 33, 33, -34, 67, 68, 69, 109, -180,
-68, -61, -61, -61, -33, 137, 71, -181, -181, -34,
54, -37, -181, -181, -181, 54, 52, 22, 54, 11,
109, 54, 11, -181, -34, -79, -77, 78, -37, -181,
-181, -181, -181, -181, -59, 30, 33, -2, -180, -180,
-55, 54, 12, 80, -44, -43, 51, 52, -45, 51,
-43, 41, 41, 120, 120, 120, -91, -117, -55, -39,
-55, -99, -100, 222, 219, 225, 56, 54, -163, 80,
53, 28, -157, -157, 56, 56, -142, 29, 67, -148,
203, 59, -145, -145, -146, 30, -146, -146, -146, -154,
58, -154, 59, 59, 51, -117, -129, -173, -172, -118,
-128, -177, 148, 127, 128, 131, 130, 56, 120, 28,
126, 129, 142, 125, -177, 148, -112, -113, 122, 22,
120, 28, 142, -129, -108, 88, 12, -123, -123, 38,
109, -51, -38, 11, 97, -118, -35, -33, 71, -61,
-61, -181, -36, -133, 106, 174, 136, 172, 168, 188,
179, 201, 170, 202, -130, -133, -61, -61, -118, -61,
-61, 243, -82, 79, -37, 77, -92, 51, -93, -70,
-72, -71, -180, -2, -88, -117, -91, -82, -97, -37,
-37, -37, 53, -37, -180, -180, -180, -181, 54, -82,
-55, 219, 223, 224, -162, -163, -166, -165, -117, 56,
56, -144, 51, 58, 59, 60, 67, 226, 66, 55,
-146, -146, 56, 106, 55, 54, 55, 54, 55, 54,
-51, 54, 80, -128, -117, -128, -117, -51, -128, -117,
58, -37, -55, -39, -181, -61, -181, -141, -141, -141,
-150, -141, 162, -141, 162, -181, -181, -181, 54, 19,
-181, 54, 19, -180, -32, 241, -37, 27, -92, 54,
-181, -181, -181, 54, 109, -181, -86, -89, -117, -89,
-89, -89, -126, -117, -86, 55, 54, -141, -152, 199,
9, -145, 58, -145, 59, 59, -129, -172, -163, 53,
26, -80, 13, -145, 56, -61, -61, -61, -61, -61,
-181, 58, 28, -72, 33, -2, -180, -117, -117, 54,
55, -181, -181, -181, -54, -168, -167, 52, 132, 65,
-165, -153, 126, 28, 125, 226, -146, -146, 55, 55,
-89, -180, -81, 14, 16, -181, -181, -181, -181, -31,
90, 246, 9, -70, -2, 109, -117, -167, 56, -158,
80, 58, -143, 65, 28, 28, 55, -169, -170, 142,
-37, -69, -181, 244, 48, 247, -93, -181, -117, 59,
58, -176, -181, 54, -117, 38, 245, 248, -174, -170,
33, 38, 144, 246, 145, 247, -180, 248, -61, 141,
-181, -181,
}
var yyDef = [...]int{
0, -2, 2, -2, 5, 6, 7, 8, 9, 10,
11, 12, 13, 14, 15, 16, 17, 18, 19, 20,
21, 508, 0, 277, 277, 277, 277, 277, 277, 0,
578, 561, 0, 0, 0, 0, -2, 267, 268, 0,
270, 271, 783, 783, 783, 783, 783, 0, 33, 34,
781, 1, 3, 516, 0, 0, 281, 284, 279, 0,
561, 0, 0, 0, 60, 0, 0, 770, 0, 771,
559, 559, 559, 579, 580, 583, 584, 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, 772, 773, 774, 775, 776, 777,
778, 779, 780, 0, 0, 562, 0, 557, 0, 557,
557, 557, 0, 226, 348, 587, 588, 770, 771, 0,
0, 0, 0, 784, 784, 784, 784, 0, 784, 255,
244, 246, 247, 248, 249, 784, 264, 265, 254, 266,
269, 272, 273, 274, 275, 276, 27, 520, 0, 0,
508, 29, 0, 277, 282, 283, 287, 285, 286, 278,
0, 295, 299, 0, 356, 0, 361, 363, -2, -2,
0, 398, 399, 400, 401, 402, 0, 0, 0, 0,
0, 0, 0, 425, 426, 427, 428, 493, 494, 495,
496, 497, 498, 499, 500, 365, 366, 490, 540, 0,
0, 0, 0, 0, 0, 0, 0, 0, 481, 0,
455, 455, 455, 455, 455, 455, 455, 455, 0, 0,
0, 0, 0, 0, 306, 308, 309, 310, 329, 0,
331, 0, 0, 41, 45, 0, 761, 544, -2, -2,
0, 0, 585, 586, -2, 690, -2, 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, 0,
77, 0, 0, 784, 0, 67, 0, 0, 0, 0,
0, 784, 0, 0, 0, 0, 0, 0, 0, 225,
0, 227, 784, 784, 784, 784, 784, 784, 784, 784,
236, 785, 786, 237, 238, 239, 784, 784, 241, 0,
256, 0, 250, 28, 782, 22, 0, 0, 517, 0,
509, 510, 513, 516, 27, 284, 0, 289, 288, 280,
0, 296, 0, 0, 0, 300, 0, 302, 303, 0,
359, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
383, 384, 385, 386, 387, 388, 389, 362, 0, 376,
0, 0, 0, 418, 419, 420, 421, 422, 423, 0,
291, 27, 0, 396, 0, 0, 0, 0, 0, 0,
0, 0, 287, 0, 482, 0, 447, 0, 448, 449,
450, 451, 452, 453, 454, 0, 291, 0, 0, 43,
0, 347, 0, 0, 0, 0, 0, 0, 336, 0,
0, 339, 0, 0, 0, 0, 330, 0, 0, 350,
734, 332, 0, 334, 335, -2, 0, 0, 0, 39,
40, 0, 46, 761, 48, 49, 0, 0, 0, 157,
552, 553, 554, 550, 185, 0, 140, 136, 82, 83,
84, 129, 86, 129, 129, 129, 129, 154, 154, 154,
154, 112, 113, 114, 115, 116, 0, 0, 99, 129,
129, 129, 103, 119, 120, 121, 122, 123, 124, 125,
126, 87, 88, 89, 90, 91, 92, 93, 131, 131,
131, 133, 133, 581, 62, 0, 70, 0, 784, 0,
784, 75, 0, 201, 0, 220, 558, 0, 784, 223,
224, 349, 589, 590, 228, 229, 230, 231, 232, 233,
234, 235, 240, 243, 257, 251, 252, 245, 521, 0,
0, 0, 0, 0, 512, 514, 515, 520, 30, 287,
0, 501, 0, 0, 0, 290, 25, 357, 358, 360,
377, 0, 379, 381, 301, 297, 0, 491, -2, 367,
368, 392, 393, 394, 0, 0, 0, 0, 390, 372,
0, 403, 404, 405, 406, 407, 408, 409, 410, 411,
412, 413, 414, 417, 466, 467, 0, 415, 416, 424,
0, 0, 292, 293, 395, 0, 539, 27, 0, 0,
0, 0, 0, 490, 0, 0, 0, 0, 488, 485,
0, 0, 456, 0, 0, 0, 0, 0, 0, 346,
354, 541, 0, 307, 325, 327, 0, 322, 337, 338,
340, 0, 342, 0, 344, 345, 311, 312, 313, 0,
0, 0, 0, 333, 354, 0, 354, 42, 545, 47,
0, 0, 52, 53, 546, 547, 548, 0, 76, 186,
188, 191, 192, 193, 78, 79, 0, 0, 0, 0,
0, 180, 181, 143, 141, 0, 138, 137, 85, 0,
154, 154, 106, 107, 157, 0, 157, 157, 157, 0,
0, 100, 101, 102, 94, 0, 95, 96, 97, 0,
98, 0, 0, 784, 64, 0, 68, 69, 65, 560,
66, 783, 0, 0, 573, 202, 563, 564, 565, 566,
567, 568, 569, 570, 571, 572, 0, 219, 784, 222,
260, 0, 0, 0, 518, 519, 0, 511, 23, 0,
555, 556, 502, 503, 304, 378, 380, 382, 0, 291,
369, 390, 373, 0, 370, 0, 0, 364, 429, 0,
0, 397, -2, 432, 433, 0, 0, 0, 0, 0,
0, 0, 0, 0, 508, 0, 486, 0, 0, 446,
457, 458, 459, 460, 533, 0, 0, -2, 0, 0,
508, 0, 0, 0, 319, 326, 0, 0, 320, 0,
321, 341, 343, 0, 0, 0, 0, 317, 508, 354,
38, 50, 51, 0, 0, 57, 158, 0, 189, 0,
0, 175, 0, 0, 178, 179, 150, 0, 142, 81,
139, 0, 157, 157, 108, 0, 109, 110, 111, 0,
127, 0, 0, 0, 0, 582, 63, 71, 72, 0,
194, 783, 0, 203, 204, 205, 206, 207, 208, 209,
210, 211, 212, 213, 783, 0, 0, 783, 574, 575,
576, 577, 0, 221, 242, 0, 0, 258, 259, 522,
0, 24, 354, 0, 298, 492, 0, 371, 0, 391,
374, 430, 294, 0, 129, 129, 471, 129, 133, 474,
129, 476, 129, 479, 0, 0, 0, 0, 491, 0,
0, 0, 483, 445, 489, 0, 31, 0, 533, 523,
535, 537, 0, 27, 0, 529, 0, 516, 542, 355,
543, 323, 0, 328, 0, 0, 0, 331, 0, 516,
37, 54, 55, 56, 187, 190, 0, 182, 129, 176,
177, 152, 0, 144, 145, 146, 147, 148, 149, 130,
104, 105, 155, 156, 154, 0, 154, 0, 134, 0,
784, 0, 0, 195, 0, 196, 198, 199, 200, 0,
261, 262, 504, 305, 431, 375, 434, 468, 154, 472,
473, 475, 477, 478, 480, 436, 435, 437, 0, 0,
440, 0, 0, 0, 0, 0, 487, 0, 32, 0,
538, -2, 0, 0, 0, 44, 35, 0, 315, 0,
0, 0, 350, 318, 36, 167, 0, 184, 159, 153,
0, 157, 128, 157, 0, 0, 61, 73, 74, 0,
0, 506, 0, 469, 470, 0, 0, 0, 0, 461,
444, 484, 0, 536, 0, -2, 0, 531, 530, 0,
324, 351, 352, 353, 314, 166, 168, 0, 173, 0,
183, 164, 0, 161, 163, 151, 117, 118, 132, 135,
0, 0, 26, 0, 0, 438, 439, 441, 442, 0,
0, 0, 0, 526, 27, 0, 316, 169, 170, 0,
174, 172, 80, 0, 160, 162, 67, 0, 215, 0,
507, 505, 443, 0, 0, 0, 534, -2, 532, 171,
165, 70, 214, 0, 0, 462, 0, 465, 197, 216,
0, 463, 0, 0, 0, 0, 0, 464, 0, 0,
217, 218,
}
var yyTok1 = [...]int{
1, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 73, 3, 3, 3, 100, 92, 3,
53, 55, 97, 95, 54, 96, 109, 98, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 250,
81, 80, 82, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 102, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
3, 3, 3, 3, 91, 3, 103,
}
var yyTok2 = [...]int{
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, 56, 57, 58, 59, 60, 61, 62, 63, 64,
65, 66, 67, 68, 69, 70, 71, 72, 74, 75,
76, 77, 78, 79, 83, 84, 85, 86, 87, 88,
89, 90, 93, 94, 99, 101, 104, 105, 106, 107,
108, 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,
}
var yyTok3 = [...]int{
0,
}
var yyErrorMessages = [...]struct {
state int
token int
msg string
}{}
//line yaccpar:1
/* parser for yacc output */
var (
yyDebug = 0
yyErrorVerbose = false
)
type yyLexer interface {
Lex(lval *yySymType) int
Error(s string)
}
type yyParser interface {
Parse(yyLexer) int
Lookahead() int
}
type yyParserImpl struct {
lval yySymType
stack [yyInitialStackSize]yySymType
char int
}
func (p *yyParserImpl) Lookahead() int {
return p.char
}
func yyNewParser() yyParser {
return &yyParserImpl{}
}
const yyFlag = -1000
func yyTokname(c int) string {
if c >= 1 && c-1 < len(yyToknames) {
if yyToknames[c-1] != "" {
return yyToknames[c-1]
}
}
return __yyfmt__.Sprintf("tok-%v", c)
}
func yyStatname(s int) string {
if s >= 0 && s < len(yyStatenames) {
if yyStatenames[s] != "" {
return yyStatenames[s]
}
}
return __yyfmt__.Sprintf("state-%v", s)
}
func yyErrorMessage(state, lookAhead int) string {
const TOKSTART = 4
if !yyErrorVerbose {
return "syntax error"
}
for _, e := range yyErrorMessages {
if e.state == state && e.token == lookAhead {
return "syntax error: " + e.msg
}
}
res := "syntax error: unexpected " + yyTokname(lookAhead)
// To match Bison, suggest at most four expected tokens.
expected := make([]int, 0, 4)
// Look for shiftable tokens.
base := yyPact[state]
for tok := TOKSTART; tok-1 < len(yyToknames); tok++ {
if n := base + tok; n >= 0 && n < yyLast && yyChk[yyAct[n]] == tok {
if len(expected) == cap(expected) {
return res
}
expected = append(expected, tok)
}
}
if yyDef[state] == -2 {
i := 0
for yyExca[i] != -1 || yyExca[i+1] != state {
i += 2
}
// Look for tokens that we accept or reduce.
for i += 2; yyExca[i] >= 0; i += 2 {
tok := yyExca[i]
if tok < TOKSTART || yyExca[i+1] == 0 {
continue
}
if len(expected) == cap(expected) {
return res
}
expected = append(expected, tok)
}
// If the default action is to accept or reduce, give up.
if yyExca[i+1] != 0 {
return res
}
}
for i, tok := range expected {
if i == 0 {
res += ", expecting "
} else {
res += " or "
}
res += yyTokname(tok)
}
return res
}
func yylex1(lex yyLexer, lval *yySymType) (char, token int) {
token = 0
char = lex.Lex(lval)
if char <= 0 {
token = yyTok1[0]
goto out
}
if char < len(yyTok1) {
token = yyTok1[char]
goto out
}
if char >= yyPrivate {
if char < yyPrivate+len(yyTok2) {
token = yyTok2[char-yyPrivate]
goto out
}
}
for i := 0; i < len(yyTok3); i += 2 {
token = yyTok3[i+0]
if token == char {
token = yyTok3[i+1]
goto out
}
}
out:
if token == 0 {
token = yyTok2[1] /* unknown char */
}
if yyDebug >= 3 {
__yyfmt__.Printf("lex %s(%d)\n", yyTokname(token), uint(char))
}
return char, token
}
func yyParse(yylex yyLexer) int {
return yyNewParser().Parse(yylex)
}
func (yyrcvr *yyParserImpl) Parse(yylex yyLexer) int {
var yyn int
var yyVAL yySymType
var yyDollar []yySymType
_ = yyDollar // silence set and not used
yyS := yyrcvr.stack[:]
Nerrs := 0 /* number of errors */
Errflag := 0 /* error recovery flag */
yystate := 0
yyrcvr.char = -1
yytoken := -1 // yyrcvr.char translated into internal numbering
defer func() {
// Make sure we report no lookahead when not parsing.
yystate = -1
yyrcvr.char = -1
yytoken = -1
}()
yyp := -1
goto yystack
ret0:
return 0
ret1:
return 1
yystack:
/* put a state and value onto the stack */
if yyDebug >= 4 {
__yyfmt__.Printf("char %v in %v\n", yyTokname(yytoken), yyStatname(yystate))
}
yyp++
if yyp >= len(yyS) {
nyys := make([]yySymType, len(yyS)*2)
copy(nyys, yyS)
yyS = nyys
}
yyS[yyp] = yyVAL
yyS[yyp].yys = yystate
yynewstate:
yyn = yyPact[yystate]
if yyn <= yyFlag {
goto yydefault /* simple state */
}
if yyrcvr.char < 0 {
yyrcvr.char, yytoken = yylex1(yylex, &yyrcvr.lval)
}
yyn += yytoken
if yyn < 0 || yyn >= yyLast {
goto yydefault
}
yyn = yyAct[yyn]
if yyChk[yyn] == yytoken { /* valid shift */
yyrcvr.char = -1
yytoken = -1
yyVAL = yyrcvr.lval
yystate = yyn
if Errflag > 0 {
Errflag--
}
goto yystack
}
yydefault:
/* default state action */
yyn = yyDef[yystate]
if yyn == -2 {
if yyrcvr.char < 0 {
yyrcvr.char, yytoken = yylex1(yylex, &yyrcvr.lval)
}
/* look through exception table */
xi := 0
for {
if yyExca[xi+0] == -1 && yyExca[xi+1] == yystate {
break
}
xi += 2
}
for xi += 2; ; xi += 2 {
yyn = yyExca[xi+0]
if yyn < 0 || yyn == yytoken {
break
}
}
yyn = yyExca[xi+1]
if yyn < 0 {
goto ret0
}
}
if yyn == 0 {
/* error ... attempt to resume parsing */
switch Errflag {
case 0: /* brand new error */
yylex.Error(yyErrorMessage(yystate, yytoken))
Nerrs++
if yyDebug >= 1 {
__yyfmt__.Printf("%s", yyStatname(yystate))
__yyfmt__.Printf(" saw %s\n", yyTokname(yytoken))
}
fallthrough
case 1, 2: /* incompletely recovered error ... try again */
Errflag = 3
/* find a state where "error" is a legal shift action */
for yyp >= 0 {
yyn = yyPact[yyS[yyp].yys] + yyErrCode
if yyn >= 0 && yyn < yyLast {
yystate = yyAct[yyn] /* simulate a shift of "error" */
if yyChk[yystate] == yyErrCode {
goto yystack
}
}
/* the current p has no shift on "error", pop stack */
if yyDebug >= 2 {
__yyfmt__.Printf("error recovery pops state %d\n", yyS[yyp].yys)
}
yyp--
}
/* there is no state on the stack with an error shift ... abort */
goto ret1
case 3: /* no shift yet; clobber input char */
if yyDebug >= 2 {
__yyfmt__.Printf("error recovery discards %s\n", yyTokname(yytoken))
}
if yytoken == yyEofCode {
goto ret1
}
yyrcvr.char = -1
yytoken = -1
goto yynewstate /* try again in the same state */
}
}
/* reduction by production yyn */
if yyDebug >= 2 {
__yyfmt__.Printf("reduce %v in:\n\t%v\n", yyn, yyStatname(yystate))
}
yynt := yyn
yypt := yyp
_ = yypt // guard against "declared and not used"
yyp -= yyR2[yyn]
// yyp is now the index of $0. Perform the default action. Iff the
// reduced production is ε, $1 is possibly out of range.
if yyp+1 >= len(yyS) {
nyys := make([]yySymType, len(yyS)*2)
copy(nyys, yyS)
yyS = nyys
}
yyVAL = yyS[yyp+1]
/* consult goto table to find next state */
yyn = yyR1[yyn]
yyg := yyPgo[yyn]
yyj := yyg + yyS[yyp].yys + 1
if yyj >= yyLast {
yystate = yyAct[yyg]
} else {
yystate = yyAct[yyj]
if yyChk[yystate] != -yyn {
yystate = yyAct[yyg]
}
}
// dummy call; replaced with literal code
switch yynt {
case 1:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:302
{
setParseTree(yylex, yyDollar[1].statement)
}
case 2:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:307
{
}
case 3:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:308
{
}
case 4:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:312
{
yyVAL.statement = yyDollar[1].selStmt
}
case 22:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:335
{
sel := yyDollar[1].selStmt.(*Select)
sel.OrderBy = yyDollar[2].orderBy
sel.Limit = yyDollar[3].limit
sel.Lock = yyDollar[4].str
yyVAL.selStmt = sel
}
case 23:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:343
{
yyVAL.selStmt = &Union{Type: yyDollar[2].str, Left: yyDollar[1].selStmt, Right: yyDollar[3].selStmt, OrderBy: yyDollar[4].orderBy, Limit: yyDollar[5].limit, Lock: yyDollar[6].str}
}
case 24:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:347
{
yyVAL.selStmt = &Select{Comments: Comments(yyDollar[2].bytes2), Cache: yyDollar[3].str, SelectExprs: SelectExprs{Nextval{Expr: yyDollar[5].expr}}, From: TableExprs{&AliasedTableExpr{Expr: yyDollar[7].tableName}}}
}
case 25:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:353
{
yyVAL.statement = &Stream{Comments: Comments(yyDollar[2].bytes2), SelectExpr: yyDollar[3].selectExpr, Table: yyDollar[5].tableName}
}
case 26:
yyDollar = yyS[yypt-10 : yypt+1]
//line sql.y:360
{
yyVAL.selStmt = &Select{Comments: Comments(yyDollar[2].bytes2), Cache: yyDollar[3].str, Distinct: yyDollar[4].str, Hints: yyDollar[5].str, SelectExprs: yyDollar[6].selectExprs, From: yyDollar[7].tableExprs, Where: NewWhere(WhereStr, yyDollar[8].expr), GroupBy: GroupBy(yyDollar[9].exprs), Having: NewWhere(HavingStr, yyDollar[10].expr)}
}
case 27:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:366
{
yyVAL.selStmt = yyDollar[1].selStmt
}
case 28:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:370
{
yyVAL.selStmt = &ParenSelect{Select: yyDollar[2].selStmt}
}
case 29:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:376
{
yyVAL.selStmt = yyDollar[1].selStmt
}
case 30:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:380
{
yyVAL.selStmt = &ParenSelect{Select: yyDollar[2].selStmt}
}
case 31:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:387
{
// insert_data returns a *Insert pre-filled with Columns & Values
ins := yyDollar[6].ins
ins.Action = yyDollar[1].str
ins.Comments = yyDollar[2].bytes2
ins.Ignore = yyDollar[3].str
ins.Table = yyDollar[4].tableName
ins.Partitions = yyDollar[5].partitions
ins.OnDup = OnDup(yyDollar[7].updateExprs)
yyVAL.statement = ins
}
case 32:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:399
{
cols := make(Columns, 0, len(yyDollar[7].updateExprs))
vals := make(ValTuple, 0, len(yyDollar[8].updateExprs))
for _, updateList := range yyDollar[7].updateExprs {
cols = append(cols, updateList.Name.Name)
vals = append(vals, updateList.Expr)
}
yyVAL.statement = &Insert{Action: yyDollar[1].str, Comments: Comments(yyDollar[2].bytes2), Ignore: yyDollar[3].str, Table: yyDollar[4].tableName, Partitions: yyDollar[5].partitions, Columns: cols, Rows: Values{vals}, OnDup: OnDup(yyDollar[8].updateExprs)}
}
case 33:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:411
{
yyVAL.str = InsertStr
}
case 34:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:415
{
yyVAL.str = ReplaceStr
}
case 35:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:421
{
yyVAL.statement = &Update{Comments: Comments(yyDollar[2].bytes2), TableExprs: yyDollar[3].tableExprs, Exprs: yyDollar[5].updateExprs, Where: NewWhere(WhereStr, yyDollar[6].expr), OrderBy: yyDollar[7].orderBy, Limit: yyDollar[8].limit}
}
case 36:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:427
{
yyVAL.statement = &Delete{Comments: Comments(yyDollar[2].bytes2), TableExprs: TableExprs{&AliasedTableExpr{Expr: yyDollar[4].tableName}}, Partitions: yyDollar[5].partitions, Where: NewWhere(WhereStr, yyDollar[6].expr), OrderBy: yyDollar[7].orderBy, Limit: yyDollar[8].limit}
}
case 37:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:431
{
yyVAL.statement = &Delete{Comments: Comments(yyDollar[2].bytes2), Targets: yyDollar[4].tableNames, TableExprs: yyDollar[6].tableExprs, Where: NewWhere(WhereStr, yyDollar[7].expr)}
}
case 38:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:435
{
yyVAL.statement = &Delete{Comments: Comments(yyDollar[2].bytes2), Targets: yyDollar[3].tableNames, TableExprs: yyDollar[5].tableExprs, Where: NewWhere(WhereStr, yyDollar[6].expr)}
}
case 39:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:440
{
}
case 40:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:441
{
}
case 41:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:445
{
yyVAL.tableNames = TableNames{yyDollar[1].tableName}
}
case 42:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:449
{
yyVAL.tableNames = append(yyVAL.tableNames, yyDollar[3].tableName)
}
case 43:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:454
{
yyVAL.partitions = nil
}
case 44:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:458
{
yyVAL.partitions = yyDollar[3].partitions
}
case 45:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:464
{
yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Exprs: yyDollar[3].setExprs}
}
case 46:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:468
{
yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Scope: yyDollar[3].str, Exprs: yyDollar[4].setExprs}
}
case 47:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:472
{
yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Scope: yyDollar[3].str, Exprs: yyDollar[5].setExprs}
}
case 48:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:476
{
yyVAL.statement = &Set{Comments: Comments(yyDollar[2].bytes2), Exprs: yyDollar[4].setExprs}
}
case 49:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:482
{
yyVAL.setExprs = SetExprs{yyDollar[1].setExpr}
}
case 50:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:486
{
yyVAL.setExprs = append(yyVAL.setExprs, yyDollar[3].setExpr)
}
case 51:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:492
{
yyVAL.setExpr = yyDollar[3].setExpr
}
case 52:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:496
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent("tx_read_only"), Expr: NewIntVal([]byte("0"))}
}
case 53:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:500
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent("tx_read_only"), Expr: NewIntVal([]byte("1"))}
}
case 54:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:506
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent("tx_isolation"), Expr: NewStrVal([]byte("repeatable read"))}
}
case 55:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:510
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent("tx_isolation"), Expr: NewStrVal([]byte("read committed"))}
}
case 56:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:514
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent("tx_isolation"), Expr: NewStrVal([]byte("read uncommitted"))}
}
case 57:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:518
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent("tx_isolation"), Expr: NewStrVal([]byte("serializable"))}
}
case 58:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:524
{
yyVAL.str = SessionStr
}
case 59:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:528
{
yyVAL.str = GlobalStr
}
case 60:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:534
{
yyDollar[1].ddl.TableSpec = yyDollar[2].TableSpec
yyVAL.statement = yyDollar[1].ddl
}
case 61:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:539
{
// Change this to an alter statement
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[7].tableName, NewName: yyDollar[7].tableName}
}
case 62:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:544
{
yyVAL.statement = &DDL{Action: CreateStr, NewName: yyDollar[3].tableName.ToViewName()}
}
case 63:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:548
{
yyVAL.statement = &DDL{Action: CreateStr, NewName: yyDollar[5].tableName.ToViewName()}
}
case 64:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:552
{
yyVAL.statement = &DDL{Action: CreateVindexStr, VindexSpec: &VindexSpec{
Name: yyDollar[3].colIdent,
Type: yyDollar[4].colIdent,
Params: yyDollar[5].vindexParams,
}}
}
case 65:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:560
{
yyVAL.statement = &DBDDL{Action: CreateStr, DBName: string(yyDollar[4].bytes)}
}
case 66:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:564
{
yyVAL.statement = &DBDDL{Action: CreateStr, DBName: string(yyDollar[4].bytes)}
}
case 67:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:569
{
yyVAL.colIdent = NewColIdent("")
}
case 68:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:573
{
yyVAL.colIdent = yyDollar[2].colIdent
}
case 69:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:579
{
yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes))
}
case 70:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:584
{
var v []VindexParam
yyVAL.vindexParams = v
}
case 71:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:589
{
yyVAL.vindexParams = yyDollar[2].vindexParams
}
case 72:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:595
{
yyVAL.vindexParams = make([]VindexParam, 0, 4)
yyVAL.vindexParams = append(yyVAL.vindexParams, yyDollar[1].vindexParam)
}
case 73:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:600
{
yyVAL.vindexParams = append(yyVAL.vindexParams, yyDollar[3].vindexParam)
}
case 74:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:606
{
yyVAL.vindexParam = VindexParam{Key: yyDollar[1].colIdent, Val: yyDollar[3].str}
}
case 75:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:612
{
yyVAL.ddl = &DDL{Action: CreateStr, NewName: yyDollar[4].tableName}
setDDL(yylex, yyVAL.ddl)
}
case 76:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:619
{
yyVAL.TableSpec = yyDollar[2].TableSpec
yyVAL.TableSpec.Options = yyDollar[4].str
}
case 77:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:626
{
yyVAL.TableSpec = &TableSpec{}
yyVAL.TableSpec.AddColumn(yyDollar[1].columnDefinition)
}
case 78:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:631
{
yyVAL.TableSpec.AddColumn(yyDollar[3].columnDefinition)
}
case 79:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:635
{
yyVAL.TableSpec.AddIndex(yyDollar[3].indexDefinition)
}
case 80:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:641
{
yyDollar[2].columnType.NotNull = yyDollar[3].boolVal
yyDollar[2].columnType.Default = yyDollar[4].optVal
yyDollar[2].columnType.OnUpdate = yyDollar[5].optVal
yyDollar[2].columnType.Autoincrement = yyDollar[6].boolVal
yyDollar[2].columnType.KeyOpt = yyDollar[7].colKeyOpt
yyDollar[2].columnType.Comment = yyDollar[8].optVal
yyVAL.columnDefinition = &ColumnDefinition{Name: NewColIdent(string(yyDollar[1].bytes)), Type: yyDollar[2].columnType}
}
case 81:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:652
{
yyVAL.columnType = yyDollar[1].columnType
yyVAL.columnType.Unsigned = yyDollar[2].boolVal
yyVAL.columnType.Zerofill = yyDollar[3].boolVal
}
case 85:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:663
{
yyVAL.columnType = yyDollar[1].columnType
yyVAL.columnType.Length = yyDollar[2].optVal
}
case 86:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:668
{
yyVAL.columnType = yyDollar[1].columnType
}
case 87:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:674
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 88:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:678
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 89:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:682
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 90:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:686
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 91:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:690
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 92:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:694
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 93:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:698
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 94:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:704
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length
yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale
}
case 95:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:710
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length
yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale
}
case 96:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:716
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length
yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale
}
case 97:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:722
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length
yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale
}
case 98:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:728
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
yyVAL.columnType.Length = yyDollar[2].LengthScaleOption.Length
yyVAL.columnType.Scale = yyDollar[2].LengthScaleOption.Scale
}
case 99:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:736
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 100:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:740
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 101:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:744
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 102:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:748
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 103:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:752
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 104:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:758
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal, Charset: yyDollar[3].str, Collate: yyDollar[4].str}
}
case 105:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:762
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal, Charset: yyDollar[3].str, Collate: yyDollar[4].str}
}
case 106:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:766
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 107:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:770
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 108:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:774
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Charset: yyDollar[2].str, Collate: yyDollar[3].str}
}
case 109:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:778
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Charset: yyDollar[2].str, Collate: yyDollar[3].str}
}
case 110:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:782
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Charset: yyDollar[2].str, Collate: yyDollar[3].str}
}
case 111:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:786
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), Charset: yyDollar[2].str, Collate: yyDollar[3].str}
}
case 112:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:790
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 113:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:794
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 114:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:798
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 115:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:802
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 116:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:806
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 117:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:810
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), EnumValues: yyDollar[3].strs, Charset: yyDollar[5].str, Collate: yyDollar[6].str}
}
case 118:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:815
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes), EnumValues: yyDollar[3].strs, Charset: yyDollar[5].str, Collate: yyDollar[6].str}
}
case 119:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:821
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 120:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:825
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 121:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:829
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 122:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:833
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 123:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:837
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 124:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:841
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 125:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:845
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 126:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:849
{
yyVAL.columnType = ColumnType{Type: string(yyDollar[1].bytes)}
}
case 127:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:855
{
yyVAL.strs = make([]string, 0, 4)
yyVAL.strs = append(yyVAL.strs, "'"+string(yyDollar[1].bytes)+"'")
}
case 128:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:860
{
yyVAL.strs = append(yyDollar[1].strs, "'"+string(yyDollar[3].bytes)+"'")
}
case 129:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:865
{
yyVAL.optVal = nil
}
case 130:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:869
{
yyVAL.optVal = NewIntVal(yyDollar[2].bytes)
}
case 131:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:874
{
yyVAL.LengthScaleOption = LengthScaleOption{}
}
case 132:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:878
{
yyVAL.LengthScaleOption = LengthScaleOption{
Length: NewIntVal(yyDollar[2].bytes),
Scale: NewIntVal(yyDollar[4].bytes),
}
}
case 133:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:886
{
yyVAL.LengthScaleOption = LengthScaleOption{}
}
case 134:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:890
{
yyVAL.LengthScaleOption = LengthScaleOption{
Length: NewIntVal(yyDollar[2].bytes),
}
}
case 135:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:896
{
yyVAL.LengthScaleOption = LengthScaleOption{
Length: NewIntVal(yyDollar[2].bytes),
Scale: NewIntVal(yyDollar[4].bytes),
}
}
case 136:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:904
{
yyVAL.boolVal = BoolVal(false)
}
case 137:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:908
{
yyVAL.boolVal = BoolVal(true)
}
case 138:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:913
{
yyVAL.boolVal = BoolVal(false)
}
case 139:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:917
{
yyVAL.boolVal = BoolVal(true)
}
case 140:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:923
{
yyVAL.boolVal = BoolVal(false)
}
case 141:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:927
{
yyVAL.boolVal = BoolVal(false)
}
case 142:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:931
{
yyVAL.boolVal = BoolVal(true)
}
case 143:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:936
{
yyVAL.optVal = nil
}
case 144:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:940
{
yyVAL.optVal = NewStrVal(yyDollar[2].bytes)
}
case 145:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:944
{
yyVAL.optVal = NewIntVal(yyDollar[2].bytes)
}
case 146:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:948
{
yyVAL.optVal = NewFloatVal(yyDollar[2].bytes)
}
case 147:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:952
{
yyVAL.optVal = NewValArg(yyDollar[2].bytes)
}
case 148:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:956
{
yyVAL.optVal = NewValArg(yyDollar[2].bytes)
}
case 149:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:960
{
yyVAL.optVal = NewBitVal(yyDollar[2].bytes)
}
case 150:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:965
{
yyVAL.optVal = nil
}
case 151:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:969
{
yyVAL.optVal = NewValArg(yyDollar[3].bytes)
}
case 152:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:974
{
yyVAL.boolVal = BoolVal(false)
}
case 153:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:978
{
yyVAL.boolVal = BoolVal(true)
}
case 154:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:983
{
yyVAL.str = ""
}
case 155:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:987
{
yyVAL.str = string(yyDollar[3].bytes)
}
case 156:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:991
{
yyVAL.str = string(yyDollar[3].bytes)
}
case 157:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:996
{
yyVAL.str = ""
}
case 158:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1000
{
yyVAL.str = string(yyDollar[2].bytes)
}
case 159:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1005
{
yyVAL.colKeyOpt = colKeyNone
}
case 160:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1009
{
yyVAL.colKeyOpt = colKeyPrimary
}
case 161:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1013
{
yyVAL.colKeyOpt = colKey
}
case 162:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1017
{
yyVAL.colKeyOpt = colKeyUniqueKey
}
case 163:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1021
{
yyVAL.colKeyOpt = colKeyUnique
}
case 164:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1026
{
yyVAL.optVal = nil
}
case 165:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1030
{
yyVAL.optVal = NewStrVal(yyDollar[2].bytes)
}
case 166:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1036
{
yyVAL.indexDefinition = &IndexDefinition{Info: yyDollar[1].indexInfo, Columns: yyDollar[3].indexColumns, Options: yyDollar[5].indexOptions}
}
case 167:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1040
{
yyVAL.indexDefinition = &IndexDefinition{Info: yyDollar[1].indexInfo, Columns: yyDollar[3].indexColumns}
}
case 168:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1046
{
yyVAL.indexOptions = []*IndexOption{yyDollar[1].indexOption}
}
case 169:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1050
{
yyVAL.indexOptions = append(yyVAL.indexOptions, yyDollar[2].indexOption)
}
case 170:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1056
{
yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Using: string(yyDollar[2].bytes)}
}
case 171:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1060
{
// should not be string
yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: NewIntVal(yyDollar[3].bytes)}
}
case 172:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1065
{
yyVAL.indexOption = &IndexOption{Name: string(yyDollar[1].bytes), Value: NewStrVal(yyDollar[2].bytes)}
}
case 173:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1071
{
yyVAL.str = ""
}
case 174:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1075
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 175:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1081
{
yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].bytes), Name: NewColIdent("PRIMARY"), Primary: true, Unique: true}
}
case 176:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1085
{
yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].str), Name: NewColIdent(string(yyDollar[3].bytes)), Spatial: true, Unique: false}
}
case 177:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1089
{
yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes) + " " + string(yyDollar[2].str), Name: NewColIdent(string(yyDollar[3].bytes)), Unique: true}
}
case 178:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1093
{
yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].bytes), Name: NewColIdent(string(yyDollar[2].bytes)), Unique: true}
}
case 179:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1097
{
yyVAL.indexInfo = &IndexInfo{Type: string(yyDollar[1].str), Name: NewColIdent(string(yyDollar[2].bytes)), Unique: false}
}
case 180:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1103
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 181:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1107
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 182:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1113
{
yyVAL.indexColumns = []*IndexColumn{yyDollar[1].indexColumn}
}
case 183:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1117
{
yyVAL.indexColumns = append(yyVAL.indexColumns, yyDollar[3].indexColumn)
}
case 184:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1123
{
yyVAL.indexColumn = &IndexColumn{Column: yyDollar[1].colIdent, Length: yyDollar[2].optVal}
}
case 185:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1128
{
yyVAL.str = ""
}
case 186:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1132
{
yyVAL.str = " " + string(yyDollar[1].str)
}
case 187:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1136
{
yyVAL.str = string(yyDollar[1].str) + ", " + string(yyDollar[3].str)
}
case 188:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1144
{
yyVAL.str = yyDollar[1].str
}
case 189:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1148
{
yyVAL.str = yyDollar[1].str + " " + yyDollar[2].str
}
case 190:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1152
{
yyVAL.str = yyDollar[1].str + "=" + yyDollar[3].str
}
case 191:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1158
{
yyVAL.str = yyDollar[1].colIdent.String()
}
case 192:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1162
{
yyVAL.str = "'" + string(yyDollar[1].bytes) + "'"
}
case 193:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1166
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 194:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:1172
{
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[4].tableName, NewName: yyDollar[4].tableName}
}
case 195:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1176
{
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[4].tableName, NewName: yyDollar[4].tableName}
}
case 196:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1180
{
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[4].tableName, NewName: yyDollar[4].tableName}
}
case 197:
yyDollar = yyS[yypt-12 : yypt+1]
//line sql.y:1184
{
yyVAL.statement = &DDL{
Action: AddColVindexStr,
Table: yyDollar[4].tableName,
VindexSpec: &VindexSpec{
Name: yyDollar[7].colIdent,
Type: yyDollar[11].colIdent,
Params: yyDollar[12].vindexParams,
},
VindexCols: yyDollar[9].columns,
}
}
case 198:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1197
{
yyVAL.statement = &DDL{
Action: DropColVindexStr,
Table: yyDollar[4].tableName,
VindexSpec: &VindexSpec{
Name: yyDollar[7].colIdent,
},
}
}
case 199:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1207
{
// Change this to a rename statement
yyVAL.statement = &DDL{Action: RenameStr, Table: yyDollar[4].tableName, NewName: yyDollar[7].tableName}
}
case 200:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1212
{
// Rename an index can just be an alter
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[4].tableName, NewName: yyDollar[4].tableName}
}
case 201:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1217
{
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[3].tableName.ToViewName(), NewName: yyDollar[3].tableName.ToViewName()}
}
case 202:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1221
{
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[4].tableName, PartitionSpec: yyDollar[5].partSpec}
}
case 214:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1240
{
yyVAL.partSpec = &PartitionSpec{Action: ReorganizeStr, Name: yyDollar[3].colIdent, Definitions: yyDollar[6].partDefs}
}
case 215:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1246
{
yyVAL.partDefs = []*PartitionDefinition{yyDollar[1].partDef}
}
case 216:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1250
{
yyVAL.partDefs = append(yyDollar[1].partDefs, yyDollar[3].partDef)
}
case 217:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:1256
{
yyVAL.partDef = &PartitionDefinition{Name: yyDollar[2].colIdent, Limit: yyDollar[7].expr}
}
case 218:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:1260
{
yyVAL.partDef = &PartitionDefinition{Name: yyDollar[2].colIdent, Maxvalue: true}
}
case 219:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1266
{
yyVAL.statement = &DDL{Action: RenameStr, Table: yyDollar[3].tableName, NewName: yyDollar[5].tableName}
}
case 220:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1272
{
var exists bool
if yyDollar[3].byt != 0 {
exists = true
}
yyVAL.statement = &DDL{Action: DropStr, Table: yyDollar[4].tableName, IfExists: exists}
}
case 221:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:1280
{
// Change this to an alter statement
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[5].tableName, NewName: yyDollar[5].tableName}
}
case 222:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1285
{
var exists bool
if yyDollar[3].byt != 0 {
exists = true
}
yyVAL.statement = &DDL{Action: DropStr, Table: yyDollar[4].tableName.ToViewName(), IfExists: exists}
}
case 223:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1293
{
yyVAL.statement = &DBDDL{Action: DropStr, DBName: string(yyDollar[4].bytes)}
}
case 224:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1297
{
yyVAL.statement = &DBDDL{Action: DropStr, DBName: string(yyDollar[4].bytes)}
}
case 225:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1303
{
yyVAL.statement = &DDL{Action: TruncateStr, Table: yyDollar[3].tableName}
}
case 226:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1307
{
yyVAL.statement = &DDL{Action: TruncateStr, Table: yyDollar[2].tableName}
}
case 227:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1312
{
yyVAL.statement = &DDL{Action: AlterStr, Table: yyDollar[3].tableName, NewName: yyDollar[3].tableName}
}
case 228:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1318
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 229:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1322
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 230:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1326
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 231:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1331
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 232:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1335
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 233:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1339
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 234:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1343
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 235:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1347
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes) + " " + string(yyDollar[3].bytes)}
}
case 236:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1351
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 237:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1355
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 238:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1359
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 239:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1363
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 240:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1367
{
yyVAL.statement = &Show{Scope: yyDollar[2].str, Type: string(yyDollar[3].bytes)}
}
case 241:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1371
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 242:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:1375
{
// this is ugly, but I couldn't find a better way for now
if yyDollar[4].str == "processlist" {
yyVAL.statement = &Show{Type: yyDollar[4].str}
} else {
showTablesOpt := &ShowTablesOpt{Extended: yyDollar[2].str, Full: yyDollar[3].str, DbName: yyDollar[5].str, Filter: yyDollar[6].showFilter}
yyVAL.statement = &Show{Type: yyDollar[4].str, ShowTablesOpt: showTablesOpt}
}
}
case 243:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1385
{
yyVAL.statement = &Show{Scope: yyDollar[2].str, Type: string(yyDollar[3].bytes)}
}
case 244:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1389
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 245:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1393
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes), OnTable: yyDollar[4].tableName}
}
case 246:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1397
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 247:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1401
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 248:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1405
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 249:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1409
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 250:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1419
{
yyVAL.statement = &Show{Type: string(yyDollar[2].bytes)}
}
case 251:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1425
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 252:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1429
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 253:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1435
{
yyVAL.str = ""
}
case 254:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1439
{
yyVAL.str = "extended "
}
case 255:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1445
{
yyVAL.str = ""
}
case 256:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1449
{
yyVAL.str = "full "
}
case 257:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1455
{
yyVAL.str = ""
}
case 258:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1459
{
yyVAL.str = yyDollar[2].tableIdent.v
}
case 259:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1463
{
yyVAL.str = yyDollar[2].tableIdent.v
}
case 260:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1469
{
yyVAL.showFilter = nil
}
case 261:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1473
{
yyVAL.showFilter = &ShowFilter{Like: string(yyDollar[2].bytes)}
}
case 262:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1477
{
yyVAL.showFilter = &ShowFilter{Filter: yyDollar[2].expr}
}
case 263:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1483
{
yyVAL.str = ""
}
case 264:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1487
{
yyVAL.str = SessionStr
}
case 265:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1491
{
yyVAL.str = GlobalStr
}
case 266:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1497
{
yyVAL.statement = &Use{DBName: yyDollar[2].tableIdent}
}
case 267:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1501
{
yyVAL.statement = &Use{DBName: TableIdent{v: ""}}
}
case 268:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1507
{
yyVAL.statement = &Begin{}
}
case 269:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1511
{
yyVAL.statement = &Begin{}
}
case 270:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1517
{
yyVAL.statement = &Commit{}
}
case 271:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1523
{
yyVAL.statement = &Rollback{}
}
case 272:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1529
{
yyVAL.statement = &OtherRead{}
}
case 273:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1533
{
yyVAL.statement = &OtherRead{}
}
case 274:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1537
{
yyVAL.statement = &OtherRead{}
}
case 275:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1541
{
yyVAL.statement = &OtherAdmin{}
}
case 276:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1545
{
yyVAL.statement = &OtherAdmin{}
}
case 277:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1550
{
setAllowComments(yylex, true)
}
case 278:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1554
{
yyVAL.bytes2 = yyDollar[2].bytes2
setAllowComments(yylex, false)
}
case 279:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1560
{
yyVAL.bytes2 = nil
}
case 280:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1564
{
yyVAL.bytes2 = append(yyDollar[1].bytes2, yyDollar[2].bytes)
}
case 281:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1570
{
yyVAL.str = UnionStr
}
case 282:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1574
{
yyVAL.str = UnionAllStr
}
case 283:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1578
{
yyVAL.str = UnionDistinctStr
}
case 284:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1583
{
yyVAL.str = ""
}
case 285:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1587
{
yyVAL.str = SQLNoCacheStr
}
case 286:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1591
{
yyVAL.str = SQLCacheStr
}
case 287:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1596
{
yyVAL.str = ""
}
case 288:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1600
{
yyVAL.str = DistinctStr
}
case 289:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1605
{
yyVAL.str = ""
}
case 290:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1609
{
yyVAL.str = StraightJoinHint
}
case 291:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1614
{
yyVAL.selectExprs = nil
}
case 292:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1618
{
yyVAL.selectExprs = yyDollar[1].selectExprs
}
case 293:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1624
{
yyVAL.selectExprs = SelectExprs{yyDollar[1].selectExpr}
}
case 294:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1628
{
yyVAL.selectExprs = append(yyVAL.selectExprs, yyDollar[3].selectExpr)
}
case 295:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1634
{
yyVAL.selectExpr = &StarExpr{}
}
case 296:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1638
{
yyVAL.selectExpr = &AliasedExpr{Expr: yyDollar[1].expr, As: yyDollar[2].colIdent}
}
case 297:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1642
{
yyVAL.selectExpr = &StarExpr{TableName: TableName{Name: yyDollar[1].tableIdent}}
}
case 298:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1646
{
yyVAL.selectExpr = &StarExpr{TableName: TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}}
}
case 299:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1651
{
yyVAL.colIdent = ColIdent{}
}
case 300:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1655
{
yyVAL.colIdent = yyDollar[1].colIdent
}
case 301:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1659
{
yyVAL.colIdent = yyDollar[2].colIdent
}
case 303:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1666
{
yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes))
}
case 304:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1671
{
yyVAL.tableExprs = TableExprs{&AliasedTableExpr{Expr: TableName{Name: NewTableIdent("dual")}}}
}
case 305:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1675
{
yyVAL.tableExprs = yyDollar[2].tableExprs
}
case 306:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1681
{
yyVAL.tableExprs = TableExprs{yyDollar[1].tableExpr}
}
case 307:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1685
{
yyVAL.tableExprs = append(yyVAL.tableExprs, yyDollar[3].tableExpr)
}
case 310:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1695
{
yyVAL.tableExpr = yyDollar[1].aliasedTableName
}
case 311:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1699
{
yyVAL.tableExpr = &AliasedTableExpr{Expr: yyDollar[1].subquery, As: yyDollar[3].tableIdent}
}
case 312:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1703
{
yyVAL.tableExpr = &ParenTableExpr{Exprs: yyDollar[2].tableExprs}
}
case 313:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1709
{
yyVAL.aliasedTableName = &AliasedTableExpr{Expr: yyDollar[1].tableName, As: yyDollar[2].tableIdent, Hints: yyDollar[3].indexHints}
}
case 314:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:1713
{
yyVAL.aliasedTableName = &AliasedTableExpr{Expr: yyDollar[1].tableName, Partitions: yyDollar[4].partitions, As: yyDollar[6].tableIdent, Hints: yyDollar[7].indexHints}
}
case 315:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1719
{
yyVAL.columns = Columns{yyDollar[1].colIdent}
}
case 316:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1723
{
yyVAL.columns = append(yyVAL.columns, yyDollar[3].colIdent)
}
case 317:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1729
{
yyVAL.partitions = Partitions{yyDollar[1].colIdent}
}
case 318:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1733
{
yyVAL.partitions = append(yyVAL.partitions, yyDollar[3].colIdent)
}
case 319:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1746
{
yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr, Condition: yyDollar[4].joinCondition}
}
case 320:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1750
{
yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr, Condition: yyDollar[4].joinCondition}
}
case 321:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1754
{
yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr, Condition: yyDollar[4].joinCondition}
}
case 322:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1758
{
yyVAL.tableExpr = &JoinTableExpr{LeftExpr: yyDollar[1].tableExpr, Join: yyDollar[2].str, RightExpr: yyDollar[3].tableExpr}
}
case 323:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1764
{
yyVAL.joinCondition = JoinCondition{On: yyDollar[2].expr}
}
case 324:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1766
{
yyVAL.joinCondition = JoinCondition{Using: yyDollar[3].columns}
}
case 325:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1770
{
yyVAL.joinCondition = JoinCondition{}
}
case 326:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1772
{
yyVAL.joinCondition = yyDollar[1].joinCondition
}
case 327:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1776
{
yyVAL.joinCondition = JoinCondition{}
}
case 328:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1778
{
yyVAL.joinCondition = JoinCondition{On: yyDollar[2].expr}
}
case 329:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1781
{
yyVAL.empty = struct{}{}
}
case 330:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1783
{
yyVAL.empty = struct{}{}
}
case 331:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1786
{
yyVAL.tableIdent = NewTableIdent("")
}
case 332:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1790
{
yyVAL.tableIdent = yyDollar[1].tableIdent
}
case 333:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1794
{
yyVAL.tableIdent = yyDollar[2].tableIdent
}
case 335:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1801
{
yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes))
}
case 336:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1807
{
yyVAL.str = JoinStr
}
case 337:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1811
{
yyVAL.str = JoinStr
}
case 338:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1815
{
yyVAL.str = JoinStr
}
case 339:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1821
{
yyVAL.str = StraightJoinStr
}
case 340:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1827
{
yyVAL.str = LeftJoinStr
}
case 341:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1831
{
yyVAL.str = LeftJoinStr
}
case 342:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1835
{
yyVAL.str = RightJoinStr
}
case 343:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1839
{
yyVAL.str = RightJoinStr
}
case 344:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1845
{
yyVAL.str = NaturalJoinStr
}
case 345:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1849
{
if yyDollar[2].str == LeftJoinStr {
yyVAL.str = NaturalLeftJoinStr
} else {
yyVAL.str = NaturalRightJoinStr
}
}
case 346:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1859
{
yyVAL.tableName = yyDollar[2].tableName
}
case 347:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1863
{
yyVAL.tableName = yyDollar[1].tableName
}
case 348:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1869
{
yyVAL.tableName = TableName{Name: yyDollar[1].tableIdent}
}
case 349:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1873
{
yyVAL.tableName = TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}
}
case 350:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1878
{
yyVAL.indexHints = nil
}
case 351:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1882
{
yyVAL.indexHints = &IndexHints{Type: UseStr, Indexes: yyDollar[4].columns}
}
case 352:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1886
{
yyVAL.indexHints = &IndexHints{Type: IgnoreStr, Indexes: yyDollar[4].columns}
}
case 353:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1890
{
yyVAL.indexHints = &IndexHints{Type: ForceStr, Indexes: yyDollar[4].columns}
}
case 354:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1895
{
yyVAL.expr = nil
}
case 355:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1899
{
yyVAL.expr = yyDollar[2].expr
}
case 356:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1905
{
yyVAL.expr = yyDollar[1].expr
}
case 357:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1909
{
yyVAL.expr = &AndExpr{Left: yyDollar[1].expr, Right: yyDollar[3].expr}
}
case 358:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1913
{
yyVAL.expr = &OrExpr{Left: yyDollar[1].expr, Right: yyDollar[3].expr}
}
case 359:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1917
{
yyVAL.expr = &NotExpr{Expr: yyDollar[2].expr}
}
case 360:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1921
{
yyVAL.expr = &IsExpr{Operator: yyDollar[3].str, Expr: yyDollar[1].expr}
}
case 361:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1925
{
yyVAL.expr = yyDollar[1].expr
}
case 362:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1929
{
yyVAL.expr = &Default{ColName: yyDollar[2].str}
}
case 363:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:1935
{
yyVAL.str = ""
}
case 364:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1939
{
yyVAL.str = string(yyDollar[2].bytes)
}
case 365:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1945
{
yyVAL.boolVal = BoolVal(true)
}
case 366:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1949
{
yyVAL.boolVal = BoolVal(false)
}
case 367:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1955
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: yyDollar[2].str, Right: yyDollar[3].expr}
}
case 368:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1959
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: InStr, Right: yyDollar[3].colTuple}
}
case 369:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1963
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: NotInStr, Right: yyDollar[4].colTuple}
}
case 370:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1967
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: LikeStr, Right: yyDollar[3].expr, Escape: yyDollar[4].expr}
}
case 371:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1971
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: NotLikeStr, Right: yyDollar[4].expr, Escape: yyDollar[5].expr}
}
case 372:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:1975
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: RegexpStr, Right: yyDollar[3].expr}
}
case 373:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:1979
{
yyVAL.expr = &ComparisonExpr{Left: yyDollar[1].expr, Operator: NotRegexpStr, Right: yyDollar[4].expr}
}
case 374:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:1983
{
yyVAL.expr = &RangeCond{Left: yyDollar[1].expr, Operator: BetweenStr, From: yyDollar[3].expr, To: yyDollar[5].expr}
}
case 375:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:1987
{
yyVAL.expr = &RangeCond{Left: yyDollar[1].expr, Operator: NotBetweenStr, From: yyDollar[4].expr, To: yyDollar[6].expr}
}
case 376:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:1991
{
yyVAL.expr = &ExistsExpr{Subquery: yyDollar[2].subquery}
}
case 377:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:1997
{
yyVAL.str = IsNullStr
}
case 378:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2001
{
yyVAL.str = IsNotNullStr
}
case 379:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2005
{
yyVAL.str = IsTrueStr
}
case 380:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2009
{
yyVAL.str = IsNotTrueStr
}
case 381:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2013
{
yyVAL.str = IsFalseStr
}
case 382:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2017
{
yyVAL.str = IsNotFalseStr
}
case 383:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2023
{
yyVAL.str = EqualStr
}
case 384:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2027
{
yyVAL.str = LessThanStr
}
case 385:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2031
{
yyVAL.str = GreaterThanStr
}
case 386:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2035
{
yyVAL.str = LessEqualStr
}
case 387:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2039
{
yyVAL.str = GreaterEqualStr
}
case 388:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2043
{
yyVAL.str = NotEqualStr
}
case 389:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2047
{
yyVAL.str = NullSafeEqualStr
}
case 390:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2052
{
yyVAL.expr = nil
}
case 391:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2056
{
yyVAL.expr = yyDollar[2].expr
}
case 392:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2062
{
yyVAL.colTuple = yyDollar[1].valTuple
}
case 393:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2066
{
yyVAL.colTuple = yyDollar[1].subquery
}
case 394:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2070
{
yyVAL.colTuple = ListArg(yyDollar[1].bytes)
}
case 395:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2076
{
yyVAL.subquery = &Subquery{yyDollar[2].selStmt}
}
case 396:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2082
{
yyVAL.exprs = Exprs{yyDollar[1].expr}
}
case 397:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2086
{
yyVAL.exprs = append(yyDollar[1].exprs, yyDollar[3].expr)
}
case 398:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2092
{
yyVAL.expr = yyDollar[1].expr
}
case 399:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2096
{
yyVAL.expr = yyDollar[1].boolVal
}
case 400:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2100
{
yyVAL.expr = yyDollar[1].colName
}
case 401:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2104
{
yyVAL.expr = yyDollar[1].expr
}
case 402:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2108
{
yyVAL.expr = yyDollar[1].subquery
}
case 403:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2112
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: BitAndStr, Right: yyDollar[3].expr}
}
case 404:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2116
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: BitOrStr, Right: yyDollar[3].expr}
}
case 405:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2120
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: BitXorStr, Right: yyDollar[3].expr}
}
case 406:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2124
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: PlusStr, Right: yyDollar[3].expr}
}
case 407:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2128
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: MinusStr, Right: yyDollar[3].expr}
}
case 408:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2132
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: MultStr, Right: yyDollar[3].expr}
}
case 409:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2136
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: DivStr, Right: yyDollar[3].expr}
}
case 410:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2140
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: IntDivStr, Right: yyDollar[3].expr}
}
case 411:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2144
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ModStr, Right: yyDollar[3].expr}
}
case 412:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2148
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ModStr, Right: yyDollar[3].expr}
}
case 413:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2152
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ShiftLeftStr, Right: yyDollar[3].expr}
}
case 414:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2156
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].expr, Operator: ShiftRightStr, Right: yyDollar[3].expr}
}
case 415:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2160
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].colName, Operator: JSONExtractOp, Right: yyDollar[3].expr}
}
case 416:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2164
{
yyVAL.expr = &BinaryExpr{Left: yyDollar[1].colName, Operator: JSONUnquoteExtractOp, Right: yyDollar[3].expr}
}
case 417:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2168
{
yyVAL.expr = &CollateExpr{Expr: yyDollar[1].expr, Charset: yyDollar[3].str}
}
case 418:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2172
{
yyVAL.expr = &UnaryExpr{Operator: BinaryStr, Expr: yyDollar[2].expr}
}
case 419:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2176
{
yyVAL.expr = &UnaryExpr{Operator: UBinaryStr, Expr: yyDollar[2].expr}
}
case 420:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2180
{
if num, ok := yyDollar[2].expr.(*SQLVal); ok && num.Type == IntVal {
yyVAL.expr = num
} else {
yyVAL.expr = &UnaryExpr{Operator: UPlusStr, Expr: yyDollar[2].expr}
}
}
case 421:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2188
{
if num, ok := yyDollar[2].expr.(*SQLVal); ok && num.Type == IntVal {
// Handle double negative
if num.Val[0] == '-' {
num.Val = num.Val[1:]
yyVAL.expr = num
} else {
yyVAL.expr = NewIntVal(append([]byte("-"), num.Val...))
}
} else {
yyVAL.expr = &UnaryExpr{Operator: UMinusStr, Expr: yyDollar[2].expr}
}
}
case 422:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2202
{
yyVAL.expr = &UnaryExpr{Operator: TildaStr, Expr: yyDollar[2].expr}
}
case 423:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2206
{
yyVAL.expr = &UnaryExpr{Operator: BangStr, Expr: yyDollar[2].expr}
}
case 424:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2210
{
// This rule prevents the usage of INTERVAL
// as a function. If support is needed for that,
// we'll need to revisit this. The solution
// will be non-trivial because of grammar conflicts.
yyVAL.expr = &IntervalExpr{Expr: yyDollar[2].expr, Unit: yyDollar[3].colIdent.String()}
}
case 429:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2228
{
yyVAL.expr = &FuncExpr{Name: yyDollar[1].colIdent, Exprs: yyDollar[3].selectExprs}
}
case 430:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:2232
{
yyVAL.expr = &FuncExpr{Name: yyDollar[1].colIdent, Distinct: true, Exprs: yyDollar[4].selectExprs}
}
case 431:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2236
{
yyVAL.expr = &FuncExpr{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].colIdent, Exprs: yyDollar[5].selectExprs}
}
case 432:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2246
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("left"), Exprs: yyDollar[3].selectExprs}
}
case 433:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2250
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("right"), Exprs: yyDollar[3].selectExprs}
}
case 434:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2254
{
yyVAL.expr = &ConvertExpr{Expr: yyDollar[3].expr, Type: yyDollar[5].convertType}
}
case 435:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2258
{
yyVAL.expr = &ConvertExpr{Expr: yyDollar[3].expr, Type: yyDollar[5].convertType}
}
case 436:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2262
{
yyVAL.expr = &ConvertUsingExpr{Expr: yyDollar[3].expr, Type: yyDollar[5].str}
}
case 437:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2266
{
yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: nil}
}
case 438:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:2270
{
yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: yyDollar[7].expr}
}
case 439:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:2274
{
yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: yyDollar[7].expr}
}
case 440:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2278
{
yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: nil}
}
case 441:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:2282
{
yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: yyDollar[7].expr}
}
case 442:
yyDollar = yyS[yypt-8 : yypt+1]
//line sql.y:2286
{
yyVAL.expr = &SubstrExpr{Name: yyDollar[3].colName, From: yyDollar[5].expr, To: yyDollar[7].expr}
}
case 443:
yyDollar = yyS[yypt-9 : yypt+1]
//line sql.y:2290
{
yyVAL.expr = &MatchExpr{Columns: yyDollar[3].selectExprs, Expr: yyDollar[7].expr, Option: yyDollar[8].str}
}
case 444:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:2294
{
yyVAL.expr = &GroupConcatExpr{Distinct: yyDollar[3].str, Exprs: yyDollar[4].selectExprs, OrderBy: yyDollar[5].orderBy, Separator: yyDollar[6].str}
}
case 445:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:2298
{
yyVAL.expr = &CaseExpr{Expr: yyDollar[2].expr, Whens: yyDollar[3].whens, Else: yyDollar[4].expr}
}
case 446:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2302
{
yyVAL.expr = &ValuesFuncExpr{Name: yyDollar[3].colName}
}
case 447:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2312
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("current_timestamp")}
}
case 448:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2316
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("utc_timestamp")}
}
case 449:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2320
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("utc_time")}
}
case 450:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2324
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("utc_date")}
}
case 451:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2329
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("localtime")}
}
case 452:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2334
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("localtimestamp")}
}
case 453:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2339
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("current_date")}
}
case 454:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2344
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("current_time")}
}
case 457:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2358
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("if"), Exprs: yyDollar[3].selectExprs}
}
case 458:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2362
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("database"), Exprs: yyDollar[3].selectExprs}
}
case 459:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2366
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("mod"), Exprs: yyDollar[3].selectExprs}
}
case 460:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2370
{
yyVAL.expr = &FuncExpr{Name: NewColIdent("replace"), Exprs: yyDollar[3].selectExprs}
}
case 461:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2376
{
yyVAL.str = ""
}
case 462:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2380
{
yyVAL.str = BooleanModeStr
}
case 463:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2384
{
yyVAL.str = NaturalLanguageModeStr
}
case 464:
yyDollar = yyS[yypt-7 : yypt+1]
//line sql.y:2388
{
yyVAL.str = NaturalLanguageModeWithQueryExpansionStr
}
case 465:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2392
{
yyVAL.str = QueryExpansionStr
}
case 466:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2398
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 467:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2402
{
yyVAL.str = string(yyDollar[1].bytes)
}
case 468:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2408
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 469:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2412
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal, Charset: yyDollar[3].str, Operator: CharacterSetStr}
}
case 470:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2416
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal, Charset: string(yyDollar[3].bytes)}
}
case 471:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2420
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
}
case 472:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2424
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 473:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2428
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
yyVAL.convertType.Length = yyDollar[2].LengthScaleOption.Length
yyVAL.convertType.Scale = yyDollar[2].LengthScaleOption.Scale
}
case 474:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2434
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
}
case 475:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2438
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 476:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2442
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
}
case 477:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2446
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
}
case 478:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2450
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes), Length: yyDollar[2].optVal}
}
case 479:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2454
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
}
case 480:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2458
{
yyVAL.convertType = &ConvertType{Type: string(yyDollar[1].bytes)}
}
case 481:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2463
{
yyVAL.expr = nil
}
case 482:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2467
{
yyVAL.expr = yyDollar[1].expr
}
case 483:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2472
{
yyVAL.str = string("")
}
case 484:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2476
{
yyVAL.str = " separator '" + string(yyDollar[2].bytes) + "'"
}
case 485:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2482
{
yyVAL.whens = []*When{yyDollar[1].when}
}
case 486:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2486
{
yyVAL.whens = append(yyDollar[1].whens, yyDollar[2].when)
}
case 487:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2492
{
yyVAL.when = &When{Cond: yyDollar[2].expr, Val: yyDollar[4].expr}
}
case 488:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2497
{
yyVAL.expr = nil
}
case 489:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2501
{
yyVAL.expr = yyDollar[2].expr
}
case 490:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2507
{
yyVAL.colName = &ColName{Name: yyDollar[1].colIdent}
}
case 491:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2511
{
yyVAL.colName = &ColName{Qualifier: TableName{Name: yyDollar[1].tableIdent}, Name: yyDollar[3].colIdent}
}
case 492:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:2515
{
yyVAL.colName = &ColName{Qualifier: TableName{Qualifier: yyDollar[1].tableIdent, Name: yyDollar[3].tableIdent}, Name: yyDollar[5].colIdent}
}
case 493:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2521
{
yyVAL.expr = NewStrVal(yyDollar[1].bytes)
}
case 494:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2525
{
yyVAL.expr = NewHexVal(yyDollar[1].bytes)
}
case 495:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2529
{
yyVAL.expr = NewBitVal(yyDollar[1].bytes)
}
case 496:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2533
{
yyVAL.expr = NewIntVal(yyDollar[1].bytes)
}
case 497:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2537
{
yyVAL.expr = NewFloatVal(yyDollar[1].bytes)
}
case 498:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2541
{
yyVAL.expr = NewHexNum(yyDollar[1].bytes)
}
case 499:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2545
{
yyVAL.expr = NewValArg(yyDollar[1].bytes)
}
case 500:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2549
{
yyVAL.expr = &NullVal{}
}
case 501:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2555
{
// TODO(sougou): Deprecate this construct.
if yyDollar[1].colIdent.Lowered() != "value" {
yylex.Error("expecting value after next")
return 1
}
yyVAL.expr = NewIntVal([]byte("1"))
}
case 502:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2564
{
yyVAL.expr = NewIntVal(yyDollar[1].bytes)
}
case 503:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2568
{
yyVAL.expr = NewValArg(yyDollar[1].bytes)
}
case 504:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2573
{
yyVAL.exprs = nil
}
case 505:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2577
{
yyVAL.exprs = yyDollar[3].exprs
}
case 506:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2582
{
yyVAL.expr = nil
}
case 507:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2586
{
yyVAL.expr = yyDollar[2].expr
}
case 508:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2591
{
yyVAL.orderBy = nil
}
case 509:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2595
{
yyVAL.orderBy = yyDollar[3].orderBy
}
case 510:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2601
{
yyVAL.orderBy = OrderBy{yyDollar[1].order}
}
case 511:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2605
{
yyVAL.orderBy = append(yyDollar[1].orderBy, yyDollar[3].order)
}
case 512:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2611
{
yyVAL.order = &Order{Expr: yyDollar[1].expr, Direction: yyDollar[2].str}
}
case 513:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2616
{
yyVAL.str = AscScr
}
case 514:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2620
{
yyVAL.str = AscScr
}
case 515:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2624
{
yyVAL.str = DescScr
}
case 516:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2629
{
yyVAL.limit = nil
}
case 517:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2633
{
yyVAL.limit = &Limit{Rowcount: yyDollar[2].expr}
}
case 518:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2637
{
yyVAL.limit = &Limit{Offset: yyDollar[2].expr, Rowcount: yyDollar[4].expr}
}
case 519:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2641
{
yyVAL.limit = &Limit{Offset: yyDollar[4].expr, Rowcount: yyDollar[2].expr}
}
case 520:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2646
{
yyVAL.str = ""
}
case 521:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2650
{
yyVAL.str = ForUpdateStr
}
case 522:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2654
{
yyVAL.str = ShareModeStr
}
case 523:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2667
{
yyVAL.ins = &Insert{Rows: yyDollar[2].values}
}
case 524:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2671
{
yyVAL.ins = &Insert{Rows: yyDollar[1].selStmt}
}
case 525:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2675
{
// Drop the redundant parenthesis.
yyVAL.ins = &Insert{Rows: yyDollar[2].selStmt}
}
case 526:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:2680
{
yyVAL.ins = &Insert{Columns: yyDollar[2].columns, Rows: yyDollar[5].values}
}
case 527:
yyDollar = yyS[yypt-4 : yypt+1]
//line sql.y:2684
{
yyVAL.ins = &Insert{Columns: yyDollar[2].columns, Rows: yyDollar[4].selStmt}
}
case 528:
yyDollar = yyS[yypt-6 : yypt+1]
//line sql.y:2688
{
// Drop the redundant parenthesis.
yyVAL.ins = &Insert{Columns: yyDollar[2].columns, Rows: yyDollar[5].selStmt}
}
case 529:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2695
{
yyVAL.columns = Columns{yyDollar[1].colIdent}
}
case 530:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2699
{
yyVAL.columns = Columns{yyDollar[3].colIdent}
}
case 531:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2703
{
yyVAL.columns = append(yyVAL.columns, yyDollar[3].colIdent)
}
case 532:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:2707
{
yyVAL.columns = append(yyVAL.columns, yyDollar[5].colIdent)
}
case 533:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2712
{
yyVAL.updateExprs = nil
}
case 534:
yyDollar = yyS[yypt-5 : yypt+1]
//line sql.y:2716
{
yyVAL.updateExprs = yyDollar[5].updateExprs
}
case 535:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2722
{
yyVAL.values = Values{yyDollar[1].valTuple}
}
case 536:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2726
{
yyVAL.values = append(yyDollar[1].values, yyDollar[3].valTuple)
}
case 537:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2732
{
yyVAL.valTuple = yyDollar[1].valTuple
}
case 538:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2736
{
yyVAL.valTuple = ValTuple{}
}
case 539:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2742
{
yyVAL.valTuple = ValTuple(yyDollar[2].exprs)
}
case 540:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2748
{
if len(yyDollar[1].valTuple) == 1 {
yyVAL.expr = &ParenExpr{yyDollar[1].valTuple[0]}
} else {
yyVAL.expr = yyDollar[1].valTuple
}
}
case 541:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2758
{
yyVAL.updateExprs = UpdateExprs{yyDollar[1].updateExpr}
}
case 542:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2762
{
yyVAL.updateExprs = append(yyDollar[1].updateExprs, yyDollar[3].updateExpr)
}
case 543:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2768
{
yyVAL.updateExpr = &UpdateExpr{Name: yyDollar[1].colName, Expr: yyDollar[3].expr}
}
case 544:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2774
{
yyVAL.setExprs = SetExprs{yyDollar[1].setExpr}
}
case 545:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2778
{
yyVAL.setExprs = append(yyDollar[1].setExprs, yyDollar[3].setExpr)
}
case 546:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2784
{
yyVAL.setExpr = &SetExpr{Name: yyDollar[1].colIdent, Expr: NewStrVal([]byte("on"))}
}
case 547:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2788
{
yyVAL.setExpr = &SetExpr{Name: yyDollar[1].colIdent, Expr: yyDollar[3].expr}
}
case 548:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2792
{
yyVAL.setExpr = &SetExpr{Name: NewColIdent(string(yyDollar[1].bytes)), Expr: yyDollar[2].expr}
}
case 550:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2799
{
yyVAL.bytes = []byte("charset")
}
case 552:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2806
{
yyVAL.expr = NewStrVal([]byte(yyDollar[1].colIdent.String()))
}
case 553:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2810
{
yyVAL.expr = NewStrVal(yyDollar[1].bytes)
}
case 554:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2814
{
yyVAL.expr = &Default{}
}
case 557:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2823
{
yyVAL.byt = 0
}
case 558:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2825
{
yyVAL.byt = 1
}
case 559:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2828
{
yyVAL.empty = struct{}{}
}
case 560:
yyDollar = yyS[yypt-3 : yypt+1]
//line sql.y:2830
{
yyVAL.empty = struct{}{}
}
case 561:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2833
{
yyVAL.str = ""
}
case 562:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2835
{
yyVAL.str = IgnoreStr
}
case 563:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2839
{
yyVAL.empty = struct{}{}
}
case 564:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2841
{
yyVAL.empty = struct{}{}
}
case 565:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2843
{
yyVAL.empty = struct{}{}
}
case 566:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2845
{
yyVAL.empty = struct{}{}
}
case 567:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2847
{
yyVAL.empty = struct{}{}
}
case 568:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2849
{
yyVAL.empty = struct{}{}
}
case 569:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2851
{
yyVAL.empty = struct{}{}
}
case 570:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2853
{
yyVAL.empty = struct{}{}
}
case 571:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2855
{
yyVAL.empty = struct{}{}
}
case 572:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2857
{
yyVAL.empty = struct{}{}
}
case 573:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2860
{
yyVAL.empty = struct{}{}
}
case 574:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2862
{
yyVAL.empty = struct{}{}
}
case 575:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2864
{
yyVAL.empty = struct{}{}
}
case 576:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2868
{
yyVAL.empty = struct{}{}
}
case 577:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2870
{
yyVAL.empty = struct{}{}
}
case 578:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2873
{
yyVAL.empty = struct{}{}
}
case 579:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2875
{
yyVAL.empty = struct{}{}
}
case 580:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2877
{
yyVAL.empty = struct{}{}
}
case 581:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:2880
{
yyVAL.colIdent = ColIdent{}
}
case 582:
yyDollar = yyS[yypt-2 : yypt+1]
//line sql.y:2882
{
yyVAL.colIdent = yyDollar[2].colIdent
}
case 583:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2886
{
yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes))
}
case 584:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2890
{
yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes))
}
case 586:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2897
{
yyVAL.colIdent = NewColIdent(string(yyDollar[1].bytes))
}
case 587:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2903
{
yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes))
}
case 588:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2907
{
yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes))
}
case 590:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:2914
{
yyVAL.tableIdent = NewTableIdent(string(yyDollar[1].bytes))
}
case 781:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:3130
{
if incNesting(yylex) {
yylex.Error("max nesting level reached")
return 1
}
}
case 782:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:3139
{
decNesting(yylex)
}
case 783:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:3144
{
forceEOF(yylex)
}
case 784:
yyDollar = yyS[yypt-0 : yypt+1]
//line sql.y:3149
{
forceEOF(yylex)
}
case 785:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:3153
{
forceEOF(yylex)
}
case 786:
yyDollar = yyS[yypt-1 : yypt+1]
//line sql.y:3157
{
forceEOF(yylex)
}
}
goto yystack /* stack new state and value */
}