All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.edurt.datacap.parser.mysql.MySqlParser Maven / Gradle / Ivy

There is a newer version: 2024.4.0
Show newest version
// Generated from io/edurt/datacap/parser/mysql/MySqlParser.g4 by ANTLR 4.12.0
package io.edurt.datacap.parser.mysql;
import org.antlr.v4.runtime.atn.*;
import org.antlr.v4.runtime.dfa.DFA;
import org.antlr.v4.runtime.*;
import org.antlr.v4.runtime.misc.*;
import org.antlr.v4.runtime.tree.*;
import java.util.List;
import java.util.Iterator;
import java.util.ArrayList;

@SuppressWarnings({"all", "warnings", "unchecked", "unused", "cast", "CheckReturnValue"})
public class MySqlParser extends Parser {
	static { RuntimeMetaData.checkVersion("4.12.0", RuntimeMetaData.VERSION); }

	protected static final DFA[] _decisionToDFA;
	protected static final PredictionContextCache _sharedContextCache =
		new PredictionContextCache();
	public static final int
		SPACE=1, SPEC_MYSQL_COMMENT=2, COMMENT_INPUT=3, LINE_COMMENT=4, ADD=5, 
		ALL=6, ALTER=7, ALWAYS=8, ANALYZE=9, AND=10, ARRAY=11, AS=12, ASC=13, 
		ATTRIBUTE=14, BEFORE=15, BETWEEN=16, BOTH=17, BUCKETS=18, BY=19, CALL=20, 
		CASCADE=21, CASE=22, CAST=23, CHANGE=24, CHARACTER=25, CHECK=26, COLLATE=27, 
		COLUMN=28, CONDITION=29, CONSTRAINT=30, CONTINUE=31, CONVERT=32, CREATE=33, 
		CROSS=34, CURRENT=35, CURRENT_ROLE=36, CURRENT_USER=37, CURSOR=38, DATABASE=39, 
		DATABASES=40, DECLARE=41, DEFAULT=42, DELAYED=43, DELETE=44, DESC=45, 
		DESCRIBE=46, DETERMINISTIC=47, DIAGNOSTICS=48, DISTINCT=49, DISTINCTROW=50, 
		DROP=51, EACH=52, ELSE=53, ELSEIF=54, EMPTY=55, ENCLOSED=56, ENFORCED=57, 
		ESCAPED=58, EXCEPT=59, EXISTS=60, EXIT=61, EXPLAIN=62, FALSE=63, FETCH=64, 
		FOR=65, FORCE=66, FOREIGN=67, FROM=68, FULLTEXT=69, GENERATED=70, GET=71, 
		GRANT=72, GROUP=73, HAVING=74, HIGH_PRIORITY=75, HISTOGRAM=76, IF=77, 
		IGNORE=78, IGNORED=79, IN=80, INDEX=81, INFILE=82, INNER=83, INOUT=84, 
		INSERT=85, INTERVAL=86, INTO=87, IS=88, ITERATE=89, JOIN=90, KEY=91, KEYS=92, 
		KILL=93, LATERAL=94, LEADING=95, LEAVE=96, LEFT=97, LIKE=98, LIMIT=99, 
		LINEAR=100, LINES=101, LOAD=102, LOCK=103, LOCKED=104, LOOP=105, LOW_PRIORITY=106, 
		MASTER_BIND=107, MASTER_SSL_VERIFY_SERVER_CERT=108, MATCH=109, MAXVALUE=110, 
		MINVALUE=111, MODIFIES=112, NATURAL=113, NOT=114, NO_WRITE_TO_BINLOG=115, 
		NULL_LITERAL=116, NUMBER=117, ON=118, OPTIMIZE=119, OPTION=120, OPTIONAL=121, 
		OPTIONALLY=122, OR=123, ORDER=124, OUT=125, OUTER=126, OUTFILE=127, OVER=128, 
		PARTITION=129, PRIMARY=130, PROCEDURE=131, PURGE=132, RANGE=133, READ=134, 
		READS=135, REFERENCES=136, REGEXP=137, RELEASE=138, RENAME=139, REPEAT=140, 
		REPLACE=141, REQUIRE=142, RESIGNAL=143, RESTRICT=144, RETAIN=145, RETURN=146, 
		REVOKE=147, RIGHT=148, RLIKE=149, SCHEMA=150, SCHEMAS=151, SELECT=152, 
		SET=153, SEPARATOR=154, SHOW=155, SIGNAL=156, SKIP_=157, SKIP_QUERY_REWRITE=158, 
		SPATIAL=159, SQL=160, SQLEXCEPTION=161, SQLSTATE=162, SQLWARNING=163, 
		SQL_BIG_RESULT=164, SQL_CALC_FOUND_ROWS=165, SQL_SMALL_RESULT=166, SSL=167, 
		STACKED=168, STARTING=169, STATEMENT=170, STRAIGHT_JOIN=171, TABLE=172, 
		TERMINATED=173, THEN=174, TO=175, TRAILING=176, TRIGGER=177, TRUE=178, 
		UNDO=179, UNION=180, UNIQUE=181, UNLOCK=182, UNSIGNED=183, UPDATE=184, 
		USAGE=185, USE=186, USING=187, VALUES=188, WHEN=189, WHERE=190, WHILE=191, 
		WITH=192, WRITE=193, XOR=194, ZEROFILL=195, TINYINT=196, SMALLINT=197, 
		MEDIUMINT=198, MIDDLEINT=199, INT=200, INT1=201, INT2=202, INT3=203, INT4=204, 
		INT8=205, INTEGER=206, BIGINT=207, REAL=208, DOUBLE=209, PRECISION=210, 
		FLOAT=211, FLOAT4=212, FLOAT8=213, DECIMAL=214, DEC=215, NUMERIC=216, 
		DATE=217, TIME=218, TIMESTAMP=219, DATETIME=220, YEAR=221, CHAR=222, VARCHAR=223, 
		NVARCHAR=224, NATIONAL=225, BINARY=226, VARBINARY=227, TINYBLOB=228, BLOB=229, 
		MEDIUMBLOB=230, LONG=231, LONGBLOB=232, TINYTEXT=233, TEXT=234, MEDIUMTEXT=235, 
		LONGTEXT=236, ENUM=237, VARYING=238, SERIAL=239, YEAR_MONTH=240, DAY_HOUR=241, 
		DAY_MINUTE=242, DAY_SECOND=243, HOUR_MINUTE=244, HOUR_SECOND=245, MINUTE_SECOND=246, 
		SECOND_MICROSECOND=247, MINUTE_MICROSECOND=248, HOUR_MICROSECOND=249, 
		DAY_MICROSECOND=250, JSON_ARRAY=251, JSON_ARRAYAGG=252, JSON_ARRAY_APPEND=253, 
		JSON_ARRAY_INSERT=254, JSON_CONTAINS=255, JSON_CONTAINS_PATH=256, JSON_DEPTH=257, 
		JSON_EXTRACT=258, JSON_INSERT=259, JSON_KEYS=260, JSON_LENGTH=261, JSON_MERGE=262, 
		JSON_MERGE_PATCH=263, JSON_MERGE_PRESERVE=264, JSON_OBJECT=265, JSON_OBJECTAGG=266, 
		JSON_OVERLAPS=267, JSON_PRETTY=268, JSON_QUOTE=269, JSON_REMOVE=270, JSON_REPLACE=271, 
		JSON_SCHEMA_VALID=272, JSON_SCHEMA_VALIDATION_REPORT=273, JSON_SEARCH=274, 
		JSON_SET=275, JSON_STORAGE_FREE=276, JSON_STORAGE_SIZE=277, JSON_TABLE=278, 
		JSON_TYPE=279, JSON_UNQUOTE=280, JSON_VALID=281, JSON_VALUE=282, NESTED=283, 
		ORDINALITY=284, PATH=285, AVG=286, BIT_AND=287, BIT_OR=288, BIT_XOR=289, 
		COUNT=290, CUME_DIST=291, DENSE_RANK=292, FIRST_VALUE=293, GROUP_CONCAT=294, 
		LAG=295, LAST_VALUE=296, LEAD=297, MAX=298, MIN=299, NTILE=300, NTH_VALUE=301, 
		PERCENT_RANK=302, RANK=303, ROW_NUMBER=304, STD=305, STDDEV=306, STDDEV_POP=307, 
		STDDEV_SAMP=308, SUM=309, VAR_POP=310, VAR_SAMP=311, VARIANCE=312, CURRENT_DATE=313, 
		CURRENT_TIME=314, CURRENT_TIMESTAMP=315, LOCALTIME=316, CURDATE=317, CURTIME=318, 
		DATE_ADD=319, DATE_SUB=320, EXTRACT=321, LOCALTIMESTAMP=322, NOW=323, 
		POSITION=324, SUBSTR=325, SUBSTRING=326, SYSDATE=327, TRIM=328, UTC_DATE=329, 
		UTC_TIME=330, UTC_TIMESTAMP=331, ACCOUNT=332, ACTION=333, AFTER=334, AGGREGATE=335, 
		ALGORITHM=336, ANY=337, AT=338, AUTHORS=339, AUTOCOMMIT=340, AUTOEXTEND_SIZE=341, 
		AUTO_INCREMENT=342, AVG_ROW_LENGTH=343, BEGIN=344, BINLOG=345, BIT=346, 
		BLOCK=347, BOOL=348, BOOLEAN=349, BTREE=350, CACHE=351, CASCADED=352, 
		CHAIN=353, CHANGED=354, CHANNEL=355, CHECKSUM=356, PAGE_CHECKSUM=357, 
		CIPHER=358, CLASS_ORIGIN=359, CLIENT=360, CLOSE=361, CLUSTERING=362, COALESCE=363, 
		CODE=364, COLUMNS=365, COLUMN_FORMAT=366, COLUMN_NAME=367, COMMENT=368, 
		COMMIT=369, COMPACT=370, COMPLETION=371, COMPRESSED=372, COMPRESSION=373, 
		CONCURRENT=374, CONNECT=375, CONNECTION=376, CONSISTENT=377, CONSTRAINT_CATALOG=378, 
		CONSTRAINT_SCHEMA=379, CONSTRAINT_NAME=380, CONTAINS=381, CONTEXT=382, 
		CONTRIBUTORS=383, COPY=384, CPU=385, CYCLE=386, CURSOR_NAME=387, DATA=388, 
		DATAFILE=389, DEALLOCATE=390, DEFAULT_AUTH=391, DEFINER=392, DELAY_KEY_WRITE=393, 
		DES_KEY_FILE=394, DIRECTORY=395, DISABLE=396, DISCARD=397, DISK=398, DO=399, 
		DUMPFILE=400, DUPLICATE=401, DYNAMIC=402, ENABLE=403, ENCRYPTED=404, ENCRYPTION=405, 
		ENCRYPTION_KEY_ID=406, END=407, ENDS=408, ENGINE=409, ENGINES=410, ERROR=411, 
		ERRORS=412, ESCAPE=413, EVEN=414, EVENT=415, EVENTS=416, EVERY=417, EXCHANGE=418, 
		EXCLUSIVE=419, EXPIRE=420, EXPORT=421, EXTENDED=422, EXTENT_SIZE=423, 
		FAILED_LOGIN_ATTEMPTS=424, FAST=425, FAULTS=426, FIELDS=427, FILE_BLOCK_SIZE=428, 
		FILTER=429, FIRST=430, FIXED=431, FLUSH=432, FOLLOWING=433, FOLLOWS=434, 
		FOUND=435, FULL=436, FUNCTION=437, GENERAL=438, GLOBAL=439, GRANTS=440, 
		GROUP_REPLICATION=441, HANDLER=442, HASH=443, HELP=444, HISTORY=445, HOST=446, 
		HOSTS=447, IDENTIFIED=448, IGNORE_SERVER_IDS=449, IMPORT=450, INCREMENT=451, 
		INDEXES=452, INITIAL_SIZE=453, INPLACE=454, INSERT_METHOD=455, INSTALL=456, 
		INSTANCE=457, INSTANT=458, INVISIBLE=459, INVOKER=460, IO=461, IO_THREAD=462, 
		IPC=463, ISOLATION=464, ISSUER=465, JSON=466, KEY_BLOCK_SIZE=467, LANGUAGE=468, 
		LAST=469, LEAVES=470, LESS=471, LEVEL=472, LIST=473, LOCAL=474, LOGFILE=475, 
		LOGS=476, MASTER=477, MASTER_AUTO_POSITION=478, MASTER_CONNECT_RETRY=479, 
		MASTER_DELAY=480, MASTER_HEARTBEAT_PERIOD=481, MASTER_HOST=482, MASTER_LOG_FILE=483, 
		MASTER_LOG_POS=484, MASTER_PASSWORD=485, MASTER_PORT=486, MASTER_RETRY_COUNT=487, 
		MASTER_SSL=488, MASTER_SSL_CA=489, MASTER_SSL_CAPATH=490, MASTER_SSL_CERT=491, 
		MASTER_SSL_CIPHER=492, MASTER_SSL_CRL=493, MASTER_SSL_CRLPATH=494, MASTER_SSL_KEY=495, 
		MASTER_TLS_VERSION=496, MASTER_USER=497, MAX_CONNECTIONS_PER_HOUR=498, 
		MAX_QUERIES_PER_HOUR=499, MAX_ROWS=500, MAX_SIZE=501, MAX_UPDATES_PER_HOUR=502, 
		MAX_USER_CONNECTIONS=503, MEDIUM=504, MEMBER=505, MERGE=506, MESSAGE_TEXT=507, 
		MID=508, MIGRATE=509, MIN_ROWS=510, MODE=511, MODIFY=512, MUTEX=513, MYSQL=514, 
		MYSQL_ERRNO=515, NAME=516, NAMES=517, NCHAR=518, NEVER=519, NEXT=520, 
		NO=521, NOCACHE=522, NOCOPY=523, NOCYCLE=524, NOMAXVALUE=525, NOMINVALUE=526, 
		NOWAIT=527, NODEGROUP=528, NONE=529, ODBC=530, OFFLINE=531, OFFSET=532, 
		OF=533, OJ=534, OLD_PASSWORD=535, ONE=536, ONLINE=537, ONLY=538, OPEN=539, 
		OPTIMIZER_COSTS=540, OPTIONS=541, OWNER=542, PACK_KEYS=543, PAGE=544, 
		PAGE_COMPRESSED=545, PAGE_COMPRESSION_LEVEL=546, PARSER=547, PARTIAL=548, 
		PARTITIONING=549, PARTITIONS=550, PASSWORD=551, PASSWORD_LOCK_TIME=552, 
		PHASE=553, PLUGIN=554, PLUGIN_DIR=555, PLUGINS=556, PORT=557, PRECEDES=558, 
		PRECEDING=559, PREPARE=560, PRESERVE=561, PREV=562, PROCESSLIST=563, PROFILE=564, 
		PROFILES=565, PROXY=566, QUERY=567, QUICK=568, REBUILD=569, RECOVER=570, 
		RECURSIVE=571, REDO_BUFFER_SIZE=572, REDUNDANT=573, RELAY=574, RELAY_LOG_FILE=575, 
		RELAY_LOG_POS=576, RELAYLOG=577, REMOVE=578, REORGANIZE=579, REPAIR=580, 
		REPLICATE_DO_DB=581, REPLICATE_DO_TABLE=582, REPLICATE_IGNORE_DB=583, 
		REPLICATE_IGNORE_TABLE=584, REPLICATE_REWRITE_DB=585, REPLICATE_WILD_DO_TABLE=586, 
		REPLICATE_WILD_IGNORE_TABLE=587, REPLICATION=588, RESET=589, RESTART=590, 
		RESUME=591, RETURNED_SQLSTATE=592, RETURNING=593, RETURNS=594, REUSE=595, 
		ROLE=596, ROLLBACK=597, ROLLUP=598, ROTATE=599, ROW=600, ROWS=601, ROW_FORMAT=602, 
		RTREE=603, SAVEPOINT=604, SCHEDULE=605, SECURITY=606, SEQUENCE=607, SERVER=608, 
		SESSION=609, SHARE=610, SHARED=611, SIGNED=612, SIMPLE=613, SLAVE=614, 
		SLOW=615, SNAPSHOT=616, SOCKET=617, SOME=618, SONAME=619, SOUNDS=620, 
		SOURCE=621, SQL_AFTER_GTIDS=622, SQL_AFTER_MTS_GAPS=623, SQL_BEFORE_GTIDS=624, 
		SQL_BUFFER_RESULT=625, SQL_CACHE=626, SQL_NO_CACHE=627, SQL_THREAD=628, 
		START=629, STARTS=630, STATS_AUTO_RECALC=631, STATS_PERSISTENT=632, STATS_SAMPLE_PAGES=633, 
		STATUS=634, STOP=635, STORAGE=636, STORED=637, STRING=638, SUBCLASS_ORIGIN=639, 
		SUBJECT=640, SUBPARTITION=641, SUBPARTITIONS=642, SUSPEND=643, SWAPS=644, 
		SWITCHES=645, TABLE_NAME=646, TABLESPACE=647, TABLE_TYPE=648, TEMPORARY=649, 
		TEMPTABLE=650, THAN=651, TRADITIONAL=652, TRANSACTION=653, TRANSACTIONAL=654, 
		TRIGGERS=655, TRUNCATE=656, UNBOUNDED=657, UNDEFINED=658, UNDOFILE=659, 
		UNDO_BUFFER_SIZE=660, UNINSTALL=661, UNKNOWN=662, UNTIL=663, UPGRADE=664, 
		USER=665, USE_FRM=666, USER_RESOURCES=667, VALIDATION=668, VALUE=669, 
		VARIABLES=670, VIEW=671, VIRTUAL=672, VISIBLE=673, WAIT=674, WARNINGS=675, 
		WINDOW=676, WITHOUT=677, WORK=678, WRAPPER=679, X509=680, XA=681, XML=682, 
		YES=683, EUR=684, USA=685, JIS=686, ISO=687, INTERNAL=688, QUARTER=689, 
		MONTH=690, DAY=691, HOUR=692, MINUTE=693, WEEK=694, SECOND=695, MICROSECOND=696, 
		ADMIN=697, APPLICATION_PASSWORD_ADMIN=698, AUDIT_ABORT_EXEMPT=699, AUDIT_ADMIN=700, 
		AUTHENTICATION_POLICY_ADMIN=701, BACKUP_ADMIN=702, BINLOG_ADMIN=703, BINLOG_ENCRYPTION_ADMIN=704, 
		CLONE_ADMIN=705, CONNECTION_ADMIN=706, ENCRYPTION_KEY_ADMIN=707, EXECUTE=708, 
		FILE=709, FIREWALL_ADMIN=710, FIREWALL_EXEMPT=711, FIREWALL_USER=712, 
		FLUSH_OPTIMIZER_COSTS=713, FLUSH_STATUS=714, FLUSH_TABLES=715, FLUSH_USER_RESOURCES=716, 
		GROUP_REPLICATION_ADMIN=717, INNODB_REDO_LOG_ARCHIVE=718, INNODB_REDO_LOG_ENABLE=719, 
		INVOKE=720, LAMBDA=721, NDB_STORED_USER=722, PASSWORDLESS_USER_ADMIN=723, 
		PERSIST_RO_VARIABLES_ADMIN=724, PRIVILEGES=725, PROCESS=726, RELOAD=727, 
		REPLICATION_APPLIER=728, REPLICATION_SLAVE_ADMIN=729, RESOURCE_GROUP_ADMIN=730, 
		RESOURCE_GROUP_USER=731, ROLE_ADMIN=732, ROUTINE=733, S3=734, SERVICE_CONNECTION_ADMIN=735, 
		SESSION_VARIABLES_ADMIN=736, SET_USER_ID=737, SHOW_ROUTINE=738, SHUTDOWN=739, 
		SUPER=740, SYSTEM_VARIABLES_ADMIN=741, TABLES=742, TABLE_ENCRYPTION_ADMIN=743, 
		VERSION_TOKEN_ADMIN=744, XA_RECOVER_ADMIN=745, ARMSCII8=746, ASCII=747, 
		BIG5=748, CP1250=749, CP1251=750, CP1256=751, CP1257=752, CP850=753, CP852=754, 
		CP866=755, CP932=756, DEC8=757, EUCJPMS=758, EUCKR=759, GB18030=760, GB2312=761, 
		GBK=762, GEOSTD8=763, GREEK=764, HEBREW=765, HP8=766, KEYBCS2=767, KOI8R=768, 
		KOI8U=769, LATIN1=770, LATIN2=771, LATIN5=772, LATIN7=773, MACCE=774, 
		MACROMAN=775, SJIS=776, SWE7=777, TIS620=778, UCS2=779, UJIS=780, UTF16=781, 
		UTF16LE=782, UTF32=783, UTF8=784, UTF8MB3=785, UTF8MB4=786, ARCHIVE=787, 
		BLACKHOLE=788, CSV=789, FEDERATED=790, INNODB=791, MEMORY=792, MRG_MYISAM=793, 
		MYISAM=794, NDB=795, NDBCLUSTER=796, PERFORMANCE_SCHEMA=797, TOKUDB=798, 
		REPEATABLE=799, COMMITTED=800, UNCOMMITTED=801, SERIALIZABLE=802, GEOMETRYCOLLECTION=803, 
		GEOMCOLLECTION=804, GEOMETRY=805, LINESTRING=806, MULTILINESTRING=807, 
		MULTIPOINT=808, MULTIPOLYGON=809, POINT=810, POLYGON=811, ABS=812, ACOS=813, 
		ADDDATE=814, ADDTIME=815, AES_DECRYPT=816, AES_ENCRYPT=817, AREA=818, 
		ASBINARY=819, ASIN=820, ASTEXT=821, ASWKB=822, ASWKT=823, ASYMMETRIC_DECRYPT=824, 
		ASYMMETRIC_DERIVE=825, ASYMMETRIC_ENCRYPT=826, ASYMMETRIC_SIGN=827, ASYMMETRIC_VERIFY=828, 
		ATAN=829, ATAN2=830, BENCHMARK=831, BIN=832, BIT_COUNT=833, BIT_LENGTH=834, 
		BUFFER=835, CATALOG_NAME=836, CEIL=837, CEILING=838, CENTROID=839, CHARACTER_LENGTH=840, 
		CHARSET=841, CHAR_LENGTH=842, COERCIBILITY=843, COLLATION=844, COMPRESS=845, 
		CONCAT=846, CONCAT_WS=847, CONNECTION_ID=848, CONV=849, CONVERT_TZ=850, 
		COS=851, COT=852, CRC32=853, CREATE_ASYMMETRIC_PRIV_KEY=854, CREATE_ASYMMETRIC_PUB_KEY=855, 
		CREATE_DH_PARAMETERS=856, CREATE_DIGEST=857, CROSSES=858, DATEDIFF=859, 
		DATE_FORMAT=860, DAYNAME=861, DAYOFMONTH=862, DAYOFWEEK=863, DAYOFYEAR=864, 
		DECODE=865, DEGREES=866, DES_DECRYPT=867, DES_ENCRYPT=868, DIMENSION=869, 
		DISJOINT=870, ELT=871, ENCODE=872, ENCRYPT=873, ENDPOINT=874, ENGINE_ATTRIBUTE=875, 
		ENVELOPE=876, EQUALS=877, EXP=878, EXPORT_SET=879, EXTERIORRING=880, EXTRACTVALUE=881, 
		FIELD=882, FIND_IN_SET=883, FLOOR=884, FORMAT=885, FOUND_ROWS=886, FROM_BASE64=887, 
		FROM_DAYS=888, FROM_UNIXTIME=889, GEOMCOLLFROMTEXT=890, GEOMCOLLFROMWKB=891, 
		GEOMETRYCOLLECTIONFROMTEXT=892, GEOMETRYCOLLECTIONFROMWKB=893, GEOMETRYFROMTEXT=894, 
		GEOMETRYFROMWKB=895, GEOMETRYN=896, GEOMETRYTYPE=897, GEOMFROMTEXT=898, 
		GEOMFROMWKB=899, GET_FORMAT=900, GET_LOCK=901, GLENGTH=902, GREATEST=903, 
		GTID_SUBSET=904, GTID_SUBTRACT=905, HEX=906, IFNULL=907, INET6_ATON=908, 
		INET6_NTOA=909, INET_ATON=910, INET_NTOA=911, INSTR=912, INTERIORRINGN=913, 
		INTERSECTS=914, ISCLOSED=915, ISEMPTY=916, ISNULL=917, ISSIMPLE=918, IS_FREE_LOCK=919, 
		IS_IPV4=920, IS_IPV4_COMPAT=921, IS_IPV4_MAPPED=922, IS_IPV6=923, IS_USED_LOCK=924, 
		LAST_INSERT_ID=925, LCASE=926, LEAST=927, LENGTH=928, LINEFROMTEXT=929, 
		LINEFROMWKB=930, LINESTRINGFROMTEXT=931, LINESTRINGFROMWKB=932, LN=933, 
		LOAD_FILE=934, LOCATE=935, LOG=936, LOG10=937, LOG2=938, LOWER=939, LPAD=940, 
		LTRIM=941, MAKEDATE=942, MAKETIME=943, MAKE_SET=944, MASTER_POS_WAIT=945, 
		MBRCONTAINS=946, MBRDISJOINT=947, MBREQUAL=948, MBRINTERSECTS=949, MBROVERLAPS=950, 
		MBRTOUCHES=951, MBRWITHIN=952, MD5=953, MLINEFROMTEXT=954, MLINEFROMWKB=955, 
		MONTHNAME=956, MPOINTFROMTEXT=957, MPOINTFROMWKB=958, MPOLYFROMTEXT=959, 
		MPOLYFROMWKB=960, MULTILINESTRINGFROMTEXT=961, MULTILINESTRINGFROMWKB=962, 
		MULTIPOINTFROMTEXT=963, MULTIPOINTFROMWKB=964, MULTIPOLYGONFROMTEXT=965, 
		MULTIPOLYGONFROMWKB=966, NAME_CONST=967, NULLIF=968, NUMGEOMETRIES=969, 
		NUMINTERIORRINGS=970, NUMPOINTS=971, OCT=972, OCTET_LENGTH=973, ORD=974, 
		OVERLAPS=975, PERIOD_ADD=976, PERIOD_DIFF=977, PI=978, POINTFROMTEXT=979, 
		POINTFROMWKB=980, POINTN=981, POLYFROMTEXT=982, POLYFROMWKB=983, POLYGONFROMTEXT=984, 
		POLYGONFROMWKB=985, POW=986, POWER=987, QUOTE=988, RADIANS=989, RAND=990, 
		RANDOM=991, RANDOM_BYTES=992, RELEASE_LOCK=993, REVERSE=994, ROUND=995, 
		ROW_COUNT=996, RPAD=997, RTRIM=998, SEC_TO_TIME=999, SECONDARY_ENGINE_ATTRIBUTE=1000, 
		SESSION_USER=1001, SHA=1002, SHA1=1003, SHA2=1004, SCHEMA_NAME=1005, SIGN=1006, 
		SIN=1007, SLEEP=1008, SOUNDEX=1009, SQL_THREAD_WAIT_AFTER_GTIDS=1010, 
		SQRT=1011, SRID=1012, STARTPOINT=1013, STRCMP=1014, STR_TO_DATE=1015, 
		ST_AREA=1016, ST_ASBINARY=1017, ST_ASTEXT=1018, ST_ASWKB=1019, ST_ASWKT=1020, 
		ST_BUFFER=1021, ST_CENTROID=1022, ST_CONTAINS=1023, ST_CROSSES=1024, ST_DIFFERENCE=1025, 
		ST_DIMENSION=1026, ST_DISJOINT=1027, ST_DISTANCE=1028, ST_ENDPOINT=1029, 
		ST_ENVELOPE=1030, ST_EQUALS=1031, ST_EXTERIORRING=1032, ST_GEOMCOLLFROMTEXT=1033, 
		ST_GEOMCOLLFROMTXT=1034, ST_GEOMCOLLFROMWKB=1035, ST_GEOMETRYCOLLECTIONFROMTEXT=1036, 
		ST_GEOMETRYCOLLECTIONFROMWKB=1037, ST_GEOMETRYFROMTEXT=1038, ST_GEOMETRYFROMWKB=1039, 
		ST_GEOMETRYN=1040, ST_GEOMETRYTYPE=1041, ST_GEOMFROMTEXT=1042, ST_GEOMFROMWKB=1043, 
		ST_INTERIORRINGN=1044, ST_INTERSECTION=1045, ST_INTERSECTS=1046, ST_ISCLOSED=1047, 
		ST_ISEMPTY=1048, ST_ISSIMPLE=1049, ST_LINEFROMTEXT=1050, ST_LINEFROMWKB=1051, 
		ST_LINESTRINGFROMTEXT=1052, ST_LINESTRINGFROMWKB=1053, ST_NUMGEOMETRIES=1054, 
		ST_NUMINTERIORRING=1055, ST_NUMINTERIORRINGS=1056, ST_NUMPOINTS=1057, 
		ST_OVERLAPS=1058, ST_POINTFROMTEXT=1059, ST_POINTFROMWKB=1060, ST_POINTN=1061, 
		ST_POLYFROMTEXT=1062, ST_POLYFROMWKB=1063, ST_POLYGONFROMTEXT=1064, ST_POLYGONFROMWKB=1065, 
		ST_SRID=1066, ST_STARTPOINT=1067, ST_SYMDIFFERENCE=1068, ST_TOUCHES=1069, 
		ST_UNION=1070, ST_WITHIN=1071, ST_X=1072, ST_Y=1073, SUBDATE=1074, SUBSTRING_INDEX=1075, 
		SUBTIME=1076, SYSTEM_USER=1077, TAN=1078, TIMEDIFF=1079, TIMESTAMPADD=1080, 
		TIMESTAMPDIFF=1081, TIME_FORMAT=1082, TIME_TO_SEC=1083, TOUCHES=1084, 
		TO_BASE64=1085, TO_DAYS=1086, TO_SECONDS=1087, TP_CONNECTION_ADMIN=1088, 
		UCASE=1089, UNCOMPRESS=1090, UNCOMPRESSED_LENGTH=1091, UNHEX=1092, UNIX_TIMESTAMP=1093, 
		UPDATEXML=1094, UPPER=1095, UUID=1096, UUID_SHORT=1097, VALIDATE_PASSWORD_STRENGTH=1098, 
		VERSION=1099, WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS=1100, WEEKDAY=1101, WEEKOFYEAR=1102, 
		WEIGHT_STRING=1103, WITHIN=1104, YEARWEEK=1105, Y_FUNCTION=1106, X_FUNCTION=1107, 
		VAR_ASSIGN=1108, PLUS_ASSIGN=1109, MINUS_ASSIGN=1110, MULT_ASSIGN=1111, 
		DIV_ASSIGN=1112, MOD_ASSIGN=1113, AND_ASSIGN=1114, XOR_ASSIGN=1115, OR_ASSIGN=1116, 
		STAR=1117, DIVIDE=1118, MODULE=1119, PLUS=1120, MINUS=1121, DIV=1122, 
		MOD=1123, EQUAL_SYMBOL=1124, GREATER_SYMBOL=1125, LESS_SYMBOL=1126, EXCLAMATION_SYMBOL=1127, 
		BIT_NOT_OP=1128, BIT_OR_OP=1129, BIT_AND_OP=1130, BIT_XOR_OP=1131, DOT=1132, 
		LR_BRACKET=1133, RR_BRACKET=1134, COMMA=1135, SEMI=1136, AT_SIGN=1137, 
		ZERO_DECIMAL=1138, ONE_DECIMAL=1139, TWO_DECIMAL=1140, SINGLE_QUOTE_SYMB=1141, 
		DOUBLE_QUOTE_SYMB=1142, REVERSE_QUOTE_SYMB=1143, COLON_SYMB=1144, CHARSET_REVERSE_QOUTE_STRING=1145, 
		FILESIZE_LITERAL=1146, START_NATIONAL_STRING_LITERAL=1147, STRING_LITERAL=1148, 
		DECIMAL_LITERAL=1149, HEXADECIMAL_LITERAL=1150, REAL_LITERAL=1151, NULL_SPEC_LITERAL=1152, 
		BIT_STRING=1153, STRING_CHARSET_NAME=1154, DOT_ID=1155, ID=1156, REVERSE_QUOTE_ID=1157, 
		HOST_IP_ADDRESS=1158, LOCAL_ID=1159, GLOBAL_ID=1160, ERROR_RECONGNIGION=1161;
	public static final int
		RULE_root = 0, RULE_sqlStatements = 1, RULE_sqlStatement = 2, RULE_emptyStatement_ = 3, 
		RULE_ddlStatement = 4, RULE_dmlStatement = 5, RULE_transactionStatement = 6, 
		RULE_replicationStatement = 7, RULE_preparedStatement = 8, RULE_compoundStatement = 9, 
		RULE_administrationStatement = 10, RULE_utilityStatement = 11, RULE_createDatabase = 12, 
		RULE_createEvent = 13, RULE_createIndex = 14, RULE_createLogfileGroup = 15, 
		RULE_createProcedure = 16, RULE_createFunction = 17, RULE_createRole = 18, 
		RULE_createServer = 19, RULE_createTable = 20, RULE_createTablespaceInnodb = 21, 
		RULE_createTablespaceNdb = 22, RULE_createTrigger = 23, RULE_withClause = 24, 
		RULE_commonTableExpressions = 25, RULE_cteName = 26, RULE_cteColumnName = 27, 
		RULE_createView = 28, RULE_createDatabaseOption = 29, RULE_charSet = 30, 
		RULE_currentUserExpression = 31, RULE_ownerStatement = 32, RULE_scheduleExpression = 33, 
		RULE_timestampValue = 34, RULE_intervalExpr = 35, RULE_intervalType = 36, 
		RULE_enableType = 37, RULE_indexType = 38, RULE_indexOption = 39, RULE_procedureParameter = 40, 
		RULE_functionParameter = 41, RULE_routineOption = 42, RULE_serverOption = 43, 
		RULE_createDefinitions = 44, RULE_createDefinition = 45, RULE_columnDefinition = 46, 
		RULE_columnConstraint = 47, RULE_tableConstraint = 48, RULE_referenceDefinition = 49, 
		RULE_referenceAction = 50, RULE_referenceControlType = 51, RULE_indexColumnDefinition = 52, 
		RULE_tableOption = 53, RULE_tableType = 54, RULE_tablespaceStorage = 55, 
		RULE_partitionDefinitions = 56, RULE_partitionFunctionDefinition = 57, 
		RULE_subpartitionFunctionDefinition = 58, RULE_partitionDefinition = 59, 
		RULE_partitionDefinerAtom = 60, RULE_partitionDefinerVector = 61, RULE_subpartitionDefinition = 62, 
		RULE_partitionOption = 63, RULE_alterDatabase = 64, RULE_alterEvent = 65, 
		RULE_alterFunction = 66, RULE_alterInstance = 67, RULE_alterLogfileGroup = 68, 
		RULE_alterProcedure = 69, RULE_alterServer = 70, RULE_alterTable = 71, 
		RULE_alterTablespace = 72, RULE_alterView = 73, RULE_alterSpecification = 74, 
		RULE_alterPartitionSpecification = 75, RULE_dropDatabase = 76, RULE_dropEvent = 77, 
		RULE_dropIndex = 78, RULE_dropLogfileGroup = 79, RULE_dropProcedure = 80, 
		RULE_dropFunction = 81, RULE_dropServer = 82, RULE_dropTable = 83, RULE_dropTablespace = 84, 
		RULE_dropTrigger = 85, RULE_dropView = 86, RULE_dropRole = 87, RULE_setRole = 88, 
		RULE_renameTable = 89, RULE_renameTableClause = 90, RULE_truncateTable = 91, 
		RULE_callStatement = 92, RULE_deleteStatement = 93, RULE_doStatement = 94, 
		RULE_handlerStatement = 95, RULE_insertStatement = 96, RULE_loadDataStatement = 97, 
		RULE_loadXmlStatement = 98, RULE_replaceStatement = 99, RULE_selectStatement = 100, 
		RULE_updateStatement = 101, RULE_valuesStatement = 102, RULE_insertStatementValue = 103, 
		RULE_updatedElement = 104, RULE_assignmentField = 105, RULE_lockClause = 106, 
		RULE_singleDeleteStatement = 107, RULE_multipleDeleteStatement = 108, 
		RULE_handlerOpenStatement = 109, RULE_handlerReadIndexStatement = 110, 
		RULE_handlerReadStatement = 111, RULE_handlerCloseStatement = 112, RULE_singleUpdateStatement = 113, 
		RULE_multipleUpdateStatement = 114, RULE_orderByClause = 115, RULE_orderByExpression = 116, 
		RULE_tableSources = 117, RULE_tableSource = 118, RULE_tableSourceItem = 119, 
		RULE_indexHint = 120, RULE_indexHintType = 121, RULE_joinPart = 122, RULE_joinSpec = 123, 
		RULE_queryExpression = 124, RULE_queryExpressionNointo = 125, RULE_querySpecification = 126, 
		RULE_querySpecificationNointo = 127, RULE_unionParenthesis = 128, RULE_unionStatement = 129, 
		RULE_lateralStatement = 130, RULE_jsonTable = 131, RULE_jsonColumnList = 132, 
		RULE_jsonColumn = 133, RULE_jsonOnEmpty = 134, RULE_jsonOnError = 135, 
		RULE_selectSpec = 136, RULE_selectElements = 137, RULE_selectElement = 138, 
		RULE_selectIntoExpression = 139, RULE_selectFieldsInto = 140, RULE_selectLinesInto = 141, 
		RULE_fromClause = 142, RULE_groupByClause = 143, RULE_havingClause = 144, 
		RULE_windowClause = 145, RULE_groupByItem = 146, RULE_limitClause = 147, 
		RULE_limitClauseAtom = 148, RULE_startTransaction = 149, RULE_beginWork = 150, 
		RULE_commitWork = 151, RULE_rollbackWork = 152, RULE_savepointStatement = 153, 
		RULE_rollbackStatement = 154, RULE_releaseStatement = 155, RULE_lockTables = 156, 
		RULE_unlockTables = 157, RULE_setAutocommitStatement = 158, RULE_setTransactionStatement = 159, 
		RULE_transactionMode = 160, RULE_lockTableElement = 161, RULE_lockAction = 162, 
		RULE_transactionOption = 163, RULE_transactionLevel = 164, RULE_changeMaster = 165, 
		RULE_changeReplicationFilter = 166, RULE_purgeBinaryLogs = 167, RULE_resetMaster = 168, 
		RULE_resetSlave = 169, RULE_startSlave = 170, RULE_stopSlave = 171, RULE_startGroupReplication = 172, 
		RULE_stopGroupReplication = 173, RULE_masterOption = 174, RULE_stringMasterOption = 175, 
		RULE_decimalMasterOption = 176, RULE_boolMasterOption = 177, RULE_channelOption = 178, 
		RULE_replicationFilter = 179, RULE_tablePair = 180, RULE_threadType = 181, 
		RULE_untilOption = 182, RULE_connectionOption = 183, RULE_gtuidSet = 184, 
		RULE_xaStartTransaction = 185, RULE_xaEndTransaction = 186, RULE_xaPrepareStatement = 187, 
		RULE_xaCommitWork = 188, RULE_xaRollbackWork = 189, RULE_xaRecoverWork = 190, 
		RULE_prepareStatement = 191, RULE_executeStatement = 192, RULE_deallocatePrepare = 193, 
		RULE_routineBody = 194, RULE_blockStatement = 195, RULE_caseStatement = 196, 
		RULE_ifStatement = 197, RULE_iterateStatement = 198, RULE_leaveStatement = 199, 
		RULE_loopStatement = 200, RULE_repeatStatement = 201, RULE_returnStatement = 202, 
		RULE_whileStatement = 203, RULE_cursorStatement = 204, RULE_declareVariable = 205, 
		RULE_declareCondition = 206, RULE_declareCursor = 207, RULE_declareHandler = 208, 
		RULE_handlerConditionValue = 209, RULE_procedureSqlStatement = 210, RULE_caseAlternative = 211, 
		RULE_elifAlternative = 212, RULE_alterUser = 213, RULE_createUser = 214, 
		RULE_dropUser = 215, RULE_grantStatement = 216, RULE_roleOption = 217, 
		RULE_grantProxy = 218, RULE_renameUser = 219, RULE_revokeStatement = 220, 
		RULE_revokeProxy = 221, RULE_setPasswordStatement = 222, RULE_userSpecification = 223, 
		RULE_userAuthOption = 224, RULE_authOptionClause = 225, RULE_authenticationRule = 226, 
		RULE_tlsOption = 227, RULE_userResourceOption = 228, RULE_userPasswordOption = 229, 
		RULE_userLockOption = 230, RULE_privelegeClause = 231, RULE_privilege = 232, 
		RULE_privilegeLevel = 233, RULE_renameUserClause = 234, RULE_analyzeTable = 235, 
		RULE_checkTable = 236, RULE_checksumTable = 237, RULE_optimizeTable = 238, 
		RULE_repairTable = 239, RULE_checkTableOption = 240, RULE_createUdfunction = 241, 
		RULE_installPlugin = 242, RULE_uninstallPlugin = 243, RULE_setStatement = 244, 
		RULE_showStatement = 245, RULE_variableClause = 246, RULE_showCommonEntity = 247, 
		RULE_showFilter = 248, RULE_showGlobalInfoClause = 249, RULE_showSchemaEntity = 250, 
		RULE_showProfileType = 251, RULE_binlogStatement = 252, RULE_cacheIndexStatement = 253, 
		RULE_flushStatement = 254, RULE_killStatement = 255, RULE_loadIndexIntoCache = 256, 
		RULE_resetStatement = 257, RULE_shutdownStatement = 258, RULE_tableIndexes = 259, 
		RULE_flushOption = 260, RULE_flushTableOption = 261, RULE_loadedTableIndexes = 262, 
		RULE_simpleDescribeStatement = 263, RULE_fullDescribeStatement = 264, 
		RULE_helpStatement = 265, RULE_useStatement = 266, RULE_signalStatement = 267, 
		RULE_resignalStatement = 268, RULE_signalConditionInformation = 269, RULE_withStatement = 270, 
		RULE_tableStatement = 271, RULE_diagnosticsStatement = 272, RULE_diagnosticsConditionInformationName = 273, 
		RULE_describeObjectClause = 274, RULE_fullId = 275, RULE_tableName = 276, 
		RULE_roleName = 277, RULE_fullColumnName = 278, RULE_indexColumnName = 279, 
		RULE_simpleUserName = 280, RULE_hostName = 281, RULE_userName = 282, RULE_mysqlVariable = 283, 
		RULE_charsetName = 284, RULE_collationName = 285, RULE_engineName = 286, 
		RULE_engineNameBase = 287, RULE_uuidSet = 288, RULE_xid = 289, RULE_xuidStringId = 290, 
		RULE_authPlugin = 291, RULE_uid = 292, RULE_simpleId = 293, RULE_dottedId = 294, 
		RULE_decimalLiteral = 295, RULE_fileSizeLiteral = 296, RULE_stringLiteral = 297, 
		RULE_booleanLiteral = 298, RULE_hexadecimalLiteral = 299, RULE_nullNotnull = 300, 
		RULE_constant = 301, RULE_dataType = 302, RULE_collectionOptions = 303, 
		RULE_convertedDataType = 304, RULE_lengthOneDimension = 305, RULE_lengthTwoDimension = 306, 
		RULE_lengthTwoOptionalDimension = 307, RULE_uidList = 308, RULE_fullColumnNameList = 309, 
		RULE_tables = 310, RULE_indexColumnNames = 311, RULE_expressions = 312, 
		RULE_expressionsWithDefaults = 313, RULE_constants = 314, RULE_simpleStrings = 315, 
		RULE_userVariables = 316, RULE_defaultValue = 317, RULE_currentTimestamp = 318, 
		RULE_expressionOrDefault = 319, RULE_ifExists = 320, RULE_ifNotExists = 321, 
		RULE_orReplace = 322, RULE_waitNowaitClause = 323, RULE_functionCall = 324, 
		RULE_specificFunction = 325, RULE_caseFuncAlternative = 326, RULE_levelsInWeightString = 327, 
		RULE_levelInWeightListElement = 328, RULE_aggregateWindowedFunction = 329, 
		RULE_nonAggregateWindowedFunction = 330, RULE_overClause = 331, RULE_windowSpec = 332, 
		RULE_windowName = 333, RULE_frameClause = 334, RULE_frameUnits = 335, 
		RULE_frameExtent = 336, RULE_frameBetween = 337, RULE_frameRange = 338, 
		RULE_partitionClause = 339, RULE_scalarFunctionName = 340, RULE_passwordFunctionClause = 341, 
		RULE_functionArgs = 342, RULE_functionArg = 343, RULE_expression = 344, 
		RULE_predicate = 345, RULE_expressionAtom = 346, RULE_unaryOperator = 347, 
		RULE_comparisonOperator = 348, RULE_logicalOperator = 349, RULE_bitOperator = 350, 
		RULE_multOperator = 351, RULE_addOperator = 352, RULE_jsonOperator = 353, 
		RULE_charsetNameBase = 354, RULE_transactionLevelBase = 355, RULE_privilegesBase = 356, 
		RULE_intervalTypeBase = 357, RULE_dataTypeBase = 358, RULE_keywordsCanBeId = 359, 
		RULE_functionNameBase = 360;
	private static String[] makeRuleNames() {
		return new String[] {
			"root", "sqlStatements", "sqlStatement", "emptyStatement_", "ddlStatement", 
			"dmlStatement", "transactionStatement", "replicationStatement", "preparedStatement", 
			"compoundStatement", "administrationStatement", "utilityStatement", "createDatabase", 
			"createEvent", "createIndex", "createLogfileGroup", "createProcedure", 
			"createFunction", "createRole", "createServer", "createTable", "createTablespaceInnodb", 
			"createTablespaceNdb", "createTrigger", "withClause", "commonTableExpressions", 
			"cteName", "cteColumnName", "createView", "createDatabaseOption", "charSet", 
			"currentUserExpression", "ownerStatement", "scheduleExpression", "timestampValue", 
			"intervalExpr", "intervalType", "enableType", "indexType", "indexOption", 
			"procedureParameter", "functionParameter", "routineOption", "serverOption", 
			"createDefinitions", "createDefinition", "columnDefinition", "columnConstraint", 
			"tableConstraint", "referenceDefinition", "referenceAction", "referenceControlType", 
			"indexColumnDefinition", "tableOption", "tableType", "tablespaceStorage", 
			"partitionDefinitions", "partitionFunctionDefinition", "subpartitionFunctionDefinition", 
			"partitionDefinition", "partitionDefinerAtom", "partitionDefinerVector", 
			"subpartitionDefinition", "partitionOption", "alterDatabase", "alterEvent", 
			"alterFunction", "alterInstance", "alterLogfileGroup", "alterProcedure", 
			"alterServer", "alterTable", "alterTablespace", "alterView", "alterSpecification", 
			"alterPartitionSpecification", "dropDatabase", "dropEvent", "dropIndex", 
			"dropLogfileGroup", "dropProcedure", "dropFunction", "dropServer", "dropTable", 
			"dropTablespace", "dropTrigger", "dropView", "dropRole", "setRole", "renameTable", 
			"renameTableClause", "truncateTable", "callStatement", "deleteStatement", 
			"doStatement", "handlerStatement", "insertStatement", "loadDataStatement", 
			"loadXmlStatement", "replaceStatement", "selectStatement", "updateStatement", 
			"valuesStatement", "insertStatementValue", "updatedElement", "assignmentField", 
			"lockClause", "singleDeleteStatement", "multipleDeleteStatement", "handlerOpenStatement", 
			"handlerReadIndexStatement", "handlerReadStatement", "handlerCloseStatement", 
			"singleUpdateStatement", "multipleUpdateStatement", "orderByClause", 
			"orderByExpression", "tableSources", "tableSource", "tableSourceItem", 
			"indexHint", "indexHintType", "joinPart", "joinSpec", "queryExpression", 
			"queryExpressionNointo", "querySpecification", "querySpecificationNointo", 
			"unionParenthesis", "unionStatement", "lateralStatement", "jsonTable", 
			"jsonColumnList", "jsonColumn", "jsonOnEmpty", "jsonOnError", "selectSpec", 
			"selectElements", "selectElement", "selectIntoExpression", "selectFieldsInto", 
			"selectLinesInto", "fromClause", "groupByClause", "havingClause", "windowClause", 
			"groupByItem", "limitClause", "limitClauseAtom", "startTransaction", 
			"beginWork", "commitWork", "rollbackWork", "savepointStatement", "rollbackStatement", 
			"releaseStatement", "lockTables", "unlockTables", "setAutocommitStatement", 
			"setTransactionStatement", "transactionMode", "lockTableElement", "lockAction", 
			"transactionOption", "transactionLevel", "changeMaster", "changeReplicationFilter", 
			"purgeBinaryLogs", "resetMaster", "resetSlave", "startSlave", "stopSlave", 
			"startGroupReplication", "stopGroupReplication", "masterOption", "stringMasterOption", 
			"decimalMasterOption", "boolMasterOption", "channelOption", "replicationFilter", 
			"tablePair", "threadType", "untilOption", "connectionOption", "gtuidSet", 
			"xaStartTransaction", "xaEndTransaction", "xaPrepareStatement", "xaCommitWork", 
			"xaRollbackWork", "xaRecoverWork", "prepareStatement", "executeStatement", 
			"deallocatePrepare", "routineBody", "blockStatement", "caseStatement", 
			"ifStatement", "iterateStatement", "leaveStatement", "loopStatement", 
			"repeatStatement", "returnStatement", "whileStatement", "cursorStatement", 
			"declareVariable", "declareCondition", "declareCursor", "declareHandler", 
			"handlerConditionValue", "procedureSqlStatement", "caseAlternative", 
			"elifAlternative", "alterUser", "createUser", "dropUser", "grantStatement", 
			"roleOption", "grantProxy", "renameUser", "revokeStatement", "revokeProxy", 
			"setPasswordStatement", "userSpecification", "userAuthOption", "authOptionClause", 
			"authenticationRule", "tlsOption", "userResourceOption", "userPasswordOption", 
			"userLockOption", "privelegeClause", "privilege", "privilegeLevel", "renameUserClause", 
			"analyzeTable", "checkTable", "checksumTable", "optimizeTable", "repairTable", 
			"checkTableOption", "createUdfunction", "installPlugin", "uninstallPlugin", 
			"setStatement", "showStatement", "variableClause", "showCommonEntity", 
			"showFilter", "showGlobalInfoClause", "showSchemaEntity", "showProfileType", 
			"binlogStatement", "cacheIndexStatement", "flushStatement", "killStatement", 
			"loadIndexIntoCache", "resetStatement", "shutdownStatement", "tableIndexes", 
			"flushOption", "flushTableOption", "loadedTableIndexes", "simpleDescribeStatement", 
			"fullDescribeStatement", "helpStatement", "useStatement", "signalStatement", 
			"resignalStatement", "signalConditionInformation", "withStatement", "tableStatement", 
			"diagnosticsStatement", "diagnosticsConditionInformationName", "describeObjectClause", 
			"fullId", "tableName", "roleName", "fullColumnName", "indexColumnName", 
			"simpleUserName", "hostName", "userName", "mysqlVariable", "charsetName", 
			"collationName", "engineName", "engineNameBase", "uuidSet", "xid", "xuidStringId", 
			"authPlugin", "uid", "simpleId", "dottedId", "decimalLiteral", "fileSizeLiteral", 
			"stringLiteral", "booleanLiteral", "hexadecimalLiteral", "nullNotnull", 
			"constant", "dataType", "collectionOptions", "convertedDataType", "lengthOneDimension", 
			"lengthTwoDimension", "lengthTwoOptionalDimension", "uidList", "fullColumnNameList", 
			"tables", "indexColumnNames", "expressions", "expressionsWithDefaults", 
			"constants", "simpleStrings", "userVariables", "defaultValue", "currentTimestamp", 
			"expressionOrDefault", "ifExists", "ifNotExists", "orReplace", "waitNowaitClause", 
			"functionCall", "specificFunction", "caseFuncAlternative", "levelsInWeightString", 
			"levelInWeightListElement", "aggregateWindowedFunction", "nonAggregateWindowedFunction", 
			"overClause", "windowSpec", "windowName", "frameClause", "frameUnits", 
			"frameExtent", "frameBetween", "frameRange", "partitionClause", "scalarFunctionName", 
			"passwordFunctionClause", "functionArgs", "functionArg", "expression", 
			"predicate", "expressionAtom", "unaryOperator", "comparisonOperator", 
			"logicalOperator", "bitOperator", "multOperator", "addOperator", "jsonOperator", 
			"charsetNameBase", "transactionLevelBase", "privilegesBase", "intervalTypeBase", 
			"dataTypeBase", "keywordsCanBeId", "functionNameBase"
		};
	}
	public static final String[] ruleNames = makeRuleNames();

	private static String[] makeLiteralNames() {
		return new String[] {
			null, null, null, null, null, "'ADD'", "'ALL'", "'ALTER'", "'ALWAYS'", 
			"'ANALYZE'", "'AND'", "'ARRAY'", "'AS'", "'ASC'", "'ATTRIBUTE'", "'BEFORE'", 
			"'BETWEEN'", "'BOTH'", "'BUCKETS'", "'BY'", "'CALL'", "'CASCADE'", "'CASE'", 
			"'CAST'", "'CHANGE'", "'CHARACTER'", "'CHECK'", "'COLLATE'", "'COLUMN'", 
			"'CONDITION'", "'CONSTRAINT'", "'CONTINUE'", "'CONVERT'", "'CREATE'", 
			"'CROSS'", "'CURRENT'", "'CURRENT_ROLE'", "'CURRENT_USER'", "'CURSOR'", 
			"'DATABASE'", "'DATABASES'", "'DECLARE'", "'DEFAULT'", "'DELAYED'", "'DELETE'", 
			"'DESC'", "'DESCRIBE'", "'DETERMINISTIC'", "'DIAGNOSTICS'", "'DISTINCT'", 
			"'DISTINCTROW'", "'DROP'", "'EACH'", "'ELSE'", "'ELSEIF'", "'EMPTY'", 
			"'ENCLOSED'", "'ENFORCED'", "'ESCAPED'", "'EXCEPT'", "'EXISTS'", "'EXIT'", 
			"'EXPLAIN'", "'FALSE'", "'FETCH'", "'FOR'", "'FORCE'", "'FOREIGN'", "'FROM'", 
			"'FULLTEXT'", "'GENERATED'", "'GET'", "'GRANT'", "'GROUP'", "'HAVING'", 
			"'HIGH_PRIORITY'", "'HISTOGRAM'", "'IF'", "'IGNORE'", "'IGNORED'", "'IN'", 
			"'INDEX'", "'INFILE'", "'INNER'", "'INOUT'", "'INSERT'", "'INTERVAL'", 
			"'INTO'", "'IS'", "'ITERATE'", "'JOIN'", "'KEY'", "'KEYS'", "'KILL'", 
			"'LATERAL'", "'LEADING'", "'LEAVE'", "'LEFT'", "'LIKE'", "'LIMIT'", "'LINEAR'", 
			"'LINES'", "'LOAD'", "'LOCK'", "'LOCKED'", "'LOOP'", "'LOW_PRIORITY'", 
			"'MASTER_BIND'", "'MASTER_SSL_VERIFY_SERVER_CERT'", "'MATCH'", "'MAXVALUE'", 
			"'MINVALUE'", "'MODIFIES'", "'NATURAL'", "'NOT'", "'NO_WRITE_TO_BINLOG'", 
			"'NULL'", "'NUMBER'", "'ON'", "'OPTIMIZE'", "'OPTION'", "'OPTIONAL'", 
			"'OPTIONALLY'", "'OR'", "'ORDER'", "'OUT'", "'OUTER'", "'OUTFILE'", "'OVER'", 
			"'PARTITION'", "'PRIMARY'", "'PROCEDURE'", "'PURGE'", "'RANGE'", "'READ'", 
			"'READS'", "'REFERENCES'", "'REGEXP'", "'RELEASE'", "'RENAME'", "'REPEAT'", 
			"'REPLACE'", "'REQUIRE'", "'RESIGNAL'", "'RESTRICT'", "'RETAIN'", "'RETURN'", 
			"'REVOKE'", "'RIGHT'", "'RLIKE'", "'SCHEMA'", "'SCHEMAS'", "'SELECT'", 
			"'SET'", "'SEPARATOR'", "'SHOW'", "'SIGNAL'", "'SKIP'", "'SKIP_QUERY_REWRITE'", 
			"'SPATIAL'", "'SQL'", "'SQLEXCEPTION'", "'SQLSTATE'", "'SQLWARNING'", 
			"'SQL_BIG_RESULT'", "'SQL_CALC_FOUND_ROWS'", "'SQL_SMALL_RESULT'", "'SSL'", 
			"'STACKED'", "'STARTING'", "'STATEMENT'", "'STRAIGHT_JOIN'", "'TABLE'", 
			"'TERMINATED'", "'THEN'", "'TO'", "'TRAILING'", "'TRIGGER'", "'TRUE'", 
			"'UNDO'", "'UNION'", "'UNIQUE'", "'UNLOCK'", "'UNSIGNED'", "'UPDATE'", 
			"'USAGE'", "'USE'", "'USING'", "'VALUES'", "'WHEN'", "'WHERE'", "'WHILE'", 
			"'WITH'", "'WRITE'", "'XOR'", "'ZEROFILL'", "'TINYINT'", "'SMALLINT'", 
			"'MEDIUMINT'", "'MIDDLEINT'", "'INT'", "'INT1'", "'INT2'", "'INT3'", 
			"'INT4'", "'INT8'", "'INTEGER'", "'BIGINT'", "'REAL'", "'DOUBLE'", "'PRECISION'", 
			"'FLOAT'", "'FLOAT4'", "'FLOAT8'", "'DECIMAL'", "'DEC'", "'NUMERIC'", 
			"'DATE'", "'TIME'", "'TIMESTAMP'", "'DATETIME'", "'YEAR'", "'CHAR'", 
			"'VARCHAR'", "'NVARCHAR'", "'NATIONAL'", "'BINARY'", "'VARBINARY'", "'TINYBLOB'", 
			"'BLOB'", "'MEDIUMBLOB'", "'LONG'", "'LONGBLOB'", "'TINYTEXT'", "'TEXT'", 
			"'MEDIUMTEXT'", "'LONGTEXT'", "'ENUM'", "'VARYING'", "'SERIAL'", "'YEAR_MONTH'", 
			"'DAY_HOUR'", "'DAY_MINUTE'", "'DAY_SECOND'", "'HOUR_MINUTE'", "'HOUR_SECOND'", 
			"'MINUTE_SECOND'", "'SECOND_MICROSECOND'", "'MINUTE_MICROSECOND'", "'HOUR_MICROSECOND'", 
			"'DAY_MICROSECOND'", "'JSON_ARRAY'", "'JSON_ARRAYAGG'", "'JSON_ARRAY_APPEND'", 
			"'JSON_ARRAY_INSERT'", "'JSON_CONTAINS'", "'JSON_CONTAINS_PATH'", "'JSON_DEPTH'", 
			"'JSON_EXTRACT'", "'JSON_INSERT'", "'JSON_KEYS'", "'JSON_LENGTH'", "'JSON_MERGE'", 
			"'JSON_MERGE_PATCH'", "'JSON_MERGE_PRESERVE'", "'JSON_OBJECT'", "'JSON_OBJECTAGG'", 
			"'JSON_OVERLAPS'", "'JSON_PRETTY'", "'JSON_QUOTE'", "'JSON_REMOVE'", 
			"'JSON_REPLACE'", "'JSON_SCHEMA_VALID'", "'JSON_SCHEMA_VALIDATION_REPORT'", 
			"'JSON_SEARCH'", "'JSON_SET'", "'JSON_STORAGE_FREE'", "'JSON_STORAGE_SIZE'", 
			"'JSON_TABLE'", "'JSON_TYPE'", "'JSON_UNQUOTE'", "'JSON_VALID'", "'JSON_VALUE'", 
			"'NESTED'", "'ORDINALITY'", "'PATH'", "'AVG'", "'BIT_AND'", "'BIT_OR'", 
			"'BIT_XOR'", "'COUNT'", "'CUME_DIST'", "'DENSE_RANK'", "'FIRST_VALUE'", 
			"'GROUP_CONCAT'", "'LAG'", "'LAST_VALUE'", "'LEAD'", "'MAX'", "'MIN'", 
			"'NTILE'", "'NTH_VALUE'", "'PERCENT_RANK'", "'RANK'", "'ROW_NUMBER'", 
			"'STD'", "'STDDEV'", "'STDDEV_POP'", "'STDDEV_SAMP'", "'SUM'", "'VAR_POP'", 
			"'VAR_SAMP'", "'VARIANCE'", "'CURRENT_DATE'", "'CURRENT_TIME'", "'CURRENT_TIMESTAMP'", 
			"'LOCALTIME'", "'CURDATE'", "'CURTIME'", "'DATE_ADD'", "'DATE_SUB'", 
			"'EXTRACT'", "'LOCALTIMESTAMP'", "'NOW'", "'POSITION'", "'SUBSTR'", "'SUBSTRING'", 
			"'SYSDATE'", "'TRIM'", "'UTC_DATE'", "'UTC_TIME'", "'UTC_TIMESTAMP'", 
			"'ACCOUNT'", "'ACTION'", "'AFTER'", "'AGGREGATE'", "'ALGORITHM'", "'ANY'", 
			"'AT'", "'AUTHORS'", "'AUTOCOMMIT'", "'AUTOEXTEND_SIZE'", "'AUTO_INCREMENT'", 
			"'AVG_ROW_LENGTH'", "'BEGIN'", "'BINLOG'", "'BIT'", "'BLOCK'", "'BOOL'", 
			"'BOOLEAN'", "'BTREE'", "'CACHE'", "'CASCADED'", "'CHAIN'", "'CHANGED'", 
			"'CHANNEL'", "'CHECKSUM'", "'PAGE_CHECKSUM'", "'CIPHER'", "'CLASS_ORIGIN'", 
			"'CLIENT'", "'CLOSE'", "'CLUSTERING'", "'COALESCE'", "'CODE'", "'COLUMNS'", 
			"'COLUMN_FORMAT'", "'COLUMN_NAME'", "'COMMENT'", "'COMMIT'", "'COMPACT'", 
			"'COMPLETION'", "'COMPRESSED'", "'COMPRESSION'", "'CONCURRENT'", "'CONNECT'", 
			"'CONNECTION'", "'CONSISTENT'", "'CONSTRAINT_CATALOG'", "'CONSTRAINT_SCHEMA'", 
			"'CONSTRAINT_NAME'", "'CONTAINS'", "'CONTEXT'", "'CONTRIBUTORS'", "'COPY'", 
			"'CPU'", "'CYCLE'", "'CURSOR_NAME'", "'DATA'", "'DATAFILE'", "'DEALLOCATE'", 
			"'DEFAULT_AUTH'", "'DEFINER'", "'DELAY_KEY_WRITE'", "'DES_KEY_FILE'", 
			"'DIRECTORY'", "'DISABLE'", "'DISCARD'", "'DISK'", "'DO'", "'DUMPFILE'", 
			"'DUPLICATE'", "'DYNAMIC'", "'ENABLE'", "'ENCRYPTED'", "'ENCRYPTION'", 
			"'ENCRYPTION_KEY_ID'", "'END'", "'ENDS'", "'ENGINE'", "'ENGINES'", "'ERROR'", 
			"'ERRORS'", "'ESCAPE'", "'EVEN'", "'EVENT'", "'EVENTS'", "'EVERY'", "'EXCHANGE'", 
			"'EXCLUSIVE'", "'EXPIRE'", "'EXPORT'", "'EXTENDED'", "'EXTENT_SIZE'", 
			"'FAILED_LOGIN_ATTEMPTS'", "'FAST'", "'FAULTS'", "'FIELDS'", "'FILE_BLOCK_SIZE'", 
			"'FILTER'", "'FIRST'", "'FIXED'", "'FLUSH'", "'FOLLOWING'", "'FOLLOWS'", 
			"'FOUND'", "'FULL'", "'FUNCTION'", "'GENERAL'", "'GLOBAL'", "'GRANTS'", 
			"'GROUP_REPLICATION'", "'HANDLER'", "'HASH'", "'HELP'", "'HISTORY'", 
			"'HOST'", "'HOSTS'", "'IDENTIFIED'", "'IGNORE_SERVER_IDS'", "'IMPORT'", 
			"'INCREMENT'", "'INDEXES'", "'INITIAL_SIZE'", "'INPLACE'", "'INSERT_METHOD'", 
			"'INSTALL'", "'INSTANCE'", "'INSTANT'", "'INVISIBLE'", "'INVOKER'", "'IO'", 
			"'IO_THREAD'", "'IPC'", "'ISOLATION'", "'ISSUER'", "'JSON'", "'KEY_BLOCK_SIZE'", 
			"'LANGUAGE'", "'LAST'", "'LEAVES'", "'LESS'", "'LEVEL'", "'LIST'", "'LOCAL'", 
			"'LOGFILE'", "'LOGS'", "'MASTER'", "'MASTER_AUTO_POSITION'", "'MASTER_CONNECT_RETRY'", 
			"'MASTER_DELAY'", "'MASTER_HEARTBEAT_PERIOD'", "'MASTER_HOST'", "'MASTER_LOG_FILE'", 
			"'MASTER_LOG_POS'", "'MASTER_PASSWORD'", "'MASTER_PORT'", "'MASTER_RETRY_COUNT'", 
			"'MASTER_SSL'", "'MASTER_SSL_CA'", "'MASTER_SSL_CAPATH'", "'MASTER_SSL_CERT'", 
			"'MASTER_SSL_CIPHER'", "'MASTER_SSL_CRL'", "'MASTER_SSL_CRLPATH'", "'MASTER_SSL_KEY'", 
			"'MASTER_TLS_VERSION'", "'MASTER_USER'", "'MAX_CONNECTIONS_PER_HOUR'", 
			"'MAX_QUERIES_PER_HOUR'", "'MAX_ROWS'", "'MAX_SIZE'", "'MAX_UPDATES_PER_HOUR'", 
			"'MAX_USER_CONNECTIONS'", "'MEDIUM'", "'MEMBER'", "'MERGE'", "'MESSAGE_TEXT'", 
			"'MID'", "'MIGRATE'", "'MIN_ROWS'", "'MODE'", "'MODIFY'", "'MUTEX'", 
			"'MYSQL'", "'MYSQL_ERRNO'", "'NAME'", "'NAMES'", "'NCHAR'", "'NEVER'", 
			"'NEXT'", "'NO'", "'NOCACHE'", "'NOCOPY'", "'NOCYCLE'", "'NOMAXVALUE'", 
			"'NOMINVALUE'", "'NOWAIT'", "'NODEGROUP'", "'NONE'", "'ODBC'", "'OFFLINE'", 
			"'OFFSET'", "'OF'", "'OJ'", "'OLD_PASSWORD'", "'ONE'", "'ONLINE'", "'ONLY'", 
			"'OPEN'", "'OPTIMIZER_COSTS'", "'OPTIONS'", "'OWNER'", "'PACK_KEYS'", 
			"'PAGE'", "'PAGE_COMPRESSED'", "'PAGE_COMPRESSION_LEVEL'", "'PARSER'", 
			"'PARTIAL'", "'PARTITIONING'", "'PARTITIONS'", "'PASSWORD'", "'PASSWORD_LOCK_TIME'", 
			"'PHASE'", "'PLUGIN'", "'PLUGIN_DIR'", "'PLUGINS'", "'PORT'", "'PRECEDES'", 
			"'PRECEDING'", "'PREPARE'", "'PRESERVE'", "'PREV'", "'PROCESSLIST'", 
			"'PROFILE'", "'PROFILES'", "'PROXY'", "'QUERY'", "'QUICK'", "'REBUILD'", 
			"'RECOVER'", "'RECURSIVE'", "'REDO_BUFFER_SIZE'", "'REDUNDANT'", "'RELAY'", 
			"'RELAY_LOG_FILE'", "'RELAY_LOG_POS'", "'RELAYLOG'", "'REMOVE'", "'REORGANIZE'", 
			"'REPAIR'", "'REPLICATE_DO_DB'", "'REPLICATE_DO_TABLE'", "'REPLICATE_IGNORE_DB'", 
			"'REPLICATE_IGNORE_TABLE'", "'REPLICATE_REWRITE_DB'", "'REPLICATE_WILD_DO_TABLE'", 
			"'REPLICATE_WILD_IGNORE_TABLE'", "'REPLICATION'", "'RESET'", "'RESTART'", 
			"'RESUME'", "'RETURNED_SQLSTATE'", "'RETURNING'", "'RETURNS'", "'REUSE'", 
			"'ROLE'", "'ROLLBACK'", "'ROLLUP'", "'ROTATE'", "'ROW'", "'ROWS'", "'ROW_FORMAT'", 
			"'RTREE'", "'SAVEPOINT'", "'SCHEDULE'", "'SECURITY'", "'SEQUENCE'", "'SERVER'", 
			"'SESSION'", "'SHARE'", "'SHARED'", "'SIGNED'", "'SIMPLE'", "'SLAVE'", 
			"'SLOW'", "'SNAPSHOT'", "'SOCKET'", "'SOME'", "'SONAME'", "'SOUNDS'", 
			"'SOURCE'", "'SQL_AFTER_GTIDS'", "'SQL_AFTER_MTS_GAPS'", "'SQL_BEFORE_GTIDS'", 
			"'SQL_BUFFER_RESULT'", "'SQL_CACHE'", "'SQL_NO_CACHE'", "'SQL_THREAD'", 
			"'START'", "'STARTS'", "'STATS_AUTO_RECALC'", "'STATS_PERSISTENT'", "'STATS_SAMPLE_PAGES'", 
			"'STATUS'", "'STOP'", "'STORAGE'", "'STORED'", "'STRING'", "'SUBCLASS_ORIGIN'", 
			"'SUBJECT'", "'SUBPARTITION'", "'SUBPARTITIONS'", "'SUSPEND'", "'SWAPS'", 
			"'SWITCHES'", "'TABLE_NAME'", "'TABLESPACE'", "'TABLE_TYPE'", "'TEMPORARY'", 
			"'TEMPTABLE'", "'THAN'", "'TRADITIONAL'", "'TRANSACTION'", "'TRANSACTIONAL'", 
			"'TRIGGERS'", "'TRUNCATE'", "'UNBOUNDED'", "'UNDEFINED'", "'UNDOFILE'", 
			"'UNDO_BUFFER_SIZE'", "'UNINSTALL'", "'UNKNOWN'", "'UNTIL'", "'UPGRADE'", 
			"'USER'", "'USE_FRM'", "'USER_RESOURCES'", "'VALIDATION'", "'VALUE'", 
			"'VARIABLES'", "'VIEW'", "'VIRTUAL'", "'VISIBLE'", "'WAIT'", "'WARNINGS'", 
			"'WINDOW'", "'WITHOUT'", "'WORK'", "'WRAPPER'", "'X509'", "'XA'", "'XML'", 
			"'YES'", "'EUR'", "'USA'", "'JIS'", "'ISO'", "'INTERNAL'", "'QUARTER'", 
			"'MONTH'", "'DAY'", "'HOUR'", "'MINUTE'", "'WEEK'", "'SECOND'", "'MICROSECOND'", 
			"'ADMIN'", "'APPLICATION_PASSWORD_ADMIN'", "'AUDIT_ABORT_EXEMPT'", "'AUDIT_ADMIN'", 
			"'AUTHENTICATION_POLICY_ADMIN'", "'BACKUP_ADMIN'", "'BINLOG_ADMIN'", 
			"'BINLOG_ENCRYPTION_ADMIN'", "'CLONE_ADMIN'", "'CONNECTION_ADMIN'", "'ENCRYPTION_KEY_ADMIN'", 
			"'EXECUTE'", "'FILE'", "'FIREWALL_ADMIN'", "'FIREWALL_EXEMPT'", "'FIREWALL_USER'", 
			"'FLUSH_OPTIMIZER_COSTS'", "'FLUSH_STATUS'", "'FLUSH_TABLES'", "'FLUSH_USER_RESOURCES'", 
			"'GROUP_REPLICATION_ADMIN'", "'INNODB_REDO_LOG_ARCHIVE'", "'INNODB_REDO_LOG_ENABLE'", 
			"'INVOKE'", "'LAMBDA'", "'NDB_STORED_USER'", "'PASSWORDLESS_USER_ADMIN'", 
			"'PERSIST_RO_VARIABLES_ADMIN'", "'PRIVILEGES'", "'PROCESS'", "'RELOAD'", 
			"'REPLICATION_APPLIER'", "'REPLICATION_SLAVE_ADMIN'", "'RESOURCE_GROUP_ADMIN'", 
			"'RESOURCE_GROUP_USER'", "'ROLE_ADMIN'", "'ROUTINE'", "'S3'", "'SERVICE_CONNECTION_ADMIN'", 
			null, "'SET_USER_ID'", "'SHOW_ROUTINE'", "'SHUTDOWN'", "'SUPER'", "'SYSTEM_VARIABLES_ADMIN'", 
			"'TABLES'", "'TABLE_ENCRYPTION_ADMIN'", "'VERSION_TOKEN_ADMIN'", "'XA_RECOVER_ADMIN'", 
			"'ARMSCII8'", "'ASCII'", "'BIG5'", "'CP1250'", "'CP1251'", "'CP1256'", 
			"'CP1257'", "'CP850'", "'CP852'", "'CP866'", "'CP932'", "'DEC8'", "'EUCJPMS'", 
			"'EUCKR'", "'GB18030'", "'GB2312'", "'GBK'", "'GEOSTD8'", "'GREEK'", 
			"'HEBREW'", "'HP8'", "'KEYBCS2'", "'KOI8R'", "'KOI8U'", "'LATIN1'", "'LATIN2'", 
			"'LATIN5'", "'LATIN7'", "'MACCE'", "'MACROMAN'", "'SJIS'", "'SWE7'", 
			"'TIS620'", "'UCS2'", "'UJIS'", "'UTF16'", "'UTF16LE'", "'UTF32'", "'UTF8'", 
			"'UTF8MB3'", "'UTF8MB4'", "'ARCHIVE'", "'BLACKHOLE'", "'CSV'", "'FEDERATED'", 
			"'INNODB'", "'MEMORY'", "'MRG_MYISAM'", "'MYISAM'", "'NDB'", "'NDBCLUSTER'", 
			"'PERFORMANCE_SCHEMA'", "'TOKUDB'", "'REPEATABLE'", "'COMMITTED'", "'UNCOMMITTED'", 
			"'SERIALIZABLE'", "'GEOMETRYCOLLECTION'", "'GEOMCOLLECTION'", "'GEOMETRY'", 
			"'LINESTRING'", "'MULTILINESTRING'", "'MULTIPOINT'", "'MULTIPOLYGON'", 
			"'POINT'", "'POLYGON'", "'ABS'", "'ACOS'", "'ADDDATE'", "'ADDTIME'", 
			"'AES_DECRYPT'", "'AES_ENCRYPT'", "'AREA'", "'ASBINARY'", "'ASIN'", "'ASTEXT'", 
			"'ASWKB'", "'ASWKT'", "'ASYMMETRIC_DECRYPT'", "'ASYMMETRIC_DERIVE'", 
			"'ASYMMETRIC_ENCRYPT'", "'ASYMMETRIC_SIGN'", "'ASYMMETRIC_VERIFY'", "'ATAN'", 
			"'ATAN2'", "'BENCHMARK'", "'BIN'", "'BIT_COUNT'", "'BIT_LENGTH'", "'BUFFER'", 
			"'CATALOG_NAME'", "'CEIL'", "'CEILING'", "'CENTROID'", "'CHARACTER_LENGTH'", 
			"'CHARSET'", "'CHAR_LENGTH'", "'COERCIBILITY'", "'COLLATION'", "'COMPRESS'", 
			"'CONCAT'", "'CONCAT_WS'", "'CONNECTION_ID'", "'CONV'", "'CONVERT_TZ'", 
			"'COS'", "'COT'", "'CRC32'", "'CREATE_ASYMMETRIC_PRIV_KEY'", "'CREATE_ASYMMETRIC_PUB_KEY'", 
			"'CREATE_DH_PARAMETERS'", "'CREATE_DIGEST'", "'CROSSES'", "'DATEDIFF'", 
			"'DATE_FORMAT'", "'DAYNAME'", "'DAYOFMONTH'", "'DAYOFWEEK'", "'DAYOFYEAR'", 
			"'DECODE'", "'DEGREES'", "'DES_DECRYPT'", "'DES_ENCRYPT'", "'DIMENSION'", 
			"'DISJOINT'", "'ELT'", "'ENCODE'", "'ENCRYPT'", "'ENDPOINT'", "'ENGINE_ATTRIBUTE'", 
			"'ENVELOPE'", "'EQUALS'", "'EXP'", "'EXPORT_SET'", "'EXTERIORRING'", 
			"'EXTRACTVALUE'", "'FIELD'", "'FIND_IN_SET'", "'FLOOR'", "'FORMAT'", 
			"'FOUND_ROWS'", "'FROM_BASE64'", "'FROM_DAYS'", "'FROM_UNIXTIME'", "'GEOMCOLLFROMTEXT'", 
			"'GEOMCOLLFROMWKB'", "'GEOMETRYCOLLECTIONFROMTEXT'", "'GEOMETRYCOLLECTIONFROMWKB'", 
			"'GEOMETRYFROMTEXT'", "'GEOMETRYFROMWKB'", "'GEOMETRYN'", "'GEOMETRYTYPE'", 
			"'GEOMFROMTEXT'", "'GEOMFROMWKB'", "'GET_FORMAT'", "'GET_LOCK'", "'GLENGTH'", 
			"'GREATEST'", "'GTID_SUBSET'", "'GTID_SUBTRACT'", "'HEX'", "'IFNULL'", 
			"'INET6_ATON'", "'INET6_NTOA'", "'INET_ATON'", "'INET_NTOA'", "'INSTR'", 
			"'INTERIORRINGN'", "'INTERSECTS'", "'ISCLOSED'", "'ISEMPTY'", "'ISNULL'", 
			"'ISSIMPLE'", "'IS_FREE_LOCK'", "'IS_IPV4'", "'IS_IPV4_COMPAT'", "'IS_IPV4_MAPPED'", 
			"'IS_IPV6'", "'IS_USED_LOCK'", "'LAST_INSERT_ID'", "'LCASE'", "'LEAST'", 
			"'LENGTH'", "'LINEFROMTEXT'", "'LINEFROMWKB'", "'LINESTRINGFROMTEXT'", 
			"'LINESTRINGFROMWKB'", "'LN'", "'LOAD_FILE'", "'LOCATE'", "'LOG'", "'LOG10'", 
			"'LOG2'", "'LOWER'", "'LPAD'", "'LTRIM'", "'MAKEDATE'", "'MAKETIME'", 
			"'MAKE_SET'", "'MASTER_POS_WAIT'", "'MBRCONTAINS'", "'MBRDISJOINT'", 
			"'MBREQUAL'", "'MBRINTERSECTS'", "'MBROVERLAPS'", "'MBRTOUCHES'", "'MBRWITHIN'", 
			"'MD5'", "'MLINEFROMTEXT'", "'MLINEFROMWKB'", "'MONTHNAME'", "'MPOINTFROMTEXT'", 
			"'MPOINTFROMWKB'", "'MPOLYFROMTEXT'", "'MPOLYFROMWKB'", "'MULTILINESTRINGFROMTEXT'", 
			"'MULTILINESTRINGFROMWKB'", "'MULTIPOINTFROMTEXT'", "'MULTIPOINTFROMWKB'", 
			"'MULTIPOLYGONFROMTEXT'", "'MULTIPOLYGONFROMWKB'", "'NAME_CONST'", "'NULLIF'", 
			"'NUMGEOMETRIES'", "'NUMINTERIORRINGS'", "'NUMPOINTS'", "'OCT'", "'OCTET_LENGTH'", 
			"'ORD'", "'OVERLAPS'", "'PERIOD_ADD'", "'PERIOD_DIFF'", "'PI'", "'POINTFROMTEXT'", 
			"'POINTFROMWKB'", "'POINTN'", "'POLYFROMTEXT'", "'POLYFROMWKB'", "'POLYGONFROMTEXT'", 
			"'POLYGONFROMWKB'", "'POW'", "'POWER'", "'QUOTE'", "'RADIANS'", "'RAND'", 
			"'RANDOM'", "'RANDOM_BYTES'", "'RELEASE_LOCK'", "'REVERSE'", "'ROUND'", 
			"'ROW_COUNT'", "'RPAD'", "'RTRIM'", "'SEC_TO_TIME'", "'SECONDARY_ENGINE_ATTRIBUTE'", 
			"'SESSION_USER'", "'SHA'", "'SHA1'", "'SHA2'", "'SCHEMA_NAME'", "'SIGN'", 
			"'SIN'", "'SLEEP'", "'SOUNDEX'", "'SQL_THREAD_WAIT_AFTER_GTIDS'", "'SQRT'", 
			"'SRID'", "'STARTPOINT'", "'STRCMP'", "'STR_TO_DATE'", "'ST_AREA'", "'ST_ASBINARY'", 
			"'ST_ASTEXT'", "'ST_ASWKB'", "'ST_ASWKT'", "'ST_BUFFER'", "'ST_CENTROID'", 
			"'ST_CONTAINS'", "'ST_CROSSES'", "'ST_DIFFERENCE'", "'ST_DIMENSION'", 
			"'ST_DISJOINT'", "'ST_DISTANCE'", "'ST_ENDPOINT'", "'ST_ENVELOPE'", "'ST_EQUALS'", 
			"'ST_EXTERIORRING'", "'ST_GEOMCOLLFROMTEXT'", "'ST_GEOMCOLLFROMTXT'", 
			"'ST_GEOMCOLLFROMWKB'", "'ST_GEOMETRYCOLLECTIONFROMTEXT'", "'ST_GEOMETRYCOLLECTIONFROMWKB'", 
			"'ST_GEOMETRYFROMTEXT'", "'ST_GEOMETRYFROMWKB'", "'ST_GEOMETRYN'", "'ST_GEOMETRYTYPE'", 
			"'ST_GEOMFROMTEXT'", "'ST_GEOMFROMWKB'", "'ST_INTERIORRINGN'", "'ST_INTERSECTION'", 
			"'ST_INTERSECTS'", "'ST_ISCLOSED'", "'ST_ISEMPTY'", "'ST_ISSIMPLE'", 
			"'ST_LINEFROMTEXT'", "'ST_LINEFROMWKB'", "'ST_LINESTRINGFROMTEXT'", "'ST_LINESTRINGFROMWKB'", 
			"'ST_NUMGEOMETRIES'", "'ST_NUMINTERIORRING'", "'ST_NUMINTERIORRINGS'", 
			"'ST_NUMPOINTS'", "'ST_OVERLAPS'", "'ST_POINTFROMTEXT'", "'ST_POINTFROMWKB'", 
			"'ST_POINTN'", "'ST_POLYFROMTEXT'", "'ST_POLYFROMWKB'", "'ST_POLYGONFROMTEXT'", 
			"'ST_POLYGONFROMWKB'", "'ST_SRID'", "'ST_STARTPOINT'", "'ST_SYMDIFFERENCE'", 
			"'ST_TOUCHES'", "'ST_UNION'", "'ST_WITHIN'", "'ST_X'", "'ST_Y'", "'SUBDATE'", 
			"'SUBSTRING_INDEX'", "'SUBTIME'", "'SYSTEM_USER'", "'TAN'", "'TIMEDIFF'", 
			"'TIMESTAMPADD'", "'TIMESTAMPDIFF'", "'TIME_FORMAT'", "'TIME_TO_SEC'", 
			"'TOUCHES'", "'TO_BASE64'", "'TO_DAYS'", "'TO_SECONDS'", "'TP_CONNECTION_ADMIN'", 
			"'UCASE'", "'UNCOMPRESS'", "'UNCOMPRESSED_LENGTH'", "'UNHEX'", "'UNIX_TIMESTAMP'", 
			"'UPDATEXML'", "'UPPER'", "'UUID'", "'UUID_SHORT'", "'VALIDATE_PASSWORD_STRENGTH'", 
			"'VERSION'", "'WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS'", "'WEEKDAY'", "'WEEKOFYEAR'", 
			"'WEIGHT_STRING'", "'WITHIN'", "'YEARWEEK'", "'Y'", "'X'", "':='", "'+='", 
			"'-='", "'*='", "'/='", "'%='", "'&='", "'^='", "'|='", "'*'", "'/'", 
			"'%'", "'+'", "'-'", "'DIV'", "'MOD'", "'='", "'>'", "'<'", "'!'", "'~'", 
			"'|'", "'&'", "'^'", "'.'", "'('", "')'", "','", "';'", "'@'", "'0'", 
			"'1'", "'2'", "'''", "'\"'", "'`'", "':'"
		};
	}
	private static final String[] _LITERAL_NAMES = makeLiteralNames();
	private static String[] makeSymbolicNames() {
		return new String[] {
			null, "SPACE", "SPEC_MYSQL_COMMENT", "COMMENT_INPUT", "LINE_COMMENT", 
			"ADD", "ALL", "ALTER", "ALWAYS", "ANALYZE", "AND", "ARRAY", "AS", "ASC", 
			"ATTRIBUTE", "BEFORE", "BETWEEN", "BOTH", "BUCKETS", "BY", "CALL", "CASCADE", 
			"CASE", "CAST", "CHANGE", "CHARACTER", "CHECK", "COLLATE", "COLUMN", 
			"CONDITION", "CONSTRAINT", "CONTINUE", "CONVERT", "CREATE", "CROSS", 
			"CURRENT", "CURRENT_ROLE", "CURRENT_USER", "CURSOR", "DATABASE", "DATABASES", 
			"DECLARE", "DEFAULT", "DELAYED", "DELETE", "DESC", "DESCRIBE", "DETERMINISTIC", 
			"DIAGNOSTICS", "DISTINCT", "DISTINCTROW", "DROP", "EACH", "ELSE", "ELSEIF", 
			"EMPTY", "ENCLOSED", "ENFORCED", "ESCAPED", "EXCEPT", "EXISTS", "EXIT", 
			"EXPLAIN", "FALSE", "FETCH", "FOR", "FORCE", "FOREIGN", "FROM", "FULLTEXT", 
			"GENERATED", "GET", "GRANT", "GROUP", "HAVING", "HIGH_PRIORITY", "HISTOGRAM", 
			"IF", "IGNORE", "IGNORED", "IN", "INDEX", "INFILE", "INNER", "INOUT", 
			"INSERT", "INTERVAL", "INTO", "IS", "ITERATE", "JOIN", "KEY", "KEYS", 
			"KILL", "LATERAL", "LEADING", "LEAVE", "LEFT", "LIKE", "LIMIT", "LINEAR", 
			"LINES", "LOAD", "LOCK", "LOCKED", "LOOP", "LOW_PRIORITY", "MASTER_BIND", 
			"MASTER_SSL_VERIFY_SERVER_CERT", "MATCH", "MAXVALUE", "MINVALUE", "MODIFIES", 
			"NATURAL", "NOT", "NO_WRITE_TO_BINLOG", "NULL_LITERAL", "NUMBER", "ON", 
			"OPTIMIZE", "OPTION", "OPTIONAL", "OPTIONALLY", "OR", "ORDER", "OUT", 
			"OUTER", "OUTFILE", "OVER", "PARTITION", "PRIMARY", "PROCEDURE", "PURGE", 
			"RANGE", "READ", "READS", "REFERENCES", "REGEXP", "RELEASE", "RENAME", 
			"REPEAT", "REPLACE", "REQUIRE", "RESIGNAL", "RESTRICT", "RETAIN", "RETURN", 
			"REVOKE", "RIGHT", "RLIKE", "SCHEMA", "SCHEMAS", "SELECT", "SET", "SEPARATOR", 
			"SHOW", "SIGNAL", "SKIP_", "SKIP_QUERY_REWRITE", "SPATIAL", "SQL", "SQLEXCEPTION", 
			"SQLSTATE", "SQLWARNING", "SQL_BIG_RESULT", "SQL_CALC_FOUND_ROWS", "SQL_SMALL_RESULT", 
			"SSL", "STACKED", "STARTING", "STATEMENT", "STRAIGHT_JOIN", "TABLE", 
			"TERMINATED", "THEN", "TO", "TRAILING", "TRIGGER", "TRUE", "UNDO", "UNION", 
			"UNIQUE", "UNLOCK", "UNSIGNED", "UPDATE", "USAGE", "USE", "USING", "VALUES", 
			"WHEN", "WHERE", "WHILE", "WITH", "WRITE", "XOR", "ZEROFILL", "TINYINT", 
			"SMALLINT", "MEDIUMINT", "MIDDLEINT", "INT", "INT1", "INT2", "INT3", 
			"INT4", "INT8", "INTEGER", "BIGINT", "REAL", "DOUBLE", "PRECISION", "FLOAT", 
			"FLOAT4", "FLOAT8", "DECIMAL", "DEC", "NUMERIC", "DATE", "TIME", "TIMESTAMP", 
			"DATETIME", "YEAR", "CHAR", "VARCHAR", "NVARCHAR", "NATIONAL", "BINARY", 
			"VARBINARY", "TINYBLOB", "BLOB", "MEDIUMBLOB", "LONG", "LONGBLOB", "TINYTEXT", 
			"TEXT", "MEDIUMTEXT", "LONGTEXT", "ENUM", "VARYING", "SERIAL", "YEAR_MONTH", 
			"DAY_HOUR", "DAY_MINUTE", "DAY_SECOND", "HOUR_MINUTE", "HOUR_SECOND", 
			"MINUTE_SECOND", "SECOND_MICROSECOND", "MINUTE_MICROSECOND", "HOUR_MICROSECOND", 
			"DAY_MICROSECOND", "JSON_ARRAY", "JSON_ARRAYAGG", "JSON_ARRAY_APPEND", 
			"JSON_ARRAY_INSERT", "JSON_CONTAINS", "JSON_CONTAINS_PATH", "JSON_DEPTH", 
			"JSON_EXTRACT", "JSON_INSERT", "JSON_KEYS", "JSON_LENGTH", "JSON_MERGE", 
			"JSON_MERGE_PATCH", "JSON_MERGE_PRESERVE", "JSON_OBJECT", "JSON_OBJECTAGG", 
			"JSON_OVERLAPS", "JSON_PRETTY", "JSON_QUOTE", "JSON_REMOVE", "JSON_REPLACE", 
			"JSON_SCHEMA_VALID", "JSON_SCHEMA_VALIDATION_REPORT", "JSON_SEARCH", 
			"JSON_SET", "JSON_STORAGE_FREE", "JSON_STORAGE_SIZE", "JSON_TABLE", "JSON_TYPE", 
			"JSON_UNQUOTE", "JSON_VALID", "JSON_VALUE", "NESTED", "ORDINALITY", "PATH", 
			"AVG", "BIT_AND", "BIT_OR", "BIT_XOR", "COUNT", "CUME_DIST", "DENSE_RANK", 
			"FIRST_VALUE", "GROUP_CONCAT", "LAG", "LAST_VALUE", "LEAD", "MAX", "MIN", 
			"NTILE", "NTH_VALUE", "PERCENT_RANK", "RANK", "ROW_NUMBER", "STD", "STDDEV", 
			"STDDEV_POP", "STDDEV_SAMP", "SUM", "VAR_POP", "VAR_SAMP", "VARIANCE", 
			"CURRENT_DATE", "CURRENT_TIME", "CURRENT_TIMESTAMP", "LOCALTIME", "CURDATE", 
			"CURTIME", "DATE_ADD", "DATE_SUB", "EXTRACT", "LOCALTIMESTAMP", "NOW", 
			"POSITION", "SUBSTR", "SUBSTRING", "SYSDATE", "TRIM", "UTC_DATE", "UTC_TIME", 
			"UTC_TIMESTAMP", "ACCOUNT", "ACTION", "AFTER", "AGGREGATE", "ALGORITHM", 
			"ANY", "AT", "AUTHORS", "AUTOCOMMIT", "AUTOEXTEND_SIZE", "AUTO_INCREMENT", 
			"AVG_ROW_LENGTH", "BEGIN", "BINLOG", "BIT", "BLOCK", "BOOL", "BOOLEAN", 
			"BTREE", "CACHE", "CASCADED", "CHAIN", "CHANGED", "CHANNEL", "CHECKSUM", 
			"PAGE_CHECKSUM", "CIPHER", "CLASS_ORIGIN", "CLIENT", "CLOSE", "CLUSTERING", 
			"COALESCE", "CODE", "COLUMNS", "COLUMN_FORMAT", "COLUMN_NAME", "COMMENT", 
			"COMMIT", "COMPACT", "COMPLETION", "COMPRESSED", "COMPRESSION", "CONCURRENT", 
			"CONNECT", "CONNECTION", "CONSISTENT", "CONSTRAINT_CATALOG", "CONSTRAINT_SCHEMA", 
			"CONSTRAINT_NAME", "CONTAINS", "CONTEXT", "CONTRIBUTORS", "COPY", "CPU", 
			"CYCLE", "CURSOR_NAME", "DATA", "DATAFILE", "DEALLOCATE", "DEFAULT_AUTH", 
			"DEFINER", "DELAY_KEY_WRITE", "DES_KEY_FILE", "DIRECTORY", "DISABLE", 
			"DISCARD", "DISK", "DO", "DUMPFILE", "DUPLICATE", "DYNAMIC", "ENABLE", 
			"ENCRYPTED", "ENCRYPTION", "ENCRYPTION_KEY_ID", "END", "ENDS", "ENGINE", 
			"ENGINES", "ERROR", "ERRORS", "ESCAPE", "EVEN", "EVENT", "EVENTS", "EVERY", 
			"EXCHANGE", "EXCLUSIVE", "EXPIRE", "EXPORT", "EXTENDED", "EXTENT_SIZE", 
			"FAILED_LOGIN_ATTEMPTS", "FAST", "FAULTS", "FIELDS", "FILE_BLOCK_SIZE", 
			"FILTER", "FIRST", "FIXED", "FLUSH", "FOLLOWING", "FOLLOWS", "FOUND", 
			"FULL", "FUNCTION", "GENERAL", "GLOBAL", "GRANTS", "GROUP_REPLICATION", 
			"HANDLER", "HASH", "HELP", "HISTORY", "HOST", "HOSTS", "IDENTIFIED", 
			"IGNORE_SERVER_IDS", "IMPORT", "INCREMENT", "INDEXES", "INITIAL_SIZE", 
			"INPLACE", "INSERT_METHOD", "INSTALL", "INSTANCE", "INSTANT", "INVISIBLE", 
			"INVOKER", "IO", "IO_THREAD", "IPC", "ISOLATION", "ISSUER", "JSON", "KEY_BLOCK_SIZE", 
			"LANGUAGE", "LAST", "LEAVES", "LESS", "LEVEL", "LIST", "LOCAL", "LOGFILE", 
			"LOGS", "MASTER", "MASTER_AUTO_POSITION", "MASTER_CONNECT_RETRY", "MASTER_DELAY", 
			"MASTER_HEARTBEAT_PERIOD", "MASTER_HOST", "MASTER_LOG_FILE", "MASTER_LOG_POS", 
			"MASTER_PASSWORD", "MASTER_PORT", "MASTER_RETRY_COUNT", "MASTER_SSL", 
			"MASTER_SSL_CA", "MASTER_SSL_CAPATH", "MASTER_SSL_CERT", "MASTER_SSL_CIPHER", 
			"MASTER_SSL_CRL", "MASTER_SSL_CRLPATH", "MASTER_SSL_KEY", "MASTER_TLS_VERSION", 
			"MASTER_USER", "MAX_CONNECTIONS_PER_HOUR", "MAX_QUERIES_PER_HOUR", "MAX_ROWS", 
			"MAX_SIZE", "MAX_UPDATES_PER_HOUR", "MAX_USER_CONNECTIONS", "MEDIUM", 
			"MEMBER", "MERGE", "MESSAGE_TEXT", "MID", "MIGRATE", "MIN_ROWS", "MODE", 
			"MODIFY", "MUTEX", "MYSQL", "MYSQL_ERRNO", "NAME", "NAMES", "NCHAR", 
			"NEVER", "NEXT", "NO", "NOCACHE", "NOCOPY", "NOCYCLE", "NOMAXVALUE", 
			"NOMINVALUE", "NOWAIT", "NODEGROUP", "NONE", "ODBC", "OFFLINE", "OFFSET", 
			"OF", "OJ", "OLD_PASSWORD", "ONE", "ONLINE", "ONLY", "OPEN", "OPTIMIZER_COSTS", 
			"OPTIONS", "OWNER", "PACK_KEYS", "PAGE", "PAGE_COMPRESSED", "PAGE_COMPRESSION_LEVEL", 
			"PARSER", "PARTIAL", "PARTITIONING", "PARTITIONS", "PASSWORD", "PASSWORD_LOCK_TIME", 
			"PHASE", "PLUGIN", "PLUGIN_DIR", "PLUGINS", "PORT", "PRECEDES", "PRECEDING", 
			"PREPARE", "PRESERVE", "PREV", "PROCESSLIST", "PROFILE", "PROFILES", 
			"PROXY", "QUERY", "QUICK", "REBUILD", "RECOVER", "RECURSIVE", "REDO_BUFFER_SIZE", 
			"REDUNDANT", "RELAY", "RELAY_LOG_FILE", "RELAY_LOG_POS", "RELAYLOG", 
			"REMOVE", "REORGANIZE", "REPAIR", "REPLICATE_DO_DB", "REPLICATE_DO_TABLE", 
			"REPLICATE_IGNORE_DB", "REPLICATE_IGNORE_TABLE", "REPLICATE_REWRITE_DB", 
			"REPLICATE_WILD_DO_TABLE", "REPLICATE_WILD_IGNORE_TABLE", "REPLICATION", 
			"RESET", "RESTART", "RESUME", "RETURNED_SQLSTATE", "RETURNING", "RETURNS", 
			"REUSE", "ROLE", "ROLLBACK", "ROLLUP", "ROTATE", "ROW", "ROWS", "ROW_FORMAT", 
			"RTREE", "SAVEPOINT", "SCHEDULE", "SECURITY", "SEQUENCE", "SERVER", "SESSION", 
			"SHARE", "SHARED", "SIGNED", "SIMPLE", "SLAVE", "SLOW", "SNAPSHOT", "SOCKET", 
			"SOME", "SONAME", "SOUNDS", "SOURCE", "SQL_AFTER_GTIDS", "SQL_AFTER_MTS_GAPS", 
			"SQL_BEFORE_GTIDS", "SQL_BUFFER_RESULT", "SQL_CACHE", "SQL_NO_CACHE", 
			"SQL_THREAD", "START", "STARTS", "STATS_AUTO_RECALC", "STATS_PERSISTENT", 
			"STATS_SAMPLE_PAGES", "STATUS", "STOP", "STORAGE", "STORED", "STRING", 
			"SUBCLASS_ORIGIN", "SUBJECT", "SUBPARTITION", "SUBPARTITIONS", "SUSPEND", 
			"SWAPS", "SWITCHES", "TABLE_NAME", "TABLESPACE", "TABLE_TYPE", "TEMPORARY", 
			"TEMPTABLE", "THAN", "TRADITIONAL", "TRANSACTION", "TRANSACTIONAL", "TRIGGERS", 
			"TRUNCATE", "UNBOUNDED", "UNDEFINED", "UNDOFILE", "UNDO_BUFFER_SIZE", 
			"UNINSTALL", "UNKNOWN", "UNTIL", "UPGRADE", "USER", "USE_FRM", "USER_RESOURCES", 
			"VALIDATION", "VALUE", "VARIABLES", "VIEW", "VIRTUAL", "VISIBLE", "WAIT", 
			"WARNINGS", "WINDOW", "WITHOUT", "WORK", "WRAPPER", "X509", "XA", "XML", 
			"YES", "EUR", "USA", "JIS", "ISO", "INTERNAL", "QUARTER", "MONTH", "DAY", 
			"HOUR", "MINUTE", "WEEK", "SECOND", "MICROSECOND", "ADMIN", "APPLICATION_PASSWORD_ADMIN", 
			"AUDIT_ABORT_EXEMPT", "AUDIT_ADMIN", "AUTHENTICATION_POLICY_ADMIN", "BACKUP_ADMIN", 
			"BINLOG_ADMIN", "BINLOG_ENCRYPTION_ADMIN", "CLONE_ADMIN", "CONNECTION_ADMIN", 
			"ENCRYPTION_KEY_ADMIN", "EXECUTE", "FILE", "FIREWALL_ADMIN", "FIREWALL_EXEMPT", 
			"FIREWALL_USER", "FLUSH_OPTIMIZER_COSTS", "FLUSH_STATUS", "FLUSH_TABLES", 
			"FLUSH_USER_RESOURCES", "GROUP_REPLICATION_ADMIN", "INNODB_REDO_LOG_ARCHIVE", 
			"INNODB_REDO_LOG_ENABLE", "INVOKE", "LAMBDA", "NDB_STORED_USER", "PASSWORDLESS_USER_ADMIN", 
			"PERSIST_RO_VARIABLES_ADMIN", "PRIVILEGES", "PROCESS", "RELOAD", "REPLICATION_APPLIER", 
			"REPLICATION_SLAVE_ADMIN", "RESOURCE_GROUP_ADMIN", "RESOURCE_GROUP_USER", 
			"ROLE_ADMIN", "ROUTINE", "S3", "SERVICE_CONNECTION_ADMIN", "SESSION_VARIABLES_ADMIN", 
			"SET_USER_ID", "SHOW_ROUTINE", "SHUTDOWN", "SUPER", "SYSTEM_VARIABLES_ADMIN", 
			"TABLES", "TABLE_ENCRYPTION_ADMIN", "VERSION_TOKEN_ADMIN", "XA_RECOVER_ADMIN", 
			"ARMSCII8", "ASCII", "BIG5", "CP1250", "CP1251", "CP1256", "CP1257", 
			"CP850", "CP852", "CP866", "CP932", "DEC8", "EUCJPMS", "EUCKR", "GB18030", 
			"GB2312", "GBK", "GEOSTD8", "GREEK", "HEBREW", "HP8", "KEYBCS2", "KOI8R", 
			"KOI8U", "LATIN1", "LATIN2", "LATIN5", "LATIN7", "MACCE", "MACROMAN", 
			"SJIS", "SWE7", "TIS620", "UCS2", "UJIS", "UTF16", "UTF16LE", "UTF32", 
			"UTF8", "UTF8MB3", "UTF8MB4", "ARCHIVE", "BLACKHOLE", "CSV", "FEDERATED", 
			"INNODB", "MEMORY", "MRG_MYISAM", "MYISAM", "NDB", "NDBCLUSTER", "PERFORMANCE_SCHEMA", 
			"TOKUDB", "REPEATABLE", "COMMITTED", "UNCOMMITTED", "SERIALIZABLE", "GEOMETRYCOLLECTION", 
			"GEOMCOLLECTION", "GEOMETRY", "LINESTRING", "MULTILINESTRING", "MULTIPOINT", 
			"MULTIPOLYGON", "POINT", "POLYGON", "ABS", "ACOS", "ADDDATE", "ADDTIME", 
			"AES_DECRYPT", "AES_ENCRYPT", "AREA", "ASBINARY", "ASIN", "ASTEXT", "ASWKB", 
			"ASWKT", "ASYMMETRIC_DECRYPT", "ASYMMETRIC_DERIVE", "ASYMMETRIC_ENCRYPT", 
			"ASYMMETRIC_SIGN", "ASYMMETRIC_VERIFY", "ATAN", "ATAN2", "BENCHMARK", 
			"BIN", "BIT_COUNT", "BIT_LENGTH", "BUFFER", "CATALOG_NAME", "CEIL", "CEILING", 
			"CENTROID", "CHARACTER_LENGTH", "CHARSET", "CHAR_LENGTH", "COERCIBILITY", 
			"COLLATION", "COMPRESS", "CONCAT", "CONCAT_WS", "CONNECTION_ID", "CONV", 
			"CONVERT_TZ", "COS", "COT", "CRC32", "CREATE_ASYMMETRIC_PRIV_KEY", "CREATE_ASYMMETRIC_PUB_KEY", 
			"CREATE_DH_PARAMETERS", "CREATE_DIGEST", "CROSSES", "DATEDIFF", "DATE_FORMAT", 
			"DAYNAME", "DAYOFMONTH", "DAYOFWEEK", "DAYOFYEAR", "DECODE", "DEGREES", 
			"DES_DECRYPT", "DES_ENCRYPT", "DIMENSION", "DISJOINT", "ELT", "ENCODE", 
			"ENCRYPT", "ENDPOINT", "ENGINE_ATTRIBUTE", "ENVELOPE", "EQUALS", "EXP", 
			"EXPORT_SET", "EXTERIORRING", "EXTRACTVALUE", "FIELD", "FIND_IN_SET", 
			"FLOOR", "FORMAT", "FOUND_ROWS", "FROM_BASE64", "FROM_DAYS", "FROM_UNIXTIME", 
			"GEOMCOLLFROMTEXT", "GEOMCOLLFROMWKB", "GEOMETRYCOLLECTIONFROMTEXT", 
			"GEOMETRYCOLLECTIONFROMWKB", "GEOMETRYFROMTEXT", "GEOMETRYFROMWKB", "GEOMETRYN", 
			"GEOMETRYTYPE", "GEOMFROMTEXT", "GEOMFROMWKB", "GET_FORMAT", "GET_LOCK", 
			"GLENGTH", "GREATEST", "GTID_SUBSET", "GTID_SUBTRACT", "HEX", "IFNULL", 
			"INET6_ATON", "INET6_NTOA", "INET_ATON", "INET_NTOA", "INSTR", "INTERIORRINGN", 
			"INTERSECTS", "ISCLOSED", "ISEMPTY", "ISNULL", "ISSIMPLE", "IS_FREE_LOCK", 
			"IS_IPV4", "IS_IPV4_COMPAT", "IS_IPV4_MAPPED", "IS_IPV6", "IS_USED_LOCK", 
			"LAST_INSERT_ID", "LCASE", "LEAST", "LENGTH", "LINEFROMTEXT", "LINEFROMWKB", 
			"LINESTRINGFROMTEXT", "LINESTRINGFROMWKB", "LN", "LOAD_FILE", "LOCATE", 
			"LOG", "LOG10", "LOG2", "LOWER", "LPAD", "LTRIM", "MAKEDATE", "MAKETIME", 
			"MAKE_SET", "MASTER_POS_WAIT", "MBRCONTAINS", "MBRDISJOINT", "MBREQUAL", 
			"MBRINTERSECTS", "MBROVERLAPS", "MBRTOUCHES", "MBRWITHIN", "MD5", "MLINEFROMTEXT", 
			"MLINEFROMWKB", "MONTHNAME", "MPOINTFROMTEXT", "MPOINTFROMWKB", "MPOLYFROMTEXT", 
			"MPOLYFROMWKB", "MULTILINESTRINGFROMTEXT", "MULTILINESTRINGFROMWKB", 
			"MULTIPOINTFROMTEXT", "MULTIPOINTFROMWKB", "MULTIPOLYGONFROMTEXT", "MULTIPOLYGONFROMWKB", 
			"NAME_CONST", "NULLIF", "NUMGEOMETRIES", "NUMINTERIORRINGS", "NUMPOINTS", 
			"OCT", "OCTET_LENGTH", "ORD", "OVERLAPS", "PERIOD_ADD", "PERIOD_DIFF", 
			"PI", "POINTFROMTEXT", "POINTFROMWKB", "POINTN", "POLYFROMTEXT", "POLYFROMWKB", 
			"POLYGONFROMTEXT", "POLYGONFROMWKB", "POW", "POWER", "QUOTE", "RADIANS", 
			"RAND", "RANDOM", "RANDOM_BYTES", "RELEASE_LOCK", "REVERSE", "ROUND", 
			"ROW_COUNT", "RPAD", "RTRIM", "SEC_TO_TIME", "SECONDARY_ENGINE_ATTRIBUTE", 
			"SESSION_USER", "SHA", "SHA1", "SHA2", "SCHEMA_NAME", "SIGN", "SIN", 
			"SLEEP", "SOUNDEX", "SQL_THREAD_WAIT_AFTER_GTIDS", "SQRT", "SRID", "STARTPOINT", 
			"STRCMP", "STR_TO_DATE", "ST_AREA", "ST_ASBINARY", "ST_ASTEXT", "ST_ASWKB", 
			"ST_ASWKT", "ST_BUFFER", "ST_CENTROID", "ST_CONTAINS", "ST_CROSSES", 
			"ST_DIFFERENCE", "ST_DIMENSION", "ST_DISJOINT", "ST_DISTANCE", "ST_ENDPOINT", 
			"ST_ENVELOPE", "ST_EQUALS", "ST_EXTERIORRING", "ST_GEOMCOLLFROMTEXT", 
			"ST_GEOMCOLLFROMTXT", "ST_GEOMCOLLFROMWKB", "ST_GEOMETRYCOLLECTIONFROMTEXT", 
			"ST_GEOMETRYCOLLECTIONFROMWKB", "ST_GEOMETRYFROMTEXT", "ST_GEOMETRYFROMWKB", 
			"ST_GEOMETRYN", "ST_GEOMETRYTYPE", "ST_GEOMFROMTEXT", "ST_GEOMFROMWKB", 
			"ST_INTERIORRINGN", "ST_INTERSECTION", "ST_INTERSECTS", "ST_ISCLOSED", 
			"ST_ISEMPTY", "ST_ISSIMPLE", "ST_LINEFROMTEXT", "ST_LINEFROMWKB", "ST_LINESTRINGFROMTEXT", 
			"ST_LINESTRINGFROMWKB", "ST_NUMGEOMETRIES", "ST_NUMINTERIORRING", "ST_NUMINTERIORRINGS", 
			"ST_NUMPOINTS", "ST_OVERLAPS", "ST_POINTFROMTEXT", "ST_POINTFROMWKB", 
			"ST_POINTN", "ST_POLYFROMTEXT", "ST_POLYFROMWKB", "ST_POLYGONFROMTEXT", 
			"ST_POLYGONFROMWKB", "ST_SRID", "ST_STARTPOINT", "ST_SYMDIFFERENCE", 
			"ST_TOUCHES", "ST_UNION", "ST_WITHIN", "ST_X", "ST_Y", "SUBDATE", "SUBSTRING_INDEX", 
			"SUBTIME", "SYSTEM_USER", "TAN", "TIMEDIFF", "TIMESTAMPADD", "TIMESTAMPDIFF", 
			"TIME_FORMAT", "TIME_TO_SEC", "TOUCHES", "TO_BASE64", "TO_DAYS", "TO_SECONDS", 
			"TP_CONNECTION_ADMIN", "UCASE", "UNCOMPRESS", "UNCOMPRESSED_LENGTH", 
			"UNHEX", "UNIX_TIMESTAMP", "UPDATEXML", "UPPER", "UUID", "UUID_SHORT", 
			"VALIDATE_PASSWORD_STRENGTH", "VERSION", "WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS", 
			"WEEKDAY", "WEEKOFYEAR", "WEIGHT_STRING", "WITHIN", "YEARWEEK", "Y_FUNCTION", 
			"X_FUNCTION", "VAR_ASSIGN", "PLUS_ASSIGN", "MINUS_ASSIGN", "MULT_ASSIGN", 
			"DIV_ASSIGN", "MOD_ASSIGN", "AND_ASSIGN", "XOR_ASSIGN", "OR_ASSIGN", 
			"STAR", "DIVIDE", "MODULE", "PLUS", "MINUS", "DIV", "MOD", "EQUAL_SYMBOL", 
			"GREATER_SYMBOL", "LESS_SYMBOL", "EXCLAMATION_SYMBOL", "BIT_NOT_OP", 
			"BIT_OR_OP", "BIT_AND_OP", "BIT_XOR_OP", "DOT", "LR_BRACKET", "RR_BRACKET", 
			"COMMA", "SEMI", "AT_SIGN", "ZERO_DECIMAL", "ONE_DECIMAL", "TWO_DECIMAL", 
			"SINGLE_QUOTE_SYMB", "DOUBLE_QUOTE_SYMB", "REVERSE_QUOTE_SYMB", "COLON_SYMB", 
			"CHARSET_REVERSE_QOUTE_STRING", "FILESIZE_LITERAL", "START_NATIONAL_STRING_LITERAL", 
			"STRING_LITERAL", "DECIMAL_LITERAL", "HEXADECIMAL_LITERAL", "REAL_LITERAL", 
			"NULL_SPEC_LITERAL", "BIT_STRING", "STRING_CHARSET_NAME", "DOT_ID", "ID", 
			"REVERSE_QUOTE_ID", "HOST_IP_ADDRESS", "LOCAL_ID", "GLOBAL_ID", "ERROR_RECONGNIGION"
		};
	}
	private static final String[] _SYMBOLIC_NAMES = makeSymbolicNames();
	public static final Vocabulary VOCABULARY = new VocabularyImpl(_LITERAL_NAMES, _SYMBOLIC_NAMES);

	/**
	 * @deprecated Use {@link #VOCABULARY} instead.
	 */
	@Deprecated
	public static final String[] tokenNames;
	static {
		tokenNames = new String[_SYMBOLIC_NAMES.length];
		for (int i = 0; i < tokenNames.length; i++) {
			tokenNames[i] = VOCABULARY.getLiteralName(i);
			if (tokenNames[i] == null) {
				tokenNames[i] = VOCABULARY.getSymbolicName(i);
			}

			if (tokenNames[i] == null) {
				tokenNames[i] = "";
			}
		}
	}

	@Override
	@Deprecated
	public String[] getTokenNames() {
		return tokenNames;
	}

	@Override

	public Vocabulary getVocabulary() {
		return VOCABULARY;
	}

	@Override
	public String getGrammarFileName() { return "MySqlParser.g4"; }

	@Override
	public String[] getRuleNames() { return ruleNames; }

	@Override
	public String getSerializedATN() { return _serializedATN; }

	@Override
	public ATN getATN() { return _ATN; }

	public MySqlParser(TokenStream input) {
		super(input);
		_interp = new ParserATNSimulator(this,_ATN,_decisionToDFA,_sharedContextCache);
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RootContext extends ParserRuleContext {
		public TerminalNode EOF() { return getToken(MySqlParser.EOF, 0); }
		public SqlStatementsContext sqlStatements() {
			return getRuleContext(SqlStatementsContext.class,0);
		}
		public List MINUS() { return getTokens(MySqlParser.MINUS); }
		public TerminalNode MINUS(int i) {
			return getToken(MySqlParser.MINUS, i);
		}
		public RootContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_root; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoot(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoot(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoot(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RootContext root() throws RecognitionException {
		RootContext _localctx = new RootContext(_ctx, getState());
		enterRule(_localctx, 0, RULE_root);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(723);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 4614060972218253952L) != 0) || ((((_la - 71)) & ~0x3f) == 0 && ((1L << (_la - 71)) & 2306124490637066243L) != 0) || ((((_la - 138)) & ~0x3f) == 0 && ((1L << (_la - 138)) & 19509751503569451L) != 0) || ((((_la - 344)) & ~0x3f) == 0 && ((1L << (_la - 344)) & 36099165796700291L) != 0) || ((((_la - 432)) & ~0x3f) == 0 && ((1L << (_la - 432)) & 16782337L) != 0) || ((((_la - 560)) & ~0x3f) == 0 && ((1L << (_la - 560)) & 17730162917377L) != 0) || ((((_la - 629)) & ~0x3f) == 0 && ((1L << (_la - 629)) & 4503604056555585L) != 0) || _la==EXECUTE || _la==SHUTDOWN || _la==LR_BRACKET || _la==SEMI) {
				{
				setState(722);
				sqlStatements();
				}
			}

			setState(727);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==MINUS) {
				{
				setState(725);
				match(MINUS);
				setState(726);
				match(MINUS);
				}
			}

			setState(729);
			match(EOF);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SqlStatementsContext extends ParserRuleContext {
		public List sqlStatement() {
			return getRuleContexts(SqlStatementContext.class);
		}
		public SqlStatementContext sqlStatement(int i) {
			return getRuleContext(SqlStatementContext.class,i);
		}
		public List emptyStatement_() {
			return getRuleContexts(EmptyStatement_Context.class);
		}
		public EmptyStatement_Context emptyStatement_(int i) {
			return getRuleContext(EmptyStatement_Context.class,i);
		}
		public List SEMI() { return getTokens(MySqlParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(MySqlParser.SEMI, i);
		}
		public List MINUS() { return getTokens(MySqlParser.MINUS); }
		public TerminalNode MINUS(int i) {
			return getToken(MySqlParser.MINUS, i);
		}
		public SqlStatementsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_sqlStatements; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSqlStatements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSqlStatements(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSqlStatements(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SqlStatementsContext sqlStatements() throws RecognitionException {
		SqlStatementsContext _localctx = new SqlStatementsContext(_ctx, getState());
		enterRule(_localctx, 2, RULE_sqlStatements);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(742);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,5,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					setState(740);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case ALTER:
					case ANALYZE:
					case CALL:
					case CHANGE:
					case CHECK:
					case CREATE:
					case DELETE:
					case DESC:
					case DESCRIBE:
					case DROP:
					case EXPLAIN:
					case GET:
					case GRANT:
					case INSERT:
					case KILL:
					case LOAD:
					case LOCK:
					case OPTIMIZE:
					case PURGE:
					case RELEASE:
					case RENAME:
					case REPLACE:
					case RESIGNAL:
					case REVOKE:
					case SELECT:
					case SET:
					case SHOW:
					case SIGNAL:
					case TABLE:
					case UNLOCK:
					case UPDATE:
					case USE:
					case VALUES:
					case WITH:
					case BEGIN:
					case BINLOG:
					case CACHE:
					case CHECKSUM:
					case COMMIT:
					case DEALLOCATE:
					case DO:
					case FLUSH:
					case HANDLER:
					case HELP:
					case INSTALL:
					case PREPARE:
					case REPAIR:
					case RESET:
					case ROLLBACK:
					case SAVEPOINT:
					case START:
					case STOP:
					case TRUNCATE:
					case UNINSTALL:
					case XA:
					case EXECUTE:
					case SHUTDOWN:
					case LR_BRACKET:
						{
						setState(731);
						sqlStatement();
						setState(734);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==MINUS) {
							{
							setState(732);
							match(MINUS);
							setState(733);
							match(MINUS);
							}
						}

						setState(737);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,3,_ctx) ) {
						case 1:
							{
							setState(736);
							match(SEMI);
							}
							break;
						}
						}
						break;
					case SEMI:
						{
						setState(739);
						emptyStatement_();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					} 
				}
				setState(744);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,5,_ctx);
			}
			setState(754);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALTER:
			case ANALYZE:
			case CALL:
			case CHANGE:
			case CHECK:
			case CREATE:
			case DELETE:
			case DESC:
			case DESCRIBE:
			case DROP:
			case EXPLAIN:
			case GET:
			case GRANT:
			case INSERT:
			case KILL:
			case LOAD:
			case LOCK:
			case OPTIMIZE:
			case PURGE:
			case RELEASE:
			case RENAME:
			case REPLACE:
			case RESIGNAL:
			case REVOKE:
			case SELECT:
			case SET:
			case SHOW:
			case SIGNAL:
			case TABLE:
			case UNLOCK:
			case UPDATE:
			case USE:
			case VALUES:
			case WITH:
			case BEGIN:
			case BINLOG:
			case CACHE:
			case CHECKSUM:
			case COMMIT:
			case DEALLOCATE:
			case DO:
			case FLUSH:
			case HANDLER:
			case HELP:
			case INSTALL:
			case PREPARE:
			case REPAIR:
			case RESET:
			case ROLLBACK:
			case SAVEPOINT:
			case START:
			case STOP:
			case TRUNCATE:
			case UNINSTALL:
			case XA:
			case EXECUTE:
			case SHUTDOWN:
			case LR_BRACKET:
				{
				setState(745);
				sqlStatement();
				setState(751);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,7,_ctx) ) {
				case 1:
					{
					setState(748);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==MINUS) {
						{
						setState(746);
						match(MINUS);
						setState(747);
						match(MINUS);
						}
					}

					setState(750);
					match(SEMI);
					}
					break;
				}
				}
				break;
			case SEMI:
				{
				setState(753);
				emptyStatement_();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SqlStatementContext extends ParserRuleContext {
		public DdlStatementContext ddlStatement() {
			return getRuleContext(DdlStatementContext.class,0);
		}
		public DmlStatementContext dmlStatement() {
			return getRuleContext(DmlStatementContext.class,0);
		}
		public TransactionStatementContext transactionStatement() {
			return getRuleContext(TransactionStatementContext.class,0);
		}
		public ReplicationStatementContext replicationStatement() {
			return getRuleContext(ReplicationStatementContext.class,0);
		}
		public PreparedStatementContext preparedStatement() {
			return getRuleContext(PreparedStatementContext.class,0);
		}
		public AdministrationStatementContext administrationStatement() {
			return getRuleContext(AdministrationStatementContext.class,0);
		}
		public UtilityStatementContext utilityStatement() {
			return getRuleContext(UtilityStatementContext.class,0);
		}
		public SqlStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_sqlStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSqlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSqlStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSqlStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SqlStatementContext sqlStatement() throws RecognitionException {
		SqlStatementContext _localctx = new SqlStatementContext(_ctx, getState());
		enterRule(_localctx, 4, RULE_sqlStatement);
		try {
			setState(763);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,9,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(756);
				ddlStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(757);
				dmlStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(758);
				transactionStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(759);
				replicationStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(760);
				preparedStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(761);
				administrationStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(762);
				utilityStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class EmptyStatement_Context extends ParserRuleContext {
		public TerminalNode SEMI() { return getToken(MySqlParser.SEMI, 0); }
		public EmptyStatement_Context(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_emptyStatement_; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterEmptyStatement_(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitEmptyStatement_(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitEmptyStatement_(this);
			else return visitor.visitChildren(this);
		}
	}

	public final EmptyStatement_Context emptyStatement_() throws RecognitionException {
		EmptyStatement_Context _localctx = new EmptyStatement_Context(_ctx, getState());
		enterRule(_localctx, 6, RULE_emptyStatement_);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(765);
			match(SEMI);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DdlStatementContext extends ParserRuleContext {
		public CreateDatabaseContext createDatabase() {
			return getRuleContext(CreateDatabaseContext.class,0);
		}
		public CreateEventContext createEvent() {
			return getRuleContext(CreateEventContext.class,0);
		}
		public CreateIndexContext createIndex() {
			return getRuleContext(CreateIndexContext.class,0);
		}
		public CreateLogfileGroupContext createLogfileGroup() {
			return getRuleContext(CreateLogfileGroupContext.class,0);
		}
		public CreateProcedureContext createProcedure() {
			return getRuleContext(CreateProcedureContext.class,0);
		}
		public CreateFunctionContext createFunction() {
			return getRuleContext(CreateFunctionContext.class,0);
		}
		public CreateServerContext createServer() {
			return getRuleContext(CreateServerContext.class,0);
		}
		public CreateTableContext createTable() {
			return getRuleContext(CreateTableContext.class,0);
		}
		public CreateTablespaceInnodbContext createTablespaceInnodb() {
			return getRuleContext(CreateTablespaceInnodbContext.class,0);
		}
		public CreateTablespaceNdbContext createTablespaceNdb() {
			return getRuleContext(CreateTablespaceNdbContext.class,0);
		}
		public CreateTriggerContext createTrigger() {
			return getRuleContext(CreateTriggerContext.class,0);
		}
		public CreateViewContext createView() {
			return getRuleContext(CreateViewContext.class,0);
		}
		public CreateRoleContext createRole() {
			return getRuleContext(CreateRoleContext.class,0);
		}
		public AlterDatabaseContext alterDatabase() {
			return getRuleContext(AlterDatabaseContext.class,0);
		}
		public AlterEventContext alterEvent() {
			return getRuleContext(AlterEventContext.class,0);
		}
		public AlterFunctionContext alterFunction() {
			return getRuleContext(AlterFunctionContext.class,0);
		}
		public AlterInstanceContext alterInstance() {
			return getRuleContext(AlterInstanceContext.class,0);
		}
		public AlterLogfileGroupContext alterLogfileGroup() {
			return getRuleContext(AlterLogfileGroupContext.class,0);
		}
		public AlterProcedureContext alterProcedure() {
			return getRuleContext(AlterProcedureContext.class,0);
		}
		public AlterServerContext alterServer() {
			return getRuleContext(AlterServerContext.class,0);
		}
		public AlterTableContext alterTable() {
			return getRuleContext(AlterTableContext.class,0);
		}
		public AlterTablespaceContext alterTablespace() {
			return getRuleContext(AlterTablespaceContext.class,0);
		}
		public AlterViewContext alterView() {
			return getRuleContext(AlterViewContext.class,0);
		}
		public DropDatabaseContext dropDatabase() {
			return getRuleContext(DropDatabaseContext.class,0);
		}
		public DropEventContext dropEvent() {
			return getRuleContext(DropEventContext.class,0);
		}
		public DropIndexContext dropIndex() {
			return getRuleContext(DropIndexContext.class,0);
		}
		public DropLogfileGroupContext dropLogfileGroup() {
			return getRuleContext(DropLogfileGroupContext.class,0);
		}
		public DropProcedureContext dropProcedure() {
			return getRuleContext(DropProcedureContext.class,0);
		}
		public DropFunctionContext dropFunction() {
			return getRuleContext(DropFunctionContext.class,0);
		}
		public DropServerContext dropServer() {
			return getRuleContext(DropServerContext.class,0);
		}
		public DropTableContext dropTable() {
			return getRuleContext(DropTableContext.class,0);
		}
		public DropTablespaceContext dropTablespace() {
			return getRuleContext(DropTablespaceContext.class,0);
		}
		public DropTriggerContext dropTrigger() {
			return getRuleContext(DropTriggerContext.class,0);
		}
		public DropViewContext dropView() {
			return getRuleContext(DropViewContext.class,0);
		}
		public DropRoleContext dropRole() {
			return getRuleContext(DropRoleContext.class,0);
		}
		public SetRoleContext setRole() {
			return getRuleContext(SetRoleContext.class,0);
		}
		public RenameTableContext renameTable() {
			return getRuleContext(RenameTableContext.class,0);
		}
		public TruncateTableContext truncateTable() {
			return getRuleContext(TruncateTableContext.class,0);
		}
		public DdlStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_ddlStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDdlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDdlStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDdlStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DdlStatementContext ddlStatement() throws RecognitionException {
		DdlStatementContext _localctx = new DdlStatementContext(_ctx, getState());
		enterRule(_localctx, 8, RULE_ddlStatement);
		try {
			setState(805);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,10,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(767);
				createDatabase();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(768);
				createEvent();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(769);
				createIndex();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(770);
				createLogfileGroup();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(771);
				createProcedure();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(772);
				createFunction();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(773);
				createServer();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(774);
				createTable();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(775);
				createTablespaceInnodb();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(776);
				createTablespaceNdb();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(777);
				createTrigger();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(778);
				createView();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(779);
				createRole();
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(780);
				alterDatabase();
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(781);
				alterEvent();
				}
				break;
			case 16:
				enterOuterAlt(_localctx, 16);
				{
				setState(782);
				alterFunction();
				}
				break;
			case 17:
				enterOuterAlt(_localctx, 17);
				{
				setState(783);
				alterInstance();
				}
				break;
			case 18:
				enterOuterAlt(_localctx, 18);
				{
				setState(784);
				alterLogfileGroup();
				}
				break;
			case 19:
				enterOuterAlt(_localctx, 19);
				{
				setState(785);
				alterProcedure();
				}
				break;
			case 20:
				enterOuterAlt(_localctx, 20);
				{
				setState(786);
				alterServer();
				}
				break;
			case 21:
				enterOuterAlt(_localctx, 21);
				{
				setState(787);
				alterTable();
				}
				break;
			case 22:
				enterOuterAlt(_localctx, 22);
				{
				setState(788);
				alterTablespace();
				}
				break;
			case 23:
				enterOuterAlt(_localctx, 23);
				{
				setState(789);
				alterView();
				}
				break;
			case 24:
				enterOuterAlt(_localctx, 24);
				{
				setState(790);
				dropDatabase();
				}
				break;
			case 25:
				enterOuterAlt(_localctx, 25);
				{
				setState(791);
				dropEvent();
				}
				break;
			case 26:
				enterOuterAlt(_localctx, 26);
				{
				setState(792);
				dropIndex();
				}
				break;
			case 27:
				enterOuterAlt(_localctx, 27);
				{
				setState(793);
				dropLogfileGroup();
				}
				break;
			case 28:
				enterOuterAlt(_localctx, 28);
				{
				setState(794);
				dropProcedure();
				}
				break;
			case 29:
				enterOuterAlt(_localctx, 29);
				{
				setState(795);
				dropFunction();
				}
				break;
			case 30:
				enterOuterAlt(_localctx, 30);
				{
				setState(796);
				dropServer();
				}
				break;
			case 31:
				enterOuterAlt(_localctx, 31);
				{
				setState(797);
				dropTable();
				}
				break;
			case 32:
				enterOuterAlt(_localctx, 32);
				{
				setState(798);
				dropTablespace();
				}
				break;
			case 33:
				enterOuterAlt(_localctx, 33);
				{
				setState(799);
				dropTrigger();
				}
				break;
			case 34:
				enterOuterAlt(_localctx, 34);
				{
				setState(800);
				dropView();
				}
				break;
			case 35:
				enterOuterAlt(_localctx, 35);
				{
				setState(801);
				dropRole();
				}
				break;
			case 36:
				enterOuterAlt(_localctx, 36);
				{
				setState(802);
				setRole();
				}
				break;
			case 37:
				enterOuterAlt(_localctx, 37);
				{
				setState(803);
				renameTable();
				}
				break;
			case 38:
				enterOuterAlt(_localctx, 38);
				{
				setState(804);
				truncateTable();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DmlStatementContext extends ParserRuleContext {
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public InsertStatementContext insertStatement() {
			return getRuleContext(InsertStatementContext.class,0);
		}
		public UpdateStatementContext updateStatement() {
			return getRuleContext(UpdateStatementContext.class,0);
		}
		public DeleteStatementContext deleteStatement() {
			return getRuleContext(DeleteStatementContext.class,0);
		}
		public ReplaceStatementContext replaceStatement() {
			return getRuleContext(ReplaceStatementContext.class,0);
		}
		public CallStatementContext callStatement() {
			return getRuleContext(CallStatementContext.class,0);
		}
		public LoadDataStatementContext loadDataStatement() {
			return getRuleContext(LoadDataStatementContext.class,0);
		}
		public LoadXmlStatementContext loadXmlStatement() {
			return getRuleContext(LoadXmlStatementContext.class,0);
		}
		public DoStatementContext doStatement() {
			return getRuleContext(DoStatementContext.class,0);
		}
		public HandlerStatementContext handlerStatement() {
			return getRuleContext(HandlerStatementContext.class,0);
		}
		public ValuesStatementContext valuesStatement() {
			return getRuleContext(ValuesStatementContext.class,0);
		}
		public WithStatementContext withStatement() {
			return getRuleContext(WithStatementContext.class,0);
		}
		public TableStatementContext tableStatement() {
			return getRuleContext(TableStatementContext.class,0);
		}
		public DmlStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dmlStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDmlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDmlStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDmlStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DmlStatementContext dmlStatement() throws RecognitionException {
		DmlStatementContext _localctx = new DmlStatementContext(_ctx, getState());
		enterRule(_localctx, 10, RULE_dmlStatement);
		try {
			setState(820);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,11,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(807);
				selectStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(808);
				insertStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(809);
				updateStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(810);
				deleteStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(811);
				replaceStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(812);
				callStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(813);
				loadDataStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(814);
				loadXmlStatement();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(815);
				doStatement();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(816);
				handlerStatement();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(817);
				valuesStatement();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(818);
				withStatement();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(819);
				tableStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TransactionStatementContext extends ParserRuleContext {
		public StartTransactionContext startTransaction() {
			return getRuleContext(StartTransactionContext.class,0);
		}
		public BeginWorkContext beginWork() {
			return getRuleContext(BeginWorkContext.class,0);
		}
		public CommitWorkContext commitWork() {
			return getRuleContext(CommitWorkContext.class,0);
		}
		public RollbackWorkContext rollbackWork() {
			return getRuleContext(RollbackWorkContext.class,0);
		}
		public SavepointStatementContext savepointStatement() {
			return getRuleContext(SavepointStatementContext.class,0);
		}
		public RollbackStatementContext rollbackStatement() {
			return getRuleContext(RollbackStatementContext.class,0);
		}
		public ReleaseStatementContext releaseStatement() {
			return getRuleContext(ReleaseStatementContext.class,0);
		}
		public LockTablesContext lockTables() {
			return getRuleContext(LockTablesContext.class,0);
		}
		public UnlockTablesContext unlockTables() {
			return getRuleContext(UnlockTablesContext.class,0);
		}
		public TransactionStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_transactionStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTransactionStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTransactionStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTransactionStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TransactionStatementContext transactionStatement() throws RecognitionException {
		TransactionStatementContext _localctx = new TransactionStatementContext(_ctx, getState());
		enterRule(_localctx, 12, RULE_transactionStatement);
		try {
			setState(831);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,12,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(822);
				startTransaction();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(823);
				beginWork();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(824);
				commitWork();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(825);
				rollbackWork();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(826);
				savepointStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(827);
				rollbackStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(828);
				releaseStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(829);
				lockTables();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(830);
				unlockTables();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReplicationStatementContext extends ParserRuleContext {
		public ChangeMasterContext changeMaster() {
			return getRuleContext(ChangeMasterContext.class,0);
		}
		public ChangeReplicationFilterContext changeReplicationFilter() {
			return getRuleContext(ChangeReplicationFilterContext.class,0);
		}
		public PurgeBinaryLogsContext purgeBinaryLogs() {
			return getRuleContext(PurgeBinaryLogsContext.class,0);
		}
		public ResetMasterContext resetMaster() {
			return getRuleContext(ResetMasterContext.class,0);
		}
		public ResetSlaveContext resetSlave() {
			return getRuleContext(ResetSlaveContext.class,0);
		}
		public StartSlaveContext startSlave() {
			return getRuleContext(StartSlaveContext.class,0);
		}
		public StopSlaveContext stopSlave() {
			return getRuleContext(StopSlaveContext.class,0);
		}
		public StartGroupReplicationContext startGroupReplication() {
			return getRuleContext(StartGroupReplicationContext.class,0);
		}
		public StopGroupReplicationContext stopGroupReplication() {
			return getRuleContext(StopGroupReplicationContext.class,0);
		}
		public XaStartTransactionContext xaStartTransaction() {
			return getRuleContext(XaStartTransactionContext.class,0);
		}
		public XaEndTransactionContext xaEndTransaction() {
			return getRuleContext(XaEndTransactionContext.class,0);
		}
		public XaPrepareStatementContext xaPrepareStatement() {
			return getRuleContext(XaPrepareStatementContext.class,0);
		}
		public XaCommitWorkContext xaCommitWork() {
			return getRuleContext(XaCommitWorkContext.class,0);
		}
		public XaRollbackWorkContext xaRollbackWork() {
			return getRuleContext(XaRollbackWorkContext.class,0);
		}
		public XaRecoverWorkContext xaRecoverWork() {
			return getRuleContext(XaRecoverWorkContext.class,0);
		}
		public ReplicationStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_replicationStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReplicationStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReplicationStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReplicationStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReplicationStatementContext replicationStatement() throws RecognitionException {
		ReplicationStatementContext _localctx = new ReplicationStatementContext(_ctx, getState());
		enterRule(_localctx, 14, RULE_replicationStatement);
		try {
			setState(848);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,13,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(833);
				changeMaster();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(834);
				changeReplicationFilter();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(835);
				purgeBinaryLogs();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(836);
				resetMaster();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(837);
				resetSlave();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(838);
				startSlave();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(839);
				stopSlave();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(840);
				startGroupReplication();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(841);
				stopGroupReplication();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(842);
				xaStartTransaction();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(843);
				xaEndTransaction();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(844);
				xaPrepareStatement();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(845);
				xaCommitWork();
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(846);
				xaRollbackWork();
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(847);
				xaRecoverWork();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PreparedStatementContext extends ParserRuleContext {
		public PrepareStatementContext prepareStatement() {
			return getRuleContext(PrepareStatementContext.class,0);
		}
		public ExecuteStatementContext executeStatement() {
			return getRuleContext(ExecuteStatementContext.class,0);
		}
		public DeallocatePrepareContext deallocatePrepare() {
			return getRuleContext(DeallocatePrepareContext.class,0);
		}
		public PreparedStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_preparedStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPreparedStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPreparedStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPreparedStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PreparedStatementContext preparedStatement() throws RecognitionException {
		PreparedStatementContext _localctx = new PreparedStatementContext(_ctx, getState());
		enterRule(_localctx, 16, RULE_preparedStatement);
		try {
			setState(853);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case PREPARE:
				enterOuterAlt(_localctx, 1);
				{
				setState(850);
				prepareStatement();
				}
				break;
			case EXECUTE:
				enterOuterAlt(_localctx, 2);
				{
				setState(851);
				executeStatement();
				}
				break;
			case DROP:
			case DEALLOCATE:
				enterOuterAlt(_localctx, 3);
				{
				setState(852);
				deallocatePrepare();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CompoundStatementContext extends ParserRuleContext {
		public BlockStatementContext blockStatement() {
			return getRuleContext(BlockStatementContext.class,0);
		}
		public CaseStatementContext caseStatement() {
			return getRuleContext(CaseStatementContext.class,0);
		}
		public IfStatementContext ifStatement() {
			return getRuleContext(IfStatementContext.class,0);
		}
		public LeaveStatementContext leaveStatement() {
			return getRuleContext(LeaveStatementContext.class,0);
		}
		public LoopStatementContext loopStatement() {
			return getRuleContext(LoopStatementContext.class,0);
		}
		public RepeatStatementContext repeatStatement() {
			return getRuleContext(RepeatStatementContext.class,0);
		}
		public WhileStatementContext whileStatement() {
			return getRuleContext(WhileStatementContext.class,0);
		}
		public IterateStatementContext iterateStatement() {
			return getRuleContext(IterateStatementContext.class,0);
		}
		public ReturnStatementContext returnStatement() {
			return getRuleContext(ReturnStatementContext.class,0);
		}
		public CursorStatementContext cursorStatement() {
			return getRuleContext(CursorStatementContext.class,0);
		}
		public CompoundStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_compoundStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCompoundStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCompoundStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCompoundStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CompoundStatementContext compoundStatement() throws RecognitionException {
		CompoundStatementContext _localctx = new CompoundStatementContext(_ctx, getState());
		enterRule(_localctx, 18, RULE_compoundStatement);
		try {
			setState(865);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,15,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(855);
				blockStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(856);
				caseStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(857);
				ifStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(858);
				leaveStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(859);
				loopStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(860);
				repeatStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(861);
				whileStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(862);
				iterateStatement();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(863);
				returnStatement();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(864);
				cursorStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AdministrationStatementContext extends ParserRuleContext {
		public AlterUserContext alterUser() {
			return getRuleContext(AlterUserContext.class,0);
		}
		public CreateUserContext createUser() {
			return getRuleContext(CreateUserContext.class,0);
		}
		public DropUserContext dropUser() {
			return getRuleContext(DropUserContext.class,0);
		}
		public GrantStatementContext grantStatement() {
			return getRuleContext(GrantStatementContext.class,0);
		}
		public GrantProxyContext grantProxy() {
			return getRuleContext(GrantProxyContext.class,0);
		}
		public RenameUserContext renameUser() {
			return getRuleContext(RenameUserContext.class,0);
		}
		public RevokeStatementContext revokeStatement() {
			return getRuleContext(RevokeStatementContext.class,0);
		}
		public RevokeProxyContext revokeProxy() {
			return getRuleContext(RevokeProxyContext.class,0);
		}
		public AnalyzeTableContext analyzeTable() {
			return getRuleContext(AnalyzeTableContext.class,0);
		}
		public CheckTableContext checkTable() {
			return getRuleContext(CheckTableContext.class,0);
		}
		public ChecksumTableContext checksumTable() {
			return getRuleContext(ChecksumTableContext.class,0);
		}
		public OptimizeTableContext optimizeTable() {
			return getRuleContext(OptimizeTableContext.class,0);
		}
		public RepairTableContext repairTable() {
			return getRuleContext(RepairTableContext.class,0);
		}
		public CreateUdfunctionContext createUdfunction() {
			return getRuleContext(CreateUdfunctionContext.class,0);
		}
		public InstallPluginContext installPlugin() {
			return getRuleContext(InstallPluginContext.class,0);
		}
		public UninstallPluginContext uninstallPlugin() {
			return getRuleContext(UninstallPluginContext.class,0);
		}
		public SetStatementContext setStatement() {
			return getRuleContext(SetStatementContext.class,0);
		}
		public ShowStatementContext showStatement() {
			return getRuleContext(ShowStatementContext.class,0);
		}
		public BinlogStatementContext binlogStatement() {
			return getRuleContext(BinlogStatementContext.class,0);
		}
		public CacheIndexStatementContext cacheIndexStatement() {
			return getRuleContext(CacheIndexStatementContext.class,0);
		}
		public FlushStatementContext flushStatement() {
			return getRuleContext(FlushStatementContext.class,0);
		}
		public KillStatementContext killStatement() {
			return getRuleContext(KillStatementContext.class,0);
		}
		public LoadIndexIntoCacheContext loadIndexIntoCache() {
			return getRuleContext(LoadIndexIntoCacheContext.class,0);
		}
		public ResetStatementContext resetStatement() {
			return getRuleContext(ResetStatementContext.class,0);
		}
		public ShutdownStatementContext shutdownStatement() {
			return getRuleContext(ShutdownStatementContext.class,0);
		}
		public AdministrationStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_administrationStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAdministrationStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAdministrationStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAdministrationStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AdministrationStatementContext administrationStatement() throws RecognitionException {
		AdministrationStatementContext _localctx = new AdministrationStatementContext(_ctx, getState());
		enterRule(_localctx, 20, RULE_administrationStatement);
		try {
			setState(892);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,16,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(867);
				alterUser();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(868);
				createUser();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(869);
				dropUser();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(870);
				grantStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(871);
				grantProxy();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(872);
				renameUser();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(873);
				revokeStatement();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(874);
				revokeProxy();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(875);
				analyzeTable();
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(876);
				checkTable();
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(877);
				checksumTable();
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(878);
				optimizeTable();
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(879);
				repairTable();
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(880);
				createUdfunction();
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(881);
				installPlugin();
				}
				break;
			case 16:
				enterOuterAlt(_localctx, 16);
				{
				setState(882);
				uninstallPlugin();
				}
				break;
			case 17:
				enterOuterAlt(_localctx, 17);
				{
				setState(883);
				setStatement();
				}
				break;
			case 18:
				enterOuterAlt(_localctx, 18);
				{
				setState(884);
				showStatement();
				}
				break;
			case 19:
				enterOuterAlt(_localctx, 19);
				{
				setState(885);
				binlogStatement();
				}
				break;
			case 20:
				enterOuterAlt(_localctx, 20);
				{
				setState(886);
				cacheIndexStatement();
				}
				break;
			case 21:
				enterOuterAlt(_localctx, 21);
				{
				setState(887);
				flushStatement();
				}
				break;
			case 22:
				enterOuterAlt(_localctx, 22);
				{
				setState(888);
				killStatement();
				}
				break;
			case 23:
				enterOuterAlt(_localctx, 23);
				{
				setState(889);
				loadIndexIntoCache();
				}
				break;
			case 24:
				enterOuterAlt(_localctx, 24);
				{
				setState(890);
				resetStatement();
				}
				break;
			case 25:
				enterOuterAlt(_localctx, 25);
				{
				setState(891);
				shutdownStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UtilityStatementContext extends ParserRuleContext {
		public SimpleDescribeStatementContext simpleDescribeStatement() {
			return getRuleContext(SimpleDescribeStatementContext.class,0);
		}
		public FullDescribeStatementContext fullDescribeStatement() {
			return getRuleContext(FullDescribeStatementContext.class,0);
		}
		public HelpStatementContext helpStatement() {
			return getRuleContext(HelpStatementContext.class,0);
		}
		public UseStatementContext useStatement() {
			return getRuleContext(UseStatementContext.class,0);
		}
		public SignalStatementContext signalStatement() {
			return getRuleContext(SignalStatementContext.class,0);
		}
		public ResignalStatementContext resignalStatement() {
			return getRuleContext(ResignalStatementContext.class,0);
		}
		public DiagnosticsStatementContext diagnosticsStatement() {
			return getRuleContext(DiagnosticsStatementContext.class,0);
		}
		public UtilityStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_utilityStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUtilityStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUtilityStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUtilityStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UtilityStatementContext utilityStatement() throws RecognitionException {
		UtilityStatementContext _localctx = new UtilityStatementContext(_ctx, getState());
		enterRule(_localctx, 22, RULE_utilityStatement);
		try {
			setState(901);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,17,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(894);
				simpleDescribeStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(895);
				fullDescribeStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(896);
				helpStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(897);
				useStatement();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(898);
				signalStatement();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(899);
				resignalStatement();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(900);
				diagnosticsStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateDatabaseContext extends ParserRuleContext {
		public Token dbFormat;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List createDatabaseOption() {
			return getRuleContexts(CreateDatabaseOptionContext.class);
		}
		public CreateDatabaseOptionContext createDatabaseOption(int i) {
			return getRuleContext(CreateDatabaseOptionContext.class,i);
		}
		public CreateDatabaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createDatabase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateDatabase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateDatabase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateDatabase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateDatabaseContext createDatabase() throws RecognitionException {
		CreateDatabaseContext _localctx = new CreateDatabaseContext(_ctx, getState());
		enterRule(_localctx, 24, RULE_createDatabase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(903);
			match(CREATE);
			setState(904);
			((CreateDatabaseContext)_localctx).dbFormat = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==DATABASE || _la==SCHEMA) ) {
				((CreateDatabaseContext)_localctx).dbFormat = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(906);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,18,_ctx) ) {
			case 1:
				{
				setState(905);
				ifNotExists();
				}
				break;
			}
			setState(908);
			uid();
			setState(912);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while ((((_la) & ~0x3f) == 0 && ((1L << _la) & 4398214283264L) != 0) || _la==READ || _la==CHAR || _la==ENCRYPTION || _la==CHARSET) {
				{
				{
				setState(909);
				createDatabaseOption();
				}
				}
				setState(914);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateEventContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode EVENT() { return getToken(MySqlParser.EVENT, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public List ON() { return getTokens(MySqlParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MySqlParser.ON, i);
		}
		public TerminalNode SCHEDULE() { return getToken(MySqlParser.SCHEDULE, 0); }
		public ScheduleExpressionContext scheduleExpression() {
			return getRuleContext(ScheduleExpressionContext.class,0);
		}
		public TerminalNode DO() { return getToken(MySqlParser.DO, 0); }
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public TerminalNode COMPLETION() { return getToken(MySqlParser.COMPLETION, 0); }
		public TerminalNode PRESERVE() { return getToken(MySqlParser.PRESERVE, 0); }
		public EnableTypeContext enableType() {
			return getRuleContext(EnableTypeContext.class,0);
		}
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public CreateEventContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createEvent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateEvent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateEvent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateEvent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateEventContext createEvent() throws RecognitionException {
		CreateEventContext _localctx = new CreateEventContext(_ctx, getState());
		enterRule(_localctx, 26, RULE_createEvent);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(915);
			match(CREATE);
			setState(917);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(916);
				ownerStatement();
				}
			}

			setState(919);
			match(EVENT);
			setState(921);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,21,_ctx) ) {
			case 1:
				{
				setState(920);
				ifNotExists();
				}
				break;
			}
			setState(923);
			fullId();
			setState(924);
			match(ON);
			setState(925);
			match(SCHEDULE);
			setState(926);
			scheduleExpression();
			setState(933);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ON) {
				{
				setState(927);
				match(ON);
				setState(928);
				match(COMPLETION);
				setState(930);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(929);
					match(NOT);
					}
				}

				setState(932);
				match(PRESERVE);
				}
			}

			setState(936);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DISABLE || _la==ENABLE) {
				{
				setState(935);
				enableType();
				}
			}

			setState(940);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(938);
				match(COMMENT);
				setState(939);
				match(STRING_LITERAL);
				}
			}

			setState(942);
			match(DO);
			setState(943);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateIndexContext extends ParserRuleContext {
		public Token intimeAction;
		public Token indexCategory;
		public Token algType;
		public Token lockType;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public List ALGORITHM() { return getTokens(MySqlParser.ALGORITHM); }
		public TerminalNode ALGORITHM(int i) {
			return getToken(MySqlParser.ALGORITHM, i);
		}
		public List LOCK() { return getTokens(MySqlParser.LOCK); }
		public TerminalNode LOCK(int i) {
			return getToken(MySqlParser.LOCK, i);
		}
		public TerminalNode ONLINE() { return getToken(MySqlParser.ONLINE, 0); }
		public TerminalNode OFFLINE() { return getToken(MySqlParser.OFFLINE, 0); }
		public TerminalNode UNIQUE() { return getToken(MySqlParser.UNIQUE, 0); }
		public TerminalNode FULLTEXT() { return getToken(MySqlParser.FULLTEXT, 0); }
		public TerminalNode SPATIAL() { return getToken(MySqlParser.SPATIAL, 0); }
		public List DEFAULT() { return getTokens(MySqlParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MySqlParser.DEFAULT, i);
		}
		public List INPLACE() { return getTokens(MySqlParser.INPLACE); }
		public TerminalNode INPLACE(int i) {
			return getToken(MySqlParser.INPLACE, i);
		}
		public List COPY() { return getTokens(MySqlParser.COPY); }
		public TerminalNode COPY(int i) {
			return getToken(MySqlParser.COPY, i);
		}
		public List NONE() { return getTokens(MySqlParser.NONE); }
		public TerminalNode NONE(int i) {
			return getToken(MySqlParser.NONE, i);
		}
		public List SHARED() { return getTokens(MySqlParser.SHARED); }
		public TerminalNode SHARED(int i) {
			return getToken(MySqlParser.SHARED, i);
		}
		public List EXCLUSIVE() { return getTokens(MySqlParser.EXCLUSIVE); }
		public TerminalNode EXCLUSIVE(int i) {
			return getToken(MySqlParser.EXCLUSIVE, i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public CreateIndexContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createIndex; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateIndex(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateIndex(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateIndexContext createIndex() throws RecognitionException {
		CreateIndexContext _localctx = new CreateIndexContext(_ctx, getState());
		enterRule(_localctx, 28, RULE_createIndex);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(945);
			match(CREATE);
			setState(947);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OFFLINE || _la==ONLINE) {
				{
				setState(946);
				((CreateIndexContext)_localctx).intimeAction = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==OFFLINE || _la==ONLINE) ) {
					((CreateIndexContext)_localctx).intimeAction = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(950);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FULLTEXT || _la==SPATIAL || _la==UNIQUE) {
				{
				setState(949);
				((CreateIndexContext)_localctx).indexCategory = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FULLTEXT || _la==SPATIAL || _la==UNIQUE) ) {
					((CreateIndexContext)_localctx).indexCategory = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(952);
			match(INDEX);
			setState(953);
			uid();
			setState(955);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==USING) {
				{
				setState(954);
				indexType();
				}
			}

			setState(957);
			match(ON);
			setState(958);
			tableName();
			setState(959);
			indexColumnNames();
			setState(963);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,29,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(960);
					indexOption();
					}
					} 
				}
				setState(965);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,29,_ctx);
			}
			setState(978);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,33,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					setState(976);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case ALGORITHM:
						{
						setState(966);
						match(ALGORITHM);
						setState(968);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(967);
							match(EQUAL_SYMBOL);
							}
						}

						setState(970);
						((CreateIndexContext)_localctx).algType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==DEFAULT || _la==COPY || _la==INPLACE) ) {
							((CreateIndexContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						break;
					case LOCK:
						{
						setState(971);
						match(LOCK);
						setState(973);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(972);
							match(EQUAL_SYMBOL);
							}
						}

						setState(975);
						((CreateIndexContext)_localctx).lockType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==DEFAULT || _la==EXCLUSIVE || _la==NONE || _la==SHARED) ) {
							((CreateIndexContext)_localctx).lockType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					} 
				}
				setState(980);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,33,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateLogfileGroupContext extends ParserRuleContext {
		public Token undoFile;
		public FileSizeLiteralContext initSize;
		public FileSizeLiteralContext undoSize;
		public FileSizeLiteralContext redoSize;
		public Token comment;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode LOGFILE() { return getToken(MySqlParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode UNDOFILE() { return getToken(MySqlParser.UNDOFILE, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public TerminalNode INITIAL_SIZE() { return getToken(MySqlParser.INITIAL_SIZE, 0); }
		public TerminalNode UNDO_BUFFER_SIZE() { return getToken(MySqlParser.UNDO_BUFFER_SIZE, 0); }
		public TerminalNode REDO_BUFFER_SIZE() { return getToken(MySqlParser.REDO_BUFFER_SIZE, 0); }
		public TerminalNode NODEGROUP() { return getToken(MySqlParser.NODEGROUP, 0); }
		public TerminalNode WAIT() { return getToken(MySqlParser.WAIT, 0); }
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public List fileSizeLiteral() {
			return getRuleContexts(FileSizeLiteralContext.class);
		}
		public FileSizeLiteralContext fileSizeLiteral(int i) {
			return getRuleContext(FileSizeLiteralContext.class,i);
		}
		public CreateLogfileGroupContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createLogfileGroup; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateLogfileGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateLogfileGroup(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateLogfileGroup(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateLogfileGroupContext createLogfileGroup() throws RecognitionException {
		CreateLogfileGroupContext _localctx = new CreateLogfileGroupContext(_ctx, getState());
		enterRule(_localctx, 30, RULE_createLogfileGroup);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(981);
			match(CREATE);
			setState(982);
			match(LOGFILE);
			setState(983);
			match(GROUP);
			setState(984);
			uid();
			setState(985);
			match(ADD);
			setState(986);
			match(UNDOFILE);
			setState(987);
			((CreateLogfileGroupContext)_localctx).undoFile = match(STRING_LITERAL);
			setState(993);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(988);
				match(INITIAL_SIZE);
				setState(990);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(989);
					match(EQUAL_SYMBOL);
					}
				}

				setState(992);
				((CreateLogfileGroupContext)_localctx).initSize = fileSizeLiteral();
				}
			}

			setState(1000);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==UNDO_BUFFER_SIZE) {
				{
				setState(995);
				match(UNDO_BUFFER_SIZE);
				setState(997);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(996);
					match(EQUAL_SYMBOL);
					}
				}

				setState(999);
				((CreateLogfileGroupContext)_localctx).undoSize = fileSizeLiteral();
				}
			}

			setState(1007);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==REDO_BUFFER_SIZE) {
				{
				setState(1002);
				match(REDO_BUFFER_SIZE);
				setState(1004);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1003);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1006);
				((CreateLogfileGroupContext)_localctx).redoSize = fileSizeLiteral();
				}
			}

			setState(1014);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NODEGROUP) {
				{
				setState(1009);
				match(NODEGROUP);
				setState(1011);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1010);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1013);
				uid();
				}
			}

			setState(1017);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WAIT) {
				{
				setState(1016);
				match(WAIT);
				}
			}

			setState(1024);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(1019);
				match(COMMENT);
				setState(1021);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1020);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1023);
				((CreateLogfileGroupContext)_localctx).comment = match(STRING_LITERAL);
				}
			}

			setState(1026);
			match(ENGINE);
			setState(1028);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(1027);
				match(EQUAL_SYMBOL);
				}
			}

			setState(1030);
			engineName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateProcedureContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public List procedureParameter() {
			return getRuleContexts(ProcedureParameterContext.class);
		}
		public ProcedureParameterContext procedureParameter(int i) {
			return getRuleContext(ProcedureParameterContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List routineOption() {
			return getRuleContexts(RoutineOptionContext.class);
		}
		public RoutineOptionContext routineOption(int i) {
			return getRuleContext(RoutineOptionContext.class,i);
		}
		public CreateProcedureContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createProcedure; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateProcedure(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateProcedure(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateProcedure(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateProcedureContext createProcedure() throws RecognitionException {
		CreateProcedureContext _localctx = new CreateProcedureContext(_ctx, getState());
		enterRule(_localctx, 32, RULE_createProcedure);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1032);
			match(CREATE);
			setState(1034);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(1033);
				ownerStatement();
				}
			}

			setState(1036);
			match(PROCEDURE);
			setState(1037);
			fullId();
			setState(1038);
			match(LR_BRACKET);
			setState(1040);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 151169654698547409L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(1039);
				procedureParameter();
				}
			}

			setState(1046);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1042);
				match(COMMA);
				setState(1043);
				procedureParameter();
				}
				}
				setState(1048);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1049);
			match(RR_BRACKET);
			setState(1053);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,49,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1050);
					routineOption();
					}
					} 
				}
				setState(1055);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,49,_ctx);
			}
			setState(1056);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateFunctionContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode RETURNS() { return getToken(MySqlParser.RETURNS, 0); }
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public ReturnStatementContext returnStatement() {
			return getRuleContext(ReturnStatementContext.class,0);
		}
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode AGGREGATE() { return getToken(MySqlParser.AGGREGATE, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List functionParameter() {
			return getRuleContexts(FunctionParameterContext.class);
		}
		public FunctionParameterContext functionParameter(int i) {
			return getRuleContext(FunctionParameterContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List routineOption() {
			return getRuleContexts(RoutineOptionContext.class);
		}
		public RoutineOptionContext routineOption(int i) {
			return getRuleContext(RoutineOptionContext.class,i);
		}
		public CreateFunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createFunction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateFunction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateFunction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateFunctionContext createFunction() throws RecognitionException {
		CreateFunctionContext _localctx = new CreateFunctionContext(_ctx, getState());
		enterRule(_localctx, 34, RULE_createFunction);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1058);
			match(CREATE);
			setState(1060);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(1059);
				ownerStatement();
				}
			}

			setState(1063);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AGGREGATE) {
				{
				setState(1062);
				match(AGGREGATE);
				}
			}

			setState(1065);
			match(FUNCTION);
			setState(1067);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,52,_ctx) ) {
			case 1:
				{
				setState(1066);
				ifNotExists();
				}
				break;
			}
			setState(1069);
			fullId();
			setState(1070);
			match(LR_BRACKET);
			setState(1072);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(1071);
				functionParameter();
				}
			}

			setState(1078);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1074);
				match(COMMA);
				setState(1075);
				functionParameter();
				}
				}
				setState(1080);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1081);
			match(RR_BRACKET);
			setState(1082);
			match(RETURNS);
			setState(1083);
			dataType();
			setState(1087);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,55,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1084);
					routineOption();
					}
					} 
				}
				setState(1089);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,55,_ctx);
			}
			setState(1092);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALTER:
			case ANALYZE:
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CALL:
			case CHANGE:
			case CHECK:
			case CONDITION:
			case CREATE:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DELETE:
			case DESC:
			case DESCRIBE:
			case DIAGNOSTICS:
			case DROP:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case EXPLAIN:
			case GET:
			case GRANT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case KILL:
			case LATERAL:
			case LEFT:
			case LOAD:
			case LOCK:
			case NUMBER:
			case OPTIMIZE:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case PURGE:
			case RELEASE:
			case RENAME:
			case REPEAT:
			case REPLACE:
			case RESIGNAL:
			case REVOKE:
			case RIGHT:
			case SCHEMA:
			case SELECT:
			case SET:
			case SHOW:
			case SIGNAL:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case TABLE:
			case UNLOCK:
			case UPDATE:
			case USE:
			case VALUES:
			case WITH:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case LR_BRACKET:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				{
				setState(1090);
				routineBody();
				}
				break;
			case RETURN:
				{
				setState(1091);
				returnStatement();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateRoleContext extends ParserRuleContext {
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public List roleName() {
			return getRuleContexts(RoleNameContext.class);
		}
		public RoleNameContext roleName(int i) {
			return getRuleContext(RoleNameContext.class,i);
		}
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public CreateRoleContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createRole; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateRole(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateRole(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateRole(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateRoleContext createRole() throws RecognitionException {
		CreateRoleContext _localctx = new CreateRoleContext(_ctx, getState());
		enterRule(_localctx, 36, RULE_createRole);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1094);
			match(CREATE);
			setState(1095);
			match(ROLE);
			setState(1097);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,57,_ctx) ) {
			case 1:
				{
				setState(1096);
				ifNotExists();
				}
				break;
			}
			setState(1099);
			roleName();
			setState(1104);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1100);
				match(COMMA);
				setState(1101);
				roleName();
				}
				}
				setState(1106);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateServerContext extends ParserRuleContext {
		public Token wrapperName;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode SERVER() { return getToken(MySqlParser.SERVER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode FOREIGN() { return getToken(MySqlParser.FOREIGN, 0); }
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode WRAPPER() { return getToken(MySqlParser.WRAPPER, 0); }
		public TerminalNode OPTIONS() { return getToken(MySqlParser.OPTIONS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List serverOption() {
			return getRuleContexts(ServerOptionContext.class);
		}
		public ServerOptionContext serverOption(int i) {
			return getRuleContext(ServerOptionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode MYSQL() { return getToken(MySqlParser.MYSQL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public CreateServerContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createServer; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateServer(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateServer(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateServer(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateServerContext createServer() throws RecognitionException {
		CreateServerContext _localctx = new CreateServerContext(_ctx, getState());
		enterRule(_localctx, 38, RULE_createServer);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1107);
			match(CREATE);
			setState(1108);
			match(SERVER);
			setState(1109);
			uid();
			setState(1110);
			match(FOREIGN);
			setState(1111);
			match(DATA);
			setState(1112);
			match(WRAPPER);
			setState(1113);
			((CreateServerContext)_localctx).wrapperName = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==MYSQL || _la==STRING_LITERAL) ) {
				((CreateServerContext)_localctx).wrapperName = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(1114);
			match(OPTIONS);
			setState(1115);
			match(LR_BRACKET);
			setState(1116);
			serverOption();
			setState(1121);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1117);
				match(COMMA);
				setState(1118);
				serverOption();
				}
				}
				setState(1123);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1124);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateTableContext extends ParserRuleContext {
		public CreateTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createTable; }
	 
		public CreateTableContext() { }
		public void copyFrom(CreateTableContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CopyCreateTableContext extends CreateTableContext {
		public TableNameContext parenthesisTable;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public TerminalNode LIKE() { return getToken(MySqlParser.LIKE, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode TEMPORARY() { return getToken(MySqlParser.TEMPORARY, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public CopyCreateTableContext(CreateTableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCopyCreateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCopyCreateTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCopyCreateTable(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ColumnCreateTableContext extends CreateTableContext {
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public CreateDefinitionsContext createDefinitions() {
			return getRuleContext(CreateDefinitionsContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MySqlParser.TEMPORARY, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List tableOption() {
			return getRuleContexts(TableOptionContext.class);
		}
		public TableOptionContext tableOption(int i) {
			return getRuleContext(TableOptionContext.class,i);
		}
		public PartitionDefinitionsContext partitionDefinitions() {
			return getRuleContext(PartitionDefinitionsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ColumnCreateTableContext(CreateTableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterColumnCreateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitColumnCreateTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitColumnCreateTable(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class QueryCreateTableContext extends CreateTableContext {
		public Token keyViolate;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MySqlParser.TEMPORARY, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public CreateDefinitionsContext createDefinitions() {
			return getRuleContext(CreateDefinitionsContext.class,0);
		}
		public List tableOption() {
			return getRuleContexts(TableOptionContext.class);
		}
		public TableOptionContext tableOption(int i) {
			return getRuleContext(TableOptionContext.class,i);
		}
		public PartitionDefinitionsContext partitionDefinitions() {
			return getRuleContext(PartitionDefinitionsContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public QueryCreateTableContext(CreateTableContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterQueryCreateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitQueryCreateTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitQueryCreateTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateTableContext createTable() throws RecognitionException {
		CreateTableContext _localctx = new CreateTableContext(_ctx, getState());
		enterRule(_localctx, 40, RULE_createTable);
		int _la;
		try {
			int _alt;
			setState(1204);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,78,_ctx) ) {
			case 1:
				_localctx = new CopyCreateTableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1126);
				match(CREATE);
				setState(1128);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==TEMPORARY) {
					{
					setState(1127);
					match(TEMPORARY);
					}
				}

				setState(1130);
				match(TABLE);
				setState(1132);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,61,_ctx) ) {
				case 1:
					{
					setState(1131);
					ifNotExists();
					}
					break;
				}
				setState(1134);
				tableName();
				setState(1142);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case LIKE:
					{
					setState(1135);
					match(LIKE);
					setState(1136);
					tableName();
					}
					break;
				case LR_BRACKET:
					{
					setState(1137);
					match(LR_BRACKET);
					setState(1138);
					match(LIKE);
					setState(1139);
					((CopyCreateTableContext)_localctx).parenthesisTable = tableName();
					setState(1140);
					match(RR_BRACKET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				_localctx = new QueryCreateTableContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1144);
				match(CREATE);
				setState(1146);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==TEMPORARY) {
					{
					setState(1145);
					match(TEMPORARY);
					}
				}

				setState(1148);
				match(TABLE);
				setState(1150);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,64,_ctx) ) {
				case 1:
					{
					setState(1149);
					ifNotExists();
					}
					break;
				}
				setState(1152);
				tableName();
				setState(1154);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,65,_ctx) ) {
				case 1:
					{
					setState(1153);
					createDefinitions();
					}
					break;
				}
				setState(1166);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 25)) & ~0x3f) == 0 && ((1L << (_la - 25)) & 72057594038059013L) != 0) || _la==UNION || _la==CHAR || ((((_la - 341)) & ~0x3f) == 0 && ((1L << (_la - 341)) & 4644375904747527L) != 0) || ((((_la - 405)) & ~0x3f) == 0 && ((1L << (_la - 405)) & 4612811918334230547L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 2366149022974977L) != 0) || ((((_la - 602)) & ~0x3f) == 0 && ((1L << (_la - 602)) & 4609173815820289L) != 0) || _la==CHARSET || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE || _la==STRING_LITERAL) {
					{
					setState(1156);
					tableOption();
					setState(1163);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (((((_la - 25)) & ~0x3f) == 0 && ((1L << (_la - 25)) & 72057594038059013L) != 0) || _la==UNION || _la==CHAR || ((((_la - 341)) & ~0x3f) == 0 && ((1L << (_la - 341)) & 4644375904747527L) != 0) || ((((_la - 405)) & ~0x3f) == 0 && ((1L << (_la - 405)) & 4612811918334230547L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 2366149022974977L) != 0) || ((((_la - 602)) & ~0x3f) == 0 && ((1L << (_la - 602)) & 4609173815820289L) != 0) || _la==CHARSET || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE || _la==COMMA || _la==STRING_LITERAL) {
						{
						{
						setState(1158);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(1157);
							match(COMMA);
							}
						}

						setState(1160);
						tableOption();
						}
						}
						setState(1165);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(1169);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PARTITION) {
					{
					setState(1168);
					partitionDefinitions();
					}
				}

				setState(1172);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IGNORE || _la==REPLACE) {
					{
					setState(1171);
					((QueryCreateTableContext)_localctx).keyViolate = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==IGNORE || _la==REPLACE) ) {
						((QueryCreateTableContext)_localctx).keyViolate = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1175);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(1174);
					match(AS);
					}
				}

				setState(1177);
				selectStatement();
				}
				break;
			case 3:
				_localctx = new ColumnCreateTableContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1179);
				match(CREATE);
				setState(1181);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==TEMPORARY) {
					{
					setState(1180);
					match(TEMPORARY);
					}
				}

				setState(1183);
				match(TABLE);
				setState(1185);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,73,_ctx) ) {
				case 1:
					{
					setState(1184);
					ifNotExists();
					}
					break;
				}
				setState(1187);
				tableName();
				setState(1188);
				createDefinitions();
				setState(1199);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,76,_ctx) ) {
				case 1:
					{
					setState(1189);
					tableOption();
					setState(1196);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,75,_ctx);
					while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
						if ( _alt==1 ) {
							{
							{
							setState(1191);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==COMMA) {
								{
								setState(1190);
								match(COMMA);
								}
							}

							setState(1193);
							tableOption();
							}
							} 
						}
						setState(1198);
						_errHandler.sync(this);
						_alt = getInterpreter().adaptivePredict(_input,75,_ctx);
					}
					}
					break;
				}
				setState(1202);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PARTITION) {
					{
					setState(1201);
					partitionDefinitions();
					}
				}

				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateTablespaceInnodbContext extends ParserRuleContext {
		public Token datafile;
		public FileSizeLiteralContext fileBlockSize;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode DATAFILE() { return getToken(MySqlParser.DATAFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode FILE_BLOCK_SIZE() { return getToken(MySqlParser.FILE_BLOCK_SIZE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public CreateTablespaceInnodbContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createTablespaceInnodb; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateTablespaceInnodb(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateTablespaceInnodb(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateTablespaceInnodb(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateTablespaceInnodbContext createTablespaceInnodb() throws RecognitionException {
		CreateTablespaceInnodbContext _localctx = new CreateTablespaceInnodbContext(_ctx, getState());
		enterRule(_localctx, 42, RULE_createTablespaceInnodb);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1206);
			match(CREATE);
			setState(1207);
			match(TABLESPACE);
			setState(1208);
			uid();
			setState(1209);
			match(ADD);
			setState(1210);
			match(DATAFILE);
			setState(1211);
			((CreateTablespaceInnodbContext)_localctx).datafile = match(STRING_LITERAL);
			setState(1215);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FILE_BLOCK_SIZE) {
				{
				setState(1212);
				match(FILE_BLOCK_SIZE);
				setState(1213);
				match(EQUAL_SYMBOL);
				setState(1214);
				((CreateTablespaceInnodbContext)_localctx).fileBlockSize = fileSizeLiteral();
				}
			}

			setState(1222);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENGINE) {
				{
				setState(1217);
				match(ENGINE);
				setState(1219);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1218);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1221);
				engineName();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateTablespaceNdbContext extends ParserRuleContext {
		public Token datafile;
		public FileSizeLiteralContext extentSize;
		public FileSizeLiteralContext initialSize;
		public FileSizeLiteralContext autoextendSize;
		public FileSizeLiteralContext maxSize;
		public Token comment;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode DATAFILE() { return getToken(MySqlParser.DATAFILE, 0); }
		public TerminalNode USE() { return getToken(MySqlParser.USE, 0); }
		public TerminalNode LOGFILE() { return getToken(MySqlParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public TerminalNode EXTENT_SIZE() { return getToken(MySqlParser.EXTENT_SIZE, 0); }
		public TerminalNode INITIAL_SIZE() { return getToken(MySqlParser.INITIAL_SIZE, 0); }
		public TerminalNode AUTOEXTEND_SIZE() { return getToken(MySqlParser.AUTOEXTEND_SIZE, 0); }
		public TerminalNode MAX_SIZE() { return getToken(MySqlParser.MAX_SIZE, 0); }
		public TerminalNode NODEGROUP() { return getToken(MySqlParser.NODEGROUP, 0); }
		public TerminalNode WAIT() { return getToken(MySqlParser.WAIT, 0); }
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public List fileSizeLiteral() {
			return getRuleContexts(FileSizeLiteralContext.class);
		}
		public FileSizeLiteralContext fileSizeLiteral(int i) {
			return getRuleContext(FileSizeLiteralContext.class,i);
		}
		public CreateTablespaceNdbContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createTablespaceNdb; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateTablespaceNdb(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateTablespaceNdb(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateTablespaceNdb(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateTablespaceNdbContext createTablespaceNdb() throws RecognitionException {
		CreateTablespaceNdbContext _localctx = new CreateTablespaceNdbContext(_ctx, getState());
		enterRule(_localctx, 44, RULE_createTablespaceNdb);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1224);
			match(CREATE);
			setState(1225);
			match(TABLESPACE);
			setState(1226);
			uid();
			setState(1227);
			match(ADD);
			setState(1228);
			match(DATAFILE);
			setState(1229);
			((CreateTablespaceNdbContext)_localctx).datafile = match(STRING_LITERAL);
			setState(1230);
			match(USE);
			setState(1231);
			match(LOGFILE);
			setState(1232);
			match(GROUP);
			setState(1233);
			uid();
			setState(1239);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENT_SIZE) {
				{
				setState(1234);
				match(EXTENT_SIZE);
				setState(1236);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1235);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1238);
				((CreateTablespaceNdbContext)_localctx).extentSize = fileSizeLiteral();
				}
			}

			setState(1246);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(1241);
				match(INITIAL_SIZE);
				setState(1243);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1242);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1245);
				((CreateTablespaceNdbContext)_localctx).initialSize = fileSizeLiteral();
				}
			}

			setState(1253);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AUTOEXTEND_SIZE) {
				{
				setState(1248);
				match(AUTOEXTEND_SIZE);
				setState(1250);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1249);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1252);
				((CreateTablespaceNdbContext)_localctx).autoextendSize = fileSizeLiteral();
				}
			}

			setState(1260);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==MAX_SIZE) {
				{
				setState(1255);
				match(MAX_SIZE);
				setState(1257);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1256);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1259);
				((CreateTablespaceNdbContext)_localctx).maxSize = fileSizeLiteral();
				}
			}

			setState(1267);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NODEGROUP) {
				{
				setState(1262);
				match(NODEGROUP);
				setState(1264);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1263);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1266);
				uid();
				}
			}

			setState(1270);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WAIT) {
				{
				setState(1269);
				match(WAIT);
				}
			}

			setState(1277);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(1272);
				match(COMMENT);
				setState(1274);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1273);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1276);
				((CreateTablespaceNdbContext)_localctx).comment = match(STRING_LITERAL);
				}
			}

			setState(1279);
			match(ENGINE);
			setState(1281);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(1280);
				match(EQUAL_SYMBOL);
				}
			}

			setState(1283);
			engineName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateTriggerContext extends ParserRuleContext {
		public FullIdContext thisTrigger;
		public Token triggerTime;
		public Token triggerEvent;
		public Token triggerPlace;
		public FullIdContext otherTrigger;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TRIGGER() { return getToken(MySqlParser.TRIGGER, 0); }
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode EACH() { return getToken(MySqlParser.EACH, 0); }
		public TerminalNode ROW() { return getToken(MySqlParser.ROW, 0); }
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public List fullId() {
			return getRuleContexts(FullIdContext.class);
		}
		public FullIdContext fullId(int i) {
			return getRuleContext(FullIdContext.class,i);
		}
		public TerminalNode BEFORE() { return getToken(MySqlParser.BEFORE, 0); }
		public TerminalNode AFTER() { return getToken(MySqlParser.AFTER, 0); }
		public TerminalNode INSERT() { return getToken(MySqlParser.INSERT, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public TerminalNode DELETE() { return getToken(MySqlParser.DELETE, 0); }
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode FOLLOWS() { return getToken(MySqlParser.FOLLOWS, 0); }
		public TerminalNode PRECEDES() { return getToken(MySqlParser.PRECEDES, 0); }
		public CreateTriggerContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createTrigger; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateTrigger(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateTrigger(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateTrigger(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateTriggerContext createTrigger() throws RecognitionException {
		CreateTriggerContext _localctx = new CreateTriggerContext(_ctx, getState());
		enterRule(_localctx, 46, RULE_createTrigger);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1285);
			match(CREATE);
			setState(1287);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(1286);
				ownerStatement();
				}
			}

			setState(1289);
			match(TRIGGER);
			setState(1290);
			((CreateTriggerContext)_localctx).thisTrigger = fullId();
			setState(1291);
			((CreateTriggerContext)_localctx).triggerTime = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==BEFORE || _la==AFTER) ) {
				((CreateTriggerContext)_localctx).triggerTime = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(1292);
			((CreateTriggerContext)_localctx).triggerEvent = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==DELETE || _la==INSERT || _la==UPDATE) ) {
				((CreateTriggerContext)_localctx).triggerEvent = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(1293);
			match(ON);
			setState(1294);
			tableName();
			setState(1295);
			match(FOR);
			setState(1296);
			match(EACH);
			setState(1297);
			match(ROW);
			setState(1300);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,97,_ctx) ) {
			case 1:
				{
				setState(1298);
				((CreateTriggerContext)_localctx).triggerPlace = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FOLLOWS || _la==PRECEDES) ) {
					((CreateTriggerContext)_localctx).triggerPlace = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1299);
				((CreateTriggerContext)_localctx).otherTrigger = fullId();
				}
				break;
			}
			setState(1302);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WithClauseContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public CommonTableExpressionsContext commonTableExpressions() {
			return getRuleContext(CommonTableExpressionsContext.class,0);
		}
		public TerminalNode RECURSIVE() { return getToken(MySqlParser.RECURSIVE, 0); }
		public WithClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_withClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWithClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWithClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWithClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WithClauseContext withClause() throws RecognitionException {
		WithClauseContext _localctx = new WithClauseContext(_ctx, getState());
		enterRule(_localctx, 48, RULE_withClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1304);
			match(WITH);
			setState(1306);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,98,_ctx) ) {
			case 1:
				{
				setState(1305);
				match(RECURSIVE);
				}
				break;
			}
			setState(1308);
			commonTableExpressions();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CommonTableExpressionsContext extends ParserRuleContext {
		public CteNameContext cteName() {
			return getRuleContext(CteNameContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public DmlStatementContext dmlStatement() {
			return getRuleContext(DmlStatementContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List cteColumnName() {
			return getRuleContexts(CteColumnNameContext.class);
		}
		public CteColumnNameContext cteColumnName(int i) {
			return getRuleContext(CteColumnNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public CommonTableExpressionsContext commonTableExpressions() {
			return getRuleContext(CommonTableExpressionsContext.class,0);
		}
		public CommonTableExpressionsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commonTableExpressions; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCommonTableExpressions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCommonTableExpressions(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCommonTableExpressions(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommonTableExpressionsContext commonTableExpressions() throws RecognitionException {
		CommonTableExpressionsContext _localctx = new CommonTableExpressionsContext(_ctx, getState());
		enterRule(_localctx, 50, RULE_commonTableExpressions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1310);
			cteName();
			setState(1322);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(1311);
				match(LR_BRACKET);
				setState(1312);
				cteColumnName();
				setState(1317);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(1313);
					match(COMMA);
					setState(1314);
					cteColumnName();
					}
					}
					setState(1319);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(1320);
				match(RR_BRACKET);
				}
			}

			setState(1324);
			match(AS);
			setState(1325);
			match(LR_BRACKET);
			setState(1326);
			dmlStatement();
			setState(1327);
			match(RR_BRACKET);
			setState(1330);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,101,_ctx) ) {
			case 1:
				{
				setState(1328);
				match(COMMA);
				setState(1329);
				commonTableExpressions();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CteNameContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public CteNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_cteName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCteName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCteName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCteName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CteNameContext cteName() throws RecognitionException {
		CteNameContext _localctx = new CteNameContext(_ctx, getState());
		enterRule(_localctx, 52, RULE_cteName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1332);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CteColumnNameContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public CteColumnNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_cteColumnName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCteColumnName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCteColumnName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCteColumnName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CteColumnNameContext cteColumnName() throws RecognitionException {
		CteColumnNameContext _localctx = new CteColumnNameContext(_ctx, getState());
		enterRule(_localctx, 54, RULE_cteColumnName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1334);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateViewContext extends ParserRuleContext {
		public Token algType;
		public Token secContext;
		public Token checkOption;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode VIEW() { return getToken(MySqlParser.VIEW, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public OrReplaceContext orReplace() {
			return getRuleContext(OrReplaceContext.class,0);
		}
		public TerminalNode ALGORITHM() { return getToken(MySqlParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode SQL() { return getToken(MySqlParser.SQL, 0); }
		public TerminalNode SECURITY() { return getToken(MySqlParser.SECURITY, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode UNDEFINED() { return getToken(MySqlParser.UNDEFINED, 0); }
		public TerminalNode MERGE() { return getToken(MySqlParser.MERGE, 0); }
		public TerminalNode TEMPTABLE() { return getToken(MySqlParser.TEMPTABLE, 0); }
		public TerminalNode DEFINER() { return getToken(MySqlParser.DEFINER, 0); }
		public TerminalNode INVOKER() { return getToken(MySqlParser.INVOKER, 0); }
		public WithClauseContext withClause() {
			return getRuleContext(WithClauseContext.class,0);
		}
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public TerminalNode OPTION() { return getToken(MySqlParser.OPTION, 0); }
		public TerminalNode CASCADED() { return getToken(MySqlParser.CASCADED, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public CreateViewContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createView; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateView(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateView(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateView(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateViewContext createView() throws RecognitionException {
		CreateViewContext _localctx = new CreateViewContext(_ctx, getState());
		enterRule(_localctx, 56, RULE_createView);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1336);
			match(CREATE);
			setState(1338);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OR) {
				{
				setState(1337);
				orReplace();
				}
			}

			setState(1343);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALGORITHM) {
				{
				setState(1340);
				match(ALGORITHM);
				setState(1341);
				match(EQUAL_SYMBOL);
				setState(1342);
				((CreateViewContext)_localctx).algType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==MERGE || _la==TEMPTABLE || _la==UNDEFINED) ) {
					((CreateViewContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(1346);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(1345);
				ownerStatement();
				}
			}

			setState(1351);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SQL) {
				{
				setState(1348);
				match(SQL);
				setState(1349);
				match(SECURITY);
				setState(1350);
				((CreateViewContext)_localctx).secContext = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFINER || _la==INVOKER) ) {
					((CreateViewContext)_localctx).secContext = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(1353);
			match(VIEW);
			setState(1354);
			fullId();
			setState(1359);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(1355);
				match(LR_BRACKET);
				setState(1356);
				uidList();
				setState(1357);
				match(RR_BRACKET);
				}
			}

			setState(1361);
			match(AS);
			setState(1381);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,111,_ctx) ) {
			case 1:
				{
				setState(1362);
				match(LR_BRACKET);
				setState(1364);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(1363);
					withClause();
					}
				}

				setState(1366);
				selectStatement();
				setState(1367);
				match(RR_BRACKET);
				}
				break;
			case 2:
				{
				setState(1370);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WITH) {
					{
					setState(1369);
					withClause();
					}
				}

				setState(1372);
				selectStatement();
				setState(1379);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,110,_ctx) ) {
				case 1:
					{
					setState(1373);
					match(WITH);
					setState(1375);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==CASCADED || _la==LOCAL) {
						{
						setState(1374);
						((CreateViewContext)_localctx).checkOption = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==CASCADED || _la==LOCAL) ) {
							((CreateViewContext)_localctx).checkOption = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
					}

					setState(1377);
					match(CHECK);
					setState(1378);
					match(OPTION);
					}
					break;
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateDatabaseOptionContext extends ParserRuleContext {
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public List DEFAULT() { return getTokens(MySqlParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MySqlParser.DEFAULT, i);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public TerminalNode ENCRYPTION() { return getToken(MySqlParser.ENCRYPTION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode ONLY() { return getToken(MySqlParser.ONLY, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public CreateDatabaseOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createDatabaseOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateDatabaseOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateDatabaseOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateDatabaseOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateDatabaseOptionContext createDatabaseOption() throws RecognitionException {
		CreateDatabaseOptionContext _localctx = new CreateDatabaseOptionContext(_ctx, getState());
		enterRule(_localctx, 58, RULE_createDatabaseOption);
		int _la;
		try {
			setState(1416);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,120,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1384);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1383);
					match(DEFAULT);
					}
				}

				setState(1386);
				charSet();
				setState(1388);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1387);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1392);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case BINARY:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
					{
					setState(1390);
					charsetName();
					}
					break;
				case DEFAULT:
					{
					setState(1391);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1395);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1394);
					match(DEFAULT);
					}
				}

				setState(1397);
				match(COLLATE);
				setState(1399);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1398);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1401);
				collationName();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1403);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1402);
					match(DEFAULT);
					}
				}

				setState(1405);
				match(ENCRYPTION);
				setState(1407);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1406);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1409);
				match(STRING_LITERAL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(1410);
				match(READ);
				setState(1411);
				match(ONLY);
				setState(1413);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1412);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1415);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CharSetContext extends ParserRuleContext {
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode CHARSET() { return getToken(MySqlParser.CHARSET, 0); }
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public CharSetContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_charSet; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCharSet(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCharSet(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCharSet(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CharSetContext charSet() throws RecognitionException {
		CharSetContext _localctx = new CharSetContext(_ctx, getState());
		enterRule(_localctx, 60, RULE_charSet);
		try {
			setState(1423);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CHARACTER:
				enterOuterAlt(_localctx, 1);
				{
				setState(1418);
				match(CHARACTER);
				setState(1419);
				match(SET);
				}
				break;
			case CHARSET:
				enterOuterAlt(_localctx, 2);
				{
				setState(1420);
				match(CHARSET);
				}
				break;
			case CHAR:
				enterOuterAlt(_localctx, 3);
				{
				setState(1421);
				match(CHAR);
				setState(1422);
				match(SET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CurrentUserExpressionContext extends ParserRuleContext {
		public TerminalNode CURRENT_USER() { return getToken(MySqlParser.CURRENT_USER, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public CurrentUserExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_currentUserExpression; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCurrentUserExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCurrentUserExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCurrentUserExpression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CurrentUserExpressionContext currentUserExpression() throws RecognitionException {
		CurrentUserExpressionContext _localctx = new CurrentUserExpressionContext(_ctx, getState());
		enterRule(_localctx, 62, RULE_currentUserExpression);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1425);
			match(CURRENT_USER);
			setState(1428);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,122,_ctx) ) {
			case 1:
				{
				setState(1426);
				match(LR_BRACKET);
				setState(1427);
				match(RR_BRACKET);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class OwnerStatementContext extends ParserRuleContext {
		public TerminalNode DEFINER() { return getToken(MySqlParser.DEFINER, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public CurrentUserExpressionContext currentUserExpression() {
			return getRuleContext(CurrentUserExpressionContext.class,0);
		}
		public OwnerStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_ownerStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOwnerStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOwnerStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOwnerStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OwnerStatementContext ownerStatement() throws RecognitionException {
		OwnerStatementContext _localctx = new OwnerStatementContext(_ctx, getState());
		enterRule(_localctx, 64, RULE_ownerStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1430);
			match(DEFINER);
			setState(1431);
			match(EQUAL_SYMBOL);
			setState(1434);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,123,_ctx) ) {
			case 1:
				{
				setState(1432);
				userName();
				}
				break;
			case 2:
				{
				setState(1433);
				currentUserExpression();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ScheduleExpressionContext extends ParserRuleContext {
		public ScheduleExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_scheduleExpression; }
	 
		public ScheduleExpressionContext() { }
		public void copyFrom(ScheduleExpressionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PreciseScheduleContext extends ScheduleExpressionContext {
		public TerminalNode AT() { return getToken(MySqlParser.AT, 0); }
		public TimestampValueContext timestampValue() {
			return getRuleContext(TimestampValueContext.class,0);
		}
		public List intervalExpr() {
			return getRuleContexts(IntervalExprContext.class);
		}
		public IntervalExprContext intervalExpr(int i) {
			return getRuleContext(IntervalExprContext.class,i);
		}
		public PreciseScheduleContext(ScheduleExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPreciseSchedule(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPreciseSchedule(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPreciseSchedule(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IntervalScheduleContext extends ScheduleExpressionContext {
		public TimestampValueContext startTimestamp;
		public IntervalExprContext intervalExpr;
		public List startIntervals = new ArrayList();
		public TimestampValueContext endTimestamp;
		public List endIntervals = new ArrayList();
		public TerminalNode EVERY() { return getToken(MySqlParser.EVERY, 0); }
		public IntervalTypeContext intervalType() {
			return getRuleContext(IntervalTypeContext.class,0);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode STARTS() { return getToken(MySqlParser.STARTS, 0); }
		public TerminalNode ENDS() { return getToken(MySqlParser.ENDS, 0); }
		public List timestampValue() {
			return getRuleContexts(TimestampValueContext.class);
		}
		public TimestampValueContext timestampValue(int i) {
			return getRuleContext(TimestampValueContext.class,i);
		}
		public List intervalExpr() {
			return getRuleContexts(IntervalExprContext.class);
		}
		public IntervalExprContext intervalExpr(int i) {
			return getRuleContext(IntervalExprContext.class,i);
		}
		public IntervalScheduleContext(ScheduleExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIntervalSchedule(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIntervalSchedule(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIntervalSchedule(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ScheduleExpressionContext scheduleExpression() throws RecognitionException {
		ScheduleExpressionContext _localctx = new ScheduleExpressionContext(_ctx, getState());
		enterRule(_localctx, 66, RULE_scheduleExpression);
		int _la;
		try {
			setState(1470);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case AT:
				_localctx = new PreciseScheduleContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1436);
				match(AT);
				setState(1437);
				timestampValue();
				setState(1441);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==PLUS) {
					{
					{
					setState(1438);
					intervalExpr();
					}
					}
					setState(1443);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case EVERY:
				_localctx = new IntervalScheduleContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1444);
				match(EVERY);
				setState(1447);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,125,_ctx) ) {
				case 1:
					{
					setState(1445);
					decimalLiteral();
					}
					break;
				case 2:
					{
					setState(1446);
					expression(0);
					}
					break;
				}
				setState(1449);
				intervalType();
				setState(1458);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STARTS) {
					{
					setState(1450);
					match(STARTS);
					setState(1451);
					((IntervalScheduleContext)_localctx).startTimestamp = timestampValue();
					setState(1455);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==PLUS) {
						{
						{
						setState(1452);
						((IntervalScheduleContext)_localctx).intervalExpr = intervalExpr();
						((IntervalScheduleContext)_localctx).startIntervals.add(((IntervalScheduleContext)_localctx).intervalExpr);
						}
						}
						setState(1457);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(1468);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ENDS) {
					{
					setState(1460);
					match(ENDS);
					setState(1461);
					((IntervalScheduleContext)_localctx).endTimestamp = timestampValue();
					setState(1465);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==PLUS) {
						{
						{
						setState(1462);
						((IntervalScheduleContext)_localctx).intervalExpr = intervalExpr();
						((IntervalScheduleContext)_localctx).endIntervals.add(((IntervalScheduleContext)_localctx).intervalExpr);
						}
						}
						setState(1467);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TimestampValueContext extends ParserRuleContext {
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MySqlParser.CURRENT_TIMESTAMP, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TimestampValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_timestampValue; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTimestampValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTimestampValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTimestampValue(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TimestampValueContext timestampValue() throws RecognitionException {
		TimestampValueContext _localctx = new TimestampValueContext(_ctx, getState());
		enterRule(_localctx, 68, RULE_timestampValue);
		try {
			setState(1476);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,131,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1472);
				match(CURRENT_TIMESTAMP);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1473);
				stringLiteral();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1474);
				decimalLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(1475);
				expression(0);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IntervalExprContext extends ParserRuleContext {
		public TerminalNode PLUS() { return getToken(MySqlParser.PLUS, 0); }
		public TerminalNode INTERVAL() { return getToken(MySqlParser.INTERVAL, 0); }
		public IntervalTypeContext intervalType() {
			return getRuleContext(IntervalTypeContext.class,0);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public IntervalExprContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_intervalExpr; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIntervalExpr(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIntervalExpr(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIntervalExpr(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IntervalExprContext intervalExpr() throws RecognitionException {
		IntervalExprContext _localctx = new IntervalExprContext(_ctx, getState());
		enterRule(_localctx, 70, RULE_intervalExpr);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1478);
			match(PLUS);
			setState(1479);
			match(INTERVAL);
			setState(1482);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,132,_ctx) ) {
			case 1:
				{
				setState(1480);
				decimalLiteral();
				}
				break;
			case 2:
				{
				setState(1481);
				expression(0);
				}
				break;
			}
			setState(1484);
			intervalType();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IntervalTypeContext extends ParserRuleContext {
		public IntervalTypeBaseContext intervalTypeBase() {
			return getRuleContext(IntervalTypeBaseContext.class,0);
		}
		public TerminalNode YEAR() { return getToken(MySqlParser.YEAR, 0); }
		public TerminalNode YEAR_MONTH() { return getToken(MySqlParser.YEAR_MONTH, 0); }
		public TerminalNode DAY_HOUR() { return getToken(MySqlParser.DAY_HOUR, 0); }
		public TerminalNode DAY_MINUTE() { return getToken(MySqlParser.DAY_MINUTE, 0); }
		public TerminalNode DAY_SECOND() { return getToken(MySqlParser.DAY_SECOND, 0); }
		public TerminalNode HOUR_MINUTE() { return getToken(MySqlParser.HOUR_MINUTE, 0); }
		public TerminalNode HOUR_SECOND() { return getToken(MySqlParser.HOUR_SECOND, 0); }
		public TerminalNode MINUTE_SECOND() { return getToken(MySqlParser.MINUTE_SECOND, 0); }
		public TerminalNode SECOND_MICROSECOND() { return getToken(MySqlParser.SECOND_MICROSECOND, 0); }
		public TerminalNode MINUTE_MICROSECOND() { return getToken(MySqlParser.MINUTE_MICROSECOND, 0); }
		public TerminalNode HOUR_MICROSECOND() { return getToken(MySqlParser.HOUR_MICROSECOND, 0); }
		public TerminalNode DAY_MICROSECOND() { return getToken(MySqlParser.DAY_MICROSECOND, 0); }
		public IntervalTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_intervalType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIntervalType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIntervalType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIntervalType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IntervalTypeContext intervalType() throws RecognitionException {
		IntervalTypeContext _localctx = new IntervalTypeContext(_ctx, getState());
		enterRule(_localctx, 72, RULE_intervalType);
		try {
			setState(1499);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
				enterOuterAlt(_localctx, 1);
				{
				setState(1486);
				intervalTypeBase();
				}
				break;
			case YEAR:
				enterOuterAlt(_localctx, 2);
				{
				setState(1487);
				match(YEAR);
				}
				break;
			case YEAR_MONTH:
				enterOuterAlt(_localctx, 3);
				{
				setState(1488);
				match(YEAR_MONTH);
				}
				break;
			case DAY_HOUR:
				enterOuterAlt(_localctx, 4);
				{
				setState(1489);
				match(DAY_HOUR);
				}
				break;
			case DAY_MINUTE:
				enterOuterAlt(_localctx, 5);
				{
				setState(1490);
				match(DAY_MINUTE);
				}
				break;
			case DAY_SECOND:
				enterOuterAlt(_localctx, 6);
				{
				setState(1491);
				match(DAY_SECOND);
				}
				break;
			case HOUR_MINUTE:
				enterOuterAlt(_localctx, 7);
				{
				setState(1492);
				match(HOUR_MINUTE);
				}
				break;
			case HOUR_SECOND:
				enterOuterAlt(_localctx, 8);
				{
				setState(1493);
				match(HOUR_SECOND);
				}
				break;
			case MINUTE_SECOND:
				enterOuterAlt(_localctx, 9);
				{
				setState(1494);
				match(MINUTE_SECOND);
				}
				break;
			case SECOND_MICROSECOND:
				enterOuterAlt(_localctx, 10);
				{
				setState(1495);
				match(SECOND_MICROSECOND);
				}
				break;
			case MINUTE_MICROSECOND:
				enterOuterAlt(_localctx, 11);
				{
				setState(1496);
				match(MINUTE_MICROSECOND);
				}
				break;
			case HOUR_MICROSECOND:
				enterOuterAlt(_localctx, 12);
				{
				setState(1497);
				match(HOUR_MICROSECOND);
				}
				break;
			case DAY_MICROSECOND:
				enterOuterAlt(_localctx, 13);
				{
				setState(1498);
				match(DAY_MICROSECOND);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class EnableTypeContext extends ParserRuleContext {
		public TerminalNode ENABLE() { return getToken(MySqlParser.ENABLE, 0); }
		public TerminalNode DISABLE() { return getToken(MySqlParser.DISABLE, 0); }
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public EnableTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_enableType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterEnableType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitEnableType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitEnableType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final EnableTypeContext enableType() throws RecognitionException {
		EnableTypeContext _localctx = new EnableTypeContext(_ctx, getState());
		enterRule(_localctx, 74, RULE_enableType);
		try {
			setState(1506);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,134,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1501);
				match(ENABLE);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1502);
				match(DISABLE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1503);
				match(DISABLE);
				setState(1504);
				match(ON);
				setState(1505);
				match(SLAVE);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexTypeContext extends ParserRuleContext {
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public TerminalNode BTREE() { return getToken(MySqlParser.BTREE, 0); }
		public TerminalNode HASH() { return getToken(MySqlParser.HASH, 0); }
		public IndexTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexTypeContext indexType() throws RecognitionException {
		IndexTypeContext _localctx = new IndexTypeContext(_ctx, getState());
		enterRule(_localctx, 76, RULE_indexType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1508);
			match(USING);
			setState(1509);
			_la = _input.LA(1);
			if ( !(_la==BTREE || _la==HASH) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexOptionContext extends ParserRuleContext {
		public TerminalNode KEY_BLOCK_SIZE() { return getToken(MySqlParser.KEY_BLOCK_SIZE, 0); }
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode PARSER() { return getToken(MySqlParser.PARSER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode VISIBLE() { return getToken(MySqlParser.VISIBLE, 0); }
		public TerminalNode INVISIBLE() { return getToken(MySqlParser.INVISIBLE, 0); }
		public TerminalNode ENGINE_ATTRIBUTE() { return getToken(MySqlParser.ENGINE_ATTRIBUTE, 0); }
		public TerminalNode SECONDARY_ENGINE_ATTRIBUTE() { return getToken(MySqlParser.SECONDARY_ENGINE_ATTRIBUTE, 0); }
		public IndexOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexOptionContext indexOption() throws RecognitionException {
		IndexOptionContext _localctx = new IndexOptionContext(_ctx, getState());
		enterRule(_localctx, 78, RULE_indexOption);
		int _la;
		try {
			setState(1533);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case KEY_BLOCK_SIZE:
				enterOuterAlt(_localctx, 1);
				{
				setState(1511);
				match(KEY_BLOCK_SIZE);
				setState(1513);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1512);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1515);
				fileSizeLiteral();
				}
				break;
			case USING:
				enterOuterAlt(_localctx, 2);
				{
				setState(1516);
				indexType();
				}
				break;
			case WITH:
				enterOuterAlt(_localctx, 3);
				{
				setState(1517);
				match(WITH);
				setState(1518);
				match(PARSER);
				setState(1519);
				uid();
				}
				break;
			case COMMENT:
				enterOuterAlt(_localctx, 4);
				{
				setState(1520);
				match(COMMENT);
				setState(1521);
				match(STRING_LITERAL);
				}
				break;
			case INVISIBLE:
			case VISIBLE:
				enterOuterAlt(_localctx, 5);
				{
				setState(1522);
				_la = _input.LA(1);
				if ( !(_la==INVISIBLE || _la==VISIBLE) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case ENGINE_ATTRIBUTE:
				enterOuterAlt(_localctx, 6);
				{
				setState(1523);
				match(ENGINE_ATTRIBUTE);
				setState(1525);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1524);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1527);
				match(STRING_LITERAL);
				}
				break;
			case SECONDARY_ENGINE_ATTRIBUTE:
				enterOuterAlt(_localctx, 7);
				{
				setState(1528);
				match(SECONDARY_ENGINE_ATTRIBUTE);
				setState(1530);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1529);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1532);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ProcedureParameterContext extends ParserRuleContext {
		public Token direction;
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public TerminalNode OUT() { return getToken(MySqlParser.OUT, 0); }
		public TerminalNode INOUT() { return getToken(MySqlParser.INOUT, 0); }
		public ProcedureParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_procedureParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterProcedureParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitProcedureParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitProcedureParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ProcedureParameterContext procedureParameter() throws RecognitionException {
		ProcedureParameterContext _localctx = new ProcedureParameterContext(_ctx, getState());
		enterRule(_localctx, 80, RULE_procedureParameter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1536);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 80)) & ~0x3f) == 0 && ((1L << (_la - 80)) & 35184372088849L) != 0)) {
				{
				setState(1535);
				((ProcedureParameterContext)_localctx).direction = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 80)) & ~0x3f) == 0 && ((1L << (_la - 80)) & 35184372088849L) != 0)) ) {
					((ProcedureParameterContext)_localctx).direction = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(1538);
			uid();
			setState(1539);
			dataType();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FunctionParameterContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public FunctionParameterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_functionParameter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFunctionParameter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFunctionParameter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFunctionParameter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FunctionParameterContext functionParameter() throws RecognitionException {
		FunctionParameterContext _localctx = new FunctionParameterContext(_ctx, getState());
		enterRule(_localctx, 82, RULE_functionParameter);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1541);
			uid();
			setState(1542);
			dataType();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RoutineOptionContext extends ParserRuleContext {
		public RoutineOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_routineOption; }
	 
		public RoutineOptionContext() { }
		public void copyFrom(RoutineOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RoutineBehaviorContext extends RoutineOptionContext {
		public TerminalNode DETERMINISTIC() { return getToken(MySqlParser.DETERMINISTIC, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public RoutineBehaviorContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoutineBehavior(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoutineBehavior(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoutineBehavior(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RoutineLanguageContext extends RoutineOptionContext {
		public TerminalNode LANGUAGE() { return getToken(MySqlParser.LANGUAGE, 0); }
		public TerminalNode SQL() { return getToken(MySqlParser.SQL, 0); }
		public RoutineLanguageContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoutineLanguage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoutineLanguage(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoutineLanguage(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RoutineCommentContext extends RoutineOptionContext {
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public RoutineCommentContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoutineComment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoutineComment(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoutineComment(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RoutineSecurityContext extends RoutineOptionContext {
		public Token context;
		public TerminalNode SQL() { return getToken(MySqlParser.SQL, 0); }
		public TerminalNode SECURITY() { return getToken(MySqlParser.SECURITY, 0); }
		public TerminalNode DEFINER() { return getToken(MySqlParser.DEFINER, 0); }
		public TerminalNode INVOKER() { return getToken(MySqlParser.INVOKER, 0); }
		public RoutineSecurityContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoutineSecurity(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoutineSecurity(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoutineSecurity(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RoutineDataContext extends RoutineOptionContext {
		public TerminalNode CONTAINS() { return getToken(MySqlParser.CONTAINS, 0); }
		public TerminalNode SQL() { return getToken(MySqlParser.SQL, 0); }
		public TerminalNode NO() { return getToken(MySqlParser.NO, 0); }
		public TerminalNode READS() { return getToken(MySqlParser.READS, 0); }
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode MODIFIES() { return getToken(MySqlParser.MODIFIES, 0); }
		public RoutineDataContext(RoutineOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoutineData(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoutineData(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoutineData(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RoutineOptionContext routineOption() throws RecognitionException {
		RoutineOptionContext _localctx = new RoutineOptionContext(_ctx, getState());
		enterRule(_localctx, 84, RULE_routineOption);
		int _la;
		try {
			setState(1567);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case COMMENT:
				_localctx = new RoutineCommentContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1544);
				match(COMMENT);
				setState(1545);
				match(STRING_LITERAL);
				}
				break;
			case LANGUAGE:
				_localctx = new RoutineLanguageContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1546);
				match(LANGUAGE);
				setState(1547);
				match(SQL);
				}
				break;
			case DETERMINISTIC:
			case NOT:
				_localctx = new RoutineBehaviorContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1549);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(1548);
					match(NOT);
					}
				}

				setState(1551);
				match(DETERMINISTIC);
				}
				break;
			case MODIFIES:
			case READS:
			case CONTAINS:
			case NO:
				_localctx = new RoutineDataContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1562);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case CONTAINS:
					{
					setState(1552);
					match(CONTAINS);
					setState(1553);
					match(SQL);
					}
					break;
				case NO:
					{
					setState(1554);
					match(NO);
					setState(1555);
					match(SQL);
					}
					break;
				case READS:
					{
					setState(1556);
					match(READS);
					setState(1557);
					match(SQL);
					setState(1558);
					match(DATA);
					}
					break;
				case MODIFIES:
					{
					setState(1559);
					match(MODIFIES);
					setState(1560);
					match(SQL);
					setState(1561);
					match(DATA);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case SQL:
				_localctx = new RoutineSecurityContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1564);
				match(SQL);
				setState(1565);
				match(SECURITY);
				setState(1566);
				((RoutineSecurityContext)_localctx).context = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFINER || _la==INVOKER) ) {
					((RoutineSecurityContext)_localctx).context = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ServerOptionContext extends ParserRuleContext {
		public TerminalNode HOST() { return getToken(MySqlParser.HOST, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode SOCKET() { return getToken(MySqlParser.SOCKET, 0); }
		public TerminalNode OWNER() { return getToken(MySqlParser.OWNER, 0); }
		public TerminalNode PORT() { return getToken(MySqlParser.PORT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public ServerOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_serverOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterServerOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitServerOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitServerOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ServerOptionContext serverOption() throws RecognitionException {
		ServerOptionContext _localctx = new ServerOptionContext(_ctx, getState());
		enterRule(_localctx, 86, RULE_serverOption);
		try {
			setState(1583);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case HOST:
				enterOuterAlt(_localctx, 1);
				{
				setState(1569);
				match(HOST);
				setState(1570);
				match(STRING_LITERAL);
				}
				break;
			case DATABASE:
				enterOuterAlt(_localctx, 2);
				{
				setState(1571);
				match(DATABASE);
				setState(1572);
				match(STRING_LITERAL);
				}
				break;
			case USER:
				enterOuterAlt(_localctx, 3);
				{
				setState(1573);
				match(USER);
				setState(1574);
				match(STRING_LITERAL);
				}
				break;
			case PASSWORD:
				enterOuterAlt(_localctx, 4);
				{
				setState(1575);
				match(PASSWORD);
				setState(1576);
				match(STRING_LITERAL);
				}
				break;
			case SOCKET:
				enterOuterAlt(_localctx, 5);
				{
				setState(1577);
				match(SOCKET);
				setState(1578);
				match(STRING_LITERAL);
				}
				break;
			case OWNER:
				enterOuterAlt(_localctx, 6);
				{
				setState(1579);
				match(OWNER);
				setState(1580);
				match(STRING_LITERAL);
				}
				break;
			case PORT:
				enterOuterAlt(_localctx, 7);
				{
				setState(1581);
				match(PORT);
				setState(1582);
				decimalLiteral();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateDefinitionsContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List createDefinition() {
			return getRuleContexts(CreateDefinitionContext.class);
		}
		public CreateDefinitionContext createDefinition(int i) {
			return getRuleContext(CreateDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public CreateDefinitionsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createDefinitions; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateDefinitions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateDefinitions(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateDefinitions(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateDefinitionsContext createDefinitions() throws RecognitionException {
		CreateDefinitionsContext _localctx = new CreateDefinitionsContext(_ctx, getState());
		enterRule(_localctx, 88, RULE_createDefinitions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1585);
			match(LR_BRACKET);
			setState(1586);
			createDefinition();
			setState(1591);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(1587);
				match(COMMA);
				setState(1588);
				createDefinition();
				}
				}
				setState(1593);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(1594);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateDefinitionContext extends ParserRuleContext {
		public CreateDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createDefinition; }
	 
		public CreateDefinitionContext() { }
		public void copyFrom(CreateDefinitionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ColumnDeclarationContext extends CreateDefinitionContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public ColumnDefinitionContext columnDefinition() {
			return getRuleContext(ColumnDefinitionContext.class,0);
		}
		public ColumnDeclarationContext(CreateDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterColumnDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitColumnDeclaration(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitColumnDeclaration(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ConstraintDeclarationContext extends CreateDefinitionContext {
		public TableConstraintContext tableConstraint() {
			return getRuleContext(TableConstraintContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode ENFORCED() { return getToken(MySqlParser.ENFORCED, 0); }
		public ConstraintDeclarationContext(CreateDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterConstraintDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitConstraintDeclaration(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitConstraintDeclaration(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IndexDeclarationContext extends CreateDefinitionContext {
		public IndexColumnDefinitionContext indexColumnDefinition() {
			return getRuleContext(IndexColumnDefinitionContext.class,0);
		}
		public IndexDeclarationContext(CreateDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexDeclaration(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexDeclaration(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateDefinitionContext createDefinition() throws RecognitionException {
		CreateDefinitionContext _localctx = new CreateDefinitionContext(_ctx, getState());
		enterRule(_localctx, 90, RULE_createDefinition);
		int _la;
		try {
			setState(1607);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,147,_ctx) ) {
			case 1:
				_localctx = new ColumnDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1596);
				fullColumnName();
				setState(1597);
				columnDefinition();
				}
				break;
			case 2:
				_localctx = new ConstraintDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1599);
				tableConstraint();
				setState(1601);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(1600);
					match(NOT);
					}
				}

				setState(1604);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ENFORCED) {
					{
					setState(1603);
					match(ENFORCED);
					}
				}

				}
				break;
			case 3:
				_localctx = new IndexDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1606);
				indexColumnDefinition();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ColumnDefinitionContext extends ParserRuleContext {
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public List columnConstraint() {
			return getRuleContexts(ColumnConstraintContext.class);
		}
		public ColumnConstraintContext columnConstraint(int i) {
			return getRuleContext(ColumnConstraintContext.class,i);
		}
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode ENFORCED() { return getToken(MySqlParser.ENFORCED, 0); }
		public ColumnDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_columnDefinition; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterColumnDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitColumnDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitColumnDefinition(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ColumnDefinitionContext columnDefinition() throws RecognitionException {
		ColumnDefinitionContext _localctx = new ColumnDefinitionContext(_ctx, getState());
		enterRule(_localctx, 92, RULE_columnDefinition);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(1609);
			dataType();
			setState(1613);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,148,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(1610);
					columnConstraint();
					}
					} 
				}
				setState(1615);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,148,_ctx);
			}
			setState(1617);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOT) {
				{
				setState(1616);
				match(NOT);
				}
			}

			setState(1620);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENFORCED) {
				{
				setState(1619);
				match(ENFORCED);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ColumnConstraintContext extends ParserRuleContext {
		public ColumnConstraintContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_columnConstraint; }
	 
		public ColumnConstraintContext() { }
		public void copyFrom(ColumnConstraintContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class StorageColumnConstraintContext extends ColumnConstraintContext {
		public Token storageval;
		public TerminalNode STORAGE() { return getToken(MySqlParser.STORAGE, 0); }
		public TerminalNode DISK() { return getToken(MySqlParser.DISK, 0); }
		public TerminalNode MEMORY() { return getToken(MySqlParser.MEMORY, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public StorageColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStorageColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStorageColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStorageColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class VisibilityColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode VISIBLE() { return getToken(MySqlParser.VISIBLE, 0); }
		public VisibilityColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterVisibilityColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitVisibilityColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitVisibilityColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AutoIncrementColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode AUTO_INCREMENT() { return getToken(MySqlParser.AUTO_INCREMENT, 0); }
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public CurrentTimestampContext currentTimestamp() {
			return getRuleContext(CurrentTimestampContext.class,0);
		}
		public AutoIncrementColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAutoIncrementColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAutoIncrementColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAutoIncrementColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CommentColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public CommentColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCommentColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCommentColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCommentColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UniqueKeyColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode UNIQUE() { return getToken(MySqlParser.UNIQUE, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public UniqueKeyColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUniqueKeyColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUniqueKeyColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUniqueKeyColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SerialDefaultColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode SERIAL() { return getToken(MySqlParser.SERIAL, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public SerialDefaultColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSerialDefaultColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSerialDefaultColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSerialDefaultColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class GeneratedColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode GENERATED() { return getToken(MySqlParser.GENERATED, 0); }
		public TerminalNode ALWAYS() { return getToken(MySqlParser.ALWAYS, 0); }
		public TerminalNode VIRTUAL() { return getToken(MySqlParser.VIRTUAL, 0); }
		public TerminalNode STORED() { return getToken(MySqlParser.STORED, 0); }
		public GeneratedColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGeneratedColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGeneratedColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGeneratedColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class FormatColumnConstraintContext extends ColumnConstraintContext {
		public Token colformat;
		public TerminalNode COLUMN_FORMAT() { return getToken(MySqlParser.COLUMN_FORMAT, 0); }
		public TerminalNode FIXED() { return getToken(MySqlParser.FIXED, 0); }
		public TerminalNode DYNAMIC() { return getToken(MySqlParser.DYNAMIC, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public FormatColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFormatColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFormatColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFormatColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CollateColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public CollateColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCollateColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCollateColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCollateColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PrimaryKeyColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public TerminalNode PRIMARY() { return getToken(MySqlParser.PRIMARY, 0); }
		public PrimaryKeyColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPrimaryKeyColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPrimaryKeyColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPrimaryKeyColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CheckColumnConstraintContext extends ColumnConstraintContext {
		public UidContext name;
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public CheckColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCheckColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCheckColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCheckColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NullColumnConstraintContext extends ColumnConstraintContext {
		public NullNotnullContext nullNotnull() {
			return getRuleContext(NullNotnullContext.class,0);
		}
		public NullColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNullColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNullColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNullColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DefaultColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public DefaultValueContext defaultValue() {
			return getRuleContext(DefaultValueContext.class,0);
		}
		public DefaultColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefaultColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefaultColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefaultColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ReferenceColumnConstraintContext extends ColumnConstraintContext {
		public ReferenceDefinitionContext referenceDefinition() {
			return getRuleContext(ReferenceDefinitionContext.class,0);
		}
		public ReferenceColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReferenceColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReferenceColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReferenceColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class InvisibilityColumnConstraintContext extends ColumnConstraintContext {
		public TerminalNode INVISIBLE() { return getToken(MySqlParser.INVISIBLE, 0); }
		public InvisibilityColumnConstraintContext(ColumnConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterInvisibilityColumnConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitInvisibilityColumnConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitInvisibilityColumnConstraint(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ColumnConstraintContext columnConstraint() throws RecognitionException {
		ColumnConstraintContext _localctx = new ColumnConstraintContext(_ctx, getState());
		enterRule(_localctx, 94, RULE_columnConstraint);
		int _la;
		try {
			setState(1675);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NOT:
			case NULL_LITERAL:
			case NULL_SPEC_LITERAL:
				_localctx = new NullColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1622);
				nullNotnull();
				}
				break;
			case DEFAULT:
				_localctx = new DefaultColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1623);
				match(DEFAULT);
				setState(1624);
				defaultValue();
				}
				break;
			case VISIBLE:
				_localctx = new VisibilityColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1625);
				match(VISIBLE);
				}
				break;
			case INVISIBLE:
				_localctx = new InvisibilityColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1626);
				match(INVISIBLE);
				}
				break;
			case ON:
			case AUTO_INCREMENT:
				_localctx = new AutoIncrementColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1631);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case AUTO_INCREMENT:
					{
					setState(1627);
					match(AUTO_INCREMENT);
					}
					break;
				case ON:
					{
					setState(1628);
					match(ON);
					setState(1629);
					match(UPDATE);
					setState(1630);
					currentTimestamp();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case KEY:
			case PRIMARY:
				_localctx = new PrimaryKeyColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1634);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRIMARY) {
					{
					setState(1633);
					match(PRIMARY);
					}
				}

				setState(1636);
				match(KEY);
				}
				break;
			case UNIQUE:
				_localctx = new UniqueKeyColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1637);
				match(UNIQUE);
				setState(1639);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,153,_ctx) ) {
				case 1:
					{
					setState(1638);
					match(KEY);
					}
					break;
				}
				}
				break;
			case COMMENT:
				_localctx = new CommentColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1641);
				match(COMMENT);
				setState(1642);
				match(STRING_LITERAL);
				}
				break;
			case COLUMN_FORMAT:
				_localctx = new FormatColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(1643);
				match(COLUMN_FORMAT);
				setState(1644);
				((FormatColumnConstraintContext)_localctx).colformat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==DYNAMIC || _la==FIXED) ) {
					((FormatColumnConstraintContext)_localctx).colformat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case STORAGE:
				_localctx = new StorageColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(1645);
				match(STORAGE);
				setState(1646);
				((StorageColumnConstraintContext)_localctx).storageval = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==DISK || _la==MEMORY) ) {
					((StorageColumnConstraintContext)_localctx).storageval = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case REFERENCES:
				_localctx = new ReferenceColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(1647);
				referenceDefinition();
				}
				break;
			case COLLATE:
				_localctx = new CollateColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(1648);
				match(COLLATE);
				setState(1649);
				collationName();
				}
				break;
			case AS:
			case GENERATED:
				_localctx = new GeneratedColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(1652);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==GENERATED) {
					{
					setState(1650);
					match(GENERATED);
					setState(1651);
					match(ALWAYS);
					}
				}

				setState(1654);
				match(AS);
				setState(1655);
				match(LR_BRACKET);
				setState(1656);
				expression(0);
				setState(1657);
				match(RR_BRACKET);
				setState(1659);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STORED || _la==VIRTUAL) {
					{
					setState(1658);
					_la = _input.LA(1);
					if ( !(_la==STORED || _la==VIRTUAL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				}
				break;
			case SERIAL:
				_localctx = new SerialDefaultColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(1661);
				match(SERIAL);
				setState(1662);
				match(DEFAULT);
				setState(1663);
				match(VALUE);
				}
				break;
			case CHECK:
			case CONSTRAINT:
				_localctx = new CheckColumnConstraintContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(1668);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(1664);
					match(CONSTRAINT);
					setState(1666);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(1665);
						((CheckColumnConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(1670);
				match(CHECK);
				setState(1671);
				match(LR_BRACKET);
				setState(1672);
				expression(0);
				setState(1673);
				match(RR_BRACKET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableConstraintContext extends ParserRuleContext {
		public TableConstraintContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableConstraint; }
	 
		public TableConstraintContext() { }
		public void copyFrom(TableConstraintContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UniqueKeyTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public Token indexFormat;
		public UidContext index;
		public TerminalNode UNIQUE() { return getToken(MySqlParser.UNIQUE, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public UniqueKeyTableConstraintContext(TableConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUniqueKeyTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUniqueKeyTableConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUniqueKeyTableConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CheckTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public CheckTableConstraintContext(TableConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCheckTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCheckTableConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCheckTableConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PrimaryKeyTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public UidContext index;
		public TerminalNode PRIMARY() { return getToken(MySqlParser.PRIMARY, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public PrimaryKeyTableConstraintContext(TableConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPrimaryKeyTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPrimaryKeyTableConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPrimaryKeyTableConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ForeignKeyTableConstraintContext extends TableConstraintContext {
		public UidContext name;
		public UidContext index;
		public TerminalNode FOREIGN() { return getToken(MySqlParser.FOREIGN, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public ReferenceDefinitionContext referenceDefinition() {
			return getRuleContext(ReferenceDefinitionContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public ForeignKeyTableConstraintContext(TableConstraintContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterForeignKeyTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitForeignKeyTableConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitForeignKeyTableConstraint(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableConstraintContext tableConstraint() throws RecognitionException {
		TableConstraintContext _localctx = new TableConstraintContext(_ctx, getState());
		enterRule(_localctx, 96, RULE_tableConstraint);
		int _la;
		try {
			setState(1746);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,175,_ctx) ) {
			case 1:
				_localctx = new PrimaryKeyTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1681);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(1677);
					match(CONSTRAINT);
					setState(1679);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,159,_ctx) ) {
					case 1:
						{
						setState(1678);
						((PrimaryKeyTableConstraintContext)_localctx).name = uid();
						}
						break;
					}
					}
				}

				setState(1683);
				match(PRIMARY);
				setState(1684);
				match(KEY);
				setState(1686);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(1685);
					((PrimaryKeyTableConstraintContext)_localctx).index = uid();
					}
				}

				setState(1689);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(1688);
					indexType();
					}
				}

				setState(1691);
				indexColumnNames();
				setState(1695);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==USING || _la==WITH || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
					{
					{
					setState(1692);
					indexOption();
					}
					}
					setState(1697);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new UniqueKeyTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1702);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(1698);
					match(CONSTRAINT);
					setState(1700);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(1699);
						((UniqueKeyTableConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(1704);
				match(UNIQUE);
				setState(1706);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(1705);
					((UniqueKeyTableConstraintContext)_localctx).indexFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==INDEX || _la==KEY) ) {
						((UniqueKeyTableConstraintContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1709);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(1708);
					((UniqueKeyTableConstraintContext)_localctx).index = uid();
					}
				}

				setState(1712);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(1711);
					indexType();
					}
				}

				setState(1714);
				indexColumnNames();
				setState(1718);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==USING || _la==WITH || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
					{
					{
					setState(1715);
					indexOption();
					}
					}
					setState(1720);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 3:
				_localctx = new ForeignKeyTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1725);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(1721);
					match(CONSTRAINT);
					setState(1723);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(1722);
						((ForeignKeyTableConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(1727);
				match(FOREIGN);
				setState(1728);
				match(KEY);
				setState(1730);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(1729);
					((ForeignKeyTableConstraintContext)_localctx).index = uid();
					}
				}

				setState(1732);
				indexColumnNames();
				setState(1733);
				referenceDefinition();
				}
				break;
			case 4:
				_localctx = new CheckTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1739);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(1735);
					match(CONSTRAINT);
					setState(1737);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(1736);
						((CheckTableConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(1741);
				match(CHECK);
				setState(1742);
				match(LR_BRACKET);
				setState(1743);
				expression(0);
				setState(1744);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReferenceDefinitionContext extends ParserRuleContext {
		public Token matchType;
		public TerminalNode REFERENCES() { return getToken(MySqlParser.REFERENCES, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode MATCH() { return getToken(MySqlParser.MATCH, 0); }
		public ReferenceActionContext referenceAction() {
			return getRuleContext(ReferenceActionContext.class,0);
		}
		public TerminalNode FULL() { return getToken(MySqlParser.FULL, 0); }
		public TerminalNode PARTIAL() { return getToken(MySqlParser.PARTIAL, 0); }
		public TerminalNode SIMPLE() { return getToken(MySqlParser.SIMPLE, 0); }
		public ReferenceDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_referenceDefinition; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReferenceDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReferenceDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReferenceDefinition(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReferenceDefinitionContext referenceDefinition() throws RecognitionException {
		ReferenceDefinitionContext _localctx = new ReferenceDefinitionContext(_ctx, getState());
		enterRule(_localctx, 98, RULE_referenceDefinition);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(1748);
			match(REFERENCES);
			setState(1749);
			tableName();
			setState(1751);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,176,_ctx) ) {
			case 1:
				{
				setState(1750);
				indexColumnNames();
				}
				break;
			}
			setState(1755);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==MATCH) {
				{
				setState(1753);
				match(MATCH);
				setState(1754);
				((ReferenceDefinitionContext)_localctx).matchType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FULL || _la==PARTIAL || _la==SIMPLE) ) {
					((ReferenceDefinitionContext)_localctx).matchType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(1758);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,178,_ctx) ) {
			case 1:
				{
				setState(1757);
				referenceAction();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReferenceActionContext extends ParserRuleContext {
		public ReferenceControlTypeContext onDelete;
		public ReferenceControlTypeContext onUpdate;
		public List ON() { return getTokens(MySqlParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MySqlParser.ON, i);
		}
		public TerminalNode DELETE() { return getToken(MySqlParser.DELETE, 0); }
		public List referenceControlType() {
			return getRuleContexts(ReferenceControlTypeContext.class);
		}
		public ReferenceControlTypeContext referenceControlType(int i) {
			return getRuleContext(ReferenceControlTypeContext.class,i);
		}
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public ReferenceActionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_referenceAction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReferenceAction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReferenceAction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReferenceAction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReferenceActionContext referenceAction() throws RecognitionException {
		ReferenceActionContext _localctx = new ReferenceActionContext(_ctx, getState());
		enterRule(_localctx, 100, RULE_referenceAction);
		try {
			setState(1776);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,181,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1760);
				match(ON);
				setState(1761);
				match(DELETE);
				setState(1762);
				((ReferenceActionContext)_localctx).onDelete = referenceControlType();
				setState(1766);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,179,_ctx) ) {
				case 1:
					{
					setState(1763);
					match(ON);
					setState(1764);
					match(UPDATE);
					setState(1765);
					((ReferenceActionContext)_localctx).onUpdate = referenceControlType();
					}
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1768);
				match(ON);
				setState(1769);
				match(UPDATE);
				setState(1770);
				((ReferenceActionContext)_localctx).onUpdate = referenceControlType();
				setState(1774);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,180,_ctx) ) {
				case 1:
					{
					setState(1771);
					match(ON);
					setState(1772);
					match(DELETE);
					setState(1773);
					((ReferenceActionContext)_localctx).onDelete = referenceControlType();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReferenceControlTypeContext extends ParserRuleContext {
		public TerminalNode RESTRICT() { return getToken(MySqlParser.RESTRICT, 0); }
		public TerminalNode CASCADE() { return getToken(MySqlParser.CASCADE, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode NULL_LITERAL() { return getToken(MySqlParser.NULL_LITERAL, 0); }
		public TerminalNode NO() { return getToken(MySqlParser.NO, 0); }
		public TerminalNode ACTION() { return getToken(MySqlParser.ACTION, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public ReferenceControlTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_referenceControlType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReferenceControlType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReferenceControlType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReferenceControlType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReferenceControlTypeContext referenceControlType() throws RecognitionException {
		ReferenceControlTypeContext _localctx = new ReferenceControlTypeContext(_ctx, getState());
		enterRule(_localctx, 102, RULE_referenceControlType);
		try {
			setState(1786);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,182,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(1778);
				match(RESTRICT);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(1779);
				match(CASCADE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(1780);
				match(SET);
				setState(1781);
				match(NULL_LITERAL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(1782);
				match(NO);
				setState(1783);
				match(ACTION);
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(1784);
				match(SET);
				setState(1785);
				match(DEFAULT);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexColumnDefinitionContext extends ParserRuleContext {
		public IndexColumnDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexColumnDefinition; }
	 
		public IndexColumnDefinitionContext() { }
		public void copyFrom(IndexColumnDefinitionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SpecialIndexDeclarationContext extends IndexColumnDefinitionContext {
		public Token indexFormat;
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode FULLTEXT() { return getToken(MySqlParser.FULLTEXT, 0); }
		public TerminalNode SPATIAL() { return getToken(MySqlParser.SPATIAL, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public SpecialIndexDeclarationContext(IndexColumnDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSpecialIndexDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSpecialIndexDeclaration(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSpecialIndexDeclaration(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SimpleIndexDeclarationContext extends IndexColumnDefinitionContext {
		public Token indexFormat;
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public SimpleIndexDeclarationContext(IndexColumnDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleIndexDeclaration(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleIndexDeclaration(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleIndexDeclaration(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexColumnDefinitionContext indexColumnDefinition() throws RecognitionException {
		IndexColumnDefinitionContext _localctx = new IndexColumnDefinitionContext(_ctx, getState());
		enterRule(_localctx, 104, RULE_indexColumnDefinition);
		int _la;
		try {
			setState(1816);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case INDEX:
			case KEY:
				_localctx = new SimpleIndexDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1788);
				((SimpleIndexDeclarationContext)_localctx).indexFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==INDEX || _la==KEY) ) {
					((SimpleIndexDeclarationContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1790);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(1789);
					uid();
					}
				}

				setState(1793);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(1792);
					indexType();
					}
				}

				setState(1795);
				indexColumnNames();
				setState(1799);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==USING || _la==WITH || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
					{
					{
					setState(1796);
					indexOption();
					}
					}
					setState(1801);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case FULLTEXT:
			case SPATIAL:
				_localctx = new SpecialIndexDeclarationContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1802);
				_la = _input.LA(1);
				if ( !(_la==FULLTEXT || _la==SPATIAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1804);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(1803);
					((SpecialIndexDeclarationContext)_localctx).indexFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==INDEX || _la==KEY) ) {
						((SpecialIndexDeclarationContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(1807);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(1806);
					uid();
					}
				}

				setState(1809);
				indexColumnNames();
				setState(1813);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==USING || _la==WITH || _la==COMMENT || _la==INVISIBLE || _la==KEY_BLOCK_SIZE || _la==VISIBLE || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE) {
					{
					{
					setState(1810);
					indexOption();
					}
					}
					setState(1815);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionContext extends ParserRuleContext {
		public TableOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableOption; }
	 
		public TableOptionContext() { }
		public void copyFrom(TableOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionEngineContext extends TableOptionContext {
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TableOptionEngineContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionEngine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionEngine(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionEngine(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionMaxRowsContext extends TableOptionContext {
		public TerminalNode MAX_ROWS() { return getToken(MySqlParser.MAX_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionMaxRowsContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionMaxRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionMaxRows(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionMaxRows(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionCollateContext extends TableOptionContext {
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionCollateContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionCollate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionCollate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionCollate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionPersistentContext extends TableOptionContext {
		public Token extBoolValue;
		public TerminalNode STATS_PERSISTENT() { return getToken(MySqlParser.STATS_PERSISTENT, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionPersistentContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionPersistent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionPersistent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionPersistent(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionTablespaceContext extends TableOptionContext {
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TablespaceStorageContext tablespaceStorage() {
			return getRuleContext(TablespaceStorageContext.class,0);
		}
		public TableOptionTablespaceContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionTablespace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionTablespace(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionAutoextendSizeContext extends TableOptionContext {
		public TerminalNode AUTOEXTEND_SIZE() { return getToken(MySqlParser.AUTOEXTEND_SIZE, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionAutoextendSizeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionAutoextendSize(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionAutoextendSize(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionAutoextendSize(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionPageCompressedContext extends TableOptionContext {
		public TerminalNode PAGE_COMPRESSED() { return getToken(MySqlParser.PAGE_COMPRESSED, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionPageCompressedContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionPageCompressed(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionPageCompressed(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionPageCompressed(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionStartTransactionContext extends TableOptionContext {
		public TerminalNode START() { return getToken(MySqlParser.START, 0); }
		public TerminalNode TRANSACTION() { return getToken(MySqlParser.TRANSACTION, 0); }
		public TableOptionStartTransactionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionStartTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionStartTransaction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionStartTransaction(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionPackKeysContext extends TableOptionContext {
		public Token extBoolValue;
		public TerminalNode PACK_KEYS() { return getToken(MySqlParser.PACK_KEYS, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionPackKeysContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionPackKeys(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionPackKeys(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionPackKeys(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionPasswordContext extends TableOptionContext {
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionPasswordContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionPassword(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionPassword(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionPassword(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionUnionContext extends TableOptionContext {
		public TerminalNode UNION() { return getToken(MySqlParser.UNION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionUnionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionUnion(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionUnion(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionUnion(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionSamplePageContext extends TableOptionContext {
		public TerminalNode STATS_SAMPLE_PAGES() { return getToken(MySqlParser.STATS_SAMPLE_PAGES, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionSamplePageContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionSamplePage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionSamplePage(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionSamplePage(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionCharsetContext extends TableOptionContext {
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public List DEFAULT() { return getTokens(MySqlParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MySqlParser.DEFAULT, i);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionCharsetContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionCharset(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionCharset(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionIndexDirectoryContext extends TableOptionContext {
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode DIRECTORY() { return getToken(MySqlParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionIndexDirectoryContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionIndexDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionIndexDirectory(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionIndexDirectory(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionTableTypeContext extends TableOptionContext {
		public TerminalNode TABLE_TYPE() { return getToken(MySqlParser.TABLE_TYPE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableTypeContext tableType() {
			return getRuleContext(TableTypeContext.class,0);
		}
		public TableOptionTableTypeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionTableType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionTableType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionTableType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionKeyBlockSizeContext extends TableOptionContext {
		public TerminalNode KEY_BLOCK_SIZE() { return getToken(MySqlParser.KEY_BLOCK_SIZE, 0); }
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionKeyBlockSizeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionKeyBlockSize(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionKeyBlockSize(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionKeyBlockSize(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionEncryptionContext extends TableOptionContext {
		public TerminalNode ENCRYPTION() { return getToken(MySqlParser.ENCRYPTION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionEncryptionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionEncryption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionEncryption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionEncryption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionDataDirectoryContext extends TableOptionContext {
		public TerminalNode DIRECTORY() { return getToken(MySqlParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionDataDirectoryContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionDataDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionDataDirectory(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionDataDirectory(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionRecalculationContext extends TableOptionContext {
		public Token extBoolValue;
		public TerminalNode STATS_AUTO_RECALC() { return getToken(MySqlParser.STATS_AUTO_RECALC, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionRecalculationContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionRecalculation(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionRecalculation(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionRecalculation(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionAutoIncrementContext extends TableOptionContext {
		public TerminalNode AUTO_INCREMENT() { return getToken(MySqlParser.AUTO_INCREMENT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionAutoIncrementContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionAutoIncrement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionAutoIncrement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionAutoIncrement(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionEncryptionKeyIdContext extends TableOptionContext {
		public TerminalNode ENCRYPTION_KEY_ID() { return getToken(MySqlParser.ENCRYPTION_KEY_ID, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionEncryptionKeyIdContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionEncryptionKeyId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionEncryptionKeyId(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionEncryptionKeyId(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionChecksumContext extends TableOptionContext {
		public Token boolValue;
		public TerminalNode CHECKSUM() { return getToken(MySqlParser.CHECKSUM, 0); }
		public TerminalNode PAGE_CHECKSUM() { return getToken(MySqlParser.PAGE_CHECKSUM, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionChecksumContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionChecksum(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionChecksum(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionChecksum(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionDelayContext extends TableOptionContext {
		public Token boolValue;
		public TerminalNode DELAY_KEY_WRITE() { return getToken(MySqlParser.DELAY_KEY_WRITE, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionDelayContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionDelay(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionDelay(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionDelay(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionConnectionContext extends TableOptionContext {
		public TerminalNode CONNECTION() { return getToken(MySqlParser.CONNECTION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionConnectionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionConnection(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionConnection(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionConnection(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionTransactionalContext extends TableOptionContext {
		public TerminalNode TRANSACTIONAL() { return getToken(MySqlParser.TRANSACTIONAL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionTransactionalContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionTransactional(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionTransactional(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionTransactional(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionPageCompressionLevelContext extends TableOptionContext {
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode PAGE_COMPRESSION_LEVEL() { return getToken(MySqlParser.PAGE_COMPRESSION_LEVEL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionPageCompressionLevelContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionPageCompressionLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionPageCompressionLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionPageCompressionLevel(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionSecondaryEngineAttributeContext extends TableOptionContext {
		public TerminalNode SECONDARY_ENGINE_ATTRIBUTE() { return getToken(MySqlParser.SECONDARY_ENGINE_ATTRIBUTE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionSecondaryEngineAttributeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionSecondaryEngineAttribute(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionSecondaryEngineAttribute(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionSecondaryEngineAttribute(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionCommentContext extends TableOptionContext {
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionCommentContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionComment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionComment(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionComment(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionAverageContext extends TableOptionContext {
		public TerminalNode AVG_ROW_LENGTH() { return getToken(MySqlParser.AVG_ROW_LENGTH, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionAverageContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionAverage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionAverage(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionAverage(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionRowFormatContext extends TableOptionContext {
		public Token rowFormat;
		public TerminalNode ROW_FORMAT() { return getToken(MySqlParser.ROW_FORMAT, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode DYNAMIC() { return getToken(MySqlParser.DYNAMIC, 0); }
		public TerminalNode FIXED() { return getToken(MySqlParser.FIXED, 0); }
		public TerminalNode COMPRESSED() { return getToken(MySqlParser.COMPRESSED, 0); }
		public TerminalNode REDUNDANT() { return getToken(MySqlParser.REDUNDANT, 0); }
		public TerminalNode COMPACT() { return getToken(MySqlParser.COMPACT, 0); }
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionRowFormatContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionRowFormat(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionRowFormat(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionRowFormat(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionCompressionContext extends TableOptionContext {
		public TerminalNode COMPRESSION() { return getToken(MySqlParser.COMPRESSION, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionCompressionContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionCompression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionCompression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionCompression(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionInsertMethodContext extends TableOptionContext {
		public Token insertMethod;
		public TerminalNode INSERT_METHOD() { return getToken(MySqlParser.INSERT_METHOD, 0); }
		public TerminalNode NO() { return getToken(MySqlParser.NO, 0); }
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode LAST() { return getToken(MySqlParser.LAST, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionInsertMethodContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionInsertMethod(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionInsertMethod(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionInsertMethod(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionEngineAttributeContext extends TableOptionContext {
		public TerminalNode ENGINE_ATTRIBUTE() { return getToken(MySqlParser.ENGINE_ATTRIBUTE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionEngineAttributeContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionEngineAttribute(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionEngineAttribute(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionEngineAttribute(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableOptionMinRowsContext extends TableOptionContext {
		public TerminalNode MIN_ROWS() { return getToken(MySqlParser.MIN_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TableOptionMinRowsContext(TableOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableOptionMinRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableOptionMinRows(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableOptionMinRows(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableOptionContext tableOption() throws RecognitionException {
		TableOptionContext _localctx = new TableOptionContext(_ctx, getState());
		enterRule(_localctx, 106, RULE_tableOption);
		int _la;
		try {
			setState(2003);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,227,_ctx) ) {
			case 1:
				_localctx = new TableOptionEngineContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(1818);
				match(ENGINE);
				setState(1820);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1819);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1823);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,191,_ctx) ) {
				case 1:
					{
					setState(1822);
					engineName();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new TableOptionEngineAttributeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(1825);
				match(ENGINE_ATTRIBUTE);
				setState(1827);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1826);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1829);
				match(STRING_LITERAL);
				}
				break;
			case 3:
				_localctx = new TableOptionAutoextendSizeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(1830);
				match(AUTOEXTEND_SIZE);
				setState(1832);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1831);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1834);
				decimalLiteral();
				}
				break;
			case 4:
				_localctx = new TableOptionAutoIncrementContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(1835);
				match(AUTO_INCREMENT);
				setState(1837);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1836);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1839);
				decimalLiteral();
				}
				break;
			case 5:
				_localctx = new TableOptionAverageContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(1840);
				match(AVG_ROW_LENGTH);
				setState(1842);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1841);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1844);
				decimalLiteral();
				}
				break;
			case 6:
				_localctx = new TableOptionCharsetContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(1846);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1845);
					match(DEFAULT);
					}
				}

				setState(1848);
				charSet();
				setState(1850);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1849);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1854);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case BINARY:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
					{
					setState(1852);
					charsetName();
					}
					break;
				case DEFAULT:
					{
					setState(1853);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 7:
				_localctx = new TableOptionChecksumContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(1856);
				_la = _input.LA(1);
				if ( !(_la==CHECKSUM || _la==PAGE_CHECKSUM) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1858);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1857);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1860);
				((TableOptionChecksumContext)_localctx).boolValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
					((TableOptionChecksumContext)_localctx).boolValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 8:
				_localctx = new TableOptionCollateContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(1862);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(1861);
					match(DEFAULT);
					}
				}

				setState(1864);
				match(COLLATE);
				setState(1866);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1865);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1868);
				collationName();
				}
				break;
			case 9:
				_localctx = new TableOptionCommentContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(1869);
				match(COMMENT);
				setState(1871);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1870);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1873);
				match(STRING_LITERAL);
				}
				break;
			case 10:
				_localctx = new TableOptionCompressionContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(1874);
				match(COMPRESSION);
				setState(1876);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1875);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1878);
				_la = _input.LA(1);
				if ( !(_la==STRING_LITERAL || _la==ID) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 11:
				_localctx = new TableOptionConnectionContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(1879);
				match(CONNECTION);
				setState(1881);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1880);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1883);
				match(STRING_LITERAL);
				}
				break;
			case 12:
				_localctx = new TableOptionDataDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(1884);
				_la = _input.LA(1);
				if ( !(_la==INDEX || _la==DATA) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1885);
				match(DIRECTORY);
				setState(1887);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1886);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1889);
				match(STRING_LITERAL);
				}
				break;
			case 13:
				_localctx = new TableOptionDelayContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(1890);
				match(DELAY_KEY_WRITE);
				setState(1892);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1891);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1894);
				((TableOptionDelayContext)_localctx).boolValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
					((TableOptionDelayContext)_localctx).boolValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 14:
				_localctx = new TableOptionEncryptionContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(1895);
				match(ENCRYPTION);
				setState(1897);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1896);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1899);
				match(STRING_LITERAL);
				}
				break;
			case 15:
				_localctx = new TableOptionPageCompressedContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(1900);
				_la = _input.LA(1);
				if ( !(_la==PAGE_COMPRESSED || _la==STRING_LITERAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1902);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1901);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1904);
				_la = _input.LA(1);
				if ( !(_la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 16:
				_localctx = new TableOptionPageCompressionLevelContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(1905);
				_la = _input.LA(1);
				if ( !(_la==PAGE_COMPRESSION_LEVEL || _la==STRING_LITERAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(1907);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1906);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1909);
				decimalLiteral();
				}
				break;
			case 17:
				_localctx = new TableOptionEncryptionKeyIdContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(1910);
				match(ENCRYPTION_KEY_ID);
				setState(1912);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1911);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1914);
				decimalLiteral();
				}
				break;
			case 18:
				_localctx = new TableOptionIndexDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 18);
				{
				setState(1915);
				match(INDEX);
				setState(1916);
				match(DIRECTORY);
				setState(1918);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1917);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1920);
				match(STRING_LITERAL);
				}
				break;
			case 19:
				_localctx = new TableOptionInsertMethodContext(_localctx);
				enterOuterAlt(_localctx, 19);
				{
				setState(1921);
				match(INSERT_METHOD);
				setState(1923);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1922);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1925);
				((TableOptionInsertMethodContext)_localctx).insertMethod = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FIRST || _la==LAST || _la==NO) ) {
					((TableOptionInsertMethodContext)_localctx).insertMethod = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 20:
				_localctx = new TableOptionKeyBlockSizeContext(_localctx);
				enterOuterAlt(_localctx, 20);
				{
				setState(1926);
				match(KEY_BLOCK_SIZE);
				setState(1928);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1927);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1930);
				fileSizeLiteral();
				}
				break;
			case 21:
				_localctx = new TableOptionMaxRowsContext(_localctx);
				enterOuterAlt(_localctx, 21);
				{
				setState(1931);
				match(MAX_ROWS);
				setState(1933);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1932);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1935);
				decimalLiteral();
				}
				break;
			case 22:
				_localctx = new TableOptionMinRowsContext(_localctx);
				enterOuterAlt(_localctx, 22);
				{
				setState(1936);
				match(MIN_ROWS);
				setState(1938);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1937);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1940);
				decimalLiteral();
				}
				break;
			case 23:
				_localctx = new TableOptionPackKeysContext(_localctx);
				enterOuterAlt(_localctx, 23);
				{
				setState(1941);
				match(PACK_KEYS);
				setState(1943);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1942);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1945);
				((TableOptionPackKeysContext)_localctx).extBoolValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
					((TableOptionPackKeysContext)_localctx).extBoolValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 24:
				_localctx = new TableOptionPasswordContext(_localctx);
				enterOuterAlt(_localctx, 24);
				{
				setState(1946);
				match(PASSWORD);
				setState(1948);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1947);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1950);
				match(STRING_LITERAL);
				}
				break;
			case 25:
				_localctx = new TableOptionRowFormatContext(_localctx);
				enterOuterAlt(_localctx, 25);
				{
				setState(1951);
				match(ROW_FORMAT);
				setState(1953);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1952);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1955);
				((TableOptionRowFormatContext)_localctx).rowFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || ((((_la - 370)) & ~0x3f) == 0 && ((1L << (_la - 370)) & 2305843013508661253L) != 0) || _la==REDUNDANT || _la==ID) ) {
					((TableOptionRowFormatContext)_localctx).rowFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 26:
				_localctx = new TableOptionStartTransactionContext(_localctx);
				enterOuterAlt(_localctx, 26);
				{
				setState(1956);
				match(START);
				setState(1957);
				match(TRANSACTION);
				}
				break;
			case 27:
				_localctx = new TableOptionSecondaryEngineAttributeContext(_localctx);
				enterOuterAlt(_localctx, 27);
				{
				setState(1958);
				match(SECONDARY_ENGINE_ATTRIBUTE);
				setState(1960);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1959);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1962);
				match(STRING_LITERAL);
				}
				break;
			case 28:
				_localctx = new TableOptionRecalculationContext(_localctx);
				enterOuterAlt(_localctx, 28);
				{
				setState(1963);
				match(STATS_AUTO_RECALC);
				setState(1965);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1964);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1967);
				((TableOptionRecalculationContext)_localctx).extBoolValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
					((TableOptionRecalculationContext)_localctx).extBoolValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 29:
				_localctx = new TableOptionPersistentContext(_localctx);
				enterOuterAlt(_localctx, 29);
				{
				setState(1968);
				match(STATS_PERSISTENT);
				setState(1970);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1969);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1972);
				((TableOptionPersistentContext)_localctx).extBoolValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
					((TableOptionPersistentContext)_localctx).extBoolValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 30:
				_localctx = new TableOptionSamplePageContext(_localctx);
				enterOuterAlt(_localctx, 30);
				{
				setState(1973);
				match(STATS_SAMPLE_PAGES);
				setState(1975);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1974);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1979);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(1977);
					match(DEFAULT);
					}
					break;
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(1978);
					decimalLiteral();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 31:
				_localctx = new TableOptionTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 31);
				{
				setState(1981);
				match(TABLESPACE);
				setState(1982);
				uid();
				setState(1984);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,224,_ctx) ) {
				case 1:
					{
					setState(1983);
					tablespaceStorage();
					}
					break;
				}
				}
				break;
			case 32:
				_localctx = new TableOptionTableTypeContext(_localctx);
				enterOuterAlt(_localctx, 32);
				{
				setState(1986);
				match(TABLE_TYPE);
				setState(1987);
				match(EQUAL_SYMBOL);
				setState(1988);
				tableType();
				}
				break;
			case 33:
				_localctx = new TableOptionTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 33);
				{
				setState(1989);
				tablespaceStorage();
				}
				break;
			case 34:
				_localctx = new TableOptionTransactionalContext(_localctx);
				enterOuterAlt(_localctx, 34);
				{
				setState(1990);
				match(TRANSACTIONAL);
				setState(1992);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1991);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1994);
				_la = _input.LA(1);
				if ( !(_la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 35:
				_localctx = new TableOptionUnionContext(_localctx);
				enterOuterAlt(_localctx, 35);
				{
				setState(1995);
				match(UNION);
				setState(1997);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(1996);
					match(EQUAL_SYMBOL);
					}
				}

				setState(1999);
				match(LR_BRACKET);
				setState(2000);
				tables();
				setState(2001);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableTypeContext extends ParserRuleContext {
		public TerminalNode MYSQL() { return getToken(MySqlParser.MYSQL, 0); }
		public TerminalNode ODBC() { return getToken(MySqlParser.ODBC, 0); }
		public TableTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableTypeContext tableType() throws RecognitionException {
		TableTypeContext _localctx = new TableTypeContext(_ctx, getState());
		enterRule(_localctx, 108, RULE_tableType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2005);
			_la = _input.LA(1);
			if ( !(_la==MYSQL || _la==ODBC) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TablespaceStorageContext extends ParserRuleContext {
		public TerminalNode STORAGE() { return getToken(MySqlParser.STORAGE, 0); }
		public TerminalNode DISK() { return getToken(MySqlParser.DISK, 0); }
		public TerminalNode MEMORY() { return getToken(MySqlParser.MEMORY, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TablespaceStorageContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tablespaceStorage; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTablespaceStorage(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTablespaceStorage(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTablespaceStorage(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TablespaceStorageContext tablespaceStorage() throws RecognitionException {
		TablespaceStorageContext _localctx = new TablespaceStorageContext(_ctx, getState());
		enterRule(_localctx, 110, RULE_tablespaceStorage);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2007);
			match(STORAGE);
			setState(2008);
			_la = _input.LA(1);
			if ( !(_la==DEFAULT || _la==DISK || _la==MEMORY) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionDefinitionsContext extends ParserRuleContext {
		public DecimalLiteralContext count;
		public DecimalLiteralContext subCount;
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public List BY() { return getTokens(MySqlParser.BY); }
		public TerminalNode BY(int i) {
			return getToken(MySqlParser.BY, i);
		}
		public PartitionFunctionDefinitionContext partitionFunctionDefinition() {
			return getRuleContext(PartitionFunctionDefinitionContext.class,0);
		}
		public TerminalNode PARTITIONS() { return getToken(MySqlParser.PARTITIONS, 0); }
		public TerminalNode SUBPARTITION() { return getToken(MySqlParser.SUBPARTITION, 0); }
		public SubpartitionFunctionDefinitionContext subpartitionFunctionDefinition() {
			return getRuleContext(SubpartitionFunctionDefinitionContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List partitionDefinition() {
			return getRuleContexts(PartitionDefinitionContext.class);
		}
		public PartitionDefinitionContext partitionDefinition(int i) {
			return getRuleContext(PartitionDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode SUBPARTITIONS() { return getToken(MySqlParser.SUBPARTITIONS, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public PartitionDefinitionsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionDefinitions; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionDefinitions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionDefinitions(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionDefinitions(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionDefinitionsContext partitionDefinitions() throws RecognitionException {
		PartitionDefinitionsContext _localctx = new PartitionDefinitionsContext(_ctx, getState());
		enterRule(_localctx, 112, RULE_partitionDefinitions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2010);
			match(PARTITION);
			setState(2011);
			match(BY);
			setState(2012);
			partitionFunctionDefinition();
			setState(2015);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITIONS) {
				{
				setState(2013);
				match(PARTITIONS);
				setState(2014);
				((PartitionDefinitionsContext)_localctx).count = decimalLiteral();
				}
			}

			setState(2024);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SUBPARTITION) {
				{
				setState(2017);
				match(SUBPARTITION);
				setState(2018);
				match(BY);
				setState(2019);
				subpartitionFunctionDefinition();
				setState(2022);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SUBPARTITIONS) {
					{
					setState(2020);
					match(SUBPARTITIONS);
					setState(2021);
					((PartitionDefinitionsContext)_localctx).subCount = decimalLiteral();
					}
				}

				}
			}

			setState(2037);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,232,_ctx) ) {
			case 1:
				{
				setState(2026);
				match(LR_BRACKET);
				setState(2027);
				partitionDefinition();
				setState(2032);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2028);
					match(COMMA);
					setState(2029);
					partitionDefinition();
					}
					}
					setState(2034);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2035);
				match(RR_BRACKET);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionFunctionDefinitionContext extends ParserRuleContext {
		public PartitionFunctionDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionFunctionDefinition; }
	 
		public PartitionFunctionDefinitionContext() { }
		public void copyFrom(PartitionFunctionDefinitionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionFunctionKeyContext extends PartitionFunctionDefinitionContext {
		public Token algType;
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MySqlParser.LINEAR, 0); }
		public TerminalNode ALGORITHM() { return getToken(MySqlParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode TWO_DECIMAL() { return getToken(MySqlParser.TWO_DECIMAL, 0); }
		public PartitionFunctionKeyContext(PartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionFunctionKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionFunctionKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionFunctionKey(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionFunctionHashContext extends PartitionFunctionDefinitionContext {
		public TerminalNode HASH() { return getToken(MySqlParser.HASH, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MySqlParser.LINEAR, 0); }
		public PartitionFunctionHashContext(PartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionFunctionHash(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionFunctionHash(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionFunctionHash(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionFunctionListContext extends PartitionFunctionDefinitionContext {
		public TerminalNode LIST() { return getToken(MySqlParser.LIST, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public PartitionFunctionListContext(PartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionFunctionList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionFunctionList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionFunctionList(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionFunctionRangeContext extends PartitionFunctionDefinitionContext {
		public TerminalNode RANGE() { return getToken(MySqlParser.RANGE, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public PartitionFunctionRangeContext(PartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionFunctionRange(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionFunctionRange(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionFunctionRange(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionFunctionDefinitionContext partitionFunctionDefinition() throws RecognitionException {
		PartitionFunctionDefinitionContext _localctx = new PartitionFunctionDefinitionContext(_ctx, getState());
		enterRule(_localctx, 114, RULE_partitionFunctionDefinition);
		int _la;
		try {
			setState(2085);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,239,_ctx) ) {
			case 1:
				_localctx = new PartitionFunctionHashContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2040);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINEAR) {
					{
					setState(2039);
					match(LINEAR);
					}
				}

				setState(2042);
				match(HASH);
				setState(2043);
				match(LR_BRACKET);
				setState(2044);
				expression(0);
				setState(2045);
				match(RR_BRACKET);
				}
				break;
			case 2:
				_localctx = new PartitionFunctionKeyContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2048);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINEAR) {
					{
					setState(2047);
					match(LINEAR);
					}
				}

				setState(2050);
				match(KEY);
				setState(2054);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ALGORITHM) {
					{
					setState(2051);
					match(ALGORITHM);
					setState(2052);
					match(EQUAL_SYMBOL);
					setState(2053);
					((PartitionFunctionKeyContext)_localctx).algType = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==ONE_DECIMAL || _la==TWO_DECIMAL) ) {
						((PartitionFunctionKeyContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(2056);
				match(LR_BRACKET);
				setState(2058);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(2057);
					uidList();
					}
				}

				setState(2060);
				match(RR_BRACKET);
				}
				break;
			case 3:
				_localctx = new PartitionFunctionRangeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2061);
				match(RANGE);
				setState(2071);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case LR_BRACKET:
					{
					setState(2062);
					match(LR_BRACKET);
					setState(2063);
					expression(0);
					setState(2064);
					match(RR_BRACKET);
					}
					break;
				case COLUMNS:
					{
					setState(2066);
					match(COLUMNS);
					setState(2067);
					match(LR_BRACKET);
					setState(2068);
					uidList();
					setState(2069);
					match(RR_BRACKET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 4:
				_localctx = new PartitionFunctionListContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2073);
				match(LIST);
				setState(2083);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case LR_BRACKET:
					{
					setState(2074);
					match(LR_BRACKET);
					setState(2075);
					expression(0);
					setState(2076);
					match(RR_BRACKET);
					}
					break;
				case COLUMNS:
					{
					setState(2078);
					match(COLUMNS);
					setState(2079);
					match(LR_BRACKET);
					setState(2080);
					uidList();
					setState(2081);
					match(RR_BRACKET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SubpartitionFunctionDefinitionContext extends ParserRuleContext {
		public SubpartitionFunctionDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_subpartitionFunctionDefinition; }
	 
		public SubpartitionFunctionDefinitionContext() { }
		public void copyFrom(SubpartitionFunctionDefinitionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SubPartitionFunctionHashContext extends SubpartitionFunctionDefinitionContext {
		public TerminalNode HASH() { return getToken(MySqlParser.HASH, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MySqlParser.LINEAR, 0); }
		public SubPartitionFunctionHashContext(SubpartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubPartitionFunctionHash(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubPartitionFunctionHash(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubPartitionFunctionHash(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SubPartitionFunctionKeyContext extends SubpartitionFunctionDefinitionContext {
		public Token algType;
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode LINEAR() { return getToken(MySqlParser.LINEAR, 0); }
		public TerminalNode ALGORITHM() { return getToken(MySqlParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode TWO_DECIMAL() { return getToken(MySqlParser.TWO_DECIMAL, 0); }
		public SubPartitionFunctionKeyContext(SubpartitionFunctionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubPartitionFunctionKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubPartitionFunctionKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubPartitionFunctionKey(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SubpartitionFunctionDefinitionContext subpartitionFunctionDefinition() throws RecognitionException {
		SubpartitionFunctionDefinitionContext _localctx = new SubpartitionFunctionDefinitionContext(_ctx, getState());
		enterRule(_localctx, 116, RULE_subpartitionFunctionDefinition);
		int _la;
		try {
			setState(2108);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,243,_ctx) ) {
			case 1:
				_localctx = new SubPartitionFunctionHashContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2088);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINEAR) {
					{
					setState(2087);
					match(LINEAR);
					}
				}

				setState(2090);
				match(HASH);
				setState(2091);
				match(LR_BRACKET);
				setState(2092);
				expression(0);
				setState(2093);
				match(RR_BRACKET);
				}
				break;
			case 2:
				_localctx = new SubPartitionFunctionKeyContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2096);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINEAR) {
					{
					setState(2095);
					match(LINEAR);
					}
				}

				setState(2098);
				match(KEY);
				setState(2102);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ALGORITHM) {
					{
					setState(2099);
					match(ALGORITHM);
					setState(2100);
					match(EQUAL_SYMBOL);
					setState(2101);
					((SubPartitionFunctionKeyContext)_localctx).algType = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==ONE_DECIMAL || _la==TWO_DECIMAL) ) {
						((SubPartitionFunctionKeyContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(2104);
				match(LR_BRACKET);
				setState(2105);
				uidList();
				setState(2106);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionDefinitionContext extends ParserRuleContext {
		public PartitionDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionDefinition; }
	 
		public PartitionDefinitionContext() { }
		public void copyFrom(PartitionDefinitionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionComparisonContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VALUES() { return getToken(MySqlParser.VALUES, 0); }
		public TerminalNode LESS() { return getToken(MySqlParser.LESS, 0); }
		public TerminalNode THAN() { return getToken(MySqlParser.THAN, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List partitionDefinerAtom() {
			return getRuleContexts(PartitionDefinerAtomContext.class);
		}
		public PartitionDefinerAtomContext partitionDefinerAtom(int i) {
			return getRuleContext(PartitionDefinerAtomContext.class,i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List partitionOption() {
			return getRuleContexts(PartitionOptionContext.class);
		}
		public PartitionOptionContext partitionOption(int i) {
			return getRuleContext(PartitionOptionContext.class,i);
		}
		public List subpartitionDefinition() {
			return getRuleContexts(SubpartitionDefinitionContext.class);
		}
		public SubpartitionDefinitionContext subpartitionDefinition(int i) {
			return getRuleContext(SubpartitionDefinitionContext.class,i);
		}
		public PartitionComparisonContext(PartitionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionComparison(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionComparison(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionComparison(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionListAtomContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VALUES() { return getToken(MySqlParser.VALUES, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List partitionDefinerAtom() {
			return getRuleContexts(PartitionDefinerAtomContext.class);
		}
		public PartitionDefinerAtomContext partitionDefinerAtom(int i) {
			return getRuleContext(PartitionDefinerAtomContext.class,i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List partitionOption() {
			return getRuleContexts(PartitionOptionContext.class);
		}
		public PartitionOptionContext partitionOption(int i) {
			return getRuleContext(PartitionOptionContext.class,i);
		}
		public List subpartitionDefinition() {
			return getRuleContexts(SubpartitionDefinitionContext.class);
		}
		public SubpartitionDefinitionContext subpartitionDefinition(int i) {
			return getRuleContext(SubpartitionDefinitionContext.class,i);
		}
		public PartitionListAtomContext(PartitionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionListAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionListAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionListAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionListVectorContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VALUES() { return getToken(MySqlParser.VALUES, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List partitionDefinerVector() {
			return getRuleContexts(PartitionDefinerVectorContext.class);
		}
		public PartitionDefinerVectorContext partitionDefinerVector(int i) {
			return getRuleContext(PartitionDefinerVectorContext.class,i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List partitionOption() {
			return getRuleContexts(PartitionOptionContext.class);
		}
		public PartitionOptionContext partitionOption(int i) {
			return getRuleContext(PartitionOptionContext.class,i);
		}
		public List subpartitionDefinition() {
			return getRuleContexts(SubpartitionDefinitionContext.class);
		}
		public SubpartitionDefinitionContext subpartitionDefinition(int i) {
			return getRuleContext(SubpartitionDefinitionContext.class,i);
		}
		public PartitionListVectorContext(PartitionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionListVector(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionListVector(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionListVector(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionSimpleContext extends PartitionDefinitionContext {
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List partitionOption() {
			return getRuleContexts(PartitionOptionContext.class);
		}
		public PartitionOptionContext partitionOption(int i) {
			return getRuleContext(PartitionOptionContext.class,i);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List subpartitionDefinition() {
			return getRuleContexts(SubpartitionDefinitionContext.class);
		}
		public SubpartitionDefinitionContext subpartitionDefinition(int i) {
			return getRuleContext(SubpartitionDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public PartitionSimpleContext(PartitionDefinitionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionSimple(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionSimple(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionSimple(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionDefinitionContext partitionDefinition() throws RecognitionException {
		PartitionDefinitionContext _localctx = new PartitionDefinitionContext(_ctx, getState());
		enterRule(_localctx, 118, RULE_partitionDefinition);
		int _la;
		try {
			setState(2256);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,262,_ctx) ) {
			case 1:
				_localctx = new PartitionComparisonContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2110);
				match(PARTITION);
				setState(2111);
				uid();
				setState(2112);
				match(VALUES);
				setState(2113);
				match(LESS);
				setState(2114);
				match(THAN);
				setState(2115);
				match(LR_BRACKET);
				setState(2116);
				partitionDefinerAtom();
				setState(2121);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2117);
					match(COMMA);
					setState(2118);
					partitionDefinerAtom();
					}
					}
					setState(2123);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2124);
				match(RR_BRACKET);
				setState(2128);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & 2199024304129L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 268436481L) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2125);
					partitionOption();
					}
					}
					setState(2130);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2142);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2131);
					match(LR_BRACKET);
					setState(2132);
					subpartitionDefinition();
					setState(2137);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2133);
						match(COMMA);
						setState(2134);
						subpartitionDefinition();
						}
						}
						setState(2139);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2140);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 2:
				_localctx = new PartitionComparisonContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2144);
				match(PARTITION);
				setState(2145);
				uid();
				setState(2146);
				match(VALUES);
				setState(2147);
				match(LESS);
				setState(2148);
				match(THAN);
				setState(2149);
				partitionDefinerAtom();
				setState(2153);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & 2199024304129L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 268436481L) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2150);
					partitionOption();
					}
					}
					setState(2155);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2167);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2156);
					match(LR_BRACKET);
					setState(2157);
					subpartitionDefinition();
					setState(2162);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2158);
						match(COMMA);
						setState(2159);
						subpartitionDefinition();
						}
						}
						setState(2164);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2165);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 3:
				_localctx = new PartitionListAtomContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2169);
				match(PARTITION);
				setState(2170);
				uid();
				setState(2171);
				match(VALUES);
				setState(2172);
				match(IN);
				setState(2173);
				match(LR_BRACKET);
				setState(2174);
				partitionDefinerAtom();
				setState(2179);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2175);
					match(COMMA);
					setState(2176);
					partitionDefinerAtom();
					}
					}
					setState(2181);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2182);
				match(RR_BRACKET);
				setState(2186);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & 2199024304129L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 268436481L) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2183);
					partitionOption();
					}
					}
					setState(2188);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2200);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2189);
					match(LR_BRACKET);
					setState(2190);
					subpartitionDefinition();
					setState(2195);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2191);
						match(COMMA);
						setState(2192);
						subpartitionDefinition();
						}
						}
						setState(2197);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2198);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 4:
				_localctx = new PartitionListVectorContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2202);
				match(PARTITION);
				setState(2203);
				uid();
				setState(2204);
				match(VALUES);
				setState(2205);
				match(IN);
				setState(2206);
				match(LR_BRACKET);
				setState(2207);
				partitionDefinerVector();
				setState(2212);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2208);
					match(COMMA);
					setState(2209);
					partitionDefinerVector();
					}
					}
					setState(2214);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2215);
				match(RR_BRACKET);
				setState(2219);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & 2199024304129L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 268436481L) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2216);
					partitionOption();
					}
					}
					setState(2221);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2233);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2222);
					match(LR_BRACKET);
					setState(2223);
					subpartitionDefinition();
					setState(2228);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2224);
						match(COMMA);
						setState(2225);
						subpartitionDefinition();
						}
						}
						setState(2230);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2231);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 5:
				_localctx = new PartitionSimpleContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2235);
				match(PARTITION);
				setState(2236);
				uid();
				setState(2240);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & 2199024304129L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 268436481L) != 0) || _la==STORAGE || _la==TABLESPACE) {
					{
					{
					setState(2237);
					partitionOption();
					}
					}
					setState(2242);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2254);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(2243);
					match(LR_BRACKET);
					setState(2244);
					subpartitionDefinition();
					setState(2249);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(2245);
						match(COMMA);
						setState(2246);
						subpartitionDefinition();
						}
						}
						setState(2251);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					setState(2252);
					match(RR_BRACKET);
					}
				}

				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionDefinerAtomContext extends ParserRuleContext {
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode MAXVALUE() { return getToken(MySqlParser.MAXVALUE, 0); }
		public PartitionDefinerAtomContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionDefinerAtom; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionDefinerAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionDefinerAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionDefinerAtom(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionDefinerAtomContext partitionDefinerAtom() throws RecognitionException {
		PartitionDefinerAtomContext _localctx = new PartitionDefinerAtomContext(_ctx, getState());
		enterRule(_localctx, 120, RULE_partitionDefinerAtom);
		try {
			setState(2261);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,263,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(2258);
				constant();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(2259);
				expression(0);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(2260);
				match(MAXVALUE);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionDefinerVectorContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List partitionDefinerAtom() {
			return getRuleContexts(PartitionDefinerAtomContext.class);
		}
		public PartitionDefinerAtomContext partitionDefinerAtom(int i) {
			return getRuleContext(PartitionDefinerAtomContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public PartitionDefinerVectorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionDefinerVector; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionDefinerVector(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionDefinerVector(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionDefinerVector(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionDefinerVectorContext partitionDefinerVector() throws RecognitionException {
		PartitionDefinerVectorContext _localctx = new PartitionDefinerVectorContext(_ctx, getState());
		enterRule(_localctx, 122, RULE_partitionDefinerVector);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2263);
			match(LR_BRACKET);
			setState(2264);
			partitionDefinerAtom();
			setState(2267); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(2265);
				match(COMMA);
				setState(2266);
				partitionDefinerAtom();
				}
				}
				setState(2269); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==COMMA );
			setState(2271);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SubpartitionDefinitionContext extends ParserRuleContext {
		public TerminalNode SUBPARTITION() { return getToken(MySqlParser.SUBPARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List partitionOption() {
			return getRuleContexts(PartitionOptionContext.class);
		}
		public PartitionOptionContext partitionOption(int i) {
			return getRuleContext(PartitionOptionContext.class,i);
		}
		public SubpartitionDefinitionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_subpartitionDefinition; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubpartitionDefinition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubpartitionDefinition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubpartitionDefinition(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SubpartitionDefinitionContext subpartitionDefinition() throws RecognitionException {
		SubpartitionDefinitionContext _localctx = new SubpartitionDefinitionContext(_ctx, getState());
		enterRule(_localctx, 124, RULE_subpartitionDefinition);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2273);
			match(SUBPARTITION);
			setState(2274);
			uid();
			setState(2278);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DEFAULT || _la==INDEX || ((((_la - 368)) & ~0x3f) == 0 && ((1L << (_la - 368)) & 2199024304129L) != 0) || ((((_la - 500)) & ~0x3f) == 0 && ((1L << (_la - 500)) & 268436481L) != 0) || _la==STORAGE || _la==TABLESPACE) {
				{
				{
				setState(2275);
				partitionOption();
				}
				}
				setState(2280);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionContext extends ParserRuleContext {
		public PartitionOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionOption; }
	 
		public PartitionOptionContext() { }
		public void copyFrom(PartitionOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionCommentContext extends PartitionOptionContext {
		public Token comment;
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionCommentContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionComment(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionComment(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionComment(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionNodeGroupContext extends PartitionOptionContext {
		public UidContext nodegroup;
		public TerminalNode NODEGROUP() { return getToken(MySqlParser.NODEGROUP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionNodeGroupContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionNodeGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionNodeGroup(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionNodeGroup(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionIndexDirectoryContext extends PartitionOptionContext {
		public Token indexDirectory;
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode DIRECTORY() { return getToken(MySqlParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionIndexDirectoryContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionIndexDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionIndexDirectory(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionIndexDirectory(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionMaxRowsContext extends PartitionOptionContext {
		public DecimalLiteralContext maxRows;
		public TerminalNode MAX_ROWS() { return getToken(MySqlParser.MAX_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionMaxRowsContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionMaxRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionMaxRows(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionMaxRows(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionTablespaceContext extends PartitionOptionContext {
		public UidContext tablespace;
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionTablespaceContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionTablespace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionTablespace(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionEngineContext extends PartitionOptionContext {
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode STORAGE() { return getToken(MySqlParser.STORAGE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionEngineContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionEngine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionEngine(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionEngine(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionMinRowsContext extends PartitionOptionContext {
		public DecimalLiteralContext minRows;
		public TerminalNode MIN_ROWS() { return getToken(MySqlParser.MIN_ROWS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionMinRowsContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionMinRows(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionMinRows(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionMinRows(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PartitionOptionDataDirectoryContext extends PartitionOptionContext {
		public Token dataDirectory;
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode DIRECTORY() { return getToken(MySqlParser.DIRECTORY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PartitionOptionDataDirectoryContext(PartitionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionOptionDataDirectory(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionOptionDataDirectory(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionOptionDataDirectory(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionOptionContext partitionOption() throws RecognitionException {
		PartitionOptionContext _localctx = new PartitionOptionContext(_ctx, getState());
		enterRule(_localctx, 126, RULE_partitionOption);
		int _la;
		try {
			setState(2329);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DEFAULT:
			case ENGINE:
			case STORAGE:
				_localctx = new PartitionOptionEngineContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2282);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(2281);
					match(DEFAULT);
					}
				}

				setState(2285);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STORAGE) {
					{
					setState(2284);
					match(STORAGE);
					}
				}

				setState(2287);
				match(ENGINE);
				setState(2289);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2288);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2291);
				engineName();
				}
				break;
			case COMMENT:
				_localctx = new PartitionOptionCommentContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2292);
				match(COMMENT);
				setState(2294);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2293);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2296);
				((PartitionOptionCommentContext)_localctx).comment = match(STRING_LITERAL);
				}
				break;
			case DATA:
				_localctx = new PartitionOptionDataDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2297);
				match(DATA);
				setState(2298);
				match(DIRECTORY);
				setState(2300);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2299);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2302);
				((PartitionOptionDataDirectoryContext)_localctx).dataDirectory = match(STRING_LITERAL);
				}
				break;
			case INDEX:
				_localctx = new PartitionOptionIndexDirectoryContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2303);
				match(INDEX);
				setState(2304);
				match(DIRECTORY);
				setState(2306);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2305);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2308);
				((PartitionOptionIndexDirectoryContext)_localctx).indexDirectory = match(STRING_LITERAL);
				}
				break;
			case MAX_ROWS:
				_localctx = new PartitionOptionMaxRowsContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2309);
				match(MAX_ROWS);
				setState(2311);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2310);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2313);
				((PartitionOptionMaxRowsContext)_localctx).maxRows = decimalLiteral();
				}
				break;
			case MIN_ROWS:
				_localctx = new PartitionOptionMinRowsContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2314);
				match(MIN_ROWS);
				setState(2316);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2315);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2318);
				((PartitionOptionMinRowsContext)_localctx).minRows = decimalLiteral();
				}
				break;
			case TABLESPACE:
				_localctx = new PartitionOptionTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(2319);
				match(TABLESPACE);
				setState(2321);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2320);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2323);
				((PartitionOptionTablespaceContext)_localctx).tablespace = uid();
				}
				break;
			case NODEGROUP:
				_localctx = new PartitionOptionNodeGroupContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(2324);
				match(NODEGROUP);
				setState(2326);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2325);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2328);
				((PartitionOptionNodeGroupContext)_localctx).nodegroup = uid();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterDatabaseContext extends ParserRuleContext {
		public AlterDatabaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterDatabase; }
	 
		public AlterDatabaseContext() { }
		public void copyFrom(AlterDatabaseContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterUpgradeNameContext extends AlterDatabaseContext {
		public Token dbFormat;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode UPGRADE() { return getToken(MySqlParser.UPGRADE, 0); }
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode DIRECTORY() { return getToken(MySqlParser.DIRECTORY, 0); }
		public TerminalNode NAME() { return getToken(MySqlParser.NAME, 0); }
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public AlterUpgradeNameContext(AlterDatabaseContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterUpgradeName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterUpgradeName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterUpgradeName(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterSimpleDatabaseContext extends AlterDatabaseContext {
		public Token dbFormat;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List createDatabaseOption() {
			return getRuleContexts(CreateDatabaseOptionContext.class);
		}
		public CreateDatabaseOptionContext createDatabaseOption(int i) {
			return getRuleContext(CreateDatabaseOptionContext.class,i);
		}
		public AlterSimpleDatabaseContext(AlterDatabaseContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterSimpleDatabase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterSimpleDatabase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterSimpleDatabase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterDatabaseContext alterDatabase() throws RecognitionException {
		AlterDatabaseContext _localctx = new AlterDatabaseContext(_ctx, getState());
		enterRule(_localctx, 128, RULE_alterDatabase);
		int _la;
		try {
			setState(2349);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,279,_ctx) ) {
			case 1:
				_localctx = new AlterSimpleDatabaseContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2331);
				match(ALTER);
				setState(2332);
				((AlterSimpleDatabaseContext)_localctx).dbFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DATABASE || _la==SCHEMA) ) {
					((AlterSimpleDatabaseContext)_localctx).dbFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2334);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,277,_ctx) ) {
				case 1:
					{
					setState(2333);
					uid();
					}
					break;
				}
				setState(2337); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(2336);
					createDatabaseOption();
					}
					}
					setState(2339); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( (((_la) & ~0x3f) == 0 && ((1L << _la) & 4398214283264L) != 0) || _la==READ || _la==CHAR || _la==ENCRYPTION || _la==CHARSET );
				}
				break;
			case 2:
				_localctx = new AlterUpgradeNameContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2341);
				match(ALTER);
				setState(2342);
				((AlterUpgradeNameContext)_localctx).dbFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DATABASE || _la==SCHEMA) ) {
					((AlterUpgradeNameContext)_localctx).dbFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2343);
				uid();
				setState(2344);
				match(UPGRADE);
				setState(2345);
				match(DATA);
				setState(2346);
				match(DIRECTORY);
				setState(2347);
				match(NAME);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterEventContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode EVENT() { return getToken(MySqlParser.EVENT, 0); }
		public List fullId() {
			return getRuleContexts(FullIdContext.class);
		}
		public FullIdContext fullId(int i) {
			return getRuleContext(FullIdContext.class,i);
		}
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public List ON() { return getTokens(MySqlParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MySqlParser.ON, i);
		}
		public TerminalNode SCHEDULE() { return getToken(MySqlParser.SCHEDULE, 0); }
		public ScheduleExpressionContext scheduleExpression() {
			return getRuleContext(ScheduleExpressionContext.class,0);
		}
		public TerminalNode COMPLETION() { return getToken(MySqlParser.COMPLETION, 0); }
		public TerminalNode PRESERVE() { return getToken(MySqlParser.PRESERVE, 0); }
		public TerminalNode RENAME() { return getToken(MySqlParser.RENAME, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public EnableTypeContext enableType() {
			return getRuleContext(EnableTypeContext.class,0);
		}
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode DO() { return getToken(MySqlParser.DO, 0); }
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public AlterEventContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterEvent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterEvent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterEvent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterEvent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterEventContext alterEvent() throws RecognitionException {
		AlterEventContext _localctx = new AlterEventContext(_ctx, getState());
		enterRule(_localctx, 130, RULE_alterEvent);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2351);
			match(ALTER);
			setState(2353);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(2352);
				ownerStatement();
				}
			}

			setState(2355);
			match(EVENT);
			setState(2356);
			fullId();
			setState(2360);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,281,_ctx) ) {
			case 1:
				{
				setState(2357);
				match(ON);
				setState(2358);
				match(SCHEDULE);
				setState(2359);
				scheduleExpression();
				}
				break;
			}
			setState(2368);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ON) {
				{
				setState(2362);
				match(ON);
				setState(2363);
				match(COMPLETION);
				setState(2365);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(2364);
					match(NOT);
					}
				}

				setState(2367);
				match(PRESERVE);
				}
			}

			setState(2373);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,284,_ctx) ) {
			case 1:
				{
				setState(2370);
				match(RENAME);
				setState(2371);
				match(TO);
				setState(2372);
				fullId();
				}
				break;
			}
			setState(2376);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DISABLE || _la==ENABLE) {
				{
				setState(2375);
				enableType();
				}
			}

			setState(2380);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMENT) {
				{
				setState(2378);
				match(COMMENT);
				setState(2379);
				match(STRING_LITERAL);
				}
			}

			setState(2384);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,287,_ctx) ) {
			case 1:
				{
				setState(2382);
				match(DO);
				setState(2383);
				routineBody();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterFunctionContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public List routineOption() {
			return getRuleContexts(RoutineOptionContext.class);
		}
		public RoutineOptionContext routineOption(int i) {
			return getRuleContext(RoutineOptionContext.class,i);
		}
		public AlterFunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterFunction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterFunction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterFunction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterFunctionContext alterFunction() throws RecognitionException {
		AlterFunctionContext _localctx = new AlterFunctionContext(_ctx, getState());
		enterRule(_localctx, 132, RULE_alterFunction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2386);
			match(ALTER);
			setState(2387);
			match(FUNCTION);
			setState(2388);
			fullId();
			setState(2392);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DETERMINISTIC || ((((_la - 112)) & ~0x3f) == 0 && ((1L << (_la - 112)) & 281474985099269L) != 0) || _la==COMMENT || _la==CONTAINS || _la==LANGUAGE || _la==NO) {
				{
				{
				setState(2389);
				routineOption();
				}
				}
				setState(2394);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterInstanceContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode INSTANCE() { return getToken(MySqlParser.INSTANCE, 0); }
		public TerminalNode ROTATE() { return getToken(MySqlParser.ROTATE, 0); }
		public TerminalNode INNODB() { return getToken(MySqlParser.INNODB, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public AlterInstanceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterInstance; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterInstance(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterInstance(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterInstance(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterInstanceContext alterInstance() throws RecognitionException {
		AlterInstanceContext _localctx = new AlterInstanceContext(_ctx, getState());
		enterRule(_localctx, 134, RULE_alterInstance);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2395);
			match(ALTER);
			setState(2396);
			match(INSTANCE);
			setState(2397);
			match(ROTATE);
			setState(2398);
			match(INNODB);
			setState(2399);
			match(MASTER);
			setState(2400);
			match(KEY);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterLogfileGroupContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode LOGFILE() { return getToken(MySqlParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode UNDOFILE() { return getToken(MySqlParser.UNDOFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode INITIAL_SIZE() { return getToken(MySqlParser.INITIAL_SIZE, 0); }
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode WAIT() { return getToken(MySqlParser.WAIT, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public AlterLogfileGroupContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterLogfileGroup; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterLogfileGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterLogfileGroup(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterLogfileGroup(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterLogfileGroupContext alterLogfileGroup() throws RecognitionException {
		AlterLogfileGroupContext _localctx = new AlterLogfileGroupContext(_ctx, getState());
		enterRule(_localctx, 136, RULE_alterLogfileGroup);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2402);
			match(ALTER);
			setState(2403);
			match(LOGFILE);
			setState(2404);
			match(GROUP);
			setState(2405);
			uid();
			setState(2406);
			match(ADD);
			setState(2407);
			match(UNDOFILE);
			setState(2408);
			match(STRING_LITERAL);
			setState(2414);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(2409);
				match(INITIAL_SIZE);
				setState(2411);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2410);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2413);
				fileSizeLiteral();
				}
			}

			setState(2417);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WAIT) {
				{
				setState(2416);
				match(WAIT);
				}
			}

			setState(2419);
			match(ENGINE);
			setState(2421);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(2420);
				match(EQUAL_SYMBOL);
				}
			}

			setState(2423);
			engineName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterProcedureContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public List routineOption() {
			return getRuleContexts(RoutineOptionContext.class);
		}
		public RoutineOptionContext routineOption(int i) {
			return getRuleContext(RoutineOptionContext.class,i);
		}
		public AlterProcedureContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterProcedure; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterProcedure(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterProcedure(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterProcedure(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterProcedureContext alterProcedure() throws RecognitionException {
		AlterProcedureContext _localctx = new AlterProcedureContext(_ctx, getState());
		enterRule(_localctx, 138, RULE_alterProcedure);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2425);
			match(ALTER);
			setState(2426);
			match(PROCEDURE);
			setState(2427);
			fullId();
			setState(2431);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DETERMINISTIC || ((((_la - 112)) & ~0x3f) == 0 && ((1L << (_la - 112)) & 281474985099269L) != 0) || _la==COMMENT || _la==CONTAINS || _la==LANGUAGE || _la==NO) {
				{
				{
				setState(2428);
				routineOption();
				}
				}
				setState(2433);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterServerContext extends ParserRuleContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode SERVER() { return getToken(MySqlParser.SERVER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode OPTIONS() { return getToken(MySqlParser.OPTIONS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List serverOption() {
			return getRuleContexts(ServerOptionContext.class);
		}
		public ServerOptionContext serverOption(int i) {
			return getRuleContext(ServerOptionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterServerContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterServer; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterServer(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterServer(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterServer(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterServerContext alterServer() throws RecognitionException {
		AlterServerContext _localctx = new AlterServerContext(_ctx, getState());
		enterRule(_localctx, 140, RULE_alterServer);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2434);
			match(ALTER);
			setState(2435);
			match(SERVER);
			setState(2436);
			uid();
			setState(2437);
			match(OPTIONS);
			setState(2438);
			match(LR_BRACKET);
			setState(2439);
			serverOption();
			setState(2444);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(2440);
				match(COMMA);
				setState(2441);
				serverOption();
				}
				}
				setState(2446);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(2447);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterTableContext extends ParserRuleContext {
		public Token intimeAction;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public List alterSpecification() {
			return getRuleContexts(AlterSpecificationContext.class);
		}
		public AlterSpecificationContext alterSpecification(int i) {
			return getRuleContext(AlterSpecificationContext.class,i);
		}
		public PartitionDefinitionsContext partitionDefinitions() {
			return getRuleContext(PartitionDefinitionsContext.class,0);
		}
		public TerminalNode ONLINE() { return getToken(MySqlParser.ONLINE, 0); }
		public TerminalNode OFFLINE() { return getToken(MySqlParser.OFFLINE, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterTableContext alterTable() throws RecognitionException {
		AlterTableContext _localctx = new AlterTableContext(_ctx, getState());
		enterRule(_localctx, 142, RULE_alterTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2449);
			match(ALTER);
			setState(2451);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==OFFLINE || _la==ONLINE) {
				{
				setState(2450);
				((AlterTableContext)_localctx).intimeAction = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==OFFLINE || _la==ONLINE) ) {
					((AlterTableContext)_localctx).intimeAction = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(2454);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(2453);
				match(IGNORE);
				}
			}

			setState(2456);
			match(TABLE);
			setState(2457);
			tableName();
			setState(2459);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(2458);
				waitNowaitClause();
				}
			}

			setState(2469);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,299,_ctx) ) {
			case 1:
				{
				setState(2461);
				alterSpecification();
				setState(2466);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2462);
					match(COMMA);
					setState(2463);
					alterSpecification();
					}
					}
					setState(2468);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			setState(2472);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(2471);
				partitionDefinitions();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterTablespaceContext extends ParserRuleContext {
		public Token objectAction;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATAFILE() { return getToken(MySqlParser.DATAFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode INITIAL_SIZE() { return getToken(MySqlParser.INITIAL_SIZE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public FileSizeLiteralContext fileSizeLiteral() {
			return getRuleContext(FileSizeLiteralContext.class,0);
		}
		public TerminalNode WAIT() { return getToken(MySqlParser.WAIT, 0); }
		public AlterTablespaceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterTablespace; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterTablespace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterTablespace(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterTablespaceContext alterTablespace() throws RecognitionException {
		AlterTablespaceContext _localctx = new AlterTablespaceContext(_ctx, getState());
		enterRule(_localctx, 144, RULE_alterTablespace);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2474);
			match(ALTER);
			setState(2475);
			match(TABLESPACE);
			setState(2476);
			uid();
			setState(2477);
			((AlterTablespaceContext)_localctx).objectAction = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==ADD || _la==DROP) ) {
				((AlterTablespaceContext)_localctx).objectAction = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(2478);
			match(DATAFILE);
			setState(2479);
			match(STRING_LITERAL);
			setState(2483);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INITIAL_SIZE) {
				{
				setState(2480);
				match(INITIAL_SIZE);
				setState(2481);
				match(EQUAL_SYMBOL);
				setState(2482);
				fileSizeLiteral();
				}
			}

			setState(2486);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WAIT) {
				{
				setState(2485);
				match(WAIT);
				}
			}

			setState(2488);
			match(ENGINE);
			setState(2490);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EQUAL_SYMBOL) {
				{
				setState(2489);
				match(EQUAL_SYMBOL);
				}
			}

			setState(2492);
			engineName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterViewContext extends ParserRuleContext {
		public Token algType;
		public Token secContext;
		public Token checkOpt;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode VIEW() { return getToken(MySqlParser.VIEW, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode ALGORITHM() { return getToken(MySqlParser.ALGORITHM, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public OwnerStatementContext ownerStatement() {
			return getRuleContext(OwnerStatementContext.class,0);
		}
		public TerminalNode SQL() { return getToken(MySqlParser.SQL, 0); }
		public TerminalNode SECURITY() { return getToken(MySqlParser.SECURITY, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public TerminalNode OPTION() { return getToken(MySqlParser.OPTION, 0); }
		public TerminalNode UNDEFINED() { return getToken(MySqlParser.UNDEFINED, 0); }
		public TerminalNode MERGE() { return getToken(MySqlParser.MERGE, 0); }
		public TerminalNode TEMPTABLE() { return getToken(MySqlParser.TEMPTABLE, 0); }
		public TerminalNode DEFINER() { return getToken(MySqlParser.DEFINER, 0); }
		public TerminalNode INVOKER() { return getToken(MySqlParser.INVOKER, 0); }
		public TerminalNode CASCADED() { return getToken(MySqlParser.CASCADED, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public AlterViewContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterView; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterView(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterView(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterView(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterViewContext alterView() throws RecognitionException {
		AlterViewContext _localctx = new AlterViewContext(_ctx, getState());
		enterRule(_localctx, 146, RULE_alterView);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2494);
			match(ALTER);
			setState(2498);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALGORITHM) {
				{
				setState(2495);
				match(ALGORITHM);
				setState(2496);
				match(EQUAL_SYMBOL);
				setState(2497);
				((AlterViewContext)_localctx).algType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==MERGE || _la==TEMPTABLE || _la==UNDEFINED) ) {
					((AlterViewContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(2501);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFINER) {
				{
				setState(2500);
				ownerStatement();
				}
			}

			setState(2506);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SQL) {
				{
				setState(2503);
				match(SQL);
				setState(2504);
				match(SECURITY);
				setState(2505);
				((AlterViewContext)_localctx).secContext = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFINER || _la==INVOKER) ) {
					((AlterViewContext)_localctx).secContext = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(2508);
			match(VIEW);
			setState(2509);
			fullId();
			setState(2514);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(2510);
				match(LR_BRACKET);
				setState(2511);
				uidList();
				setState(2512);
				match(RR_BRACKET);
				}
			}

			setState(2516);
			match(AS);
			setState(2517);
			selectStatement();
			setState(2524);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,309,_ctx) ) {
			case 1:
				{
				setState(2518);
				match(WITH);
				setState(2520);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CASCADED || _la==LOCAL) {
					{
					setState(2519);
					((AlterViewContext)_localctx).checkOpt = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==CASCADED || _la==LOCAL) ) {
						((AlterViewContext)_localctx).checkOpt = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(2522);
				match(CHECK);
				setState(2523);
				match(OPTION);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterSpecificationContext extends ParserRuleContext {
		public AlterSpecificationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterSpecification; }
	 
		public AlterSpecificationContext() { }
		public void copyFrom(AlterSpecificationContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAlterColumnDefaultContext extends AlterSpecificationContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public TerminalNode VISIBLE() { return getToken(MySqlParser.VISIBLE, 0); }
		public TerminalNode INVISIBLE() { return getToken(MySqlParser.INVISIBLE, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public AlterByAlterColumnDefaultContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAlterColumnDefault(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAlterColumnDefault(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAlterColumnDefault(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDisableKeysContext extends AlterSpecificationContext {
		public TerminalNode DISABLE() { return getToken(MySqlParser.DISABLE, 0); }
		public TerminalNode KEYS() { return getToken(MySqlParser.KEYS, 0); }
		public AlterByDisableKeysContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDisableKeys(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDisableKeys(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDisableKeys(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDefaultCharsetContext extends AlterSpecificationContext {
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public AlterByDefaultCharsetContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDefaultCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDefaultCharset(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDefaultCharset(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByRenameColumnContext extends AlterSpecificationContext {
		public UidContext oldColumn;
		public UidContext newColumn;
		public TerminalNode RENAME() { return getToken(MySqlParser.RENAME, 0); }
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public AlterByRenameColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByRenameColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByRenameColumn(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByRenameColumn(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByConvertCharsetContext extends AlterSpecificationContext {
		public TerminalNode CONVERT() { return getToken(MySqlParser.CONVERT, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode CHARSET() { return getToken(MySqlParser.CHARSET, 0); }
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public AlterByConvertCharsetContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByConvertCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByConvertCharset(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByConvertCharset(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddForeignKeyContext extends AlterSpecificationContext {
		public UidContext name;
		public UidContext indexName;
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode FOREIGN() { return getToken(MySqlParser.FOREIGN, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public ReferenceDefinitionContext referenceDefinition() {
			return getRuleContext(ReferenceDefinitionContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public AlterByAddForeignKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddForeignKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddForeignKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddForeignKey(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByRenameIndexContext extends AlterSpecificationContext {
		public Token indexFormat;
		public TerminalNode RENAME() { return getToken(MySqlParser.RENAME, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public AlterByRenameIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByRenameIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByRenameIndex(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByRenameIndex(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByRenameContext extends AlterSpecificationContext {
		public Token renameFormat;
		public TerminalNode RENAME() { return getToken(MySqlParser.RENAME, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public AlterByRenameContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByRename(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByRename(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByRename(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByImportTablespaceContext extends AlterSpecificationContext {
		public TerminalNode IMPORT() { return getToken(MySqlParser.IMPORT, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public AlterByImportTablespaceContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByImportTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByImportTablespace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByImportTablespace(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddDefinitionsContext extends AlterSpecificationContext {
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List createDefinition() {
			return getRuleContexts(CreateDefinitionContext.class);
		}
		public CreateDefinitionContext createDefinition(int i) {
			return getRuleContext(CreateDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterByAddDefinitionsContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddDefinitions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddDefinitions(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddDefinitions(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAlterCheckTableConstraintContext extends AlterSpecificationContext {
		public UidContext name;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode ENFORCED() { return getToken(MySqlParser.ENFORCED, 0); }
		public AlterByAlterCheckTableConstraintContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAlterCheckTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAlterCheckTableConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAlterCheckTableConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDropConstraintCheckContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public AlterByDropConstraintCheckContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDropConstraintCheck(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDropConstraintCheck(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDropConstraintCheck(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddColumnsContext extends AlterSpecificationContext {
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public List columnDefinition() {
			return getRuleContexts(ColumnDefinitionContext.class);
		}
		public ColumnDefinitionContext columnDefinition(int i) {
			return getRuleContext(ColumnDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterByAddColumnsContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddColumns(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddColumns(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddColumns(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAlterIndexVisibilityContext extends AlterSpecificationContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode VISIBLE() { return getToken(MySqlParser.VISIBLE, 0); }
		public TerminalNode INVISIBLE() { return getToken(MySqlParser.INVISIBLE, 0); }
		public AlterByAlterIndexVisibilityContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAlterIndexVisibility(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAlterIndexVisibility(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAlterIndexVisibility(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDropForeignKeyContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode FOREIGN() { return getToken(MySqlParser.FOREIGN, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public AlterByDropForeignKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDropForeignKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDropForeignKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDropForeignKey(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddCheckTableConstraintContext extends AlterSpecificationContext {
		public UidContext name;
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode ENFORCED() { return getToken(MySqlParser.ENFORCED, 0); }
		public AlterByAddCheckTableConstraintContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddCheckTableConstraint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddCheckTableConstraint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddCheckTableConstraint(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterPartitionContext extends AlterSpecificationContext {
		public AlterPartitionSpecificationContext alterPartitionSpecification() {
			return getRuleContext(AlterPartitionSpecificationContext.class,0);
		}
		public AlterPartitionContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddIndexContext extends AlterSpecificationContext {
		public Token indexFormat;
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public AlterByAddIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddIndex(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddIndex(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDropColumnContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public TerminalNode RESTRICT() { return getToken(MySqlParser.RESTRICT, 0); }
		public AlterByDropColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDropColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDropColumn(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDropColumn(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByChangeDefaultContext extends AlterSpecificationContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public DefaultValueContext defaultValue() {
			return getRuleContext(DefaultValueContext.class,0);
		}
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public AlterByChangeDefaultContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByChangeDefault(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByChangeDefault(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByChangeDefault(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByForceContext extends AlterSpecificationContext {
		public TerminalNode FORCE() { return getToken(MySqlParser.FORCE, 0); }
		public AlterByForceContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByForce(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByForce(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByForce(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddSpecialIndexContext extends AlterSpecificationContext {
		public Token keyType;
		public Token indexFormat;
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode FULLTEXT() { return getToken(MySqlParser.FULLTEXT, 0); }
		public TerminalNode SPATIAL() { return getToken(MySqlParser.SPATIAL, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public AlterByAddSpecialIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddSpecialIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddSpecialIndex(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddSpecialIndex(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByModifyColumnContext extends AlterSpecificationContext {
		public TerminalNode MODIFY() { return getToken(MySqlParser.MODIFY, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public ColumnDefinitionContext columnDefinition() {
			return getRuleContext(ColumnDefinitionContext.class,0);
		}
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode AFTER() { return getToken(MySqlParser.AFTER, 0); }
		public AlterByModifyColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByModifyColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByModifyColumn(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByModifyColumn(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByTableOptionContext extends AlterSpecificationContext {
		public List tableOption() {
			return getRuleContexts(TableOptionContext.class);
		}
		public TableOptionContext tableOption(int i) {
			return getRuleContext(TableOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterByTableOptionContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByTableOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByTableOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByTableOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDropPrimaryKeyContext extends AlterSpecificationContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode PRIMARY() { return getToken(MySqlParser.PRIMARY, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public AlterByDropPrimaryKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDropPrimaryKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDropPrimaryKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDropPrimaryKey(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByLockContext extends AlterSpecificationContext {
		public Token lockType;
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public TerminalNode SHARED() { return getToken(MySqlParser.SHARED, 0); }
		public TerminalNode EXCLUSIVE() { return getToken(MySqlParser.EXCLUSIVE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public AlterByLockContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByLock(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByLock(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByLock(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDiscardTablespaceContext extends AlterSpecificationContext {
		public TerminalNode DISCARD() { return getToken(MySqlParser.DISCARD, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public AlterByDiscardTablespaceContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDiscardTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDiscardTablespace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDiscardTablespace(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByValidateContext extends AlterSpecificationContext {
		public Token validationFormat;
		public TerminalNode VALIDATION() { return getToken(MySqlParser.VALIDATION, 0); }
		public TerminalNode WITHOUT() { return getToken(MySqlParser.WITHOUT, 0); }
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public AlterByValidateContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByValidate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByValidate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByValidate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddPrimaryKeyContext extends AlterSpecificationContext {
		public UidContext name;
		public UidContext index;
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode PRIMARY() { return getToken(MySqlParser.PRIMARY, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public AlterByAddPrimaryKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddPrimaryKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddPrimaryKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddPrimaryKey(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByEnableKeysContext extends AlterSpecificationContext {
		public TerminalNode ENABLE() { return getToken(MySqlParser.ENABLE, 0); }
		public TerminalNode KEYS() { return getToken(MySqlParser.KEYS, 0); }
		public AlterByEnableKeysContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByEnableKeys(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByEnableKeys(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByEnableKeys(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterBySetAlgorithmContext extends AlterSpecificationContext {
		public Token algType;
		public TerminalNode ALGORITHM() { return getToken(MySqlParser.ALGORITHM, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode INSTANT() { return getToken(MySqlParser.INSTANT, 0); }
		public TerminalNode INPLACE() { return getToken(MySqlParser.INPLACE, 0); }
		public TerminalNode COPY() { return getToken(MySqlParser.COPY, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public AlterBySetAlgorithmContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterBySetAlgorithm(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterBySetAlgorithm(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterBySetAlgorithm(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByChangeColumnContext extends AlterSpecificationContext {
		public UidContext oldColumn;
		public UidContext newColumn;
		public UidContext afterColumn;
		public TerminalNode CHANGE() { return getToken(MySqlParser.CHANGE, 0); }
		public ColumnDefinitionContext columnDefinition() {
			return getRuleContext(ColumnDefinitionContext.class,0);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode AFTER() { return getToken(MySqlParser.AFTER, 0); }
		public AlterByChangeColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByChangeColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByChangeColumn(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByChangeColumn(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddUniqueKeyContext extends AlterSpecificationContext {
		public UidContext name;
		public Token indexFormat;
		public UidContext indexName;
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode UNIQUE() { return getToken(MySqlParser.UNIQUE, 0); }
		public IndexColumnNamesContext indexColumnNames() {
			return getRuleContext(IndexColumnNamesContext.class,0);
		}
		public TerminalNode CONSTRAINT() { return getToken(MySqlParser.CONSTRAINT, 0); }
		public IndexTypeContext indexType() {
			return getRuleContext(IndexTypeContext.class,0);
		}
		public List indexOption() {
			return getRuleContexts(IndexOptionContext.class);
		}
		public IndexOptionContext indexOption(int i) {
			return getRuleContext(IndexOptionContext.class,i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public AlterByAddUniqueKeyContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddUniqueKey(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddUniqueKey(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddUniqueKey(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDropIndexContext extends AlterSpecificationContext {
		public Token indexFormat;
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public AlterByDropIndexContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDropIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDropIndex(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDropIndex(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddColumnContext extends AlterSpecificationContext {
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public ColumnDefinitionContext columnDefinition() {
			return getRuleContext(ColumnDefinitionContext.class,0);
		}
		public TerminalNode COLUMN() { return getToken(MySqlParser.COLUMN, 0); }
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode AFTER() { return getToken(MySqlParser.AFTER, 0); }
		public AlterByAddColumnContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddColumn(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddColumn(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByOrderContext extends AlterSpecificationContext {
		public TerminalNode ORDER() { return getToken(MySqlParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public AlterByOrderContext(AlterSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByOrder(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByOrder(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByOrder(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterSpecificationContext alterSpecification() throws RecognitionException {
		AlterSpecificationContext _localctx = new AlterSpecificationContext(_ctx, getState());
		enterRule(_localctx, 148, RULE_alterSpecification);
		int _la;
		try {
			int _alt;
			setState(2877);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,369,_ctx) ) {
			case 1:
				_localctx = new AlterByTableOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2526);
				tableOption();
				setState(2533);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,311,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(2528);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==COMMA) {
							{
							setState(2527);
							match(COMMA);
							}
						}

						setState(2530);
						tableOption();
						}
						} 
					}
					setState(2535);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,311,_ctx);
				}
				}
				break;
			case 2:
				_localctx = new AlterByAddColumnContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2536);
				match(ADD);
				setState(2538);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2537);
					match(COLUMN);
					}
				}

				setState(2540);
				uid();
				setState(2541);
				columnDefinition();
				setState(2545);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FIRST:
					{
					setState(2542);
					match(FIRST);
					}
					break;
				case AFTER:
					{
					setState(2543);
					match(AFTER);
					setState(2544);
					uid();
					}
					break;
				case EOF:
				case ALTER:
				case ANALYZE:
				case CALL:
				case CHANGE:
				case CHECK:
				case CREATE:
				case DELETE:
				case DESC:
				case DESCRIBE:
				case DROP:
				case EXPLAIN:
				case GET:
				case GRANT:
				case INSERT:
				case KILL:
				case LOAD:
				case LOCK:
				case OPTIMIZE:
				case PARTITION:
				case PURGE:
				case RELEASE:
				case RENAME:
				case REPLACE:
				case RESIGNAL:
				case REVOKE:
				case SELECT:
				case SET:
				case SHOW:
				case SIGNAL:
				case TABLE:
				case UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				case WITH:
				case BEGIN:
				case BINLOG:
				case CACHE:
				case CHECKSUM:
				case COMMIT:
				case DEALLOCATE:
				case DO:
				case FLUSH:
				case HANDLER:
				case HELP:
				case INSTALL:
				case PREPARE:
				case REPAIR:
				case RESET:
				case ROLLBACK:
				case SAVEPOINT:
				case START:
				case STOP:
				case TRUNCATE:
				case UNINSTALL:
				case XA:
				case EXECUTE:
				case SHUTDOWN:
				case MINUS:
				case LR_BRACKET:
				case COMMA:
				case SEMI:
					break;
				default:
					break;
				}
				}
				break;
			case 3:
				_localctx = new AlterByAddColumnsContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2547);
				match(ADD);
				setState(2549);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2548);
					match(COLUMN);
					}
				}

				setState(2551);
				match(LR_BRACKET);
				setState(2552);
				uid();
				setState(2553);
				columnDefinition();
				setState(2560);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2554);
					match(COMMA);
					setState(2555);
					uid();
					setState(2556);
					columnDefinition();
					}
					}
					setState(2562);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2563);
				match(RR_BRACKET);
				}
				break;
			case 4:
				_localctx = new AlterByAddIndexContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2565);
				match(ADD);
				setState(2566);
				((AlterByAddIndexContext)_localctx).indexFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==INDEX || _la==KEY) ) {
					((AlterByAddIndexContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2568);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(2567);
					uid();
					}
				}

				setState(2571);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(2570);
					indexType();
					}
				}

				setState(2573);
				indexColumnNames();
				setState(2577);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,318,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(2574);
						indexOption();
						}
						} 
					}
					setState(2579);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,318,_ctx);
				}
				}
				break;
			case 5:
				_localctx = new AlterByAddPrimaryKeyContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2580);
				match(ADD);
				setState(2585);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2581);
					match(CONSTRAINT);
					setState(2583);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,319,_ctx) ) {
					case 1:
						{
						setState(2582);
						((AlterByAddPrimaryKeyContext)_localctx).name = uid();
						}
						break;
					}
					}
				}

				setState(2587);
				match(PRIMARY);
				setState(2588);
				match(KEY);
				setState(2590);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(2589);
					((AlterByAddPrimaryKeyContext)_localctx).index = uid();
					}
				}

				setState(2593);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(2592);
					indexType();
					}
				}

				setState(2595);
				indexColumnNames();
				setState(2599);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,323,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(2596);
						indexOption();
						}
						} 
					}
					setState(2601);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,323,_ctx);
				}
				}
				break;
			case 6:
				_localctx = new AlterByAddUniqueKeyContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2602);
				match(ADD);
				setState(2607);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2603);
					match(CONSTRAINT);
					setState(2605);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(2604);
						((AlterByAddUniqueKeyContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(2609);
				match(UNIQUE);
				setState(2611);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(2610);
					((AlterByAddUniqueKeyContext)_localctx).indexFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==INDEX || _la==KEY) ) {
						((AlterByAddUniqueKeyContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(2614);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(2613);
					((AlterByAddUniqueKeyContext)_localctx).indexName = uid();
					}
				}

				setState(2617);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(2616);
					indexType();
					}
				}

				setState(2619);
				indexColumnNames();
				setState(2623);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,329,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(2620);
						indexOption();
						}
						} 
					}
					setState(2625);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,329,_ctx);
				}
				}
				break;
			case 7:
				_localctx = new AlterByAddSpecialIndexContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(2626);
				match(ADD);
				setState(2627);
				((AlterByAddSpecialIndexContext)_localctx).keyType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FULLTEXT || _la==SPATIAL) ) {
					((AlterByAddSpecialIndexContext)_localctx).keyType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2629);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(2628);
					((AlterByAddSpecialIndexContext)_localctx).indexFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==INDEX || _la==KEY) ) {
						((AlterByAddSpecialIndexContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(2632);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(2631);
					uid();
					}
				}

				setState(2634);
				indexColumnNames();
				setState(2638);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,332,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(2635);
						indexOption();
						}
						} 
					}
					setState(2640);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,332,_ctx);
				}
				}
				break;
			case 8:
				_localctx = new AlterByAddForeignKeyContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(2641);
				match(ADD);
				setState(2646);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2642);
					match(CONSTRAINT);
					setState(2644);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(2643);
						((AlterByAddForeignKeyContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(2648);
				match(FOREIGN);
				setState(2649);
				match(KEY);
				setState(2651);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(2650);
					((AlterByAddForeignKeyContext)_localctx).indexName = uid();
					}
				}

				setState(2653);
				indexColumnNames();
				setState(2654);
				referenceDefinition();
				}
				break;
			case 9:
				_localctx = new AlterByAddCheckTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(2656);
				match(ADD);
				setState(2661);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2657);
					match(CONSTRAINT);
					setState(2659);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(2658);
						((AlterByAddCheckTableConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(2663);
				match(CHECK);
				setState(2670);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,338,_ctx) ) {
				case 1:
					{
					setState(2664);
					uid();
					}
					break;
				case 2:
					{
					setState(2665);
					stringLiteral();
					}
					break;
				case 3:
					{
					setState(2666);
					match(LR_BRACKET);
					setState(2667);
					expression(0);
					setState(2668);
					match(RR_BRACKET);
					}
					break;
				}
				setState(2673);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(2672);
					match(NOT);
					}
				}

				setState(2676);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ENFORCED) {
					{
					setState(2675);
					match(ENFORCED);
					}
				}

				}
				break;
			case 10:
				_localctx = new AlterByAlterCheckTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(2678);
				match(ALTER);
				setState(2683);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2679);
					match(CONSTRAINT);
					setState(2681);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(2680);
						((AlterByAlterCheckTableConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(2685);
				match(CHECK);
				setState(2692);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,343,_ctx) ) {
				case 1:
					{
					setState(2686);
					uid();
					}
					break;
				case 2:
					{
					setState(2687);
					stringLiteral();
					}
					break;
				case 3:
					{
					setState(2688);
					match(LR_BRACKET);
					setState(2689);
					expression(0);
					setState(2690);
					match(RR_BRACKET);
					}
					break;
				}
				setState(2695);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(2694);
					match(NOT);
					}
				}

				setState(2698);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ENFORCED) {
					{
					setState(2697);
					match(ENFORCED);
					}
				}

				}
				break;
			case 11:
				_localctx = new AlterByAddCheckTableConstraintContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(2700);
				match(ADD);
				setState(2705);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CONSTRAINT) {
					{
					setState(2701);
					match(CONSTRAINT);
					setState(2703);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
						{
						setState(2702);
						((AlterByAddCheckTableConstraintContext)_localctx).name = uid();
						}
					}

					}
				}

				setState(2707);
				match(CHECK);
				setState(2708);
				match(LR_BRACKET);
				setState(2709);
				expression(0);
				setState(2710);
				match(RR_BRACKET);
				}
				break;
			case 12:
				_localctx = new AlterBySetAlgorithmContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(2712);
				match(ALGORITHM);
				setState(2714);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2713);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2716);
				((AlterBySetAlgorithmContext)_localctx).algType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==COPY || _la==INPLACE || _la==INSTANT) ) {
					((AlterBySetAlgorithmContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 13:
				_localctx = new AlterByChangeDefaultContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(2717);
				match(ALTER);
				setState(2719);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2718);
					match(COLUMN);
					}
				}

				setState(2721);
				uid();
				setState(2727);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SET:
					{
					setState(2722);
					match(SET);
					setState(2723);
					match(DEFAULT);
					setState(2724);
					defaultValue();
					}
					break;
				case DROP:
					{
					setState(2725);
					match(DROP);
					setState(2726);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 14:
				_localctx = new AlterByChangeColumnContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(2729);
				match(CHANGE);
				setState(2731);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2730);
					match(COLUMN);
					}
				}

				setState(2733);
				((AlterByChangeColumnContext)_localctx).oldColumn = uid();
				setState(2734);
				((AlterByChangeColumnContext)_localctx).newColumn = uid();
				setState(2735);
				columnDefinition();
				setState(2739);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FIRST:
					{
					setState(2736);
					match(FIRST);
					}
					break;
				case AFTER:
					{
					setState(2737);
					match(AFTER);
					setState(2738);
					((AlterByChangeColumnContext)_localctx).afterColumn = uid();
					}
					break;
				case EOF:
				case ALTER:
				case ANALYZE:
				case CALL:
				case CHANGE:
				case CHECK:
				case CREATE:
				case DELETE:
				case DESC:
				case DESCRIBE:
				case DROP:
				case EXPLAIN:
				case GET:
				case GRANT:
				case INSERT:
				case KILL:
				case LOAD:
				case LOCK:
				case OPTIMIZE:
				case PARTITION:
				case PURGE:
				case RELEASE:
				case RENAME:
				case REPLACE:
				case RESIGNAL:
				case REVOKE:
				case SELECT:
				case SET:
				case SHOW:
				case SIGNAL:
				case TABLE:
				case UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				case WITH:
				case BEGIN:
				case BINLOG:
				case CACHE:
				case CHECKSUM:
				case COMMIT:
				case DEALLOCATE:
				case DO:
				case FLUSH:
				case HANDLER:
				case HELP:
				case INSTALL:
				case PREPARE:
				case REPAIR:
				case RESET:
				case ROLLBACK:
				case SAVEPOINT:
				case START:
				case STOP:
				case TRUNCATE:
				case UNINSTALL:
				case XA:
				case EXECUTE:
				case SHUTDOWN:
				case MINUS:
				case LR_BRACKET:
				case COMMA:
				case SEMI:
					break;
				default:
					break;
				}
				}
				break;
			case 15:
				_localctx = new AlterByRenameColumnContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(2741);
				match(RENAME);
				setState(2742);
				match(COLUMN);
				setState(2743);
				((AlterByRenameColumnContext)_localctx).oldColumn = uid();
				setState(2744);
				match(TO);
				setState(2745);
				((AlterByRenameColumnContext)_localctx).newColumn = uid();
				}
				break;
			case 16:
				_localctx = new AlterByLockContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(2747);
				match(LOCK);
				setState(2749);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(2748);
					match(EQUAL_SYMBOL);
					}
				}

				setState(2751);
				((AlterByLockContext)_localctx).lockType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DEFAULT || _la==EXCLUSIVE || _la==NONE || _la==SHARED) ) {
					((AlterByLockContext)_localctx).lockType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 17:
				_localctx = new AlterByModifyColumnContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(2752);
				match(MODIFY);
				setState(2754);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2753);
					match(COLUMN);
					}
				}

				setState(2756);
				uid();
				setState(2757);
				columnDefinition();
				setState(2761);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FIRST:
					{
					setState(2758);
					match(FIRST);
					}
					break;
				case AFTER:
					{
					setState(2759);
					match(AFTER);
					setState(2760);
					uid();
					}
					break;
				case EOF:
				case ALTER:
				case ANALYZE:
				case CALL:
				case CHANGE:
				case CHECK:
				case CREATE:
				case DELETE:
				case DESC:
				case DESCRIBE:
				case DROP:
				case EXPLAIN:
				case GET:
				case GRANT:
				case INSERT:
				case KILL:
				case LOAD:
				case LOCK:
				case OPTIMIZE:
				case PARTITION:
				case PURGE:
				case RELEASE:
				case RENAME:
				case REPLACE:
				case RESIGNAL:
				case REVOKE:
				case SELECT:
				case SET:
				case SHOW:
				case SIGNAL:
				case TABLE:
				case UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				case WITH:
				case BEGIN:
				case BINLOG:
				case CACHE:
				case CHECKSUM:
				case COMMIT:
				case DEALLOCATE:
				case DO:
				case FLUSH:
				case HANDLER:
				case HELP:
				case INSTALL:
				case PREPARE:
				case REPAIR:
				case RESET:
				case ROLLBACK:
				case SAVEPOINT:
				case START:
				case STOP:
				case TRUNCATE:
				case UNINSTALL:
				case XA:
				case EXECUTE:
				case SHUTDOWN:
				case MINUS:
				case LR_BRACKET:
				case COMMA:
				case SEMI:
					break;
				default:
					break;
				}
				}
				break;
			case 18:
				_localctx = new AlterByDropColumnContext(_localctx);
				enterOuterAlt(_localctx, 18);
				{
				setState(2763);
				match(DROP);
				setState(2765);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2764);
					match(COLUMN);
					}
				}

				setState(2767);
				uid();
				setState(2769);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==RESTRICT) {
					{
					setState(2768);
					match(RESTRICT);
					}
				}

				}
				break;
			case 19:
				_localctx = new AlterByDropConstraintCheckContext(_localctx);
				enterOuterAlt(_localctx, 19);
				{
				setState(2771);
				match(DROP);
				setState(2772);
				_la = _input.LA(1);
				if ( !(_la==CHECK || _la==CONSTRAINT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2773);
				uid();
				}
				break;
			case 20:
				_localctx = new AlterByDropPrimaryKeyContext(_localctx);
				enterOuterAlt(_localctx, 20);
				{
				setState(2774);
				match(DROP);
				setState(2775);
				match(PRIMARY);
				setState(2776);
				match(KEY);
				}
				break;
			case 21:
				_localctx = new AlterByDropIndexContext(_localctx);
				enterOuterAlt(_localctx, 21);
				{
				setState(2777);
				match(DROP);
				setState(2778);
				((AlterByDropIndexContext)_localctx).indexFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==INDEX || _la==KEY) ) {
					((AlterByDropIndexContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2779);
				uid();
				}
				break;
			case 22:
				_localctx = new AlterByRenameIndexContext(_localctx);
				enterOuterAlt(_localctx, 22);
				{
				setState(2780);
				match(RENAME);
				setState(2781);
				((AlterByRenameIndexContext)_localctx).indexFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==INDEX || _la==KEY) ) {
					((AlterByRenameIndexContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2782);
				uid();
				setState(2783);
				match(TO);
				setState(2784);
				uid();
				}
				break;
			case 23:
				_localctx = new AlterByAlterColumnDefaultContext(_localctx);
				enterOuterAlt(_localctx, 23);
				{
				setState(2786);
				match(ALTER);
				setState(2788);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2787);
					match(COLUMN);
					}
				}

				setState(2790);
				uid();
				setState(2804);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,360,_ctx) ) {
				case 1:
					{
					setState(2791);
					match(SET);
					setState(2792);
					match(DEFAULT);
					setState(2798);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case START_NATIONAL_STRING_LITERAL:
					case STRING_LITERAL:
					case STRING_CHARSET_NAME:
						{
						setState(2793);
						stringLiteral();
						}
						break;
					case LR_BRACKET:
						{
						setState(2794);
						match(LR_BRACKET);
						setState(2795);
						expression(0);
						setState(2796);
						match(RR_BRACKET);
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					break;
				case 2:
					{
					setState(2800);
					match(SET);
					setState(2801);
					_la = _input.LA(1);
					if ( !(_la==INVISIBLE || _la==VISIBLE) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					break;
				case 3:
					{
					setState(2802);
					match(DROP);
					setState(2803);
					match(DEFAULT);
					}
					break;
				}
				}
				break;
			case 24:
				_localctx = new AlterByAlterIndexVisibilityContext(_localctx);
				enterOuterAlt(_localctx, 24);
				{
				setState(2806);
				match(ALTER);
				setState(2807);
				match(INDEX);
				setState(2808);
				uid();
				setState(2809);
				_la = _input.LA(1);
				if ( !(_la==INVISIBLE || _la==VISIBLE) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 25:
				_localctx = new AlterByDropForeignKeyContext(_localctx);
				enterOuterAlt(_localctx, 25);
				{
				setState(2811);
				match(DROP);
				setState(2812);
				match(FOREIGN);
				setState(2813);
				match(KEY);
				setState(2814);
				uid();
				}
				break;
			case 26:
				_localctx = new AlterByDisableKeysContext(_localctx);
				enterOuterAlt(_localctx, 26);
				{
				setState(2815);
				match(DISABLE);
				setState(2816);
				match(KEYS);
				}
				break;
			case 27:
				_localctx = new AlterByEnableKeysContext(_localctx);
				enterOuterAlt(_localctx, 27);
				{
				setState(2817);
				match(ENABLE);
				setState(2818);
				match(KEYS);
				}
				break;
			case 28:
				_localctx = new AlterByRenameContext(_localctx);
				enterOuterAlt(_localctx, 28);
				{
				setState(2819);
				match(RENAME);
				setState(2821);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS || _la==TO) {
					{
					setState(2820);
					((AlterByRenameContext)_localctx).renameFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==AS || _la==TO) ) {
						((AlterByRenameContext)_localctx).renameFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(2825);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,362,_ctx) ) {
				case 1:
					{
					setState(2823);
					uid();
					}
					break;
				case 2:
					{
					setState(2824);
					fullId();
					}
					break;
				}
				}
				break;
			case 29:
				_localctx = new AlterByOrderContext(_localctx);
				enterOuterAlt(_localctx, 29);
				{
				setState(2827);
				match(ORDER);
				setState(2828);
				match(BY);
				setState(2829);
				uidList();
				}
				break;
			case 30:
				_localctx = new AlterByConvertCharsetContext(_localctx);
				enterOuterAlt(_localctx, 30);
				{
				setState(2830);
				match(CONVERT);
				setState(2831);
				match(TO);
				setState(2835);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case CHARSET:
					{
					setState(2832);
					match(CHARSET);
					}
					break;
				case CHARACTER:
					{
					setState(2833);
					match(CHARACTER);
					setState(2834);
					match(SET);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(2837);
				charsetName();
				setState(2840);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLLATE) {
					{
					setState(2838);
					match(COLLATE);
					setState(2839);
					collationName();
					}
				}

				}
				break;
			case 31:
				_localctx = new AlterByDefaultCharsetContext(_localctx);
				enterOuterAlt(_localctx, 31);
				{
				setState(2843);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(2842);
					match(DEFAULT);
					}
				}

				setState(2845);
				match(CHARACTER);
				setState(2846);
				match(SET);
				setState(2847);
				match(EQUAL_SYMBOL);
				setState(2848);
				charsetName();
				setState(2852);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLLATE) {
					{
					setState(2849);
					match(COLLATE);
					setState(2850);
					match(EQUAL_SYMBOL);
					setState(2851);
					collationName();
					}
				}

				}
				break;
			case 32:
				_localctx = new AlterByDiscardTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 32);
				{
				setState(2854);
				match(DISCARD);
				setState(2855);
				match(TABLESPACE);
				}
				break;
			case 33:
				_localctx = new AlterByImportTablespaceContext(_localctx);
				enterOuterAlt(_localctx, 33);
				{
				setState(2856);
				match(IMPORT);
				setState(2857);
				match(TABLESPACE);
				}
				break;
			case 34:
				_localctx = new AlterByForceContext(_localctx);
				enterOuterAlt(_localctx, 34);
				{
				setState(2858);
				match(FORCE);
				}
				break;
			case 35:
				_localctx = new AlterByValidateContext(_localctx);
				enterOuterAlt(_localctx, 35);
				{
				setState(2859);
				((AlterByValidateContext)_localctx).validationFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==WITH || _la==WITHOUT) ) {
					((AlterByValidateContext)_localctx).validationFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(2860);
				match(VALIDATION);
				}
				break;
			case 36:
				_localctx = new AlterByAddDefinitionsContext(_localctx);
				enterOuterAlt(_localctx, 36);
				{
				setState(2861);
				match(ADD);
				setState(2863);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COLUMN) {
					{
					setState(2862);
					match(COLUMN);
					}
				}

				setState(2865);
				match(LR_BRACKET);
				setState(2866);
				createDefinition();
				setState(2871);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2867);
					match(COMMA);
					setState(2868);
					createDefinition();
					}
					}
					setState(2873);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2874);
				match(RR_BRACKET);
				}
				break;
			case 37:
				_localctx = new AlterPartitionContext(_localctx);
				enterOuterAlt(_localctx, 37);
				{
				setState(2876);
				alterPartitionSpecification();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterPartitionSpecificationContext extends ParserRuleContext {
		public AlterPartitionSpecificationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterPartitionSpecification; }
	 
		public AlterPartitionSpecificationContext() { }
		public void copyFrom(AlterPartitionSpecificationContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByImportPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode IMPORT() { return getToken(MySqlParser.IMPORT, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByImportPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByImportPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByImportPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByImportPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDropPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public AlterByDropPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDropPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDropPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDropPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByDiscardPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode DISCARD() { return getToken(MySqlParser.DISCARD, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByDiscardPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByDiscardPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByDiscardPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByDiscardPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAddPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode ADD() { return getToken(MySqlParser.ADD, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List partitionDefinition() {
			return getRuleContexts(PartitionDefinitionContext.class);
		}
		public PartitionDefinitionContext partitionDefinition(int i) {
			return getRuleContext(PartitionDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterByAddPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAddPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAddPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAddPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByRemovePartitioningContext extends AlterPartitionSpecificationContext {
		public TerminalNode REMOVE() { return getToken(MySqlParser.REMOVE, 0); }
		public TerminalNode PARTITIONING() { return getToken(MySqlParser.PARTITIONING, 0); }
		public AlterByRemovePartitioningContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByRemovePartitioning(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByRemovePartitioning(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByRemovePartitioning(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByOptimizePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode OPTIMIZE() { return getToken(MySqlParser.OPTIMIZE, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByOptimizePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByOptimizePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByOptimizePartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByOptimizePartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByCheckPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByCheckPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByCheckPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByCheckPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByCheckPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByCoalescePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode COALESCE() { return getToken(MySqlParser.COALESCE, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public AlterByCoalescePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByCoalescePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByCoalescePartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByCoalescePartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByReorganizePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode REORGANIZE() { return getToken(MySqlParser.REORGANIZE, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List partitionDefinition() {
			return getRuleContexts(PartitionDefinitionContext.class);
		}
		public PartitionDefinitionContext partitionDefinition(int i) {
			return getRuleContext(PartitionDefinitionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterByReorganizePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByReorganizePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByReorganizePartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByReorganizePartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByAnalyzePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode ANALYZE() { return getToken(MySqlParser.ANALYZE, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByAnalyzePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByAnalyzePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByAnalyzePartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByAnalyzePartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByRebuildPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode REBUILD() { return getToken(MySqlParser.REBUILD, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByRebuildPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByRebuildPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByRebuildPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByRebuildPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByUpgradePartitioningContext extends AlterPartitionSpecificationContext {
		public TerminalNode UPGRADE() { return getToken(MySqlParser.UPGRADE, 0); }
		public TerminalNode PARTITIONING() { return getToken(MySqlParser.PARTITIONING, 0); }
		public AlterByUpgradePartitioningContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByUpgradePartitioning(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByUpgradePartitioning(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByUpgradePartitioning(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByTruncatePartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode TRUNCATE() { return getToken(MySqlParser.TRUNCATE, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByTruncatePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByTruncatePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByTruncatePartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByTruncatePartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByRepairPartitionContext extends AlterPartitionSpecificationContext {
		public TerminalNode REPAIR() { return getToken(MySqlParser.REPAIR, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public AlterByRepairPartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByRepairPartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByRepairPartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByRepairPartition(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterByExchangePartitionContext extends AlterPartitionSpecificationContext {
		public Token validationFormat;
		public TerminalNode EXCHANGE() { return getToken(MySqlParser.EXCHANGE, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List WITH() { return getTokens(MySqlParser.WITH); }
		public TerminalNode WITH(int i) {
			return getToken(MySqlParser.WITH, i);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode VALIDATION() { return getToken(MySqlParser.VALIDATION, 0); }
		public TerminalNode WITHOUT() { return getToken(MySqlParser.WITHOUT, 0); }
		public AlterByExchangePartitionContext(AlterPartitionSpecificationContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterByExchangePartition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterByExchangePartition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterByExchangePartition(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterPartitionSpecificationContext alterPartitionSpecification() throws RecognitionException {
		AlterPartitionSpecificationContext _localctx = new AlterPartitionSpecificationContext(_ctx, getState());
		enterRule(_localctx, 150, RULE_alterPartitionSpecification);
		int _la;
		try {
			setState(2977);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ADD:
				_localctx = new AlterByAddPartitionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(2879);
				match(ADD);
				setState(2880);
				match(PARTITION);
				setState(2881);
				match(LR_BRACKET);
				setState(2882);
				partitionDefinition();
				setState(2887);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2883);
					match(COMMA);
					setState(2884);
					partitionDefinition();
					}
					}
					setState(2889);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2890);
				match(RR_BRACKET);
				}
				break;
			case DROP:
				_localctx = new AlterByDropPartitionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(2892);
				match(DROP);
				setState(2893);
				match(PARTITION);
				setState(2894);
				uidList();
				}
				break;
			case DISCARD:
				_localctx = new AlterByDiscardPartitionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(2895);
				match(DISCARD);
				setState(2896);
				match(PARTITION);
				setState(2899);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2897);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2898);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(2901);
				match(TABLESPACE);
				}
				break;
			case IMPORT:
				_localctx = new AlterByImportPartitionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(2902);
				match(IMPORT);
				setState(2903);
				match(PARTITION);
				setState(2906);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2904);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2905);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(2908);
				match(TABLESPACE);
				}
				break;
			case TRUNCATE:
				_localctx = new AlterByTruncatePartitionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(2909);
				match(TRUNCATE);
				setState(2910);
				match(PARTITION);
				setState(2913);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2911);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2912);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case COALESCE:
				_localctx = new AlterByCoalescePartitionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(2915);
				match(COALESCE);
				setState(2916);
				match(PARTITION);
				setState(2917);
				decimalLiteral();
				}
				break;
			case REORGANIZE:
				_localctx = new AlterByReorganizePartitionContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(2918);
				match(REORGANIZE);
				setState(2919);
				match(PARTITION);
				setState(2920);
				uidList();
				setState(2921);
				match(INTO);
				setState(2922);
				match(LR_BRACKET);
				setState(2923);
				partitionDefinition();
				setState(2928);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(2924);
					match(COMMA);
					setState(2925);
					partitionDefinition();
					}
					}
					setState(2930);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(2931);
				match(RR_BRACKET);
				}
				break;
			case EXCHANGE:
				_localctx = new AlterByExchangePartitionContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(2933);
				match(EXCHANGE);
				setState(2934);
				match(PARTITION);
				setState(2935);
				uid();
				setState(2936);
				match(WITH);
				setState(2937);
				match(TABLE);
				setState(2938);
				tableName();
				setState(2941);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,375,_ctx) ) {
				case 1:
					{
					setState(2939);
					((AlterByExchangePartitionContext)_localctx).validationFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==WITH || _la==WITHOUT) ) {
						((AlterByExchangePartitionContext)_localctx).validationFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(2940);
					match(VALIDATION);
					}
					break;
				}
				}
				break;
			case ANALYZE:
				_localctx = new AlterByAnalyzePartitionContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(2943);
				match(ANALYZE);
				setState(2944);
				match(PARTITION);
				setState(2947);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2945);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2946);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case CHECK:
				_localctx = new AlterByCheckPartitionContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(2949);
				match(CHECK);
				setState(2950);
				match(PARTITION);
				setState(2953);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2951);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2952);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case OPTIMIZE:
				_localctx = new AlterByOptimizePartitionContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(2955);
				match(OPTIMIZE);
				setState(2956);
				match(PARTITION);
				setState(2959);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2957);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2958);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case REBUILD:
				_localctx = new AlterByRebuildPartitionContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(2961);
				match(REBUILD);
				setState(2962);
				match(PARTITION);
				setState(2965);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2963);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2964);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case REPAIR:
				_localctx = new AlterByRepairPartitionContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(2967);
				match(REPAIR);
				setState(2968);
				match(PARTITION);
				setState(2971);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(2969);
					uidList();
					}
					break;
				case ALL:
					{
					setState(2970);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case REMOVE:
				_localctx = new AlterByRemovePartitioningContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(2973);
				match(REMOVE);
				setState(2974);
				match(PARTITIONING);
				}
				break;
			case UPGRADE:
				_localctx = new AlterByUpgradePartitioningContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(2975);
				match(UPGRADE);
				setState(2976);
				match(PARTITIONING);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropDatabaseContext extends ParserRuleContext {
		public Token dbFormat;
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DropDatabaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropDatabase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropDatabase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropDatabase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropDatabase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropDatabaseContext dropDatabase() throws RecognitionException {
		DropDatabaseContext _localctx = new DropDatabaseContext(_ctx, getState());
		enterRule(_localctx, 152, RULE_dropDatabase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2979);
			match(DROP);
			setState(2980);
			((DropDatabaseContext)_localctx).dbFormat = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==DATABASE || _la==SCHEMA) ) {
				((DropDatabaseContext)_localctx).dbFormat = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(2982);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,382,_ctx) ) {
			case 1:
				{
				setState(2981);
				ifExists();
				}
				break;
			}
			setState(2984);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropEventContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode EVENT() { return getToken(MySqlParser.EVENT, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DropEventContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropEvent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropEvent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropEvent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropEvent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropEventContext dropEvent() throws RecognitionException {
		DropEventContext _localctx = new DropEventContext(_ctx, getState());
		enterRule(_localctx, 154, RULE_dropEvent);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(2986);
			match(DROP);
			setState(2987);
			match(EVENT);
			setState(2989);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,383,_ctx) ) {
			case 1:
				{
				setState(2988);
				ifExists();
				}
				break;
			}
			setState(2991);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropIndexContext extends ParserRuleContext {
		public Token intimeAction;
		public Token algType;
		public Token lockType;
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public List ALGORITHM() { return getTokens(MySqlParser.ALGORITHM); }
		public TerminalNode ALGORITHM(int i) {
			return getToken(MySqlParser.ALGORITHM, i);
		}
		public List LOCK() { return getTokens(MySqlParser.LOCK); }
		public TerminalNode LOCK(int i) {
			return getToken(MySqlParser.LOCK, i);
		}
		public TerminalNode ONLINE() { return getToken(MySqlParser.ONLINE, 0); }
		public TerminalNode OFFLINE() { return getToken(MySqlParser.OFFLINE, 0); }
		public List DEFAULT() { return getTokens(MySqlParser.DEFAULT); }
		public TerminalNode DEFAULT(int i) {
			return getToken(MySqlParser.DEFAULT, i);
		}
		public List INPLACE() { return getTokens(MySqlParser.INPLACE); }
		public TerminalNode INPLACE(int i) {
			return getToken(MySqlParser.INPLACE, i);
		}
		public List COPY() { return getTokens(MySqlParser.COPY); }
		public TerminalNode COPY(int i) {
			return getToken(MySqlParser.COPY, i);
		}
		public List NONE() { return getTokens(MySqlParser.NONE); }
		public TerminalNode NONE(int i) {
			return getToken(MySqlParser.NONE, i);
		}
		public List SHARED() { return getTokens(MySqlParser.SHARED); }
		public TerminalNode SHARED(int i) {
			return getToken(MySqlParser.SHARED, i);
		}
		public List EXCLUSIVE() { return getTokens(MySqlParser.EXCLUSIVE); }
		public TerminalNode EXCLUSIVE(int i) {
			return getToken(MySqlParser.EXCLUSIVE, i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public DropIndexContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropIndex; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropIndex(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropIndex(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropIndex(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropIndexContext dropIndex() throws RecognitionException {
		DropIndexContext _localctx = new DropIndexContext(_ctx, getState());
		enterRule(_localctx, 156, RULE_dropIndex);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(2993);
			match(DROP);
			setState(2994);
			match(INDEX);
			setState(2996);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,384,_ctx) ) {
			case 1:
				{
				setState(2995);
				((DropIndexContext)_localctx).intimeAction = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==OFFLINE || _la==ONLINE) ) {
					((DropIndexContext)_localctx).intimeAction = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
			setState(2998);
			uid();
			setState(2999);
			match(ON);
			setState(3000);
			tableName();
			setState(3013);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,388,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					setState(3011);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case ALGORITHM:
						{
						setState(3001);
						match(ALGORITHM);
						setState(3003);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(3002);
							match(EQUAL_SYMBOL);
							}
						}

						setState(3005);
						((DropIndexContext)_localctx).algType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==DEFAULT || _la==COPY || _la==INPLACE) ) {
							((DropIndexContext)_localctx).algType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						break;
					case LOCK:
						{
						setState(3006);
						match(LOCK);
						setState(3008);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==EQUAL_SYMBOL) {
							{
							setState(3007);
							match(EQUAL_SYMBOL);
							}
						}

						setState(3010);
						((DropIndexContext)_localctx).lockType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==DEFAULT || _la==EXCLUSIVE || _la==NONE || _la==SHARED) ) {
							((DropIndexContext)_localctx).lockType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					} 
				}
				setState(3015);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,388,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropLogfileGroupContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode LOGFILE() { return getToken(MySqlParser.LOGFILE, 0); }
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public DropLogfileGroupContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropLogfileGroup; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropLogfileGroup(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropLogfileGroup(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropLogfileGroup(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropLogfileGroupContext dropLogfileGroup() throws RecognitionException {
		DropLogfileGroupContext _localctx = new DropLogfileGroupContext(_ctx, getState());
		enterRule(_localctx, 158, RULE_dropLogfileGroup);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3016);
			match(DROP);
			setState(3017);
			match(LOGFILE);
			setState(3018);
			match(GROUP);
			setState(3019);
			uid();
			setState(3020);
			match(ENGINE);
			setState(3021);
			match(EQUAL_SYMBOL);
			setState(3022);
			engineName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropProcedureContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DropProcedureContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropProcedure; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropProcedure(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropProcedure(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropProcedure(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropProcedureContext dropProcedure() throws RecognitionException {
		DropProcedureContext _localctx = new DropProcedureContext(_ctx, getState());
		enterRule(_localctx, 160, RULE_dropProcedure);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3024);
			match(DROP);
			setState(3025);
			match(PROCEDURE);
			setState(3027);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,389,_ctx) ) {
			case 1:
				{
				setState(3026);
				ifExists();
				}
				break;
			}
			setState(3029);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropFunctionContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DropFunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropFunction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropFunction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropFunction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropFunctionContext dropFunction() throws RecognitionException {
		DropFunctionContext _localctx = new DropFunctionContext(_ctx, getState());
		enterRule(_localctx, 162, RULE_dropFunction);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3031);
			match(DROP);
			setState(3032);
			match(FUNCTION);
			setState(3034);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,390,_ctx) ) {
			case 1:
				{
				setState(3033);
				ifExists();
				}
				break;
			}
			setState(3036);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropServerContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode SERVER() { return getToken(MySqlParser.SERVER, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DropServerContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropServer; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropServer(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropServer(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropServer(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropServerContext dropServer() throws RecognitionException {
		DropServerContext _localctx = new DropServerContext(_ctx, getState());
		enterRule(_localctx, 164, RULE_dropServer);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3038);
			match(DROP);
			setState(3039);
			match(SERVER);
			setState(3041);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,391,_ctx) ) {
			case 1:
				{
				setState(3040);
				ifExists();
				}
				break;
			}
			setState(3043);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropTableContext extends ParserRuleContext {
		public Token dropType;
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode TEMPORARY() { return getToken(MySqlParser.TEMPORARY, 0); }
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public TerminalNode RESTRICT() { return getToken(MySqlParser.RESTRICT, 0); }
		public TerminalNode CASCADE() { return getToken(MySqlParser.CASCADE, 0); }
		public DropTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropTableContext dropTable() throws RecognitionException {
		DropTableContext _localctx = new DropTableContext(_ctx, getState());
		enterRule(_localctx, 166, RULE_dropTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3045);
			match(DROP);
			setState(3047);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==TEMPORARY) {
				{
				setState(3046);
				match(TEMPORARY);
				}
			}

			setState(3049);
			match(TABLE);
			setState(3051);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,393,_ctx) ) {
			case 1:
				{
				setState(3050);
				ifExists();
				}
				break;
			}
			setState(3053);
			tables();
			setState(3055);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CASCADE || _la==RESTRICT) {
				{
				setState(3054);
				((DropTableContext)_localctx).dropType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CASCADE || _la==RESTRICT) ) {
					((DropTableContext)_localctx).dropType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropTablespaceContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public DropTablespaceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropTablespace; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropTablespace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropTablespace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropTablespace(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropTablespaceContext dropTablespace() throws RecognitionException {
		DropTablespaceContext _localctx = new DropTablespaceContext(_ctx, getState());
		enterRule(_localctx, 168, RULE_dropTablespace);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3057);
			match(DROP);
			setState(3058);
			match(TABLESPACE);
			setState(3059);
			uid();
			setState(3065);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ENGINE) {
				{
				setState(3060);
				match(ENGINE);
				setState(3062);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EQUAL_SYMBOL) {
					{
					setState(3061);
					match(EQUAL_SYMBOL);
					}
				}

				setState(3064);
				engineName();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropTriggerContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode TRIGGER() { return getToken(MySqlParser.TRIGGER, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public DropTriggerContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropTrigger; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropTrigger(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropTrigger(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropTrigger(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropTriggerContext dropTrigger() throws RecognitionException {
		DropTriggerContext _localctx = new DropTriggerContext(_ctx, getState());
		enterRule(_localctx, 170, RULE_dropTrigger);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3067);
			match(DROP);
			setState(3068);
			match(TRIGGER);
			setState(3070);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,397,_ctx) ) {
			case 1:
				{
				setState(3069);
				ifExists();
				}
				break;
			}
			setState(3072);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropViewContext extends ParserRuleContext {
		public Token dropType;
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode VIEW() { return getToken(MySqlParser.VIEW, 0); }
		public List fullId() {
			return getRuleContexts(FullIdContext.class);
		}
		public FullIdContext fullId(int i) {
			return getRuleContext(FullIdContext.class,i);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode RESTRICT() { return getToken(MySqlParser.RESTRICT, 0); }
		public TerminalNode CASCADE() { return getToken(MySqlParser.CASCADE, 0); }
		public DropViewContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropView; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropView(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropView(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropView(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropViewContext dropView() throws RecognitionException {
		DropViewContext _localctx = new DropViewContext(_ctx, getState());
		enterRule(_localctx, 172, RULE_dropView);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3074);
			match(DROP);
			setState(3075);
			match(VIEW);
			setState(3077);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,398,_ctx) ) {
			case 1:
				{
				setState(3076);
				ifExists();
				}
				break;
			}
			setState(3079);
			fullId();
			setState(3084);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3080);
				match(COMMA);
				setState(3081);
				fullId();
				}
				}
				setState(3086);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(3088);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CASCADE || _la==RESTRICT) {
				{
				setState(3087);
				((DropViewContext)_localctx).dropType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CASCADE || _la==RESTRICT) ) {
					((DropViewContext)_localctx).dropType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropRoleContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public List roleName() {
			return getRuleContexts(RoleNameContext.class);
		}
		public RoleNameContext roleName(int i) {
			return getRuleContext(RoleNameContext.class,i);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public DropRoleContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropRole; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropRole(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropRole(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropRole(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropRoleContext dropRole() throws RecognitionException {
		DropRoleContext _localctx = new DropRoleContext(_ctx, getState());
		enterRule(_localctx, 174, RULE_dropRole);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3090);
			match(DROP);
			setState(3091);
			match(ROLE);
			setState(3093);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,401,_ctx) ) {
			case 1:
				{
				setState(3092);
				ifExists();
				}
				break;
			}
			setState(3095);
			roleName();
			setState(3100);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3096);
				match(COMMA);
				setState(3097);
				roleName();
				}
				}
				setState(3102);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SetRoleContext extends ParserRuleContext {
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public List roleName() {
			return getRuleContexts(RoleNameContext.class);
		}
		public RoleNameContext roleName(int i) {
			return getRuleContext(RoleNameContext.class,i);
		}
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RoleOptionContext roleOption() {
			return getRuleContext(RoleOptionContext.class,0);
		}
		public SetRoleContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_setRole; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetRole(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetRole(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetRole(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SetRoleContext setRole() throws RecognitionException {
		SetRoleContext _localctx = new SetRoleContext(_ctx, getState());
		enterRule(_localctx, 176, RULE_setRole);
		int _la;
		try {
			setState(3136);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,408,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3103);
				match(SET);
				setState(3104);
				match(DEFAULT);
				setState(3105);
				match(ROLE);
				setState(3116);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,404,_ctx) ) {
				case 1:
					{
					setState(3106);
					match(NONE);
					}
					break;
				case 2:
					{
					setState(3107);
					match(ALL);
					}
					break;
				case 3:
					{
					setState(3108);
					roleName();
					setState(3113);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(3109);
						match(COMMA);
						setState(3110);
						roleName();
						}
						}
						setState(3115);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
					break;
				}
				setState(3118);
				match(TO);
				setState(3121);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,405,_ctx) ) {
				case 1:
					{
					setState(3119);
					userName();
					}
					break;
				case 2:
					{
					setState(3120);
					uid();
					}
					break;
				}
				setState(3130);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3123);
					match(COMMA);
					setState(3126);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,406,_ctx) ) {
					case 1:
						{
						setState(3124);
						userName();
						}
						break;
					case 2:
						{
						setState(3125);
						uid();
						}
						break;
					}
					}
					}
					setState(3132);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3133);
				match(SET);
				setState(3134);
				match(ROLE);
				setState(3135);
				roleOption();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RenameTableContext extends ParserRuleContext {
		public TerminalNode RENAME() { return getToken(MySqlParser.RENAME, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public List renameTableClause() {
			return getRuleContexts(RenameTableClauseContext.class);
		}
		public RenameTableClauseContext renameTableClause(int i) {
			return getRuleContext(RenameTableClauseContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RenameTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_renameTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRenameTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRenameTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRenameTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RenameTableContext renameTable() throws RecognitionException {
		RenameTableContext _localctx = new RenameTableContext(_ctx, getState());
		enterRule(_localctx, 178, RULE_renameTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3138);
			match(RENAME);
			setState(3139);
			match(TABLE);
			setState(3140);
			renameTableClause();
			setState(3145);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3141);
				match(COMMA);
				setState(3142);
				renameTableClause();
				}
				}
				setState(3147);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RenameTableClauseContext extends ParserRuleContext {
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public RenameTableClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_renameTableClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRenameTableClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRenameTableClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRenameTableClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RenameTableClauseContext renameTableClause() throws RecognitionException {
		RenameTableClauseContext _localctx = new RenameTableClauseContext(_ctx, getState());
		enterRule(_localctx, 180, RULE_renameTableClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3148);
			tableName();
			setState(3149);
			match(TO);
			setState(3150);
			tableName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TruncateTableContext extends ParserRuleContext {
		public TerminalNode TRUNCATE() { return getToken(MySqlParser.TRUNCATE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TruncateTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_truncateTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTruncateTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTruncateTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTruncateTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TruncateTableContext truncateTable() throws RecognitionException {
		TruncateTableContext _localctx = new TruncateTableContext(_ctx, getState());
		enterRule(_localctx, 182, RULE_truncateTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3152);
			match(TRUNCATE);
			setState(3154);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==TABLE) {
				{
				setState(3153);
				match(TABLE);
				}
			}

			setState(3156);
			tableName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CallStatementContext extends ParserRuleContext {
		public TerminalNode CALL() { return getToken(MySqlParser.CALL, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public ConstantsContext constants() {
			return getRuleContext(ConstantsContext.class,0);
		}
		public ExpressionsContext expressions() {
			return getRuleContext(ExpressionsContext.class,0);
		}
		public CallStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_callStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCallStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCallStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCallStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CallStatementContext callStatement() throws RecognitionException {
		CallStatementContext _localctx = new CallStatementContext(_ctx, getState());
		enterRule(_localctx, 184, RULE_callStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3158);
			match(CALL);
			setState(3159);
			fullId();
			setState(3166);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,412,_ctx) ) {
			case 1:
				{
				setState(3160);
				match(LR_BRACKET);
				setState(3163);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,411,_ctx) ) {
				case 1:
					{
					setState(3161);
					constants();
					}
					break;
				case 2:
					{
					setState(3162);
					expressions();
					}
					break;
				}
				setState(3165);
				match(RR_BRACKET);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DeleteStatementContext extends ParserRuleContext {
		public SingleDeleteStatementContext singleDeleteStatement() {
			return getRuleContext(SingleDeleteStatementContext.class,0);
		}
		public MultipleDeleteStatementContext multipleDeleteStatement() {
			return getRuleContext(MultipleDeleteStatementContext.class,0);
		}
		public DeleteStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_deleteStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDeleteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDeleteStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDeleteStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DeleteStatementContext deleteStatement() throws RecognitionException {
		DeleteStatementContext _localctx = new DeleteStatementContext(_ctx, getState());
		enterRule(_localctx, 186, RULE_deleteStatement);
		try {
			setState(3170);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,413,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3168);
				singleDeleteStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3169);
				multipleDeleteStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DoStatementContext extends ParserRuleContext {
		public TerminalNode DO() { return getToken(MySqlParser.DO, 0); }
		public ExpressionsContext expressions() {
			return getRuleContext(ExpressionsContext.class,0);
		}
		public DoStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_doStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDoStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDoStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDoStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DoStatementContext doStatement() throws RecognitionException {
		DoStatementContext _localctx = new DoStatementContext(_ctx, getState());
		enterRule(_localctx, 188, RULE_doStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3172);
			match(DO);
			setState(3173);
			expressions();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HandlerStatementContext extends ParserRuleContext {
		public HandlerOpenStatementContext handlerOpenStatement() {
			return getRuleContext(HandlerOpenStatementContext.class,0);
		}
		public HandlerReadIndexStatementContext handlerReadIndexStatement() {
			return getRuleContext(HandlerReadIndexStatementContext.class,0);
		}
		public HandlerReadStatementContext handlerReadStatement() {
			return getRuleContext(HandlerReadStatementContext.class,0);
		}
		public HandlerCloseStatementContext handlerCloseStatement() {
			return getRuleContext(HandlerCloseStatementContext.class,0);
		}
		public HandlerStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_handlerStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HandlerStatementContext handlerStatement() throws RecognitionException {
		HandlerStatementContext _localctx = new HandlerStatementContext(_ctx, getState());
		enterRule(_localctx, 190, RULE_handlerStatement);
		try {
			setState(3179);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,414,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3175);
				handlerOpenStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3176);
				handlerReadIndexStatement();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(3177);
				handlerReadStatement();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(3178);
				handlerCloseStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class InsertStatementContext extends ParserRuleContext {
		public Token priority;
		public UidListContext partitions;
		public FullColumnNameListContext columns;
		public UpdatedElementContext setFirst;
		public UpdatedElementContext updatedElement;
		public List setElements = new ArrayList();
		public UpdatedElementContext duplicatedFirst;
		public List duplicatedElements = new ArrayList();
		public TerminalNode INSERT() { return getToken(MySqlParser.INSERT, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public InsertStatementValueContext insertStatementValue() {
			return getRuleContext(InsertStatementValueContext.class,0);
		}
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode DUPLICATE() { return getToken(MySqlParser.DUPLICATE, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public TerminalNode DELAYED() { return getToken(MySqlParser.DELAYED, 0); }
		public TerminalNode HIGH_PRIORITY() { return getToken(MySqlParser.HIGH_PRIORITY, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public FullColumnNameListContext fullColumnNameList() {
			return getRuleContext(FullColumnNameListContext.class,0);
		}
		public InsertStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_insertStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterInsertStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitInsertStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitInsertStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final InsertStatementContext insertStatement() throws RecognitionException {
		InsertStatementContext _localctx = new InsertStatementContext(_ctx, getState());
		enterRule(_localctx, 192, RULE_insertStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3181);
			match(INSERT);
			setState(3183);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (((((_la - 43)) & ~0x3f) == 0 && ((1L << (_la - 43)) & -9223372032559808511L) != 0)) {
				{
				setState(3182);
				((InsertStatementContext)_localctx).priority = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 43)) & ~0x3f) == 0 && ((1L << (_la - 43)) & -9223372032559808511L) != 0)) ) {
					((InsertStatementContext)_localctx).priority = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3186);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3185);
				match(IGNORE);
				}
			}

			setState(3189);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INTO) {
				{
				setState(3188);
				match(INTO);
				}
			}

			setState(3191);
			tableName();
			setState(3198);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3192);
				match(PARTITION);
				setState(3193);
				match(LR_BRACKET);
				setState(3195);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(3194);
					((InsertStatementContext)_localctx).partitions = uidList();
					}
				}

				setState(3197);
				match(RR_BRACKET);
				}
			}

			setState(3223);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
			case VALUES:
			case VALUE:
			case LR_BRACKET:
				{
				setState(3205);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,421,_ctx) ) {
				case 1:
					{
					setState(3200);
					match(LR_BRACKET);
					setState(3202);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,420,_ctx) ) {
					case 1:
						{
						setState(3201);
						((InsertStatementContext)_localctx).columns = fullColumnNameList();
						}
						break;
					}
					setState(3204);
					match(RR_BRACKET);
					}
					break;
				}
				setState(3207);
				insertStatementValue();
				setState(3212);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,423,_ctx) ) {
				case 1:
					{
					setState(3209);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(3208);
						match(AS);
						}
					}

					setState(3211);
					uid();
					}
					break;
				}
				}
				break;
			case SET:
				{
				setState(3214);
				match(SET);
				setState(3215);
				((InsertStatementContext)_localctx).setFirst = updatedElement();
				setState(3220);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3216);
					match(COMMA);
					setState(3217);
					((InsertStatementContext)_localctx).updatedElement = updatedElement();
					((InsertStatementContext)_localctx).setElements.add(((InsertStatementContext)_localctx).updatedElement);
					}
					}
					setState(3222);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(3237);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ON) {
				{
				setState(3225);
				match(ON);
				setState(3226);
				match(DUPLICATE);
				setState(3227);
				match(KEY);
				setState(3228);
				match(UPDATE);
				setState(3229);
				((InsertStatementContext)_localctx).duplicatedFirst = updatedElement();
				setState(3234);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3230);
					match(COMMA);
					setState(3231);
					((InsertStatementContext)_localctx).updatedElement = updatedElement();
					((InsertStatementContext)_localctx).duplicatedElements.add(((InsertStatementContext)_localctx).updatedElement);
					}
					}
					setState(3236);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LoadDataStatementContext extends ParserRuleContext {
		public Token priority;
		public Token filename;
		public Token violation;
		public CharsetNameContext charset;
		public Token fieldsFormat;
		public Token linesFormat;
		public TerminalNode LOAD() { return getToken(MySqlParser.LOAD, 0); }
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode INFILE() { return getToken(MySqlParser.INFILE, 0); }
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public List SET() { return getTokens(MySqlParser.SET); }
		public TerminalNode SET(int i) {
			return getToken(MySqlParser.SET, i);
		}
		public List LINES() { return getTokens(MySqlParser.LINES); }
		public TerminalNode LINES(int i) {
			return getToken(MySqlParser.LINES, i);
		}
		public List IGNORE() { return getTokens(MySqlParser.IGNORE); }
		public TerminalNode IGNORE(int i) {
			return getToken(MySqlParser.IGNORE, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public List assignmentField() {
			return getRuleContexts(AssignmentFieldContext.class);
		}
		public AssignmentFieldContext assignmentField(int i) {
			return getRuleContext(AssignmentFieldContext.class,i);
		}
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public TerminalNode CONCURRENT() { return getToken(MySqlParser.CONCURRENT, 0); }
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public TerminalNode FIELDS() { return getToken(MySqlParser.FIELDS, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public TerminalNode ROWS() { return getToken(MySqlParser.ROWS, 0); }
		public List selectFieldsInto() {
			return getRuleContexts(SelectFieldsIntoContext.class);
		}
		public SelectFieldsIntoContext selectFieldsInto(int i) {
			return getRuleContext(SelectFieldsIntoContext.class,i);
		}
		public List selectLinesInto() {
			return getRuleContexts(SelectLinesIntoContext.class);
		}
		public SelectLinesIntoContext selectLinesInto(int i) {
			return getRuleContext(SelectLinesIntoContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public LoadDataStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_loadDataStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLoadDataStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLoadDataStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLoadDataStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LoadDataStatementContext loadDataStatement() throws RecognitionException {
		LoadDataStatementContext _localctx = new LoadDataStatementContext(_ctx, getState());
		enterRule(_localctx, 194, RULE_loadDataStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3239);
			match(LOAD);
			setState(3240);
			match(DATA);
			setState(3242);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY || _la==CONCURRENT) {
				{
				setState(3241);
				((LoadDataStatementContext)_localctx).priority = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==LOW_PRIORITY || _la==CONCURRENT) ) {
					((LoadDataStatementContext)_localctx).priority = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3245);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL) {
				{
				setState(3244);
				match(LOCAL);
				}
			}

			setState(3247);
			match(INFILE);
			setState(3248);
			((LoadDataStatementContext)_localctx).filename = match(STRING_LITERAL);
			setState(3250);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE || _la==REPLACE) {
				{
				setState(3249);
				((LoadDataStatementContext)_localctx).violation = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==IGNORE || _la==REPLACE) ) {
					((LoadDataStatementContext)_localctx).violation = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3252);
			match(INTO);
			setState(3253);
			match(TABLE);
			setState(3254);
			tableName();
			setState(3260);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3255);
				match(PARTITION);
				setState(3256);
				match(LR_BRACKET);
				setState(3257);
				uidList();
				setState(3258);
				match(RR_BRACKET);
				}
			}

			setState(3265);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CHARACTER) {
				{
				setState(3262);
				match(CHARACTER);
				setState(3263);
				match(SET);
				setState(3264);
				((LoadDataStatementContext)_localctx).charset = charsetName();
				}
			}

			setState(3273);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COLUMNS || _la==FIELDS) {
				{
				setState(3267);
				((LoadDataStatementContext)_localctx).fieldsFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==COLUMNS || _la==FIELDS) ) {
					((LoadDataStatementContext)_localctx).fieldsFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(3269); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(3268);
					selectFieldsInto();
					}
					}
					setState(3271); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==ENCLOSED || _la==ESCAPED || _la==OPTIONALLY || _la==TERMINATED );
				}
			}

			setState(3281);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LINES) {
				{
				setState(3275);
				match(LINES);
				setState(3277); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(3276);
					selectLinesInto();
					}
					}
					setState(3279); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==STARTING || _la==TERMINATED );
				}
			}

			setState(3287);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3283);
				match(IGNORE);
				setState(3284);
				decimalLiteral();
				setState(3285);
				((LoadDataStatementContext)_localctx).linesFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==LINES || _la==ROWS) ) {
					((LoadDataStatementContext)_localctx).linesFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3300);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,439,_ctx) ) {
			case 1:
				{
				setState(3289);
				match(LR_BRACKET);
				setState(3290);
				assignmentField();
				setState(3295);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3291);
					match(COMMA);
					setState(3292);
					assignmentField();
					}
					}
					setState(3297);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3298);
				match(RR_BRACKET);
				}
				break;
			}
			setState(3311);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,441,_ctx) ) {
			case 1:
				{
				setState(3302);
				match(SET);
				setState(3303);
				updatedElement();
				setState(3308);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3304);
					match(COMMA);
					setState(3305);
					updatedElement();
					}
					}
					setState(3310);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LoadXmlStatementContext extends ParserRuleContext {
		public Token priority;
		public Token filename;
		public Token violation;
		public CharsetNameContext charset;
		public Token tag;
		public Token linesFormat;
		public TerminalNode LOAD() { return getToken(MySqlParser.LOAD, 0); }
		public TerminalNode XML() { return getToken(MySqlParser.XML, 0); }
		public TerminalNode INFILE() { return getToken(MySqlParser.INFILE, 0); }
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public List SET() { return getTokens(MySqlParser.SET); }
		public TerminalNode SET(int i) {
			return getToken(MySqlParser.SET, i);
		}
		public List ROWS() { return getTokens(MySqlParser.ROWS); }
		public TerminalNode ROWS(int i) {
			return getToken(MySqlParser.ROWS, i);
		}
		public TerminalNode IDENTIFIED() { return getToken(MySqlParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode LESS_SYMBOL() { return getToken(MySqlParser.LESS_SYMBOL, 0); }
		public TerminalNode GREATER_SYMBOL() { return getToken(MySqlParser.GREATER_SYMBOL, 0); }
		public List IGNORE() { return getTokens(MySqlParser.IGNORE); }
		public TerminalNode IGNORE(int i) {
			return getToken(MySqlParser.IGNORE, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List assignmentField() {
			return getRuleContexts(AssignmentFieldContext.class);
		}
		public AssignmentFieldContext assignmentField(int i) {
			return getRuleContext(AssignmentFieldContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public TerminalNode CONCURRENT() { return getToken(MySqlParser.CONCURRENT, 0); }
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public TerminalNode LINES() { return getToken(MySqlParser.LINES, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public LoadXmlStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_loadXmlStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLoadXmlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLoadXmlStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLoadXmlStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LoadXmlStatementContext loadXmlStatement() throws RecognitionException {
		LoadXmlStatementContext _localctx = new LoadXmlStatementContext(_ctx, getState());
		enterRule(_localctx, 196, RULE_loadXmlStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3313);
			match(LOAD);
			setState(3314);
			match(XML);
			setState(3316);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY || _la==CONCURRENT) {
				{
				setState(3315);
				((LoadXmlStatementContext)_localctx).priority = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==LOW_PRIORITY || _la==CONCURRENT) ) {
					((LoadXmlStatementContext)_localctx).priority = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3319);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOCAL) {
				{
				setState(3318);
				match(LOCAL);
				}
			}

			setState(3321);
			match(INFILE);
			setState(3322);
			((LoadXmlStatementContext)_localctx).filename = match(STRING_LITERAL);
			setState(3324);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE || _la==REPLACE) {
				{
				setState(3323);
				((LoadXmlStatementContext)_localctx).violation = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==IGNORE || _la==REPLACE) ) {
					((LoadXmlStatementContext)_localctx).violation = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3326);
			match(INTO);
			setState(3327);
			match(TABLE);
			setState(3328);
			tableName();
			setState(3332);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CHARACTER) {
				{
				setState(3329);
				match(CHARACTER);
				setState(3330);
				match(SET);
				setState(3331);
				((LoadXmlStatementContext)_localctx).charset = charsetName();
				}
			}

			setState(3340);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ROWS) {
				{
				setState(3334);
				match(ROWS);
				setState(3335);
				match(IDENTIFIED);
				setState(3336);
				match(BY);
				setState(3337);
				match(LESS_SYMBOL);
				setState(3338);
				((LoadXmlStatementContext)_localctx).tag = match(STRING_LITERAL);
				setState(3339);
				match(GREATER_SYMBOL);
				}
			}

			setState(3346);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3342);
				match(IGNORE);
				setState(3343);
				decimalLiteral();
				setState(3344);
				((LoadXmlStatementContext)_localctx).linesFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==LINES || _la==ROWS) ) {
					((LoadXmlStatementContext)_localctx).linesFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3359);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,449,_ctx) ) {
			case 1:
				{
				setState(3348);
				match(LR_BRACKET);
				setState(3349);
				assignmentField();
				setState(3354);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3350);
					match(COMMA);
					setState(3351);
					assignmentField();
					}
					}
					setState(3356);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3357);
				match(RR_BRACKET);
				}
				break;
			}
			setState(3370);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,451,_ctx) ) {
			case 1:
				{
				setState(3361);
				match(SET);
				setState(3362);
				updatedElement();
				setState(3367);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3363);
					match(COMMA);
					setState(3364);
					updatedElement();
					}
					}
					setState(3369);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReplaceStatementContext extends ParserRuleContext {
		public Token priority;
		public UidListContext partitions;
		public UidListContext columns;
		public UpdatedElementContext setFirst;
		public UpdatedElementContext updatedElement;
		public List setElements = new ArrayList();
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public InsertStatementValueContext insertStatementValue() {
			return getRuleContext(InsertStatementValueContext.class,0);
		}
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public List uidList() {
			return getRuleContexts(UidListContext.class);
		}
		public UidListContext uidList(int i) {
			return getRuleContext(UidListContext.class,i);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public TerminalNode DELAYED() { return getToken(MySqlParser.DELAYED, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ReplaceStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_replaceStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReplaceStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReplaceStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReplaceStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReplaceStatementContext replaceStatement() throws RecognitionException {
		ReplaceStatementContext _localctx = new ReplaceStatementContext(_ctx, getState());
		enterRule(_localctx, 198, RULE_replaceStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3372);
			match(REPLACE);
			setState(3374);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DELAYED || _la==LOW_PRIORITY) {
				{
				setState(3373);
				((ReplaceStatementContext)_localctx).priority = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DELAYED || _la==LOW_PRIORITY) ) {
					((ReplaceStatementContext)_localctx).priority = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3377);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INTO) {
				{
				setState(3376);
				match(INTO);
				}
			}

			setState(3379);
			tableName();
			setState(3385);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3380);
				match(PARTITION);
				setState(3381);
				match(LR_BRACKET);
				setState(3382);
				((ReplaceStatementContext)_localctx).partitions = uidList();
				setState(3383);
				match(RR_BRACKET);
				}
			}

			setState(3403);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
			case VALUES:
			case VALUE:
			case LR_BRACKET:
				{
				setState(3391);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,455,_ctx) ) {
				case 1:
					{
					setState(3387);
					match(LR_BRACKET);
					setState(3388);
					((ReplaceStatementContext)_localctx).columns = uidList();
					setState(3389);
					match(RR_BRACKET);
					}
					break;
				}
				setState(3393);
				insertStatementValue();
				}
				break;
			case SET:
				{
				setState(3394);
				match(SET);
				setState(3395);
				((ReplaceStatementContext)_localctx).setFirst = updatedElement();
				setState(3400);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3396);
					match(COMMA);
					setState(3397);
					((ReplaceStatementContext)_localctx).updatedElement = updatedElement();
					((ReplaceStatementContext)_localctx).setElements.add(((ReplaceStatementContext)_localctx).updatedElement);
					}
					}
					setState(3402);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectStatementContext extends ParserRuleContext {
		public SelectStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectStatement; }
	 
		public SelectStatementContext() { }
		public void copyFrom(SelectStatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UnionSelectContext extends SelectStatementContext {
		public Token unionType;
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public List unionStatement() {
			return getRuleContexts(UnionStatementContext.class);
		}
		public UnionStatementContext unionStatement(int i) {
			return getRuleContext(UnionStatementContext.class,i);
		}
		public TerminalNode UNION() { return getToken(MySqlParser.UNION, 0); }
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public LockClauseContext lockClause() {
			return getRuleContext(LockClauseContext.class,0);
		}
		public QuerySpecificationContext querySpecification() {
			return getRuleContext(QuerySpecificationContext.class,0);
		}
		public QueryExpressionContext queryExpression() {
			return getRuleContext(QueryExpressionContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MySqlParser.DISTINCT, 0); }
		public UnionSelectContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnionSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnionSelect(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnionSelect(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UnionParenthesisSelectContext extends SelectStatementContext {
		public Token unionType;
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public List unionParenthesis() {
			return getRuleContexts(UnionParenthesisContext.class);
		}
		public UnionParenthesisContext unionParenthesis(int i) {
			return getRuleContext(UnionParenthesisContext.class,i);
		}
		public TerminalNode UNION() { return getToken(MySqlParser.UNION, 0); }
		public QueryExpressionContext queryExpression() {
			return getRuleContext(QueryExpressionContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public LockClauseContext lockClause() {
			return getRuleContext(LockClauseContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MySqlParser.DISTINCT, 0); }
		public UnionParenthesisSelectContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnionParenthesisSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnionParenthesisSelect(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnionParenthesisSelect(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SimpleSelectContext extends SelectStatementContext {
		public QuerySpecificationContext querySpecification() {
			return getRuleContext(QuerySpecificationContext.class,0);
		}
		public LockClauseContext lockClause() {
			return getRuleContext(LockClauseContext.class,0);
		}
		public SimpleSelectContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleSelect(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleSelect(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ParenthesisSelectContext extends SelectStatementContext {
		public QueryExpressionContext queryExpression() {
			return getRuleContext(QueryExpressionContext.class,0);
		}
		public LockClauseContext lockClause() {
			return getRuleContext(LockClauseContext.class,0);
		}
		public ParenthesisSelectContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterParenthesisSelect(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitParenthesisSelect(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitParenthesisSelect(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class WithLateralStatementContext extends SelectStatementContext {
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List lateralStatement() {
			return getRuleContexts(LateralStatementContext.class);
		}
		public LateralStatementContext lateralStatement(int i) {
			return getRuleContext(LateralStatementContext.class,i);
		}
		public WithLateralStatementContext(SelectStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWithLateralStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWithLateralStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWithLateralStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectStatementContext selectStatement() throws RecognitionException {
		SelectStatementContext _localctx = new SelectStatementContext(_ctx, getState());
		enterRule(_localctx, 200, RULE_selectStatement);
		int _la;
		try {
			int _alt;
			setState(3470);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,475,_ctx) ) {
			case 1:
				_localctx = new SimpleSelectContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3405);
				querySpecification();
				setState(3407);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,458,_ctx) ) {
				case 1:
					{
					setState(3406);
					lockClause();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new ParenthesisSelectContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3409);
				queryExpression();
				setState(3411);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,459,_ctx) ) {
				case 1:
					{
					setState(3410);
					lockClause();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new UnionSelectContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3415);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SELECT:
					{
					setState(3413);
					querySpecificationNointo();
					}
					break;
				case LR_BRACKET:
					{
					setState(3414);
					queryExpressionNointo();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(3418); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(3417);
						unionStatement();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(3420); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,461,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(3430);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==UNION) {
					{
					setState(3422);
					match(UNION);
					setState(3424);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==ALL || _la==DISTINCT) {
						{
						setState(3423);
						((UnionSelectContext)_localctx).unionType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==ALL || _la==DISTINCT) ) {
							((UnionSelectContext)_localctx).unionType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
					}

					setState(3428);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case SELECT:
						{
						setState(3426);
						querySpecification();
						}
						break;
					case LR_BRACKET:
						{
						setState(3427);
						queryExpression();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
				}

				setState(3433);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,465,_ctx) ) {
				case 1:
					{
					setState(3432);
					orderByClause();
					}
					break;
				}
				setState(3436);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(3435);
					limitClause();
					}
				}

				setState(3439);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,467,_ctx) ) {
				case 1:
					{
					setState(3438);
					lockClause();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new UnionParenthesisSelectContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(3441);
				queryExpressionNointo();
				setState(3443); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(3442);
						unionParenthesis();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(3445); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,468,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				setState(3452);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==UNION) {
					{
					setState(3447);
					match(UNION);
					setState(3449);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==ALL || _la==DISTINCT) {
						{
						setState(3448);
						((UnionParenthesisSelectContext)_localctx).unionType = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==ALL || _la==DISTINCT) ) {
							((UnionParenthesisSelectContext)_localctx).unionType = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
					}

					setState(3451);
					queryExpression();
					}
				}

				setState(3455);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,471,_ctx) ) {
				case 1:
					{
					setState(3454);
					orderByClause();
					}
					break;
				}
				setState(3458);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(3457);
					limitClause();
					}
				}

				setState(3461);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,473,_ctx) ) {
				case 1:
					{
					setState(3460);
					lockClause();
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new WithLateralStatementContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(3463);
				querySpecificationNointo();
				setState(3466); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(3464);
					match(COMMA);
					setState(3465);
					lateralStatement();
					}
					}
					setState(3468); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==COMMA );
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UpdateStatementContext extends ParserRuleContext {
		public SingleUpdateStatementContext singleUpdateStatement() {
			return getRuleContext(SingleUpdateStatementContext.class,0);
		}
		public MultipleUpdateStatementContext multipleUpdateStatement() {
			return getRuleContext(MultipleUpdateStatementContext.class,0);
		}
		public UpdateStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_updateStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUpdateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUpdateStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUpdateStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UpdateStatementContext updateStatement() throws RecognitionException {
		UpdateStatementContext _localctx = new UpdateStatementContext(_ctx, getState());
		enterRule(_localctx, 202, RULE_updateStatement);
		try {
			setState(3474);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,476,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3472);
				singleUpdateStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3473);
				multipleUpdateStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ValuesStatementContext extends ParserRuleContext {
		public TerminalNode VALUES() { return getToken(MySqlParser.VALUES, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List expressionsWithDefaults() {
			return getRuleContexts(ExpressionsWithDefaultsContext.class);
		}
		public ExpressionsWithDefaultsContext expressionsWithDefaults(int i) {
			return getRuleContext(ExpressionsWithDefaultsContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ValuesStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_valuesStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterValuesStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitValuesStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitValuesStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ValuesStatementContext valuesStatement() throws RecognitionException {
		ValuesStatementContext _localctx = new ValuesStatementContext(_ctx, getState());
		enterRule(_localctx, 204, RULE_valuesStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3476);
			match(VALUES);
			setState(3477);
			match(LR_BRACKET);
			setState(3479);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,477,_ctx) ) {
			case 1:
				{
				setState(3478);
				expressionsWithDefaults();
				}
				break;
			}
			setState(3481);
			match(RR_BRACKET);
			setState(3490);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3482);
				match(COMMA);
				setState(3483);
				match(LR_BRACKET);
				setState(3485);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,478,_ctx) ) {
				case 1:
					{
					setState(3484);
					expressionsWithDefaults();
					}
					break;
				}
				setState(3487);
				match(RR_BRACKET);
				}
				}
				setState(3492);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class InsertStatementValueContext extends ParserRuleContext {
		public Token insertFormat;
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public TerminalNode VALUES() { return getToken(MySqlParser.VALUES, 0); }
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public List expressionsWithDefaults() {
			return getRuleContexts(ExpressionsWithDefaultsContext.class);
		}
		public ExpressionsWithDefaultsContext expressionsWithDefaults(int i) {
			return getRuleContext(ExpressionsWithDefaultsContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public InsertStatementValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_insertStatementValue; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterInsertStatementValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitInsertStatementValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitInsertStatementValue(this);
			else return visitor.visitChildren(this);
		}
	}

	public final InsertStatementValueContext insertStatementValue() throws RecognitionException {
		InsertStatementValueContext _localctx = new InsertStatementValueContext(_ctx, getState());
		enterRule(_localctx, 206, RULE_insertStatementValue);
		int _la;
		try {
			setState(3511);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
			case LR_BRACKET:
				enterOuterAlt(_localctx, 1);
				{
				setState(3493);
				selectStatement();
				}
				break;
			case VALUES:
			case VALUE:
				enterOuterAlt(_localctx, 2);
				{
				setState(3494);
				((InsertStatementValueContext)_localctx).insertFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==VALUES || _la==VALUE) ) {
					((InsertStatementValueContext)_localctx).insertFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(3495);
				match(LR_BRACKET);
				setState(3497);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,480,_ctx) ) {
				case 1:
					{
					setState(3496);
					expressionsWithDefaults();
					}
					break;
				}
				setState(3499);
				match(RR_BRACKET);
				setState(3508);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3500);
					match(COMMA);
					setState(3501);
					match(LR_BRACKET);
					setState(3503);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,481,_ctx) ) {
					case 1:
						{
						setState(3502);
						expressionsWithDefaults();
						}
						break;
					}
					setState(3505);
					match(RR_BRACKET);
					}
					}
					setState(3510);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UpdatedElementContext extends ParserRuleContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public UpdatedElementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_updatedElement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUpdatedElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUpdatedElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUpdatedElement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UpdatedElementContext updatedElement() throws RecognitionException {
		UpdatedElementContext _localctx = new UpdatedElementContext(_ctx, getState());
		enterRule(_localctx, 208, RULE_updatedElement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3513);
			fullColumnName();
			setState(3514);
			match(EQUAL_SYMBOL);
			setState(3517);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,484,_ctx) ) {
			case 1:
				{
				setState(3515);
				expression(0);
				}
				break;
			case 2:
				{
				setState(3516);
				match(DEFAULT);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AssignmentFieldContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public AssignmentFieldContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_assignmentField; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAssignmentField(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAssignmentField(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAssignmentField(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AssignmentFieldContext assignmentField() throws RecognitionException {
		AssignmentFieldContext _localctx = new AssignmentFieldContext(_ctx, getState());
		enterRule(_localctx, 210, RULE_assignmentField);
		try {
			setState(3521);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(3519);
				uid();
				}
				break;
			case LOCAL_ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(3520);
				match(LOCAL_ID);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LockClauseContext extends ParserRuleContext {
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public TerminalNode SHARE() { return getToken(MySqlParser.SHARE, 0); }
		public TerminalNode MODE() { return getToken(MySqlParser.MODE, 0); }
		public LockClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lockClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLockClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLockClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLockClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LockClauseContext lockClause() throws RecognitionException {
		LockClauseContext _localctx = new LockClauseContext(_ctx, getState());
		enterRule(_localctx, 212, RULE_lockClause);
		try {
			setState(3529);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FOR:
				enterOuterAlt(_localctx, 1);
				{
				setState(3523);
				match(FOR);
				setState(3524);
				match(UPDATE);
				}
				break;
			case LOCK:
				enterOuterAlt(_localctx, 2);
				{
				setState(3525);
				match(LOCK);
				setState(3526);
				match(IN);
				setState(3527);
				match(SHARE);
				setState(3528);
				match(MODE);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SingleDeleteStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode DELETE() { return getToken(MySqlParser.DELETE, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode QUICK() { return getToken(MySqlParser.QUICK, 0); }
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public LimitClauseAtomContext limitClauseAtom() {
			return getRuleContext(LimitClauseAtomContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SingleDeleteStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_singleDeleteStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSingleDeleteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSingleDeleteStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSingleDeleteStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SingleDeleteStatementContext singleDeleteStatement() throws RecognitionException {
		SingleDeleteStatementContext _localctx = new SingleDeleteStatementContext(_ctx, getState());
		enterRule(_localctx, 214, RULE_singleDeleteStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3531);
			match(DELETE);
			setState(3533);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY) {
				{
				setState(3532);
				((SingleDeleteStatementContext)_localctx).priority = match(LOW_PRIORITY);
				}
			}

			setState(3536);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==QUICK) {
				{
				setState(3535);
				match(QUICK);
				}
			}

			setState(3539);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3538);
				match(IGNORE);
				}
			}

			setState(3541);
			match(FROM);
			setState(3542);
			tableName();
			setState(3547);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,491,_ctx) ) {
			case 1:
				{
				setState(3544);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(3543);
					match(AS);
					}
				}

				setState(3546);
				uid();
				}
				break;
			}
			setState(3554);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(3549);
				match(PARTITION);
				setState(3550);
				match(LR_BRACKET);
				setState(3551);
				uidList();
				setState(3552);
				match(RR_BRACKET);
				}
			}

			setState(3558);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3556);
				match(WHERE);
				setState(3557);
				expression(0);
				}
			}

			setState(3561);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ORDER) {
				{
				setState(3560);
				orderByClause();
				}
			}

			setState(3565);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3563);
				match(LIMIT);
				setState(3564);
				limitClauseAtom();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class MultipleDeleteStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode DELETE() { return getToken(MySqlParser.DELETE, 0); }
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public TerminalNode QUICK() { return getToken(MySqlParser.QUICK, 0); }
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public List DOT() { return getTokens(MySqlParser.DOT); }
		public TerminalNode DOT(int i) {
			return getToken(MySqlParser.DOT, i);
		}
		public List STAR() { return getTokens(MySqlParser.STAR); }
		public TerminalNode STAR(int i) {
			return getToken(MySqlParser.STAR, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public MultipleDeleteStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleDeleteStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMultipleDeleteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMultipleDeleteStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMultipleDeleteStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleDeleteStatementContext multipleDeleteStatement() throws RecognitionException {
		MultipleDeleteStatementContext _localctx = new MultipleDeleteStatementContext(_ctx, getState());
		enterRule(_localctx, 216, RULE_multipleDeleteStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3567);
			match(DELETE);
			setState(3569);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY) {
				{
				setState(3568);
				((MultipleDeleteStatementContext)_localctx).priority = match(LOW_PRIORITY);
				}
			}

			setState(3572);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,497,_ctx) ) {
			case 1:
				{
				setState(3571);
				match(QUICK);
				}
				break;
			}
			setState(3575);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3574);
				match(IGNORE);
				}
			}

			setState(3616);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				{
				setState(3577);
				tableName();
				setState(3580);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DOT) {
					{
					setState(3578);
					match(DOT);
					setState(3579);
					match(STAR);
					}
				}

				setState(3590);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3582);
					match(COMMA);
					setState(3583);
					tableName();
					setState(3586);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==DOT) {
						{
						setState(3584);
						match(DOT);
						setState(3585);
						match(STAR);
						}
					}

					}
					}
					setState(3592);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3593);
				match(FROM);
				setState(3594);
				tableSources();
				}
				break;
			case FROM:
				{
				setState(3596);
				match(FROM);
				setState(3597);
				tableName();
				setState(3600);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DOT) {
					{
					setState(3598);
					match(DOT);
					setState(3599);
					match(STAR);
					}
				}

				setState(3610);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(3602);
					match(COMMA);
					setState(3603);
					tableName();
					setState(3606);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==DOT) {
						{
						setState(3604);
						match(DOT);
						setState(3605);
						match(STAR);
						}
					}

					}
					}
					setState(3612);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3613);
				match(USING);
				setState(3614);
				tableSources();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(3620);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3618);
				match(WHERE);
				setState(3619);
				expression(0);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HandlerOpenStatementContext extends ParserRuleContext {
		public TerminalNode HANDLER() { return getToken(MySqlParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode OPEN() { return getToken(MySqlParser.OPEN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public HandlerOpenStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_handlerOpenStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerOpenStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerOpenStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerOpenStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HandlerOpenStatementContext handlerOpenStatement() throws RecognitionException {
		HandlerOpenStatementContext _localctx = new HandlerOpenStatementContext(_ctx, getState());
		enterRule(_localctx, 218, RULE_handlerOpenStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3622);
			match(HANDLER);
			setState(3623);
			tableName();
			setState(3624);
			match(OPEN);
			setState(3629);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,508,_ctx) ) {
			case 1:
				{
				setState(3626);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(3625);
					match(AS);
					}
				}

				setState(3628);
				uid();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HandlerReadIndexStatementContext extends ParserRuleContext {
		public UidContext index;
		public Token moveOrder;
		public TerminalNode HANDLER() { return getToken(MySqlParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ComparisonOperatorContext comparisonOperator() {
			return getRuleContext(ComparisonOperatorContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ConstantsContext constants() {
			return getRuleContext(ConstantsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public LimitClauseAtomContext limitClauseAtom() {
			return getRuleContext(LimitClauseAtomContext.class,0);
		}
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode NEXT() { return getToken(MySqlParser.NEXT, 0); }
		public TerminalNode PREV() { return getToken(MySqlParser.PREV, 0); }
		public TerminalNode LAST() { return getToken(MySqlParser.LAST, 0); }
		public HandlerReadIndexStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_handlerReadIndexStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerReadIndexStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerReadIndexStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerReadIndexStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HandlerReadIndexStatementContext handlerReadIndexStatement() throws RecognitionException {
		HandlerReadIndexStatementContext _localctx = new HandlerReadIndexStatementContext(_ctx, getState());
		enterRule(_localctx, 220, RULE_handlerReadIndexStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3631);
			match(HANDLER);
			setState(3632);
			tableName();
			setState(3633);
			match(READ);
			setState(3634);
			((HandlerReadIndexStatementContext)_localctx).index = uid();
			setState(3641);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EQUAL_SYMBOL:
			case GREATER_SYMBOL:
			case LESS_SYMBOL:
			case EXCLAMATION_SYMBOL:
				{
				setState(3635);
				comparisonOperator();
				setState(3636);
				match(LR_BRACKET);
				setState(3637);
				constants();
				setState(3638);
				match(RR_BRACKET);
				}
				break;
			case FIRST:
			case LAST:
			case NEXT:
			case PREV:
				{
				setState(3640);
				((HandlerReadIndexStatementContext)_localctx).moveOrder = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FIRST || _la==LAST || _la==NEXT || _la==PREV) ) {
					((HandlerReadIndexStatementContext)_localctx).moveOrder = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(3645);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3643);
				match(WHERE);
				setState(3644);
				expression(0);
				}
			}

			setState(3649);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3647);
				match(LIMIT);
				setState(3648);
				limitClauseAtom();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HandlerReadStatementContext extends ParserRuleContext {
		public Token moveOrder;
		public TerminalNode HANDLER() { return getToken(MySqlParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode NEXT() { return getToken(MySqlParser.NEXT, 0); }
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public LimitClauseAtomContext limitClauseAtom() {
			return getRuleContext(LimitClauseAtomContext.class,0);
		}
		public HandlerReadStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_handlerReadStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerReadStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerReadStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerReadStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HandlerReadStatementContext handlerReadStatement() throws RecognitionException {
		HandlerReadStatementContext _localctx = new HandlerReadStatementContext(_ctx, getState());
		enterRule(_localctx, 222, RULE_handlerReadStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3651);
			match(HANDLER);
			setState(3652);
			tableName();
			setState(3653);
			match(READ);
			setState(3654);
			((HandlerReadStatementContext)_localctx).moveOrder = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==FIRST || _la==NEXT) ) {
				((HandlerReadStatementContext)_localctx).moveOrder = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(3657);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3655);
				match(WHERE);
				setState(3656);
				expression(0);
				}
			}

			setState(3661);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3659);
				match(LIMIT);
				setState(3660);
				limitClauseAtom();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HandlerCloseStatementContext extends ParserRuleContext {
		public TerminalNode HANDLER() { return getToken(MySqlParser.HANDLER, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode CLOSE() { return getToken(MySqlParser.CLOSE, 0); }
		public HandlerCloseStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_handlerCloseStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerCloseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerCloseStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerCloseStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HandlerCloseStatementContext handlerCloseStatement() throws RecognitionException {
		HandlerCloseStatementContext _localctx = new HandlerCloseStatementContext(_ctx, getState());
		enterRule(_localctx, 224, RULE_handlerCloseStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3663);
			match(HANDLER);
			setState(3664);
			tableName();
			setState(3665);
			match(CLOSE);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SingleUpdateStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SingleUpdateStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_singleUpdateStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSingleUpdateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSingleUpdateStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSingleUpdateStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SingleUpdateStatementContext singleUpdateStatement() throws RecognitionException {
		SingleUpdateStatementContext _localctx = new SingleUpdateStatementContext(_ctx, getState());
		enterRule(_localctx, 226, RULE_singleUpdateStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3667);
			match(UPDATE);
			setState(3669);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY) {
				{
				setState(3668);
				((SingleUpdateStatementContext)_localctx).priority = match(LOW_PRIORITY);
				}
			}

			setState(3672);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3671);
				match(IGNORE);
				}
			}

			setState(3674);
			tableName();
			setState(3679);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513126400L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(3676);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(3675);
					match(AS);
					}
				}

				setState(3678);
				uid();
				}
			}

			setState(3681);
			match(SET);
			setState(3682);
			updatedElement();
			setState(3687);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3683);
				match(COMMA);
				setState(3684);
				updatedElement();
				}
				}
				setState(3689);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(3692);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3690);
				match(WHERE);
				setState(3691);
				expression(0);
				}
			}

			setState(3695);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ORDER) {
				{
				setState(3694);
				orderByClause();
				}
			}

			setState(3698);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(3697);
				limitClause();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class MultipleUpdateStatementContext extends ParserRuleContext {
		public Token priority;
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List updatedElement() {
			return getRuleContexts(UpdatedElementContext.class);
		}
		public UpdatedElementContext updatedElement(int i) {
			return getRuleContext(UpdatedElementContext.class,i);
		}
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public MultipleUpdateStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multipleUpdateStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMultipleUpdateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMultipleUpdateStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMultipleUpdateStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultipleUpdateStatementContext multipleUpdateStatement() throws RecognitionException {
		MultipleUpdateStatementContext _localctx = new MultipleUpdateStatementContext(_ctx, getState());
		enterRule(_localctx, 228, RULE_multipleUpdateStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3700);
			match(UPDATE);
			setState(3702);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LOW_PRIORITY) {
				{
				setState(3701);
				((MultipleUpdateStatementContext)_localctx).priority = match(LOW_PRIORITY);
				}
			}

			setState(3705);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(3704);
				match(IGNORE);
				}
			}

			setState(3707);
			tableSources();
			setState(3708);
			match(SET);
			setState(3709);
			updatedElement();
			setState(3714);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(3710);
				match(COMMA);
				setState(3711);
				updatedElement();
				}
				}
				setState(3716);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(3719);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(3717);
				match(WHERE);
				setState(3718);
				expression(0);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class OrderByClauseContext extends ParserRuleContext {
		public TerminalNode ORDER() { return getToken(MySqlParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public List orderByExpression() {
			return getRuleContexts(OrderByExpressionContext.class);
		}
		public OrderByExpressionContext orderByExpression(int i) {
			return getRuleContext(OrderByExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public OrderByClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_orderByClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOrderByClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOrderByClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOrderByClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OrderByClauseContext orderByClause() throws RecognitionException {
		OrderByClauseContext _localctx = new OrderByClauseContext(_ctx, getState());
		enterRule(_localctx, 230, RULE_orderByClause);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(3721);
			match(ORDER);
			setState(3722);
			match(BY);
			setState(3723);
			orderByExpression();
			setState(3728);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,526,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(3724);
					match(COMMA);
					setState(3725);
					orderByExpression();
					}
					} 
				}
				setState(3730);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,526,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class OrderByExpressionContext extends ParserRuleContext {
		public Token order;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode ASC() { return getToken(MySqlParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MySqlParser.DESC, 0); }
		public OrderByExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_orderByExpression; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOrderByExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOrderByExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOrderByExpression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OrderByExpressionContext orderByExpression() throws RecognitionException {
		OrderByExpressionContext _localctx = new OrderByExpressionContext(_ctx, getState());
		enterRule(_localctx, 232, RULE_orderByExpression);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3731);
			expression(0);
			setState(3733);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,527,_ctx) ) {
			case 1:
				{
				setState(3732);
				((OrderByExpressionContext)_localctx).order = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ASC || _la==DESC) ) {
					((OrderByExpressionContext)_localctx).order = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableSourcesContext extends ParserRuleContext {
		public List tableSource() {
			return getRuleContexts(TableSourceContext.class);
		}
		public TableSourceContext tableSource(int i) {
			return getRuleContext(TableSourceContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TableSourcesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableSources; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableSources(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableSources(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableSources(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableSourcesContext tableSources() throws RecognitionException {
		TableSourcesContext _localctx = new TableSourcesContext(_ctx, getState());
		enterRule(_localctx, 234, RULE_tableSources);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(3735);
			tableSource();
			setState(3740);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,528,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(3736);
					match(COMMA);
					setState(3737);
					tableSource();
					}
					} 
				}
				setState(3742);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,528,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableSourceContext extends ParserRuleContext {
		public TableSourceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableSource; }
	 
		public TableSourceContext() { }
		public void copyFrom(TableSourceContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableJsonContext extends TableSourceContext {
		public JsonTableContext jsonTable() {
			return getRuleContext(JsonTableContext.class,0);
		}
		public TableJsonContext(TableSourceContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableJson(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableJson(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableJson(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableSourceNestedContext extends TableSourceContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List joinPart() {
			return getRuleContexts(JoinPartContext.class);
		}
		public JoinPartContext joinPart(int i) {
			return getRuleContext(JoinPartContext.class,i);
		}
		public TableSourceNestedContext(TableSourceContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableSourceNested(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableSourceNested(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableSourceNested(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableSourceBaseContext extends TableSourceContext {
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public List joinPart() {
			return getRuleContexts(JoinPartContext.class);
		}
		public JoinPartContext joinPart(int i) {
			return getRuleContext(JoinPartContext.class,i);
		}
		public TableSourceBaseContext(TableSourceContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableSourceBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableSourceBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableSourceBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableSourceContext tableSource() throws RecognitionException {
		TableSourceContext _localctx = new TableSourceContext(_ctx, getState());
		enterRule(_localctx, 236, RULE_tableSource);
		int _la;
		try {
			int _alt;
			setState(3761);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,531,_ctx) ) {
			case 1:
				_localctx = new TableSourceBaseContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3743);
				tableSourceItem();
				setState(3747);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,529,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3744);
						joinPart();
						}
						} 
					}
					setState(3749);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,529,_ctx);
				}
				}
				break;
			case 2:
				_localctx = new TableSourceNestedContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3750);
				match(LR_BRACKET);
				setState(3751);
				tableSourceItem();
				setState(3755);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (((((_la - 34)) & ~0x3f) == 0 && ((1L << (_la - 34)) & -9150751492863426559L) != 0) || ((((_la - 113)) & ~0x3f) == 0 && ((1L << (_la - 113)) & 288230410511450113L) != 0)) {
					{
					{
					setState(3752);
					joinPart();
					}
					}
					setState(3757);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(3758);
				match(RR_BRACKET);
				}
				break;
			case 3:
				_localctx = new TableJsonContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3760);
				jsonTable();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableSourceItemContext extends ParserRuleContext {
		public TableSourceItemContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableSourceItem; }
	 
		public TableSourceItemContext() { }
		public void copyFrom(TableSourceItemContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SubqueryTableItemContext extends TableSourceItemContext {
		public SelectStatementContext parenthesisSubquery;
		public UidContext alias;
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SubqueryTableItemContext(TableSourceItemContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubqueryTableItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubqueryTableItem(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubqueryTableItem(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AtomTableItemContext extends TableSourceItemContext {
		public UidContext alias;
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List indexHint() {
			return getRuleContexts(IndexHintContext.class);
		}
		public IndexHintContext indexHint(int i) {
			return getRuleContext(IndexHintContext.class,i);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AtomTableItemContext(TableSourceItemContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAtomTableItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAtomTableItem(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAtomTableItem(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableSourcesItemContext extends TableSourceItemContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TableSourcesItemContext(TableSourceItemContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableSourcesItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableSourcesItem(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableSourcesItem(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableSourceItemContext tableSourceItem() throws RecognitionException {
		TableSourceItemContext _localctx = new TableSourceItemContext(_ctx, getState());
		enterRule(_localctx, 238, RULE_tableSourceItem);
		int _la;
		try {
			int _alt;
			setState(3803);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,539,_ctx) ) {
			case 1:
				_localctx = new AtomTableItemContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3763);
				tableName();
				setState(3769);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PARTITION) {
					{
					setState(3764);
					match(PARTITION);
					setState(3765);
					match(LR_BRACKET);
					setState(3766);
					uidList();
					setState(3767);
					match(RR_BRACKET);
					}
				}

				setState(3775);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,534,_ctx) ) {
				case 1:
					{
					setState(3772);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(3771);
						match(AS);
						}
					}

					setState(3774);
					((AtomTableItemContext)_localctx).alias = uid();
					}
					break;
				}
				setState(3785);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,536,_ctx) ) {
				case 1:
					{
					setState(3777);
					indexHint();
					setState(3782);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,535,_ctx);
					while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
						if ( _alt==1 ) {
							{
							{
							setState(3778);
							match(COMMA);
							setState(3779);
							indexHint();
							}
							} 
						}
						setState(3784);
						_errHandler.sync(this);
						_alt = getInterpreter().adaptivePredict(_input,535,_ctx);
					}
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new SubqueryTableItemContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3792);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,537,_ctx) ) {
				case 1:
					{
					setState(3787);
					selectStatement();
					}
					break;
				case 2:
					{
					setState(3788);
					match(LR_BRACKET);
					setState(3789);
					((SubqueryTableItemContext)_localctx).parenthesisSubquery = selectStatement();
					setState(3790);
					match(RR_BRACKET);
					}
					break;
				}
				setState(3795);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(3794);
					match(AS);
					}
				}

				setState(3797);
				((SubqueryTableItemContext)_localctx).alias = uid();
				}
				break;
			case 3:
				_localctx = new TableSourcesItemContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3799);
				match(LR_BRACKET);
				setState(3800);
				tableSources();
				setState(3801);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexHintContext extends ParserRuleContext {
		public Token indexHintAction;
		public Token keyFormat;
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode USE() { return getToken(MySqlParser.USE, 0); }
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public TerminalNode FORCE() { return getToken(MySqlParser.FORCE, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public IndexHintTypeContext indexHintType() {
			return getRuleContext(IndexHintTypeContext.class,0);
		}
		public IndexHintContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexHint; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexHint(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexHint(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexHint(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexHintContext indexHint() throws RecognitionException {
		IndexHintContext _localctx = new IndexHintContext(_ctx, getState());
		enterRule(_localctx, 240, RULE_indexHint);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3805);
			((IndexHintContext)_localctx).indexHintAction = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==FORCE || _la==IGNORE || _la==USE) ) {
				((IndexHintContext)_localctx).indexHintAction = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(3806);
			((IndexHintContext)_localctx).keyFormat = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==INDEX || _la==KEY) ) {
				((IndexHintContext)_localctx).keyFormat = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(3809);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(3807);
				match(FOR);
				setState(3808);
				indexHintType();
				}
			}

			setState(3811);
			match(LR_BRACKET);
			setState(3812);
			uidList();
			setState(3813);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexHintTypeContext extends ParserRuleContext {
		public TerminalNode JOIN() { return getToken(MySqlParser.JOIN, 0); }
		public TerminalNode ORDER() { return getToken(MySqlParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public IndexHintTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexHintType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexHintType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexHintType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexHintType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexHintTypeContext indexHintType() throws RecognitionException {
		IndexHintTypeContext _localctx = new IndexHintTypeContext(_ctx, getState());
		enterRule(_localctx, 242, RULE_indexHintType);
		try {
			setState(3820);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case JOIN:
				enterOuterAlt(_localctx, 1);
				{
				setState(3815);
				match(JOIN);
				}
				break;
			case ORDER:
				enterOuterAlt(_localctx, 2);
				{
				setState(3816);
				match(ORDER);
				setState(3817);
				match(BY);
				}
				break;
			case GROUP:
				enterOuterAlt(_localctx, 3);
				{
				setState(3818);
				match(GROUP);
				setState(3819);
				match(BY);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JoinPartContext extends ParserRuleContext {
		public JoinPartContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_joinPart; }
	 
		public JoinPartContext() { }
		public void copyFrom(JoinPartContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class InnerJoinContext extends JoinPartContext {
		public TerminalNode JOIN() { return getToken(MySqlParser.JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode LATERAL() { return getToken(MySqlParser.LATERAL, 0); }
		public List joinSpec() {
			return getRuleContexts(JoinSpecContext.class);
		}
		public JoinSpecContext joinSpec(int i) {
			return getRuleContext(JoinSpecContext.class,i);
		}
		public TerminalNode INNER() { return getToken(MySqlParser.INNER, 0); }
		public TerminalNode CROSS() { return getToken(MySqlParser.CROSS, 0); }
		public InnerJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterInnerJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitInnerJoin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitInnerJoin(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NaturalJoinContext extends JoinPartContext {
		public TerminalNode NATURAL() { return getToken(MySqlParser.NATURAL, 0); }
		public TerminalNode JOIN() { return getToken(MySqlParser.JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode LEFT() { return getToken(MySqlParser.LEFT, 0); }
		public TerminalNode RIGHT() { return getToken(MySqlParser.RIGHT, 0); }
		public TerminalNode OUTER() { return getToken(MySqlParser.OUTER, 0); }
		public NaturalJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNaturalJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNaturalJoin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNaturalJoin(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class OuterJoinContext extends JoinPartContext {
		public TerminalNode JOIN() { return getToken(MySqlParser.JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public TerminalNode LEFT() { return getToken(MySqlParser.LEFT, 0); }
		public TerminalNode RIGHT() { return getToken(MySqlParser.RIGHT, 0); }
		public TerminalNode OUTER() { return getToken(MySqlParser.OUTER, 0); }
		public TerminalNode LATERAL() { return getToken(MySqlParser.LATERAL, 0); }
		public List joinSpec() {
			return getRuleContexts(JoinSpecContext.class);
		}
		public JoinSpecContext joinSpec(int i) {
			return getRuleContext(JoinSpecContext.class,i);
		}
		public OuterJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOuterJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOuterJoin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOuterJoin(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class StraightJoinContext extends JoinPartContext {
		public TerminalNode STRAIGHT_JOIN() { return getToken(MySqlParser.STRAIGHT_JOIN, 0); }
		public TableSourceItemContext tableSourceItem() {
			return getRuleContext(TableSourceItemContext.class,0);
		}
		public List ON() { return getTokens(MySqlParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MySqlParser.ON, i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public StraightJoinContext(JoinPartContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStraightJoin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStraightJoin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStraightJoin(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JoinPartContext joinPart() throws RecognitionException {
		JoinPartContext _localctx = new JoinPartContext(_ctx, getState());
		enterRule(_localctx, 244, RULE_joinPart);
		int _la;
		try {
			int _alt;
			setState(3869);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CROSS:
			case INNER:
			case JOIN:
				_localctx = new InnerJoinContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(3823);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CROSS || _la==INNER) {
					{
					setState(3822);
					_la = _input.LA(1);
					if ( !(_la==CROSS || _la==INNER) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(3825);
				match(JOIN);
				setState(3827);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,543,_ctx) ) {
				case 1:
					{
					setState(3826);
					match(LATERAL);
					}
					break;
				}
				setState(3829);
				tableSourceItem();
				setState(3833);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,544,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3830);
						joinSpec();
						}
						} 
					}
					setState(3835);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,544,_ctx);
				}
				}
				break;
			case STRAIGHT_JOIN:
				_localctx = new StraightJoinContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(3836);
				match(STRAIGHT_JOIN);
				setState(3837);
				tableSourceItem();
				setState(3842);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,545,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3838);
						match(ON);
						setState(3839);
						expression(0);
						}
						} 
					}
					setState(3844);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,545,_ctx);
				}
				}
				break;
			case LEFT:
			case RIGHT:
				_localctx = new OuterJoinContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(3845);
				_la = _input.LA(1);
				if ( !(_la==LEFT || _la==RIGHT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(3847);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OUTER) {
					{
					setState(3846);
					match(OUTER);
					}
				}

				setState(3849);
				match(JOIN);
				setState(3851);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,547,_ctx) ) {
				case 1:
					{
					setState(3850);
					match(LATERAL);
					}
					break;
				}
				setState(3853);
				tableSourceItem();
				setState(3857);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,548,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3854);
						joinSpec();
						}
						} 
					}
					setState(3859);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,548,_ctx);
				}
				}
				break;
			case NATURAL:
				_localctx = new NaturalJoinContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(3860);
				match(NATURAL);
				setState(3865);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LEFT || _la==RIGHT) {
					{
					setState(3861);
					_la = _input.LA(1);
					if ( !(_la==LEFT || _la==RIGHT) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(3863);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==OUTER) {
						{
						setState(3862);
						match(OUTER);
						}
					}

					}
				}

				setState(3867);
				match(JOIN);
				setState(3868);
				tableSourceItem();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JoinSpecContext extends ParserRuleContext {
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public JoinSpecContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_joinSpec; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJoinSpec(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJoinSpec(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJoinSpec(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JoinSpecContext joinSpec() throws RecognitionException {
		JoinSpecContext _localctx = new JoinSpecContext(_ctx, getState());
		enterRule(_localctx, 246, RULE_joinSpec);
		try {
			setState(3878);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ON:
				enterOuterAlt(_localctx, 1);
				{
				{
				setState(3871);
				match(ON);
				setState(3872);
				expression(0);
				}
				}
				break;
			case USING:
				enterOuterAlt(_localctx, 2);
				{
				setState(3873);
				match(USING);
				setState(3874);
				match(LR_BRACKET);
				setState(3875);
				uidList();
				setState(3876);
				match(RR_BRACKET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class QueryExpressionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public QuerySpecificationContext querySpecification() {
			return getRuleContext(QuerySpecificationContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public QueryExpressionContext queryExpression() {
			return getRuleContext(QueryExpressionContext.class,0);
		}
		public QueryExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_queryExpression; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterQueryExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitQueryExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitQueryExpression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QueryExpressionContext queryExpression() throws RecognitionException {
		QueryExpressionContext _localctx = new QueryExpressionContext(_ctx, getState());
		enterRule(_localctx, 248, RULE_queryExpression);
		try {
			setState(3888);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,553,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3880);
				match(LR_BRACKET);
				setState(3881);
				querySpecification();
				setState(3882);
				match(RR_BRACKET);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3884);
				match(LR_BRACKET);
				setState(3885);
				queryExpression();
				setState(3886);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class QueryExpressionNointoContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public QueryExpressionNointoContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_queryExpressionNointo; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterQueryExpressionNointo(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitQueryExpressionNointo(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitQueryExpressionNointo(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QueryExpressionNointoContext queryExpressionNointo() throws RecognitionException {
		QueryExpressionNointoContext _localctx = new QueryExpressionNointoContext(_ctx, getState());
		enterRule(_localctx, 250, RULE_queryExpressionNointo);
		try {
			setState(3898);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,554,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3890);
				match(LR_BRACKET);
				setState(3891);
				querySpecificationNointo();
				setState(3892);
				match(RR_BRACKET);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3894);
				match(LR_BRACKET);
				setState(3895);
				queryExpressionNointo();
				setState(3896);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class QuerySpecificationContext extends ParserRuleContext {
		public TerminalNode SELECT() { return getToken(MySqlParser.SELECT, 0); }
		public SelectElementsContext selectElements() {
			return getRuleContext(SelectElementsContext.class,0);
		}
		public FromClauseContext fromClause() {
			return getRuleContext(FromClauseContext.class,0);
		}
		public List selectSpec() {
			return getRuleContexts(SelectSpecContext.class);
		}
		public SelectSpecContext selectSpec(int i) {
			return getRuleContext(SelectSpecContext.class,i);
		}
		public SelectIntoExpressionContext selectIntoExpression() {
			return getRuleContext(SelectIntoExpressionContext.class,0);
		}
		public GroupByClauseContext groupByClause() {
			return getRuleContext(GroupByClauseContext.class,0);
		}
		public HavingClauseContext havingClause() {
			return getRuleContext(HavingClauseContext.class,0);
		}
		public WindowClauseContext windowClause() {
			return getRuleContext(WindowClauseContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public QuerySpecificationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_querySpecification; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterQuerySpecification(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitQuerySpecification(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitQuerySpecification(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuerySpecificationContext querySpecification() throws RecognitionException {
		QuerySpecificationContext _localctx = new QuerySpecificationContext(_ctx, getState());
		enterRule(_localctx, 252, RULE_querySpecification);
		int _la;
		try {
			int _alt;
			setState(3954);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,569,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(3900);
				match(SELECT);
				setState(3904);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,555,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3901);
						selectSpec();
						}
						} 
					}
					setState(3906);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,555,_ctx);
				}
				setState(3907);
				selectElements();
				setState(3909);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INTO) {
					{
					setState(3908);
					selectIntoExpression();
					}
				}

				setState(3911);
				fromClause();
				setState(3913);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,557,_ctx) ) {
				case 1:
					{
					setState(3912);
					groupByClause();
					}
					break;
				}
				setState(3916);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==HAVING) {
					{
					setState(3915);
					havingClause();
					}
				}

				setState(3919);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WINDOW) {
					{
					setState(3918);
					windowClause();
					}
				}

				setState(3922);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,560,_ctx) ) {
				case 1:
					{
					setState(3921);
					orderByClause();
					}
					break;
				}
				setState(3925);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,561,_ctx) ) {
				case 1:
					{
					setState(3924);
					limitClause();
					}
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(3927);
				match(SELECT);
				setState(3931);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,562,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(3928);
						selectSpec();
						}
						} 
					}
					setState(3933);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,562,_ctx);
				}
				setState(3934);
				selectElements();
				setState(3935);
				fromClause();
				setState(3937);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,563,_ctx) ) {
				case 1:
					{
					setState(3936);
					groupByClause();
					}
					break;
				}
				setState(3940);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==HAVING) {
					{
					setState(3939);
					havingClause();
					}
				}

				setState(3943);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WINDOW) {
					{
					setState(3942);
					windowClause();
					}
				}

				setState(3946);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,566,_ctx) ) {
				case 1:
					{
					setState(3945);
					orderByClause();
					}
					break;
				}
				setState(3949);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,567,_ctx) ) {
				case 1:
					{
					setState(3948);
					limitClause();
					}
					break;
				}
				setState(3952);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INTO) {
					{
					setState(3951);
					selectIntoExpression();
					}
				}

				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class QuerySpecificationNointoContext extends ParserRuleContext {
		public TerminalNode SELECT() { return getToken(MySqlParser.SELECT, 0); }
		public SelectElementsContext selectElements() {
			return getRuleContext(SelectElementsContext.class,0);
		}
		public FromClauseContext fromClause() {
			return getRuleContext(FromClauseContext.class,0);
		}
		public List selectSpec() {
			return getRuleContexts(SelectSpecContext.class);
		}
		public SelectSpecContext selectSpec(int i) {
			return getRuleContext(SelectSpecContext.class,i);
		}
		public GroupByClauseContext groupByClause() {
			return getRuleContext(GroupByClauseContext.class,0);
		}
		public HavingClauseContext havingClause() {
			return getRuleContext(HavingClauseContext.class,0);
		}
		public WindowClauseContext windowClause() {
			return getRuleContext(WindowClauseContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public QuerySpecificationNointoContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_querySpecificationNointo; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterQuerySpecificationNointo(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitQuerySpecificationNointo(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitQuerySpecificationNointo(this);
			else return visitor.visitChildren(this);
		}
	}

	public final QuerySpecificationNointoContext querySpecificationNointo() throws RecognitionException {
		QuerySpecificationNointoContext _localctx = new QuerySpecificationNointoContext(_ctx, getState());
		enterRule(_localctx, 254, RULE_querySpecificationNointo);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(3956);
			match(SELECT);
			setState(3960);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,570,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(3957);
					selectSpec();
					}
					} 
				}
				setState(3962);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,570,_ctx);
			}
			setState(3963);
			selectElements();
			setState(3964);
			fromClause();
			setState(3966);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,571,_ctx) ) {
			case 1:
				{
				setState(3965);
				groupByClause();
				}
				break;
			}
			setState(3969);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==HAVING) {
				{
				setState(3968);
				havingClause();
				}
			}

			setState(3972);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WINDOW) {
				{
				setState(3971);
				windowClause();
				}
			}

			setState(3975);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,574,_ctx) ) {
			case 1:
				{
				setState(3974);
				orderByClause();
				}
				break;
			}
			setState(3978);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,575,_ctx) ) {
			case 1:
				{
				setState(3977);
				limitClause();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UnionParenthesisContext extends ParserRuleContext {
		public Token unionType;
		public TerminalNode UNION() { return getToken(MySqlParser.UNION, 0); }
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MySqlParser.DISTINCT, 0); }
		public UnionParenthesisContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_unionParenthesis; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnionParenthesis(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnionParenthesis(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnionParenthesis(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UnionParenthesisContext unionParenthesis() throws RecognitionException {
		UnionParenthesisContext _localctx = new UnionParenthesisContext(_ctx, getState());
		enterRule(_localctx, 256, RULE_unionParenthesis);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3980);
			match(UNION);
			setState(3982);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALL || _la==DISTINCT) {
				{
				setState(3981);
				((UnionParenthesisContext)_localctx).unionType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ALL || _la==DISTINCT) ) {
					((UnionParenthesisContext)_localctx).unionType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3984);
			queryExpressionNointo();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UnionStatementContext extends ParserRuleContext {
		public Token unionType;
		public TerminalNode UNION() { return getToken(MySqlParser.UNION, 0); }
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MySqlParser.DISTINCT, 0); }
		public UnionStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_unionStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnionStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnionStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnionStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UnionStatementContext unionStatement() throws RecognitionException {
		UnionStatementContext _localctx = new UnionStatementContext(_ctx, getState());
		enterRule(_localctx, 258, RULE_unionStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3986);
			match(UNION);
			setState(3988);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALL || _la==DISTINCT) {
				{
				setState(3987);
				((UnionStatementContext)_localctx).unionType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ALL || _la==DISTINCT) ) {
					((UnionStatementContext)_localctx).unionType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(3992);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SELECT:
				{
				setState(3990);
				querySpecificationNointo();
				}
				break;
			case LR_BRACKET:
				{
				setState(3991);
				queryExpressionNointo();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LateralStatementContext extends ParserRuleContext {
		public TerminalNode LATERAL() { return getToken(MySqlParser.LATERAL, 0); }
		public QuerySpecificationNointoContext querySpecificationNointo() {
			return getRuleContext(QuerySpecificationNointoContext.class,0);
		}
		public QueryExpressionNointoContext queryExpressionNointo() {
			return getRuleContext(QueryExpressionNointoContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public LateralStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lateralStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLateralStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLateralStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLateralStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LateralStatementContext lateralStatement() throws RecognitionException {
		LateralStatementContext _localctx = new LateralStatementContext(_ctx, getState());
		enterRule(_localctx, 260, RULE_lateralStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(3994);
			match(LATERAL);
			setState(4009);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,582,_ctx) ) {
			case 1:
				{
				setState(3995);
				querySpecificationNointo();
				}
				break;
			case 2:
				{
				setState(3996);
				queryExpressionNointo();
				}
				break;
			case 3:
				{
				{
				setState(3997);
				match(LR_BRACKET);
				setState(4000);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SELECT:
					{
					setState(3998);
					querySpecificationNointo();
					}
					break;
				case LR_BRACKET:
					{
					setState(3999);
					queryExpressionNointo();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4002);
				match(RR_BRACKET);
				setState(4007);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,581,_ctx) ) {
				case 1:
					{
					setState(4004);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4003);
						match(AS);
						}
					}

					setState(4006);
					uid();
					}
					break;
				}
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JsonTableContext extends ParserRuleContext {
		public TerminalNode JSON_TABLE() { return getToken(MySqlParser.JSON_TABLE, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public JsonColumnListContext jsonColumnList() {
			return getRuleContext(JsonColumnListContext.class,0);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public JsonTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_jsonTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JsonTableContext jsonTable() throws RecognitionException {
		JsonTableContext _localctx = new JsonTableContext(_ctx, getState());
		enterRule(_localctx, 262, RULE_jsonTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4011);
			match(JSON_TABLE);
			setState(4012);
			match(LR_BRACKET);
			setState(4013);
			match(STRING_LITERAL);
			setState(4014);
			match(COMMA);
			setState(4015);
			match(STRING_LITERAL);
			setState(4016);
			match(COLUMNS);
			setState(4017);
			match(LR_BRACKET);
			setState(4018);
			jsonColumnList();
			setState(4019);
			match(RR_BRACKET);
			setState(4020);
			match(RR_BRACKET);
			setState(4025);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,584,_ctx) ) {
			case 1:
				{
				setState(4022);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(4021);
					match(AS);
					}
				}

				setState(4024);
				uid();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JsonColumnListContext extends ParserRuleContext {
		public List jsonColumn() {
			return getRuleContexts(JsonColumnContext.class);
		}
		public JsonColumnContext jsonColumn(int i) {
			return getRuleContext(JsonColumnContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public JsonColumnListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_jsonColumnList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonColumnList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonColumnList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonColumnList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JsonColumnListContext jsonColumnList() throws RecognitionException {
		JsonColumnListContext _localctx = new JsonColumnListContext(_ctx, getState());
		enterRule(_localctx, 264, RULE_jsonColumnList);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4027);
			jsonColumn();
			setState(4032);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4028);
				match(COMMA);
				setState(4029);
				jsonColumn();
				}
				}
				setState(4034);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JsonColumnContext extends ParserRuleContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode ORDINALITY() { return getToken(MySqlParser.ORDINALITY, 0); }
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public TerminalNode PATH() { return getToken(MySqlParser.PATH, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode EXISTS() { return getToken(MySqlParser.EXISTS, 0); }
		public JsonOnEmptyContext jsonOnEmpty() {
			return getRuleContext(JsonOnEmptyContext.class,0);
		}
		public JsonOnErrorContext jsonOnError() {
			return getRuleContext(JsonOnErrorContext.class,0);
		}
		public TerminalNode NESTED() { return getToken(MySqlParser.NESTED, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public JsonColumnListContext jsonColumnList() {
			return getRuleContext(JsonColumnListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public JsonColumnContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_jsonColumn; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonColumn(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonColumn(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonColumn(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JsonColumnContext jsonColumn() throws RecognitionException {
		JsonColumnContext _localctx = new JsonColumnContext(_ctx, getState());
		enterRule(_localctx, 266, RULE_jsonColumn);
		int _la;
		try {
			setState(4064);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,591,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4035);
				fullColumnName();
				setState(4052);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case FOR:
					{
					setState(4036);
					match(FOR);
					setState(4037);
					match(ORDINALITY);
					}
					break;
				case CHARACTER:
				case SET:
				case TINYINT:
				case SMALLINT:
				case MEDIUMINT:
				case MIDDLEINT:
				case INT:
				case INT1:
				case INT2:
				case INT3:
				case INT4:
				case INT8:
				case INTEGER:
				case BIGINT:
				case REAL:
				case DOUBLE:
				case FLOAT:
				case FLOAT4:
				case FLOAT8:
				case DECIMAL:
				case DEC:
				case NUMERIC:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case CHAR:
				case VARCHAR:
				case NVARCHAR:
				case NATIONAL:
				case BINARY:
				case VARBINARY:
				case TINYBLOB:
				case BLOB:
				case MEDIUMBLOB:
				case LONG:
				case LONGBLOB:
				case TINYTEXT:
				case TEXT:
				case MEDIUMTEXT:
				case LONGTEXT:
				case ENUM:
				case SERIAL:
				case BIT:
				case BOOL:
				case BOOLEAN:
				case FIXED:
				case JSON:
				case NCHAR:
				case GEOMETRYCOLLECTION:
				case GEOMCOLLECTION:
				case GEOMETRY:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
					{
					setState(4038);
					dataType();
					setState(4050);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case PATH:
						{
						setState(4039);
						match(PATH);
						setState(4040);
						match(STRING_LITERAL);
						setState(4042);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,586,_ctx) ) {
						case 1:
							{
							setState(4041);
							jsonOnEmpty();
							}
							break;
						}
						setState(4045);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==DEFAULT || _la==NULL_LITERAL || _la==ERROR) {
							{
							setState(4044);
							jsonOnError();
							}
						}

						}
						break;
					case EXISTS:
						{
						setState(4047);
						match(EXISTS);
						setState(4048);
						match(PATH);
						setState(4049);
						match(STRING_LITERAL);
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4054);
				match(NESTED);
				setState(4056);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PATH) {
					{
					setState(4055);
					match(PATH);
					}
				}

				setState(4058);
				match(STRING_LITERAL);
				setState(4059);
				match(COLUMNS);
				setState(4060);
				match(LR_BRACKET);
				setState(4061);
				jsonColumnList();
				setState(4062);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JsonOnEmptyContext extends ParserRuleContext {
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode EMPTY() { return getToken(MySqlParser.EMPTY, 0); }
		public TerminalNode NULL_LITERAL() { return getToken(MySqlParser.NULL_LITERAL, 0); }
		public TerminalNode ERROR() { return getToken(MySqlParser.ERROR, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public DefaultValueContext defaultValue() {
			return getRuleContext(DefaultValueContext.class,0);
		}
		public JsonOnEmptyContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_jsonOnEmpty; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonOnEmpty(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonOnEmpty(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonOnEmpty(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JsonOnEmptyContext jsonOnEmpty() throws RecognitionException {
		JsonOnEmptyContext _localctx = new JsonOnEmptyContext(_ctx, getState());
		enterRule(_localctx, 268, RULE_jsonOnEmpty);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4070);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NULL_LITERAL:
				{
				setState(4066);
				match(NULL_LITERAL);
				}
				break;
			case ERROR:
				{
				setState(4067);
				match(ERROR);
				}
				break;
			case DEFAULT:
				{
				setState(4068);
				match(DEFAULT);
				setState(4069);
				defaultValue();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(4072);
			match(ON);
			setState(4073);
			match(EMPTY);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JsonOnErrorContext extends ParserRuleContext {
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public List ERROR() { return getTokens(MySqlParser.ERROR); }
		public TerminalNode ERROR(int i) {
			return getToken(MySqlParser.ERROR, i);
		}
		public TerminalNode NULL_LITERAL() { return getToken(MySqlParser.NULL_LITERAL, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public DefaultValueContext defaultValue() {
			return getRuleContext(DefaultValueContext.class,0);
		}
		public JsonOnErrorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_jsonOnError; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonOnError(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonOnError(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonOnError(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JsonOnErrorContext jsonOnError() throws RecognitionException {
		JsonOnErrorContext _localctx = new JsonOnErrorContext(_ctx, getState());
		enterRule(_localctx, 270, RULE_jsonOnError);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4079);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case NULL_LITERAL:
				{
				setState(4075);
				match(NULL_LITERAL);
				}
				break;
			case ERROR:
				{
				setState(4076);
				match(ERROR);
				}
				break;
			case DEFAULT:
				{
				setState(4077);
				match(DEFAULT);
				setState(4078);
				defaultValue();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(4081);
			match(ON);
			setState(4082);
			match(ERROR);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectSpecContext extends ParserRuleContext {
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MySqlParser.DISTINCT, 0); }
		public TerminalNode DISTINCTROW() { return getToken(MySqlParser.DISTINCTROW, 0); }
		public TerminalNode HIGH_PRIORITY() { return getToken(MySqlParser.HIGH_PRIORITY, 0); }
		public TerminalNode STRAIGHT_JOIN() { return getToken(MySqlParser.STRAIGHT_JOIN, 0); }
		public TerminalNode SQL_SMALL_RESULT() { return getToken(MySqlParser.SQL_SMALL_RESULT, 0); }
		public TerminalNode SQL_BIG_RESULT() { return getToken(MySqlParser.SQL_BIG_RESULT, 0); }
		public TerminalNode SQL_BUFFER_RESULT() { return getToken(MySqlParser.SQL_BUFFER_RESULT, 0); }
		public TerminalNode SQL_CACHE() { return getToken(MySqlParser.SQL_CACHE, 0); }
		public TerminalNode SQL_NO_CACHE() { return getToken(MySqlParser.SQL_NO_CACHE, 0); }
		public TerminalNode SQL_CALC_FOUND_ROWS() { return getToken(MySqlParser.SQL_CALC_FOUND_ROWS, 0); }
		public SelectSpecContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectSpec; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectSpec(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectSpec(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectSpec(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectSpecContext selectSpec() throws RecognitionException {
		SelectSpecContext _localctx = new SelectSpecContext(_ctx, getState());
		enterRule(_localctx, 272, RULE_selectSpec);
		int _la;
		try {
			setState(4092);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALL:
			case DISTINCT:
			case DISTINCTROW:
				enterOuterAlt(_localctx, 1);
				{
				setState(4084);
				_la = _input.LA(1);
				if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & 1688849860264000L) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case HIGH_PRIORITY:
				enterOuterAlt(_localctx, 2);
				{
				setState(4085);
				match(HIGH_PRIORITY);
				}
				break;
			case STRAIGHT_JOIN:
				enterOuterAlt(_localctx, 3);
				{
				setState(4086);
				match(STRAIGHT_JOIN);
				}
				break;
			case SQL_SMALL_RESULT:
				enterOuterAlt(_localctx, 4);
				{
				setState(4087);
				match(SQL_SMALL_RESULT);
				}
				break;
			case SQL_BIG_RESULT:
				enterOuterAlt(_localctx, 5);
				{
				setState(4088);
				match(SQL_BIG_RESULT);
				}
				break;
			case SQL_BUFFER_RESULT:
				enterOuterAlt(_localctx, 6);
				{
				setState(4089);
				match(SQL_BUFFER_RESULT);
				}
				break;
			case SQL_CACHE:
			case SQL_NO_CACHE:
				enterOuterAlt(_localctx, 7);
				{
				setState(4090);
				_la = _input.LA(1);
				if ( !(_la==SQL_CACHE || _la==SQL_NO_CACHE) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case SQL_CALC_FOUND_ROWS:
				enterOuterAlt(_localctx, 8);
				{
				setState(4091);
				match(SQL_CALC_FOUND_ROWS);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectElementsContext extends ParserRuleContext {
		public Token star;
		public List selectElement() {
			return getRuleContexts(SelectElementContext.class);
		}
		public SelectElementContext selectElement(int i) {
			return getRuleContext(SelectElementContext.class,i);
		}
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public SelectElementsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectElements; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectElements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectElements(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectElements(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectElementsContext selectElements() throws RecognitionException {
		SelectElementsContext _localctx = new SelectElementsContext(_ctx, getState());
		enterRule(_localctx, 274, RULE_selectElements);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4096);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,595,_ctx) ) {
			case 1:
				{
				setState(4094);
				((SelectElementsContext)_localctx).star = match(STAR);
				}
				break;
			case 2:
				{
				setState(4095);
				selectElement();
				}
				break;
			}
			setState(4102);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,596,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4098);
					match(COMMA);
					setState(4099);
					selectElement();
					}
					} 
				}
				setState(4104);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,596,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectElementContext extends ParserRuleContext {
		public SelectElementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectElement; }
	 
		public SelectElementContext() { }
		public void copyFrom(SelectElementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectExpressionElementContext extends SelectElementContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public TerminalNode VAR_ASSIGN() { return getToken(MySqlParser.VAR_ASSIGN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SelectExpressionElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectExpressionElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectExpressionElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectExpressionElement(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectFunctionElementContext extends SelectElementContext {
		public FunctionCallContext functionCall() {
			return getRuleContext(FunctionCallContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SelectFunctionElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectFunctionElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectFunctionElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectFunctionElement(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectStarElementContext extends SelectElementContext {
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode DOT() { return getToken(MySqlParser.DOT, 0); }
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public SelectStarElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectStarElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectStarElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectStarElement(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectColumnElementContext extends SelectElementContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public SelectColumnElementContext(SelectElementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectColumnElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectColumnElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectColumnElement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectElementContext selectElement() throws RecognitionException {
		SelectElementContext _localctx = new SelectElementContext(_ctx, getState());
		enterRule(_localctx, 276, RULE_selectElement);
		int _la;
		try {
			setState(4134);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,604,_ctx) ) {
			case 1:
				_localctx = new SelectStarElementContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4105);
				fullId();
				setState(4106);
				match(DOT);
				setState(4107);
				match(STAR);
				}
				break;
			case 2:
				_localctx = new SelectColumnElementContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4109);
				fullColumnName();
				setState(4114);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,598,_ctx) ) {
				case 1:
					{
					setState(4111);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4110);
						match(AS);
						}
					}

					setState(4113);
					uid();
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new SelectFunctionElementContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4116);
				functionCall();
				setState(4121);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,600,_ctx) ) {
				case 1:
					{
					setState(4118);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4117);
						match(AS);
						}
					}

					setState(4120);
					uid();
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new SelectExpressionElementContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4125);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,601,_ctx) ) {
				case 1:
					{
					setState(4123);
					match(LOCAL_ID);
					setState(4124);
					match(VAR_ASSIGN);
					}
					break;
				}
				setState(4127);
				expression(0);
				setState(4132);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,603,_ctx) ) {
				case 1:
					{
					setState(4129);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AS) {
						{
						setState(4128);
						match(AS);
						}
					}

					setState(4131);
					uid();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectIntoExpressionContext extends ParserRuleContext {
		public SelectIntoExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectIntoExpression; }
	 
		public SelectIntoExpressionContext() { }
		public void copyFrom(SelectIntoExpressionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectIntoVariablesContext extends SelectIntoExpressionContext {
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public List assignmentField() {
			return getRuleContexts(AssignmentFieldContext.class);
		}
		public AssignmentFieldContext assignmentField(int i) {
			return getRuleContext(AssignmentFieldContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public SelectIntoVariablesContext(SelectIntoExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectIntoVariables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectIntoVariables(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectIntoVariables(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectIntoTextFileContext extends SelectIntoExpressionContext {
		public Token filename;
		public CharsetNameContext charset;
		public Token fieldsFormat;
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode OUTFILE() { return getToken(MySqlParser.OUTFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode LINES() { return getToken(MySqlParser.LINES, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode FIELDS() { return getToken(MySqlParser.FIELDS, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public List selectFieldsInto() {
			return getRuleContexts(SelectFieldsIntoContext.class);
		}
		public SelectFieldsIntoContext selectFieldsInto(int i) {
			return getRuleContext(SelectFieldsIntoContext.class,i);
		}
		public List selectLinesInto() {
			return getRuleContexts(SelectLinesIntoContext.class);
		}
		public SelectLinesIntoContext selectLinesInto(int i) {
			return getRuleContext(SelectLinesIntoContext.class,i);
		}
		public SelectIntoTextFileContext(SelectIntoExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectIntoTextFile(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectIntoTextFile(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectIntoTextFile(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SelectIntoDumpFileContext extends SelectIntoExpressionContext {
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode DUMPFILE() { return getToken(MySqlParser.DUMPFILE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public SelectIntoDumpFileContext(SelectIntoExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectIntoDumpFile(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectIntoDumpFile(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectIntoDumpFile(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectIntoExpressionContext selectIntoExpression() throws RecognitionException {
		SelectIntoExpressionContext _localctx = new SelectIntoExpressionContext(_ctx, getState());
		enterRule(_localctx, 278, RULE_selectIntoExpression);
		int _la;
		try {
			setState(4172);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,611,_ctx) ) {
			case 1:
				_localctx = new SelectIntoVariablesContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4136);
				match(INTO);
				setState(4137);
				assignmentField();
				setState(4142);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4138);
					match(COMMA);
					setState(4139);
					assignmentField();
					}
					}
					setState(4144);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new SelectIntoDumpFileContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4145);
				match(INTO);
				setState(4146);
				match(DUMPFILE);
				setState(4147);
				match(STRING_LITERAL);
				}
				break;
			case 3:
				_localctx = new SelectIntoTextFileContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				{
				setState(4148);
				match(INTO);
				setState(4149);
				match(OUTFILE);
				setState(4150);
				((SelectIntoTextFileContext)_localctx).filename = match(STRING_LITERAL);
				setState(4154);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CHARACTER) {
					{
					setState(4151);
					match(CHARACTER);
					setState(4152);
					match(SET);
					setState(4153);
					((SelectIntoTextFileContext)_localctx).charset = charsetName();
					}
				}

				setState(4162);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,608,_ctx) ) {
				case 1:
					{
					setState(4156);
					((SelectIntoTextFileContext)_localctx).fieldsFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==COLUMNS || _la==FIELDS) ) {
						((SelectIntoTextFileContext)_localctx).fieldsFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(4158); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(4157);
						selectFieldsInto();
						}
						}
						setState(4160); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==ENCLOSED || _la==ESCAPED || _la==OPTIONALLY || _la==TERMINATED );
					}
					break;
				}
				setState(4170);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LINES) {
					{
					setState(4164);
					match(LINES);
					setState(4166); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(4165);
						selectLinesInto();
						}
						}
						setState(4168); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( _la==STARTING || _la==TERMINATED );
					}
				}

				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectFieldsIntoContext extends ParserRuleContext {
		public Token terminationField;
		public Token enclosion;
		public Token escaping;
		public TerminalNode TERMINATED() { return getToken(MySqlParser.TERMINATED, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ENCLOSED() { return getToken(MySqlParser.ENCLOSED, 0); }
		public TerminalNode OPTIONALLY() { return getToken(MySqlParser.OPTIONALLY, 0); }
		public TerminalNode ESCAPED() { return getToken(MySqlParser.ESCAPED, 0); }
		public SelectFieldsIntoContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectFieldsInto; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectFieldsInto(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectFieldsInto(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectFieldsInto(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectFieldsIntoContext selectFieldsInto() throws RecognitionException {
		SelectFieldsIntoContext _localctx = new SelectFieldsIntoContext(_ctx, getState());
		enterRule(_localctx, 280, RULE_selectFieldsInto);
		int _la;
		try {
			setState(4186);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case TERMINATED:
				enterOuterAlt(_localctx, 1);
				{
				setState(4174);
				match(TERMINATED);
				setState(4175);
				match(BY);
				setState(4176);
				((SelectFieldsIntoContext)_localctx).terminationField = match(STRING_LITERAL);
				}
				break;
			case ENCLOSED:
			case OPTIONALLY:
				enterOuterAlt(_localctx, 2);
				{
				setState(4178);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==OPTIONALLY) {
					{
					setState(4177);
					match(OPTIONALLY);
					}
				}

				setState(4180);
				match(ENCLOSED);
				setState(4181);
				match(BY);
				setState(4182);
				((SelectFieldsIntoContext)_localctx).enclosion = match(STRING_LITERAL);
				}
				break;
			case ESCAPED:
				enterOuterAlt(_localctx, 3);
				{
				setState(4183);
				match(ESCAPED);
				setState(4184);
				match(BY);
				setState(4185);
				((SelectFieldsIntoContext)_localctx).escaping = match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SelectLinesIntoContext extends ParserRuleContext {
		public Token starting;
		public Token terminationLine;
		public TerminalNode STARTING() { return getToken(MySqlParser.STARTING, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode TERMINATED() { return getToken(MySqlParser.TERMINATED, 0); }
		public SelectLinesIntoContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_selectLinesInto; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSelectLinesInto(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSelectLinesInto(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSelectLinesInto(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SelectLinesIntoContext selectLinesInto() throws RecognitionException {
		SelectLinesIntoContext _localctx = new SelectLinesIntoContext(_ctx, getState());
		enterRule(_localctx, 282, RULE_selectLinesInto);
		try {
			setState(4194);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STARTING:
				enterOuterAlt(_localctx, 1);
				{
				setState(4188);
				match(STARTING);
				setState(4189);
				match(BY);
				setState(4190);
				((SelectLinesIntoContext)_localctx).starting = match(STRING_LITERAL);
				}
				break;
			case TERMINATED:
				enterOuterAlt(_localctx, 2);
				{
				setState(4191);
				match(TERMINATED);
				setState(4192);
				match(BY);
				setState(4193);
				((SelectLinesIntoContext)_localctx).terminationLine = match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FromClauseContext extends ParserRuleContext {
		public ExpressionContext whereExpr;
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TableSourcesContext tableSources() {
			return getRuleContext(TableSourcesContext.class,0);
		}
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public FromClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_fromClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFromClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFromClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFromClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FromClauseContext fromClause() throws RecognitionException {
		FromClauseContext _localctx = new FromClauseContext(_ctx, getState());
		enterRule(_localctx, 284, RULE_fromClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4198);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FROM) {
				{
				setState(4196);
				match(FROM);
				setState(4197);
				tableSources();
				}
			}

			setState(4202);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WHERE) {
				{
				setState(4200);
				match(WHERE);
				setState(4201);
				((FromClauseContext)_localctx).whereExpr = expression(0);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class GroupByClauseContext extends ParserRuleContext {
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public List groupByItem() {
			return getRuleContexts(GroupByItemContext.class);
		}
		public GroupByItemContext groupByItem(int i) {
			return getRuleContext(GroupByItemContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode ROLLUP() { return getToken(MySqlParser.ROLLUP, 0); }
		public GroupByClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_groupByClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGroupByClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGroupByClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGroupByClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GroupByClauseContext groupByClause() throws RecognitionException {
		GroupByClauseContext _localctx = new GroupByClauseContext(_ctx, getState());
		enterRule(_localctx, 286, RULE_groupByClause);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4204);
			match(GROUP);
			setState(4205);
			match(BY);
			setState(4206);
			groupByItem();
			setState(4211);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,617,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4207);
					match(COMMA);
					setState(4208);
					groupByItem();
					}
					} 
				}
				setState(4213);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,617,_ctx);
			}
			setState(4216);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,618,_ctx) ) {
			case 1:
				{
				setState(4214);
				match(WITH);
				setState(4215);
				match(ROLLUP);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HavingClauseContext extends ParserRuleContext {
		public ExpressionContext havingExpr;
		public TerminalNode HAVING() { return getToken(MySqlParser.HAVING, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public HavingClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_havingClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHavingClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHavingClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHavingClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HavingClauseContext havingClause() throws RecognitionException {
		HavingClauseContext _localctx = new HavingClauseContext(_ctx, getState());
		enterRule(_localctx, 288, RULE_havingClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4218);
			match(HAVING);
			setState(4219);
			((HavingClauseContext)_localctx).havingExpr = expression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WindowClauseContext extends ParserRuleContext {
		public TerminalNode WINDOW() { return getToken(MySqlParser.WINDOW, 0); }
		public List windowName() {
			return getRuleContexts(WindowNameContext.class);
		}
		public WindowNameContext windowName(int i) {
			return getRuleContext(WindowNameContext.class,i);
		}
		public List AS() { return getTokens(MySqlParser.AS); }
		public TerminalNode AS(int i) {
			return getToken(MySqlParser.AS, i);
		}
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List windowSpec() {
			return getRuleContexts(WindowSpecContext.class);
		}
		public WindowSpecContext windowSpec(int i) {
			return getRuleContext(WindowSpecContext.class,i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public WindowClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_windowClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWindowClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWindowClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWindowClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WindowClauseContext windowClause() throws RecognitionException {
		WindowClauseContext _localctx = new WindowClauseContext(_ctx, getState());
		enterRule(_localctx, 290, RULE_windowClause);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4221);
			match(WINDOW);
			setState(4222);
			windowName();
			setState(4223);
			match(AS);
			setState(4224);
			match(LR_BRACKET);
			setState(4225);
			windowSpec();
			setState(4226);
			match(RR_BRACKET);
			setState(4236);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,619,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4227);
					match(COMMA);
					setState(4228);
					windowName();
					setState(4229);
					match(AS);
					setState(4230);
					match(LR_BRACKET);
					setState(4231);
					windowSpec();
					setState(4232);
					match(RR_BRACKET);
					}
					} 
				}
				setState(4238);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,619,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class GroupByItemContext extends ParserRuleContext {
		public Token order;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode ASC() { return getToken(MySqlParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MySqlParser.DESC, 0); }
		public GroupByItemContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_groupByItem; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGroupByItem(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGroupByItem(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGroupByItem(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GroupByItemContext groupByItem() throws RecognitionException {
		GroupByItemContext _localctx = new GroupByItemContext(_ctx, getState());
		enterRule(_localctx, 292, RULE_groupByItem);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4239);
			expression(0);
			setState(4241);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,620,_ctx) ) {
			case 1:
				{
				setState(4240);
				((GroupByItemContext)_localctx).order = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ASC || _la==DESC) ) {
					((GroupByItemContext)_localctx).order = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LimitClauseContext extends ParserRuleContext {
		public LimitClauseAtomContext offset;
		public LimitClauseAtomContext limit;
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public TerminalNode OFFSET() { return getToken(MySqlParser.OFFSET, 0); }
		public List limitClauseAtom() {
			return getRuleContexts(LimitClauseAtomContext.class);
		}
		public LimitClauseAtomContext limitClauseAtom(int i) {
			return getRuleContext(LimitClauseAtomContext.class,i);
		}
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public LimitClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_limitClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLimitClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLimitClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLimitClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LimitClauseContext limitClause() throws RecognitionException {
		LimitClauseContext _localctx = new LimitClauseContext(_ctx, getState());
		enterRule(_localctx, 294, RULE_limitClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4243);
			match(LIMIT);
			setState(4254);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,622,_ctx) ) {
			case 1:
				{
				setState(4247);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,621,_ctx) ) {
				case 1:
					{
					setState(4244);
					((LimitClauseContext)_localctx).offset = limitClauseAtom();
					setState(4245);
					match(COMMA);
					}
					break;
				}
				setState(4249);
				((LimitClauseContext)_localctx).limit = limitClauseAtom();
				}
				break;
			case 2:
				{
				setState(4250);
				((LimitClauseContext)_localctx).limit = limitClauseAtom();
				setState(4251);
				match(OFFSET);
				setState(4252);
				((LimitClauseContext)_localctx).offset = limitClauseAtom();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LimitClauseAtomContext extends ParserRuleContext {
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public MysqlVariableContext mysqlVariable() {
			return getRuleContext(MysqlVariableContext.class,0);
		}
		public SimpleIdContext simpleId() {
			return getRuleContext(SimpleIdContext.class,0);
		}
		public LimitClauseAtomContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_limitClauseAtom; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLimitClauseAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLimitClauseAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLimitClauseAtom(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LimitClauseAtomContext limitClauseAtom() throws RecognitionException {
		LimitClauseAtomContext _localctx = new LimitClauseAtomContext(_ctx, getState());
		enterRule(_localctx, 296, RULE_limitClauseAtom);
		try {
			setState(4259);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(4256);
				decimalLiteral();
				}
				break;
			case LOCAL_ID:
			case GLOBAL_ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(4257);
				mysqlVariable();
				}
				break;
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case ID:
				enterOuterAlt(_localctx, 3);
				{
				setState(4258);
				simpleId();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StartTransactionContext extends ParserRuleContext {
		public TerminalNode START() { return getToken(MySqlParser.START, 0); }
		public TerminalNode TRANSACTION() { return getToken(MySqlParser.TRANSACTION, 0); }
		public List transactionMode() {
			return getRuleContexts(TransactionModeContext.class);
		}
		public TransactionModeContext transactionMode(int i) {
			return getRuleContext(TransactionModeContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public StartTransactionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_startTransaction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStartTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStartTransaction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStartTransaction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StartTransactionContext startTransaction() throws RecognitionException {
		StartTransactionContext _localctx = new StartTransactionContext(_ctx, getState());
		enterRule(_localctx, 298, RULE_startTransaction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4261);
			match(START);
			setState(4262);
			match(TRANSACTION);
			setState(4271);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,625,_ctx) ) {
			case 1:
				{
				setState(4263);
				transactionMode();
				setState(4268);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4264);
					match(COMMA);
					setState(4265);
					transactionMode();
					}
					}
					setState(4270);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class BeginWorkContext extends ParserRuleContext {
		public TerminalNode BEGIN() { return getToken(MySqlParser.BEGIN, 0); }
		public TerminalNode WORK() { return getToken(MySqlParser.WORK, 0); }
		public BeginWorkContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_beginWork; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBeginWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBeginWork(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBeginWork(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BeginWorkContext beginWork() throws RecognitionException {
		BeginWorkContext _localctx = new BeginWorkContext(_ctx, getState());
		enterRule(_localctx, 300, RULE_beginWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4273);
			match(BEGIN);
			setState(4275);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WORK) {
				{
				setState(4274);
				match(WORK);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CommitWorkContext extends ParserRuleContext {
		public Token nochain;
		public Token norelease;
		public TerminalNode COMMIT() { return getToken(MySqlParser.COMMIT, 0); }
		public TerminalNode WORK() { return getToken(MySqlParser.WORK, 0); }
		public TerminalNode AND() { return getToken(MySqlParser.AND, 0); }
		public TerminalNode CHAIN() { return getToken(MySqlParser.CHAIN, 0); }
		public TerminalNode RELEASE() { return getToken(MySqlParser.RELEASE, 0); }
		public List NO() { return getTokens(MySqlParser.NO); }
		public TerminalNode NO(int i) {
			return getToken(MySqlParser.NO, i);
		}
		public CommitWorkContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_commitWork; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCommitWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCommitWork(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCommitWork(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CommitWorkContext commitWork() throws RecognitionException {
		CommitWorkContext _localctx = new CommitWorkContext(_ctx, getState());
		enterRule(_localctx, 302, RULE_commitWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4277);
			match(COMMIT);
			setState(4279);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WORK) {
				{
				setState(4278);
				match(WORK);
				}
			}

			setState(4286);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AND) {
				{
				setState(4281);
				match(AND);
				setState(4283);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4282);
					((CommitWorkContext)_localctx).nochain = match(NO);
					}
				}

				setState(4285);
				match(CHAIN);
				}
			}

			setState(4292);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,631,_ctx) ) {
			case 1:
				{
				setState(4289);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4288);
					((CommitWorkContext)_localctx).norelease = match(NO);
					}
				}

				setState(4291);
				match(RELEASE);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RollbackWorkContext extends ParserRuleContext {
		public Token nochain;
		public Token norelease;
		public TerminalNode ROLLBACK() { return getToken(MySqlParser.ROLLBACK, 0); }
		public TerminalNode WORK() { return getToken(MySqlParser.WORK, 0); }
		public TerminalNode AND() { return getToken(MySqlParser.AND, 0); }
		public TerminalNode CHAIN() { return getToken(MySqlParser.CHAIN, 0); }
		public TerminalNode RELEASE() { return getToken(MySqlParser.RELEASE, 0); }
		public List NO() { return getTokens(MySqlParser.NO); }
		public TerminalNode NO(int i) {
			return getToken(MySqlParser.NO, i);
		}
		public RollbackWorkContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_rollbackWork; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRollbackWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRollbackWork(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRollbackWork(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RollbackWorkContext rollbackWork() throws RecognitionException {
		RollbackWorkContext _localctx = new RollbackWorkContext(_ctx, getState());
		enterRule(_localctx, 304, RULE_rollbackWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4294);
			match(ROLLBACK);
			setState(4296);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WORK) {
				{
				setState(4295);
				match(WORK);
				}
			}

			setState(4303);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AND) {
				{
				setState(4298);
				match(AND);
				setState(4300);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4299);
					((RollbackWorkContext)_localctx).nochain = match(NO);
					}
				}

				setState(4302);
				match(CHAIN);
				}
			}

			setState(4309);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,636,_ctx) ) {
			case 1:
				{
				setState(4306);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NO) {
					{
					setState(4305);
					((RollbackWorkContext)_localctx).norelease = match(NO);
					}
				}

				setState(4308);
				match(RELEASE);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SavepointStatementContext extends ParserRuleContext {
		public TerminalNode SAVEPOINT() { return getToken(MySqlParser.SAVEPOINT, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public SavepointStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_savepointStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSavepointStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSavepointStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSavepointStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SavepointStatementContext savepointStatement() throws RecognitionException {
		SavepointStatementContext _localctx = new SavepointStatementContext(_ctx, getState());
		enterRule(_localctx, 306, RULE_savepointStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4311);
			match(SAVEPOINT);
			setState(4312);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RollbackStatementContext extends ParserRuleContext {
		public TerminalNode ROLLBACK() { return getToken(MySqlParser.ROLLBACK, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode WORK() { return getToken(MySqlParser.WORK, 0); }
		public TerminalNode SAVEPOINT() { return getToken(MySqlParser.SAVEPOINT, 0); }
		public RollbackStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_rollbackStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRollbackStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRollbackStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRollbackStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RollbackStatementContext rollbackStatement() throws RecognitionException {
		RollbackStatementContext _localctx = new RollbackStatementContext(_ctx, getState());
		enterRule(_localctx, 308, RULE_rollbackStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4314);
			match(ROLLBACK);
			setState(4316);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==WORK) {
				{
				setState(4315);
				match(WORK);
				}
			}

			setState(4318);
			match(TO);
			setState(4320);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,638,_ctx) ) {
			case 1:
				{
				setState(4319);
				match(SAVEPOINT);
				}
				break;
			}
			setState(4322);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReleaseStatementContext extends ParserRuleContext {
		public TerminalNode RELEASE() { return getToken(MySqlParser.RELEASE, 0); }
		public TerminalNode SAVEPOINT() { return getToken(MySqlParser.SAVEPOINT, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ReleaseStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_releaseStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReleaseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReleaseStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReleaseStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReleaseStatementContext releaseStatement() throws RecognitionException {
		ReleaseStatementContext _localctx = new ReleaseStatementContext(_ctx, getState());
		enterRule(_localctx, 310, RULE_releaseStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4324);
			match(RELEASE);
			setState(4325);
			match(SAVEPOINT);
			setState(4326);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LockTablesContext extends ParserRuleContext {
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public List lockTableElement() {
			return getRuleContexts(LockTableElementContext.class);
		}
		public LockTableElementContext lockTableElement(int i) {
			return getRuleContext(LockTableElementContext.class,i);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public WaitNowaitClauseContext waitNowaitClause() {
			return getRuleContext(WaitNowaitClauseContext.class,0);
		}
		public LockTablesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lockTables; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLockTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLockTables(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLockTables(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LockTablesContext lockTables() throws RecognitionException {
		LockTablesContext _localctx = new LockTablesContext(_ctx, getState());
		enterRule(_localctx, 312, RULE_lockTables);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4328);
			match(LOCK);
			setState(4329);
			_la = _input.LA(1);
			if ( !(_la==TABLE || _la==TABLES) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(4330);
			lockTableElement();
			setState(4335);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4331);
				match(COMMA);
				setState(4332);
				lockTableElement();
				}
				}
				setState(4337);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4339);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOWAIT || _la==WAIT) {
				{
				setState(4338);
				waitNowaitClause();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UnlockTablesContext extends ParserRuleContext {
		public TerminalNode UNLOCK() { return getToken(MySqlParser.UNLOCK, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public UnlockTablesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_unlockTables; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnlockTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnlockTables(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnlockTables(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UnlockTablesContext unlockTables() throws RecognitionException {
		UnlockTablesContext _localctx = new UnlockTablesContext(_ctx, getState());
		enterRule(_localctx, 314, RULE_unlockTables);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4341);
			match(UNLOCK);
			setState(4342);
			match(TABLES);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SetAutocommitStatementContext extends ParserRuleContext {
		public Token autocommitValue;
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode AUTOCOMMIT() { return getToken(MySqlParser.AUTOCOMMIT, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public SetAutocommitStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_setAutocommitStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetAutocommitStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetAutocommitStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetAutocommitStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SetAutocommitStatementContext setAutocommitStatement() throws RecognitionException {
		SetAutocommitStatementContext _localctx = new SetAutocommitStatementContext(_ctx, getState());
		enterRule(_localctx, 316, RULE_setAutocommitStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4344);
			match(SET);
			setState(4345);
			match(AUTOCOMMIT);
			setState(4346);
			match(EQUAL_SYMBOL);
			setState(4347);
			((SetAutocommitStatementContext)_localctx).autocommitValue = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
				((SetAutocommitStatementContext)_localctx).autocommitValue = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SetTransactionStatementContext extends ParserRuleContext {
		public Token transactionContext;
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode TRANSACTION() { return getToken(MySqlParser.TRANSACTION, 0); }
		public List transactionOption() {
			return getRuleContexts(TransactionOptionContext.class);
		}
		public TransactionOptionContext transactionOption(int i) {
			return getRuleContext(TransactionOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode GLOBAL() { return getToken(MySqlParser.GLOBAL, 0); }
		public TerminalNode SESSION() { return getToken(MySqlParser.SESSION, 0); }
		public SetTransactionStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_setTransactionStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetTransactionStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetTransactionStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetTransactionStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SetTransactionStatementContext setTransactionStatement() throws RecognitionException {
		SetTransactionStatementContext _localctx = new SetTransactionStatementContext(_ctx, getState());
		enterRule(_localctx, 318, RULE_setTransactionStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4349);
			match(SET);
			setState(4351);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==GLOBAL || _la==SESSION) {
				{
				setState(4350);
				((SetTransactionStatementContext)_localctx).transactionContext = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==GLOBAL || _la==SESSION) ) {
					((SetTransactionStatementContext)_localctx).transactionContext = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(4353);
			match(TRANSACTION);
			setState(4354);
			transactionOption();
			setState(4359);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4355);
				match(COMMA);
				setState(4356);
				transactionOption();
				}
				}
				setState(4361);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TransactionModeContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode CONSISTENT() { return getToken(MySqlParser.CONSISTENT, 0); }
		public TerminalNode SNAPSHOT() { return getToken(MySqlParser.SNAPSHOT, 0); }
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode WRITE() { return getToken(MySqlParser.WRITE, 0); }
		public TerminalNode ONLY() { return getToken(MySqlParser.ONLY, 0); }
		public TransactionModeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_transactionMode; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTransactionMode(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTransactionMode(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTransactionMode(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TransactionModeContext transactionMode() throws RecognitionException {
		TransactionModeContext _localctx = new TransactionModeContext(_ctx, getState());
		enterRule(_localctx, 320, RULE_transactionMode);
		try {
			setState(4369);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,643,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4362);
				match(WITH);
				setState(4363);
				match(CONSISTENT);
				setState(4364);
				match(SNAPSHOT);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4365);
				match(READ);
				setState(4366);
				match(WRITE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(4367);
				match(READ);
				setState(4368);
				match(ONLY);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LockTableElementContext extends ParserRuleContext {
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public LockActionContext lockAction() {
			return getRuleContext(LockActionContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public LockTableElementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lockTableElement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLockTableElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLockTableElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLockTableElement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LockTableElementContext lockTableElement() throws RecognitionException {
		LockTableElementContext _localctx = new LockTableElementContext(_ctx, getState());
		enterRule(_localctx, 322, RULE_lockTableElement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4371);
			tableName();
			setState(4376);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513126400L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(4373);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(4372);
					match(AS);
					}
				}

				setState(4375);
				uid();
				}
			}

			setState(4378);
			lockAction();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LockActionContext extends ParserRuleContext {
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public TerminalNode WRITE() { return getToken(MySqlParser.WRITE, 0); }
		public TerminalNode LOW_PRIORITY() { return getToken(MySqlParser.LOW_PRIORITY, 0); }
		public LockActionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lockAction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLockAction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLockAction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLockAction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LockActionContext lockAction() throws RecognitionException {
		LockActionContext _localctx = new LockActionContext(_ctx, getState());
		enterRule(_localctx, 324, RULE_lockAction);
		int _la;
		try {
			setState(4388);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case READ:
				enterOuterAlt(_localctx, 1);
				{
				setState(4380);
				match(READ);
				setState(4382);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LOCAL) {
					{
					setState(4381);
					match(LOCAL);
					}
				}

				}
				break;
			case LOW_PRIORITY:
			case WRITE:
				enterOuterAlt(_localctx, 2);
				{
				setState(4385);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LOW_PRIORITY) {
					{
					setState(4384);
					match(LOW_PRIORITY);
					}
				}

				setState(4387);
				match(WRITE);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TransactionOptionContext extends ParserRuleContext {
		public TerminalNode ISOLATION() { return getToken(MySqlParser.ISOLATION, 0); }
		public TerminalNode LEVEL() { return getToken(MySqlParser.LEVEL, 0); }
		public TransactionLevelContext transactionLevel() {
			return getRuleContext(TransactionLevelContext.class,0);
		}
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode WRITE() { return getToken(MySqlParser.WRITE, 0); }
		public TerminalNode ONLY() { return getToken(MySqlParser.ONLY, 0); }
		public TransactionOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_transactionOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTransactionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTransactionOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTransactionOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TransactionOptionContext transactionOption() throws RecognitionException {
		TransactionOptionContext _localctx = new TransactionOptionContext(_ctx, getState());
		enterRule(_localctx, 326, RULE_transactionOption);
		try {
			setState(4397);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,649,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4390);
				match(ISOLATION);
				setState(4391);
				match(LEVEL);
				setState(4392);
				transactionLevel();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4393);
				match(READ);
				setState(4394);
				match(WRITE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(4395);
				match(READ);
				setState(4396);
				match(ONLY);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TransactionLevelContext extends ParserRuleContext {
		public TerminalNode REPEATABLE() { return getToken(MySqlParser.REPEATABLE, 0); }
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode COMMITTED() { return getToken(MySqlParser.COMMITTED, 0); }
		public TerminalNode UNCOMMITTED() { return getToken(MySqlParser.UNCOMMITTED, 0); }
		public TerminalNode SERIALIZABLE() { return getToken(MySqlParser.SERIALIZABLE, 0); }
		public TransactionLevelContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_transactionLevel; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTransactionLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTransactionLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTransactionLevel(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TransactionLevelContext transactionLevel() throws RecognitionException {
		TransactionLevelContext _localctx = new TransactionLevelContext(_ctx, getState());
		enterRule(_localctx, 328, RULE_transactionLevel);
		try {
			setState(4406);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,650,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4399);
				match(REPEATABLE);
				setState(4400);
				match(READ);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4401);
				match(READ);
				setState(4402);
				match(COMMITTED);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(4403);
				match(READ);
				setState(4404);
				match(UNCOMMITTED);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(4405);
				match(SERIALIZABLE);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ChangeMasterContext extends ParserRuleContext {
		public TerminalNode CHANGE() { return getToken(MySqlParser.CHANGE, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public List masterOption() {
			return getRuleContexts(MasterOptionContext.class);
		}
		public MasterOptionContext masterOption(int i) {
			return getRuleContext(MasterOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ChannelOptionContext channelOption() {
			return getRuleContext(ChannelOptionContext.class,0);
		}
		public ChangeMasterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_changeMaster; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterChangeMaster(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitChangeMaster(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitChangeMaster(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ChangeMasterContext changeMaster() throws RecognitionException {
		ChangeMasterContext _localctx = new ChangeMasterContext(_ctx, getState());
		enterRule(_localctx, 330, RULE_changeMaster);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4408);
			match(CHANGE);
			setState(4409);
			match(MASTER);
			setState(4410);
			match(TO);
			setState(4411);
			masterOption();
			setState(4416);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4412);
				match(COMMA);
				setState(4413);
				masterOption();
				}
				}
				setState(4418);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4420);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(4419);
				channelOption();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ChangeReplicationFilterContext extends ParserRuleContext {
		public TerminalNode CHANGE() { return getToken(MySqlParser.CHANGE, 0); }
		public TerminalNode REPLICATION() { return getToken(MySqlParser.REPLICATION, 0); }
		public TerminalNode FILTER() { return getToken(MySqlParser.FILTER, 0); }
		public List replicationFilter() {
			return getRuleContexts(ReplicationFilterContext.class);
		}
		public ReplicationFilterContext replicationFilter(int i) {
			return getRuleContext(ReplicationFilterContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ChangeReplicationFilterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_changeReplicationFilter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterChangeReplicationFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitChangeReplicationFilter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitChangeReplicationFilter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ChangeReplicationFilterContext changeReplicationFilter() throws RecognitionException {
		ChangeReplicationFilterContext _localctx = new ChangeReplicationFilterContext(_ctx, getState());
		enterRule(_localctx, 332, RULE_changeReplicationFilter);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4422);
			match(CHANGE);
			setState(4423);
			match(REPLICATION);
			setState(4424);
			match(FILTER);
			setState(4425);
			replicationFilter();
			setState(4430);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4426);
				match(COMMA);
				setState(4427);
				replicationFilter();
				}
				}
				setState(4432);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PurgeBinaryLogsContext extends ParserRuleContext {
		public Token purgeFormat;
		public Token fileName;
		public Token timeValue;
		public TerminalNode PURGE() { return getToken(MySqlParser.PURGE, 0); }
		public TerminalNode LOGS() { return getToken(MySqlParser.LOGS, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public TerminalNode BEFORE() { return getToken(MySqlParser.BEFORE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public PurgeBinaryLogsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_purgeBinaryLogs; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPurgeBinaryLogs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPurgeBinaryLogs(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPurgeBinaryLogs(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PurgeBinaryLogsContext purgeBinaryLogs() throws RecognitionException {
		PurgeBinaryLogsContext _localctx = new PurgeBinaryLogsContext(_ctx, getState());
		enterRule(_localctx, 334, RULE_purgeBinaryLogs);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4433);
			match(PURGE);
			setState(4434);
			((PurgeBinaryLogsContext)_localctx).purgeFormat = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==BINARY || _la==MASTER) ) {
				((PurgeBinaryLogsContext)_localctx).purgeFormat = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(4435);
			match(LOGS);
			setState(4440);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case TO:
				{
				setState(4436);
				match(TO);
				setState(4437);
				((PurgeBinaryLogsContext)_localctx).fileName = match(STRING_LITERAL);
				}
				break;
			case BEFORE:
				{
				setState(4438);
				match(BEFORE);
				setState(4439);
				((PurgeBinaryLogsContext)_localctx).timeValue = match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ResetMasterContext extends ParserRuleContext {
		public TerminalNode RESET() { return getToken(MySqlParser.RESET, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public ResetMasterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_resetMaster; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterResetMaster(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitResetMaster(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitResetMaster(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ResetMasterContext resetMaster() throws RecognitionException {
		ResetMasterContext _localctx = new ResetMasterContext(_ctx, getState());
		enterRule(_localctx, 336, RULE_resetMaster);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4442);
			match(RESET);
			setState(4443);
			match(MASTER);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ResetSlaveContext extends ParserRuleContext {
		public TerminalNode RESET() { return getToken(MySqlParser.RESET, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public ChannelOptionContext channelOption() {
			return getRuleContext(ChannelOptionContext.class,0);
		}
		public ResetSlaveContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_resetSlave; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterResetSlave(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitResetSlave(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitResetSlave(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ResetSlaveContext resetSlave() throws RecognitionException {
		ResetSlaveContext _localctx = new ResetSlaveContext(_ctx, getState());
		enterRule(_localctx, 338, RULE_resetSlave);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4445);
			match(RESET);
			setState(4446);
			match(SLAVE);
			setState(4448);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ALL) {
				{
				setState(4447);
				match(ALL);
				}
			}

			setState(4451);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(4450);
				channelOption();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StartSlaveContext extends ParserRuleContext {
		public TerminalNode START() { return getToken(MySqlParser.START, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public List threadType() {
			return getRuleContexts(ThreadTypeContext.class);
		}
		public ThreadTypeContext threadType(int i) {
			return getRuleContext(ThreadTypeContext.class,i);
		}
		public TerminalNode UNTIL() { return getToken(MySqlParser.UNTIL, 0); }
		public UntilOptionContext untilOption() {
			return getRuleContext(UntilOptionContext.class,0);
		}
		public List connectionOption() {
			return getRuleContexts(ConnectionOptionContext.class);
		}
		public ConnectionOptionContext connectionOption(int i) {
			return getRuleContext(ConnectionOptionContext.class,i);
		}
		public ChannelOptionContext channelOption() {
			return getRuleContext(ChannelOptionContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public StartSlaveContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_startSlave; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStartSlave(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStartSlave(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStartSlave(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StartSlaveContext startSlave() throws RecognitionException {
		StartSlaveContext _localctx = new StartSlaveContext(_ctx, getState());
		enterRule(_localctx, 340, RULE_startSlave);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4453);
			match(START);
			setState(4454);
			match(SLAVE);
			setState(4463);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IO_THREAD || _la==SQL_THREAD) {
				{
				setState(4455);
				threadType();
				setState(4460);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4456);
					match(COMMA);
					setState(4457);
					threadType();
					}
					}
					setState(4462);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
			}

			setState(4467);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==UNTIL) {
				{
				setState(4465);
				match(UNTIL);
				setState(4466);
				untilOption();
				}
			}

			setState(4472);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DEFAULT_AUTH || _la==PASSWORD || _la==PLUGIN_DIR || _la==USER) {
				{
				{
				setState(4469);
				connectionOption();
				}
				}
				setState(4474);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4476);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(4475);
				channelOption();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StopSlaveContext extends ParserRuleContext {
		public TerminalNode STOP() { return getToken(MySqlParser.STOP, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public List threadType() {
			return getRuleContexts(ThreadTypeContext.class);
		}
		public ThreadTypeContext threadType(int i) {
			return getRuleContext(ThreadTypeContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public StopSlaveContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_stopSlave; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStopSlave(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStopSlave(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStopSlave(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StopSlaveContext stopSlave() throws RecognitionException {
		StopSlaveContext _localctx = new StopSlaveContext(_ctx, getState());
		enterRule(_localctx, 342, RULE_stopSlave);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4478);
			match(STOP);
			setState(4479);
			match(SLAVE);
			setState(4488);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IO_THREAD || _la==SQL_THREAD) {
				{
				setState(4480);
				threadType();
				setState(4485);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4481);
					match(COMMA);
					setState(4482);
					threadType();
					}
					}
					setState(4487);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StartGroupReplicationContext extends ParserRuleContext {
		public TerminalNode START() { return getToken(MySqlParser.START, 0); }
		public TerminalNode GROUP_REPLICATION() { return getToken(MySqlParser.GROUP_REPLICATION, 0); }
		public StartGroupReplicationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_startGroupReplication; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStartGroupReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStartGroupReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStartGroupReplication(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StartGroupReplicationContext startGroupReplication() throws RecognitionException {
		StartGroupReplicationContext _localctx = new StartGroupReplicationContext(_ctx, getState());
		enterRule(_localctx, 344, RULE_startGroupReplication);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4490);
			match(START);
			setState(4491);
			match(GROUP_REPLICATION);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StopGroupReplicationContext extends ParserRuleContext {
		public TerminalNode STOP() { return getToken(MySqlParser.STOP, 0); }
		public TerminalNode GROUP_REPLICATION() { return getToken(MySqlParser.GROUP_REPLICATION, 0); }
		public StopGroupReplicationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_stopGroupReplication; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStopGroupReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStopGroupReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStopGroupReplication(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StopGroupReplicationContext stopGroupReplication() throws RecognitionException {
		StopGroupReplicationContext _localctx = new StopGroupReplicationContext(_ctx, getState());
		enterRule(_localctx, 346, RULE_stopGroupReplication);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4493);
			match(STOP);
			setState(4494);
			match(GROUP_REPLICATION);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class MasterOptionContext extends ParserRuleContext {
		public MasterOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_masterOption; }
	 
		public MasterOptionContext() { }
		public void copyFrom(MasterOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MasterStringOptionContext extends MasterOptionContext {
		public StringMasterOptionContext stringMasterOption() {
			return getRuleContext(StringMasterOptionContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public MasterStringOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMasterStringOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMasterStringOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMasterStringOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MasterRealOptionContext extends MasterOptionContext {
		public TerminalNode MASTER_HEARTBEAT_PERIOD() { return getToken(MySqlParser.MASTER_HEARTBEAT_PERIOD, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode REAL_LITERAL() { return getToken(MySqlParser.REAL_LITERAL, 0); }
		public MasterRealOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMasterRealOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMasterRealOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMasterRealOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MasterBoolOptionContext extends MasterOptionContext {
		public Token boolVal;
		public BoolMasterOptionContext boolMasterOption() {
			return getRuleContext(BoolMasterOptionContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public MasterBoolOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMasterBoolOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMasterBoolOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMasterBoolOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MasterUidListOptionContext extends MasterOptionContext {
		public TerminalNode IGNORE_SERVER_IDS() { return getToken(MySqlParser.IGNORE_SERVER_IDS, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public MasterUidListOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMasterUidListOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMasterUidListOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMasterUidListOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MasterDecimalOptionContext extends MasterOptionContext {
		public DecimalMasterOptionContext decimalMasterOption() {
			return getRuleContext(DecimalMasterOptionContext.class,0);
		}
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public MasterDecimalOptionContext(MasterOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMasterDecimalOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMasterDecimalOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMasterDecimalOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MasterOptionContext masterOption() throws RecognitionException {
		MasterOptionContext _localctx = new MasterOptionContext(_ctx, getState());
		enterRule(_localctx, 348, RULE_masterOption);
		int _la;
		try {
			setState(4525);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case MASTER_BIND:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_PASSWORD:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case RELAY_LOG_FILE:
				_localctx = new MasterStringOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4496);
				stringMasterOption();
				setState(4497);
				match(EQUAL_SYMBOL);
				setState(4498);
				match(STRING_LITERAL);
				}
				break;
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_LOG_POS:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case RELAY_LOG_POS:
				_localctx = new MasterDecimalOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4500);
				decimalMasterOption();
				setState(4501);
				match(EQUAL_SYMBOL);
				setState(4502);
				decimalLiteral();
				}
				break;
			case MASTER_SSL_VERIFY_SERVER_CERT:
			case MASTER_AUTO_POSITION:
			case MASTER_SSL:
				_localctx = new MasterBoolOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4504);
				boolMasterOption();
				setState(4505);
				match(EQUAL_SYMBOL);
				setState(4506);
				((MasterBoolOptionContext)_localctx).boolVal = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ZERO_DECIMAL || _la==ONE_DECIMAL) ) {
					((MasterBoolOptionContext)_localctx).boolVal = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case MASTER_HEARTBEAT_PERIOD:
				_localctx = new MasterRealOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4508);
				match(MASTER_HEARTBEAT_PERIOD);
				setState(4509);
				match(EQUAL_SYMBOL);
				setState(4510);
				match(REAL_LITERAL);
				}
				break;
			case IGNORE_SERVER_IDS:
				_localctx = new MasterUidListOptionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(4511);
				match(IGNORE_SERVER_IDS);
				setState(4512);
				match(EQUAL_SYMBOL);
				setState(4513);
				match(LR_BRACKET);
				setState(4522);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
					{
					setState(4514);
					uid();
					setState(4519);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(4515);
						match(COMMA);
						setState(4516);
						uid();
						}
						}
						setState(4521);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(4524);
				match(RR_BRACKET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StringMasterOptionContext extends ParserRuleContext {
		public TerminalNode MASTER_BIND() { return getToken(MySqlParser.MASTER_BIND, 0); }
		public TerminalNode MASTER_HOST() { return getToken(MySqlParser.MASTER_HOST, 0); }
		public TerminalNode MASTER_USER() { return getToken(MySqlParser.MASTER_USER, 0); }
		public TerminalNode MASTER_PASSWORD() { return getToken(MySqlParser.MASTER_PASSWORD, 0); }
		public TerminalNode MASTER_LOG_FILE() { return getToken(MySqlParser.MASTER_LOG_FILE, 0); }
		public TerminalNode RELAY_LOG_FILE() { return getToken(MySqlParser.RELAY_LOG_FILE, 0); }
		public TerminalNode MASTER_SSL_CA() { return getToken(MySqlParser.MASTER_SSL_CA, 0); }
		public TerminalNode MASTER_SSL_CAPATH() { return getToken(MySqlParser.MASTER_SSL_CAPATH, 0); }
		public TerminalNode MASTER_SSL_CERT() { return getToken(MySqlParser.MASTER_SSL_CERT, 0); }
		public TerminalNode MASTER_SSL_CRL() { return getToken(MySqlParser.MASTER_SSL_CRL, 0); }
		public TerminalNode MASTER_SSL_CRLPATH() { return getToken(MySqlParser.MASTER_SSL_CRLPATH, 0); }
		public TerminalNode MASTER_SSL_KEY() { return getToken(MySqlParser.MASTER_SSL_KEY, 0); }
		public TerminalNode MASTER_SSL_CIPHER() { return getToken(MySqlParser.MASTER_SSL_CIPHER, 0); }
		public TerminalNode MASTER_TLS_VERSION() { return getToken(MySqlParser.MASTER_TLS_VERSION, 0); }
		public StringMasterOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_stringMasterOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStringMasterOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStringMasterOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStringMasterOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StringMasterOptionContext stringMasterOption() throws RecognitionException {
		StringMasterOptionContext _localctx = new StringMasterOptionContext(_ctx, getState());
		enterRule(_localctx, 350, RULE_stringMasterOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4527);
			_la = _input.LA(1);
			if ( !(_la==MASTER_BIND || ((((_la - 482)) & ~0x3f) == 0 && ((1L << (_la - 482)) & 65419L) != 0) || _la==RELAY_LOG_FILE) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DecimalMasterOptionContext extends ParserRuleContext {
		public TerminalNode MASTER_PORT() { return getToken(MySqlParser.MASTER_PORT, 0); }
		public TerminalNode MASTER_CONNECT_RETRY() { return getToken(MySqlParser.MASTER_CONNECT_RETRY, 0); }
		public TerminalNode MASTER_RETRY_COUNT() { return getToken(MySqlParser.MASTER_RETRY_COUNT, 0); }
		public TerminalNode MASTER_DELAY() { return getToken(MySqlParser.MASTER_DELAY, 0); }
		public TerminalNode MASTER_LOG_POS() { return getToken(MySqlParser.MASTER_LOG_POS, 0); }
		public TerminalNode RELAY_LOG_POS() { return getToken(MySqlParser.RELAY_LOG_POS, 0); }
		public DecimalMasterOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_decimalMasterOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDecimalMasterOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDecimalMasterOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDecimalMasterOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DecimalMasterOptionContext decimalMasterOption() throws RecognitionException {
		DecimalMasterOptionContext _localctx = new DecimalMasterOptionContext(_ctx, getState());
		enterRule(_localctx, 352, RULE_decimalMasterOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4529);
			_la = _input.LA(1);
			if ( !(((((_la - 479)) & ~0x3f) == 0 && ((1L << (_la - 479)) & 419L) != 0) || _la==RELAY_LOG_POS) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class BoolMasterOptionContext extends ParserRuleContext {
		public TerminalNode MASTER_AUTO_POSITION() { return getToken(MySqlParser.MASTER_AUTO_POSITION, 0); }
		public TerminalNode MASTER_SSL() { return getToken(MySqlParser.MASTER_SSL, 0); }
		public TerminalNode MASTER_SSL_VERIFY_SERVER_CERT() { return getToken(MySqlParser.MASTER_SSL_VERIFY_SERVER_CERT, 0); }
		public BoolMasterOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_boolMasterOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBoolMasterOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBoolMasterOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBoolMasterOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BoolMasterOptionContext boolMasterOption() throws RecognitionException {
		BoolMasterOptionContext _localctx = new BoolMasterOptionContext(_ctx, getState());
		enterRule(_localctx, 354, RULE_boolMasterOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4531);
			_la = _input.LA(1);
			if ( !(_la==MASTER_SSL_VERIFY_SERVER_CERT || _la==MASTER_AUTO_POSITION || _la==MASTER_SSL) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ChannelOptionContext extends ParserRuleContext {
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode CHANNEL() { return getToken(MySqlParser.CHANNEL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public ChannelOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_channelOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterChannelOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitChannelOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitChannelOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ChannelOptionContext channelOption() throws RecognitionException {
		ChannelOptionContext _localctx = new ChannelOptionContext(_ctx, getState());
		enterRule(_localctx, 356, RULE_channelOption);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4533);
			match(FOR);
			setState(4534);
			match(CHANNEL);
			setState(4535);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReplicationFilterContext extends ParserRuleContext {
		public ReplicationFilterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_replicationFilter; }
	 
		public ReplicationFilterContext() { }
		public void copyFrom(ReplicationFilterContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class WildIgnoreTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_WILD_IGNORE_TABLE() { return getToken(MySqlParser.REPLICATE_WILD_IGNORE_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public SimpleStringsContext simpleStrings() {
			return getRuleContext(SimpleStringsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public WildIgnoreTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWildIgnoreTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWildIgnoreTableReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWildIgnoreTableReplication(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DoTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_DO_TABLE() { return getToken(MySqlParser.REPLICATE_DO_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public DoTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDoTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDoTableReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDoTableReplication(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IgnoreTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_IGNORE_TABLE() { return getToken(MySqlParser.REPLICATE_IGNORE_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public IgnoreTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIgnoreTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIgnoreTableReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIgnoreTableReplication(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RewriteDbReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_REWRITE_DB() { return getToken(MySqlParser.REPLICATE_REWRITE_DB, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List tablePair() {
			return getRuleContexts(TablePairContext.class);
		}
		public TablePairContext tablePair(int i) {
			return getRuleContext(TablePairContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RewriteDbReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRewriteDbReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRewriteDbReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRewriteDbReplication(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DoDbReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_DO_DB() { return getToken(MySqlParser.REPLICATE_DO_DB, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public DoDbReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDoDbReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDoDbReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDoDbReplication(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IgnoreDbReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_IGNORE_DB() { return getToken(MySqlParser.REPLICATE_IGNORE_DB, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public IgnoreDbReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIgnoreDbReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIgnoreDbReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIgnoreDbReplication(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class WildDoTableReplicationContext extends ReplicationFilterContext {
		public TerminalNode REPLICATE_WILD_DO_TABLE() { return getToken(MySqlParser.REPLICATE_WILD_DO_TABLE, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public SimpleStringsContext simpleStrings() {
			return getRuleContext(SimpleStringsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public WildDoTableReplicationContext(ReplicationFilterContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWildDoTableReplication(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWildDoTableReplication(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWildDoTableReplication(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReplicationFilterContext replicationFilter() throws RecognitionException {
		ReplicationFilterContext _localctx = new ReplicationFilterContext(_ctx, getState());
		enterRule(_localctx, 358, RULE_replicationFilter);
		int _la;
		try {
			setState(4586);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case REPLICATE_DO_DB:
				_localctx = new DoDbReplicationContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4537);
				match(REPLICATE_DO_DB);
				setState(4538);
				match(EQUAL_SYMBOL);
				setState(4539);
				match(LR_BRACKET);
				setState(4540);
				uidList();
				setState(4541);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_IGNORE_DB:
				_localctx = new IgnoreDbReplicationContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4543);
				match(REPLICATE_IGNORE_DB);
				setState(4544);
				match(EQUAL_SYMBOL);
				setState(4545);
				match(LR_BRACKET);
				setState(4546);
				uidList();
				setState(4547);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_DO_TABLE:
				_localctx = new DoTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4549);
				match(REPLICATE_DO_TABLE);
				setState(4550);
				match(EQUAL_SYMBOL);
				setState(4551);
				match(LR_BRACKET);
				setState(4552);
				tables();
				setState(4553);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_IGNORE_TABLE:
				_localctx = new IgnoreTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4555);
				match(REPLICATE_IGNORE_TABLE);
				setState(4556);
				match(EQUAL_SYMBOL);
				setState(4557);
				match(LR_BRACKET);
				setState(4558);
				tables();
				setState(4559);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_WILD_DO_TABLE:
				_localctx = new WildDoTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(4561);
				match(REPLICATE_WILD_DO_TABLE);
				setState(4562);
				match(EQUAL_SYMBOL);
				setState(4563);
				match(LR_BRACKET);
				setState(4564);
				simpleStrings();
				setState(4565);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_WILD_IGNORE_TABLE:
				_localctx = new WildIgnoreTableReplicationContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(4567);
				match(REPLICATE_WILD_IGNORE_TABLE);
				setState(4568);
				match(EQUAL_SYMBOL);
				setState(4569);
				match(LR_BRACKET);
				setState(4570);
				simpleStrings();
				setState(4571);
				match(RR_BRACKET);
				}
				break;
			case REPLICATE_REWRITE_DB:
				_localctx = new RewriteDbReplicationContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(4573);
				match(REPLICATE_REWRITE_DB);
				setState(4574);
				match(EQUAL_SYMBOL);
				setState(4575);
				match(LR_BRACKET);
				setState(4576);
				tablePair();
				setState(4581);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4577);
					match(COMMA);
					setState(4578);
					tablePair();
					}
					}
					setState(4583);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(4584);
				match(RR_BRACKET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TablePairContext extends ParserRuleContext {
		public TableNameContext firstTable;
		public TableNameContext secondTable;
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public TablePairContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tablePair; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTablePair(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTablePair(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTablePair(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TablePairContext tablePair() throws RecognitionException {
		TablePairContext _localctx = new TablePairContext(_ctx, getState());
		enterRule(_localctx, 360, RULE_tablePair);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4588);
			match(LR_BRACKET);
			setState(4589);
			((TablePairContext)_localctx).firstTable = tableName();
			setState(4590);
			match(COMMA);
			setState(4591);
			((TablePairContext)_localctx).secondTable = tableName();
			setState(4592);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ThreadTypeContext extends ParserRuleContext {
		public TerminalNode IO_THREAD() { return getToken(MySqlParser.IO_THREAD, 0); }
		public TerminalNode SQL_THREAD() { return getToken(MySqlParser.SQL_THREAD, 0); }
		public ThreadTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_threadType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterThreadType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitThreadType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitThreadType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ThreadTypeContext threadType() throws RecognitionException {
		ThreadTypeContext _localctx = new ThreadTypeContext(_ctx, getState());
		enterRule(_localctx, 362, RULE_threadType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4594);
			_la = _input.LA(1);
			if ( !(_la==IO_THREAD || _la==SQL_THREAD) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UntilOptionContext extends ParserRuleContext {
		public UntilOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_untilOption; }
	 
		public UntilOptionContext() { }
		public void copyFrom(UntilOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class GtidsUntilOptionContext extends UntilOptionContext {
		public Token gtids;
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public GtuidSetContext gtuidSet() {
			return getRuleContext(GtuidSetContext.class,0);
		}
		public TerminalNode SQL_BEFORE_GTIDS() { return getToken(MySqlParser.SQL_BEFORE_GTIDS, 0); }
		public TerminalNode SQL_AFTER_GTIDS() { return getToken(MySqlParser.SQL_AFTER_GTIDS, 0); }
		public GtidsUntilOptionContext(UntilOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGtidsUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGtidsUntilOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGtidsUntilOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SqlGapsUntilOptionContext extends UntilOptionContext {
		public TerminalNode SQL_AFTER_MTS_GAPS() { return getToken(MySqlParser.SQL_AFTER_MTS_GAPS, 0); }
		public SqlGapsUntilOptionContext(UntilOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSqlGapsUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSqlGapsUntilOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSqlGapsUntilOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MasterLogUntilOptionContext extends UntilOptionContext {
		public TerminalNode MASTER_LOG_FILE() { return getToken(MySqlParser.MASTER_LOG_FILE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode MASTER_LOG_POS() { return getToken(MySqlParser.MASTER_LOG_POS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public MasterLogUntilOptionContext(UntilOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMasterLogUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMasterLogUntilOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMasterLogUntilOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RelayLogUntilOptionContext extends UntilOptionContext {
		public TerminalNode RELAY_LOG_FILE() { return getToken(MySqlParser.RELAY_LOG_FILE, 0); }
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode RELAY_LOG_POS() { return getToken(MySqlParser.RELAY_LOG_POS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public RelayLogUntilOptionContext(UntilOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRelayLogUntilOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRelayLogUntilOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRelayLogUntilOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UntilOptionContext untilOption() throws RecognitionException {
		UntilOptionContext _localctx = new UntilOptionContext(_ctx, getState());
		enterRule(_localctx, 364, RULE_untilOption);
		int _la;
		try {
			setState(4614);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SQL_AFTER_GTIDS:
			case SQL_BEFORE_GTIDS:
				_localctx = new GtidsUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4596);
				((GtidsUntilOptionContext)_localctx).gtids = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==SQL_AFTER_GTIDS || _la==SQL_BEFORE_GTIDS) ) {
					((GtidsUntilOptionContext)_localctx).gtids = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(4597);
				match(EQUAL_SYMBOL);
				setState(4598);
				gtuidSet();
				}
				break;
			case MASTER_LOG_FILE:
				_localctx = new MasterLogUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4599);
				match(MASTER_LOG_FILE);
				setState(4600);
				match(EQUAL_SYMBOL);
				setState(4601);
				match(STRING_LITERAL);
				setState(4602);
				match(COMMA);
				setState(4603);
				match(MASTER_LOG_POS);
				setState(4604);
				match(EQUAL_SYMBOL);
				setState(4605);
				decimalLiteral();
				}
				break;
			case RELAY_LOG_FILE:
				_localctx = new RelayLogUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4606);
				match(RELAY_LOG_FILE);
				setState(4607);
				match(EQUAL_SYMBOL);
				setState(4608);
				match(STRING_LITERAL);
				setState(4609);
				match(COMMA);
				setState(4610);
				match(RELAY_LOG_POS);
				setState(4611);
				match(EQUAL_SYMBOL);
				setState(4612);
				decimalLiteral();
				}
				break;
			case SQL_AFTER_MTS_GAPS:
				_localctx = new SqlGapsUntilOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4613);
				match(SQL_AFTER_MTS_GAPS);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ConnectionOptionContext extends ParserRuleContext {
		public ConnectionOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_connectionOption; }
	 
		public ConnectionOptionContext() { }
		public void copyFrom(ConnectionOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PluginDirConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptPluginDir;
		public TerminalNode PLUGIN_DIR() { return getToken(MySqlParser.PLUGIN_DIR, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public PluginDirConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPluginDirConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPluginDirConnectionOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPluginDirConnectionOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UserConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptUser;
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public UserConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserConnectionOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserConnectionOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DefaultAuthConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptDefAuth;
		public TerminalNode DEFAULT_AUTH() { return getToken(MySqlParser.DEFAULT_AUTH, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public DefaultAuthConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefaultAuthConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefaultAuthConnectionOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefaultAuthConnectionOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PasswordConnectionOptionContext extends ConnectionOptionContext {
		public Token conOptPassword;
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public PasswordConnectionOptionContext(ConnectionOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPasswordConnectionOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPasswordConnectionOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPasswordConnectionOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ConnectionOptionContext connectionOption() throws RecognitionException {
		ConnectionOptionContext _localctx = new ConnectionOptionContext(_ctx, getState());
		enterRule(_localctx, 366, RULE_connectionOption);
		try {
			setState(4628);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case USER:
				_localctx = new UserConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4616);
				match(USER);
				setState(4617);
				match(EQUAL_SYMBOL);
				setState(4618);
				((UserConnectionOptionContext)_localctx).conOptUser = match(STRING_LITERAL);
				}
				break;
			case PASSWORD:
				_localctx = new PasswordConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4619);
				match(PASSWORD);
				setState(4620);
				match(EQUAL_SYMBOL);
				setState(4621);
				((PasswordConnectionOptionContext)_localctx).conOptPassword = match(STRING_LITERAL);
				}
				break;
			case DEFAULT_AUTH:
				_localctx = new DefaultAuthConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4622);
				match(DEFAULT_AUTH);
				setState(4623);
				match(EQUAL_SYMBOL);
				setState(4624);
				((DefaultAuthConnectionOptionContext)_localctx).conOptDefAuth = match(STRING_LITERAL);
				}
				break;
			case PLUGIN_DIR:
				_localctx = new PluginDirConnectionOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4625);
				match(PLUGIN_DIR);
				setState(4626);
				match(EQUAL_SYMBOL);
				setState(4627);
				((PluginDirConnectionOptionContext)_localctx).conOptPluginDir = match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class GtuidSetContext extends ParserRuleContext {
		public List uuidSet() {
			return getRuleContexts(UuidSetContext.class);
		}
		public UuidSetContext uuidSet(int i) {
			return getRuleContext(UuidSetContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public GtuidSetContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_gtuidSet; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGtuidSet(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGtuidSet(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGtuidSet(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GtuidSetContext gtuidSet() throws RecognitionException {
		GtuidSetContext _localctx = new GtuidSetContext(_ctx, getState());
		enterRule(_localctx, 368, RULE_gtuidSet);
		int _la;
		try {
			setState(4639);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(4630);
				uuidSet();
				setState(4635);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4631);
					match(COMMA);
					setState(4632);
					uuidSet();
					}
					}
					setState(4637);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(4638);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XaStartTransactionContext extends ParserRuleContext {
		public Token xaStart;
		public Token xaAction;
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public TerminalNode START() { return getToken(MySqlParser.START, 0); }
		public TerminalNode BEGIN() { return getToken(MySqlParser.BEGIN, 0); }
		public TerminalNode JOIN() { return getToken(MySqlParser.JOIN, 0); }
		public TerminalNode RESUME() { return getToken(MySqlParser.RESUME, 0); }
		public XaStartTransactionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xaStartTransaction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXaStartTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXaStartTransaction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXaStartTransaction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XaStartTransactionContext xaStartTransaction() throws RecognitionException {
		XaStartTransactionContext _localctx = new XaStartTransactionContext(_ctx, getState());
		enterRule(_localctx, 370, RULE_xaStartTransaction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4641);
			match(XA);
			setState(4642);
			((XaStartTransactionContext)_localctx).xaStart = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==BEGIN || _la==START) ) {
				((XaStartTransactionContext)_localctx).xaStart = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(4643);
			xid();
			setState(4645);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==JOIN || _la==RESUME) {
				{
				setState(4644);
				((XaStartTransactionContext)_localctx).xaAction = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==JOIN || _la==RESUME) ) {
					((XaStartTransactionContext)_localctx).xaAction = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XaEndTransactionContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public TerminalNode SUSPEND() { return getToken(MySqlParser.SUSPEND, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode MIGRATE() { return getToken(MySqlParser.MIGRATE, 0); }
		public XaEndTransactionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xaEndTransaction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXaEndTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXaEndTransaction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXaEndTransaction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XaEndTransactionContext xaEndTransaction() throws RecognitionException {
		XaEndTransactionContext _localctx = new XaEndTransactionContext(_ctx, getState());
		enterRule(_localctx, 372, RULE_xaEndTransaction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4647);
			match(XA);
			setState(4648);
			match(END);
			setState(4649);
			xid();
			setState(4655);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==SUSPEND) {
				{
				setState(4650);
				match(SUSPEND);
				setState(4653);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(4651);
					match(FOR);
					setState(4652);
					match(MIGRATE);
					}
				}

				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XaPrepareStatementContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public TerminalNode PREPARE() { return getToken(MySqlParser.PREPARE, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public XaPrepareStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xaPrepareStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXaPrepareStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXaPrepareStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXaPrepareStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XaPrepareStatementContext xaPrepareStatement() throws RecognitionException {
		XaPrepareStatementContext _localctx = new XaPrepareStatementContext(_ctx, getState());
		enterRule(_localctx, 374, RULE_xaPrepareStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4657);
			match(XA);
			setState(4658);
			match(PREPARE);
			setState(4659);
			xid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XaCommitWorkContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public TerminalNode COMMIT() { return getToken(MySqlParser.COMMIT, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public TerminalNode ONE() { return getToken(MySqlParser.ONE, 0); }
		public TerminalNode PHASE() { return getToken(MySqlParser.PHASE, 0); }
		public XaCommitWorkContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xaCommitWork; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXaCommitWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXaCommitWork(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXaCommitWork(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XaCommitWorkContext xaCommitWork() throws RecognitionException {
		XaCommitWorkContext _localctx = new XaCommitWorkContext(_ctx, getState());
		enterRule(_localctx, 376, RULE_xaCommitWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4661);
			match(XA);
			setState(4662);
			match(COMMIT);
			setState(4663);
			xid();
			setState(4666);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ONE) {
				{
				setState(4664);
				match(ONE);
				setState(4665);
				match(PHASE);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XaRollbackWorkContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public TerminalNode ROLLBACK() { return getToken(MySqlParser.ROLLBACK, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public XaRollbackWorkContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xaRollbackWork; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXaRollbackWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXaRollbackWork(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXaRollbackWork(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XaRollbackWorkContext xaRollbackWork() throws RecognitionException {
		XaRollbackWorkContext _localctx = new XaRollbackWorkContext(_ctx, getState());
		enterRule(_localctx, 378, RULE_xaRollbackWork);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4668);
			match(XA);
			setState(4669);
			match(ROLLBACK);
			setState(4670);
			xid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XaRecoverWorkContext extends ParserRuleContext {
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public TerminalNode RECOVER() { return getToken(MySqlParser.RECOVER, 0); }
		public TerminalNode CONVERT() { return getToken(MySqlParser.CONVERT, 0); }
		public XidContext xid() {
			return getRuleContext(XidContext.class,0);
		}
		public XaRecoverWorkContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xaRecoverWork; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXaRecoverWork(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXaRecoverWork(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXaRecoverWork(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XaRecoverWorkContext xaRecoverWork() throws RecognitionException {
		XaRecoverWorkContext _localctx = new XaRecoverWorkContext(_ctx, getState());
		enterRule(_localctx, 380, RULE_xaRecoverWork);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4672);
			match(XA);
			setState(4673);
			match(RECOVER);
			setState(4676);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CONVERT) {
				{
				setState(4674);
				match(CONVERT);
				setState(4675);
				xid();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PrepareStatementContext extends ParserRuleContext {
		public Token query;
		public Token variable;
		public TerminalNode PREPARE() { return getToken(MySqlParser.PREPARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public PrepareStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_prepareStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPrepareStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPrepareStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPrepareStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrepareStatementContext prepareStatement() throws RecognitionException {
		PrepareStatementContext _localctx = new PrepareStatementContext(_ctx, getState());
		enterRule(_localctx, 382, RULE_prepareStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4678);
			match(PREPARE);
			setState(4679);
			uid();
			setState(4680);
			match(FROM);
			setState(4683);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STRING_LITERAL:
				{
				setState(4681);
				((PrepareStatementContext)_localctx).query = match(STRING_LITERAL);
				}
				break;
			case LOCAL_ID:
				{
				setState(4682);
				((PrepareStatementContext)_localctx).variable = match(LOCAL_ID);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ExecuteStatementContext extends ParserRuleContext {
		public TerminalNode EXECUTE() { return getToken(MySqlParser.EXECUTE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public UserVariablesContext userVariables() {
			return getRuleContext(UserVariablesContext.class,0);
		}
		public ExecuteStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_executeStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExecuteStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExecuteStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExecuteStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExecuteStatementContext executeStatement() throws RecognitionException {
		ExecuteStatementContext _localctx = new ExecuteStatementContext(_ctx, getState());
		enterRule(_localctx, 384, RULE_executeStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4685);
			match(EXECUTE);
			setState(4686);
			uid();
			setState(4689);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==USING) {
				{
				setState(4687);
				match(USING);
				setState(4688);
				userVariables();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DeallocatePrepareContext extends ParserRuleContext {
		public Token dropFormat;
		public TerminalNode PREPARE() { return getToken(MySqlParser.PREPARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DEALLOCATE() { return getToken(MySqlParser.DEALLOCATE, 0); }
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public DeallocatePrepareContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_deallocatePrepare; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDeallocatePrepare(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDeallocatePrepare(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDeallocatePrepare(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DeallocatePrepareContext deallocatePrepare() throws RecognitionException {
		DeallocatePrepareContext _localctx = new DeallocatePrepareContext(_ctx, getState());
		enterRule(_localctx, 386, RULE_deallocatePrepare);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4691);
			((DeallocatePrepareContext)_localctx).dropFormat = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==DROP || _la==DEALLOCATE) ) {
				((DeallocatePrepareContext)_localctx).dropFormat = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(4692);
			match(PREPARE);
			setState(4693);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RoutineBodyContext extends ParserRuleContext {
		public BlockStatementContext blockStatement() {
			return getRuleContext(BlockStatementContext.class,0);
		}
		public SqlStatementContext sqlStatement() {
			return getRuleContext(SqlStatementContext.class,0);
		}
		public RoutineBodyContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_routineBody; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoutineBody(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoutineBody(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoutineBody(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RoutineBodyContext routineBody() throws RecognitionException {
		RoutineBodyContext _localctx = new RoutineBodyContext(_ctx, getState());
		enterRule(_localctx, 388, RULE_routineBody);
		try {
			setState(4697);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,680,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(4695);
				blockStatement();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(4696);
				sqlStatement();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class BlockStatementContext extends ParserRuleContext {
		public TerminalNode BEGIN() { return getToken(MySqlParser.BEGIN, 0); }
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode COLON_SYMB() { return getToken(MySqlParser.COLON_SYMB, 0); }
		public List declareVariable() {
			return getRuleContexts(DeclareVariableContext.class);
		}
		public DeclareVariableContext declareVariable(int i) {
			return getRuleContext(DeclareVariableContext.class,i);
		}
		public List SEMI() { return getTokens(MySqlParser.SEMI); }
		public TerminalNode SEMI(int i) {
			return getToken(MySqlParser.SEMI, i);
		}
		public List declareCondition() {
			return getRuleContexts(DeclareConditionContext.class);
		}
		public DeclareConditionContext declareCondition(int i) {
			return getRuleContext(DeclareConditionContext.class,i);
		}
		public List declareCursor() {
			return getRuleContexts(DeclareCursorContext.class);
		}
		public DeclareCursorContext declareCursor(int i) {
			return getRuleContext(DeclareCursorContext.class,i);
		}
		public List declareHandler() {
			return getRuleContexts(DeclareHandlerContext.class);
		}
		public DeclareHandlerContext declareHandler(int i) {
			return getRuleContext(DeclareHandlerContext.class,i);
		}
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public BlockStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_blockStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBlockStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBlockStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBlockStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BlockStatementContext blockStatement() throws RecognitionException {
		BlockStatementContext _localctx = new BlockStatementContext(_ctx, getState());
		enterRule(_localctx, 390, RULE_blockStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4702);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,681,_ctx) ) {
			case 1:
				{
				setState(4699);
				uid();
				setState(4700);
				match(COLON_SYMB);
				}
				break;
			}
			setState(4704);
			match(BEGIN);
			setState(4710);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,682,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4705);
					declareVariable();
					setState(4706);
					match(SEMI);
					}
					} 
				}
				setState(4712);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,682,_ctx);
			}
			setState(4718);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,683,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4713);
					declareCondition();
					setState(4714);
					match(SEMI);
					}
					} 
				}
				setState(4720);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,683,_ctx);
			}
			setState(4726);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,684,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4721);
					declareCursor();
					setState(4722);
					match(SEMI);
					}
					} 
				}
				setState(4728);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,684,_ctx);
			}
			setState(4734);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==DECLARE) {
				{
				{
				setState(4729);
				declareHandler();
				setState(4730);
				match(SEMI);
				}
				}
				setState(4736);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4740);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,686,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(4737);
					procedureSqlStatement();
					}
					} 
				}
				setState(4742);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,686,_ctx);
			}
			setState(4743);
			match(END);
			setState(4745);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,687,_ctx) ) {
			case 1:
				{
				setState(4744);
				uid();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CaseStatementContext extends ParserRuleContext {
		public List CASE() { return getTokens(MySqlParser.CASE); }
		public TerminalNode CASE(int i) {
			return getToken(MySqlParser.CASE, i);
		}
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public List caseAlternative() {
			return getRuleContexts(CaseAlternativeContext.class);
		}
		public CaseAlternativeContext caseAlternative(int i) {
			return getRuleContext(CaseAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MySqlParser.ELSE, 0); }
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public CaseStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_caseStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCaseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCaseStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCaseStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CaseStatementContext caseStatement() throws RecognitionException {
		CaseStatementContext _localctx = new CaseStatementContext(_ctx, getState());
		enterRule(_localctx, 392, RULE_caseStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4747);
			match(CASE);
			setState(4750);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,688,_ctx) ) {
			case 1:
				{
				setState(4748);
				uid();
				}
				break;
			case 2:
				{
				setState(4749);
				expression(0);
				}
				break;
			}
			setState(4753); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(4752);
				caseAlternative();
				}
				}
				setState(4755); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==WHEN );
			setState(4763);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(4757);
				match(ELSE);
				setState(4759); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(4758);
						procedureSqlStatement();
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(4761); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,690,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
			}

			setState(4765);
			match(END);
			setState(4766);
			match(CASE);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IfStatementContext extends ParserRuleContext {
		public ProcedureSqlStatementContext procedureSqlStatement;
		public List thenStatements = new ArrayList();
		public List elseStatements = new ArrayList();
		public List IF() { return getTokens(MySqlParser.IF); }
		public TerminalNode IF(int i) {
			return getToken(MySqlParser.IF, i);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode THEN() { return getToken(MySqlParser.THEN, 0); }
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List elifAlternative() {
			return getRuleContexts(ElifAlternativeContext.class);
		}
		public ElifAlternativeContext elifAlternative(int i) {
			return getRuleContext(ElifAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MySqlParser.ELSE, 0); }
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public IfStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_ifStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIfStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIfStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIfStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IfStatementContext ifStatement() throws RecognitionException {
		IfStatementContext _localctx = new IfStatementContext(_ctx, getState());
		enterRule(_localctx, 394, RULE_ifStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4768);
			match(IF);
			setState(4769);
			expression(0);
			setState(4770);
			match(THEN);
			setState(4772); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4771);
					((IfStatementContext)_localctx).procedureSqlStatement = procedureSqlStatement();
					((IfStatementContext)_localctx).thenStatements.add(((IfStatementContext)_localctx).procedureSqlStatement);
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4774); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,692,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			setState(4779);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==ELSEIF) {
				{
				{
				setState(4776);
				elifAlternative();
				}
				}
				setState(4781);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4788);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ELSE) {
				{
				setState(4782);
				match(ELSE);
				setState(4784); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(4783);
						((IfStatementContext)_localctx).procedureSqlStatement = procedureSqlStatement();
						((IfStatementContext)_localctx).elseStatements.add(((IfStatementContext)_localctx).procedureSqlStatement);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(4786); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,694,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
			}

			setState(4790);
			match(END);
			setState(4791);
			match(IF);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IterateStatementContext extends ParserRuleContext {
		public TerminalNode ITERATE() { return getToken(MySqlParser.ITERATE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public IterateStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_iterateStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIterateStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIterateStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIterateStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IterateStatementContext iterateStatement() throws RecognitionException {
		IterateStatementContext _localctx = new IterateStatementContext(_ctx, getState());
		enterRule(_localctx, 396, RULE_iterateStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4793);
			match(ITERATE);
			setState(4794);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LeaveStatementContext extends ParserRuleContext {
		public TerminalNode LEAVE() { return getToken(MySqlParser.LEAVE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public LeaveStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_leaveStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLeaveStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLeaveStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLeaveStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LeaveStatementContext leaveStatement() throws RecognitionException {
		LeaveStatementContext _localctx = new LeaveStatementContext(_ctx, getState());
		enterRule(_localctx, 398, RULE_leaveStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4796);
			match(LEAVE);
			setState(4797);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LoopStatementContext extends ParserRuleContext {
		public List LOOP() { return getTokens(MySqlParser.LOOP); }
		public TerminalNode LOOP(int i) {
			return getToken(MySqlParser.LOOP, i);
		}
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode COLON_SYMB() { return getToken(MySqlParser.COLON_SYMB, 0); }
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public LoopStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_loopStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLoopStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLoopStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLoopStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LoopStatementContext loopStatement() throws RecognitionException {
		LoopStatementContext _localctx = new LoopStatementContext(_ctx, getState());
		enterRule(_localctx, 400, RULE_loopStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4802);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(4799);
				uid();
				setState(4800);
				match(COLON_SYMB);
				}
			}

			setState(4804);
			match(LOOP);
			setState(4806); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4805);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4808); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,697,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			setState(4810);
			match(END);
			setState(4811);
			match(LOOP);
			setState(4813);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(4812);
				uid();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RepeatStatementContext extends ParserRuleContext {
		public List REPEAT() { return getTokens(MySqlParser.REPEAT); }
		public TerminalNode REPEAT(int i) {
			return getToken(MySqlParser.REPEAT, i);
		}
		public TerminalNode UNTIL() { return getToken(MySqlParser.UNTIL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode COLON_SYMB() { return getToken(MySqlParser.COLON_SYMB, 0); }
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public RepeatStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_repeatStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRepeatStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRepeatStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRepeatStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RepeatStatementContext repeatStatement() throws RecognitionException {
		RepeatStatementContext _localctx = new RepeatStatementContext(_ctx, getState());
		enterRule(_localctx, 402, RULE_repeatStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4818);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,699,_ctx) ) {
			case 1:
				{
				setState(4815);
				uid();
				setState(4816);
				match(COLON_SYMB);
				}
				break;
			}
			setState(4820);
			match(REPEAT);
			setState(4822); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4821);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4824); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,700,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			setState(4826);
			match(UNTIL);
			setState(4827);
			expression(0);
			setState(4828);
			match(END);
			setState(4829);
			match(REPEAT);
			setState(4831);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(4830);
				uid();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ReturnStatementContext extends ParserRuleContext {
		public TerminalNode RETURN() { return getToken(MySqlParser.RETURN, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public ReturnStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_returnStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterReturnStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitReturnStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitReturnStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ReturnStatementContext returnStatement() throws RecognitionException {
		ReturnStatementContext _localctx = new ReturnStatementContext(_ctx, getState());
		enterRule(_localctx, 404, RULE_returnStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4833);
			match(RETURN);
			setState(4834);
			expression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WhileStatementContext extends ParserRuleContext {
		public List WHILE() { return getTokens(MySqlParser.WHILE); }
		public TerminalNode WHILE(int i) {
			return getToken(MySqlParser.WHILE, i);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DO() { return getToken(MySqlParser.DO, 0); }
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode COLON_SYMB() { return getToken(MySqlParser.COLON_SYMB, 0); }
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public WhileStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_whileStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWhileStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWhileStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWhileStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WhileStatementContext whileStatement() throws RecognitionException {
		WhileStatementContext _localctx = new WhileStatementContext(_ctx, getState());
		enterRule(_localctx, 406, RULE_whileStatement);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4839);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(4836);
				uid();
				setState(4837);
				match(COLON_SYMB);
				}
			}

			setState(4841);
			match(WHILE);
			setState(4842);
			expression(0);
			setState(4843);
			match(DO);
			setState(4845); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4844);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4847); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,703,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			setState(4849);
			match(END);
			setState(4850);
			match(WHILE);
			setState(4852);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if ((((_la) & ~0x3f) == 0 && ((1L << _la) & 756891332513122304L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055071174737L) != 0) || ((((_la - 140)) & ~0x3f) == 0 && ((1L << (_la - 140)) & 268698883L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17174494689L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & -1099511627777L) != 0) || ((((_la - 345)) & ~0x3f) == 0 && ((1L << (_la - 345)) & -2882305960540372993L) != 0) || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & -4398063288321L) != 0) || ((((_la - 473)) & ~0x3f) == 0 && ((1L << (_la - 473)) & -16325548649218049L) != 0) || ((((_la - 537)) & ~0x3f) == 0 && ((1L << (_la - 537)) & -81064793296864001L) != 0) || ((((_la - 601)) & ~0x3f) == 0 && ((1L << (_la - 601)) & -68719476801L) != 0) || ((((_la - 665)) & ~0x3f) == 0 && ((1L << (_la - 665)) & -22236531750340609L) != 0) || ((((_la - 729)) & ~0x3f) == 0 && ((1L << (_la - 729)) & -65L) != 0) || ((((_la - 793)) & ~0x3f) == 0 && ((1L << (_la - 793)) & -6145L) != 0) || ((((_la - 857)) & ~0x3f) == 0 && ((1L << (_la - 857)) & -1L) != 0) || ((((_la - 921)) & ~0x3f) == 0 && ((1L << (_la - 921)) & -1L) != 0) || ((((_la - 985)) & ~0x3f) == 0 && ((1L << (_la - 985)) & -1L) != 0) || ((((_la - 1049)) & ~0x3f) == 0 && ((1L << (_la - 1049)) & 576460752303423487L) != 0) || ((((_la - 1123)) & ~0x3f) == 0 && ((1L << (_la - 1123)) & 8627683329L) != 0)) {
				{
				setState(4851);
				uid();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CursorStatementContext extends ParserRuleContext {
		public CursorStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_cursorStatement; }
	 
		public CursorStatementContext() { }
		public void copyFrom(CursorStatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CloseCursorContext extends CursorStatementContext {
		public TerminalNode CLOSE() { return getToken(MySqlParser.CLOSE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public CloseCursorContext(CursorStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCloseCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCloseCursor(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCloseCursor(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class OpenCursorContext extends CursorStatementContext {
		public TerminalNode OPEN() { return getToken(MySqlParser.OPEN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public OpenCursorContext(CursorStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOpenCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOpenCursor(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOpenCursor(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class FetchCursorContext extends CursorStatementContext {
		public TerminalNode FETCH() { return getToken(MySqlParser.FETCH, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode NEXT() { return getToken(MySqlParser.NEXT, 0); }
		public FetchCursorContext(CursorStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFetchCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFetchCursor(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFetchCursor(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CursorStatementContext cursorStatement() throws RecognitionException {
		CursorStatementContext _localctx = new CursorStatementContext(_ctx, getState());
		enterRule(_localctx, 408, RULE_cursorStatement);
		int _la;
		try {
			setState(4869);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CLOSE:
				_localctx = new CloseCursorContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4854);
				match(CLOSE);
				setState(4855);
				uid();
				}
				break;
			case FETCH:
				_localctx = new FetchCursorContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4856);
				match(FETCH);
				setState(4861);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,706,_ctx) ) {
				case 1:
					{
					setState(4858);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==NEXT) {
						{
						setState(4857);
						match(NEXT);
						}
					}

					setState(4860);
					match(FROM);
					}
					break;
				}
				setState(4863);
				uid();
				setState(4864);
				match(INTO);
				setState(4865);
				uidList();
				}
				break;
			case OPEN:
				_localctx = new OpenCursorContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4867);
				match(OPEN);
				setState(4868);
				uid();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DeclareVariableContext extends ParserRuleContext {
		public TerminalNode DECLARE() { return getToken(MySqlParser.DECLARE, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public DataTypeContext dataType() {
			return getRuleContext(DataTypeContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public DeclareVariableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_declareVariable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDeclareVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDeclareVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDeclareVariable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DeclareVariableContext declareVariable() throws RecognitionException {
		DeclareVariableContext _localctx = new DeclareVariableContext(_ctx, getState());
		enterRule(_localctx, 410, RULE_declareVariable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4871);
			match(DECLARE);
			setState(4872);
			uidList();
			setState(4873);
			dataType();
			setState(4876);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==DEFAULT) {
				{
				setState(4874);
				match(DEFAULT);
				setState(4875);
				expression(0);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DeclareConditionContext extends ParserRuleContext {
		public TerminalNode DECLARE() { return getToken(MySqlParser.DECLARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode CONDITION() { return getToken(MySqlParser.CONDITION, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode SQLSTATE() { return getToken(MySqlParser.SQLSTATE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public DeclareConditionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_declareCondition; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDeclareCondition(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDeclareCondition(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDeclareCondition(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DeclareConditionContext declareCondition() throws RecognitionException {
		DeclareConditionContext _localctx = new DeclareConditionContext(_ctx, getState());
		enterRule(_localctx, 412, RULE_declareCondition);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4878);
			match(DECLARE);
			setState(4879);
			uid();
			setState(4880);
			match(CONDITION);
			setState(4881);
			match(FOR);
			setState(4888);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				{
				setState(4882);
				decimalLiteral();
				}
				break;
			case SQLSTATE:
				{
				setState(4883);
				match(SQLSTATE);
				setState(4885);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(4884);
					match(VALUE);
					}
				}

				setState(4887);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DeclareCursorContext extends ParserRuleContext {
		public TerminalNode DECLARE() { return getToken(MySqlParser.DECLARE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode CURSOR() { return getToken(MySqlParser.CURSOR, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public DeclareCursorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_declareCursor; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDeclareCursor(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDeclareCursor(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDeclareCursor(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DeclareCursorContext declareCursor() throws RecognitionException {
		DeclareCursorContext _localctx = new DeclareCursorContext(_ctx, getState());
		enterRule(_localctx, 414, RULE_declareCursor);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4890);
			match(DECLARE);
			setState(4891);
			uid();
			setState(4892);
			match(CURSOR);
			setState(4893);
			match(FOR);
			setState(4894);
			selectStatement();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DeclareHandlerContext extends ParserRuleContext {
		public Token handlerAction;
		public TerminalNode DECLARE() { return getToken(MySqlParser.DECLARE, 0); }
		public TerminalNode HANDLER() { return getToken(MySqlParser.HANDLER, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public List handlerConditionValue() {
			return getRuleContexts(HandlerConditionValueContext.class);
		}
		public HandlerConditionValueContext handlerConditionValue(int i) {
			return getRuleContext(HandlerConditionValueContext.class,i);
		}
		public RoutineBodyContext routineBody() {
			return getRuleContext(RoutineBodyContext.class,0);
		}
		public TerminalNode CONTINUE() { return getToken(MySqlParser.CONTINUE, 0); }
		public TerminalNode EXIT() { return getToken(MySqlParser.EXIT, 0); }
		public TerminalNode UNDO() { return getToken(MySqlParser.UNDO, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public DeclareHandlerContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_declareHandler; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDeclareHandler(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDeclareHandler(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDeclareHandler(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DeclareHandlerContext declareHandler() throws RecognitionException {
		DeclareHandlerContext _localctx = new DeclareHandlerContext(_ctx, getState());
		enterRule(_localctx, 416, RULE_declareHandler);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4896);
			match(DECLARE);
			setState(4897);
			((DeclareHandlerContext)_localctx).handlerAction = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==CONTINUE || _la==EXIT || _la==UNDO) ) {
				((DeclareHandlerContext)_localctx).handlerAction = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(4898);
			match(HANDLER);
			setState(4899);
			match(FOR);
			setState(4900);
			handlerConditionValue();
			setState(4905);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(4901);
				match(COMMA);
				setState(4902);
				handlerConditionValue();
				}
				}
				setState(4907);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(4908);
			routineBody();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionValueContext extends ParserRuleContext {
		public HandlerConditionValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_handlerConditionValue; }
	 
		public HandlerConditionValueContext() { }
		public void copyFrom(HandlerConditionValueContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionWarningContext extends HandlerConditionValueContext {
		public TerminalNode SQLWARNING() { return getToken(MySqlParser.SQLWARNING, 0); }
		public HandlerConditionWarningContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerConditionWarning(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerConditionWarning(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerConditionWarning(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionCodeContext extends HandlerConditionValueContext {
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public HandlerConditionCodeContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerConditionCode(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerConditionCode(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerConditionCode(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionNotfoundContext extends HandlerConditionValueContext {
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode FOUND() { return getToken(MySqlParser.FOUND, 0); }
		public HandlerConditionNotfoundContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerConditionNotfound(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerConditionNotfound(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerConditionNotfound(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionStateContext extends HandlerConditionValueContext {
		public TerminalNode SQLSTATE() { return getToken(MySqlParser.SQLSTATE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public HandlerConditionStateContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerConditionState(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerConditionState(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerConditionState(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionExceptionContext extends HandlerConditionValueContext {
		public TerminalNode SQLEXCEPTION() { return getToken(MySqlParser.SQLEXCEPTION, 0); }
		public HandlerConditionExceptionContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerConditionException(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerConditionException(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerConditionException(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HandlerConditionNameContext extends HandlerConditionValueContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public HandlerConditionNameContext(HandlerConditionValueContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHandlerConditionName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHandlerConditionName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHandlerConditionName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HandlerConditionValueContext handlerConditionValue() throws RecognitionException {
		HandlerConditionValueContext _localctx = new HandlerConditionValueContext(_ctx, getState());
		enterRule(_localctx, 418, RULE_handlerConditionValue);
		int _la;
		try {
			setState(4921);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				_localctx = new HandlerConditionCodeContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4910);
				decimalLiteral();
				}
				break;
			case SQLSTATE:
				_localctx = new HandlerConditionStateContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4911);
				match(SQLSTATE);
				setState(4913);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(4912);
					match(VALUE);
					}
				}

				setState(4915);
				match(STRING_LITERAL);
				}
				break;
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				_localctx = new HandlerConditionNameContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(4916);
				uid();
				}
				break;
			case SQLWARNING:
				_localctx = new HandlerConditionWarningContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(4917);
				match(SQLWARNING);
				}
				break;
			case NOT:
				_localctx = new HandlerConditionNotfoundContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(4918);
				match(NOT);
				setState(4919);
				match(FOUND);
				}
				break;
			case SQLEXCEPTION:
				_localctx = new HandlerConditionExceptionContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(4920);
				match(SQLEXCEPTION);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ProcedureSqlStatementContext extends ParserRuleContext {
		public TerminalNode SEMI() { return getToken(MySqlParser.SEMI, 0); }
		public CompoundStatementContext compoundStatement() {
			return getRuleContext(CompoundStatementContext.class,0);
		}
		public SqlStatementContext sqlStatement() {
			return getRuleContext(SqlStatementContext.class,0);
		}
		public ProcedureSqlStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_procedureSqlStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterProcedureSqlStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitProcedureSqlStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitProcedureSqlStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ProcedureSqlStatementContext procedureSqlStatement() throws RecognitionException {
		ProcedureSqlStatementContext _localctx = new ProcedureSqlStatementContext(_ctx, getState());
		enterRule(_localctx, 420, RULE_procedureSqlStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(4925);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,714,_ctx) ) {
			case 1:
				{
				setState(4923);
				compoundStatement();
				}
				break;
			case 2:
				{
				setState(4924);
				sqlStatement();
				}
				break;
			}
			setState(4927);
			match(SEMI);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CaseAlternativeContext extends ParserRuleContext {
		public TerminalNode WHEN() { return getToken(MySqlParser.WHEN, 0); }
		public TerminalNode THEN() { return getToken(MySqlParser.THEN, 0); }
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public CaseAlternativeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_caseAlternative; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCaseAlternative(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCaseAlternative(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCaseAlternative(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CaseAlternativeContext caseAlternative() throws RecognitionException {
		CaseAlternativeContext _localctx = new CaseAlternativeContext(_ctx, getState());
		enterRule(_localctx, 422, RULE_caseAlternative);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4929);
			match(WHEN);
			setState(4932);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,715,_ctx) ) {
			case 1:
				{
				setState(4930);
				constant();
				}
				break;
			case 2:
				{
				setState(4931);
				expression(0);
				}
				break;
			}
			setState(4934);
			match(THEN);
			setState(4936); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4935);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4938); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,716,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ElifAlternativeContext extends ParserRuleContext {
		public TerminalNode ELSEIF() { return getToken(MySqlParser.ELSEIF, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode THEN() { return getToken(MySqlParser.THEN, 0); }
		public List procedureSqlStatement() {
			return getRuleContexts(ProcedureSqlStatementContext.class);
		}
		public ProcedureSqlStatementContext procedureSqlStatement(int i) {
			return getRuleContext(ProcedureSqlStatementContext.class,i);
		}
		public ElifAlternativeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_elifAlternative; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterElifAlternative(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitElifAlternative(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitElifAlternative(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ElifAlternativeContext elifAlternative() throws RecognitionException {
		ElifAlternativeContext _localctx = new ElifAlternativeContext(_ctx, getState());
		enterRule(_localctx, 424, RULE_elifAlternative);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(4940);
			match(ELSEIF);
			setState(4941);
			expression(0);
			setState(4942);
			match(THEN);
			setState(4944); 
			_errHandler.sync(this);
			_alt = 1;
			do {
				switch (_alt) {
				case 1:
					{
					{
					setState(4943);
					procedureSqlStatement();
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(4946); 
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,717,_ctx);
			} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AlterUserContext extends ParserRuleContext {
		public AlterUserContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_alterUser; }
	 
		public AlterUserContext() { }
		public void copyFrom(AlterUserContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterUserMysqlV80Context extends AlterUserContext {
		public Token tlsNone;
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public List userAuthOption() {
			return getRuleContexts(UserAuthOptionContext.class);
		}
		public UserAuthOptionContext userAuthOption(int i) {
			return getRuleContext(UserAuthOptionContext.class,i);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode REQUIRE() { return getToken(MySqlParser.REQUIRE, 0); }
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public List userPasswordOption() {
			return getRuleContexts(UserPasswordOptionContext.class);
		}
		public UserPasswordOptionContext userPasswordOption(int i) {
			return getRuleContext(UserPasswordOptionContext.class,i);
		}
		public List userLockOption() {
			return getRuleContexts(UserLockOptionContext.class);
		}
		public UserLockOptionContext userLockOption(int i) {
			return getRuleContext(UserLockOptionContext.class,i);
		}
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ATTRIBUTE() { return getToken(MySqlParser.ATTRIBUTE, 0); }
		public List tlsOption() {
			return getRuleContexts(TlsOptionContext.class);
		}
		public TlsOptionContext tlsOption(int i) {
			return getRuleContext(TlsOptionContext.class,i);
		}
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public List userResourceOption() {
			return getRuleContexts(UserResourceOptionContext.class);
		}
		public UserResourceOptionContext userResourceOption(int i) {
			return getRuleContext(UserResourceOptionContext.class,i);
		}
		public List AND() { return getTokens(MySqlParser.AND); }
		public TerminalNode AND(int i) {
			return getToken(MySqlParser.AND, i);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public RoleOptionContext roleOption() {
			return getRuleContext(RoleOptionContext.class,0);
		}
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public AlterUserMysqlV80Context(AlterUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterUserMysqlV80(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterUserMysqlV80(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterUserMysqlV80(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AlterUserMysqlV56Context extends AlterUserContext {
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public List userSpecification() {
			return getRuleContexts(UserSpecificationContext.class);
		}
		public UserSpecificationContext userSpecification(int i) {
			return getRuleContext(UserSpecificationContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AlterUserMysqlV56Context(AlterUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAlterUserMysqlV56(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAlterUserMysqlV56(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAlterUserMysqlV56(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AlterUserContext alterUser() throws RecognitionException {
		AlterUserContext _localctx = new AlterUserContext(_ctx, getState());
		enterRule(_localctx, 426, RULE_alterUser);
		int _la;
		try {
			setState(5021);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,732,_ctx) ) {
			case 1:
				_localctx = new AlterUserMysqlV56Context(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(4948);
				match(ALTER);
				setState(4949);
				match(USER);
				setState(4950);
				userSpecification();
				setState(4955);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4951);
					match(COMMA);
					setState(4952);
					userSpecification();
					}
					}
					setState(4957);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new AlterUserMysqlV80Context(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(4958);
				match(ALTER);
				setState(4959);
				match(USER);
				setState(4961);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(4960);
					ifExists();
					}
				}

				setState(4963);
				userAuthOption();
				setState(4968);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(4964);
					match(COMMA);
					setState(4965);
					userAuthOption();
					}
					}
					setState(4970);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(4985);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==REQUIRE) {
					{
					setState(4971);
					match(REQUIRE);
					setState(4983);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case NONE:
						{
						setState(4972);
						((AlterUserMysqlV80Context)_localctx).tlsNone = match(NONE);
						}
						break;
					case SSL:
					case CIPHER:
					case ISSUER:
					case SUBJECT:
					case X509:
						{
						setState(4973);
						tlsOption();
						setState(4980);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==AND || _la==SSL || _la==CIPHER || _la==ISSUER || _la==SUBJECT || _la==X509) {
							{
							{
							setState(4975);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==AND) {
								{
								setState(4974);
								match(AND);
								}
							}

							setState(4977);
							tlsOption();
							}
							}
							setState(4982);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
				}

				setState(4993);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,726,_ctx) ) {
				case 1:
					{
					setState(4987);
					match(WITH);
					setState(4989); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(4988);
						userResourceOption();
						}
						}
						setState(4991); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( ((((_la - 498)) & ~0x3f) == 0 && ((1L << (_la - 498)) & 51L) != 0) );
					}
					break;
				}
				setState(4999);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ACCOUNT || _la==FAILED_LOGIN_ATTEMPTS || _la==PASSWORD || _la==PASSWORD_LOCK_TIME) {
					{
					setState(4997);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case FAILED_LOGIN_ATTEMPTS:
					case PASSWORD:
					case PASSWORD_LOCK_TIME:
						{
						setState(4995);
						userPasswordOption();
						}
						break;
					case ACCOUNT:
						{
						setState(4996);
						userLockOption();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					setState(5001);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5006);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case COMMENT:
					{
					setState(5002);
					match(COMMENT);
					setState(5003);
					match(STRING_LITERAL);
					}
					break;
				case ATTRIBUTE:
					{
					setState(5004);
					match(ATTRIBUTE);
					setState(5005);
					match(STRING_LITERAL);
					}
					break;
				case EOF:
				case ALTER:
				case ANALYZE:
				case CALL:
				case CHANGE:
				case CHECK:
				case CREATE:
				case DELETE:
				case DESC:
				case DESCRIBE:
				case DROP:
				case EXPLAIN:
				case GET:
				case GRANT:
				case INSERT:
				case KILL:
				case LOAD:
				case LOCK:
				case OPTIMIZE:
				case PURGE:
				case RELEASE:
				case RENAME:
				case REPLACE:
				case RESIGNAL:
				case REVOKE:
				case SELECT:
				case SET:
				case SHOW:
				case SIGNAL:
				case TABLE:
				case UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				case WITH:
				case BEGIN:
				case BINLOG:
				case CACHE:
				case CHECKSUM:
				case COMMIT:
				case DEALLOCATE:
				case DO:
				case FLUSH:
				case HANDLER:
				case HELP:
				case INSTALL:
				case PREPARE:
				case REPAIR:
				case RESET:
				case ROLLBACK:
				case SAVEPOINT:
				case START:
				case STOP:
				case TRUNCATE:
				case UNINSTALL:
				case XA:
				case EXECUTE:
				case SHUTDOWN:
				case MINUS:
				case LR_BRACKET:
				case SEMI:
					break;
				default:
					break;
				}
				}
				break;
			case 3:
				_localctx = new AlterUserMysqlV80Context(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5008);
				match(ALTER);
				setState(5009);
				match(USER);
				setState(5011);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,730,_ctx) ) {
				case 1:
					{
					setState(5010);
					ifExists();
					}
					break;
				}
				setState(5015);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,731,_ctx) ) {
				case 1:
					{
					setState(5013);
					userName();
					}
					break;
				case 2:
					{
					setState(5014);
					uid();
					}
					break;
				}
				setState(5017);
				match(DEFAULT);
				setState(5018);
				match(ROLE);
				setState(5019);
				roleOption();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateUserContext extends ParserRuleContext {
		public CreateUserContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createUser; }
	 
		public CreateUserContext() { }
		public void copyFrom(CreateUserContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CreateUserMysqlV56Context extends CreateUserContext {
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public List userAuthOption() {
			return getRuleContexts(UserAuthOptionContext.class);
		}
		public UserAuthOptionContext userAuthOption(int i) {
			return getRuleContext(UserAuthOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public CreateUserMysqlV56Context(CreateUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateUserMysqlV56(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateUserMysqlV56(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateUserMysqlV56(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CreateUserMysqlV80Context extends CreateUserContext {
		public Token tlsNone;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public List userAuthOption() {
			return getRuleContexts(UserAuthOptionContext.class);
		}
		public UserAuthOptionContext userAuthOption(int i) {
			return getRuleContext(UserAuthOptionContext.class,i);
		}
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public RoleOptionContext roleOption() {
			return getRuleContext(RoleOptionContext.class,0);
		}
		public TerminalNode REQUIRE() { return getToken(MySqlParser.REQUIRE, 0); }
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public List userPasswordOption() {
			return getRuleContexts(UserPasswordOptionContext.class);
		}
		public UserPasswordOptionContext userPasswordOption(int i) {
			return getRuleContext(UserPasswordOptionContext.class,i);
		}
		public List userLockOption() {
			return getRuleContexts(UserLockOptionContext.class);
		}
		public UserLockOptionContext userLockOption(int i) {
			return getRuleContext(UserLockOptionContext.class,i);
		}
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ATTRIBUTE() { return getToken(MySqlParser.ATTRIBUTE, 0); }
		public List tlsOption() {
			return getRuleContexts(TlsOptionContext.class);
		}
		public TlsOptionContext tlsOption(int i) {
			return getRuleContext(TlsOptionContext.class,i);
		}
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public List userResourceOption() {
			return getRuleContexts(UserResourceOptionContext.class);
		}
		public UserResourceOptionContext userResourceOption(int i) {
			return getRuleContext(UserResourceOptionContext.class,i);
		}
		public List AND() { return getTokens(MySqlParser.AND); }
		public TerminalNode AND(int i) {
			return getToken(MySqlParser.AND, i);
		}
		public CreateUserMysqlV80Context(CreateUserContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateUserMysqlV80(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateUserMysqlV80(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateUserMysqlV80(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateUserContext createUser() throws RecognitionException {
		CreateUserContext _localctx = new CreateUserContext(_ctx, getState());
		enterRule(_localctx, 428, RULE_createUser);
		int _la;
		try {
			setState(5088);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,746,_ctx) ) {
			case 1:
				_localctx = new CreateUserMysqlV56Context(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5023);
				match(CREATE);
				setState(5024);
				match(USER);
				setState(5025);
				userAuthOption();
				setState(5030);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5026);
					match(COMMA);
					setState(5027);
					userAuthOption();
					}
					}
					setState(5032);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new CreateUserMysqlV80Context(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5033);
				match(CREATE);
				setState(5034);
				match(USER);
				setState(5036);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IF) {
					{
					setState(5035);
					ifNotExists();
					}
				}

				setState(5038);
				userAuthOption();
				setState(5043);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5039);
					match(COMMA);
					setState(5040);
					userAuthOption();
					}
					}
					setState(5045);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5049);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT) {
					{
					setState(5046);
					match(DEFAULT);
					setState(5047);
					match(ROLE);
					setState(5048);
					roleOption();
					}
				}

				setState(5065);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==REQUIRE) {
					{
					setState(5051);
					match(REQUIRE);
					setState(5063);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case NONE:
						{
						setState(5052);
						((CreateUserMysqlV80Context)_localctx).tlsNone = match(NONE);
						}
						break;
					case SSL:
					case CIPHER:
					case ISSUER:
					case SUBJECT:
					case X509:
						{
						setState(5053);
						tlsOption();
						setState(5060);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==AND || _la==SSL || _la==CIPHER || _la==ISSUER || _la==SUBJECT || _la==X509) {
							{
							{
							setState(5055);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==AND) {
								{
								setState(5054);
								match(AND);
								}
							}

							setState(5057);
							tlsOption();
							}
							}
							setState(5062);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
				}

				setState(5073);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,742,_ctx) ) {
				case 1:
					{
					setState(5067);
					match(WITH);
					setState(5069); 
					_errHandler.sync(this);
					_la = _input.LA(1);
					do {
						{
						{
						setState(5068);
						userResourceOption();
						}
						}
						setState(5071); 
						_errHandler.sync(this);
						_la = _input.LA(1);
					} while ( ((((_la - 498)) & ~0x3f) == 0 && ((1L << (_la - 498)) & 51L) != 0) );
					}
					break;
				}
				setState(5079);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==ACCOUNT || _la==FAILED_LOGIN_ATTEMPTS || _la==PASSWORD || _la==PASSWORD_LOCK_TIME) {
					{
					setState(5077);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case FAILED_LOGIN_ATTEMPTS:
					case PASSWORD:
					case PASSWORD_LOCK_TIME:
						{
						setState(5075);
						userPasswordOption();
						}
						break;
					case ACCOUNT:
						{
						setState(5076);
						userLockOption();
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
					setState(5081);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5086);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case COMMENT:
					{
					setState(5082);
					match(COMMENT);
					setState(5083);
					match(STRING_LITERAL);
					}
					break;
				case ATTRIBUTE:
					{
					setState(5084);
					match(ATTRIBUTE);
					setState(5085);
					match(STRING_LITERAL);
					}
					break;
				case EOF:
				case ALTER:
				case ANALYZE:
				case CALL:
				case CHANGE:
				case CHECK:
				case CREATE:
				case DELETE:
				case DESC:
				case DESCRIBE:
				case DROP:
				case EXPLAIN:
				case GET:
				case GRANT:
				case INSERT:
				case KILL:
				case LOAD:
				case LOCK:
				case OPTIMIZE:
				case PURGE:
				case RELEASE:
				case RENAME:
				case REPLACE:
				case RESIGNAL:
				case REVOKE:
				case SELECT:
				case SET:
				case SHOW:
				case SIGNAL:
				case TABLE:
				case UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				case WITH:
				case BEGIN:
				case BINLOG:
				case CACHE:
				case CHECKSUM:
				case COMMIT:
				case DEALLOCATE:
				case DO:
				case FLUSH:
				case HANDLER:
				case HELP:
				case INSTALL:
				case PREPARE:
				case REPAIR:
				case RESET:
				case ROLLBACK:
				case SAVEPOINT:
				case START:
				case STOP:
				case TRUNCATE:
				case UNINSTALL:
				case XA:
				case EXECUTE:
				case SHUTDOWN:
				case MINUS:
				case LR_BRACKET:
				case SEMI:
					break;
				default:
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DropUserContext extends ParserRuleContext {
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public IfExistsContext ifExists() {
			return getRuleContext(IfExistsContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public DropUserContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dropUser; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDropUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDropUser(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDropUser(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DropUserContext dropUser() throws RecognitionException {
		DropUserContext _localctx = new DropUserContext(_ctx, getState());
		enterRule(_localctx, 430, RULE_dropUser);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5090);
			match(DROP);
			setState(5091);
			match(USER);
			setState(5093);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IF) {
				{
				setState(5092);
				ifExists();
				}
			}

			setState(5095);
			userName();
			setState(5100);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5096);
				match(COMMA);
				setState(5097);
				userName();
				}
				}
				setState(5102);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class GrantStatementContext extends ParserRuleContext {
		public Token privilegeObject;
		public Token tlsNone;
		public List GRANT() { return getTokens(MySqlParser.GRANT); }
		public TerminalNode GRANT(int i) {
			return getToken(MySqlParser.GRANT, i);
		}
		public List privelegeClause() {
			return getRuleContexts(PrivelegeClauseContext.class);
		}
		public PrivelegeClauseContext privelegeClause(int i) {
			return getRuleContext(PrivelegeClauseContext.class,i);
		}
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public PrivilegeLevelContext privilegeLevel() {
			return getRuleContext(PrivilegeLevelContext.class,0);
		}
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public List userAuthOption() {
			return getRuleContexts(UserAuthOptionContext.class);
		}
		public UserAuthOptionContext userAuthOption(int i) {
			return getRuleContext(UserAuthOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode REQUIRE() { return getToken(MySqlParser.REQUIRE, 0); }
		public List WITH() { return getTokens(MySqlParser.WITH); }
		public TerminalNode WITH(int i) {
			return getToken(MySqlParser.WITH, i);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public RoleOptionContext roleOption() {
			return getRuleContext(RoleOptionContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public List tlsOption() {
			return getRuleContexts(TlsOptionContext.class);
		}
		public TlsOptionContext tlsOption(int i) {
			return getRuleContext(TlsOptionContext.class,i);
		}
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public List OPTION() { return getTokens(MySqlParser.OPTION); }
		public TerminalNode OPTION(int i) {
			return getToken(MySqlParser.OPTION, i);
		}
		public List userResourceOption() {
			return getRuleContexts(UserResourceOptionContext.class);
		}
		public UserResourceOptionContext userResourceOption(int i) {
			return getRuleContext(UserResourceOptionContext.class,i);
		}
		public List AND() { return getTokens(MySqlParser.AND); }
		public TerminalNode AND(int i) {
			return getToken(MySqlParser.AND, i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode ADMIN() { return getToken(MySqlParser.ADMIN, 0); }
		public GrantStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_grantStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGrantStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGrantStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGrantStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GrantStatementContext grantStatement() throws RecognitionException {
		GrantStatementContext _localctx = new GrantStatementContext(_ctx, getState());
		enterRule(_localctx, 432, RULE_grantStatement);
		int _la;
		try {
			int _alt;
			setState(5196);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,767,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5103);
				match(GRANT);
				setState(5104);
				privelegeClause();
				setState(5109);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5105);
					match(COMMA);
					setState(5106);
					privelegeClause();
					}
					}
					setState(5111);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5112);
				match(ON);
				setState(5114);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,750,_ctx) ) {
				case 1:
					{
					setState(5113);
					((GrantStatementContext)_localctx).privilegeObject = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==PROCEDURE || _la==TABLE || _la==FUNCTION) ) {
						((GrantStatementContext)_localctx).privilegeObject = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					break;
				}
				setState(5116);
				privilegeLevel();
				setState(5117);
				match(TO);
				setState(5118);
				userAuthOption();
				setState(5123);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5119);
					match(COMMA);
					setState(5120);
					userAuthOption();
					}
					}
					setState(5125);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5140);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==REQUIRE) {
					{
					setState(5126);
					match(REQUIRE);
					setState(5138);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case NONE:
						{
						setState(5127);
						((GrantStatementContext)_localctx).tlsNone = match(NONE);
						}
						break;
					case SSL:
					case CIPHER:
					case ISSUER:
					case SUBJECT:
					case X509:
						{
						setState(5128);
						tlsOption();
						setState(5135);
						_errHandler.sync(this);
						_la = _input.LA(1);
						while (_la==AND || _la==SSL || _la==CIPHER || _la==ISSUER || _la==SUBJECT || _la==X509) {
							{
							{
							setState(5130);
							_errHandler.sync(this);
							_la = _input.LA(1);
							if (_la==AND) {
								{
								setState(5129);
								match(AND);
								}
							}

							setState(5132);
							tlsOption();
							}
							}
							setState(5137);
							_errHandler.sync(this);
							_la = _input.LA(1);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					}
				}

				setState(5151);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,758,_ctx) ) {
				case 1:
					{
					setState(5142);
					match(WITH);
					setState(5148);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,757,_ctx);
					while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
						if ( _alt==1 ) {
							{
							setState(5146);
							_errHandler.sync(this);
							switch (_input.LA(1)) {
							case GRANT:
								{
								setState(5143);
								match(GRANT);
								setState(5144);
								match(OPTION);
								}
								break;
							case MAX_CONNECTIONS_PER_HOUR:
							case MAX_QUERIES_PER_HOUR:
							case MAX_UPDATES_PER_HOUR:
							case MAX_USER_CONNECTIONS:
								{
								setState(5145);
								userResourceOption();
								}
								break;
							default:
								throw new NoViableAltException(this);
							}
							} 
						}
						setState(5150);
						_errHandler.sync(this);
						_alt = getInterpreter().adaptivePredict(_input,757,_ctx);
					}
					}
					break;
				}
				setState(5159);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(5153);
					match(AS);
					setState(5154);
					userName();
					setState(5155);
					match(WITH);
					setState(5156);
					match(ROLE);
					setState(5157);
					roleOption();
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5161);
				match(GRANT);
				setState(5164);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,760,_ctx) ) {
				case 1:
					{
					setState(5162);
					userName();
					}
					break;
				case 2:
					{
					setState(5163);
					uid();
					}
					break;
				}
				setState(5173);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5166);
					match(COMMA);
					setState(5169);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,761,_ctx) ) {
					case 1:
						{
						setState(5167);
						userName();
						}
						break;
					case 2:
						{
						setState(5168);
						uid();
						}
						break;
					}
					}
					}
					setState(5175);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5176);
				match(TO);
				setState(5179);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,763,_ctx) ) {
				case 1:
					{
					setState(5177);
					userName();
					}
					break;
				case 2:
					{
					setState(5178);
					uid();
					}
					break;
				}
				setState(5188);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5181);
					match(COMMA);
					setState(5184);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,764,_ctx) ) {
					case 1:
						{
						setState(5182);
						userName();
						}
						break;
					case 2:
						{
						setState(5183);
						uid();
						}
						break;
					}
					}
					}
					setState(5190);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5194);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,766,_ctx) ) {
				case 1:
					{
					setState(5191);
					match(WITH);
					setState(5192);
					match(ADMIN);
					setState(5193);
					match(OPTION);
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RoleOptionContext extends ParserRuleContext {
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode EXCEPT() { return getToken(MySqlParser.EXCEPT, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RoleOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_roleOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoleOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoleOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoleOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RoleOptionContext roleOption() throws RecognitionException {
		RoleOptionContext _localctx = new RoleOptionContext(_ctx, getState());
		enterRule(_localctx, 434, RULE_roleOption);
		int _la;
		try {
			setState(5220);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,771,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5198);
				match(DEFAULT);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5199);
				match(NONE);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(5200);
				match(ALL);
				setState(5210);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==EXCEPT) {
					{
					setState(5201);
					match(EXCEPT);
					setState(5202);
					userName();
					setState(5207);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(5203);
						match(COMMA);
						setState(5204);
						userName();
						}
						}
						setState(5209);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(5212);
				userName();
				setState(5217);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5213);
					match(COMMA);
					setState(5214);
					userName();
					}
					}
					setState(5219);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class GrantProxyContext extends ParserRuleContext {
		public UserNameContext fromFirst;
		public UserNameContext toFirst;
		public UserNameContext userName;
		public List toOther = new ArrayList();
		public List GRANT() { return getTokens(MySqlParser.GRANT); }
		public TerminalNode GRANT(int i) {
			return getToken(MySqlParser.GRANT, i);
		}
		public TerminalNode PROXY() { return getToken(MySqlParser.PROXY, 0); }
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode OPTION() { return getToken(MySqlParser.OPTION, 0); }
		public GrantProxyContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_grantProxy; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGrantProxy(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGrantProxy(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGrantProxy(this);
			else return visitor.visitChildren(this);
		}
	}

	public final GrantProxyContext grantProxy() throws RecognitionException {
		GrantProxyContext _localctx = new GrantProxyContext(_ctx, getState());
		enterRule(_localctx, 436, RULE_grantProxy);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5222);
			match(GRANT);
			setState(5223);
			match(PROXY);
			setState(5224);
			match(ON);
			setState(5225);
			((GrantProxyContext)_localctx).fromFirst = userName();
			setState(5226);
			match(TO);
			setState(5227);
			((GrantProxyContext)_localctx).toFirst = userName();
			setState(5232);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5228);
				match(COMMA);
				setState(5229);
				((GrantProxyContext)_localctx).userName = userName();
				((GrantProxyContext)_localctx).toOther.add(((GrantProxyContext)_localctx).userName);
				}
				}
				setState(5234);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(5238);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,773,_ctx) ) {
			case 1:
				{
				setState(5235);
				match(WITH);
				setState(5236);
				match(GRANT);
				setState(5237);
				match(OPTION);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RenameUserContext extends ParserRuleContext {
		public TerminalNode RENAME() { return getToken(MySqlParser.RENAME, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public List renameUserClause() {
			return getRuleContexts(RenameUserClauseContext.class);
		}
		public RenameUserClauseContext renameUserClause(int i) {
			return getRuleContext(RenameUserClauseContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RenameUserContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_renameUser; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRenameUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRenameUser(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRenameUser(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RenameUserContext renameUser() throws RecognitionException {
		RenameUserContext _localctx = new RenameUserContext(_ctx, getState());
		enterRule(_localctx, 438, RULE_renameUser);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5240);
			match(RENAME);
			setState(5241);
			match(USER);
			setState(5242);
			renameUserClause();
			setState(5247);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5243);
				match(COMMA);
				setState(5244);
				renameUserClause();
				}
				}
				setState(5249);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RevokeStatementContext extends ParserRuleContext {
		public RevokeStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_revokeStatement; }
	 
		public RevokeStatementContext() { }
		public void copyFrom(RevokeStatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DetailRevokeContext extends RevokeStatementContext {
		public Token privilegeObject;
		public TerminalNode REVOKE() { return getToken(MySqlParser.REVOKE, 0); }
		public List privelegeClause() {
			return getRuleContexts(PrivelegeClauseContext.class);
		}
		public PrivelegeClauseContext privelegeClause(int i) {
			return getRuleContext(PrivelegeClauseContext.class,i);
		}
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public PrivilegeLevelContext privilegeLevel() {
			return getRuleContext(PrivilegeLevelContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public DetailRevokeContext(RevokeStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDetailRevoke(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDetailRevoke(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDetailRevoke(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RoleRevokeContext extends RevokeStatementContext {
		public TerminalNode REVOKE() { return getToken(MySqlParser.REVOKE, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RoleRevokeContext(RevokeStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoleRevoke(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoleRevoke(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoleRevoke(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShortRevokeContext extends RevokeStatementContext {
		public TerminalNode REVOKE() { return getToken(MySqlParser.REVOKE, 0); }
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode GRANT() { return getToken(MySqlParser.GRANT, 0); }
		public TerminalNode OPTION() { return getToken(MySqlParser.OPTION, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public TerminalNode PRIVILEGES() { return getToken(MySqlParser.PRIVILEGES, 0); }
		public ShortRevokeContext(RevokeStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShortRevoke(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShortRevoke(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShortRevoke(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RevokeStatementContext revokeStatement() throws RecognitionException {
		RevokeStatementContext _localctx = new RevokeStatementContext(_ctx, getState());
		enterRule(_localctx, 440, RULE_revokeStatement);
		int _la;
		try {
			setState(5320);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,786,_ctx) ) {
			case 1:
				_localctx = new DetailRevokeContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5250);
				match(REVOKE);
				setState(5251);
				privelegeClause();
				setState(5256);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5252);
					match(COMMA);
					setState(5253);
					privelegeClause();
					}
					}
					setState(5258);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5259);
				match(ON);
				setState(5261);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,776,_ctx) ) {
				case 1:
					{
					setState(5260);
					((DetailRevokeContext)_localctx).privilegeObject = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==PROCEDURE || _la==TABLE || _la==FUNCTION) ) {
						((DetailRevokeContext)_localctx).privilegeObject = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					break;
				}
				setState(5263);
				privilegeLevel();
				setState(5264);
				match(FROM);
				setState(5265);
				userName();
				setState(5270);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5266);
					match(COMMA);
					setState(5267);
					userName();
					}
					}
					setState(5272);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new ShortRevokeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5273);
				match(REVOKE);
				setState(5274);
				match(ALL);
				setState(5276);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRIVILEGES) {
					{
					setState(5275);
					match(PRIVILEGES);
					}
				}

				setState(5278);
				match(COMMA);
				setState(5279);
				match(GRANT);
				setState(5280);
				match(OPTION);
				setState(5281);
				match(FROM);
				setState(5282);
				userName();
				setState(5287);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5283);
					match(COMMA);
					setState(5284);
					userName();
					}
					}
					setState(5289);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 3:
				_localctx = new RoleRevokeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5290);
				match(REVOKE);
				setState(5293);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,780,_ctx) ) {
				case 1:
					{
					setState(5291);
					userName();
					}
					break;
				case 2:
					{
					setState(5292);
					uid();
					}
					break;
				}
				setState(5302);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5295);
					match(COMMA);
					setState(5298);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,781,_ctx) ) {
					case 1:
						{
						setState(5296);
						userName();
						}
						break;
					case 2:
						{
						setState(5297);
						uid();
						}
						break;
					}
					}
					}
					setState(5304);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5305);
				match(FROM);
				setState(5308);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,783,_ctx) ) {
				case 1:
					{
					setState(5306);
					userName();
					}
					break;
				case 2:
					{
					setState(5307);
					uid();
					}
					break;
				}
				setState(5317);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5310);
					match(COMMA);
					setState(5313);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,784,_ctx) ) {
					case 1:
						{
						setState(5311);
						userName();
						}
						break;
					case 2:
						{
						setState(5312);
						uid();
						}
						break;
					}
					}
					}
					setState(5319);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RevokeProxyContext extends ParserRuleContext {
		public UserNameContext onUser;
		public UserNameContext fromFirst;
		public UserNameContext userName;
		public List fromOther = new ArrayList();
		public TerminalNode REVOKE() { return getToken(MySqlParser.REVOKE, 0); }
		public TerminalNode PROXY() { return getToken(MySqlParser.PROXY, 0); }
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public RevokeProxyContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_revokeProxy; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRevokeProxy(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRevokeProxy(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRevokeProxy(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RevokeProxyContext revokeProxy() throws RecognitionException {
		RevokeProxyContext _localctx = new RevokeProxyContext(_ctx, getState());
		enterRule(_localctx, 442, RULE_revokeProxy);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5322);
			match(REVOKE);
			setState(5323);
			match(PROXY);
			setState(5324);
			match(ON);
			setState(5325);
			((RevokeProxyContext)_localctx).onUser = userName();
			setState(5326);
			match(FROM);
			setState(5327);
			((RevokeProxyContext)_localctx).fromFirst = userName();
			setState(5332);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5328);
				match(COMMA);
				setState(5329);
				((RevokeProxyContext)_localctx).userName = userName();
				((RevokeProxyContext)_localctx).fromOther.add(((RevokeProxyContext)_localctx).userName);
				}
				}
				setState(5334);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SetPasswordStatementContext extends ParserRuleContext {
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public PasswordFunctionClauseContext passwordFunctionClause() {
			return getRuleContext(PasswordFunctionClauseContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public SetPasswordStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_setPasswordStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetPasswordStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetPasswordStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetPasswordStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SetPasswordStatementContext setPasswordStatement() throws RecognitionException {
		SetPasswordStatementContext _localctx = new SetPasswordStatementContext(_ctx, getState());
		enterRule(_localctx, 444, RULE_setPasswordStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5335);
			match(SET);
			setState(5336);
			match(PASSWORD);
			setState(5339);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==FOR) {
				{
				setState(5337);
				match(FOR);
				setState(5338);
				userName();
				}
			}

			setState(5341);
			match(EQUAL_SYMBOL);
			setState(5344);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case OLD_PASSWORD:
			case PASSWORD:
				{
				setState(5342);
				passwordFunctionClause();
				}
				break;
			case STRING_LITERAL:
				{
				setState(5343);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserSpecificationContext extends ParserRuleContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public UserPasswordOptionContext userPasswordOption() {
			return getRuleContext(UserPasswordOptionContext.class,0);
		}
		public UserSpecificationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userSpecification; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserSpecification(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserSpecification(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserSpecification(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserSpecificationContext userSpecification() throws RecognitionException {
		UserSpecificationContext _localctx = new UserSpecificationContext(_ctx, getState());
		enterRule(_localctx, 446, RULE_userSpecification);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5346);
			userName();
			setState(5347);
			userPasswordOption();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserAuthOptionContext extends ParserRuleContext {
		public UserAuthOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userAuthOption; }
	 
		public UserAuthOptionContext() { }
		public void copyFrom(UserAuthOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SimpleAuthOptionContext extends UserAuthOptionContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public SimpleAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleAuthOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleAuthOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ModuleAuthOptionContext extends UserAuthOptionContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MySqlParser.IDENTIFIED, 0); }
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public AuthenticationRuleContext authenticationRule() {
			return getRuleContext(AuthenticationRuleContext.class,0);
		}
		public ModuleAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterModuleAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitModuleAuthOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitModuleAuthOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RandomAuthOptionContext extends UserAuthOptionContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MySqlParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode RANDOM() { return getToken(MySqlParser.RANDOM, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public AuthOptionClauseContext authOptionClause() {
			return getRuleContext(AuthOptionClauseContext.class,0);
		}
		public RandomAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRandomAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRandomAuthOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRandomAuthOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class StringAuthOptionContext extends UserAuthOptionContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MySqlParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public AuthOptionClauseContext authOptionClause() {
			return getRuleContext(AuthOptionClauseContext.class,0);
		}
		public StringAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStringAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStringAuthOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStringAuthOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class HashAuthOptionContext extends UserAuthOptionContext {
		public Token hashed;
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public TerminalNode IDENTIFIED() { return getToken(MySqlParser.IDENTIFIED, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public HashAuthOptionContext(UserAuthOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHashAuthOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHashAuthOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHashAuthOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserAuthOptionContext userAuthOption() throws RecognitionException {
		UserAuthOptionContext _localctx = new UserAuthOptionContext(_ctx, getState());
		enterRule(_localctx, 448, RULE_userAuthOption);
		try {
			setState(5374);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,790,_ctx) ) {
			case 1:
				_localctx = new HashAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5349);
				userName();
				setState(5350);
				match(IDENTIFIED);
				setState(5351);
				match(BY);
				setState(5352);
				match(PASSWORD);
				setState(5353);
				((HashAuthOptionContext)_localctx).hashed = match(STRING_LITERAL);
				}
				break;
			case 2:
				_localctx = new RandomAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5355);
				userName();
				setState(5356);
				match(IDENTIFIED);
				setState(5357);
				match(BY);
				setState(5358);
				match(RANDOM);
				setState(5359);
				match(PASSWORD);
				setState(5360);
				authOptionClause();
				}
				break;
			case 3:
				_localctx = new StringAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5362);
				userName();
				setState(5363);
				match(IDENTIFIED);
				setState(5364);
				match(BY);
				setState(5365);
				match(STRING_LITERAL);
				setState(5366);
				authOptionClause();
				}
				break;
			case 4:
				_localctx = new ModuleAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5368);
				userName();
				setState(5369);
				match(IDENTIFIED);
				setState(5370);
				match(WITH);
				setState(5371);
				authenticationRule();
				}
				break;
			case 5:
				_localctx = new SimpleAuthOptionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5373);
				userName();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AuthOptionClauseContext extends ParserRuleContext {
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode RETAIN() { return getToken(MySqlParser.RETAIN, 0); }
		public TerminalNode CURRENT() { return getToken(MySqlParser.CURRENT, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public AuthOptionClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_authOptionClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAuthOptionClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAuthOptionClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAuthOptionClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AuthOptionClauseContext authOptionClause() throws RecognitionException {
		AuthOptionClauseContext _localctx = new AuthOptionClauseContext(_ctx, getState());
		enterRule(_localctx, 450, RULE_authOptionClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5378);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,791,_ctx) ) {
			case 1:
				{
				setState(5376);
				match(REPLACE);
				setState(5377);
				match(STRING_LITERAL);
				}
				break;
			}
			setState(5383);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==RETAIN) {
				{
				setState(5380);
				match(RETAIN);
				setState(5381);
				match(CURRENT);
				setState(5382);
				match(PASSWORD);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AuthenticationRuleContext extends ParserRuleContext {
		public AuthenticationRuleContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_authenticationRule; }
	 
		public AuthenticationRuleContext() { }
		public void copyFrom(AuthenticationRuleContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PasswordModuleOptionContext extends AuthenticationRuleContext {
		public AuthPluginContext authPlugin() {
			return getRuleContext(AuthPluginContext.class,0);
		}
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public PasswordFunctionClauseContext passwordFunctionClause() {
			return getRuleContext(PasswordFunctionClauseContext.class,0);
		}
		public PasswordModuleOptionContext(AuthenticationRuleContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPasswordModuleOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPasswordModuleOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPasswordModuleOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ModuleContext extends AuthenticationRuleContext {
		public AuthPluginContext authPlugin() {
			return getRuleContext(AuthPluginContext.class,0);
		}
		public AuthOptionClauseContext authOptionClause() {
			return getRuleContext(AuthOptionClauseContext.class,0);
		}
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode RANDOM() { return getToken(MySqlParser.RANDOM, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public ModuleContext(AuthenticationRuleContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterModule(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitModule(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitModule(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AuthenticationRuleContext authenticationRule() throws RecognitionException {
		AuthenticationRuleContext _localctx = new AuthenticationRuleContext(_ctx, getState());
		enterRule(_localctx, 452, RULE_authenticationRule);
		int _la;
		try {
			setState(5399);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,795,_ctx) ) {
			case 1:
				_localctx = new ModuleContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5385);
				authPlugin();
				setState(5393);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,794,_ctx) ) {
				case 1:
					{
					setState(5386);
					_la = _input.LA(1);
					if ( !(_la==AS || _la==BY || _la==USING) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5390);
					_errHandler.sync(this);
					switch (_input.LA(1)) {
					case STRING_LITERAL:
						{
						setState(5387);
						match(STRING_LITERAL);
						}
						break;
					case RANDOM:
						{
						setState(5388);
						match(RANDOM);
						setState(5389);
						match(PASSWORD);
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(5392);
					authOptionClause();
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new PasswordModuleOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5395);
				authPlugin();
				setState(5396);
				match(USING);
				setState(5397);
				passwordFunctionClause();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TlsOptionContext extends ParserRuleContext {
		public TerminalNode SSL() { return getToken(MySqlParser.SSL, 0); }
		public TerminalNode X509() { return getToken(MySqlParser.X509, 0); }
		public TerminalNode CIPHER() { return getToken(MySqlParser.CIPHER, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ISSUER() { return getToken(MySqlParser.ISSUER, 0); }
		public TerminalNode SUBJECT() { return getToken(MySqlParser.SUBJECT, 0); }
		public TlsOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tlsOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTlsOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTlsOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTlsOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TlsOptionContext tlsOption() throws RecognitionException {
		TlsOptionContext _localctx = new TlsOptionContext(_ctx, getState());
		enterRule(_localctx, 454, RULE_tlsOption);
		try {
			setState(5409);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SSL:
				enterOuterAlt(_localctx, 1);
				{
				setState(5401);
				match(SSL);
				}
				break;
			case X509:
				enterOuterAlt(_localctx, 2);
				{
				setState(5402);
				match(X509);
				}
				break;
			case CIPHER:
				enterOuterAlt(_localctx, 3);
				{
				setState(5403);
				match(CIPHER);
				setState(5404);
				match(STRING_LITERAL);
				}
				break;
			case ISSUER:
				enterOuterAlt(_localctx, 4);
				{
				setState(5405);
				match(ISSUER);
				setState(5406);
				match(STRING_LITERAL);
				}
				break;
			case SUBJECT:
				enterOuterAlt(_localctx, 5);
				{
				setState(5407);
				match(SUBJECT);
				setState(5408);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserResourceOptionContext extends ParserRuleContext {
		public TerminalNode MAX_QUERIES_PER_HOUR() { return getToken(MySqlParser.MAX_QUERIES_PER_HOUR, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode MAX_UPDATES_PER_HOUR() { return getToken(MySqlParser.MAX_UPDATES_PER_HOUR, 0); }
		public TerminalNode MAX_CONNECTIONS_PER_HOUR() { return getToken(MySqlParser.MAX_CONNECTIONS_PER_HOUR, 0); }
		public TerminalNode MAX_USER_CONNECTIONS() { return getToken(MySqlParser.MAX_USER_CONNECTIONS, 0); }
		public UserResourceOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userResourceOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserResourceOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserResourceOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserResourceOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserResourceOptionContext userResourceOption() throws RecognitionException {
		UserResourceOptionContext _localctx = new UserResourceOptionContext(_ctx, getState());
		enterRule(_localctx, 456, RULE_userResourceOption);
		try {
			setState(5419);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case MAX_QUERIES_PER_HOUR:
				enterOuterAlt(_localctx, 1);
				{
				setState(5411);
				match(MAX_QUERIES_PER_HOUR);
				setState(5412);
				decimalLiteral();
				}
				break;
			case MAX_UPDATES_PER_HOUR:
				enterOuterAlt(_localctx, 2);
				{
				setState(5413);
				match(MAX_UPDATES_PER_HOUR);
				setState(5414);
				decimalLiteral();
				}
				break;
			case MAX_CONNECTIONS_PER_HOUR:
				enterOuterAlt(_localctx, 3);
				{
				setState(5415);
				match(MAX_CONNECTIONS_PER_HOUR);
				setState(5416);
				decimalLiteral();
				}
				break;
			case MAX_USER_CONNECTIONS:
				enterOuterAlt(_localctx, 4);
				{
				setState(5417);
				match(MAX_USER_CONNECTIONS);
				setState(5418);
				decimalLiteral();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserPasswordOptionContext extends ParserRuleContext {
		public Token expireType;
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode EXPIRE() { return getToken(MySqlParser.EXPIRE, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode DAY() { return getToken(MySqlParser.DAY, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode NEVER() { return getToken(MySqlParser.NEVER, 0); }
		public TerminalNode INTERVAL() { return getToken(MySqlParser.INTERVAL, 0); }
		public TerminalNode HISTORY() { return getToken(MySqlParser.HISTORY, 0); }
		public TerminalNode REUSE() { return getToken(MySqlParser.REUSE, 0); }
		public TerminalNode REQUIRE() { return getToken(MySqlParser.REQUIRE, 0); }
		public TerminalNode CURRENT() { return getToken(MySqlParser.CURRENT, 0); }
		public TerminalNode OPTIONAL() { return getToken(MySqlParser.OPTIONAL, 0); }
		public TerminalNode FAILED_LOGIN_ATTEMPTS() { return getToken(MySqlParser.FAILED_LOGIN_ATTEMPTS, 0); }
		public TerminalNode PASSWORD_LOCK_TIME() { return getToken(MySqlParser.PASSWORD_LOCK_TIME, 0); }
		public TerminalNode UNBOUNDED() { return getToken(MySqlParser.UNBOUNDED, 0); }
		public UserPasswordOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userPasswordOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserPasswordOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserPasswordOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserPasswordOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserPasswordOptionContext userPasswordOption() throws RecognitionException {
		UserPasswordOptionContext _localctx = new UserPasswordOptionContext(_ctx, getState());
		enterRule(_localctx, 458, RULE_userPasswordOption);
		int _la;
		try {
			setState(5459);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,803,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5421);
				match(PASSWORD);
				setState(5422);
				match(EXPIRE);
				setState(5429);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(5423);
					((UserPasswordOptionContext)_localctx).expireType = match(DEFAULT);
					}
					break;
				case NEVER:
					{
					setState(5424);
					((UserPasswordOptionContext)_localctx).expireType = match(NEVER);
					}
					break;
				case INTERVAL:
					{
					setState(5425);
					((UserPasswordOptionContext)_localctx).expireType = match(INTERVAL);
					setState(5426);
					decimalLiteral();
					setState(5427);
					match(DAY);
					}
					break;
				case EOF:
				case ALTER:
				case ANALYZE:
				case ATTRIBUTE:
				case CALL:
				case CHANGE:
				case CHECK:
				case CREATE:
				case DELETE:
				case DESC:
				case DESCRIBE:
				case DROP:
				case EXPLAIN:
				case GET:
				case GRANT:
				case INSERT:
				case KILL:
				case LOAD:
				case LOCK:
				case OPTIMIZE:
				case PURGE:
				case RELEASE:
				case RENAME:
				case REPLACE:
				case RESIGNAL:
				case REVOKE:
				case SELECT:
				case SET:
				case SHOW:
				case SIGNAL:
				case TABLE:
				case UNLOCK:
				case UPDATE:
				case USE:
				case VALUES:
				case WITH:
				case ACCOUNT:
				case BEGIN:
				case BINLOG:
				case CACHE:
				case CHECKSUM:
				case COMMENT:
				case COMMIT:
				case DEALLOCATE:
				case DO:
				case FAILED_LOGIN_ATTEMPTS:
				case FLUSH:
				case HANDLER:
				case HELP:
				case INSTALL:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PREPARE:
				case REPAIR:
				case RESET:
				case ROLLBACK:
				case SAVEPOINT:
				case START:
				case STOP:
				case TRUNCATE:
				case UNINSTALL:
				case XA:
				case EXECUTE:
				case SHUTDOWN:
				case MINUS:
				case LR_BRACKET:
				case COMMA:
				case SEMI:
					break;
				default:
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5431);
				match(PASSWORD);
				setState(5432);
				match(HISTORY);
				setState(5435);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(5433);
					match(DEFAULT);
					}
					break;
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(5434);
					decimalLiteral();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(5437);
				match(PASSWORD);
				setState(5438);
				match(REUSE);
				setState(5439);
				match(INTERVAL);
				setState(5444);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DEFAULT:
					{
					setState(5440);
					match(DEFAULT);
					}
					break;
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(5441);
					decimalLiteral();
					setState(5442);
					match(DAY);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(5446);
				match(PASSWORD);
				setState(5447);
				match(REQUIRE);
				setState(5448);
				match(CURRENT);
				setState(5450);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT || _la==OPTIONAL) {
					{
					setState(5449);
					_la = _input.LA(1);
					if ( !(_la==DEFAULT || _la==OPTIONAL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(5452);
				match(FAILED_LOGIN_ATTEMPTS);
				setState(5453);
				decimalLiteral();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(5454);
				match(PASSWORD_LOCK_TIME);
				setState(5457);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(5455);
					decimalLiteral();
					}
					break;
				case UNBOUNDED:
					{
					setState(5456);
					match(UNBOUNDED);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserLockOptionContext extends ParserRuleContext {
		public Token lockType;
		public TerminalNode ACCOUNT() { return getToken(MySqlParser.ACCOUNT, 0); }
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public TerminalNode UNLOCK() { return getToken(MySqlParser.UNLOCK, 0); }
		public UserLockOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userLockOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserLockOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserLockOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserLockOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserLockOptionContext userLockOption() throws RecognitionException {
		UserLockOptionContext _localctx = new UserLockOptionContext(_ctx, getState());
		enterRule(_localctx, 460, RULE_userLockOption);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5461);
			match(ACCOUNT);
			setState(5462);
			((UserLockOptionContext)_localctx).lockType = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==LOCK || _la==UNLOCK) ) {
				((UserLockOptionContext)_localctx).lockType = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PrivelegeClauseContext extends ParserRuleContext {
		public PrivilegeContext privilege() {
			return getRuleContext(PrivilegeContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public PrivelegeClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_privelegeClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPrivelegeClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPrivelegeClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPrivelegeClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrivelegeClauseContext privelegeClause() throws RecognitionException {
		PrivelegeClauseContext _localctx = new PrivelegeClauseContext(_ctx, getState());
		enterRule(_localctx, 462, RULE_privelegeClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5464);
			privilege();
			setState(5469);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LR_BRACKET) {
				{
				setState(5465);
				match(LR_BRACKET);
				setState(5466);
				uidList();
				setState(5467);
				match(RR_BRACKET);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PrivilegeContext extends ParserRuleContext {
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MySqlParser.PRIVILEGES, 0); }
		public TerminalNode ALTER() { return getToken(MySqlParser.ALTER, 0); }
		public TerminalNode ROUTINE() { return getToken(MySqlParser.ROUTINE, 0); }
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode TEMPORARY() { return getToken(MySqlParser.TEMPORARY, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TerminalNode VIEW() { return getToken(MySqlParser.VIEW, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public TerminalNode DELETE() { return getToken(MySqlParser.DELETE, 0); }
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode EVENT() { return getToken(MySqlParser.EVENT, 0); }
		public TerminalNode EXECUTE() { return getToken(MySqlParser.EXECUTE, 0); }
		public TerminalNode FILE() { return getToken(MySqlParser.FILE, 0); }
		public TerminalNode GRANT() { return getToken(MySqlParser.GRANT, 0); }
		public TerminalNode OPTION() { return getToken(MySqlParser.OPTION, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode INSERT() { return getToken(MySqlParser.INSERT, 0); }
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public TerminalNode PROCESS() { return getToken(MySqlParser.PROCESS, 0); }
		public TerminalNode PROXY() { return getToken(MySqlParser.PROXY, 0); }
		public TerminalNode REFERENCES() { return getToken(MySqlParser.REFERENCES, 0); }
		public TerminalNode RELOAD() { return getToken(MySqlParser.RELOAD, 0); }
		public TerminalNode REPLICATION() { return getToken(MySqlParser.REPLICATION, 0); }
		public TerminalNode CLIENT() { return getToken(MySqlParser.CLIENT, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public TerminalNode SELECT() { return getToken(MySqlParser.SELECT, 0); }
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode DATABASES() { return getToken(MySqlParser.DATABASES, 0); }
		public TerminalNode SHUTDOWN() { return getToken(MySqlParser.SHUTDOWN, 0); }
		public TerminalNode SUPER() { return getToken(MySqlParser.SUPER, 0); }
		public TerminalNode TRIGGER() { return getToken(MySqlParser.TRIGGER, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public TerminalNode USAGE() { return getToken(MySqlParser.USAGE, 0); }
		public TerminalNode APPLICATION_PASSWORD_ADMIN() { return getToken(MySqlParser.APPLICATION_PASSWORD_ADMIN, 0); }
		public TerminalNode AUDIT_ABORT_EXEMPT() { return getToken(MySqlParser.AUDIT_ABORT_EXEMPT, 0); }
		public TerminalNode AUDIT_ADMIN() { return getToken(MySqlParser.AUDIT_ADMIN, 0); }
		public TerminalNode AUTHENTICATION_POLICY_ADMIN() { return getToken(MySqlParser.AUTHENTICATION_POLICY_ADMIN, 0); }
		public TerminalNode BACKUP_ADMIN() { return getToken(MySqlParser.BACKUP_ADMIN, 0); }
		public TerminalNode BINLOG_ADMIN() { return getToken(MySqlParser.BINLOG_ADMIN, 0); }
		public TerminalNode BINLOG_ENCRYPTION_ADMIN() { return getToken(MySqlParser.BINLOG_ENCRYPTION_ADMIN, 0); }
		public TerminalNode CLONE_ADMIN() { return getToken(MySqlParser.CLONE_ADMIN, 0); }
		public TerminalNode CONNECTION_ADMIN() { return getToken(MySqlParser.CONNECTION_ADMIN, 0); }
		public TerminalNode ENCRYPTION_KEY_ADMIN() { return getToken(MySqlParser.ENCRYPTION_KEY_ADMIN, 0); }
		public TerminalNode FIREWALL_ADMIN() { return getToken(MySqlParser.FIREWALL_ADMIN, 0); }
		public TerminalNode FIREWALL_EXEMPT() { return getToken(MySqlParser.FIREWALL_EXEMPT, 0); }
		public TerminalNode FIREWALL_USER() { return getToken(MySqlParser.FIREWALL_USER, 0); }
		public TerminalNode FLUSH_OPTIMIZER_COSTS() { return getToken(MySqlParser.FLUSH_OPTIMIZER_COSTS, 0); }
		public TerminalNode FLUSH_STATUS() { return getToken(MySqlParser.FLUSH_STATUS, 0); }
		public TerminalNode FLUSH_TABLES() { return getToken(MySqlParser.FLUSH_TABLES, 0); }
		public TerminalNode FLUSH_USER_RESOURCES() { return getToken(MySqlParser.FLUSH_USER_RESOURCES, 0); }
		public TerminalNode GROUP_REPLICATION_ADMIN() { return getToken(MySqlParser.GROUP_REPLICATION_ADMIN, 0); }
		public TerminalNode INNODB_REDO_LOG_ARCHIVE() { return getToken(MySqlParser.INNODB_REDO_LOG_ARCHIVE, 0); }
		public TerminalNode INNODB_REDO_LOG_ENABLE() { return getToken(MySqlParser.INNODB_REDO_LOG_ENABLE, 0); }
		public TerminalNode NDB_STORED_USER() { return getToken(MySqlParser.NDB_STORED_USER, 0); }
		public TerminalNode PASSWORDLESS_USER_ADMIN() { return getToken(MySqlParser.PASSWORDLESS_USER_ADMIN, 0); }
		public TerminalNode PERSIST_RO_VARIABLES_ADMIN() { return getToken(MySqlParser.PERSIST_RO_VARIABLES_ADMIN, 0); }
		public TerminalNode REPLICATION_APPLIER() { return getToken(MySqlParser.REPLICATION_APPLIER, 0); }
		public TerminalNode REPLICATION_SLAVE_ADMIN() { return getToken(MySqlParser.REPLICATION_SLAVE_ADMIN, 0); }
		public TerminalNode RESOURCE_GROUP_ADMIN() { return getToken(MySqlParser.RESOURCE_GROUP_ADMIN, 0); }
		public TerminalNode RESOURCE_GROUP_USER() { return getToken(MySqlParser.RESOURCE_GROUP_USER, 0); }
		public TerminalNode ROLE_ADMIN() { return getToken(MySqlParser.ROLE_ADMIN, 0); }
		public TerminalNode SERVICE_CONNECTION_ADMIN() { return getToken(MySqlParser.SERVICE_CONNECTION_ADMIN, 0); }
		public TerminalNode SESSION_VARIABLES_ADMIN() { return getToken(MySqlParser.SESSION_VARIABLES_ADMIN, 0); }
		public TerminalNode SET_USER_ID() { return getToken(MySqlParser.SET_USER_ID, 0); }
		public TerminalNode SKIP_QUERY_REWRITE() { return getToken(MySqlParser.SKIP_QUERY_REWRITE, 0); }
		public TerminalNode SHOW_ROUTINE() { return getToken(MySqlParser.SHOW_ROUTINE, 0); }
		public TerminalNode SYSTEM_USER() { return getToken(MySqlParser.SYSTEM_USER, 0); }
		public TerminalNode SYSTEM_VARIABLES_ADMIN() { return getToken(MySqlParser.SYSTEM_VARIABLES_ADMIN, 0); }
		public TerminalNode TABLE_ENCRYPTION_ADMIN() { return getToken(MySqlParser.TABLE_ENCRYPTION_ADMIN, 0); }
		public TerminalNode TP_CONNECTION_ADMIN() { return getToken(MySqlParser.TP_CONNECTION_ADMIN, 0); }
		public TerminalNode VERSION_TOKEN_ADMIN() { return getToken(MySqlParser.VERSION_TOKEN_ADMIN, 0); }
		public TerminalNode XA_RECOVER_ADMIN() { return getToken(MySqlParser.XA_RECOVER_ADMIN, 0); }
		public TerminalNode LOAD() { return getToken(MySqlParser.LOAD, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode S3() { return getToken(MySqlParser.S3, 0); }
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode INVOKE() { return getToken(MySqlParser.INVOKE, 0); }
		public TerminalNode LAMBDA() { return getToken(MySqlParser.LAMBDA, 0); }
		public PrivilegeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_privilege; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPrivilege(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPrivilege(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPrivilege(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrivilegeContext privilege() throws RecognitionException {
		PrivilegeContext _localctx = new PrivilegeContext(_ctx, getState());
		enterRule(_localctx, 464, RULE_privilege);
		int _la;
		try {
			setState(5564);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,809,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(5471);
				match(ALL);
				setState(5473);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRIVILEGES) {
					{
					setState(5472);
					match(PRIVILEGES);
					}
				}

				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(5475);
				match(ALTER);
				setState(5477);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ROUTINE) {
					{
					setState(5476);
					match(ROUTINE);
					}
				}

				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(5479);
				match(CREATE);
				setState(5487);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case TEMPORARY:
					{
					setState(5480);
					match(TEMPORARY);
					setState(5481);
					match(TABLES);
					}
					break;
				case ROUTINE:
					{
					setState(5482);
					match(ROUTINE);
					}
					break;
				case VIEW:
					{
					setState(5483);
					match(VIEW);
					}
					break;
				case USER:
					{
					setState(5484);
					match(USER);
					}
					break;
				case TABLESPACE:
					{
					setState(5485);
					match(TABLESPACE);
					}
					break;
				case ROLE:
					{
					setState(5486);
					match(ROLE);
					}
					break;
				case ON:
				case LR_BRACKET:
				case COMMA:
					break;
				default:
					break;
				}
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(5489);
				match(DELETE);
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(5490);
				match(DROP);
				setState(5492);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ROLE) {
					{
					setState(5491);
					match(ROLE);
					}
				}

				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(5494);
				match(EVENT);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(5495);
				match(EXECUTE);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(5496);
				match(FILE);
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(5497);
				match(GRANT);
				setState(5498);
				match(OPTION);
				}
				break;
			case 10:
				enterOuterAlt(_localctx, 10);
				{
				setState(5499);
				match(INDEX);
				}
				break;
			case 11:
				enterOuterAlt(_localctx, 11);
				{
				setState(5500);
				match(INSERT);
				}
				break;
			case 12:
				enterOuterAlt(_localctx, 12);
				{
				setState(5501);
				match(LOCK);
				setState(5502);
				match(TABLES);
				}
				break;
			case 13:
				enterOuterAlt(_localctx, 13);
				{
				setState(5503);
				match(PROCESS);
				}
				break;
			case 14:
				enterOuterAlt(_localctx, 14);
				{
				setState(5504);
				match(PROXY);
				}
				break;
			case 15:
				enterOuterAlt(_localctx, 15);
				{
				setState(5505);
				match(REFERENCES);
				}
				break;
			case 16:
				enterOuterAlt(_localctx, 16);
				{
				setState(5506);
				match(RELOAD);
				}
				break;
			case 17:
				enterOuterAlt(_localctx, 17);
				{
				setState(5507);
				match(REPLICATION);
				setState(5508);
				_la = _input.LA(1);
				if ( !(_la==CLIENT || _la==SLAVE) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 18:
				enterOuterAlt(_localctx, 18);
				{
				setState(5509);
				match(SELECT);
				}
				break;
			case 19:
				enterOuterAlt(_localctx, 19);
				{
				setState(5510);
				match(SHOW);
				setState(5511);
				_la = _input.LA(1);
				if ( !(_la==DATABASES || _la==VIEW) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 20:
				enterOuterAlt(_localctx, 20);
				{
				setState(5512);
				match(SHUTDOWN);
				}
				break;
			case 21:
				enterOuterAlt(_localctx, 21);
				{
				setState(5513);
				match(SUPER);
				}
				break;
			case 22:
				enterOuterAlt(_localctx, 22);
				{
				setState(5514);
				match(TRIGGER);
				}
				break;
			case 23:
				enterOuterAlt(_localctx, 23);
				{
				setState(5515);
				match(UPDATE);
				}
				break;
			case 24:
				enterOuterAlt(_localctx, 24);
				{
				setState(5516);
				match(USAGE);
				}
				break;
			case 25:
				enterOuterAlt(_localctx, 25);
				{
				setState(5517);
				match(APPLICATION_PASSWORD_ADMIN);
				}
				break;
			case 26:
				enterOuterAlt(_localctx, 26);
				{
				setState(5518);
				match(AUDIT_ABORT_EXEMPT);
				}
				break;
			case 27:
				enterOuterAlt(_localctx, 27);
				{
				setState(5519);
				match(AUDIT_ADMIN);
				}
				break;
			case 28:
				enterOuterAlt(_localctx, 28);
				{
				setState(5520);
				match(AUTHENTICATION_POLICY_ADMIN);
				}
				break;
			case 29:
				enterOuterAlt(_localctx, 29);
				{
				setState(5521);
				match(BACKUP_ADMIN);
				}
				break;
			case 30:
				enterOuterAlt(_localctx, 30);
				{
				setState(5522);
				match(BINLOG_ADMIN);
				}
				break;
			case 31:
				enterOuterAlt(_localctx, 31);
				{
				setState(5523);
				match(BINLOG_ENCRYPTION_ADMIN);
				}
				break;
			case 32:
				enterOuterAlt(_localctx, 32);
				{
				setState(5524);
				match(CLONE_ADMIN);
				}
				break;
			case 33:
				enterOuterAlt(_localctx, 33);
				{
				setState(5525);
				match(CONNECTION_ADMIN);
				}
				break;
			case 34:
				enterOuterAlt(_localctx, 34);
				{
				setState(5526);
				match(ENCRYPTION_KEY_ADMIN);
				}
				break;
			case 35:
				enterOuterAlt(_localctx, 35);
				{
				setState(5527);
				match(FIREWALL_ADMIN);
				}
				break;
			case 36:
				enterOuterAlt(_localctx, 36);
				{
				setState(5528);
				match(FIREWALL_EXEMPT);
				}
				break;
			case 37:
				enterOuterAlt(_localctx, 37);
				{
				setState(5529);
				match(FIREWALL_USER);
				}
				break;
			case 38:
				enterOuterAlt(_localctx, 38);
				{
				setState(5530);
				match(FLUSH_OPTIMIZER_COSTS);
				}
				break;
			case 39:
				enterOuterAlt(_localctx, 39);
				{
				setState(5531);
				match(FLUSH_STATUS);
				}
				break;
			case 40:
				enterOuterAlt(_localctx, 40);
				{
				setState(5532);
				match(FLUSH_TABLES);
				}
				break;
			case 41:
				enterOuterAlt(_localctx, 41);
				{
				setState(5533);
				match(FLUSH_USER_RESOURCES);
				}
				break;
			case 42:
				enterOuterAlt(_localctx, 42);
				{
				setState(5534);
				match(GROUP_REPLICATION_ADMIN);
				}
				break;
			case 43:
				enterOuterAlt(_localctx, 43);
				{
				setState(5535);
				match(INNODB_REDO_LOG_ARCHIVE);
				}
				break;
			case 44:
				enterOuterAlt(_localctx, 44);
				{
				setState(5536);
				match(INNODB_REDO_LOG_ENABLE);
				}
				break;
			case 45:
				enterOuterAlt(_localctx, 45);
				{
				setState(5537);
				match(NDB_STORED_USER);
				}
				break;
			case 46:
				enterOuterAlt(_localctx, 46);
				{
				setState(5538);
				match(PASSWORDLESS_USER_ADMIN);
				}
				break;
			case 47:
				enterOuterAlt(_localctx, 47);
				{
				setState(5539);
				match(PERSIST_RO_VARIABLES_ADMIN);
				}
				break;
			case 48:
				enterOuterAlt(_localctx, 48);
				{
				setState(5540);
				match(REPLICATION_APPLIER);
				}
				break;
			case 49:
				enterOuterAlt(_localctx, 49);
				{
				setState(5541);
				match(REPLICATION_SLAVE_ADMIN);
				}
				break;
			case 50:
				enterOuterAlt(_localctx, 50);
				{
				setState(5542);
				match(RESOURCE_GROUP_ADMIN);
				}
				break;
			case 51:
				enterOuterAlt(_localctx, 51);
				{
				setState(5543);
				match(RESOURCE_GROUP_USER);
				}
				break;
			case 52:
				enterOuterAlt(_localctx, 52);
				{
				setState(5544);
				match(ROLE_ADMIN);
				}
				break;
			case 53:
				enterOuterAlt(_localctx, 53);
				{
				setState(5545);
				match(SERVICE_CONNECTION_ADMIN);
				}
				break;
			case 54:
				enterOuterAlt(_localctx, 54);
				{
				setState(5546);
				match(SESSION_VARIABLES_ADMIN);
				}
				break;
			case 55:
				enterOuterAlt(_localctx, 55);
				{
				setState(5547);
				match(SET_USER_ID);
				}
				break;
			case 56:
				enterOuterAlt(_localctx, 56);
				{
				setState(5548);
				match(SKIP_QUERY_REWRITE);
				}
				break;
			case 57:
				enterOuterAlt(_localctx, 57);
				{
				setState(5549);
				match(SHOW_ROUTINE);
				}
				break;
			case 58:
				enterOuterAlt(_localctx, 58);
				{
				setState(5550);
				match(SYSTEM_USER);
				}
				break;
			case 59:
				enterOuterAlt(_localctx, 59);
				{
				setState(5551);
				match(SYSTEM_VARIABLES_ADMIN);
				}
				break;
			case 60:
				enterOuterAlt(_localctx, 60);
				{
				setState(5552);
				match(TABLE_ENCRYPTION_ADMIN);
				}
				break;
			case 61:
				enterOuterAlt(_localctx, 61);
				{
				setState(5553);
				match(TP_CONNECTION_ADMIN);
				}
				break;
			case 62:
				enterOuterAlt(_localctx, 62);
				{
				setState(5554);
				match(VERSION_TOKEN_ADMIN);
				}
				break;
			case 63:
				enterOuterAlt(_localctx, 63);
				{
				setState(5555);
				match(XA_RECOVER_ADMIN);
				}
				break;
			case 64:
				enterOuterAlt(_localctx, 64);
				{
				setState(5556);
				match(LOAD);
				setState(5557);
				match(FROM);
				setState(5558);
				match(S3);
				}
				break;
			case 65:
				enterOuterAlt(_localctx, 65);
				{
				setState(5559);
				match(SELECT);
				setState(5560);
				match(INTO);
				setState(5561);
				match(S3);
				}
				break;
			case 66:
				enterOuterAlt(_localctx, 66);
				{
				setState(5562);
				match(INVOKE);
				setState(5563);
				match(LAMBDA);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PrivilegeLevelContext extends ParserRuleContext {
		public PrivilegeLevelContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_privilegeLevel; }
	 
		public PrivilegeLevelContext() { }
		public void copyFrom(PrivilegeLevelContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DefiniteSchemaPrivLevelContext extends PrivilegeLevelContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DOT() { return getToken(MySqlParser.DOT, 0); }
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public DefiniteSchemaPrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefiniteSchemaPrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefiniteSchemaPrivLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefiniteSchemaPrivLevel(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DefiniteFullTablePrivLevel2Context extends PrivilegeLevelContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public DottedIdContext dottedId() {
			return getRuleContext(DottedIdContext.class,0);
		}
		public DefiniteFullTablePrivLevel2Context(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefiniteFullTablePrivLevel2(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefiniteFullTablePrivLevel2(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefiniteFullTablePrivLevel2(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DefiniteFullTablePrivLevelContext extends PrivilegeLevelContext {
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode DOT() { return getToken(MySqlParser.DOT, 0); }
		public DefiniteFullTablePrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefiniteFullTablePrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefiniteFullTablePrivLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefiniteFullTablePrivLevel(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class GlobalPrivLevelContext extends PrivilegeLevelContext {
		public List STAR() { return getTokens(MySqlParser.STAR); }
		public TerminalNode STAR(int i) {
			return getToken(MySqlParser.STAR, i);
		}
		public TerminalNode DOT() { return getToken(MySqlParser.DOT, 0); }
		public GlobalPrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGlobalPrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGlobalPrivLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGlobalPrivLevel(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DefiniteTablePrivLevelContext extends PrivilegeLevelContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public DefiniteTablePrivLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefiniteTablePrivLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefiniteTablePrivLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefiniteTablePrivLevel(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CurrentSchemaPriviLevelContext extends PrivilegeLevelContext {
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public CurrentSchemaPriviLevelContext(PrivilegeLevelContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCurrentSchemaPriviLevel(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCurrentSchemaPriviLevel(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCurrentSchemaPriviLevel(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrivilegeLevelContext privilegeLevel() throws RecognitionException {
		PrivilegeLevelContext _localctx = new PrivilegeLevelContext(_ctx, getState());
		enterRule(_localctx, 466, RULE_privilegeLevel);
		try {
			setState(5582);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,810,_ctx) ) {
			case 1:
				_localctx = new CurrentSchemaPriviLevelContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5566);
				match(STAR);
				}
				break;
			case 2:
				_localctx = new GlobalPrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5567);
				match(STAR);
				setState(5568);
				match(DOT);
				setState(5569);
				match(STAR);
				}
				break;
			case 3:
				_localctx = new DefiniteSchemaPrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5570);
				uid();
				setState(5571);
				match(DOT);
				setState(5572);
				match(STAR);
				}
				break;
			case 4:
				_localctx = new DefiniteFullTablePrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5574);
				uid();
				setState(5575);
				match(DOT);
				setState(5576);
				uid();
				}
				break;
			case 5:
				_localctx = new DefiniteFullTablePrivLevel2Context(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5578);
				uid();
				setState(5579);
				dottedId();
				}
				break;
			case 6:
				_localctx = new DefiniteTablePrivLevelContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5581);
				uid();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RenameUserClauseContext extends ParserRuleContext {
		public UserNameContext fromFirst;
		public UserNameContext toFirst;
		public TerminalNode TO() { return getToken(MySqlParser.TO, 0); }
		public List userName() {
			return getRuleContexts(UserNameContext.class);
		}
		public UserNameContext userName(int i) {
			return getRuleContext(UserNameContext.class,i);
		}
		public RenameUserClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_renameUserClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRenameUserClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRenameUserClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRenameUserClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RenameUserClauseContext renameUserClause() throws RecognitionException {
		RenameUserClauseContext _localctx = new RenameUserClauseContext(_ctx, getState());
		enterRule(_localctx, 468, RULE_renameUserClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5584);
			((RenameUserClauseContext)_localctx).fromFirst = userName();
			setState(5585);
			match(TO);
			setState(5586);
			((RenameUserClauseContext)_localctx).toFirst = userName();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AnalyzeTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode ANALYZE() { return getToken(MySqlParser.ANALYZE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public List HISTOGRAM() { return getTokens(MySqlParser.HISTOGRAM); }
		public TerminalNode HISTOGRAM(int i) {
			return getToken(MySqlParser.HISTOGRAM, i);
		}
		public List ON() { return getTokens(MySqlParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MySqlParser.ON, i);
		}
		public List fullColumnName() {
			return getRuleContexts(FullColumnNameContext.class);
		}
		public FullColumnNameContext fullColumnName(int i) {
			return getRuleContext(FullColumnNameContext.class,i);
		}
		public TerminalNode DROP() { return getToken(MySqlParser.DROP, 0); }
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MySqlParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode BUCKETS() { return getToken(MySqlParser.BUCKETS, 0); }
		public AnalyzeTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_analyzeTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAnalyzeTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAnalyzeTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAnalyzeTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AnalyzeTableContext analyzeTable() throws RecognitionException {
		AnalyzeTableContext _localctx = new AnalyzeTableContext(_ctx, getState());
		enterRule(_localctx, 470, RULE_analyzeTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5588);
			match(ANALYZE);
			setState(5590);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(5589);
				((AnalyzeTableContext)_localctx).actionOption = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==NO_WRITE_TO_BINLOG || _la==LOCAL) ) {
					((AnalyzeTableContext)_localctx).actionOption = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(5592);
			_la = _input.LA(1);
			if ( !(_la==TABLE || _la==TABLES) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(5593);
			tables();
			setState(5611);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,814,_ctx) ) {
			case 1:
				{
				setState(5594);
				match(UPDATE);
				setState(5595);
				match(HISTOGRAM);
				setState(5596);
				match(ON);
				setState(5597);
				fullColumnName();
				setState(5602);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5598);
					match(COMMA);
					setState(5599);
					fullColumnName();
					}
					}
					setState(5604);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5609);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,813,_ctx) ) {
				case 1:
					{
					setState(5605);
					match(WITH);
					setState(5606);
					decimalLiteral();
					setState(5607);
					match(BUCKETS);
					}
					break;
				}
				}
				break;
			}
			setState(5624);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,816,_ctx) ) {
			case 1:
				{
				setState(5613);
				match(DROP);
				setState(5614);
				match(HISTOGRAM);
				setState(5615);
				match(ON);
				setState(5616);
				fullColumnName();
				setState(5621);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5617);
					match(COMMA);
					setState(5618);
					fullColumnName();
					}
					}
					setState(5623);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CheckTableContext extends ParserRuleContext {
		public TerminalNode CHECK() { return getToken(MySqlParser.CHECK, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public List checkTableOption() {
			return getRuleContexts(CheckTableOptionContext.class);
		}
		public CheckTableOptionContext checkTableOption(int i) {
			return getRuleContext(CheckTableOptionContext.class,i);
		}
		public CheckTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_checkTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCheckTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCheckTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCheckTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CheckTableContext checkTable() throws RecognitionException {
		CheckTableContext _localctx = new CheckTableContext(_ctx, getState());
		enterRule(_localctx, 472, RULE_checkTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5626);
			match(CHECK);
			setState(5627);
			match(TABLE);
			setState(5628);
			tables();
			setState(5632);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==FOR || _la==CHANGED || _la==EXTENDED || _la==FAST || _la==MEDIUM || _la==QUICK) {
				{
				{
				setState(5629);
				checkTableOption();
				}
				}
				setState(5634);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ChecksumTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode CHECKSUM() { return getToken(MySqlParser.CHECKSUM, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode QUICK() { return getToken(MySqlParser.QUICK, 0); }
		public TerminalNode EXTENDED() { return getToken(MySqlParser.EXTENDED, 0); }
		public ChecksumTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_checksumTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterChecksumTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitChecksumTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitChecksumTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ChecksumTableContext checksumTable() throws RecognitionException {
		ChecksumTableContext _localctx = new ChecksumTableContext(_ctx, getState());
		enterRule(_localctx, 474, RULE_checksumTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5635);
			match(CHECKSUM);
			setState(5636);
			match(TABLE);
			setState(5637);
			tables();
			setState(5639);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENDED || _la==QUICK) {
				{
				setState(5638);
				((ChecksumTableContext)_localctx).actionOption = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==EXTENDED || _la==QUICK) ) {
					((ChecksumTableContext)_localctx).actionOption = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class OptimizeTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode OPTIMIZE() { return getToken(MySqlParser.OPTIMIZE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MySqlParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public OptimizeTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_optimizeTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOptimizeTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOptimizeTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOptimizeTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OptimizeTableContext optimizeTable() throws RecognitionException {
		OptimizeTableContext _localctx = new OptimizeTableContext(_ctx, getState());
		enterRule(_localctx, 476, RULE_optimizeTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5641);
			match(OPTIMIZE);
			setState(5643);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(5642);
				((OptimizeTableContext)_localctx).actionOption = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==NO_WRITE_TO_BINLOG || _la==LOCAL) ) {
					((OptimizeTableContext)_localctx).actionOption = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(5645);
			_la = _input.LA(1);
			if ( !(_la==TABLE || _la==TABLES) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(5646);
			tables();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RepairTableContext extends ParserRuleContext {
		public Token actionOption;
		public TerminalNode REPAIR() { return getToken(MySqlParser.REPAIR, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public TerminalNode QUICK() { return getToken(MySqlParser.QUICK, 0); }
		public TerminalNode EXTENDED() { return getToken(MySqlParser.EXTENDED, 0); }
		public TerminalNode USE_FRM() { return getToken(MySqlParser.USE_FRM, 0); }
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MySqlParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public RepairTableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_repairTable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRepairTable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRepairTable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRepairTable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RepairTableContext repairTable() throws RecognitionException {
		RepairTableContext _localctx = new RepairTableContext(_ctx, getState());
		enterRule(_localctx, 478, RULE_repairTable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5648);
			match(REPAIR);
			setState(5650);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(5649);
				((RepairTableContext)_localctx).actionOption = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==NO_WRITE_TO_BINLOG || _la==LOCAL) ) {
					((RepairTableContext)_localctx).actionOption = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(5652);
			match(TABLE);
			setState(5653);
			tables();
			setState(5655);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==QUICK) {
				{
				setState(5654);
				match(QUICK);
				}
			}

			setState(5658);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENDED) {
				{
				setState(5657);
				match(EXTENDED);
				}
			}

			setState(5661);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==USE_FRM) {
				{
				setState(5660);
				match(USE_FRM);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CheckTableOptionContext extends ParserRuleContext {
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode UPGRADE() { return getToken(MySqlParser.UPGRADE, 0); }
		public TerminalNode QUICK() { return getToken(MySqlParser.QUICK, 0); }
		public TerminalNode FAST() { return getToken(MySqlParser.FAST, 0); }
		public TerminalNode MEDIUM() { return getToken(MySqlParser.MEDIUM, 0); }
		public TerminalNode EXTENDED() { return getToken(MySqlParser.EXTENDED, 0); }
		public TerminalNode CHANGED() { return getToken(MySqlParser.CHANGED, 0); }
		public CheckTableOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_checkTableOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCheckTableOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCheckTableOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCheckTableOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CheckTableOptionContext checkTableOption() throws RecognitionException {
		CheckTableOptionContext _localctx = new CheckTableOptionContext(_ctx, getState());
		enterRule(_localctx, 480, RULE_checkTableOption);
		try {
			setState(5670);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FOR:
				enterOuterAlt(_localctx, 1);
				{
				setState(5663);
				match(FOR);
				setState(5664);
				match(UPGRADE);
				}
				break;
			case QUICK:
				enterOuterAlt(_localctx, 2);
				{
				setState(5665);
				match(QUICK);
				}
				break;
			case FAST:
				enterOuterAlt(_localctx, 3);
				{
				setState(5666);
				match(FAST);
				}
				break;
			case MEDIUM:
				enterOuterAlt(_localctx, 4);
				{
				setState(5667);
				match(MEDIUM);
				}
				break;
			case EXTENDED:
				enterOuterAlt(_localctx, 5);
				{
				setState(5668);
				match(EXTENDED);
				}
				break;
			case CHANGED:
				enterOuterAlt(_localctx, 6);
				{
				setState(5669);
				match(CHANGED);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CreateUdfunctionContext extends ParserRuleContext {
		public Token returnType;
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode RETURNS() { return getToken(MySqlParser.RETURNS, 0); }
		public TerminalNode SONAME() { return getToken(MySqlParser.SONAME, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode STRING() { return getToken(MySqlParser.STRING, 0); }
		public TerminalNode INTEGER() { return getToken(MySqlParser.INTEGER, 0); }
		public TerminalNode REAL() { return getToken(MySqlParser.REAL, 0); }
		public TerminalNode DECIMAL() { return getToken(MySqlParser.DECIMAL, 0); }
		public TerminalNode AGGREGATE() { return getToken(MySqlParser.AGGREGATE, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public CreateUdfunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_createUdfunction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCreateUdfunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCreateUdfunction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCreateUdfunction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CreateUdfunctionContext createUdfunction() throws RecognitionException {
		CreateUdfunctionContext _localctx = new CreateUdfunctionContext(_ctx, getState());
		enterRule(_localctx, 482, RULE_createUdfunction);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5672);
			match(CREATE);
			setState(5674);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==AGGREGATE) {
				{
				setState(5673);
				match(AGGREGATE);
				}
			}

			setState(5676);
			match(FUNCTION);
			setState(5678);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,826,_ctx) ) {
			case 1:
				{
				setState(5677);
				ifNotExists();
				}
				break;
			}
			setState(5680);
			uid();
			setState(5681);
			match(RETURNS);
			setState(5682);
			((CreateUdfunctionContext)_localctx).returnType = _input.LT(1);
			_la = _input.LA(1);
			if ( !(((((_la - 206)) & ~0x3f) == 0 && ((1L << (_la - 206)) & 261L) != 0) || _la==STRING) ) {
				((CreateUdfunctionContext)_localctx).returnType = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(5683);
			match(SONAME);
			setState(5684);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class InstallPluginContext extends ParserRuleContext {
		public TerminalNode INSTALL() { return getToken(MySqlParser.INSTALL, 0); }
		public TerminalNode PLUGIN() { return getToken(MySqlParser.PLUGIN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode SONAME() { return getToken(MySqlParser.SONAME, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public InstallPluginContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_installPlugin; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterInstallPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitInstallPlugin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitInstallPlugin(this);
			else return visitor.visitChildren(this);
		}
	}

	public final InstallPluginContext installPlugin() throws RecognitionException {
		InstallPluginContext _localctx = new InstallPluginContext(_ctx, getState());
		enterRule(_localctx, 484, RULE_installPlugin);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5686);
			match(INSTALL);
			setState(5687);
			match(PLUGIN);
			setState(5688);
			uid();
			setState(5689);
			match(SONAME);
			setState(5690);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UninstallPluginContext extends ParserRuleContext {
		public TerminalNode UNINSTALL() { return getToken(MySqlParser.UNINSTALL, 0); }
		public TerminalNode PLUGIN() { return getToken(MySqlParser.PLUGIN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public UninstallPluginContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_uninstallPlugin; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUninstallPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUninstallPlugin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUninstallPlugin(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UninstallPluginContext uninstallPlugin() throws RecognitionException {
		UninstallPluginContext _localctx = new UninstallPluginContext(_ctx, getState());
		enterRule(_localctx, 486, RULE_uninstallPlugin);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5692);
			match(UNINSTALL);
			setState(5693);
			match(PLUGIN);
			setState(5694);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SetStatementContext extends ParserRuleContext {
		public SetStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_setStatement; }
	 
		public SetStatementContext() { }
		public void copyFrom(SetStatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetTransactionContext extends SetStatementContext {
		public SetTransactionStatementContext setTransactionStatement() {
			return getRuleContext(SetTransactionStatementContext.class,0);
		}
		public SetTransactionContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetTransaction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetTransaction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetTransaction(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetCharsetContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public SetCharsetContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetCharset(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetCharset(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetCharset(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetNamesContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode NAMES() { return getToken(MySqlParser.NAMES, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public SetNamesContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetNames(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetNames(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetNames(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetPasswordContext extends SetStatementContext {
		public SetPasswordStatementContext setPasswordStatement() {
			return getRuleContext(SetPasswordStatementContext.class,0);
		}
		public SetPasswordContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetPassword(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetPassword(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetPassword(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetAutocommitContext extends SetStatementContext {
		public SetAutocommitStatementContext setAutocommitStatement() {
			return getRuleContext(SetAutocommitStatementContext.class,0);
		}
		public SetAutocommitContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetAutocommit(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetAutocommit(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetAutocommit(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetNewValueInsideTriggerContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List fullId() {
			return getRuleContexts(FullIdContext.class);
		}
		public FullIdContext fullId(int i) {
			return getRuleContext(FullIdContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public List VAR_ASSIGN() { return getTokens(MySqlParser.VAR_ASSIGN); }
		public TerminalNode VAR_ASSIGN(int i) {
			return getToken(MySqlParser.VAR_ASSIGN, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public SetNewValueInsideTriggerContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetNewValueInsideTrigger(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetNewValueInsideTrigger(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetNewValueInsideTrigger(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SetVariableContext extends SetStatementContext {
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List variableClause() {
			return getRuleContexts(VariableClauseContext.class);
		}
		public VariableClauseContext variableClause(int i) {
			return getRuleContext(VariableClauseContext.class,i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public List VAR_ASSIGN() { return getTokens(MySqlParser.VAR_ASSIGN); }
		public TerminalNode VAR_ASSIGN(int i) {
			return getToken(MySqlParser.VAR_ASSIGN, i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List ON() { return getTokens(MySqlParser.ON); }
		public TerminalNode ON(int i) {
			return getToken(MySqlParser.ON, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public SetVariableContext(SetStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSetVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSetVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSetVariable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SetStatementContext setStatement() throws RecognitionException {
		SetStatementContext _localctx = new SetStatementContext(_ctx, getState());
		enterRule(_localctx, 488, RULE_setStatement);
		int _la;
		try {
			setState(5748);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,834,_ctx) ) {
			case 1:
				_localctx = new SetVariableContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5696);
				match(SET);
				setState(5697);
				variableClause();
				setState(5698);
				_la = _input.LA(1);
				if ( !(_la==VAR_ASSIGN || _la==EQUAL_SYMBOL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5701);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,827,_ctx) ) {
				case 1:
					{
					setState(5699);
					expression(0);
					}
					break;
				case 2:
					{
					setState(5700);
					match(ON);
					}
					break;
				}
				setState(5712);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5703);
					match(COMMA);
					setState(5704);
					variableClause();
					setState(5705);
					_la = _input.LA(1);
					if ( !(_la==VAR_ASSIGN || _la==EQUAL_SYMBOL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5708);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,828,_ctx) ) {
					case 1:
						{
						setState(5706);
						expression(0);
						}
						break;
					case 2:
						{
						setState(5707);
						match(ON);
						}
						break;
					}
					}
					}
					setState(5714);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new SetCharsetContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5715);
				match(SET);
				setState(5716);
				charSet();
				setState(5719);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case BINARY:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
					{
					setState(5717);
					charsetName();
					}
					break;
				case DEFAULT:
					{
					setState(5718);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 3:
				_localctx = new SetNamesContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5721);
				match(SET);
				setState(5722);
				match(NAMES);
				setState(5729);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case BINARY:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
					{
					setState(5723);
					charsetName();
					setState(5726);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==COLLATE) {
						{
						setState(5724);
						match(COLLATE);
						setState(5725);
						collationName();
						}
					}

					}
					break;
				case DEFAULT:
					{
					setState(5728);
					match(DEFAULT);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 4:
				_localctx = new SetPasswordContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5731);
				setPasswordStatement();
				}
				break;
			case 5:
				_localctx = new SetTransactionContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5732);
				setTransactionStatement();
				}
				break;
			case 6:
				_localctx = new SetAutocommitContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5733);
				setAutocommitStatement();
				}
				break;
			case 7:
				_localctx = new SetNewValueInsideTriggerContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(5734);
				match(SET);
				setState(5735);
				fullId();
				setState(5736);
				_la = _input.LA(1);
				if ( !(_la==VAR_ASSIGN || _la==EQUAL_SYMBOL) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5737);
				expression(0);
				setState(5745);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5738);
					match(COMMA);
					setState(5739);
					fullId();
					setState(5740);
					_la = _input.LA(1);
					if ( !(_la==VAR_ASSIGN || _la==EQUAL_SYMBOL) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5741);
					expression(0);
					}
					}
					setState(5747);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShowStatementContext extends ParserRuleContext {
		public ShowStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_showStatement; }
	 
		public ShowStatementContext() { }
		public void copyFrom(ShowStatementContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowOpenTablesContext extends ShowStatementContext {
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode OPEN() { return getToken(MySqlParser.OPEN, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public ShowOpenTablesContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowOpenTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowOpenTables(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowOpenTables(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowGlobalInfoContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public ShowGlobalInfoClauseContext showGlobalInfoClause() {
			return getRuleContext(ShowGlobalInfoClauseContext.class,0);
		}
		public ShowGlobalInfoContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowGlobalInfo(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowGlobalInfo(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowGlobalInfo(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowCreateFullIdObjectContext extends ShowStatementContext {
		public Token namedEntity;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode EVENT() { return getToken(MySqlParser.EVENT, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode TRIGGER() { return getToken(MySqlParser.TRIGGER, 0); }
		public TerminalNode VIEW() { return getToken(MySqlParser.VIEW, 0); }
		public ShowCreateFullIdObjectContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowCreateFullIdObject(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowCreateFullIdObject(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowCreateFullIdObject(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowCreateUserContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public ShowCreateUserContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowCreateUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowCreateUser(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowCreateUser(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowErrorsContext extends ShowStatementContext {
		public Token errorFormat;
		public DecimalLiteralContext offset;
		public DecimalLiteralContext rowCount;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode ERRORS() { return getToken(MySqlParser.ERRORS, 0); }
		public TerminalNode WARNINGS() { return getToken(MySqlParser.WARNINGS, 0); }
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public ShowErrorsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowErrors(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowErrors(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowErrors(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowCountErrorsContext extends ShowStatementContext {
		public Token errorFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode COUNT() { return getToken(MySqlParser.COUNT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode ERRORS() { return getToken(MySqlParser.ERRORS, 0); }
		public TerminalNode WARNINGS() { return getToken(MySqlParser.WARNINGS, 0); }
		public ShowCountErrorsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowCountErrors(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowCountErrors(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowCountErrors(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowObjectFilterContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public ShowCommonEntityContext showCommonEntity() {
			return getRuleContext(ShowCommonEntityContext.class,0);
		}
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public ShowObjectFilterContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowObjectFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowObjectFilter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowObjectFilter(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowCreateDbContext extends ShowStatementContext {
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode CREATE() { return getToken(MySqlParser.CREATE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public IfNotExistsContext ifNotExists() {
			return getRuleContext(IfNotExistsContext.class,0);
		}
		public ShowCreateDbContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowCreateDb(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowCreateDb(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowCreateDb(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowEngineContext extends ShowStatementContext {
		public Token engineOption;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public EngineNameContext engineName() {
			return getRuleContext(EngineNameContext.class,0);
		}
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode MUTEX() { return getToken(MySqlParser.MUTEX, 0); }
		public ShowEngineContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowEngine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowEngine(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowEngine(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowSchemaFilterContext extends ShowStatementContext {
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public ShowSchemaEntityContext showSchemaEntity() {
			return getRuleContext(ShowSchemaEntityContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public ShowSchemaFilterContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowSchemaFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowSchemaFilter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowSchemaFilter(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowIndexesContext extends ShowStatementContext {
		public Token indexFormat;
		public Token tableFormat;
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode INDEXES() { return getToken(MySqlParser.INDEXES, 0); }
		public TerminalNode KEYS() { return getToken(MySqlParser.KEYS, 0); }
		public List FROM() { return getTokens(MySqlParser.FROM); }
		public TerminalNode FROM(int i) {
			return getToken(MySqlParser.FROM, i);
		}
		public List IN() { return getTokens(MySqlParser.IN); }
		public TerminalNode IN(int i) {
			return getToken(MySqlParser.IN, i);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public ShowIndexesContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowIndexes(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowIndexes(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowIndexes(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowLogEventsContext extends ShowStatementContext {
		public Token logFormat;
		public Token filename;
		public DecimalLiteralContext fromPosition;
		public DecimalLiteralContext offset;
		public DecimalLiteralContext rowCount;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode EVENTS() { return getToken(MySqlParser.EVENTS, 0); }
		public TerminalNode BINLOG() { return getToken(MySqlParser.BINLOG, 0); }
		public TerminalNode RELAYLOG() { return getToken(MySqlParser.RELAYLOG, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public ShowLogEventsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowLogEvents(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowLogEvents(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowLogEvents(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowMasterLogsContext extends ShowStatementContext {
		public Token logFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode LOGS() { return getToken(MySqlParser.LOGS, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public ShowMasterLogsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowMasterLogs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowMasterLogs(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowMasterLogs(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowGrantsContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode GRANTS() { return getToken(MySqlParser.GRANTS, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public ShowGrantsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowGrants(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowGrants(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowGrants(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowSlaveStatusContext extends ShowStatementContext {
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode CHANNEL() { return getToken(MySqlParser.CHANNEL, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public ShowSlaveStatusContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowSlaveStatus(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowSlaveStatus(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowSlaveStatus(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowRoutineContext extends ShowStatementContext {
		public Token routine;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode CODE() { return getToken(MySqlParser.CODE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public ShowRoutineContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowRoutine(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowRoutine(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowRoutine(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowProfileContext extends ShowStatementContext {
		public DecimalLiteralContext queryCount;
		public DecimalLiteralContext offset;
		public DecimalLiteralContext rowCount;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TerminalNode PROFILE() { return getToken(MySqlParser.PROFILE, 0); }
		public List showProfileType() {
			return getRuleContexts(ShowProfileTypeContext.class);
		}
		public ShowProfileTypeContext showProfileType(int i) {
			return getRuleContext(ShowProfileTypeContext.class,i);
		}
		public TerminalNode LIMIT() { return getToken(MySqlParser.LIMIT, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode QUERY() { return getToken(MySqlParser.QUERY, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public ShowProfileContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowProfile(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowProfile(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowProfile(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ShowColumnsContext extends ShowStatementContext {
		public Token columnsFormat;
		public Token tableFormat;
		public Token schemaFormat;
		public TerminalNode SHOW() { return getToken(MySqlParser.SHOW, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public TerminalNode FIELDS() { return getToken(MySqlParser.FIELDS, 0); }
		public List FROM() { return getTokens(MySqlParser.FROM); }
		public TerminalNode FROM(int i) {
			return getToken(MySqlParser.FROM, i);
		}
		public List IN() { return getTokens(MySqlParser.IN); }
		public TerminalNode IN(int i) {
			return getToken(MySqlParser.IN, i);
		}
		public TerminalNode FULL() { return getToken(MySqlParser.FULL, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public ShowFilterContext showFilter() {
			return getRuleContext(ShowFilterContext.class,0);
		}
		public ShowColumnsContext(ShowStatementContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowColumns(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowColumns(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowColumns(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShowStatementContext showStatement() throws RecognitionException {
		ShowStatementContext _localctx = new ShowStatementContext(_ctx, getState());
		enterRule(_localctx, 490, RULE_showStatement);
		int _la;
		try {
			setState(5903);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,857,_ctx) ) {
			case 1:
				_localctx = new ShowMasterLogsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(5750);
				match(SHOW);
				setState(5751);
				((ShowMasterLogsContext)_localctx).logFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==BINARY || _la==MASTER) ) {
					((ShowMasterLogsContext)_localctx).logFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5752);
				match(LOGS);
				}
				break;
			case 2:
				_localctx = new ShowLogEventsContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(5753);
				match(SHOW);
				setState(5754);
				((ShowLogEventsContext)_localctx).logFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==BINLOG || _la==RELAYLOG) ) {
					((ShowLogEventsContext)_localctx).logFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5755);
				match(EVENTS);
				setState(5758);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==IN) {
					{
					setState(5756);
					match(IN);
					setState(5757);
					((ShowLogEventsContext)_localctx).filename = match(STRING_LITERAL);
					}
				}

				setState(5762);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM) {
					{
					setState(5760);
					match(FROM);
					setState(5761);
					((ShowLogEventsContext)_localctx).fromPosition = decimalLiteral();
					}
				}

				setState(5771);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(5764);
					match(LIMIT);
					setState(5768);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,837,_ctx) ) {
					case 1:
						{
						setState(5765);
						((ShowLogEventsContext)_localctx).offset = decimalLiteral();
						setState(5766);
						match(COMMA);
						}
						break;
					}
					setState(5770);
					((ShowLogEventsContext)_localctx).rowCount = decimalLiteral();
					}
				}

				}
				break;
			case 3:
				_localctx = new ShowObjectFilterContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(5773);
				match(SHOW);
				setState(5774);
				showCommonEntity();
				setState(5776);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5775);
					showFilter();
					}
				}

				}
				break;
			case 4:
				_localctx = new ShowColumnsContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(5778);
				match(SHOW);
				setState(5780);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FULL) {
					{
					setState(5779);
					match(FULL);
					}
				}

				setState(5782);
				((ShowColumnsContext)_localctx).columnsFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==COLUMNS || _la==FIELDS) ) {
					((ShowColumnsContext)_localctx).columnsFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5783);
				((ShowColumnsContext)_localctx).tableFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FROM || _la==IN) ) {
					((ShowColumnsContext)_localctx).tableFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5784);
				tableName();
				setState(5787);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(5785);
					((ShowColumnsContext)_localctx).schemaFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==FROM || _la==IN) ) {
						((ShowColumnsContext)_localctx).schemaFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5786);
					uid();
					}
				}

				setState(5790);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5789);
					showFilter();
					}
				}

				}
				break;
			case 5:
				_localctx = new ShowCreateDbContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(5792);
				match(SHOW);
				setState(5793);
				match(CREATE);
				setState(5794);
				((ShowCreateDbContext)_localctx).schemaFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DATABASE || _la==SCHEMA) ) {
					((ShowCreateDbContext)_localctx).schemaFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5796);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,843,_ctx) ) {
				case 1:
					{
					setState(5795);
					ifNotExists();
					}
					break;
				}
				setState(5798);
				uid();
				}
				break;
			case 6:
				_localctx = new ShowCreateFullIdObjectContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(5799);
				match(SHOW);
				setState(5800);
				match(CREATE);
				setState(5801);
				((ShowCreateFullIdObjectContext)_localctx).namedEntity = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 131)) & ~0x3f) == 0 && ((1L << (_la - 131)) & 72567767433217L) != 0) || _la==EVENT || _la==FUNCTION || _la==VIEW) ) {
					((ShowCreateFullIdObjectContext)_localctx).namedEntity = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5802);
				fullId();
				}
				break;
			case 7:
				_localctx = new ShowCreateUserContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(5803);
				match(SHOW);
				setState(5804);
				match(CREATE);
				setState(5805);
				match(USER);
				setState(5806);
				userName();
				}
				break;
			case 8:
				_localctx = new ShowEngineContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(5807);
				match(SHOW);
				setState(5808);
				match(ENGINE);
				setState(5809);
				engineName();
				setState(5810);
				((ShowEngineContext)_localctx).engineOption = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==MUTEX || _la==STATUS) ) {
					((ShowEngineContext)_localctx).engineOption = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 9:
				_localctx = new ShowGlobalInfoContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(5812);
				match(SHOW);
				setState(5813);
				showGlobalInfoClause();
				}
				break;
			case 10:
				_localctx = new ShowErrorsContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(5814);
				match(SHOW);
				setState(5815);
				((ShowErrorsContext)_localctx).errorFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ERRORS || _la==WARNINGS) ) {
					((ShowErrorsContext)_localctx).errorFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5823);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIMIT) {
					{
					setState(5816);
					match(LIMIT);
					setState(5820);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,844,_ctx) ) {
					case 1:
						{
						setState(5817);
						((ShowErrorsContext)_localctx).offset = decimalLiteral();
						setState(5818);
						match(COMMA);
						}
						break;
					}
					setState(5822);
					((ShowErrorsContext)_localctx).rowCount = decimalLiteral();
					}
				}

				}
				break;
			case 11:
				_localctx = new ShowCountErrorsContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(5825);
				match(SHOW);
				setState(5826);
				match(COUNT);
				setState(5827);
				match(LR_BRACKET);
				setState(5828);
				match(STAR);
				setState(5829);
				match(RR_BRACKET);
				setState(5830);
				((ShowCountErrorsContext)_localctx).errorFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ERRORS || _la==WARNINGS) ) {
					((ShowCountErrorsContext)_localctx).errorFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 12:
				_localctx = new ShowSchemaFilterContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(5831);
				match(SHOW);
				setState(5832);
				showSchemaEntity();
				setState(5835);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(5833);
					((ShowSchemaFilterContext)_localctx).schemaFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==FROM || _la==IN) ) {
						((ShowSchemaFilterContext)_localctx).schemaFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5834);
					uid();
					}
				}

				setState(5838);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5837);
					showFilter();
					}
				}

				}
				break;
			case 13:
				_localctx = new ShowRoutineContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(5840);
				match(SHOW);
				setState(5841);
				((ShowRoutineContext)_localctx).routine = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==PROCEDURE || _la==FUNCTION) ) {
					((ShowRoutineContext)_localctx).routine = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5842);
				match(CODE);
				setState(5843);
				fullId();
				}
				break;
			case 14:
				_localctx = new ShowGrantsContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(5844);
				match(SHOW);
				setState(5845);
				match(GRANTS);
				setState(5848);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(5846);
					match(FOR);
					setState(5847);
					userName();
					}
				}

				}
				break;
			case 15:
				_localctx = new ShowIndexesContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(5850);
				match(SHOW);
				setState(5851);
				((ShowIndexesContext)_localctx).indexFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==INDEX || _la==KEYS || _la==INDEXES) ) {
					((ShowIndexesContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5852);
				((ShowIndexesContext)_localctx).tableFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FROM || _la==IN) ) {
					((ShowIndexesContext)_localctx).tableFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(5853);
				tableName();
				setState(5856);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(5854);
					((ShowIndexesContext)_localctx).schemaFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==FROM || _la==IN) ) {
						((ShowIndexesContext)_localctx).schemaFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5855);
					uid();
					}
				}

				setState(5860);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==WHERE) {
					{
					setState(5858);
					match(WHERE);
					setState(5859);
					expression(0);
					}
				}

				}
				break;
			case 16:
				_localctx = new ShowOpenTablesContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(5862);
				match(SHOW);
				setState(5863);
				match(OPEN);
				setState(5864);
				match(TABLES);
				setState(5867);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FROM || _la==IN) {
					{
					setState(5865);
					((ShowOpenTablesContext)_localctx).schemaFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==FROM || _la==IN) ) {
						((ShowOpenTablesContext)_localctx).schemaFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(5866);
					uid();
					}
				}

				setState(5870);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LIKE || _la==WHERE) {
					{
					setState(5869);
					showFilter();
					}
				}

				}
				break;
			case 17:
				_localctx = new ShowProfileContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(5872);
				match(SHOW);
				setState(5873);
				match(PROFILE);
				setState(5874);
				showProfileType();
				setState(5879);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(5875);
					match(COMMA);
					setState(5876);
					showProfileType();
					}
					}
					setState(5881);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(5885);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(5882);
					match(FOR);
					setState(5883);
					match(QUERY);
					setState(5884);
					((ShowProfileContext)_localctx).queryCount = decimalLiteral();
					}
				}

				{
				setState(5887);
				match(LIMIT);
				setState(5891);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,855,_ctx) ) {
				case 1:
					{
					setState(5888);
					((ShowProfileContext)_localctx).offset = decimalLiteral();
					setState(5889);
					match(COMMA);
					}
					break;
				}
				setState(5893);
				((ShowProfileContext)_localctx).rowCount = decimalLiteral();
				}
				}
				break;
			case 18:
				_localctx = new ShowSlaveStatusContext(_localctx);
				enterOuterAlt(_localctx, 18);
				{
				setState(5895);
				match(SHOW);
				setState(5896);
				match(SLAVE);
				setState(5897);
				match(STATUS);
				setState(5901);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(5898);
					match(FOR);
					setState(5899);
					match(CHANNEL);
					setState(5900);
					match(STRING_LITERAL);
					}
				}

				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class VariableClauseContext extends ParserRuleContext {
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public TerminalNode GLOBAL_ID() { return getToken(MySqlParser.GLOBAL_ID, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode GLOBAL() { return getToken(MySqlParser.GLOBAL, 0); }
		public TerminalNode SESSION() { return getToken(MySqlParser.SESSION, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public List AT_SIGN() { return getTokens(MySqlParser.AT_SIGN); }
		public TerminalNode AT_SIGN(int i) {
			return getToken(MySqlParser.AT_SIGN, i);
		}
		public VariableClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_variableClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterVariableClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitVariableClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitVariableClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final VariableClauseContext variableClause() throws RecognitionException {
		VariableClauseContext _localctx = new VariableClauseContext(_ctx, getState());
		enterRule(_localctx, 492, RULE_variableClause);
		int _la;
		try {
			setState(5915);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LOCAL_ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(5905);
				match(LOCAL_ID);
				}
				break;
			case GLOBAL_ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(5906);
				match(GLOBAL_ID);
				}
				break;
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case AT_SIGN:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				enterOuterAlt(_localctx, 3);
				{
				setState(5912);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,859,_ctx) ) {
				case 1:
					{
					setState(5909);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==AT_SIGN) {
						{
						setState(5907);
						match(AT_SIGN);
						setState(5908);
						match(AT_SIGN);
						}
					}

					setState(5911);
					_la = _input.LA(1);
					if ( !(_la==GLOBAL || _la==LOCAL || _la==SESSION) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					break;
				}
				setState(5914);
				uid();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShowCommonEntityContext extends ParserRuleContext {
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode COLLATION() { return getToken(MySqlParser.COLLATION, 0); }
		public TerminalNode DATABASES() { return getToken(MySqlParser.DATABASES, 0); }
		public TerminalNode SCHEMAS() { return getToken(MySqlParser.SCHEMAS, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode PROCEDURE() { return getToken(MySqlParser.PROCEDURE, 0); }
		public TerminalNode VARIABLES() { return getToken(MySqlParser.VARIABLES, 0); }
		public TerminalNode GLOBAL() { return getToken(MySqlParser.GLOBAL, 0); }
		public TerminalNode SESSION() { return getToken(MySqlParser.SESSION, 0); }
		public ShowCommonEntityContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_showCommonEntity; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowCommonEntity(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowCommonEntity(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowCommonEntity(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShowCommonEntityContext showCommonEntity() throws RecognitionException {
		ShowCommonEntityContext _localctx = new ShowCommonEntityContext(_ctx, getState());
		enterRule(_localctx, 494, RULE_showCommonEntity);
		int _la;
		try {
			setState(5930);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CHARACTER:
				enterOuterAlt(_localctx, 1);
				{
				setState(5917);
				match(CHARACTER);
				setState(5918);
				match(SET);
				}
				break;
			case COLLATION:
				enterOuterAlt(_localctx, 2);
				{
				setState(5919);
				match(COLLATION);
				}
				break;
			case DATABASES:
				enterOuterAlt(_localctx, 3);
				{
				setState(5920);
				match(DATABASES);
				}
				break;
			case SCHEMAS:
				enterOuterAlt(_localctx, 4);
				{
				setState(5921);
				match(SCHEMAS);
				}
				break;
			case FUNCTION:
				enterOuterAlt(_localctx, 5);
				{
				setState(5922);
				match(FUNCTION);
				setState(5923);
				match(STATUS);
				}
				break;
			case PROCEDURE:
				enterOuterAlt(_localctx, 6);
				{
				setState(5924);
				match(PROCEDURE);
				setState(5925);
				match(STATUS);
				}
				break;
			case GLOBAL:
			case SESSION:
			case STATUS:
			case VARIABLES:
				enterOuterAlt(_localctx, 7);
				{
				setState(5927);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==GLOBAL || _la==SESSION) {
					{
					setState(5926);
					_la = _input.LA(1);
					if ( !(_la==GLOBAL || _la==SESSION) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(5929);
				_la = _input.LA(1);
				if ( !(_la==STATUS || _la==VARIABLES) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShowFilterContext extends ParserRuleContext {
		public TerminalNode LIKE() { return getToken(MySqlParser.LIKE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode WHERE() { return getToken(MySqlParser.WHERE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public ShowFilterContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_showFilter; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowFilter(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowFilter(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowFilter(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShowFilterContext showFilter() throws RecognitionException {
		ShowFilterContext _localctx = new ShowFilterContext(_ctx, getState());
		enterRule(_localctx, 496, RULE_showFilter);
		try {
			setState(5936);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LIKE:
				enterOuterAlt(_localctx, 1);
				{
				setState(5932);
				match(LIKE);
				setState(5933);
				match(STRING_LITERAL);
				}
				break;
			case WHERE:
				enterOuterAlt(_localctx, 2);
				{
				setState(5934);
				match(WHERE);
				setState(5935);
				expression(0);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShowGlobalInfoClauseContext extends ParserRuleContext {
		public TerminalNode ENGINES() { return getToken(MySqlParser.ENGINES, 0); }
		public TerminalNode STORAGE() { return getToken(MySqlParser.STORAGE, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode PLUGINS() { return getToken(MySqlParser.PLUGINS, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MySqlParser.PRIVILEGES, 0); }
		public TerminalNode PROCESSLIST() { return getToken(MySqlParser.PROCESSLIST, 0); }
		public TerminalNode FULL() { return getToken(MySqlParser.FULL, 0); }
		public TerminalNode PROFILES() { return getToken(MySqlParser.PROFILES, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public TerminalNode HOSTS() { return getToken(MySqlParser.HOSTS, 0); }
		public TerminalNode AUTHORS() { return getToken(MySqlParser.AUTHORS, 0); }
		public TerminalNode CONTRIBUTORS() { return getToken(MySqlParser.CONTRIBUTORS, 0); }
		public ShowGlobalInfoClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_showGlobalInfoClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowGlobalInfoClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowGlobalInfoClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowGlobalInfoClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShowGlobalInfoClauseContext showGlobalInfoClause() throws RecognitionException {
		ShowGlobalInfoClauseContext _localctx = new ShowGlobalInfoClauseContext(_ctx, getState());
		enterRule(_localctx, 498, RULE_showGlobalInfoClause);
		int _la;
		try {
			setState(5955);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ENGINES:
			case STORAGE:
				enterOuterAlt(_localctx, 1);
				{
				setState(5939);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==STORAGE) {
					{
					setState(5938);
					match(STORAGE);
					}
				}

				setState(5941);
				match(ENGINES);
				}
				break;
			case MASTER:
				enterOuterAlt(_localctx, 2);
				{
				setState(5942);
				match(MASTER);
				setState(5943);
				match(STATUS);
				}
				break;
			case PLUGINS:
				enterOuterAlt(_localctx, 3);
				{
				setState(5944);
				match(PLUGINS);
				}
				break;
			case PRIVILEGES:
				enterOuterAlt(_localctx, 4);
				{
				setState(5945);
				match(PRIVILEGES);
				}
				break;
			case FULL:
			case PROCESSLIST:
				enterOuterAlt(_localctx, 5);
				{
				setState(5947);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FULL) {
					{
					setState(5946);
					match(FULL);
					}
				}

				setState(5949);
				match(PROCESSLIST);
				}
				break;
			case PROFILES:
				enterOuterAlt(_localctx, 6);
				{
				setState(5950);
				match(PROFILES);
				}
				break;
			case SLAVE:
				enterOuterAlt(_localctx, 7);
				{
				setState(5951);
				match(SLAVE);
				setState(5952);
				match(HOSTS);
				}
				break;
			case AUTHORS:
				enterOuterAlt(_localctx, 8);
				{
				setState(5953);
				match(AUTHORS);
				}
				break;
			case CONTRIBUTORS:
				enterOuterAlt(_localctx, 9);
				{
				setState(5954);
				match(CONTRIBUTORS);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShowSchemaEntityContext extends ParserRuleContext {
		public TerminalNode EVENTS() { return getToken(MySqlParser.EVENTS, 0); }
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TerminalNode FULL() { return getToken(MySqlParser.FULL, 0); }
		public TerminalNode TRIGGERS() { return getToken(MySqlParser.TRIGGERS, 0); }
		public ShowSchemaEntityContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_showSchemaEntity; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowSchemaEntity(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowSchemaEntity(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowSchemaEntity(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShowSchemaEntityContext showSchemaEntity() throws RecognitionException {
		ShowSchemaEntityContext _localctx = new ShowSchemaEntityContext(_ctx, getState());
		enterRule(_localctx, 500, RULE_showSchemaEntity);
		int _la;
		try {
			setState(5965);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case EVENTS:
				enterOuterAlt(_localctx, 1);
				{
				setState(5957);
				match(EVENTS);
				}
				break;
			case TABLE:
				enterOuterAlt(_localctx, 2);
				{
				setState(5958);
				match(TABLE);
				setState(5959);
				match(STATUS);
				}
				break;
			case FULL:
			case TABLES:
				enterOuterAlt(_localctx, 3);
				{
				setState(5961);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FULL) {
					{
					setState(5960);
					match(FULL);
					}
				}

				setState(5963);
				match(TABLES);
				}
				break;
			case TRIGGERS:
				enterOuterAlt(_localctx, 4);
				{
				setState(5964);
				match(TRIGGERS);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShowProfileTypeContext extends ParserRuleContext {
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode BLOCK() { return getToken(MySqlParser.BLOCK, 0); }
		public TerminalNode IO() { return getToken(MySqlParser.IO, 0); }
		public TerminalNode CONTEXT() { return getToken(MySqlParser.CONTEXT, 0); }
		public TerminalNode SWITCHES() { return getToken(MySqlParser.SWITCHES, 0); }
		public TerminalNode CPU() { return getToken(MySqlParser.CPU, 0); }
		public TerminalNode IPC() { return getToken(MySqlParser.IPC, 0); }
		public TerminalNode MEMORY() { return getToken(MySqlParser.MEMORY, 0); }
		public TerminalNode PAGE() { return getToken(MySqlParser.PAGE, 0); }
		public TerminalNode FAULTS() { return getToken(MySqlParser.FAULTS, 0); }
		public TerminalNode SOURCE() { return getToken(MySqlParser.SOURCE, 0); }
		public TerminalNode SWAPS() { return getToken(MySqlParser.SWAPS, 0); }
		public ShowProfileTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_showProfileType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShowProfileType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShowProfileType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShowProfileType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShowProfileTypeContext showProfileType() throws RecognitionException {
		ShowProfileTypeContext _localctx = new ShowProfileTypeContext(_ctx, getState());
		enterRule(_localctx, 502, RULE_showProfileType);
		try {
			setState(5979);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ALL:
				enterOuterAlt(_localctx, 1);
				{
				setState(5967);
				match(ALL);
				}
				break;
			case BLOCK:
				enterOuterAlt(_localctx, 2);
				{
				setState(5968);
				match(BLOCK);
				setState(5969);
				match(IO);
				}
				break;
			case CONTEXT:
				enterOuterAlt(_localctx, 3);
				{
				setState(5970);
				match(CONTEXT);
				setState(5971);
				match(SWITCHES);
				}
				break;
			case CPU:
				enterOuterAlt(_localctx, 4);
				{
				setState(5972);
				match(CPU);
				}
				break;
			case IPC:
				enterOuterAlt(_localctx, 5);
				{
				setState(5973);
				match(IPC);
				}
				break;
			case MEMORY:
				enterOuterAlt(_localctx, 6);
				{
				setState(5974);
				match(MEMORY);
				}
				break;
			case PAGE:
				enterOuterAlt(_localctx, 7);
				{
				setState(5975);
				match(PAGE);
				setState(5976);
				match(FAULTS);
				}
				break;
			case SOURCE:
				enterOuterAlt(_localctx, 8);
				{
				setState(5977);
				match(SOURCE);
				}
				break;
			case SWAPS:
				enterOuterAlt(_localctx, 9);
				{
				setState(5978);
				match(SWAPS);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class BinlogStatementContext extends ParserRuleContext {
		public TerminalNode BINLOG() { return getToken(MySqlParser.BINLOG, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public BinlogStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_binlogStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBinlogStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBinlogStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBinlogStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BinlogStatementContext binlogStatement() throws RecognitionException {
		BinlogStatementContext _localctx = new BinlogStatementContext(_ctx, getState());
		enterRule(_localctx, 504, RULE_binlogStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5981);
			match(BINLOG);
			setState(5982);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CacheIndexStatementContext extends ParserRuleContext {
		public UidContext schema;
		public TerminalNode CACHE() { return getToken(MySqlParser.CACHE, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public List tableIndexes() {
			return getRuleContexts(TableIndexesContext.class);
		}
		public TableIndexesContext tableIndexes(int i) {
			return getRuleContext(TableIndexesContext.class,i);
		}
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public CacheIndexStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_cacheIndexStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCacheIndexStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCacheIndexStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCacheIndexStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CacheIndexStatementContext cacheIndexStatement() throws RecognitionException {
		CacheIndexStatementContext _localctx = new CacheIndexStatementContext(_ctx, getState());
		enterRule(_localctx, 506, RULE_cacheIndexStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(5984);
			match(CACHE);
			setState(5985);
			match(INDEX);
			setState(5986);
			tableIndexes();
			setState(5991);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(5987);
				match(COMMA);
				setState(5988);
				tableIndexes();
				}
				}
				setState(5993);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(6001);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(5994);
				match(PARTITION);
				setState(5995);
				match(LR_BRACKET);
				setState(5998);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(5996);
					uidList();
					}
					break;
				case ALL:
					{
					setState(5997);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6000);
				match(RR_BRACKET);
				}
			}

			setState(6003);
			match(IN);
			setState(6004);
			((CacheIndexStatementContext)_localctx).schema = uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FlushStatementContext extends ParserRuleContext {
		public Token flushFormat;
		public TerminalNode FLUSH() { return getToken(MySqlParser.FLUSH, 0); }
		public List flushOption() {
			return getRuleContexts(FlushOptionContext.class);
		}
		public FlushOptionContext flushOption(int i) {
			return getRuleContext(FlushOptionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode NO_WRITE_TO_BINLOG() { return getToken(MySqlParser.NO_WRITE_TO_BINLOG, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public FlushStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_flushStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFlushStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFlushStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFlushStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FlushStatementContext flushStatement() throws RecognitionException {
		FlushStatementContext _localctx = new FlushStatementContext(_ctx, getState());
		enterRule(_localctx, 508, RULE_flushStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6006);
			match(FLUSH);
			setState(6008);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NO_WRITE_TO_BINLOG || _la==LOCAL) {
				{
				setState(6007);
				((FlushStatementContext)_localctx).flushFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==NO_WRITE_TO_BINLOG || _la==LOCAL) ) {
					((FlushStatementContext)_localctx).flushFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(6010);
			flushOption();
			setState(6015);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6011);
				match(COMMA);
				setState(6012);
				flushOption();
				}
				}
				setState(6017);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class KillStatementContext extends ParserRuleContext {
		public Token connectionFormat;
		public TerminalNode KILL() { return getToken(MySqlParser.KILL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode CONNECTION() { return getToken(MySqlParser.CONNECTION, 0); }
		public TerminalNode QUERY() { return getToken(MySqlParser.QUERY, 0); }
		public KillStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_killStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterKillStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitKillStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitKillStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final KillStatementContext killStatement() throws RecognitionException {
		KillStatementContext _localctx = new KillStatementContext(_ctx, getState());
		enterRule(_localctx, 510, RULE_killStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6018);
			match(KILL);
			setState(6020);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,875,_ctx) ) {
			case 1:
				{
				setState(6019);
				((KillStatementContext)_localctx).connectionFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CONNECTION || _la==QUERY) ) {
					((KillStatementContext)_localctx).connectionFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
			setState(6022);
			expression(0);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LoadIndexIntoCacheContext extends ParserRuleContext {
		public TerminalNode LOAD() { return getToken(MySqlParser.LOAD, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode INTO() { return getToken(MySqlParser.INTO, 0); }
		public TerminalNode CACHE() { return getToken(MySqlParser.CACHE, 0); }
		public List loadedTableIndexes() {
			return getRuleContexts(LoadedTableIndexesContext.class);
		}
		public LoadedTableIndexesContext loadedTableIndexes(int i) {
			return getRuleContext(LoadedTableIndexesContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public LoadIndexIntoCacheContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_loadIndexIntoCache; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLoadIndexIntoCache(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLoadIndexIntoCache(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLoadIndexIntoCache(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LoadIndexIntoCacheContext loadIndexIntoCache() throws RecognitionException {
		LoadIndexIntoCacheContext _localctx = new LoadIndexIntoCacheContext(_ctx, getState());
		enterRule(_localctx, 512, RULE_loadIndexIntoCache);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6024);
			match(LOAD);
			setState(6025);
			match(INDEX);
			setState(6026);
			match(INTO);
			setState(6027);
			match(CACHE);
			setState(6028);
			loadedTableIndexes();
			setState(6033);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6029);
				match(COMMA);
				setState(6030);
				loadedTableIndexes();
				}
				}
				setState(6035);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ResetStatementContext extends ParserRuleContext {
		public TerminalNode RESET() { return getToken(MySqlParser.RESET, 0); }
		public TerminalNode QUERY() { return getToken(MySqlParser.QUERY, 0); }
		public TerminalNode CACHE() { return getToken(MySqlParser.CACHE, 0); }
		public ResetStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_resetStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterResetStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitResetStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitResetStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ResetStatementContext resetStatement() throws RecognitionException {
		ResetStatementContext _localctx = new ResetStatementContext(_ctx, getState());
		enterRule(_localctx, 514, RULE_resetStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6036);
			match(RESET);
			setState(6037);
			match(QUERY);
			setState(6038);
			match(CACHE);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ShutdownStatementContext extends ParserRuleContext {
		public TerminalNode SHUTDOWN() { return getToken(MySqlParser.SHUTDOWN, 0); }
		public ShutdownStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_shutdownStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterShutdownStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitShutdownStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitShutdownStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ShutdownStatementContext shutdownStatement() throws RecognitionException {
		ShutdownStatementContext _localctx = new ShutdownStatementContext(_ctx, getState());
		enterRule(_localctx, 516, RULE_shutdownStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6040);
			match(SHUTDOWN);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableIndexesContext extends ParserRuleContext {
		public Token indexFormat;
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public UidListContext uidList() {
			return getRuleContext(UidListContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public TableIndexesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableIndexes; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableIndexes(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableIndexes(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableIndexes(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableIndexesContext tableIndexes() throws RecognitionException {
		TableIndexesContext _localctx = new TableIndexesContext(_ctx, getState());
		enterRule(_localctx, 518, RULE_tableIndexes);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6042);
			tableName();
			setState(6050);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==INDEX || _la==KEY || _la==LR_BRACKET) {
				{
				setState(6044);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(6043);
					((TableIndexesContext)_localctx).indexFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==INDEX || _la==KEY) ) {
						((TableIndexesContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(6046);
				match(LR_BRACKET);
				setState(6047);
				uidList();
				setState(6048);
				match(RR_BRACKET);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FlushOptionContext extends ParserRuleContext {
		public FlushOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_flushOption; }
	 
		public FlushOptionContext() { }
		public void copyFrom(FlushOptionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TableFlushOptionContext extends FlushOptionContext {
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TablesContext tables() {
			return getRuleContext(TablesContext.class,0);
		}
		public FlushTableOptionContext flushTableOption() {
			return getRuleContext(FlushTableOptionContext.class,0);
		}
		public TableFlushOptionContext(FlushOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableFlushOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableFlushOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableFlushOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ChannelFlushOptionContext extends FlushOptionContext {
		public TerminalNode RELAY() { return getToken(MySqlParser.RELAY, 0); }
		public TerminalNode LOGS() { return getToken(MySqlParser.LOGS, 0); }
		public ChannelOptionContext channelOption() {
			return getRuleContext(ChannelOptionContext.class,0);
		}
		public ChannelFlushOptionContext(FlushOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterChannelFlushOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitChannelFlushOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitChannelFlushOption(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SimpleFlushOptionContext extends FlushOptionContext {
		public TerminalNode DES_KEY_FILE() { return getToken(MySqlParser.DES_KEY_FILE, 0); }
		public TerminalNode HOSTS() { return getToken(MySqlParser.HOSTS, 0); }
		public TerminalNode LOGS() { return getToken(MySqlParser.LOGS, 0); }
		public TerminalNode OPTIMIZER_COSTS() { return getToken(MySqlParser.OPTIMIZER_COSTS, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MySqlParser.PRIVILEGES, 0); }
		public TerminalNode QUERY() { return getToken(MySqlParser.QUERY, 0); }
		public TerminalNode CACHE() { return getToken(MySqlParser.CACHE, 0); }
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode USER_RESOURCES() { return getToken(MySqlParser.USER_RESOURCES, 0); }
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public TerminalNode ERROR() { return getToken(MySqlParser.ERROR, 0); }
		public TerminalNode GENERAL() { return getToken(MySqlParser.GENERAL, 0); }
		public TerminalNode RELAY() { return getToken(MySqlParser.RELAY, 0); }
		public TerminalNode SLOW() { return getToken(MySqlParser.SLOW, 0); }
		public SimpleFlushOptionContext(FlushOptionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleFlushOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleFlushOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleFlushOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FlushOptionContext flushOption() throws RecognitionException {
		FlushOptionContext _localctx = new FlushOptionContext(_ctx, getState());
		enterRule(_localctx, 520, RULE_flushOption);
		int _la;
		try {
			setState(6084);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,885,_ctx) ) {
			case 1:
				_localctx = new SimpleFlushOptionContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6070);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case DES_KEY_FILE:
					{
					setState(6052);
					match(DES_KEY_FILE);
					}
					break;
				case HOSTS:
					{
					setState(6053);
					match(HOSTS);
					}
					break;
				case BINARY:
				case ENGINE:
				case ERROR:
				case GENERAL:
				case LOGS:
				case RELAY:
				case SLOW:
					{
					setState(6055);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==BINARY || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & 536870917L) != 0) || _la==RELAY || _la==SLOW) {
						{
						setState(6054);
						_la = _input.LA(1);
						if ( !(_la==BINARY || ((((_la - 409)) & ~0x3f) == 0 && ((1L << (_la - 409)) & 536870917L) != 0) || _la==RELAY || _la==SLOW) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
					}

					setState(6057);
					match(LOGS);
					}
					break;
				case OPTIMIZER_COSTS:
					{
					setState(6058);
					match(OPTIMIZER_COSTS);
					}
					break;
				case PRIVILEGES:
					{
					setState(6059);
					match(PRIVILEGES);
					}
					break;
				case QUERY:
					{
					setState(6060);
					match(QUERY);
					setState(6061);
					match(CACHE);
					}
					break;
				case STATUS:
					{
					setState(6062);
					match(STATUS);
					}
					break;
				case USER_RESOURCES:
					{
					setState(6063);
					match(USER_RESOURCES);
					}
					break;
				case TABLES:
					{
					setState(6064);
					match(TABLES);
					setState(6068);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,880,_ctx) ) {
					case 1:
						{
						setState(6065);
						match(WITH);
						setState(6066);
						match(READ);
						setState(6067);
						match(LOCK);
						}
						break;
					}
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case 2:
				_localctx = new ChannelFlushOptionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6072);
				match(RELAY);
				setState(6073);
				match(LOGS);
				setState(6075);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(6074);
					channelOption();
					}
				}

				}
				break;
			case 3:
				_localctx = new TableFlushOptionContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6077);
				_la = _input.LA(1);
				if ( !(_la==TABLE || _la==TABLES) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6079);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,883,_ctx) ) {
				case 1:
					{
					setState(6078);
					tables();
					}
					break;
				}
				setState(6082);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,884,_ctx) ) {
				case 1:
					{
					setState(6081);
					flushTableOption();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FlushTableOptionContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public TerminalNode READ() { return getToken(MySqlParser.READ, 0); }
		public TerminalNode LOCK() { return getToken(MySqlParser.LOCK, 0); }
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode EXPORT() { return getToken(MySqlParser.EXPORT, 0); }
		public FlushTableOptionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_flushTableOption; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFlushTableOption(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFlushTableOption(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFlushTableOption(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FlushTableOptionContext flushTableOption() throws RecognitionException {
		FlushTableOptionContext _localctx = new FlushTableOptionContext(_ctx, getState());
		enterRule(_localctx, 522, RULE_flushTableOption);
		try {
			setState(6091);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case WITH:
				enterOuterAlt(_localctx, 1);
				{
				setState(6086);
				match(WITH);
				setState(6087);
				match(READ);
				setState(6088);
				match(LOCK);
				}
				break;
			case FOR:
				enterOuterAlt(_localctx, 2);
				{
				setState(6089);
				match(FOR);
				setState(6090);
				match(EXPORT);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LoadedTableIndexesContext extends ParserRuleContext {
		public UidListContext partitionList;
		public Token indexFormat;
		public UidListContext indexList;
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public TerminalNode IGNORE() { return getToken(MySqlParser.IGNORE, 0); }
		public TerminalNode LEAVES() { return getToken(MySqlParser.LEAVES, 0); }
		public List uidList() {
			return getRuleContexts(UidListContext.class);
		}
		public UidListContext uidList(int i) {
			return getRuleContext(UidListContext.class,i);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode INDEX() { return getToken(MySqlParser.INDEX, 0); }
		public TerminalNode KEY() { return getToken(MySqlParser.KEY, 0); }
		public LoadedTableIndexesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_loadedTableIndexes; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLoadedTableIndexes(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLoadedTableIndexes(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLoadedTableIndexes(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LoadedTableIndexesContext loadedTableIndexes() throws RecognitionException {
		LoadedTableIndexesContext _localctx = new LoadedTableIndexesContext(_ctx, getState());
		enterRule(_localctx, 524, RULE_loadedTableIndexes);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6093);
			tableName();
			setState(6101);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(6094);
				match(PARTITION);
				setState(6095);
				match(LR_BRACKET);
				setState(6098);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
					{
					setState(6096);
					((LoadedTableIndexesContext)_localctx).partitionList = uidList();
					}
					break;
				case ALL:
					{
					setState(6097);
					match(ALL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6100);
				match(RR_BRACKET);
				}
			}

			setState(6110);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,890,_ctx) ) {
			case 1:
				{
				setState(6104);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INDEX || _la==KEY) {
					{
					setState(6103);
					((LoadedTableIndexesContext)_localctx).indexFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==INDEX || _la==KEY) ) {
						((LoadedTableIndexesContext)_localctx).indexFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				setState(6106);
				match(LR_BRACKET);
				setState(6107);
				((LoadedTableIndexesContext)_localctx).indexList = uidList();
				setState(6108);
				match(RR_BRACKET);
				}
				break;
			}
			setState(6114);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==IGNORE) {
				{
				setState(6112);
				match(IGNORE);
				setState(6113);
				match(LEAVES);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SimpleDescribeStatementContext extends ParserRuleContext {
		public Token command;
		public UidContext column;
		public Token pattern;
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public TerminalNode EXPLAIN() { return getToken(MySqlParser.EXPLAIN, 0); }
		public TerminalNode DESCRIBE() { return getToken(MySqlParser.DESCRIBE, 0); }
		public TerminalNode DESC() { return getToken(MySqlParser.DESC, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public SimpleDescribeStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_simpleDescribeStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleDescribeStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleDescribeStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleDescribeStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SimpleDescribeStatementContext simpleDescribeStatement() throws RecognitionException {
		SimpleDescribeStatementContext _localctx = new SimpleDescribeStatementContext(_ctx, getState());
		enterRule(_localctx, 526, RULE_simpleDescribeStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6116);
			((SimpleDescribeStatementContext)_localctx).command = _input.LT(1);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & 4611791571543654400L) != 0)) ) {
				((SimpleDescribeStatementContext)_localctx).command = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(6117);
			tableName();
			setState(6120);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,892,_ctx) ) {
			case 1:
				{
				setState(6118);
				((SimpleDescribeStatementContext)_localctx).column = uid();
				}
				break;
			case 2:
				{
				setState(6119);
				((SimpleDescribeStatementContext)_localctx).pattern = match(STRING_LITERAL);
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FullDescribeStatementContext extends ParserRuleContext {
		public Token command;
		public Token formatType;
		public Token formatValue;
		public DescribeObjectClauseContext describeObjectClause() {
			return getRuleContext(DescribeObjectClauseContext.class,0);
		}
		public TerminalNode EXPLAIN() { return getToken(MySqlParser.EXPLAIN, 0); }
		public TerminalNode DESCRIBE() { return getToken(MySqlParser.DESCRIBE, 0); }
		public TerminalNode DESC() { return getToken(MySqlParser.DESC, 0); }
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode EXTENDED() { return getToken(MySqlParser.EXTENDED, 0); }
		public TerminalNode PARTITIONS() { return getToken(MySqlParser.PARTITIONS, 0); }
		public TerminalNode FORMAT() { return getToken(MySqlParser.FORMAT, 0); }
		public TerminalNode TRADITIONAL() { return getToken(MySqlParser.TRADITIONAL, 0); }
		public TerminalNode JSON() { return getToken(MySqlParser.JSON, 0); }
		public FullDescribeStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_fullDescribeStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFullDescribeStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFullDescribeStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFullDescribeStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FullDescribeStatementContext fullDescribeStatement() throws RecognitionException {
		FullDescribeStatementContext _localctx = new FullDescribeStatementContext(_ctx, getState());
		enterRule(_localctx, 528, RULE_fullDescribeStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6122);
			((FullDescribeStatementContext)_localctx).command = _input.LT(1);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & 4611791571543654400L) != 0)) ) {
				((FullDescribeStatementContext)_localctx).command = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(6126);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==EXTENDED || _la==PARTITIONS || _la==FORMAT) {
				{
				setState(6123);
				((FullDescribeStatementContext)_localctx).formatType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==EXTENDED || _la==PARTITIONS || _la==FORMAT) ) {
					((FullDescribeStatementContext)_localctx).formatType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6124);
				match(EQUAL_SYMBOL);
				setState(6125);
				((FullDescribeStatementContext)_localctx).formatValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==JSON || _la==TRADITIONAL) ) {
					((FullDescribeStatementContext)_localctx).formatValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(6128);
			describeObjectClause();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HelpStatementContext extends ParserRuleContext {
		public TerminalNode HELP() { return getToken(MySqlParser.HELP, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public HelpStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_helpStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHelpStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHelpStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHelpStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HelpStatementContext helpStatement() throws RecognitionException {
		HelpStatementContext _localctx = new HelpStatementContext(_ctx, getState());
		enterRule(_localctx, 530, RULE_helpStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6130);
			match(HELP);
			setState(6131);
			match(STRING_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UseStatementContext extends ParserRuleContext {
		public TerminalNode USE() { return getToken(MySqlParser.USE, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public UseStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_useStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUseStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUseStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUseStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UseStatementContext useStatement() throws RecognitionException {
		UseStatementContext _localctx = new UseStatementContext(_ctx, getState());
		enterRule(_localctx, 532, RULE_useStatement);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6133);
			match(USE);
			setState(6134);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SignalStatementContext extends ParserRuleContext {
		public TerminalNode SIGNAL() { return getToken(MySqlParser.SIGNAL, 0); }
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public TerminalNode REVERSE_QUOTE_ID() { return getToken(MySqlParser.REVERSE_QUOTE_ID, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List signalConditionInformation() {
			return getRuleContexts(SignalConditionInformationContext.class);
		}
		public SignalConditionInformationContext signalConditionInformation(int i) {
			return getRuleContext(SignalConditionInformationContext.class,i);
		}
		public TerminalNode SQLSTATE() { return getToken(MySqlParser.SQLSTATE, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public SignalStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_signalStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSignalStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSignalStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSignalStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SignalStatementContext signalStatement() throws RecognitionException {
		SignalStatementContext _localctx = new SignalStatementContext(_ctx, getState());
		enterRule(_localctx, 534, RULE_signalStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6136);
			match(SIGNAL);
			setState(6144);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SQLSTATE:
				{
				{
				setState(6137);
				match(SQLSTATE);
				setState(6139);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(6138);
					match(VALUE);
					}
				}

				setState(6141);
				stringLiteral();
				}
				}
				break;
			case ID:
				{
				setState(6142);
				match(ID);
				}
				break;
			case REVERSE_QUOTE_ID:
				{
				setState(6143);
				match(REVERSE_QUOTE_ID);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(6155);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,897,_ctx) ) {
			case 1:
				{
				setState(6146);
				match(SET);
				setState(6147);
				signalConditionInformation();
				setState(6152);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6148);
					match(COMMA);
					setState(6149);
					signalConditionInformation();
					}
					}
					setState(6154);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ResignalStatementContext extends ParserRuleContext {
		public TerminalNode RESIGNAL() { return getToken(MySqlParser.RESIGNAL, 0); }
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public TerminalNode REVERSE_QUOTE_ID() { return getToken(MySqlParser.REVERSE_QUOTE_ID, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public List signalConditionInformation() {
			return getRuleContexts(SignalConditionInformationContext.class);
		}
		public SignalConditionInformationContext signalConditionInformation(int i) {
			return getRuleContext(SignalConditionInformationContext.class,i);
		}
		public TerminalNode SQLSTATE() { return getToken(MySqlParser.SQLSTATE, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public ResignalStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_resignalStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterResignalStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitResignalStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitResignalStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ResignalStatementContext resignalStatement() throws RecognitionException {
		ResignalStatementContext _localctx = new ResignalStatementContext(_ctx, getState());
		enterRule(_localctx, 536, RULE_resignalStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6157);
			match(RESIGNAL);
			setState(6165);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case SQLSTATE:
				{
				{
				setState(6158);
				match(SQLSTATE);
				setState(6160);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VALUE) {
					{
					setState(6159);
					match(VALUE);
					}
				}

				setState(6162);
				stringLiteral();
				}
				}
				break;
			case ID:
				{
				setState(6163);
				match(ID);
				}
				break;
			case REVERSE_QUOTE_ID:
				{
				setState(6164);
				match(REVERSE_QUOTE_ID);
				}
				break;
			case EOF:
			case ALTER:
			case ANALYZE:
			case CALL:
			case CHANGE:
			case CHECK:
			case CREATE:
			case DELETE:
			case DESC:
			case DESCRIBE:
			case DROP:
			case EXPLAIN:
			case GET:
			case GRANT:
			case INSERT:
			case KILL:
			case LOAD:
			case LOCK:
			case OPTIMIZE:
			case PURGE:
			case RELEASE:
			case RENAME:
			case REPLACE:
			case RESIGNAL:
			case REVOKE:
			case SELECT:
			case SET:
			case SHOW:
			case SIGNAL:
			case TABLE:
			case UNLOCK:
			case UPDATE:
			case USE:
			case VALUES:
			case WITH:
			case BEGIN:
			case BINLOG:
			case CACHE:
			case CHECKSUM:
			case COMMIT:
			case DEALLOCATE:
			case DO:
			case FLUSH:
			case HANDLER:
			case HELP:
			case INSTALL:
			case PREPARE:
			case REPAIR:
			case RESET:
			case ROLLBACK:
			case SAVEPOINT:
			case START:
			case STOP:
			case TRUNCATE:
			case UNINSTALL:
			case XA:
			case EXECUTE:
			case SHUTDOWN:
			case MINUS:
			case LR_BRACKET:
			case SEMI:
				break;
			default:
				break;
			}
			setState(6176);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,901,_ctx) ) {
			case 1:
				{
				setState(6167);
				match(SET);
				setState(6168);
				signalConditionInformation();
				setState(6173);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6169);
					match(COMMA);
					setState(6170);
					signalConditionInformation();
					}
					}
					setState(6175);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SignalConditionInformationContext extends ParserRuleContext {
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode CLASS_ORIGIN() { return getToken(MySqlParser.CLASS_ORIGIN, 0); }
		public TerminalNode SUBCLASS_ORIGIN() { return getToken(MySqlParser.SUBCLASS_ORIGIN, 0); }
		public TerminalNode MESSAGE_TEXT() { return getToken(MySqlParser.MESSAGE_TEXT, 0); }
		public TerminalNode MYSQL_ERRNO() { return getToken(MySqlParser.MYSQL_ERRNO, 0); }
		public TerminalNode CONSTRAINT_CATALOG() { return getToken(MySqlParser.CONSTRAINT_CATALOG, 0); }
		public TerminalNode CONSTRAINT_SCHEMA() { return getToken(MySqlParser.CONSTRAINT_SCHEMA, 0); }
		public TerminalNode CONSTRAINT_NAME() { return getToken(MySqlParser.CONSTRAINT_NAME, 0); }
		public TerminalNode CATALOG_NAME() { return getToken(MySqlParser.CATALOG_NAME, 0); }
		public TerminalNode SCHEMA_NAME() { return getToken(MySqlParser.SCHEMA_NAME, 0); }
		public TerminalNode TABLE_NAME() { return getToken(MySqlParser.TABLE_NAME, 0); }
		public TerminalNode COLUMN_NAME() { return getToken(MySqlParser.COLUMN_NAME, 0); }
		public TerminalNode CURSOR_NAME() { return getToken(MySqlParser.CURSOR_NAME, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode DECIMAL_LITERAL() { return getToken(MySqlParser.DECIMAL_LITERAL, 0); }
		public MysqlVariableContext mysqlVariable() {
			return getRuleContext(MysqlVariableContext.class,0);
		}
		public SimpleIdContext simpleId() {
			return getRuleContext(SimpleIdContext.class,0);
		}
		public SignalConditionInformationContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_signalConditionInformation; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSignalConditionInformation(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSignalConditionInformation(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSignalConditionInformation(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SignalConditionInformationContext signalConditionInformation() throws RecognitionException {
		SignalConditionInformationContext _localctx = new SignalConditionInformationContext(_ctx, getState());
		enterRule(_localctx, 538, RULE_signalConditionInformation);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6178);
			_la = _input.LA(1);
			if ( !(((((_la - 359)) & ~0x3f) == 0 && ((1L << (_la - 359)) & 272105729L) != 0) || _la==MESSAGE_TEXT || _la==MYSQL_ERRNO || _la==SUBCLASS_ORIGIN || _la==TABLE_NAME || _la==CATALOG_NAME || _la==SCHEMA_NAME) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(6179);
			match(EQUAL_SYMBOL);
			setState(6184);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case START_NATIONAL_STRING_LITERAL:
			case STRING_LITERAL:
			case STRING_CHARSET_NAME:
				{
				setState(6180);
				stringLiteral();
				}
				break;
			case DECIMAL_LITERAL:
				{
				setState(6181);
				match(DECIMAL_LITERAL);
				}
				break;
			case LOCAL_ID:
			case GLOBAL_ID:
				{
				setState(6182);
				mysqlVariable();
				}
				break;
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case ID:
				{
				setState(6183);
				simpleId();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WithStatementContext extends ParserRuleContext {
		public TerminalNode WITH() { return getToken(MySqlParser.WITH, 0); }
		public List commonTableExpressions() {
			return getRuleContexts(CommonTableExpressionsContext.class);
		}
		public CommonTableExpressionsContext commonTableExpressions(int i) {
			return getRuleContext(CommonTableExpressionsContext.class,i);
		}
		public TerminalNode RECURSIVE() { return getToken(MySqlParser.RECURSIVE, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public WithStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_withStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWithStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWithStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWithStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WithStatementContext withStatement() throws RecognitionException {
		WithStatementContext _localctx = new WithStatementContext(_ctx, getState());
		enterRule(_localctx, 540, RULE_withStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6186);
			match(WITH);
			setState(6188);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,903,_ctx) ) {
			case 1:
				{
				setState(6187);
				match(RECURSIVE);
				}
				break;
			}
			setState(6190);
			commonTableExpressions();
			setState(6195);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6191);
				match(COMMA);
				setState(6192);
				commonTableExpressions();
				}
				}
				setState(6197);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableStatementContext extends ParserRuleContext {
		public TerminalNode TABLE() { return getToken(MySqlParser.TABLE, 0); }
		public TableNameContext tableName() {
			return getRuleContext(TableNameContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public LimitClauseContext limitClause() {
			return getRuleContext(LimitClauseContext.class,0);
		}
		public TableStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableStatementContext tableStatement() throws RecognitionException {
		TableStatementContext _localctx = new TableStatementContext(_ctx, getState());
		enterRule(_localctx, 542, RULE_tableStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6198);
			match(TABLE);
			setState(6199);
			tableName();
			setState(6201);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ORDER) {
				{
				setState(6200);
				orderByClause();
				}
			}

			setState(6204);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==LIMIT) {
				{
				setState(6203);
				limitClause();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DiagnosticsStatementContext extends ParserRuleContext {
		public TerminalNode GET() { return getToken(MySqlParser.GET, 0); }
		public TerminalNode DIAGNOSTICS() { return getToken(MySqlParser.DIAGNOSTICS, 0); }
		public TerminalNode CURRENT() { return getToken(MySqlParser.CURRENT, 0); }
		public TerminalNode STACKED() { return getToken(MySqlParser.STACKED, 0); }
		public List variableClause() {
			return getRuleContexts(VariableClauseContext.class);
		}
		public VariableClauseContext variableClause(int i) {
			return getRuleContext(VariableClauseContext.class,i);
		}
		public List EQUAL_SYMBOL() { return getTokens(MySqlParser.EQUAL_SYMBOL); }
		public TerminalNode EQUAL_SYMBOL(int i) {
			return getToken(MySqlParser.EQUAL_SYMBOL, i);
		}
		public TerminalNode CONDITION() { return getToken(MySqlParser.CONDITION, 0); }
		public List diagnosticsConditionInformationName() {
			return getRuleContexts(DiagnosticsConditionInformationNameContext.class);
		}
		public DiagnosticsConditionInformationNameContext diagnosticsConditionInformationName(int i) {
			return getRuleContext(DiagnosticsConditionInformationNameContext.class,i);
		}
		public List NUMBER() { return getTokens(MySqlParser.NUMBER); }
		public TerminalNode NUMBER(int i) {
			return getToken(MySqlParser.NUMBER, i);
		}
		public List ROW_COUNT() { return getTokens(MySqlParser.ROW_COUNT); }
		public TerminalNode ROW_COUNT(int i) {
			return getToken(MySqlParser.ROW_COUNT, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public DiagnosticsStatementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_diagnosticsStatement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDiagnosticsStatement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDiagnosticsStatement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDiagnosticsStatement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DiagnosticsStatementContext diagnosticsStatement() throws RecognitionException {
		DiagnosticsStatementContext _localctx = new DiagnosticsStatementContext(_ctx, getState());
		enterRule(_localctx, 544, RULE_diagnosticsStatement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6206);
			match(GET);
			setState(6208);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==CURRENT || _la==STACKED) {
				{
				setState(6207);
				_la = _input.LA(1);
				if ( !(_la==CURRENT || _la==STACKED) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			setState(6210);
			match(DIAGNOSTICS);
			setState(6242);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,911,_ctx) ) {
			case 1:
				{
				{
				setState(6211);
				variableClause();
				setState(6212);
				match(EQUAL_SYMBOL);
				setState(6213);
				_la = _input.LA(1);
				if ( !(_la==NUMBER || _la==ROW_COUNT) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6221);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6214);
					match(COMMA);
					setState(6215);
					variableClause();
					setState(6216);
					match(EQUAL_SYMBOL);
					setState(6217);
					_la = _input.LA(1);
					if ( !(_la==NUMBER || _la==ROW_COUNT) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					}
					setState(6223);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				}
				break;
			case 2:
				{
				{
				setState(6224);
				match(CONDITION);
				setState(6227);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case ZERO_DECIMAL:
				case ONE_DECIMAL:
				case TWO_DECIMAL:
				case DECIMAL_LITERAL:
				case REAL_LITERAL:
					{
					setState(6225);
					decimalLiteral();
					}
					break;
				case ARRAY:
				case ATTRIBUTE:
				case BUCKETS:
				case CONDITION:
				case CURRENT:
				case CURRENT_USER:
				case DATABASE:
				case DEFAULT:
				case DIAGNOSTICS:
				case EMPTY:
				case ENFORCED:
				case EXCEPT:
				case GROUP:
				case IF:
				case IGNORED:
				case INSERT:
				case LATERAL:
				case LEFT:
				case NUMBER:
				case OPTIONAL:
				case ORDER:
				case PRIMARY:
				case REPEAT:
				case REPLACE:
				case RIGHT:
				case SCHEMA:
				case SKIP_QUERY_REWRITE:
				case STACKED:
				case DATE:
				case TIME:
				case TIMESTAMP:
				case DATETIME:
				case YEAR:
				case BINARY:
				case TEXT:
				case ENUM:
				case SERIAL:
				case JSON_ARRAY:
				case JSON_ARRAYAGG:
				case JSON_ARRAY_APPEND:
				case JSON_ARRAY_INSERT:
				case JSON_CONTAINS:
				case JSON_CONTAINS_PATH:
				case JSON_DEPTH:
				case JSON_EXTRACT:
				case JSON_INSERT:
				case JSON_KEYS:
				case JSON_LENGTH:
				case JSON_MERGE:
				case JSON_MERGE_PATCH:
				case JSON_MERGE_PRESERVE:
				case JSON_OBJECT:
				case JSON_OBJECTAGG:
				case JSON_OVERLAPS:
				case JSON_PRETTY:
				case JSON_QUOTE:
				case JSON_REMOVE:
				case JSON_REPLACE:
				case JSON_SCHEMA_VALID:
				case JSON_SCHEMA_VALIDATION_REPORT:
				case JSON_SEARCH:
				case JSON_SET:
				case JSON_STORAGE_FREE:
				case JSON_STORAGE_SIZE:
				case JSON_TABLE:
				case JSON_TYPE:
				case JSON_UNQUOTE:
				case JSON_VALID:
				case JSON_VALUE:
				case NESTED:
				case ORDINALITY:
				case PATH:
				case AVG:
				case BIT_AND:
				case BIT_OR:
				case BIT_XOR:
				case COUNT:
				case CUME_DIST:
				case DENSE_RANK:
				case FIRST_VALUE:
				case GROUP_CONCAT:
				case LAG:
				case LAST_VALUE:
				case LEAD:
				case MAX:
				case MIN:
				case NTILE:
				case NTH_VALUE:
				case PERCENT_RANK:
				case RANK:
				case ROW_NUMBER:
				case STD:
				case STDDEV:
				case STDDEV_POP:
				case STDDEV_SAMP:
				case SUM:
				case VAR_POP:
				case VAR_SAMP:
				case VARIANCE:
				case CURRENT_DATE:
				case CURRENT_TIME:
				case CURRENT_TIMESTAMP:
				case LOCALTIME:
				case CURDATE:
				case CURTIME:
				case DATE_ADD:
				case DATE_SUB:
				case LOCALTIMESTAMP:
				case NOW:
				case POSITION:
				case SUBSTR:
				case SUBSTRING:
				case SYSDATE:
				case TRIM:
				case UTC_DATE:
				case UTC_TIME:
				case UTC_TIMESTAMP:
				case ACCOUNT:
				case ACTION:
				case AFTER:
				case AGGREGATE:
				case ALGORITHM:
				case ANY:
				case AT:
				case AUTHORS:
				case AUTOCOMMIT:
				case AUTOEXTEND_SIZE:
				case AUTO_INCREMENT:
				case AVG_ROW_LENGTH:
				case BEGIN:
				case BINLOG:
				case BIT:
				case BLOCK:
				case BOOL:
				case BOOLEAN:
				case BTREE:
				case CACHE:
				case CASCADED:
				case CHAIN:
				case CHANGED:
				case CHANNEL:
				case CHECKSUM:
				case PAGE_CHECKSUM:
				case CIPHER:
				case CLASS_ORIGIN:
				case CLIENT:
				case CLOSE:
				case CLUSTERING:
				case COALESCE:
				case CODE:
				case COLUMNS:
				case COLUMN_FORMAT:
				case COLUMN_NAME:
				case COMMENT:
				case COMMIT:
				case COMPACT:
				case COMPLETION:
				case COMPRESSED:
				case COMPRESSION:
				case CONCURRENT:
				case CONNECT:
				case CONNECTION:
				case CONSISTENT:
				case CONSTRAINT_CATALOG:
				case CONSTRAINT_SCHEMA:
				case CONSTRAINT_NAME:
				case CONTAINS:
				case CONTEXT:
				case CONTRIBUTORS:
				case COPY:
				case CPU:
				case CURSOR_NAME:
				case DATA:
				case DATAFILE:
				case DEALLOCATE:
				case DEFAULT_AUTH:
				case DEFINER:
				case DELAY_KEY_WRITE:
				case DES_KEY_FILE:
				case DIRECTORY:
				case DISABLE:
				case DISCARD:
				case DISK:
				case DO:
				case DUMPFILE:
				case DUPLICATE:
				case DYNAMIC:
				case ENABLE:
				case ENCRYPTION:
				case END:
				case ENDS:
				case ENGINE:
				case ENGINES:
				case ERROR:
				case ERRORS:
				case ESCAPE:
				case EVEN:
				case EVENT:
				case EVENTS:
				case EVERY:
				case EXCHANGE:
				case EXCLUSIVE:
				case EXPIRE:
				case EXPORT:
				case EXTENDED:
				case EXTENT_SIZE:
				case FAILED_LOGIN_ATTEMPTS:
				case FAST:
				case FAULTS:
				case FIELDS:
				case FILE_BLOCK_SIZE:
				case FILTER:
				case FIRST:
				case FIXED:
				case FLUSH:
				case FOLLOWS:
				case FOUND:
				case FULL:
				case FUNCTION:
				case GENERAL:
				case GLOBAL:
				case GRANTS:
				case GROUP_REPLICATION:
				case HANDLER:
				case HASH:
				case HELP:
				case HISTORY:
				case HOST:
				case HOSTS:
				case IDENTIFIED:
				case IGNORE_SERVER_IDS:
				case IMPORT:
				case INDEXES:
				case INITIAL_SIZE:
				case INPLACE:
				case INSERT_METHOD:
				case INSTALL:
				case INSTANCE:
				case INSTANT:
				case INVISIBLE:
				case INVOKER:
				case IO:
				case IO_THREAD:
				case IPC:
				case ISOLATION:
				case ISSUER:
				case JSON:
				case KEY_BLOCK_SIZE:
				case LANGUAGE:
				case LAST:
				case LEAVES:
				case LESS:
				case LEVEL:
				case LIST:
				case LOCAL:
				case LOGFILE:
				case LOGS:
				case MASTER:
				case MASTER_AUTO_POSITION:
				case MASTER_CONNECT_RETRY:
				case MASTER_DELAY:
				case MASTER_HEARTBEAT_PERIOD:
				case MASTER_HOST:
				case MASTER_LOG_FILE:
				case MASTER_LOG_POS:
				case MASTER_PASSWORD:
				case MASTER_PORT:
				case MASTER_RETRY_COUNT:
				case MASTER_SSL:
				case MASTER_SSL_CA:
				case MASTER_SSL_CAPATH:
				case MASTER_SSL_CERT:
				case MASTER_SSL_CIPHER:
				case MASTER_SSL_CRL:
				case MASTER_SSL_CRLPATH:
				case MASTER_SSL_KEY:
				case MASTER_TLS_VERSION:
				case MASTER_USER:
				case MAX_CONNECTIONS_PER_HOUR:
				case MAX_QUERIES_PER_HOUR:
				case MAX_ROWS:
				case MAX_SIZE:
				case MAX_UPDATES_PER_HOUR:
				case MAX_USER_CONNECTIONS:
				case MEDIUM:
				case MEMBER:
				case MERGE:
				case MESSAGE_TEXT:
				case MID:
				case MIGRATE:
				case MIN_ROWS:
				case MODE:
				case MODIFY:
				case MUTEX:
				case MYSQL:
				case MYSQL_ERRNO:
				case NAME:
				case NAMES:
				case NCHAR:
				case NEVER:
				case NEXT:
				case NO:
				case NOCOPY:
				case NOWAIT:
				case NODEGROUP:
				case NONE:
				case ODBC:
				case OFFLINE:
				case OFFSET:
				case OF:
				case OJ:
				case OLD_PASSWORD:
				case ONE:
				case ONLINE:
				case ONLY:
				case OPEN:
				case OPTIMIZER_COSTS:
				case OPTIONS:
				case OWNER:
				case PACK_KEYS:
				case PAGE:
				case PARSER:
				case PARTIAL:
				case PARTITIONING:
				case PARTITIONS:
				case PASSWORD:
				case PASSWORD_LOCK_TIME:
				case PHASE:
				case PLUGIN:
				case PLUGIN_DIR:
				case PLUGINS:
				case PORT:
				case PRECEDES:
				case PREPARE:
				case PRESERVE:
				case PREV:
				case PROCESSLIST:
				case PROFILE:
				case PROFILES:
				case PROXY:
				case QUERY:
				case QUICK:
				case REBUILD:
				case RECOVER:
				case RECURSIVE:
				case REDO_BUFFER_SIZE:
				case REDUNDANT:
				case RELAY:
				case RELAY_LOG_FILE:
				case RELAY_LOG_POS:
				case RELAYLOG:
				case REMOVE:
				case REORGANIZE:
				case REPAIR:
				case REPLICATE_DO_DB:
				case REPLICATE_DO_TABLE:
				case REPLICATE_IGNORE_DB:
				case REPLICATE_IGNORE_TABLE:
				case REPLICATE_REWRITE_DB:
				case REPLICATE_WILD_DO_TABLE:
				case REPLICATE_WILD_IGNORE_TABLE:
				case REPLICATION:
				case RESET:
				case RESUME:
				case RETURNED_SQLSTATE:
				case RETURNS:
				case REUSE:
				case ROLE:
				case ROLLBACK:
				case ROLLUP:
				case ROTATE:
				case ROW:
				case ROWS:
				case ROW_FORMAT:
				case RTREE:
				case SAVEPOINT:
				case SCHEDULE:
				case SECURITY:
				case SERVER:
				case SESSION:
				case SHARE:
				case SHARED:
				case SIGNED:
				case SIMPLE:
				case SLAVE:
				case SLOW:
				case SNAPSHOT:
				case SOCKET:
				case SOME:
				case SONAME:
				case SOUNDS:
				case SOURCE:
				case SQL_AFTER_GTIDS:
				case SQL_AFTER_MTS_GAPS:
				case SQL_BEFORE_GTIDS:
				case SQL_BUFFER_RESULT:
				case SQL_CACHE:
				case SQL_NO_CACHE:
				case SQL_THREAD:
				case START:
				case STARTS:
				case STATS_AUTO_RECALC:
				case STATS_PERSISTENT:
				case STATS_SAMPLE_PAGES:
				case STATUS:
				case STOP:
				case STORAGE:
				case STRING:
				case SUBCLASS_ORIGIN:
				case SUBJECT:
				case SUBPARTITION:
				case SUBPARTITIONS:
				case SUSPEND:
				case SWAPS:
				case SWITCHES:
				case TABLE_NAME:
				case TABLESPACE:
				case TABLE_TYPE:
				case TEMPORARY:
				case TEMPTABLE:
				case THAN:
				case TRADITIONAL:
				case TRANSACTION:
				case TRANSACTIONAL:
				case TRIGGERS:
				case TRUNCATE:
				case UNBOUNDED:
				case UNDEFINED:
				case UNDOFILE:
				case UNDO_BUFFER_SIZE:
				case UNINSTALL:
				case UNKNOWN:
				case UNTIL:
				case UPGRADE:
				case USER:
				case USE_FRM:
				case USER_RESOURCES:
				case VALIDATION:
				case VALUE:
				case VARIABLES:
				case VIEW:
				case VIRTUAL:
				case VISIBLE:
				case WAIT:
				case WARNINGS:
				case WITHOUT:
				case WORK:
				case WRAPPER:
				case X509:
				case XA:
				case XML:
				case EUR:
				case USA:
				case JIS:
				case ISO:
				case INTERNAL:
				case QUARTER:
				case MONTH:
				case DAY:
				case HOUR:
				case MINUTE:
				case WEEK:
				case SECOND:
				case MICROSECOND:
				case ADMIN:
				case AUDIT_ABORT_EXEMPT:
				case AUDIT_ADMIN:
				case AUTHENTICATION_POLICY_ADMIN:
				case BACKUP_ADMIN:
				case BINLOG_ADMIN:
				case BINLOG_ENCRYPTION_ADMIN:
				case CLONE_ADMIN:
				case CONNECTION_ADMIN:
				case ENCRYPTION_KEY_ADMIN:
				case EXECUTE:
				case FILE:
				case FIREWALL_ADMIN:
				case FIREWALL_EXEMPT:
				case FIREWALL_USER:
				case GROUP_REPLICATION_ADMIN:
				case INNODB_REDO_LOG_ARCHIVE:
				case INVOKE:
				case LAMBDA:
				case NDB_STORED_USER:
				case PASSWORDLESS_USER_ADMIN:
				case PERSIST_RO_VARIABLES_ADMIN:
				case PRIVILEGES:
				case PROCESS:
				case RELOAD:
				case REPLICATION_APPLIER:
				case REPLICATION_SLAVE_ADMIN:
				case RESOURCE_GROUP_ADMIN:
				case RESOURCE_GROUP_USER:
				case ROLE_ADMIN:
				case ROUTINE:
				case S3:
				case SESSION_VARIABLES_ADMIN:
				case SET_USER_ID:
				case SHOW_ROUTINE:
				case SHUTDOWN:
				case SUPER:
				case SYSTEM_VARIABLES_ADMIN:
				case TABLES:
				case TABLE_ENCRYPTION_ADMIN:
				case VERSION_TOKEN_ADMIN:
				case XA_RECOVER_ADMIN:
				case ARMSCII8:
				case ASCII:
				case BIG5:
				case CP1250:
				case CP1251:
				case CP1256:
				case CP1257:
				case CP850:
				case CP852:
				case CP866:
				case CP932:
				case DEC8:
				case EUCJPMS:
				case EUCKR:
				case GB18030:
				case GB2312:
				case GBK:
				case GEOSTD8:
				case GREEK:
				case HEBREW:
				case HP8:
				case KEYBCS2:
				case KOI8R:
				case KOI8U:
				case LATIN1:
				case LATIN2:
				case LATIN5:
				case LATIN7:
				case MACCE:
				case MACROMAN:
				case SJIS:
				case SWE7:
				case TIS620:
				case UCS2:
				case UJIS:
				case UTF16:
				case UTF16LE:
				case UTF32:
				case UTF8:
				case UTF8MB3:
				case UTF8MB4:
				case ARCHIVE:
				case BLACKHOLE:
				case CSV:
				case FEDERATED:
				case INNODB:
				case MEMORY:
				case MRG_MYISAM:
				case MYISAM:
				case NDB:
				case NDBCLUSTER:
				case PERFORMANCE_SCHEMA:
				case TOKUDB:
				case REPEATABLE:
				case COMMITTED:
				case UNCOMMITTED:
				case SERIALIZABLE:
				case GEOMETRYCOLLECTION:
				case LINESTRING:
				case MULTILINESTRING:
				case MULTIPOINT:
				case MULTIPOLYGON:
				case POINT:
				case POLYGON:
				case ABS:
				case ACOS:
				case ADDDATE:
				case ADDTIME:
				case AES_DECRYPT:
				case AES_ENCRYPT:
				case AREA:
				case ASBINARY:
				case ASIN:
				case ASTEXT:
				case ASWKB:
				case ASWKT:
				case ASYMMETRIC_DECRYPT:
				case ASYMMETRIC_DERIVE:
				case ASYMMETRIC_ENCRYPT:
				case ASYMMETRIC_SIGN:
				case ASYMMETRIC_VERIFY:
				case ATAN:
				case ATAN2:
				case BENCHMARK:
				case BIN:
				case BIT_COUNT:
				case BIT_LENGTH:
				case BUFFER:
				case CATALOG_NAME:
				case CEIL:
				case CEILING:
				case CENTROID:
				case CHARACTER_LENGTH:
				case CHARSET:
				case CHAR_LENGTH:
				case COERCIBILITY:
				case COLLATION:
				case COMPRESS:
				case CONCAT:
				case CONCAT_WS:
				case CONNECTION_ID:
				case CONV:
				case CONVERT_TZ:
				case COS:
				case COT:
				case CRC32:
				case CREATE_ASYMMETRIC_PRIV_KEY:
				case CREATE_ASYMMETRIC_PUB_KEY:
				case CREATE_DH_PARAMETERS:
				case CREATE_DIGEST:
				case CROSSES:
				case DATEDIFF:
				case DATE_FORMAT:
				case DAYNAME:
				case DAYOFMONTH:
				case DAYOFWEEK:
				case DAYOFYEAR:
				case DECODE:
				case DEGREES:
				case DES_DECRYPT:
				case DES_ENCRYPT:
				case DIMENSION:
				case DISJOINT:
				case ELT:
				case ENCODE:
				case ENCRYPT:
				case ENDPOINT:
				case ENGINE_ATTRIBUTE:
				case ENVELOPE:
				case EQUALS:
				case EXP:
				case EXPORT_SET:
				case EXTERIORRING:
				case EXTRACTVALUE:
				case FIELD:
				case FIND_IN_SET:
				case FLOOR:
				case FORMAT:
				case FOUND_ROWS:
				case FROM_BASE64:
				case FROM_DAYS:
				case FROM_UNIXTIME:
				case GEOMCOLLFROMTEXT:
				case GEOMCOLLFROMWKB:
				case GEOMETRYCOLLECTIONFROMTEXT:
				case GEOMETRYCOLLECTIONFROMWKB:
				case GEOMETRYFROMTEXT:
				case GEOMETRYFROMWKB:
				case GEOMETRYN:
				case GEOMETRYTYPE:
				case GEOMFROMTEXT:
				case GEOMFROMWKB:
				case GET_FORMAT:
				case GET_LOCK:
				case GLENGTH:
				case GREATEST:
				case GTID_SUBSET:
				case GTID_SUBTRACT:
				case HEX:
				case IFNULL:
				case INET6_ATON:
				case INET6_NTOA:
				case INET_ATON:
				case INET_NTOA:
				case INSTR:
				case INTERIORRINGN:
				case INTERSECTS:
				case ISCLOSED:
				case ISEMPTY:
				case ISNULL:
				case ISSIMPLE:
				case IS_FREE_LOCK:
				case IS_IPV4:
				case IS_IPV4_COMPAT:
				case IS_IPV4_MAPPED:
				case IS_IPV6:
				case IS_USED_LOCK:
				case LAST_INSERT_ID:
				case LCASE:
				case LEAST:
				case LENGTH:
				case LINEFROMTEXT:
				case LINEFROMWKB:
				case LINESTRINGFROMTEXT:
				case LINESTRINGFROMWKB:
				case LN:
				case LOAD_FILE:
				case LOCATE:
				case LOG:
				case LOG10:
				case LOG2:
				case LOWER:
				case LPAD:
				case LTRIM:
				case MAKEDATE:
				case MAKETIME:
				case MAKE_SET:
				case MASTER_POS_WAIT:
				case MBRCONTAINS:
				case MBRDISJOINT:
				case MBREQUAL:
				case MBRINTERSECTS:
				case MBROVERLAPS:
				case MBRTOUCHES:
				case MBRWITHIN:
				case MD5:
				case MLINEFROMTEXT:
				case MLINEFROMWKB:
				case MONTHNAME:
				case MPOINTFROMTEXT:
				case MPOINTFROMWKB:
				case MPOLYFROMTEXT:
				case MPOLYFROMWKB:
				case MULTILINESTRINGFROMTEXT:
				case MULTILINESTRINGFROMWKB:
				case MULTIPOINTFROMTEXT:
				case MULTIPOINTFROMWKB:
				case MULTIPOLYGONFROMTEXT:
				case MULTIPOLYGONFROMWKB:
				case NAME_CONST:
				case NULLIF:
				case NUMGEOMETRIES:
				case NUMINTERIORRINGS:
				case NUMPOINTS:
				case OCT:
				case OCTET_LENGTH:
				case ORD:
				case OVERLAPS:
				case PERIOD_ADD:
				case PERIOD_DIFF:
				case PI:
				case POINTFROMTEXT:
				case POINTFROMWKB:
				case POINTN:
				case POLYFROMTEXT:
				case POLYFROMWKB:
				case POLYGONFROMTEXT:
				case POLYGONFROMWKB:
				case POW:
				case POWER:
				case QUOTE:
				case RADIANS:
				case RAND:
				case RANDOM:
				case RANDOM_BYTES:
				case RELEASE_LOCK:
				case REVERSE:
				case ROUND:
				case ROW_COUNT:
				case RPAD:
				case RTRIM:
				case SEC_TO_TIME:
				case SECONDARY_ENGINE_ATTRIBUTE:
				case SESSION_USER:
				case SHA:
				case SHA1:
				case SHA2:
				case SCHEMA_NAME:
				case SIGN:
				case SIN:
				case SLEEP:
				case SOUNDEX:
				case SQL_THREAD_WAIT_AFTER_GTIDS:
				case SQRT:
				case SRID:
				case STARTPOINT:
				case STRCMP:
				case STR_TO_DATE:
				case ST_AREA:
				case ST_ASBINARY:
				case ST_ASTEXT:
				case ST_ASWKB:
				case ST_ASWKT:
				case ST_BUFFER:
				case ST_CENTROID:
				case ST_CONTAINS:
				case ST_CROSSES:
				case ST_DIFFERENCE:
				case ST_DIMENSION:
				case ST_DISJOINT:
				case ST_DISTANCE:
				case ST_ENDPOINT:
				case ST_ENVELOPE:
				case ST_EQUALS:
				case ST_EXTERIORRING:
				case ST_GEOMCOLLFROMTEXT:
				case ST_GEOMCOLLFROMTXT:
				case ST_GEOMCOLLFROMWKB:
				case ST_GEOMETRYCOLLECTIONFROMTEXT:
				case ST_GEOMETRYCOLLECTIONFROMWKB:
				case ST_GEOMETRYFROMTEXT:
				case ST_GEOMETRYFROMWKB:
				case ST_GEOMETRYN:
				case ST_GEOMETRYTYPE:
				case ST_GEOMFROMTEXT:
				case ST_GEOMFROMWKB:
				case ST_INTERIORRINGN:
				case ST_INTERSECTION:
				case ST_INTERSECTS:
				case ST_ISCLOSED:
				case ST_ISEMPTY:
				case ST_ISSIMPLE:
				case ST_LINEFROMTEXT:
				case ST_LINEFROMWKB:
				case ST_LINESTRINGFROMTEXT:
				case ST_LINESTRINGFROMWKB:
				case ST_NUMGEOMETRIES:
				case ST_NUMINTERIORRING:
				case ST_NUMINTERIORRINGS:
				case ST_NUMPOINTS:
				case ST_OVERLAPS:
				case ST_POINTFROMTEXT:
				case ST_POINTFROMWKB:
				case ST_POINTN:
				case ST_POLYFROMTEXT:
				case ST_POLYFROMWKB:
				case ST_POLYGONFROMTEXT:
				case ST_POLYGONFROMWKB:
				case ST_SRID:
				case ST_STARTPOINT:
				case ST_SYMDIFFERENCE:
				case ST_TOUCHES:
				case ST_UNION:
				case ST_WITHIN:
				case ST_X:
				case ST_Y:
				case SUBDATE:
				case SUBSTRING_INDEX:
				case SUBTIME:
				case SYSTEM_USER:
				case TAN:
				case TIMEDIFF:
				case TIMESTAMPADD:
				case TIMESTAMPDIFF:
				case TIME_FORMAT:
				case TIME_TO_SEC:
				case TOUCHES:
				case TO_BASE64:
				case TO_DAYS:
				case TO_SECONDS:
				case TP_CONNECTION_ADMIN:
				case UCASE:
				case UNCOMPRESS:
				case UNCOMPRESSED_LENGTH:
				case UNHEX:
				case UNIX_TIMESTAMP:
				case UPDATEXML:
				case UPPER:
				case UUID:
				case UUID_SHORT:
				case VALIDATE_PASSWORD_STRENGTH:
				case VERSION:
				case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
				case WEEKDAY:
				case WEEKOFYEAR:
				case WEIGHT_STRING:
				case WITHIN:
				case YEARWEEK:
				case Y_FUNCTION:
				case X_FUNCTION:
				case MOD:
				case AT_SIGN:
				case CHARSET_REVERSE_QOUTE_STRING:
				case STRING_LITERAL:
				case ID:
				case LOCAL_ID:
				case GLOBAL_ID:
					{
					setState(6226);
					variableClause();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6229);
				variableClause();
				setState(6230);
				match(EQUAL_SYMBOL);
				setState(6231);
				diagnosticsConditionInformationName();
				setState(6239);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6232);
					match(COMMA);
					setState(6233);
					variableClause();
					setState(6234);
					match(EQUAL_SYMBOL);
					setState(6235);
					diagnosticsConditionInformationName();
					}
					}
					setState(6241);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DiagnosticsConditionInformationNameContext extends ParserRuleContext {
		public TerminalNode CLASS_ORIGIN() { return getToken(MySqlParser.CLASS_ORIGIN, 0); }
		public TerminalNode SUBCLASS_ORIGIN() { return getToken(MySqlParser.SUBCLASS_ORIGIN, 0); }
		public TerminalNode RETURNED_SQLSTATE() { return getToken(MySqlParser.RETURNED_SQLSTATE, 0); }
		public TerminalNode MESSAGE_TEXT() { return getToken(MySqlParser.MESSAGE_TEXT, 0); }
		public TerminalNode MYSQL_ERRNO() { return getToken(MySqlParser.MYSQL_ERRNO, 0); }
		public TerminalNode CONSTRAINT_CATALOG() { return getToken(MySqlParser.CONSTRAINT_CATALOG, 0); }
		public TerminalNode CONSTRAINT_SCHEMA() { return getToken(MySqlParser.CONSTRAINT_SCHEMA, 0); }
		public TerminalNode CONSTRAINT_NAME() { return getToken(MySqlParser.CONSTRAINT_NAME, 0); }
		public TerminalNode CATALOG_NAME() { return getToken(MySqlParser.CATALOG_NAME, 0); }
		public TerminalNode SCHEMA_NAME() { return getToken(MySqlParser.SCHEMA_NAME, 0); }
		public TerminalNode TABLE_NAME() { return getToken(MySqlParser.TABLE_NAME, 0); }
		public TerminalNode COLUMN_NAME() { return getToken(MySqlParser.COLUMN_NAME, 0); }
		public TerminalNode CURSOR_NAME() { return getToken(MySqlParser.CURSOR_NAME, 0); }
		public DiagnosticsConditionInformationNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_diagnosticsConditionInformationName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDiagnosticsConditionInformationName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDiagnosticsConditionInformationName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDiagnosticsConditionInformationName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DiagnosticsConditionInformationNameContext diagnosticsConditionInformationName() throws RecognitionException {
		DiagnosticsConditionInformationNameContext _localctx = new DiagnosticsConditionInformationNameContext(_ctx, getState());
		enterRule(_localctx, 546, RULE_diagnosticsConditionInformationName);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6244);
			_la = _input.LA(1);
			if ( !(((((_la - 359)) & ~0x3f) == 0 && ((1L << (_la - 359)) & 272105729L) != 0) || _la==MESSAGE_TEXT || _la==MYSQL_ERRNO || ((((_la - 592)) & ~0x3f) == 0 && ((1L << (_la - 592)) & 18155135997837313L) != 0) || _la==CATALOG_NAME || _la==SCHEMA_NAME) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DescribeObjectClauseContext extends ParserRuleContext {
		public DescribeObjectClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_describeObjectClause; }
	 
		public DescribeObjectClauseContext() { }
		public void copyFrom(DescribeObjectClauseContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DescribeStatementsContext extends DescribeObjectClauseContext {
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public DeleteStatementContext deleteStatement() {
			return getRuleContext(DeleteStatementContext.class,0);
		}
		public InsertStatementContext insertStatement() {
			return getRuleContext(InsertStatementContext.class,0);
		}
		public ReplaceStatementContext replaceStatement() {
			return getRuleContext(ReplaceStatementContext.class,0);
		}
		public UpdateStatementContext updateStatement() {
			return getRuleContext(UpdateStatementContext.class,0);
		}
		public DescribeStatementsContext(DescribeObjectClauseContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDescribeStatements(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDescribeStatements(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDescribeStatements(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DescribeConnectionContext extends DescribeObjectClauseContext {
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public TerminalNode CONNECTION() { return getToken(MySqlParser.CONNECTION, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public DescribeConnectionContext(DescribeObjectClauseContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDescribeConnection(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDescribeConnection(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDescribeConnection(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DescribeObjectClauseContext describeObjectClause() throws RecognitionException {
		DescribeObjectClauseContext _localctx = new DescribeObjectClauseContext(_ctx, getState());
		enterRule(_localctx, 548, RULE_describeObjectClause);
		try {
			setState(6256);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DELETE:
			case INSERT:
			case REPLACE:
			case SELECT:
			case UPDATE:
			case LR_BRACKET:
				_localctx = new DescribeStatementsContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6251);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case SELECT:
				case LR_BRACKET:
					{
					setState(6246);
					selectStatement();
					}
					break;
				case DELETE:
					{
					setState(6247);
					deleteStatement();
					}
					break;
				case INSERT:
					{
					setState(6248);
					insertStatement();
					}
					break;
				case REPLACE:
					{
					setState(6249);
					replaceStatement();
					}
					break;
				case UPDATE:
					{
					setState(6250);
					updateStatement();
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				}
				break;
			case FOR:
				_localctx = new DescribeConnectionContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6253);
				match(FOR);
				setState(6254);
				match(CONNECTION);
				setState(6255);
				uid();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FullIdContext extends ParserRuleContext {
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public TerminalNode DOT_ID() { return getToken(MySqlParser.DOT_ID, 0); }
		public TerminalNode DOT() { return getToken(MySqlParser.DOT, 0); }
		public FullIdContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_fullId; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFullId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFullId(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFullId(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FullIdContext fullId() throws RecognitionException {
		FullIdContext _localctx = new FullIdContext(_ctx, getState());
		enterRule(_localctx, 550, RULE_fullId);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6258);
			uid();
			setState(6262);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,914,_ctx) ) {
			case 1:
				{
				setState(6259);
				match(DOT_ID);
				}
				break;
			case 2:
				{
				setState(6260);
				match(DOT);
				setState(6261);
				uid();
				}
				break;
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TableNameContext extends ParserRuleContext {
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TableNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tableName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTableName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTableName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTableName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TableNameContext tableName() throws RecognitionException {
		TableNameContext _localctx = new TableNameContext(_ctx, getState());
		enterRule(_localctx, 552, RULE_tableName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6264);
			fullId();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class RoleNameContext extends ParserRuleContext {
		public UserNameContext userName() {
			return getRuleContext(UserNameContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public RoleNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_roleName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRoleName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRoleName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRoleName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final RoleNameContext roleName() throws RecognitionException {
		RoleNameContext _localctx = new RoleNameContext(_ctx, getState());
		enterRule(_localctx, 554, RULE_roleName);
		try {
			setState(6268);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,915,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6266);
				userName();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6267);
				uid();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FullColumnNameContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public List dottedId() {
			return getRuleContexts(DottedIdContext.class);
		}
		public DottedIdContext dottedId(int i) {
			return getRuleContext(DottedIdContext.class,i);
		}
		public FullColumnNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_fullColumnName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFullColumnName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFullColumnName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFullColumnName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FullColumnNameContext fullColumnName() throws RecognitionException {
		FullColumnNameContext _localctx = new FullColumnNameContext(_ctx, getState());
		enterRule(_localctx, 556, RULE_fullColumnName);
		try {
			setState(6284);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,920,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6270);
				uid();
				setState(6275);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,917,_ctx) ) {
				case 1:
					{
					setState(6271);
					dottedId();
					setState(6273);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,916,_ctx) ) {
					case 1:
						{
						setState(6272);
						dottedId();
						}
						break;
					}
					}
					break;
				}
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6278);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,918,_ctx) ) {
				case 1:
					{
					setState(6277);
					matchWildcard();
					}
					break;
				}
				setState(6280);
				dottedId();
				setState(6282);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,919,_ctx) ) {
				case 1:
					{
					setState(6281);
					dottedId();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexColumnNameContext extends ParserRuleContext {
		public Token sortType;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode ASC() { return getToken(MySqlParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MySqlParser.DESC, 0); }
		public IndexColumnNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexColumnName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexColumnName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexColumnName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexColumnName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexColumnNameContext indexColumnName() throws RecognitionException {
		IndexColumnNameContext _localctx = new IndexColumnNameContext(_ctx, getState());
		enterRule(_localctx, 558, RULE_indexColumnName);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6297);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,923,_ctx) ) {
			case 1:
				{
				setState(6288);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,921,_ctx) ) {
				case 1:
					{
					setState(6286);
					uid();
					}
					break;
				case 2:
					{
					setState(6287);
					match(STRING_LITERAL);
					}
					break;
				}
				setState(6294);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6290);
					match(LR_BRACKET);
					setState(6291);
					decimalLiteral();
					setState(6292);
					match(RR_BRACKET);
					}
				}

				}
				break;
			case 2:
				{
				setState(6296);
				expression(0);
				}
				break;
			}
			setState(6300);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ASC || _la==DESC) {
				{
				setState(6299);
				((IndexColumnNameContext)_localctx).sortType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ASC || _la==DESC) ) {
					((IndexColumnNameContext)_localctx).sortType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SimpleUserNameContext extends ParserRuleContext {
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public TerminalNode ADMIN() { return getToken(MySqlParser.ADMIN, 0); }
		public KeywordsCanBeIdContext keywordsCanBeId() {
			return getRuleContext(KeywordsCanBeIdContext.class,0);
		}
		public SimpleUserNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_simpleUserName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleUserName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleUserName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleUserName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SimpleUserNameContext simpleUserName() throws RecognitionException {
		SimpleUserNameContext _localctx = new SimpleUserNameContext(_ctx, getState());
		enterRule(_localctx, 560, RULE_simpleUserName);
		try {
			setState(6306);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,925,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6302);
				match(STRING_LITERAL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6303);
				match(ID);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6304);
				match(ADMIN);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6305);
				keywordsCanBeId();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HostNameContext extends ParserRuleContext {
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public TerminalNode HOST_IP_ADDRESS() { return getToken(MySqlParser.HOST_IP_ADDRESS, 0); }
		public TerminalNode AT_SIGN() { return getToken(MySqlParser.AT_SIGN, 0); }
		public HostNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_hostName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHostName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHostName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHostName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HostNameContext hostName() throws RecognitionException {
		HostNameContext _localctx = new HostNameContext(_ctx, getState());
		enterRule(_localctx, 562, RULE_hostName);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6308);
			_la = _input.LA(1);
			if ( !(((((_la - 1137)) & ~0x3f) == 0 && ((1L << (_la - 1137)) & 6291457L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserNameContext extends ParserRuleContext {
		public SimpleUserNameContext simpleUserName() {
			return getRuleContext(SimpleUserNameContext.class,0);
		}
		public HostNameContext hostName() {
			return getRuleContext(HostNameContext.class,0);
		}
		public CurrentUserExpressionContext currentUserExpression() {
			return getRuleContext(CurrentUserExpressionContext.class,0);
		}
		public UserNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserNameContext userName() throws RecognitionException {
		UserNameContext _localctx = new UserNameContext(_ctx, getState());
		enterRule(_localctx, 564, RULE_userName);
		try {
			setState(6315);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,926,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6310);
				simpleUserName();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6311);
				simpleUserName();
				setState(6312);
				hostName();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6314);
				currentUserExpression();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class MysqlVariableContext extends ParserRuleContext {
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public TerminalNode GLOBAL_ID() { return getToken(MySqlParser.GLOBAL_ID, 0); }
		public MysqlVariableContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_mysqlVariable; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMysqlVariable(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMysqlVariable(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMysqlVariable(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MysqlVariableContext mysqlVariable() throws RecognitionException {
		MysqlVariableContext _localctx = new MysqlVariableContext(_ctx, getState());
		enterRule(_localctx, 566, RULE_mysqlVariable);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6317);
			_la = _input.LA(1);
			if ( !(_la==LOCAL_ID || _la==GLOBAL_ID) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CharsetNameContext extends ParserRuleContext {
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public CharsetNameBaseContext charsetNameBase() {
			return getRuleContext(CharsetNameBaseContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode CHARSET_REVERSE_QOUTE_STRING() { return getToken(MySqlParser.CHARSET_REVERSE_QOUTE_STRING, 0); }
		public CharsetNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_charsetName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCharsetName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCharsetName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCharsetName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CharsetNameContext charsetName() throws RecognitionException {
		CharsetNameContext _localctx = new CharsetNameContext(_ctx, getState());
		enterRule(_localctx, 568, RULE_charsetName);
		try {
			setState(6323);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,927,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6319);
				match(BINARY);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6320);
				charsetNameBase();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6321);
				match(STRING_LITERAL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6322);
				match(CHARSET_REVERSE_QOUTE_STRING);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CollationNameContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public CollationNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_collationName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCollationName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCollationName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCollationName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CollationNameContext collationName() throws RecognitionException {
		CollationNameContext _localctx = new CollationNameContext(_ctx, getState());
		enterRule(_localctx, 570, RULE_collationName);
		try {
			setState(6327);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,928,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6325);
				uid();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6326);
				match(STRING_LITERAL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class EngineNameContext extends ParserRuleContext {
		public EngineNameBaseContext engineNameBase() {
			return getRuleContext(EngineNameBaseContext.class,0);
		}
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public EngineNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_engineName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterEngineName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitEngineName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitEngineName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final EngineNameContext engineName() throws RecognitionException {
		EngineNameContext _localctx = new EngineNameContext(_ctx, getState());
		enterRule(_localctx, 572, RULE_engineName);
		try {
			setState(6332);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CONNECT:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
				enterOuterAlt(_localctx, 1);
				{
				setState(6329);
				engineNameBase();
				}
				break;
			case ID:
				enterOuterAlt(_localctx, 2);
				{
				setState(6330);
				match(ID);
				}
				break;
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 3);
				{
				setState(6331);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class EngineNameBaseContext extends ParserRuleContext {
		public TerminalNode ARCHIVE() { return getToken(MySqlParser.ARCHIVE, 0); }
		public TerminalNode BLACKHOLE() { return getToken(MySqlParser.BLACKHOLE, 0); }
		public TerminalNode CONNECT() { return getToken(MySqlParser.CONNECT, 0); }
		public TerminalNode CSV() { return getToken(MySqlParser.CSV, 0); }
		public TerminalNode FEDERATED() { return getToken(MySqlParser.FEDERATED, 0); }
		public TerminalNode INNODB() { return getToken(MySqlParser.INNODB, 0); }
		public TerminalNode MEMORY() { return getToken(MySqlParser.MEMORY, 0); }
		public TerminalNode MRG_MYISAM() { return getToken(MySqlParser.MRG_MYISAM, 0); }
		public TerminalNode MYISAM() { return getToken(MySqlParser.MYISAM, 0); }
		public TerminalNode NDB() { return getToken(MySqlParser.NDB, 0); }
		public TerminalNode NDBCLUSTER() { return getToken(MySqlParser.NDBCLUSTER, 0); }
		public TerminalNode PERFORMANCE_SCHEMA() { return getToken(MySqlParser.PERFORMANCE_SCHEMA, 0); }
		public TerminalNode TOKUDB() { return getToken(MySqlParser.TOKUDB, 0); }
		public EngineNameBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_engineNameBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterEngineNameBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitEngineNameBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitEngineNameBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final EngineNameBaseContext engineNameBase() throws RecognitionException {
		EngineNameBaseContext _localctx = new EngineNameBaseContext(_ctx, getState());
		enterRule(_localctx, 574, RULE_engineNameBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6334);
			_la = _input.LA(1);
			if ( !(_la==CONNECT || ((((_la - 787)) & ~0x3f) == 0 && ((1L << (_la - 787)) & 4095L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UuidSetContext extends ParserRuleContext {
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public List MINUS() { return getTokens(MySqlParser.MINUS); }
		public TerminalNode MINUS(int i) {
			return getToken(MySqlParser.MINUS, i);
		}
		public List COLON_SYMB() { return getTokens(MySqlParser.COLON_SYMB); }
		public TerminalNode COLON_SYMB(int i) {
			return getToken(MySqlParser.COLON_SYMB, i);
		}
		public UuidSetContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_uuidSet; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUuidSet(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUuidSet(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUuidSet(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UuidSetContext uuidSet() throws RecognitionException {
		UuidSetContext _localctx = new UuidSetContext(_ctx, getState());
		enterRule(_localctx, 576, RULE_uuidSet);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6336);
			decimalLiteral();
			setState(6337);
			match(MINUS);
			setState(6338);
			decimalLiteral();
			setState(6339);
			match(MINUS);
			setState(6340);
			decimalLiteral();
			setState(6341);
			match(MINUS);
			setState(6342);
			decimalLiteral();
			setState(6343);
			match(MINUS);
			setState(6344);
			decimalLiteral();
			setState(6350); 
			_errHandler.sync(this);
			_la = _input.LA(1);
			do {
				{
				{
				setState(6345);
				match(COLON_SYMB);
				setState(6346);
				decimalLiteral();
				setState(6347);
				match(MINUS);
				setState(6348);
				decimalLiteral();
				}
				}
				setState(6352); 
				_errHandler.sync(this);
				_la = _input.LA(1);
			} while ( _la==COLON_SYMB );
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XidContext extends ParserRuleContext {
		public XuidStringIdContext globalTableUid;
		public XuidStringIdContext qualifier;
		public DecimalLiteralContext idFormat;
		public List xuidStringId() {
			return getRuleContexts(XuidStringIdContext.class);
		}
		public XuidStringIdContext xuidStringId(int i) {
			return getRuleContext(XuidStringIdContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public XidContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xid; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXid(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXid(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXid(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XidContext xid() throws RecognitionException {
		XidContext _localctx = new XidContext(_ctx, getState());
		enterRule(_localctx, 578, RULE_xid);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6354);
			((XidContext)_localctx).globalTableUid = xuidStringId();
			setState(6361);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(6355);
				match(COMMA);
				setState(6356);
				((XidContext)_localctx).qualifier = xuidStringId();
				setState(6359);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(6357);
					match(COMMA);
					setState(6358);
					((XidContext)_localctx).idFormat = decimalLiteral();
					}
				}

				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class XuidStringIdContext extends ParserRuleContext {
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public TerminalNode BIT_STRING() { return getToken(MySqlParser.BIT_STRING, 0); }
		public List HEXADECIMAL_LITERAL() { return getTokens(MySqlParser.HEXADECIMAL_LITERAL); }
		public TerminalNode HEXADECIMAL_LITERAL(int i) {
			return getToken(MySqlParser.HEXADECIMAL_LITERAL, i);
		}
		public XuidStringIdContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_xuidStringId; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterXuidStringId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitXuidStringId(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitXuidStringId(this);
			else return visitor.visitChildren(this);
		}
	}

	public final XuidStringIdContext xuidStringId() throws RecognitionException {
		XuidStringIdContext _localctx = new XuidStringIdContext(_ctx, getState());
		enterRule(_localctx, 580, RULE_xuidStringId);
		int _la;
		try {
			setState(6370);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(6363);
				match(STRING_LITERAL);
				}
				break;
			case BIT_STRING:
				enterOuterAlt(_localctx, 2);
				{
				setState(6364);
				match(BIT_STRING);
				}
				break;
			case HEXADECIMAL_LITERAL:
				enterOuterAlt(_localctx, 3);
				{
				setState(6366); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(6365);
					match(HEXADECIMAL_LITERAL);
					}
					}
					setState(6368); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==HEXADECIMAL_LITERAL );
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AuthPluginContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public AuthPluginContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_authPlugin; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAuthPlugin(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAuthPlugin(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAuthPlugin(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AuthPluginContext authPlugin() throws RecognitionException {
		AuthPluginContext _localctx = new AuthPluginContext(_ctx, getState());
		enterRule(_localctx, 582, RULE_authPlugin);
		try {
			setState(6374);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,935,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6372);
				uid();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6373);
				match(STRING_LITERAL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UidContext extends ParserRuleContext {
		public SimpleIdContext simpleId() {
			return getRuleContext(SimpleIdContext.class,0);
		}
		public TerminalNode CHARSET_REVERSE_QOUTE_STRING() { return getToken(MySqlParser.CHARSET_REVERSE_QOUTE_STRING, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public UidContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_uid; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUid(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUid(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUid(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UidContext uid() throws RecognitionException {
		UidContext _localctx = new UidContext(_ctx, getState());
		enterRule(_localctx, 584, RULE_uid);
		try {
			setState(6379);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(6376);
				simpleId();
				}
				break;
			case CHARSET_REVERSE_QOUTE_STRING:
				enterOuterAlt(_localctx, 2);
				{
				setState(6377);
				match(CHARSET_REVERSE_QOUTE_STRING);
				}
				break;
			case STRING_LITERAL:
				enterOuterAlt(_localctx, 3);
				{
				setState(6378);
				match(STRING_LITERAL);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SimpleIdContext extends ParserRuleContext {
		public TerminalNode ID() { return getToken(MySqlParser.ID, 0); }
		public CharsetNameBaseContext charsetNameBase() {
			return getRuleContext(CharsetNameBaseContext.class,0);
		}
		public TransactionLevelBaseContext transactionLevelBase() {
			return getRuleContext(TransactionLevelBaseContext.class,0);
		}
		public EngineNameBaseContext engineNameBase() {
			return getRuleContext(EngineNameBaseContext.class,0);
		}
		public PrivilegesBaseContext privilegesBase() {
			return getRuleContext(PrivilegesBaseContext.class,0);
		}
		public IntervalTypeBaseContext intervalTypeBase() {
			return getRuleContext(IntervalTypeBaseContext.class,0);
		}
		public DataTypeBaseContext dataTypeBase() {
			return getRuleContext(DataTypeBaseContext.class,0);
		}
		public KeywordsCanBeIdContext keywordsCanBeId() {
			return getRuleContext(KeywordsCanBeIdContext.class,0);
		}
		public ScalarFunctionNameContext scalarFunctionName() {
			return getRuleContext(ScalarFunctionNameContext.class,0);
		}
		public SimpleIdContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_simpleId; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleId(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleId(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SimpleIdContext simpleId() throws RecognitionException {
		SimpleIdContext _localctx = new SimpleIdContext(_ctx, getState());
		enterRule(_localctx, 586, RULE_simpleId);
		try {
			setState(6390);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,937,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6381);
				match(ID);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6382);
				charsetNameBase();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6383);
				transactionLevelBase();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6384);
				engineNameBase();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(6385);
				privilegesBase();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(6386);
				intervalTypeBase();
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(6387);
				dataTypeBase();
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(6388);
				keywordsCanBeId();
				}
				break;
			case 9:
				enterOuterAlt(_localctx, 9);
				{
				setState(6389);
				scalarFunctionName();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DottedIdContext extends ParserRuleContext {
		public TerminalNode DOT_ID() { return getToken(MySqlParser.DOT_ID, 0); }
		public TerminalNode DOT() { return getToken(MySqlParser.DOT, 0); }
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public DottedIdContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dottedId; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDottedId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDottedId(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDottedId(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DottedIdContext dottedId() throws RecognitionException {
		DottedIdContext _localctx = new DottedIdContext(_ctx, getState());
		enterRule(_localctx, 588, RULE_dottedId);
		try {
			setState(6395);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DOT_ID:
				enterOuterAlt(_localctx, 1);
				{
				setState(6392);
				match(DOT_ID);
				}
				break;
			case DOT:
				enterOuterAlt(_localctx, 2);
				{
				setState(6393);
				match(DOT);
				setState(6394);
				uid();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DecimalLiteralContext extends ParserRuleContext {
		public TerminalNode DECIMAL_LITERAL() { return getToken(MySqlParser.DECIMAL_LITERAL, 0); }
		public TerminalNode ZERO_DECIMAL() { return getToken(MySqlParser.ZERO_DECIMAL, 0); }
		public TerminalNode ONE_DECIMAL() { return getToken(MySqlParser.ONE_DECIMAL, 0); }
		public TerminalNode TWO_DECIMAL() { return getToken(MySqlParser.TWO_DECIMAL, 0); }
		public TerminalNode REAL_LITERAL() { return getToken(MySqlParser.REAL_LITERAL, 0); }
		public DecimalLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_decimalLiteral; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDecimalLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDecimalLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDecimalLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DecimalLiteralContext decimalLiteral() throws RecognitionException {
		DecimalLiteralContext _localctx = new DecimalLiteralContext(_ctx, getState());
		enterRule(_localctx, 590, RULE_decimalLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6397);
			_la = _input.LA(1);
			if ( !(((((_la - 1138)) & ~0x3f) == 0 && ((1L << (_la - 1138)) & 10247L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FileSizeLiteralContext extends ParserRuleContext {
		public TerminalNode FILESIZE_LITERAL() { return getToken(MySqlParser.FILESIZE_LITERAL, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public FileSizeLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_fileSizeLiteral; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFileSizeLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFileSizeLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFileSizeLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FileSizeLiteralContext fileSizeLiteral() throws RecognitionException {
		FileSizeLiteralContext _localctx = new FileSizeLiteralContext(_ctx, getState());
		enterRule(_localctx, 592, RULE_fileSizeLiteral);
		try {
			setState(6401);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FILESIZE_LITERAL:
				enterOuterAlt(_localctx, 1);
				{
				setState(6399);
				match(FILESIZE_LITERAL);
				}
				break;
			case ZERO_DECIMAL:
			case ONE_DECIMAL:
			case TWO_DECIMAL:
			case DECIMAL_LITERAL:
			case REAL_LITERAL:
				enterOuterAlt(_localctx, 2);
				{
				setState(6400);
				decimalLiteral();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class StringLiteralContext extends ParserRuleContext {
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public TerminalNode START_NATIONAL_STRING_LITERAL() { return getToken(MySqlParser.START_NATIONAL_STRING_LITERAL, 0); }
		public TerminalNode STRING_CHARSET_NAME() { return getToken(MySqlParser.STRING_CHARSET_NAME, 0); }
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public StringLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_stringLiteral; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStringLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStringLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStringLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final StringLiteralContext stringLiteral() throws RecognitionException {
		StringLiteralContext _localctx = new StringLiteralContext(_ctx, getState());
		enterRule(_localctx, 594, RULE_stringLiteral);
		int _la;
		try {
			int _alt;
			setState(6426);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,946,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6408);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case STRING_LITERAL:
				case STRING_CHARSET_NAME:
					{
					setState(6404);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==STRING_CHARSET_NAME) {
						{
						setState(6403);
						match(STRING_CHARSET_NAME);
						}
					}

					setState(6406);
					match(STRING_LITERAL);
					}
					break;
				case START_NATIONAL_STRING_LITERAL:
					{
					setState(6407);
					match(START_NATIONAL_STRING_LITERAL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6411); 
				_errHandler.sync(this);
				_alt = 1;
				do {
					switch (_alt) {
					case 1:
						{
						{
						setState(6410);
						match(STRING_LITERAL);
						}
						}
						break;
					default:
						throw new NoViableAltException(this);
					}
					setState(6413); 
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,942,_ctx);
				} while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER );
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6420);
				_errHandler.sync(this);
				switch (_input.LA(1)) {
				case STRING_LITERAL:
				case STRING_CHARSET_NAME:
					{
					setState(6416);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (_la==STRING_CHARSET_NAME) {
						{
						setState(6415);
						match(STRING_CHARSET_NAME);
						}
					}

					setState(6418);
					match(STRING_LITERAL);
					}
					break;
				case START_NATIONAL_STRING_LITERAL:
					{
					setState(6419);
					match(START_NATIONAL_STRING_LITERAL);
					}
					break;
				default:
					throw new NoViableAltException(this);
				}
				setState(6424);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,945,_ctx) ) {
				case 1:
					{
					setState(6422);
					match(COLLATE);
					setState(6423);
					collationName();
					}
					break;
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class BooleanLiteralContext extends ParserRuleContext {
		public TerminalNode TRUE() { return getToken(MySqlParser.TRUE, 0); }
		public TerminalNode FALSE() { return getToken(MySqlParser.FALSE, 0); }
		public BooleanLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_booleanLiteral; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBooleanLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBooleanLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBooleanLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BooleanLiteralContext booleanLiteral() throws RecognitionException {
		BooleanLiteralContext _localctx = new BooleanLiteralContext(_ctx, getState());
		enterRule(_localctx, 596, RULE_booleanLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6428);
			_la = _input.LA(1);
			if ( !(_la==FALSE || _la==TRUE) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class HexadecimalLiteralContext extends ParserRuleContext {
		public TerminalNode HEXADECIMAL_LITERAL() { return getToken(MySqlParser.HEXADECIMAL_LITERAL, 0); }
		public TerminalNode STRING_CHARSET_NAME() { return getToken(MySqlParser.STRING_CHARSET_NAME, 0); }
		public HexadecimalLiteralContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_hexadecimalLiteral; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterHexadecimalLiteral(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitHexadecimalLiteral(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitHexadecimalLiteral(this);
			else return visitor.visitChildren(this);
		}
	}

	public final HexadecimalLiteralContext hexadecimalLiteral() throws RecognitionException {
		HexadecimalLiteralContext _localctx = new HexadecimalLiteralContext(_ctx, getState());
		enterRule(_localctx, 598, RULE_hexadecimalLiteral);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6431);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==STRING_CHARSET_NAME) {
				{
				setState(6430);
				match(STRING_CHARSET_NAME);
				}
			}

			setState(6433);
			match(HEXADECIMAL_LITERAL);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class NullNotnullContext extends ParserRuleContext {
		public TerminalNode NULL_LITERAL() { return getToken(MySqlParser.NULL_LITERAL, 0); }
		public TerminalNode NULL_SPEC_LITERAL() { return getToken(MySqlParser.NULL_SPEC_LITERAL, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public NullNotnullContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_nullNotnull; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNullNotnull(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNullNotnull(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNullNotnull(this);
			else return visitor.visitChildren(this);
		}
	}

	public final NullNotnullContext nullNotnull() throws RecognitionException {
		NullNotnullContext _localctx = new NullNotnullContext(_ctx, getState());
		enterRule(_localctx, 600, RULE_nullNotnull);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6436);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==NOT) {
				{
				setState(6435);
				match(NOT);
				}
			}

			setState(6438);
			_la = _input.LA(1);
			if ( !(_la==NULL_LITERAL || _la==NULL_SPEC_LITERAL) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ConstantContext extends ParserRuleContext {
		public Token nullLiteral;
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode MINUS() { return getToken(MySqlParser.MINUS, 0); }
		public HexadecimalLiteralContext hexadecimalLiteral() {
			return getRuleContext(HexadecimalLiteralContext.class,0);
		}
		public BooleanLiteralContext booleanLiteral() {
			return getRuleContext(BooleanLiteralContext.class,0);
		}
		public TerminalNode REAL_LITERAL() { return getToken(MySqlParser.REAL_LITERAL, 0); }
		public TerminalNode BIT_STRING() { return getToken(MySqlParser.BIT_STRING, 0); }
		public TerminalNode NULL_LITERAL() { return getToken(MySqlParser.NULL_LITERAL, 0); }
		public TerminalNode NULL_SPEC_LITERAL() { return getToken(MySqlParser.NULL_SPEC_LITERAL, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public ConstantContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_constant; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterConstant(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitConstant(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitConstant(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ConstantContext constant() throws RecognitionException {
		ConstantContext _localctx = new ConstantContext(_ctx, getState());
		enterRule(_localctx, 602, RULE_constant);
		int _la;
		try {
			setState(6452);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,950,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6440);
				stringLiteral();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6441);
				decimalLiteral();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6442);
				match(MINUS);
				setState(6443);
				decimalLiteral();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6444);
				hexadecimalLiteral();
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(6445);
				booleanLiteral();
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(6446);
				match(REAL_LITERAL);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(6447);
				match(BIT_STRING);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(6449);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(6448);
					match(NOT);
					}
				}

				setState(6451);
				((ConstantContext)_localctx).nullLiteral = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==NULL_LITERAL || _la==NULL_SPEC_LITERAL) ) {
					((ConstantContext)_localctx).nullLiteral = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DataTypeContext extends ParserRuleContext {
		public DataTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dataType; }
	 
		public DataTypeContext() { }
		public void copyFrom(DataTypeContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SpatialDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode GEOMETRYCOLLECTION() { return getToken(MySqlParser.GEOMETRYCOLLECTION, 0); }
		public TerminalNode GEOMCOLLECTION() { return getToken(MySqlParser.GEOMCOLLECTION, 0); }
		public TerminalNode LINESTRING() { return getToken(MySqlParser.LINESTRING, 0); }
		public TerminalNode MULTILINESTRING() { return getToken(MySqlParser.MULTILINESTRING, 0); }
		public TerminalNode MULTIPOINT() { return getToken(MySqlParser.MULTIPOINT, 0); }
		public TerminalNode MULTIPOLYGON() { return getToken(MySqlParser.MULTIPOLYGON, 0); }
		public TerminalNode POINT() { return getToken(MySqlParser.POINT, 0); }
		public TerminalNode POLYGON() { return getToken(MySqlParser.POLYGON, 0); }
		public TerminalNode JSON() { return getToken(MySqlParser.JSON, 0); }
		public TerminalNode GEOMETRY() { return getToken(MySqlParser.GEOMETRY, 0); }
		public TerminalNode SRID() { return getToken(MySqlParser.SRID, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public SpatialDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSpatialDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSpatialDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSpatialDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class LongVarbinaryDataTypeContext extends DataTypeContext {
		public TerminalNode LONG() { return getToken(MySqlParser.LONG, 0); }
		public TerminalNode VARBINARY() { return getToken(MySqlParser.VARBINARY, 0); }
		public LongVarbinaryDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLongVarbinaryDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLongVarbinaryDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLongVarbinaryDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CollectionDataTypeContext extends DataTypeContext {
		public Token typeName;
		public CollectionOptionsContext collectionOptions() {
			return getRuleContext(CollectionOptionsContext.class,0);
		}
		public TerminalNode ENUM() { return getToken(MySqlParser.ENUM, 0); }
		public TerminalNode SET() { return getToken(MySqlParser.SET, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public CollectionDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCollectionDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCollectionDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCollectionDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NationalVaryingStringDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode NATIONAL() { return getToken(MySqlParser.NATIONAL, 0); }
		public TerminalNode VARYING() { return getToken(MySqlParser.VARYING, 0); }
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public NationalVaryingStringDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNationalVaryingStringDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNationalVaryingStringDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNationalVaryingStringDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DimensionDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode TINYINT() { return getToken(MySqlParser.TINYINT, 0); }
		public TerminalNode SMALLINT() { return getToken(MySqlParser.SMALLINT, 0); }
		public TerminalNode MEDIUMINT() { return getToken(MySqlParser.MEDIUMINT, 0); }
		public TerminalNode INT() { return getToken(MySqlParser.INT, 0); }
		public TerminalNode INTEGER() { return getToken(MySqlParser.INTEGER, 0); }
		public TerminalNode BIGINT() { return getToken(MySqlParser.BIGINT, 0); }
		public TerminalNode MIDDLEINT() { return getToken(MySqlParser.MIDDLEINT, 0); }
		public TerminalNode INT1() { return getToken(MySqlParser.INT1, 0); }
		public TerminalNode INT2() { return getToken(MySqlParser.INT2, 0); }
		public TerminalNode INT3() { return getToken(MySqlParser.INT3, 0); }
		public TerminalNode INT4() { return getToken(MySqlParser.INT4, 0); }
		public TerminalNode INT8() { return getToken(MySqlParser.INT8, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public List SIGNED() { return getTokens(MySqlParser.SIGNED); }
		public TerminalNode SIGNED(int i) {
			return getToken(MySqlParser.SIGNED, i);
		}
		public List UNSIGNED() { return getTokens(MySqlParser.UNSIGNED); }
		public TerminalNode UNSIGNED(int i) {
			return getToken(MySqlParser.UNSIGNED, i);
		}
		public List ZEROFILL() { return getTokens(MySqlParser.ZEROFILL); }
		public TerminalNode ZEROFILL(int i) {
			return getToken(MySqlParser.ZEROFILL, i);
		}
		public TerminalNode REAL() { return getToken(MySqlParser.REAL, 0); }
		public LengthTwoDimensionContext lengthTwoDimension() {
			return getRuleContext(LengthTwoDimensionContext.class,0);
		}
		public TerminalNode DOUBLE() { return getToken(MySqlParser.DOUBLE, 0); }
		public TerminalNode PRECISION() { return getToken(MySqlParser.PRECISION, 0); }
		public TerminalNode DECIMAL() { return getToken(MySqlParser.DECIMAL, 0); }
		public TerminalNode DEC() { return getToken(MySqlParser.DEC, 0); }
		public TerminalNode FIXED() { return getToken(MySqlParser.FIXED, 0); }
		public TerminalNode NUMERIC() { return getToken(MySqlParser.NUMERIC, 0); }
		public TerminalNode FLOAT() { return getToken(MySqlParser.FLOAT, 0); }
		public TerminalNode FLOAT4() { return getToken(MySqlParser.FLOAT4, 0); }
		public TerminalNode FLOAT8() { return getToken(MySqlParser.FLOAT8, 0); }
		public LengthTwoOptionalDimensionContext lengthTwoOptionalDimension() {
			return getRuleContext(LengthTwoOptionalDimensionContext.class,0);
		}
		public TerminalNode BIT() { return getToken(MySqlParser.BIT, 0); }
		public TerminalNode TIME() { return getToken(MySqlParser.TIME, 0); }
		public TerminalNode TIMESTAMP() { return getToken(MySqlParser.TIMESTAMP, 0); }
		public TerminalNode DATETIME() { return getToken(MySqlParser.DATETIME, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode VARBINARY() { return getToken(MySqlParser.VARBINARY, 0); }
		public TerminalNode BLOB() { return getToken(MySqlParser.BLOB, 0); }
		public TerminalNode YEAR() { return getToken(MySqlParser.YEAR, 0); }
		public DimensionDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDimensionDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDimensionDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDimensionDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class StringDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode VARCHAR() { return getToken(MySqlParser.VARCHAR, 0); }
		public TerminalNode TINYTEXT() { return getToken(MySqlParser.TINYTEXT, 0); }
		public TerminalNode TEXT() { return getToken(MySqlParser.TEXT, 0); }
		public TerminalNode MEDIUMTEXT() { return getToken(MySqlParser.MEDIUMTEXT, 0); }
		public TerminalNode LONGTEXT() { return getToken(MySqlParser.LONGTEXT, 0); }
		public TerminalNode NCHAR() { return getToken(MySqlParser.NCHAR, 0); }
		public TerminalNode NVARCHAR() { return getToken(MySqlParser.NVARCHAR, 0); }
		public TerminalNode LONG() { return getToken(MySqlParser.LONG, 0); }
		public TerminalNode VARYING() { return getToken(MySqlParser.VARYING, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public List BINARY() { return getTokens(MySqlParser.BINARY); }
		public TerminalNode BINARY(int i) {
			return getToken(MySqlParser.BINARY, i);
		}
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public StringDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterStringDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitStringDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitStringDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class LongVarcharDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode LONG() { return getToken(MySqlParser.LONG, 0); }
		public TerminalNode VARCHAR() { return getToken(MySqlParser.VARCHAR, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public LongVarcharDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLongVarcharDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLongVarcharDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLongVarcharDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NationalStringDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode NATIONAL() { return getToken(MySqlParser.NATIONAL, 0); }
		public TerminalNode VARCHAR() { return getToken(MySqlParser.VARCHAR, 0); }
		public TerminalNode CHARACTER() { return getToken(MySqlParser.CHARACTER, 0); }
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode NCHAR() { return getToken(MySqlParser.NCHAR, 0); }
		public NationalStringDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNationalStringDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNationalStringDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNationalStringDataType(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SimpleDataTypeContext extends DataTypeContext {
		public Token typeName;
		public TerminalNode DATE() { return getToken(MySqlParser.DATE, 0); }
		public TerminalNode TINYBLOB() { return getToken(MySqlParser.TINYBLOB, 0); }
		public TerminalNode MEDIUMBLOB() { return getToken(MySqlParser.MEDIUMBLOB, 0); }
		public TerminalNode LONGBLOB() { return getToken(MySqlParser.LONGBLOB, 0); }
		public TerminalNode BOOL() { return getToken(MySqlParser.BOOL, 0); }
		public TerminalNode BOOLEAN() { return getToken(MySqlParser.BOOLEAN, 0); }
		public TerminalNode SERIAL() { return getToken(MySqlParser.SERIAL, 0); }
		public SimpleDataTypeContext(DataTypeContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleDataType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DataTypeContext dataType() throws RecognitionException {
		DataTypeContext _localctx = new DataTypeContext(_ctx, getState());
		enterRule(_localctx, 604, RULE_dataType);
		int _la;
		try {
			int _alt;
			setState(6580);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,979,_ctx) ) {
			case 1:
				_localctx = new StringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6454);
				((StringDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CHARACTER || ((((_la - 222)) & ~0x3f) == 0 && ((1L << (_la - 222)) & 31239L) != 0) || _la==NCHAR) ) {
					((StringDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6456);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VARYING) {
					{
					setState(6455);
					match(VARYING);
					}
				}

				setState(6459);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,952,_ctx) ) {
				case 1:
					{
					setState(6458);
					lengthOneDimension();
					}
					break;
				}
				setState(6462);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,953,_ctx) ) {
				case 1:
					{
					setState(6461);
					match(BINARY);
					}
					break;
				}
				setState(6467);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,954,_ctx) ) {
				case 1:
					{
					setState(6464);
					charSet();
					setState(6465);
					charsetName();
					}
					break;
				}
				setState(6472);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,955,_ctx) ) {
				case 1:
					{
					setState(6469);
					match(COLLATE);
					setState(6470);
					collationName();
					}
					break;
				case 2:
					{
					setState(6471);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new NationalVaryingStringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6474);
				match(NATIONAL);
				setState(6475);
				((NationalVaryingStringDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CHARACTER || _la==CHAR) ) {
					((NationalVaryingStringDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6476);
				match(VARYING);
				setState(6478);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,956,_ctx) ) {
				case 1:
					{
					setState(6477);
					lengthOneDimension();
					}
					break;
				}
				setState(6481);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,957,_ctx) ) {
				case 1:
					{
					setState(6480);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 3:
				_localctx = new NationalStringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6483);
				match(NATIONAL);
				setState(6484);
				((NationalStringDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==CHARACTER || _la==CHAR || _la==VARCHAR) ) {
					((NationalStringDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6486);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,958,_ctx) ) {
				case 1:
					{
					setState(6485);
					lengthOneDimension();
					}
					break;
				}
				setState(6489);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,959,_ctx) ) {
				case 1:
					{
					setState(6488);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 4:
				_localctx = new NationalStringDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(6491);
				match(NCHAR);
				setState(6492);
				((NationalStringDataTypeContext)_localctx).typeName = match(VARCHAR);
				setState(6494);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,960,_ctx) ) {
				case 1:
					{
					setState(6493);
					lengthOneDimension();
					}
					break;
				}
				setState(6497);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,961,_ctx) ) {
				case 1:
					{
					setState(6496);
					match(BINARY);
					}
					break;
				}
				}
				break;
			case 5:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(6499);
				((DimensionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 196)) & ~0x3f) == 0 && ((1L << (_la - 196)) & 4095L) != 0)) ) {
					((DimensionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6501);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,962,_ctx) ) {
				case 1:
					{
					setState(6500);
					lengthOneDimension();
					}
					break;
				}
				setState(6506);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,963,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6503);
						_la = _input.LA(1);
						if ( !(_la==UNSIGNED || _la==ZEROFILL || _la==SIGNED) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						} 
					}
					setState(6508);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,963,_ctx);
				}
				}
				break;
			case 6:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(6509);
				((DimensionDataTypeContext)_localctx).typeName = match(REAL);
				setState(6511);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,964,_ctx) ) {
				case 1:
					{
					setState(6510);
					lengthTwoDimension();
					}
					break;
				}
				setState(6516);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,965,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6513);
						_la = _input.LA(1);
						if ( !(_la==UNSIGNED || _la==ZEROFILL || _la==SIGNED) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						} 
					}
					setState(6518);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,965,_ctx);
				}
				}
				break;
			case 7:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(6519);
				((DimensionDataTypeContext)_localctx).typeName = match(DOUBLE);
				setState(6521);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==PRECISION) {
					{
					setState(6520);
					match(PRECISION);
					}
				}

				setState(6524);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,967,_ctx) ) {
				case 1:
					{
					setState(6523);
					lengthTwoDimension();
					}
					break;
				}
				setState(6529);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,968,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6526);
						_la = _input.LA(1);
						if ( !(_la==UNSIGNED || _la==ZEROFILL || _la==SIGNED) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						} 
					}
					setState(6531);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,968,_ctx);
				}
				}
				break;
			case 8:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(6532);
				((DimensionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 211)) & ~0x3f) == 0 && ((1L << (_la - 211)) & 63L) != 0) || _la==FIXED) ) {
					((DimensionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6534);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,969,_ctx) ) {
				case 1:
					{
					setState(6533);
					lengthTwoOptionalDimension();
					}
					break;
				}
				setState(6539);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,970,_ctx);
				while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
					if ( _alt==1 ) {
						{
						{
						setState(6536);
						_la = _input.LA(1);
						if ( !(_la==UNSIGNED || _la==ZEROFILL || _la==SIGNED) ) {
						_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						}
						} 
					}
					setState(6541);
					_errHandler.sync(this);
					_alt = getInterpreter().adaptivePredict(_input,970,_ctx);
				}
				}
				break;
			case 9:
				_localctx = new SimpleDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(6542);
				((SimpleDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & 4237313L) != 0) || _la==BOOL || _la==BOOLEAN) ) {
					((SimpleDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 10:
				_localctx = new DimensionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(6543);
				((DimensionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 218)) & ~0x3f) == 0 && ((1L << (_la - 218)) & 2831L) != 0) || _la==BIT) ) {
					((DimensionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6545);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,971,_ctx) ) {
				case 1:
					{
					setState(6544);
					lengthOneDimension();
					}
					break;
				}
				}
				break;
			case 11:
				_localctx = new CollectionDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(6547);
				((CollectionDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==SET || _la==ENUM) ) {
					((CollectionDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6548);
				collectionOptions();
				setState(6550);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,972,_ctx) ) {
				case 1:
					{
					setState(6549);
					match(BINARY);
					}
					break;
				}
				setState(6555);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,973,_ctx) ) {
				case 1:
					{
					setState(6552);
					charSet();
					setState(6553);
					charsetName();
					}
					break;
				}
				}
				break;
			case 12:
				_localctx = new SpatialDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(6557);
				((SpatialDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==JSON || ((((_la - 803)) & ~0x3f) == 0 && ((1L << (_la - 803)) & 511L) != 0)) ) {
					((SpatialDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6560);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,974,_ctx) ) {
				case 1:
					{
					setState(6558);
					match(SRID);
					setState(6559);
					decimalLiteral();
					}
					break;
				}
				}
				break;
			case 13:
				_localctx = new LongVarcharDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(6562);
				((LongVarcharDataTypeContext)_localctx).typeName = match(LONG);
				setState(6564);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==VARCHAR) {
					{
					setState(6563);
					match(VARCHAR);
					}
				}

				setState(6567);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,976,_ctx) ) {
				case 1:
					{
					setState(6566);
					match(BINARY);
					}
					break;
				}
				setState(6572);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,977,_ctx) ) {
				case 1:
					{
					setState(6569);
					charSet();
					setState(6570);
					charsetName();
					}
					break;
				}
				setState(6576);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,978,_ctx) ) {
				case 1:
					{
					setState(6574);
					match(COLLATE);
					setState(6575);
					collationName();
					}
					break;
				}
				}
				break;
			case 14:
				_localctx = new LongVarbinaryDataTypeContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(6578);
				match(LONG);
				setState(6579);
				match(VARBINARY);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CollectionOptionsContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public CollectionOptionsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_collectionOptions; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCollectionOptions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCollectionOptions(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCollectionOptions(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CollectionOptionsContext collectionOptions() throws RecognitionException {
		CollectionOptionsContext _localctx = new CollectionOptionsContext(_ctx, getState());
		enterRule(_localctx, 606, RULE_collectionOptions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6582);
			match(LR_BRACKET);
			setState(6583);
			match(STRING_LITERAL);
			setState(6588);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6584);
				match(COMMA);
				setState(6585);
				match(STRING_LITERAL);
				}
				}
				setState(6590);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(6591);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ConvertedDataTypeContext extends ParserRuleContext {
		public Token typeName;
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public TerminalNode SIGNED() { return getToken(MySqlParser.SIGNED, 0); }
		public TerminalNode UNSIGNED() { return getToken(MySqlParser.UNSIGNED, 0); }
		public TerminalNode ARRAY() { return getToken(MySqlParser.ARRAY, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode NCHAR() { return getToken(MySqlParser.NCHAR, 0); }
		public TerminalNode FLOAT() { return getToken(MySqlParser.FLOAT, 0); }
		public TerminalNode DATE() { return getToken(MySqlParser.DATE, 0); }
		public TerminalNode DATETIME() { return getToken(MySqlParser.DATETIME, 0); }
		public TerminalNode TIME() { return getToken(MySqlParser.TIME, 0); }
		public TerminalNode YEAR() { return getToken(MySqlParser.YEAR, 0); }
		public TerminalNode JSON() { return getToken(MySqlParser.JSON, 0); }
		public TerminalNode INT() { return getToken(MySqlParser.INT, 0); }
		public TerminalNode INTEGER() { return getToken(MySqlParser.INTEGER, 0); }
		public TerminalNode DOUBLE() { return getToken(MySqlParser.DOUBLE, 0); }
		public TerminalNode DECIMAL() { return getToken(MySqlParser.DECIMAL, 0); }
		public TerminalNode DEC() { return getToken(MySqlParser.DEC, 0); }
		public LengthOneDimensionContext lengthOneDimension() {
			return getRuleContext(LengthOneDimensionContext.class,0);
		}
		public CharSetContext charSet() {
			return getRuleContext(CharSetContext.class,0);
		}
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public LengthTwoOptionalDimensionContext lengthTwoOptionalDimension() {
			return getRuleContext(LengthTwoOptionalDimensionContext.class,0);
		}
		public ConvertedDataTypeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_convertedDataType; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterConvertedDataType(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitConvertedDataType(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitConvertedDataType(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ConvertedDataTypeContext convertedDataType() throws RecognitionException {
		ConvertedDataTypeContext _localctx = new ConvertedDataTypeContext(_ctx, getState());
		enterRule(_localctx, 608, RULE_convertedDataType);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6615);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case FLOAT:
			case BINARY:
			case NCHAR:
				{
				setState(6593);
				((ConvertedDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FLOAT || _la==BINARY || _la==NCHAR) ) {
					((ConvertedDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6595);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6594);
					lengthOneDimension();
					}
				}

				}
				break;
			case CHAR:
				{
				setState(6597);
				((ConvertedDataTypeContext)_localctx).typeName = match(CHAR);
				setState(6599);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6598);
					lengthOneDimension();
					}
				}

				setState(6604);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==CHARACTER || _la==CHAR || _la==CHARSET) {
					{
					setState(6601);
					charSet();
					setState(6602);
					charsetName();
					}
				}

				}
				break;
			case INT:
			case INTEGER:
			case DOUBLE:
			case DATE:
			case TIME:
			case DATETIME:
			case YEAR:
			case JSON:
				{
				setState(6606);
				((ConvertedDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 200)) & ~0x3f) == 0 && ((1L << (_la - 200)) & 3539521L) != 0) || _la==JSON) ) {
					((ConvertedDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case DECIMAL:
			case DEC:
				{
				setState(6607);
				((ConvertedDataTypeContext)_localctx).typeName = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==DECIMAL || _la==DEC) ) {
					((ConvertedDataTypeContext)_localctx).typeName = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6609);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LR_BRACKET) {
					{
					setState(6608);
					lengthTwoOptionalDimension();
					}
				}

				}
				break;
			case UNSIGNED:
			case SIGNED:
				{
				setState(6611);
				_la = _input.LA(1);
				if ( !(_la==UNSIGNED || _la==SIGNED) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6613);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==INT || _la==INTEGER) {
					{
					setState(6612);
					_la = _input.LA(1);
					if ( !(_la==INT || _la==INTEGER) ) {
					_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
				}

				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			setState(6618);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ARRAY) {
				{
				setState(6617);
				match(ARRAY);
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LengthOneDimensionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public LengthOneDimensionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lengthOneDimension; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLengthOneDimension(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLengthOneDimension(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLengthOneDimension(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LengthOneDimensionContext lengthOneDimension() throws RecognitionException {
		LengthOneDimensionContext _localctx = new LengthOneDimensionContext(_ctx, getState());
		enterRule(_localctx, 610, RULE_lengthOneDimension);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6620);
			match(LR_BRACKET);
			setState(6621);
			decimalLiteral();
			setState(6622);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LengthTwoDimensionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public LengthTwoDimensionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lengthTwoDimension; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLengthTwoDimension(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLengthTwoDimension(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLengthTwoDimension(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LengthTwoDimensionContext lengthTwoDimension() throws RecognitionException {
		LengthTwoDimensionContext _localctx = new LengthTwoDimensionContext(_ctx, getState());
		enterRule(_localctx, 612, RULE_lengthTwoDimension);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6624);
			match(LR_BRACKET);
			setState(6625);
			decimalLiteral();
			setState(6626);
			match(COMMA);
			setState(6627);
			decimalLiteral();
			setState(6628);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LengthTwoOptionalDimensionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public LengthTwoOptionalDimensionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_lengthTwoOptionalDimension; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLengthTwoOptionalDimension(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLengthTwoOptionalDimension(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLengthTwoOptionalDimension(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LengthTwoOptionalDimensionContext lengthTwoOptionalDimension() throws RecognitionException {
		LengthTwoOptionalDimensionContext _localctx = new LengthTwoOptionalDimensionContext(_ctx, getState());
		enterRule(_localctx, 614, RULE_lengthTwoOptionalDimension);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6630);
			match(LR_BRACKET);
			setState(6631);
			decimalLiteral();
			setState(6634);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==COMMA) {
				{
				setState(6632);
				match(COMMA);
				setState(6633);
				decimalLiteral();
				}
			}

			setState(6636);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UidListContext extends ParserRuleContext {
		public List uid() {
			return getRuleContexts(UidContext.class);
		}
		public UidContext uid(int i) {
			return getRuleContext(UidContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public UidListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_uidList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUidList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUidList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUidList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UidListContext uidList() throws RecognitionException {
		UidListContext _localctx = new UidListContext(_ctx, getState());
		enterRule(_localctx, 616, RULE_uidList);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(6638);
			uid();
			setState(6643);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,989,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(6639);
					match(COMMA);
					setState(6640);
					uid();
					}
					} 
				}
				setState(6645);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,989,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FullColumnNameListContext extends ParserRuleContext {
		public List fullColumnName() {
			return getRuleContexts(FullColumnNameContext.class);
		}
		public FullColumnNameContext fullColumnName(int i) {
			return getRuleContext(FullColumnNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public FullColumnNameListContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_fullColumnNameList; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFullColumnNameList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFullColumnNameList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFullColumnNameList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FullColumnNameListContext fullColumnNameList() throws RecognitionException {
		FullColumnNameListContext _localctx = new FullColumnNameListContext(_ctx, getState());
		enterRule(_localctx, 618, RULE_fullColumnNameList);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6646);
			fullColumnName();
			setState(6651);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6647);
				match(COMMA);
				setState(6648);
				fullColumnName();
				}
				}
				setState(6653);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TablesContext extends ParserRuleContext {
		public List tableName() {
			return getRuleContexts(TableNameContext.class);
		}
		public TableNameContext tableName(int i) {
			return getRuleContext(TableNameContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public TablesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_tables; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTables(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTables(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TablesContext tables() throws RecognitionException {
		TablesContext _localctx = new TablesContext(_ctx, getState());
		enterRule(_localctx, 620, RULE_tables);
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(6654);
			tableName();
			setState(6659);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,991,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					{
					{
					setState(6655);
					match(COMMA);
					setState(6656);
					tableName();
					}
					} 
				}
				setState(6661);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,991,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IndexColumnNamesContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List indexColumnName() {
			return getRuleContexts(IndexColumnNameContext.class);
		}
		public IndexColumnNameContext indexColumnName(int i) {
			return getRuleContext(IndexColumnNameContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public IndexColumnNamesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_indexColumnNames; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIndexColumnNames(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIndexColumnNames(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIndexColumnNames(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IndexColumnNamesContext indexColumnNames() throws RecognitionException {
		IndexColumnNamesContext _localctx = new IndexColumnNamesContext(_ctx, getState());
		enterRule(_localctx, 622, RULE_indexColumnNames);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6662);
			match(LR_BRACKET);
			setState(6663);
			indexColumnName();
			setState(6668);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6664);
				match(COMMA);
				setState(6665);
				indexColumnName();
				}
				}
				setState(6670);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			setState(6671);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ExpressionsContext extends ParserRuleContext {
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ExpressionsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expressions; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExpressions(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExpressions(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExpressions(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionsContext expressions() throws RecognitionException {
		ExpressionsContext _localctx = new ExpressionsContext(_ctx, getState());
		enterRule(_localctx, 624, RULE_expressions);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6673);
			expression(0);
			setState(6678);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6674);
				match(COMMA);
				setState(6675);
				expression(0);
				}
				}
				setState(6680);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ExpressionsWithDefaultsContext extends ParserRuleContext {
		public List expressionOrDefault() {
			return getRuleContexts(ExpressionOrDefaultContext.class);
		}
		public ExpressionOrDefaultContext expressionOrDefault(int i) {
			return getRuleContext(ExpressionOrDefaultContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ExpressionsWithDefaultsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expressionsWithDefaults; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExpressionsWithDefaults(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExpressionsWithDefaults(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExpressionsWithDefaults(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionsWithDefaultsContext expressionsWithDefaults() throws RecognitionException {
		ExpressionsWithDefaultsContext _localctx = new ExpressionsWithDefaultsContext(_ctx, getState());
		enterRule(_localctx, 626, RULE_expressionsWithDefaults);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6681);
			expressionOrDefault();
			setState(6686);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6682);
				match(COMMA);
				setState(6683);
				expressionOrDefault();
				}
				}
				setState(6688);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ConstantsContext extends ParserRuleContext {
		public List constant() {
			return getRuleContexts(ConstantContext.class);
		}
		public ConstantContext constant(int i) {
			return getRuleContext(ConstantContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public ConstantsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_constants; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterConstants(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitConstants(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitConstants(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ConstantsContext constants() throws RecognitionException {
		ConstantsContext _localctx = new ConstantsContext(_ctx, getState());
		enterRule(_localctx, 628, RULE_constants);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6689);
			constant();
			setState(6694);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6690);
				match(COMMA);
				setState(6691);
				constant();
				}
				}
				setState(6696);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SimpleStringsContext extends ParserRuleContext {
		public List STRING_LITERAL() { return getTokens(MySqlParser.STRING_LITERAL); }
		public TerminalNode STRING_LITERAL(int i) {
			return getToken(MySqlParser.STRING_LITERAL, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public SimpleStringsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_simpleStrings; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleStrings(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleStrings(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleStrings(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SimpleStringsContext simpleStrings() throws RecognitionException {
		SimpleStringsContext _localctx = new SimpleStringsContext(_ctx, getState());
		enterRule(_localctx, 630, RULE_simpleStrings);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6697);
			match(STRING_LITERAL);
			setState(6702);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6698);
				match(COMMA);
				setState(6699);
				match(STRING_LITERAL);
				}
				}
				setState(6704);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UserVariablesContext extends ParserRuleContext {
		public List LOCAL_ID() { return getTokens(MySqlParser.LOCAL_ID); }
		public TerminalNode LOCAL_ID(int i) {
			return getToken(MySqlParser.LOCAL_ID, i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public UserVariablesContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_userVariables; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUserVariables(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUserVariables(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUserVariables(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UserVariablesContext userVariables() throws RecognitionException {
		UserVariablesContext _localctx = new UserVariablesContext(_ctx, getState());
		enterRule(_localctx, 632, RULE_userVariables);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6705);
			match(LOCAL_ID);
			setState(6710);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(6706);
				match(COMMA);
				setState(6707);
				match(LOCAL_ID);
				}
				}
				setState(6712);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DefaultValueContext extends ParserRuleContext {
		public TerminalNode NULL_LITERAL() { return getToken(MySqlParser.NULL_LITERAL, 0); }
		public TerminalNode CAST() { return getToken(MySqlParser.CAST, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public ConvertedDataTypeContext convertedDataType() {
			return getRuleContext(ConvertedDataTypeContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public UnaryOperatorContext unaryOperator() {
			return getRuleContext(UnaryOperatorContext.class,0);
		}
		public List currentTimestamp() {
			return getRuleContexts(CurrentTimestampContext.class);
		}
		public CurrentTimestampContext currentTimestamp(int i) {
			return getRuleContext(CurrentTimestampContext.class,i);
		}
		public TerminalNode ON() { return getToken(MySqlParser.ON, 0); }
		public TerminalNode UPDATE() { return getToken(MySqlParser.UPDATE, 0); }
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public DefaultValueContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_defaultValue; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDefaultValue(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDefaultValue(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDefaultValue(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DefaultValueContext defaultValue() throws RecognitionException {
		DefaultValueContext _localctx = new DefaultValueContext(_ctx, getState());
		enterRule(_localctx, 634, RULE_defaultValue);
		try {
			setState(6739);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1000,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6713);
				match(NULL_LITERAL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6714);
				match(CAST);
				setState(6715);
				match(LR_BRACKET);
				setState(6716);
				expression(0);
				setState(6717);
				match(AS);
				setState(6718);
				convertedDataType();
				setState(6719);
				match(RR_BRACKET);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(6722);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,998,_ctx) ) {
				case 1:
					{
					setState(6721);
					unaryOperator();
					}
					break;
				}
				setState(6724);
				constant();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(6725);
				currentTimestamp();
				setState(6729);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,999,_ctx) ) {
				case 1:
					{
					setState(6726);
					match(ON);
					setState(6727);
					match(UPDATE);
					setState(6728);
					currentTimestamp();
					}
					break;
				}
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(6731);
				match(LR_BRACKET);
				setState(6732);
				expression(0);
				setState(6733);
				match(RR_BRACKET);
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(6735);
				match(LR_BRACKET);
				setState(6736);
				fullId();
				setState(6737);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CurrentTimestampContext extends ParserRuleContext {
		public TerminalNode NOW() { return getToken(MySqlParser.NOW, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MySqlParser.CURRENT_TIMESTAMP, 0); }
		public TerminalNode LOCALTIME() { return getToken(MySqlParser.LOCALTIME, 0); }
		public TerminalNode LOCALTIMESTAMP() { return getToken(MySqlParser.LOCALTIMESTAMP, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public CurrentTimestampContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_currentTimestamp; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCurrentTimestamp(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCurrentTimestamp(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCurrentTimestamp(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CurrentTimestampContext currentTimestamp() throws RecognitionException {
		CurrentTimestampContext _localctx = new CurrentTimestampContext(_ctx, getState());
		enterRule(_localctx, 636, RULE_currentTimestamp);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6755);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case LOCALTIMESTAMP:
				{
				setState(6741);
				_la = _input.LA(1);
				if ( !(((((_la - 315)) & ~0x3f) == 0 && ((1L << (_la - 315)) & 131L) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6747);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1002,_ctx) ) {
				case 1:
					{
					setState(6742);
					match(LR_BRACKET);
					setState(6744);
					_errHandler.sync(this);
					_la = _input.LA(1);
					if (((((_la - 1138)) & ~0x3f) == 0 && ((1L << (_la - 1138)) & 10247L) != 0)) {
						{
						setState(6743);
						decimalLiteral();
						}
					}

					setState(6746);
					match(RR_BRACKET);
					}
					break;
				}
				}
				break;
			case NOW:
				{
				setState(6749);
				match(NOW);
				setState(6750);
				match(LR_BRACKET);
				setState(6752);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (((((_la - 1138)) & ~0x3f) == 0 && ((1L << (_la - 1138)) & 10247L) != 0)) {
					{
					setState(6751);
					decimalLiteral();
					}
				}

				setState(6754);
				match(RR_BRACKET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ExpressionOrDefaultContext extends ParserRuleContext {
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public ExpressionOrDefaultContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expressionOrDefault; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExpressionOrDefault(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExpressionOrDefault(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExpressionOrDefault(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionOrDefaultContext expressionOrDefault() throws RecognitionException {
		ExpressionOrDefaultContext _localctx = new ExpressionOrDefaultContext(_ctx, getState());
		enterRule(_localctx, 638, RULE_expressionOrDefault);
		try {
			setState(6759);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1005,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(6757);
				expression(0);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(6758);
				match(DEFAULT);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IfExistsContext extends ParserRuleContext {
		public TerminalNode IF() { return getToken(MySqlParser.IF, 0); }
		public TerminalNode EXISTS() { return getToken(MySqlParser.EXISTS, 0); }
		public IfExistsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_ifExists; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIfExists(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIfExists(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIfExists(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IfExistsContext ifExists() throws RecognitionException {
		IfExistsContext _localctx = new IfExistsContext(_ctx, getState());
		enterRule(_localctx, 640, RULE_ifExists);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6761);
			match(IF);
			setState(6762);
			match(EXISTS);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IfNotExistsContext extends ParserRuleContext {
		public TerminalNode IF() { return getToken(MySqlParser.IF, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode EXISTS() { return getToken(MySqlParser.EXISTS, 0); }
		public IfNotExistsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_ifNotExists; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIfNotExists(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIfNotExists(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIfNotExists(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IfNotExistsContext ifNotExists() throws RecognitionException {
		IfNotExistsContext _localctx = new IfNotExistsContext(_ctx, getState());
		enterRule(_localctx, 642, RULE_ifNotExists);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6764);
			match(IF);
			setState(6765);
			match(NOT);
			setState(6766);
			match(EXISTS);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class OrReplaceContext extends ParserRuleContext {
		public TerminalNode OR() { return getToken(MySqlParser.OR, 0); }
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public OrReplaceContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_orReplace; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOrReplace(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOrReplace(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOrReplace(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OrReplaceContext orReplace() throws RecognitionException {
		OrReplaceContext _localctx = new OrReplaceContext(_ctx, getState());
		enterRule(_localctx, 644, RULE_orReplace);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6768);
			match(OR);
			setState(6769);
			match(REPLACE);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WaitNowaitClauseContext extends ParserRuleContext {
		public TerminalNode WAIT() { return getToken(MySqlParser.WAIT, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode NOWAIT() { return getToken(MySqlParser.NOWAIT, 0); }
		public WaitNowaitClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_waitNowaitClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWaitNowaitClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWaitNowaitClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWaitNowaitClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WaitNowaitClauseContext waitNowaitClause() throws RecognitionException {
		WaitNowaitClauseContext _localctx = new WaitNowaitClauseContext(_ctx, getState());
		enterRule(_localctx, 646, RULE_waitNowaitClause);
		try {
			setState(6774);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case WAIT:
				enterOuterAlt(_localctx, 1);
				{
				setState(6771);
				match(WAIT);
				setState(6772);
				decimalLiteral();
				}
				break;
			case NOWAIT:
				enterOuterAlt(_localctx, 2);
				{
				setState(6773);
				match(NOWAIT);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FunctionCallContext extends ParserRuleContext {
		public FunctionCallContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_functionCall; }
	 
		public FunctionCallContext() { }
		public void copyFrom(FunctionCallContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SpecificFunctionCallContext extends FunctionCallContext {
		public SpecificFunctionContext specificFunction() {
			return getRuleContext(SpecificFunctionContext.class,0);
		}
		public SpecificFunctionCallContext(FunctionCallContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSpecificFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSpecificFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSpecificFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PasswordFunctionCallContext extends FunctionCallContext {
		public PasswordFunctionClauseContext passwordFunctionClause() {
			return getRuleContext(PasswordFunctionClauseContext.class,0);
		}
		public PasswordFunctionCallContext(FunctionCallContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPasswordFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPasswordFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPasswordFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UdfFunctionCallContext extends FunctionCallContext {
		public FullIdContext fullId() {
			return getRuleContext(FullIdContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public FunctionArgsContext functionArgs() {
			return getRuleContext(FunctionArgsContext.class,0);
		}
		public UdfFunctionCallContext(FunctionCallContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUdfFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUdfFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUdfFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NonAggregateFunctionCallContext extends FunctionCallContext {
		public NonAggregateWindowedFunctionContext nonAggregateWindowedFunction() {
			return getRuleContext(NonAggregateWindowedFunctionContext.class,0);
		}
		public NonAggregateFunctionCallContext(FunctionCallContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNonAggregateFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNonAggregateFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNonAggregateFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class AggregateFunctionCallContext extends FunctionCallContext {
		public AggregateWindowedFunctionContext aggregateWindowedFunction() {
			return getRuleContext(AggregateWindowedFunctionContext.class,0);
		}
		public AggregateFunctionCallContext(FunctionCallContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAggregateFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAggregateFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAggregateFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ScalarFunctionCallContext extends FunctionCallContext {
		public ScalarFunctionNameContext scalarFunctionName() {
			return getRuleContext(ScalarFunctionNameContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public FunctionArgsContext functionArgs() {
			return getRuleContext(FunctionArgsContext.class,0);
		}
		public ScalarFunctionCallContext(FunctionCallContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterScalarFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitScalarFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitScalarFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FunctionCallContext functionCall() throws RecognitionException {
		FunctionCallContext _localctx = new FunctionCallContext(_ctx, getState());
		enterRule(_localctx, 648, RULE_functionCall);
		try {
			setState(6794);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1009,_ctx) ) {
			case 1:
				_localctx = new SpecificFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6776);
				specificFunction();
				}
				break;
			case 2:
				_localctx = new AggregateFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6777);
				aggregateWindowedFunction();
				}
				break;
			case 3:
				_localctx = new NonAggregateFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6778);
				nonAggregateWindowedFunction();
				}
				break;
			case 4:
				_localctx = new ScalarFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(6779);
				scalarFunctionName();
				setState(6780);
				match(LR_BRACKET);
				setState(6782);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1007,_ctx) ) {
				case 1:
					{
					setState(6781);
					functionArgs();
					}
					break;
				}
				setState(6784);
				match(RR_BRACKET);
				}
				break;
			case 5:
				_localctx = new UdfFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(6786);
				fullId();
				setState(6787);
				match(LR_BRACKET);
				setState(6789);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1008,_ctx) ) {
				case 1:
					{
					setState(6788);
					functionArgs();
					}
					break;
				}
				setState(6791);
				match(RR_BRACKET);
				}
				break;
			case 6:
				_localctx = new PasswordFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(6793);
				passwordFunctionClause();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class SpecificFunctionContext extends ParserRuleContext {
		public SpecificFunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_specificFunction; }
	 
		public SpecificFunctionContext() { }
		public void copyFrom(SpecificFunctionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PositionFunctionCallContext extends SpecificFunctionContext {
		public StringLiteralContext positionString;
		public ExpressionContext positionExpression;
		public StringLiteralContext inString;
		public ExpressionContext inExpression;
		public TerminalNode POSITION() { return getToken(MySqlParser.POSITION, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List stringLiteral() {
			return getRuleContexts(StringLiteralContext.class);
		}
		public StringLiteralContext stringLiteral(int i) {
			return getRuleContext(StringLiteralContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public PositionFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPositionFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPositionFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPositionFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class TrimFunctionCallContext extends SpecificFunctionContext {
		public Token positioinForm;
		public StringLiteralContext sourceString;
		public ExpressionContext sourceExpression;
		public StringLiteralContext fromString;
		public ExpressionContext fromExpression;
		public TerminalNode TRIM() { return getToken(MySqlParser.TRIM, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode BOTH() { return getToken(MySqlParser.BOTH, 0); }
		public TerminalNode LEADING() { return getToken(MySqlParser.LEADING, 0); }
		public TerminalNode TRAILING() { return getToken(MySqlParser.TRAILING, 0); }
		public List stringLiteral() {
			return getRuleContexts(StringLiteralContext.class);
		}
		public StringLiteralContext stringLiteral(int i) {
			return getRuleContext(StringLiteralContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public TrimFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTrimFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTrimFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTrimFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class JsonValueFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode JSON_VALUE() { return getToken(MySqlParser.JSON_VALUE, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode RETURNING() { return getToken(MySqlParser.RETURNING, 0); }
		public ConvertedDataTypeContext convertedDataType() {
			return getRuleContext(ConvertedDataTypeContext.class,0);
		}
		public JsonOnEmptyContext jsonOnEmpty() {
			return getRuleContext(JsonOnEmptyContext.class,0);
		}
		public JsonOnErrorContext jsonOnError() {
			return getRuleContext(JsonOnErrorContext.class,0);
		}
		public JsonValueFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonValueFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonValueFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonValueFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CaseFunctionCallContext extends SpecificFunctionContext {
		public FunctionArgContext elseArg;
		public TerminalNode CASE() { return getToken(MySqlParser.CASE, 0); }
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List caseFuncAlternative() {
			return getRuleContexts(CaseFuncAlternativeContext.class);
		}
		public CaseFuncAlternativeContext caseFuncAlternative(int i) {
			return getRuleContext(CaseFuncAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MySqlParser.ELSE, 0); }
		public FunctionArgContext functionArg() {
			return getRuleContext(FunctionArgContext.class,0);
		}
		public CaseFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCaseFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCaseFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCaseFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ExtractFunctionCallContext extends SpecificFunctionContext {
		public StringLiteralContext sourceString;
		public ExpressionContext sourceExpression;
		public TerminalNode EXTRACT() { return getToken(MySqlParser.EXTRACT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public IntervalTypeContext intervalType() {
			return getRuleContext(IntervalTypeContext.class,0);
		}
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public ExtractFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExtractFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExtractFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExtractFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class DataTypeFunctionCallContext extends SpecificFunctionContext {
		public Token separator;
		public TerminalNode CONVERT() { return getToken(MySqlParser.CONVERT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public ConvertedDataTypeContext convertedDataType() {
			return getRuleContext(ConvertedDataTypeContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public TerminalNode CAST() { return getToken(MySqlParser.CAST, 0); }
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public DataTypeFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDataTypeFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDataTypeFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDataTypeFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ValuesFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode VALUES() { return getToken(MySqlParser.VALUES, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public ValuesFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterValuesFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitValuesFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitValuesFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CaseExpressionFunctionCallContext extends SpecificFunctionContext {
		public FunctionArgContext elseArg;
		public TerminalNode CASE() { return getToken(MySqlParser.CASE, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public List caseFuncAlternative() {
			return getRuleContexts(CaseFuncAlternativeContext.class);
		}
		public CaseFuncAlternativeContext caseFuncAlternative(int i) {
			return getRuleContext(CaseFuncAlternativeContext.class,i);
		}
		public TerminalNode ELSE() { return getToken(MySqlParser.ELSE, 0); }
		public FunctionArgContext functionArg() {
			return getRuleContext(FunctionArgContext.class,0);
		}
		public CaseExpressionFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCaseExpressionFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCaseExpressionFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCaseExpressionFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CurrentUserContext extends SpecificFunctionContext {
		public CurrentUserExpressionContext currentUserExpression() {
			return getRuleContext(CurrentUserExpressionContext.class,0);
		}
		public CurrentUserContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCurrentUser(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCurrentUser(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCurrentUser(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SimpleFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode CURRENT_DATE() { return getToken(MySqlParser.CURRENT_DATE, 0); }
		public TerminalNode CURRENT_TIME() { return getToken(MySqlParser.CURRENT_TIME, 0); }
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MySqlParser.CURRENT_TIMESTAMP, 0); }
		public TerminalNode LOCALTIME() { return getToken(MySqlParser.LOCALTIME, 0); }
		public TerminalNode UTC_TIMESTAMP() { return getToken(MySqlParser.UTC_TIMESTAMP, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public SimpleFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSimpleFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSimpleFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSimpleFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CharFunctionCallContext extends SpecificFunctionContext {
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public FunctionArgsContext functionArgs() {
			return getRuleContext(FunctionArgsContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode USING() { return getToken(MySqlParser.USING, 0); }
		public CharsetNameContext charsetName() {
			return getRuleContext(CharsetNameContext.class,0);
		}
		public CharFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCharFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCharFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCharFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class WeightFunctionCallContext extends SpecificFunctionContext {
		public Token stringFormat;
		public TerminalNode WEIGHT_STRING() { return getToken(MySqlParser.WEIGHT_STRING, 0); }
		public List LR_BRACKET() { return getTokens(MySqlParser.LR_BRACKET); }
		public TerminalNode LR_BRACKET(int i) {
			return getToken(MySqlParser.LR_BRACKET, i);
		}
		public List RR_BRACKET() { return getTokens(MySqlParser.RR_BRACKET); }
		public TerminalNode RR_BRACKET(int i) {
			return getToken(MySqlParser.RR_BRACKET, i);
		}
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode AS() { return getToken(MySqlParser.AS, 0); }
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public LevelsInWeightStringContext levelsInWeightString() {
			return getRuleContext(LevelsInWeightStringContext.class,0);
		}
		public TerminalNode CHAR() { return getToken(MySqlParser.CHAR, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public WeightFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWeightFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWeightFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWeightFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class GetFormatFunctionCallContext extends SpecificFunctionContext {
		public Token datetimeFormat;
		public TerminalNode GET_FORMAT() { return getToken(MySqlParser.GET_FORMAT, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode COMMA() { return getToken(MySqlParser.COMMA, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode DATE() { return getToken(MySqlParser.DATE, 0); }
		public TerminalNode TIME() { return getToken(MySqlParser.TIME, 0); }
		public TerminalNode DATETIME() { return getToken(MySqlParser.DATETIME, 0); }
		public GetFormatFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterGetFormatFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitGetFormatFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitGetFormatFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SubstrFunctionCallContext extends SpecificFunctionContext {
		public StringLiteralContext sourceString;
		public ExpressionContext sourceExpression;
		public DecimalLiteralContext fromDecimal;
		public ExpressionContext fromExpression;
		public DecimalLiteralContext forDecimal;
		public ExpressionContext forExpression;
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode FROM() { return getToken(MySqlParser.FROM, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode SUBSTR() { return getToken(MySqlParser.SUBSTR, 0); }
		public TerminalNode SUBSTRING() { return getToken(MySqlParser.SUBSTRING, 0); }
		public StringLiteralContext stringLiteral() {
			return getRuleContext(StringLiteralContext.class,0);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode FOR() { return getToken(MySqlParser.FOR, 0); }
		public SubstrFunctionCallContext(SpecificFunctionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubstrFunctionCall(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubstrFunctionCall(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubstrFunctionCall(this);
			else return visitor.visitChildren(this);
		}
	}

	public final SpecificFunctionContext specificFunction() throws RecognitionException {
		SpecificFunctionContext _localctx = new SpecificFunctionContext(_ctx, getState());
		enterRule(_localctx, 650, RULE_specificFunction);
		int _la;
		try {
			setState(6975);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1033,_ctx) ) {
			case 1:
				_localctx = new SimpleFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6796);
				_la = _input.LA(1);
				if ( !(_la==SCHEMA || ((((_la - 313)) & ~0x3f) == 0 && ((1L << (_la - 313)) & 262159L) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6799);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1010,_ctx) ) {
				case 1:
					{
					setState(6797);
					match(LR_BRACKET);
					setState(6798);
					match(RR_BRACKET);
					}
					break;
				}
				}
				break;
			case 2:
				_localctx = new CurrentUserContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6801);
				currentUserExpression();
				}
				break;
			case 3:
				_localctx = new DataTypeFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 3);
				{
				setState(6802);
				match(CONVERT);
				setState(6803);
				match(LR_BRACKET);
				setState(6804);
				expression(0);
				setState(6805);
				((DataTypeFunctionCallContext)_localctx).separator = match(COMMA);
				setState(6806);
				convertedDataType();
				setState(6807);
				match(RR_BRACKET);
				}
				break;
			case 4:
				_localctx = new DataTypeFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 4);
				{
				setState(6809);
				match(CONVERT);
				setState(6810);
				match(LR_BRACKET);
				setState(6811);
				expression(0);
				setState(6812);
				match(USING);
				setState(6813);
				charsetName();
				setState(6814);
				match(RR_BRACKET);
				}
				break;
			case 5:
				_localctx = new DataTypeFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 5);
				{
				setState(6816);
				match(CAST);
				setState(6817);
				match(LR_BRACKET);
				setState(6818);
				expression(0);
				setState(6819);
				match(AS);
				setState(6820);
				convertedDataType();
				setState(6821);
				match(RR_BRACKET);
				}
				break;
			case 6:
				_localctx = new ValuesFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 6);
				{
				setState(6823);
				match(VALUES);
				setState(6824);
				match(LR_BRACKET);
				setState(6825);
				fullColumnName();
				setState(6826);
				match(RR_BRACKET);
				}
				break;
			case 7:
				_localctx = new CaseExpressionFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 7);
				{
				setState(6828);
				match(CASE);
				setState(6829);
				expression(0);
				setState(6831); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(6830);
					caseFuncAlternative();
					}
					}
					setState(6833); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(6837);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(6835);
					match(ELSE);
					setState(6836);
					((CaseExpressionFunctionCallContext)_localctx).elseArg = functionArg();
					}
				}

				setState(6839);
				match(END);
				}
				break;
			case 8:
				_localctx = new CaseFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 8);
				{
				setState(6841);
				match(CASE);
				setState(6843); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(6842);
					caseFuncAlternative();
					}
					}
					setState(6845); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==WHEN );
				setState(6849);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ELSE) {
					{
					setState(6847);
					match(ELSE);
					setState(6848);
					((CaseFunctionCallContext)_localctx).elseArg = functionArg();
					}
				}

				setState(6851);
				match(END);
				}
				break;
			case 9:
				_localctx = new CharFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 9);
				{
				setState(6853);
				match(CHAR);
				setState(6854);
				match(LR_BRACKET);
				setState(6855);
				functionArgs();
				setState(6858);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==USING) {
					{
					setState(6856);
					match(USING);
					setState(6857);
					charsetName();
					}
				}

				setState(6860);
				match(RR_BRACKET);
				}
				break;
			case 10:
				_localctx = new PositionFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 10);
				{
				setState(6862);
				match(POSITION);
				setState(6863);
				match(LR_BRACKET);
				setState(6866);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1016,_ctx) ) {
				case 1:
					{
					setState(6864);
					((PositionFunctionCallContext)_localctx).positionString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6865);
					((PositionFunctionCallContext)_localctx).positionExpression = expression(0);
					}
					break;
				}
				setState(6868);
				match(IN);
				setState(6871);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1017,_ctx) ) {
				case 1:
					{
					setState(6869);
					((PositionFunctionCallContext)_localctx).inString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6870);
					((PositionFunctionCallContext)_localctx).inExpression = expression(0);
					}
					break;
				}
				setState(6873);
				match(RR_BRACKET);
				}
				break;
			case 11:
				_localctx = new SubstrFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 11);
				{
				setState(6875);
				_la = _input.LA(1);
				if ( !(_la==SUBSTR || _la==SUBSTRING) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6876);
				match(LR_BRACKET);
				setState(6879);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1018,_ctx) ) {
				case 1:
					{
					setState(6877);
					((SubstrFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6878);
					((SubstrFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(6881);
				match(FROM);
				setState(6884);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1019,_ctx) ) {
				case 1:
					{
					setState(6882);
					((SubstrFunctionCallContext)_localctx).fromDecimal = decimalLiteral();
					}
					break;
				case 2:
					{
					setState(6883);
					((SubstrFunctionCallContext)_localctx).fromExpression = expression(0);
					}
					break;
				}
				setState(6891);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==FOR) {
					{
					setState(6886);
					match(FOR);
					setState(6889);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1020,_ctx) ) {
					case 1:
						{
						setState(6887);
						((SubstrFunctionCallContext)_localctx).forDecimal = decimalLiteral();
						}
						break;
					case 2:
						{
						setState(6888);
						((SubstrFunctionCallContext)_localctx).forExpression = expression(0);
						}
						break;
					}
					}
				}

				setState(6893);
				match(RR_BRACKET);
				}
				break;
			case 12:
				_localctx = new TrimFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 12);
				{
				setState(6895);
				match(TRIM);
				setState(6896);
				match(LR_BRACKET);
				setState(6897);
				((TrimFunctionCallContext)_localctx).positioinForm = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==BOTH || _la==LEADING || _la==TRAILING) ) {
					((TrimFunctionCallContext)_localctx).positioinForm = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6900);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1022,_ctx) ) {
				case 1:
					{
					setState(6898);
					((TrimFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6899);
					((TrimFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(6902);
				match(FROM);
				setState(6905);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1023,_ctx) ) {
				case 1:
					{
					setState(6903);
					((TrimFunctionCallContext)_localctx).fromString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6904);
					((TrimFunctionCallContext)_localctx).fromExpression = expression(0);
					}
					break;
				}
				setState(6907);
				match(RR_BRACKET);
				}
				break;
			case 13:
				_localctx = new TrimFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 13);
				{
				setState(6909);
				match(TRIM);
				setState(6910);
				match(LR_BRACKET);
				setState(6913);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1024,_ctx) ) {
				case 1:
					{
					setState(6911);
					((TrimFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6912);
					((TrimFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(6915);
				match(FROM);
				setState(6918);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1025,_ctx) ) {
				case 1:
					{
					setState(6916);
					((TrimFunctionCallContext)_localctx).fromString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6917);
					((TrimFunctionCallContext)_localctx).fromExpression = expression(0);
					}
					break;
				}
				setState(6920);
				match(RR_BRACKET);
				}
				break;
			case 14:
				_localctx = new WeightFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 14);
				{
				setState(6922);
				match(WEIGHT_STRING);
				setState(6923);
				match(LR_BRACKET);
				setState(6926);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1026,_ctx) ) {
				case 1:
					{
					setState(6924);
					stringLiteral();
					}
					break;
				case 2:
					{
					setState(6925);
					expression(0);
					}
					break;
				}
				setState(6934);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==AS) {
					{
					setState(6928);
					match(AS);
					setState(6929);
					((WeightFunctionCallContext)_localctx).stringFormat = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==CHAR || _la==BINARY) ) {
						((WeightFunctionCallContext)_localctx).stringFormat = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					setState(6930);
					match(LR_BRACKET);
					setState(6931);
					decimalLiteral();
					setState(6932);
					match(RR_BRACKET);
					}
				}

				setState(6937);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==LEVEL) {
					{
					setState(6936);
					levelsInWeightString();
					}
				}

				setState(6939);
				match(RR_BRACKET);
				}
				break;
			case 15:
				_localctx = new ExtractFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 15);
				{
				setState(6941);
				match(EXTRACT);
				setState(6942);
				match(LR_BRACKET);
				setState(6943);
				intervalType();
				setState(6944);
				match(FROM);
				setState(6947);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1029,_ctx) ) {
				case 1:
					{
					setState(6945);
					((ExtractFunctionCallContext)_localctx).sourceString = stringLiteral();
					}
					break;
				case 2:
					{
					setState(6946);
					((ExtractFunctionCallContext)_localctx).sourceExpression = expression(0);
					}
					break;
				}
				setState(6949);
				match(RR_BRACKET);
				}
				break;
			case 16:
				_localctx = new GetFormatFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 16);
				{
				setState(6951);
				match(GET_FORMAT);
				setState(6952);
				match(LR_BRACKET);
				setState(6953);
				((GetFormatFunctionCallContext)_localctx).datetimeFormat = _input.LT(1);
				_la = _input.LA(1);
				if ( !(((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & 11L) != 0)) ) {
					((GetFormatFunctionCallContext)_localctx).datetimeFormat = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(6954);
				match(COMMA);
				setState(6955);
				stringLiteral();
				setState(6956);
				match(RR_BRACKET);
				}
				break;
			case 17:
				_localctx = new JsonValueFunctionCallContext(_localctx);
				enterOuterAlt(_localctx, 17);
				{
				setState(6958);
				match(JSON_VALUE);
				setState(6959);
				match(LR_BRACKET);
				setState(6960);
				expression(0);
				setState(6961);
				match(COMMA);
				setState(6962);
				expression(0);
				setState(6965);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==RETURNING) {
					{
					setState(6963);
					match(RETURNING);
					setState(6964);
					convertedDataType();
					}
				}

				setState(6968);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1031,_ctx) ) {
				case 1:
					{
					setState(6967);
					jsonOnEmpty();
					}
					break;
				}
				setState(6971);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==DEFAULT || _la==NULL_LITERAL || _la==ERROR) {
					{
					setState(6970);
					jsonOnError();
					}
				}

				setState(6973);
				match(RR_BRACKET);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CaseFuncAlternativeContext extends ParserRuleContext {
		public FunctionArgContext condition;
		public FunctionArgContext consequent;
		public TerminalNode WHEN() { return getToken(MySqlParser.WHEN, 0); }
		public TerminalNode THEN() { return getToken(MySqlParser.THEN, 0); }
		public List functionArg() {
			return getRuleContexts(FunctionArgContext.class);
		}
		public FunctionArgContext functionArg(int i) {
			return getRuleContext(FunctionArgContext.class,i);
		}
		public CaseFuncAlternativeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_caseFuncAlternative; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCaseFuncAlternative(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCaseFuncAlternative(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCaseFuncAlternative(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CaseFuncAlternativeContext caseFuncAlternative() throws RecognitionException {
		CaseFuncAlternativeContext _localctx = new CaseFuncAlternativeContext(_ctx, getState());
		enterRule(_localctx, 652, RULE_caseFuncAlternative);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6977);
			match(WHEN);
			setState(6978);
			((CaseFuncAlternativeContext)_localctx).condition = functionArg();
			setState(6979);
			match(THEN);
			setState(6980);
			((CaseFuncAlternativeContext)_localctx).consequent = functionArg();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LevelsInWeightStringContext extends ParserRuleContext {
		public LevelsInWeightStringContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_levelsInWeightString; }
	 
		public LevelsInWeightStringContext() { }
		public void copyFrom(LevelsInWeightStringContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class LevelWeightRangeContext extends LevelsInWeightStringContext {
		public DecimalLiteralContext firstLevel;
		public DecimalLiteralContext lastLevel;
		public TerminalNode LEVEL() { return getToken(MySqlParser.LEVEL, 0); }
		public TerminalNode MINUS() { return getToken(MySqlParser.MINUS, 0); }
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public LevelWeightRangeContext(LevelsInWeightStringContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLevelWeightRange(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLevelWeightRange(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLevelWeightRange(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class LevelWeightListContext extends LevelsInWeightStringContext {
		public TerminalNode LEVEL() { return getToken(MySqlParser.LEVEL, 0); }
		public List levelInWeightListElement() {
			return getRuleContexts(LevelInWeightListElementContext.class);
		}
		public LevelInWeightListElementContext levelInWeightListElement(int i) {
			return getRuleContext(LevelInWeightListElementContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public LevelWeightListContext(LevelsInWeightStringContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLevelWeightList(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLevelWeightList(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLevelWeightList(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LevelsInWeightStringContext levelsInWeightString() throws RecognitionException {
		LevelsInWeightStringContext _localctx = new LevelsInWeightStringContext(_ctx, getState());
		enterRule(_localctx, 654, RULE_levelsInWeightString);
		int _la;
		try {
			setState(6996);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1035,_ctx) ) {
			case 1:
				_localctx = new LevelWeightListContext(_localctx);
				enterOuterAlt(_localctx, 1);
				{
				setState(6982);
				match(LEVEL);
				setState(6983);
				levelInWeightListElement();
				setState(6988);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(6984);
					match(COMMA);
					setState(6985);
					levelInWeightListElement();
					}
					}
					setState(6990);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				}
				break;
			case 2:
				_localctx = new LevelWeightRangeContext(_localctx);
				enterOuterAlt(_localctx, 2);
				{
				setState(6991);
				match(LEVEL);
				setState(6992);
				((LevelWeightRangeContext)_localctx).firstLevel = decimalLiteral();
				setState(6993);
				match(MINUS);
				setState(6994);
				((LevelWeightRangeContext)_localctx).lastLevel = decimalLiteral();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LevelInWeightListElementContext extends ParserRuleContext {
		public Token orderType;
		public DecimalLiteralContext decimalLiteral() {
			return getRuleContext(DecimalLiteralContext.class,0);
		}
		public TerminalNode ASC() { return getToken(MySqlParser.ASC, 0); }
		public TerminalNode DESC() { return getToken(MySqlParser.DESC, 0); }
		public TerminalNode REVERSE() { return getToken(MySqlParser.REVERSE, 0); }
		public LevelInWeightListElementContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_levelInWeightListElement; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLevelInWeightListElement(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLevelInWeightListElement(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLevelInWeightListElement(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LevelInWeightListElementContext levelInWeightListElement() throws RecognitionException {
		LevelInWeightListElementContext _localctx = new LevelInWeightListElementContext(_ctx, getState());
		enterRule(_localctx, 656, RULE_levelInWeightListElement);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(6998);
			decimalLiteral();
			setState(7000);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ASC || _la==DESC || _la==REVERSE) {
				{
				setState(6999);
				((LevelInWeightListElementContext)_localctx).orderType = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==ASC || _la==DESC || _la==REVERSE) ) {
					((LevelInWeightListElementContext)_localctx).orderType = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AggregateWindowedFunctionContext extends ParserRuleContext {
		public Token aggregator;
		public Token starArg;
		public Token separator;
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public FunctionArgContext functionArg() {
			return getRuleContext(FunctionArgContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode AVG() { return getToken(MySqlParser.AVG, 0); }
		public TerminalNode MAX() { return getToken(MySqlParser.MAX, 0); }
		public TerminalNode MIN() { return getToken(MySqlParser.MIN, 0); }
		public TerminalNode SUM() { return getToken(MySqlParser.SUM, 0); }
		public OverClauseContext overClause() {
			return getRuleContext(OverClauseContext.class,0);
		}
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode DISTINCT() { return getToken(MySqlParser.DISTINCT, 0); }
		public TerminalNode COUNT() { return getToken(MySqlParser.COUNT, 0); }
		public FunctionArgsContext functionArgs() {
			return getRuleContext(FunctionArgsContext.class,0);
		}
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public TerminalNode BIT_AND() { return getToken(MySqlParser.BIT_AND, 0); }
		public TerminalNode BIT_OR() { return getToken(MySqlParser.BIT_OR, 0); }
		public TerminalNode BIT_XOR() { return getToken(MySqlParser.BIT_XOR, 0); }
		public TerminalNode STD() { return getToken(MySqlParser.STD, 0); }
		public TerminalNode STDDEV() { return getToken(MySqlParser.STDDEV, 0); }
		public TerminalNode STDDEV_POP() { return getToken(MySqlParser.STDDEV_POP, 0); }
		public TerminalNode STDDEV_SAMP() { return getToken(MySqlParser.STDDEV_SAMP, 0); }
		public TerminalNode VAR_POP() { return getToken(MySqlParser.VAR_POP, 0); }
		public TerminalNode VAR_SAMP() { return getToken(MySqlParser.VAR_SAMP, 0); }
		public TerminalNode VARIANCE() { return getToken(MySqlParser.VARIANCE, 0); }
		public TerminalNode GROUP_CONCAT() { return getToken(MySqlParser.GROUP_CONCAT, 0); }
		public TerminalNode ORDER() { return getToken(MySqlParser.ORDER, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public List orderByExpression() {
			return getRuleContexts(OrderByExpressionContext.class);
		}
		public OrderByExpressionContext orderByExpression(int i) {
			return getRuleContext(OrderByExpressionContext.class,i);
		}
		public TerminalNode SEPARATOR() { return getToken(MySqlParser.SEPARATOR, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public AggregateWindowedFunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_aggregateWindowedFunction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAggregateWindowedFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAggregateWindowedFunction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAggregateWindowedFunction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AggregateWindowedFunctionContext aggregateWindowedFunction() throws RecognitionException {
		AggregateWindowedFunctionContext _localctx = new AggregateWindowedFunctionContext(_ctx, getState());
		enterRule(_localctx, 658, RULE_aggregateWindowedFunction);
		int _la;
		try {
			setState(7061);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case AVG:
			case MAX:
			case MIN:
			case SUM:
				enterOuterAlt(_localctx, 1);
				{
				setState(7002);
				_la = _input.LA(1);
				if ( !(((((_la - 286)) & ~0x3f) == 0 && ((1L << (_la - 286)) & 8400897L) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7003);
				match(LR_BRACKET);
				setState(7005);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1037,_ctx) ) {
				case 1:
					{
					setState(7004);
					((AggregateWindowedFunctionContext)_localctx).aggregator = _input.LT(1);
					_la = _input.LA(1);
					if ( !(_la==ALL || _la==DISTINCT) ) {
						((AggregateWindowedFunctionContext)_localctx).aggregator = (Token)_errHandler.recoverInline(this);
					}
					else {
						if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
						_errHandler.reportMatch(this);
						consume();
					}
					}
					break;
				}
				setState(7007);
				functionArg();
				setState(7008);
				match(RR_BRACKET);
				setState(7010);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1038,_ctx) ) {
				case 1:
					{
					setState(7009);
					overClause();
					}
					break;
				}
				}
				break;
			case COUNT:
				enterOuterAlt(_localctx, 2);
				{
				setState(7012);
				match(COUNT);
				setState(7013);
				match(LR_BRACKET);
				setState(7021);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1040,_ctx) ) {
				case 1:
					{
					setState(7014);
					((AggregateWindowedFunctionContext)_localctx).starArg = match(STAR);
					}
					break;
				case 2:
					{
					setState(7016);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1039,_ctx) ) {
					case 1:
						{
						setState(7015);
						((AggregateWindowedFunctionContext)_localctx).aggregator = match(ALL);
						}
						break;
					}
					setState(7018);
					functionArg();
					}
					break;
				case 3:
					{
					setState(7019);
					((AggregateWindowedFunctionContext)_localctx).aggregator = match(DISTINCT);
					setState(7020);
					functionArgs();
					}
					break;
				}
				setState(7023);
				match(RR_BRACKET);
				setState(7025);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1041,_ctx) ) {
				case 1:
					{
					setState(7024);
					overClause();
					}
					break;
				}
				}
				break;
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
				enterOuterAlt(_localctx, 3);
				{
				setState(7027);
				_la = _input.LA(1);
				if ( !(((((_la - 287)) & ~0x3f) == 0 && ((1L << (_la - 287)) & 62652423L) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7028);
				match(LR_BRACKET);
				setState(7030);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1042,_ctx) ) {
				case 1:
					{
					setState(7029);
					((AggregateWindowedFunctionContext)_localctx).aggregator = match(ALL);
					}
					break;
				}
				setState(7032);
				functionArg();
				setState(7033);
				match(RR_BRACKET);
				setState(7035);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1043,_ctx) ) {
				case 1:
					{
					setState(7034);
					overClause();
					}
					break;
				}
				}
				break;
			case GROUP_CONCAT:
				enterOuterAlt(_localctx, 4);
				{
				setState(7037);
				match(GROUP_CONCAT);
				setState(7038);
				match(LR_BRACKET);
				setState(7040);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1044,_ctx) ) {
				case 1:
					{
					setState(7039);
					((AggregateWindowedFunctionContext)_localctx).aggregator = match(DISTINCT);
					}
					break;
				}
				setState(7042);
				functionArgs();
				setState(7053);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==ORDER) {
					{
					setState(7043);
					match(ORDER);
					setState(7044);
					match(BY);
					setState(7045);
					orderByExpression();
					setState(7050);
					_errHandler.sync(this);
					_la = _input.LA(1);
					while (_la==COMMA) {
						{
						{
						setState(7046);
						match(COMMA);
						setState(7047);
						orderByExpression();
						}
						}
						setState(7052);
						_errHandler.sync(this);
						_la = _input.LA(1);
					}
					}
				}

				setState(7057);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==SEPARATOR) {
					{
					setState(7055);
					match(SEPARATOR);
					setState(7056);
					((AggregateWindowedFunctionContext)_localctx).separator = match(STRING_LITERAL);
					}
				}

				setState(7059);
				match(RR_BRACKET);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class NonAggregateWindowedFunctionContext extends ParserRuleContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public OverClauseContext overClause() {
			return getRuleContext(OverClauseContext.class,0);
		}
		public TerminalNode LAG() { return getToken(MySqlParser.LAG, 0); }
		public TerminalNode LEAD() { return getToken(MySqlParser.LEAD, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public List decimalLiteral() {
			return getRuleContexts(DecimalLiteralContext.class);
		}
		public DecimalLiteralContext decimalLiteral(int i) {
			return getRuleContext(DecimalLiteralContext.class,i);
		}
		public TerminalNode FIRST_VALUE() { return getToken(MySqlParser.FIRST_VALUE, 0); }
		public TerminalNode LAST_VALUE() { return getToken(MySqlParser.LAST_VALUE, 0); }
		public TerminalNode CUME_DIST() { return getToken(MySqlParser.CUME_DIST, 0); }
		public TerminalNode DENSE_RANK() { return getToken(MySqlParser.DENSE_RANK, 0); }
		public TerminalNode PERCENT_RANK() { return getToken(MySqlParser.PERCENT_RANK, 0); }
		public TerminalNode RANK() { return getToken(MySqlParser.RANK, 0); }
		public TerminalNode ROW_NUMBER() { return getToken(MySqlParser.ROW_NUMBER, 0); }
		public TerminalNode NTH_VALUE() { return getToken(MySqlParser.NTH_VALUE, 0); }
		public TerminalNode NTILE() { return getToken(MySqlParser.NTILE, 0); }
		public NonAggregateWindowedFunctionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_nonAggregateWindowedFunction; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNonAggregateWindowedFunction(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNonAggregateWindowedFunction(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNonAggregateWindowedFunction(this);
			else return visitor.visitChildren(this);
		}
	}

	public final NonAggregateWindowedFunctionContext nonAggregateWindowedFunction() throws RecognitionException {
		NonAggregateWindowedFunctionContext _localctx = new NonAggregateWindowedFunctionContext(_ctx, getState());
		enterRule(_localctx, 660, RULE_nonAggregateWindowedFunction);
		int _la;
		try {
			setState(7101);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LAG:
			case LEAD:
				enterOuterAlt(_localctx, 1);
				{
				setState(7063);
				_la = _input.LA(1);
				if ( !(_la==LAG || _la==LEAD) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7064);
				match(LR_BRACKET);
				setState(7065);
				expression(0);
				setState(7068);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1049,_ctx) ) {
				case 1:
					{
					setState(7066);
					match(COMMA);
					setState(7067);
					decimalLiteral();
					}
					break;
				}
				setState(7072);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==COMMA) {
					{
					setState(7070);
					match(COMMA);
					setState(7071);
					decimalLiteral();
					}
				}

				setState(7074);
				match(RR_BRACKET);
				setState(7075);
				overClause();
				}
				break;
			case FIRST_VALUE:
			case LAST_VALUE:
				enterOuterAlt(_localctx, 2);
				{
				setState(7077);
				_la = _input.LA(1);
				if ( !(_la==FIRST_VALUE || _la==LAST_VALUE) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7078);
				match(LR_BRACKET);
				setState(7079);
				expression(0);
				setState(7080);
				match(RR_BRACKET);
				setState(7081);
				overClause();
				}
				break;
			case CUME_DIST:
			case DENSE_RANK:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
				enterOuterAlt(_localctx, 3);
				{
				setState(7083);
				_la = _input.LA(1);
				if ( !(((((_la - 291)) & ~0x3f) == 0 && ((1L << (_la - 291)) & 14339L) != 0)) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7084);
				match(LR_BRACKET);
				setState(7085);
				match(RR_BRACKET);
				setState(7086);
				overClause();
				}
				break;
			case NTH_VALUE:
				enterOuterAlt(_localctx, 4);
				{
				setState(7087);
				match(NTH_VALUE);
				setState(7088);
				match(LR_BRACKET);
				setState(7089);
				expression(0);
				setState(7090);
				match(COMMA);
				setState(7091);
				decimalLiteral();
				setState(7092);
				match(RR_BRACKET);
				setState(7093);
				overClause();
				}
				break;
			case NTILE:
				enterOuterAlt(_localctx, 5);
				{
				setState(7095);
				match(NTILE);
				setState(7096);
				match(LR_BRACKET);
				setState(7097);
				decimalLiteral();
				setState(7098);
				match(RR_BRACKET);
				setState(7099);
				overClause();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class OverClauseContext extends ParserRuleContext {
		public TerminalNode OVER() { return getToken(MySqlParser.OVER, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public WindowSpecContext windowSpec() {
			return getRuleContext(WindowSpecContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public WindowNameContext windowName() {
			return getRuleContext(WindowNameContext.class,0);
		}
		public OverClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_overClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterOverClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitOverClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitOverClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final OverClauseContext overClause() throws RecognitionException {
		OverClauseContext _localctx = new OverClauseContext(_ctx, getState());
		enterRule(_localctx, 662, RULE_overClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7103);
			match(OVER);
			setState(7109);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LR_BRACKET:
				{
				setState(7104);
				match(LR_BRACKET);
				setState(7105);
				windowSpec();
				setState(7106);
				match(RR_BRACKET);
				}
				break;
			case ARRAY:
			case ATTRIBUTE:
			case BUCKETS:
			case CONDITION:
			case CURRENT:
			case CURRENT_USER:
			case DATABASE:
			case DEFAULT:
			case DIAGNOSTICS:
			case EMPTY:
			case ENFORCED:
			case EXCEPT:
			case GROUP:
			case IF:
			case IGNORED:
			case INSERT:
			case LATERAL:
			case LEFT:
			case NUMBER:
			case OPTIONAL:
			case ORDER:
			case PRIMARY:
			case REPEAT:
			case REPLACE:
			case RIGHT:
			case SCHEMA:
			case SKIP_QUERY_REWRITE:
			case STACKED:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case DATETIME:
			case YEAR:
			case BINARY:
			case TEXT:
			case ENUM:
			case SERIAL:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case NESTED:
			case ORDINALITY:
			case PATH:
			case AVG:
			case BIT_AND:
			case BIT_OR:
			case BIT_XOR:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case GROUP_CONCAT:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case MAX:
			case MIN:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case STD:
			case STDDEV:
			case STDDEV_POP:
			case STDDEV_SAMP:
			case SUM:
			case VAR_POP:
			case VAR_SAMP:
			case VARIANCE:
			case CURRENT_DATE:
			case CURRENT_TIME:
			case CURRENT_TIMESTAMP:
			case LOCALTIME:
			case CURDATE:
			case CURTIME:
			case DATE_ADD:
			case DATE_SUB:
			case LOCALTIMESTAMP:
			case NOW:
			case POSITION:
			case SUBSTR:
			case SUBSTRING:
			case SYSDATE:
			case TRIM:
			case UTC_DATE:
			case UTC_TIME:
			case UTC_TIMESTAMP:
			case ACCOUNT:
			case ACTION:
			case AFTER:
			case AGGREGATE:
			case ALGORITHM:
			case ANY:
			case AT:
			case AUTHORS:
			case AUTOCOMMIT:
			case AUTOEXTEND_SIZE:
			case AUTO_INCREMENT:
			case AVG_ROW_LENGTH:
			case BEGIN:
			case BINLOG:
			case BIT:
			case BLOCK:
			case BOOL:
			case BOOLEAN:
			case BTREE:
			case CACHE:
			case CASCADED:
			case CHAIN:
			case CHANGED:
			case CHANNEL:
			case CHECKSUM:
			case PAGE_CHECKSUM:
			case CIPHER:
			case CLASS_ORIGIN:
			case CLIENT:
			case CLOSE:
			case CLUSTERING:
			case COALESCE:
			case CODE:
			case COLUMNS:
			case COLUMN_FORMAT:
			case COLUMN_NAME:
			case COMMENT:
			case COMMIT:
			case COMPACT:
			case COMPLETION:
			case COMPRESSED:
			case COMPRESSION:
			case CONCURRENT:
			case CONNECT:
			case CONNECTION:
			case CONSISTENT:
			case CONSTRAINT_CATALOG:
			case CONSTRAINT_SCHEMA:
			case CONSTRAINT_NAME:
			case CONTAINS:
			case CONTEXT:
			case CONTRIBUTORS:
			case COPY:
			case CPU:
			case CURSOR_NAME:
			case DATA:
			case DATAFILE:
			case DEALLOCATE:
			case DEFAULT_AUTH:
			case DEFINER:
			case DELAY_KEY_WRITE:
			case DES_KEY_FILE:
			case DIRECTORY:
			case DISABLE:
			case DISCARD:
			case DISK:
			case DO:
			case DUMPFILE:
			case DUPLICATE:
			case DYNAMIC:
			case ENABLE:
			case ENCRYPTION:
			case END:
			case ENDS:
			case ENGINE:
			case ENGINES:
			case ERROR:
			case ERRORS:
			case ESCAPE:
			case EVEN:
			case EVENT:
			case EVENTS:
			case EVERY:
			case EXCHANGE:
			case EXCLUSIVE:
			case EXPIRE:
			case EXPORT:
			case EXTENDED:
			case EXTENT_SIZE:
			case FAILED_LOGIN_ATTEMPTS:
			case FAST:
			case FAULTS:
			case FIELDS:
			case FILE_BLOCK_SIZE:
			case FILTER:
			case FIRST:
			case FIXED:
			case FLUSH:
			case FOLLOWS:
			case FOUND:
			case FULL:
			case FUNCTION:
			case GENERAL:
			case GLOBAL:
			case GRANTS:
			case GROUP_REPLICATION:
			case HANDLER:
			case HASH:
			case HELP:
			case HISTORY:
			case HOST:
			case HOSTS:
			case IDENTIFIED:
			case IGNORE_SERVER_IDS:
			case IMPORT:
			case INDEXES:
			case INITIAL_SIZE:
			case INPLACE:
			case INSERT_METHOD:
			case INSTALL:
			case INSTANCE:
			case INSTANT:
			case INVISIBLE:
			case INVOKER:
			case IO:
			case IO_THREAD:
			case IPC:
			case ISOLATION:
			case ISSUER:
			case JSON:
			case KEY_BLOCK_SIZE:
			case LANGUAGE:
			case LAST:
			case LEAVES:
			case LESS:
			case LEVEL:
			case LIST:
			case LOCAL:
			case LOGFILE:
			case LOGS:
			case MASTER:
			case MASTER_AUTO_POSITION:
			case MASTER_CONNECT_RETRY:
			case MASTER_DELAY:
			case MASTER_HEARTBEAT_PERIOD:
			case MASTER_HOST:
			case MASTER_LOG_FILE:
			case MASTER_LOG_POS:
			case MASTER_PASSWORD:
			case MASTER_PORT:
			case MASTER_RETRY_COUNT:
			case MASTER_SSL:
			case MASTER_SSL_CA:
			case MASTER_SSL_CAPATH:
			case MASTER_SSL_CERT:
			case MASTER_SSL_CIPHER:
			case MASTER_SSL_CRL:
			case MASTER_SSL_CRLPATH:
			case MASTER_SSL_KEY:
			case MASTER_TLS_VERSION:
			case MASTER_USER:
			case MAX_CONNECTIONS_PER_HOUR:
			case MAX_QUERIES_PER_HOUR:
			case MAX_ROWS:
			case MAX_SIZE:
			case MAX_UPDATES_PER_HOUR:
			case MAX_USER_CONNECTIONS:
			case MEDIUM:
			case MEMBER:
			case MERGE:
			case MESSAGE_TEXT:
			case MID:
			case MIGRATE:
			case MIN_ROWS:
			case MODE:
			case MODIFY:
			case MUTEX:
			case MYSQL:
			case MYSQL_ERRNO:
			case NAME:
			case NAMES:
			case NCHAR:
			case NEVER:
			case NEXT:
			case NO:
			case NOCOPY:
			case NOWAIT:
			case NODEGROUP:
			case NONE:
			case ODBC:
			case OFFLINE:
			case OFFSET:
			case OF:
			case OJ:
			case OLD_PASSWORD:
			case ONE:
			case ONLINE:
			case ONLY:
			case OPEN:
			case OPTIMIZER_COSTS:
			case OPTIONS:
			case OWNER:
			case PACK_KEYS:
			case PAGE:
			case PARSER:
			case PARTIAL:
			case PARTITIONING:
			case PARTITIONS:
			case PASSWORD:
			case PASSWORD_LOCK_TIME:
			case PHASE:
			case PLUGIN:
			case PLUGIN_DIR:
			case PLUGINS:
			case PORT:
			case PRECEDES:
			case PREPARE:
			case PRESERVE:
			case PREV:
			case PROCESSLIST:
			case PROFILE:
			case PROFILES:
			case PROXY:
			case QUERY:
			case QUICK:
			case REBUILD:
			case RECOVER:
			case RECURSIVE:
			case REDO_BUFFER_SIZE:
			case REDUNDANT:
			case RELAY:
			case RELAY_LOG_FILE:
			case RELAY_LOG_POS:
			case RELAYLOG:
			case REMOVE:
			case REORGANIZE:
			case REPAIR:
			case REPLICATE_DO_DB:
			case REPLICATE_DO_TABLE:
			case REPLICATE_IGNORE_DB:
			case REPLICATE_IGNORE_TABLE:
			case REPLICATE_REWRITE_DB:
			case REPLICATE_WILD_DO_TABLE:
			case REPLICATE_WILD_IGNORE_TABLE:
			case REPLICATION:
			case RESET:
			case RESUME:
			case RETURNED_SQLSTATE:
			case RETURNS:
			case REUSE:
			case ROLE:
			case ROLLBACK:
			case ROLLUP:
			case ROTATE:
			case ROW:
			case ROWS:
			case ROW_FORMAT:
			case RTREE:
			case SAVEPOINT:
			case SCHEDULE:
			case SECURITY:
			case SERVER:
			case SESSION:
			case SHARE:
			case SHARED:
			case SIGNED:
			case SIMPLE:
			case SLAVE:
			case SLOW:
			case SNAPSHOT:
			case SOCKET:
			case SOME:
			case SONAME:
			case SOUNDS:
			case SOURCE:
			case SQL_AFTER_GTIDS:
			case SQL_AFTER_MTS_GAPS:
			case SQL_BEFORE_GTIDS:
			case SQL_BUFFER_RESULT:
			case SQL_CACHE:
			case SQL_NO_CACHE:
			case SQL_THREAD:
			case START:
			case STARTS:
			case STATS_AUTO_RECALC:
			case STATS_PERSISTENT:
			case STATS_SAMPLE_PAGES:
			case STATUS:
			case STOP:
			case STORAGE:
			case STRING:
			case SUBCLASS_ORIGIN:
			case SUBJECT:
			case SUBPARTITION:
			case SUBPARTITIONS:
			case SUSPEND:
			case SWAPS:
			case SWITCHES:
			case TABLE_NAME:
			case TABLESPACE:
			case TABLE_TYPE:
			case TEMPORARY:
			case TEMPTABLE:
			case THAN:
			case TRADITIONAL:
			case TRANSACTION:
			case TRANSACTIONAL:
			case TRIGGERS:
			case TRUNCATE:
			case UNBOUNDED:
			case UNDEFINED:
			case UNDOFILE:
			case UNDO_BUFFER_SIZE:
			case UNINSTALL:
			case UNKNOWN:
			case UNTIL:
			case UPGRADE:
			case USER:
			case USE_FRM:
			case USER_RESOURCES:
			case VALIDATION:
			case VALUE:
			case VARIABLES:
			case VIEW:
			case VIRTUAL:
			case VISIBLE:
			case WAIT:
			case WARNINGS:
			case WITHOUT:
			case WORK:
			case WRAPPER:
			case X509:
			case XA:
			case XML:
			case EUR:
			case USA:
			case JIS:
			case ISO:
			case INTERNAL:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case ADMIN:
			case AUDIT_ABORT_EXEMPT:
			case AUDIT_ADMIN:
			case AUTHENTICATION_POLICY_ADMIN:
			case BACKUP_ADMIN:
			case BINLOG_ADMIN:
			case BINLOG_ENCRYPTION_ADMIN:
			case CLONE_ADMIN:
			case CONNECTION_ADMIN:
			case ENCRYPTION_KEY_ADMIN:
			case EXECUTE:
			case FILE:
			case FIREWALL_ADMIN:
			case FIREWALL_EXEMPT:
			case FIREWALL_USER:
			case GROUP_REPLICATION_ADMIN:
			case INNODB_REDO_LOG_ARCHIVE:
			case INVOKE:
			case LAMBDA:
			case NDB_STORED_USER:
			case PASSWORDLESS_USER_ADMIN:
			case PERSIST_RO_VARIABLES_ADMIN:
			case PRIVILEGES:
			case PROCESS:
			case RELOAD:
			case REPLICATION_APPLIER:
			case REPLICATION_SLAVE_ADMIN:
			case RESOURCE_GROUP_ADMIN:
			case RESOURCE_GROUP_USER:
			case ROLE_ADMIN:
			case ROUTINE:
			case S3:
			case SESSION_VARIABLES_ADMIN:
			case SET_USER_ID:
			case SHOW_ROUTINE:
			case SHUTDOWN:
			case SUPER:
			case SYSTEM_VARIABLES_ADMIN:
			case TABLES:
			case TABLE_ENCRYPTION_ADMIN:
			case VERSION_TOKEN_ADMIN:
			case XA_RECOVER_ADMIN:
			case ARMSCII8:
			case ASCII:
			case BIG5:
			case CP1250:
			case CP1251:
			case CP1256:
			case CP1257:
			case CP850:
			case CP852:
			case CP866:
			case CP932:
			case DEC8:
			case EUCJPMS:
			case EUCKR:
			case GB18030:
			case GB2312:
			case GBK:
			case GEOSTD8:
			case GREEK:
			case HEBREW:
			case HP8:
			case KEYBCS2:
			case KOI8R:
			case KOI8U:
			case LATIN1:
			case LATIN2:
			case LATIN5:
			case LATIN7:
			case MACCE:
			case MACROMAN:
			case SJIS:
			case SWE7:
			case TIS620:
			case UCS2:
			case UJIS:
			case UTF16:
			case UTF16LE:
			case UTF32:
			case UTF8:
			case UTF8MB3:
			case UTF8MB4:
			case ARCHIVE:
			case BLACKHOLE:
			case CSV:
			case FEDERATED:
			case INNODB:
			case MEMORY:
			case MRG_MYISAM:
			case MYISAM:
			case NDB:
			case NDBCLUSTER:
			case PERFORMANCE_SCHEMA:
			case TOKUDB:
			case REPEATABLE:
			case COMMITTED:
			case UNCOMMITTED:
			case SERIALIZABLE:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CATALOG_NAME:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENGINE_ATTRIBUTE:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SECONDARY_ENGINE_ATTRIBUTE:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SCHEMA_NAME:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case TP_CONNECTION_ADMIN:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
			case CHARSET_REVERSE_QOUTE_STRING:
			case STRING_LITERAL:
			case ID:
				{
				setState(7108);
				windowName();
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WindowSpecContext extends ParserRuleContext {
		public WindowNameContext windowName() {
			return getRuleContext(WindowNameContext.class,0);
		}
		public PartitionClauseContext partitionClause() {
			return getRuleContext(PartitionClauseContext.class,0);
		}
		public OrderByClauseContext orderByClause() {
			return getRuleContext(OrderByClauseContext.class,0);
		}
		public FrameClauseContext frameClause() {
			return getRuleContext(FrameClauseContext.class,0);
		}
		public WindowSpecContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_windowSpec; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWindowSpec(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWindowSpec(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWindowSpec(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WindowSpecContext windowSpec() throws RecognitionException {
		WindowSpecContext _localctx = new WindowSpecContext(_ctx, getState());
		enterRule(_localctx, 664, RULE_windowSpec);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7112);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1053,_ctx) ) {
			case 1:
				{
				setState(7111);
				windowName();
				}
				break;
			}
			setState(7115);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==PARTITION) {
				{
				setState(7114);
				partitionClause();
				}
			}

			setState(7118);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==ORDER) {
				{
				setState(7117);
				orderByClause();
				}
			}

			setState(7121);
			_errHandler.sync(this);
			_la = _input.LA(1);
			if (_la==RANGE || _la==ROWS) {
				{
				setState(7120);
				frameClause();
				}
			}

			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class WindowNameContext extends ParserRuleContext {
		public UidContext uid() {
			return getRuleContext(UidContext.class,0);
		}
		public WindowNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_windowName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterWindowName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitWindowName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitWindowName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final WindowNameContext windowName() throws RecognitionException {
		WindowNameContext _localctx = new WindowNameContext(_ctx, getState());
		enterRule(_localctx, 666, RULE_windowName);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7123);
			uid();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FrameClauseContext extends ParserRuleContext {
		public FrameUnitsContext frameUnits() {
			return getRuleContext(FrameUnitsContext.class,0);
		}
		public FrameExtentContext frameExtent() {
			return getRuleContext(FrameExtentContext.class,0);
		}
		public FrameClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_frameClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFrameClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFrameClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFrameClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FrameClauseContext frameClause() throws RecognitionException {
		FrameClauseContext _localctx = new FrameClauseContext(_ctx, getState());
		enterRule(_localctx, 668, RULE_frameClause);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7125);
			frameUnits();
			setState(7126);
			frameExtent();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FrameUnitsContext extends ParserRuleContext {
		public TerminalNode ROWS() { return getToken(MySqlParser.ROWS, 0); }
		public TerminalNode RANGE() { return getToken(MySqlParser.RANGE, 0); }
		public FrameUnitsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_frameUnits; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFrameUnits(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFrameUnits(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFrameUnits(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FrameUnitsContext frameUnits() throws RecognitionException {
		FrameUnitsContext _localctx = new FrameUnitsContext(_ctx, getState());
		enterRule(_localctx, 670, RULE_frameUnits);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7128);
			_la = _input.LA(1);
			if ( !(_la==RANGE || _la==ROWS) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FrameExtentContext extends ParserRuleContext {
		public FrameRangeContext frameRange() {
			return getRuleContext(FrameRangeContext.class,0);
		}
		public FrameBetweenContext frameBetween() {
			return getRuleContext(FrameBetweenContext.class,0);
		}
		public FrameExtentContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_frameExtent; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFrameExtent(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFrameExtent(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFrameExtent(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FrameExtentContext frameExtent() throws RecognitionException {
		FrameExtentContext _localctx = new FrameExtentContext(_ctx, getState());
		enterRule(_localctx, 672, RULE_frameExtent);
		try {
			setState(7132);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1057,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7130);
				frameRange();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7131);
				frameBetween();
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FrameBetweenContext extends ParserRuleContext {
		public TerminalNode BETWEEN() { return getToken(MySqlParser.BETWEEN, 0); }
		public List frameRange() {
			return getRuleContexts(FrameRangeContext.class);
		}
		public FrameRangeContext frameRange(int i) {
			return getRuleContext(FrameRangeContext.class,i);
		}
		public TerminalNode AND() { return getToken(MySqlParser.AND, 0); }
		public FrameBetweenContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_frameBetween; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFrameBetween(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFrameBetween(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFrameBetween(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FrameBetweenContext frameBetween() throws RecognitionException {
		FrameBetweenContext _localctx = new FrameBetweenContext(_ctx, getState());
		enterRule(_localctx, 674, RULE_frameBetween);
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7134);
			match(BETWEEN);
			setState(7135);
			frameRange();
			setState(7136);
			match(AND);
			setState(7137);
			frameRange();
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FrameRangeContext extends ParserRuleContext {
		public TerminalNode CURRENT() { return getToken(MySqlParser.CURRENT, 0); }
		public TerminalNode ROW() { return getToken(MySqlParser.ROW, 0); }
		public TerminalNode UNBOUNDED() { return getToken(MySqlParser.UNBOUNDED, 0); }
		public TerminalNode PRECEDING() { return getToken(MySqlParser.PRECEDING, 0); }
		public TerminalNode FOLLOWING() { return getToken(MySqlParser.FOLLOWING, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public FrameRangeContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_frameRange; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFrameRange(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFrameRange(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFrameRange(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FrameRangeContext frameRange() throws RecognitionException {
		FrameRangeContext _localctx = new FrameRangeContext(_ctx, getState());
		enterRule(_localctx, 676, RULE_frameRange);
		int _la;
		try {
			setState(7146);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1058,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7139);
				match(CURRENT);
				setState(7140);
				match(ROW);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7141);
				match(UNBOUNDED);
				setState(7142);
				_la = _input.LA(1);
				if ( !(_la==FOLLOWING || _la==PRECEDING) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(7143);
				expression(0);
				setState(7144);
				_la = _input.LA(1);
				if ( !(_la==FOLLOWING || _la==PRECEDING) ) {
				_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PartitionClauseContext extends ParserRuleContext {
		public TerminalNode PARTITION() { return getToken(MySqlParser.PARTITION, 0); }
		public TerminalNode BY() { return getToken(MySqlParser.BY, 0); }
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public PartitionClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_partitionClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPartitionClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPartitionClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPartitionClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PartitionClauseContext partitionClause() throws RecognitionException {
		PartitionClauseContext _localctx = new PartitionClauseContext(_ctx, getState());
		enterRule(_localctx, 678, RULE_partitionClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7148);
			match(PARTITION);
			setState(7149);
			match(BY);
			setState(7150);
			expression(0);
			setState(7155);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(7151);
				match(COMMA);
				setState(7152);
				expression(0);
				}
				}
				setState(7157);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ScalarFunctionNameContext extends ParserRuleContext {
		public FunctionNameBaseContext functionNameBase() {
			return getRuleContext(FunctionNameBaseContext.class,0);
		}
		public TerminalNode ASCII() { return getToken(MySqlParser.ASCII, 0); }
		public TerminalNode CURDATE() { return getToken(MySqlParser.CURDATE, 0); }
		public TerminalNode CURRENT_DATE() { return getToken(MySqlParser.CURRENT_DATE, 0); }
		public TerminalNode CURRENT_TIME() { return getToken(MySqlParser.CURRENT_TIME, 0); }
		public TerminalNode CURRENT_TIMESTAMP() { return getToken(MySqlParser.CURRENT_TIMESTAMP, 0); }
		public TerminalNode CURTIME() { return getToken(MySqlParser.CURTIME, 0); }
		public TerminalNode DATE_ADD() { return getToken(MySqlParser.DATE_ADD, 0); }
		public TerminalNode DATE_SUB() { return getToken(MySqlParser.DATE_SUB, 0); }
		public TerminalNode IF() { return getToken(MySqlParser.IF, 0); }
		public TerminalNode INSERT() { return getToken(MySqlParser.INSERT, 0); }
		public TerminalNode LOCALTIME() { return getToken(MySqlParser.LOCALTIME, 0); }
		public TerminalNode LOCALTIMESTAMP() { return getToken(MySqlParser.LOCALTIMESTAMP, 0); }
		public TerminalNode MID() { return getToken(MySqlParser.MID, 0); }
		public TerminalNode NOW() { return getToken(MySqlParser.NOW, 0); }
		public TerminalNode REPEAT() { return getToken(MySqlParser.REPEAT, 0); }
		public TerminalNode REPLACE() { return getToken(MySqlParser.REPLACE, 0); }
		public TerminalNode SUBSTR() { return getToken(MySqlParser.SUBSTR, 0); }
		public TerminalNode SUBSTRING() { return getToken(MySqlParser.SUBSTRING, 0); }
		public TerminalNode SYSDATE() { return getToken(MySqlParser.SYSDATE, 0); }
		public TerminalNode TRIM() { return getToken(MySqlParser.TRIM, 0); }
		public TerminalNode UTC_DATE() { return getToken(MySqlParser.UTC_DATE, 0); }
		public TerminalNode UTC_TIME() { return getToken(MySqlParser.UTC_TIME, 0); }
		public TerminalNode UTC_TIMESTAMP() { return getToken(MySqlParser.UTC_TIMESTAMP, 0); }
		public ScalarFunctionNameContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_scalarFunctionName; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterScalarFunctionName(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitScalarFunctionName(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitScalarFunctionName(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ScalarFunctionNameContext scalarFunctionName() throws RecognitionException {
		ScalarFunctionNameContext _localctx = new ScalarFunctionNameContext(_ctx, getState());
		enterRule(_localctx, 680, RULE_scalarFunctionName);
		try {
			setState(7182);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case DATABASE:
			case LEFT:
			case RIGHT:
			case SCHEMA:
			case DATE:
			case TIME:
			case TIMESTAMP:
			case YEAR:
			case JSON_ARRAY:
			case JSON_ARRAYAGG:
			case JSON_ARRAY_APPEND:
			case JSON_ARRAY_INSERT:
			case JSON_CONTAINS:
			case JSON_CONTAINS_PATH:
			case JSON_DEPTH:
			case JSON_EXTRACT:
			case JSON_INSERT:
			case JSON_KEYS:
			case JSON_LENGTH:
			case JSON_MERGE:
			case JSON_MERGE_PATCH:
			case JSON_MERGE_PRESERVE:
			case JSON_OBJECT:
			case JSON_OBJECTAGG:
			case JSON_OVERLAPS:
			case JSON_PRETTY:
			case JSON_QUOTE:
			case JSON_REMOVE:
			case JSON_REPLACE:
			case JSON_SCHEMA_VALID:
			case JSON_SCHEMA_VALIDATION_REPORT:
			case JSON_SEARCH:
			case JSON_SET:
			case JSON_STORAGE_FREE:
			case JSON_STORAGE_SIZE:
			case JSON_TABLE:
			case JSON_TYPE:
			case JSON_UNQUOTE:
			case JSON_VALID:
			case JSON_VALUE:
			case COUNT:
			case CUME_DIST:
			case DENSE_RANK:
			case FIRST_VALUE:
			case LAG:
			case LAST_VALUE:
			case LEAD:
			case NTILE:
			case NTH_VALUE:
			case PERCENT_RANK:
			case RANK:
			case ROW_NUMBER:
			case POSITION:
			case INVISIBLE:
			case VISIBLE:
			case QUARTER:
			case MONTH:
			case DAY:
			case HOUR:
			case MINUTE:
			case WEEK:
			case SECOND:
			case MICROSECOND:
			case SESSION_VARIABLES_ADMIN:
			case GEOMETRYCOLLECTION:
			case LINESTRING:
			case MULTILINESTRING:
			case MULTIPOINT:
			case MULTIPOLYGON:
			case POINT:
			case POLYGON:
			case ABS:
			case ACOS:
			case ADDDATE:
			case ADDTIME:
			case AES_DECRYPT:
			case AES_ENCRYPT:
			case AREA:
			case ASBINARY:
			case ASIN:
			case ASTEXT:
			case ASWKB:
			case ASWKT:
			case ASYMMETRIC_DECRYPT:
			case ASYMMETRIC_DERIVE:
			case ASYMMETRIC_ENCRYPT:
			case ASYMMETRIC_SIGN:
			case ASYMMETRIC_VERIFY:
			case ATAN:
			case ATAN2:
			case BENCHMARK:
			case BIN:
			case BIT_COUNT:
			case BIT_LENGTH:
			case BUFFER:
			case CEIL:
			case CEILING:
			case CENTROID:
			case CHARACTER_LENGTH:
			case CHARSET:
			case CHAR_LENGTH:
			case COERCIBILITY:
			case COLLATION:
			case COMPRESS:
			case CONCAT:
			case CONCAT_WS:
			case CONNECTION_ID:
			case CONV:
			case CONVERT_TZ:
			case COS:
			case COT:
			case CRC32:
			case CREATE_ASYMMETRIC_PRIV_KEY:
			case CREATE_ASYMMETRIC_PUB_KEY:
			case CREATE_DH_PARAMETERS:
			case CREATE_DIGEST:
			case CROSSES:
			case DATEDIFF:
			case DATE_FORMAT:
			case DAYNAME:
			case DAYOFMONTH:
			case DAYOFWEEK:
			case DAYOFYEAR:
			case DECODE:
			case DEGREES:
			case DES_DECRYPT:
			case DES_ENCRYPT:
			case DIMENSION:
			case DISJOINT:
			case ELT:
			case ENCODE:
			case ENCRYPT:
			case ENDPOINT:
			case ENVELOPE:
			case EQUALS:
			case EXP:
			case EXPORT_SET:
			case EXTERIORRING:
			case EXTRACTVALUE:
			case FIELD:
			case FIND_IN_SET:
			case FLOOR:
			case FORMAT:
			case FOUND_ROWS:
			case FROM_BASE64:
			case FROM_DAYS:
			case FROM_UNIXTIME:
			case GEOMCOLLFROMTEXT:
			case GEOMCOLLFROMWKB:
			case GEOMETRYCOLLECTIONFROMTEXT:
			case GEOMETRYCOLLECTIONFROMWKB:
			case GEOMETRYFROMTEXT:
			case GEOMETRYFROMWKB:
			case GEOMETRYN:
			case GEOMETRYTYPE:
			case GEOMFROMTEXT:
			case GEOMFROMWKB:
			case GET_FORMAT:
			case GET_LOCK:
			case GLENGTH:
			case GREATEST:
			case GTID_SUBSET:
			case GTID_SUBTRACT:
			case HEX:
			case IFNULL:
			case INET6_ATON:
			case INET6_NTOA:
			case INET_ATON:
			case INET_NTOA:
			case INSTR:
			case INTERIORRINGN:
			case INTERSECTS:
			case ISCLOSED:
			case ISEMPTY:
			case ISNULL:
			case ISSIMPLE:
			case IS_FREE_LOCK:
			case IS_IPV4:
			case IS_IPV4_COMPAT:
			case IS_IPV4_MAPPED:
			case IS_IPV6:
			case IS_USED_LOCK:
			case LAST_INSERT_ID:
			case LCASE:
			case LEAST:
			case LENGTH:
			case LINEFROMTEXT:
			case LINEFROMWKB:
			case LINESTRINGFROMTEXT:
			case LINESTRINGFROMWKB:
			case LN:
			case LOAD_FILE:
			case LOCATE:
			case LOG:
			case LOG10:
			case LOG2:
			case LOWER:
			case LPAD:
			case LTRIM:
			case MAKEDATE:
			case MAKETIME:
			case MAKE_SET:
			case MASTER_POS_WAIT:
			case MBRCONTAINS:
			case MBRDISJOINT:
			case MBREQUAL:
			case MBRINTERSECTS:
			case MBROVERLAPS:
			case MBRTOUCHES:
			case MBRWITHIN:
			case MD5:
			case MLINEFROMTEXT:
			case MLINEFROMWKB:
			case MONTHNAME:
			case MPOINTFROMTEXT:
			case MPOINTFROMWKB:
			case MPOLYFROMTEXT:
			case MPOLYFROMWKB:
			case MULTILINESTRINGFROMTEXT:
			case MULTILINESTRINGFROMWKB:
			case MULTIPOINTFROMTEXT:
			case MULTIPOINTFROMWKB:
			case MULTIPOLYGONFROMTEXT:
			case MULTIPOLYGONFROMWKB:
			case NAME_CONST:
			case NULLIF:
			case NUMGEOMETRIES:
			case NUMINTERIORRINGS:
			case NUMPOINTS:
			case OCT:
			case OCTET_LENGTH:
			case ORD:
			case OVERLAPS:
			case PERIOD_ADD:
			case PERIOD_DIFF:
			case PI:
			case POINTFROMTEXT:
			case POINTFROMWKB:
			case POINTN:
			case POLYFROMTEXT:
			case POLYFROMWKB:
			case POLYGONFROMTEXT:
			case POLYGONFROMWKB:
			case POW:
			case POWER:
			case QUOTE:
			case RADIANS:
			case RAND:
			case RANDOM:
			case RANDOM_BYTES:
			case RELEASE_LOCK:
			case REVERSE:
			case ROUND:
			case ROW_COUNT:
			case RPAD:
			case RTRIM:
			case SEC_TO_TIME:
			case SESSION_USER:
			case SHA:
			case SHA1:
			case SHA2:
			case SIGN:
			case SIN:
			case SLEEP:
			case SOUNDEX:
			case SQL_THREAD_WAIT_AFTER_GTIDS:
			case SQRT:
			case SRID:
			case STARTPOINT:
			case STRCMP:
			case STR_TO_DATE:
			case ST_AREA:
			case ST_ASBINARY:
			case ST_ASTEXT:
			case ST_ASWKB:
			case ST_ASWKT:
			case ST_BUFFER:
			case ST_CENTROID:
			case ST_CONTAINS:
			case ST_CROSSES:
			case ST_DIFFERENCE:
			case ST_DIMENSION:
			case ST_DISJOINT:
			case ST_DISTANCE:
			case ST_ENDPOINT:
			case ST_ENVELOPE:
			case ST_EQUALS:
			case ST_EXTERIORRING:
			case ST_GEOMCOLLFROMTEXT:
			case ST_GEOMCOLLFROMTXT:
			case ST_GEOMCOLLFROMWKB:
			case ST_GEOMETRYCOLLECTIONFROMTEXT:
			case ST_GEOMETRYCOLLECTIONFROMWKB:
			case ST_GEOMETRYFROMTEXT:
			case ST_GEOMETRYFROMWKB:
			case ST_GEOMETRYN:
			case ST_GEOMETRYTYPE:
			case ST_GEOMFROMTEXT:
			case ST_GEOMFROMWKB:
			case ST_INTERIORRINGN:
			case ST_INTERSECTION:
			case ST_INTERSECTS:
			case ST_ISCLOSED:
			case ST_ISEMPTY:
			case ST_ISSIMPLE:
			case ST_LINEFROMTEXT:
			case ST_LINEFROMWKB:
			case ST_LINESTRINGFROMTEXT:
			case ST_LINESTRINGFROMWKB:
			case ST_NUMGEOMETRIES:
			case ST_NUMINTERIORRING:
			case ST_NUMINTERIORRINGS:
			case ST_NUMPOINTS:
			case ST_OVERLAPS:
			case ST_POINTFROMTEXT:
			case ST_POINTFROMWKB:
			case ST_POINTN:
			case ST_POLYFROMTEXT:
			case ST_POLYFROMWKB:
			case ST_POLYGONFROMTEXT:
			case ST_POLYGONFROMWKB:
			case ST_SRID:
			case ST_STARTPOINT:
			case ST_SYMDIFFERENCE:
			case ST_TOUCHES:
			case ST_UNION:
			case ST_WITHIN:
			case ST_X:
			case ST_Y:
			case SUBDATE:
			case SUBSTRING_INDEX:
			case SUBTIME:
			case SYSTEM_USER:
			case TAN:
			case TIMEDIFF:
			case TIMESTAMPADD:
			case TIMESTAMPDIFF:
			case TIME_FORMAT:
			case TIME_TO_SEC:
			case TOUCHES:
			case TO_BASE64:
			case TO_DAYS:
			case TO_SECONDS:
			case UCASE:
			case UNCOMPRESS:
			case UNCOMPRESSED_LENGTH:
			case UNHEX:
			case UNIX_TIMESTAMP:
			case UPDATEXML:
			case UPPER:
			case UUID:
			case UUID_SHORT:
			case VALIDATE_PASSWORD_STRENGTH:
			case VERSION:
			case WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS:
			case WEEKDAY:
			case WEEKOFYEAR:
			case WEIGHT_STRING:
			case WITHIN:
			case YEARWEEK:
			case Y_FUNCTION:
			case X_FUNCTION:
			case MOD:
				enterOuterAlt(_localctx, 1);
				{
				setState(7158);
				functionNameBase();
				}
				break;
			case ASCII:
				enterOuterAlt(_localctx, 2);
				{
				setState(7159);
				match(ASCII);
				}
				break;
			case CURDATE:
				enterOuterAlt(_localctx, 3);
				{
				setState(7160);
				match(CURDATE);
				}
				break;
			case CURRENT_DATE:
				enterOuterAlt(_localctx, 4);
				{
				setState(7161);
				match(CURRENT_DATE);
				}
				break;
			case CURRENT_TIME:
				enterOuterAlt(_localctx, 5);
				{
				setState(7162);
				match(CURRENT_TIME);
				}
				break;
			case CURRENT_TIMESTAMP:
				enterOuterAlt(_localctx, 6);
				{
				setState(7163);
				match(CURRENT_TIMESTAMP);
				}
				break;
			case CURTIME:
				enterOuterAlt(_localctx, 7);
				{
				setState(7164);
				match(CURTIME);
				}
				break;
			case DATE_ADD:
				enterOuterAlt(_localctx, 8);
				{
				setState(7165);
				match(DATE_ADD);
				}
				break;
			case DATE_SUB:
				enterOuterAlt(_localctx, 9);
				{
				setState(7166);
				match(DATE_SUB);
				}
				break;
			case IF:
				enterOuterAlt(_localctx, 10);
				{
				setState(7167);
				match(IF);
				}
				break;
			case INSERT:
				enterOuterAlt(_localctx, 11);
				{
				setState(7168);
				match(INSERT);
				}
				break;
			case LOCALTIME:
				enterOuterAlt(_localctx, 12);
				{
				setState(7169);
				match(LOCALTIME);
				}
				break;
			case LOCALTIMESTAMP:
				enterOuterAlt(_localctx, 13);
				{
				setState(7170);
				match(LOCALTIMESTAMP);
				}
				break;
			case MID:
				enterOuterAlt(_localctx, 14);
				{
				setState(7171);
				match(MID);
				}
				break;
			case NOW:
				enterOuterAlt(_localctx, 15);
				{
				setState(7172);
				match(NOW);
				}
				break;
			case REPEAT:
				enterOuterAlt(_localctx, 16);
				{
				setState(7173);
				match(REPEAT);
				}
				break;
			case REPLACE:
				enterOuterAlt(_localctx, 17);
				{
				setState(7174);
				match(REPLACE);
				}
				break;
			case SUBSTR:
				enterOuterAlt(_localctx, 18);
				{
				setState(7175);
				match(SUBSTR);
				}
				break;
			case SUBSTRING:
				enterOuterAlt(_localctx, 19);
				{
				setState(7176);
				match(SUBSTRING);
				}
				break;
			case SYSDATE:
				enterOuterAlt(_localctx, 20);
				{
				setState(7177);
				match(SYSDATE);
				}
				break;
			case TRIM:
				enterOuterAlt(_localctx, 21);
				{
				setState(7178);
				match(TRIM);
				}
				break;
			case UTC_DATE:
				enterOuterAlt(_localctx, 22);
				{
				setState(7179);
				match(UTC_DATE);
				}
				break;
			case UTC_TIME:
				enterOuterAlt(_localctx, 23);
				{
				setState(7180);
				match(UTC_TIME);
				}
				break;
			case UTC_TIMESTAMP:
				enterOuterAlt(_localctx, 24);
				{
				setState(7181);
				match(UTC_TIMESTAMP);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PasswordFunctionClauseContext extends ParserRuleContext {
		public Token functionName;
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public FunctionArgContext functionArg() {
			return getRuleContext(FunctionArgContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode OLD_PASSWORD() { return getToken(MySqlParser.OLD_PASSWORD, 0); }
		public PasswordFunctionClauseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_passwordFunctionClause; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPasswordFunctionClause(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPasswordFunctionClause(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPasswordFunctionClause(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PasswordFunctionClauseContext passwordFunctionClause() throws RecognitionException {
		PasswordFunctionClauseContext _localctx = new PasswordFunctionClauseContext(_ctx, getState());
		enterRule(_localctx, 682, RULE_passwordFunctionClause);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7184);
			((PasswordFunctionClauseContext)_localctx).functionName = _input.LT(1);
			_la = _input.LA(1);
			if ( !(_la==OLD_PASSWORD || _la==PASSWORD) ) {
				((PasswordFunctionClauseContext)_localctx).functionName = (Token)_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			setState(7185);
			match(LR_BRACKET);
			setState(7186);
			functionArg();
			setState(7187);
			match(RR_BRACKET);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FunctionArgsContext extends ParserRuleContext {
		public List constant() {
			return getRuleContexts(ConstantContext.class);
		}
		public ConstantContext constant(int i) {
			return getRuleContext(ConstantContext.class,i);
		}
		public List fullColumnName() {
			return getRuleContexts(FullColumnNameContext.class);
		}
		public FullColumnNameContext fullColumnName(int i) {
			return getRuleContext(FullColumnNameContext.class,i);
		}
		public List functionCall() {
			return getRuleContexts(FunctionCallContext.class);
		}
		public FunctionCallContext functionCall(int i) {
			return getRuleContext(FunctionCallContext.class,i);
		}
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public FunctionArgsContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_functionArgs; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFunctionArgs(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFunctionArgs(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFunctionArgs(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FunctionArgsContext functionArgs() throws RecognitionException {
		FunctionArgsContext _localctx = new FunctionArgsContext(_ctx, getState());
		enterRule(_localctx, 684, RULE_functionArgs);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7193);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1061,_ctx) ) {
			case 1:
				{
				setState(7189);
				constant();
				}
				break;
			case 2:
				{
				setState(7190);
				fullColumnName();
				}
				break;
			case 3:
				{
				setState(7191);
				functionCall();
				}
				break;
			case 4:
				{
				setState(7192);
				expression(0);
				}
				break;
			}
			setState(7204);
			_errHandler.sync(this);
			_la = _input.LA(1);
			while (_la==COMMA) {
				{
				{
				setState(7195);
				match(COMMA);
				setState(7200);
				_errHandler.sync(this);
				switch ( getInterpreter().adaptivePredict(_input,1062,_ctx) ) {
				case 1:
					{
					setState(7196);
					constant();
					}
					break;
				case 2:
					{
					setState(7197);
					fullColumnName();
					}
					break;
				case 3:
					{
					setState(7198);
					functionCall();
					}
					break;
				case 4:
					{
					setState(7199);
					expression(0);
					}
					break;
				}
				}
				}
				setState(7206);
				_errHandler.sync(this);
				_la = _input.LA(1);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FunctionArgContext extends ParserRuleContext {
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public FunctionCallContext functionCall() {
			return getRuleContext(FunctionCallContext.class,0);
		}
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public FunctionArgContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_functionArg; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFunctionArg(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFunctionArg(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFunctionArg(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FunctionArgContext functionArg() throws RecognitionException {
		FunctionArgContext _localctx = new FunctionArgContext(_ctx, getState());
		enterRule(_localctx, 686, RULE_functionArg);
		try {
			setState(7211);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1064,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7207);
				constant();
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7208);
				fullColumnName();
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(7209);
				functionCall();
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(7210);
				expression(0);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ExpressionContext extends ParserRuleContext {
		public ExpressionContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expression; }
	 
		public ExpressionContext() { }
		public void copyFrom(ExpressionContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IsExpressionContext extends ExpressionContext {
		public Token testValue;
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public TerminalNode IS() { return getToken(MySqlParser.IS, 0); }
		public TerminalNode TRUE() { return getToken(MySqlParser.TRUE, 0); }
		public TerminalNode FALSE() { return getToken(MySqlParser.FALSE, 0); }
		public TerminalNode UNKNOWN() { return getToken(MySqlParser.UNKNOWN, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public IsExpressionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIsExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIsExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIsExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NotExpressionContext extends ExpressionContext {
		public Token notOperator;
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode EXCLAMATION_SYMBOL() { return getToken(MySqlParser.EXCLAMATION_SYMBOL, 0); }
		public NotExpressionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNotExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNotExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNotExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class LogicalExpressionContext extends ExpressionContext {
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public LogicalOperatorContext logicalOperator() {
			return getRuleContext(LogicalOperatorContext.class,0);
		}
		public LogicalExpressionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLogicalExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLogicalExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLogicalExpression(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class PredicateExpressionContext extends ExpressionContext {
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public PredicateExpressionContext(ExpressionContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPredicateExpression(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPredicateExpression(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPredicateExpression(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionContext expression() throws RecognitionException {
		return expression(0);
	}

	private ExpressionContext expression(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		ExpressionContext _localctx = new ExpressionContext(_ctx, _parentState);
		ExpressionContext _prevctx = _localctx;
		int _startState = 688;
		enterRecursionRule(_localctx, 688, RULE_expression, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(7224);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1066,_ctx) ) {
			case 1:
				{
				_localctx = new NotExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(7214);
				((NotExpressionContext)_localctx).notOperator = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==NOT || _la==EXCLAMATION_SYMBOL) ) {
					((NotExpressionContext)_localctx).notOperator = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				setState(7215);
				expression(4);
				}
				break;
			case 2:
				{
				_localctx = new IsExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7216);
				predicate(0);
				setState(7217);
				match(IS);
				setState(7219);
				_errHandler.sync(this);
				_la = _input.LA(1);
				if (_la==NOT) {
					{
					setState(7218);
					match(NOT);
					}
				}

				setState(7221);
				((IsExpressionContext)_localctx).testValue = _input.LT(1);
				_la = _input.LA(1);
				if ( !(_la==FALSE || _la==TRUE || _la==UNKNOWN) ) {
					((IsExpressionContext)_localctx).testValue = (Token)_errHandler.recoverInline(this);
				}
				else {
					if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
					_errHandler.reportMatch(this);
					consume();
				}
				}
				break;
			case 3:
				{
				_localctx = new PredicateExpressionContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7223);
				predicate(0);
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(7232);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1067,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					{
					_localctx = new LogicalExpressionContext(new ExpressionContext(_parentctx, _parentState));
					pushNewRecursionContext(_localctx, _startState, RULE_expression);
					setState(7226);
					if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
					setState(7227);
					logicalOperator();
					setState(7228);
					expression(4);
					}
					} 
				}
				setState(7234);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1067,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PredicateContext extends ParserRuleContext {
		public PredicateContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_predicate; }
	 
		public PredicateContext() { }
		public void copyFrom(PredicateContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SoundsLikePredicateContext extends PredicateContext {
		public List predicate() {
			return getRuleContexts(PredicateContext.class);
		}
		public PredicateContext predicate(int i) {
			return getRuleContext(PredicateContext.class,i);
		}
		public TerminalNode SOUNDS() { return getToken(MySqlParser.SOUNDS, 0); }
		public TerminalNode LIKE() { return getToken(MySqlParser.LIKE, 0); }
		public SoundsLikePredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSoundsLikePredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSoundsLikePredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSoundsLikePredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ExpressionAtomPredicateContext extends PredicateContext {
		public ExpressionAtomContext expressionAtom() {
			return getRuleContext(ExpressionAtomContext.class,0);
		}
		public ExpressionAtomPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExpressionAtomPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExpressionAtomPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExpressionAtomPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SubqueryComparisonPredicateContext extends PredicateContext {
		public Token quantifier;
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public ComparisonOperatorContext comparisonOperator() {
			return getRuleContext(ComparisonOperatorContext.class,0);
		}
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public TerminalNode ALL() { return getToken(MySqlParser.ALL, 0); }
		public TerminalNode ANY() { return getToken(MySqlParser.ANY, 0); }
		public TerminalNode SOME() { return getToken(MySqlParser.SOME, 0); }
		public SubqueryComparisonPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubqueryComparisonPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubqueryComparisonPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubqueryComparisonPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class JsonMemberOfPredicateContext extends PredicateContext {
		public List predicate() {
			return getRuleContexts(PredicateContext.class);
		}
		public PredicateContext predicate(int i) {
			return getRuleContext(PredicateContext.class,i);
		}
		public TerminalNode MEMBER() { return getToken(MySqlParser.MEMBER, 0); }
		public TerminalNode OF() { return getToken(MySqlParser.OF, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public JsonMemberOfPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonMemberOfPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonMemberOfPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonMemberOfPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class BinaryComparisonPredicateContext extends PredicateContext {
		public PredicateContext left;
		public PredicateContext right;
		public ComparisonOperatorContext comparisonOperator() {
			return getRuleContext(ComparisonOperatorContext.class,0);
		}
		public List predicate() {
			return getRuleContexts(PredicateContext.class);
		}
		public PredicateContext predicate(int i) {
			return getRuleContext(PredicateContext.class,i);
		}
		public BinaryComparisonPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBinaryComparisonPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBinaryComparisonPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBinaryComparisonPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class InPredicateContext extends PredicateContext {
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public TerminalNode IN() { return getToken(MySqlParser.IN, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public ExpressionsContext expressions() {
			return getRuleContext(ExpressionsContext.class,0);
		}
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public InPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterInPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitInPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitInPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class BetweenPredicateContext extends PredicateContext {
		public List predicate() {
			return getRuleContexts(PredicateContext.class);
		}
		public PredicateContext predicate(int i) {
			return getRuleContext(PredicateContext.class,i);
		}
		public TerminalNode BETWEEN() { return getToken(MySqlParser.BETWEEN, 0); }
		public TerminalNode AND() { return getToken(MySqlParser.AND, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public BetweenPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBetweenPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBetweenPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBetweenPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IsNullPredicateContext extends PredicateContext {
		public PredicateContext predicate() {
			return getRuleContext(PredicateContext.class,0);
		}
		public TerminalNode IS() { return getToken(MySqlParser.IS, 0); }
		public NullNotnullContext nullNotnull() {
			return getRuleContext(NullNotnullContext.class,0);
		}
		public IsNullPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIsNullPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIsNullPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIsNullPredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class LikePredicateContext extends PredicateContext {
		public List predicate() {
			return getRuleContexts(PredicateContext.class);
		}
		public PredicateContext predicate(int i) {
			return getRuleContext(PredicateContext.class,i);
		}
		public TerminalNode LIKE() { return getToken(MySqlParser.LIKE, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public TerminalNode ESCAPE() { return getToken(MySqlParser.ESCAPE, 0); }
		public TerminalNode STRING_LITERAL() { return getToken(MySqlParser.STRING_LITERAL, 0); }
		public LikePredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLikePredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLikePredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLikePredicate(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class RegexpPredicateContext extends PredicateContext {
		public Token regex;
		public List predicate() {
			return getRuleContexts(PredicateContext.class);
		}
		public PredicateContext predicate(int i) {
			return getRuleContext(PredicateContext.class,i);
		}
		public TerminalNode REGEXP() { return getToken(MySqlParser.REGEXP, 0); }
		public TerminalNode RLIKE() { return getToken(MySqlParser.RLIKE, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public RegexpPredicateContext(PredicateContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterRegexpPredicate(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitRegexpPredicate(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitRegexpPredicate(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PredicateContext predicate() throws RecognitionException {
		return predicate(0);
	}

	private PredicateContext predicate(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		PredicateContext _localctx = new PredicateContext(_ctx, _parentState);
		PredicateContext _prevctx = _localctx;
		int _startState = 690;
		enterRecursionRule(_localctx, 690, RULE_predicate, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			{
			_localctx = new ExpressionAtomPredicateContext(_localctx);
			_ctx = _localctx;
			_prevctx = _localctx;

			setState(7236);
			expressionAtom(0);
			}
			_ctx.stop = _input.LT(-1);
			setState(7302);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1075,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(7300);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1074,_ctx) ) {
					case 1:
						{
						_localctx = new BinaryComparisonPredicateContext(new PredicateContext(_parentctx, _parentState));
						((BinaryComparisonPredicateContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7238);
						if (!(precpred(_ctx, 8))) throw new FailedPredicateException(this, "precpred(_ctx, 8)");
						setState(7239);
						comparisonOperator();
						setState(7240);
						((BinaryComparisonPredicateContext)_localctx).right = predicate(9);
						}
						break;
					case 2:
						{
						_localctx = new BetweenPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7242);
						if (!(precpred(_ctx, 6))) throw new FailedPredicateException(this, "precpred(_ctx, 6)");
						setState(7244);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7243);
							match(NOT);
							}
						}

						setState(7246);
						match(BETWEEN);
						setState(7247);
						predicate(0);
						setState(7248);
						match(AND);
						setState(7249);
						predicate(7);
						}
						break;
					case 3:
						{
						_localctx = new SoundsLikePredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7251);
						if (!(precpred(_ctx, 5))) throw new FailedPredicateException(this, "precpred(_ctx, 5)");
						setState(7252);
						match(SOUNDS);
						setState(7253);
						match(LIKE);
						setState(7254);
						predicate(6);
						}
						break;
					case 4:
						{
						_localctx = new RegexpPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7255);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(7257);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7256);
							match(NOT);
							}
						}

						setState(7259);
						((RegexpPredicateContext)_localctx).regex = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==REGEXP || _la==RLIKE) ) {
							((RegexpPredicateContext)_localctx).regex = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						setState(7260);
						predicate(4);
						}
						break;
					case 5:
						{
						_localctx = new InPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7261);
						if (!(precpred(_ctx, 10))) throw new FailedPredicateException(this, "precpred(_ctx, 10)");
						setState(7263);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7262);
							match(NOT);
							}
						}

						setState(7265);
						match(IN);
						setState(7266);
						match(LR_BRACKET);
						setState(7269);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,1071,_ctx) ) {
						case 1:
							{
							setState(7267);
							selectStatement();
							}
							break;
						case 2:
							{
							setState(7268);
							expressions();
							}
							break;
						}
						setState(7271);
						match(RR_BRACKET);
						}
						break;
					case 6:
						{
						_localctx = new IsNullPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7273);
						if (!(precpred(_ctx, 9))) throw new FailedPredicateException(this, "precpred(_ctx, 9)");
						setState(7274);
						match(IS);
						setState(7275);
						nullNotnull();
						}
						break;
					case 7:
						{
						_localctx = new SubqueryComparisonPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7276);
						if (!(precpred(_ctx, 7))) throw new FailedPredicateException(this, "precpred(_ctx, 7)");
						setState(7277);
						comparisonOperator();
						setState(7278);
						((SubqueryComparisonPredicateContext)_localctx).quantifier = _input.LT(1);
						_la = _input.LA(1);
						if ( !(_la==ALL || _la==ANY || _la==SOME) ) {
							((SubqueryComparisonPredicateContext)_localctx).quantifier = (Token)_errHandler.recoverInline(this);
						}
						else {
							if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
							_errHandler.reportMatch(this);
							consume();
						}
						setState(7279);
						match(LR_BRACKET);
						setState(7280);
						selectStatement();
						setState(7281);
						match(RR_BRACKET);
						}
						break;
					case 8:
						{
						_localctx = new LikePredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7283);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(7285);
						_errHandler.sync(this);
						_la = _input.LA(1);
						if (_la==NOT) {
							{
							setState(7284);
							match(NOT);
							}
						}

						setState(7287);
						match(LIKE);
						setState(7288);
						predicate(0);
						setState(7291);
						_errHandler.sync(this);
						switch ( getInterpreter().adaptivePredict(_input,1073,_ctx) ) {
						case 1:
							{
							setState(7289);
							match(ESCAPE);
							setState(7290);
							match(STRING_LITERAL);
							}
							break;
						}
						}
						break;
					case 9:
						{
						_localctx = new JsonMemberOfPredicateContext(new PredicateContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_predicate);
						setState(7293);
						if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)");
						setState(7294);
						match(MEMBER);
						setState(7295);
						match(OF);
						setState(7296);
						match(LR_BRACKET);
						setState(7297);
						predicate(0);
						setState(7298);
						match(RR_BRACKET);
						}
						break;
					}
					} 
				}
				setState(7304);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1075,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ExpressionAtomContext extends ParserRuleContext {
		public ExpressionAtomContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_expressionAtom; }
	 
		public ExpressionAtomContext() { }
		public void copyFrom(ExpressionAtomContext ctx) {
			super.copyFrom(ctx);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class UnaryExpressionAtomContext extends ExpressionAtomContext {
		public UnaryOperatorContext unaryOperator() {
			return getRuleContext(UnaryOperatorContext.class,0);
		}
		public ExpressionAtomContext expressionAtom() {
			return getRuleContext(ExpressionAtomContext.class,0);
		}
		public UnaryExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnaryExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnaryExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnaryExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class CollateExpressionAtomContext extends ExpressionAtomContext {
		public ExpressionAtomContext expressionAtom() {
			return getRuleContext(ExpressionAtomContext.class,0);
		}
		public TerminalNode COLLATE() { return getToken(MySqlParser.COLLATE, 0); }
		public CollationNameContext collationName() {
			return getRuleContext(CollationNameContext.class,0);
		}
		public CollateExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCollateExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCollateExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCollateExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class VariableAssignExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode LOCAL_ID() { return getToken(MySqlParser.LOCAL_ID, 0); }
		public TerminalNode VAR_ASSIGN() { return getToken(MySqlParser.VAR_ASSIGN, 0); }
		public ExpressionAtomContext expressionAtom() {
			return getRuleContext(ExpressionAtomContext.class,0);
		}
		public VariableAssignExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterVariableAssignExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitVariableAssignExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitVariableAssignExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MysqlVariableExpressionAtomContext extends ExpressionAtomContext {
		public MysqlVariableContext mysqlVariable() {
			return getRuleContext(MysqlVariableContext.class,0);
		}
		public MysqlVariableExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMysqlVariableExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMysqlVariableExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMysqlVariableExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NestedExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public NestedExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNestedExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNestedExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNestedExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class NestedRowExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode ROW() { return getToken(MySqlParser.ROW, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public List expression() {
			return getRuleContexts(ExpressionContext.class);
		}
		public ExpressionContext expression(int i) {
			return getRuleContext(ExpressionContext.class,i);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public List COMMA() { return getTokens(MySqlParser.COMMA); }
		public TerminalNode COMMA(int i) {
			return getToken(MySqlParser.COMMA, i);
		}
		public NestedRowExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterNestedRowExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitNestedRowExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitNestedRowExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class MathExpressionAtomContext extends ExpressionAtomContext {
		public ExpressionAtomContext left;
		public ExpressionAtomContext right;
		public MultOperatorContext multOperator() {
			return getRuleContext(MultOperatorContext.class,0);
		}
		public List expressionAtom() {
			return getRuleContexts(ExpressionAtomContext.class);
		}
		public ExpressionAtomContext expressionAtom(int i) {
			return getRuleContext(ExpressionAtomContext.class,i);
		}
		public AddOperatorContext addOperator() {
			return getRuleContext(AddOperatorContext.class,0);
		}
		public MathExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMathExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMathExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMathExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ExistsExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode EXISTS() { return getToken(MySqlParser.EXISTS, 0); }
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public ExistsExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterExistsExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitExistsExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitExistsExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class IntervalExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode INTERVAL() { return getToken(MySqlParser.INTERVAL, 0); }
		public ExpressionContext expression() {
			return getRuleContext(ExpressionContext.class,0);
		}
		public IntervalTypeContext intervalType() {
			return getRuleContext(IntervalTypeContext.class,0);
		}
		public IntervalExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIntervalExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIntervalExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIntervalExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class JsonExpressionAtomContext extends ExpressionAtomContext {
		public ExpressionAtomContext left;
		public ExpressionAtomContext right;
		public JsonOperatorContext jsonOperator() {
			return getRuleContext(JsonOperatorContext.class,0);
		}
		public List expressionAtom() {
			return getRuleContexts(ExpressionAtomContext.class);
		}
		public ExpressionAtomContext expressionAtom(int i) {
			return getRuleContext(ExpressionAtomContext.class,i);
		}
		public JsonExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class SubqueryExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode LR_BRACKET() { return getToken(MySqlParser.LR_BRACKET, 0); }
		public SelectStatementContext selectStatement() {
			return getRuleContext(SelectStatementContext.class,0);
		}
		public TerminalNode RR_BRACKET() { return getToken(MySqlParser.RR_BRACKET, 0); }
		public SubqueryExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterSubqueryExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitSubqueryExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitSubqueryExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class ConstantExpressionAtomContext extends ExpressionAtomContext {
		public ConstantContext constant() {
			return getRuleContext(ConstantContext.class,0);
		}
		public ConstantExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterConstantExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitConstantExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitConstantExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class FunctionCallExpressionAtomContext extends ExpressionAtomContext {
		public FunctionCallContext functionCall() {
			return getRuleContext(FunctionCallContext.class,0);
		}
		public FunctionCallExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFunctionCallExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFunctionCallExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFunctionCallExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class BinaryExpressionAtomContext extends ExpressionAtomContext {
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public ExpressionAtomContext expressionAtom() {
			return getRuleContext(ExpressionAtomContext.class,0);
		}
		public BinaryExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBinaryExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBinaryExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBinaryExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class FullColumnNameExpressionAtomContext extends ExpressionAtomContext {
		public FullColumnNameContext fullColumnName() {
			return getRuleContext(FullColumnNameContext.class,0);
		}
		public FullColumnNameExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFullColumnNameExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFullColumnNameExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFullColumnNameExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}
	@SuppressWarnings("CheckReturnValue")
	public static class BitExpressionAtomContext extends ExpressionAtomContext {
		public ExpressionAtomContext left;
		public ExpressionAtomContext right;
		public BitOperatorContext bitOperator() {
			return getRuleContext(BitOperatorContext.class,0);
		}
		public List expressionAtom() {
			return getRuleContexts(ExpressionAtomContext.class);
		}
		public ExpressionAtomContext expressionAtom(int i) {
			return getRuleContext(ExpressionAtomContext.class,i);
		}
		public BitExpressionAtomContext(ExpressionAtomContext ctx) { copyFrom(ctx); }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBitExpressionAtom(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBitExpressionAtom(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBitExpressionAtom(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ExpressionAtomContext expressionAtom() throws RecognitionException {
		return expressionAtom(0);
	}

	private ExpressionAtomContext expressionAtom(int _p) throws RecognitionException {
		ParserRuleContext _parentctx = _ctx;
		int _parentState = getState();
		ExpressionAtomContext _localctx = new ExpressionAtomContext(_ctx, _parentState);
		ExpressionAtomContext _prevctx = _localctx;
		int _startState = 692;
		enterRecursionRule(_localctx, 692, RULE_expressionAtom, _p);
		int _la;
		try {
			int _alt;
			enterOuterAlt(_localctx, 1);
			{
			setState(7353);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1078,_ctx) ) {
			case 1:
				{
				_localctx = new ConstantExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;

				setState(7306);
				constant();
				}
				break;
			case 2:
				{
				_localctx = new FullColumnNameExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7307);
				fullColumnName();
				}
				break;
			case 3:
				{
				_localctx = new FunctionCallExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7308);
				functionCall();
				}
				break;
			case 4:
				{
				_localctx = new MysqlVariableExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7309);
				mysqlVariable();
				}
				break;
			case 5:
				{
				_localctx = new UnaryExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7310);
				unaryOperator();
				setState(7311);
				expressionAtom(12);
				}
				break;
			case 6:
				{
				_localctx = new BinaryExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7313);
				match(BINARY);
				setState(7314);
				expressionAtom(11);
				}
				break;
			case 7:
				{
				_localctx = new VariableAssignExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7315);
				match(LOCAL_ID);
				setState(7316);
				match(VAR_ASSIGN);
				setState(7317);
				expressionAtom(10);
				}
				break;
			case 8:
				{
				_localctx = new NestedExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7318);
				match(LR_BRACKET);
				setState(7319);
				expression(0);
				setState(7324);
				_errHandler.sync(this);
				_la = _input.LA(1);
				while (_la==COMMA) {
					{
					{
					setState(7320);
					match(COMMA);
					setState(7321);
					expression(0);
					}
					}
					setState(7326);
					_errHandler.sync(this);
					_la = _input.LA(1);
				}
				setState(7327);
				match(RR_BRACKET);
				}
				break;
			case 9:
				{
				_localctx = new NestedRowExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7329);
				match(ROW);
				setState(7330);
				match(LR_BRACKET);
				setState(7331);
				expression(0);
				setState(7334); 
				_errHandler.sync(this);
				_la = _input.LA(1);
				do {
					{
					{
					setState(7332);
					match(COMMA);
					setState(7333);
					expression(0);
					}
					}
					setState(7336); 
					_errHandler.sync(this);
					_la = _input.LA(1);
				} while ( _la==COMMA );
				setState(7338);
				match(RR_BRACKET);
				}
				break;
			case 10:
				{
				_localctx = new ExistsExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7340);
				match(EXISTS);
				setState(7341);
				match(LR_BRACKET);
				setState(7342);
				selectStatement();
				setState(7343);
				match(RR_BRACKET);
				}
				break;
			case 11:
				{
				_localctx = new SubqueryExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7345);
				match(LR_BRACKET);
				setState(7346);
				selectStatement();
				setState(7347);
				match(RR_BRACKET);
				}
				break;
			case 12:
				{
				_localctx = new IntervalExpressionAtomContext(_localctx);
				_ctx = _localctx;
				_prevctx = _localctx;
				setState(7349);
				match(INTERVAL);
				setState(7350);
				expression(0);
				setState(7351);
				intervalType();
				}
				break;
			}
			_ctx.stop = _input.LT(-1);
			setState(7376);
			_errHandler.sync(this);
			_alt = getInterpreter().adaptivePredict(_input,1080,_ctx);
			while ( _alt!=2 && _alt!=org.antlr.v4.runtime.atn.ATN.INVALID_ALT_NUMBER ) {
				if ( _alt==1 ) {
					if ( _parseListeners!=null ) triggerExitRuleEvent();
					_prevctx = _localctx;
					{
					setState(7374);
					_errHandler.sync(this);
					switch ( getInterpreter().adaptivePredict(_input,1079,_ctx) ) {
					case 1:
						{
						_localctx = new BitExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((BitExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7355);
						if (!(precpred(_ctx, 4))) throw new FailedPredicateException(this, "precpred(_ctx, 4)");
						setState(7356);
						bitOperator();
						setState(7357);
						((BitExpressionAtomContext)_localctx).right = expressionAtom(5);
						}
						break;
					case 2:
						{
						_localctx = new MathExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((MathExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7359);
						if (!(precpred(_ctx, 3))) throw new FailedPredicateException(this, "precpred(_ctx, 3)");
						setState(7360);
						multOperator();
						setState(7361);
						((MathExpressionAtomContext)_localctx).right = expressionAtom(4);
						}
						break;
					case 3:
						{
						_localctx = new MathExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((MathExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7363);
						if (!(precpred(_ctx, 2))) throw new FailedPredicateException(this, "precpred(_ctx, 2)");
						setState(7364);
						addOperator();
						setState(7365);
						((MathExpressionAtomContext)_localctx).right = expressionAtom(3);
						}
						break;
					case 4:
						{
						_localctx = new JsonExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						((JsonExpressionAtomContext)_localctx).left = _prevctx;
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7367);
						if (!(precpred(_ctx, 1))) throw new FailedPredicateException(this, "precpred(_ctx, 1)");
						setState(7368);
						jsonOperator();
						setState(7369);
						((JsonExpressionAtomContext)_localctx).right = expressionAtom(2);
						}
						break;
					case 5:
						{
						_localctx = new CollateExpressionAtomContext(new ExpressionAtomContext(_parentctx, _parentState));
						pushNewRecursionContext(_localctx, _startState, RULE_expressionAtom);
						setState(7371);
						if (!(precpred(_ctx, 14))) throw new FailedPredicateException(this, "precpred(_ctx, 14)");
						setState(7372);
						match(COLLATE);
						setState(7373);
						collationName();
						}
						break;
					}
					} 
				}
				setState(7378);
				_errHandler.sync(this);
				_alt = getInterpreter().adaptivePredict(_input,1080,_ctx);
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			unrollRecursionContexts(_parentctx);
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class UnaryOperatorContext extends ParserRuleContext {
		public TerminalNode EXCLAMATION_SYMBOL() { return getToken(MySqlParser.EXCLAMATION_SYMBOL, 0); }
		public TerminalNode BIT_NOT_OP() { return getToken(MySqlParser.BIT_NOT_OP, 0); }
		public TerminalNode PLUS() { return getToken(MySqlParser.PLUS, 0); }
		public TerminalNode MINUS() { return getToken(MySqlParser.MINUS, 0); }
		public TerminalNode NOT() { return getToken(MySqlParser.NOT, 0); }
		public UnaryOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_unaryOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterUnaryOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitUnaryOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitUnaryOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final UnaryOperatorContext unaryOperator() throws RecognitionException {
		UnaryOperatorContext _localctx = new UnaryOperatorContext(_ctx, getState());
		enterRule(_localctx, 694, RULE_unaryOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7379);
			_la = _input.LA(1);
			if ( !(_la==NOT || ((((_la - 1120)) & ~0x3f) == 0 && ((1L << (_la - 1120)) & 387L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class ComparisonOperatorContext extends ParserRuleContext {
		public TerminalNode EQUAL_SYMBOL() { return getToken(MySqlParser.EQUAL_SYMBOL, 0); }
		public TerminalNode GREATER_SYMBOL() { return getToken(MySqlParser.GREATER_SYMBOL, 0); }
		public TerminalNode LESS_SYMBOL() { return getToken(MySqlParser.LESS_SYMBOL, 0); }
		public TerminalNode EXCLAMATION_SYMBOL() { return getToken(MySqlParser.EXCLAMATION_SYMBOL, 0); }
		public ComparisonOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_comparisonOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterComparisonOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitComparisonOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitComparisonOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final ComparisonOperatorContext comparisonOperator() throws RecognitionException {
		ComparisonOperatorContext _localctx = new ComparisonOperatorContext(_ctx, getState());
		enterRule(_localctx, 696, RULE_comparisonOperator);
		try {
			setState(7395);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1081,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7381);
				match(EQUAL_SYMBOL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7382);
				match(GREATER_SYMBOL);
				}
				break;
			case 3:
				enterOuterAlt(_localctx, 3);
				{
				setState(7383);
				match(LESS_SYMBOL);
				}
				break;
			case 4:
				enterOuterAlt(_localctx, 4);
				{
				setState(7384);
				match(LESS_SYMBOL);
				setState(7385);
				match(EQUAL_SYMBOL);
				}
				break;
			case 5:
				enterOuterAlt(_localctx, 5);
				{
				setState(7386);
				match(GREATER_SYMBOL);
				setState(7387);
				match(EQUAL_SYMBOL);
				}
				break;
			case 6:
				enterOuterAlt(_localctx, 6);
				{
				setState(7388);
				match(LESS_SYMBOL);
				setState(7389);
				match(GREATER_SYMBOL);
				}
				break;
			case 7:
				enterOuterAlt(_localctx, 7);
				{
				setState(7390);
				match(EXCLAMATION_SYMBOL);
				setState(7391);
				match(EQUAL_SYMBOL);
				}
				break;
			case 8:
				enterOuterAlt(_localctx, 8);
				{
				setState(7392);
				match(LESS_SYMBOL);
				setState(7393);
				match(EQUAL_SYMBOL);
				setState(7394);
				match(GREATER_SYMBOL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class LogicalOperatorContext extends ParserRuleContext {
		public TerminalNode AND() { return getToken(MySqlParser.AND, 0); }
		public List BIT_AND_OP() { return getTokens(MySqlParser.BIT_AND_OP); }
		public TerminalNode BIT_AND_OP(int i) {
			return getToken(MySqlParser.BIT_AND_OP, i);
		}
		public TerminalNode XOR() { return getToken(MySqlParser.XOR, 0); }
		public TerminalNode OR() { return getToken(MySqlParser.OR, 0); }
		public List BIT_OR_OP() { return getTokens(MySqlParser.BIT_OR_OP); }
		public TerminalNode BIT_OR_OP(int i) {
			return getToken(MySqlParser.BIT_OR_OP, i);
		}
		public LogicalOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_logicalOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterLogicalOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitLogicalOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitLogicalOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final LogicalOperatorContext logicalOperator() throws RecognitionException {
		LogicalOperatorContext _localctx = new LogicalOperatorContext(_ctx, getState());
		enterRule(_localctx, 698, RULE_logicalOperator);
		try {
			setState(7404);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case AND:
				enterOuterAlt(_localctx, 1);
				{
				setState(7397);
				match(AND);
				}
				break;
			case BIT_AND_OP:
				enterOuterAlt(_localctx, 2);
				{
				setState(7398);
				match(BIT_AND_OP);
				setState(7399);
				match(BIT_AND_OP);
				}
				break;
			case XOR:
				enterOuterAlt(_localctx, 3);
				{
				setState(7400);
				match(XOR);
				}
				break;
			case OR:
				enterOuterAlt(_localctx, 4);
				{
				setState(7401);
				match(OR);
				}
				break;
			case BIT_OR_OP:
				enterOuterAlt(_localctx, 5);
				{
				setState(7402);
				match(BIT_OR_OP);
				setState(7403);
				match(BIT_OR_OP);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class BitOperatorContext extends ParserRuleContext {
		public List LESS_SYMBOL() { return getTokens(MySqlParser.LESS_SYMBOL); }
		public TerminalNode LESS_SYMBOL(int i) {
			return getToken(MySqlParser.LESS_SYMBOL, i);
		}
		public List GREATER_SYMBOL() { return getTokens(MySqlParser.GREATER_SYMBOL); }
		public TerminalNode GREATER_SYMBOL(int i) {
			return getToken(MySqlParser.GREATER_SYMBOL, i);
		}
		public TerminalNode BIT_AND_OP() { return getToken(MySqlParser.BIT_AND_OP, 0); }
		public TerminalNode BIT_XOR_OP() { return getToken(MySqlParser.BIT_XOR_OP, 0); }
		public TerminalNode BIT_OR_OP() { return getToken(MySqlParser.BIT_OR_OP, 0); }
		public BitOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_bitOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterBitOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitBitOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitBitOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final BitOperatorContext bitOperator() throws RecognitionException {
		BitOperatorContext _localctx = new BitOperatorContext(_ctx, getState());
		enterRule(_localctx, 700, RULE_bitOperator);
		try {
			setState(7413);
			_errHandler.sync(this);
			switch (_input.LA(1)) {
			case LESS_SYMBOL:
				enterOuterAlt(_localctx, 1);
				{
				setState(7406);
				match(LESS_SYMBOL);
				setState(7407);
				match(LESS_SYMBOL);
				}
				break;
			case GREATER_SYMBOL:
				enterOuterAlt(_localctx, 2);
				{
				setState(7408);
				match(GREATER_SYMBOL);
				setState(7409);
				match(GREATER_SYMBOL);
				}
				break;
			case BIT_AND_OP:
				enterOuterAlt(_localctx, 3);
				{
				setState(7410);
				match(BIT_AND_OP);
				}
				break;
			case BIT_XOR_OP:
				enterOuterAlt(_localctx, 4);
				{
				setState(7411);
				match(BIT_XOR_OP);
				}
				break;
			case BIT_OR_OP:
				enterOuterAlt(_localctx, 5);
				{
				setState(7412);
				match(BIT_OR_OP);
				}
				break;
			default:
				throw new NoViableAltException(this);
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class MultOperatorContext extends ParserRuleContext {
		public TerminalNode STAR() { return getToken(MySqlParser.STAR, 0); }
		public TerminalNode DIVIDE() { return getToken(MySqlParser.DIVIDE, 0); }
		public TerminalNode MODULE() { return getToken(MySqlParser.MODULE, 0); }
		public TerminalNode DIV() { return getToken(MySqlParser.DIV, 0); }
		public TerminalNode MOD() { return getToken(MySqlParser.MOD, 0); }
		public MultOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_multOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterMultOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitMultOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitMultOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final MultOperatorContext multOperator() throws RecognitionException {
		MultOperatorContext _localctx = new MultOperatorContext(_ctx, getState());
		enterRule(_localctx, 702, RULE_multOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7415);
			_la = _input.LA(1);
			if ( !(((((_la - 1117)) & ~0x3f) == 0 && ((1L << (_la - 1117)) & 103L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class AddOperatorContext extends ParserRuleContext {
		public TerminalNode PLUS() { return getToken(MySqlParser.PLUS, 0); }
		public TerminalNode MINUS() { return getToken(MySqlParser.MINUS, 0); }
		public AddOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_addOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterAddOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitAddOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitAddOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final AddOperatorContext addOperator() throws RecognitionException {
		AddOperatorContext _localctx = new AddOperatorContext(_ctx, getState());
		enterRule(_localctx, 704, RULE_addOperator);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7417);
			_la = _input.LA(1);
			if ( !(_la==PLUS || _la==MINUS) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class JsonOperatorContext extends ParserRuleContext {
		public TerminalNode MINUS() { return getToken(MySqlParser.MINUS, 0); }
		public List GREATER_SYMBOL() { return getTokens(MySqlParser.GREATER_SYMBOL); }
		public TerminalNode GREATER_SYMBOL(int i) {
			return getToken(MySqlParser.GREATER_SYMBOL, i);
		}
		public JsonOperatorContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_jsonOperator; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterJsonOperator(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitJsonOperator(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitJsonOperator(this);
			else return visitor.visitChildren(this);
		}
	}

	public final JsonOperatorContext jsonOperator() throws RecognitionException {
		JsonOperatorContext _localctx = new JsonOperatorContext(_ctx, getState());
		enterRule(_localctx, 706, RULE_jsonOperator);
		try {
			setState(7424);
			_errHandler.sync(this);
			switch ( getInterpreter().adaptivePredict(_input,1084,_ctx) ) {
			case 1:
				enterOuterAlt(_localctx, 1);
				{
				setState(7419);
				match(MINUS);
				setState(7420);
				match(GREATER_SYMBOL);
				}
				break;
			case 2:
				enterOuterAlt(_localctx, 2);
				{
				setState(7421);
				match(MINUS);
				setState(7422);
				match(GREATER_SYMBOL);
				setState(7423);
				match(GREATER_SYMBOL);
				}
				break;
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class CharsetNameBaseContext extends ParserRuleContext {
		public TerminalNode ARMSCII8() { return getToken(MySqlParser.ARMSCII8, 0); }
		public TerminalNode ASCII() { return getToken(MySqlParser.ASCII, 0); }
		public TerminalNode BIG5() { return getToken(MySqlParser.BIG5, 0); }
		public TerminalNode BINARY() { return getToken(MySqlParser.BINARY, 0); }
		public TerminalNode CP1250() { return getToken(MySqlParser.CP1250, 0); }
		public TerminalNode CP1251() { return getToken(MySqlParser.CP1251, 0); }
		public TerminalNode CP1256() { return getToken(MySqlParser.CP1256, 0); }
		public TerminalNode CP1257() { return getToken(MySqlParser.CP1257, 0); }
		public TerminalNode CP850() { return getToken(MySqlParser.CP850, 0); }
		public TerminalNode CP852() { return getToken(MySqlParser.CP852, 0); }
		public TerminalNode CP866() { return getToken(MySqlParser.CP866, 0); }
		public TerminalNode CP932() { return getToken(MySqlParser.CP932, 0); }
		public TerminalNode DEC8() { return getToken(MySqlParser.DEC8, 0); }
		public TerminalNode EUCJPMS() { return getToken(MySqlParser.EUCJPMS, 0); }
		public TerminalNode EUCKR() { return getToken(MySqlParser.EUCKR, 0); }
		public TerminalNode GB18030() { return getToken(MySqlParser.GB18030, 0); }
		public TerminalNode GB2312() { return getToken(MySqlParser.GB2312, 0); }
		public TerminalNode GBK() { return getToken(MySqlParser.GBK, 0); }
		public TerminalNode GEOSTD8() { return getToken(MySqlParser.GEOSTD8, 0); }
		public TerminalNode GREEK() { return getToken(MySqlParser.GREEK, 0); }
		public TerminalNode HEBREW() { return getToken(MySqlParser.HEBREW, 0); }
		public TerminalNode HP8() { return getToken(MySqlParser.HP8, 0); }
		public TerminalNode KEYBCS2() { return getToken(MySqlParser.KEYBCS2, 0); }
		public TerminalNode KOI8R() { return getToken(MySqlParser.KOI8R, 0); }
		public TerminalNode KOI8U() { return getToken(MySqlParser.KOI8U, 0); }
		public TerminalNode LATIN1() { return getToken(MySqlParser.LATIN1, 0); }
		public TerminalNode LATIN2() { return getToken(MySqlParser.LATIN2, 0); }
		public TerminalNode LATIN5() { return getToken(MySqlParser.LATIN5, 0); }
		public TerminalNode LATIN7() { return getToken(MySqlParser.LATIN7, 0); }
		public TerminalNode MACCE() { return getToken(MySqlParser.MACCE, 0); }
		public TerminalNode MACROMAN() { return getToken(MySqlParser.MACROMAN, 0); }
		public TerminalNode SJIS() { return getToken(MySqlParser.SJIS, 0); }
		public TerminalNode SWE7() { return getToken(MySqlParser.SWE7, 0); }
		public TerminalNode TIS620() { return getToken(MySqlParser.TIS620, 0); }
		public TerminalNode UCS2() { return getToken(MySqlParser.UCS2, 0); }
		public TerminalNode UJIS() { return getToken(MySqlParser.UJIS, 0); }
		public TerminalNode UTF16() { return getToken(MySqlParser.UTF16, 0); }
		public TerminalNode UTF16LE() { return getToken(MySqlParser.UTF16LE, 0); }
		public TerminalNode UTF32() { return getToken(MySqlParser.UTF32, 0); }
		public TerminalNode UTF8() { return getToken(MySqlParser.UTF8, 0); }
		public TerminalNode UTF8MB3() { return getToken(MySqlParser.UTF8MB3, 0); }
		public TerminalNode UTF8MB4() { return getToken(MySqlParser.UTF8MB4, 0); }
		public CharsetNameBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_charsetNameBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterCharsetNameBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitCharsetNameBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitCharsetNameBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final CharsetNameBaseContext charsetNameBase() throws RecognitionException {
		CharsetNameBaseContext _localctx = new CharsetNameBaseContext(_ctx, getState());
		enterRule(_localctx, 708, RULE_charsetNameBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7426);
			_la = _input.LA(1);
			if ( !(_la==BINARY || ((((_la - 746)) & ~0x3f) == 0 && ((1L << (_la - 746)) & 2199023255551L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class TransactionLevelBaseContext extends ParserRuleContext {
		public TerminalNode REPEATABLE() { return getToken(MySqlParser.REPEATABLE, 0); }
		public TerminalNode COMMITTED() { return getToken(MySqlParser.COMMITTED, 0); }
		public TerminalNode UNCOMMITTED() { return getToken(MySqlParser.UNCOMMITTED, 0); }
		public TerminalNode SERIALIZABLE() { return getToken(MySqlParser.SERIALIZABLE, 0); }
		public TransactionLevelBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_transactionLevelBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterTransactionLevelBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitTransactionLevelBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitTransactionLevelBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final TransactionLevelBaseContext transactionLevelBase() throws RecognitionException {
		TransactionLevelBaseContext _localctx = new TransactionLevelBaseContext(_ctx, getState());
		enterRule(_localctx, 710, RULE_transactionLevelBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7428);
			_la = _input.LA(1);
			if ( !(((((_la - 799)) & ~0x3f) == 0 && ((1L << (_la - 799)) & 15L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class PrivilegesBaseContext extends ParserRuleContext {
		public TerminalNode TABLES() { return getToken(MySqlParser.TABLES, 0); }
		public TerminalNode ROUTINE() { return getToken(MySqlParser.ROUTINE, 0); }
		public TerminalNode EXECUTE() { return getToken(MySqlParser.EXECUTE, 0); }
		public TerminalNode FILE() { return getToken(MySqlParser.FILE, 0); }
		public TerminalNode PROCESS() { return getToken(MySqlParser.PROCESS, 0); }
		public TerminalNode RELOAD() { return getToken(MySqlParser.RELOAD, 0); }
		public TerminalNode SHUTDOWN() { return getToken(MySqlParser.SHUTDOWN, 0); }
		public TerminalNode SUPER() { return getToken(MySqlParser.SUPER, 0); }
		public TerminalNode PRIVILEGES() { return getToken(MySqlParser.PRIVILEGES, 0); }
		public PrivilegesBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_privilegesBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterPrivilegesBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitPrivilegesBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitPrivilegesBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final PrivilegesBaseContext privilegesBase() throws RecognitionException {
		PrivilegesBaseContext _localctx = new PrivilegesBaseContext(_ctx, getState());
		enterRule(_localctx, 712, RULE_privilegesBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7430);
			_la = _input.LA(1);
			if ( !(((((_la - 708)) & ~0x3f) == 0 && ((1L << (_la - 708)) & 23656792067L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class IntervalTypeBaseContext extends ParserRuleContext {
		public TerminalNode QUARTER() { return getToken(MySqlParser.QUARTER, 0); }
		public TerminalNode MONTH() { return getToken(MySqlParser.MONTH, 0); }
		public TerminalNode DAY() { return getToken(MySqlParser.DAY, 0); }
		public TerminalNode HOUR() { return getToken(MySqlParser.HOUR, 0); }
		public TerminalNode MINUTE() { return getToken(MySqlParser.MINUTE, 0); }
		public TerminalNode WEEK() { return getToken(MySqlParser.WEEK, 0); }
		public TerminalNode SECOND() { return getToken(MySqlParser.SECOND, 0); }
		public TerminalNode MICROSECOND() { return getToken(MySqlParser.MICROSECOND, 0); }
		public IntervalTypeBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_intervalTypeBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterIntervalTypeBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitIntervalTypeBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitIntervalTypeBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final IntervalTypeBaseContext intervalTypeBase() throws RecognitionException {
		IntervalTypeBaseContext _localctx = new IntervalTypeBaseContext(_ctx, getState());
		enterRule(_localctx, 714, RULE_intervalTypeBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7432);
			_la = _input.LA(1);
			if ( !(((((_la - 689)) & ~0x3f) == 0 && ((1L << (_la - 689)) & 255L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class DataTypeBaseContext extends ParserRuleContext {
		public TerminalNode DATE() { return getToken(MySqlParser.DATE, 0); }
		public TerminalNode TIME() { return getToken(MySqlParser.TIME, 0); }
		public TerminalNode TIMESTAMP() { return getToken(MySqlParser.TIMESTAMP, 0); }
		public TerminalNode DATETIME() { return getToken(MySqlParser.DATETIME, 0); }
		public TerminalNode YEAR() { return getToken(MySqlParser.YEAR, 0); }
		public TerminalNode ENUM() { return getToken(MySqlParser.ENUM, 0); }
		public TerminalNode TEXT() { return getToken(MySqlParser.TEXT, 0); }
		public DataTypeBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_dataTypeBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterDataTypeBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitDataTypeBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitDataTypeBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final DataTypeBaseContext dataTypeBase() throws RecognitionException {
		DataTypeBaseContext _localctx = new DataTypeBaseContext(_ctx, getState());
		enterRule(_localctx, 716, RULE_dataTypeBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7434);
			_la = _input.LA(1);
			if ( !(((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & 1179679L) != 0)) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class KeywordsCanBeIdContext extends ParserRuleContext {
		public TerminalNode ACCOUNT() { return getToken(MySqlParser.ACCOUNT, 0); }
		public TerminalNode ACTION() { return getToken(MySqlParser.ACTION, 0); }
		public TerminalNode ADMIN() { return getToken(MySqlParser.ADMIN, 0); }
		public TerminalNode AFTER() { return getToken(MySqlParser.AFTER, 0); }
		public TerminalNode AGGREGATE() { return getToken(MySqlParser.AGGREGATE, 0); }
		public TerminalNode ALGORITHM() { return getToken(MySqlParser.ALGORITHM, 0); }
		public TerminalNode ANY() { return getToken(MySqlParser.ANY, 0); }
		public TerminalNode ARRAY() { return getToken(MySqlParser.ARRAY, 0); }
		public TerminalNode AT() { return getToken(MySqlParser.AT, 0); }
		public TerminalNode AUDIT_ADMIN() { return getToken(MySqlParser.AUDIT_ADMIN, 0); }
		public TerminalNode AUDIT_ABORT_EXEMPT() { return getToken(MySqlParser.AUDIT_ABORT_EXEMPT, 0); }
		public TerminalNode AUTHORS() { return getToken(MySqlParser.AUTHORS, 0); }
		public TerminalNode AUTOCOMMIT() { return getToken(MySqlParser.AUTOCOMMIT, 0); }
		public TerminalNode AUTOEXTEND_SIZE() { return getToken(MySqlParser.AUTOEXTEND_SIZE, 0); }
		public TerminalNode AUTO_INCREMENT() { return getToken(MySqlParser.AUTO_INCREMENT, 0); }
		public TerminalNode AUTHENTICATION_POLICY_ADMIN() { return getToken(MySqlParser.AUTHENTICATION_POLICY_ADMIN, 0); }
		public TerminalNode AVG() { return getToken(MySqlParser.AVG, 0); }
		public TerminalNode AVG_ROW_LENGTH() { return getToken(MySqlParser.AVG_ROW_LENGTH, 0); }
		public TerminalNode ATTRIBUTE() { return getToken(MySqlParser.ATTRIBUTE, 0); }
		public TerminalNode BACKUP_ADMIN() { return getToken(MySqlParser.BACKUP_ADMIN, 0); }
		public TerminalNode BEGIN() { return getToken(MySqlParser.BEGIN, 0); }
		public TerminalNode BINLOG() { return getToken(MySqlParser.BINLOG, 0); }
		public TerminalNode BINLOG_ADMIN() { return getToken(MySqlParser.BINLOG_ADMIN, 0); }
		public TerminalNode BINLOG_ENCRYPTION_ADMIN() { return getToken(MySqlParser.BINLOG_ENCRYPTION_ADMIN, 0); }
		public TerminalNode BIT() { return getToken(MySqlParser.BIT, 0); }
		public TerminalNode BIT_AND() { return getToken(MySqlParser.BIT_AND, 0); }
		public TerminalNode BIT_OR() { return getToken(MySqlParser.BIT_OR, 0); }
		public TerminalNode BIT_XOR() { return getToken(MySqlParser.BIT_XOR, 0); }
		public TerminalNode BLOCK() { return getToken(MySqlParser.BLOCK, 0); }
		public TerminalNode BOOL() { return getToken(MySqlParser.BOOL, 0); }
		public TerminalNode BOOLEAN() { return getToken(MySqlParser.BOOLEAN, 0); }
		public TerminalNode BTREE() { return getToken(MySqlParser.BTREE, 0); }
		public TerminalNode BUCKETS() { return getToken(MySqlParser.BUCKETS, 0); }
		public TerminalNode CACHE() { return getToken(MySqlParser.CACHE, 0); }
		public TerminalNode CASCADED() { return getToken(MySqlParser.CASCADED, 0); }
		public TerminalNode CHAIN() { return getToken(MySqlParser.CHAIN, 0); }
		public TerminalNode CHANGED() { return getToken(MySqlParser.CHANGED, 0); }
		public TerminalNode CHANNEL() { return getToken(MySqlParser.CHANNEL, 0); }
		public TerminalNode CHECKSUM() { return getToken(MySqlParser.CHECKSUM, 0); }
		public TerminalNode PAGE_CHECKSUM() { return getToken(MySqlParser.PAGE_CHECKSUM, 0); }
		public TerminalNode CATALOG_NAME() { return getToken(MySqlParser.CATALOG_NAME, 0); }
		public TerminalNode CIPHER() { return getToken(MySqlParser.CIPHER, 0); }
		public TerminalNode CLASS_ORIGIN() { return getToken(MySqlParser.CLASS_ORIGIN, 0); }
		public TerminalNode CLIENT() { return getToken(MySqlParser.CLIENT, 0); }
		public TerminalNode CLONE_ADMIN() { return getToken(MySqlParser.CLONE_ADMIN, 0); }
		public TerminalNode CLOSE() { return getToken(MySqlParser.CLOSE, 0); }
		public TerminalNode CLUSTERING() { return getToken(MySqlParser.CLUSTERING, 0); }
		public TerminalNode COALESCE() { return getToken(MySqlParser.COALESCE, 0); }
		public TerminalNode CODE() { return getToken(MySqlParser.CODE, 0); }
		public TerminalNode COLUMNS() { return getToken(MySqlParser.COLUMNS, 0); }
		public TerminalNode COLUMN_FORMAT() { return getToken(MySqlParser.COLUMN_FORMAT, 0); }
		public TerminalNode COLUMN_NAME() { return getToken(MySqlParser.COLUMN_NAME, 0); }
		public TerminalNode COMMENT() { return getToken(MySqlParser.COMMENT, 0); }
		public TerminalNode COMMIT() { return getToken(MySqlParser.COMMIT, 0); }
		public TerminalNode COMPACT() { return getToken(MySqlParser.COMPACT, 0); }
		public TerminalNode COMPLETION() { return getToken(MySqlParser.COMPLETION, 0); }
		public TerminalNode COMPRESSED() { return getToken(MySqlParser.COMPRESSED, 0); }
		public TerminalNode COMPRESSION() { return getToken(MySqlParser.COMPRESSION, 0); }
		public TerminalNode CONCURRENT() { return getToken(MySqlParser.CONCURRENT, 0); }
		public TerminalNode CONDITION() { return getToken(MySqlParser.CONDITION, 0); }
		public TerminalNode CONNECT() { return getToken(MySqlParser.CONNECT, 0); }
		public TerminalNode CONNECTION() { return getToken(MySqlParser.CONNECTION, 0); }
		public TerminalNode CONNECTION_ADMIN() { return getToken(MySqlParser.CONNECTION_ADMIN, 0); }
		public TerminalNode CONSISTENT() { return getToken(MySqlParser.CONSISTENT, 0); }
		public TerminalNode CONSTRAINT_CATALOG() { return getToken(MySqlParser.CONSTRAINT_CATALOG, 0); }
		public TerminalNode CONSTRAINT_NAME() { return getToken(MySqlParser.CONSTRAINT_NAME, 0); }
		public TerminalNode CONSTRAINT_SCHEMA() { return getToken(MySqlParser.CONSTRAINT_SCHEMA, 0); }
		public TerminalNode CONTAINS() { return getToken(MySqlParser.CONTAINS, 0); }
		public TerminalNode CONTEXT() { return getToken(MySqlParser.CONTEXT, 0); }
		public TerminalNode CONTRIBUTORS() { return getToken(MySqlParser.CONTRIBUTORS, 0); }
		public TerminalNode COPY() { return getToken(MySqlParser.COPY, 0); }
		public TerminalNode COUNT() { return getToken(MySqlParser.COUNT, 0); }
		public TerminalNode CPU() { return getToken(MySqlParser.CPU, 0); }
		public TerminalNode CURRENT() { return getToken(MySqlParser.CURRENT, 0); }
		public TerminalNode CURRENT_USER() { return getToken(MySqlParser.CURRENT_USER, 0); }
		public TerminalNode CURSOR_NAME() { return getToken(MySqlParser.CURSOR_NAME, 0); }
		public TerminalNode DATA() { return getToken(MySqlParser.DATA, 0); }
		public TerminalNode DATAFILE() { return getToken(MySqlParser.DATAFILE, 0); }
		public TerminalNode DEALLOCATE() { return getToken(MySqlParser.DEALLOCATE, 0); }
		public TerminalNode DEFAULT() { return getToken(MySqlParser.DEFAULT, 0); }
		public TerminalNode DEFAULT_AUTH() { return getToken(MySqlParser.DEFAULT_AUTH, 0); }
		public TerminalNode DEFINER() { return getToken(MySqlParser.DEFINER, 0); }
		public TerminalNode DELAY_KEY_WRITE() { return getToken(MySqlParser.DELAY_KEY_WRITE, 0); }
		public TerminalNode DES_KEY_FILE() { return getToken(MySqlParser.DES_KEY_FILE, 0); }
		public TerminalNode DIAGNOSTICS() { return getToken(MySqlParser.DIAGNOSTICS, 0); }
		public TerminalNode DIRECTORY() { return getToken(MySqlParser.DIRECTORY, 0); }
		public TerminalNode DISABLE() { return getToken(MySqlParser.DISABLE, 0); }
		public TerminalNode DISCARD() { return getToken(MySqlParser.DISCARD, 0); }
		public TerminalNode DISK() { return getToken(MySqlParser.DISK, 0); }
		public TerminalNode DO() { return getToken(MySqlParser.DO, 0); }
		public TerminalNode DUMPFILE() { return getToken(MySqlParser.DUMPFILE, 0); }
		public TerminalNode DUPLICATE() { return getToken(MySqlParser.DUPLICATE, 0); }
		public TerminalNode DYNAMIC() { return getToken(MySqlParser.DYNAMIC, 0); }
		public TerminalNode EMPTY() { return getToken(MySqlParser.EMPTY, 0); }
		public TerminalNode ENABLE() { return getToken(MySqlParser.ENABLE, 0); }
		public TerminalNode ENCRYPTION() { return getToken(MySqlParser.ENCRYPTION, 0); }
		public TerminalNode ENCRYPTION_KEY_ADMIN() { return getToken(MySqlParser.ENCRYPTION_KEY_ADMIN, 0); }
		public TerminalNode END() { return getToken(MySqlParser.END, 0); }
		public TerminalNode ENDS() { return getToken(MySqlParser.ENDS, 0); }
		public TerminalNode ENGINE() { return getToken(MySqlParser.ENGINE, 0); }
		public TerminalNode ENGINE_ATTRIBUTE() { return getToken(MySqlParser.ENGINE_ATTRIBUTE, 0); }
		public TerminalNode ENGINES() { return getToken(MySqlParser.ENGINES, 0); }
		public TerminalNode ENFORCED() { return getToken(MySqlParser.ENFORCED, 0); }
		public TerminalNode ERROR() { return getToken(MySqlParser.ERROR, 0); }
		public TerminalNode ERRORS() { return getToken(MySqlParser.ERRORS, 0); }
		public TerminalNode ESCAPE() { return getToken(MySqlParser.ESCAPE, 0); }
		public TerminalNode EUR() { return getToken(MySqlParser.EUR, 0); }
		public TerminalNode EVEN() { return getToken(MySqlParser.EVEN, 0); }
		public TerminalNode EVENT() { return getToken(MySqlParser.EVENT, 0); }
		public TerminalNode EVENTS() { return getToken(MySqlParser.EVENTS, 0); }
		public TerminalNode EVERY() { return getToken(MySqlParser.EVERY, 0); }
		public TerminalNode EXCEPT() { return getToken(MySqlParser.EXCEPT, 0); }
		public TerminalNode EXCHANGE() { return getToken(MySqlParser.EXCHANGE, 0); }
		public TerminalNode EXCLUSIVE() { return getToken(MySqlParser.EXCLUSIVE, 0); }
		public TerminalNode EXPIRE() { return getToken(MySqlParser.EXPIRE, 0); }
		public TerminalNode EXPORT() { return getToken(MySqlParser.EXPORT, 0); }
		public TerminalNode EXTENDED() { return getToken(MySqlParser.EXTENDED, 0); }
		public TerminalNode EXTENT_SIZE() { return getToken(MySqlParser.EXTENT_SIZE, 0); }
		public TerminalNode FAILED_LOGIN_ATTEMPTS() { return getToken(MySqlParser.FAILED_LOGIN_ATTEMPTS, 0); }
		public TerminalNode FAST() { return getToken(MySqlParser.FAST, 0); }
		public TerminalNode FAULTS() { return getToken(MySqlParser.FAULTS, 0); }
		public TerminalNode FIELDS() { return getToken(MySqlParser.FIELDS, 0); }
		public TerminalNode FILE_BLOCK_SIZE() { return getToken(MySqlParser.FILE_BLOCK_SIZE, 0); }
		public TerminalNode FILTER() { return getToken(MySqlParser.FILTER, 0); }
		public TerminalNode FIREWALL_ADMIN() { return getToken(MySqlParser.FIREWALL_ADMIN, 0); }
		public TerminalNode FIREWALL_EXEMPT() { return getToken(MySqlParser.FIREWALL_EXEMPT, 0); }
		public TerminalNode FIREWALL_USER() { return getToken(MySqlParser.FIREWALL_USER, 0); }
		public TerminalNode FIRST() { return getToken(MySqlParser.FIRST, 0); }
		public TerminalNode FIXED() { return getToken(MySqlParser.FIXED, 0); }
		public TerminalNode FLUSH() { return getToken(MySqlParser.FLUSH, 0); }
		public TerminalNode FOLLOWS() { return getToken(MySqlParser.FOLLOWS, 0); }
		public TerminalNode FOUND() { return getToken(MySqlParser.FOUND, 0); }
		public TerminalNode FULL() { return getToken(MySqlParser.FULL, 0); }
		public TerminalNode FUNCTION() { return getToken(MySqlParser.FUNCTION, 0); }
		public TerminalNode GENERAL() { return getToken(MySqlParser.GENERAL, 0); }
		public TerminalNode GLOBAL() { return getToken(MySqlParser.GLOBAL, 0); }
		public TerminalNode GRANTS() { return getToken(MySqlParser.GRANTS, 0); }
		public TerminalNode GROUP() { return getToken(MySqlParser.GROUP, 0); }
		public TerminalNode GROUP_CONCAT() { return getToken(MySqlParser.GROUP_CONCAT, 0); }
		public TerminalNode GROUP_REPLICATION() { return getToken(MySqlParser.GROUP_REPLICATION, 0); }
		public TerminalNode GROUP_REPLICATION_ADMIN() { return getToken(MySqlParser.GROUP_REPLICATION_ADMIN, 0); }
		public TerminalNode HANDLER() { return getToken(MySqlParser.HANDLER, 0); }
		public TerminalNode HASH() { return getToken(MySqlParser.HASH, 0); }
		public TerminalNode HELP() { return getToken(MySqlParser.HELP, 0); }
		public TerminalNode HISTORY() { return getToken(MySqlParser.HISTORY, 0); }
		public TerminalNode HOST() { return getToken(MySqlParser.HOST, 0); }
		public TerminalNode HOSTS() { return getToken(MySqlParser.HOSTS, 0); }
		public TerminalNode IDENTIFIED() { return getToken(MySqlParser.IDENTIFIED, 0); }
		public TerminalNode IGNORED() { return getToken(MySqlParser.IGNORED, 0); }
		public TerminalNode IGNORE_SERVER_IDS() { return getToken(MySqlParser.IGNORE_SERVER_IDS, 0); }
		public TerminalNode IMPORT() { return getToken(MySqlParser.IMPORT, 0); }
		public TerminalNode INDEXES() { return getToken(MySqlParser.INDEXES, 0); }
		public TerminalNode INITIAL_SIZE() { return getToken(MySqlParser.INITIAL_SIZE, 0); }
		public TerminalNode INNODB_REDO_LOG_ARCHIVE() { return getToken(MySqlParser.INNODB_REDO_LOG_ARCHIVE, 0); }
		public TerminalNode INPLACE() { return getToken(MySqlParser.INPLACE, 0); }
		public TerminalNode INSERT_METHOD() { return getToken(MySqlParser.INSERT_METHOD, 0); }
		public TerminalNode INSTALL() { return getToken(MySqlParser.INSTALL, 0); }
		public TerminalNode INSTANCE() { return getToken(MySqlParser.INSTANCE, 0); }
		public TerminalNode INSTANT() { return getToken(MySqlParser.INSTANT, 0); }
		public TerminalNode INTERNAL() { return getToken(MySqlParser.INTERNAL, 0); }
		public TerminalNode INVOKE() { return getToken(MySqlParser.INVOKE, 0); }
		public TerminalNode INVOKER() { return getToken(MySqlParser.INVOKER, 0); }
		public TerminalNode IO() { return getToken(MySqlParser.IO, 0); }
		public TerminalNode IO_THREAD() { return getToken(MySqlParser.IO_THREAD, 0); }
		public TerminalNode IPC() { return getToken(MySqlParser.IPC, 0); }
		public TerminalNode ISO() { return getToken(MySqlParser.ISO, 0); }
		public TerminalNode ISOLATION() { return getToken(MySqlParser.ISOLATION, 0); }
		public TerminalNode ISSUER() { return getToken(MySqlParser.ISSUER, 0); }
		public TerminalNode JIS() { return getToken(MySqlParser.JIS, 0); }
		public TerminalNode JSON() { return getToken(MySqlParser.JSON, 0); }
		public TerminalNode KEY_BLOCK_SIZE() { return getToken(MySqlParser.KEY_BLOCK_SIZE, 0); }
		public TerminalNode LAMBDA() { return getToken(MySqlParser.LAMBDA, 0); }
		public TerminalNode LANGUAGE() { return getToken(MySqlParser.LANGUAGE, 0); }
		public TerminalNode LAST() { return getToken(MySqlParser.LAST, 0); }
		public TerminalNode LATERAL() { return getToken(MySqlParser.LATERAL, 0); }
		public TerminalNode LEAVES() { return getToken(MySqlParser.LEAVES, 0); }
		public TerminalNode LESS() { return getToken(MySqlParser.LESS, 0); }
		public TerminalNode LEVEL() { return getToken(MySqlParser.LEVEL, 0); }
		public TerminalNode LIST() { return getToken(MySqlParser.LIST, 0); }
		public TerminalNode LOCAL() { return getToken(MySqlParser.LOCAL, 0); }
		public TerminalNode LOGFILE() { return getToken(MySqlParser.LOGFILE, 0); }
		public TerminalNode LOGS() { return getToken(MySqlParser.LOGS, 0); }
		public TerminalNode MASTER() { return getToken(MySqlParser.MASTER, 0); }
		public TerminalNode MASTER_AUTO_POSITION() { return getToken(MySqlParser.MASTER_AUTO_POSITION, 0); }
		public TerminalNode MASTER_CONNECT_RETRY() { return getToken(MySqlParser.MASTER_CONNECT_RETRY, 0); }
		public TerminalNode MASTER_DELAY() { return getToken(MySqlParser.MASTER_DELAY, 0); }
		public TerminalNode MASTER_HEARTBEAT_PERIOD() { return getToken(MySqlParser.MASTER_HEARTBEAT_PERIOD, 0); }
		public TerminalNode MASTER_HOST() { return getToken(MySqlParser.MASTER_HOST, 0); }
		public TerminalNode MASTER_LOG_FILE() { return getToken(MySqlParser.MASTER_LOG_FILE, 0); }
		public TerminalNode MASTER_LOG_POS() { return getToken(MySqlParser.MASTER_LOG_POS, 0); }
		public TerminalNode MASTER_PASSWORD() { return getToken(MySqlParser.MASTER_PASSWORD, 0); }
		public TerminalNode MASTER_PORT() { return getToken(MySqlParser.MASTER_PORT, 0); }
		public TerminalNode MASTER_RETRY_COUNT() { return getToken(MySqlParser.MASTER_RETRY_COUNT, 0); }
		public TerminalNode MASTER_SSL() { return getToken(MySqlParser.MASTER_SSL, 0); }
		public TerminalNode MASTER_SSL_CA() { return getToken(MySqlParser.MASTER_SSL_CA, 0); }
		public TerminalNode MASTER_SSL_CAPATH() { return getToken(MySqlParser.MASTER_SSL_CAPATH, 0); }
		public TerminalNode MASTER_SSL_CERT() { return getToken(MySqlParser.MASTER_SSL_CERT, 0); }
		public TerminalNode MASTER_SSL_CIPHER() { return getToken(MySqlParser.MASTER_SSL_CIPHER, 0); }
		public TerminalNode MASTER_SSL_CRL() { return getToken(MySqlParser.MASTER_SSL_CRL, 0); }
		public TerminalNode MASTER_SSL_CRLPATH() { return getToken(MySqlParser.MASTER_SSL_CRLPATH, 0); }
		public TerminalNode MASTER_SSL_KEY() { return getToken(MySqlParser.MASTER_SSL_KEY, 0); }
		public TerminalNode MASTER_TLS_VERSION() { return getToken(MySqlParser.MASTER_TLS_VERSION, 0); }
		public TerminalNode MASTER_USER() { return getToken(MySqlParser.MASTER_USER, 0); }
		public TerminalNode MAX_CONNECTIONS_PER_HOUR() { return getToken(MySqlParser.MAX_CONNECTIONS_PER_HOUR, 0); }
		public TerminalNode MAX_QUERIES_PER_HOUR() { return getToken(MySqlParser.MAX_QUERIES_PER_HOUR, 0); }
		public TerminalNode MAX() { return getToken(MySqlParser.MAX, 0); }
		public TerminalNode MAX_ROWS() { return getToken(MySqlParser.MAX_ROWS, 0); }
		public TerminalNode MAX_SIZE() { return getToken(MySqlParser.MAX_SIZE, 0); }
		public TerminalNode MAX_UPDATES_PER_HOUR() { return getToken(MySqlParser.MAX_UPDATES_PER_HOUR, 0); }
		public TerminalNode MAX_USER_CONNECTIONS() { return getToken(MySqlParser.MAX_USER_CONNECTIONS, 0); }
		public TerminalNode MEDIUM() { return getToken(MySqlParser.MEDIUM, 0); }
		public TerminalNode MEMBER() { return getToken(MySqlParser.MEMBER, 0); }
		public TerminalNode MEMORY() { return getToken(MySqlParser.MEMORY, 0); }
		public TerminalNode MERGE() { return getToken(MySqlParser.MERGE, 0); }
		public TerminalNode MESSAGE_TEXT() { return getToken(MySqlParser.MESSAGE_TEXT, 0); }
		public TerminalNode MID() { return getToken(MySqlParser.MID, 0); }
		public TerminalNode MIGRATE() { return getToken(MySqlParser.MIGRATE, 0); }
		public TerminalNode MIN() { return getToken(MySqlParser.MIN, 0); }
		public TerminalNode MIN_ROWS() { return getToken(MySqlParser.MIN_ROWS, 0); }
		public TerminalNode MODE() { return getToken(MySqlParser.MODE, 0); }
		public TerminalNode MODIFY() { return getToken(MySqlParser.MODIFY, 0); }
		public TerminalNode MUTEX() { return getToken(MySqlParser.MUTEX, 0); }
		public TerminalNode MYSQL() { return getToken(MySqlParser.MYSQL, 0); }
		public TerminalNode MYSQL_ERRNO() { return getToken(MySqlParser.MYSQL_ERRNO, 0); }
		public TerminalNode NAME() { return getToken(MySqlParser.NAME, 0); }
		public TerminalNode NAMES() { return getToken(MySqlParser.NAMES, 0); }
		public TerminalNode NCHAR() { return getToken(MySqlParser.NCHAR, 0); }
		public TerminalNode NDB_STORED_USER() { return getToken(MySqlParser.NDB_STORED_USER, 0); }
		public TerminalNode NESTED() { return getToken(MySqlParser.NESTED, 0); }
		public TerminalNode NEVER() { return getToken(MySqlParser.NEVER, 0); }
		public TerminalNode NEXT() { return getToken(MySqlParser.NEXT, 0); }
		public TerminalNode NO() { return getToken(MySqlParser.NO, 0); }
		public TerminalNode NOCOPY() { return getToken(MySqlParser.NOCOPY, 0); }
		public TerminalNode NODEGROUP() { return getToken(MySqlParser.NODEGROUP, 0); }
		public TerminalNode NONE() { return getToken(MySqlParser.NONE, 0); }
		public TerminalNode NOWAIT() { return getToken(MySqlParser.NOWAIT, 0); }
		public TerminalNode NUMBER() { return getToken(MySqlParser.NUMBER, 0); }
		public TerminalNode ODBC() { return getToken(MySqlParser.ODBC, 0); }
		public TerminalNode OFFLINE() { return getToken(MySqlParser.OFFLINE, 0); }
		public TerminalNode OFFSET() { return getToken(MySqlParser.OFFSET, 0); }
		public TerminalNode OF() { return getToken(MySqlParser.OF, 0); }
		public TerminalNode OJ() { return getToken(MySqlParser.OJ, 0); }
		public TerminalNode OLD_PASSWORD() { return getToken(MySqlParser.OLD_PASSWORD, 0); }
		public TerminalNode ONE() { return getToken(MySqlParser.ONE, 0); }
		public TerminalNode ONLINE() { return getToken(MySqlParser.ONLINE, 0); }
		public TerminalNode ONLY() { return getToken(MySqlParser.ONLY, 0); }
		public TerminalNode OPEN() { return getToken(MySqlParser.OPEN, 0); }
		public TerminalNode OPTIMIZER_COSTS() { return getToken(MySqlParser.OPTIMIZER_COSTS, 0); }
		public TerminalNode OPTIONAL() { return getToken(MySqlParser.OPTIONAL, 0); }
		public TerminalNode OPTIONS() { return getToken(MySqlParser.OPTIONS, 0); }
		public TerminalNode ORDER() { return getToken(MySqlParser.ORDER, 0); }
		public TerminalNode ORDINALITY() { return getToken(MySqlParser.ORDINALITY, 0); }
		public TerminalNode OWNER() { return getToken(MySqlParser.OWNER, 0); }
		public TerminalNode PACK_KEYS() { return getToken(MySqlParser.PACK_KEYS, 0); }
		public TerminalNode PAGE() { return getToken(MySqlParser.PAGE, 0); }
		public TerminalNode PARSER() { return getToken(MySqlParser.PARSER, 0); }
		public TerminalNode PARTIAL() { return getToken(MySqlParser.PARTIAL, 0); }
		public TerminalNode PARTITIONING() { return getToken(MySqlParser.PARTITIONING, 0); }
		public TerminalNode PARTITIONS() { return getToken(MySqlParser.PARTITIONS, 0); }
		public TerminalNode PASSWORD() { return getToken(MySqlParser.PASSWORD, 0); }
		public TerminalNode PASSWORDLESS_USER_ADMIN() { return getToken(MySqlParser.PASSWORDLESS_USER_ADMIN, 0); }
		public TerminalNode PASSWORD_LOCK_TIME() { return getToken(MySqlParser.PASSWORD_LOCK_TIME, 0); }
		public TerminalNode PATH() { return getToken(MySqlParser.PATH, 0); }
		public TerminalNode PERSIST_RO_VARIABLES_ADMIN() { return getToken(MySqlParser.PERSIST_RO_VARIABLES_ADMIN, 0); }
		public TerminalNode PHASE() { return getToken(MySqlParser.PHASE, 0); }
		public TerminalNode PLUGINS() { return getToken(MySqlParser.PLUGINS, 0); }
		public TerminalNode PLUGIN_DIR() { return getToken(MySqlParser.PLUGIN_DIR, 0); }
		public TerminalNode PLUGIN() { return getToken(MySqlParser.PLUGIN, 0); }
		public TerminalNode PORT() { return getToken(MySqlParser.PORT, 0); }
		public TerminalNode PRECEDES() { return getToken(MySqlParser.PRECEDES, 0); }
		public TerminalNode PREPARE() { return getToken(MySqlParser.PREPARE, 0); }
		public TerminalNode PRESERVE() { return getToken(MySqlParser.PRESERVE, 0); }
		public TerminalNode PREV() { return getToken(MySqlParser.PREV, 0); }
		public TerminalNode PRIMARY() { return getToken(MySqlParser.PRIMARY, 0); }
		public TerminalNode PROCESSLIST() { return getToken(MySqlParser.PROCESSLIST, 0); }
		public TerminalNode PROFILE() { return getToken(MySqlParser.PROFILE, 0); }
		public TerminalNode PROFILES() { return getToken(MySqlParser.PROFILES, 0); }
		public TerminalNode PROXY() { return getToken(MySqlParser.PROXY, 0); }
		public TerminalNode QUERY() { return getToken(MySqlParser.QUERY, 0); }
		public TerminalNode QUICK() { return getToken(MySqlParser.QUICK, 0); }
		public TerminalNode REBUILD() { return getToken(MySqlParser.REBUILD, 0); }
		public TerminalNode RECOVER() { return getToken(MySqlParser.RECOVER, 0); }
		public TerminalNode RECURSIVE() { return getToken(MySqlParser.RECURSIVE, 0); }
		public TerminalNode REDO_BUFFER_SIZE() { return getToken(MySqlParser.REDO_BUFFER_SIZE, 0); }
		public TerminalNode REDUNDANT() { return getToken(MySqlParser.REDUNDANT, 0); }
		public TerminalNode RELAY() { return getToken(MySqlParser.RELAY, 0); }
		public TerminalNode RELAYLOG() { return getToken(MySqlParser.RELAYLOG, 0); }
		public TerminalNode RELAY_LOG_FILE() { return getToken(MySqlParser.RELAY_LOG_FILE, 0); }
		public TerminalNode RELAY_LOG_POS() { return getToken(MySqlParser.RELAY_LOG_POS, 0); }
		public TerminalNode REMOVE() { return getToken(MySqlParser.REMOVE, 0); }
		public TerminalNode REORGANIZE() { return getToken(MySqlParser.REORGANIZE, 0); }
		public TerminalNode REPAIR() { return getToken(MySqlParser.REPAIR, 0); }
		public TerminalNode REPLICATE_DO_DB() { return getToken(MySqlParser.REPLICATE_DO_DB, 0); }
		public TerminalNode REPLICATE_DO_TABLE() { return getToken(MySqlParser.REPLICATE_DO_TABLE, 0); }
		public TerminalNode REPLICATE_IGNORE_DB() { return getToken(MySqlParser.REPLICATE_IGNORE_DB, 0); }
		public TerminalNode REPLICATE_IGNORE_TABLE() { return getToken(MySqlParser.REPLICATE_IGNORE_TABLE, 0); }
		public TerminalNode REPLICATE_REWRITE_DB() { return getToken(MySqlParser.REPLICATE_REWRITE_DB, 0); }
		public TerminalNode REPLICATE_WILD_DO_TABLE() { return getToken(MySqlParser.REPLICATE_WILD_DO_TABLE, 0); }
		public TerminalNode REPLICATE_WILD_IGNORE_TABLE() { return getToken(MySqlParser.REPLICATE_WILD_IGNORE_TABLE, 0); }
		public TerminalNode REPLICATION() { return getToken(MySqlParser.REPLICATION, 0); }
		public TerminalNode REPLICATION_APPLIER() { return getToken(MySqlParser.REPLICATION_APPLIER, 0); }
		public TerminalNode REPLICATION_SLAVE_ADMIN() { return getToken(MySqlParser.REPLICATION_SLAVE_ADMIN, 0); }
		public TerminalNode RESET() { return getToken(MySqlParser.RESET, 0); }
		public TerminalNode RESOURCE_GROUP_ADMIN() { return getToken(MySqlParser.RESOURCE_GROUP_ADMIN, 0); }
		public TerminalNode RESOURCE_GROUP_USER() { return getToken(MySqlParser.RESOURCE_GROUP_USER, 0); }
		public TerminalNode RESUME() { return getToken(MySqlParser.RESUME, 0); }
		public TerminalNode RETURNED_SQLSTATE() { return getToken(MySqlParser.RETURNED_SQLSTATE, 0); }
		public TerminalNode RETURNS() { return getToken(MySqlParser.RETURNS, 0); }
		public TerminalNode REUSE() { return getToken(MySqlParser.REUSE, 0); }
		public TerminalNode ROLE() { return getToken(MySqlParser.ROLE, 0); }
		public TerminalNode ROLE_ADMIN() { return getToken(MySqlParser.ROLE_ADMIN, 0); }
		public TerminalNode ROLLBACK() { return getToken(MySqlParser.ROLLBACK, 0); }
		public TerminalNode ROLLUP() { return getToken(MySqlParser.ROLLUP, 0); }
		public TerminalNode ROTATE() { return getToken(MySqlParser.ROTATE, 0); }
		public TerminalNode ROW() { return getToken(MySqlParser.ROW, 0); }
		public TerminalNode ROWS() { return getToken(MySqlParser.ROWS, 0); }
		public TerminalNode ROW_FORMAT() { return getToken(MySqlParser.ROW_FORMAT, 0); }
		public TerminalNode RTREE() { return getToken(MySqlParser.RTREE, 0); }
		public TerminalNode S3() { return getToken(MySqlParser.S3, 0); }
		public TerminalNode SAVEPOINT() { return getToken(MySqlParser.SAVEPOINT, 0); }
		public TerminalNode SCHEDULE() { return getToken(MySqlParser.SCHEDULE, 0); }
		public TerminalNode SCHEMA_NAME() { return getToken(MySqlParser.SCHEMA_NAME, 0); }
		public TerminalNode SECURITY() { return getToken(MySqlParser.SECURITY, 0); }
		public TerminalNode SECONDARY_ENGINE_ATTRIBUTE() { return getToken(MySqlParser.SECONDARY_ENGINE_ATTRIBUTE, 0); }
		public TerminalNode SERIAL() { return getToken(MySqlParser.SERIAL, 0); }
		public TerminalNode SERVER() { return getToken(MySqlParser.SERVER, 0); }
		public TerminalNode SESSION() { return getToken(MySqlParser.SESSION, 0); }
		public TerminalNode SESSION_VARIABLES_ADMIN() { return getToken(MySqlParser.SESSION_VARIABLES_ADMIN, 0); }
		public TerminalNode SET_USER_ID() { return getToken(MySqlParser.SET_USER_ID, 0); }
		public TerminalNode SHARE() { return getToken(MySqlParser.SHARE, 0); }
		public TerminalNode SHARED() { return getToken(MySqlParser.SHARED, 0); }
		public TerminalNode SHOW_ROUTINE() { return getToken(MySqlParser.SHOW_ROUTINE, 0); }
		public TerminalNode SIGNED() { return getToken(MySqlParser.SIGNED, 0); }
		public TerminalNode SIMPLE() { return getToken(MySqlParser.SIMPLE, 0); }
		public TerminalNode SLAVE() { return getToken(MySqlParser.SLAVE, 0); }
		public TerminalNode SLOW() { return getToken(MySqlParser.SLOW, 0); }
		public TerminalNode SKIP_QUERY_REWRITE() { return getToken(MySqlParser.SKIP_QUERY_REWRITE, 0); }
		public TerminalNode SNAPSHOT() { return getToken(MySqlParser.SNAPSHOT, 0); }
		public TerminalNode SOCKET() { return getToken(MySqlParser.SOCKET, 0); }
		public TerminalNode SOME() { return getToken(MySqlParser.SOME, 0); }
		public TerminalNode SONAME() { return getToken(MySqlParser.SONAME, 0); }
		public TerminalNode SOUNDS() { return getToken(MySqlParser.SOUNDS, 0); }
		public TerminalNode SOURCE() { return getToken(MySqlParser.SOURCE, 0); }
		public TerminalNode SQL_AFTER_GTIDS() { return getToken(MySqlParser.SQL_AFTER_GTIDS, 0); }
		public TerminalNode SQL_AFTER_MTS_GAPS() { return getToken(MySqlParser.SQL_AFTER_MTS_GAPS, 0); }
		public TerminalNode SQL_BEFORE_GTIDS() { return getToken(MySqlParser.SQL_BEFORE_GTIDS, 0); }
		public TerminalNode SQL_BUFFER_RESULT() { return getToken(MySqlParser.SQL_BUFFER_RESULT, 0); }
		public TerminalNode SQL_CACHE() { return getToken(MySqlParser.SQL_CACHE, 0); }
		public TerminalNode SQL_NO_CACHE() { return getToken(MySqlParser.SQL_NO_CACHE, 0); }
		public TerminalNode SQL_THREAD() { return getToken(MySqlParser.SQL_THREAD, 0); }
		public TerminalNode STACKED() { return getToken(MySqlParser.STACKED, 0); }
		public TerminalNode START() { return getToken(MySqlParser.START, 0); }
		public TerminalNode STARTS() { return getToken(MySqlParser.STARTS, 0); }
		public TerminalNode STATS_AUTO_RECALC() { return getToken(MySqlParser.STATS_AUTO_RECALC, 0); }
		public TerminalNode STATS_PERSISTENT() { return getToken(MySqlParser.STATS_PERSISTENT, 0); }
		public TerminalNode STATS_SAMPLE_PAGES() { return getToken(MySqlParser.STATS_SAMPLE_PAGES, 0); }
		public TerminalNode STATUS() { return getToken(MySqlParser.STATUS, 0); }
		public TerminalNode STD() { return getToken(MySqlParser.STD, 0); }
		public TerminalNode STDDEV() { return getToken(MySqlParser.STDDEV, 0); }
		public TerminalNode STDDEV_POP() { return getToken(MySqlParser.STDDEV_POP, 0); }
		public TerminalNode STDDEV_SAMP() { return getToken(MySqlParser.STDDEV_SAMP, 0); }
		public TerminalNode STOP() { return getToken(MySqlParser.STOP, 0); }
		public TerminalNode STORAGE() { return getToken(MySqlParser.STORAGE, 0); }
		public TerminalNode STRING() { return getToken(MySqlParser.STRING, 0); }
		public TerminalNode SUBCLASS_ORIGIN() { return getToken(MySqlParser.SUBCLASS_ORIGIN, 0); }
		public TerminalNode SUBJECT() { return getToken(MySqlParser.SUBJECT, 0); }
		public TerminalNode SUBPARTITION() { return getToken(MySqlParser.SUBPARTITION, 0); }
		public TerminalNode SUBPARTITIONS() { return getToken(MySqlParser.SUBPARTITIONS, 0); }
		public TerminalNode SUM() { return getToken(MySqlParser.SUM, 0); }
		public TerminalNode SUSPEND() { return getToken(MySqlParser.SUSPEND, 0); }
		public TerminalNode SWAPS() { return getToken(MySqlParser.SWAPS, 0); }
		public TerminalNode SWITCHES() { return getToken(MySqlParser.SWITCHES, 0); }
		public TerminalNode SYSTEM_VARIABLES_ADMIN() { return getToken(MySqlParser.SYSTEM_VARIABLES_ADMIN, 0); }
		public TerminalNode TABLE_NAME() { return getToken(MySqlParser.TABLE_NAME, 0); }
		public TerminalNode TABLESPACE() { return getToken(MySqlParser.TABLESPACE, 0); }
		public TerminalNode TABLE_ENCRYPTION_ADMIN() { return getToken(MySqlParser.TABLE_ENCRYPTION_ADMIN, 0); }
		public TerminalNode TABLE_TYPE() { return getToken(MySqlParser.TABLE_TYPE, 0); }
		public TerminalNode TEMPORARY() { return getToken(MySqlParser.TEMPORARY, 0); }
		public TerminalNode TEMPTABLE() { return getToken(MySqlParser.TEMPTABLE, 0); }
		public TerminalNode THAN() { return getToken(MySqlParser.THAN, 0); }
		public TerminalNode TP_CONNECTION_ADMIN() { return getToken(MySqlParser.TP_CONNECTION_ADMIN, 0); }
		public TerminalNode TRADITIONAL() { return getToken(MySqlParser.TRADITIONAL, 0); }
		public TerminalNode TRANSACTION() { return getToken(MySqlParser.TRANSACTION, 0); }
		public TerminalNode TRANSACTIONAL() { return getToken(MySqlParser.TRANSACTIONAL, 0); }
		public TerminalNode TRIGGERS() { return getToken(MySqlParser.TRIGGERS, 0); }
		public TerminalNode TRUNCATE() { return getToken(MySqlParser.TRUNCATE, 0); }
		public TerminalNode UNBOUNDED() { return getToken(MySqlParser.UNBOUNDED, 0); }
		public TerminalNode UNDEFINED() { return getToken(MySqlParser.UNDEFINED, 0); }
		public TerminalNode UNDOFILE() { return getToken(MySqlParser.UNDOFILE, 0); }
		public TerminalNode UNDO_BUFFER_SIZE() { return getToken(MySqlParser.UNDO_BUFFER_SIZE, 0); }
		public TerminalNode UNINSTALL() { return getToken(MySqlParser.UNINSTALL, 0); }
		public TerminalNode UNKNOWN() { return getToken(MySqlParser.UNKNOWN, 0); }
		public TerminalNode UNTIL() { return getToken(MySqlParser.UNTIL, 0); }
		public TerminalNode UPGRADE() { return getToken(MySqlParser.UPGRADE, 0); }
		public TerminalNode USA() { return getToken(MySqlParser.USA, 0); }
		public TerminalNode USER() { return getToken(MySqlParser.USER, 0); }
		public TerminalNode USE_FRM() { return getToken(MySqlParser.USE_FRM, 0); }
		public TerminalNode USER_RESOURCES() { return getToken(MySqlParser.USER_RESOURCES, 0); }
		public TerminalNode VALIDATION() { return getToken(MySqlParser.VALIDATION, 0); }
		public TerminalNode VALUE() { return getToken(MySqlParser.VALUE, 0); }
		public TerminalNode VAR_POP() { return getToken(MySqlParser.VAR_POP, 0); }
		public TerminalNode VAR_SAMP() { return getToken(MySqlParser.VAR_SAMP, 0); }
		public TerminalNode VARIABLES() { return getToken(MySqlParser.VARIABLES, 0); }
		public TerminalNode VARIANCE() { return getToken(MySqlParser.VARIANCE, 0); }
		public TerminalNode VERSION_TOKEN_ADMIN() { return getToken(MySqlParser.VERSION_TOKEN_ADMIN, 0); }
		public TerminalNode VIEW() { return getToken(MySqlParser.VIEW, 0); }
		public TerminalNode VIRTUAL() { return getToken(MySqlParser.VIRTUAL, 0); }
		public TerminalNode WAIT() { return getToken(MySqlParser.WAIT, 0); }
		public TerminalNode WARNINGS() { return getToken(MySqlParser.WARNINGS, 0); }
		public TerminalNode WITHOUT() { return getToken(MySqlParser.WITHOUT, 0); }
		public TerminalNode WORK() { return getToken(MySqlParser.WORK, 0); }
		public TerminalNode WRAPPER() { return getToken(MySqlParser.WRAPPER, 0); }
		public TerminalNode X509() { return getToken(MySqlParser.X509, 0); }
		public TerminalNode XA() { return getToken(MySqlParser.XA, 0); }
		public TerminalNode XA_RECOVER_ADMIN() { return getToken(MySqlParser.XA_RECOVER_ADMIN, 0); }
		public TerminalNode XML() { return getToken(MySqlParser.XML, 0); }
		public KeywordsCanBeIdContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_keywordsCanBeId; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterKeywordsCanBeId(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitKeywordsCanBeId(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitKeywordsCanBeId(this);
			else return visitor.visitChildren(this);
		}
	}

	public final KeywordsCanBeIdContext keywordsCanBeId() throws RecognitionException {
		KeywordsCanBeIdContext _localctx = new KeywordsCanBeIdContext(_ctx, getState());
		enterRule(_localctx, 718, RULE_keywordsCanBeId);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7436);
			_la = _input.LA(1);
			if ( !((((_la) & ~0x3f) == 0 && ((1L << _la) & 756890782757308416L) != 0) || ((((_la - 73)) & ~0x3f) == 0 && ((1L << (_la - 73)) & 146666055054393409L) != 0) || _la==SKIP_QUERY_REWRITE || _la==STACKED || ((((_la - 239)) & ~0x3f) == 0 && ((1L << (_la - 239)) & 1769897061370560513L) != 0) || ((((_la - 305)) & ~0x3f) == 0 && ((1L << (_la - 305)) & -134217473L) != 0) || ((((_la - 369)) & ~0x3f) == 0 && ((1L << (_la - 369)) & -171798822913L) != 0) || ((((_la - 434)) & ~0x3f) == 0 && ((1L << (_la - 434)) & -33685505L) != 0) || ((((_la - 498)) & ~0x3f) == 0 && ((1L << (_la - 498)) & -2306265222165299201L) != 0) || ((((_la - 562)) & ~0x3f) == 0 && ((1L << (_la - 562)) & -35186788007937L) != 0) || ((((_la - 626)) & ~0x3f) == 0 && ((1L << (_la - 626)) & 9077990211383719935L) != 0) || ((((_la - 697)) & ~0x3f) == 0 && ((1L << (_la - 697)) & 514225960183805L) != 0) || _la==MEMORY || _la==CATALOG_NAME || _la==ENGINE_ATTRIBUTE || _la==SECONDARY_ENGINE_ATTRIBUTE || _la==SCHEMA_NAME || _la==TP_CONNECTION_ADMIN) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	@SuppressWarnings("CheckReturnValue")
	public static class FunctionNameBaseContext extends ParserRuleContext {
		public TerminalNode ABS() { return getToken(MySqlParser.ABS, 0); }
		public TerminalNode ACOS() { return getToken(MySqlParser.ACOS, 0); }
		public TerminalNode ADDDATE() { return getToken(MySqlParser.ADDDATE, 0); }
		public TerminalNode ADDTIME() { return getToken(MySqlParser.ADDTIME, 0); }
		public TerminalNode AES_DECRYPT() { return getToken(MySqlParser.AES_DECRYPT, 0); }
		public TerminalNode AES_ENCRYPT() { return getToken(MySqlParser.AES_ENCRYPT, 0); }
		public TerminalNode AREA() { return getToken(MySqlParser.AREA, 0); }
		public TerminalNode ASBINARY() { return getToken(MySqlParser.ASBINARY, 0); }
		public TerminalNode ASIN() { return getToken(MySqlParser.ASIN, 0); }
		public TerminalNode ASTEXT() { return getToken(MySqlParser.ASTEXT, 0); }
		public TerminalNode ASWKB() { return getToken(MySqlParser.ASWKB, 0); }
		public TerminalNode ASWKT() { return getToken(MySqlParser.ASWKT, 0); }
		public TerminalNode ASYMMETRIC_DECRYPT() { return getToken(MySqlParser.ASYMMETRIC_DECRYPT, 0); }
		public TerminalNode ASYMMETRIC_DERIVE() { return getToken(MySqlParser.ASYMMETRIC_DERIVE, 0); }
		public TerminalNode ASYMMETRIC_ENCRYPT() { return getToken(MySqlParser.ASYMMETRIC_ENCRYPT, 0); }
		public TerminalNode ASYMMETRIC_SIGN() { return getToken(MySqlParser.ASYMMETRIC_SIGN, 0); }
		public TerminalNode ASYMMETRIC_VERIFY() { return getToken(MySqlParser.ASYMMETRIC_VERIFY, 0); }
		public TerminalNode ATAN() { return getToken(MySqlParser.ATAN, 0); }
		public TerminalNode ATAN2() { return getToken(MySqlParser.ATAN2, 0); }
		public TerminalNode BENCHMARK() { return getToken(MySqlParser.BENCHMARK, 0); }
		public TerminalNode BIN() { return getToken(MySqlParser.BIN, 0); }
		public TerminalNode BIT_COUNT() { return getToken(MySqlParser.BIT_COUNT, 0); }
		public TerminalNode BIT_LENGTH() { return getToken(MySqlParser.BIT_LENGTH, 0); }
		public TerminalNode BUFFER() { return getToken(MySqlParser.BUFFER, 0); }
		public TerminalNode CEIL() { return getToken(MySqlParser.CEIL, 0); }
		public TerminalNode CEILING() { return getToken(MySqlParser.CEILING, 0); }
		public TerminalNode CENTROID() { return getToken(MySqlParser.CENTROID, 0); }
		public TerminalNode CHARACTER_LENGTH() { return getToken(MySqlParser.CHARACTER_LENGTH, 0); }
		public TerminalNode CHARSET() { return getToken(MySqlParser.CHARSET, 0); }
		public TerminalNode CHAR_LENGTH() { return getToken(MySqlParser.CHAR_LENGTH, 0); }
		public TerminalNode COERCIBILITY() { return getToken(MySqlParser.COERCIBILITY, 0); }
		public TerminalNode COLLATION() { return getToken(MySqlParser.COLLATION, 0); }
		public TerminalNode COMPRESS() { return getToken(MySqlParser.COMPRESS, 0); }
		public TerminalNode CONCAT() { return getToken(MySqlParser.CONCAT, 0); }
		public TerminalNode CONCAT_WS() { return getToken(MySqlParser.CONCAT_WS, 0); }
		public TerminalNode CONNECTION_ID() { return getToken(MySqlParser.CONNECTION_ID, 0); }
		public TerminalNode CONV() { return getToken(MySqlParser.CONV, 0); }
		public TerminalNode CONVERT_TZ() { return getToken(MySqlParser.CONVERT_TZ, 0); }
		public TerminalNode COS() { return getToken(MySqlParser.COS, 0); }
		public TerminalNode COT() { return getToken(MySqlParser.COT, 0); }
		public TerminalNode COUNT() { return getToken(MySqlParser.COUNT, 0); }
		public TerminalNode CRC32() { return getToken(MySqlParser.CRC32, 0); }
		public TerminalNode CREATE_ASYMMETRIC_PRIV_KEY() { return getToken(MySqlParser.CREATE_ASYMMETRIC_PRIV_KEY, 0); }
		public TerminalNode CREATE_ASYMMETRIC_PUB_KEY() { return getToken(MySqlParser.CREATE_ASYMMETRIC_PUB_KEY, 0); }
		public TerminalNode CREATE_DH_PARAMETERS() { return getToken(MySqlParser.CREATE_DH_PARAMETERS, 0); }
		public TerminalNode CREATE_DIGEST() { return getToken(MySqlParser.CREATE_DIGEST, 0); }
		public TerminalNode CROSSES() { return getToken(MySqlParser.CROSSES, 0); }
		public TerminalNode CUME_DIST() { return getToken(MySqlParser.CUME_DIST, 0); }
		public TerminalNode DATABASE() { return getToken(MySqlParser.DATABASE, 0); }
		public TerminalNode DATE() { return getToken(MySqlParser.DATE, 0); }
		public TerminalNode DATEDIFF() { return getToken(MySqlParser.DATEDIFF, 0); }
		public TerminalNode DATE_FORMAT() { return getToken(MySqlParser.DATE_FORMAT, 0); }
		public TerminalNode DAY() { return getToken(MySqlParser.DAY, 0); }
		public TerminalNode DAYNAME() { return getToken(MySqlParser.DAYNAME, 0); }
		public TerminalNode DAYOFMONTH() { return getToken(MySqlParser.DAYOFMONTH, 0); }
		public TerminalNode DAYOFWEEK() { return getToken(MySqlParser.DAYOFWEEK, 0); }
		public TerminalNode DAYOFYEAR() { return getToken(MySqlParser.DAYOFYEAR, 0); }
		public TerminalNode DECODE() { return getToken(MySqlParser.DECODE, 0); }
		public TerminalNode DEGREES() { return getToken(MySqlParser.DEGREES, 0); }
		public TerminalNode DENSE_RANK() { return getToken(MySqlParser.DENSE_RANK, 0); }
		public TerminalNode DES_DECRYPT() { return getToken(MySqlParser.DES_DECRYPT, 0); }
		public TerminalNode DES_ENCRYPT() { return getToken(MySqlParser.DES_ENCRYPT, 0); }
		public TerminalNode DIMENSION() { return getToken(MySqlParser.DIMENSION, 0); }
		public TerminalNode DISJOINT() { return getToken(MySqlParser.DISJOINT, 0); }
		public TerminalNode ELT() { return getToken(MySqlParser.ELT, 0); }
		public TerminalNode ENCODE() { return getToken(MySqlParser.ENCODE, 0); }
		public TerminalNode ENCRYPT() { return getToken(MySqlParser.ENCRYPT, 0); }
		public TerminalNode ENDPOINT() { return getToken(MySqlParser.ENDPOINT, 0); }
		public TerminalNode ENVELOPE() { return getToken(MySqlParser.ENVELOPE, 0); }
		public TerminalNode EQUALS() { return getToken(MySqlParser.EQUALS, 0); }
		public TerminalNode EXP() { return getToken(MySqlParser.EXP, 0); }
		public TerminalNode EXPORT_SET() { return getToken(MySqlParser.EXPORT_SET, 0); }
		public TerminalNode EXTERIORRING() { return getToken(MySqlParser.EXTERIORRING, 0); }
		public TerminalNode EXTRACTVALUE() { return getToken(MySqlParser.EXTRACTVALUE, 0); }
		public TerminalNode FIELD() { return getToken(MySqlParser.FIELD, 0); }
		public TerminalNode FIND_IN_SET() { return getToken(MySqlParser.FIND_IN_SET, 0); }
		public TerminalNode FIRST_VALUE() { return getToken(MySqlParser.FIRST_VALUE, 0); }
		public TerminalNode FLOOR() { return getToken(MySqlParser.FLOOR, 0); }
		public TerminalNode FORMAT() { return getToken(MySqlParser.FORMAT, 0); }
		public TerminalNode FOUND_ROWS() { return getToken(MySqlParser.FOUND_ROWS, 0); }
		public TerminalNode FROM_BASE64() { return getToken(MySqlParser.FROM_BASE64, 0); }
		public TerminalNode FROM_DAYS() { return getToken(MySqlParser.FROM_DAYS, 0); }
		public TerminalNode FROM_UNIXTIME() { return getToken(MySqlParser.FROM_UNIXTIME, 0); }
		public TerminalNode GEOMCOLLFROMTEXT() { return getToken(MySqlParser.GEOMCOLLFROMTEXT, 0); }
		public TerminalNode GEOMCOLLFROMWKB() { return getToken(MySqlParser.GEOMCOLLFROMWKB, 0); }
		public TerminalNode GEOMETRYCOLLECTION() { return getToken(MySqlParser.GEOMETRYCOLLECTION, 0); }
		public TerminalNode GEOMETRYCOLLECTIONFROMTEXT() { return getToken(MySqlParser.GEOMETRYCOLLECTIONFROMTEXT, 0); }
		public TerminalNode GEOMETRYCOLLECTIONFROMWKB() { return getToken(MySqlParser.GEOMETRYCOLLECTIONFROMWKB, 0); }
		public TerminalNode GEOMETRYFROMTEXT() { return getToken(MySqlParser.GEOMETRYFROMTEXT, 0); }
		public TerminalNode GEOMETRYFROMWKB() { return getToken(MySqlParser.GEOMETRYFROMWKB, 0); }
		public TerminalNode GEOMETRYN() { return getToken(MySqlParser.GEOMETRYN, 0); }
		public TerminalNode GEOMETRYTYPE() { return getToken(MySqlParser.GEOMETRYTYPE, 0); }
		public TerminalNode GEOMFROMTEXT() { return getToken(MySqlParser.GEOMFROMTEXT, 0); }
		public TerminalNode GEOMFROMWKB() { return getToken(MySqlParser.GEOMFROMWKB, 0); }
		public TerminalNode GET_FORMAT() { return getToken(MySqlParser.GET_FORMAT, 0); }
		public TerminalNode GET_LOCK() { return getToken(MySqlParser.GET_LOCK, 0); }
		public TerminalNode GLENGTH() { return getToken(MySqlParser.GLENGTH, 0); }
		public TerminalNode GREATEST() { return getToken(MySqlParser.GREATEST, 0); }
		public TerminalNode GTID_SUBSET() { return getToken(MySqlParser.GTID_SUBSET, 0); }
		public TerminalNode GTID_SUBTRACT() { return getToken(MySqlParser.GTID_SUBTRACT, 0); }
		public TerminalNode HEX() { return getToken(MySqlParser.HEX, 0); }
		public TerminalNode HOUR() { return getToken(MySqlParser.HOUR, 0); }
		public TerminalNode IFNULL() { return getToken(MySqlParser.IFNULL, 0); }
		public TerminalNode INET6_ATON() { return getToken(MySqlParser.INET6_ATON, 0); }
		public TerminalNode INET6_NTOA() { return getToken(MySqlParser.INET6_NTOA, 0); }
		public TerminalNode INET_ATON() { return getToken(MySqlParser.INET_ATON, 0); }
		public TerminalNode INET_NTOA() { return getToken(MySqlParser.INET_NTOA, 0); }
		public TerminalNode INSTR() { return getToken(MySqlParser.INSTR, 0); }
		public TerminalNode INTERIORRINGN() { return getToken(MySqlParser.INTERIORRINGN, 0); }
		public TerminalNode INTERSECTS() { return getToken(MySqlParser.INTERSECTS, 0); }
		public TerminalNode INVISIBLE() { return getToken(MySqlParser.INVISIBLE, 0); }
		public TerminalNode ISCLOSED() { return getToken(MySqlParser.ISCLOSED, 0); }
		public TerminalNode ISEMPTY() { return getToken(MySqlParser.ISEMPTY, 0); }
		public TerminalNode ISNULL() { return getToken(MySqlParser.ISNULL, 0); }
		public TerminalNode ISSIMPLE() { return getToken(MySqlParser.ISSIMPLE, 0); }
		public TerminalNode IS_FREE_LOCK() { return getToken(MySqlParser.IS_FREE_LOCK, 0); }
		public TerminalNode IS_IPV4() { return getToken(MySqlParser.IS_IPV4, 0); }
		public TerminalNode IS_IPV4_COMPAT() { return getToken(MySqlParser.IS_IPV4_COMPAT, 0); }
		public TerminalNode IS_IPV4_MAPPED() { return getToken(MySqlParser.IS_IPV4_MAPPED, 0); }
		public TerminalNode IS_IPV6() { return getToken(MySqlParser.IS_IPV6, 0); }
		public TerminalNode IS_USED_LOCK() { return getToken(MySqlParser.IS_USED_LOCK, 0); }
		public TerminalNode LAG() { return getToken(MySqlParser.LAG, 0); }
		public TerminalNode LAST_INSERT_ID() { return getToken(MySqlParser.LAST_INSERT_ID, 0); }
		public TerminalNode LAST_VALUE() { return getToken(MySqlParser.LAST_VALUE, 0); }
		public TerminalNode LCASE() { return getToken(MySqlParser.LCASE, 0); }
		public TerminalNode LEAD() { return getToken(MySqlParser.LEAD, 0); }
		public TerminalNode LEAST() { return getToken(MySqlParser.LEAST, 0); }
		public TerminalNode LEFT() { return getToken(MySqlParser.LEFT, 0); }
		public TerminalNode LENGTH() { return getToken(MySqlParser.LENGTH, 0); }
		public TerminalNode LINEFROMTEXT() { return getToken(MySqlParser.LINEFROMTEXT, 0); }
		public TerminalNode LINEFROMWKB() { return getToken(MySqlParser.LINEFROMWKB, 0); }
		public TerminalNode LINESTRING() { return getToken(MySqlParser.LINESTRING, 0); }
		public TerminalNode LINESTRINGFROMTEXT() { return getToken(MySqlParser.LINESTRINGFROMTEXT, 0); }
		public TerminalNode LINESTRINGFROMWKB() { return getToken(MySqlParser.LINESTRINGFROMWKB, 0); }
		public TerminalNode LN() { return getToken(MySqlParser.LN, 0); }
		public TerminalNode LOAD_FILE() { return getToken(MySqlParser.LOAD_FILE, 0); }
		public TerminalNode LOCATE() { return getToken(MySqlParser.LOCATE, 0); }
		public TerminalNode LOG() { return getToken(MySqlParser.LOG, 0); }
		public TerminalNode LOG10() { return getToken(MySqlParser.LOG10, 0); }
		public TerminalNode LOG2() { return getToken(MySqlParser.LOG2, 0); }
		public TerminalNode LOWER() { return getToken(MySqlParser.LOWER, 0); }
		public TerminalNode LPAD() { return getToken(MySqlParser.LPAD, 0); }
		public TerminalNode LTRIM() { return getToken(MySqlParser.LTRIM, 0); }
		public TerminalNode MAKEDATE() { return getToken(MySqlParser.MAKEDATE, 0); }
		public TerminalNode MAKETIME() { return getToken(MySqlParser.MAKETIME, 0); }
		public TerminalNode MAKE_SET() { return getToken(MySqlParser.MAKE_SET, 0); }
		public TerminalNode MASTER_POS_WAIT() { return getToken(MySqlParser.MASTER_POS_WAIT, 0); }
		public TerminalNode MBRCONTAINS() { return getToken(MySqlParser.MBRCONTAINS, 0); }
		public TerminalNode MBRDISJOINT() { return getToken(MySqlParser.MBRDISJOINT, 0); }
		public TerminalNode MBREQUAL() { return getToken(MySqlParser.MBREQUAL, 0); }
		public TerminalNode MBRINTERSECTS() { return getToken(MySqlParser.MBRINTERSECTS, 0); }
		public TerminalNode MBROVERLAPS() { return getToken(MySqlParser.MBROVERLAPS, 0); }
		public TerminalNode MBRTOUCHES() { return getToken(MySqlParser.MBRTOUCHES, 0); }
		public TerminalNode MBRWITHIN() { return getToken(MySqlParser.MBRWITHIN, 0); }
		public TerminalNode MD5() { return getToken(MySqlParser.MD5, 0); }
		public TerminalNode MICROSECOND() { return getToken(MySqlParser.MICROSECOND, 0); }
		public TerminalNode MINUTE() { return getToken(MySqlParser.MINUTE, 0); }
		public TerminalNode MLINEFROMTEXT() { return getToken(MySqlParser.MLINEFROMTEXT, 0); }
		public TerminalNode MLINEFROMWKB() { return getToken(MySqlParser.MLINEFROMWKB, 0); }
		public TerminalNode MOD() { return getToken(MySqlParser.MOD, 0); }
		public TerminalNode MONTH() { return getToken(MySqlParser.MONTH, 0); }
		public TerminalNode MONTHNAME() { return getToken(MySqlParser.MONTHNAME, 0); }
		public TerminalNode MPOINTFROMTEXT() { return getToken(MySqlParser.MPOINTFROMTEXT, 0); }
		public TerminalNode MPOINTFROMWKB() { return getToken(MySqlParser.MPOINTFROMWKB, 0); }
		public TerminalNode MPOLYFROMTEXT() { return getToken(MySqlParser.MPOLYFROMTEXT, 0); }
		public TerminalNode MPOLYFROMWKB() { return getToken(MySqlParser.MPOLYFROMWKB, 0); }
		public TerminalNode MULTILINESTRING() { return getToken(MySqlParser.MULTILINESTRING, 0); }
		public TerminalNode MULTILINESTRINGFROMTEXT() { return getToken(MySqlParser.MULTILINESTRINGFROMTEXT, 0); }
		public TerminalNode MULTILINESTRINGFROMWKB() { return getToken(MySqlParser.MULTILINESTRINGFROMWKB, 0); }
		public TerminalNode MULTIPOINT() { return getToken(MySqlParser.MULTIPOINT, 0); }
		public TerminalNode MULTIPOINTFROMTEXT() { return getToken(MySqlParser.MULTIPOINTFROMTEXT, 0); }
		public TerminalNode MULTIPOINTFROMWKB() { return getToken(MySqlParser.MULTIPOINTFROMWKB, 0); }
		public TerminalNode MULTIPOLYGON() { return getToken(MySqlParser.MULTIPOLYGON, 0); }
		public TerminalNode MULTIPOLYGONFROMTEXT() { return getToken(MySqlParser.MULTIPOLYGONFROMTEXT, 0); }
		public TerminalNode MULTIPOLYGONFROMWKB() { return getToken(MySqlParser.MULTIPOLYGONFROMWKB, 0); }
		public TerminalNode NAME_CONST() { return getToken(MySqlParser.NAME_CONST, 0); }
		public TerminalNode NTH_VALUE() { return getToken(MySqlParser.NTH_VALUE, 0); }
		public TerminalNode NTILE() { return getToken(MySqlParser.NTILE, 0); }
		public TerminalNode NULLIF() { return getToken(MySqlParser.NULLIF, 0); }
		public TerminalNode NUMGEOMETRIES() { return getToken(MySqlParser.NUMGEOMETRIES, 0); }
		public TerminalNode NUMINTERIORRINGS() { return getToken(MySqlParser.NUMINTERIORRINGS, 0); }
		public TerminalNode NUMPOINTS() { return getToken(MySqlParser.NUMPOINTS, 0); }
		public TerminalNode OCT() { return getToken(MySqlParser.OCT, 0); }
		public TerminalNode OCTET_LENGTH() { return getToken(MySqlParser.OCTET_LENGTH, 0); }
		public TerminalNode ORD() { return getToken(MySqlParser.ORD, 0); }
		public TerminalNode OVERLAPS() { return getToken(MySqlParser.OVERLAPS, 0); }
		public TerminalNode PERCENT_RANK() { return getToken(MySqlParser.PERCENT_RANK, 0); }
		public TerminalNode PERIOD_ADD() { return getToken(MySqlParser.PERIOD_ADD, 0); }
		public TerminalNode PERIOD_DIFF() { return getToken(MySqlParser.PERIOD_DIFF, 0); }
		public TerminalNode PI() { return getToken(MySqlParser.PI, 0); }
		public TerminalNode POINT() { return getToken(MySqlParser.POINT, 0); }
		public TerminalNode POINTFROMTEXT() { return getToken(MySqlParser.POINTFROMTEXT, 0); }
		public TerminalNode POINTFROMWKB() { return getToken(MySqlParser.POINTFROMWKB, 0); }
		public TerminalNode POINTN() { return getToken(MySqlParser.POINTN, 0); }
		public TerminalNode POLYFROMTEXT() { return getToken(MySqlParser.POLYFROMTEXT, 0); }
		public TerminalNode POLYFROMWKB() { return getToken(MySqlParser.POLYFROMWKB, 0); }
		public TerminalNode POLYGON() { return getToken(MySqlParser.POLYGON, 0); }
		public TerminalNode POLYGONFROMTEXT() { return getToken(MySqlParser.POLYGONFROMTEXT, 0); }
		public TerminalNode POLYGONFROMWKB() { return getToken(MySqlParser.POLYGONFROMWKB, 0); }
		public TerminalNode POSITION() { return getToken(MySqlParser.POSITION, 0); }
		public TerminalNode POW() { return getToken(MySqlParser.POW, 0); }
		public TerminalNode POWER() { return getToken(MySqlParser.POWER, 0); }
		public TerminalNode QUARTER() { return getToken(MySqlParser.QUARTER, 0); }
		public TerminalNode QUOTE() { return getToken(MySqlParser.QUOTE, 0); }
		public TerminalNode RADIANS() { return getToken(MySqlParser.RADIANS, 0); }
		public TerminalNode RAND() { return getToken(MySqlParser.RAND, 0); }
		public TerminalNode RANDOM() { return getToken(MySqlParser.RANDOM, 0); }
		public TerminalNode RANK() { return getToken(MySqlParser.RANK, 0); }
		public TerminalNode RANDOM_BYTES() { return getToken(MySqlParser.RANDOM_BYTES, 0); }
		public TerminalNode RELEASE_LOCK() { return getToken(MySqlParser.RELEASE_LOCK, 0); }
		public TerminalNode REVERSE() { return getToken(MySqlParser.REVERSE, 0); }
		public TerminalNode RIGHT() { return getToken(MySqlParser.RIGHT, 0); }
		public TerminalNode ROUND() { return getToken(MySqlParser.ROUND, 0); }
		public TerminalNode ROW_COUNT() { return getToken(MySqlParser.ROW_COUNT, 0); }
		public TerminalNode ROW_NUMBER() { return getToken(MySqlParser.ROW_NUMBER, 0); }
		public TerminalNode RPAD() { return getToken(MySqlParser.RPAD, 0); }
		public TerminalNode RTRIM() { return getToken(MySqlParser.RTRIM, 0); }
		public TerminalNode SCHEMA() { return getToken(MySqlParser.SCHEMA, 0); }
		public TerminalNode SECOND() { return getToken(MySqlParser.SECOND, 0); }
		public TerminalNode SEC_TO_TIME() { return getToken(MySqlParser.SEC_TO_TIME, 0); }
		public TerminalNode SESSION_USER() { return getToken(MySqlParser.SESSION_USER, 0); }
		public TerminalNode SESSION_VARIABLES_ADMIN() { return getToken(MySqlParser.SESSION_VARIABLES_ADMIN, 0); }
		public TerminalNode SHA() { return getToken(MySqlParser.SHA, 0); }
		public TerminalNode SHA1() { return getToken(MySqlParser.SHA1, 0); }
		public TerminalNode SHA2() { return getToken(MySqlParser.SHA2, 0); }
		public TerminalNode SIGN() { return getToken(MySqlParser.SIGN, 0); }
		public TerminalNode SIN() { return getToken(MySqlParser.SIN, 0); }
		public TerminalNode SLEEP() { return getToken(MySqlParser.SLEEP, 0); }
		public TerminalNode SOUNDEX() { return getToken(MySqlParser.SOUNDEX, 0); }
		public TerminalNode SQL_THREAD_WAIT_AFTER_GTIDS() { return getToken(MySqlParser.SQL_THREAD_WAIT_AFTER_GTIDS, 0); }
		public TerminalNode SQRT() { return getToken(MySqlParser.SQRT, 0); }
		public TerminalNode SRID() { return getToken(MySqlParser.SRID, 0); }
		public TerminalNode STARTPOINT() { return getToken(MySqlParser.STARTPOINT, 0); }
		public TerminalNode STRCMP() { return getToken(MySqlParser.STRCMP, 0); }
		public TerminalNode STR_TO_DATE() { return getToken(MySqlParser.STR_TO_DATE, 0); }
		public TerminalNode ST_AREA() { return getToken(MySqlParser.ST_AREA, 0); }
		public TerminalNode ST_ASBINARY() { return getToken(MySqlParser.ST_ASBINARY, 0); }
		public TerminalNode ST_ASTEXT() { return getToken(MySqlParser.ST_ASTEXT, 0); }
		public TerminalNode ST_ASWKB() { return getToken(MySqlParser.ST_ASWKB, 0); }
		public TerminalNode ST_ASWKT() { return getToken(MySqlParser.ST_ASWKT, 0); }
		public TerminalNode ST_BUFFER() { return getToken(MySqlParser.ST_BUFFER, 0); }
		public TerminalNode ST_CENTROID() { return getToken(MySqlParser.ST_CENTROID, 0); }
		public TerminalNode ST_CONTAINS() { return getToken(MySqlParser.ST_CONTAINS, 0); }
		public TerminalNode ST_CROSSES() { return getToken(MySqlParser.ST_CROSSES, 0); }
		public TerminalNode ST_DIFFERENCE() { return getToken(MySqlParser.ST_DIFFERENCE, 0); }
		public TerminalNode ST_DIMENSION() { return getToken(MySqlParser.ST_DIMENSION, 0); }
		public TerminalNode ST_DISJOINT() { return getToken(MySqlParser.ST_DISJOINT, 0); }
		public TerminalNode ST_DISTANCE() { return getToken(MySqlParser.ST_DISTANCE, 0); }
		public TerminalNode ST_ENDPOINT() { return getToken(MySqlParser.ST_ENDPOINT, 0); }
		public TerminalNode ST_ENVELOPE() { return getToken(MySqlParser.ST_ENVELOPE, 0); }
		public TerminalNode ST_EQUALS() { return getToken(MySqlParser.ST_EQUALS, 0); }
		public TerminalNode ST_EXTERIORRING() { return getToken(MySqlParser.ST_EXTERIORRING, 0); }
		public TerminalNode ST_GEOMCOLLFROMTEXT() { return getToken(MySqlParser.ST_GEOMCOLLFROMTEXT, 0); }
		public TerminalNode ST_GEOMCOLLFROMTXT() { return getToken(MySqlParser.ST_GEOMCOLLFROMTXT, 0); }
		public TerminalNode ST_GEOMCOLLFROMWKB() { return getToken(MySqlParser.ST_GEOMCOLLFROMWKB, 0); }
		public TerminalNode ST_GEOMETRYCOLLECTIONFROMTEXT() { return getToken(MySqlParser.ST_GEOMETRYCOLLECTIONFROMTEXT, 0); }
		public TerminalNode ST_GEOMETRYCOLLECTIONFROMWKB() { return getToken(MySqlParser.ST_GEOMETRYCOLLECTIONFROMWKB, 0); }
		public TerminalNode ST_GEOMETRYFROMTEXT() { return getToken(MySqlParser.ST_GEOMETRYFROMTEXT, 0); }
		public TerminalNode ST_GEOMETRYFROMWKB() { return getToken(MySqlParser.ST_GEOMETRYFROMWKB, 0); }
		public TerminalNode ST_GEOMETRYN() { return getToken(MySqlParser.ST_GEOMETRYN, 0); }
		public TerminalNode ST_GEOMETRYTYPE() { return getToken(MySqlParser.ST_GEOMETRYTYPE, 0); }
		public TerminalNode ST_GEOMFROMTEXT() { return getToken(MySqlParser.ST_GEOMFROMTEXT, 0); }
		public TerminalNode ST_GEOMFROMWKB() { return getToken(MySqlParser.ST_GEOMFROMWKB, 0); }
		public TerminalNode ST_INTERIORRINGN() { return getToken(MySqlParser.ST_INTERIORRINGN, 0); }
		public TerminalNode ST_INTERSECTION() { return getToken(MySqlParser.ST_INTERSECTION, 0); }
		public TerminalNode ST_INTERSECTS() { return getToken(MySqlParser.ST_INTERSECTS, 0); }
		public TerminalNode ST_ISCLOSED() { return getToken(MySqlParser.ST_ISCLOSED, 0); }
		public TerminalNode ST_ISEMPTY() { return getToken(MySqlParser.ST_ISEMPTY, 0); }
		public TerminalNode ST_ISSIMPLE() { return getToken(MySqlParser.ST_ISSIMPLE, 0); }
		public TerminalNode ST_LINEFROMTEXT() { return getToken(MySqlParser.ST_LINEFROMTEXT, 0); }
		public TerminalNode ST_LINEFROMWKB() { return getToken(MySqlParser.ST_LINEFROMWKB, 0); }
		public TerminalNode ST_LINESTRINGFROMTEXT() { return getToken(MySqlParser.ST_LINESTRINGFROMTEXT, 0); }
		public TerminalNode ST_LINESTRINGFROMWKB() { return getToken(MySqlParser.ST_LINESTRINGFROMWKB, 0); }
		public TerminalNode ST_NUMGEOMETRIES() { return getToken(MySqlParser.ST_NUMGEOMETRIES, 0); }
		public TerminalNode ST_NUMINTERIORRING() { return getToken(MySqlParser.ST_NUMINTERIORRING, 0); }
		public TerminalNode ST_NUMINTERIORRINGS() { return getToken(MySqlParser.ST_NUMINTERIORRINGS, 0); }
		public TerminalNode ST_NUMPOINTS() { return getToken(MySqlParser.ST_NUMPOINTS, 0); }
		public TerminalNode ST_OVERLAPS() { return getToken(MySqlParser.ST_OVERLAPS, 0); }
		public TerminalNode ST_POINTFROMTEXT() { return getToken(MySqlParser.ST_POINTFROMTEXT, 0); }
		public TerminalNode ST_POINTFROMWKB() { return getToken(MySqlParser.ST_POINTFROMWKB, 0); }
		public TerminalNode ST_POINTN() { return getToken(MySqlParser.ST_POINTN, 0); }
		public TerminalNode ST_POLYFROMTEXT() { return getToken(MySqlParser.ST_POLYFROMTEXT, 0); }
		public TerminalNode ST_POLYFROMWKB() { return getToken(MySqlParser.ST_POLYFROMWKB, 0); }
		public TerminalNode ST_POLYGONFROMTEXT() { return getToken(MySqlParser.ST_POLYGONFROMTEXT, 0); }
		public TerminalNode ST_POLYGONFROMWKB() { return getToken(MySqlParser.ST_POLYGONFROMWKB, 0); }
		public TerminalNode ST_SRID() { return getToken(MySqlParser.ST_SRID, 0); }
		public TerminalNode ST_STARTPOINT() { return getToken(MySqlParser.ST_STARTPOINT, 0); }
		public TerminalNode ST_SYMDIFFERENCE() { return getToken(MySqlParser.ST_SYMDIFFERENCE, 0); }
		public TerminalNode ST_TOUCHES() { return getToken(MySqlParser.ST_TOUCHES, 0); }
		public TerminalNode ST_UNION() { return getToken(MySqlParser.ST_UNION, 0); }
		public TerminalNode ST_WITHIN() { return getToken(MySqlParser.ST_WITHIN, 0); }
		public TerminalNode ST_X() { return getToken(MySqlParser.ST_X, 0); }
		public TerminalNode ST_Y() { return getToken(MySqlParser.ST_Y, 0); }
		public TerminalNode SUBDATE() { return getToken(MySqlParser.SUBDATE, 0); }
		public TerminalNode SUBSTRING_INDEX() { return getToken(MySqlParser.SUBSTRING_INDEX, 0); }
		public TerminalNode SUBTIME() { return getToken(MySqlParser.SUBTIME, 0); }
		public TerminalNode SYSTEM_USER() { return getToken(MySqlParser.SYSTEM_USER, 0); }
		public TerminalNode TAN() { return getToken(MySqlParser.TAN, 0); }
		public TerminalNode TIME() { return getToken(MySqlParser.TIME, 0); }
		public TerminalNode TIMEDIFF() { return getToken(MySqlParser.TIMEDIFF, 0); }
		public TerminalNode TIMESTAMP() { return getToken(MySqlParser.TIMESTAMP, 0); }
		public TerminalNode TIMESTAMPADD() { return getToken(MySqlParser.TIMESTAMPADD, 0); }
		public TerminalNode TIMESTAMPDIFF() { return getToken(MySqlParser.TIMESTAMPDIFF, 0); }
		public TerminalNode TIME_FORMAT() { return getToken(MySqlParser.TIME_FORMAT, 0); }
		public TerminalNode TIME_TO_SEC() { return getToken(MySqlParser.TIME_TO_SEC, 0); }
		public TerminalNode TOUCHES() { return getToken(MySqlParser.TOUCHES, 0); }
		public TerminalNode TO_BASE64() { return getToken(MySqlParser.TO_BASE64, 0); }
		public TerminalNode TO_DAYS() { return getToken(MySqlParser.TO_DAYS, 0); }
		public TerminalNode TO_SECONDS() { return getToken(MySqlParser.TO_SECONDS, 0); }
		public TerminalNode UCASE() { return getToken(MySqlParser.UCASE, 0); }
		public TerminalNode UNCOMPRESS() { return getToken(MySqlParser.UNCOMPRESS, 0); }
		public TerminalNode UNCOMPRESSED_LENGTH() { return getToken(MySqlParser.UNCOMPRESSED_LENGTH, 0); }
		public TerminalNode UNHEX() { return getToken(MySqlParser.UNHEX, 0); }
		public TerminalNode UNIX_TIMESTAMP() { return getToken(MySqlParser.UNIX_TIMESTAMP, 0); }
		public TerminalNode UPDATEXML() { return getToken(MySqlParser.UPDATEXML, 0); }
		public TerminalNode UPPER() { return getToken(MySqlParser.UPPER, 0); }
		public TerminalNode UUID() { return getToken(MySqlParser.UUID, 0); }
		public TerminalNode UUID_SHORT() { return getToken(MySqlParser.UUID_SHORT, 0); }
		public TerminalNode VALIDATE_PASSWORD_STRENGTH() { return getToken(MySqlParser.VALIDATE_PASSWORD_STRENGTH, 0); }
		public TerminalNode VERSION() { return getToken(MySqlParser.VERSION, 0); }
		public TerminalNode VISIBLE() { return getToken(MySqlParser.VISIBLE, 0); }
		public TerminalNode WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS() { return getToken(MySqlParser.WAIT_UNTIL_SQL_THREAD_AFTER_GTIDS, 0); }
		public TerminalNode WEEK() { return getToken(MySqlParser.WEEK, 0); }
		public TerminalNode WEEKDAY() { return getToken(MySqlParser.WEEKDAY, 0); }
		public TerminalNode WEEKOFYEAR() { return getToken(MySqlParser.WEEKOFYEAR, 0); }
		public TerminalNode WEIGHT_STRING() { return getToken(MySqlParser.WEIGHT_STRING, 0); }
		public TerminalNode WITHIN() { return getToken(MySqlParser.WITHIN, 0); }
		public TerminalNode YEAR() { return getToken(MySqlParser.YEAR, 0); }
		public TerminalNode YEARWEEK() { return getToken(MySqlParser.YEARWEEK, 0); }
		public TerminalNode Y_FUNCTION() { return getToken(MySqlParser.Y_FUNCTION, 0); }
		public TerminalNode X_FUNCTION() { return getToken(MySqlParser.X_FUNCTION, 0); }
		public TerminalNode JSON_ARRAY() { return getToken(MySqlParser.JSON_ARRAY, 0); }
		public TerminalNode JSON_OBJECT() { return getToken(MySqlParser.JSON_OBJECT, 0); }
		public TerminalNode JSON_QUOTE() { return getToken(MySqlParser.JSON_QUOTE, 0); }
		public TerminalNode JSON_CONTAINS() { return getToken(MySqlParser.JSON_CONTAINS, 0); }
		public TerminalNode JSON_CONTAINS_PATH() { return getToken(MySqlParser.JSON_CONTAINS_PATH, 0); }
		public TerminalNode JSON_EXTRACT() { return getToken(MySqlParser.JSON_EXTRACT, 0); }
		public TerminalNode JSON_KEYS() { return getToken(MySqlParser.JSON_KEYS, 0); }
		public TerminalNode JSON_OVERLAPS() { return getToken(MySqlParser.JSON_OVERLAPS, 0); }
		public TerminalNode JSON_SEARCH() { return getToken(MySqlParser.JSON_SEARCH, 0); }
		public TerminalNode JSON_VALUE() { return getToken(MySqlParser.JSON_VALUE, 0); }
		public TerminalNode JSON_ARRAY_APPEND() { return getToken(MySqlParser.JSON_ARRAY_APPEND, 0); }
		public TerminalNode JSON_ARRAY_INSERT() { return getToken(MySqlParser.JSON_ARRAY_INSERT, 0); }
		public TerminalNode JSON_INSERT() { return getToken(MySqlParser.JSON_INSERT, 0); }
		public TerminalNode JSON_MERGE() { return getToken(MySqlParser.JSON_MERGE, 0); }
		public TerminalNode JSON_MERGE_PATCH() { return getToken(MySqlParser.JSON_MERGE_PATCH, 0); }
		public TerminalNode JSON_MERGE_PRESERVE() { return getToken(MySqlParser.JSON_MERGE_PRESERVE, 0); }
		public TerminalNode JSON_REMOVE() { return getToken(MySqlParser.JSON_REMOVE, 0); }
		public TerminalNode JSON_REPLACE() { return getToken(MySqlParser.JSON_REPLACE, 0); }
		public TerminalNode JSON_SET() { return getToken(MySqlParser.JSON_SET, 0); }
		public TerminalNode JSON_UNQUOTE() { return getToken(MySqlParser.JSON_UNQUOTE, 0); }
		public TerminalNode JSON_DEPTH() { return getToken(MySqlParser.JSON_DEPTH, 0); }
		public TerminalNode JSON_LENGTH() { return getToken(MySqlParser.JSON_LENGTH, 0); }
		public TerminalNode JSON_TYPE() { return getToken(MySqlParser.JSON_TYPE, 0); }
		public TerminalNode JSON_VALID() { return getToken(MySqlParser.JSON_VALID, 0); }
		public TerminalNode JSON_TABLE() { return getToken(MySqlParser.JSON_TABLE, 0); }
		public TerminalNode JSON_SCHEMA_VALID() { return getToken(MySqlParser.JSON_SCHEMA_VALID, 0); }
		public TerminalNode JSON_SCHEMA_VALIDATION_REPORT() { return getToken(MySqlParser.JSON_SCHEMA_VALIDATION_REPORT, 0); }
		public TerminalNode JSON_PRETTY() { return getToken(MySqlParser.JSON_PRETTY, 0); }
		public TerminalNode JSON_STORAGE_FREE() { return getToken(MySqlParser.JSON_STORAGE_FREE, 0); }
		public TerminalNode JSON_STORAGE_SIZE() { return getToken(MySqlParser.JSON_STORAGE_SIZE, 0); }
		public TerminalNode JSON_ARRAYAGG() { return getToken(MySqlParser.JSON_ARRAYAGG, 0); }
		public TerminalNode JSON_OBJECTAGG() { return getToken(MySqlParser.JSON_OBJECTAGG, 0); }
		public FunctionNameBaseContext(ParserRuleContext parent, int invokingState) {
			super(parent, invokingState);
		}
		@Override public int getRuleIndex() { return RULE_functionNameBase; }
		@Override
		public void enterRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).enterFunctionNameBase(this);
		}
		@Override
		public void exitRule(ParseTreeListener listener) {
			if ( listener instanceof MySqlParserListener ) ((MySqlParserListener)listener).exitFunctionNameBase(this);
		}
		@Override
		public  T accept(ParseTreeVisitor visitor) {
			if ( visitor instanceof MySqlParserVisitor ) return ((MySqlParserVisitor)visitor).visitFunctionNameBase(this);
			else return visitor.visitChildren(this);
		}
	}

	public final FunctionNameBaseContext functionNameBase() throws RecognitionException {
		FunctionNameBaseContext _localctx = new FunctionNameBaseContext(_ctx, getState());
		enterRule(_localctx, 720, RULE_functionNameBase);
		int _la;
		try {
			enterOuterAlt(_localctx, 1);
			{
			setState(7438);
			_la = _input.LA(1);
			if ( !(_la==DATABASE || ((((_la - 97)) & ~0x3f) == 0 && ((1L << (_la - 97)) & 11258999068426241L) != 0) || ((((_la - 217)) & ~0x3f) == 0 && ((1L << (_la - 217)) & -17179869161L) != 0) || ((((_la - 281)) & ~0x3f) == 0 && ((1L << (_la - 281)) & 8796109397507L) != 0) || _la==INVISIBLE || ((((_la - 673)) & ~0x3f) == 0 && ((1L << (_la - 673)) & -9223372036838064127L) != 0) || ((((_la - 803)) & ~0x3f) == 0 && ((1L << (_la - 803)) & -8589934599L) != 0) || ((((_la - 867)) & ~0x3f) == 0 && ((1L << (_la - 867)) & -257L) != 0) || ((((_la - 931)) & ~0x3f) == 0 && ((1L << (_la - 931)) & -1L) != 0) || ((((_la - 995)) & ~0x3f) == 0 && ((1L << (_la - 995)) & -1057L) != 0) || ((((_la - 1059)) & ~0x3f) == 0 && ((1L << (_la - 1059)) & 562949416550399L) != 0) || _la==MOD) ) {
			_errHandler.recoverInline(this);
			}
			else {
				if ( _input.LA(1)==Token.EOF ) matchedEOF = true;
				_errHandler.reportMatch(this);
				consume();
			}
			}
		}
		catch (RecognitionException re) {
			_localctx.exception = re;
			_errHandler.reportError(this, re);
			_errHandler.recover(this, re);
		}
		finally {
			exitRule();
		}
		return _localctx;
	}

	public boolean sempred(RuleContext _localctx, int ruleIndex, int predIndex) {
		switch (ruleIndex) {
		case 344:
			return expression_sempred((ExpressionContext)_localctx, predIndex);
		case 345:
			return predicate_sempred((PredicateContext)_localctx, predIndex);
		case 346:
			return expressionAtom_sempred((ExpressionAtomContext)_localctx, predIndex);
		}
		return true;
	}
	private boolean expression_sempred(ExpressionContext _localctx, int predIndex) {
		switch (predIndex) {
		case 0:
			return precpred(_ctx, 3);
		}
		return true;
	}
	private boolean predicate_sempred(PredicateContext _localctx, int predIndex) {
		switch (predIndex) {
		case 1:
			return precpred(_ctx, 8);
		case 2:
			return precpred(_ctx, 6);
		case 3:
			return precpred(_ctx, 5);
		case 4:
			return precpred(_ctx, 3);
		case 5:
			return precpred(_ctx, 10);
		case 6:
			return precpred(_ctx, 9);
		case 7:
			return precpred(_ctx, 7);
		case 8:
			return precpred(_ctx, 4);
		case 9:
			return precpred(_ctx, 2);
		}
		return true;
	}
	private boolean expressionAtom_sempred(ExpressionAtomContext _localctx, int predIndex) {
		switch (predIndex) {
		case 10:
			return precpred(_ctx, 4);
		case 11:
			return precpred(_ctx, 3);
		case 12:
			return precpred(_ctx, 2);
		case 13:
			return precpred(_ctx, 1);
		case 14:
			return precpred(_ctx, 14);
		}
		return true;
	}

	private static final String _serializedATNSegment0 =
		"\u0004\u0001\u0489\u1d11\u0002\u0000\u0007\u0000\u0002\u0001\u0007\u0001"+
		"\u0002\u0002\u0007\u0002\u0002\u0003\u0007\u0003\u0002\u0004\u0007\u0004"+
		"\u0002\u0005\u0007\u0005\u0002\u0006\u0007\u0006\u0002\u0007\u0007\u0007"+
		"\u0002\b\u0007\b\u0002\t\u0007\t\u0002\n\u0007\n\u0002\u000b\u0007\u000b"+
		"\u0002\f\u0007\f\u0002\r\u0007\r\u0002\u000e\u0007\u000e\u0002\u000f\u0007"+
		"\u000f\u0002\u0010\u0007\u0010\u0002\u0011\u0007\u0011\u0002\u0012\u0007"+
		"\u0012\u0002\u0013\u0007\u0013\u0002\u0014\u0007\u0014\u0002\u0015\u0007"+
		"\u0015\u0002\u0016\u0007\u0016\u0002\u0017\u0007\u0017\u0002\u0018\u0007"+
		"\u0018\u0002\u0019\u0007\u0019\u0002\u001a\u0007\u001a\u0002\u001b\u0007"+
		"\u001b\u0002\u001c\u0007\u001c\u0002\u001d\u0007\u001d\u0002\u001e\u0007"+
		"\u001e\u0002\u001f\u0007\u001f\u0002 \u0007 \u0002!\u0007!\u0002\"\u0007"+
		"\"\u0002#\u0007#\u0002$\u0007$\u0002%\u0007%\u0002&\u0007&\u0002\'\u0007"+
		"\'\u0002(\u0007(\u0002)\u0007)\u0002*\u0007*\u0002+\u0007+\u0002,\u0007"+
		",\u0002-\u0007-\u0002.\u0007.\u0002/\u0007/\u00020\u00070\u00021\u0007"+
		"1\u00022\u00072\u00023\u00073\u00024\u00074\u00025\u00075\u00026\u0007"+
		"6\u00027\u00077\u00028\u00078\u00029\u00079\u0002:\u0007:\u0002;\u0007"+
		";\u0002<\u0007<\u0002=\u0007=\u0002>\u0007>\u0002?\u0007?\u0002@\u0007"+
		"@\u0002A\u0007A\u0002B\u0007B\u0002C\u0007C\u0002D\u0007D\u0002E\u0007"+
		"E\u0002F\u0007F\u0002G\u0007G\u0002H\u0007H\u0002I\u0007I\u0002J\u0007"+
		"J\u0002K\u0007K\u0002L\u0007L\u0002M\u0007M\u0002N\u0007N\u0002O\u0007"+
		"O\u0002P\u0007P\u0002Q\u0007Q\u0002R\u0007R\u0002S\u0007S\u0002T\u0007"+
		"T\u0002U\u0007U\u0002V\u0007V\u0002W\u0007W\u0002X\u0007X\u0002Y\u0007"+
		"Y\u0002Z\u0007Z\u0002[\u0007[\u0002\\\u0007\\\u0002]\u0007]\u0002^\u0007"+
		"^\u0002_\u0007_\u0002`\u0007`\u0002a\u0007a\u0002b\u0007b\u0002c\u0007"+
		"c\u0002d\u0007d\u0002e\u0007e\u0002f\u0007f\u0002g\u0007g\u0002h\u0007"+
		"h\u0002i\u0007i\u0002j\u0007j\u0002k\u0007k\u0002l\u0007l\u0002m\u0007"+
		"m\u0002n\u0007n\u0002o\u0007o\u0002p\u0007p\u0002q\u0007q\u0002r\u0007"+
		"r\u0002s\u0007s\u0002t\u0007t\u0002u\u0007u\u0002v\u0007v\u0002w\u0007"+
		"w\u0002x\u0007x\u0002y\u0007y\u0002z\u0007z\u0002{\u0007{\u0002|\u0007"+
		"|\u0002}\u0007}\u0002~\u0007~\u0002\u007f\u0007\u007f\u0002\u0080\u0007"+
		"\u0080\u0002\u0081\u0007\u0081\u0002\u0082\u0007\u0082\u0002\u0083\u0007"+
		"\u0083\u0002\u0084\u0007\u0084\u0002\u0085\u0007\u0085\u0002\u0086\u0007"+
		"\u0086\u0002\u0087\u0007\u0087\u0002\u0088\u0007\u0088\u0002\u0089\u0007"+
		"\u0089\u0002\u008a\u0007\u008a\u0002\u008b\u0007\u008b\u0002\u008c\u0007"+
		"\u008c\u0002\u008d\u0007\u008d\u0002\u008e\u0007\u008e\u0002\u008f\u0007"+
		"\u008f\u0002\u0090\u0007\u0090\u0002\u0091\u0007\u0091\u0002\u0092\u0007"+
		"\u0092\u0002\u0093\u0007\u0093\u0002\u0094\u0007\u0094\u0002\u0095\u0007"+
		"\u0095\u0002\u0096\u0007\u0096\u0002\u0097\u0007\u0097\u0002\u0098\u0007"+
		"\u0098\u0002\u0099\u0007\u0099\u0002\u009a\u0007\u009a\u0002\u009b\u0007"+
		"\u009b\u0002\u009c\u0007\u009c\u0002\u009d\u0007\u009d\u0002\u009e\u0007"+
		"\u009e\u0002\u009f\u0007\u009f\u0002\u00a0\u0007\u00a0\u0002\u00a1\u0007"+
		"\u00a1\u0002\u00a2\u0007\u00a2\u0002\u00a3\u0007\u00a3\u0002\u00a4\u0007"+
		"\u00a4\u0002\u00a5\u0007\u00a5\u0002\u00a6\u0007\u00a6\u0002\u00a7\u0007"+
		"\u00a7\u0002\u00a8\u0007\u00a8\u0002\u00a9\u0007\u00a9\u0002\u00aa\u0007"+
		"\u00aa\u0002\u00ab\u0007\u00ab\u0002\u00ac\u0007\u00ac\u0002\u00ad\u0007"+
		"\u00ad\u0002\u00ae\u0007\u00ae\u0002\u00af\u0007\u00af\u0002\u00b0\u0007"+
		"\u00b0\u0002\u00b1\u0007\u00b1\u0002\u00b2\u0007\u00b2\u0002\u00b3\u0007"+
		"\u00b3\u0002\u00b4\u0007\u00b4\u0002\u00b5\u0007\u00b5\u0002\u00b6\u0007"+
		"\u00b6\u0002\u00b7\u0007\u00b7\u0002\u00b8\u0007\u00b8\u0002\u00b9\u0007"+
		"\u00b9\u0002\u00ba\u0007\u00ba\u0002\u00bb\u0007\u00bb\u0002\u00bc\u0007"+
		"\u00bc\u0002\u00bd\u0007\u00bd\u0002\u00be\u0007\u00be\u0002\u00bf\u0007"+
		"\u00bf\u0002\u00c0\u0007\u00c0\u0002\u00c1\u0007\u00c1\u0002\u00c2\u0007"+
		"\u00c2\u0002\u00c3\u0007\u00c3\u0002\u00c4\u0007\u00c4\u0002\u00c5\u0007"+
		"\u00c5\u0002\u00c6\u0007\u00c6\u0002\u00c7\u0007\u00c7\u0002\u00c8\u0007"+
		"\u00c8\u0002\u00c9\u0007\u00c9\u0002\u00ca\u0007\u00ca\u0002\u00cb\u0007"+
		"\u00cb\u0002\u00cc\u0007\u00cc\u0002\u00cd\u0007\u00cd\u0002\u00ce\u0007"+
		"\u00ce\u0002\u00cf\u0007\u00cf\u0002\u00d0\u0007\u00d0\u0002\u00d1\u0007"+
		"\u00d1\u0002\u00d2\u0007\u00d2\u0002\u00d3\u0007\u00d3\u0002\u00d4\u0007"+
		"\u00d4\u0002\u00d5\u0007\u00d5\u0002\u00d6\u0007\u00d6\u0002\u00d7\u0007"+
		"\u00d7\u0002\u00d8\u0007\u00d8\u0002\u00d9\u0007\u00d9\u0002\u00da\u0007"+
		"\u00da\u0002\u00db\u0007\u00db\u0002\u00dc\u0007\u00dc\u0002\u00dd\u0007"+
		"\u00dd\u0002\u00de\u0007\u00de\u0002\u00df\u0007\u00df\u0002\u00e0\u0007"+
		"\u00e0\u0002\u00e1\u0007\u00e1\u0002\u00e2\u0007\u00e2\u0002\u00e3\u0007"+
		"\u00e3\u0002\u00e4\u0007\u00e4\u0002\u00e5\u0007\u00e5\u0002\u00e6\u0007"+
		"\u00e6\u0002\u00e7\u0007\u00e7\u0002\u00e8\u0007\u00e8\u0002\u00e9\u0007"+
		"\u00e9\u0002\u00ea\u0007\u00ea\u0002\u00eb\u0007\u00eb\u0002\u00ec\u0007"+
		"\u00ec\u0002\u00ed\u0007\u00ed\u0002\u00ee\u0007\u00ee\u0002\u00ef\u0007"+
		"\u00ef\u0002\u00f0\u0007\u00f0\u0002\u00f1\u0007\u00f1\u0002\u00f2\u0007"+
		"\u00f2\u0002\u00f3\u0007\u00f3\u0002\u00f4\u0007\u00f4\u0002\u00f5\u0007"+
		"\u00f5\u0002\u00f6\u0007\u00f6\u0002\u00f7\u0007\u00f7\u0002\u00f8\u0007"+
		"\u00f8\u0002\u00f9\u0007\u00f9\u0002\u00fa\u0007\u00fa\u0002\u00fb\u0007"+
		"\u00fb\u0002\u00fc\u0007\u00fc\u0002\u00fd\u0007\u00fd\u0002\u00fe\u0007"+
		"\u00fe\u0002\u00ff\u0007\u00ff\u0002\u0100\u0007\u0100\u0002\u0101\u0007"+
		"\u0101\u0002\u0102\u0007\u0102\u0002\u0103\u0007\u0103\u0002\u0104\u0007"+
		"\u0104\u0002\u0105\u0007\u0105\u0002\u0106\u0007\u0106\u0002\u0107\u0007"+
		"\u0107\u0002\u0108\u0007\u0108\u0002\u0109\u0007\u0109\u0002\u010a\u0007"+
		"\u010a\u0002\u010b\u0007\u010b\u0002\u010c\u0007\u010c\u0002\u010d\u0007"+
		"\u010d\u0002\u010e\u0007\u010e\u0002\u010f\u0007\u010f\u0002\u0110\u0007"+
		"\u0110\u0002\u0111\u0007\u0111\u0002\u0112\u0007\u0112\u0002\u0113\u0007"+
		"\u0113\u0002\u0114\u0007\u0114\u0002\u0115\u0007\u0115\u0002\u0116\u0007"+
		"\u0116\u0002\u0117\u0007\u0117\u0002\u0118\u0007\u0118\u0002\u0119\u0007"+
		"\u0119\u0002\u011a\u0007\u011a\u0002\u011b\u0007\u011b\u0002\u011c\u0007"+
		"\u011c\u0002\u011d\u0007\u011d\u0002\u011e\u0007\u011e\u0002\u011f\u0007"+
		"\u011f\u0002\u0120\u0007\u0120\u0002\u0121\u0007\u0121\u0002\u0122\u0007"+
		"\u0122\u0002\u0123\u0007\u0123\u0002\u0124\u0007\u0124\u0002\u0125\u0007"+
		"\u0125\u0002\u0126\u0007\u0126\u0002\u0127\u0007\u0127\u0002\u0128\u0007"+
		"\u0128\u0002\u0129\u0007\u0129\u0002\u012a\u0007\u012a\u0002\u012b\u0007"+
		"\u012b\u0002\u012c\u0007\u012c\u0002\u012d\u0007\u012d\u0002\u012e\u0007"+
		"\u012e\u0002\u012f\u0007\u012f\u0002\u0130\u0007\u0130\u0002\u0131\u0007"+
		"\u0131\u0002\u0132\u0007\u0132\u0002\u0133\u0007\u0133\u0002\u0134\u0007"+
		"\u0134\u0002\u0135\u0007\u0135\u0002\u0136\u0007\u0136\u0002\u0137\u0007"+
		"\u0137\u0002\u0138\u0007\u0138\u0002\u0139\u0007\u0139\u0002\u013a\u0007"+
		"\u013a\u0002\u013b\u0007\u013b\u0002\u013c\u0007\u013c\u0002\u013d\u0007"+
		"\u013d\u0002\u013e\u0007\u013e\u0002\u013f\u0007\u013f\u0002\u0140\u0007"+
		"\u0140\u0002\u0141\u0007\u0141\u0002\u0142\u0007\u0142\u0002\u0143\u0007"+
		"\u0143\u0002\u0144\u0007\u0144\u0002\u0145\u0007\u0145\u0002\u0146\u0007"+
		"\u0146\u0002\u0147\u0007\u0147\u0002\u0148\u0007\u0148\u0002\u0149\u0007"+
		"\u0149\u0002\u014a\u0007\u014a\u0002\u014b\u0007\u014b\u0002\u014c\u0007"+
		"\u014c\u0002\u014d\u0007\u014d\u0002\u014e\u0007\u014e\u0002\u014f\u0007"+
		"\u014f\u0002\u0150\u0007\u0150\u0002\u0151\u0007\u0151\u0002\u0152\u0007"+
		"\u0152\u0002\u0153\u0007\u0153\u0002\u0154\u0007\u0154\u0002\u0155\u0007"+
		"\u0155\u0002\u0156\u0007\u0156\u0002\u0157\u0007\u0157\u0002\u0158\u0007"+
		"\u0158\u0002\u0159\u0007\u0159\u0002\u015a\u0007\u015a\u0002\u015b\u0007"+
		"\u015b\u0002\u015c\u0007\u015c\u0002\u015d\u0007\u015d\u0002\u015e\u0007"+
		"\u015e\u0002\u015f\u0007\u015f\u0002\u0160\u0007\u0160\u0002\u0161\u0007"+
		"\u0161\u0002\u0162\u0007\u0162\u0002\u0163\u0007\u0163\u0002\u0164\u0007"+
		"\u0164\u0002\u0165\u0007\u0165\u0002\u0166\u0007\u0166\u0002\u0167\u0007"+
		"\u0167\u0002\u0168\u0007\u0168\u0001\u0000\u0003\u0000\u02d4\b\u0000\u0001"+
		"\u0000\u0001\u0000\u0003\u0000\u02d8\b\u0000\u0001\u0000\u0001\u0000\u0001"+
		"\u0001\u0001\u0001\u0001\u0001\u0003\u0001\u02df\b\u0001\u0001\u0001\u0003"+
		"\u0001\u02e2\b\u0001\u0001\u0001\u0005\u0001\u02e5\b\u0001\n\u0001\f\u0001"+
		"\u02e8\t\u0001\u0001\u0001\u0001\u0001\u0001\u0001\u0003\u0001\u02ed\b"+
		"\u0001\u0001\u0001\u0003\u0001\u02f0\b\u0001\u0001\u0001\u0003\u0001\u02f3"+
		"\b\u0001\u0001\u0002\u0001\u0002\u0001\u0002\u0001\u0002\u0001\u0002\u0001"+
		"\u0002\u0001\u0002\u0003\u0002\u02fc\b\u0002\u0001\u0003\u0001\u0003\u0001"+
		"\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001"+
		"\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001"+
		"\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001"+
		"\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001"+
		"\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001"+
		"\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001\u0004\u0001"+
		"\u0004\u0001\u0004\u0003\u0004\u0326\b\u0004\u0001\u0005\u0001\u0005\u0001"+
		"\u0005\u0001\u0005\u0001\u0005\u0001\u0005\u0001\u0005\u0001\u0005\u0001"+
		"\u0005\u0001\u0005\u0001\u0005\u0001\u0005\u0001\u0005\u0003\u0005\u0335"+
		"\b\u0005\u0001\u0006\u0001\u0006\u0001\u0006\u0001\u0006\u0001\u0006\u0001"+
		"\u0006\u0001\u0006\u0001\u0006\u0001\u0006\u0003\u0006\u0340\b\u0006\u0001"+
		"\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001"+
		"\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001\u0007\u0001"+
		"\u0007\u0001\u0007\u0001\u0007\u0003\u0007\u0351\b\u0007\u0001\b\u0001"+
		"\b\u0001\b\u0003\b\u0356\b\b\u0001\t\u0001\t\u0001\t\u0001\t\u0001\t\u0001"+
		"\t\u0001\t\u0001\t\u0001\t\u0001\t\u0003\t\u0362\b\t\u0001\n\u0001\n\u0001"+
		"\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001"+
		"\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001\n\u0001"+
		"\n\u0001\n\u0001\n\u0001\n\u0001\n\u0003\n\u037d\b\n\u0001\u000b\u0001"+
		"\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0001\u000b\u0003"+
		"\u000b\u0386\b\u000b\u0001\f\u0001\f\u0001\f\u0003\f\u038b\b\f\u0001\f"+
		"\u0001\f\u0005\f\u038f\b\f\n\f\f\f\u0392\t\f\u0001\r\u0001\r\u0003\r\u0396"+
		"\b\r\u0001\r\u0001\r\u0003\r\u039a\b\r\u0001\r\u0001\r\u0001\r\u0001\r"+
		"\u0001\r\u0001\r\u0001\r\u0003\r\u03a3\b\r\u0001\r\u0003\r\u03a6\b\r\u0001"+
		"\r\u0003\r\u03a9\b\r\u0001\r\u0001\r\u0003\r\u03ad\b\r\u0001\r\u0001\r"+
		"\u0001\r\u0001\u000e\u0001\u000e\u0003\u000e\u03b4\b\u000e\u0001\u000e"+
		"\u0003\u000e\u03b7\b\u000e\u0001\u000e\u0001\u000e\u0001\u000e\u0003\u000e"+
		"\u03bc\b\u000e\u0001\u000e\u0001\u000e\u0001\u000e\u0001\u000e\u0005\u000e"+
		"\u03c2\b\u000e\n\u000e\f\u000e\u03c5\t\u000e\u0001\u000e\u0001\u000e\u0003"+
		"\u000e\u03c9\b\u000e\u0001\u000e\u0001\u000e\u0001\u000e\u0003\u000e\u03ce"+
		"\b\u000e\u0001\u000e\u0005\u000e\u03d1\b\u000e\n\u000e\f\u000e\u03d4\t"+
		"\u000e\u0001\u000f\u0001\u000f\u0001\u000f\u0001\u000f\u0001\u000f\u0001"+
		"\u000f\u0001\u000f\u0001\u000f\u0001\u000f\u0003\u000f\u03df\b\u000f\u0001"+
		"\u000f\u0003\u000f\u03e2\b\u000f\u0001\u000f\u0001\u000f\u0003\u000f\u03e6"+
		"\b\u000f\u0001\u000f\u0003\u000f\u03e9\b\u000f\u0001\u000f\u0001\u000f"+
		"\u0003\u000f\u03ed\b\u000f\u0001\u000f\u0003\u000f\u03f0\b\u000f\u0001"+
		"\u000f\u0001\u000f\u0003\u000f\u03f4\b\u000f\u0001\u000f\u0003\u000f\u03f7"+
		"\b\u000f\u0001\u000f\u0003\u000f\u03fa\b\u000f\u0001\u000f\u0001\u000f"+
		"\u0003\u000f\u03fe\b\u000f\u0001\u000f\u0003\u000f\u0401\b\u000f\u0001"+
		"\u000f\u0001\u000f\u0003\u000f\u0405\b\u000f\u0001\u000f\u0001\u000f\u0001"+
		"\u0010\u0001\u0010\u0003\u0010\u040b\b\u0010\u0001\u0010\u0001\u0010\u0001"+
		"\u0010\u0001\u0010\u0003\u0010\u0411\b\u0010\u0001\u0010\u0001\u0010\u0005"+
		"\u0010\u0415\b\u0010\n\u0010\f\u0010\u0418\t\u0010\u0001\u0010\u0001\u0010"+
		"\u0005\u0010\u041c\b\u0010\n\u0010\f\u0010\u041f\t\u0010\u0001\u0010\u0001"+
		"\u0010\u0001\u0011\u0001\u0011\u0003\u0011\u0425\b\u0011\u0001\u0011\u0003"+
		"\u0011\u0428\b\u0011\u0001\u0011\u0001\u0011\u0003\u0011\u042c\b\u0011"+
		"\u0001\u0011\u0001\u0011\u0001\u0011\u0003\u0011\u0431\b\u0011\u0001\u0011"+
		"\u0001\u0011\u0005\u0011\u0435\b\u0011\n\u0011\f\u0011\u0438\t\u0011\u0001"+
		"\u0011\u0001\u0011\u0001\u0011\u0001\u0011\u0005\u0011\u043e\b\u0011\n"+
		"\u0011\f\u0011\u0441\t\u0011\u0001\u0011\u0001\u0011\u0003\u0011\u0445"+
		"\b\u0011\u0001\u0012\u0001\u0012\u0001\u0012\u0003\u0012\u044a\b\u0012"+
		"\u0001\u0012\u0001\u0012\u0001\u0012\u0005\u0012\u044f\b\u0012\n\u0012"+
		"\f\u0012\u0452\t\u0012\u0001\u0013\u0001\u0013\u0001\u0013\u0001\u0013"+
		"\u0001\u0013\u0001\u0013\u0001\u0013\u0001\u0013\u0001\u0013\u0001\u0013"+
		"\u0001\u0013\u0001\u0013\u0005\u0013\u0460\b\u0013\n\u0013\f\u0013\u0463"+
		"\t\u0013\u0001\u0013\u0001\u0013\u0001\u0014\u0001\u0014\u0003\u0014\u0469"+
		"\b\u0014\u0001\u0014\u0001\u0014\u0003\u0014\u046d\b\u0014\u0001\u0014"+
		"\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014"+
		"\u0001\u0014\u0003\u0014\u0477\b\u0014\u0001\u0014\u0001\u0014\u0003\u0014"+
		"\u047b\b\u0014\u0001\u0014\u0001\u0014\u0003\u0014\u047f\b\u0014\u0001"+
		"\u0014\u0001\u0014\u0003\u0014\u0483\b\u0014\u0001\u0014\u0001\u0014\u0003"+
		"\u0014\u0487\b\u0014\u0001\u0014\u0005\u0014\u048a\b\u0014\n\u0014\f\u0014"+
		"\u048d\t\u0014\u0003\u0014\u048f\b\u0014\u0001\u0014\u0003\u0014\u0492"+
		"\b\u0014\u0001\u0014\u0003\u0014\u0495\b\u0014\u0001\u0014\u0003\u0014"+
		"\u0498\b\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0003\u0014"+
		"\u049e\b\u0014\u0001\u0014\u0001\u0014\u0003\u0014\u04a2\b\u0014\u0001"+
		"\u0014\u0001\u0014\u0001\u0014\u0001\u0014\u0003\u0014\u04a8\b\u0014\u0001"+
		"\u0014\u0005\u0014\u04ab\b\u0014\n\u0014\f\u0014\u04ae\t\u0014\u0003\u0014"+
		"\u04b0\b\u0014\u0001\u0014\u0003\u0014\u04b3\b\u0014\u0003\u0014\u04b5"+
		"\b\u0014\u0001\u0015\u0001\u0015\u0001\u0015\u0001\u0015\u0001\u0015\u0001"+
		"\u0015\u0001\u0015\u0001\u0015\u0001\u0015\u0003\u0015\u04c0\b\u0015\u0001"+
		"\u0015\u0001\u0015\u0003\u0015\u04c4\b\u0015\u0001\u0015\u0003\u0015\u04c7"+
		"\b\u0015\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001"+
		"\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001\u0016\u0001"+
		"\u0016\u0003\u0016\u04d5\b\u0016\u0001\u0016\u0003\u0016\u04d8\b\u0016"+
		"\u0001\u0016\u0001\u0016\u0003\u0016\u04dc\b\u0016\u0001\u0016\u0003\u0016"+
		"\u04df\b\u0016\u0001\u0016\u0001\u0016\u0003\u0016\u04e3\b\u0016\u0001"+
		"\u0016\u0003\u0016\u04e6\b\u0016\u0001\u0016\u0001\u0016\u0003\u0016\u04ea"+
		"\b\u0016\u0001\u0016\u0003\u0016\u04ed\b\u0016\u0001\u0016\u0001\u0016"+
		"\u0003\u0016\u04f1\b\u0016\u0001\u0016\u0003\u0016\u04f4\b\u0016\u0001"+
		"\u0016\u0003\u0016\u04f7\b\u0016\u0001\u0016\u0001\u0016\u0003\u0016\u04fb"+
		"\b\u0016\u0001\u0016\u0003\u0016\u04fe\b\u0016\u0001\u0016\u0001\u0016"+
		"\u0003\u0016\u0502\b\u0016\u0001\u0016\u0001\u0016\u0001\u0017\u0001\u0017"+
		"\u0003\u0017\u0508\b\u0017\u0001\u0017\u0001\u0017\u0001\u0017\u0001\u0017"+
		"\u0001\u0017\u0001\u0017\u0001\u0017\u0001\u0017\u0001\u0017\u0001\u0017"+
		"\u0001\u0017\u0003\u0017\u0515\b\u0017\u0001\u0017\u0001\u0017\u0001\u0018"+
		"\u0001\u0018\u0003\u0018\u051b\b\u0018\u0001\u0018\u0001\u0018\u0001\u0019"+
		"\u0001\u0019\u0001\u0019\u0001\u0019\u0001\u0019\u0005\u0019\u0524\b\u0019"+
		"\n\u0019\f\u0019\u0527\t\u0019\u0001\u0019\u0001\u0019\u0003\u0019\u052b"+
		"\b\u0019\u0001\u0019\u0001\u0019\u0001\u0019\u0001\u0019\u0001\u0019\u0001"+
		"\u0019\u0003\u0019\u0533\b\u0019\u0001\u001a\u0001\u001a\u0001\u001b\u0001"+
		"\u001b\u0001\u001c\u0001\u001c\u0003\u001c\u053b\b\u001c\u0001\u001c\u0001"+
		"\u001c\u0001\u001c\u0003\u001c\u0540\b\u001c\u0001\u001c\u0003\u001c\u0543"+
		"\b\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0003\u001c\u0548\b\u001c"+
		"\u0001\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0001\u001c"+
		"\u0003\u001c\u0550\b\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0003\u001c"+
		"\u0555\b\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0003\u001c"+
		"\u055b\b\u001c\u0001\u001c\u0001\u001c\u0001\u001c\u0003\u001c\u0560\b"+
		"\u001c\u0001\u001c\u0001\u001c\u0003\u001c\u0564\b\u001c\u0003\u001c\u0566"+
		"\b\u001c\u0001\u001d\u0003\u001d\u0569\b\u001d\u0001\u001d\u0001\u001d"+
		"\u0003\u001d\u056d\b\u001d\u0001\u001d\u0001\u001d\u0003\u001d\u0571\b"+
		"\u001d\u0001\u001d\u0003\u001d\u0574\b\u001d\u0001\u001d\u0001\u001d\u0003"+
		"\u001d\u0578\b\u001d\u0001\u001d\u0001\u001d\u0003\u001d\u057c\b\u001d"+
		"\u0001\u001d\u0001\u001d\u0003\u001d\u0580\b\u001d\u0001\u001d\u0001\u001d"+
		"\u0001\u001d\u0001\u001d\u0003\u001d\u0586\b\u001d\u0001\u001d\u0003\u001d"+
		"\u0589\b\u001d\u0001\u001e\u0001\u001e\u0001\u001e\u0001\u001e\u0001\u001e"+
		"\u0003\u001e\u0590\b\u001e\u0001\u001f\u0001\u001f\u0001\u001f\u0003\u001f"+
		"\u0595\b\u001f\u0001 \u0001 \u0001 \u0001 \u0003 \u059b\b \u0001!\u0001"+
		"!\u0001!\u0005!\u05a0\b!\n!\f!\u05a3\t!\u0001!\u0001!\u0001!\u0003!\u05a8"+
		"\b!\u0001!\u0001!\u0001!\u0001!\u0005!\u05ae\b!\n!\f!\u05b1\t!\u0003!"+
		"\u05b3\b!\u0001!\u0001!\u0001!\u0005!\u05b8\b!\n!\f!\u05bb\t!\u0003!\u05bd"+
		"\b!\u0003!\u05bf\b!\u0001\"\u0001\"\u0001\"\u0001\"\u0003\"\u05c5\b\""+
		"\u0001#\u0001#\u0001#\u0001#\u0003#\u05cb\b#\u0001#\u0001#\u0001$\u0001"+
		"$\u0001$\u0001$\u0001$\u0001$\u0001$\u0001$\u0001$\u0001$\u0001$\u0001"+
		"$\u0001$\u0003$\u05dc\b$\u0001%\u0001%\u0001%\u0001%\u0001%\u0003%\u05e3"+
		"\b%\u0001&\u0001&\u0001&\u0001\'\u0001\'\u0003\'\u05ea\b\'\u0001\'\u0001"+
		"\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0001\'\u0003"+
		"\'\u05f6\b\'\u0001\'\u0001\'\u0001\'\u0003\'\u05fb\b\'\u0001\'\u0003\'"+
		"\u05fe\b\'\u0001(\u0003(\u0601\b(\u0001(\u0001(\u0001(\u0001)\u0001)\u0001"+
		")\u0001*\u0001*\u0001*\u0001*\u0001*\u0003*\u060e\b*\u0001*\u0001*\u0001"+
		"*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001*\u0001*\u0003*\u061b"+
		"\b*\u0001*\u0001*\u0001*\u0003*\u0620\b*\u0001+\u0001+\u0001+\u0001+\u0001"+
		"+\u0001+\u0001+\u0001+\u0001+\u0001+\u0001+\u0001+\u0001+\u0001+\u0003"+
		"+\u0630\b+\u0001,\u0001,\u0001,\u0001,\u0005,\u0636\b,\n,\f,\u0639\t,"+
		"\u0001,\u0001,\u0001-\u0001-\u0001-\u0001-\u0001-\u0003-\u0642\b-\u0001"+
		"-\u0003-\u0645\b-\u0001-\u0003-\u0648\b-\u0001.\u0001.\u0005.\u064c\b"+
		".\n.\f.\u064f\t.\u0001.\u0003.\u0652\b.\u0001.\u0003.\u0655\b.\u0001/"+
		"\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0003/\u0660"+
		"\b/\u0001/\u0003/\u0663\b/\u0001/\u0001/\u0001/\u0003/\u0668\b/\u0001"+
		"/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001/\u0001"+
		"/\u0003/\u0675\b/\u0001/\u0001/\u0001/\u0001/\u0001/\u0003/\u067c\b/\u0001"+
		"/\u0001/\u0001/\u0001/\u0001/\u0003/\u0683\b/\u0003/\u0685\b/\u0001/\u0001"+
		"/\u0001/\u0001/\u0001/\u0003/\u068c\b/\u00010\u00010\u00030\u0690\b0\u0003"+
		"0\u0692\b0\u00010\u00010\u00010\u00030\u0697\b0\u00010\u00030\u069a\b"+
		"0\u00010\u00010\u00050\u069e\b0\n0\f0\u06a1\t0\u00010\u00010\u00030\u06a5"+
		"\b0\u00030\u06a7\b0\u00010\u00010\u00030\u06ab\b0\u00010\u00030\u06ae"+
		"\b0\u00010\u00030\u06b1\b0\u00010\u00010\u00050\u06b5\b0\n0\f0\u06b8\t"+
		"0\u00010\u00010\u00030\u06bc\b0\u00030\u06be\b0\u00010\u00010\u00010\u0003"+
		"0\u06c3\b0\u00010\u00010\u00010\u00010\u00010\u00030\u06ca\b0\u00030\u06cc"+
		"\b0\u00010\u00010\u00010\u00010\u00010\u00030\u06d3\b0\u00011\u00011\u0001"+
		"1\u00031\u06d8\b1\u00011\u00011\u00031\u06dc\b1\u00011\u00031\u06df\b"+
		"1\u00012\u00012\u00012\u00012\u00012\u00012\u00032\u06e7\b2\u00012\u0001"+
		"2\u00012\u00012\u00012\u00012\u00032\u06ef\b2\u00032\u06f1\b2\u00013\u0001"+
		"3\u00013\u00013\u00013\u00013\u00013\u00013\u00033\u06fb\b3\u00014\u0001"+
		"4\u00034\u06ff\b4\u00014\u00034\u0702\b4\u00014\u00014\u00054\u0706\b"+
		"4\n4\f4\u0709\t4\u00014\u00014\u00034\u070d\b4\u00014\u00034\u0710\b4"+
		"\u00014\u00014\u00054\u0714\b4\n4\f4\u0717\t4\u00034\u0719\b4\u00015\u0001"+
		"5\u00035\u071d\b5\u00015\u00035\u0720\b5\u00015\u00015\u00035\u0724\b"+
		"5\u00015\u00015\u00015\u00035\u0729\b5\u00015\u00015\u00015\u00035\u072e"+
		"\b5\u00015\u00015\u00015\u00035\u0733\b5\u00015\u00015\u00035\u0737\b"+
		"5\u00015\u00015\u00035\u073b\b5\u00015\u00015\u00035\u073f\b5\u00015\u0001"+
		"5\u00035\u0743\b5\u00015\u00015\u00035\u0747\b5\u00015\u00015\u00035\u074b"+
		"\b5\u00015\u00015\u00015\u00035\u0750\b5\u00015\u00015\u00015\u00035\u0755"+
		"\b5\u00015\u00015\u00015\u00035\u075a\b5\u00015\u00015\u00015\u00015\u0003"+
		"5\u0760\b5\u00015\u00015\u00015\u00035\u0765\b5\u00015\u00015\u00015\u0003"+
		"5\u076a\b5\u00015\u00015\u00015\u00035\u076f\b5\u00015\u00015\u00015\u0003"+
		"5\u0774\b5\u00015\u00015\u00015\u00035\u0779\b5\u00015\u00015\u00015\u0001"+
		"5\u00035\u077f\b5\u00015\u00015\u00015\u00035\u0784\b5\u00015\u00015\u0001"+
		"5\u00035\u0789\b5\u00015\u00015\u00015\u00035\u078e\b5\u00015\u00015\u0001"+
		"5\u00035\u0793\b5\u00015\u00015\u00015\u00035\u0798\b5\u00015\u00015\u0001"+
		"5\u00035\u079d\b5\u00015\u00015\u00015\u00035\u07a2\b5\u00015\u00015\u0001"+
		"5\u00015\u00015\u00035\u07a9\b5\u00015\u00015\u00015\u00035\u07ae\b5\u0001"+
		"5\u00015\u00015\u00035\u07b3\b5\u00015\u00015\u00015\u00035\u07b8\b5\u0001"+
		"5\u00015\u00035\u07bc\b5\u00015\u00015\u00015\u00035\u07c1\b5\u00015\u0001"+
		"5\u00015\u00015\u00015\u00015\u00035\u07c9\b5\u00015\u00015\u00015\u0003"+
		"5\u07ce\b5\u00015\u00015\u00015\u00015\u00035\u07d4\b5\u00016\u00016\u0001"+
		"7\u00017\u00017\u00018\u00018\u00018\u00018\u00018\u00038\u07e0\b8\u0001"+
		"8\u00018\u00018\u00018\u00018\u00038\u07e7\b8\u00038\u07e9\b8\u00018\u0001"+
		"8\u00018\u00018\u00058\u07ef\b8\n8\f8\u07f2\t8\u00018\u00018\u00038\u07f6"+
		"\b8\u00019\u00039\u07f9\b9\u00019\u00019\u00019\u00019\u00019\u00019\u0003"+
		"9\u0801\b9\u00019\u00019\u00019\u00019\u00039\u0807\b9\u00019\u00019\u0003"+
		"9\u080b\b9\u00019\u00019\u00019\u00019\u00019\u00019\u00019\u00019\u0001"+
		"9\u00019\u00019\u00039\u0818\b9\u00019\u00019\u00019\u00019\u00019\u0001"+
		"9\u00019\u00019\u00019\u00019\u00039\u0824\b9\u00039\u0826\b9\u0001:\u0003"+
		":\u0829\b:\u0001:\u0001:\u0001:\u0001:\u0001:\u0001:\u0003:\u0831\b:\u0001"+
		":\u0001:\u0001:\u0001:\u0003:\u0837\b:\u0001:\u0001:\u0001:\u0001:\u0003"+
		":\u083d\b:\u0001;\u0001;\u0001;\u0001;\u0001;\u0001;\u0001;\u0001;\u0001"+
		";\u0005;\u0848\b;\n;\f;\u084b\t;\u0001;\u0001;\u0005;\u084f\b;\n;\f;\u0852"+
		"\t;\u0001;\u0001;\u0001;\u0001;\u0005;\u0858\b;\n;\f;\u085b\t;\u0001;"+
		"\u0001;\u0003;\u085f\b;\u0001;\u0001;\u0001;\u0001;\u0001;\u0001;\u0001"+
		";\u0005;\u0868\b;\n;\f;\u086b\t;\u0001;\u0001;\u0001;\u0001;\u0005;\u0871"+
		"\b;\n;\f;\u0874\t;\u0001;\u0001;\u0003;\u0878\b;\u0001;\u0001;\u0001;"+
		"\u0001;\u0001;\u0001;\u0001;\u0001;\u0005;\u0882\b;\n;\f;\u0885\t;\u0001"+
		";\u0001;\u0005;\u0889\b;\n;\f;\u088c\t;\u0001;\u0001;\u0001;\u0001;\u0005"+
		";\u0892\b;\n;\f;\u0895\t;\u0001;\u0001;\u0003;\u0899\b;\u0001;\u0001;"+
		"\u0001;\u0001;\u0001;\u0001;\u0001;\u0001;\u0005;\u08a3\b;\n;\f;\u08a6"+
		"\t;\u0001;\u0001;\u0005;\u08aa\b;\n;\f;\u08ad\t;\u0001;\u0001;\u0001;"+
		"\u0001;\u0005;\u08b3\b;\n;\f;\u08b6\t;\u0001;\u0001;\u0003;\u08ba\b;\u0001"+
		";\u0001;\u0001;\u0005;\u08bf\b;\n;\f;\u08c2\t;\u0001;\u0001;\u0001;\u0001"+
		";\u0005;\u08c8\b;\n;\f;\u08cb\t;\u0001;\u0001;\u0003;\u08cf\b;\u0003;"+
		"\u08d1\b;\u0001<\u0001<\u0001<\u0003<\u08d6\b<\u0001=\u0001=\u0001=\u0001"+
		"=\u0004=\u08dc\b=\u000b=\f=\u08dd\u0001=\u0001=\u0001>\u0001>\u0001>\u0005"+
		">\u08e5\b>\n>\f>\u08e8\t>\u0001?\u0003?\u08eb\b?\u0001?\u0003?\u08ee\b"+
		"?\u0001?\u0001?\u0003?\u08f2\b?\u0001?\u0001?\u0001?\u0003?\u08f7\b?\u0001"+
		"?\u0001?\u0001?\u0001?\u0003?\u08fd\b?\u0001?\u0001?\u0001?\u0001?\u0003"+
		"?\u0903\b?\u0001?\u0001?\u0001?\u0003?\u0908\b?\u0001?\u0001?\u0001?\u0003"+
		"?\u090d\b?\u0001?\u0001?\u0001?\u0003?\u0912\b?\u0001?\u0001?\u0001?\u0003"+
		"?\u0917\b?\u0001?\u0003?\u091a\b?\u0001@\u0001@\u0001@\u0003@\u091f\b"+
		"@\u0001@\u0004@\u0922\b@\u000b@\f@\u0923\u0001@\u0001@\u0001@\u0001@\u0001"+
		"@\u0001@\u0001@\u0001@\u0003@\u092e\b@\u0001A\u0001A\u0003A\u0932\bA\u0001"+
		"A\u0001A\u0001A\u0001A\u0001A\u0003A\u0939\bA\u0001A\u0001A\u0001A\u0003"+
		"A\u093e\bA\u0001A\u0003A\u0941\bA\u0001A\u0001A\u0001A\u0003A\u0946\b"+
		"A\u0001A\u0003A\u0949\bA\u0001A\u0001A\u0003A\u094d\bA\u0001A\u0001A\u0003"+
		"A\u0951\bA\u0001B\u0001B\u0001B\u0001B\u0005B\u0957\bB\nB\fB\u095a\tB"+
		"\u0001C\u0001C\u0001C\u0001C\u0001C\u0001C\u0001C\u0001D\u0001D\u0001"+
		"D\u0001D\u0001D\u0001D\u0001D\u0001D\u0001D\u0003D\u096c\bD\u0001D\u0003"+
		"D\u096f\bD\u0001D\u0003D\u0972\bD\u0001D\u0001D\u0003D\u0976\bD\u0001"+
		"D\u0001D\u0001E\u0001E\u0001E\u0001E\u0005E\u097e\bE\nE\fE\u0981\tE\u0001"+
		"F\u0001F\u0001F\u0001F\u0001F\u0001F\u0001F\u0001F\u0005F\u098b\bF\nF"+
		"\fF\u098e\tF\u0001F\u0001F\u0001G\u0001G\u0003G\u0994\bG\u0001G\u0003"+
		"G\u0997\bG\u0001G\u0001G\u0001G\u0003G\u099c\bG\u0001G\u0001G\u0001G\u0005"+
		"G\u09a1\bG\nG\fG\u09a4\tG\u0003G\u09a6\bG\u0001G\u0003G\u09a9\bG\u0001"+
		"H\u0001H\u0001H\u0001H\u0001H\u0001H\u0001H\u0001H\u0001H\u0003H\u09b4"+
		"\bH\u0001H\u0003H\u09b7\bH\u0001H\u0001H\u0003H\u09bb\bH\u0001H\u0001"+
		"H\u0001I\u0001I\u0001I\u0001I\u0003I\u09c3\bI\u0001I\u0003I\u09c6\bI\u0001"+
		"I\u0001I\u0001I\u0003I\u09cb\bI\u0001I\u0001I\u0001I\u0001I\u0001I\u0001"+
		"I\u0003I\u09d3\bI\u0001I\u0001I\u0001I\u0001I\u0003I\u09d9\bI\u0001I\u0001"+
		"I\u0003I\u09dd\bI\u0001J\u0001J\u0003J\u09e1\bJ\u0001J\u0005J\u09e4\b"+
		"J\nJ\fJ\u09e7\tJ\u0001J\u0001J\u0003J\u09eb\bJ\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0003J\u09f2\bJ\u0001J\u0001J\u0003J\u09f6\bJ\u0001J\u0001J\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0005J\u09ff\bJ\nJ\fJ\u0a02\tJ\u0001J\u0001"+
		"J\u0001J\u0001J\u0001J\u0003J\u0a09\bJ\u0001J\u0003J\u0a0c\bJ\u0001J\u0001"+
		"J\u0005J\u0a10\bJ\nJ\fJ\u0a13\tJ\u0001J\u0001J\u0001J\u0003J\u0a18\bJ"+
		"\u0003J\u0a1a\bJ\u0001J\u0001J\u0001J\u0003J\u0a1f\bJ\u0001J\u0003J\u0a22"+
		"\bJ\u0001J\u0001J\u0005J\u0a26\bJ\nJ\fJ\u0a29\tJ\u0001J\u0001J\u0001J"+
		"\u0003J\u0a2e\bJ\u0003J\u0a30\bJ\u0001J\u0001J\u0003J\u0a34\bJ\u0001J"+
		"\u0003J\u0a37\bJ\u0001J\u0003J\u0a3a\bJ\u0001J\u0001J\u0005J\u0a3e\bJ"+
		"\nJ\fJ\u0a41\tJ\u0001J\u0001J\u0001J\u0003J\u0a46\bJ\u0001J\u0003J\u0a49"+
		"\bJ\u0001J\u0001J\u0005J\u0a4d\bJ\nJ\fJ\u0a50\tJ\u0001J\u0001J\u0001J"+
		"\u0003J\u0a55\bJ\u0003J\u0a57\bJ\u0001J\u0001J\u0001J\u0003J\u0a5c\bJ"+
		"\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0a64\bJ\u0003J\u0a66"+
		"\bJ\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0a6f\bJ\u0001"+
		"J\u0003J\u0a72\bJ\u0001J\u0003J\u0a75\bJ\u0001J\u0001J\u0001J\u0003J\u0a7a"+
		"\bJ\u0003J\u0a7c\bJ\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003"+
		"J\u0a85\bJ\u0001J\u0003J\u0a88\bJ\u0001J\u0003J\u0a8b\bJ\u0001J\u0001"+
		"J\u0001J\u0003J\u0a90\bJ\u0003J\u0a92\bJ\u0001J\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0001J\u0003J\u0a9b\bJ\u0001J\u0001J\u0001J\u0003J\u0aa0\bJ\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0aa8\bJ\u0001J\u0001J\u0003"+
		"J\u0aac\bJ\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0ab4\bJ\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0abe\bJ\u0001"+
		"J\u0001J\u0001J\u0003J\u0ac3\bJ\u0001J\u0001J\u0001J\u0001J\u0001J\u0003"+
		"J\u0aca\bJ\u0001J\u0001J\u0003J\u0ace\bJ\u0001J\u0001J\u0003J\u0ad2\b"+
		"J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0ae5\bJ\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0003J\u0aef\bJ\u0001"+
		"J\u0001J\u0001J\u0001J\u0003J\u0af5\bJ\u0001J\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001"+
		"J\u0003J\u0b06\bJ\u0001J\u0001J\u0003J\u0b0a\bJ\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0001J\u0001J\u0001J\u0003J\u0b14\bJ\u0001J\u0001J\u0001J\u0003"+
		"J\u0b19\bJ\u0001J\u0003J\u0b1c\bJ\u0001J\u0001J\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0003J\u0b25\bJ\u0001J\u0001J\u0001J\u0001J\u0001J\u0001J\u0001"+
		"J\u0001J\u0001J\u0003J\u0b30\bJ\u0001J\u0001J\u0001J\u0001J\u0005J\u0b36"+
		"\bJ\nJ\fJ\u0b39\tJ\u0001J\u0001J\u0001J\u0003J\u0b3e\bJ\u0001K\u0001K"+
		"\u0001K\u0001K\u0001K\u0001K\u0005K\u0b46\bK\nK\fK\u0b49\tK\u0001K\u0001"+
		"K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0003K\u0b54\bK\u0001"+
		"K\u0001K\u0001K\u0001K\u0001K\u0003K\u0b5b\bK\u0001K\u0001K\u0001K\u0001"+
		"K\u0001K\u0003K\u0b62\bK\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001"+
		"K\u0001K\u0001K\u0001K\u0001K\u0005K\u0b6f\bK\nK\fK\u0b72\tK\u0001K\u0001"+
		"K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0001K\u0003K\u0b7e"+
		"\bK\u0001K\u0001K\u0001K\u0001K\u0003K\u0b84\bK\u0001K\u0001K\u0001K\u0001"+
		"K\u0003K\u0b8a\bK\u0001K\u0001K\u0001K\u0001K\u0003K\u0b90\bK\u0001K\u0001"+
		"K\u0001K\u0001K\u0003K\u0b96\bK\u0001K\u0001K\u0001K\u0001K\u0003K\u0b9c"+
		"\bK\u0001K\u0001K\u0001K\u0001K\u0003K\u0ba2\bK\u0001L\u0001L\u0001L\u0003"+
		"L\u0ba7\bL\u0001L\u0001L\u0001M\u0001M\u0001M\u0003M\u0bae\bM\u0001M\u0001"+
		"M\u0001N\u0001N\u0001N\u0003N\u0bb5\bN\u0001N\u0001N\u0001N\u0001N\u0001"+
		"N\u0003N\u0bbc\bN\u0001N\u0001N\u0001N\u0003N\u0bc1\bN\u0001N\u0005N\u0bc4"+
		"\bN\nN\fN\u0bc7\tN\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001O\u0001"+
		"O\u0001P\u0001P\u0001P\u0003P\u0bd4\bP\u0001P\u0001P\u0001Q\u0001Q\u0001"+
		"Q\u0003Q\u0bdb\bQ\u0001Q\u0001Q\u0001R\u0001R\u0001R\u0003R\u0be2\bR\u0001"+
		"R\u0001R\u0001S\u0001S\u0003S\u0be8\bS\u0001S\u0001S\u0003S\u0bec\bS\u0001"+
		"S\u0001S\u0003S\u0bf0\bS\u0001T\u0001T\u0001T\u0001T\u0001T\u0003T\u0bf7"+
		"\bT\u0001T\u0003T\u0bfa\bT\u0001U\u0001U\u0001U\u0003U\u0bff\bU\u0001"+
		"U\u0001U\u0001V\u0001V\u0001V\u0003V\u0c06\bV\u0001V\u0001V\u0001V\u0005"+
		"V\u0c0b\bV\nV\fV\u0c0e\tV\u0001V\u0003V\u0c11\bV\u0001W\u0001W\u0001W"+
		"\u0003W\u0c16\bW\u0001W\u0001W\u0001W\u0005W\u0c1b\bW\nW\fW\u0c1e\tW\u0001"+
		"X\u0001X\u0001X\u0001X\u0001X\u0001X\u0001X\u0001X\u0005X\u0c28\bX\nX"+
		"\fX\u0c2b\tX\u0003X\u0c2d\bX\u0001X\u0001X\u0001X\u0003X\u0c32\bX\u0001"+
		"X\u0001X\u0001X\u0003X\u0c37\bX\u0005X\u0c39\bX\nX\fX\u0c3c\tX\u0001X"+
		"\u0001X\u0001X\u0003X\u0c41\bX\u0001Y\u0001Y\u0001Y\u0001Y\u0001Y\u0005"+
		"Y\u0c48\bY\nY\fY\u0c4b\tY\u0001Z\u0001Z\u0001Z\u0001Z\u0001[\u0001[\u0003"+
		"[\u0c53\b[\u0001[\u0001[\u0001\\\u0001\\\u0001\\\u0001\\\u0001\\\u0003"+
		"\\\u0c5c\b\\\u0001\\\u0003\\\u0c5f\b\\\u0001]\u0001]\u0003]\u0c63\b]\u0001"+
		"^\u0001^\u0001^\u0001_\u0001_\u0001_\u0001_\u0003_\u0c6c\b_\u0001`\u0001"+
		"`\u0003`\u0c70\b`\u0001`\u0003`\u0c73\b`\u0001`\u0003`\u0c76\b`\u0001"+
		"`\u0001`\u0001`\u0001`\u0003`\u0c7c\b`\u0001`\u0003`\u0c7f\b`\u0001`\u0001"+
		"`\u0003`\u0c83\b`\u0001`\u0003`\u0c86\b`\u0001`\u0001`\u0003`\u0c8a\b"+
		"`\u0001`\u0003`\u0c8d\b`\u0001`\u0001`\u0001`\u0001`\u0005`\u0c93\b`\n"+
		"`\f`\u0c96\t`\u0003`\u0c98\b`\u0001`\u0001`\u0001`\u0001`\u0001`\u0001"+
		"`\u0001`\u0005`\u0ca1\b`\n`\f`\u0ca4\t`\u0003`\u0ca6\b`\u0001a\u0001a"+
		"\u0001a\u0003a\u0cab\ba\u0001a\u0003a\u0cae\ba\u0001a\u0001a\u0001a\u0003"+
		"a\u0cb3\ba\u0001a\u0001a\u0001a\u0001a\u0001a\u0001a\u0001a\u0001a\u0003"+
		"a\u0cbd\ba\u0001a\u0001a\u0001a\u0003a\u0cc2\ba\u0001a\u0001a\u0004a\u0cc6"+
		"\ba\u000ba\fa\u0cc7\u0003a\u0cca\ba\u0001a\u0001a\u0004a\u0cce\ba\u000b"+
		"a\fa\u0ccf\u0003a\u0cd2\ba\u0001a\u0001a\u0001a\u0001a\u0003a\u0cd8\b"+
		"a\u0001a\u0001a\u0001a\u0001a\u0005a\u0cde\ba\na\fa\u0ce1\ta\u0001a\u0001"+
		"a\u0003a\u0ce5\ba\u0001a\u0001a\u0001a\u0001a\u0005a\u0ceb\ba\na\fa\u0cee"+
		"\ta\u0003a\u0cf0\ba\u0001b\u0001b\u0001b\u0003b\u0cf5\bb\u0001b\u0003"+
		"b\u0cf8\bb\u0001b\u0001b\u0001b\u0003b\u0cfd\bb\u0001b\u0001b\u0001b\u0001"+
		"b\u0001b\u0001b\u0003b\u0d05\bb\u0001b\u0001b\u0001b\u0001b\u0001b\u0001"+
		"b\u0003b\u0d0d\bb\u0001b\u0001b\u0001b\u0001b\u0003b\u0d13\bb\u0001b\u0001"+
		"b\u0001b\u0001b\u0005b\u0d19\bb\nb\fb\u0d1c\tb\u0001b\u0001b\u0003b\u0d20"+
		"\bb\u0001b\u0001b\u0001b\u0001b\u0005b\u0d26\bb\nb\fb\u0d29\tb\u0003b"+
		"\u0d2b\bb\u0001c\u0001c\u0003c\u0d2f\bc\u0001c\u0003c\u0d32\bc\u0001c"+
		"\u0001c\u0001c\u0001c\u0001c\u0001c\u0003c\u0d3a\bc\u0001c\u0001c\u0001"+
		"c\u0001c\u0003c\u0d40\bc\u0001c\u0001c\u0001c\u0001c\u0001c\u0005c\u0d47"+
		"\bc\nc\fc\u0d4a\tc\u0003c\u0d4c\bc\u0001d\u0001d\u0003d\u0d50\bd\u0001"+
		"d\u0001d\u0003d\u0d54\bd\u0001d\u0001d\u0003d\u0d58\bd\u0001d\u0004d\u0d5b"+
		"\bd\u000bd\fd\u0d5c\u0001d\u0001d\u0003d\u0d61\bd\u0001d\u0001d\u0003"+
		"d\u0d65\bd\u0003d\u0d67\bd\u0001d\u0003d\u0d6a\bd\u0001d\u0003d\u0d6d"+
		"\bd\u0001d\u0003d\u0d70\bd\u0001d\u0001d\u0004d\u0d74\bd\u000bd\fd\u0d75"+
		"\u0001d\u0001d\u0003d\u0d7a\bd\u0001d\u0003d\u0d7d\bd\u0001d\u0003d\u0d80"+
		"\bd\u0001d\u0003d\u0d83\bd\u0001d\u0003d\u0d86\bd\u0001d\u0001d\u0001"+
		"d\u0004d\u0d8b\bd\u000bd\fd\u0d8c\u0003d\u0d8f\bd\u0001e\u0001e\u0003"+
		"e\u0d93\be\u0001f\u0001f\u0001f\u0003f\u0d98\bf\u0001f\u0001f\u0001f\u0001"+
		"f\u0003f\u0d9e\bf\u0001f\u0005f\u0da1\bf\nf\ff\u0da4\tf\u0001g\u0001g"+
		"\u0001g\u0001g\u0003g\u0daa\bg\u0001g\u0001g\u0001g\u0001g\u0003g\u0db0"+
		"\bg\u0001g\u0005g\u0db3\bg\ng\fg\u0db6\tg\u0003g\u0db8\bg\u0001h\u0001"+
		"h\u0001h\u0001h\u0003h\u0dbe\bh\u0001i\u0001i\u0003i\u0dc2\bi\u0001j\u0001"+
		"j\u0001j\u0001j\u0001j\u0001j\u0003j\u0dca\bj\u0001k\u0001k\u0003k\u0dce"+
		"\bk\u0001k\u0003k\u0dd1\bk\u0001k\u0003k\u0dd4\bk\u0001k\u0001k\u0001"+
		"k\u0003k\u0dd9\bk\u0001k\u0003k\u0ddc\bk\u0001k\u0001k\u0001k\u0001k\u0001"+
		"k\u0003k\u0de3\bk\u0001k\u0001k\u0003k\u0de7\bk\u0001k\u0003k\u0dea\b"+
		"k\u0001k\u0001k\u0003k\u0dee\bk\u0001l\u0001l\u0003l\u0df2\bl\u0001l\u0003"+
		"l\u0df5\bl\u0001l\u0003l\u0df8\bl\u0001l\u0001l\u0001l\u0003l\u0dfd\b"+
		"l\u0001l\u0001l\u0001l\u0001l\u0003l\u0e03\bl\u0005l\u0e05\bl\nl\fl\u0e08"+
		"\tl\u0001l\u0001l\u0001l\u0001l\u0001l\u0001l\u0001l\u0003l\u0e11\bl\u0001"+
		"l\u0001l\u0001l\u0001l\u0003l\u0e17\bl\u0005l\u0e19\bl\nl\fl\u0e1c\tl"+
		"\u0001l\u0001l\u0001l\u0003l\u0e21\bl\u0001l\u0001l\u0003l\u0e25\bl\u0001"+
		"m\u0001m\u0001m\u0001m\u0003m\u0e2b\bm\u0001m\u0003m\u0e2e\bm\u0001n\u0001"+
		"n\u0001n\u0001n\u0001n\u0001n\u0001n\u0001n\u0001n\u0001n\u0003n\u0e3a"+
		"\bn\u0001n\u0001n\u0003n\u0e3e\bn\u0001n\u0001n\u0003n\u0e42\bn\u0001"+
		"o\u0001o\u0001o\u0001o\u0001o\u0001o\u0003o\u0e4a\bo\u0001o\u0001o\u0003"+
		"o\u0e4e\bo\u0001p\u0001p\u0001p\u0001p\u0001q\u0001q\u0003q\u0e56\bq\u0001"+
		"q\u0003q\u0e59\bq\u0001q\u0001q\u0003q\u0e5d\bq\u0001q\u0003q\u0e60\b"+
		"q\u0001q\u0001q\u0001q\u0001q\u0005q\u0e66\bq\nq\fq\u0e69\tq\u0001q\u0001"+
		"q\u0003q\u0e6d\bq\u0001q\u0003q\u0e70\bq\u0001q\u0003q\u0e73\bq\u0001"+
		"r\u0001r\u0003r\u0e77\br\u0001r\u0003r\u0e7a\br\u0001r\u0001r\u0001r\u0001"+
		"r\u0001r\u0005r\u0e81\br\nr\fr\u0e84\tr\u0001r\u0001r\u0003r\u0e88\br"+
		"\u0001s\u0001s\u0001s\u0001s\u0001s\u0005s\u0e8f\bs\ns\fs\u0e92\ts\u0001"+
		"t\u0001t\u0003t\u0e96\bt\u0001u\u0001u\u0001u\u0005u\u0e9b\bu\nu\fu\u0e9e"+
		"\tu\u0001v\u0001v\u0005v\u0ea2\bv\nv\fv\u0ea5\tv\u0001v\u0001v\u0001v"+
		"\u0005v\u0eaa\bv\nv\fv\u0ead\tv\u0001v\u0001v\u0001v\u0003v\u0eb2\bv\u0001"+
		"w\u0001w\u0001w\u0001w\u0001w\u0001w\u0003w\u0eba\bw\u0001w\u0003w\u0ebd"+
		"\bw\u0001w\u0003w\u0ec0\bw\u0001w\u0001w\u0001w\u0005w\u0ec5\bw\nw\fw"+
		"\u0ec8\tw\u0003w\u0eca\bw\u0001w\u0001w\u0001w\u0001w\u0001w\u0003w\u0ed1"+
		"\bw\u0001w\u0003w\u0ed4\bw\u0001w\u0001w\u0001w\u0001w\u0001w\u0001w\u0003"+
		"w\u0edc\bw\u0001x\u0001x\u0001x\u0001x\u0003x\u0ee2\bx\u0001x\u0001x\u0001"+
		"x\u0001x\u0001y\u0001y\u0001y\u0001y\u0001y\u0003y\u0eed\by\u0001z\u0003"+
		"z\u0ef0\bz\u0001z\u0001z\u0003z\u0ef4\bz\u0001z\u0001z\u0005z\u0ef8\b"+
		"z\nz\fz\u0efb\tz\u0001z\u0001z\u0001z\u0001z\u0005z\u0f01\bz\nz\fz\u0f04"+
		"\tz\u0001z\u0001z\u0003z\u0f08\bz\u0001z\u0001z\u0003z\u0f0c\bz\u0001"+
		"z\u0001z\u0005z\u0f10\bz\nz\fz\u0f13\tz\u0001z\u0001z\u0001z\u0003z\u0f18"+
		"\bz\u0003z\u0f1a\bz\u0001z\u0001z\u0003z\u0f1e\bz\u0001{\u0001{\u0001"+
		"{\u0001{\u0001{\u0001{\u0001{\u0003{\u0f27\b{\u0001|\u0001|\u0001|\u0001"+
		"|\u0001|\u0001|\u0001|\u0001|\u0003|\u0f31\b|\u0001}\u0001}\u0001}\u0001"+
		"}\u0001}\u0001}\u0001}\u0001}\u0003}\u0f3b\b}\u0001~\u0001~\u0005~\u0f3f"+
		"\b~\n~\f~\u0f42\t~\u0001~\u0001~\u0003~\u0f46\b~\u0001~\u0001~\u0003~"+
		"\u0f4a\b~\u0001~\u0003~\u0f4d\b~\u0001~\u0003~\u0f50\b~\u0001~\u0003~"+
		"\u0f53\b~\u0001~\u0003~\u0f56\b~\u0001~\u0001~\u0005~\u0f5a\b~\n~\f~\u0f5d"+
		"\t~\u0001~\u0001~\u0001~\u0003~\u0f62\b~\u0001~\u0003~\u0f65\b~\u0001"+
		"~\u0003~\u0f68\b~\u0001~\u0003~\u0f6b\b~\u0001~\u0003~\u0f6e\b~\u0001"+
		"~\u0003~\u0f71\b~\u0003~\u0f73\b~\u0001\u007f\u0001\u007f\u0005\u007f"+
		"\u0f77\b\u007f\n\u007f\f\u007f\u0f7a\t\u007f\u0001\u007f\u0001\u007f\u0001"+
		"\u007f\u0003\u007f\u0f7f\b\u007f\u0001\u007f\u0003\u007f\u0f82\b\u007f"+
		"\u0001\u007f\u0003\u007f\u0f85\b\u007f\u0001\u007f\u0003\u007f\u0f88\b"+
		"\u007f\u0001\u007f\u0003\u007f\u0f8b\b\u007f\u0001\u0080\u0001\u0080\u0003"+
		"\u0080\u0f8f\b\u0080\u0001\u0080\u0001\u0080\u0001\u0081\u0001\u0081\u0003"+
		"\u0081\u0f95\b\u0081\u0001\u0081\u0001\u0081\u0003\u0081\u0f99\b\u0081"+
		"\u0001\u0082\u0001\u0082\u0001\u0082\u0001\u0082\u0001\u0082\u0001\u0082"+
		"\u0003\u0082\u0fa1\b\u0082\u0001\u0082\u0001\u0082\u0003\u0082\u0fa5\b"+
		"\u0082\u0001\u0082\u0003\u0082\u0fa8\b\u0082\u0003\u0082\u0faa\b\u0082"+
		"\u0001\u0083\u0001\u0083\u0001\u0083\u0001\u0083\u0001\u0083\u0001\u0083"+
		"\u0001\u0083\u0001\u0083\u0001\u0083\u0001\u0083\u0001\u0083\u0003\u0083"+
		"\u0fb7\b\u0083\u0001\u0083\u0003\u0083\u0fba\b\u0083\u0001\u0084\u0001"+
		"\u0084\u0001\u0084\u0005\u0084\u0fbf\b\u0084\n\u0084\f\u0084\u0fc2\t\u0084"+
		"\u0001\u0085\u0001\u0085\u0001\u0085\u0001\u0085\u0001\u0085\u0001\u0085"+
		"\u0001\u0085\u0003\u0085\u0fcb\b\u0085\u0001\u0085\u0003\u0085\u0fce\b"+
		"\u0085\u0001\u0085\u0001\u0085\u0001\u0085\u0003\u0085\u0fd3\b\u0085\u0003"+
		"\u0085\u0fd5\b\u0085\u0001\u0085\u0001\u0085\u0003\u0085\u0fd9\b\u0085"+
		"\u0001\u0085\u0001\u0085\u0001\u0085\u0001\u0085\u0001\u0085\u0001\u0085"+
		"\u0003\u0085\u0fe1\b\u0085\u0001\u0086\u0001\u0086\u0001\u0086\u0001\u0086"+
		"\u0003\u0086\u0fe7\b\u0086\u0001\u0086\u0001\u0086\u0001\u0086\u0001\u0087"+
		"\u0001\u0087\u0001\u0087\u0001\u0087\u0003\u0087\u0ff0\b\u0087\u0001\u0087"+
		"\u0001\u0087\u0001\u0087\u0001\u0088\u0001\u0088\u0001\u0088\u0001\u0088"+
		"\u0001\u0088\u0001\u0088\u0001\u0088\u0001\u0088\u0003\u0088\u0ffd\b\u0088"+
		"\u0001\u0089\u0001\u0089\u0003\u0089\u1001\b\u0089\u0001\u0089\u0001\u0089"+
		"\u0005\u0089\u1005\b\u0089\n\u0089\f\u0089\u1008\t\u0089\u0001\u008a\u0001"+
		"\u008a\u0001\u008a\u0001\u008a\u0001\u008a\u0001\u008a\u0003\u008a\u1010"+
		"\b\u008a\u0001\u008a\u0003\u008a\u1013\b\u008a\u0001\u008a\u0001\u008a"+
		"\u0003\u008a\u1017\b\u008a\u0001\u008a\u0003\u008a\u101a\b\u008a\u0001"+
		"\u008a\u0001\u008a\u0003\u008a\u101e\b\u008a\u0001\u008a\u0001\u008a\u0003"+
		"\u008a\u1022\b\u008a\u0001\u008a\u0003\u008a\u1025\b\u008a\u0003\u008a"+
		"\u1027\b\u008a\u0001\u008b\u0001\u008b\u0001\u008b\u0001\u008b\u0005\u008b"+
		"\u102d\b\u008b\n\u008b\f\u008b\u1030\t\u008b\u0001\u008b\u0001\u008b\u0001"+
		"\u008b\u0001\u008b\u0001\u008b\u0001\u008b\u0001\u008b\u0001\u008b\u0001"+
		"\u008b\u0003\u008b\u103b\b\u008b\u0001\u008b\u0001\u008b\u0004\u008b\u103f"+
		"\b\u008b\u000b\u008b\f\u008b\u1040\u0003\u008b\u1043\b\u008b\u0001\u008b"+
		"\u0001\u008b\u0004\u008b\u1047\b\u008b\u000b\u008b\f\u008b\u1048\u0003"+
		"\u008b\u104b\b\u008b\u0003\u008b\u104d\b\u008b\u0001\u008c\u0001\u008c"+
		"\u0001\u008c\u0001\u008c\u0003\u008c\u1053\b\u008c\u0001\u008c\u0001\u008c"+
		"\u0001\u008c\u0001\u008c\u0001\u008c\u0001\u008c\u0003\u008c\u105b\b\u008c"+
		"\u0001\u008d\u0001\u008d\u0001\u008d\u0001\u008d\u0001\u008d\u0001\u008d"+
		"\u0003\u008d\u1063\b\u008d\u0001\u008e\u0001\u008e\u0003\u008e\u1067\b"+
		"\u008e\u0001\u008e\u0001\u008e\u0003\u008e\u106b\b\u008e\u0001\u008f\u0001"+
		"\u008f\u0001\u008f\u0001\u008f\u0001\u008f\u0005\u008f\u1072\b\u008f\n"+
		"\u008f\f\u008f\u1075\t\u008f\u0001\u008f\u0001\u008f\u0003\u008f\u1079"+
		"\b\u008f\u0001\u0090\u0001\u0090\u0001\u0090\u0001\u0091\u0001\u0091\u0001"+
		"\u0091\u0001\u0091\u0001\u0091\u0001\u0091\u0001\u0091\u0001\u0091\u0001"+
		"\u0091\u0001\u0091\u0001\u0091\u0001\u0091\u0001\u0091\u0005\u0091\u108b"+
		"\b\u0091\n\u0091\f\u0091\u108e\t\u0091\u0001\u0092\u0001\u0092\u0003\u0092"+
		"\u1092\b\u0092\u0001\u0093\u0001\u0093\u0001\u0093\u0001\u0093\u0003\u0093"+
		"\u1098\b\u0093\u0001\u0093\u0001\u0093\u0001\u0093\u0001\u0093\u0001\u0093"+
		"\u0003\u0093\u109f\b\u0093\u0001\u0094\u0001\u0094\u0001\u0094\u0003\u0094"+
		"\u10a4\b\u0094\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095\u0001\u0095"+
		"\u0005\u0095\u10ab\b\u0095\n\u0095\f\u0095\u10ae\t\u0095\u0003\u0095\u10b0"+
		"\b\u0095\u0001\u0096\u0001\u0096\u0003\u0096\u10b4\b\u0096\u0001\u0097"+
		"\u0001\u0097\u0003\u0097\u10b8\b\u0097\u0001\u0097\u0001\u0097\u0003\u0097"+
		"\u10bc\b\u0097\u0001\u0097\u0003\u0097\u10bf\b\u0097\u0001\u0097\u0003"+
		"\u0097\u10c2\b\u0097\u0001\u0097\u0003\u0097\u10c5\b\u0097\u0001\u0098"+
		"\u0001\u0098\u0003\u0098\u10c9\b\u0098\u0001\u0098\u0001\u0098\u0003\u0098"+
		"\u10cd\b\u0098\u0001\u0098\u0003\u0098\u10d0\b\u0098\u0001\u0098\u0003"+
		"\u0098\u10d3\b\u0098\u0001\u0098\u0003\u0098\u10d6\b\u0098\u0001\u0099"+
		"\u0001\u0099\u0001\u0099\u0001\u009a\u0001\u009a\u0003\u009a\u10dd\b\u009a"+
		"\u0001\u009a\u0001\u009a\u0003\u009a\u10e1\b\u009a\u0001\u009a\u0001\u009a"+
		"\u0001\u009b\u0001\u009b\u0001\u009b\u0001\u009b\u0001\u009c\u0001\u009c"+
		"\u0001\u009c\u0001\u009c\u0001\u009c\u0005\u009c\u10ee\b\u009c\n\u009c"+
		"\f\u009c\u10f1\t\u009c\u0001\u009c\u0003\u009c\u10f4\b\u009c\u0001\u009d"+
		"\u0001\u009d\u0001\u009d\u0001\u009e\u0001\u009e\u0001\u009e\u0001\u009e"+
		"\u0001\u009e\u0001\u009f\u0001\u009f\u0003\u009f\u1100\b\u009f\u0001\u009f"+
		"\u0001\u009f\u0001\u009f\u0001\u009f\u0005\u009f\u1106\b\u009f\n\u009f"+
		"\f\u009f\u1109\t\u009f\u0001\u00a0\u0001\u00a0\u0001\u00a0\u0001\u00a0"+
		"\u0001\u00a0\u0001\u00a0\u0001\u00a0\u0003\u00a0\u1112\b\u00a0\u0001\u00a1"+
		"\u0001\u00a1\u0003\u00a1\u1116\b\u00a1\u0001\u00a1\u0003\u00a1\u1119\b"+
		"\u00a1\u0001\u00a1\u0001\u00a1\u0001\u00a2\u0001\u00a2\u0003\u00a2\u111f"+
		"\b\u00a2\u0001\u00a2\u0003\u00a2\u1122\b\u00a2\u0001\u00a2\u0003\u00a2"+
		"\u1125\b\u00a2\u0001\u00a3\u0001\u00a3\u0001\u00a3\u0001\u00a3\u0001\u00a3"+
		"\u0001\u00a3\u0001\u00a3\u0003\u00a3\u112e\b\u00a3\u0001\u00a4\u0001\u00a4"+
		"\u0001\u00a4\u0001\u00a4\u0001\u00a4\u0001\u00a4\u0001\u00a4\u0003\u00a4"+
		"\u1137\b\u00a4\u0001\u00a5\u0001\u00a5\u0001\u00a5\u0001\u00a5\u0001\u00a5"+
		"\u0001\u00a5\u0005\u00a5\u113f\b\u00a5\n\u00a5\f\u00a5\u1142\t\u00a5\u0001"+
		"\u00a5\u0003\u00a5\u1145\b\u00a5\u0001\u00a6\u0001\u00a6\u0001\u00a6\u0001"+
		"\u00a6\u0001\u00a6\u0001\u00a6\u0005\u00a6\u114d\b\u00a6\n\u00a6\f\u00a6"+
		"\u1150\t\u00a6\u0001\u00a7\u0001\u00a7\u0001\u00a7\u0001\u00a7\u0001\u00a7"+
		"\u0001\u00a7\u0001\u00a7\u0003\u00a7\u1159\b\u00a7\u0001\u00a8\u0001\u00a8"+
		"\u0001\u00a8\u0001\u00a9\u0001\u00a9\u0001\u00a9\u0003\u00a9\u1161\b\u00a9"+
		"\u0001\u00a9\u0003\u00a9\u1164\b\u00a9\u0001\u00aa\u0001\u00aa\u0001\u00aa"+
		"\u0001\u00aa\u0001\u00aa\u0005\u00aa\u116b\b\u00aa\n\u00aa\f\u00aa\u116e"+
		"\t\u00aa\u0003\u00aa\u1170\b\u00aa\u0001\u00aa\u0001\u00aa\u0003\u00aa"+
		"\u1174\b\u00aa\u0001\u00aa\u0005\u00aa\u1177\b\u00aa\n\u00aa\f\u00aa\u117a"+
		"\t\u00aa\u0001\u00aa\u0003\u00aa\u117d\b\u00aa\u0001\u00ab\u0001\u00ab"+
		"\u0001\u00ab\u0001\u00ab\u0001\u00ab\u0005\u00ab\u1184\b\u00ab\n\u00ab"+
		"\f\u00ab\u1187\t\u00ab\u0003\u00ab\u1189\b\u00ab\u0001\u00ac\u0001\u00ac"+
		"\u0001\u00ac\u0001\u00ad\u0001\u00ad\u0001\u00ad\u0001\u00ae\u0001\u00ae"+
		"\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae"+
		"\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae"+
		"\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae\u0001\u00ae"+
		"\u0001\u00ae\u0005\u00ae\u11a6\b\u00ae\n\u00ae\f\u00ae\u11a9\t\u00ae\u0003"+
		"\u00ae\u11ab\b\u00ae\u0001\u00ae\u0003\u00ae\u11ae\b\u00ae\u0001\u00af"+
		"\u0001\u00af\u0001\u00b0\u0001\u00b0\u0001\u00b1\u0001\u00b1\u0001\u00b2"+
		"\u0001\u00b2\u0001\u00b2\u0001\u00b2\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0001\u00b3"+
		"\u0001\u00b3\u0001\u00b3\u0001\u00b3\u0005\u00b3\u11e4\b\u00b3\n\u00b3"+
		"\f\u00b3\u11e7\t\u00b3\u0001\u00b3\u0001\u00b3\u0003\u00b3\u11eb\b\u00b3"+
		"\u0001\u00b4\u0001\u00b4\u0001\u00b4\u0001\u00b4\u0001\u00b4\u0001\u00b4"+
		"\u0001\u00b5\u0001\u00b5\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6"+
		"\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6"+
		"\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6\u0001\u00b6"+
		"\u0001\u00b6\u0001\u00b6\u0003\u00b6\u1207\b\u00b6\u0001\u00b7\u0001\u00b7"+
		"\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7"+
		"\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0001\u00b7\u0003\u00b7\u1215\b\u00b7"+
		"\u0001\u00b8\u0001\u00b8\u0001\u00b8\u0005\u00b8\u121a\b\u00b8\n\u00b8"+
		"\f\u00b8\u121d\t\u00b8\u0001\u00b8\u0003\u00b8\u1220\b\u00b8\u0001\u00b9"+
		"\u0001\u00b9\u0001\u00b9\u0001\u00b9\u0003\u00b9\u1226\b\u00b9\u0001\u00ba"+
		"\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0001\u00ba\u0003\u00ba"+
		"\u122e\b\u00ba\u0003\u00ba\u1230\b\u00ba\u0001\u00bb\u0001\u00bb\u0001"+
		"\u00bb\u0001\u00bb\u0001\u00bc\u0001\u00bc\u0001\u00bc\u0001\u00bc\u0001"+
		"\u00bc\u0003\u00bc\u123b\b\u00bc\u0001\u00bd\u0001\u00bd\u0001\u00bd\u0001"+
		"\u00bd\u0001\u00be\u0001\u00be\u0001\u00be\u0001\u00be\u0003\u00be\u1245"+
		"\b\u00be\u0001\u00bf\u0001\u00bf\u0001\u00bf\u0001\u00bf\u0001\u00bf\u0003"+
		"\u00bf\u124c\b\u00bf\u0001\u00c0\u0001\u00c0\u0001\u00c0\u0001\u00c0\u0003"+
		"\u00c0\u1252\b\u00c0\u0001\u00c1\u0001\u00c1\u0001\u00c1\u0001\u00c1\u0001"+
		"\u00c2\u0001\u00c2\u0003\u00c2\u125a\b\u00c2\u0001\u00c3\u0001\u00c3\u0001"+
		"\u00c3\u0003\u00c3\u125f\b\u00c3\u0001\u00c3\u0001\u00c3\u0001\u00c3\u0001"+
		"\u00c3\u0005\u00c3\u1265\b\u00c3\n\u00c3\f\u00c3\u1268\t\u00c3\u0001\u00c3"+
		"\u0001\u00c3\u0001\u00c3\u0005\u00c3\u126d\b\u00c3\n\u00c3\f\u00c3\u1270"+
		"\t\u00c3\u0001\u00c3\u0001\u00c3\u0001\u00c3\u0005\u00c3\u1275\b\u00c3"+
		"\n\u00c3\f\u00c3\u1278\t\u00c3\u0001\u00c3\u0001\u00c3\u0001\u00c3\u0005"+
		"\u00c3\u127d\b\u00c3\n\u00c3\f\u00c3\u1280\t\u00c3\u0001\u00c3\u0005\u00c3"+
		"\u1283\b\u00c3\n\u00c3\f\u00c3\u1286\t\u00c3\u0001\u00c3\u0001\u00c3\u0003"+
		"\u00c3\u128a\b\u00c3\u0001\u00c4\u0001\u00c4\u0001\u00c4\u0003\u00c4\u128f"+
		"\b\u00c4\u0001\u00c4\u0004\u00c4\u1292\b\u00c4\u000b\u00c4\f\u00c4\u1293"+
		"\u0001\u00c4\u0001\u00c4\u0004\u00c4\u1298\b\u00c4\u000b\u00c4\f\u00c4"+
		"\u1299\u0003\u00c4\u129c\b\u00c4\u0001\u00c4\u0001\u00c4\u0001\u00c4\u0001"+
		"\u00c5\u0001\u00c5\u0001\u00c5\u0001\u00c5\u0004\u00c5\u12a5\b\u00c5\u000b"+
		"\u00c5\f\u00c5\u12a6\u0001\u00c5\u0005\u00c5\u12aa\b\u00c5\n\u00c5\f\u00c5"+
		"\u12ad\t\u00c5\u0001\u00c5\u0001\u00c5\u0004\u00c5\u12b1\b\u00c5\u000b"+
		"\u00c5\f\u00c5\u12b2\u0003\u00c5\u12b5\b\u00c5\u0001\u00c5\u0001\u00c5"+
		"\u0001\u00c5\u0001\u00c6\u0001\u00c6\u0001\u00c6\u0001\u00c7\u0001\u00c7"+
		"\u0001\u00c7\u0001\u00c8\u0001\u00c8\u0001\u00c8\u0003\u00c8\u12c3\b\u00c8"+
		"\u0001\u00c8\u0001\u00c8\u0004\u00c8\u12c7\b\u00c8\u000b\u00c8\f\u00c8"+
		"\u12c8\u0001\u00c8\u0001\u00c8\u0001\u00c8\u0003\u00c8\u12ce\b\u00c8\u0001"+
		"\u00c9\u0001\u00c9\u0001\u00c9\u0003\u00c9\u12d3\b\u00c9\u0001\u00c9\u0001"+
		"\u00c9\u0004\u00c9\u12d7\b\u00c9\u000b\u00c9\f\u00c9\u12d8\u0001\u00c9"+
		"\u0001\u00c9\u0001\u00c9\u0001\u00c9\u0001\u00c9\u0003\u00c9\u12e0\b\u00c9"+
		"\u0001\u00ca\u0001\u00ca\u0001\u00ca\u0001\u00cb\u0001\u00cb\u0001\u00cb"+
		"\u0003\u00cb\u12e8\b\u00cb\u0001\u00cb\u0001\u00cb\u0001\u00cb\u0001\u00cb"+
		"\u0004\u00cb\u12ee\b\u00cb\u000b\u00cb\f\u00cb\u12ef\u0001\u00cb\u0001"+
		"\u00cb\u0001\u00cb\u0003\u00cb\u12f5\b\u00cb\u0001\u00cc\u0001\u00cc\u0001"+
		"\u00cc\u0001\u00cc\u0003\u00cc\u12fb\b\u00cc\u0001\u00cc\u0003\u00cc\u12fe"+
		"\b\u00cc\u0001\u00cc\u0001\u00cc\u0001\u00cc\u0001\u00cc\u0001\u00cc\u0001"+
		"\u00cc\u0003\u00cc\u1306\b\u00cc\u0001\u00cd\u0001\u00cd\u0001\u00cd\u0001"+
		"\u00cd\u0001\u00cd\u0003\u00cd\u130d\b\u00cd\u0001\u00ce\u0001\u00ce\u0001"+
		"\u00ce\u0001\u00ce\u0001\u00ce\u0001\u00ce\u0001\u00ce\u0003\u00ce\u1316"+
		"\b\u00ce\u0001\u00ce\u0003\u00ce\u1319\b\u00ce\u0001\u00cf\u0001\u00cf"+
		"\u0001\u00cf\u0001\u00cf\u0001\u00cf\u0001\u00cf\u0001\u00d0\u0001\u00d0"+
		"\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0001\u00d0\u0005\u00d0"+
		"\u1328\b\u00d0\n\u00d0\f\u00d0\u132b\t\u00d0\u0001\u00d0\u0001\u00d0\u0001"+
		"\u00d1\u0001\u00d1\u0001\u00d1\u0003\u00d1\u1332\b\u00d1\u0001\u00d1\u0001"+
		"\u00d1\u0001\u00d1\u0001\u00d1\u0001\u00d1\u0001\u00d1\u0003\u00d1\u133a"+
		"\b\u00d1\u0001\u00d2\u0001\u00d2\u0003\u00d2\u133e\b\u00d2\u0001\u00d2"+
		"\u0001\u00d2\u0001\u00d3\u0001\u00d3\u0001\u00d3\u0003\u00d3\u1345\b\u00d3"+
		"\u0001\u00d3\u0001\u00d3\u0004\u00d3\u1349\b\u00d3\u000b\u00d3\f\u00d3"+
		"\u134a\u0001\u00d4\u0001\u00d4\u0001\u00d4\u0001\u00d4\u0004\u00d4\u1351"+
		"\b\u00d4\u000b\u00d4\f\u00d4\u1352\u0001\u00d5\u0001\u00d5\u0001\u00d5"+
		"\u0001\u00d5\u0001\u00d5\u0005\u00d5\u135a\b\u00d5\n\u00d5\f\u00d5\u135d"+
		"\t\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0003\u00d5\u1362\b\u00d5"+
		"\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0005\u00d5\u1367\b\u00d5\n\u00d5"+
		"\f\u00d5\u136a\t\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5"+
		"\u0003\u00d5\u1370\b\u00d5\u0001\u00d5\u0005\u00d5\u1373\b\u00d5\n\u00d5"+
		"\f\u00d5\u1376\t\u00d5\u0003\u00d5\u1378\b\u00d5\u0003\u00d5\u137a\b\u00d5"+
		"\u0001\u00d5\u0001\u00d5\u0004\u00d5\u137e\b\u00d5\u000b\u00d5\f\u00d5"+
		"\u137f\u0003\u00d5\u1382\b\u00d5\u0001\u00d5\u0001\u00d5\u0005\u00d5\u1386"+
		"\b\u00d5\n\u00d5\f\u00d5\u1389\t\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5"+
		"\u0001\u00d5\u0003\u00d5\u138f\b\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5"+
		"\u0003\u00d5\u1394\b\u00d5\u0001\u00d5\u0001\u00d5\u0003\u00d5\u1398\b"+
		"\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0001\u00d5\u0003\u00d5\u139e"+
		"\b\u00d5\u0001\u00d6\u0001\u00d6\u0001\u00d6\u0001\u00d6\u0001\u00d6\u0005"+
		"\u00d6\u13a5\b\u00d6\n\u00d6\f\u00d6\u13a8\t\u00d6\u0001\u00d6\u0001\u00d6"+
		"\u0001\u00d6\u0003\u00d6\u13ad\b\u00d6\u0001\u00d6\u0001\u00d6\u0001\u00d6"+
		"\u0005\u00d6\u13b2\b\u00d6\n\u00d6\f\u00d6\u13b5\t\u00d6\u0001\u00d6\u0001"+
		"\u00d6\u0001\u00d6\u0003\u00d6\u13ba\b\u00d6\u0001\u00d6\u0001\u00d6\u0001"+
		"\u00d6\u0001\u00d6\u0003\u00d6\u13c0\b\u00d6\u0001\u00d6\u0005\u00d6\u13c3"+
		"\b\u00d6\n\u00d6\f\u00d6\u13c6\t\u00d6\u0003\u00d6\u13c8\b\u00d6\u0003"+
		"\u00d6\u13ca\b\u00d6\u0001\u00d6\u0001\u00d6\u0004\u00d6\u13ce\b\u00d6"+
		"\u000b\u00d6\f\u00d6\u13cf\u0003\u00d6\u13d2\b\u00d6\u0001\u00d6\u0001"+
		"\u00d6\u0005\u00d6\u13d6\b\u00d6\n\u00d6\f\u00d6\u13d9\t\u00d6\u0001\u00d6"+
		"\u0001\u00d6\u0001\u00d6\u0001\u00d6\u0003\u00d6\u13df\b\u00d6\u0003\u00d6"+
		"\u13e1\b\u00d6\u0001\u00d7\u0001\u00d7\u0001\u00d7\u0003\u00d7\u13e6\b"+
		"\u00d7\u0001\u00d7\u0001\u00d7\u0001\u00d7\u0005\u00d7\u13eb\b\u00d7\n"+
		"\u00d7\f\u00d7\u13ee\t\u00d7\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0001"+
		"\u00d8\u0005\u00d8\u13f4\b\u00d8\n\u00d8\f\u00d8\u13f7\t\u00d8\u0001\u00d8"+
		"\u0001\u00d8\u0003\u00d8\u13fb\b\u00d8\u0001\u00d8\u0001\u00d8\u0001\u00d8"+
		"\u0001\u00d8\u0001\u00d8\u0005\u00d8\u1402\b\u00d8\n\u00d8\f\u00d8\u1405"+
		"\t\u00d8\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0003\u00d8\u140b"+
		"\b\u00d8\u0001\u00d8\u0005\u00d8\u140e\b\u00d8\n\u00d8\f\u00d8\u1411\t"+
		"\u00d8\u0003\u00d8\u1413\b\u00d8\u0003\u00d8\u1415\b\u00d8\u0001\u00d8"+
		"\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0005\u00d8\u141b\b\u00d8\n\u00d8"+
		"\f\u00d8\u141e\t\u00d8\u0003\u00d8\u1420\b\u00d8\u0001\u00d8\u0001\u00d8"+
		"\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0003\u00d8\u1428\b\u00d8"+
		"\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0003\u00d8\u142d\b\u00d8\u0001\u00d8"+
		"\u0001\u00d8\u0001\u00d8\u0003\u00d8\u1432\b\u00d8\u0005\u00d8\u1434\b"+
		"\u00d8\n\u00d8\f\u00d8\u1437\t\u00d8\u0001\u00d8\u0001\u00d8\u0001\u00d8"+
		"\u0003\u00d8\u143c\b\u00d8\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0003\u00d8"+
		"\u1441\b\u00d8\u0005\u00d8\u1443\b\u00d8\n\u00d8\f\u00d8\u1446\t\u00d8"+
		"\u0001\u00d8\u0001\u00d8\u0001\u00d8\u0003\u00d8\u144b\b\u00d8\u0003\u00d8"+
		"\u144d\b\u00d8\u0001\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9"+
		"\u0001\u00d9\u0001\u00d9\u0005\u00d9\u1456\b\u00d9\n\u00d9\f\u00d9\u1459"+
		"\t\u00d9\u0003\u00d9\u145b\b\u00d9\u0001\u00d9\u0001\u00d9\u0001\u00d9"+
		"\u0005\u00d9\u1460\b\u00d9\n\u00d9\f\u00d9\u1463\t\u00d9\u0003\u00d9\u1465"+
		"\b\u00d9\u0001\u00da\u0001\u00da\u0001\u00da\u0001\u00da\u0001\u00da\u0001"+
		"\u00da\u0001\u00da\u0001\u00da\u0005\u00da\u146f\b\u00da\n\u00da\f\u00da"+
		"\u1472\t\u00da\u0001\u00da\u0001\u00da\u0001\u00da\u0003\u00da\u1477\b"+
		"\u00da\u0001\u00db\u0001\u00db\u0001\u00db\u0001\u00db\u0001\u00db\u0005"+
		"\u00db\u147e\b\u00db\n\u00db\f\u00db\u1481\t\u00db\u0001\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0005\u00dc\u1487\b\u00dc\n\u00dc\f\u00dc\u148a"+
		"\t\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc\u148e\b\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0005\u00dc\u1495\b\u00dc"+
		"\n\u00dc\f\u00dc\u1498\t\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003"+
		"\u00dc\u149d\b\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0001"+
		"\u00dc\u0001\u00dc\u0001\u00dc\u0005\u00dc\u14a6\b\u00dc\n\u00dc\f\u00dc"+
		"\u14a9\t\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc\u14ae\b"+
		"\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc\u0003\u00dc\u14b3\b\u00dc\u0005"+
		"\u00dc\u14b5\b\u00dc\n\u00dc\f\u00dc\u14b8\t\u00dc\u0001\u00dc\u0001\u00dc"+
		"\u0001\u00dc\u0003\u00dc\u14bd\b\u00dc\u0001\u00dc\u0001\u00dc\u0001\u00dc"+
		"\u0003\u00dc\u14c2\b\u00dc\u0005\u00dc\u14c4\b\u00dc\n\u00dc\f\u00dc\u14c7"+
		"\t\u00dc\u0003\u00dc\u14c9\b\u00dc\u0001\u00dd\u0001\u00dd\u0001\u00dd"+
		"\u0001\u00dd\u0001\u00dd\u0001\u00dd\u0001\u00dd\u0001\u00dd\u0005\u00dd"+
		"\u14d3\b\u00dd\n\u00dd\f\u00dd\u14d6\t\u00dd\u0001\u00de\u0001\u00de\u0001"+
		"\u00de\u0001\u00de\u0003\u00de\u14dc\b\u00de\u0001\u00de\u0001\u00de\u0001"+
		"\u00de\u0003\u00de\u14e1\b\u00de\u0001\u00df\u0001\u00df\u0001\u00df\u0001"+
		"\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001"+
		"\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001"+
		"\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001"+
		"\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001\u00e0\u0001"+
		"\u00e0\u0003\u00e0\u14ff\b\u00e0\u0001\u00e1\u0001\u00e1\u0003\u00e1\u1503"+
		"\b\u00e1\u0001\u00e1\u0001\u00e1\u0001\u00e1\u0003\u00e1\u1508\b\u00e1"+
		"\u0001\u00e2\u0001\u00e2\u0001\u00e2\u0001\u00e2\u0001\u00e2\u0003\u00e2"+
		"\u150f\b\u00e2\u0001\u00e2\u0003\u00e2\u1512\b\u00e2\u0001\u00e2\u0001"+
		"\u00e2\u0001\u00e2\u0001\u00e2\u0003\u00e2\u1518\b\u00e2\u0001\u00e3\u0001"+
		"\u00e3\u0001\u00e3\u0001\u00e3\u0001\u00e3\u0001\u00e3\u0001\u00e3\u0001"+
		"\u00e3\u0003\u00e3\u1522\b\u00e3\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001"+
		"\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0001\u00e4\u0003\u00e4\u152c"+
		"\b\u00e4\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001"+
		"\u00e5\u0001\u00e5\u0001\u00e5\u0003\u00e5\u1536\b\u00e5\u0001\u00e5\u0001"+
		"\u00e5\u0001\u00e5\u0001\u00e5\u0003\u00e5\u153c\b\u00e5\u0001\u00e5\u0001"+
		"\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0003"+
		"\u00e5\u1545\b\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0003"+
		"\u00e5\u154b\b\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001\u00e5\u0001"+
		"\u00e5\u0003\u00e5\u1552\b\u00e5\u0003\u00e5\u1554\b\u00e5\u0001\u00e6"+
		"\u0001\u00e6\u0001\u00e6\u0001\u00e7\u0001\u00e7\u0001\u00e7\u0001\u00e7"+
		"\u0001\u00e7\u0003\u00e7\u155e\b\u00e7\u0001\u00e8\u0001\u00e8\u0003\u00e8"+
		"\u1562\b\u00e8\u0001\u00e8\u0001\u00e8\u0003\u00e8\u1566\b\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0003\u00e8\u1570\b\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0003\u00e8\u1575\b\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001\u00e8\u0001"+
		"\u00e8\u0003\u00e8\u15bd\b\u00e8\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001"+
		"\u00e9\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001"+
		"\u00e9\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001\u00e9\u0001"+
		"\u00e9\u0003\u00e9\u15cf\b\u00e9\u0001\u00ea\u0001\u00ea\u0001\u00ea\u0001"+
		"\u00ea\u0001\u00eb\u0001\u00eb\u0003\u00eb\u15d7\b\u00eb\u0001\u00eb\u0001"+
		"\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001"+
		"\u00eb\u0005\u00eb\u15e1\b\u00eb\n\u00eb\f\u00eb\u15e4\t\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0003\u00eb\u15ea\b\u00eb\u0003\u00eb"+
		"\u15ec\b\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb\u0001\u00eb"+
		"\u0001\u00eb\u0005\u00eb\u15f4\b\u00eb\n\u00eb\f\u00eb\u15f7\t\u00eb\u0003"+
		"\u00eb\u15f9\b\u00eb\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0001\u00ec\u0005"+
		"\u00ec\u15ff\b\u00ec\n\u00ec\f\u00ec\u1602\t\u00ec\u0001\u00ed\u0001\u00ed"+
		"\u0001\u00ed\u0001\u00ed\u0003\u00ed\u1608\b\u00ed\u0001\u00ee\u0001\u00ee"+
		"\u0003\u00ee\u160c\b\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ee\u0001\u00ef"+
		"\u0001\u00ef\u0003\u00ef\u1613\b\u00ef\u0001\u00ef\u0001\u00ef\u0001\u00ef"+
		"\u0003\u00ef\u1618\b\u00ef\u0001\u00ef\u0003\u00ef\u161b\b\u00ef\u0001"+
		"\u00ef\u0003\u00ef\u161e\b\u00ef\u0001\u00f0\u0001\u00f0\u0001\u00f0\u0001"+
		"\u00f0\u0001\u00f0\u0001\u00f0\u0001\u00f0\u0003\u00f0\u1627\b\u00f0\u0001"+
		"\u00f1\u0001\u00f1\u0003\u00f1\u162b\b\u00f1\u0001\u00f1\u0001\u00f1\u0003"+
		"\u00f1\u162f\b\u00f1\u0001\u00f1\u0001\u00f1\u0001\u00f1\u0001\u00f1\u0001"+
		"\u00f1\u0001\u00f1\u0001\u00f2\u0001\u00f2\u0001\u00f2\u0001\u00f2\u0001"+
		"\u00f2\u0001\u00f2\u0001\u00f3\u0001\u00f3\u0001\u00f3\u0001\u00f3\u0001"+
		"\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0003\u00f4\u1646"+
		"\b\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0003"+
		"\u00f4\u164d\b\u00f4\u0005\u00f4\u164f\b\u00f4\n\u00f4\f\u00f4\u1652\t"+
		"\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0003\u00f4\u1658"+
		"\b\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0003"+
		"\u00f4\u165f\b\u00f4\u0001\u00f4\u0003\u00f4\u1662\b\u00f4\u0001\u00f4"+
		"\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4"+
		"\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0001\u00f4\u0005\u00f4"+
		"\u1670\b\u00f4\n\u00f4\f\u00f4\u1673\t\u00f4\u0003\u00f4\u1675\b\u00f4"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0003\u00f5\u167f\b\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0003\u00f5\u1683\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0003\u00f5\u1689\b\u00f5\u0001\u00f5\u0003\u00f5\u168c\b\u00f5\u0001"+
		"\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u1691\b\u00f5\u0001\u00f5\u0001"+
		"\u00f5\u0003\u00f5\u1695\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001"+
		"\u00f5\u0001\u00f5\u0003\u00f5\u169c\b\u00f5\u0001\u00f5\u0003\u00f5\u169f"+
		"\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u16a5"+
		"\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001"+
		"\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001"+
		"\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001"+
		"\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u16bd"+
		"\b\u00f5\u0001\u00f5\u0003\u00f5\u16c0\b\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0003\u00f5\u16cc\b\u00f5\u0001\u00f5\u0003\u00f5"+
		"\u16cf\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u16d9\b\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5"+
		"\u16e1\b\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u16e5\b\u00f5\u0001"+
		"\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u16ec"+
		"\b\u00f5\u0001\u00f5\u0003\u00f5\u16ef\b\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0005\u00f5\u16f6\b\u00f5\n\u00f5"+
		"\f\u00f5\u16f9\t\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5"+
		"\u16fe\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5"+
		"\u1704\b\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0001\u00f5"+
		"\u0001\u00f5\u0001\u00f5\u0001\u00f5\u0003\u00f5\u170e\b\u00f5\u0003\u00f5"+
		"\u1710\b\u00f5\u0001\u00f6\u0001\u00f6\u0001\u00f6\u0001\u00f6\u0003\u00f6"+
		"\u1716\b\u00f6\u0001\u00f6\u0003\u00f6\u1719\b\u00f6\u0001\u00f6\u0003"+
		"\u00f6\u171c\b\u00f6\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001"+
		"\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0001\u00f7\u0003"+
		"\u00f7\u1728\b\u00f7\u0001\u00f7\u0003\u00f7\u172b\b\u00f7\u0001\u00f8"+
		"\u0001\u00f8\u0001\u00f8\u0001\u00f8\u0003\u00f8\u1731\b\u00f8\u0001\u00f9"+
		"\u0003\u00f9\u1734\b\u00f9\u0001\u00f9\u0001\u00f9\u0001\u00f9\u0001\u00f9"+
		"\u0001\u00f9\u0001\u00f9\u0003\u00f9\u173c\b\u00f9\u0001\u00f9\u0001\u00f9"+
		"\u0001\u00f9\u0001\u00f9\u0001\u00f9\u0001\u00f9\u0003\u00f9\u1744\b\u00f9"+
		"\u0001\u00fa\u0001\u00fa\u0001\u00fa\u0001\u00fa\u0003\u00fa\u174a\b\u00fa"+
		"\u0001\u00fa\u0001\u00fa\u0003\u00fa\u174e\b\u00fa\u0001\u00fb\u0001\u00fb"+
		"\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb"+
		"\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0001\u00fb\u0003\u00fb\u175c\b\u00fb"+
		"\u0001\u00fc\u0001\u00fc\u0001\u00fc\u0001\u00fd\u0001\u00fd\u0001\u00fd"+
		"\u0001\u00fd\u0001\u00fd\u0005\u00fd\u1766\b\u00fd\n\u00fd\f\u00fd\u1769"+
		"\t\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0001\u00fd\u0003\u00fd\u176f"+
		"\b\u00fd\u0001\u00fd\u0003\u00fd\u1772\b\u00fd\u0001\u00fd\u0001\u00fd"+
		"\u0001\u00fd\u0001\u00fe\u0001\u00fe\u0003\u00fe\u1779\b\u00fe\u0001\u00fe"+
		"\u0001\u00fe\u0001\u00fe\u0005\u00fe\u177e\b\u00fe\n\u00fe\f\u00fe\u1781"+
		"\t\u00fe\u0001\u00ff\u0001\u00ff\u0003\u00ff\u1785\b\u00ff\u0001\u00ff"+
		"\u0001\u00ff\u0001\u0100\u0001\u0100\u0001\u0100\u0001\u0100\u0001\u0100"+
		"\u0001\u0100\u0001\u0100\u0005\u0100\u1790\b\u0100\n\u0100\f\u0100\u1793"+
		"\t\u0100\u0001\u0101\u0001\u0101\u0001\u0101\u0001\u0101\u0001\u0102\u0001"+
		"\u0102\u0001\u0103\u0001\u0103\u0003\u0103\u179d\b\u0103\u0001\u0103\u0001"+
		"\u0103\u0001\u0103\u0001\u0103\u0003\u0103\u17a3\b\u0103\u0001\u0104\u0001"+
		"\u0104\u0001\u0104\u0003\u0104\u17a8\b\u0104\u0001\u0104\u0001\u0104\u0001"+
		"\u0104\u0001\u0104\u0001\u0104\u0001\u0104\u0001\u0104\u0001\u0104\u0001"+
		"\u0104\u0001\u0104\u0001\u0104\u0003\u0104\u17b5\b\u0104\u0003\u0104\u17b7"+
		"\b\u0104\u0001\u0104\u0001\u0104\u0001\u0104\u0003\u0104\u17bc\b\u0104"+
		"\u0001\u0104\u0001\u0104\u0003\u0104\u17c0\b\u0104\u0001\u0104\u0003\u0104"+
		"\u17c3\b\u0104\u0003\u0104\u17c5\b\u0104\u0001\u0105\u0001\u0105\u0001"+
		"\u0105\u0001\u0105\u0001\u0105\u0003\u0105\u17cc\b\u0105\u0001\u0106\u0001"+
		"\u0106\u0001\u0106\u0001\u0106\u0001\u0106\u0003\u0106\u17d3\b\u0106\u0001"+
		"\u0106\u0003\u0106\u17d6\b\u0106\u0001\u0106\u0003\u0106\u17d9\b\u0106"+
		"\u0001\u0106\u0001\u0106\u0001\u0106\u0001\u0106\u0003\u0106\u17df\b\u0106"+
		"\u0001\u0106\u0001\u0106\u0003\u0106\u17e3\b\u0106\u0001\u0107\u0001\u0107"+
		"\u0001\u0107\u0001\u0107\u0003\u0107\u17e9\b\u0107\u0001\u0108\u0001\u0108"+
		"\u0001\u0108\u0001\u0108\u0003\u0108\u17ef\b\u0108\u0001\u0108\u0001\u0108"+
		"\u0001\u0109\u0001\u0109\u0001\u0109\u0001\u010a\u0001\u010a\u0001\u010a"+
		"\u0001\u010b\u0001\u010b\u0001\u010b\u0003\u010b\u17fc\b\u010b\u0001\u010b"+
		"\u0001\u010b\u0001\u010b\u0003\u010b\u1801\b\u010b\u0001\u010b\u0001\u010b"+
		"\u0001\u010b\u0001\u010b\u0005\u010b\u1807\b\u010b\n\u010b\f\u010b\u180a"+
		"\t\u010b\u0003\u010b\u180c\b\u010b\u0001\u010c\u0001\u010c\u0001\u010c"+
		"\u0003\u010c\u1811\b\u010c\u0001\u010c\u0001\u010c\u0001\u010c\u0003\u010c"+
		"\u1816\b\u010c\u0001\u010c\u0001\u010c\u0001\u010c\u0001\u010c\u0005\u010c"+
		"\u181c\b\u010c\n\u010c\f\u010c\u181f\t\u010c\u0003\u010c\u1821\b\u010c"+
		"\u0001\u010d\u0001\u010d\u0001\u010d\u0001\u010d\u0001\u010d\u0001\u010d"+
		"\u0003\u010d\u1829\b\u010d\u0001\u010e\u0001\u010e\u0003\u010e\u182d\b"+
		"\u010e\u0001\u010e\u0001\u010e\u0001\u010e\u0005\u010e\u1832\b\u010e\n"+
		"\u010e\f\u010e\u1835\t\u010e\u0001\u010f\u0001\u010f\u0001\u010f\u0003"+
		"\u010f\u183a\b\u010f\u0001\u010f\u0003\u010f\u183d\b\u010f\u0001\u0110"+
		"\u0001\u0110\u0003\u0110\u1841\b\u0110\u0001\u0110\u0001\u0110\u0001\u0110"+
		"\u0001\u0110\u0001\u0110\u0001\u0110\u0001\u0110\u0001\u0110\u0001\u0110"+
		"\u0005\u0110\u184c\b\u0110\n\u0110\f\u0110\u184f\t\u0110\u0001\u0110\u0001"+
		"\u0110\u0001\u0110\u0003\u0110\u1854\b\u0110\u0001\u0110\u0001\u0110\u0001"+
		"\u0110\u0001\u0110\u0001\u0110\u0001\u0110\u0001\u0110\u0001\u0110\u0005"+
		"\u0110\u185e\b\u0110\n\u0110\f\u0110\u1861\t\u0110\u0003\u0110\u1863\b"+
		"\u0110\u0001\u0111\u0001\u0111\u0001\u0112\u0001\u0112\u0001\u0112\u0001"+
		"\u0112\u0001\u0112\u0003\u0112\u186c\b\u0112\u0001\u0112\u0001\u0112\u0001"+
		"\u0112\u0003\u0112\u1871\b\u0112\u0001\u0113\u0001\u0113\u0001\u0113\u0001"+
		"\u0113\u0003\u0113\u1877\b\u0113\u0001\u0114\u0001\u0114\u0001\u0115\u0001"+
		"\u0115\u0003\u0115\u187d\b\u0115\u0001\u0116\u0001\u0116\u0001\u0116\u0003"+
		"\u0116\u1882\b\u0116\u0003\u0116\u1884\b\u0116\u0001\u0116\u0003\u0116"+
		"\u1887\b\u0116\u0001\u0116\u0001\u0116\u0003\u0116\u188b\b\u0116\u0003"+
		"\u0116\u188d\b\u0116\u0001\u0117\u0001\u0117\u0003\u0117\u1891\b\u0117"+
		"\u0001\u0117\u0001\u0117\u0001\u0117\u0001\u0117\u0003\u0117\u1897\b\u0117"+
		"\u0001\u0117\u0003\u0117\u189a\b\u0117\u0001\u0117\u0003\u0117\u189d\b"+
		"\u0117\u0001\u0118\u0001\u0118\u0001\u0118\u0001\u0118\u0003\u0118\u18a3"+
		"\b\u0118\u0001\u0119\u0001\u0119\u0001\u011a\u0001\u011a\u0001\u011a\u0001"+
		"\u011a\u0001\u011a\u0003\u011a\u18ac\b\u011a\u0001\u011b\u0001\u011b\u0001"+
		"\u011c\u0001\u011c\u0001\u011c\u0001\u011c\u0003\u011c\u18b4\b\u011c\u0001"+
		"\u011d\u0001\u011d\u0003\u011d\u18b8\b\u011d\u0001\u011e\u0001\u011e\u0001"+
		"\u011e\u0003\u011e\u18bd\b\u011e\u0001\u011f\u0001\u011f\u0001\u0120\u0001"+
		"\u0120\u0001\u0120\u0001\u0120\u0001\u0120\u0001\u0120\u0001\u0120\u0001"+
		"\u0120\u0001\u0120\u0001\u0120\u0001\u0120\u0001\u0120\u0001\u0120\u0001"+
		"\u0120\u0004\u0120\u18cf\b\u0120\u000b\u0120\f\u0120\u18d0\u0001\u0121"+
		"\u0001\u0121\u0001\u0121\u0001\u0121\u0001\u0121\u0003\u0121\u18d8\b\u0121"+
		"\u0003\u0121\u18da\b\u0121\u0001\u0122\u0001\u0122\u0001\u0122\u0004\u0122"+
		"\u18df\b\u0122\u000b\u0122\f\u0122\u18e0\u0003\u0122\u18e3\b\u0122\u0001"+
		"\u0123\u0001\u0123\u0003\u0123\u18e7\b\u0123\u0001\u0124\u0001\u0124\u0001"+
		"\u0124\u0003\u0124\u18ec\b\u0124\u0001\u0125\u0001\u0125\u0001\u0125\u0001"+
		"\u0125\u0001\u0125\u0001\u0125\u0001\u0125\u0001\u0125\u0001\u0125\u0003"+
		"\u0125\u18f7\b\u0125\u0001\u0126\u0001\u0126\u0001\u0126\u0003\u0126\u18fc"+
		"\b\u0126\u0001\u0127\u0001\u0127\u0001\u0128\u0001\u0128\u0003\u0128\u1902"+
		"\b\u0128\u0001\u0129\u0003\u0129\u1905\b\u0129\u0001\u0129\u0001\u0129"+
		"\u0003\u0129\u1909\b\u0129\u0001\u0129\u0004\u0129\u190c\b\u0129\u000b"+
		"\u0129\f\u0129\u190d\u0001\u0129\u0003\u0129\u1911\b\u0129\u0001\u0129"+
		"\u0001\u0129\u0003\u0129\u1915\b\u0129\u0001\u0129\u0001\u0129\u0003\u0129"+
		"\u1919\b\u0129\u0003\u0129\u191b\b\u0129\u0001\u012a\u0001\u012a\u0001"+
		"\u012b\u0003\u012b\u1920\b\u012b\u0001\u012b\u0001\u012b\u0001\u012c\u0003"+
		"\u012c\u1925\b\u012c\u0001\u012c\u0001\u012c\u0001\u012d\u0001\u012d\u0001"+
		"\u012d\u0001\u012d\u0001\u012d\u0001\u012d\u0001\u012d\u0001\u012d\u0001"+
		"\u012d\u0003\u012d\u1932\b\u012d\u0001\u012d\u0003\u012d\u1935\b\u012d"+
		"\u0001\u012e\u0001\u012e\u0003\u012e\u1939\b\u012e\u0001\u012e\u0003\u012e"+
		"\u193c\b\u012e\u0001\u012e\u0003\u012e\u193f\b\u012e\u0001\u012e\u0001"+
		"\u012e\u0001\u012e\u0003\u012e\u1944\b\u012e\u0001\u012e\u0001\u012e\u0001"+
		"\u012e\u0003\u012e\u1949\b\u012e\u0001\u012e\u0001\u012e\u0001\u012e\u0001"+
		"\u012e\u0003\u012e\u194f\b\u012e\u0001\u012e\u0003\u012e\u1952\b\u012e"+
		"\u0001\u012e\u0001\u012e\u0001\u012e\u0003\u012e\u1957\b\u012e\u0001\u012e"+
		"\u0003\u012e\u195a\b\u012e\u0001\u012e\u0001\u012e\u0001\u012e\u0003\u012e"+
		"\u195f\b\u012e\u0001\u012e\u0003\u012e\u1962\b\u012e\u0001\u012e\u0001"+
		"\u012e\u0003\u012e\u1966\b\u012e\u0001\u012e\u0005\u012e\u1969\b\u012e"+
		"\n\u012e\f\u012e\u196c\t\u012e\u0001\u012e\u0001\u012e\u0003\u012e\u1970"+
		"\b\u012e\u0001\u012e\u0005\u012e\u1973\b\u012e\n\u012e\f\u012e\u1976\t"+
		"\u012e\u0001\u012e\u0001\u012e\u0003\u012e\u197a\b\u012e\u0001\u012e\u0003"+
		"\u012e\u197d\b\u012e\u0001\u012e\u0005\u012e\u1980\b\u012e\n\u012e\f\u012e"+
		"\u1983\t\u012e\u0001\u012e\u0001\u012e\u0003\u012e\u1987\b\u012e\u0001"+
		"\u012e\u0005\u012e\u198a\b\u012e\n\u012e\f\u012e\u198d\t\u012e\u0001\u012e"+
		"\u0001\u012e\u0001\u012e\u0003\u012e\u1992\b\u012e\u0001\u012e\u0001\u012e"+
		"\u0001\u012e\u0003\u012e\u1997\b\u012e\u0001\u012e\u0001\u012e\u0001\u012e"+
		"\u0003\u012e\u199c\b\u012e\u0001\u012e\u0001\u012e\u0001\u012e\u0003\u012e"+
		"\u19a1\b\u012e\u0001\u012e\u0001\u012e\u0003\u012e\u19a5\b\u012e\u0001"+
		"\u012e\u0003\u012e\u19a8\b\u012e\u0001\u012e\u0001\u012e\u0001\u012e\u0003"+
		"\u012e\u19ad\b\u012e\u0001\u012e\u0001\u012e\u0003\u012e\u19b1\b\u012e"+
		"\u0001\u012e\u0001\u012e\u0003\u012e\u19b5\b\u012e\u0001\u012f\u0001\u012f"+
		"\u0001\u012f\u0001\u012f\u0005\u012f\u19bb\b\u012f\n\u012f\f\u012f\u19be"+
		"\t\u012f\u0001\u012f\u0001\u012f\u0001\u0130\u0001\u0130\u0003\u0130\u19c4"+
		"\b\u0130\u0001\u0130\u0001\u0130\u0003\u0130\u19c8\b\u0130\u0001\u0130"+
		"\u0001\u0130\u0001\u0130\u0003\u0130\u19cd\b\u0130\u0001\u0130\u0001\u0130"+
		"\u0001\u0130\u0003\u0130\u19d2\b\u0130\u0001\u0130\u0001\u0130\u0003\u0130"+
		"\u19d6\b\u0130\u0003\u0130\u19d8\b\u0130\u0001\u0130\u0003\u0130\u19db"+
		"\b\u0130\u0001\u0131\u0001\u0131\u0001\u0131\u0001\u0131\u0001\u0132\u0001"+
		"\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0001\u0132\u0001\u0133\u0001"+
		"\u0133\u0001\u0133\u0001\u0133\u0003\u0133\u19eb\b\u0133\u0001\u0133\u0001"+
		"\u0133\u0001\u0134\u0001\u0134\u0001\u0134\u0005\u0134\u19f2\b\u0134\n"+
		"\u0134\f\u0134\u19f5\t\u0134\u0001\u0135\u0001\u0135\u0001\u0135\u0005"+
		"\u0135\u19fa\b\u0135\n\u0135\f\u0135\u19fd\t\u0135\u0001\u0136\u0001\u0136"+
		"\u0001\u0136\u0005\u0136\u1a02\b\u0136\n\u0136\f\u0136\u1a05\t\u0136\u0001"+
		"\u0137\u0001\u0137\u0001\u0137\u0001\u0137\u0005\u0137\u1a0b\b\u0137\n"+
		"\u0137\f\u0137\u1a0e\t\u0137\u0001\u0137\u0001\u0137\u0001\u0138\u0001"+
		"\u0138\u0001\u0138\u0005\u0138\u1a15\b\u0138\n\u0138\f\u0138\u1a18\t\u0138"+
		"\u0001\u0139\u0001\u0139\u0001\u0139\u0005\u0139\u1a1d\b\u0139\n\u0139"+
		"\f\u0139\u1a20\t\u0139\u0001\u013a\u0001\u013a\u0001\u013a\u0005\u013a"+
		"\u1a25\b\u013a\n\u013a\f\u013a\u1a28\t\u013a\u0001\u013b\u0001\u013b\u0001"+
		"\u013b\u0005\u013b\u1a2d\b\u013b\n\u013b\f\u013b\u1a30\t\u013b\u0001\u013c"+
		"\u0001\u013c\u0001\u013c\u0005\u013c\u1a35\b\u013c\n\u013c\f\u013c\u1a38"+
		"\t\u013c\u0001\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0001"+
		"\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0003\u013d\u1a43\b\u013d\u0001"+
		"\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0003\u013d\u1a4a"+
		"\b\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0001\u013d\u0001"+
		"\u013d\u0001\u013d\u0001\u013d\u0003\u013d\u1a54\b\u013d\u0001\u013e\u0001"+
		"\u013e\u0001\u013e\u0003\u013e\u1a59\b\u013e\u0001\u013e\u0003\u013e\u1a5c"+
		"\b\u013e\u0001\u013e\u0001\u013e\u0001\u013e\u0003\u013e\u1a61\b\u013e"+
		"\u0001\u013e\u0003\u013e\u1a64\b\u013e\u0001\u013f\u0001\u013f\u0003\u013f"+
		"\u1a68\b\u013f\u0001\u0140\u0001\u0140\u0001\u0140\u0001\u0141\u0001\u0141"+
		"\u0001\u0141\u0001\u0141\u0001\u0142\u0001\u0142\u0001\u0142\u0001\u0143"+
		"\u0001\u0143\u0001\u0143\u0003\u0143\u1a77\b\u0143\u0001\u0144\u0001\u0144"+
		"\u0001\u0144\u0001\u0144\u0001\u0144\u0001\u0144\u0003\u0144\u1a7f\b\u0144"+
		"\u0001\u0144\u0001\u0144\u0001\u0144\u0001\u0144\u0001\u0144\u0003\u0144"+
		"\u1a86\b\u0144\u0001\u0144\u0001\u0144\u0001\u0144\u0003\u0144\u1a8b\b"+
		"\u0144\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1a90\b\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0004"+
		"\u0145\u1ab0\b\u0145\u000b\u0145\f\u0145\u1ab1\u0001\u0145\u0001\u0145"+
		"\u0003\u0145\u1ab6\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145"+
		"\u0004\u0145\u1abc\b\u0145\u000b\u0145\f\u0145\u1abd\u0001\u0145\u0001"+
		"\u0145\u0003\u0145\u1ac2\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1acb\b\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003"+
		"\u0145\u1ad3\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1ad8"+
		"\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0003\u0145\u1ae0\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003"+
		"\u0145\u1ae5\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1aea"+
		"\b\u0145\u0003\u0145\u1aec\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145"+
		"\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1af5\b\u0145"+
		"\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1afa\b\u0145\u0001\u0145"+
		"\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145"+
		"\u1b02\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1b07\b"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0003\u0145\u1b0f\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1b17\b\u0145\u0001\u0145\u0003"+
		"\u0145\u1b1a\b\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1b24\b\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0001"+
		"\u0145\u0001\u0145\u0001\u0145\u0001\u0145\u0003\u0145\u1b36\b\u0145\u0001"+
		"\u0145\u0003\u0145\u1b39\b\u0145\u0001\u0145\u0003\u0145\u1b3c\b\u0145"+
		"\u0001\u0145\u0001\u0145\u0003\u0145\u1b40\b\u0145\u0001\u0146\u0001\u0146"+
		"\u0001\u0146\u0001\u0146\u0001\u0146\u0001\u0147\u0001\u0147\u0001\u0147"+
		"\u0001\u0147\u0005\u0147\u1b4b\b\u0147\n\u0147\f\u0147\u1b4e\t\u0147\u0001"+
		"\u0147\u0001\u0147\u0001\u0147\u0001\u0147\u0001\u0147\u0003\u0147\u1b55"+
		"\b\u0147\u0001\u0148\u0001\u0148\u0003\u0148\u1b59\b\u0148\u0001\u0149"+
		"\u0001\u0149\u0001\u0149\u0003\u0149\u1b5e\b\u0149\u0001\u0149\u0001\u0149"+
		"\u0001\u0149\u0003\u0149\u1b63\b\u0149\u0001\u0149\u0001\u0149\u0001\u0149"+
		"\u0001\u0149\u0003\u0149\u1b69\b\u0149\u0001\u0149\u0001\u0149\u0001\u0149"+
		"\u0003\u0149\u1b6e\b\u0149\u0001\u0149\u0001\u0149\u0003\u0149\u1b72\b"+
		"\u0149\u0001\u0149\u0001\u0149\u0001\u0149\u0003\u0149\u1b77\b\u0149\u0001"+
		"\u0149\u0001\u0149\u0001\u0149\u0003\u0149\u1b7c\b\u0149\u0001\u0149\u0001"+
		"\u0149\u0001\u0149\u0003\u0149\u1b81\b\u0149\u0001\u0149\u0001\u0149\u0001"+
		"\u0149\u0001\u0149\u0001\u0149\u0001\u0149\u0005\u0149\u1b89\b\u0149\n"+
		"\u0149\f\u0149\u1b8c\t\u0149\u0003\u0149\u1b8e\b\u0149\u0001\u0149\u0001"+
		"\u0149\u0003\u0149\u1b92\b\u0149\u0001\u0149\u0001\u0149\u0003\u0149\u1b96"+
		"\b\u0149\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0003"+
		"\u014a\u1b9d\b\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1ba1\b\u014a"+
		"\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a"+
		"\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a"+
		"\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a"+
		"\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a\u0001\u014a"+
		"\u0001\u014a\u0001\u014a\u0001\u014a\u0003\u014a\u1bbe\b\u014a\u0001\u014b"+
		"\u0001\u014b\u0001\u014b\u0001\u014b\u0001\u014b\u0001\u014b\u0003\u014b"+
		"\u1bc6\b\u014b\u0001\u014c\u0003\u014c\u1bc9\b\u014c\u0001\u014c\u0003"+
		"\u014c\u1bcc\b\u014c\u0001\u014c\u0003\u014c\u1bcf\b\u014c\u0001\u014c"+
		"\u0003\u014c\u1bd2\b\u014c\u0001\u014d\u0001\u014d\u0001\u014e\u0001\u014e"+
		"\u0001\u014e\u0001\u014f\u0001\u014f\u0001\u0150\u0001\u0150\u0003\u0150"+
		"\u1bdd\b\u0150\u0001\u0151\u0001\u0151\u0001\u0151\u0001\u0151\u0001\u0151"+
		"\u0001\u0152\u0001\u0152\u0001\u0152\u0001\u0152\u0001\u0152\u0001\u0152"+
		"\u0001\u0152\u0003\u0152\u1beb\b\u0152\u0001\u0153\u0001\u0153\u0001\u0153"+
		"\u0001\u0153\u0001\u0153\u0005\u0153\u1bf2\b\u0153\n\u0153\f\u0153\u1bf5"+
		"\t\u0153\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001"+
		"\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001"+
		"\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001"+
		"\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001\u0154\u0001"+
		"\u0154\u0003\u0154\u1c0f\b\u0154\u0001\u0155\u0001\u0155\u0001\u0155\u0001"+
		"\u0155\u0001\u0155\u0001\u0156\u0001\u0156\u0001\u0156\u0001\u0156\u0003"+
		"\u0156\u1c1a\b\u0156\u0001\u0156\u0001\u0156\u0001\u0156\u0001\u0156\u0001"+
		"\u0156\u0003\u0156\u1c21\b\u0156\u0005\u0156\u1c23\b\u0156\n\u0156\f\u0156"+
		"\u1c26\t\u0156\u0001\u0157\u0001\u0157\u0001\u0157\u0001\u0157\u0003\u0157"+
		"\u1c2c\b\u0157\u0001\u0158\u0001\u0158\u0001\u0158\u0001\u0158\u0001\u0158"+
		"\u0001\u0158\u0003\u0158\u1c34\b\u0158\u0001\u0158\u0001\u0158\u0001\u0158"+
		"\u0003\u0158\u1c39\b\u0158\u0001\u0158\u0001\u0158\u0001\u0158\u0001\u0158"+
		"\u0005\u0158\u1c3f\b\u0158\n\u0158\f\u0158\u1c42\t\u0158\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0003\u0159\u1c4d\b\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0003\u0159\u1c5a\b\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0003\u0159\u1c60\b\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0003\u0159\u1c66\b\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0003\u0159\u1c76\b\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0003\u0159\u1c7c\b\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0001"+
		"\u0159\u0001\u0159\u0001\u0159\u0001\u0159\u0005\u0159\u1c85\b\u0159\n"+
		"\u0159\f\u0159\u1c88\t\u0159\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0005\u015a\u1c9b\b\u015a\n\u015a\f\u015a\u1c9e\t\u015a"+
		"\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a"+
		"\u0001\u015a\u0004\u015a\u1ca7\b\u015a\u000b\u015a\f\u015a\u1ca8\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0003\u015a\u1cba\b\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001"+
		"\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0001\u015a\u0005"+
		"\u015a\u1ccf\b\u015a\n\u015a\f\u015a\u1cd2\t\u015a\u0001\u015b\u0001\u015b"+
		"\u0001\u015c\u0001\u015c\u0001\u015c\u0001\u015c\u0001\u015c\u0001\u015c"+
		"\u0001\u015c\u0001\u015c\u0001\u015c\u0001\u015c\u0001\u015c\u0001\u015c"+
		"\u0001\u015c\u0001\u015c\u0003\u015c\u1ce4\b\u015c\u0001\u015d\u0001\u015d"+
		"\u0001\u015d\u0001\u015d\u0001\u015d\u0001\u015d\u0001\u015d\u0003\u015d"+
		"\u1ced\b\u015d\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e\u0001\u015e"+
		"\u0001\u015e\u0001\u015e\u0003\u015e\u1cf6\b\u015e\u0001\u015f\u0001\u015f"+
		"\u0001\u0160\u0001\u0160\u0001\u0161\u0001\u0161\u0001\u0161\u0001\u0161"+
		"\u0001\u0161\u0003\u0161\u1d01\b\u0161\u0001\u0162\u0001\u0162\u0001\u0163"+
		"\u0001\u0163\u0001\u0164\u0001\u0164\u0001\u0165\u0001\u0165\u0001\u0166"+
		"\u0001\u0166\u0001\u0167\u0001\u0167\u0001\u0168\u0001\u0168\u0001\u0168"+
		"\u0000\u0003\u02b0\u02b2\u02b4\u0169\u0000\u0002\u0004\u0006\b\n\f\u000e"+
		"\u0010\u0012\u0014\u0016\u0018\u001a\u001c\u001e \"$&(*,.02468:<>@BDF"+
		"HJLNPRTVXZ\\^`bdfhjlnprtvxz|~\u0080\u0082\u0084\u0086\u0088\u008a\u008c"+
		"\u008e\u0090\u0092\u0094\u0096\u0098\u009a\u009c\u009e\u00a0\u00a2\u00a4"+
		"\u00a6\u00a8\u00aa\u00ac\u00ae\u00b0\u00b2\u00b4\u00b6\u00b8\u00ba\u00bc"+
		"\u00be\u00c0\u00c2\u00c4\u00c6\u00c8\u00ca\u00cc\u00ce\u00d0\u00d2\u00d4"+
		"\u00d6\u00d8\u00da\u00dc\u00de\u00e0\u00e2\u00e4\u00e6\u00e8\u00ea\u00ec"+
		"\u00ee\u00f0\u00f2\u00f4\u00f6\u00f8\u00fa\u00fc\u00fe\u0100\u0102\u0104"+
		"\u0106\u0108\u010a\u010c\u010e\u0110\u0112\u0114\u0116\u0118\u011a\u011c"+
		"\u011e\u0120\u0122\u0124\u0126\u0128\u012a\u012c\u012e\u0130\u0132\u0134"+
		"\u0136\u0138\u013a\u013c\u013e\u0140\u0142\u0144\u0146\u0148\u014a\u014c"+
		"\u014e\u0150\u0152\u0154\u0156\u0158\u015a\u015c\u015e\u0160\u0162\u0164"+
		"\u0166\u0168\u016a\u016c\u016e\u0170\u0172\u0174\u0176\u0178\u017a\u017c"+
		"\u017e\u0180\u0182\u0184\u0186\u0188\u018a\u018c\u018e\u0190\u0192\u0194"+
		"\u0196\u0198\u019a\u019c\u019e\u01a0\u01a2\u01a4\u01a6\u01a8\u01aa\u01ac"+
		"\u01ae\u01b0\u01b2\u01b4\u01b6\u01b8\u01ba\u01bc\u01be\u01c0\u01c2\u01c4"+
		"\u01c6\u01c8\u01ca\u01cc\u01ce\u01d0\u01d2\u01d4\u01d6\u01d8\u01da\u01dc"+
		"\u01de\u01e0\u01e2\u01e4\u01e6\u01e8\u01ea\u01ec\u01ee\u01f0\u01f2\u01f4"+
		"\u01f6\u01f8\u01fa\u01fc\u01fe\u0200\u0202\u0204\u0206\u0208\u020a\u020c"+
		"\u020e\u0210\u0212\u0214\u0216\u0218\u021a\u021c\u021e\u0220\u0222\u0224"+
		"\u0226\u0228\u022a\u022c\u022e\u0230\u0232\u0234\u0236\u0238\u023a\u023c"+
		"\u023e\u0240\u0242\u0244\u0246\u0248\u024a\u024c\u024e\u0250\u0252\u0254"+
		"\u0256\u0258\u025a\u025c\u025e\u0260\u0262\u0264\u0266\u0268\u026a\u026c"+
		"\u026e\u0270\u0272\u0274\u0276\u0278\u027a\u027c\u027e\u0280\u0282\u0284"+
		"\u0286\u0288\u028a\u028c\u028e\u0290\u0292\u0294\u0296\u0298\u029a\u029c"+
		"\u029e\u02a0\u02a2\u02a4\u02a6\u02a8\u02aa\u02ac\u02ae\u02b0\u02b2\u02b4"+
		"\u02b6\u02b8\u02ba\u02bc\u02be\u02c0\u02c2\u02c4\u02c6\u02c8\u02ca\u02cc"+
		"\u02ce\u02d0\u0000\u0090\u0002\u0000\'\'\u0096\u0096\u0002\u0000\u0213"+
		"\u0213\u0219\u0219\u0003\u0000EE\u009f\u009f\u00b5\u00b5\u0003\u0000*"+
		"*\u0180\u0180\u01c6\u01c6\u0004\u0000**\u01a3\u01a3\u0211\u0211\u0263"+
		"\u0263\u0002\u0000\u0202\u0202\u047c\u047c\u0002\u0000NN\u008d\u008d\u0002"+
		"\u0000\u000f\u000f\u014e\u014e\u0003\u0000,,UU\u00b8\u00b8\u0002\u0000"+
		"\u01b2\u01b2\u022e\u022e\u0003\u0000\u01fa\u01fa\u028a\u028a\u0292\u0292"+
		"\u0002\u0000\u0188\u0188\u01cc\u01cc\u0002\u0000\u0160\u0160\u01da\u01da"+
		"\u0002\u0000**\u0472\u0473\u0002\u0000\u015e\u015e\u01bb\u01bb\u0002\u0000"+
		"\u01cb\u01cb\u02a1\u02a1\u0003\u0000PPTT}}\u0003\u0000**\u0192\u0192\u01af"+
		"\u01af\u0003\u0000**\u018e\u018e\u0318\u0318\u0002\u0000\u027d\u027d\u02a0"+
		"\u02a0\u0002\u0000QQ[[\u0003\u0000\u01b4\u01b4\u0224\u0224\u0265\u0265"+
		"\u0002\u0000EE\u009f\u009f\u0001\u0000\u0164\u0165\u0001\u0000\u0472\u0473"+
		"\u0002\u0000\u047c\u047c\u0484\u0484\u0002\u0000QQ\u0184\u0184\u0002\u0000"+
		"\u0221\u0221\u047c\u047c\u0002\u0000\u0222\u0222\u047c\u047c\u0003\u0000"+
		"\u01ae\u01ae\u01d5\u01d5\u0209\u0209\u0007\u0000**\u0172\u0172\u0174\u0174"+
		"\u0192\u0192\u01af\u01af\u023d\u023d\u0484\u0484\u0002\u0000\u0202\u0202"+
		"\u0212\u0212\u0001\u0000\u0473\u0474\u0002\u0000\u0005\u000533\u0004\u0000"+
		"**\u0180\u0180\u01c6\u01c6\u01ca\u01ca\u0002\u0000\u001a\u001a\u001e\u001e"+
		"\u0002\u0000\f\f\u00af\u00af\u0002\u0000\u00c0\u00c0\u02a5\u02a5\u0002"+
		"\u0000\u0015\u0015\u0090\u0090\u0003\u0000++KKjj\u0002\u0000jj\u0176\u0176"+
		"\u0002\u0000\u016d\u016d\u01ab\u01ab\u0002\u0000ee\u0259\u0259\u0002\u0000"+
		"++jj\u0002\u0000\u0006\u000611\u0002\u0000\u00bc\u00bc\u029d\u029d\u0004"+
		"\u0000\u01ae\u01ae\u01d5\u01d5\u0208\u0208\u0232\u0232\u0002\u0000\u01ae"+
		"\u01ae\u0208\u0208\u0002\u0000\r\r--\u0003\u0000BBNN\u00ba\u00ba\u0002"+
		"\u0000\"\"SS\u0002\u0000aa\u0094\u0094\u0002\u0000\u0006\u000612\u0001"+
		"\u0000\u0272\u0273\u0002\u0000\u00ac\u00ac\u02e6\u02e6\u0002\u0000\u01b7"+
		"\u01b7\u0261\u0261\u0002\u0000\u00e2\u00e2\u01dd\u01dd\u0005\u0000kk\u01e2"+
		"\u01e3\u01e5\u01e5\u01e9\u01f1\u023f\u023f\u0004\u0000\u01df\u01e0\u01e4"+
		"\u01e4\u01e6\u01e7\u0240\u0240\u0003\u0000ll\u01de\u01de\u01e8\u01e8\u0002"+
		"\u0000\u01ce\u01ce\u0274\u0274\u0002\u0000\u026e\u026e\u0270\u0270\u0002"+
		"\u0000\u0158\u0158\u0275\u0275\u0002\u0000ZZ\u024f\u024f\u0002\u00003"+
		"3\u0186\u0186\u0003\u0000\u001f\u001f==\u00b3\u00b3\u0003\u0000\u0083"+
		"\u0083\u00ac\u00ac\u01b5\u01b5\u0003\u0000\f\f\u0013\u0013\u00bb\u00bb"+
		"\u0002\u0000**yy\u0002\u0000gg\u00b6\u00b6\u0002\u0000\u0168\u0168\u0266"+
		"\u0266\u0002\u0000((\u029f\u029f\u0002\u0000ss\u01da\u01da\u0002\u0000"+
		"\u01a6\u01a6\u0238\u0238\u0004\u0000\u00ce\u00ce\u00d0\u00d0\u00d6\u00d6"+
		"\u027e\u027e\u0002\u0000\u0454\u0454\u0464\u0464\u0002\u0000\u0159\u0159"+
		"\u0241\u0241\u0002\u0000DDPP\u0006\u0000\u0083\u0083\u00ac\u00ac\u00b1"+
		"\u00b1\u019f\u019f\u01b5\u01b5\u029f\u029f\u0002\u0000\u0201\u0201\u027a"+
		"\u027a\u0002\u0000\u019c\u019c\u02a3\u02a3\u0002\u0000\u0083\u0083\u01b5"+
		"\u01b5\u0003\u0000QQ\\\\\u01c4\u01c4\u0003\u0000\u01b7\u01b7\u01da\u01da"+
		"\u0261\u0261\u0002\u0000\u027a\u027a\u029e\u029e\u0002\u0000\u0178\u0178"+
		"\u0237\u0237\u0006\u0000\u00e2\u00e2\u0199\u0199\u019b\u019b\u01b6\u01b6"+
		"\u023e\u023e\u0267\u0267\u0002\u0000-.>>\u0003\u0000\u01a6\u01a6\u0226"+
		"\u0226\u0375\u0375\u0002\u0000\u01d2\u01d2\u028c\u028c\n\u0000\u0167\u0167"+
		"\u016f\u016f\u017a\u017c\u0183\u0183\u01fb\u01fb\u0203\u0203\u027f\u027f"+
		"\u0286\u0286\u0344\u0344\u03ed\u03ed\u0002\u0000##\u00a8\u00a8\u0002\u0000"+
		"uu\u03e4\u03e4\u000b\u0000\u0167\u0167\u016f\u016f\u017a\u017c\u0183\u0183"+
		"\u01fb\u01fb\u0203\u0203\u0250\u0250\u027f\u027f\u0286\u0286\u0344\u0344"+
		"\u03ed\u03ed\u0002\u0000\u0471\u0471\u0486\u0487\u0001\u0000\u0487\u0488"+
		"\u0002\u0000\u0177\u0177\u0313\u031e\u0003\u0000\u0472\u0474\u047d\u047d"+
		"\u047f\u047f\u0002\u0000??\u00b2\u00b2\u0002\u0000tt\u0480\u0480\u0005"+
		"\u0000\u0019\u0019\u00de\u00e0\u00e7\u00e7\u00e9\u00ec\u0206\u0206\u0002"+
		"\u0000\u0019\u0019\u00de\u00de\u0002\u0000\u0019\u0019\u00de\u00df\u0001"+
		"\u0000\u00c4\u00cf\u0003\u0000\u00b7\u00b7\u00c3\u00c3\u0264\u0264\u0002"+
		"\u0000\u00d3\u00d8\u01af\u01af\u0006\u0000\u00d9\u00d9\u00e4\u00e4\u00e6"+
		"\u00e6\u00e8\u00e8\u00ef\u00ef\u015c\u015d\u0004\u0000\u00da\u00dd\u00e2"+
		"\u00e3\u00e5\u00e5\u015a\u015a\u0002\u0000\u0099\u0099\u00ed\u00ed\u0002"+
		"\u0000\u01d2\u01d2\u0323\u032b\u0003\u0000\u00d3\u00d3\u00e2\u00e2\u0206"+
		"\u0206\u0006\u0000\u00c8\u00c8\u00ce\u00ce\u00d1\u00d1\u00d9\u00da\u00dc"+
		"\u00dd\u01d2\u01d2\u0001\u0000\u00d6\u00d7\u0002\u0000\u00b7\u00b7\u0264"+
		"\u0264\u0002\u0000\u00c8\u00c8\u00ce\u00ce\u0002\u0000\u013b\u013c\u0142"+
		"\u0142\u0003\u0000\u0096\u0096\u0139\u013c\u014b\u014b\u0001\u0000\u0145"+
		"\u0146\u0003\u0000\u0011\u0011__\u00b0\u00b0\u0002\u0000\u00de\u00de\u00e2"+
		"\u00e2\u0002\u0000\u00d9\u00da\u00dc\u00dc\u0003\u0000\r\r--\u03e2\u03e2"+
		"\u0003\u0000\u011e\u011e\u012a\u012b\u0135\u0135\u0003\u0000\u011f\u0121"+
		"\u0131\u0134\u0136\u0138\u0002\u0000\u0127\u0127\u0129\u0129\u0002\u0000"+
		"\u0125\u0125\u0128\u0128\u0002\u0000\u0123\u0124\u012e\u0130\u0002\u0000"+
		"\u0085\u0085\u0259\u0259\u0002\u0000\u01b1\u01b1\u022f\u022f\u0002\u0000"+
		"\u0217\u0217\u0227\u0227\u0002\u0000rr\u0467\u0467\u0003\u0000??\u00b2"+
		"\u00b2\u0296\u0296\u0002\u0000\u0089\u0089\u0095\u0095\u0003\u0000\u0006"+
		"\u0006\u0151\u0151\u026a\u026a\u0003\u0000rr\u0460\u0461\u0467\u0468\u0002"+
		"\u0000\u045d\u045f\u0462\u0463\u0001\u0000\u0460\u0461\u0002\u0000\u00e2"+
		"\u00e2\u02ea\u0312\u0001\u0000\u031f\u0322\u0005\u0000\u02c4\u02c5\u02d5"+
		"\u02d7\u02dd\u02dd\u02e3\u02e4\u02e6\u02e6\u0001\u0000\u02b1\u02b8\u0003"+
		"\u0000\u00d9\u00dd\u00ea\u00ea\u00ed\u00ed;\u0000\u000b\u000b\u000e\u000e"+
		"\u0012\u0012\u001d\u001d##%%**007799;;IIOO^^uuyy||\u0082\u0082\u009e\u009e"+
		"\u00a8\u00a8\u00ef\u00ef\u011b\u0122\u0126\u0126\u012a\u012b\u0131\u0138"+
		"\u014c\u0181\u0183\u0193\u0195\u0195\u0197\u01b0\u01b2\u01c2\u01c4\u01ca"+
		"\u01cc\u0209\u020b\u020b\u020f\u0220\u0223\u022e\u0230\u024d\u024f\u0250"+
		"\u0252\u025e\u0260\u027c\u027e\u02a0\u02a2\u02a3\u02a5\u02aa\u02ac\u02b0"+
		"\u02b9\u02b9\u02bb\u02c3\u02c6\u02c8\u02cd\u02ce\u02d0\u02d4\u02d8\u02dc"+
		"\u02de\u02de\u02e0\u02e2\u02e5\u02e5\u02e7\u02e9\u0318\u0318\u0344\u0344"+
		"\u036b\u036b\u03e8\u03e8\u03ed\u03ed\u0440\u0440\u0017\u0000\'\'aa\u0094"+
		"\u0094\u0096\u0096\u00d9\u00db\u00dd\u00dd\u00fb\u011a\u0122\u0125\u0127"+
		"\u0129\u012c\u0130\u0144\u0144\u01cb\u01cb\u02a1\u02a1\u02b1\u02b8\u02e0"+
		"\u02e0\u0323\u0323\u0326\u0343\u0345\u036a\u036c\u03e7\u03e9\u03ec\u03ee"+
		"\u043f\u0441\u0453\u0463\u0463\u2237\u0000\u02d3\u0001\u0000\u0000\u0000"+
		"\u0002\u02e6\u0001\u0000\u0000\u0000\u0004\u02fb\u0001\u0000\u0000\u0000"+
		"\u0006\u02fd\u0001\u0000\u0000\u0000\b\u0325\u0001\u0000\u0000\u0000\n"+
		"\u0334\u0001\u0000\u0000\u0000\f\u033f\u0001\u0000\u0000\u0000\u000e\u0350"+
		"\u0001\u0000\u0000\u0000\u0010\u0355\u0001\u0000\u0000\u0000\u0012\u0361"+
		"\u0001\u0000\u0000\u0000\u0014\u037c\u0001\u0000\u0000\u0000\u0016\u0385"+
		"\u0001\u0000\u0000\u0000\u0018\u0387\u0001\u0000\u0000\u0000\u001a\u0393"+
		"\u0001\u0000\u0000\u0000\u001c\u03b1\u0001\u0000\u0000\u0000\u001e\u03d5"+
		"\u0001\u0000\u0000\u0000 \u0408\u0001\u0000\u0000\u0000\"\u0422\u0001"+
		"\u0000\u0000\u0000$\u0446\u0001\u0000\u0000\u0000&\u0453\u0001\u0000\u0000"+
		"\u0000(\u04b4\u0001\u0000\u0000\u0000*\u04b6\u0001\u0000\u0000\u0000,"+
		"\u04c8\u0001\u0000\u0000\u0000.\u0505\u0001\u0000\u0000\u00000\u0518\u0001"+
		"\u0000\u0000\u00002\u051e\u0001\u0000\u0000\u00004\u0534\u0001\u0000\u0000"+
		"\u00006\u0536\u0001\u0000\u0000\u00008\u0538\u0001\u0000\u0000\u0000:"+
		"\u0588\u0001\u0000\u0000\u0000<\u058f\u0001\u0000\u0000\u0000>\u0591\u0001"+
		"\u0000\u0000\u0000@\u0596\u0001\u0000\u0000\u0000B\u05be\u0001\u0000\u0000"+
		"\u0000D\u05c4\u0001\u0000\u0000\u0000F\u05c6\u0001\u0000\u0000\u0000H"+
		"\u05db\u0001\u0000\u0000\u0000J\u05e2\u0001\u0000\u0000\u0000L\u05e4\u0001"+
		"\u0000\u0000\u0000N\u05fd\u0001\u0000\u0000\u0000P\u0600\u0001\u0000\u0000"+
		"\u0000R\u0605\u0001\u0000\u0000\u0000T\u061f\u0001\u0000\u0000\u0000V"+
		"\u062f\u0001\u0000\u0000\u0000X\u0631\u0001\u0000\u0000\u0000Z\u0647\u0001"+
		"\u0000\u0000\u0000\\\u0649\u0001\u0000\u0000\u0000^\u068b\u0001\u0000"+
		"\u0000\u0000`\u06d2\u0001\u0000\u0000\u0000b\u06d4\u0001\u0000\u0000\u0000"+
		"d\u06f0\u0001\u0000\u0000\u0000f\u06fa\u0001\u0000\u0000\u0000h\u0718"+
		"\u0001\u0000\u0000\u0000j\u07d3\u0001\u0000\u0000\u0000l\u07d5\u0001\u0000"+
		"\u0000\u0000n\u07d7\u0001\u0000\u0000\u0000p\u07da\u0001\u0000\u0000\u0000"+
		"r\u0825\u0001\u0000\u0000\u0000t\u083c\u0001\u0000\u0000\u0000v\u08d0"+
		"\u0001\u0000\u0000\u0000x\u08d5\u0001\u0000\u0000\u0000z\u08d7\u0001\u0000"+
		"\u0000\u0000|\u08e1\u0001\u0000\u0000\u0000~\u0919\u0001\u0000\u0000\u0000"+
		"\u0080\u092d\u0001\u0000\u0000\u0000\u0082\u092f\u0001\u0000\u0000\u0000"+
		"\u0084\u0952\u0001\u0000\u0000\u0000\u0086\u095b\u0001\u0000\u0000\u0000"+
		"\u0088\u0962\u0001\u0000\u0000\u0000\u008a\u0979\u0001\u0000\u0000\u0000"+
		"\u008c\u0982\u0001\u0000\u0000\u0000\u008e\u0991\u0001\u0000\u0000\u0000"+
		"\u0090\u09aa\u0001\u0000\u0000\u0000\u0092\u09be\u0001\u0000\u0000\u0000"+
		"\u0094\u0b3d\u0001\u0000\u0000\u0000\u0096\u0ba1\u0001\u0000\u0000\u0000"+
		"\u0098\u0ba3\u0001\u0000\u0000\u0000\u009a\u0baa\u0001\u0000\u0000\u0000"+
		"\u009c\u0bb1\u0001\u0000\u0000\u0000\u009e\u0bc8\u0001\u0000\u0000\u0000"+
		"\u00a0\u0bd0\u0001\u0000\u0000\u0000\u00a2\u0bd7\u0001\u0000\u0000\u0000"+
		"\u00a4\u0bde\u0001\u0000\u0000\u0000\u00a6\u0be5\u0001\u0000\u0000\u0000"+
		"\u00a8\u0bf1\u0001\u0000\u0000\u0000\u00aa\u0bfb\u0001\u0000\u0000\u0000"+
		"\u00ac\u0c02\u0001\u0000\u0000\u0000\u00ae\u0c12\u0001\u0000\u0000\u0000"+
		"\u00b0\u0c40\u0001\u0000\u0000\u0000\u00b2\u0c42\u0001\u0000\u0000\u0000"+
		"\u00b4\u0c4c\u0001\u0000\u0000\u0000\u00b6\u0c50\u0001\u0000\u0000\u0000"+
		"\u00b8\u0c56\u0001\u0000\u0000\u0000\u00ba\u0c62\u0001\u0000\u0000\u0000"+
		"\u00bc\u0c64\u0001\u0000\u0000\u0000\u00be\u0c6b\u0001\u0000\u0000\u0000"+
		"\u00c0\u0c6d\u0001\u0000\u0000\u0000\u00c2\u0ca7\u0001\u0000\u0000\u0000"+
		"\u00c4\u0cf1\u0001\u0000\u0000\u0000\u00c6\u0d2c\u0001\u0000\u0000\u0000"+
		"\u00c8\u0d8e\u0001\u0000\u0000\u0000\u00ca\u0d92\u0001\u0000\u0000\u0000"+
		"\u00cc\u0d94\u0001\u0000\u0000\u0000\u00ce\u0db7\u0001\u0000\u0000\u0000"+
		"\u00d0\u0db9\u0001\u0000\u0000\u0000\u00d2\u0dc1\u0001\u0000\u0000\u0000"+
		"\u00d4\u0dc9\u0001\u0000\u0000\u0000\u00d6\u0dcb\u0001\u0000\u0000\u0000"+
		"\u00d8\u0def\u0001\u0000\u0000\u0000\u00da\u0e26\u0001\u0000\u0000\u0000"+
		"\u00dc\u0e2f\u0001\u0000\u0000\u0000\u00de\u0e43\u0001\u0000\u0000\u0000"+
		"\u00e0\u0e4f\u0001\u0000\u0000\u0000\u00e2\u0e53\u0001\u0000\u0000\u0000"+
		"\u00e4\u0e74\u0001\u0000\u0000\u0000\u00e6\u0e89\u0001\u0000\u0000\u0000"+
		"\u00e8\u0e93\u0001\u0000\u0000\u0000\u00ea\u0e97\u0001\u0000\u0000\u0000"+
		"\u00ec\u0eb1\u0001\u0000\u0000\u0000\u00ee\u0edb\u0001\u0000\u0000\u0000"+
		"\u00f0\u0edd\u0001\u0000\u0000\u0000\u00f2\u0eec\u0001\u0000\u0000\u0000"+
		"\u00f4\u0f1d\u0001\u0000\u0000\u0000\u00f6\u0f26\u0001\u0000\u0000\u0000"+
		"\u00f8\u0f30\u0001\u0000\u0000\u0000\u00fa\u0f3a\u0001\u0000\u0000\u0000"+
		"\u00fc\u0f72\u0001\u0000\u0000\u0000\u00fe\u0f74\u0001\u0000\u0000\u0000"+
		"\u0100\u0f8c\u0001\u0000\u0000\u0000\u0102\u0f92\u0001\u0000\u0000\u0000"+
		"\u0104\u0f9a\u0001\u0000\u0000\u0000\u0106\u0fab\u0001\u0000\u0000\u0000"+
		"\u0108\u0fbb\u0001\u0000\u0000\u0000\u010a\u0fe0\u0001\u0000\u0000\u0000"+
		"\u010c\u0fe6\u0001\u0000\u0000\u0000\u010e\u0fef\u0001\u0000\u0000\u0000"+
		"\u0110\u0ffc\u0001\u0000\u0000\u0000\u0112\u1000\u0001\u0000\u0000\u0000"+
		"\u0114\u1026\u0001\u0000\u0000\u0000\u0116\u104c\u0001\u0000\u0000\u0000"+
		"\u0118\u105a\u0001\u0000\u0000\u0000\u011a\u1062\u0001\u0000\u0000\u0000"+
		"\u011c\u1066\u0001\u0000\u0000\u0000\u011e\u106c\u0001\u0000\u0000\u0000"+
		"\u0120\u107a\u0001\u0000\u0000\u0000\u0122\u107d\u0001\u0000\u0000\u0000"+
		"\u0124\u108f\u0001\u0000\u0000\u0000\u0126\u1093\u0001\u0000\u0000\u0000"+
		"\u0128\u10a3\u0001\u0000\u0000\u0000\u012a\u10a5\u0001\u0000\u0000\u0000"+
		"\u012c\u10b1\u0001\u0000\u0000\u0000\u012e\u10b5\u0001\u0000\u0000\u0000"+
		"\u0130\u10c6\u0001\u0000\u0000\u0000\u0132\u10d7\u0001\u0000\u0000\u0000"+
		"\u0134\u10da\u0001\u0000\u0000\u0000\u0136\u10e4\u0001\u0000\u0000\u0000"+
		"\u0138\u10e8\u0001\u0000\u0000\u0000\u013a\u10f5\u0001\u0000\u0000\u0000"+
		"\u013c\u10f8\u0001\u0000\u0000\u0000\u013e\u10fd\u0001\u0000\u0000\u0000"+
		"\u0140\u1111\u0001\u0000\u0000\u0000\u0142\u1113\u0001\u0000\u0000\u0000"+
		"\u0144\u1124\u0001\u0000\u0000\u0000\u0146\u112d\u0001\u0000\u0000\u0000"+
		"\u0148\u1136\u0001\u0000\u0000\u0000\u014a\u1138\u0001\u0000\u0000\u0000"+
		"\u014c\u1146\u0001\u0000\u0000\u0000\u014e\u1151\u0001\u0000\u0000\u0000"+
		"\u0150\u115a\u0001\u0000\u0000\u0000\u0152\u115d\u0001\u0000\u0000\u0000"+
		"\u0154\u1165\u0001\u0000\u0000\u0000\u0156\u117e\u0001\u0000\u0000\u0000"+
		"\u0158\u118a\u0001\u0000\u0000\u0000\u015a\u118d\u0001\u0000\u0000\u0000"+
		"\u015c\u11ad\u0001\u0000\u0000\u0000\u015e\u11af\u0001\u0000\u0000\u0000"+
		"\u0160\u11b1\u0001\u0000\u0000\u0000\u0162\u11b3\u0001\u0000\u0000\u0000"+
		"\u0164\u11b5\u0001\u0000\u0000\u0000\u0166\u11ea\u0001\u0000\u0000\u0000"+
		"\u0168\u11ec\u0001\u0000\u0000\u0000\u016a\u11f2\u0001\u0000\u0000\u0000"+
		"\u016c\u1206\u0001\u0000\u0000\u0000\u016e\u1214\u0001\u0000\u0000\u0000"+
		"\u0170\u121f\u0001\u0000\u0000\u0000\u0172\u1221\u0001\u0000\u0000\u0000"+
		"\u0174\u1227\u0001\u0000\u0000\u0000\u0176\u1231\u0001\u0000\u0000\u0000"+
		"\u0178\u1235\u0001\u0000\u0000\u0000\u017a\u123c\u0001\u0000\u0000\u0000"+
		"\u017c\u1240\u0001\u0000\u0000\u0000\u017e\u1246\u0001\u0000\u0000\u0000"+
		"\u0180\u124d\u0001\u0000\u0000\u0000\u0182\u1253\u0001\u0000\u0000\u0000"+
		"\u0184\u1259\u0001\u0000\u0000\u0000\u0186\u125e\u0001\u0000\u0000\u0000"+
		"\u0188\u128b\u0001\u0000\u0000\u0000\u018a\u12a0\u0001\u0000\u0000\u0000"+
		"\u018c\u12b9\u0001\u0000\u0000\u0000\u018e\u12bc\u0001\u0000\u0000\u0000"+
		"\u0190\u12c2\u0001\u0000\u0000\u0000\u0192\u12d2\u0001\u0000\u0000\u0000"+
		"\u0194\u12e1\u0001\u0000\u0000\u0000\u0196\u12e7\u0001\u0000\u0000\u0000"+
		"\u0198\u1305\u0001\u0000\u0000\u0000\u019a\u1307\u0001\u0000\u0000\u0000"+
		"\u019c\u130e\u0001\u0000\u0000\u0000\u019e\u131a\u0001\u0000\u0000\u0000"+
		"\u01a0\u1320\u0001\u0000\u0000\u0000\u01a2\u1339\u0001\u0000\u0000\u0000"+
		"\u01a4\u133d\u0001\u0000\u0000\u0000\u01a6\u1341\u0001\u0000\u0000\u0000"+
		"\u01a8\u134c\u0001\u0000\u0000\u0000\u01aa\u139d\u0001\u0000\u0000\u0000"+
		"\u01ac\u13e0\u0001\u0000\u0000\u0000\u01ae\u13e2\u0001\u0000\u0000\u0000"+
		"\u01b0\u144c\u0001\u0000\u0000\u0000\u01b2\u1464\u0001\u0000\u0000\u0000"+
		"\u01b4\u1466\u0001\u0000\u0000\u0000\u01b6\u1478\u0001\u0000\u0000\u0000"+
		"\u01b8\u14c8\u0001\u0000\u0000\u0000\u01ba\u14ca\u0001\u0000\u0000\u0000"+
		"\u01bc\u14d7\u0001\u0000\u0000\u0000\u01be\u14e2\u0001\u0000\u0000\u0000"+
		"\u01c0\u14fe\u0001\u0000\u0000\u0000\u01c2\u1502\u0001\u0000\u0000\u0000"+
		"\u01c4\u1517\u0001\u0000\u0000\u0000\u01c6\u1521\u0001\u0000\u0000\u0000"+
		"\u01c8\u152b\u0001\u0000\u0000\u0000\u01ca\u1553\u0001\u0000\u0000\u0000"+
		"\u01cc\u1555\u0001\u0000\u0000\u0000\u01ce\u1558\u0001\u0000\u0000\u0000"+
		"\u01d0\u15bc\u0001\u0000\u0000\u0000\u01d2\u15ce\u0001\u0000\u0000\u0000"+
		"\u01d4\u15d0\u0001\u0000\u0000\u0000\u01d6\u15d4\u0001\u0000\u0000\u0000"+
		"\u01d8\u15fa\u0001\u0000\u0000\u0000\u01da\u1603\u0001\u0000\u0000\u0000"+
		"\u01dc\u1609\u0001\u0000\u0000\u0000\u01de\u1610\u0001\u0000\u0000\u0000"+
		"\u01e0\u1626\u0001\u0000\u0000\u0000\u01e2\u1628\u0001\u0000\u0000\u0000"+
		"\u01e4\u1636\u0001\u0000\u0000\u0000\u01e6\u163c\u0001\u0000\u0000\u0000"+
		"\u01e8\u1674\u0001\u0000\u0000\u0000\u01ea\u170f\u0001\u0000\u0000\u0000"+
		"\u01ec\u171b\u0001\u0000\u0000\u0000\u01ee\u172a\u0001\u0000\u0000\u0000"+
		"\u01f0\u1730\u0001\u0000\u0000\u0000\u01f2\u1743\u0001\u0000\u0000\u0000"+
		"\u01f4\u174d\u0001\u0000\u0000\u0000\u01f6\u175b\u0001\u0000\u0000\u0000"+
		"\u01f8\u175d\u0001\u0000\u0000\u0000\u01fa\u1760\u0001\u0000\u0000\u0000"+
		"\u01fc\u1776\u0001\u0000\u0000\u0000\u01fe\u1782\u0001\u0000\u0000\u0000"+
		"\u0200\u1788\u0001\u0000\u0000\u0000\u0202\u1794\u0001\u0000\u0000\u0000"+
		"\u0204\u1798\u0001\u0000\u0000\u0000\u0206\u179a\u0001\u0000\u0000\u0000"+
		"\u0208\u17c4\u0001\u0000\u0000\u0000\u020a\u17cb\u0001\u0000\u0000\u0000"+
		"\u020c\u17cd\u0001\u0000\u0000\u0000\u020e\u17e4\u0001\u0000\u0000\u0000"+
		"\u0210\u17ea\u0001\u0000\u0000\u0000\u0212\u17f2\u0001\u0000\u0000\u0000"+
		"\u0214\u17f5\u0001\u0000\u0000\u0000\u0216\u17f8\u0001\u0000\u0000\u0000"+
		"\u0218\u180d\u0001\u0000\u0000\u0000\u021a\u1822\u0001\u0000\u0000\u0000"+
		"\u021c\u182a\u0001\u0000\u0000\u0000\u021e\u1836\u0001\u0000\u0000\u0000"+
		"\u0220\u183e\u0001\u0000\u0000\u0000\u0222\u1864\u0001\u0000\u0000\u0000"+
		"\u0224\u1870\u0001\u0000\u0000\u0000\u0226\u1872\u0001\u0000\u0000\u0000"+
		"\u0228\u1878\u0001\u0000\u0000\u0000\u022a\u187c\u0001\u0000\u0000\u0000"+
		"\u022c\u188c\u0001\u0000\u0000\u0000\u022e\u1899\u0001\u0000\u0000\u0000"+
		"\u0230\u18a2\u0001\u0000\u0000\u0000\u0232\u18a4\u0001\u0000\u0000\u0000"+
		"\u0234\u18ab\u0001\u0000\u0000\u0000\u0236\u18ad\u0001\u0000\u0000\u0000"+
		"\u0238\u18b3\u0001\u0000\u0000\u0000\u023a\u18b7\u0001\u0000\u0000\u0000"+
		"\u023c\u18bc\u0001\u0000\u0000\u0000\u023e\u18be\u0001\u0000\u0000\u0000"+
		"\u0240\u18c0\u0001\u0000\u0000\u0000\u0242\u18d2\u0001\u0000\u0000\u0000"+
		"\u0244\u18e2\u0001\u0000\u0000\u0000\u0246\u18e6\u0001\u0000\u0000\u0000"+
		"\u0248\u18eb\u0001\u0000\u0000\u0000\u024a\u18f6\u0001\u0000\u0000\u0000"+
		"\u024c\u18fb\u0001\u0000\u0000\u0000\u024e\u18fd\u0001\u0000\u0000\u0000"+
		"\u0250\u1901\u0001\u0000\u0000\u0000\u0252\u191a\u0001\u0000\u0000\u0000"+
		"\u0254\u191c\u0001\u0000\u0000\u0000\u0256\u191f\u0001\u0000\u0000\u0000"+
		"\u0258\u1924\u0001\u0000\u0000\u0000\u025a\u1934\u0001\u0000\u0000\u0000"+
		"\u025c\u19b4\u0001\u0000\u0000\u0000\u025e\u19b6\u0001\u0000\u0000\u0000"+
		"\u0260\u19d7\u0001\u0000\u0000\u0000\u0262\u19dc\u0001\u0000\u0000\u0000"+
		"\u0264\u19e0\u0001\u0000\u0000\u0000\u0266\u19e6\u0001\u0000\u0000\u0000"+
		"\u0268\u19ee\u0001\u0000\u0000\u0000\u026a\u19f6\u0001\u0000\u0000\u0000"+
		"\u026c\u19fe\u0001\u0000\u0000\u0000\u026e\u1a06\u0001\u0000\u0000\u0000"+
		"\u0270\u1a11\u0001\u0000\u0000\u0000\u0272\u1a19\u0001\u0000\u0000\u0000"+
		"\u0274\u1a21\u0001\u0000\u0000\u0000\u0276\u1a29\u0001\u0000\u0000\u0000"+
		"\u0278\u1a31\u0001\u0000\u0000\u0000\u027a\u1a53\u0001\u0000\u0000\u0000"+
		"\u027c\u1a63\u0001\u0000\u0000\u0000\u027e\u1a67\u0001\u0000\u0000\u0000"+
		"\u0280\u1a69\u0001\u0000\u0000\u0000\u0282\u1a6c\u0001\u0000\u0000\u0000"+
		"\u0284\u1a70\u0001\u0000\u0000\u0000\u0286\u1a76\u0001\u0000\u0000\u0000"+
		"\u0288\u1a8a\u0001\u0000\u0000\u0000\u028a\u1b3f\u0001\u0000\u0000\u0000"+
		"\u028c\u1b41\u0001\u0000\u0000\u0000\u028e\u1b54\u0001\u0000\u0000\u0000"+
		"\u0290\u1b56\u0001\u0000\u0000\u0000\u0292\u1b95\u0001\u0000\u0000\u0000"+
		"\u0294\u1bbd\u0001\u0000\u0000\u0000\u0296\u1bbf\u0001\u0000\u0000\u0000"+
		"\u0298\u1bc8\u0001\u0000\u0000\u0000\u029a\u1bd3\u0001\u0000\u0000\u0000"+
		"\u029c\u1bd5\u0001\u0000\u0000\u0000\u029e\u1bd8\u0001\u0000\u0000\u0000"+
		"\u02a0\u1bdc\u0001\u0000\u0000\u0000\u02a2\u1bde\u0001\u0000\u0000\u0000"+
		"\u02a4\u1bea\u0001\u0000\u0000\u0000\u02a6\u1bec\u0001\u0000\u0000\u0000"+
		"\u02a8\u1c0e\u0001\u0000\u0000\u0000\u02aa\u1c10\u0001\u0000\u0000\u0000"+
		"\u02ac\u1c19\u0001\u0000\u0000\u0000\u02ae\u1c2b\u0001\u0000\u0000\u0000"+
		"\u02b0\u1c38\u0001\u0000\u0000\u0000\u02b2\u1c43\u0001\u0000\u0000\u0000"+
		"\u02b4\u1cb9\u0001\u0000\u0000\u0000\u02b6\u1cd3\u0001\u0000\u0000\u0000"+
		"\u02b8\u1ce3\u0001\u0000\u0000\u0000\u02ba\u1cec\u0001\u0000\u0000\u0000"+
		"\u02bc\u1cf5\u0001\u0000\u0000\u0000\u02be\u1cf7\u0001\u0000\u0000\u0000"+
		"\u02c0\u1cf9\u0001\u0000\u0000\u0000\u02c2\u1d00\u0001\u0000\u0000\u0000"+
		"\u02c4\u1d02\u0001\u0000\u0000\u0000\u02c6\u1d04\u0001\u0000\u0000\u0000"+
		"\u02c8\u1d06\u0001\u0000\u0000\u0000\u02ca\u1d08\u0001\u0000\u0000\u0000"+
		"\u02cc\u1d0a\u0001\u0000\u0000\u0000\u02ce\u1d0c\u0001\u0000\u0000\u0000"+
		"\u02d0\u1d0e\u0001\u0000\u0000\u0000\u02d2\u02d4\u0003\u0002\u0001\u0000"+
		"\u02d3\u02d2\u0001\u0000\u0000\u0000\u02d3\u02d4\u0001\u0000\u0000\u0000"+
		"\u02d4\u02d7\u0001\u0000\u0000\u0000\u02d5\u02d6\u0005\u0461\u0000\u0000"+
		"\u02d6\u02d8\u0005\u0461\u0000\u0000\u02d7\u02d5\u0001\u0000\u0000\u0000"+
		"\u02d7\u02d8\u0001\u0000\u0000\u0000\u02d8\u02d9\u0001\u0000\u0000\u0000"+
		"\u02d9\u02da\u0005\u0000\u0000\u0001\u02da\u0001\u0001\u0000\u0000\u0000"+
		"\u02db\u02de\u0003\u0004\u0002\u0000\u02dc\u02dd\u0005\u0461\u0000\u0000"+
		"\u02dd\u02df\u0005\u0461\u0000\u0000\u02de\u02dc\u0001\u0000\u0000\u0000"+
		"\u02de\u02df\u0001\u0000\u0000\u0000\u02df\u02e1\u0001\u0000\u0000\u0000"+
		"\u02e0\u02e2\u0005\u0470\u0000\u0000\u02e1\u02e0\u0001\u0000\u0000\u0000"+
		"\u02e1\u02e2\u0001\u0000\u0000\u0000\u02e2\u02e5\u0001\u0000\u0000\u0000"+
		"\u02e3\u02e5\u0003\u0006\u0003\u0000\u02e4\u02db\u0001\u0000\u0000\u0000"+
		"\u02e4\u02e3\u0001\u0000\u0000\u0000\u02e5\u02e8\u0001\u0000\u0000\u0000"+
		"\u02e6\u02e4\u0001\u0000\u0000\u0000\u02e6\u02e7\u0001\u0000\u0000\u0000"+
		"\u02e7\u02f2\u0001\u0000\u0000\u0000\u02e8\u02e6\u0001\u0000\u0000\u0000"+
		"\u02e9\u02ef\u0003\u0004\u0002\u0000\u02ea\u02eb\u0005\u0461\u0000\u0000"+
		"\u02eb\u02ed\u0005\u0461\u0000\u0000\u02ec\u02ea\u0001\u0000\u0000\u0000"+
		"\u02ec\u02ed\u0001\u0000\u0000\u0000\u02ed\u02ee\u0001\u0000\u0000\u0000"+
		"\u02ee\u02f0\u0005\u0470\u0000\u0000\u02ef\u02ec\u0001\u0000\u0000\u0000"+
		"\u02ef\u02f0\u0001\u0000\u0000\u0000\u02f0\u02f3\u0001\u0000\u0000\u0000"+
		"\u02f1\u02f3\u0003\u0006\u0003\u0000\u02f2\u02e9\u0001\u0000\u0000\u0000"+
		"\u02f2\u02f1\u0001\u0000\u0000\u0000\u02f3\u0003\u0001\u0000\u0000\u0000"+
		"\u02f4\u02fc\u0003\b\u0004\u0000\u02f5\u02fc\u0003\n\u0005\u0000\u02f6"+
		"\u02fc\u0003\f\u0006\u0000\u02f7\u02fc\u0003\u000e\u0007\u0000\u02f8\u02fc"+
		"\u0003\u0010\b\u0000\u02f9\u02fc\u0003\u0014\n\u0000\u02fa\u02fc\u0003"+
		"\u0016\u000b\u0000\u02fb\u02f4\u0001\u0000\u0000\u0000\u02fb\u02f5\u0001"+
		"\u0000\u0000\u0000\u02fb\u02f6\u0001\u0000\u0000\u0000\u02fb\u02f7\u0001"+
		"\u0000\u0000\u0000\u02fb\u02f8\u0001\u0000\u0000\u0000\u02fb\u02f9\u0001"+
		"\u0000\u0000\u0000\u02fb\u02fa\u0001\u0000\u0000\u0000\u02fc\u0005\u0001"+
		"\u0000\u0000\u0000\u02fd\u02fe\u0005\u0470\u0000\u0000\u02fe\u0007\u0001"+
		"\u0000\u0000\u0000\u02ff\u0326\u0003\u0018\f\u0000\u0300\u0326\u0003\u001a"+
		"\r\u0000\u0301\u0326\u0003\u001c\u000e\u0000\u0302\u0326\u0003\u001e\u000f"+
		"\u0000\u0303\u0326\u0003 \u0010\u0000\u0304\u0326\u0003\"\u0011\u0000"+
		"\u0305\u0326\u0003&\u0013\u0000\u0306\u0326\u0003(\u0014\u0000\u0307\u0326"+
		"\u0003*\u0015\u0000\u0308\u0326\u0003,\u0016\u0000\u0309\u0326\u0003."+
		"\u0017\u0000\u030a\u0326\u00038\u001c\u0000\u030b\u0326\u0003$\u0012\u0000"+
		"\u030c\u0326\u0003\u0080@\u0000\u030d\u0326\u0003\u0082A\u0000\u030e\u0326"+
		"\u0003\u0084B\u0000\u030f\u0326\u0003\u0086C\u0000\u0310\u0326\u0003\u0088"+
		"D\u0000\u0311\u0326\u0003\u008aE\u0000\u0312\u0326\u0003\u008cF\u0000"+
		"\u0313\u0326\u0003\u008eG\u0000\u0314\u0326\u0003\u0090H\u0000\u0315\u0326"+
		"\u0003\u0092I\u0000\u0316\u0326\u0003\u0098L\u0000\u0317\u0326\u0003\u009a"+
		"M\u0000\u0318\u0326\u0003\u009cN\u0000\u0319\u0326\u0003\u009eO\u0000"+
		"\u031a\u0326\u0003\u00a0P\u0000\u031b\u0326\u0003\u00a2Q\u0000\u031c\u0326"+
		"\u0003\u00a4R\u0000\u031d\u0326\u0003\u00a6S\u0000\u031e\u0326\u0003\u00a8"+
		"T\u0000\u031f\u0326\u0003\u00aaU\u0000\u0320\u0326\u0003\u00acV\u0000"+
		"\u0321\u0326\u0003\u00aeW\u0000\u0322\u0326\u0003\u00b0X\u0000\u0323\u0326"+
		"\u0003\u00b2Y\u0000\u0324\u0326\u0003\u00b6[\u0000\u0325\u02ff\u0001\u0000"+
		"\u0000\u0000\u0325\u0300\u0001\u0000\u0000\u0000\u0325\u0301\u0001\u0000"+
		"\u0000\u0000\u0325\u0302\u0001\u0000\u0000\u0000\u0325\u0303\u0001\u0000"+
		"\u0000\u0000\u0325\u0304\u0001\u0000\u0000\u0000\u0325\u0305\u0001\u0000"+
		"\u0000\u0000\u0325\u0306\u0001\u0000\u0000\u0000\u0325\u0307\u0001\u0000"+
		"\u0000\u0000\u0325\u0308\u0001\u0000\u0000\u0000\u0325\u0309\u0001\u0000"+
		"\u0000\u0000\u0325\u030a\u0001\u0000\u0000\u0000\u0325\u030b\u0001\u0000"+
		"\u0000\u0000\u0325\u030c\u0001\u0000\u0000\u0000\u0325\u030d\u0001\u0000"+
		"\u0000\u0000\u0325\u030e\u0001\u0000\u0000\u0000\u0325\u030f\u0001\u0000"+
		"\u0000\u0000\u0325\u0310\u0001\u0000\u0000\u0000\u0325\u0311\u0001\u0000"+
		"\u0000\u0000\u0325\u0312\u0001\u0000\u0000\u0000\u0325\u0313\u0001\u0000"+
		"\u0000\u0000\u0325\u0314\u0001\u0000\u0000\u0000\u0325\u0315\u0001\u0000"+
		"\u0000\u0000\u0325\u0316\u0001\u0000\u0000\u0000\u0325\u0317\u0001\u0000"+
		"\u0000\u0000\u0325\u0318\u0001\u0000\u0000\u0000\u0325\u0319\u0001\u0000"+
		"\u0000\u0000\u0325\u031a\u0001\u0000\u0000\u0000\u0325\u031b\u0001\u0000"+
		"\u0000\u0000\u0325\u031c\u0001\u0000\u0000\u0000\u0325\u031d\u0001\u0000"+
		"\u0000\u0000\u0325\u031e\u0001\u0000\u0000\u0000\u0325\u031f\u0001\u0000"+
		"\u0000\u0000\u0325\u0320\u0001\u0000\u0000\u0000\u0325\u0321\u0001\u0000"+
		"\u0000\u0000\u0325\u0322\u0001\u0000\u0000\u0000\u0325\u0323\u0001\u0000"+
		"\u0000\u0000\u0325\u0324\u0001\u0000\u0000\u0000\u0326\t\u0001\u0000\u0000"+
		"\u0000\u0327\u0335\u0003\u00c8d\u0000\u0328\u0335\u0003\u00c0`\u0000\u0329"+
		"\u0335\u0003\u00cae\u0000\u032a\u0335\u0003\u00ba]\u0000\u032b\u0335\u0003"+
		"\u00c6c\u0000\u032c\u0335\u0003\u00b8\\\u0000\u032d\u0335\u0003\u00c2"+
		"a\u0000\u032e\u0335\u0003\u00c4b\u0000\u032f\u0335\u0003\u00bc^\u0000"+
		"\u0330\u0335\u0003\u00be_\u0000\u0331\u0335\u0003\u00ccf\u0000\u0332\u0335"+
		"\u0003\u021c\u010e\u0000\u0333\u0335\u0003\u021e\u010f\u0000\u0334\u0327"+
		"\u0001\u0000\u0000\u0000\u0334\u0328\u0001\u0000\u0000\u0000\u0334\u0329"+
		"\u0001\u0000\u0000\u0000\u0334\u032a\u0001\u0000\u0000\u0000\u0334\u032b"+
		"\u0001\u0000\u0000\u0000\u0334\u032c\u0001\u0000\u0000\u0000\u0334\u032d"+
		"\u0001\u0000\u0000\u0000\u0334\u032e\u0001\u0000\u0000\u0000\u0334\u032f"+
		"\u0001\u0000\u0000\u0000\u0334\u0330\u0001\u0000\u0000\u0000\u0334\u0331"+
		"\u0001\u0000\u0000\u0000\u0334\u0332\u0001\u0000\u0000\u0000\u0334\u0333"+
		"\u0001\u0000\u0000\u0000\u0335\u000b\u0001\u0000\u0000\u0000\u0336\u0340"+
		"\u0003\u012a\u0095\u0000\u0337\u0340\u0003\u012c\u0096\u0000\u0338\u0340"+
		"\u0003\u012e\u0097\u0000\u0339\u0340\u0003\u0130\u0098\u0000\u033a\u0340"+
		"\u0003\u0132\u0099\u0000\u033b\u0340\u0003\u0134\u009a\u0000\u033c\u0340"+
		"\u0003\u0136\u009b\u0000\u033d\u0340\u0003\u0138\u009c\u0000\u033e\u0340"+
		"\u0003\u013a\u009d\u0000\u033f\u0336\u0001\u0000\u0000\u0000\u033f\u0337"+
		"\u0001\u0000\u0000\u0000\u033f\u0338\u0001\u0000\u0000\u0000\u033f\u0339"+
		"\u0001\u0000\u0000\u0000\u033f\u033a\u0001\u0000\u0000\u0000\u033f\u033b"+
		"\u0001\u0000\u0000\u0000\u033f\u033c\u0001\u0000\u0000\u0000\u033f\u033d"+
		"\u0001\u0000\u0000\u0000\u033f\u033e\u0001\u0000\u0000\u0000\u0340\r\u0001"+
		"\u0000\u0000\u0000\u0341\u0351\u0003\u014a\u00a5\u0000\u0342\u0351\u0003"+
		"\u014c\u00a6\u0000\u0343\u0351\u0003\u014e\u00a7\u0000\u0344\u0351\u0003"+
		"\u0150\u00a8\u0000\u0345\u0351\u0003\u0152\u00a9\u0000\u0346\u0351\u0003"+
		"\u0154\u00aa\u0000\u0347\u0351\u0003\u0156\u00ab\u0000\u0348\u0351\u0003"+
		"\u0158\u00ac\u0000\u0349\u0351\u0003\u015a\u00ad\u0000\u034a\u0351\u0003"+
		"\u0172\u00b9\u0000\u034b\u0351\u0003\u0174\u00ba\u0000\u034c\u0351\u0003"+
		"\u0176\u00bb\u0000\u034d\u0351\u0003\u0178\u00bc\u0000\u034e\u0351\u0003"+
		"\u017a\u00bd\u0000\u034f\u0351\u0003\u017c\u00be\u0000\u0350\u0341\u0001"+
		"\u0000\u0000\u0000\u0350\u0342\u0001\u0000\u0000\u0000\u0350\u0343\u0001"+
		"\u0000\u0000\u0000\u0350\u0344\u0001\u0000\u0000\u0000\u0350\u0345\u0001"+
		"\u0000\u0000\u0000\u0350\u0346\u0001\u0000\u0000\u0000\u0350\u0347\u0001"+
		"\u0000\u0000\u0000\u0350\u0348\u0001\u0000\u0000\u0000\u0350\u0349\u0001"+
		"\u0000\u0000\u0000\u0350\u034a\u0001\u0000\u0000\u0000\u0350\u034b\u0001"+
		"\u0000\u0000\u0000\u0350\u034c\u0001\u0000\u0000\u0000\u0350\u034d\u0001"+
		"\u0000\u0000\u0000\u0350\u034e\u0001\u0000\u0000\u0000\u0350\u034f\u0001"+
		"\u0000\u0000\u0000\u0351\u000f\u0001\u0000\u0000\u0000\u0352\u0356\u0003"+
		"\u017e\u00bf\u0000\u0353\u0356\u0003\u0180\u00c0\u0000\u0354\u0356\u0003"+
		"\u0182\u00c1\u0000\u0355\u0352\u0001\u0000\u0000\u0000\u0355\u0353\u0001"+
		"\u0000\u0000\u0000\u0355\u0354\u0001\u0000\u0000\u0000\u0356\u0011\u0001"+
		"\u0000\u0000\u0000\u0357\u0362\u0003\u0186\u00c3\u0000\u0358\u0362\u0003"+
		"\u0188\u00c4\u0000\u0359\u0362\u0003\u018a\u00c5\u0000\u035a\u0362\u0003"+
		"\u018e\u00c7\u0000\u035b\u0362\u0003\u0190\u00c8\u0000\u035c\u0362\u0003"+
		"\u0192\u00c9\u0000\u035d\u0362\u0003\u0196\u00cb\u0000\u035e\u0362\u0003"+
		"\u018c\u00c6\u0000\u035f\u0362\u0003\u0194\u00ca\u0000\u0360\u0362\u0003"+
		"\u0198\u00cc\u0000\u0361\u0357\u0001\u0000\u0000\u0000\u0361\u0358\u0001"+
		"\u0000\u0000\u0000\u0361\u0359\u0001\u0000\u0000\u0000\u0361\u035a\u0001"+
		"\u0000\u0000\u0000\u0361\u035b\u0001\u0000\u0000\u0000\u0361\u035c\u0001"+
		"\u0000\u0000\u0000\u0361\u035d\u0001\u0000\u0000\u0000\u0361\u035e\u0001"+
		"\u0000\u0000\u0000\u0361\u035f\u0001\u0000\u0000\u0000\u0361\u0360\u0001"+
		"\u0000\u0000\u0000\u0362\u0013\u0001\u0000\u0000\u0000\u0363\u037d\u0003"+
		"\u01aa\u00d5\u0000\u0364\u037d\u0003\u01ac\u00d6\u0000\u0365\u037d\u0003"+
		"\u01ae\u00d7\u0000\u0366\u037d\u0003\u01b0\u00d8\u0000\u0367\u037d\u0003"+
		"\u01b4\u00da\u0000\u0368\u037d\u0003\u01b6\u00db\u0000\u0369\u037d\u0003"+
		"\u01b8\u00dc\u0000\u036a\u037d\u0003\u01ba\u00dd\u0000\u036b\u037d\u0003"+
		"\u01d6\u00eb\u0000\u036c\u037d\u0003\u01d8\u00ec\u0000\u036d\u037d\u0003"+
		"\u01da\u00ed\u0000\u036e\u037d\u0003\u01dc\u00ee\u0000\u036f\u037d\u0003"+
		"\u01de\u00ef\u0000\u0370\u037d\u0003\u01e2\u00f1\u0000\u0371\u037d\u0003"+
		"\u01e4\u00f2\u0000\u0372\u037d\u0003\u01e6\u00f3\u0000\u0373\u037d\u0003"+
		"\u01e8\u00f4\u0000\u0374\u037d\u0003\u01ea\u00f5\u0000\u0375\u037d\u0003"+
		"\u01f8\u00fc\u0000\u0376\u037d\u0003\u01fa\u00fd\u0000\u0377\u037d\u0003"+
		"\u01fc\u00fe\u0000\u0378\u037d\u0003\u01fe\u00ff\u0000\u0379\u037d\u0003"+
		"\u0200\u0100\u0000\u037a\u037d\u0003\u0202\u0101\u0000\u037b\u037d\u0003"+
		"\u0204\u0102\u0000\u037c\u0363\u0001\u0000\u0000\u0000\u037c\u0364\u0001"+
		"\u0000\u0000\u0000\u037c\u0365\u0001\u0000\u0000\u0000\u037c\u0366\u0001"+
		"\u0000\u0000\u0000\u037c\u0367\u0001\u0000\u0000\u0000\u037c\u0368\u0001"+
		"\u0000\u0000\u0000\u037c\u0369\u0001\u0000\u0000\u0000\u037c\u036a\u0001"+
		"\u0000\u0000\u0000\u037c\u036b\u0001\u0000\u0000\u0000\u037c\u036c\u0001"+
		"\u0000\u0000\u0000\u037c\u036d\u0001\u0000\u0000\u0000\u037c\u036e\u0001"+
		"\u0000\u0000\u0000\u037c\u036f\u0001\u0000\u0000\u0000\u037c\u0370\u0001"+
		"\u0000\u0000\u0000\u037c\u0371\u0001\u0000\u0000\u0000\u037c\u0372\u0001"+
		"\u0000\u0000\u0000\u037c\u0373\u0001\u0000\u0000\u0000\u037c\u0374\u0001"+
		"\u0000\u0000\u0000\u037c\u0375\u0001\u0000\u0000\u0000\u037c\u0376\u0001"+
		"\u0000\u0000\u0000\u037c\u0377\u0001\u0000\u0000\u0000\u037c\u0378\u0001"+
		"\u0000\u0000\u0000\u037c\u0379\u0001\u0000\u0000\u0000\u037c\u037a\u0001"+
		"\u0000\u0000\u0000\u037c\u037b\u0001\u0000\u0000\u0000\u037d\u0015\u0001"+
		"\u0000\u0000\u0000\u037e\u0386\u0003\u020e\u0107\u0000\u037f\u0386\u0003"+
		"\u0210\u0108\u0000\u0380\u0386\u0003\u0212\u0109\u0000\u0381\u0386\u0003"+
		"\u0214\u010a\u0000\u0382\u0386\u0003\u0216\u010b\u0000\u0383\u0386\u0003"+
		"\u0218\u010c\u0000\u0384\u0386\u0003\u0220\u0110\u0000\u0385\u037e\u0001"+
		"\u0000\u0000\u0000\u0385\u037f\u0001\u0000\u0000\u0000\u0385\u0380\u0001"+
		"\u0000\u0000\u0000\u0385\u0381\u0001\u0000\u0000\u0000\u0385\u0382\u0001"+
		"\u0000\u0000\u0000\u0385\u0383\u0001\u0000\u0000\u0000\u0385\u0384\u0001"+
		"\u0000\u0000\u0000\u0386\u0017\u0001\u0000\u0000\u0000\u0387\u0388\u0005"+
		"!\u0000\u0000\u0388\u038a\u0007\u0000\u0000\u0000\u0389\u038b\u0003\u0282"+
		"\u0141\u0000\u038a\u0389\u0001\u0000\u0000\u0000\u038a\u038b\u0001\u0000"+
		"\u0000\u0000\u038b\u038c\u0001\u0000\u0000\u0000\u038c\u0390\u0003\u0248"+
		"\u0124\u0000\u038d\u038f\u0003:\u001d\u0000\u038e\u038d\u0001\u0000\u0000"+
		"\u0000\u038f\u0392\u0001\u0000\u0000\u0000\u0390\u038e\u0001\u0000\u0000"+
		"\u0000\u0390\u0391\u0001\u0000\u0000\u0000\u0391\u0019\u0001\u0000\u0000"+
		"\u0000\u0392\u0390\u0001\u0000\u0000\u0000\u0393\u0395\u0005!\u0000\u0000"+
		"\u0394\u0396\u0003@ \u0000\u0395\u0394\u0001\u0000\u0000\u0000\u0395\u0396"+
		"\u0001\u0000\u0000\u0000\u0396\u0397\u0001\u0000\u0000\u0000\u0397\u0399"+
		"\u0005\u019f\u0000\u0000\u0398\u039a\u0003\u0282\u0141\u0000\u0399\u0398"+
		"\u0001\u0000\u0000\u0000";
	private static final String _serializedATNSegment1 =
		"\u0399\u039a\u0001\u0000\u0000\u0000\u039a\u039b\u0001\u0000\u0000\u0000"+
		"\u039b\u039c\u0003\u0226\u0113\u0000\u039c\u039d\u0005v\u0000\u0000\u039d"+
		"\u039e\u0005\u025d\u0000\u0000\u039e\u03a5\u0003B!\u0000\u039f\u03a0\u0005"+
		"v\u0000\u0000\u03a0\u03a2\u0005\u0173\u0000\u0000\u03a1\u03a3\u0005r\u0000"+
		"\u0000\u03a2\u03a1\u0001\u0000\u0000\u0000\u03a2\u03a3\u0001\u0000\u0000"+
		"\u0000\u03a3\u03a4\u0001\u0000\u0000\u0000\u03a4\u03a6\u0005\u0231\u0000"+
		"\u0000\u03a5\u039f\u0001\u0000\u0000\u0000\u03a5\u03a6\u0001\u0000\u0000"+
		"\u0000\u03a6\u03a8\u0001\u0000\u0000\u0000\u03a7\u03a9\u0003J%\u0000\u03a8"+
		"\u03a7\u0001\u0000\u0000\u0000\u03a8\u03a9\u0001\u0000\u0000\u0000\u03a9"+
		"\u03ac\u0001\u0000\u0000\u0000\u03aa\u03ab\u0005\u0170\u0000\u0000\u03ab"+
		"\u03ad\u0005\u047c\u0000\u0000\u03ac\u03aa\u0001\u0000\u0000\u0000\u03ac"+
		"\u03ad\u0001\u0000\u0000\u0000\u03ad\u03ae\u0001\u0000\u0000\u0000\u03ae"+
		"\u03af\u0005\u018f\u0000\u0000\u03af\u03b0\u0003\u0184\u00c2\u0000\u03b0"+
		"\u001b\u0001\u0000\u0000\u0000\u03b1\u03b3\u0005!\u0000\u0000\u03b2\u03b4"+
		"\u0007\u0001\u0000\u0000\u03b3\u03b2\u0001\u0000\u0000\u0000\u03b3\u03b4"+
		"\u0001\u0000\u0000\u0000\u03b4\u03b6\u0001\u0000\u0000\u0000\u03b5\u03b7"+
		"\u0007\u0002\u0000\u0000\u03b6\u03b5\u0001\u0000\u0000\u0000\u03b6\u03b7"+
		"\u0001\u0000\u0000\u0000\u03b7\u03b8\u0001\u0000\u0000\u0000\u03b8\u03b9"+
		"\u0005Q\u0000\u0000\u03b9\u03bb\u0003\u0248\u0124\u0000\u03ba\u03bc\u0003"+
		"L&\u0000\u03bb\u03ba\u0001\u0000\u0000\u0000\u03bb\u03bc\u0001\u0000\u0000"+
		"\u0000\u03bc\u03bd\u0001\u0000\u0000\u0000\u03bd\u03be\u0005v\u0000\u0000"+
		"\u03be\u03bf\u0003\u0228\u0114\u0000\u03bf\u03c3\u0003\u026e\u0137\u0000"+
		"\u03c0\u03c2\u0003N\'\u0000\u03c1\u03c0\u0001\u0000\u0000\u0000\u03c2"+
		"\u03c5\u0001\u0000\u0000\u0000\u03c3\u03c1\u0001\u0000\u0000\u0000\u03c3"+
		"\u03c4\u0001\u0000\u0000\u0000\u03c4\u03d2\u0001\u0000\u0000\u0000\u03c5"+
		"\u03c3\u0001\u0000\u0000\u0000\u03c6\u03c8\u0005\u0150\u0000\u0000\u03c7"+
		"\u03c9\u0005\u0464\u0000\u0000\u03c8\u03c7\u0001\u0000\u0000\u0000\u03c8"+
		"\u03c9\u0001\u0000\u0000\u0000\u03c9\u03ca\u0001\u0000\u0000\u0000\u03ca"+
		"\u03d1\u0007\u0003\u0000\u0000\u03cb\u03cd\u0005g\u0000\u0000\u03cc\u03ce"+
		"\u0005\u0464\u0000\u0000\u03cd\u03cc\u0001\u0000\u0000\u0000\u03cd\u03ce"+
		"\u0001\u0000\u0000\u0000\u03ce\u03cf\u0001\u0000\u0000\u0000\u03cf\u03d1"+
		"\u0007\u0004\u0000\u0000\u03d0\u03c6\u0001\u0000\u0000\u0000\u03d0\u03cb"+
		"\u0001\u0000\u0000\u0000\u03d1\u03d4\u0001\u0000\u0000\u0000\u03d2\u03d0"+
		"\u0001\u0000\u0000\u0000\u03d2\u03d3\u0001\u0000\u0000\u0000\u03d3\u001d"+
		"\u0001\u0000\u0000\u0000\u03d4\u03d2\u0001\u0000\u0000\u0000\u03d5\u03d6"+
		"\u0005!\u0000\u0000\u03d6\u03d7\u0005\u01db\u0000\u0000\u03d7\u03d8\u0005"+
		"I\u0000\u0000\u03d8\u03d9\u0003\u0248\u0124\u0000\u03d9\u03da\u0005\u0005"+
		"\u0000\u0000\u03da\u03db\u0005\u0293\u0000\u0000\u03db\u03e1\u0005\u047c"+
		"\u0000\u0000\u03dc\u03de\u0005\u01c5\u0000\u0000\u03dd\u03df\u0005\u0464"+
		"\u0000\u0000\u03de\u03dd\u0001\u0000\u0000\u0000\u03de\u03df\u0001\u0000"+
		"\u0000\u0000\u03df\u03e0\u0001\u0000\u0000\u0000\u03e0\u03e2\u0003\u0250"+
		"\u0128\u0000\u03e1\u03dc\u0001\u0000\u0000\u0000\u03e1\u03e2\u0001\u0000"+
		"\u0000\u0000\u03e2\u03e8\u0001\u0000\u0000\u0000\u03e3\u03e5\u0005\u0294"+
		"\u0000\u0000\u03e4\u03e6\u0005\u0464\u0000\u0000\u03e5\u03e4\u0001\u0000"+
		"\u0000\u0000\u03e5\u03e6\u0001\u0000\u0000\u0000\u03e6\u03e7\u0001\u0000"+
		"\u0000\u0000\u03e7\u03e9\u0003\u0250\u0128\u0000\u03e8\u03e3\u0001\u0000"+
		"\u0000\u0000\u03e8\u03e9\u0001\u0000\u0000\u0000\u03e9\u03ef\u0001\u0000"+
		"\u0000\u0000\u03ea\u03ec\u0005\u023c\u0000\u0000\u03eb\u03ed\u0005\u0464"+
		"\u0000\u0000\u03ec\u03eb\u0001\u0000\u0000\u0000\u03ec\u03ed\u0001\u0000"+
		"\u0000\u0000\u03ed\u03ee\u0001\u0000\u0000\u0000\u03ee\u03f0\u0003\u0250"+
		"\u0128\u0000\u03ef\u03ea\u0001\u0000\u0000\u0000\u03ef\u03f0\u0001\u0000"+
		"\u0000\u0000\u03f0\u03f6\u0001\u0000\u0000\u0000\u03f1\u03f3\u0005\u0210"+
		"\u0000\u0000\u03f2\u03f4\u0005\u0464\u0000\u0000\u03f3\u03f2\u0001\u0000"+
		"\u0000\u0000\u03f3\u03f4\u0001\u0000\u0000\u0000\u03f4\u03f5\u0001\u0000"+
		"\u0000\u0000\u03f5\u03f7\u0003\u0248\u0124\u0000\u03f6\u03f1\u0001\u0000"+
		"\u0000\u0000\u03f6\u03f7\u0001\u0000\u0000\u0000\u03f7\u03f9\u0001\u0000"+
		"\u0000\u0000\u03f8\u03fa\u0005\u02a2\u0000\u0000\u03f9\u03f8\u0001\u0000"+
		"\u0000\u0000\u03f9\u03fa\u0001\u0000\u0000\u0000\u03fa\u0400\u0001\u0000"+
		"\u0000\u0000\u03fb\u03fd\u0005\u0170\u0000\u0000\u03fc\u03fe\u0005\u0464"+
		"\u0000\u0000\u03fd\u03fc\u0001\u0000\u0000\u0000\u03fd\u03fe\u0001\u0000"+
		"\u0000\u0000\u03fe\u03ff\u0001\u0000\u0000\u0000\u03ff\u0401\u0005\u047c"+
		"\u0000\u0000\u0400\u03fb\u0001\u0000\u0000\u0000\u0400\u0401\u0001\u0000"+
		"\u0000\u0000\u0401\u0402\u0001\u0000\u0000\u0000\u0402\u0404\u0005\u0199"+
		"\u0000\u0000\u0403\u0405\u0005\u0464\u0000\u0000\u0404\u0403\u0001\u0000"+
		"\u0000\u0000\u0404\u0405\u0001\u0000\u0000\u0000\u0405\u0406\u0001\u0000"+
		"\u0000\u0000\u0406\u0407\u0003\u023c\u011e\u0000\u0407\u001f\u0001\u0000"+
		"\u0000\u0000\u0408\u040a\u0005!\u0000\u0000\u0409\u040b\u0003@ \u0000"+
		"\u040a\u0409\u0001\u0000\u0000\u0000\u040a\u040b\u0001\u0000\u0000\u0000"+
		"\u040b\u040c\u0001\u0000\u0000\u0000\u040c\u040d\u0005\u0083\u0000\u0000"+
		"\u040d\u040e\u0003\u0226\u0113\u0000\u040e\u0410\u0005\u046d\u0000\u0000"+
		"\u040f\u0411\u0003P(\u0000\u0410\u040f\u0001\u0000\u0000\u0000\u0410\u0411"+
		"\u0001\u0000\u0000\u0000\u0411\u0416\u0001\u0000\u0000\u0000\u0412\u0413"+
		"\u0005\u046f\u0000\u0000\u0413\u0415\u0003P(\u0000\u0414\u0412\u0001\u0000"+
		"\u0000\u0000\u0415\u0418\u0001\u0000\u0000\u0000\u0416\u0414\u0001\u0000"+
		"\u0000\u0000\u0416\u0417\u0001\u0000\u0000\u0000\u0417\u0419\u0001\u0000"+
		"\u0000\u0000\u0418\u0416\u0001\u0000\u0000\u0000\u0419\u041d\u0005\u046e"+
		"\u0000\u0000\u041a\u041c\u0003T*\u0000\u041b\u041a\u0001\u0000\u0000\u0000"+
		"\u041c\u041f\u0001\u0000\u0000\u0000\u041d\u041b\u0001\u0000\u0000\u0000"+
		"\u041d\u041e\u0001\u0000\u0000\u0000\u041e\u0420\u0001\u0000\u0000\u0000"+
		"\u041f\u041d\u0001\u0000\u0000\u0000\u0420\u0421\u0003\u0184\u00c2\u0000"+
		"\u0421!\u0001\u0000\u0000\u0000\u0422\u0424\u0005!\u0000\u0000\u0423\u0425"+
		"\u0003@ \u0000\u0424\u0423\u0001\u0000\u0000\u0000\u0424\u0425\u0001\u0000"+
		"\u0000\u0000\u0425\u0427\u0001\u0000\u0000\u0000\u0426\u0428\u0005\u014f"+
		"\u0000\u0000\u0427\u0426\u0001\u0000\u0000\u0000\u0427\u0428\u0001\u0000"+
		"\u0000\u0000\u0428\u0429\u0001\u0000\u0000\u0000\u0429\u042b\u0005\u01b5"+
		"\u0000\u0000\u042a\u042c\u0003\u0282\u0141\u0000\u042b\u042a\u0001\u0000"+
		"\u0000\u0000\u042b\u042c\u0001\u0000\u0000\u0000\u042c\u042d\u0001\u0000"+
		"\u0000\u0000\u042d\u042e\u0003\u0226\u0113\u0000\u042e\u0430\u0005\u046d"+
		"\u0000\u0000\u042f\u0431\u0003R)\u0000\u0430\u042f\u0001\u0000\u0000\u0000"+
		"\u0430\u0431\u0001\u0000\u0000\u0000\u0431\u0436\u0001\u0000\u0000\u0000"+
		"\u0432\u0433\u0005\u046f\u0000\u0000\u0433\u0435\u0003R)\u0000\u0434\u0432"+
		"\u0001\u0000\u0000\u0000\u0435\u0438\u0001\u0000\u0000\u0000\u0436\u0434"+
		"\u0001\u0000\u0000\u0000\u0436\u0437\u0001\u0000\u0000\u0000\u0437\u0439"+
		"\u0001\u0000\u0000\u0000\u0438\u0436\u0001\u0000\u0000\u0000\u0439\u043a"+
		"\u0005\u046e\u0000\u0000\u043a\u043b\u0005\u0252\u0000\u0000\u043b\u043f"+
		"\u0003\u025c\u012e\u0000\u043c\u043e\u0003T*\u0000\u043d\u043c\u0001\u0000"+
		"\u0000\u0000\u043e\u0441\u0001\u0000\u0000\u0000\u043f\u043d\u0001\u0000"+
		"\u0000\u0000\u043f\u0440\u0001\u0000\u0000\u0000\u0440\u0444\u0001\u0000"+
		"\u0000\u0000\u0441\u043f\u0001\u0000\u0000\u0000\u0442\u0445\u0003\u0184"+
		"\u00c2\u0000\u0443\u0445\u0003\u0194\u00ca\u0000\u0444\u0442\u0001\u0000"+
		"\u0000\u0000\u0444\u0443\u0001\u0000\u0000\u0000\u0445#\u0001\u0000\u0000"+
		"\u0000\u0446\u0447\u0005!\u0000\u0000\u0447\u0449\u0005\u0254\u0000\u0000"+
		"\u0448\u044a\u0003\u0282\u0141\u0000\u0449\u0448\u0001\u0000\u0000\u0000"+
		"\u0449\u044a\u0001\u0000\u0000\u0000\u044a\u044b\u0001\u0000\u0000\u0000"+
		"\u044b\u0450\u0003\u022a\u0115\u0000\u044c\u044d\u0005\u046f\u0000\u0000"+
		"\u044d\u044f\u0003\u022a\u0115\u0000\u044e\u044c\u0001\u0000\u0000\u0000"+
		"\u044f\u0452\u0001\u0000\u0000\u0000\u0450\u044e\u0001\u0000\u0000\u0000"+
		"\u0450\u0451\u0001\u0000\u0000\u0000\u0451%\u0001\u0000\u0000\u0000\u0452"+
		"\u0450\u0001\u0000\u0000\u0000\u0453\u0454\u0005!\u0000\u0000\u0454\u0455"+
		"\u0005\u0260\u0000\u0000\u0455\u0456\u0003\u0248\u0124\u0000\u0456\u0457"+
		"\u0005C\u0000\u0000\u0457\u0458\u0005\u0184\u0000\u0000\u0458\u0459\u0005"+
		"\u02a7\u0000\u0000\u0459\u045a\u0007\u0005\u0000\u0000\u045a\u045b\u0005"+
		"\u021d\u0000\u0000\u045b\u045c\u0005\u046d\u0000\u0000\u045c\u0461\u0003"+
		"V+\u0000\u045d\u045e\u0005\u046f\u0000\u0000\u045e\u0460\u0003V+\u0000"+
		"\u045f\u045d\u0001\u0000\u0000\u0000\u0460\u0463\u0001\u0000\u0000\u0000"+
		"\u0461\u045f\u0001\u0000\u0000\u0000\u0461\u0462\u0001\u0000\u0000\u0000"+
		"\u0462\u0464\u0001\u0000\u0000\u0000\u0463\u0461\u0001\u0000\u0000\u0000"+
		"\u0464\u0465\u0005\u046e\u0000\u0000\u0465\'\u0001\u0000\u0000\u0000\u0466"+
		"\u0468\u0005!\u0000\u0000\u0467\u0469\u0005\u0289\u0000\u0000\u0468\u0467"+
		"\u0001\u0000\u0000\u0000\u0468\u0469\u0001\u0000\u0000\u0000\u0469\u046a"+
		"\u0001\u0000\u0000\u0000\u046a\u046c\u0005\u00ac\u0000\u0000\u046b\u046d"+
		"\u0003\u0282\u0141\u0000\u046c\u046b\u0001\u0000\u0000\u0000\u046c\u046d"+
		"\u0001\u0000\u0000\u0000\u046d\u046e\u0001\u0000\u0000\u0000\u046e\u0476"+
		"\u0003\u0228\u0114\u0000\u046f\u0470\u0005b\u0000\u0000\u0470\u0477\u0003"+
		"\u0228\u0114\u0000\u0471\u0472\u0005\u046d\u0000\u0000\u0472\u0473\u0005"+
		"b\u0000\u0000\u0473\u0474\u0003\u0228\u0114\u0000\u0474\u0475\u0005\u046e"+
		"\u0000\u0000\u0475\u0477\u0001\u0000\u0000\u0000\u0476\u046f\u0001\u0000"+
		"\u0000\u0000\u0476\u0471\u0001\u0000\u0000\u0000\u0477\u04b5\u0001\u0000"+
		"\u0000\u0000\u0478\u047a\u0005!\u0000\u0000\u0479\u047b\u0005\u0289\u0000"+
		"\u0000\u047a\u0479\u0001\u0000\u0000\u0000\u047a\u047b\u0001\u0000\u0000"+
		"\u0000\u047b\u047c\u0001\u0000\u0000\u0000\u047c\u047e\u0005\u00ac\u0000"+
		"\u0000\u047d\u047f\u0003\u0282\u0141\u0000\u047e\u047d\u0001\u0000\u0000"+
		"\u0000\u047e\u047f\u0001\u0000\u0000\u0000\u047f\u0480\u0001\u0000\u0000"+
		"\u0000\u0480\u0482\u0003\u0228\u0114\u0000\u0481\u0483\u0003X,\u0000\u0482"+
		"\u0481\u0001\u0000\u0000\u0000\u0482\u0483\u0001\u0000\u0000\u0000\u0483"+
		"\u048e\u0001\u0000\u0000\u0000\u0484\u048b\u0003j5\u0000\u0485\u0487\u0005"+
		"\u046f\u0000\u0000\u0486\u0485\u0001\u0000\u0000\u0000\u0486\u0487\u0001"+
		"\u0000\u0000\u0000\u0487\u0488\u0001\u0000\u0000\u0000\u0488\u048a\u0003"+
		"j5\u0000\u0489\u0486\u0001\u0000\u0000\u0000\u048a\u048d\u0001\u0000\u0000"+
		"\u0000\u048b\u0489\u0001\u0000\u0000\u0000\u048b\u048c\u0001\u0000\u0000"+
		"\u0000\u048c\u048f\u0001\u0000\u0000\u0000\u048d\u048b\u0001\u0000\u0000"+
		"\u0000\u048e\u0484\u0001\u0000\u0000\u0000\u048e\u048f\u0001\u0000\u0000"+
		"\u0000\u048f\u0491\u0001\u0000\u0000\u0000\u0490\u0492\u0003p8\u0000\u0491"+
		"\u0490\u0001\u0000\u0000\u0000\u0491\u0492\u0001\u0000\u0000\u0000\u0492"+
		"\u0494\u0001\u0000\u0000\u0000\u0493\u0495\u0007\u0006\u0000\u0000\u0494"+
		"\u0493\u0001\u0000\u0000\u0000\u0494\u0495\u0001\u0000\u0000\u0000\u0495"+
		"\u0497\u0001\u0000\u0000\u0000\u0496\u0498\u0005\f\u0000\u0000\u0497\u0496"+
		"\u0001\u0000\u0000\u0000\u0497\u0498\u0001\u0000\u0000\u0000\u0498\u0499"+
		"\u0001\u0000\u0000\u0000\u0499\u049a\u0003\u00c8d\u0000\u049a\u04b5\u0001"+
		"\u0000\u0000\u0000\u049b\u049d\u0005!\u0000\u0000\u049c\u049e\u0005\u0289"+
		"\u0000\u0000\u049d\u049c\u0001\u0000\u0000\u0000\u049d\u049e\u0001\u0000"+
		"\u0000\u0000\u049e\u049f\u0001\u0000\u0000\u0000\u049f\u04a1\u0005\u00ac"+
		"\u0000\u0000\u04a0\u04a2\u0003\u0282\u0141\u0000\u04a1\u04a0\u0001\u0000"+
		"\u0000\u0000\u04a1\u04a2\u0001\u0000\u0000\u0000\u04a2\u04a3\u0001\u0000"+
		"\u0000\u0000\u04a3\u04a4\u0003\u0228\u0114\u0000\u04a4\u04af\u0003X,\u0000"+
		"\u04a5\u04ac\u0003j5\u0000\u04a6\u04a8\u0005\u046f\u0000\u0000\u04a7\u04a6"+
		"\u0001\u0000\u0000\u0000\u04a7\u04a8\u0001\u0000\u0000\u0000\u04a8\u04a9"+
		"\u0001\u0000\u0000\u0000\u04a9\u04ab\u0003j5\u0000\u04aa\u04a7\u0001\u0000"+
		"\u0000\u0000\u04ab\u04ae\u0001\u0000\u0000\u0000\u04ac\u04aa\u0001\u0000"+
		"\u0000\u0000\u04ac\u04ad\u0001\u0000\u0000\u0000\u04ad\u04b0\u0001\u0000"+
		"\u0000\u0000\u04ae\u04ac\u0001\u0000\u0000\u0000\u04af\u04a5\u0001\u0000"+
		"\u0000\u0000\u04af\u04b0\u0001\u0000\u0000\u0000\u04b0\u04b2\u0001\u0000"+
		"\u0000\u0000\u04b1\u04b3\u0003p8\u0000\u04b2\u04b1\u0001\u0000\u0000\u0000"+
		"\u04b2\u04b3\u0001\u0000\u0000\u0000\u04b3\u04b5\u0001\u0000\u0000\u0000"+
		"\u04b4\u0466\u0001\u0000\u0000\u0000\u04b4\u0478\u0001\u0000\u0000\u0000"+
		"\u04b4\u049b\u0001\u0000\u0000\u0000\u04b5)\u0001\u0000\u0000\u0000\u04b6"+
		"\u04b7\u0005!\u0000\u0000\u04b7\u04b8\u0005\u0287\u0000\u0000\u04b8\u04b9"+
		"\u0003\u0248\u0124\u0000\u04b9\u04ba\u0005\u0005\u0000\u0000\u04ba\u04bb"+
		"\u0005\u0185\u0000\u0000\u04bb\u04bf\u0005\u047c\u0000\u0000\u04bc\u04bd"+
		"\u0005\u01ac\u0000\u0000\u04bd\u04be\u0005\u0464\u0000\u0000\u04be\u04c0"+
		"\u0003\u0250\u0128\u0000\u04bf\u04bc\u0001\u0000\u0000\u0000\u04bf\u04c0"+
		"\u0001\u0000\u0000\u0000\u04c0\u04c6\u0001\u0000\u0000\u0000\u04c1\u04c3"+
		"\u0005\u0199\u0000\u0000\u04c2\u04c4\u0005\u0464\u0000\u0000\u04c3\u04c2"+
		"\u0001\u0000\u0000\u0000\u04c3\u04c4\u0001\u0000\u0000\u0000\u04c4\u04c5"+
		"\u0001\u0000\u0000\u0000\u04c5\u04c7\u0003\u023c\u011e\u0000\u04c6\u04c1"+
		"\u0001\u0000\u0000\u0000\u04c6\u04c7\u0001\u0000\u0000\u0000\u04c7+\u0001"+
		"\u0000\u0000\u0000\u04c8\u04c9\u0005!\u0000\u0000\u04c9\u04ca\u0005\u0287"+
		"\u0000\u0000\u04ca\u04cb\u0003\u0248\u0124\u0000\u04cb\u04cc\u0005\u0005"+
		"\u0000\u0000\u04cc\u04cd\u0005\u0185\u0000\u0000\u04cd\u04ce\u0005\u047c"+
		"\u0000\u0000\u04ce\u04cf\u0005\u00ba\u0000\u0000\u04cf\u04d0\u0005\u01db"+
		"\u0000\u0000\u04d0\u04d1\u0005I\u0000\u0000\u04d1\u04d7\u0003\u0248\u0124"+
		"\u0000\u04d2\u04d4\u0005\u01a7\u0000\u0000\u04d3\u04d5\u0005\u0464\u0000"+
		"\u0000\u04d4\u04d3\u0001\u0000\u0000\u0000\u04d4\u04d5\u0001\u0000\u0000"+
		"\u0000\u04d5\u04d6\u0001\u0000\u0000\u0000\u04d6\u04d8\u0003\u0250\u0128"+
		"\u0000\u04d7\u04d2\u0001\u0000\u0000\u0000\u04d7\u04d8\u0001\u0000\u0000"+
		"\u0000\u04d8\u04de\u0001\u0000\u0000\u0000\u04d9\u04db\u0005\u01c5\u0000"+
		"\u0000\u04da\u04dc\u0005\u0464\u0000\u0000\u04db\u04da\u0001\u0000\u0000"+
		"\u0000\u04db\u04dc\u0001\u0000\u0000\u0000\u04dc\u04dd\u0001\u0000\u0000"+
		"\u0000\u04dd\u04df\u0003\u0250\u0128\u0000\u04de\u04d9\u0001\u0000\u0000"+
		"\u0000\u04de\u04df\u0001\u0000\u0000\u0000\u04df\u04e5\u0001\u0000\u0000"+
		"\u0000\u04e0\u04e2\u0005\u0155\u0000\u0000\u04e1\u04e3\u0005\u0464\u0000"+
		"\u0000\u04e2\u04e1\u0001\u0000\u0000\u0000\u04e2\u04e3\u0001\u0000\u0000"+
		"\u0000\u04e3\u04e4\u0001\u0000\u0000\u0000\u04e4\u04e6\u0003\u0250\u0128"+
		"\u0000\u04e5\u04e0\u0001\u0000\u0000\u0000\u04e5\u04e6\u0001\u0000\u0000"+
		"\u0000\u04e6\u04ec\u0001\u0000\u0000\u0000\u04e7\u04e9\u0005\u01f5\u0000"+
		"\u0000\u04e8\u04ea\u0005\u0464\u0000\u0000\u04e9\u04e8\u0001\u0000\u0000"+
		"\u0000\u04e9\u04ea\u0001\u0000\u0000\u0000\u04ea\u04eb\u0001\u0000\u0000"+
		"\u0000\u04eb\u04ed\u0003\u0250\u0128\u0000\u04ec\u04e7\u0001\u0000\u0000"+
		"\u0000\u04ec\u04ed\u0001\u0000\u0000\u0000\u04ed\u04f3\u0001\u0000\u0000"+
		"\u0000\u04ee\u04f0\u0005\u0210\u0000\u0000\u04ef\u04f1\u0005\u0464\u0000"+
		"\u0000\u04f0\u04ef\u0001\u0000\u0000\u0000\u04f0\u04f1\u0001\u0000\u0000"+
		"\u0000\u04f1\u04f2\u0001\u0000\u0000\u0000\u04f2\u04f4\u0003\u0248\u0124"+
		"\u0000\u04f3\u04ee\u0001\u0000\u0000\u0000\u04f3\u04f4\u0001\u0000\u0000"+
		"\u0000\u04f4\u04f6\u0001\u0000\u0000\u0000\u04f5\u04f7\u0005\u02a2\u0000"+
		"\u0000\u04f6\u04f5\u0001\u0000\u0000\u0000\u04f6\u04f7\u0001\u0000\u0000"+
		"\u0000\u04f7\u04fd\u0001\u0000\u0000\u0000\u04f8\u04fa\u0005\u0170\u0000"+
		"\u0000\u04f9\u04fb\u0005\u0464\u0000\u0000\u04fa\u04f9\u0001\u0000\u0000"+
		"\u0000\u04fa\u04fb\u0001\u0000\u0000\u0000\u04fb\u04fc\u0001\u0000\u0000"+
		"\u0000\u04fc\u04fe\u0005\u047c\u0000\u0000\u04fd\u04f8\u0001\u0000\u0000"+
		"\u0000\u04fd\u04fe\u0001\u0000\u0000\u0000\u04fe\u04ff\u0001\u0000\u0000"+
		"\u0000\u04ff\u0501\u0005\u0199\u0000\u0000\u0500\u0502\u0005\u0464\u0000"+
		"\u0000\u0501\u0500\u0001\u0000\u0000\u0000\u0501\u0502\u0001\u0000\u0000"+
		"\u0000\u0502\u0503\u0001\u0000\u0000\u0000\u0503\u0504\u0003\u023c\u011e"+
		"\u0000\u0504-\u0001\u0000\u0000\u0000\u0505\u0507\u0005!\u0000\u0000\u0506"+
		"\u0508\u0003@ \u0000\u0507\u0506\u0001\u0000\u0000\u0000\u0507\u0508\u0001"+
		"\u0000\u0000\u0000\u0508\u0509\u0001\u0000\u0000\u0000\u0509\u050a\u0005"+
		"\u00b1\u0000\u0000\u050a\u050b\u0003\u0226\u0113\u0000\u050b\u050c\u0007"+
		"\u0007\u0000\u0000\u050c\u050d\u0007\b\u0000\u0000\u050d\u050e\u0005v"+
		"\u0000\u0000\u050e\u050f\u0003\u0228\u0114\u0000\u050f\u0510\u0005A\u0000"+
		"\u0000\u0510\u0511\u00054\u0000\u0000\u0511\u0514\u0005\u0258\u0000\u0000"+
		"\u0512\u0513\u0007\t\u0000\u0000\u0513\u0515\u0003\u0226\u0113\u0000\u0514"+
		"\u0512\u0001\u0000\u0000\u0000\u0514\u0515\u0001\u0000\u0000\u0000\u0515"+
		"\u0516\u0001\u0000\u0000\u0000\u0516\u0517\u0003\u0184\u00c2\u0000\u0517"+
		"/\u0001\u0000\u0000\u0000\u0518\u051a\u0005\u00c0\u0000\u0000\u0519\u051b"+
		"\u0005\u023b\u0000\u0000\u051a\u0519\u0001\u0000\u0000\u0000\u051a\u051b"+
		"\u0001\u0000\u0000\u0000\u051b\u051c\u0001\u0000\u0000\u0000\u051c\u051d"+
		"\u00032\u0019\u0000\u051d1\u0001\u0000\u0000\u0000\u051e\u052a\u00034"+
		"\u001a\u0000\u051f\u0520\u0005\u046d\u0000\u0000\u0520\u0525\u00036\u001b"+
		"\u0000\u0521\u0522\u0005\u046f\u0000\u0000\u0522\u0524\u00036\u001b\u0000"+
		"\u0523\u0521\u0001\u0000\u0000\u0000\u0524\u0527\u0001\u0000\u0000\u0000"+
		"\u0525\u0523\u0001\u0000\u0000\u0000\u0525\u0526\u0001\u0000\u0000\u0000"+
		"\u0526\u0528\u0001\u0000\u0000\u0000\u0527\u0525\u0001\u0000\u0000\u0000"+
		"\u0528\u0529\u0005\u046e\u0000\u0000\u0529\u052b\u0001\u0000\u0000\u0000"+
		"\u052a\u051f\u0001\u0000\u0000\u0000\u052a\u052b\u0001\u0000\u0000\u0000"+
		"\u052b\u052c\u0001\u0000\u0000\u0000\u052c\u052d\u0005\f\u0000\u0000\u052d"+
		"\u052e\u0005\u046d\u0000\u0000\u052e\u052f\u0003\n\u0005\u0000\u052f\u0532"+
		"\u0005\u046e\u0000\u0000\u0530\u0531\u0005\u046f\u0000\u0000\u0531\u0533"+
		"\u00032\u0019\u0000\u0532\u0530\u0001\u0000\u0000\u0000\u0532\u0533\u0001"+
		"\u0000\u0000\u0000\u05333\u0001\u0000\u0000\u0000\u0534\u0535\u0003\u0248"+
		"\u0124\u0000\u05355\u0001\u0000\u0000\u0000\u0536\u0537\u0003\u0248\u0124"+
		"\u0000\u05377\u0001\u0000\u0000\u0000\u0538\u053a\u0005!\u0000\u0000\u0539"+
		"\u053b\u0003\u0284\u0142\u0000\u053a\u0539\u0001\u0000\u0000\u0000\u053a"+
		"\u053b\u0001\u0000\u0000\u0000\u053b\u053f\u0001\u0000\u0000\u0000\u053c"+
		"\u053d\u0005\u0150\u0000\u0000\u053d\u053e\u0005\u0464\u0000\u0000\u053e"+
		"\u0540\u0007\n\u0000\u0000\u053f\u053c\u0001\u0000\u0000\u0000\u053f\u0540"+
		"\u0001\u0000\u0000\u0000\u0540\u0542\u0001\u0000\u0000\u0000\u0541\u0543"+
		"\u0003@ \u0000\u0542\u0541\u0001\u0000\u0000\u0000\u0542\u0543\u0001\u0000"+
		"\u0000\u0000\u0543\u0547\u0001\u0000\u0000\u0000\u0544\u0545\u0005\u00a0"+
		"\u0000\u0000\u0545\u0546\u0005\u025e\u0000\u0000\u0546\u0548\u0007\u000b"+
		"\u0000\u0000\u0547\u0544\u0001\u0000\u0000\u0000\u0547\u0548\u0001\u0000"+
		"\u0000\u0000\u0548\u0549\u0001\u0000\u0000\u0000\u0549\u054a\u0005\u029f"+
		"\u0000\u0000\u054a\u054f\u0003\u0226\u0113\u0000\u054b\u054c\u0005\u046d"+
		"\u0000\u0000\u054c\u054d\u0003\u0268\u0134\u0000\u054d\u054e\u0005\u046e"+
		"\u0000\u0000\u054e\u0550\u0001\u0000\u0000\u0000\u054f\u054b\u0001\u0000"+
		"\u0000\u0000\u054f\u0550\u0001\u0000\u0000\u0000\u0550\u0551\u0001\u0000"+
		"\u0000\u0000\u0551\u0565\u0005\f\u0000\u0000\u0552\u0554\u0005\u046d\u0000"+
		"\u0000\u0553\u0555\u00030\u0018\u0000\u0554\u0553\u0001\u0000\u0000\u0000"+
		"\u0554\u0555\u0001\u0000\u0000\u0000\u0555\u0556\u0001\u0000\u0000\u0000"+
		"\u0556\u0557\u0003\u00c8d\u0000\u0557\u0558\u0005\u046e\u0000\u0000\u0558"+
		"\u0566\u0001\u0000\u0000\u0000\u0559\u055b\u00030\u0018\u0000\u055a\u0559"+
		"\u0001\u0000\u0000\u0000\u055a\u055b\u0001\u0000\u0000\u0000\u055b\u055c"+
		"\u0001\u0000\u0000\u0000\u055c\u0563\u0003\u00c8d\u0000\u055d\u055f\u0005"+
		"\u00c0\u0000\u0000\u055e\u0560\u0007\f\u0000\u0000\u055f\u055e\u0001\u0000"+
		"\u0000\u0000\u055f\u0560\u0001\u0000\u0000\u0000\u0560\u0561\u0001\u0000"+
		"\u0000\u0000\u0561\u0562\u0005\u001a\u0000\u0000\u0562\u0564\u0005x\u0000"+
		"\u0000\u0563\u055d\u0001\u0000\u0000\u0000\u0563\u0564\u0001\u0000\u0000"+
		"\u0000\u0564\u0566\u0001\u0000\u0000\u0000\u0565\u0552\u0001\u0000\u0000"+
		"\u0000\u0565\u055a\u0001\u0000\u0000\u0000\u05669\u0001\u0000\u0000\u0000"+
		"\u0567\u0569\u0005*\u0000\u0000\u0568\u0567\u0001\u0000\u0000\u0000\u0568"+
		"\u0569\u0001\u0000\u0000\u0000\u0569\u056a\u0001\u0000\u0000\u0000\u056a"+
		"\u056c\u0003<\u001e\u0000\u056b\u056d\u0005\u0464\u0000\u0000\u056c\u056b"+
		"\u0001\u0000\u0000\u0000\u056c\u056d\u0001\u0000\u0000\u0000\u056d\u0570"+
		"\u0001\u0000\u0000\u0000\u056e\u0571\u0003\u0238\u011c\u0000\u056f\u0571"+
		"\u0005*\u0000\u0000\u0570\u056e\u0001\u0000\u0000\u0000\u0570\u056f\u0001"+
		"\u0000\u0000\u0000\u0571\u0589\u0001\u0000\u0000\u0000\u0572\u0574\u0005"+
		"*\u0000\u0000\u0573\u0572\u0001\u0000\u0000\u0000\u0573\u0574\u0001\u0000"+
		"\u0000\u0000\u0574\u0575\u0001\u0000\u0000\u0000\u0575\u0577\u0005\u001b"+
		"\u0000\u0000\u0576\u0578\u0005\u0464\u0000\u0000\u0577\u0576\u0001\u0000"+
		"\u0000\u0000\u0577\u0578\u0001\u0000\u0000\u0000\u0578\u0579\u0001\u0000"+
		"\u0000\u0000\u0579\u0589\u0003\u023a\u011d\u0000\u057a\u057c\u0005*\u0000"+
		"\u0000\u057b\u057a\u0001\u0000\u0000\u0000\u057b\u057c\u0001\u0000\u0000"+
		"\u0000\u057c\u057d\u0001\u0000\u0000\u0000\u057d\u057f\u0005\u0195\u0000"+
		"\u0000\u057e\u0580\u0005\u0464\u0000\u0000\u057f\u057e\u0001\u0000\u0000"+
		"\u0000\u057f\u0580\u0001\u0000\u0000\u0000\u0580\u0581\u0001\u0000\u0000"+
		"\u0000\u0581\u0589\u0005\u047c\u0000\u0000\u0582\u0583\u0005\u0086\u0000"+
		"\u0000\u0583\u0585\u0005\u021a\u0000\u0000\u0584\u0586\u0005\u0464\u0000"+
		"\u0000\u0585\u0584\u0001\u0000\u0000\u0000\u0585\u0586\u0001\u0000\u0000"+
		"\u0000\u0586\u0587\u0001\u0000\u0000\u0000\u0587\u0589\u0007\r\u0000\u0000"+
		"\u0588\u0568\u0001\u0000\u0000\u0000\u0588\u0573\u0001\u0000\u0000\u0000"+
		"\u0588\u057b\u0001\u0000\u0000\u0000\u0588\u0582\u0001\u0000\u0000\u0000"+
		"\u0589;\u0001\u0000\u0000\u0000\u058a\u058b\u0005\u0019\u0000\u0000\u058b"+
		"\u0590\u0005\u0099\u0000\u0000\u058c\u0590\u0005\u0349\u0000\u0000\u058d"+
		"\u058e\u0005\u00de\u0000\u0000\u058e\u0590\u0005\u0099\u0000\u0000\u058f"+
		"\u058a\u0001\u0000\u0000\u0000\u058f\u058c\u0001\u0000\u0000\u0000\u058f"+
		"\u058d\u0001\u0000\u0000\u0000\u0590=\u0001\u0000\u0000\u0000\u0591\u0594"+
		"\u0005%\u0000\u0000\u0592\u0593\u0005\u046d\u0000\u0000\u0593\u0595\u0005"+
		"\u046e\u0000\u0000\u0594\u0592\u0001\u0000\u0000\u0000\u0594\u0595\u0001"+
		"\u0000\u0000\u0000\u0595?\u0001\u0000\u0000\u0000\u0596\u0597\u0005\u0188"+
		"\u0000\u0000\u0597\u059a\u0005\u0464\u0000\u0000\u0598\u059b\u0003\u0234"+
		"\u011a\u0000\u0599\u059b\u0003>\u001f\u0000\u059a\u0598\u0001\u0000\u0000"+
		"\u0000\u059a\u0599\u0001\u0000\u0000\u0000\u059bA\u0001\u0000\u0000\u0000"+
		"\u059c\u059d\u0005\u0152\u0000\u0000\u059d\u05a1\u0003D\"\u0000\u059e"+
		"\u05a0\u0003F#\u0000\u059f\u059e\u0001\u0000\u0000\u0000\u05a0\u05a3\u0001"+
		"\u0000\u0000\u0000\u05a1\u059f\u0001\u0000\u0000\u0000\u05a1\u05a2\u0001"+
		"\u0000\u0000\u0000\u05a2\u05bf\u0001\u0000\u0000\u0000\u05a3\u05a1\u0001"+
		"\u0000\u0000\u0000\u05a4\u05a7\u0005\u01a1\u0000\u0000\u05a5\u05a8\u0003"+
		"\u024e\u0127\u0000\u05a6\u05a8\u0003\u02b0\u0158\u0000\u05a7\u05a5\u0001"+
		"\u0000\u0000\u0000\u05a7\u05a6\u0001\u0000\u0000\u0000\u05a8\u05a9\u0001"+
		"\u0000\u0000\u0000\u05a9\u05b2\u0003H$\u0000\u05aa\u05ab\u0005\u0276\u0000"+
		"\u0000\u05ab\u05af\u0003D\"\u0000\u05ac\u05ae\u0003F#\u0000\u05ad\u05ac"+
		"\u0001\u0000\u0000\u0000\u05ae\u05b1\u0001\u0000\u0000\u0000\u05af\u05ad"+
		"\u0001\u0000\u0000\u0000\u05af\u05b0\u0001\u0000\u0000\u0000\u05b0\u05b3"+
		"\u0001\u0000\u0000\u0000\u05b1\u05af\u0001\u0000\u0000\u0000\u05b2\u05aa"+
		"\u0001\u0000\u0000\u0000\u05b2\u05b3\u0001\u0000\u0000\u0000\u05b3\u05bc"+
		"\u0001\u0000\u0000\u0000\u05b4\u05b5\u0005\u0198\u0000\u0000\u05b5\u05b9"+
		"\u0003D\"\u0000\u05b6\u05b8\u0003F#\u0000\u05b7\u05b6\u0001\u0000\u0000"+
		"\u0000\u05b8\u05bb\u0001\u0000\u0000\u0000\u05b9\u05b7\u0001\u0000\u0000"+
		"\u0000\u05b9\u05ba\u0001\u0000\u0000\u0000\u05ba\u05bd\u0001\u0000\u0000"+
		"\u0000\u05bb\u05b9\u0001\u0000\u0000\u0000\u05bc\u05b4\u0001\u0000\u0000"+
		"\u0000\u05bc\u05bd\u0001\u0000\u0000\u0000\u05bd\u05bf\u0001\u0000\u0000"+
		"\u0000\u05be\u059c\u0001\u0000\u0000\u0000\u05be\u05a4\u0001\u0000\u0000"+
		"\u0000\u05bfC\u0001\u0000\u0000\u0000\u05c0\u05c5\u0005\u013b\u0000\u0000"+
		"\u05c1\u05c5\u0003\u0252\u0129\u0000\u05c2\u05c5\u0003\u024e\u0127\u0000"+
		"\u05c3\u05c5\u0003\u02b0\u0158\u0000\u05c4\u05c0\u0001\u0000\u0000\u0000"+
		"\u05c4\u05c1\u0001\u0000\u0000\u0000\u05c4\u05c2\u0001\u0000\u0000\u0000"+
		"\u05c4\u05c3\u0001\u0000\u0000\u0000\u05c5E\u0001\u0000\u0000\u0000\u05c6"+
		"\u05c7\u0005\u0460\u0000\u0000\u05c7\u05ca\u0005V\u0000\u0000\u05c8\u05cb"+
		"\u0003\u024e\u0127\u0000\u05c9\u05cb\u0003\u02b0\u0158\u0000\u05ca\u05c8"+
		"\u0001\u0000\u0000\u0000\u05ca\u05c9\u0001\u0000\u0000\u0000\u05cb\u05cc"+
		"\u0001\u0000\u0000\u0000\u05cc\u05cd\u0003H$\u0000\u05cdG\u0001\u0000"+
		"\u0000\u0000\u05ce\u05dc\u0003\u02ca\u0165\u0000\u05cf\u05dc\u0005\u00dd"+
		"\u0000\u0000\u05d0\u05dc\u0005\u00f0\u0000\u0000\u05d1\u05dc\u0005\u00f1"+
		"\u0000\u0000\u05d2\u05dc\u0005\u00f2\u0000\u0000\u05d3\u05dc\u0005\u00f3"+
		"\u0000\u0000\u05d4\u05dc\u0005\u00f4\u0000\u0000\u05d5\u05dc\u0005\u00f5"+
		"\u0000\u0000\u05d6\u05dc\u0005\u00f6\u0000\u0000\u05d7\u05dc\u0005\u00f7"+
		"\u0000\u0000\u05d8\u05dc\u0005\u00f8\u0000\u0000\u05d9\u05dc\u0005\u00f9"+
		"\u0000\u0000\u05da\u05dc\u0005\u00fa\u0000\u0000\u05db\u05ce\u0001\u0000"+
		"\u0000\u0000\u05db\u05cf\u0001\u0000\u0000\u0000\u05db\u05d0\u0001\u0000"+
		"\u0000\u0000\u05db\u05d1\u0001\u0000\u0000\u0000\u05db\u05d2\u0001\u0000"+
		"\u0000\u0000\u05db\u05d3\u0001\u0000\u0000\u0000\u05db\u05d4\u0001\u0000"+
		"\u0000\u0000\u05db\u05d5\u0001\u0000\u0000\u0000\u05db\u05d6\u0001\u0000"+
		"\u0000\u0000\u05db\u05d7\u0001\u0000\u0000\u0000\u05db\u05d8\u0001\u0000"+
		"\u0000\u0000\u05db\u05d9\u0001\u0000\u0000\u0000\u05db\u05da\u0001\u0000"+
		"\u0000\u0000\u05dcI\u0001\u0000\u0000\u0000\u05dd\u05e3\u0005\u0193\u0000"+
		"\u0000\u05de\u05e3\u0005\u018c\u0000\u0000\u05df\u05e0\u0005\u018c\u0000"+
		"\u0000\u05e0\u05e1\u0005v\u0000\u0000\u05e1\u05e3\u0005\u0266\u0000\u0000"+
		"\u05e2\u05dd\u0001\u0000\u0000\u0000\u05e2\u05de\u0001\u0000\u0000\u0000"+
		"\u05e2\u05df\u0001\u0000\u0000\u0000\u05e3K\u0001\u0000\u0000\u0000\u05e4"+
		"\u05e5\u0005\u00bb\u0000\u0000\u05e5\u05e6\u0007\u000e\u0000\u0000\u05e6"+
		"M\u0001\u0000\u0000\u0000\u05e7\u05e9\u0005\u01d3\u0000\u0000\u05e8\u05ea"+
		"\u0005\u0464\u0000\u0000\u05e9\u05e8\u0001\u0000\u0000\u0000\u05e9\u05ea"+
		"\u0001\u0000\u0000\u0000\u05ea\u05eb\u0001\u0000\u0000\u0000\u05eb\u05fe"+
		"\u0003\u0250\u0128\u0000\u05ec\u05fe\u0003L&\u0000\u05ed\u05ee\u0005\u00c0"+
		"\u0000\u0000\u05ee\u05ef\u0005\u0223\u0000\u0000\u05ef\u05fe\u0003\u0248"+
		"\u0124\u0000\u05f0\u05f1\u0005\u0170\u0000\u0000\u05f1\u05fe\u0005\u047c"+
		"\u0000\u0000\u05f2\u05fe\u0007\u000f\u0000\u0000\u05f3\u05f5\u0005\u036b"+
		"\u0000\u0000\u05f4\u05f6\u0005\u0464\u0000\u0000\u05f5\u05f4\u0001\u0000"+
		"\u0000\u0000\u05f5\u05f6\u0001\u0000\u0000\u0000\u05f6\u05f7\u0001\u0000"+
		"\u0000\u0000\u05f7\u05fe\u0005\u047c\u0000\u0000\u05f8\u05fa\u0005\u03e8"+
		"\u0000\u0000\u05f9\u05fb\u0005\u0464\u0000\u0000\u05fa\u05f9\u0001\u0000"+
		"\u0000\u0000\u05fa\u05fb\u0001\u0000\u0000\u0000\u05fb\u05fc\u0001\u0000"+
		"\u0000\u0000\u05fc\u05fe\u0005\u047c\u0000\u0000\u05fd\u05e7\u0001\u0000"+
		"\u0000\u0000\u05fd\u05ec\u0001\u0000\u0000\u0000\u05fd\u05ed\u0001\u0000"+
		"\u0000\u0000\u05fd\u05f0\u0001\u0000\u0000\u0000\u05fd\u05f2\u0001\u0000"+
		"\u0000\u0000\u05fd\u05f3\u0001\u0000\u0000\u0000\u05fd\u05f8\u0001\u0000"+
		"\u0000\u0000\u05feO\u0001\u0000\u0000\u0000\u05ff\u0601\u0007\u0010\u0000"+
		"\u0000\u0600\u05ff\u0001\u0000\u0000\u0000\u0600\u0601\u0001\u0000\u0000"+
		"\u0000\u0601\u0602\u0001\u0000\u0000\u0000\u0602\u0603\u0003\u0248\u0124"+
		"\u0000\u0603\u0604\u0003\u025c\u012e\u0000\u0604Q\u0001\u0000\u0000\u0000"+
		"\u0605\u0606\u0003\u0248\u0124\u0000\u0606\u0607\u0003\u025c\u012e\u0000"+
		"\u0607S\u0001\u0000\u0000\u0000\u0608\u0609\u0005\u0170\u0000\u0000\u0609"+
		"\u0620\u0005\u047c\u0000\u0000\u060a\u060b\u0005\u01d4\u0000\u0000\u060b"+
		"\u0620\u0005\u00a0\u0000\u0000\u060c\u060e\u0005r\u0000\u0000\u060d\u060c"+
		"\u0001\u0000\u0000\u0000\u060d\u060e\u0001\u0000\u0000\u0000\u060e\u060f"+
		"\u0001\u0000\u0000\u0000\u060f\u0620\u0005/\u0000\u0000\u0610\u0611\u0005"+
		"\u017d\u0000\u0000\u0611\u061b\u0005\u00a0\u0000\u0000\u0612\u0613\u0005"+
		"\u0209\u0000\u0000\u0613\u061b\u0005\u00a0\u0000\u0000\u0614\u0615\u0005"+
		"\u0087\u0000\u0000\u0615\u0616\u0005\u00a0\u0000\u0000\u0616\u061b\u0005"+
		"\u0184\u0000\u0000\u0617\u0618\u0005p\u0000\u0000\u0618\u0619\u0005\u00a0"+
		"\u0000\u0000\u0619\u061b\u0005\u0184\u0000\u0000\u061a\u0610\u0001\u0000"+
		"\u0000\u0000\u061a\u0612\u0001\u0000\u0000\u0000\u061a\u0614\u0001\u0000"+
		"\u0000\u0000\u061a\u0617\u0001\u0000\u0000\u0000\u061b\u0620\u0001\u0000"+
		"\u0000\u0000\u061c\u061d\u0005\u00a0\u0000\u0000\u061d\u061e\u0005\u025e"+
		"\u0000\u0000\u061e\u0620\u0007\u000b\u0000\u0000\u061f\u0608\u0001\u0000"+
		"\u0000\u0000\u061f\u060a\u0001\u0000\u0000\u0000\u061f\u060d\u0001\u0000"+
		"\u0000\u0000\u061f\u061a\u0001\u0000\u0000\u0000\u061f\u061c\u0001\u0000"+
		"\u0000\u0000\u0620U\u0001\u0000\u0000\u0000\u0621\u0622\u0005\u01be\u0000"+
		"\u0000\u0622\u0630\u0005\u047c\u0000\u0000\u0623\u0624\u0005\'\u0000\u0000"+
		"\u0624\u0630\u0005\u047c\u0000\u0000\u0625\u0626\u0005\u0299\u0000\u0000"+
		"\u0626\u0630\u0005\u047c\u0000\u0000\u0627\u0628\u0005\u0227\u0000\u0000"+
		"\u0628\u0630\u0005\u047c\u0000\u0000\u0629\u062a\u0005\u0269\u0000\u0000"+
		"\u062a\u0630\u0005\u047c\u0000\u0000\u062b\u062c\u0005\u021e\u0000\u0000"+
		"\u062c\u0630\u0005\u047c\u0000\u0000\u062d\u062e\u0005\u022d\u0000\u0000"+
		"\u062e\u0630\u0003\u024e\u0127\u0000\u062f\u0621\u0001\u0000\u0000\u0000"+
		"\u062f\u0623\u0001\u0000\u0000\u0000\u062f\u0625\u0001\u0000\u0000\u0000"+
		"\u062f\u0627\u0001\u0000\u0000\u0000\u062f\u0629\u0001\u0000\u0000\u0000"+
		"\u062f\u062b\u0001\u0000\u0000\u0000\u062f\u062d\u0001\u0000\u0000\u0000"+
		"\u0630W\u0001\u0000\u0000\u0000\u0631\u0632\u0005\u046d\u0000\u0000\u0632"+
		"\u0637\u0003Z-\u0000\u0633\u0634\u0005\u046f\u0000\u0000\u0634\u0636\u0003"+
		"Z-\u0000\u0635\u0633\u0001\u0000\u0000\u0000\u0636\u0639\u0001\u0000\u0000"+
		"\u0000\u0637\u0635\u0001\u0000\u0000\u0000\u0637\u0638\u0001\u0000\u0000"+
		"\u0000\u0638\u063a\u0001\u0000\u0000\u0000\u0639\u0637\u0001\u0000\u0000"+
		"\u0000\u063a\u063b\u0005\u046e\u0000\u0000\u063bY\u0001\u0000\u0000\u0000"+
		"\u063c\u063d\u0003\u022c\u0116\u0000\u063d\u063e\u0003\\.\u0000\u063e"+
		"\u0648\u0001\u0000\u0000\u0000\u063f\u0641\u0003`0\u0000\u0640\u0642\u0005"+
		"r\u0000\u0000\u0641\u0640\u0001\u0000\u0000\u0000\u0641\u0642\u0001\u0000"+
		"\u0000\u0000\u0642\u0644\u0001\u0000\u0000\u0000\u0643\u0645\u00059\u0000"+
		"\u0000\u0644\u0643\u0001\u0000\u0000\u0000\u0644\u0645\u0001\u0000\u0000"+
		"\u0000\u0645\u0648\u0001\u0000\u0000\u0000\u0646\u0648\u0003h4\u0000\u0647"+
		"\u063c\u0001\u0000\u0000\u0000\u0647\u063f\u0001\u0000\u0000\u0000\u0647"+
		"\u0646\u0001\u0000\u0000\u0000\u0648[\u0001\u0000\u0000\u0000\u0649\u064d"+
		"\u0003\u025c\u012e\u0000\u064a\u064c\u0003^/\u0000\u064b\u064a\u0001\u0000"+
		"\u0000\u0000\u064c\u064f\u0001\u0000\u0000\u0000\u064d\u064b\u0001\u0000"+
		"\u0000\u0000\u064d\u064e\u0001\u0000\u0000\u0000\u064e\u0651\u0001\u0000"+
		"\u0000\u0000\u064f\u064d\u0001\u0000\u0000\u0000\u0650\u0652\u0005r\u0000"+
		"\u0000\u0651\u0650\u0001\u0000\u0000\u0000\u0651\u0652\u0001\u0000\u0000"+
		"\u0000\u0652\u0654\u0001\u0000\u0000\u0000\u0653\u0655\u00059\u0000\u0000"+
		"\u0654\u0653\u0001\u0000\u0000\u0000\u0654\u0655\u0001\u0000\u0000\u0000"+
		"\u0655]\u0001\u0000\u0000\u0000\u0656\u068c\u0003\u0258\u012c\u0000\u0657"+
		"\u0658\u0005*\u0000\u0000\u0658\u068c\u0003\u027a\u013d\u0000\u0659\u068c"+
		"\u0005\u02a1\u0000\u0000\u065a\u068c\u0005\u01cb\u0000\u0000\u065b\u0660"+
		"\u0005\u0156\u0000\u0000\u065c\u065d\u0005v\u0000\u0000\u065d\u065e\u0005"+
		"\u00b8\u0000\u0000\u065e\u0660\u0003\u027c\u013e\u0000\u065f\u065b\u0001"+
		"\u0000\u0000\u0000\u065f\u065c\u0001\u0000\u0000\u0000\u0660\u068c\u0001"+
		"\u0000\u0000\u0000\u0661\u0663\u0005\u0082\u0000\u0000\u0662\u0661\u0001"+
		"\u0000\u0000\u0000\u0662\u0663\u0001\u0000\u0000\u0000\u0663\u0664\u0001"+
		"\u0000\u0000\u0000\u0664\u068c\u0005[\u0000\u0000\u0665\u0667\u0005\u00b5"+
		"\u0000\u0000\u0666\u0668\u0005[\u0000\u0000\u0667\u0666\u0001\u0000\u0000"+
		"\u0000\u0667\u0668\u0001\u0000\u0000\u0000\u0668\u068c\u0001\u0000\u0000"+
		"\u0000\u0669\u066a\u0005\u0170\u0000\u0000\u066a\u068c\u0005\u047c\u0000"+
		"\u0000\u066b\u066c\u0005\u016e\u0000\u0000\u066c\u068c\u0007\u0011\u0000"+
		"\u0000\u066d\u066e\u0005\u027c\u0000\u0000\u066e\u068c\u0007\u0012\u0000"+
		"\u0000\u066f\u068c\u0003b1\u0000\u0670\u0671\u0005\u001b\u0000\u0000\u0671"+
		"\u068c\u0003\u023a\u011d\u0000\u0672\u0673\u0005F\u0000\u0000\u0673\u0675"+
		"\u0005\b\u0000\u0000\u0674\u0672\u0001\u0000\u0000\u0000\u0674\u0675\u0001"+
		"\u0000\u0000\u0000\u0675\u0676\u0001\u0000\u0000\u0000\u0676\u0677\u0005"+
		"\f\u0000\u0000\u0677\u0678\u0005\u046d\u0000\u0000\u0678\u0679\u0003\u02b0"+
		"\u0158\u0000\u0679\u067b\u0005\u046e\u0000\u0000\u067a\u067c\u0007\u0013"+
		"\u0000\u0000\u067b\u067a\u0001\u0000\u0000\u0000\u067b\u067c\u0001\u0000"+
		"\u0000\u0000\u067c\u068c\u0001\u0000\u0000\u0000\u067d\u067e\u0005\u00ef"+
		"\u0000\u0000\u067e\u067f\u0005*\u0000\u0000\u067f\u068c\u0005\u029d\u0000"+
		"\u0000\u0680\u0682\u0005\u001e\u0000\u0000\u0681\u0683\u0003\u0248\u0124"+
		"\u0000\u0682\u0681\u0001\u0000\u0000\u0000\u0682\u0683\u0001\u0000\u0000"+
		"\u0000\u0683\u0685\u0001\u0000\u0000\u0000\u0684\u0680\u0001\u0000\u0000"+
		"\u0000\u0684\u0685\u0001\u0000\u0000\u0000\u0685\u0686\u0001\u0000\u0000"+
		"\u0000\u0686\u0687\u0005\u001a\u0000\u0000\u0687\u0688\u0005\u046d\u0000"+
		"\u0000\u0688\u0689\u0003\u02b0\u0158\u0000\u0689\u068a\u0005\u046e\u0000"+
		"\u0000\u068a\u068c\u0001\u0000\u0000\u0000\u068b\u0656\u0001\u0000\u0000"+
		"\u0000\u068b\u0657\u0001\u0000\u0000\u0000\u068b\u0659\u0001\u0000\u0000"+
		"\u0000\u068b\u065a\u0001\u0000\u0000\u0000\u068b\u065f\u0001\u0000\u0000"+
		"\u0000\u068b\u0662\u0001\u0000\u0000\u0000\u068b\u0665\u0001\u0000\u0000"+
		"\u0000\u068b\u0669\u0001\u0000\u0000\u0000\u068b\u066b\u0001\u0000\u0000"+
		"\u0000\u068b\u066d\u0001\u0000\u0000\u0000\u068b\u066f\u0001\u0000\u0000"+
		"\u0000\u068b\u0670\u0001\u0000\u0000\u0000\u068b\u0674\u0001\u0000\u0000"+
		"\u0000\u068b\u067d\u0001\u0000\u0000\u0000\u068b\u0684\u0001\u0000\u0000"+
		"\u0000\u068c_\u0001\u0000\u0000\u0000\u068d\u068f\u0005\u001e\u0000\u0000"+
		"\u068e\u0690\u0003\u0248\u0124\u0000\u068f\u068e\u0001\u0000\u0000\u0000"+
		"\u068f\u0690\u0001\u0000\u0000\u0000\u0690\u0692\u0001\u0000\u0000\u0000"+
		"\u0691\u068d\u0001\u0000\u0000\u0000\u0691\u0692\u0001\u0000\u0000\u0000"+
		"\u0692\u0693\u0001\u0000\u0000\u0000\u0693\u0694\u0005\u0082\u0000\u0000"+
		"\u0694\u0696\u0005[\u0000\u0000\u0695\u0697\u0003\u0248\u0124\u0000\u0696"+
		"\u0695\u0001\u0000\u0000\u0000\u0696\u0697\u0001\u0000\u0000\u0000\u0697"+
		"\u0699\u0001\u0000\u0000\u0000\u0698\u069a\u0003L&\u0000\u0699\u0698\u0001"+
		"\u0000\u0000\u0000\u0699\u069a\u0001\u0000\u0000\u0000\u069a\u069b\u0001"+
		"\u0000\u0000\u0000\u069b\u069f\u0003\u026e\u0137\u0000\u069c\u069e\u0003"+
		"N\'\u0000\u069d\u069c\u0001\u0000\u0000\u0000\u069e\u06a1\u0001\u0000"+
		"\u0000\u0000\u069f\u069d\u0001\u0000\u0000\u0000\u069f\u06a0\u0001\u0000"+
		"\u0000\u0000\u06a0\u06d3\u0001\u0000\u0000\u0000\u06a1\u069f\u0001\u0000"+
		"\u0000\u0000\u06a2\u06a4\u0005\u001e\u0000\u0000\u06a3\u06a5\u0003\u0248"+
		"\u0124\u0000\u06a4\u06a3\u0001\u0000\u0000\u0000\u06a4\u06a5\u0001\u0000"+
		"\u0000\u0000\u06a5\u06a7\u0001\u0000\u0000\u0000\u06a6\u06a2\u0001\u0000"+
		"\u0000\u0000\u06a6\u06a7\u0001\u0000\u0000\u0000\u06a7\u06a8\u0001\u0000"+
		"\u0000\u0000\u06a8\u06aa\u0005\u00b5\u0000\u0000\u06a9\u06ab\u0007\u0014"+
		"\u0000\u0000\u06aa\u06a9\u0001\u0000\u0000\u0000\u06aa\u06ab\u0001\u0000"+
		"\u0000\u0000\u06ab\u06ad\u0001\u0000\u0000\u0000\u06ac\u06ae\u0003\u0248"+
		"\u0124\u0000\u06ad\u06ac\u0001\u0000\u0000\u0000\u06ad\u06ae\u0001\u0000"+
		"\u0000\u0000\u06ae\u06b0\u0001\u0000\u0000\u0000\u06af\u06b1\u0003L&\u0000"+
		"\u06b0\u06af\u0001\u0000\u0000\u0000\u06b0\u06b1\u0001\u0000\u0000\u0000"+
		"\u06b1\u06b2\u0001\u0000\u0000\u0000\u06b2\u06b6\u0003\u026e\u0137\u0000"+
		"\u06b3\u06b5\u0003N\'\u0000\u06b4\u06b3\u0001\u0000\u0000\u0000\u06b5"+
		"\u06b8\u0001\u0000\u0000\u0000\u06b6\u06b4\u0001\u0000\u0000\u0000\u06b6"+
		"\u06b7\u0001\u0000\u0000\u0000\u06b7\u06d3\u0001\u0000\u0000\u0000\u06b8"+
		"\u06b6\u0001\u0000\u0000\u0000\u06b9\u06bb\u0005\u001e\u0000\u0000\u06ba"+
		"\u06bc\u0003\u0248\u0124\u0000\u06bb\u06ba\u0001\u0000\u0000\u0000\u06bb"+
		"\u06bc\u0001\u0000\u0000\u0000\u06bc\u06be\u0001\u0000\u0000\u0000\u06bd"+
		"\u06b9\u0001\u0000\u0000\u0000\u06bd\u06be\u0001\u0000\u0000\u0000\u06be"+
		"\u06bf\u0001\u0000\u0000\u0000\u06bf\u06c0\u0005C\u0000\u0000\u06c0\u06c2"+
		"\u0005[\u0000\u0000\u06c1\u06c3\u0003\u0248\u0124\u0000\u06c2\u06c1\u0001"+
		"\u0000\u0000\u0000\u06c2\u06c3\u0001\u0000\u0000\u0000\u06c3\u06c4\u0001"+
		"\u0000\u0000\u0000\u06c4\u06c5\u0003\u026e\u0137\u0000\u06c5\u06c6\u0003"+
		"b1\u0000\u06c6\u06d3\u0001\u0000\u0000\u0000\u06c7\u06c9\u0005\u001e\u0000"+
		"\u0000\u06c8\u06ca\u0003\u0248\u0124\u0000\u06c9\u06c8\u0001\u0000\u0000"+
		"\u0000\u06c9\u06ca\u0001\u0000\u0000\u0000\u06ca\u06cc\u0001\u0000\u0000"+
		"\u0000\u06cb\u06c7\u0001\u0000\u0000\u0000\u06cb\u06cc\u0001\u0000\u0000"+
		"\u0000\u06cc\u06cd\u0001\u0000\u0000\u0000\u06cd\u06ce\u0005\u001a\u0000"+
		"\u0000\u06ce\u06cf\u0005\u046d\u0000\u0000\u06cf\u06d0\u0003\u02b0\u0158"+
		"\u0000\u06d0\u06d1\u0005\u046e\u0000\u0000\u06d1\u06d3\u0001\u0000\u0000"+
		"\u0000\u06d2\u0691\u0001\u0000\u0000\u0000\u06d2\u06a6\u0001\u0000\u0000"+
		"\u0000\u06d2\u06bd\u0001\u0000\u0000\u0000\u06d2\u06cb\u0001\u0000\u0000"+
		"\u0000\u06d3a\u0001\u0000\u0000\u0000\u06d4\u06d5\u0005\u0088\u0000\u0000"+
		"\u06d5\u06d7\u0003\u0228\u0114\u0000\u06d6\u06d8\u0003\u026e\u0137\u0000"+
		"\u06d7\u06d6\u0001\u0000\u0000\u0000\u06d7\u06d8\u0001\u0000\u0000\u0000"+
		"\u06d8\u06db\u0001\u0000\u0000\u0000\u06d9\u06da\u0005m\u0000\u0000\u06da"+
		"\u06dc\u0007\u0015\u0000\u0000\u06db\u06d9\u0001\u0000\u0000\u0000\u06db"+
		"\u06dc\u0001\u0000\u0000\u0000\u06dc\u06de\u0001\u0000\u0000\u0000\u06dd"+
		"\u06df\u0003d2\u0000\u06de\u06dd\u0001\u0000\u0000\u0000\u06de\u06df\u0001"+
		"\u0000\u0000\u0000\u06dfc\u0001\u0000\u0000\u0000\u06e0\u06e1\u0005v\u0000"+
		"\u0000\u06e1\u06e2\u0005,\u0000\u0000\u06e2\u06e6\u0003f3\u0000\u06e3"+
		"\u06e4\u0005v\u0000\u0000\u06e4\u06e5\u0005\u00b8\u0000\u0000\u06e5\u06e7"+
		"\u0003f3\u0000\u06e6\u06e3\u0001\u0000\u0000\u0000\u06e6\u06e7\u0001\u0000"+
		"\u0000\u0000\u06e7\u06f1\u0001\u0000\u0000\u0000\u06e8\u06e9\u0005v\u0000"+
		"\u0000\u06e9\u06ea\u0005\u00b8\u0000\u0000\u06ea\u06ee\u0003f3\u0000\u06eb"+
		"\u06ec\u0005v\u0000\u0000\u06ec\u06ed\u0005,\u0000\u0000\u06ed\u06ef\u0003"+
		"f3\u0000\u06ee\u06eb\u0001\u0000\u0000\u0000\u06ee\u06ef\u0001\u0000\u0000"+
		"\u0000\u06ef\u06f1\u0001\u0000\u0000\u0000\u06f0\u06e0\u0001\u0000\u0000"+
		"\u0000\u06f0\u06e8\u0001\u0000\u0000\u0000\u06f1e\u0001\u0000\u0000\u0000"+
		"\u06f2\u06fb\u0005\u0090\u0000\u0000\u06f3\u06fb\u0005\u0015\u0000\u0000"+
		"\u06f4\u06f5\u0005\u0099\u0000\u0000\u06f5\u06fb\u0005t\u0000\u0000\u06f6"+
		"\u06f7\u0005\u0209\u0000\u0000\u06f7\u06fb\u0005\u014d\u0000\u0000\u06f8"+
		"\u06f9\u0005\u0099\u0000\u0000\u06f9\u06fb\u0005*\u0000\u0000\u06fa\u06f2"+
		"\u0001\u0000\u0000\u0000\u06fa\u06f3\u0001\u0000\u0000\u0000\u06fa\u06f4"+
		"\u0001\u0000\u0000\u0000\u06fa\u06f6\u0001\u0000\u0000\u0000\u06fa\u06f8"+
		"\u0001\u0000\u0000\u0000\u06fbg\u0001\u0000\u0000\u0000\u06fc\u06fe\u0007"+
		"\u0014\u0000\u0000\u06fd\u06ff\u0003\u0248\u0124\u0000\u06fe\u06fd\u0001"+
		"\u0000\u0000\u0000\u06fe\u06ff\u0001\u0000\u0000\u0000\u06ff\u0701\u0001"+
		"\u0000\u0000\u0000\u0700\u0702\u0003L&\u0000\u0701\u0700\u0001\u0000\u0000"+
		"\u0000\u0701\u0702\u0001\u0000\u0000\u0000\u0702\u0703\u0001\u0000\u0000"+
		"\u0000\u0703\u0707\u0003\u026e\u0137\u0000\u0704\u0706\u0003N\'\u0000"+
		"\u0705\u0704\u0001\u0000\u0000\u0000\u0706\u0709\u0001\u0000\u0000\u0000"+
		"\u0707\u0705\u0001\u0000\u0000\u0000\u0707\u0708\u0001\u0000\u0000\u0000"+
		"\u0708\u0719\u0001\u0000\u0000\u0000\u0709\u0707\u0001\u0000\u0000\u0000"+
		"\u070a\u070c\u0007\u0016\u0000\u0000\u070b\u070d\u0007\u0014\u0000\u0000"+
		"\u070c\u070b\u0001\u0000\u0000\u0000\u070c\u070d\u0001\u0000\u0000\u0000"+
		"\u070d\u070f\u0001\u0000\u0000\u0000\u070e\u0710\u0003\u0248\u0124\u0000"+
		"\u070f\u070e\u0001\u0000\u0000\u0000\u070f\u0710\u0001\u0000\u0000\u0000"+
		"\u0710\u0711\u0001\u0000\u0000\u0000\u0711\u0715\u0003\u026e\u0137\u0000"+
		"\u0712\u0714\u0003N\'\u0000\u0713\u0712\u0001\u0000\u0000\u0000\u0714"+
		"\u0717\u0001\u0000\u0000\u0000\u0715\u0713\u0001\u0000\u0000\u0000\u0715"+
		"\u0716\u0001\u0000\u0000\u0000\u0716\u0719\u0001\u0000\u0000\u0000\u0717"+
		"\u0715\u0001\u0000\u0000\u0000\u0718\u06fc\u0001\u0000\u0000\u0000\u0718"+
		"\u070a\u0001\u0000\u0000\u0000\u0719i\u0001\u0000\u0000\u0000\u071a\u071c"+
		"\u0005\u0199\u0000\u0000\u071b\u071d\u0005\u0464\u0000\u0000\u071c\u071b"+
		"\u0001\u0000\u0000\u0000\u071c\u071d\u0001\u0000\u0000\u0000\u071d\u071f"+
		"\u0001\u0000\u0000\u0000\u071e\u0720\u0003\u023c\u011e\u0000\u071f\u071e"+
		"\u0001\u0000\u0000\u0000\u071f\u0720\u0001\u0000\u0000\u0000\u0720\u07d4"+
		"\u0001\u0000\u0000\u0000\u0721\u0723\u0005\u036b\u0000\u0000\u0722\u0724"+
		"\u0005\u0464\u0000\u0000\u0723\u0722\u0001\u0000\u0000\u0000\u0723\u0724"+
		"\u0001\u0000\u0000\u0000\u0724\u0725\u0001\u0000\u0000\u0000\u0725\u07d4"+
		"\u0005\u047c\u0000\u0000\u0726\u0728\u0005\u0155\u0000\u0000\u0727\u0729"+
		"\u0005\u0464\u0000\u0000\u0728\u0727\u0001\u0000\u0000\u0000\u0728\u0729"+
		"\u0001\u0000\u0000\u0000\u0729\u072a\u0001\u0000\u0000\u0000\u072a\u07d4"+
		"\u0003\u024e\u0127\u0000\u072b\u072d\u0005\u0156\u0000\u0000\u072c\u072e"+
		"\u0005\u0464\u0000\u0000\u072d\u072c\u0001\u0000\u0000\u0000\u072d\u072e"+
		"\u0001\u0000\u0000\u0000\u072e\u072f\u0001\u0000\u0000\u0000\u072f\u07d4"+
		"\u0003\u024e\u0127\u0000\u0730\u0732\u0005\u0157\u0000\u0000\u0731\u0733"+
		"\u0005\u0464\u0000\u0000\u0732\u0731\u0001\u0000\u0000\u0000\u0732\u0733"+
		"\u0001\u0000\u0000\u0000\u0733\u0734\u0001\u0000\u0000\u0000\u0734\u07d4"+
		"\u0003\u024e\u0127\u0000\u0735\u0737\u0005*\u0000\u0000\u0736\u0735\u0001"+
		"\u0000\u0000\u0000\u0736\u0737\u0001\u0000\u0000\u0000\u0737\u0738\u0001"+
		"\u0000\u0000\u0000\u0738\u073a\u0003<\u001e\u0000\u0739\u073b\u0005\u0464"+
		"\u0000\u0000\u073a\u0739\u0001\u0000\u0000\u0000\u073a\u073b\u0001\u0000"+
		"\u0000\u0000\u073b\u073e\u0001\u0000\u0000\u0000\u073c\u073f\u0003\u0238"+
		"\u011c\u0000\u073d\u073f\u0005*\u0000\u0000\u073e\u073c\u0001\u0000\u0000"+
		"\u0000\u073e\u073d\u0001\u0000\u0000\u0000\u073f\u07d4\u0001\u0000\u0000"+
		"\u0000\u0740\u0742\u0007\u0017\u0000\u0000\u0741\u0743\u0005\u0464\u0000"+
		"\u0000\u0742\u0741\u0001\u0000\u0000\u0000\u0742\u0743\u0001\u0000\u0000"+
		"\u0000\u0743\u0744\u0001\u0000\u0000\u0000\u0744\u07d4\u0007\u0018\u0000"+
		"\u0000\u0745\u0747\u0005*\u0000\u0000\u0746\u0745\u0001\u0000\u0000\u0000"+
		"\u0746\u0747\u0001\u0000\u0000\u0000\u0747\u0748\u0001\u0000\u0000\u0000"+
		"\u0748\u074a\u0005\u001b\u0000\u0000\u0749\u074b\u0005\u0464\u0000\u0000"+
		"\u074a\u0749\u0001\u0000\u0000\u0000\u074a\u074b\u0001\u0000\u0000\u0000"+
		"\u074b\u074c\u0001\u0000\u0000\u0000\u074c\u07d4\u0003\u023a\u011d\u0000"+
		"\u074d\u074f\u0005\u0170\u0000\u0000\u074e\u0750\u0005\u0464\u0000\u0000"+
		"\u074f\u074e\u0001\u0000\u0000\u0000\u074f\u0750\u0001\u0000\u0000\u0000"+
		"\u0750\u0751\u0001\u0000\u0000\u0000\u0751\u07d4\u0005\u047c\u0000\u0000"+
		"\u0752\u0754\u0005\u0175\u0000\u0000\u0753\u0755\u0005\u0464\u0000\u0000"+
		"\u0754\u0753\u0001\u0000\u0000\u0000\u0754\u0755\u0001\u0000\u0000\u0000"+
		"\u0755\u0756\u0001\u0000\u0000\u0000\u0756\u07d4\u0007\u0019\u0000\u0000"+
		"\u0757\u0759\u0005\u0178\u0000\u0000\u0758\u075a\u0005\u0464\u0000\u0000"+
		"\u0759\u0758\u0001\u0000\u0000\u0000\u0759\u075a\u0001\u0000\u0000\u0000"+
		"\u075a\u075b\u0001\u0000\u0000\u0000\u075b\u07d4\u0005\u047c\u0000\u0000"+
		"\u075c\u075d\u0007\u001a\u0000\u0000\u075d\u075f\u0005\u018b\u0000\u0000"+
		"\u075e\u0760\u0005\u0464\u0000\u0000\u075f\u075e\u0001\u0000\u0000\u0000"+
		"\u075f\u0760\u0001\u0000\u0000\u0000\u0760\u0761\u0001\u0000\u0000\u0000"+
		"\u0761\u07d4\u0005\u047c\u0000\u0000\u0762\u0764\u0005\u0189\u0000\u0000"+
		"\u0763\u0765\u0005\u0464\u0000\u0000\u0764\u0763\u0001\u0000\u0000\u0000"+
		"\u0764\u0765\u0001\u0000\u0000\u0000\u0765\u0766\u0001\u0000\u0000\u0000"+
		"\u0766\u07d4\u0007\u0018\u0000\u0000\u0767\u0769\u0005\u0195\u0000\u0000"+
		"\u0768\u076a\u0005\u0464\u0000\u0000\u0769\u0768\u0001\u0000\u0000\u0000"+
		"\u0769\u076a\u0001\u0000\u0000\u0000\u076a\u076b\u0001\u0000\u0000\u0000"+
		"\u076b\u07d4\u0005\u047c\u0000\u0000\u076c\u076e\u0007\u001b\u0000\u0000"+
		"\u076d\u076f\u0005\u0464\u0000\u0000\u076e\u076d\u0001\u0000\u0000\u0000"+
		"\u076e\u076f\u0001\u0000\u0000\u0000\u076f\u0770\u0001\u0000\u0000\u0000"+
		"\u0770\u07d4\u0007\u0018\u0000\u0000\u0771\u0773\u0007\u001c\u0000\u0000"+
		"\u0772\u0774\u0005\u0464\u0000\u0000\u0773\u0772\u0001\u0000\u0000\u0000"+
		"\u0773\u0774\u0001\u0000\u0000\u0000\u0774\u0775\u0001\u0000\u0000\u0000"+
		"\u0775\u07d4\u0003\u024e\u0127\u0000\u0776\u0778\u0005\u0196\u0000\u0000"+
		"\u0777\u0779\u0005\u0464\u0000\u0000\u0778\u0777\u0001\u0000\u0000\u0000"+
		"\u0778\u0779\u0001\u0000\u0000\u0000\u0779\u077a\u0001\u0000\u0000\u0000"+
		"\u077a\u07d4\u0003\u024e\u0127\u0000\u077b\u077c\u0005Q\u0000\u0000\u077c"+
		"\u077e\u0005\u018b\u0000\u0000\u077d\u077f\u0005\u0464\u0000\u0000\u077e"+
		"\u077d\u0001\u0000\u0000\u0000\u077e\u077f\u0001\u0000\u0000\u0000\u077f"+
		"\u0780\u0001\u0000\u0000\u0000\u0780\u07d4\u0005\u047c\u0000\u0000\u0781"+
		"\u0783\u0005\u01c7\u0000\u0000\u0782\u0784\u0005\u0464\u0000\u0000\u0783"+
		"\u0782\u0001\u0000\u0000\u0000\u0783\u0784\u0001\u0000\u0000\u0000\u0784"+
		"\u0785\u0001\u0000\u0000\u0000\u0785\u07d4\u0007\u001d\u0000\u0000\u0786"+
		"\u0788\u0005\u01d3\u0000\u0000\u0787\u0789\u0005\u0464\u0000\u0000\u0788"+
		"\u0787\u0001\u0000\u0000\u0000\u0788\u0789\u0001\u0000\u0000\u0000\u0789"+
		"\u078a\u0001\u0000\u0000\u0000\u078a\u07d4\u0003\u0250\u0128\u0000\u078b"+
		"\u078d\u0005\u01f4\u0000\u0000\u078c\u078e\u0005\u0464\u0000\u0000\u078d"+
		"\u078c\u0001\u0000\u0000\u0000\u078d\u078e\u0001\u0000\u0000\u0000\u078e"+
		"\u078f\u0001\u0000\u0000\u0000\u078f\u07d4\u0003\u024e\u0127\u0000\u0790"+
		"\u0792\u0005\u01fe\u0000\u0000\u0791\u0793\u0005\u0464\u0000\u0000\u0792"+
		"\u0791\u0001\u0000\u0000\u0000\u0792\u0793\u0001\u0000\u0000\u0000\u0793"+
		"\u0794\u0001\u0000\u0000\u0000\u0794\u07d4\u0003\u024e\u0127\u0000\u0795"+
		"\u0797\u0005\u021f\u0000\u0000\u0796\u0798\u0005\u0464\u0000\u0000\u0797"+
		"\u0796\u0001\u0000\u0000\u0000\u0797\u0798\u0001\u0000\u0000\u0000\u0798"+
		"\u0799\u0001\u0000\u0000\u0000\u0799\u07d4\u0007\r\u0000\u0000\u079a\u079c"+
		"\u0005\u0227\u0000\u0000\u079b\u079d\u0005\u0464\u0000\u0000\u079c\u079b"+
		"\u0001\u0000\u0000\u0000\u079c\u079d\u0001\u0000\u0000\u0000\u079d\u079e"+
		"\u0001\u0000\u0000\u0000\u079e\u07d4\u0005\u047c\u0000\u0000\u079f\u07a1"+
		"\u0005\u025a\u0000\u0000\u07a0\u07a2\u0005\u0464\u0000\u0000\u07a1\u07a0"+
		"\u0001\u0000\u0000\u0000\u07a1\u07a2\u0001\u0000\u0000\u0000\u07a2\u07a3"+
		"\u0001\u0000\u0000\u0000\u07a3\u07d4\u0007\u001e\u0000\u0000\u07a4\u07a5"+
		"\u0005\u0275\u0000\u0000\u07a5\u07d4\u0005\u028d\u0000\u0000\u07a6\u07a8"+
		"\u0005\u03e8\u0000\u0000\u07a7\u07a9\u0005\u0464\u0000\u0000\u07a8\u07a7"+
		"\u0001\u0000\u0000\u0000\u07a8\u07a9\u0001\u0000\u0000\u0000\u07a9\u07aa"+
		"\u0001\u0000\u0000\u0000\u07aa\u07d4\u0005\u047c\u0000\u0000\u07ab\u07ad"+
		"\u0005\u0277\u0000\u0000\u07ac\u07ae\u0005\u0464\u0000\u0000\u07ad\u07ac"+
		"\u0001\u0000\u0000\u0000\u07ad\u07ae\u0001\u0000\u0000\u0000\u07ae\u07af"+
		"\u0001\u0000\u0000\u0000\u07af\u07d4\u0007\r\u0000\u0000\u07b0\u07b2\u0005"+
		"\u0278\u0000\u0000\u07b1\u07b3\u0005\u0464\u0000\u0000\u07b2\u07b1\u0001"+
		"\u0000\u0000\u0000\u07b2\u07b3\u0001\u0000\u0000\u0000\u07b3\u07b4\u0001"+
		"\u0000\u0000\u0000\u07b4\u07d4\u0007\r\u0000\u0000\u07b5\u07b7\u0005\u0279"+
		"\u0000\u0000\u07b6\u07b8\u0005\u0464\u0000\u0000\u07b7\u07b6\u0001\u0000"+
		"\u0000\u0000\u07b7\u07b8\u0001\u0000\u0000\u0000\u07b8\u07bb\u0001\u0000"+
		"\u0000\u0000\u07b9\u07bc\u0005*\u0000\u0000\u07ba\u07bc\u0003\u024e\u0127"+
		"\u0000\u07bb\u07b9\u0001\u0000\u0000\u0000\u07bb\u07ba\u0001\u0000\u0000"+
		"\u0000\u07bc\u07d4\u0001\u0000\u0000\u0000\u07bd\u07be\u0005\u0287\u0000"+
		"\u0000\u07be\u07c0\u0003\u0248\u0124\u0000\u07bf\u07c1\u0003n7\u0000\u07c0"+
		"\u07bf\u0001\u0000\u0000\u0000\u07c0\u07c1\u0001\u0000\u0000\u0000\u07c1"+
		"\u07d4\u0001\u0000\u0000\u0000\u07c2\u07c3\u0005\u0288\u0000\u0000\u07c3"+
		"\u07c4\u0005\u0464\u0000\u0000\u07c4\u07d4\u0003l6\u0000\u07c5\u07d4\u0003"+
		"n7\u0000\u07c6\u07c8\u0005\u028e\u0000\u0000\u07c7\u07c9\u0005\u0464\u0000"+
		"\u0000\u07c8\u07c7\u0001\u0000\u0000\u0000\u07c8\u07c9\u0001\u0000\u0000"+
		"\u0000\u07c9\u07ca\u0001\u0000\u0000\u0000\u07ca\u07d4\u0007\u0018\u0000"+
		"\u0000\u07cb\u07cd\u0005\u00b4\u0000\u0000\u07cc\u07ce\u0005\u0464\u0000"+
		"\u0000\u07cd\u07cc\u0001\u0000\u0000\u0000\u07cd\u07ce\u0001\u0000\u0000"+
		"\u0000\u07ce\u07cf\u0001\u0000\u0000\u0000\u07cf\u07d0\u0005\u046d\u0000"+
		"\u0000\u07d0\u07d1\u0003\u026c\u0136\u0000\u07d1\u07d2\u0005\u046e\u0000"+
		"\u0000\u07d2\u07d4\u0001\u0000\u0000\u0000\u07d3\u071a\u0001\u0000\u0000"+
		"\u0000\u07d3\u0721\u0001\u0000\u0000\u0000\u07d3\u0726\u0001\u0000\u0000"+
		"\u0000\u07d3\u072b\u0001\u0000\u0000\u0000\u07d3\u0730\u0001\u0000\u0000"+
		"\u0000\u07d3\u0736\u0001\u0000\u0000\u0000\u07d3\u0740\u0001\u0000\u0000"+
		"\u0000\u07d3\u0746\u0001\u0000\u0000\u0000\u07d3\u074d\u0001\u0000\u0000"+
		"\u0000\u07d3\u0752\u0001\u0000\u0000\u0000\u07d3\u0757\u0001\u0000\u0000"+
		"\u0000\u07d3\u075c\u0001\u0000\u0000\u0000\u07d3\u0762\u0001\u0000\u0000"+
		"\u0000\u07d3\u0767\u0001\u0000\u0000\u0000\u07d3\u076c\u0001\u0000\u0000"+
		"\u0000\u07d3\u0771\u0001\u0000\u0000\u0000\u07d3\u0776\u0001\u0000\u0000"+
		"\u0000\u07d3\u077b\u0001\u0000\u0000\u0000\u07d3\u0781\u0001\u0000\u0000"+
		"\u0000\u07d3\u0786\u0001\u0000\u0000\u0000\u07d3\u078b\u0001\u0000\u0000"+
		"\u0000\u07d3\u0790\u0001\u0000\u0000\u0000\u07d3\u0795\u0001\u0000\u0000"+
		"\u0000\u07d3\u079a\u0001\u0000\u0000\u0000\u07d3\u079f\u0001\u0000\u0000"+
		"\u0000\u07d3\u07a4\u0001\u0000\u0000\u0000\u07d3\u07a6\u0001\u0000\u0000"+
		"\u0000\u07d3\u07ab\u0001\u0000\u0000\u0000\u07d3\u07b0\u0001\u0000\u0000"+
		"\u0000\u07d3\u07b5\u0001\u0000\u0000\u0000\u07d3\u07bd\u0001\u0000\u0000"+
		"\u0000\u07d3\u07c2\u0001\u0000\u0000\u0000\u07d3\u07c5\u0001\u0000\u0000"+
		"\u0000\u07d3\u07c6\u0001\u0000\u0000\u0000\u07d3\u07cb\u0001\u0000\u0000"+
		"\u0000\u07d4k\u0001\u0000\u0000\u0000\u07d5\u07d6\u0007\u001f\u0000\u0000"+
		"\u07d6m\u0001\u0000\u0000\u0000\u07d7\u07d8\u0005\u027c\u0000\u0000\u07d8"+
		"\u07d9\u0007\u0012\u0000\u0000\u07d9o\u0001\u0000\u0000\u0000\u07da\u07db"+
		"\u0005\u0081\u0000\u0000\u07db\u07dc\u0005\u0013\u0000\u0000\u07dc\u07df"+
		"\u0003r9\u0000\u07dd\u07de\u0005\u0226\u0000\u0000\u07de\u07e0\u0003\u024e"+
		"\u0127\u0000\u07df\u07dd\u0001\u0000\u0000\u0000\u07df\u07e0\u0001\u0000"+
		"\u0000\u0000\u07e0\u07e8\u0001\u0000\u0000\u0000\u07e1\u07e2\u0005\u0281"+
		"\u0000\u0000\u07e2\u07e3\u0005\u0013\u0000\u0000\u07e3\u07e6\u0003t:\u0000"+
		"\u07e4\u07e5\u0005\u0282\u0000\u0000\u07e5\u07e7\u0003\u024e\u0127\u0000"+
		"\u07e6\u07e4\u0001\u0000\u0000\u0000\u07e6\u07e7\u0001\u0000\u0000\u0000"+
		"\u07e7\u07e9\u0001\u0000\u0000\u0000\u07e8\u07e1\u0001\u0000\u0000\u0000"+
		"\u07e8\u07e9\u0001\u0000\u0000\u0000\u07e9\u07f5\u0001\u0000\u0000\u0000"+
		"\u07ea\u07eb\u0005\u046d\u0000\u0000\u07eb\u07f0\u0003v;\u0000\u07ec\u07ed"+
		"\u0005\u046f\u0000\u0000\u07ed\u07ef\u0003v;\u0000\u07ee\u07ec\u0001\u0000"+
		"\u0000\u0000\u07ef\u07f2\u0001\u0000\u0000\u0000\u07f0\u07ee\u0001\u0000"+
		"\u0000\u0000\u07f0\u07f1\u0001\u0000\u0000\u0000\u07f1\u07f3\u0001\u0000"+
		"\u0000\u0000\u07f2\u07f0\u0001\u0000\u0000\u0000\u07f3\u07f4\u0005\u046e"+
		"\u0000\u0000\u07f4\u07f6\u0001\u0000\u0000\u0000\u07f5\u07ea\u0001\u0000"+
		"\u0000\u0000\u07f5\u07f6\u0001\u0000\u0000\u0000\u07f6q\u0001\u0000\u0000"+
		"\u0000\u07f7\u07f9\u0005d\u0000\u0000\u07f8\u07f7\u0001\u0000\u0000\u0000"+
		"\u07f8\u07f9\u0001\u0000\u0000\u0000\u07f9\u07fa\u0001\u0000\u0000\u0000"+
		"\u07fa\u07fb\u0005\u01bb\u0000\u0000\u07fb\u07fc\u0005\u046d\u0000\u0000"+
		"\u07fc\u07fd\u0003\u02b0\u0158\u0000\u07fd\u07fe\u0005\u046e\u0000\u0000"+
		"\u07fe\u0826\u0001\u0000\u0000\u0000\u07ff\u0801\u0005d\u0000\u0000\u0800"+
		"\u07ff\u0001\u0000\u0000\u0000\u0800\u0801\u0001\u0000\u0000\u0000\u0801"+
		"\u0802\u0001\u0000\u0000\u0000\u0802\u0806\u0005[\u0000\u0000\u0803\u0804"+
		"\u0005\u0150\u0000\u0000\u0804\u0805\u0005\u0464\u0000\u0000\u0805\u0807"+
		"\u0007 \u0000\u0000\u0806\u0803\u0001\u0000\u0000\u0000\u0806\u0807\u0001"+
		"\u0000\u0000\u0000\u0807\u0808\u0001\u0000\u0000\u0000\u0808\u080a\u0005"+
		"\u046d\u0000\u0000\u0809\u080b\u0003\u0268\u0134\u0000\u080a\u0809\u0001"+
		"\u0000\u0000\u0000\u080a\u080b\u0001\u0000\u0000\u0000\u080b\u080c\u0001"+
		"\u0000\u0000\u0000\u080c\u0826\u0005\u046e\u0000\u0000\u080d\u0817\u0005"+
		"\u0085\u0000\u0000\u080e\u080f\u0005\u046d\u0000\u0000\u080f\u0810\u0003"+
		"\u02b0\u0158\u0000\u0810\u0811\u0005\u046e\u0000\u0000\u0811\u0818\u0001"+
		"\u0000\u0000\u0000\u0812\u0813\u0005\u016d\u0000\u0000\u0813\u0814\u0005"+
		"\u046d\u0000\u0000\u0814\u0815\u0003\u0268\u0134\u0000\u0815\u0816\u0005"+
		"\u046e\u0000\u0000\u0816\u0818\u0001\u0000\u0000\u0000\u0817\u080e\u0001"+
		"\u0000\u0000\u0000\u0817\u0812\u0001\u0000\u0000\u0000\u0818\u0826\u0001"+
		"\u0000\u0000\u0000\u0819\u0823\u0005\u01d9\u0000\u0000\u081a\u081b\u0005"+
		"\u046d\u0000\u0000\u081b\u081c\u0003\u02b0\u0158\u0000\u081c\u081d\u0005"+
		"\u046e\u0000\u0000\u081d\u0824\u0001\u0000\u0000\u0000\u081e\u081f\u0005"+
		"\u016d\u0000\u0000\u081f\u0820\u0005\u046d\u0000\u0000\u0820\u0821\u0003"+
		"\u0268\u0134\u0000\u0821\u0822\u0005\u046e\u0000\u0000\u0822\u0824\u0001"+
		"\u0000\u0000\u0000\u0823\u081a\u0001\u0000\u0000\u0000\u0823\u081e\u0001"+
		"\u0000\u0000\u0000\u0824\u0826\u0001\u0000\u0000\u0000\u0825\u07f8\u0001"+
		"\u0000\u0000\u0000\u0825\u0800\u0001\u0000\u0000\u0000\u0825\u080d\u0001"+
		"\u0000\u0000\u0000\u0825\u0819\u0001\u0000\u0000\u0000\u0826s\u0001\u0000"+
		"\u0000\u0000\u0827\u0829\u0005d\u0000\u0000\u0828\u0827\u0001\u0000\u0000"+
		"\u0000\u0828\u0829\u0001\u0000\u0000\u0000\u0829\u082a\u0001\u0000\u0000"+
		"\u0000\u082a\u082b\u0005\u01bb\u0000\u0000\u082b\u082c\u0005\u046d\u0000"+
		"\u0000\u082c\u082d\u0003\u02b0\u0158\u0000\u082d\u082e\u0005\u046e\u0000"+
		"\u0000\u082e\u083d\u0001\u0000\u0000\u0000\u082f\u0831\u0005d\u0000\u0000"+
		"\u0830\u082f\u0001\u0000\u0000\u0000\u0830\u0831\u0001\u0000\u0000\u0000"+
		"\u0831\u0832\u0001\u0000\u0000\u0000\u0832\u0836\u0005[\u0000\u0000\u0833"+
		"\u0834\u0005\u0150\u0000\u0000\u0834\u0835\u0005\u0464\u0000\u0000\u0835"+
		"\u0837\u0007 \u0000\u0000\u0836\u0833\u0001\u0000\u0000\u0000\u0836\u0837"+
		"\u0001\u0000\u0000\u0000\u0837\u0838\u0001\u0000\u0000\u0000\u0838\u0839"+
		"\u0005\u046d\u0000\u0000\u0839\u083a\u0003\u0268\u0134\u0000\u083a\u083b"+
		"\u0005\u046e\u0000\u0000\u083b\u083d\u0001\u0000\u0000\u0000\u083c\u0828"+
		"\u0001\u0000\u0000\u0000\u083c\u0830\u0001\u0000\u0000\u0000\u083du\u0001"+
		"\u0000\u0000\u0000\u083e\u083f\u0005\u0081\u0000\u0000\u083f\u0840\u0003"+
		"\u0248\u0124\u0000\u0840\u0841\u0005\u00bc\u0000\u0000\u0841\u0842\u0005"+
		"\u01d7\u0000\u0000\u0842\u0843\u0005\u028b\u0000\u0000\u0843\u0844\u0005"+
		"\u046d\u0000\u0000\u0844\u0849\u0003x<\u0000\u0845\u0846\u0005\u046f\u0000"+
		"\u0000\u0846\u0848\u0003x<\u0000\u0847\u0845\u0001\u0000\u0000\u0000\u0848"+
		"\u084b\u0001\u0000\u0000\u0000\u0849\u0847\u0001\u0000\u0000\u0000\u0849"+
		"\u084a\u0001\u0000\u0000\u0000\u084a\u084c\u0001\u0000\u0000\u0000\u084b"+
		"\u0849\u0001\u0000\u0000\u0000\u084c\u0850\u0005\u046e\u0000\u0000\u084d"+
		"\u084f\u0003~?\u0000\u084e\u084d\u0001\u0000\u0000\u0000\u084f\u0852\u0001"+
		"\u0000\u0000\u0000\u0850\u084e\u0001\u0000\u0000\u0000\u0850\u0851\u0001"+
		"\u0000\u0000\u0000\u0851\u085e\u0001\u0000\u0000\u0000\u0852\u0850\u0001"+
		"\u0000\u0000\u0000\u0853\u0854\u0005\u046d\u0000\u0000\u0854\u0859\u0003"+
		"|>\u0000\u0855\u0856\u0005\u046f\u0000\u0000\u0856\u0858\u0003|>\u0000"+
		"\u0857\u0855\u0001\u0000\u0000\u0000\u0858\u085b\u0001\u0000\u0000\u0000"+
		"\u0859\u0857\u0001\u0000\u0000\u0000\u0859\u085a\u0001\u0000\u0000\u0000"+
		"\u085a\u085c\u0001\u0000\u0000\u0000\u085b\u0859\u0001\u0000\u0000\u0000"+
		"\u085c\u085d\u0005\u046e\u0000\u0000\u085d\u085f\u0001\u0000\u0000\u0000"+
		"\u085e\u0853\u0001\u0000\u0000\u0000\u085e\u085f\u0001\u0000\u0000\u0000"+
		"\u085f\u08d1\u0001\u0000\u0000\u0000\u0860\u0861\u0005\u0081\u0000\u0000"+
		"\u0861\u0862\u0003\u0248\u0124\u0000\u0862\u0863\u0005\u00bc\u0000\u0000"+
		"\u0863\u0864\u0005\u01d7\u0000\u0000\u0864\u0865\u0005\u028b\u0000\u0000"+
		"\u0865\u0869\u0003x<\u0000\u0866\u0868\u0003~?\u0000\u0867\u0866\u0001"+
		"\u0000\u0000\u0000\u0868\u086b\u0001\u0000\u0000\u0000\u0869\u0867\u0001"+
		"\u0000\u0000\u0000\u0869\u086a\u0001\u0000\u0000\u0000\u086a\u0877\u0001"+
		"\u0000\u0000\u0000\u086b\u0869\u0001\u0000\u0000\u0000\u086c\u086d\u0005"+
		"\u046d\u0000\u0000\u086d\u0872\u0003|>\u0000\u086e\u086f\u0005\u046f\u0000"+
		"\u0000\u086f\u0871\u0003|>\u0000\u0870\u086e\u0001\u0000\u0000\u0000\u0871"+
		"\u0874\u0001\u0000\u0000\u0000\u0872\u0870\u0001\u0000\u0000\u0000\u0872"+
		"\u0873\u0001\u0000\u0000\u0000\u0873\u0875\u0001\u0000\u0000\u0000\u0874"+
		"\u0872\u0001\u0000\u0000\u0000\u0875\u0876\u0005\u046e\u0000\u0000\u0876"+
		"\u0878\u0001\u0000\u0000\u0000\u0877\u086c\u0001\u0000\u0000\u0000\u0877"+
		"\u0878\u0001\u0000\u0000\u0000\u0878\u08d1\u0001\u0000\u0000\u0000\u0879"+
		"\u087a\u0005\u0081\u0000\u0000\u087a\u087b\u0003\u0248\u0124\u0000\u087b"+
		"\u087c\u0005\u00bc\u0000\u0000\u087c\u087d\u0005P\u0000\u0000\u087d\u087e"+
		"\u0005\u046d\u0000\u0000\u087e\u0883\u0003x<\u0000\u087f\u0880\u0005\u046f"+
		"\u0000\u0000\u0880\u0882\u0003x<\u0000\u0881\u087f\u0001\u0000\u0000\u0000"+
		"\u0882\u0885\u0001\u0000\u0000\u0000\u0883\u0881\u0001\u0000\u0000\u0000"+
		"\u0883\u0884\u0001\u0000\u0000\u0000\u0884\u0886\u0001\u0000\u0000\u0000"+
		"\u0885\u0883\u0001\u0000\u0000\u0000\u0886\u088a\u0005\u046e\u0000\u0000"+
		"\u0887\u0889\u0003~?\u0000\u0888\u0887\u0001\u0000\u0000\u0000\u0889\u088c"+
		"\u0001\u0000\u0000\u0000\u088a\u0888\u0001\u0000\u0000\u0000\u088a\u088b"+
		"\u0001\u0000\u0000\u0000\u088b\u0898\u0001\u0000\u0000\u0000\u088c\u088a"+
		"\u0001\u0000\u0000\u0000\u088d\u088e\u0005\u046d\u0000\u0000\u088e\u0893"+
		"\u0003|>\u0000\u088f\u0890\u0005\u046f\u0000\u0000\u0890\u0892\u0003|"+
		">\u0000\u0891\u088f\u0001\u0000\u0000\u0000\u0892\u0895\u0001\u0000\u0000"+
		"\u0000\u0893\u0891\u0001\u0000\u0000\u0000\u0893\u0894\u0001\u0000\u0000"+
		"\u0000\u0894\u0896\u0001\u0000\u0000\u0000\u0895\u0893\u0001\u0000\u0000"+
		"\u0000\u0896\u0897\u0005\u046e\u0000\u0000\u0897\u0899\u0001\u0000\u0000"+
		"\u0000\u0898\u088d\u0001\u0000\u0000\u0000\u0898\u0899\u0001\u0000\u0000"+
		"\u0000\u0899\u08d1\u0001\u0000\u0000\u0000\u089a\u089b\u0005\u0081\u0000"+
		"\u0000\u089b\u089c\u0003\u0248\u0124\u0000\u089c\u089d\u0005\u00bc\u0000"+
		"\u0000\u089d\u089e\u0005P\u0000\u0000\u089e\u089f\u0005\u046d\u0000\u0000"+
		"\u089f\u08a4\u0003z=\u0000\u08a0\u08a1\u0005\u046f\u0000\u0000\u08a1\u08a3"+
		"\u0003z=\u0000\u08a2\u08a0\u0001\u0000\u0000\u0000\u08a3\u08a6\u0001\u0000"+
		"\u0000\u0000\u08a4\u08a2\u0001\u0000\u0000\u0000\u08a4\u08a5\u0001\u0000"+
		"\u0000\u0000\u08a5\u08a7\u0001\u0000\u0000\u0000\u08a6\u08a4\u0001\u0000"+
		"\u0000\u0000\u08a7\u08ab\u0005\u046e\u0000\u0000\u08a8\u08aa\u0003~?\u0000"+
		"\u08a9\u08a8\u0001\u0000\u0000\u0000\u08aa\u08ad\u0001\u0000\u0000\u0000"+
		"\u08ab\u08a9\u0001\u0000\u0000\u0000\u08ab\u08ac\u0001\u0000\u0000\u0000"+
		"\u08ac\u08b9\u0001\u0000\u0000\u0000\u08ad\u08ab\u0001\u0000\u0000\u0000"+
		"\u08ae\u08af\u0005\u046d\u0000\u0000\u08af\u08b4\u0003|>\u0000\u08b0\u08b1"+
		"\u0005\u046f\u0000\u0000\u08b1\u08b3\u0003|>\u0000\u08b2\u08b0\u0001\u0000"+
		"\u0000\u0000\u08b3\u08b6\u0001\u0000\u0000\u0000\u08b4\u08b2\u0001\u0000"+
		"\u0000\u0000\u08b4\u08b5\u0001\u0000\u0000\u0000\u08b5\u08b7\u0001\u0000"+
		"\u0000\u0000\u08b6\u08b4\u0001\u0000\u0000\u0000\u08b7\u08b8\u0005\u046e"+
		"\u0000\u0000\u08b8\u08ba\u0001\u0000\u0000\u0000\u08b9\u08ae\u0001\u0000"+
		"\u0000\u0000\u08b9\u08ba\u0001\u0000\u0000\u0000\u08ba\u08d1\u0001\u0000"+
		"\u0000\u0000\u08bb\u08bc\u0005\u0081\u0000\u0000\u08bc\u08c0\u0003\u0248"+
		"\u0124\u0000\u08bd\u08bf\u0003~?\u0000\u08be\u08bd\u0001\u0000\u0000\u0000"+
		"\u08bf\u08c2\u0001\u0000\u0000\u0000\u08c0\u08be\u0001\u0000\u0000\u0000"+
		"\u08c0\u08c1\u0001\u0000\u0000\u0000\u08c1\u08ce\u0001\u0000\u0000\u0000"+
		"\u08c2\u08c0\u0001\u0000\u0000\u0000\u08c3\u08c4\u0005\u046d\u0000\u0000"+
		"\u08c4\u08c9\u0003|>\u0000\u08c5\u08c6\u0005\u046f\u0000\u0000\u08c6\u08c8"+
		"\u0003|>\u0000\u08c7\u08c5\u0001\u0000\u0000\u0000\u08c8\u08cb\u0001\u0000"+
		"\u0000\u0000\u08c9\u08c7\u0001\u0000\u0000\u0000\u08c9\u08ca\u0001\u0000"+
		"\u0000\u0000\u08ca\u08cc\u0001\u0000\u0000\u0000\u08cb\u08c9\u0001\u0000"+
		"\u0000\u0000\u08cc\u08cd\u0005\u046e\u0000\u0000\u08cd\u08cf\u0001\u0000"+
		"\u0000\u0000\u08ce\u08c3\u0001\u0000\u0000\u0000\u08ce\u08cf\u0001\u0000"+
		"\u0000\u0000\u08cf\u08d1\u0001\u0000\u0000\u0000\u08d0\u083e\u0001\u0000"+
		"\u0000\u0000\u08d0\u0860\u0001\u0000\u0000\u0000\u08d0\u0879\u0001\u0000"+
		"\u0000\u0000\u08d0\u089a\u0001\u0000\u0000\u0000\u08d0\u08bb\u0001\u0000"+
		"\u0000\u0000\u08d1w\u0001\u0000\u0000\u0000\u08d2\u08d6\u0003\u025a\u012d"+
		"\u0000\u08d3\u08d6\u0003\u02b0\u0158\u0000\u08d4\u08d6\u0005n\u0000\u0000"+
		"\u08d5\u08d2\u0001\u0000\u0000\u0000\u08d5\u08d3\u0001\u0000\u0000\u0000"+
		"\u08d5\u08d4\u0001\u0000\u0000\u0000\u08d6y\u0001\u0000\u0000\u0000\u08d7"+
		"\u08d8\u0005\u046d\u0000\u0000\u08d8\u08db\u0003x<\u0000\u08d9\u08da\u0005"+
		"\u046f\u0000\u0000\u08da\u08dc\u0003x<\u0000\u08db\u08d9\u0001\u0000\u0000"+
		"\u0000\u08dc\u08dd\u0001\u0000\u0000\u0000\u08dd\u08db\u0001\u0000\u0000"+
		"\u0000\u08dd\u08de\u0001\u0000\u0000\u0000\u08de\u08df\u0001\u0000\u0000"+
		"\u0000\u08df\u08e0\u0005\u046e\u0000\u0000\u08e0{\u0001\u0000\u0000\u0000"+
		"\u08e1\u08e2\u0005\u0281\u0000\u0000\u08e2\u08e6\u0003\u0248\u0124\u0000"+
		"\u08e3\u08e5\u0003~?\u0000\u08e4\u08e3\u0001\u0000\u0000\u0000\u08e5\u08e8"+
		"\u0001\u0000\u0000\u0000\u08e6\u08e4\u0001\u0000\u0000\u0000\u08e6\u08e7"+
		"\u0001\u0000\u0000\u0000\u08e7}\u0001\u0000\u0000\u0000\u08e8\u08e6\u0001"+
		"\u0000\u0000\u0000\u08e9\u08eb\u0005*\u0000\u0000\u08ea\u08e9\u0001\u0000"+
		"\u0000\u0000\u08ea\u08eb\u0001\u0000\u0000\u0000\u08eb\u08ed\u0001\u0000"+
		"\u0000\u0000\u08ec\u08ee\u0005\u027c\u0000\u0000\u08ed\u08ec\u0001\u0000"+
		"\u0000\u0000\u08ed\u08ee\u0001\u0000\u0000\u0000\u08ee\u08ef\u0001\u0000"+
		"\u0000\u0000\u08ef\u08f1\u0005\u0199\u0000\u0000\u08f0\u08f2\u0005\u0464"+
		"\u0000\u0000\u08f1\u08f0\u0001\u0000\u0000\u0000\u08f1\u08f2\u0001\u0000"+
		"\u0000\u0000\u08f2\u08f3\u0001\u0000\u0000\u0000\u08f3\u091a\u0003\u023c"+
		"\u011e\u0000\u08f4\u08f6\u0005\u0170\u0000\u0000\u08f5\u08f7\u0005\u0464"+
		"\u0000\u0000\u08f6\u08f5\u0001\u0000\u0000\u0000\u08f6\u08f7\u0001\u0000"+
		"\u0000\u0000\u08f7\u08f8\u0001\u0000\u0000\u0000\u08f8\u091a\u0005\u047c"+
		"\u0000\u0000\u08f9\u08fa\u0005\u0184\u0000\u0000\u08fa\u08fc\u0005\u018b"+
		"\u0000\u0000\u08fb\u08fd\u0005\u0464\u0000\u0000\u08fc\u08fb\u0001\u0000"+
		"\u0000\u0000\u08fc\u08fd\u0001\u0000\u0000\u0000\u08fd\u08fe\u0001\u0000"+
		"\u0000\u0000\u08fe\u091a\u0005\u047c\u0000\u0000\u08ff\u0900\u0005Q\u0000"+
		"\u0000\u0900\u0902\u0005\u018b\u0000\u0000\u0901\u0903\u0005\u0464\u0000"+
		"\u0000\u0902\u0901\u0001\u0000\u0000\u0000\u0902\u0903\u0001\u0000\u0000"+
		"\u0000\u0903\u0904\u0001\u0000\u0000\u0000\u0904\u091a\u0005\u047c\u0000"+
		"\u0000\u0905\u0907\u0005\u01f4\u0000\u0000\u0906\u0908\u0005\u0464\u0000"+
		"\u0000\u0907\u0906\u0001\u0000\u0000\u0000\u0907\u0908\u0001\u0000\u0000"+
		"\u0000\u0908\u0909\u0001\u0000\u0000\u0000\u0909\u091a\u0003\u024e\u0127"+
		"\u0000\u090a\u090c\u0005\u01fe\u0000\u0000\u090b\u090d\u0005\u0464\u0000"+
		"\u0000\u090c\u090b\u0001\u0000\u0000\u0000\u090c\u090d\u0001\u0000\u0000"+
		"\u0000\u090d\u090e\u0001\u0000\u0000\u0000\u090e\u091a\u0003\u024e\u0127"+
		"\u0000\u090f\u0911\u0005\u0287\u0000\u0000\u0910\u0912\u0005\u0464\u0000"+
		"\u0000\u0911\u0910\u0001\u0000\u0000\u0000\u0911\u0912\u0001\u0000\u0000"+
		"\u0000\u0912\u0913\u0001\u0000\u0000\u0000\u0913\u091a\u0003\u0248\u0124"+
		"\u0000\u0914\u0916\u0005\u0210\u0000\u0000\u0915\u0917\u0005\u0464\u0000"+
		"\u0000\u0916\u0915\u0001\u0000\u0000\u0000\u0916\u0917\u0001\u0000\u0000"+
		"\u0000\u0917\u0918\u0001\u0000\u0000\u0000\u0918\u091a\u0003\u0248\u0124"+
		"\u0000\u0919\u08ea\u0001\u0000\u0000\u0000\u0919\u08f4\u0001\u0000\u0000"+
		"\u0000\u0919\u08f9\u0001\u0000\u0000\u0000\u0919\u08ff\u0001\u0000\u0000"+
		"\u0000\u0919\u0905\u0001\u0000\u0000\u0000\u0919\u090a\u0001\u0000\u0000"+
		"\u0000\u0919\u090f\u0001\u0000\u0000\u0000\u0919\u0914\u0001\u0000\u0000"+
		"\u0000\u091a\u007f\u0001\u0000\u0000\u0000\u091b\u091c\u0005\u0007\u0000"+
		"\u0000\u091c\u091e\u0007\u0000\u0000\u0000\u091d\u091f\u0003\u0248\u0124"+
		"\u0000\u091e\u091d\u0001\u0000\u0000\u0000\u091e\u091f\u0001\u0000\u0000"+
		"\u0000\u091f\u0921\u0001\u0000\u0000\u0000\u0920\u0922\u0003:\u001d\u0000"+
		"\u0921\u0920\u0001\u0000\u0000\u0000\u0922\u0923\u0001\u0000\u0000\u0000"+
		"\u0923\u0921\u0001\u0000\u0000\u0000\u0923\u0924\u0001\u0000\u0000\u0000"+
		"\u0924\u092e\u0001\u0000\u0000\u0000\u0925\u0926\u0005\u0007\u0000\u0000"+
		"\u0926\u0927\u0007\u0000\u0000\u0000\u0927\u0928\u0003\u0248\u0124\u0000"+
		"\u0928\u0929\u0005\u0298\u0000\u0000\u0929\u092a\u0005\u0184\u0000\u0000"+
		"\u092a\u092b\u0005\u018b\u0000\u0000\u092b\u092c\u0005\u0204\u0000\u0000"+
		"\u092c\u092e\u0001\u0000\u0000\u0000\u092d\u091b\u0001\u0000\u0000\u0000"+
		"\u092d\u0925\u0001\u0000\u0000\u0000\u092e\u0081\u0001\u0000\u0000\u0000"+
		"\u092f\u0931\u0005\u0007\u0000\u0000\u0930\u0932\u0003@ \u0000\u0931\u0930"+
		"\u0001\u0000\u0000\u0000\u0931\u0932\u0001\u0000\u0000\u0000\u0932\u0933"+
		"\u0001\u0000\u0000\u0000\u0933\u0934\u0005\u019f\u0000\u0000\u0934\u0938"+
		"\u0003\u0226\u0113\u0000\u0935\u0936\u0005v\u0000\u0000\u0936\u0937\u0005"+
		"\u025d\u0000\u0000\u0937\u0939\u0003B!\u0000\u0938\u0935\u0001\u0000\u0000"+
		"\u0000\u0938\u0939\u0001\u0000\u0000\u0000\u0939\u0940\u0001\u0000\u0000"+
		"\u0000\u093a\u093b\u0005v\u0000\u0000\u093b\u093d\u0005\u0173\u0000\u0000"+
		"\u093c\u093e\u0005r\u0000\u0000\u093d\u093c\u0001\u0000\u0000\u0000\u093d"+
		"\u093e\u0001\u0000\u0000\u0000\u093e\u093f\u0001\u0000\u0000\u0000\u093f"+
		"\u0941\u0005\u0231\u0000\u0000\u0940\u093a\u0001\u0000\u0000\u0000\u0940"+
		"\u0941\u0001\u0000\u0000\u0000\u0941\u0945\u0001\u0000\u0000\u0000\u0942"+
		"\u0943\u0005\u008b\u0000\u0000\u0943\u0944\u0005\u00af\u0000\u0000\u0944"+
		"\u0946\u0003\u0226\u0113\u0000\u0945\u0942\u0001\u0000\u0000\u0000\u0945"+
		"\u0946\u0001\u0000\u0000\u0000\u0946\u0948\u0001\u0000\u0000\u0000\u0947"+
		"\u0949\u0003J%\u0000\u0948\u0947\u0001\u0000\u0000\u0000\u0948\u0949\u0001"+
		"\u0000\u0000\u0000\u0949\u094c\u0001\u0000\u0000\u0000\u094a\u094b\u0005"+
		"\u0170\u0000\u0000\u094b\u094d\u0005\u047c\u0000\u0000\u094c\u094a\u0001"+
		"\u0000\u0000\u0000\u094c\u094d\u0001\u0000\u0000\u0000\u094d\u0950\u0001"+
		"\u0000\u0000\u0000\u094e\u094f\u0005\u018f\u0000\u0000\u094f\u0951\u0003"+
		"\u0184\u00c2\u0000\u0950\u094e\u0001\u0000\u0000\u0000\u0950\u0951\u0001"+
		"\u0000\u0000\u0000\u0951\u0083\u0001\u0000\u0000\u0000\u0952\u0953\u0005"+
		"\u0007\u0000\u0000\u0953\u0954\u0005\u01b5\u0000\u0000\u0954\u0958\u0003"+
		"\u0226\u0113\u0000\u0955\u0957\u0003T*\u0000\u0956\u0955\u0001\u0000\u0000"+
		"\u0000\u0957\u095a\u0001\u0000\u0000\u0000\u0958\u0956\u0001\u0000\u0000"+
		"\u0000\u0958\u0959\u0001\u0000\u0000\u0000\u0959\u0085\u0001\u0000\u0000"+
		"\u0000\u095a\u0958\u0001\u0000\u0000\u0000\u095b\u095c\u0005\u0007\u0000"+
		"\u0000\u095c\u095d\u0005\u01c9\u0000\u0000\u095d\u095e\u0005\u0257\u0000"+
		"\u0000\u095e\u095f\u0005\u0317\u0000\u0000\u095f\u0960\u0005\u01dd\u0000"+
		"\u0000\u0960\u0961\u0005[\u0000\u0000\u0961\u0087\u0001\u0000\u0000\u0000"+
		"\u0962\u0963\u0005\u0007\u0000\u0000\u0963\u0964\u0005\u01db\u0000\u0000"+
		"\u0964\u0965\u0005I\u0000\u0000\u0965\u0966\u0003\u0248\u0124\u0000\u0966"+
		"\u0967\u0005\u0005\u0000\u0000\u0967\u0968\u0005\u0293\u0000\u0000\u0968"+
		"\u096e\u0005\u047c\u0000\u0000\u0969\u096b\u0005\u01c5\u0000\u0000\u096a"+
		"\u096c\u0005\u0464\u0000\u0000\u096b\u096a\u0001\u0000\u0000\u0000\u096b"+
		"\u096c\u0001\u0000\u0000\u0000\u096c\u096d\u0001\u0000\u0000\u0000\u096d"+
		"\u096f\u0003\u0250\u0128\u0000\u096e\u0969\u0001\u0000\u0000\u0000\u096e"+
		"\u096f\u0001\u0000\u0000\u0000\u096f\u0971\u0001\u0000\u0000\u0000\u0970"+
		"\u0972\u0005\u02a2\u0000\u0000\u0971\u0970\u0001\u0000\u0000\u0000\u0971"+
		"\u0972\u0001\u0000\u0000\u0000\u0972\u0973\u0001\u0000\u0000\u0000\u0973"+
		"\u0975\u0005\u0199\u0000\u0000\u0974\u0976\u0005\u0464\u0000\u0000\u0975"+
		"\u0974\u0001\u0000\u0000\u0000\u0975\u0976\u0001\u0000\u0000\u0000\u0976"+
		"\u0977\u0001\u0000\u0000\u0000\u0977\u0978\u0003\u023c\u011e\u0000\u0978"+
		"\u0089\u0001\u0000\u0000\u0000\u0979\u097a\u0005\u0007\u0000\u0000\u097a"+
		"\u097b\u0005\u0083\u0000\u0000\u097b\u097f\u0003\u0226\u0113\u0000\u097c"+
		"\u097e\u0003T*\u0000\u097d\u097c\u0001\u0000\u0000\u0000\u097e\u0981\u0001"+
		"\u0000\u0000\u0000\u097f\u097d\u0001\u0000\u0000\u0000\u097f\u0980\u0001"+
		"\u0000\u0000\u0000\u0980\u008b\u0001\u0000\u0000\u0000\u0981\u097f\u0001"+
		"\u0000\u0000\u0000\u0982\u0983\u0005\u0007\u0000\u0000\u0983\u0984\u0005"+
		"\u0260\u0000\u0000\u0984\u0985\u0003\u0248\u0124\u0000\u0985\u0986\u0005"+
		"\u021d\u0000\u0000\u0986\u0987\u0005\u046d\u0000\u0000\u0987\u098c\u0003"+
		"V+\u0000\u0988\u0989\u0005\u046f\u0000\u0000\u0989\u098b\u0003V+\u0000"+
		"\u098a\u0988\u0001\u0000\u0000\u0000\u098b\u098e\u0001\u0000\u0000\u0000"+
		"\u098c\u098a\u0001\u0000\u0000\u0000\u098c\u098d\u0001\u0000\u0000\u0000"+
		"\u098d\u098f\u0001\u0000\u0000\u0000\u098e\u098c\u0001\u0000\u0000\u0000"+
		"\u098f\u0990\u0005\u046e\u0000\u0000\u0990\u008d\u0001\u0000\u0000\u0000"+
		"\u0991\u0993\u0005\u0007\u0000\u0000\u0992\u0994\u0007\u0001\u0000\u0000"+
		"\u0993\u0992\u0001\u0000\u0000\u0000\u0993\u0994\u0001\u0000\u0000\u0000"+
		"\u0994\u0996\u0001\u0000\u0000\u0000\u0995\u0997\u0005N\u0000\u0000\u0996"+
		"\u0995\u0001\u0000\u0000\u0000\u0996\u0997\u0001\u0000\u0000\u0000\u0997"+
		"\u0998\u0001\u0000\u0000\u0000\u0998\u0999\u0005\u00ac\u0000\u0000\u0999"+
		"\u099b\u0003\u0228\u0114\u0000\u099a\u099c\u0003\u0286\u0143\u0000\u099b"+
		"\u099a\u0001\u0000\u0000\u0000\u099b\u099c\u0001\u0000\u0000\u0000\u099c"+
		"\u09a5\u0001\u0000\u0000\u0000\u099d\u09a2\u0003\u0094J\u0000\u099e\u099f"+
		"\u0005\u046f\u0000\u0000\u099f\u09a1\u0003\u0094J\u0000\u09a0\u099e\u0001"+
		"\u0000\u0000\u0000\u09a1\u09a4\u0001\u0000\u0000\u0000\u09a2\u09a0\u0001"+
		"\u0000\u0000\u0000\u09a2\u09a3\u0001\u0000\u0000\u0000\u09a3\u09a6\u0001"+
		"\u0000\u0000\u0000\u09a4\u09a2\u0001\u0000\u0000\u0000\u09a5\u099d\u0001"+
		"\u0000\u0000\u0000\u09a5\u09a6\u0001\u0000\u0000\u0000\u09a6\u09a8\u0001"+
		"\u0000\u0000\u0000\u09a7\u09a9\u0003p8\u0000\u09a8\u09a7\u0001\u0000\u0000"+
		"\u0000\u09a8\u09a9\u0001\u0000\u0000\u0000\u09a9\u008f\u0001\u0000\u0000"+
		"\u0000\u09aa\u09ab\u0005\u0007\u0000\u0000\u09ab\u09ac\u0005\u0287\u0000"+
		"\u0000\u09ac\u09ad\u0003\u0248\u0124\u0000\u09ad\u09ae\u0007!\u0000\u0000"+
		"\u09ae\u09af\u0005\u0185\u0000\u0000\u09af\u09b3\u0005\u047c\u0000\u0000"+
		"\u09b0\u09b1\u0005\u01c5\u0000\u0000\u09b1\u09b2\u0005\u0464\u0000\u0000"+
		"\u09b2\u09b4\u0003\u0250\u0128\u0000\u09b3\u09b0\u0001\u0000\u0000\u0000"+
		"\u09b3\u09b4\u0001\u0000\u0000\u0000\u09b4\u09b6\u0001\u0000\u0000\u0000"+
		"\u09b5\u09b7\u0005\u02a2\u0000\u0000\u09b6\u09b5\u0001\u0000\u0000\u0000"+
		"\u09b6\u09b7\u0001\u0000\u0000\u0000\u09b7\u09b8\u0001\u0000\u0000\u0000"+
		"\u09b8\u09ba\u0005\u0199\u0000\u0000\u09b9\u09bb\u0005\u0464\u0000\u0000"+
		"\u09ba\u09b9\u0001\u0000\u0000\u0000\u09ba\u09bb\u0001\u0000\u0000\u0000"+
		"\u09bb\u09bc\u0001\u0000\u0000\u0000\u09bc\u09bd\u0003\u023c\u011e\u0000"+
		"\u09bd\u0091\u0001\u0000\u0000\u0000\u09be\u09c2\u0005\u0007\u0000\u0000"+
		"\u09bf\u09c0\u0005\u0150\u0000\u0000\u09c0\u09c1\u0005\u0464\u0000\u0000"+
		"\u09c1\u09c3\u0007\n\u0000\u0000\u09c2\u09bf\u0001\u0000\u0000\u0000\u09c2"+
		"\u09c3\u0001\u0000\u0000\u0000\u09c3\u09c5\u0001\u0000\u0000\u0000\u09c4"+
		"\u09c6\u0003@ \u0000\u09c5\u09c4\u0001\u0000\u0000\u0000\u09c5\u09c6\u0001"+
		"\u0000\u0000\u0000\u09c6\u09ca\u0001\u0000\u0000\u0000\u09c7\u09c8\u0005"+
		"\u00a0\u0000\u0000\u09c8\u09c9\u0005\u025e\u0000\u0000\u09c9\u09cb\u0007"+
		"\u000b\u0000\u0000\u09ca\u09c7\u0001\u0000\u0000\u0000\u09ca\u09cb\u0001"+
		"\u0000\u0000\u0000\u09cb\u09cc\u0001\u0000\u0000\u0000\u09cc\u09cd\u0005"+
		"\u029f\u0000\u0000\u09cd\u09d2\u0003\u0226\u0113\u0000\u09ce\u09cf\u0005"+
		"\u046d\u0000\u0000\u09cf\u09d0\u0003\u0268\u0134\u0000\u09d0\u09d1\u0005"+
		"\u046e\u0000\u0000\u09d1\u09d3\u0001\u0000\u0000\u0000\u09d2\u09ce\u0001"+
		"\u0000\u0000\u0000\u09d2\u09d3\u0001\u0000\u0000\u0000\u09d3\u09d4\u0001"+
		"\u0000\u0000\u0000\u09d4\u09d5\u0005\f\u0000\u0000\u09d5\u09dc\u0003\u00c8"+
		"d\u0000\u09d6\u09d8\u0005\u00c0\u0000\u0000\u09d7\u09d9\u0007\f\u0000"+
		"\u0000\u09d8\u09d7\u0001\u0000\u0000\u0000\u09d8\u09d9\u0001\u0000\u0000"+
		"\u0000\u09d9\u09da\u0001\u0000\u0000\u0000\u09da\u09db\u0005\u001a\u0000"+
		"\u0000\u09db\u09dd\u0005x\u0000\u0000\u09dc\u09d6\u0001\u0000\u0000\u0000"+
		"\u09dc\u09dd\u0001\u0000\u0000\u0000\u09dd\u0093\u0001\u0000\u0000\u0000"+
		"\u09de\u09e5\u0003j5\u0000\u09df\u09e1\u0005\u046f\u0000\u0000\u09e0\u09df"+
		"\u0001\u0000\u0000\u0000\u09e0\u09e1\u0001\u0000\u0000\u0000\u09e1\u09e2"+
		"\u0001\u0000\u0000\u0000\u09e2\u09e4\u0003j5\u0000\u09e3\u09e0\u0001\u0000"+
		"\u0000\u0000\u09e4\u09e7\u0001\u0000\u0000\u0000\u09e5\u09e3\u0001\u0000"+
		"\u0000\u0000\u09e5\u09e6\u0001\u0000\u0000\u0000\u09e6\u0b3e\u0001\u0000"+
		"\u0000\u0000\u09e7\u09e5\u0001\u0000\u0000\u0000\u09e8\u09ea\u0005\u0005"+
		"\u0000\u0000\u09e9\u09eb\u0005\u001c\u0000\u0000\u09ea\u09e9\u0001\u0000"+
		"\u0000\u0000\u09ea\u09eb\u0001\u0000\u0000\u0000\u09eb\u09ec\u0001\u0000"+
		"\u0000\u0000\u09ec\u09ed\u0003\u0248\u0124\u0000\u09ed\u09f1\u0003\\."+
		"\u0000\u09ee\u09f2\u0005\u01ae\u0000\u0000\u09ef\u09f0\u0005\u014e\u0000"+
		"\u0000\u09f0\u09f2\u0003\u0248\u0124\u0000\u09f1\u09ee\u0001\u0000\u0000"+
		"\u0000\u09f1\u09ef\u0001\u0000\u0000\u0000\u09f1\u09f2\u0001\u0000\u0000"+
		"\u0000\u09f2\u0b3e\u0001\u0000\u0000\u0000\u09f3\u09f5\u0005\u0005\u0000"+
		"\u0000\u09f4\u09f6\u0005\u001c\u0000\u0000\u09f5\u09f4\u0001\u0000\u0000"+
		"\u0000\u09f5\u09f6\u0001\u0000\u0000\u0000\u09f6\u09f7\u0001\u0000\u0000"+
		"\u0000\u09f7\u09f8\u0005\u046d\u0000\u0000\u09f8\u09f9\u0003\u0248\u0124"+
		"\u0000\u09f9\u0a00\u0003\\.\u0000\u09fa\u09fb\u0005\u046f\u0000\u0000"+
		"\u09fb\u09fc\u0003\u0248\u0124\u0000\u09fc\u09fd\u0003\\.\u0000\u09fd"+
		"\u09ff\u0001\u0000\u0000\u0000\u09fe\u09fa\u0001\u0000\u0000\u0000\u09ff"+
		"\u0a02\u0001\u0000\u0000\u0000\u0a00\u09fe\u0001\u0000\u0000\u0000\u0a00"+
		"\u0a01\u0001\u0000\u0000\u0000\u0a01\u0a03\u0001\u0000\u0000\u0000\u0a02"+
		"\u0a00\u0001\u0000\u0000\u0000\u0a03\u0a04\u0005\u046e\u0000\u0000\u0a04"+
		"\u0b3e\u0001\u0000\u0000\u0000\u0a05\u0a06\u0005\u0005\u0000\u0000\u0a06"+
		"\u0a08\u0007\u0014\u0000\u0000\u0a07\u0a09\u0003\u0248\u0124\u0000\u0a08"+
		"\u0a07\u0001\u0000\u0000\u0000\u0a08\u0a09\u0001\u0000\u0000\u0000\u0a09"+
		"\u0a0b\u0001\u0000\u0000\u0000\u0a0a\u0a0c\u0003L&\u0000\u0a0b\u0a0a\u0001"+
		"\u0000\u0000\u0000\u0a0b\u0a0c\u0001\u0000\u0000\u0000\u0a0c\u0a0d\u0001"+
		"\u0000\u0000\u0000\u0a0d\u0a11\u0003\u026e\u0137\u0000\u0a0e\u0a10\u0003"+
		"N\'\u0000\u0a0f\u0a0e\u0001\u0000\u0000\u0000\u0a10\u0a13\u0001\u0000"+
		"\u0000\u0000\u0a11\u0a0f\u0001\u0000\u0000\u0000\u0a11\u0a12\u0001\u0000"+
		"\u0000\u0000\u0a12\u0b3e\u0001\u0000\u0000\u0000\u0a13\u0a11\u0001\u0000"+
		"\u0000\u0000\u0a14\u0a19\u0005\u0005\u0000\u0000\u0a15\u0a17\u0005\u001e"+
		"\u0000\u0000\u0a16\u0a18\u0003\u0248\u0124\u0000\u0a17\u0a16\u0001\u0000"+
		"\u0000\u0000\u0a17\u0a18\u0001\u0000\u0000\u0000\u0a18\u0a1a\u0001\u0000"+
		"\u0000\u0000\u0a19\u0a15\u0001\u0000\u0000\u0000\u0a19\u0a1a\u0001\u0000"+
		"\u0000\u0000\u0a1a\u0a1b\u0001\u0000\u0000\u0000\u0a1b\u0a1c\u0005\u0082"+
		"\u0000\u0000\u0a1c\u0a1e\u0005[\u0000\u0000\u0a1d\u0a1f\u0003\u0248\u0124"+
		"\u0000\u0a1e\u0a1d\u0001\u0000\u0000\u0000\u0a1e\u0a1f\u0001\u0000\u0000"+
		"\u0000\u0a1f\u0a21\u0001\u0000\u0000\u0000\u0a20\u0a22\u0003L&\u0000\u0a21"+
		"\u0a20\u0001\u0000\u0000\u0000\u0a21\u0a22\u0001\u0000\u0000\u0000\u0a22"+
		"\u0a23\u0001\u0000\u0000\u0000\u0a23\u0a27\u0003\u026e\u0137\u0000\u0a24"+
		"\u0a26\u0003N\'\u0000\u0a25\u0a24\u0001\u0000\u0000\u0000\u0a26\u0a29"+
		"\u0001\u0000\u0000\u0000\u0a27\u0a25\u0001\u0000\u0000\u0000\u0a27\u0a28"+
		"\u0001\u0000\u0000\u0000\u0a28\u0b3e\u0001\u0000\u0000\u0000\u0a29\u0a27"+
		"\u0001\u0000\u0000\u0000\u0a2a\u0a2f\u0005\u0005\u0000\u0000\u0a2b\u0a2d"+
		"\u0005\u001e\u0000\u0000\u0a2c\u0a2e\u0003\u0248\u0124\u0000\u0a2d\u0a2c"+
		"\u0001\u0000\u0000\u0000\u0a2d\u0a2e\u0001\u0000\u0000\u0000\u0a2e\u0a30"+
		"\u0001\u0000\u0000\u0000\u0a2f\u0a2b\u0001\u0000\u0000\u0000\u0a2f\u0a30"+
		"\u0001\u0000\u0000\u0000\u0a30\u0a31\u0001\u0000\u0000\u0000\u0a31\u0a33"+
		"\u0005\u00b5\u0000\u0000\u0a32\u0a34\u0007\u0014\u0000\u0000\u0a33\u0a32"+
		"\u0001\u0000\u0000\u0000\u0a33\u0a34\u0001\u0000\u0000\u0000\u0a34\u0a36"+
		"\u0001\u0000\u0000\u0000\u0a35\u0a37\u0003\u0248\u0124\u0000\u0a36\u0a35"+
		"\u0001\u0000\u0000\u0000\u0a36\u0a37\u0001\u0000\u0000\u0000\u0a37\u0a39"+
		"\u0001\u0000\u0000\u0000\u0a38\u0a3a\u0003L&\u0000\u0a39\u0a38\u0001\u0000"+
		"\u0000\u0000\u0a39\u0a3a\u0001\u0000\u0000\u0000\u0a3a\u0a3b\u0001\u0000"+
		"\u0000\u0000\u0a3b\u0a3f\u0003\u026e\u0137\u0000\u0a3c\u0a3e\u0003N\'"+
		"\u0000\u0a3d\u0a3c\u0001\u0000\u0000\u0000\u0a3e\u0a41\u0001\u0000\u0000"+
		"\u0000\u0a3f\u0a3d\u0001\u0000\u0000\u0000\u0a3f\u0a40\u0001\u0000\u0000"+
		"\u0000\u0a40\u0b3e\u0001\u0000\u0000\u0000\u0a41\u0a3f\u0001\u0000\u0000"+
		"\u0000\u0a42\u0a43\u0005\u0005\u0000\u0000\u0a43\u0a45\u0007\u0016\u0000"+
		"\u0000\u0a44\u0a46\u0007\u0014\u0000\u0000\u0a45\u0a44\u0001\u0000\u0000"+
		"\u0000\u0a45\u0a46\u0001\u0000\u0000\u0000\u0a46\u0a48\u0001\u0000\u0000"+
		"\u0000\u0a47\u0a49\u0003\u0248\u0124\u0000\u0a48\u0a47\u0001\u0000\u0000"+
		"\u0000\u0a48\u0a49\u0001\u0000\u0000\u0000\u0a49\u0a4a\u0001\u0000\u0000"+
		"\u0000\u0a4a\u0a4e\u0003\u026e\u0137\u0000\u0a4b\u0a4d\u0003N\'\u0000"+
		"\u0a4c\u0a4b\u0001\u0000\u0000\u0000\u0a4d\u0a50\u0001\u0000\u0000\u0000"+
		"\u0a4e\u0a4c\u0001\u0000\u0000\u0000\u0a4e\u0a4f\u0001\u0000\u0000\u0000"+
		"\u0a4f\u0b3e\u0001\u0000\u0000\u0000\u0a50\u0a4e\u0001\u0000\u0000\u0000"+
		"\u0a51\u0a56\u0005\u0005\u0000\u0000\u0a52\u0a54\u0005\u001e\u0000\u0000"+
		"\u0a53\u0a55\u0003\u0248\u0124\u0000\u0a54\u0a53\u0001\u0000\u0000\u0000"+
		"\u0a54\u0a55\u0001\u0000\u0000\u0000\u0a55\u0a57\u0001\u0000\u0000\u0000"+
		"\u0a56\u0a52\u0001\u0000\u0000\u0000\u0a56\u0a57\u0001\u0000\u0000\u0000"+
		"\u0a57\u0a58\u0001\u0000\u0000\u0000\u0a58\u0a59\u0005C\u0000\u0000\u0a59"+
		"\u0a5b\u0005[\u0000\u0000\u0a5a\u0a5c\u0003\u0248\u0124\u0000\u0a5b\u0a5a"+
		"\u0001\u0000\u0000\u0000\u0a5b\u0a5c\u0001\u0000\u0000\u0000\u0a5c\u0a5d"+
		"\u0001\u0000\u0000\u0000\u0a5d\u0a5e\u0003\u026e\u0137\u0000\u0a5e\u0a5f"+
		"\u0003b1\u0000\u0a5f\u0b3e\u0001\u0000\u0000\u0000\u0a60\u0a65\u0005\u0005"+
		"\u0000\u0000\u0a61\u0a63\u0005\u001e\u0000\u0000\u0a62\u0a64\u0003\u0248"+
		"\u0124\u0000\u0a63\u0a62\u0001\u0000\u0000\u0000\u0a63\u0a64\u0001\u0000"+
		"\u0000\u0000\u0a64\u0a66\u0001\u0000\u0000\u0000\u0a65\u0a61\u0001\u0000"+
		"\u0000\u0000\u0a65\u0a66\u0001\u0000\u0000\u0000\u0a66\u0a67\u0001\u0000"+
		"\u0000\u0000\u0a67\u0a6e\u0005\u001a\u0000\u0000\u0a68\u0a6f\u0003\u0248"+
		"\u0124\u0000\u0a69\u0a6f\u0003\u0252\u0129\u0000\u0a6a\u0a6b\u0005\u046d"+
		"\u0000\u0000\u0a6b\u0a6c\u0003\u02b0\u0158\u0000\u0a6c\u0a6d\u0005\u046e"+
		"\u0000\u0000\u0a6d\u0a6f\u0001\u0000\u0000\u0000\u0a6e\u0a68\u0001\u0000"+
		"\u0000\u0000\u0a6e\u0a69\u0001\u0000\u0000\u0000\u0a6e\u0a6a\u0001\u0000"+
		"\u0000\u0000\u0a6f\u0a71\u0001\u0000\u0000\u0000\u0a70\u0a72\u0005r\u0000"+
		"\u0000\u0a71\u0a70\u0001\u0000\u0000\u0000\u0a71\u0a72\u0001\u0000\u0000"+
		"\u0000\u0a72\u0a74\u0001\u0000\u0000\u0000\u0a73\u0a75\u00059\u0000\u0000"+
		"\u0a74\u0a73\u0001\u0000\u0000\u0000\u0a74\u0a75\u0001\u0000\u0000\u0000"+
		"\u0a75\u0b3e\u0001\u0000\u0000\u0000\u0a76\u0a7b\u0005\u0007\u0000\u0000"+
		"\u0a77\u0a79\u0005\u001e\u0000\u0000\u0a78\u0a7a\u0003\u0248\u0124\u0000"+
		"\u0a79\u0a78\u0001\u0000\u0000\u0000\u0a79\u0a7a\u0001\u0000\u0000\u0000"+
		"\u0a7a\u0a7c\u0001\u0000\u0000\u0000\u0a7b\u0a77\u0001\u0000\u0000\u0000"+
		"\u0a7b\u0a7c\u0001\u0000\u0000\u0000\u0a7c\u0a7d\u0001\u0000\u0000\u0000"+
		"\u0a7d\u0a84\u0005\u001a\u0000\u0000\u0a7e\u0a85\u0003\u0248\u0124\u0000"+
		"\u0a7f\u0a85\u0003\u0252\u0129\u0000\u0a80\u0a81\u0005\u046d\u0000\u0000"+
		"\u0a81\u0a82\u0003\u02b0\u0158\u0000\u0a82\u0a83\u0005\u046e\u0000\u0000"+
		"\u0a83\u0a85\u0001\u0000\u0000\u0000\u0a84\u0a7e\u0001\u0000\u0000\u0000"+
		"\u0a84\u0a7f\u0001\u0000\u0000\u0000\u0a84\u0a80\u0001\u0000\u0000\u0000"+
		"\u0a85\u0a87\u0001\u0000\u0000\u0000\u0a86\u0a88\u0005r\u0000\u0000\u0a87"+
		"\u0a86\u0001\u0000\u0000\u0000\u0a87\u0a88\u0001\u0000\u0000\u0000\u0a88"+
		"\u0a8a\u0001\u0000\u0000\u0000\u0a89\u0a8b\u00059\u0000\u0000\u0a8a\u0a89"+
		"\u0001\u0000\u0000\u0000\u0a8a\u0a8b\u0001\u0000\u0000\u0000\u0a8b\u0b3e"+
		"\u0001\u0000\u0000\u0000\u0a8c\u0a91\u0005\u0005\u0000\u0000\u0a8d\u0a8f"+
		"\u0005\u001e\u0000\u0000\u0a8e\u0a90\u0003\u0248\u0124\u0000\u0a8f\u0a8e"+
		"\u0001\u0000\u0000\u0000\u0a8f\u0a90\u0001\u0000\u0000\u0000\u0a90\u0a92"+
		"\u0001\u0000\u0000\u0000\u0a91\u0a8d\u0001\u0000\u0000\u0000\u0a91\u0a92"+
		"\u0001\u0000\u0000\u0000\u0a92\u0a93\u0001\u0000\u0000\u0000\u0a93\u0a94"+
		"\u0005\u001a\u0000\u0000\u0a94\u0a95\u0005\u046d\u0000\u0000\u0a95\u0a96"+
		"\u0003\u02b0\u0158\u0000\u0a96\u0a97\u0005\u046e\u0000\u0000\u0a97\u0b3e"+
		"\u0001\u0000\u0000\u0000\u0a98\u0a9a\u0005\u0150\u0000\u0000\u0a99\u0a9b"+
		"\u0005\u0464\u0000\u0000\u0a9a\u0a99\u0001\u0000\u0000\u0000\u0a9a\u0a9b"+
		"\u0001\u0000\u0000\u0000\u0a9b\u0a9c\u0001\u0000\u0000\u0000\u0a9c\u0b3e"+
		"\u0007\"\u0000\u0000\u0a9d\u0a9f\u0005\u0007\u0000\u0000\u0a9e\u0aa0\u0005"+
		"\u001c\u0000\u0000\u0a9f\u0a9e\u0001\u0000\u0000\u0000\u0a9f\u0aa0\u0001"+
		"\u0000\u0000\u0000\u0aa0\u0aa1\u0001\u0000\u0000\u0000\u0aa1\u0aa7\u0003"+
		"\u0248\u0124\u0000\u0aa2\u0aa3\u0005\u0099\u0000\u0000\u0aa3\u0aa4\u0005"+
		"*\u0000\u0000\u0aa4\u0aa8\u0003\u027a\u013d\u0000\u0aa5\u0aa6\u00053\u0000"+
		"\u0000\u0aa6\u0aa8\u0005*\u0000\u0000\u0aa7\u0aa2\u0001\u0000\u0000\u0000"+
		"\u0aa7\u0aa5\u0001\u0000\u0000\u0000\u0aa8\u0b3e\u0001\u0000\u0000\u0000"+
		"\u0aa9\u0aab\u0005\u0018\u0000\u0000\u0aaa\u0aac\u0005\u001c\u0000\u0000"+
		"\u0aab\u0aaa\u0001\u0000\u0000\u0000\u0aab\u0aac\u0001\u0000\u0000\u0000"+
		"\u0aac\u0aad\u0001\u0000\u0000\u0000\u0aad\u0aae\u0003\u0248\u0124\u0000"+
		"\u0aae\u0aaf\u0003\u0248\u0124\u0000\u0aaf\u0ab3\u0003\\.\u0000\u0ab0"+
		"\u0ab4\u0005\u01ae\u0000\u0000\u0ab1\u0ab2\u0005\u014e\u0000\u0000\u0ab2"+
		"\u0ab4\u0003\u0248\u0124\u0000\u0ab3\u0ab0\u0001\u0000\u0000\u0000\u0ab3"+
		"\u0ab1\u0001\u0000\u0000\u0000\u0ab3\u0ab4\u0001\u0000\u0000\u0000\u0ab4"+
		"\u0b3e\u0001\u0000\u0000\u0000\u0ab5\u0ab6\u0005\u008b\u0000\u0000\u0ab6"+
		"\u0ab7\u0005\u001c\u0000\u0000\u0ab7\u0ab8\u0003\u0248\u0124\u0000\u0ab8"+
		"\u0ab9\u0005\u00af\u0000\u0000\u0ab9\u0aba\u0003\u0248\u0124\u0000\u0aba"+
		"\u0b3e\u0001\u0000\u0000\u0000\u0abb\u0abd\u0005g\u0000\u0000\u0abc\u0abe"+
		"\u0005\u0464\u0000\u0000\u0abd\u0abc\u0001\u0000\u0000\u0000\u0abd\u0abe"+
		"\u0001\u0000\u0000\u0000\u0abe\u0abf\u0001\u0000\u0000\u0000\u0abf\u0b3e"+
		"\u0007\u0004\u0000\u0000\u0ac0\u0ac2\u0005\u0200\u0000\u0000\u0ac1\u0ac3"+
		"\u0005\u001c\u0000\u0000\u0ac2\u0ac1\u0001\u0000\u0000\u0000\u0ac2\u0ac3"+
		"\u0001\u0000\u0000\u0000\u0ac3\u0ac4\u0001\u0000\u0000\u0000\u0ac4\u0ac5"+
		"\u0003\u0248\u0124\u0000\u0ac5\u0ac9\u0003\\.\u0000\u0ac6\u0aca\u0005"+
		"\u01ae\u0000\u0000\u0ac7\u0ac8\u0005\u014e\u0000\u0000\u0ac8\u0aca\u0003"+
		"\u0248\u0124\u0000\u0ac9\u0ac6\u0001\u0000\u0000\u0000\u0ac9\u0ac7\u0001"+
		"\u0000\u0000\u0000\u0ac9\u0aca\u0001\u0000\u0000\u0000\u0aca\u0b3e\u0001"+
		"\u0000\u0000\u0000\u0acb\u0acd\u00053\u0000\u0000\u0acc\u0ace\u0005\u001c"+
		"\u0000\u0000\u0acd\u0acc\u0001\u0000\u0000\u0000\u0acd\u0ace\u0001\u0000"+
		"\u0000\u0000\u0ace\u0acf\u0001\u0000\u0000\u0000\u0acf\u0ad1\u0003\u0248"+
		"\u0124\u0000\u0ad0\u0ad2\u0005\u0090\u0000\u0000\u0ad1\u0ad0\u0001\u0000"+
		"\u0000\u0000\u0ad1\u0ad2\u0001\u0000\u0000\u0000\u0ad2\u0b3e\u0001\u0000"+
		"\u0000\u0000\u0ad3\u0ad4\u00053\u0000\u0000\u0ad4\u0ad5\u0007#\u0000\u0000"+
		"\u0ad5\u0b3e\u0003\u0248\u0124\u0000\u0ad6\u0ad7\u00053\u0000\u0000\u0ad7"+
		"\u0ad8\u0005\u0082\u0000\u0000\u0ad8\u0b3e\u0005[\u0000\u0000\u0ad9\u0ada"+
		"\u00053\u0000\u0000\u0ada\u0adb\u0007\u0014\u0000\u0000\u0adb\u0b3e\u0003"+
		"\u0248\u0124\u0000\u0adc\u0add\u0005\u008b\u0000\u0000\u0add\u0ade\u0007"+
		"\u0014\u0000\u0000\u0ade\u0adf\u0003\u0248\u0124\u0000\u0adf\u0ae0\u0005"+
		"\u00af\u0000\u0000\u0ae0\u0ae1\u0003\u0248\u0124\u0000\u0ae1\u0b3e\u0001"+
		"\u0000\u0000\u0000\u0ae2\u0ae4\u0005\u0007\u0000\u0000\u0ae3\u0ae5\u0005"+
		"\u001c\u0000\u0000\u0ae4\u0ae3\u0001\u0000\u0000\u0000\u0ae4\u0ae5\u0001"+
		"\u0000\u0000\u0000\u0ae5\u0ae6\u0001\u0000\u0000\u0000\u0ae6\u0af4\u0003"+
		"\u0248\u0124\u0000\u0ae7\u0ae8\u0005\u0099\u0000\u0000\u0ae8\u0aee\u0005"+
		"*\u0000\u0000\u0ae9\u0aef\u0003\u0252\u0129\u0000\u0aea\u0aeb\u0005\u046d"+
		"\u0000\u0000\u0aeb\u0aec\u0003\u02b0\u0158\u0000\u0aec\u0aed\u0005\u046e"+
		"\u0000\u0000\u0aed\u0aef\u0001\u0000\u0000\u0000\u0aee\u0ae9\u0001\u0000"+
		"\u0000\u0000\u0aee\u0aea\u0001\u0000\u0000\u0000\u0aef\u0af5\u0001\u0000"+
		"\u0000\u0000\u0af0\u0af1\u0005\u0099\u0000\u0000\u0af1\u0af5\u0007\u000f"+
		"\u0000\u0000\u0af2\u0af3\u00053\u0000\u0000\u0af3\u0af5\u0005*\u0000\u0000"+
		"\u0af4\u0ae7\u0001\u0000\u0000\u0000\u0af4\u0af0\u0001\u0000\u0000\u0000"+
		"\u0af4\u0af2\u0001\u0000\u0000\u0000\u0af5\u0b3e\u0001\u0000\u0000\u0000"+
		"\u0af6\u0af7\u0005\u0007\u0000\u0000\u0af7\u0af8\u0005Q\u0000\u0000\u0af8"+
		"\u0af9\u0003\u0248\u0124\u0000\u0af9\u0afa\u0007\u000f\u0000\u0000\u0afa"+
		"\u0b3e\u0001\u0000\u0000\u0000\u0afb\u0afc\u00053\u0000\u0000\u0afc\u0afd"+
		"\u0005C\u0000\u0000\u0afd\u0afe\u0005[\u0000\u0000\u0afe\u0b3e\u0003\u0248"+
		"\u0124\u0000\u0aff\u0b00\u0005\u018c\u0000\u0000\u0b00\u0b3e\u0005\\\u0000"+
		"\u0000\u0b01\u0b02\u0005\u0193\u0000\u0000\u0b02\u0b3e\u0005\\\u0000\u0000"+
		"\u0b03\u0b05\u0005\u008b\u0000\u0000\u0b04\u0b06\u0007$\u0000\u0000\u0b05"+
		"\u0b04\u0001\u0000\u0000\u0000\u0b05\u0b06\u0001\u0000\u0000\u0000\u0b06"+
		"\u0b09\u0001\u0000\u0000\u0000\u0b07\u0b0a\u0003\u0248\u0124\u0000\u0b08"+
		"\u0b0a\u0003\u0226\u0113\u0000\u0b09\u0b07\u0001\u0000\u0000\u0000\u0b09"+
		"\u0b08\u0001\u0000\u0000\u0000\u0b0a\u0b3e\u0001\u0000\u0000\u0000\u0b0b"+
		"\u0b0c\u0005|\u0000\u0000\u0b0c\u0b0d\u0005\u0013\u0000\u0000\u0b0d\u0b3e"+
		"\u0003\u0268\u0134\u0000\u0b0e\u0b0f\u0005 \u0000\u0000\u0b0f\u0b13\u0005"+
		"\u00af\u0000\u0000\u0b10\u0b14\u0005\u0349\u0000\u0000\u0b11\u0b12\u0005"+
		"\u0019\u0000\u0000\u0b12\u0b14\u0005\u0099\u0000\u0000\u0b13\u0b10\u0001"+
		"\u0000\u0000\u0000\u0b13\u0b11\u0001\u0000\u0000\u0000\u0b14\u0b15\u0001"+
		"\u0000\u0000\u0000\u0b15\u0b18\u0003\u0238\u011c\u0000\u0b16\u0b17\u0005"+
		"\u001b\u0000\u0000\u0b17\u0b19\u0003\u023a\u011d\u0000\u0b18\u0b16\u0001"+
		"\u0000\u0000\u0000\u0b18\u0b19\u0001\u0000\u0000\u0000\u0b19\u0b3e\u0001"+
		"\u0000\u0000\u0000\u0b1a\u0b1c\u0005*\u0000\u0000\u0b1b\u0b1a\u0001\u0000"+
		"\u0000\u0000\u0b1b\u0b1c\u0001\u0000\u0000\u0000\u0b1c\u0b1d\u0001\u0000"+
		"\u0000\u0000\u0b1d\u0b1e\u0005\u0019\u0000\u0000\u0b1e\u0b1f\u0005\u0099"+
		"\u0000\u0000\u0b1f\u0b20\u0005\u0464\u0000\u0000\u0b20\u0b24\u0003\u0238"+
		"\u011c\u0000\u0b21\u0b22\u0005\u001b\u0000\u0000\u0b22\u0b23\u0005\u0464"+
		"\u0000\u0000\u0b23\u0b25\u0003\u023a\u011d\u0000\u0b24\u0b21\u0001\u0000"+
		"\u0000\u0000\u0b24\u0b25\u0001\u0000\u0000\u0000\u0b25\u0b3e\u0001\u0000"+
		"\u0000\u0000\u0b26\u0b27\u0005\u018d\u0000\u0000\u0b27\u0b3e\u0005\u0287"+
		"\u0000\u0000\u0b28\u0b29\u0005\u01c2\u0000\u0000\u0b29\u0b3e\u0005\u0287"+
		"\u0000\u0000\u0b2a\u0b3e\u0005B\u0000\u0000\u0b2b\u0b2c\u0007%\u0000\u0000"+
		"\u0b2c\u0b3e\u0005\u029c\u0000\u0000\u0b2d\u0b2f\u0005\u0005\u0000\u0000"+
		"\u0b2e\u0b30\u0005\u001c\u0000\u0000\u0b2f\u0b2e\u0001\u0000\u0000\u0000"+
		"\u0b2f\u0b30\u0001\u0000\u0000\u0000\u0b30\u0b31\u0001\u0000\u0000\u0000"+
		"\u0b31\u0b32\u0005\u046d\u0000\u0000\u0b32\u0b37\u0003Z-\u0000\u0b33\u0b34"+
		"\u0005\u046f\u0000\u0000\u0b34\u0b36\u0003Z-\u0000\u0b35\u0b33\u0001\u0000"+
		"\u0000\u0000\u0b36\u0b39\u0001\u0000\u0000\u0000\u0b37\u0b35\u0001\u0000"+
		"\u0000\u0000\u0b37\u0b38\u0001\u0000\u0000\u0000\u0b38\u0b3a\u0001\u0000"+
		"\u0000\u0000\u0b39\u0b37\u0001\u0000\u0000\u0000\u0b3a\u0b3b\u0005\u046e"+
		"\u0000\u0000\u0b3b\u0b3e\u0001\u0000\u0000\u0000\u0b3c\u0b3e\u0003\u0096"+
		"K\u0000\u0b3d\u09de\u0001\u0000\u0000\u0000\u0b3d\u09e8\u0001\u0000\u0000"+
		"\u0000\u0b3d\u09f3\u0001\u0000\u0000\u0000\u0b3d\u0a05\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0a14\u0001\u0000\u0000\u0000\u0b3d\u0a2a\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0a42\u0001\u0000\u0000\u0000\u0b3d\u0a51\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0a60\u0001\u0000\u0000\u0000\u0b3d\u0a76\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0a8c\u0001\u0000\u0000\u0000\u0b3d\u0a98\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0a9d\u0001\u0000\u0000\u0000\u0b3d\u0aa9\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0ab5\u0001\u0000\u0000\u0000\u0b3d\u0abb\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0ac0\u0001\u0000\u0000\u0000\u0b3d\u0acb\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0ad3\u0001\u0000\u0000\u0000\u0b3d\u0ad6\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0ad9\u0001\u0000\u0000\u0000\u0b3d\u0adc\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0ae2\u0001\u0000\u0000\u0000\u0b3d\u0af6\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0afb\u0001\u0000\u0000\u0000\u0b3d\u0aff\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0b01\u0001\u0000\u0000\u0000\u0b3d\u0b03\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0b0b\u0001\u0000\u0000\u0000\u0b3d\u0b0e\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0b1b\u0001\u0000\u0000\u0000\u0b3d\u0b26\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0b28\u0001\u0000\u0000\u0000\u0b3d\u0b2a\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0b2b\u0001\u0000\u0000\u0000\u0b3d\u0b2d\u0001\u0000\u0000"+
		"\u0000\u0b3d\u0b3c\u0001\u0000\u0000\u0000\u0b3e\u0095\u0001\u0000\u0000"+
		"\u0000\u0b3f\u0b40\u0005\u0005\u0000\u0000\u0b40\u0b41\u0005\u0081\u0000"+
		"\u0000\u0b41\u0b42\u0005\u046d\u0000\u0000\u0b42\u0b47\u0003v;\u0000\u0b43"+
		"\u0b44\u0005\u046f\u0000\u0000\u0b44\u0b46\u0003v;\u0000\u0b45\u0b43\u0001"+
		"\u0000\u0000\u0000\u0b46\u0b49\u0001\u0000\u0000\u0000\u0b47\u0b45\u0001"+
		"\u0000\u0000\u0000\u0b47\u0b48\u0001\u0000\u0000\u0000\u0b48\u0b4a\u0001"+
		"\u0000\u0000\u0000\u0b49\u0b47\u0001\u0000\u0000\u0000\u0b4a\u0b4b\u0005"+
		"\u046e\u0000\u0000\u0b4b\u0ba2\u0001\u0000\u0000\u0000\u0b4c\u0b4d\u0005"+
		"3\u0000\u0000\u0b4d\u0b4e\u0005\u0081\u0000\u0000\u0b4e\u0ba2\u0003\u0268"+
		"\u0134\u0000\u0b4f\u0b50\u0005\u018d\u0000\u0000\u0b50\u0b53\u0005\u0081"+
		"\u0000\u0000\u0b51\u0b54\u0003\u0268\u0134\u0000\u0b52\u0b54\u0005\u0006"+
		"\u0000\u0000\u0b53\u0b51\u0001\u0000\u0000\u0000\u0b53\u0b52\u0001\u0000"+
		"\u0000\u0000\u0b54\u0b55\u0001\u0000\u0000\u0000\u0b55\u0ba2\u0005\u0287"+
		"\u0000\u0000\u0b56\u0b57\u0005\u01c2\u0000\u0000\u0b57\u0b5a\u0005\u0081"+
		"\u0000\u0000\u0b58\u0b5b\u0003\u0268\u0134\u0000\u0b59\u0b5b\u0005\u0006"+
		"\u0000\u0000\u0b5a\u0b58\u0001\u0000\u0000\u0000\u0b5a\u0b59\u0001\u0000"+
		"\u0000\u0000\u0b5b\u0b5c\u0001\u0000\u0000\u0000\u0b5c\u0ba2\u0005\u0287"+
		"\u0000\u0000\u0b5d\u0b5e\u0005\u0290\u0000\u0000\u0b5e\u0b61\u0005\u0081"+
		"\u0000\u0000\u0b5f\u0b62\u0003\u0268\u0134\u0000\u0b60\u0b62\u0005\u0006"+
		"\u0000\u0000\u0b61\u0b5f\u0001\u0000\u0000\u0000\u0b61\u0b60\u0001\u0000"+
		"\u0000\u0000\u0b62\u0ba2\u0001\u0000\u0000\u0000\u0b63\u0b64\u0005\u016b"+
		"\u0000\u0000\u0b64\u0b65\u0005\u0081\u0000\u0000\u0b65\u0ba2\u0003\u024e"+
		"\u0127\u0000\u0b66\u0b67\u0005\u0243\u0000\u0000\u0b67\u0b68\u0005\u0081"+
		"\u0000\u0000\u0b68\u0b69\u0003\u0268\u0134\u0000\u0b69\u0b6a\u0005W\u0000"+
		"\u0000\u0b6a\u0b6b\u0005\u046d\u0000\u0000\u0b6b\u0b70\u0003v;\u0000\u0b6c"+
		"\u0b6d\u0005\u046f\u0000\u0000\u0b6d\u0b6f\u0003v;\u0000\u0b6e\u0b6c\u0001"+
		"\u0000\u0000\u0000\u0b6f\u0b72\u0001\u0000\u0000\u0000\u0b70\u0b6e\u0001"+
		"\u0000\u0000\u0000\u0b70\u0b71\u0001\u0000\u0000\u0000\u0b71\u0b73\u0001"+
		"\u0000\u0000\u0000\u0b72\u0b70\u0001\u0000\u0000\u0000\u0b73\u0b74\u0005"+
		"\u046e\u0000\u0000\u0b74\u0ba2\u0001\u0000\u0000\u0000\u0b75\u0b76\u0005"+
		"\u01a2\u0000\u0000\u0b76\u0b77\u0005\u0081\u0000\u0000\u0b77\u0b78\u0003"+
		"\u0248\u0124\u0000\u0b78\u0b79\u0005\u00c0\u0000\u0000\u0b79\u0b7a\u0005"+
		"\u00ac\u0000\u0000\u0b7a\u0b7d\u0003\u0228\u0114\u0000\u0b7b\u0b7c\u0007"+
		"%\u0000\u0000\u0b7c\u0b7e\u0005\u029c\u0000\u0000\u0b7d\u0b7b\u0001\u0000"+
		"\u0000\u0000\u0b7d\u0b7e\u0001\u0000\u0000\u0000\u0b7e\u0ba2\u0001\u0000"+
		"\u0000\u0000\u0b7f\u0b80\u0005\t\u0000\u0000\u0b80\u0b83\u0005\u0081\u0000"+
		"\u0000\u0b81\u0b84\u0003\u0268\u0134\u0000\u0b82\u0b84\u0005\u0006\u0000"+
		"\u0000\u0b83\u0b81\u0001\u0000\u0000\u0000\u0b83\u0b82\u0001\u0000\u0000"+
		"\u0000\u0b84\u0ba2\u0001\u0000\u0000\u0000\u0b85\u0b86\u0005\u001a\u0000"+
		"\u0000\u0b86\u0b89\u0005\u0081\u0000\u0000\u0b87\u0b8a\u0003\u0268\u0134"+
		"\u0000\u0b88\u0b8a\u0005\u0006\u0000\u0000\u0b89\u0b87\u0001\u0000\u0000"+
		"\u0000\u0b89\u0b88\u0001\u0000\u0000\u0000\u0b8a\u0ba2\u0001\u0000\u0000"+
		"\u0000\u0b8b\u0b8c\u0005w\u0000\u0000\u0b8c\u0b8f\u0005\u0081\u0000\u0000"+
		"\u0b8d\u0b90\u0003\u0268\u0134\u0000\u0b8e\u0b90\u0005\u0006\u0000\u0000"+
		"\u0b8f\u0b8d\u0001\u0000\u0000\u0000\u0b8f\u0b8e\u0001\u0000\u0000\u0000"+
		"\u0b90\u0ba2\u0001\u0000\u0000\u0000\u0b91\u0b92\u0005\u0239\u0000\u0000"+
		"\u0b92\u0b95\u0005\u0081\u0000\u0000\u0b93\u0b96\u0003\u0268\u0134\u0000"+
		"\u0b94\u0b96\u0005\u0006\u0000\u0000\u0b95\u0b93\u0001\u0000\u0000\u0000"+
		"\u0b95\u0b94\u0001\u0000\u0000\u0000\u0b96\u0ba2\u0001\u0000\u0000\u0000"+
		"\u0b97\u0b98\u0005\u0244\u0000\u0000\u0b98\u0b9b\u0005\u0081\u0000\u0000"+
		"\u0b99\u0b9c\u0003\u0268\u0134\u0000\u0b9a\u0b9c\u0005\u0006\u0000\u0000"+
		"\u0b9b\u0b99\u0001\u0000\u0000\u0000\u0b9b\u0b9a\u0001\u0000\u0000\u0000"+
		"\u0b9c\u0ba2\u0001\u0000\u0000\u0000\u0b9d\u0b9e\u0005\u0242\u0000\u0000"+
		"\u0b9e\u0ba2\u0005\u0225\u0000\u0000\u0b9f\u0ba0\u0005\u0298\u0000\u0000"+
		"\u0ba0\u0ba2\u0005\u0225\u0000\u0000\u0ba1\u0b3f\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b4c\u0001\u0000\u0000\u0000\u0ba1\u0b4f\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b56\u0001\u0000\u0000\u0000\u0ba1\u0b5d\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b63\u0001\u0000\u0000\u0000\u0ba1\u0b66\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b75\u0001\u0000\u0000\u0000\u0ba1\u0b7f\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b85\u0001\u0000\u0000\u0000\u0ba1\u0b8b\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b91\u0001\u0000\u0000\u0000\u0ba1\u0b97\u0001\u0000\u0000\u0000"+
		"\u0ba1\u0b9d\u0001\u0000\u0000\u0000\u0ba1\u0b9f\u0001\u0000\u0000\u0000"+
		"\u0ba2\u0097\u0001\u0000\u0000\u0000\u0ba3\u0ba4\u00053\u0000\u0000\u0ba4"+
		"\u0ba6\u0007\u0000\u0000\u0000\u0ba5\u0ba7\u0003\u0280\u0140\u0000\u0ba6"+
		"\u0ba5\u0001\u0000\u0000\u0000\u0ba6\u0ba7\u0001\u0000\u0000\u0000\u0ba7"+
		"\u0ba8\u0001\u0000\u0000\u0000\u0ba8\u0ba9\u0003\u0248\u0124\u0000\u0ba9"+
		"\u0099\u0001\u0000\u0000\u0000\u0baa\u0bab\u00053\u0000\u0000\u0bab\u0bad"+
		"\u0005\u019f\u0000\u0000\u0bac\u0bae\u0003\u0280\u0140\u0000\u0bad\u0bac"+
		"\u0001\u0000\u0000\u0000\u0bad\u0bae\u0001\u0000\u0000\u0000\u0bae\u0baf"+
		"\u0001\u0000\u0000\u0000\u0baf\u0bb0\u0003\u0226\u0113\u0000\u0bb0\u009b"+
		"\u0001\u0000\u0000\u0000\u0bb1\u0bb2\u00053\u0000\u0000\u0bb2\u0bb4\u0005"+
		"Q\u0000\u0000\u0bb3\u0bb5\u0007\u0001\u0000\u0000\u0bb4\u0bb3\u0001\u0000"+
		"\u0000\u0000\u0bb4\u0bb5\u0001\u0000\u0000\u0000\u0bb5\u0bb6\u0001\u0000"+
		"\u0000\u0000\u0bb6\u0bb7\u0003\u0248\u0124\u0000\u0bb7\u0bb8\u0005v\u0000"+
		"\u0000\u0bb8\u0bc5\u0003\u0228\u0114\u0000\u0bb9\u0bbb\u0005\u0150\u0000"+
		"\u0000\u0bba\u0bbc\u0005\u0464\u0000\u0000\u0bbb\u0bba\u0001\u0000\u0000"+
		"\u0000\u0bbb\u0bbc\u0001\u0000\u0000\u0000\u0bbc\u0bbd\u0001\u0000\u0000"+
		"\u0000\u0bbd\u0bc4\u0007\u0003\u0000\u0000\u0bbe\u0bc0\u0005g\u0000\u0000"+
		"\u0bbf\u0bc1\u0005\u0464\u0000\u0000\u0bc0\u0bbf\u0001\u0000\u0000\u0000"+
		"\u0bc0\u0bc1\u0001\u0000\u0000\u0000\u0bc1\u0bc2\u0001\u0000\u0000\u0000"+
		"\u0bc2\u0bc4\u0007\u0004\u0000\u0000\u0bc3\u0bb9\u0001\u0000\u0000\u0000"+
		"\u0bc3\u0bbe\u0001\u0000\u0000\u0000\u0bc4\u0bc7\u0001\u0000\u0000\u0000"+
		"\u0bc5\u0bc3\u0001\u0000\u0000\u0000\u0bc5\u0bc6\u0001\u0000\u0000\u0000"+
		"\u0bc6\u009d\u0001\u0000\u0000\u0000\u0bc7\u0bc5\u0001\u0000\u0000\u0000"+
		"\u0bc8\u0bc9\u00053\u0000\u0000\u0bc9\u0bca\u0005\u01db\u0000\u0000\u0bca"+
		"\u0bcb\u0005I\u0000\u0000\u0bcb\u0bcc\u0003\u0248\u0124\u0000\u0bcc\u0bcd"+
		"\u0005\u0199\u0000\u0000\u0bcd\u0bce\u0005\u0464\u0000\u0000\u0bce\u0bcf"+
		"\u0003\u023c\u011e\u0000\u0bcf\u009f\u0001\u0000\u0000\u0000\u0bd0\u0bd1"+
		"\u00053\u0000\u0000\u0bd1\u0bd3\u0005\u0083\u0000\u0000\u0bd2\u0bd4\u0003"+
		"\u0280\u0140\u0000\u0bd3\u0bd2\u0001\u0000\u0000\u0000\u0bd3\u0bd4\u0001"+
		"\u0000\u0000\u0000\u0bd4\u0bd5\u0001\u0000\u0000\u0000\u0bd5\u0bd6\u0003"+
		"\u0226\u0113\u0000\u0bd6\u00a1\u0001\u0000\u0000\u0000\u0bd7\u0bd8\u0005"+
		"3\u0000\u0000\u0bd8\u0bda\u0005\u01b5\u0000\u0000\u0bd9\u0bdb\u0003\u0280"+
		"\u0140\u0000\u0bda\u0bd9\u0001\u0000\u0000\u0000\u0bda\u0bdb\u0001\u0000"+
		"\u0000\u0000\u0bdb\u0bdc\u0001\u0000\u0000\u0000\u0bdc\u0bdd\u0003\u0226"+
		"\u0113\u0000\u0bdd\u00a3\u0001\u0000\u0000\u0000\u0bde\u0bdf\u00053\u0000"+
		"\u0000\u0bdf\u0be1\u0005\u0260\u0000\u0000\u0be0\u0be2\u0003\u0280\u0140"+
		"\u0000\u0be1\u0be0\u0001\u0000\u0000\u0000\u0be1\u0be2\u0001\u0000\u0000"+
		"\u0000\u0be2\u0be3\u0001\u0000\u0000\u0000\u0be3\u0be4\u0003\u0248\u0124"+
		"\u0000\u0be4\u00a5\u0001\u0000\u0000\u0000\u0be5\u0be7\u00053\u0000\u0000"+
		"\u0be6\u0be8\u0005\u0289\u0000\u0000\u0be7\u0be6\u0001\u0000\u0000\u0000"+
		"\u0be7\u0be8\u0001\u0000\u0000\u0000\u0be8\u0be9\u0001\u0000\u0000\u0000"+
		"\u0be9\u0beb\u0005\u00ac\u0000\u0000\u0bea\u0bec\u0003\u0280\u0140\u0000"+
		"\u0beb\u0bea\u0001\u0000\u0000\u0000\u0beb\u0bec\u0001\u0000\u0000\u0000"+
		"\u0bec\u0bed\u0001\u0000\u0000\u0000\u0bed\u0bef\u0003\u026c\u0136\u0000"+
		"\u0bee\u0bf0\u0007&\u0000\u0000\u0bef\u0bee\u0001\u0000\u0000\u0000\u0bef"+
		"\u0bf0\u0001\u0000\u0000\u0000\u0bf0\u00a7\u0001\u0000\u0000\u0000\u0bf1"+
		"\u0bf2\u00053\u0000\u0000\u0bf2\u0bf3\u0005\u0287\u0000\u0000\u0bf3\u0bf9"+
		"\u0003\u0248\u0124\u0000\u0bf4\u0bf6\u0005\u0199\u0000\u0000\u0bf5\u0bf7"+
		"\u0005\u0464\u0000\u0000\u0bf6\u0bf5\u0001\u0000\u0000\u0000\u0bf6\u0bf7"+
		"\u0001\u0000\u0000\u0000\u0bf7\u0bf8\u0001\u0000\u0000\u0000\u0bf8\u0bfa"+
		"\u0003\u023c\u011e\u0000\u0bf9\u0bf4\u0001\u0000\u0000\u0000\u0bf9\u0bfa"+
		"\u0001\u0000\u0000\u0000\u0bfa\u00a9\u0001\u0000\u0000\u0000\u0bfb\u0bfc"+
		"\u00053\u0000\u0000\u0bfc\u0bfe\u0005\u00b1\u0000\u0000\u0bfd\u0bff\u0003"+
		"\u0280\u0140\u0000\u0bfe\u0bfd\u0001\u0000\u0000\u0000\u0bfe\u0bff\u0001"+
		"\u0000\u0000\u0000\u0bff\u0c00\u0001\u0000\u0000\u0000\u0c00\u0c01\u0003"+
		"\u0226\u0113\u0000\u0c01\u00ab\u0001\u0000\u0000\u0000\u0c02\u0c03\u0005"+
		"3\u0000\u0000\u0c03\u0c05\u0005\u029f\u0000\u0000\u0c04\u0c06\u0003\u0280"+
		"\u0140\u0000\u0c05\u0c04\u0001\u0000\u0000\u0000\u0c05\u0c06\u0001\u0000"+
		"\u0000\u0000\u0c06\u0c07\u0001\u0000\u0000\u0000\u0c07\u0c0c\u0003\u0226"+
		"\u0113\u0000\u0c08\u0c09\u0005\u046f\u0000\u0000\u0c09\u0c0b\u0003\u0226"+
		"\u0113\u0000\u0c0a\u0c08\u0001\u0000\u0000\u0000\u0c0b\u0c0e\u0001\u0000"+
		"\u0000\u0000\u0c0c\u0c0a\u0001\u0000\u0000\u0000\u0c0c\u0c0d\u0001\u0000"+
		"\u0000\u0000\u0c0d\u0c10\u0001\u0000\u0000\u0000\u0c0e\u0c0c\u0001\u0000"+
		"\u0000\u0000\u0c0f\u0c11\u0007&\u0000\u0000\u0c10\u0c0f\u0001\u0000\u0000"+
		"\u0000\u0c10\u0c11\u0001\u0000\u0000\u0000\u0c11\u00ad\u0001\u0000\u0000"+
		"\u0000\u0c12\u0c13\u00053\u0000\u0000\u0c13\u0c15\u0005\u0254\u0000\u0000"+
		"\u0c14\u0c16\u0003\u0280\u0140\u0000\u0c15\u0c14\u0001\u0000\u0000\u0000"+
		"\u0c15\u0c16\u0001\u0000\u0000\u0000\u0c16\u0c17\u0001\u0000\u0000\u0000"+
		"\u0c17\u0c1c\u0003\u022a\u0115\u0000\u0c18\u0c19\u0005\u046f\u0000\u0000"+
		"\u0c19\u0c1b\u0003\u022a\u0115\u0000\u0c1a\u0c18\u0001\u0000\u0000\u0000"+
		"\u0c1b\u0c1e\u0001\u0000\u0000\u0000\u0c1c\u0c1a\u0001\u0000\u0000\u0000"+
		"\u0c1c\u0c1d\u0001\u0000\u0000\u0000\u0c1d\u00af\u0001\u0000\u0000\u0000"+
		"\u0c1e\u0c1c\u0001\u0000\u0000\u0000\u0c1f\u0c20\u0005\u0099\u0000\u0000"+
		"\u0c20\u0c21\u0005*\u0000\u0000\u0c21\u0c2c\u0005\u0254\u0000\u0000\u0c22"+
		"\u0c2d\u0005\u0211\u0000\u0000\u0c23\u0c2d\u0005\u0006\u0000\u0000\u0c24"+
		"\u0c29\u0003\u022a\u0115\u0000\u0c25\u0c26\u0005\u046f\u0000\u0000\u0c26"+
		"\u0c28\u0003\u022a\u0115\u0000\u0c27\u0c25\u0001\u0000\u0000\u0000\u0c28"+
		"\u0c2b\u0001\u0000\u0000\u0000\u0c29\u0c27\u0001\u0000\u0000\u0000\u0c29"+
		"\u0c2a\u0001\u0000\u0000\u0000\u0c2a\u0c2d\u0001\u0000\u0000\u0000\u0c2b"+
		"\u0c29\u0001\u0000\u0000\u0000\u0c2c\u0c22\u0001\u0000\u0000\u0000\u0c2c"+
		"\u0c23\u0001\u0000\u0000\u0000\u0c2c\u0c24\u0001\u0000\u0000\u0000\u0c2d"+
		"\u0c2e\u0001\u0000\u0000\u0000\u0c2e\u0c31\u0005\u00af\u0000\u0000\u0c2f"+
		"\u0c32\u0003\u0234\u011a\u0000\u0c30\u0c32\u0003\u0248\u0124\u0000\u0c31"+
		"\u0c2f\u0001\u0000\u0000\u0000\u0c31\u0c30\u0001\u0000\u0000\u0000\u0c32"+
		"\u0c3a\u0001\u0000\u0000\u0000\u0c33\u0c36\u0005\u046f\u0000\u0000\u0c34"+
		"\u0c37\u0003\u0234\u011a\u0000\u0c35\u0c37\u0003\u0248\u0124\u0000\u0c36"+
		"\u0c34\u0001\u0000\u0000\u0000\u0c36\u0c35\u0001\u0000\u0000\u0000\u0c37"+
		"\u0c39\u0001\u0000\u0000\u0000\u0c38\u0c33\u0001\u0000\u0000\u0000\u0c39"+
		"\u0c3c\u0001\u0000\u0000\u0000\u0c3a\u0c38\u0001\u0000\u0000\u0000\u0c3a"+
		"\u0c3b\u0001\u0000\u0000\u0000\u0c3b\u0c41\u0001\u0000\u0000\u0000\u0c3c"+
		"\u0c3a\u0001\u0000\u0000\u0000\u0c3d\u0c3e\u0005\u0099\u0000\u0000\u0c3e"+
		"\u0c3f\u0005\u0254\u0000\u0000\u0c3f\u0c41\u0003\u01b2\u00d9\u0000\u0c40"+
		"\u0c1f\u0001\u0000\u0000\u0000\u0c40\u0c3d\u0001\u0000\u0000\u0000\u0c41"+
		"\u00b1\u0001\u0000\u0000\u0000\u0c42\u0c43\u0005\u008b\u0000\u0000\u0c43"+
		"\u0c44\u0005\u00ac\u0000\u0000\u0c44\u0c49\u0003\u00b4Z\u0000\u0c45\u0c46"+
		"\u0005\u046f\u0000\u0000\u0c46\u0c48\u0003\u00b4Z\u0000\u0c47\u0c45\u0001"+
		"\u0000\u0000\u0000\u0c48\u0c4b\u0001\u0000\u0000\u0000\u0c49\u0c47\u0001"+
		"\u0000\u0000\u0000\u0c49\u0c4a\u0001\u0000\u0000\u0000\u0c4a\u00b3\u0001"+
		"\u0000\u0000\u0000\u0c4b\u0c49\u0001\u0000\u0000\u0000\u0c4c\u0c4d\u0003"+
		"\u0228\u0114\u0000\u0c4d\u0c4e\u0005\u00af\u0000\u0000\u0c4e\u0c4f\u0003"+
		"\u0228\u0114\u0000\u0c4f\u00b5\u0001\u0000\u0000\u0000\u0c50\u0c52\u0005"+
		"\u0290\u0000\u0000\u0c51\u0c53\u0005\u00ac\u0000\u0000\u0c52\u0c51\u0001"+
		"\u0000\u0000\u0000\u0c52\u0c53\u0001\u0000\u0000\u0000\u0c53\u0c54\u0001"+
		"\u0000\u0000\u0000\u0c54\u0c55\u0003\u0228\u0114\u0000\u0c55\u00b7\u0001"+
		"\u0000\u0000\u0000\u0c56\u0c57\u0005\u0014\u0000\u0000\u0c57\u0c5e\u0003"+
		"\u0226\u0113\u0000\u0c58\u0c5b\u0005\u046d\u0000\u0000\u0c59\u0c5c\u0003"+
		"\u0274\u013a\u0000\u0c5a\u0c5c\u0003\u0270\u0138\u0000\u0c5b\u0c59\u0001"+
		"\u0000\u0000\u0000\u0c5b\u0c5a\u0001\u0000\u0000\u0000\u0c5b\u0c5c\u0001"+
		"\u0000\u0000\u0000\u0c5c\u0c5d\u0001\u0000\u0000\u0000\u0c5d\u0c5f\u0005"+
		"\u046e\u0000\u0000\u0c5e\u0c58\u0001\u0000\u0000\u0000\u0c5e\u0c5f\u0001"+
		"\u0000\u0000\u0000\u0c5f\u00b9\u0001\u0000\u0000\u0000\u0c60\u0c63\u0003"+
		"\u00d6k\u0000\u0c61\u0c63\u0003\u00d8l\u0000\u0c62\u0c60\u0001\u0000\u0000"+
		"\u0000\u0c62\u0c61\u0001\u0000\u0000\u0000\u0c63\u00bb\u0001\u0000\u0000"+
		"\u0000\u0c64\u0c65\u0005\u018f\u0000\u0000\u0c65\u0c66\u0003\u0270\u0138"+
		"\u0000\u0c66\u00bd\u0001\u0000\u0000\u0000\u0c67\u0c6c\u0003\u00dam\u0000"+
		"\u0c68\u0c6c\u0003\u00dcn\u0000\u0c69\u0c6c\u0003\u00deo\u0000\u0c6a\u0c6c"+
		"\u0003\u00e0p\u0000\u0c6b\u0c67\u0001\u0000\u0000\u0000\u0c6b\u0c68\u0001"+
		"\u0000\u0000\u0000\u0c6b\u0c69\u0001\u0000\u0000\u0000\u0c6b\u0c6a\u0001"+
		"\u0000\u0000\u0000\u0c6c\u00bf\u0001\u0000\u0000\u0000\u0c6d\u0c6f\u0005"+
		"U\u0000\u0000\u0c6e\u0c70\u0007\'\u0000\u0000\u0c6f\u0c6e\u0001\u0000"+
		"\u0000\u0000\u0c6f\u0c70\u0001\u0000\u0000\u0000\u0c70\u0c72\u0001\u0000"+
		"\u0000\u0000\u0c71\u0c73\u0005N\u0000\u0000\u0c72\u0c71\u0001\u0000\u0000"+
		"\u0000\u0c72\u0c73\u0001\u0000\u0000\u0000\u0c73\u0c75\u0001\u0000\u0000"+
		"\u0000\u0c74\u0c76\u0005W\u0000\u0000\u0c75\u0c74\u0001\u0000\u0000\u0000"+
		"\u0c75\u0c76\u0001\u0000\u0000\u0000\u0c76\u0c77\u0001\u0000\u0000\u0000"+
		"\u0c77\u0c7e\u0003\u0228\u0114\u0000\u0c78\u0c79\u0005\u0081\u0000\u0000"+
		"\u0c79\u0c7b\u0005\u046d\u0000\u0000\u0c7a\u0c7c\u0003\u0268\u0134\u0000"+
		"\u0c7b\u0c7a\u0001\u0000\u0000\u0000\u0c7b\u0c7c\u0001\u0000\u0000\u0000"+
		"\u0c7c\u0c7d\u0001\u0000\u0000\u0000\u0c7d\u0c7f\u0005\u046e\u0000\u0000"+
		"\u0c7e\u0c78\u0001\u0000\u0000\u0000\u0c7e\u0c7f\u0001\u0000\u0000\u0000"+
		"\u0c7f\u0c97\u0001\u0000\u0000\u0000\u0c80\u0c82\u0005\u046d\u0000\u0000"+
		"\u0c81\u0c83\u0003\u026a\u0135\u0000\u0c82\u0c81\u0001\u0000\u0000\u0000"+
		"\u0c82\u0c83\u0001\u0000\u0000\u0000\u0c83\u0c84\u0001\u0000\u0000\u0000"+
		"\u0c84\u0c86\u0005\u046e\u0000\u0000\u0c85\u0c80\u0001\u0000\u0000\u0000"+
		"\u0c85\u0c86\u0001\u0000\u0000\u0000\u0c86\u0c87\u0001\u0000\u0000\u0000"+
		"\u0c87\u0c8c\u0003\u00ceg\u0000\u0c88\u0c8a\u0005\f\u0000\u0000\u0c89"+
		"\u0c88\u0001\u0000\u0000\u0000\u0c89\u0c8a\u0001\u0000\u0000\u0000\u0c8a"+
		"\u0c8b\u0001\u0000\u0000\u0000\u0c8b\u0c8d\u0003\u0248\u0124\u0000\u0c8c"+
		"\u0c89\u0001\u0000\u0000\u0000\u0c8c\u0c8d\u0001\u0000\u0000\u0000\u0c8d"+
		"\u0c98\u0001\u0000\u0000\u0000\u0c8e\u0c8f\u0005\u0099\u0000\u0000\u0c8f"+
		"\u0c94\u0003\u00d0h\u0000\u0c90\u0c91\u0005\u046f\u0000\u0000\u0c91\u0c93"+
		"\u0003\u00d0h\u0000\u0c92\u0c90\u0001\u0000\u0000\u0000\u0c93\u0c96\u0001"+
		"\u0000\u0000\u0000\u0c94\u0c92\u0001\u0000\u0000\u0000\u0c94\u0c95\u0001"+
		"\u0000\u0000\u0000\u0c95\u0c98\u0001\u0000\u0000\u0000\u0c96\u0c94\u0001"+
		"\u0000\u0000\u0000\u0c97\u0c85\u0001\u0000\u0000\u0000\u0c97\u0c8e\u0001"+
		"\u0000\u0000\u0000\u0c98\u0ca5\u0001\u0000\u0000\u0000\u0c99\u0c9a\u0005"+
		"v\u0000\u0000\u0c9a\u0c9b\u0005\u0191\u0000\u0000\u0c9b\u0c9c\u0005[\u0000"+
		"\u0000\u0c9c\u0c9d\u0005\u00b8\u0000\u0000\u0c9d\u0ca2\u0003\u00d0h\u0000"+
		"\u0c9e\u0c9f\u0005\u046f\u0000\u0000\u0c9f\u0ca1\u0003\u00d0h\u0000\u0ca0"+
		"\u0c9e\u0001\u0000\u0000\u0000\u0ca1\u0ca4\u0001\u0000\u0000\u0000\u0ca2"+
		"\u0ca0\u0001\u0000\u0000\u0000\u0ca2\u0ca3\u0001\u0000\u0000\u0000\u0ca3"+
		"\u0ca6\u0001\u0000\u0000\u0000\u0ca4\u0ca2\u0001\u0000\u0000\u0000\u0ca5"+
		"\u0c99\u0001\u0000\u0000\u0000\u0ca5\u0ca6\u0001\u0000\u0000\u0000\u0ca6"+
		"\u00c1\u0001\u0000\u0000\u0000\u0ca7\u0ca8\u0005f\u0000\u0000\u0ca8\u0caa"+
		"\u0005\u0184\u0000\u0000\u0ca9\u0cab\u0007(\u0000\u0000\u0caa\u0ca9\u0001"+
		"\u0000\u0000\u0000\u0caa\u0cab\u0001\u0000\u0000\u0000\u0cab\u0cad\u0001"+
		"\u0000\u0000\u0000\u0cac\u0cae\u0005\u01da\u0000\u0000\u0cad\u0cac\u0001"+
		"\u0000\u0000\u0000\u0cad\u0cae\u0001\u0000\u0000\u0000\u0cae\u0caf\u0001"+
		"\u0000\u0000\u0000\u0caf\u0cb0\u0005R\u0000\u0000\u0cb0\u0cb2\u0005\u047c"+
		"\u0000\u0000\u0cb1\u0cb3\u0007\u0006\u0000\u0000\u0cb2\u0cb1\u0001\u0000"+
		"\u0000\u0000\u0cb2\u0cb3\u0001\u0000\u0000\u0000\u0cb3\u0cb4\u0001\u0000"+
		"\u0000\u0000\u0cb4\u0cb5\u0005W\u0000\u0000\u0cb5\u0cb6\u0005\u00ac\u0000"+
		"\u0000\u0cb6\u0cbc\u0003\u0228\u0114\u0000\u0cb7\u0cb8\u0005\u0081\u0000"+
		"\u0000\u0cb8\u0cb9\u0005\u046d\u0000\u0000\u0cb9\u0cba\u0003\u0268\u0134"+
		"\u0000\u0cba\u0cbb\u0005\u046e\u0000\u0000\u0cbb\u0cbd\u0001\u0000\u0000"+
		"\u0000\u0cbc\u0cb7\u0001\u0000\u0000\u0000\u0cbc\u0cbd\u0001\u0000\u0000"+
		"\u0000\u0cbd\u0cc1\u0001\u0000\u0000\u0000\u0cbe\u0cbf\u0005\u0019\u0000"+
		"\u0000\u0cbf\u0cc0\u0005\u0099\u0000\u0000\u0cc0\u0cc2\u0003\u0238\u011c"+
		"\u0000\u0cc1\u0cbe\u0001\u0000\u0000\u0000\u0cc1\u0cc2\u0001\u0000\u0000"+
		"\u0000\u0cc2\u0cc9\u0001\u0000\u0000\u0000\u0cc3\u0cc5\u0007)\u0000\u0000"+
		"\u0cc4\u0cc6\u0003\u0118\u008c\u0000\u0cc5\u0cc4\u0001\u0000\u0000\u0000"+
		"\u0cc6\u0cc7\u0001\u0000\u0000\u0000\u0cc7\u0cc5\u0001\u0000\u0000\u0000"+
		"\u0cc7\u0cc8\u0001\u0000\u0000\u0000\u0cc8\u0cca\u0001\u0000\u0000\u0000"+
		"\u0cc9\u0cc3\u0001\u0000\u0000\u0000\u0cc9\u0cca\u0001\u0000\u0000\u0000"+
		"\u0cca\u0cd1\u0001\u0000\u0000\u0000\u0ccb\u0ccd\u0005e\u0000\u0000\u0ccc"+
		"\u0cce\u0003\u011a\u008d\u0000\u0ccd\u0ccc\u0001\u0000\u0000\u0000\u0cce"+
		"\u0ccf\u0001\u0000\u0000\u0000\u0ccf\u0ccd\u0001\u0000\u0000\u0000\u0ccf"+
		"\u0cd0\u0001\u0000\u0000\u0000\u0cd0\u0cd2\u0001\u0000\u0000\u0000\u0cd1"+
		"\u0ccb\u0001\u0000\u0000\u0000\u0cd1\u0cd2\u0001\u0000\u0000\u0000\u0cd2"+
		"\u0cd7\u0001\u0000\u0000\u0000\u0cd3\u0cd4\u0005N\u0000\u0000\u0cd4\u0cd5"+
		"\u0003\u024e\u0127\u0000\u0cd5\u0cd6\u0007*\u0000\u0000\u0cd6\u0cd8\u0001"+
		"\u0000\u0000\u0000\u0cd7\u0cd3\u0001\u0000\u0000\u0000\u0cd7\u0cd8\u0001"+
		"\u0000\u0000\u0000\u0cd8\u0ce4\u0001\u0000\u0000\u0000\u0cd9\u0cda\u0005"+
		"\u046d\u0000\u0000\u0cda\u0cdf\u0003\u00d2i\u0000\u0cdb\u0cdc\u0005\u046f"+
		"\u0000\u0000\u0cdc\u0cde\u0003\u00d2i\u0000\u0cdd\u0cdb\u0001\u0000\u0000"+
		"\u0000\u0cde\u0ce1\u0001\u0000\u0000\u0000\u0cdf\u0cdd\u0001\u0000\u0000"+
		"\u0000\u0cdf\u0ce0\u0001\u0000\u0000\u0000\u0ce0\u0ce2\u0001\u0000\u0000"+
		"\u0000\u0ce1\u0cdf\u0001\u0000\u0000\u0000\u0ce2\u0ce3\u0005\u046e\u0000"+
		"\u0000\u0ce3\u0ce5\u0001\u0000\u0000\u0000\u0ce4\u0cd9\u0001\u0000\u0000"+
		"\u0000\u0ce4\u0ce5\u0001\u0000\u0000\u0000\u0ce5\u0cef\u0001\u0000\u0000"+
		"\u0000\u0ce6\u0ce7\u0005\u0099\u0000\u0000\u0ce7\u0cec\u0003\u00d0h\u0000"+
		"\u0ce8\u0ce9\u0005\u046f\u0000\u0000\u0ce9\u0ceb\u0003\u00d0h\u0000\u0cea"+
		"\u0ce8\u0001\u0000\u0000\u0000\u0ceb\u0cee\u0001\u0000\u0000\u0000\u0cec"+
		"\u0cea\u0001\u0000\u0000\u0000\u0cec\u0ced\u0001\u0000\u0000\u0000\u0ced"+
		"\u0cf0\u0001\u0000\u0000\u0000\u0cee\u0cec\u0001\u0000\u0000\u0000\u0cef"+
		"\u0ce6\u0001\u0000\u0000\u0000\u0cef\u0cf0\u0001\u0000\u0000\u0000\u0cf0"+
		"\u00c3\u0001\u0000\u0000\u0000\u0cf1\u0cf2\u0005f\u0000\u0000\u0cf2\u0cf4"+
		"\u0005\u02aa\u0000\u0000\u0cf3\u0cf5\u0007(\u0000\u0000\u0cf4\u0cf3\u0001"+
		"\u0000\u0000\u0000\u0cf4\u0cf5\u0001\u0000\u0000\u0000\u0cf5\u0cf7\u0001"+
		"\u0000\u0000\u0000\u0cf6\u0cf8\u0005\u01da\u0000\u0000\u0cf7\u0cf6\u0001"+
		"\u0000\u0000\u0000\u0cf7\u0cf8\u0001\u0000\u0000\u0000\u0cf8\u0cf9\u0001"+
		"\u0000\u0000\u0000\u0cf9\u0cfa\u0005R\u0000\u0000\u0cfa\u0cfc\u0005\u047c"+
		"\u0000\u0000\u0cfb\u0cfd\u0007\u0006\u0000\u0000\u0cfc\u0cfb\u0001\u0000"+
		"\u0000\u0000\u0cfc\u0cfd\u0001\u0000\u0000\u0000\u0cfd\u0cfe\u0001\u0000"+
		"\u0000\u0000\u0cfe\u0cff\u0005W\u0000\u0000\u0cff\u0d00\u0005\u00ac\u0000"+
		"\u0000\u0d00\u0d04\u0003\u0228\u0114\u0000\u0d01\u0d02\u0005\u0019\u0000"+
		"\u0000\u0d02\u0d03\u0005\u0099\u0000\u0000\u0d03\u0d05\u0003\u0238\u011c"+
		"\u0000\u0d04\u0d01\u0001\u0000\u0000\u0000\u0d04\u0d05\u0001\u0000\u0000"+
		"\u0000\u0d05\u0d0c\u0001\u0000\u0000\u0000\u0d06\u0d07\u0005\u0259\u0000"+
		"\u0000\u0d07\u0d08\u0005\u01c0\u0000\u0000\u0d08\u0d09\u0005\u0013\u0000"+
		"\u0000\u0d09\u0d0a\u0005\u0466\u0000\u0000\u0d0a\u0d0b\u0005\u047c\u0000"+
		"\u0000\u0d0b\u0d0d\u0005\u0465\u0000\u0000\u0d0c\u0d06\u0001\u0000\u0000"+
		"\u0000\u0d0c\u0d0d\u0001\u0000\u0000\u0000\u0d0d\u0d12\u0001\u0000\u0000"+
		"\u0000\u0d0e\u0d0f\u0005N\u0000\u0000\u0d0f\u0d10\u0003\u024e\u0127\u0000"+
		"\u0d10\u0d11\u0007*\u0000\u0000\u0d11\u0d13\u0001\u0000\u0000\u0000\u0d12"+
		"\u0d0e\u0001\u0000\u0000\u0000\u0d12\u0d13\u0001\u0000\u0000\u0000\u0d13"+
		"\u0d1f\u0001\u0000\u0000\u0000\u0d14\u0d15\u0005\u046d\u0000\u0000\u0d15"+
		"\u0d1a\u0003\u00d2i\u0000\u0d16\u0d17\u0005\u046f\u0000\u0000\u0d17\u0d19"+
		"\u0003\u00d2i\u0000\u0d18\u0d16\u0001\u0000\u0000\u0000\u0d19\u0d1c\u0001"+
		"\u0000\u0000\u0000\u0d1a\u0d18\u0001\u0000\u0000\u0000\u0d1a\u0d1b\u0001"+
		"\u0000\u0000\u0000\u0d1b\u0d1d\u0001\u0000\u0000\u0000\u0d1c\u0d1a\u0001"+
		"\u0000\u0000\u0000\u0d1d\u0d1e\u0005\u046e\u0000\u0000\u0d1e\u0d20\u0001"+
		"\u0000\u0000\u0000\u0d1f\u0d14\u0001\u0000\u0000\u0000\u0d1f\u0d20\u0001"+
		"\u0000\u0000\u0000\u0d20\u0d2a\u0001\u0000\u0000\u0000\u0d21\u0d22\u0005"+
		"\u0099\u0000\u0000\u0d22\u0d27\u0003\u00d0h\u0000\u0d23\u0d24\u0005\u046f"+
		"\u0000\u0000\u0d24\u0d26\u0003\u00d0h\u0000\u0d25\u0d23\u0001\u0000\u0000"+
		"\u0000\u0d26\u0d29\u0001\u0000\u0000\u0000\u0d27\u0d25\u0001\u0000\u0000"+
		"\u0000\u0d27\u0d28\u0001\u0000\u0000\u0000\u0d28\u0d2b\u0001\u0000\u0000"+
		"\u0000\u0d29\u0d27\u0001\u0000\u0000\u0000\u0d2a\u0d21\u0001\u0000\u0000"+
		"\u0000\u0d2a\u0d2b\u0001\u0000\u0000\u0000\u0d2b\u00c5\u0001\u0000\u0000"+
		"\u0000\u0d2c\u0d2e\u0005\u008d\u0000\u0000\u0d2d\u0d2f\u0007+\u0000\u0000"+
		"\u0d2e\u0d2d\u0001\u0000\u0000\u0000\u0d2e\u0d2f\u0001\u0000\u0000\u0000"+
		"\u0d2f\u0d31\u0001\u0000\u0000\u0000\u0d30\u0d32\u0005W\u0000\u0000\u0d31"+
		"\u0d30\u0001\u0000\u0000\u0000\u0d31\u0d32\u0001\u0000\u0000\u0000\u0d32"+
		"\u0d33\u0001\u0000\u0000\u0000\u0d33\u0d39\u0003\u0228\u0114\u0000\u0d34"+
		"\u0d35\u0005\u0081\u0000\u0000\u0d35\u0d36\u0005\u046d\u0000\u0000\u0d36"+
		"\u0d37\u0003\u0268\u0134\u0000\u0d37\u0d38\u0005\u046e\u0000\u0000\u0d38"+
		"\u0d3a\u0001\u0000\u0000\u0000\u0d39\u0d34\u0001\u0000\u0000\u0000\u0d39"+
		"\u0d3a\u0001\u0000\u0000\u0000\u0d3a\u0d4b\u0001\u0000\u0000\u0000\u0d3b"+
		"\u0d3c\u0005\u046d\u0000\u0000\u0d3c\u0d3d\u0003\u0268\u0134\u0000\u0d3d"+
		"\u0d3e\u0005\u046e\u0000\u0000\u0d3e\u0d40\u0001\u0000\u0000\u0000\u0d3f"+
		"\u0d3b\u0001\u0000\u0000\u0000\u0d3f\u0d40\u0001\u0000\u0000\u0000\u0d40"+
		"\u0d41\u0001\u0000\u0000\u0000\u0d41\u0d4c\u0003\u00ceg\u0000\u0d42\u0d43"+
		"\u0005\u0099\u0000\u0000\u0d43\u0d48\u0003\u00d0h\u0000\u0d44\u0d45\u0005"+
		"\u046f\u0000\u0000\u0d45\u0d47\u0003\u00d0h\u0000\u0d46\u0d44\u0001\u0000"+
		"\u0000\u0000\u0d47\u0d4a\u0001\u0000\u0000\u0000\u0d48\u0d46\u0001\u0000"+
		"\u0000\u0000\u0d48\u0d49\u0001\u0000\u0000\u0000\u0d49\u0d4c\u0001\u0000"+
		"\u0000\u0000\u0d4a\u0d48\u0001\u0000\u0000\u0000\u0d4b\u0d3f\u0001\u0000"+
		"\u0000\u0000\u0d4b\u0d42\u0001\u0000\u0000\u0000\u0d4c\u00c7\u0001\u0000"+
		"\u0000\u0000\u0d4d\u0d4f\u0003\u00fc~\u0000\u0d4e\u0d50\u0003\u00d4j\u0000"+
		"\u0d4f\u0d4e\u0001\u0000\u0000\u0000\u0d4f\u0d50\u0001\u0000\u0000\u0000"+
		"\u0d50\u0d8f\u0001\u0000\u0000\u0000\u0d51\u0d53\u0003\u00f8|\u0000\u0d52"+
		"\u0d54\u0003\u00d4j\u0000\u0d53\u0d52\u0001\u0000\u0000\u0000\u0d53\u0d54"+
		"\u0001\u0000\u0000\u0000\u0d54\u0d8f\u0001\u0000\u0000\u0000\u0d55\u0d58"+
		"\u0003\u00fe\u007f\u0000\u0d56\u0d58\u0003\u00fa}\u0000\u0d57\u0d55\u0001"+
		"\u0000\u0000\u0000\u0d57\u0d56\u0001\u0000\u0000\u0000\u0d58\u0d5a\u0001"+
		"\u0000\u0000\u0000\u0d59\u0d5b\u0003\u0102\u0081\u0000\u0d5a\u0d59\u0001"+
		"\u0000\u0000\u0000\u0d5b\u0d5c\u0001\u0000\u0000\u0000\u0d5c\u0d5a\u0001"+
		"\u0000\u0000\u0000\u0d5c\u0d5d\u0001\u0000\u0000\u0000\u0d5d\u0d66\u0001"+
		"\u0000\u0000\u0000\u0d5e\u0d60\u0005\u00b4\u0000\u0000\u0d5f\u0d61\u0007"+
		",\u0000\u0000\u0d60\u0d5f\u0001\u0000\u0000\u0000\u0d60\u0d61\u0001\u0000"+
		"\u0000\u0000\u0d61\u0d64\u0001\u0000\u0000\u0000\u0d62\u0d65\u0003\u00fc"+
		"~\u0000\u0d63\u0d65\u0003\u00f8|\u0000\u0d64\u0d62\u0001\u0000\u0000\u0000"+
		"\u0d64\u0d63\u0001\u0000\u0000\u0000\u0d65\u0d67\u0001\u0000\u0000\u0000"+
		"\u0d66\u0d5e\u0001\u0000\u0000\u0000\u0d66\u0d67\u0001\u0000\u0000\u0000"+
		"\u0d67\u0d69\u0001\u0000\u0000\u0000\u0d68\u0d6a\u0003\u00e6s\u0000\u0d69"+
		"\u0d68\u0001\u0000\u0000\u0000\u0d69\u0d6a\u0001\u0000\u0000\u0000\u0d6a"+
		"\u0d6c\u0001\u0000\u0000\u0000\u0d6b\u0d6d\u0003\u0126\u0093\u0000\u0d6c"+
		"\u0d6b\u0001\u0000\u0000\u0000\u0d6c\u0d6d\u0001\u0000\u0000\u0000\u0d6d"+
		"\u0d6f\u0001\u0000\u0000\u0000\u0d6e\u0d70\u0003\u00d4j\u0000\u0d6f\u0d6e"+
		"\u0001\u0000\u0000\u0000\u0d6f\u0d70\u0001\u0000\u0000\u0000\u0d70\u0d8f"+
		"\u0001\u0000\u0000\u0000\u0d71\u0d73\u0003\u00fa}\u0000\u0d72\u0d74\u0003"+
		"\u0100\u0080\u0000\u0d73\u0d72\u0001\u0000\u0000\u0000\u0d74\u0d75\u0001"+
		"\u0000\u0000\u0000\u0d75\u0d73\u0001\u0000\u0000\u0000\u0d75\u0d76\u0001"+
		"\u0000\u0000\u0000\u0d76\u0d7c\u0001\u0000\u0000\u0000\u0d77\u0d79\u0005"+
		"\u00b4\u0000\u0000\u0d78\u0d7a\u0007,\u0000\u0000\u0d79\u0d78\u0001\u0000"+
		"\u0000\u0000\u0d79\u0d7a\u0001\u0000\u0000\u0000\u0d7a\u0d7b\u0001\u0000"+
		"\u0000\u0000\u0d7b\u0d7d\u0003\u00f8|\u0000\u0d7c\u0d77\u0001\u0000\u0000"+
		"\u0000\u0d7c\u0d7d\u0001\u0000\u0000\u0000\u0d7d\u0d7f\u0001\u0000\u0000"+
		"\u0000\u0d7e\u0d80\u0003\u00e6s\u0000\u0d7f\u0d7e\u0001\u0000\u0000\u0000"+
		"\u0d7f\u0d80\u0001\u0000\u0000\u0000\u0d80\u0d82\u0001\u0000\u0000\u0000"+
		"\u0d81\u0d83\u0003\u0126\u0093\u0000\u0d82\u0d81\u0001\u0000\u0000\u0000"+
		"\u0d82\u0d83\u0001\u0000\u0000\u0000\u0d83\u0d85\u0001\u0000\u0000\u0000"+
		"\u0d84\u0d86\u0003\u00d4j\u0000\u0d85\u0d84\u0001\u0000\u0000\u0000\u0d85"+
		"\u0d86\u0001\u0000\u0000\u0000\u0d86\u0d8f\u0001\u0000\u0000\u0000\u0d87"+
		"\u0d8a\u0003\u00fe\u007f\u0000\u0d88\u0d89\u0005\u046f\u0000\u0000\u0d89"+
		"\u0d8b\u0003\u0104\u0082\u0000\u0d8a\u0d88\u0001\u0000\u0000\u0000\u0d8b"+
		"\u0d8c\u0001\u0000\u0000\u0000\u0d8c\u0d8a\u0001\u0000\u0000\u0000\u0d8c"+
		"\u0d8d\u0001\u0000\u0000\u0000\u0d8d\u0d8f\u0001\u0000\u0000\u0000\u0d8e"+
		"\u0d4d\u0001\u0000\u0000\u0000\u0d8e\u0d51\u0001\u0000\u0000\u0000\u0d8e"+
		"\u0d57\u0001\u0000\u0000\u0000\u0d8e\u0d71\u0001\u0000\u0000\u0000\u0d8e"+
		"\u0d87\u0001\u0000\u0000\u0000\u0d8f\u00c9\u0001\u0000\u0000\u0000\u0d90"+
		"\u0d93\u0003\u00e2q\u0000\u0d91\u0d93\u0003\u00e4r\u0000\u0d92\u0d90\u0001"+
		"\u0000\u0000\u0000\u0d92\u0d91\u0001\u0000\u0000\u0000\u0d93\u00cb\u0001"+
		"\u0000\u0000\u0000\u0d94\u0d95\u0005\u00bc\u0000\u0000\u0d95\u0d97\u0005"+
		"\u046d\u0000\u0000\u0d96\u0d98\u0003\u0272\u0139\u0000\u0d97\u0d96\u0001"+
		"\u0000\u0000\u0000\u0d97\u0d98\u0001\u0000\u0000\u0000\u0d98\u0d99\u0001"+
		"\u0000\u0000\u0000\u0d99\u0da2\u0005\u046e\u0000\u0000\u0d9a\u0d9b\u0005"+
		"\u046f\u0000\u0000\u0d9b\u0d9d\u0005\u046d\u0000\u0000\u0d9c\u0d9e\u0003"+
		"\u0272\u0139\u0000\u0d9d\u0d9c\u0001\u0000\u0000\u0000\u0d9d\u0d9e\u0001"+
		"\u0000\u0000\u0000\u0d9e\u0d9f\u0001\u0000\u0000\u0000\u0d9f\u0da1\u0005"+
		"\u046e\u0000\u0000\u0da0\u0d9a\u0001\u0000\u0000\u0000\u0da1\u0da4\u0001"+
		"\u0000\u0000\u0000\u0da2\u0da0\u0001\u0000\u0000\u0000\u0da2\u0da3\u0001"+
		"\u0000\u0000\u0000\u0da3\u00cd\u0001\u0000\u0000\u0000\u0da4\u0da2\u0001"+
		"\u0000\u0000\u0000\u0da5\u0db8\u0003\u00c8d\u0000\u0da6\u0da7\u0007-\u0000"+
		"\u0000\u0da7\u0da9\u0005\u046d\u0000\u0000\u0da8\u0daa\u0003\u0272\u0139"+
		"\u0000\u0da9\u0da8\u0001\u0000\u0000\u0000\u0da9\u0daa\u0001\u0000\u0000"+
		"\u0000\u0daa\u0dab\u0001\u0000\u0000\u0000\u0dab\u0db4\u0005\u046e\u0000"+
		"\u0000\u0dac\u0dad\u0005\u046f\u0000\u0000\u0dad\u0daf\u0005\u046d\u0000"+
		"\u0000\u0dae\u0db0\u0003\u0272\u0139\u0000\u0daf\u0dae\u0001\u0000\u0000"+
		"\u0000\u0daf\u0db0\u0001\u0000\u0000\u0000\u0db0\u0db1\u0001\u0000\u0000"+
		"\u0000\u0db1\u0db3\u0005\u046e\u0000\u0000\u0db2\u0dac\u0001\u0000\u0000"+
		"\u0000\u0db3\u0db6\u0001\u0000\u0000\u0000\u0db4\u0db2\u0001\u0000\u0000"+
		"\u0000\u0db4\u0db5\u0001\u0000\u0000\u0000\u0db5\u0db8\u0001\u0000\u0000"+
		"\u0000\u0db6\u0db4\u0001\u0000\u0000\u0000\u0db7\u0da5\u0001\u0000\u0000"+
		"\u0000\u0db7\u0da6\u0001\u0000\u0000\u0000\u0db8\u00cf\u0001\u0000\u0000"+
		"\u0000\u0db9\u0dba\u0003\u022c\u0116\u0000\u0dba\u0dbd\u0005\u0464\u0000"+
		"\u0000\u0dbb\u0dbe\u0003\u02b0\u0158\u0000\u0dbc\u0dbe\u0005*\u0000\u0000"+
		"\u0dbd\u0dbb\u0001\u0000\u0000\u0000\u0dbd\u0dbc\u0001\u0000\u0000\u0000"+
		"\u0dbe\u00d1\u0001\u0000\u0000\u0000\u0dbf\u0dc2\u0003\u0248\u0124\u0000"+
		"\u0dc0\u0dc2\u0005\u0487\u0000\u0000\u0dc1\u0dbf\u0001\u0000\u0000\u0000"+
		"\u0dc1\u0dc0\u0001\u0000\u0000\u0000\u0dc2\u00d3\u0001\u0000\u0000\u0000"+
		"\u0dc3\u0dc4\u0005A\u0000\u0000\u0dc4\u0dca\u0005\u00b8\u0000\u0000\u0dc5"+
		"\u0dc6\u0005g\u0000\u0000\u0dc6\u0dc7\u0005P\u0000\u0000\u0dc7\u0dc8\u0005"+
		"\u0262\u0000\u0000\u0dc8\u0dca\u0005\u01ff\u0000\u0000\u0dc9\u0dc3\u0001"+
		"\u0000\u0000\u0000\u0dc9\u0dc5\u0001\u0000\u0000\u0000\u0dca\u00d5\u0001"+
		"\u0000\u0000\u0000\u0dcb\u0dcd\u0005,\u0000\u0000\u0dcc\u0dce\u0005j\u0000"+
		"\u0000\u0dcd\u0dcc\u0001\u0000\u0000\u0000\u0dcd\u0dce\u0001\u0000\u0000"+
		"\u0000\u0dce\u0dd0\u0001\u0000\u0000\u0000\u0dcf\u0dd1\u0005\u0238\u0000"+
		"\u0000\u0dd0\u0dcf\u0001\u0000\u0000\u0000\u0dd0\u0dd1\u0001\u0000\u0000"+
		"\u0000\u0dd1\u0dd3\u0001\u0000\u0000\u0000\u0dd2\u0dd4\u0005N\u0000\u0000"+
		"\u0dd3\u0dd2\u0001\u0000\u0000\u0000\u0dd3\u0dd4\u0001\u0000\u0000\u0000"+
		"\u0dd4\u0dd5\u0001\u0000\u0000\u0000\u0dd5\u0dd6\u0005D\u0000\u0000\u0dd6"+
		"\u0ddb\u0003\u0228\u0114\u0000\u0dd7\u0dd9\u0005\f\u0000\u0000\u0dd8\u0dd7"+
		"\u0001\u0000\u0000\u0000\u0dd8\u0dd9\u0001\u0000\u0000\u0000\u0dd9\u0dda"+
		"\u0001\u0000\u0000\u0000\u0dda\u0ddc\u0003\u0248\u0124\u0000\u0ddb\u0dd8"+
		"\u0001\u0000\u0000\u0000\u0ddb\u0ddc\u0001\u0000\u0000\u0000\u0ddc\u0de2"+
		"\u0001\u0000\u0000\u0000\u0ddd\u0dde\u0005\u0081\u0000\u0000\u0dde\u0ddf"+
		"\u0005\u046d\u0000\u0000\u0ddf\u0de0\u0003\u0268\u0134\u0000\u0de0\u0de1"+
		"\u0005\u046e\u0000\u0000\u0de1\u0de3\u0001\u0000\u0000\u0000\u0de2\u0ddd"+
		"\u0001\u0000\u0000\u0000\u0de2\u0de3\u0001\u0000\u0000\u0000\u0de3\u0de6"+
		"\u0001\u0000\u0000\u0000\u0de4\u0de5\u0005\u00be\u0000\u0000\u0de5\u0de7"+
		"\u0003\u02b0\u0158\u0000\u0de6\u0de4\u0001\u0000\u0000\u0000\u0de6\u0de7"+
		"\u0001\u0000\u0000\u0000\u0de7\u0de9\u0001\u0000\u0000\u0000\u0de8\u0dea"+
		"\u0003\u00e6s\u0000\u0de9\u0de8\u0001\u0000\u0000\u0000\u0de9\u0dea\u0001"+
		"\u0000\u0000\u0000\u0dea\u0ded\u0001\u0000\u0000\u0000\u0deb\u0dec\u0005"+
		"c\u0000\u0000\u0dec\u0dee\u0003\u0128\u0094\u0000\u0ded\u0deb\u0001\u0000"+
		"\u0000\u0000\u0ded\u0dee\u0001\u0000\u0000\u0000\u0dee\u00d7\u0001\u0000"+
		"\u0000\u0000\u0def\u0df1\u0005,\u0000\u0000\u0df0\u0df2\u0005j\u0000\u0000"+
		"\u0df1\u0df0\u0001\u0000\u0000\u0000\u0df1\u0df2\u0001\u0000\u0000\u0000"+
		"\u0df2\u0df4\u0001\u0000\u0000\u0000\u0df3\u0df5\u0005\u0238\u0000\u0000"+
		"\u0df4\u0df3\u0001\u0000\u0000\u0000\u0df4\u0df5\u0001\u0000\u0000\u0000"+
		"\u0df5\u0df7\u0001\u0000\u0000\u0000\u0df6\u0df8\u0005N\u0000\u0000\u0df7"+
		"\u0df6\u0001\u0000\u0000\u0000\u0df7\u0df8\u0001\u0000\u0000\u0000\u0df8"+
		"\u0e20\u0001\u0000\u0000\u0000\u0df9\u0dfc\u0003\u0228\u0114\u0000\u0dfa"+
		"\u0dfb\u0005\u046c\u0000\u0000\u0dfb\u0dfd\u0005\u045d\u0000\u0000\u0dfc"+
		"\u0dfa\u0001\u0000\u0000\u0000\u0dfc\u0dfd\u0001\u0000\u0000\u0000\u0dfd"+
		"\u0e06\u0001\u0000\u0000\u0000\u0dfe\u0dff\u0005\u046f\u0000\u0000\u0dff"+
		"\u0e02\u0003\u0228\u0114\u0000\u0e00\u0e01\u0005\u046c\u0000\u0000\u0e01"+
		"\u0e03\u0005\u045d\u0000\u0000\u0e02\u0e00\u0001\u0000\u0000\u0000\u0e02"+
		"\u0e03\u0001\u0000\u0000\u0000\u0e03\u0e05\u0001\u0000\u0000\u0000\u0e04"+
		"\u0dfe\u0001\u0000\u0000\u0000\u0e05\u0e08\u0001\u0000\u0000\u0000\u0e06"+
		"\u0e04\u0001\u0000\u0000\u0000\u0e06\u0e07\u0001\u0000\u0000\u0000\u0e07"+
		"\u0e09\u0001\u0000\u0000\u0000\u0e08\u0e06\u0001\u0000\u0000\u0000\u0e09"+
		"\u0e0a\u0005D\u0000\u0000\u0e0a\u0e0b\u0003\u00eau\u0000\u0e0b\u0e21\u0001"+
		"\u0000\u0000\u0000\u0e0c\u0e0d\u0005D\u0000\u0000\u0e0d\u0e10\u0003\u0228"+
		"\u0114\u0000\u0e0e\u0e0f\u0005\u046c\u0000\u0000\u0e0f\u0e11\u0005\u045d"+
		"\u0000\u0000\u0e10\u0e0e\u0001\u0000\u0000\u0000\u0e10\u0e11\u0001\u0000"+
		"\u0000\u0000\u0e11\u0e1a\u0001\u0000\u0000\u0000\u0e12\u0e13\u0005\u046f"+
		"\u0000\u0000\u0e13\u0e16\u0003\u0228\u0114\u0000\u0e14\u0e15\u0005\u046c"+
		"\u0000\u0000\u0e15\u0e17\u0005\u045d\u0000\u0000\u0e16\u0e14\u0001\u0000"+
		"\u0000\u0000\u0e16\u0e17\u0001\u0000\u0000\u0000\u0e17\u0e19\u0001\u0000"+
		"\u0000\u0000\u0e18\u0e12\u0001\u0000\u0000\u0000\u0e19\u0e1c\u0001\u0000"+
		"\u0000\u0000\u0e1a\u0e18\u0001\u0000\u0000\u0000\u0e1a\u0e1b\u0001\u0000"+
		"\u0000\u0000\u0e1b\u0e1d\u0001\u0000\u0000\u0000\u0e1c\u0e1a\u0001\u0000"+
		"\u0000\u0000\u0e1d\u0e1e\u0005\u00bb\u0000\u0000\u0e1e\u0e1f\u0003\u00ea"+
		"u\u0000\u0e1f\u0e21\u0001\u0000\u0000\u0000\u0e20\u0df9\u0001\u0000\u0000"+
		"\u0000\u0e20\u0e0c\u0001\u0000\u0000\u0000\u0e21\u0e24\u0001\u0000\u0000"+
		"\u0000\u0e22\u0e23\u0005\u00be\u0000\u0000\u0e23\u0e25\u0003\u02b0\u0158"+
		"\u0000\u0e24\u0e22\u0001\u0000\u0000\u0000\u0e24\u0e25\u0001\u0000\u0000"+
		"\u0000\u0e25\u00d9\u0001\u0000\u0000\u0000\u0e26\u0e27\u0005\u01ba\u0000"+
		"\u0000\u0e27\u0e28\u0003\u0228\u0114\u0000\u0e28\u0e2d\u0005\u021b\u0000"+
		"\u0000\u0e29\u0e2b\u0005\f\u0000\u0000\u0e2a\u0e29\u0001\u0000\u0000\u0000"+
		"\u0e2a\u0e2b\u0001\u0000\u0000\u0000\u0e2b\u0e2c\u0001\u0000\u0000\u0000"+
		"\u0e2c\u0e2e\u0003\u0248\u0124\u0000\u0e2d\u0e2a\u0001\u0000\u0000\u0000"+
		"\u0e2d\u0e2e\u0001\u0000\u0000\u0000\u0e2e\u00db\u0001\u0000\u0000\u0000"+
		"\u0e2f\u0e30\u0005\u01ba\u0000\u0000\u0e30\u0e31\u0003\u0228\u0114\u0000"+
		"\u0e31\u0e32\u0005\u0086\u0000\u0000\u0e32\u0e39\u0003\u0248\u0124\u0000"+
		"\u0e33\u0e34\u0003\u02b8\u015c\u0000\u0e34\u0e35\u0005\u046d\u0000\u0000"+
		"\u0e35\u0e36\u0003\u0274\u013a\u0000\u0e36\u0e37\u0005\u046e\u0000\u0000"+
		"\u0e37\u0e3a\u0001\u0000\u0000\u0000\u0e38\u0e3a\u0007.\u0000\u0000\u0e39"+
		"\u0e33\u0001\u0000\u0000\u0000\u0e39\u0e38\u0001\u0000\u0000\u0000\u0e3a"+
		"\u0e3d\u0001\u0000\u0000\u0000\u0e3b\u0e3c\u0005\u00be\u0000\u0000\u0e3c"+
		"\u0e3e\u0003\u02b0\u0158\u0000\u0e3d\u0e3b\u0001\u0000\u0000\u0000\u0e3d"+
		"\u0e3e\u0001\u0000\u0000\u0000\u0e3e\u0e41\u0001\u0000\u0000\u0000\u0e3f"+
		"\u0e40\u0005c\u0000\u0000\u0e40\u0e42\u0003\u0128\u0094\u0000\u0e41\u0e3f"+
		"\u0001\u0000\u0000\u0000\u0e41\u0e42\u0001\u0000\u0000\u0000\u0e42\u00dd"+
		"\u0001\u0000\u0000\u0000\u0e43\u0e44\u0005\u01ba\u0000\u0000\u0e44\u0e45"+
		"\u0003\u0228\u0114\u0000\u0e45\u0e46\u0005\u0086\u0000\u0000\u0e46\u0e49"+
		"\u0007/\u0000\u0000\u0e47\u0e48\u0005\u00be\u0000\u0000\u0e48\u0e4a\u0003"+
		"\u02b0\u0158\u0000\u0e49\u0e47\u0001\u0000\u0000\u0000\u0e49\u0e4a\u0001"+
		"\u0000\u0000\u0000\u0e4a\u0e4d\u0001\u0000\u0000\u0000\u0e4b\u0e4c\u0005"+
		"c\u0000\u0000\u0e4c\u0e4e\u0003\u0128\u0094\u0000\u0e4d\u0e4b\u0001\u0000"+
		"\u0000\u0000\u0e4d\u0e4e\u0001\u0000\u0000\u0000\u0e4e\u00df\u0001\u0000"+
		"\u0000\u0000\u0e4f\u0e50\u0005\u01ba\u0000\u0000\u0e50\u0e51\u0003\u0228"+
		"\u0114\u0000\u0e51\u0e52\u0005\u0169\u0000\u0000\u0e52\u00e1\u0001\u0000"+
		"\u0000\u0000\u0e53\u0e55\u0005\u00b8\u0000\u0000\u0e54\u0e56\u0005j\u0000"+
		"\u0000\u0e55\u0e54\u0001\u0000\u0000\u0000\u0e55\u0e56\u0001\u0000\u0000"+
		"\u0000\u0e56\u0e58\u0001\u0000\u0000\u0000\u0e57\u0e59\u0005N\u0000\u0000"+
		"\u0e58\u0e57\u0001\u0000\u0000\u0000\u0e58\u0e59\u0001\u0000\u0000\u0000"+
		"\u0e59\u0e5a\u0001\u0000\u0000\u0000\u0e5a\u0e5f\u0003\u0228\u0114\u0000"+
		"\u0e5b\u0e5d\u0005\f\u0000\u0000\u0e5c\u0e5b\u0001\u0000\u0000\u0000\u0e5c"+
		"\u0e5d\u0001\u0000\u0000\u0000\u0e5d\u0e5e\u0001\u0000\u0000\u0000\u0e5e"+
		"\u0e60\u0003\u0248\u0124\u0000\u0e5f\u0e5c\u0001\u0000\u0000\u0000\u0e5f"+
		"\u0e60\u0001\u0000\u0000\u0000\u0e60\u0e61\u0001\u0000\u0000\u0000\u0e61"+
		"\u0e62\u0005\u0099\u0000\u0000\u0e62\u0e67\u0003\u00d0h\u0000\u0e63\u0e64"+
		"\u0005\u046f\u0000\u0000\u0e64\u0e66\u0003\u00d0h\u0000\u0e65\u0e63\u0001"+
		"\u0000\u0000\u0000\u0e66\u0e69\u0001\u0000\u0000\u0000\u0e67\u0e65\u0001"+
		"\u0000\u0000\u0000\u0e67\u0e68\u0001\u0000\u0000\u0000\u0e68\u0e6c\u0001"+
		"\u0000\u0000\u0000\u0e69\u0e67\u0001\u0000\u0000\u0000\u0e6a\u0e6b\u0005"+
		"\u00be\u0000\u0000\u0e6b\u0e6d\u0003\u02b0\u0158\u0000\u0e6c\u0e6a\u0001"+
		"\u0000\u0000\u0000\u0e6c\u0e6d\u0001\u0000\u0000\u0000\u0e6d\u0e6f\u0001"+
		"\u0000\u0000\u0000\u0e6e\u0e70\u0003\u00e6s\u0000\u0e6f\u0e6e\u0001\u0000"+
		"\u0000\u0000\u0e6f\u0e70\u0001\u0000\u0000\u0000\u0e70\u0e72\u0001\u0000"+
		"\u0000\u0000\u0e71\u0e73\u0003\u0126\u0093\u0000\u0e72\u0e71\u0001\u0000"+
		"\u0000\u0000\u0e72\u0e73\u0001\u0000\u0000\u0000\u0e73\u00e3\u0001\u0000"+
		"\u0000\u0000\u0e74\u0e76\u0005\u00b8\u0000\u0000\u0e75\u0e77\u0005j\u0000"+
		"\u0000\u0e76\u0e75\u0001\u0000\u0000\u0000\u0e76\u0e77\u0001\u0000\u0000"+
		"\u0000\u0e77\u0e79\u0001\u0000\u0000\u0000\u0e78\u0e7a\u0005N\u0000\u0000"+
		"\u0e79\u0e78\u0001\u0000\u0000\u0000\u0e79\u0e7a\u0001\u0000\u0000\u0000"+
		"\u0e7a\u0e7b\u0001\u0000\u0000\u0000\u0e7b\u0e7c\u0003\u00eau\u0000\u0e7c"+
		"\u0e7d\u0005\u0099\u0000\u0000\u0e7d\u0e82\u0003\u00d0h\u0000\u0e7e\u0e7f"+
		"\u0005\u046f\u0000\u0000\u0e7f\u0e81\u0003\u00d0h\u0000\u0e80\u0e7e\u0001"+
		"\u0000\u0000\u0000\u0e81\u0e84\u0001\u0000\u0000\u0000\u0e82\u0e80\u0001"+
		"\u0000\u0000\u0000\u0e82\u0e83\u0001\u0000\u0000\u0000\u0e83\u0e87\u0001"+
		"\u0000\u0000\u0000\u0e84\u0e82\u0001\u0000\u0000\u0000\u0e85\u0e86\u0005"+
		"\u00be\u0000\u0000\u0e86\u0e88\u0003\u02b0\u0158\u0000\u0e87\u0e85\u0001"+
		"\u0000\u0000\u0000\u0e87\u0e88\u0001\u0000\u0000\u0000\u0e88\u00e5\u0001"+
		"\u0000\u0000\u0000\u0e89\u0e8a\u0005|\u0000\u0000\u0e8a\u0e8b\u0005\u0013"+
		"\u0000\u0000\u0e8b\u0e90\u0003\u00e8t\u0000\u0e8c\u0e8d\u0005\u046f\u0000"+
		"\u0000\u0e8d\u0e8f\u0003\u00e8t\u0000\u0e8e\u0e8c\u0001\u0000\u0000\u0000"+
		"\u0e8f\u0e92\u0001\u0000\u0000\u0000\u0e90\u0e8e\u0001\u0000\u0000\u0000"+
		"\u0e90\u0e91\u0001\u0000\u0000\u0000\u0e91\u00e7\u0001\u0000\u0000\u0000"+
		"\u0e92\u0e90\u0001\u0000\u0000\u0000\u0e93\u0e95\u0003\u02b0\u0158\u0000"+
		"\u0e94\u0e96\u00070\u0000\u0000\u0e95\u0e94\u0001\u0000\u0000\u0000\u0e95"+
		"\u0e96\u0001\u0000\u0000\u0000\u0e96\u00e9\u0001\u0000\u0000\u0000\u0e97"+
		"\u0e9c\u0003\u00ecv\u0000\u0e98\u0e99\u0005\u046f\u0000\u0000\u0e99\u0e9b"+
		"\u0003\u00ecv\u0000\u0e9a\u0e98\u0001\u0000\u0000\u0000\u0e9b\u0e9e\u0001"+
		"\u0000\u0000\u0000\u0e9c\u0e9a\u0001\u0000\u0000\u0000\u0e9c\u0e9d\u0001"+
		"\u0000\u0000\u0000\u0e9d\u00eb\u0001\u0000\u0000\u0000\u0e9e\u0e9c\u0001"+
		"\u0000\u0000\u0000\u0e9f\u0ea3\u0003\u00eew\u0000\u0ea0\u0ea2\u0003\u00f4"+
		"z\u0000\u0ea1\u0ea0\u0001\u0000\u0000\u0000\u0ea2\u0ea5\u0001\u0000\u0000"+
		"\u0000\u0ea3\u0ea1\u0001\u0000\u0000\u0000\u0ea3\u0ea4\u0001\u0000\u0000"+
		"\u0000\u0ea4\u0eb2\u0001\u0000\u0000\u0000\u0ea5\u0ea3\u0001\u0000\u0000"+
		"\u0000\u0ea6\u0ea7\u0005\u046d\u0000\u0000\u0ea7\u0eab\u0003\u00eew\u0000"+
		"\u0ea8\u0eaa\u0003\u00f4z\u0000\u0ea9\u0ea8\u0001\u0000\u0000\u0000\u0eaa"+
		"\u0ead\u0001\u0000\u0000\u0000\u0eab\u0ea9\u0001\u0000\u0000\u0000\u0eab"+
		"\u0eac\u0001\u0000\u0000\u0000\u0eac\u0eae\u0001\u0000\u0000\u0000\u0ead"+
		"\u0eab\u0001\u0000\u0000\u0000\u0eae\u0eaf\u0005\u046e\u0000\u0000\u0eaf"+
		"\u0eb2\u0001\u0000\u0000\u0000\u0eb0\u0eb2\u0003\u0106\u0083\u0000\u0eb1"+
		"\u0e9f\u0001\u0000\u0000\u0000\u0eb1\u0ea6\u0001\u0000\u0000\u0000\u0eb1"+
		"\u0eb0\u0001\u0000\u0000\u0000\u0eb2\u00ed\u0001\u0000\u0000\u0000\u0eb3"+
		"\u0eb9\u0003\u0228\u0114\u0000\u0eb4\u0eb5\u0005\u0081\u0000\u0000\u0eb5"+
		"\u0eb6\u0005\u046d\u0000\u0000\u0eb6\u0eb7\u0003\u0268\u0134\u0000\u0eb7"+
		"\u0eb8\u0005\u046e\u0000\u0000\u0eb8\u0eba\u0001\u0000\u0000\u0000\u0eb9"+
		"\u0eb4\u0001\u0000\u0000\u0000\u0eb9\u0eba\u0001\u0000\u0000\u0000\u0eba"+
		"\u0ebf\u0001\u0000\u0000\u0000\u0ebb\u0ebd\u0005\f\u0000\u0000\u0ebc\u0ebb"+
		"\u0001\u0000\u0000\u0000\u0ebc\u0ebd\u0001\u0000\u0000\u0000\u0ebd\u0ebe"+
		"\u0001\u0000\u0000\u0000\u0ebe\u0ec0\u0003\u0248\u0124\u0000\u0ebf\u0ebc"+
		"\u0001\u0000\u0000\u0000\u0ebf\u0ec0\u0001\u0000\u0000\u0000\u0ec0\u0ec9"+
		"\u0001\u0000\u0000\u0000\u0ec1\u0ec6\u0003\u00f0x\u0000\u0ec2\u0ec3\u0005"+
		"\u046f\u0000\u0000\u0ec3\u0ec5\u0003\u00f0x\u0000\u0ec4\u0ec2\u0001\u0000"+
		"\u0000\u0000\u0ec5\u0ec8\u0001\u0000\u0000\u0000\u0ec6\u0ec4\u0001\u0000"+
		"\u0000\u0000\u0ec6\u0ec7\u0001\u0000\u0000\u0000\u0ec7\u0eca\u0001\u0000"+
		"\u0000\u0000\u0ec8\u0ec6\u0001\u0000\u0000\u0000\u0ec9\u0ec1\u0001\u0000"+
		"\u0000\u0000\u0ec9\u0eca\u0001\u0000\u0000\u0000\u0eca\u0edc\u0001\u0000"+
		"\u0000\u0000\u0ecb\u0ed1\u0003\u00c8d\u0000\u0ecc\u0ecd\u0005\u046d\u0000"+
		"\u0000\u0ecd\u0ece\u0003\u00c8d\u0000\u0ece\u0ecf\u0005\u046e\u0000\u0000"+
		"\u0ecf\u0ed1\u0001\u0000\u0000\u0000\u0ed0\u0ecb\u0001\u0000\u0000\u0000"+
		"\u0ed0\u0ecc\u0001\u0000\u0000\u0000\u0ed1\u0ed3\u0001\u0000\u0000\u0000"+
		"\u0ed2\u0ed4\u0005\f\u0000\u0000\u0ed3\u0ed2\u0001\u0000\u0000\u0000\u0ed3"+
		"\u0ed4\u0001\u0000\u0000\u0000\u0ed4\u0ed5\u0001\u0000\u0000\u0000\u0ed5"+
		"\u0ed6\u0003\u0248\u0124\u0000\u0ed6\u0edc\u0001\u0000\u0000\u0000\u0ed7"+
		"\u0ed8\u0005\u046d\u0000\u0000\u0ed8\u0ed9\u0003\u00eau\u0000\u0ed9\u0eda"+
		"\u0005\u046e\u0000\u0000\u0eda\u0edc\u0001\u0000\u0000\u0000\u0edb\u0eb3"+
		"\u0001\u0000\u0000\u0000\u0edb\u0ed0\u0001\u0000\u0000\u0000\u0edb\u0ed7"+
		"\u0001\u0000\u0000\u0000\u0edc\u00ef\u0001\u0000\u0000\u0000\u0edd\u0ede"+
		"\u00071\u0000\u0000\u0ede\u0ee1\u0007\u0014\u0000\u0000\u0edf\u0ee0\u0005"+
		"A\u0000\u0000\u0ee0\u0ee2\u0003\u00f2y\u0000\u0ee1\u0edf\u0001\u0000\u0000"+
		"\u0000\u0ee1\u0ee2\u0001\u0000\u0000\u0000\u0ee2\u0ee3\u0001\u0000\u0000"+
		"\u0000\u0ee3\u0ee4\u0005\u046d\u0000\u0000\u0ee4\u0ee5\u0003\u0268\u0134"+
		"\u0000\u0ee5\u0ee6\u0005\u046e\u0000\u0000\u0ee6\u00f1\u0001\u0000\u0000"+
		"\u0000\u0ee7\u0eed\u0005Z\u0000\u0000\u0ee8\u0ee9\u0005|\u0000\u0000\u0ee9"+
		"\u0eed\u0005\u0013\u0000\u0000\u0eea\u0eeb\u0005I\u0000\u0000\u0eeb\u0eed"+
		"\u0005\u0013\u0000\u0000\u0eec\u0ee7\u0001\u0000\u0000\u0000\u0eec\u0ee8"+
		"\u0001\u0000\u0000\u0000\u0eec\u0eea\u0001\u0000\u0000\u0000\u0eed\u00f3"+
		"\u0001\u0000\u0000\u0000\u0eee\u0ef0\u00072\u0000\u0000\u0eef\u0eee\u0001"+
		"\u0000\u0000\u0000\u0eef\u0ef0\u0001\u0000\u0000\u0000\u0ef0\u0ef1\u0001"+
		"\u0000\u0000\u0000\u0ef1\u0ef3\u0005Z\u0000\u0000\u0ef2\u0ef4\u0005^\u0000"+
		"\u0000\u0ef3\u0ef2\u0001\u0000\u0000\u0000\u0ef3\u0ef4\u0001\u0000\u0000"+
		"\u0000\u0ef4\u0ef5\u0001\u0000\u0000\u0000\u0ef5\u0ef9\u0003\u00eew\u0000"+
		"\u0ef6\u0ef8\u0003\u00f6{\u0000\u0ef7\u0ef6\u0001\u0000\u0000\u0000\u0ef8"+
		"\u0efb\u0001\u0000\u0000\u0000\u0ef9\u0ef7\u0001\u0000\u0000\u0000\u0ef9"+
		"\u0efa\u0001\u0000\u0000\u0000\u0efa\u0f1e\u0001\u0000\u0000\u0000\u0efb"+
		"\u0ef9\u0001\u0000\u0000\u0000\u0efc\u0efd\u0005\u00ab\u0000\u0000\u0efd"+
		"\u0f02\u0003\u00eew\u0000\u0efe\u0eff\u0005v\u0000\u0000\u0eff\u0f01\u0003"+
		"\u02b0\u0158\u0000\u0f00\u0efe\u0001\u0000\u0000\u0000\u0f01\u0f04\u0001"+
		"\u0000\u0000\u0000\u0f02\u0f00\u0001\u0000\u0000\u0000\u0f02\u0f03\u0001"+
		"\u0000\u0000\u0000\u0f03\u0f1e\u0001\u0000\u0000\u0000\u0f04\u0f02\u0001"+
		"\u0000\u0000\u0000\u0f05\u0f07\u00073\u0000\u0000\u0f06\u0f08\u0005~\u0000"+
		"\u0000\u0f07\u0f06\u0001\u0000\u0000\u0000\u0f07\u0f08\u0001\u0000\u0000"+
		"\u0000\u0f08\u0f09\u0001\u0000\u0000\u0000\u0f09\u0f0b\u0005Z\u0000\u0000"+
		"\u0f0a\u0f0c\u0005^\u0000\u0000\u0f0b\u0f0a\u0001\u0000\u0000\u0000\u0f0b"+
		"\u0f0c\u0001\u0000\u0000\u0000\u0f0c\u0f0d\u0001\u0000\u0000\u0000\u0f0d"+
		"\u0f11\u0003\u00eew\u0000\u0f0e\u0f10\u0003\u00f6{\u0000\u0f0f\u0f0e\u0001"+
		"\u0000\u0000\u0000\u0f10\u0f13\u0001\u0000\u0000\u0000\u0f11\u0f0f\u0001"+
		"\u0000\u0000\u0000\u0f11\u0f12\u0001\u0000\u0000\u0000\u0f12\u0f1e\u0001"+
		"\u0000\u0000\u0000\u0f13\u0f11\u0001\u0000\u0000\u0000\u0f14\u0f19\u0005"+
		"q\u0000\u0000\u0f15\u0f17\u00073\u0000\u0000\u0f16\u0f18\u0005~\u0000"+
		"\u0000\u0f17\u0f16\u0001\u0000\u0000\u0000\u0f17\u0f18\u0001\u0000\u0000"+
		"\u0000\u0f18\u0f1a\u0001\u0000\u0000\u0000\u0f19\u0f15\u0001\u0000\u0000"+
		"\u0000\u0f19\u0f1a\u0001\u0000\u0000\u0000\u0f1a\u0f1b\u0001\u0000\u0000"+
		"\u0000\u0f1b\u0f1c\u0005Z\u0000\u0000\u0f1c\u0f1e\u0003\u00eew\u0000\u0f1d"+
		"\u0eef\u0001\u0000\u0000\u0000\u0f1d\u0efc\u0001\u0000\u0000\u0000\u0f1d"+
		"\u0f05\u0001\u0000\u0000";
	private static final String _serializedATNSegment2 =
		"\u0000\u0f1d\u0f14\u0001\u0000\u0000\u0000\u0f1e\u00f5\u0001\u0000\u0000"+
		"\u0000\u0f1f\u0f20\u0005v\u0000\u0000\u0f20\u0f27\u0003\u02b0\u0158\u0000"+
		"\u0f21\u0f22\u0005\u00bb\u0000\u0000\u0f22\u0f23\u0005\u046d\u0000\u0000"+
		"\u0f23\u0f24\u0003\u0268\u0134\u0000\u0f24\u0f25\u0005\u046e\u0000\u0000"+
		"\u0f25\u0f27\u0001\u0000\u0000\u0000\u0f26\u0f1f\u0001\u0000\u0000\u0000"+
		"\u0f26\u0f21\u0001\u0000\u0000\u0000\u0f27\u00f7\u0001\u0000\u0000\u0000"+
		"\u0f28\u0f29\u0005\u046d\u0000\u0000\u0f29\u0f2a\u0003\u00fc~\u0000\u0f2a"+
		"\u0f2b\u0005\u046e\u0000\u0000\u0f2b\u0f31\u0001\u0000\u0000\u0000\u0f2c"+
		"\u0f2d\u0005\u046d\u0000\u0000\u0f2d\u0f2e\u0003\u00f8|\u0000\u0f2e\u0f2f"+
		"\u0005\u046e\u0000\u0000\u0f2f\u0f31\u0001\u0000\u0000\u0000\u0f30\u0f28"+
		"\u0001\u0000\u0000\u0000\u0f30\u0f2c\u0001\u0000\u0000\u0000\u0f31\u00f9"+
		"\u0001\u0000\u0000\u0000\u0f32\u0f33\u0005\u046d\u0000\u0000\u0f33\u0f34"+
		"\u0003\u00fe\u007f\u0000\u0f34\u0f35\u0005\u046e\u0000\u0000\u0f35\u0f3b"+
		"\u0001\u0000\u0000\u0000\u0f36\u0f37\u0005\u046d\u0000\u0000\u0f37\u0f38"+
		"\u0003\u00fa}\u0000\u0f38\u0f39\u0005\u046e\u0000\u0000\u0f39\u0f3b\u0001"+
		"\u0000\u0000\u0000\u0f3a\u0f32\u0001\u0000\u0000\u0000\u0f3a\u0f36\u0001"+
		"\u0000\u0000\u0000\u0f3b\u00fb\u0001\u0000\u0000\u0000\u0f3c\u0f40\u0005"+
		"\u0098\u0000\u0000\u0f3d\u0f3f\u0003\u0110\u0088\u0000\u0f3e\u0f3d\u0001"+
		"\u0000\u0000\u0000\u0f3f\u0f42\u0001\u0000\u0000\u0000\u0f40\u0f3e\u0001"+
		"\u0000\u0000\u0000\u0f40\u0f41\u0001\u0000\u0000\u0000\u0f41\u0f43\u0001"+
		"\u0000\u0000\u0000\u0f42\u0f40\u0001\u0000\u0000\u0000\u0f43\u0f45\u0003"+
		"\u0112\u0089\u0000\u0f44\u0f46\u0003\u0116\u008b\u0000\u0f45\u0f44\u0001"+
		"\u0000\u0000\u0000\u0f45\u0f46\u0001\u0000\u0000\u0000\u0f46\u0f47\u0001"+
		"\u0000\u0000\u0000\u0f47\u0f49\u0003\u011c\u008e\u0000\u0f48\u0f4a\u0003"+
		"\u011e\u008f\u0000\u0f49\u0f48\u0001\u0000\u0000\u0000\u0f49\u0f4a\u0001"+
		"\u0000\u0000\u0000\u0f4a\u0f4c\u0001\u0000\u0000\u0000\u0f4b\u0f4d\u0003"+
		"\u0120\u0090\u0000\u0f4c\u0f4b\u0001\u0000\u0000\u0000\u0f4c\u0f4d\u0001"+
		"\u0000\u0000\u0000\u0f4d\u0f4f\u0001\u0000\u0000\u0000\u0f4e\u0f50\u0003"+
		"\u0122\u0091\u0000\u0f4f\u0f4e\u0001\u0000\u0000\u0000\u0f4f\u0f50\u0001"+
		"\u0000\u0000\u0000\u0f50\u0f52\u0001\u0000\u0000\u0000\u0f51\u0f53\u0003"+
		"\u00e6s\u0000\u0f52\u0f51\u0001\u0000\u0000\u0000\u0f52\u0f53\u0001\u0000"+
		"\u0000\u0000\u0f53\u0f55\u0001\u0000\u0000\u0000\u0f54\u0f56\u0003\u0126"+
		"\u0093\u0000\u0f55\u0f54\u0001\u0000\u0000\u0000\u0f55\u0f56\u0001\u0000"+
		"\u0000\u0000\u0f56\u0f73\u0001\u0000\u0000\u0000\u0f57\u0f5b\u0005\u0098"+
		"\u0000\u0000\u0f58\u0f5a\u0003\u0110\u0088\u0000\u0f59\u0f58\u0001\u0000"+
		"\u0000\u0000\u0f5a\u0f5d\u0001\u0000\u0000\u0000\u0f5b\u0f59\u0001\u0000"+
		"\u0000\u0000\u0f5b\u0f5c\u0001\u0000\u0000\u0000\u0f5c\u0f5e\u0001\u0000"+
		"\u0000\u0000\u0f5d\u0f5b\u0001\u0000\u0000\u0000\u0f5e\u0f5f\u0003\u0112"+
		"\u0089\u0000\u0f5f\u0f61\u0003\u011c\u008e\u0000\u0f60\u0f62\u0003\u011e"+
		"\u008f\u0000\u0f61\u0f60\u0001\u0000\u0000\u0000\u0f61\u0f62\u0001\u0000"+
		"\u0000\u0000\u0f62\u0f64\u0001\u0000\u0000\u0000\u0f63\u0f65\u0003\u0120"+
		"\u0090\u0000\u0f64\u0f63\u0001\u0000\u0000\u0000\u0f64\u0f65\u0001\u0000"+
		"\u0000\u0000\u0f65\u0f67\u0001\u0000\u0000\u0000\u0f66\u0f68\u0003\u0122"+
		"\u0091\u0000\u0f67\u0f66\u0001\u0000\u0000\u0000\u0f67\u0f68\u0001\u0000"+
		"\u0000\u0000\u0f68\u0f6a\u0001\u0000\u0000\u0000\u0f69\u0f6b\u0003\u00e6"+
		"s\u0000\u0f6a\u0f69\u0001\u0000\u0000\u0000\u0f6a\u0f6b\u0001\u0000\u0000"+
		"\u0000\u0f6b\u0f6d\u0001\u0000\u0000\u0000\u0f6c\u0f6e\u0003\u0126\u0093"+
		"\u0000\u0f6d\u0f6c\u0001\u0000\u0000\u0000\u0f6d\u0f6e\u0001\u0000\u0000"+
		"\u0000\u0f6e\u0f70\u0001\u0000\u0000\u0000\u0f6f\u0f71\u0003\u0116\u008b"+
		"\u0000\u0f70\u0f6f\u0001\u0000\u0000\u0000\u0f70\u0f71\u0001\u0000\u0000"+
		"\u0000\u0f71\u0f73\u0001\u0000\u0000\u0000\u0f72\u0f3c\u0001\u0000\u0000"+
		"\u0000\u0f72\u0f57\u0001\u0000\u0000\u0000\u0f73\u00fd\u0001\u0000\u0000"+
		"\u0000\u0f74\u0f78\u0005\u0098\u0000\u0000\u0f75\u0f77\u0003\u0110\u0088"+
		"\u0000\u0f76\u0f75\u0001\u0000\u0000\u0000\u0f77\u0f7a\u0001\u0000\u0000"+
		"\u0000\u0f78\u0f76\u0001\u0000\u0000\u0000\u0f78\u0f79\u0001\u0000\u0000"+
		"\u0000\u0f79\u0f7b\u0001\u0000\u0000\u0000\u0f7a\u0f78\u0001\u0000\u0000"+
		"\u0000\u0f7b\u0f7c\u0003\u0112\u0089\u0000\u0f7c\u0f7e\u0003\u011c\u008e"+
		"\u0000\u0f7d\u0f7f\u0003\u011e\u008f\u0000\u0f7e\u0f7d\u0001\u0000\u0000"+
		"\u0000\u0f7e\u0f7f\u0001\u0000\u0000\u0000\u0f7f\u0f81\u0001\u0000\u0000"+
		"\u0000\u0f80\u0f82\u0003\u0120\u0090\u0000\u0f81\u0f80\u0001\u0000\u0000"+
		"\u0000\u0f81\u0f82\u0001\u0000\u0000\u0000\u0f82\u0f84\u0001\u0000\u0000"+
		"\u0000\u0f83\u0f85\u0003\u0122\u0091\u0000\u0f84\u0f83\u0001\u0000\u0000"+
		"\u0000\u0f84\u0f85\u0001\u0000\u0000\u0000\u0f85\u0f87\u0001\u0000\u0000"+
		"\u0000\u0f86\u0f88\u0003\u00e6s\u0000\u0f87\u0f86\u0001\u0000\u0000\u0000"+
		"\u0f87\u0f88\u0001\u0000\u0000\u0000\u0f88\u0f8a\u0001\u0000\u0000\u0000"+
		"\u0f89\u0f8b\u0003\u0126\u0093\u0000\u0f8a\u0f89\u0001\u0000\u0000\u0000"+
		"\u0f8a\u0f8b\u0001\u0000\u0000\u0000\u0f8b\u00ff\u0001\u0000\u0000\u0000"+
		"\u0f8c\u0f8e\u0005\u00b4\u0000\u0000\u0f8d\u0f8f\u0007,\u0000\u0000\u0f8e"+
		"\u0f8d\u0001\u0000\u0000\u0000\u0f8e\u0f8f\u0001\u0000\u0000\u0000\u0f8f"+
		"\u0f90\u0001\u0000\u0000\u0000\u0f90\u0f91\u0003\u00fa}\u0000\u0f91\u0101"+
		"\u0001\u0000\u0000\u0000\u0f92\u0f94\u0005\u00b4\u0000\u0000\u0f93\u0f95"+
		"\u0007,\u0000\u0000\u0f94\u0f93\u0001\u0000\u0000\u0000\u0f94\u0f95\u0001"+
		"\u0000\u0000\u0000\u0f95\u0f98\u0001\u0000\u0000\u0000\u0f96\u0f99\u0003"+
		"\u00fe\u007f\u0000\u0f97\u0f99\u0003\u00fa}\u0000\u0f98\u0f96\u0001\u0000"+
		"\u0000\u0000\u0f98\u0f97\u0001\u0000\u0000\u0000\u0f99\u0103\u0001\u0000"+
		"\u0000\u0000\u0f9a\u0fa9\u0005^\u0000\u0000\u0f9b\u0faa\u0003\u00fe\u007f"+
		"\u0000\u0f9c\u0faa\u0003\u00fa}\u0000\u0f9d\u0fa0\u0005\u046d\u0000\u0000"+
		"\u0f9e\u0fa1\u0003\u00fe\u007f\u0000\u0f9f\u0fa1\u0003\u00fa}\u0000\u0fa0"+
		"\u0f9e\u0001\u0000\u0000\u0000\u0fa0\u0f9f\u0001\u0000\u0000\u0000\u0fa1"+
		"\u0fa2\u0001\u0000\u0000\u0000\u0fa2\u0fa7\u0005\u046e\u0000\u0000\u0fa3"+
		"\u0fa5\u0005\f\u0000\u0000\u0fa4\u0fa3\u0001\u0000\u0000\u0000\u0fa4\u0fa5"+
		"\u0001\u0000\u0000\u0000\u0fa5\u0fa6\u0001\u0000\u0000\u0000\u0fa6\u0fa8"+
		"\u0003\u0248\u0124\u0000\u0fa7\u0fa4\u0001\u0000\u0000\u0000\u0fa7\u0fa8"+
		"\u0001\u0000\u0000\u0000\u0fa8\u0faa\u0001\u0000\u0000\u0000\u0fa9\u0f9b"+
		"\u0001\u0000\u0000\u0000\u0fa9\u0f9c\u0001\u0000\u0000\u0000\u0fa9\u0f9d"+
		"\u0001\u0000\u0000\u0000\u0faa\u0105\u0001\u0000\u0000\u0000\u0fab\u0fac"+
		"\u0005\u0116\u0000\u0000\u0fac\u0fad\u0005\u046d\u0000\u0000\u0fad\u0fae"+
		"\u0005\u047c\u0000\u0000\u0fae\u0faf\u0005\u046f\u0000\u0000\u0faf\u0fb0"+
		"\u0005\u047c\u0000\u0000\u0fb0\u0fb1\u0005\u016d\u0000\u0000\u0fb1\u0fb2"+
		"\u0005\u046d\u0000\u0000\u0fb2\u0fb3\u0003\u0108\u0084\u0000\u0fb3\u0fb4"+
		"\u0005\u046e\u0000\u0000\u0fb4\u0fb9\u0005\u046e\u0000\u0000\u0fb5\u0fb7"+
		"\u0005\f\u0000\u0000\u0fb6\u0fb5\u0001\u0000\u0000\u0000\u0fb6\u0fb7\u0001"+
		"\u0000\u0000\u0000\u0fb7\u0fb8\u0001\u0000\u0000\u0000\u0fb8\u0fba\u0003"+
		"\u0248\u0124\u0000\u0fb9\u0fb6\u0001\u0000\u0000\u0000\u0fb9\u0fba\u0001"+
		"\u0000\u0000\u0000\u0fba\u0107\u0001\u0000\u0000\u0000\u0fbb\u0fc0\u0003"+
		"\u010a\u0085\u0000\u0fbc\u0fbd\u0005\u046f\u0000\u0000\u0fbd\u0fbf\u0003"+
		"\u010a\u0085\u0000\u0fbe\u0fbc\u0001\u0000\u0000\u0000\u0fbf\u0fc2\u0001"+
		"\u0000\u0000\u0000\u0fc0\u0fbe\u0001\u0000\u0000\u0000\u0fc0\u0fc1\u0001"+
		"\u0000\u0000\u0000\u0fc1\u0109\u0001\u0000\u0000\u0000\u0fc2\u0fc0\u0001"+
		"\u0000\u0000\u0000\u0fc3\u0fd4\u0003\u022c\u0116\u0000\u0fc4\u0fc5\u0005"+
		"A\u0000\u0000\u0fc5\u0fd5\u0005\u011c\u0000\u0000\u0fc6\u0fd2\u0003\u025c"+
		"\u012e\u0000\u0fc7\u0fc8\u0005\u011d\u0000\u0000\u0fc8\u0fca\u0005\u047c"+
		"\u0000\u0000\u0fc9\u0fcb\u0003\u010c\u0086\u0000\u0fca\u0fc9\u0001\u0000"+
		"\u0000\u0000\u0fca\u0fcb\u0001\u0000\u0000\u0000\u0fcb\u0fcd\u0001\u0000"+
		"\u0000\u0000\u0fcc\u0fce\u0003\u010e\u0087\u0000\u0fcd\u0fcc\u0001\u0000"+
		"\u0000\u0000\u0fcd\u0fce\u0001\u0000\u0000\u0000\u0fce\u0fd3\u0001\u0000"+
		"\u0000\u0000\u0fcf\u0fd0\u0005<\u0000\u0000\u0fd0\u0fd1\u0005\u011d\u0000"+
		"\u0000\u0fd1\u0fd3\u0005\u047c\u0000\u0000\u0fd2\u0fc7\u0001\u0000\u0000"+
		"\u0000\u0fd2\u0fcf\u0001\u0000\u0000\u0000\u0fd3\u0fd5\u0001\u0000\u0000"+
		"\u0000\u0fd4\u0fc4\u0001\u0000\u0000\u0000\u0fd4\u0fc6\u0001\u0000\u0000"+
		"\u0000\u0fd5\u0fe1\u0001\u0000\u0000\u0000\u0fd6\u0fd8\u0005\u011b\u0000"+
		"\u0000\u0fd7\u0fd9\u0005\u011d\u0000\u0000\u0fd8\u0fd7\u0001\u0000\u0000"+
		"\u0000\u0fd8\u0fd9\u0001\u0000\u0000\u0000\u0fd9\u0fda\u0001\u0000\u0000"+
		"\u0000\u0fda\u0fdb\u0005\u047c\u0000\u0000\u0fdb\u0fdc\u0005\u016d\u0000"+
		"\u0000\u0fdc\u0fdd\u0005\u046d\u0000\u0000\u0fdd\u0fde\u0003\u0108\u0084"+
		"\u0000\u0fde\u0fdf\u0005\u046e\u0000\u0000\u0fdf\u0fe1\u0001\u0000\u0000"+
		"\u0000\u0fe0\u0fc3\u0001\u0000\u0000\u0000\u0fe0\u0fd6\u0001\u0000\u0000"+
		"\u0000\u0fe1\u010b\u0001\u0000\u0000\u0000\u0fe2\u0fe7\u0005t\u0000\u0000"+
		"\u0fe3\u0fe7\u0005\u019b\u0000\u0000\u0fe4\u0fe5\u0005*\u0000\u0000\u0fe5"+
		"\u0fe7\u0003\u027a\u013d\u0000\u0fe6\u0fe2\u0001\u0000\u0000\u0000\u0fe6"+
		"\u0fe3\u0001\u0000\u0000\u0000\u0fe6\u0fe4\u0001\u0000\u0000\u0000\u0fe7"+
		"\u0fe8\u0001\u0000\u0000\u0000\u0fe8\u0fe9\u0005v\u0000\u0000\u0fe9\u0fea"+
		"\u00057\u0000\u0000\u0fea\u010d\u0001\u0000\u0000\u0000\u0feb\u0ff0\u0005"+
		"t\u0000\u0000\u0fec\u0ff0\u0005\u019b\u0000\u0000\u0fed\u0fee\u0005*\u0000"+
		"\u0000\u0fee\u0ff0\u0003\u027a\u013d\u0000\u0fef\u0feb\u0001\u0000\u0000"+
		"\u0000\u0fef\u0fec\u0001\u0000\u0000\u0000\u0fef\u0fed\u0001\u0000\u0000"+
		"\u0000\u0ff0\u0ff1\u0001\u0000\u0000\u0000\u0ff1\u0ff2\u0005v\u0000\u0000"+
		"\u0ff2\u0ff3\u0005\u019b\u0000\u0000\u0ff3\u010f\u0001\u0000\u0000\u0000"+
		"\u0ff4\u0ffd\u00074\u0000\u0000\u0ff5\u0ffd\u0005K\u0000\u0000\u0ff6\u0ffd"+
		"\u0005\u00ab\u0000\u0000\u0ff7\u0ffd\u0005\u00a6\u0000\u0000\u0ff8\u0ffd"+
		"\u0005\u00a4\u0000\u0000\u0ff9\u0ffd\u0005\u0271\u0000\u0000\u0ffa\u0ffd"+
		"\u00075\u0000\u0000\u0ffb\u0ffd\u0005\u00a5\u0000\u0000\u0ffc\u0ff4\u0001"+
		"\u0000\u0000\u0000\u0ffc\u0ff5\u0001\u0000\u0000\u0000\u0ffc\u0ff6\u0001"+
		"\u0000\u0000\u0000\u0ffc\u0ff7\u0001\u0000\u0000\u0000\u0ffc\u0ff8\u0001"+
		"\u0000\u0000\u0000\u0ffc\u0ff9\u0001\u0000\u0000\u0000\u0ffc\u0ffa\u0001"+
		"\u0000\u0000\u0000\u0ffc\u0ffb\u0001\u0000\u0000\u0000\u0ffd\u0111\u0001"+
		"\u0000\u0000\u0000\u0ffe\u1001\u0005\u045d\u0000\u0000\u0fff\u1001\u0003"+
		"\u0114\u008a\u0000\u1000\u0ffe\u0001\u0000\u0000\u0000\u1000\u0fff\u0001"+
		"\u0000\u0000\u0000\u1001\u1006\u0001\u0000\u0000\u0000\u1002\u1003\u0005"+
		"\u046f\u0000\u0000\u1003\u1005\u0003\u0114\u008a\u0000\u1004\u1002\u0001"+
		"\u0000\u0000\u0000\u1005\u1008\u0001\u0000\u0000\u0000\u1006\u1004\u0001"+
		"\u0000\u0000\u0000\u1006\u1007\u0001\u0000\u0000\u0000\u1007\u0113\u0001"+
		"\u0000\u0000\u0000\u1008\u1006\u0001\u0000\u0000\u0000\u1009\u100a\u0003"+
		"\u0226\u0113\u0000\u100a\u100b\u0005\u046c\u0000\u0000\u100b\u100c\u0005"+
		"\u045d\u0000\u0000\u100c\u1027\u0001\u0000\u0000\u0000\u100d\u1012\u0003"+
		"\u022c\u0116\u0000\u100e\u1010\u0005\f\u0000\u0000\u100f\u100e\u0001\u0000"+
		"\u0000\u0000\u100f\u1010\u0001\u0000\u0000\u0000\u1010\u1011\u0001\u0000"+
		"\u0000\u0000\u1011\u1013\u0003\u0248\u0124\u0000\u1012\u100f\u0001\u0000"+
		"\u0000\u0000\u1012\u1013\u0001\u0000\u0000\u0000\u1013\u1027\u0001\u0000"+
		"\u0000\u0000\u1014\u1019\u0003\u0288\u0144\u0000\u1015\u1017\u0005\f\u0000"+
		"\u0000\u1016\u1015\u0001\u0000\u0000\u0000\u1016\u1017\u0001\u0000\u0000"+
		"\u0000\u1017\u1018\u0001\u0000\u0000\u0000\u1018\u101a\u0003\u0248\u0124"+
		"\u0000\u1019\u1016\u0001\u0000\u0000\u0000\u1019\u101a\u0001\u0000\u0000"+
		"\u0000\u101a\u1027\u0001\u0000\u0000\u0000\u101b\u101c\u0005\u0487\u0000"+
		"\u0000\u101c\u101e\u0005\u0454\u0000\u0000\u101d\u101b\u0001\u0000\u0000"+
		"\u0000\u101d\u101e\u0001\u0000\u0000\u0000\u101e\u101f\u0001\u0000\u0000"+
		"\u0000\u101f\u1024\u0003\u02b0\u0158\u0000\u1020\u1022\u0005\f\u0000\u0000"+
		"\u1021\u1020\u0001\u0000\u0000\u0000\u1021\u1022\u0001\u0000\u0000\u0000"+
		"\u1022\u1023\u0001\u0000\u0000\u0000\u1023\u1025\u0003\u0248\u0124\u0000"+
		"\u1024\u1021\u0001\u0000\u0000\u0000\u1024\u1025\u0001\u0000\u0000\u0000"+
		"\u1025\u1027\u0001\u0000\u0000\u0000\u1026\u1009\u0001\u0000\u0000\u0000"+
		"\u1026\u100d\u0001\u0000\u0000\u0000\u1026\u1014\u0001\u0000\u0000\u0000"+
		"\u1026\u101d\u0001\u0000\u0000\u0000\u1027\u0115\u0001\u0000\u0000\u0000"+
		"\u1028\u1029\u0005W\u0000\u0000\u1029\u102e\u0003\u00d2i\u0000\u102a\u102b"+
		"\u0005\u046f\u0000\u0000\u102b\u102d\u0003\u00d2i\u0000\u102c\u102a\u0001"+
		"\u0000\u0000\u0000\u102d\u1030\u0001\u0000\u0000\u0000\u102e\u102c\u0001"+
		"\u0000\u0000\u0000\u102e\u102f\u0001\u0000\u0000\u0000\u102f\u104d\u0001"+
		"\u0000\u0000\u0000\u1030\u102e\u0001\u0000\u0000\u0000\u1031\u1032\u0005"+
		"W\u0000\u0000\u1032\u1033\u0005\u0190\u0000\u0000\u1033\u104d\u0005\u047c"+
		"\u0000\u0000\u1034\u1035\u0005W\u0000\u0000\u1035\u1036\u0005\u007f\u0000"+
		"\u0000\u1036\u103a\u0005\u047c\u0000\u0000\u1037\u1038\u0005\u0019\u0000"+
		"\u0000\u1038\u1039\u0005\u0099\u0000\u0000\u1039\u103b\u0003\u0238\u011c"+
		"\u0000\u103a\u1037\u0001\u0000\u0000\u0000\u103a\u103b\u0001\u0000\u0000"+
		"\u0000\u103b\u1042\u0001\u0000\u0000\u0000\u103c\u103e\u0007)\u0000\u0000"+
		"\u103d\u103f\u0003\u0118\u008c\u0000\u103e\u103d\u0001\u0000\u0000\u0000"+
		"\u103f\u1040\u0001\u0000\u0000\u0000\u1040\u103e\u0001\u0000\u0000\u0000"+
		"\u1040\u1041\u0001\u0000\u0000\u0000\u1041\u1043\u0001\u0000\u0000\u0000"+
		"\u1042\u103c\u0001\u0000\u0000\u0000\u1042\u1043\u0001\u0000\u0000\u0000"+
		"\u1043\u104a\u0001\u0000\u0000\u0000\u1044\u1046\u0005e\u0000\u0000\u1045"+
		"\u1047\u0003\u011a\u008d\u0000\u1046\u1045\u0001\u0000\u0000\u0000\u1047"+
		"\u1048\u0001\u0000\u0000\u0000\u1048\u1046\u0001\u0000\u0000\u0000\u1048"+
		"\u1049\u0001\u0000\u0000\u0000\u1049\u104b\u0001\u0000\u0000\u0000\u104a"+
		"\u1044\u0001\u0000\u0000\u0000\u104a\u104b\u0001\u0000\u0000\u0000\u104b"+
		"\u104d\u0001\u0000\u0000\u0000\u104c\u1028\u0001\u0000\u0000\u0000\u104c"+
		"\u1031\u0001\u0000\u0000\u0000\u104c\u1034\u0001\u0000\u0000\u0000\u104d"+
		"\u0117\u0001\u0000\u0000\u0000\u104e\u104f\u0005\u00ad\u0000\u0000\u104f"+
		"\u1050\u0005\u0013\u0000\u0000\u1050\u105b\u0005\u047c\u0000\u0000\u1051"+
		"\u1053\u0005z\u0000\u0000\u1052\u1051\u0001\u0000\u0000\u0000\u1052\u1053"+
		"\u0001\u0000\u0000\u0000\u1053\u1054\u0001\u0000\u0000\u0000\u1054\u1055"+
		"\u00058\u0000\u0000\u1055\u1056\u0005\u0013\u0000\u0000\u1056\u105b\u0005"+
		"\u047c\u0000\u0000\u1057\u1058\u0005:\u0000\u0000\u1058\u1059\u0005\u0013"+
		"\u0000\u0000\u1059\u105b\u0005\u047c\u0000\u0000\u105a\u104e\u0001\u0000"+
		"\u0000\u0000\u105a\u1052\u0001\u0000\u0000\u0000\u105a\u1057\u0001\u0000"+
		"\u0000\u0000\u105b\u0119\u0001\u0000\u0000\u0000\u105c\u105d\u0005\u00a9"+
		"\u0000\u0000\u105d\u105e\u0005\u0013\u0000\u0000\u105e\u1063\u0005\u047c"+
		"\u0000\u0000\u105f\u1060\u0005\u00ad\u0000\u0000\u1060\u1061\u0005\u0013"+
		"\u0000\u0000\u1061\u1063\u0005\u047c\u0000\u0000\u1062\u105c\u0001\u0000"+
		"\u0000\u0000\u1062\u105f\u0001\u0000\u0000\u0000\u1063\u011b\u0001\u0000"+
		"\u0000\u0000\u1064\u1065\u0005D\u0000\u0000\u1065\u1067\u0003\u00eau\u0000"+
		"\u1066\u1064\u0001\u0000\u0000\u0000\u1066\u1067\u0001\u0000\u0000\u0000"+
		"\u1067\u106a\u0001\u0000\u0000\u0000\u1068\u1069\u0005\u00be\u0000\u0000"+
		"\u1069\u106b\u0003\u02b0\u0158\u0000\u106a\u1068\u0001\u0000\u0000\u0000"+
		"\u106a\u106b\u0001\u0000\u0000\u0000\u106b\u011d\u0001\u0000\u0000\u0000"+
		"\u106c\u106d\u0005I\u0000\u0000\u106d\u106e\u0005\u0013\u0000\u0000\u106e"+
		"\u1073\u0003\u0124\u0092\u0000\u106f\u1070\u0005\u046f\u0000\u0000\u1070"+
		"\u1072\u0003\u0124\u0092\u0000\u1071\u106f\u0001\u0000\u0000\u0000\u1072"+
		"\u1075\u0001\u0000\u0000\u0000\u1073\u1071\u0001\u0000\u0000\u0000\u1073"+
		"\u1074\u0001\u0000\u0000\u0000\u1074\u1078\u0001\u0000\u0000\u0000\u1075"+
		"\u1073\u0001\u0000\u0000\u0000\u1076\u1077\u0005\u00c0\u0000\u0000\u1077"+
		"\u1079\u0005\u0256\u0000\u0000\u1078\u1076\u0001\u0000\u0000\u0000\u1078"+
		"\u1079\u0001\u0000\u0000\u0000\u1079\u011f\u0001\u0000\u0000\u0000\u107a"+
		"\u107b\u0005J\u0000\u0000\u107b\u107c\u0003\u02b0\u0158\u0000\u107c\u0121"+
		"\u0001\u0000\u0000\u0000\u107d\u107e\u0005\u02a4\u0000\u0000\u107e\u107f"+
		"\u0003\u029a\u014d\u0000\u107f\u1080\u0005\f\u0000\u0000\u1080\u1081\u0005"+
		"\u046d\u0000\u0000\u1081\u1082\u0003\u0298\u014c\u0000\u1082\u108c\u0005"+
		"\u046e\u0000\u0000\u1083\u1084\u0005\u046f\u0000\u0000\u1084\u1085\u0003"+
		"\u029a\u014d\u0000\u1085\u1086\u0005\f\u0000\u0000\u1086\u1087\u0005\u046d"+
		"\u0000\u0000\u1087\u1088\u0003\u0298\u014c\u0000\u1088\u1089\u0005\u046e"+
		"\u0000\u0000\u1089\u108b\u0001\u0000\u0000\u0000\u108a\u1083\u0001\u0000"+
		"\u0000\u0000\u108b\u108e\u0001\u0000\u0000\u0000\u108c\u108a\u0001\u0000"+
		"\u0000\u0000\u108c\u108d\u0001\u0000\u0000\u0000\u108d\u0123\u0001\u0000"+
		"\u0000\u0000\u108e\u108c\u0001\u0000\u0000\u0000\u108f\u1091\u0003\u02b0"+
		"\u0158\u0000\u1090\u1092\u00070\u0000\u0000\u1091\u1090\u0001\u0000\u0000"+
		"\u0000\u1091\u1092\u0001\u0000\u0000\u0000\u1092\u0125\u0001\u0000\u0000"+
		"\u0000\u1093\u109e\u0005c\u0000\u0000\u1094\u1095\u0003\u0128\u0094\u0000"+
		"\u1095\u1096\u0005\u046f\u0000\u0000\u1096\u1098\u0001\u0000\u0000\u0000"+
		"\u1097\u1094\u0001\u0000\u0000\u0000\u1097\u1098\u0001\u0000\u0000\u0000"+
		"\u1098\u1099\u0001\u0000\u0000\u0000\u1099\u109f\u0003\u0128\u0094\u0000"+
		"\u109a\u109b\u0003\u0128\u0094\u0000\u109b\u109c\u0005\u0214\u0000\u0000"+
		"\u109c\u109d\u0003\u0128\u0094\u0000\u109d\u109f\u0001\u0000\u0000\u0000"+
		"\u109e\u1097\u0001\u0000\u0000\u0000\u109e\u109a\u0001\u0000\u0000\u0000"+
		"\u109f\u0127\u0001\u0000\u0000\u0000\u10a0\u10a4\u0003\u024e\u0127\u0000"+
		"\u10a1\u10a4\u0003\u0236\u011b\u0000\u10a2\u10a4\u0003\u024a\u0125\u0000"+
		"\u10a3\u10a0\u0001\u0000\u0000\u0000\u10a3\u10a1\u0001\u0000\u0000\u0000"+
		"\u10a3\u10a2\u0001\u0000\u0000\u0000\u10a4\u0129\u0001\u0000\u0000\u0000"+
		"\u10a5\u10a6\u0005\u0275\u0000\u0000\u10a6\u10af\u0005\u028d\u0000\u0000"+
		"\u10a7\u10ac\u0003\u0140\u00a0\u0000\u10a8\u10a9\u0005\u046f\u0000\u0000"+
		"\u10a9\u10ab\u0003\u0140\u00a0\u0000\u10aa\u10a8\u0001\u0000\u0000\u0000"+
		"\u10ab\u10ae\u0001\u0000\u0000\u0000\u10ac\u10aa\u0001\u0000\u0000\u0000"+
		"\u10ac\u10ad\u0001\u0000\u0000\u0000\u10ad\u10b0\u0001\u0000\u0000\u0000"+
		"\u10ae\u10ac\u0001\u0000\u0000\u0000\u10af\u10a7\u0001\u0000\u0000\u0000"+
		"\u10af\u10b0\u0001\u0000\u0000\u0000\u10b0\u012b\u0001\u0000\u0000\u0000"+
		"\u10b1\u10b3\u0005\u0158\u0000\u0000\u10b2\u10b4\u0005\u02a6\u0000\u0000"+
		"\u10b3\u10b2\u0001\u0000\u0000\u0000\u10b3\u10b4\u0001\u0000\u0000\u0000"+
		"\u10b4\u012d\u0001\u0000\u0000\u0000\u10b5\u10b7\u0005\u0171\u0000\u0000"+
		"\u10b6\u10b8\u0005\u02a6\u0000\u0000\u10b7\u10b6\u0001\u0000\u0000\u0000"+
		"\u10b7\u10b8\u0001\u0000\u0000\u0000\u10b8\u10be\u0001\u0000\u0000\u0000"+
		"\u10b9\u10bb\u0005\n\u0000\u0000\u10ba\u10bc\u0005\u0209\u0000\u0000\u10bb"+
		"\u10ba\u0001\u0000\u0000\u0000\u10bb\u10bc\u0001\u0000\u0000\u0000\u10bc"+
		"\u10bd\u0001\u0000\u0000\u0000\u10bd\u10bf\u0005\u0161\u0000\u0000\u10be"+
		"\u10b9\u0001\u0000\u0000\u0000\u10be\u10bf\u0001\u0000\u0000\u0000\u10bf"+
		"\u10c4\u0001\u0000\u0000\u0000\u10c0\u10c2\u0005\u0209\u0000\u0000\u10c1"+
		"\u10c0\u0001\u0000\u0000\u0000\u10c1\u10c2\u0001\u0000\u0000\u0000\u10c2"+
		"\u10c3\u0001\u0000\u0000\u0000\u10c3\u10c5\u0005\u008a\u0000\u0000\u10c4"+
		"\u10c1\u0001\u0000\u0000\u0000\u10c4\u10c5\u0001\u0000\u0000\u0000\u10c5"+
		"\u012f\u0001\u0000\u0000\u0000\u10c6\u10c8\u0005\u0255\u0000\u0000\u10c7"+
		"\u10c9\u0005\u02a6\u0000\u0000\u10c8\u10c7\u0001\u0000\u0000\u0000\u10c8"+
		"\u10c9\u0001\u0000\u0000\u0000\u10c9\u10cf\u0001\u0000\u0000\u0000\u10ca"+
		"\u10cc\u0005\n\u0000\u0000\u10cb\u10cd\u0005\u0209\u0000\u0000\u10cc\u10cb"+
		"\u0001\u0000\u0000\u0000\u10cc\u10cd\u0001\u0000\u0000\u0000\u10cd\u10ce"+
		"\u0001\u0000\u0000\u0000\u10ce\u10d0\u0005\u0161\u0000\u0000\u10cf\u10ca"+
		"\u0001\u0000\u0000\u0000\u10cf\u10d0\u0001\u0000\u0000\u0000\u10d0\u10d5"+
		"\u0001\u0000\u0000\u0000\u10d1\u10d3\u0005\u0209\u0000\u0000\u10d2\u10d1"+
		"\u0001\u0000\u0000\u0000\u10d2\u10d3\u0001\u0000\u0000\u0000\u10d3\u10d4"+
		"\u0001\u0000\u0000\u0000\u10d4\u10d6\u0005\u008a\u0000\u0000\u10d5\u10d2"+
		"\u0001\u0000\u0000\u0000\u10d5\u10d6\u0001\u0000\u0000\u0000\u10d6\u0131"+
		"\u0001\u0000\u0000\u0000\u10d7\u10d8\u0005\u025c\u0000\u0000\u10d8\u10d9"+
		"\u0003\u0248\u0124\u0000\u10d9\u0133\u0001\u0000\u0000\u0000\u10da\u10dc"+
		"\u0005\u0255\u0000\u0000\u10db\u10dd\u0005\u02a6\u0000\u0000\u10dc\u10db"+
		"\u0001\u0000\u0000\u0000\u10dc\u10dd\u0001\u0000\u0000\u0000\u10dd\u10de"+
		"\u0001\u0000\u0000\u0000\u10de\u10e0\u0005\u00af\u0000\u0000\u10df\u10e1"+
		"\u0005\u025c\u0000\u0000\u10e0\u10df\u0001\u0000\u0000\u0000\u10e0\u10e1"+
		"\u0001\u0000\u0000\u0000\u10e1\u10e2\u0001\u0000\u0000\u0000\u10e2\u10e3"+
		"\u0003\u0248\u0124\u0000\u10e3\u0135\u0001\u0000\u0000\u0000\u10e4\u10e5"+
		"\u0005\u008a\u0000\u0000\u10e5\u10e6\u0005\u025c\u0000\u0000\u10e6\u10e7"+
		"\u0003\u0248\u0124\u0000\u10e7\u0137\u0001\u0000\u0000\u0000\u10e8\u10e9"+
		"\u0005g\u0000\u0000\u10e9\u10ea\u00076\u0000\u0000\u10ea\u10ef\u0003\u0142"+
		"\u00a1\u0000\u10eb\u10ec\u0005\u046f\u0000\u0000\u10ec\u10ee\u0003\u0142"+
		"\u00a1\u0000\u10ed\u10eb\u0001\u0000\u0000\u0000\u10ee\u10f1\u0001\u0000"+
		"\u0000\u0000\u10ef\u10ed\u0001\u0000\u0000\u0000\u10ef\u10f0\u0001\u0000"+
		"\u0000\u0000\u10f0\u10f3\u0001\u0000\u0000\u0000\u10f1\u10ef\u0001\u0000"+
		"\u0000\u0000\u10f2\u10f4\u0003\u0286\u0143\u0000\u10f3\u10f2\u0001\u0000"+
		"\u0000\u0000\u10f3\u10f4\u0001\u0000\u0000\u0000\u10f4\u0139\u0001\u0000"+
		"\u0000\u0000\u10f5\u10f6\u0005\u00b6\u0000\u0000\u10f6\u10f7\u0005\u02e6"+
		"\u0000\u0000\u10f7\u013b\u0001\u0000\u0000\u0000\u10f8\u10f9\u0005\u0099"+
		"\u0000\u0000\u10f9\u10fa\u0005\u0154\u0000\u0000\u10fa\u10fb\u0005\u0464"+
		"\u0000\u0000\u10fb\u10fc\u0007\u0018\u0000\u0000\u10fc\u013d\u0001\u0000"+
		"\u0000\u0000\u10fd\u10ff\u0005\u0099\u0000\u0000\u10fe\u1100\u00077\u0000"+
		"\u0000\u10ff\u10fe\u0001\u0000\u0000\u0000\u10ff\u1100\u0001\u0000\u0000"+
		"\u0000\u1100\u1101\u0001\u0000\u0000\u0000\u1101\u1102\u0005\u028d\u0000"+
		"\u0000\u1102\u1107\u0003\u0146\u00a3\u0000\u1103\u1104\u0005\u046f\u0000"+
		"\u0000\u1104\u1106\u0003\u0146\u00a3\u0000\u1105\u1103\u0001\u0000\u0000"+
		"\u0000\u1106\u1109\u0001\u0000\u0000\u0000\u1107\u1105\u0001\u0000\u0000"+
		"\u0000\u1107\u1108\u0001\u0000\u0000\u0000\u1108\u013f\u0001\u0000\u0000"+
		"\u0000\u1109\u1107\u0001\u0000\u0000\u0000\u110a\u110b\u0005\u00c0\u0000"+
		"\u0000\u110b\u110c\u0005\u0179\u0000\u0000\u110c\u1112\u0005\u0268\u0000"+
		"\u0000\u110d\u110e\u0005\u0086\u0000\u0000\u110e\u1112\u0005\u00c1\u0000"+
		"\u0000\u110f\u1110\u0005\u0086\u0000\u0000\u1110\u1112\u0005\u021a\u0000"+
		"\u0000\u1111\u110a\u0001\u0000\u0000\u0000\u1111\u110d\u0001\u0000\u0000"+
		"\u0000\u1111\u110f\u0001\u0000\u0000\u0000\u1112\u0141\u0001\u0000\u0000"+
		"\u0000\u1113\u1118\u0003\u0228\u0114\u0000\u1114\u1116\u0005\f\u0000\u0000"+
		"\u1115\u1114\u0001\u0000\u0000\u0000\u1115\u1116\u0001\u0000\u0000\u0000"+
		"\u1116\u1117\u0001\u0000\u0000\u0000\u1117\u1119\u0003\u0248\u0124\u0000"+
		"\u1118\u1115\u0001\u0000\u0000\u0000\u1118\u1119\u0001\u0000\u0000\u0000"+
		"\u1119\u111a\u0001\u0000\u0000\u0000\u111a\u111b\u0003\u0144\u00a2\u0000"+
		"\u111b\u0143\u0001\u0000\u0000\u0000\u111c\u111e\u0005\u0086\u0000\u0000"+
		"\u111d\u111f\u0005\u01da\u0000\u0000\u111e\u111d\u0001\u0000\u0000\u0000"+
		"\u111e\u111f\u0001\u0000\u0000\u0000\u111f\u1125\u0001\u0000\u0000\u0000"+
		"\u1120\u1122\u0005j\u0000\u0000\u1121\u1120\u0001\u0000\u0000\u0000\u1121"+
		"\u1122\u0001\u0000\u0000\u0000\u1122\u1123\u0001\u0000\u0000\u0000\u1123"+
		"\u1125\u0005\u00c1\u0000\u0000\u1124\u111c\u0001\u0000\u0000\u0000\u1124"+
		"\u1121\u0001\u0000\u0000\u0000\u1125\u0145\u0001\u0000\u0000\u0000\u1126"+
		"\u1127\u0005\u01d0\u0000\u0000\u1127\u1128\u0005\u01d8\u0000\u0000\u1128"+
		"\u112e\u0003\u0148\u00a4\u0000\u1129\u112a\u0005\u0086\u0000\u0000\u112a"+
		"\u112e\u0005\u00c1\u0000\u0000\u112b\u112c\u0005\u0086\u0000\u0000\u112c"+
		"\u112e\u0005\u021a\u0000\u0000\u112d\u1126\u0001\u0000\u0000\u0000\u112d"+
		"\u1129\u0001\u0000\u0000\u0000\u112d\u112b\u0001\u0000\u0000\u0000\u112e"+
		"\u0147\u0001\u0000\u0000\u0000\u112f\u1130\u0005\u031f\u0000\u0000\u1130"+
		"\u1137\u0005\u0086\u0000\u0000\u1131\u1132\u0005\u0086\u0000\u0000\u1132"+
		"\u1137\u0005\u0320\u0000\u0000\u1133\u1134\u0005\u0086\u0000\u0000\u1134"+
		"\u1137\u0005\u0321\u0000\u0000\u1135\u1137\u0005\u0322\u0000\u0000\u1136"+
		"\u112f\u0001\u0000\u0000\u0000\u1136\u1131\u0001\u0000\u0000\u0000\u1136"+
		"\u1133\u0001\u0000\u0000\u0000\u1136\u1135\u0001\u0000\u0000\u0000\u1137"+
		"\u0149\u0001\u0000\u0000\u0000\u1138\u1139\u0005\u0018\u0000\u0000\u1139"+
		"\u113a\u0005\u01dd\u0000\u0000\u113a\u113b\u0005\u00af\u0000\u0000\u113b"+
		"\u1140\u0003\u015c\u00ae\u0000\u113c\u113d\u0005\u046f\u0000\u0000\u113d"+
		"\u113f\u0003\u015c\u00ae\u0000\u113e\u113c\u0001\u0000\u0000\u0000\u113f"+
		"\u1142\u0001\u0000\u0000\u0000\u1140\u113e\u0001\u0000\u0000\u0000\u1140"+
		"\u1141\u0001\u0000\u0000\u0000\u1141\u1144\u0001\u0000\u0000\u0000\u1142"+
		"\u1140\u0001\u0000\u0000\u0000\u1143\u1145\u0003\u0164\u00b2\u0000\u1144"+
		"\u1143\u0001\u0000\u0000\u0000\u1144\u1145\u0001\u0000\u0000\u0000\u1145"+
		"\u014b\u0001\u0000\u0000\u0000\u1146\u1147\u0005\u0018\u0000\u0000\u1147"+
		"\u1148\u0005\u024c\u0000\u0000\u1148\u1149\u0005\u01ad\u0000\u0000\u1149"+
		"\u114e\u0003\u0166\u00b3\u0000\u114a\u114b\u0005\u046f\u0000\u0000\u114b"+
		"\u114d\u0003\u0166\u00b3\u0000\u114c\u114a\u0001\u0000\u0000\u0000\u114d"+
		"\u1150\u0001\u0000\u0000\u0000\u114e\u114c\u0001\u0000\u0000\u0000\u114e"+
		"\u114f\u0001\u0000\u0000\u0000\u114f\u014d\u0001\u0000\u0000\u0000\u1150"+
		"\u114e\u0001\u0000\u0000\u0000\u1151\u1152\u0005\u0084\u0000\u0000\u1152"+
		"\u1153\u00078\u0000\u0000\u1153\u1158\u0005\u01dc\u0000\u0000\u1154\u1155"+
		"\u0005\u00af\u0000\u0000\u1155\u1159\u0005\u047c\u0000\u0000\u1156\u1157"+
		"\u0005\u000f\u0000\u0000\u1157\u1159\u0005\u047c\u0000\u0000\u1158\u1154"+
		"\u0001\u0000\u0000\u0000\u1158\u1156\u0001\u0000\u0000\u0000\u1159\u014f"+
		"\u0001\u0000\u0000\u0000\u115a\u115b\u0005\u024d\u0000\u0000\u115b\u115c"+
		"\u0005\u01dd\u0000\u0000\u115c\u0151\u0001\u0000\u0000\u0000\u115d\u115e"+
		"\u0005\u024d\u0000\u0000\u115e\u1160\u0005\u0266\u0000\u0000\u115f\u1161"+
		"\u0005\u0006\u0000\u0000\u1160\u115f\u0001\u0000\u0000\u0000\u1160\u1161"+
		"\u0001\u0000\u0000\u0000\u1161\u1163\u0001\u0000\u0000\u0000\u1162\u1164"+
		"\u0003\u0164\u00b2\u0000\u1163\u1162\u0001\u0000\u0000\u0000\u1163\u1164"+
		"\u0001\u0000\u0000\u0000\u1164\u0153\u0001\u0000\u0000\u0000\u1165\u1166"+
		"\u0005\u0275\u0000\u0000\u1166\u116f\u0005\u0266\u0000\u0000\u1167\u116c"+
		"\u0003\u016a\u00b5\u0000\u1168\u1169\u0005\u046f\u0000\u0000\u1169\u116b"+
		"\u0003\u016a\u00b5\u0000\u116a\u1168\u0001\u0000\u0000\u0000\u116b\u116e"+
		"\u0001\u0000\u0000\u0000\u116c\u116a\u0001\u0000\u0000\u0000\u116c\u116d"+
		"\u0001\u0000\u0000\u0000\u116d\u1170\u0001\u0000\u0000\u0000\u116e\u116c"+
		"\u0001\u0000\u0000\u0000\u116f\u1167\u0001\u0000\u0000\u0000\u116f\u1170"+
		"\u0001\u0000\u0000\u0000\u1170\u1173\u0001\u0000\u0000\u0000\u1171\u1172"+
		"\u0005\u0297\u0000\u0000\u1172\u1174\u0003\u016c\u00b6\u0000\u1173\u1171"+
		"\u0001\u0000\u0000\u0000\u1173\u1174\u0001\u0000\u0000\u0000\u1174\u1178"+
		"\u0001\u0000\u0000\u0000\u1175\u1177\u0003\u016e\u00b7\u0000\u1176\u1175"+
		"\u0001\u0000\u0000\u0000\u1177\u117a\u0001\u0000\u0000\u0000\u1178\u1176"+
		"\u0001\u0000\u0000\u0000\u1178\u1179\u0001\u0000\u0000\u0000\u1179\u117c"+
		"\u0001\u0000\u0000\u0000\u117a\u1178\u0001\u0000\u0000\u0000\u117b\u117d"+
		"\u0003\u0164\u00b2\u0000\u117c\u117b\u0001\u0000\u0000\u0000\u117c\u117d"+
		"\u0001\u0000\u0000\u0000\u117d\u0155\u0001\u0000\u0000\u0000\u117e\u117f"+
		"\u0005\u027b\u0000\u0000\u117f\u1188\u0005\u0266\u0000\u0000\u1180\u1185"+
		"\u0003\u016a\u00b5\u0000\u1181\u1182\u0005\u046f\u0000\u0000\u1182\u1184"+
		"\u0003\u016a\u00b5\u0000\u1183\u1181\u0001\u0000\u0000\u0000\u1184\u1187"+
		"\u0001\u0000\u0000\u0000\u1185\u1183\u0001\u0000\u0000\u0000\u1185\u1186"+
		"\u0001\u0000\u0000\u0000\u1186\u1189\u0001\u0000\u0000\u0000\u1187\u1185"+
		"\u0001\u0000\u0000\u0000\u1188\u1180\u0001\u0000\u0000\u0000\u1188\u1189"+
		"\u0001\u0000\u0000\u0000\u1189\u0157\u0001\u0000\u0000\u0000\u118a\u118b"+
		"\u0005\u0275\u0000\u0000\u118b\u118c\u0005\u01b9\u0000\u0000\u118c\u0159"+
		"\u0001\u0000\u0000\u0000\u118d\u118e\u0005\u027b\u0000\u0000\u118e\u118f"+
		"\u0005\u01b9\u0000\u0000\u118f\u015b\u0001\u0000\u0000\u0000\u1190\u1191"+
		"\u0003\u015e\u00af\u0000\u1191\u1192\u0005\u0464\u0000\u0000\u1192\u1193"+
		"\u0005\u047c\u0000\u0000\u1193\u11ae\u0001\u0000\u0000\u0000\u1194\u1195"+
		"\u0003\u0160\u00b0\u0000\u1195\u1196\u0005\u0464\u0000\u0000\u1196\u1197"+
		"\u0003\u024e\u0127\u0000\u1197\u11ae\u0001\u0000\u0000\u0000\u1198\u1199"+
		"\u0003\u0162\u00b1\u0000\u1199\u119a\u0005\u0464\u0000\u0000\u119a\u119b"+
		"\u0007\u0018\u0000\u0000\u119b\u11ae\u0001\u0000\u0000\u0000\u119c\u119d"+
		"\u0005\u01e1\u0000\u0000\u119d\u119e\u0005\u0464\u0000\u0000\u119e\u11ae"+
		"\u0005\u047f\u0000\u0000\u119f\u11a0\u0005\u01c1\u0000\u0000\u11a0\u11a1"+
		"\u0005\u0464\u0000\u0000\u11a1\u11aa\u0005\u046d\u0000\u0000\u11a2\u11a7"+
		"\u0003\u0248\u0124\u0000\u11a3\u11a4\u0005\u046f\u0000\u0000\u11a4\u11a6"+
		"\u0003\u0248\u0124\u0000\u11a5\u11a3\u0001\u0000\u0000\u0000\u11a6\u11a9"+
		"\u0001\u0000\u0000\u0000\u11a7\u11a5\u0001\u0000\u0000\u0000\u11a7\u11a8"+
		"\u0001\u0000\u0000\u0000\u11a8\u11ab\u0001\u0000\u0000\u0000\u11a9\u11a7"+
		"\u0001\u0000\u0000\u0000\u11aa\u11a2\u0001\u0000\u0000\u0000\u11aa\u11ab"+
		"\u0001\u0000\u0000\u0000\u11ab\u11ac\u0001\u0000\u0000\u0000\u11ac\u11ae"+
		"\u0005\u046e\u0000\u0000\u11ad\u1190\u0001\u0000\u0000\u0000\u11ad\u1194"+
		"\u0001\u0000\u0000\u0000\u11ad\u1198\u0001\u0000\u0000\u0000\u11ad\u119c"+
		"\u0001\u0000\u0000\u0000\u11ad\u119f\u0001\u0000\u0000\u0000\u11ae\u015d"+
		"\u0001\u0000\u0000\u0000\u11af\u11b0\u00079\u0000\u0000\u11b0\u015f\u0001"+
		"\u0000\u0000\u0000\u11b1\u11b2\u0007:\u0000\u0000\u11b2\u0161\u0001\u0000"+
		"\u0000\u0000\u11b3\u11b4\u0007;\u0000\u0000\u11b4\u0163\u0001\u0000\u0000"+
		"\u0000\u11b5\u11b6\u0005A\u0000\u0000\u11b6\u11b7\u0005\u0163\u0000\u0000"+
		"\u11b7\u11b8\u0005\u047c\u0000\u0000\u11b8\u0165\u0001\u0000\u0000\u0000"+
		"\u11b9\u11ba\u0005\u0245\u0000\u0000\u11ba\u11bb\u0005\u0464\u0000\u0000"+
		"\u11bb\u11bc\u0005\u046d\u0000\u0000\u11bc\u11bd\u0003\u0268\u0134\u0000"+
		"\u11bd\u11be\u0005\u046e\u0000\u0000\u11be\u11eb\u0001\u0000\u0000\u0000"+
		"\u11bf\u11c0\u0005\u0247\u0000\u0000\u11c0\u11c1\u0005\u0464\u0000\u0000"+
		"\u11c1\u11c2\u0005\u046d\u0000\u0000\u11c2\u11c3\u0003\u0268\u0134\u0000"+
		"\u11c3\u11c4\u0005\u046e\u0000\u0000\u11c4\u11eb\u0001\u0000\u0000\u0000"+
		"\u11c5\u11c6\u0005\u0246\u0000\u0000\u11c6\u11c7\u0005\u0464\u0000\u0000"+
		"\u11c7\u11c8\u0005\u046d\u0000\u0000\u11c8\u11c9\u0003\u026c\u0136\u0000"+
		"\u11c9\u11ca\u0005\u046e\u0000\u0000\u11ca\u11eb\u0001\u0000\u0000\u0000"+
		"\u11cb\u11cc\u0005\u0248\u0000\u0000\u11cc\u11cd\u0005\u0464\u0000\u0000"+
		"\u11cd\u11ce\u0005\u046d\u0000\u0000\u11ce\u11cf\u0003\u026c\u0136\u0000"+
		"\u11cf\u11d0\u0005\u046e\u0000\u0000\u11d0\u11eb\u0001\u0000\u0000\u0000"+
		"\u11d1\u11d2\u0005\u024a\u0000\u0000\u11d2\u11d3\u0005\u0464\u0000\u0000"+
		"\u11d3\u11d4\u0005\u046d\u0000\u0000\u11d4\u11d5\u0003\u0276\u013b\u0000"+
		"\u11d5\u11d6\u0005\u046e\u0000\u0000\u11d6\u11eb\u0001\u0000\u0000\u0000"+
		"\u11d7\u11d8\u0005\u024b\u0000\u0000\u11d8\u11d9\u0005\u0464\u0000\u0000"+
		"\u11d9\u11da\u0005\u046d\u0000\u0000\u11da\u11db\u0003\u0276\u013b\u0000"+
		"\u11db\u11dc\u0005\u046e\u0000\u0000\u11dc\u11eb\u0001\u0000\u0000\u0000"+
		"\u11dd\u11de\u0005\u0249\u0000\u0000\u11de\u11df\u0005\u0464\u0000\u0000"+
		"\u11df\u11e0\u0005\u046d\u0000\u0000\u11e0\u11e5\u0003\u0168\u00b4\u0000"+
		"\u11e1\u11e2\u0005\u046f\u0000\u0000\u11e2\u11e4\u0003\u0168\u00b4\u0000"+
		"\u11e3\u11e1\u0001\u0000\u0000\u0000\u11e4\u11e7\u0001\u0000\u0000\u0000"+
		"\u11e5\u11e3\u0001\u0000\u0000\u0000\u11e5\u11e6\u0001\u0000\u0000\u0000"+
		"\u11e6\u11e8\u0001\u0000\u0000\u0000\u11e7\u11e5\u0001\u0000\u0000\u0000"+
		"\u11e8\u11e9\u0005\u046e\u0000\u0000\u11e9\u11eb\u0001\u0000\u0000\u0000"+
		"\u11ea\u11b9\u0001\u0000\u0000\u0000\u11ea\u11bf\u0001\u0000\u0000\u0000"+
		"\u11ea\u11c5\u0001\u0000\u0000\u0000\u11ea\u11cb\u0001\u0000\u0000\u0000"+
		"\u11ea\u11d1\u0001\u0000\u0000\u0000\u11ea\u11d7\u0001\u0000\u0000\u0000"+
		"\u11ea\u11dd\u0001\u0000\u0000\u0000\u11eb\u0167\u0001\u0000\u0000\u0000"+
		"\u11ec\u11ed\u0005\u046d\u0000\u0000\u11ed\u11ee\u0003\u0228\u0114\u0000"+
		"\u11ee\u11ef\u0005\u046f\u0000\u0000\u11ef\u11f0\u0003\u0228\u0114\u0000"+
		"\u11f0\u11f1\u0005\u046e\u0000\u0000\u11f1\u0169\u0001\u0000\u0000\u0000"+
		"\u11f2\u11f3\u0007<\u0000\u0000\u11f3\u016b\u0001\u0000\u0000\u0000\u11f4"+
		"\u11f5\u0007=\u0000\u0000\u11f5\u11f6\u0005\u0464\u0000\u0000\u11f6\u1207"+
		"\u0003\u0170\u00b8\u0000\u11f7\u11f8\u0005\u01e3\u0000\u0000\u11f8\u11f9"+
		"\u0005\u0464\u0000\u0000\u11f9\u11fa\u0005\u047c\u0000\u0000\u11fa\u11fb"+
		"\u0005\u046f\u0000\u0000\u11fb\u11fc\u0005\u01e4\u0000\u0000\u11fc\u11fd"+
		"\u0005\u0464\u0000\u0000\u11fd\u1207\u0003\u024e\u0127\u0000\u11fe\u11ff"+
		"\u0005\u023f\u0000\u0000\u11ff\u1200\u0005\u0464\u0000\u0000\u1200\u1201"+
		"\u0005\u047c\u0000\u0000\u1201\u1202\u0005\u046f\u0000\u0000\u1202\u1203"+
		"\u0005\u0240\u0000\u0000\u1203\u1204\u0005\u0464\u0000\u0000\u1204\u1207"+
		"\u0003\u024e\u0127\u0000\u1205\u1207\u0005\u026f\u0000\u0000\u1206\u11f4"+
		"\u0001\u0000\u0000\u0000\u1206\u11f7\u0001\u0000\u0000\u0000\u1206\u11fe"+
		"\u0001\u0000\u0000\u0000\u1206\u1205\u0001\u0000\u0000\u0000\u1207\u016d"+
		"\u0001\u0000\u0000\u0000\u1208\u1209\u0005\u0299\u0000\u0000\u1209\u120a"+
		"\u0005\u0464\u0000\u0000\u120a\u1215\u0005\u047c\u0000\u0000\u120b\u120c"+
		"\u0005\u0227\u0000\u0000\u120c\u120d\u0005\u0464\u0000\u0000\u120d\u1215"+
		"\u0005\u047c\u0000\u0000\u120e\u120f\u0005\u0187\u0000\u0000\u120f\u1210"+
		"\u0005\u0464\u0000\u0000\u1210\u1215\u0005\u047c\u0000\u0000\u1211\u1212"+
		"\u0005\u022b\u0000\u0000\u1212\u1213\u0005\u0464\u0000\u0000\u1213\u1215"+
		"\u0005\u047c\u0000\u0000\u1214\u1208\u0001\u0000\u0000\u0000\u1214\u120b"+
		"\u0001\u0000\u0000\u0000\u1214\u120e\u0001\u0000\u0000\u0000\u1214\u1211"+
		"\u0001\u0000\u0000\u0000\u1215\u016f\u0001\u0000\u0000\u0000\u1216\u121b"+
		"\u0003\u0240\u0120\u0000\u1217\u1218\u0005\u046f\u0000\u0000\u1218\u121a"+
		"\u0003\u0240\u0120\u0000\u1219\u1217\u0001\u0000\u0000\u0000\u121a\u121d"+
		"\u0001\u0000\u0000\u0000\u121b\u1219\u0001\u0000\u0000\u0000\u121b\u121c"+
		"\u0001\u0000\u0000\u0000\u121c\u1220\u0001\u0000\u0000\u0000\u121d\u121b"+
		"\u0001\u0000\u0000\u0000\u121e\u1220\u0005\u047c\u0000\u0000\u121f\u1216"+
		"\u0001\u0000\u0000\u0000\u121f\u121e\u0001\u0000\u0000\u0000\u1220\u0171"+
		"\u0001\u0000\u0000\u0000\u1221\u1222\u0005\u02a9\u0000\u0000\u1222\u1223"+
		"\u0007>\u0000\u0000\u1223\u1225\u0003\u0242\u0121\u0000\u1224\u1226\u0007"+
		"?\u0000\u0000\u1225\u1224\u0001\u0000\u0000\u0000\u1225\u1226\u0001\u0000"+
		"\u0000\u0000\u1226\u0173\u0001\u0000\u0000\u0000\u1227\u1228\u0005\u02a9"+
		"\u0000\u0000\u1228\u1229\u0005\u0197\u0000\u0000\u1229\u122f\u0003\u0242"+
		"\u0121\u0000\u122a\u122d\u0005\u0283\u0000\u0000\u122b\u122c\u0005A\u0000"+
		"\u0000\u122c\u122e\u0005\u01fd\u0000\u0000\u122d\u122b\u0001\u0000\u0000"+
		"\u0000\u122d\u122e\u0001\u0000\u0000\u0000\u122e\u1230\u0001\u0000\u0000"+
		"\u0000\u122f\u122a\u0001\u0000\u0000\u0000\u122f\u1230\u0001\u0000\u0000"+
		"\u0000\u1230\u0175\u0001\u0000\u0000\u0000\u1231\u1232\u0005\u02a9\u0000"+
		"\u0000\u1232\u1233\u0005\u0230\u0000\u0000\u1233\u1234\u0003\u0242\u0121"+
		"\u0000\u1234\u0177\u0001\u0000\u0000\u0000\u1235\u1236\u0005\u02a9\u0000"+
		"\u0000\u1236\u1237\u0005\u0171\u0000\u0000\u1237\u123a\u0003\u0242\u0121"+
		"\u0000\u1238\u1239\u0005\u0218\u0000\u0000\u1239\u123b\u0005\u0229\u0000"+
		"\u0000\u123a\u1238\u0001\u0000\u0000\u0000\u123a\u123b\u0001\u0000\u0000"+
		"\u0000\u123b\u0179\u0001\u0000\u0000\u0000\u123c\u123d\u0005\u02a9\u0000"+
		"\u0000\u123d\u123e\u0005\u0255\u0000\u0000\u123e\u123f\u0003\u0242\u0121"+
		"\u0000\u123f\u017b\u0001\u0000\u0000\u0000\u1240\u1241\u0005\u02a9\u0000"+
		"\u0000\u1241\u1244\u0005\u023a\u0000\u0000\u1242\u1243\u0005 \u0000\u0000"+
		"\u1243\u1245\u0003\u0242\u0121\u0000\u1244\u1242\u0001\u0000\u0000\u0000"+
		"\u1244\u1245\u0001\u0000\u0000\u0000\u1245\u017d\u0001\u0000\u0000\u0000"+
		"\u1246\u1247\u0005\u0230\u0000\u0000\u1247\u1248\u0003\u0248\u0124\u0000"+
		"\u1248\u124b\u0005D\u0000\u0000\u1249\u124c\u0005\u047c\u0000\u0000\u124a"+
		"\u124c\u0005\u0487\u0000\u0000\u124b\u1249\u0001\u0000\u0000\u0000\u124b"+
		"\u124a\u0001\u0000\u0000\u0000\u124c\u017f\u0001\u0000\u0000\u0000\u124d"+
		"\u124e\u0005\u02c4\u0000\u0000\u124e\u1251\u0003\u0248\u0124\u0000\u124f"+
		"\u1250\u0005\u00bb\u0000\u0000\u1250\u1252\u0003\u0278\u013c\u0000\u1251"+
		"\u124f\u0001\u0000\u0000\u0000\u1251\u1252\u0001\u0000\u0000\u0000\u1252"+
		"\u0181\u0001\u0000\u0000\u0000\u1253\u1254\u0007@\u0000\u0000\u1254\u1255"+
		"\u0005\u0230\u0000\u0000\u1255\u1256\u0003\u0248\u0124\u0000\u1256\u0183"+
		"\u0001\u0000\u0000\u0000\u1257\u125a\u0003\u0186\u00c3\u0000\u1258\u125a"+
		"\u0003\u0004\u0002\u0000\u1259\u1257\u0001\u0000\u0000\u0000\u1259\u1258"+
		"\u0001\u0000\u0000\u0000\u125a\u0185\u0001\u0000\u0000\u0000\u125b\u125c"+
		"\u0003\u0248\u0124\u0000\u125c\u125d\u0005\u0478\u0000\u0000\u125d\u125f"+
		"\u0001\u0000\u0000\u0000\u125e\u125b\u0001\u0000\u0000\u0000\u125e\u125f"+
		"\u0001\u0000\u0000\u0000\u125f\u1260\u0001\u0000\u0000\u0000\u1260\u1266"+
		"\u0005\u0158\u0000\u0000\u1261\u1262\u0003\u019a\u00cd\u0000\u1262\u1263"+
		"\u0005\u0470\u0000\u0000\u1263\u1265\u0001\u0000\u0000\u0000\u1264\u1261"+
		"\u0001\u0000\u0000\u0000\u1265\u1268\u0001\u0000\u0000\u0000\u1266\u1264"+
		"\u0001\u0000\u0000\u0000\u1266\u1267\u0001\u0000\u0000\u0000\u1267\u126e"+
		"\u0001\u0000\u0000\u0000\u1268\u1266\u0001\u0000\u0000\u0000\u1269\u126a"+
		"\u0003\u019c\u00ce\u0000\u126a\u126b\u0005\u0470\u0000\u0000\u126b\u126d"+
		"\u0001\u0000\u0000\u0000\u126c\u1269\u0001\u0000\u0000\u0000\u126d\u1270"+
		"\u0001\u0000\u0000\u0000\u126e\u126c\u0001\u0000\u0000\u0000\u126e\u126f"+
		"\u0001\u0000\u0000\u0000\u126f\u1276\u0001\u0000\u0000\u0000\u1270\u126e"+
		"\u0001\u0000\u0000\u0000\u1271\u1272\u0003\u019e\u00cf\u0000\u1272\u1273"+
		"\u0005\u0470\u0000\u0000\u1273\u1275\u0001\u0000\u0000\u0000\u1274\u1271"+
		"\u0001\u0000\u0000\u0000\u1275\u1278\u0001\u0000\u0000\u0000\u1276\u1274"+
		"\u0001\u0000\u0000\u0000\u1276\u1277\u0001\u0000\u0000\u0000\u1277\u127e"+
		"\u0001\u0000\u0000\u0000\u1278\u1276\u0001\u0000\u0000\u0000\u1279\u127a"+
		"\u0003\u01a0\u00d0\u0000\u127a\u127b\u0005\u0470\u0000\u0000\u127b\u127d"+
		"\u0001\u0000\u0000\u0000\u127c\u1279\u0001\u0000\u0000\u0000\u127d\u1280"+
		"\u0001\u0000\u0000\u0000\u127e\u127c\u0001\u0000\u0000\u0000\u127e\u127f"+
		"\u0001\u0000\u0000\u0000\u127f\u1284\u0001\u0000\u0000\u0000\u1280\u127e"+
		"\u0001\u0000\u0000\u0000\u1281\u1283\u0003\u01a4\u00d2\u0000\u1282\u1281"+
		"\u0001\u0000\u0000\u0000\u1283\u1286\u0001\u0000\u0000\u0000\u1284\u1282"+
		"\u0001\u0000\u0000\u0000\u1284\u1285\u0001\u0000\u0000\u0000\u1285\u1287"+
		"\u0001\u0000\u0000\u0000\u1286\u1284\u0001\u0000\u0000\u0000\u1287\u1289"+
		"\u0005\u0197\u0000\u0000\u1288\u128a\u0003\u0248\u0124\u0000\u1289\u1288"+
		"\u0001\u0000\u0000\u0000\u1289\u128a\u0001\u0000\u0000\u0000\u128a\u0187"+
		"\u0001\u0000\u0000\u0000\u128b\u128e\u0005\u0016\u0000\u0000\u128c\u128f"+
		"\u0003\u0248\u0124\u0000\u128d\u128f\u0003\u02b0\u0158\u0000\u128e\u128c"+
		"\u0001\u0000\u0000\u0000\u128e\u128d\u0001\u0000\u0000\u0000\u128e\u128f"+
		"\u0001\u0000\u0000\u0000\u128f\u1291\u0001\u0000\u0000\u0000\u1290\u1292"+
		"\u0003\u01a6\u00d3\u0000\u1291\u1290\u0001\u0000\u0000\u0000\u1292\u1293"+
		"\u0001\u0000\u0000\u0000\u1293\u1291\u0001\u0000\u0000\u0000\u1293\u1294"+
		"\u0001\u0000\u0000\u0000\u1294\u129b\u0001\u0000\u0000\u0000\u1295\u1297"+
		"\u00055\u0000\u0000\u1296\u1298\u0003\u01a4\u00d2\u0000\u1297\u1296\u0001"+
		"\u0000\u0000\u0000\u1298\u1299\u0001\u0000\u0000\u0000\u1299\u1297\u0001"+
		"\u0000\u0000\u0000\u1299\u129a\u0001\u0000\u0000\u0000\u129a\u129c\u0001"+
		"\u0000\u0000\u0000\u129b\u1295\u0001\u0000\u0000\u0000\u129b\u129c\u0001"+
		"\u0000\u0000\u0000\u129c\u129d\u0001\u0000\u0000\u0000\u129d\u129e\u0005"+
		"\u0197\u0000\u0000\u129e\u129f\u0005\u0016\u0000\u0000\u129f\u0189\u0001"+
		"\u0000\u0000\u0000\u12a0\u12a1\u0005M\u0000\u0000\u12a1\u12a2\u0003\u02b0"+
		"\u0158\u0000\u12a2\u12a4\u0005\u00ae\u0000\u0000\u12a3\u12a5\u0003\u01a4"+
		"\u00d2\u0000\u12a4\u12a3\u0001\u0000\u0000\u0000\u12a5\u12a6\u0001\u0000"+
		"\u0000\u0000\u12a6\u12a4\u0001\u0000\u0000\u0000\u12a6\u12a7\u0001\u0000"+
		"\u0000\u0000\u12a7\u12ab\u0001\u0000\u0000\u0000\u12a8\u12aa\u0003\u01a8"+
		"\u00d4\u0000\u12a9\u12a8\u0001\u0000\u0000\u0000\u12aa\u12ad\u0001\u0000"+
		"\u0000\u0000\u12ab\u12a9\u0001\u0000\u0000\u0000\u12ab\u12ac\u0001\u0000"+
		"\u0000\u0000\u12ac\u12b4\u0001\u0000\u0000\u0000\u12ad\u12ab\u0001\u0000"+
		"\u0000\u0000\u12ae\u12b0\u00055\u0000\u0000\u12af\u12b1\u0003\u01a4\u00d2"+
		"\u0000\u12b0\u12af\u0001\u0000\u0000\u0000\u12b1\u12b2\u0001\u0000\u0000"+
		"\u0000\u12b2\u12b0\u0001\u0000\u0000\u0000\u12b2\u12b3\u0001\u0000\u0000"+
		"\u0000\u12b3\u12b5\u0001\u0000\u0000\u0000\u12b4\u12ae\u0001\u0000\u0000"+
		"\u0000\u12b4\u12b5\u0001\u0000\u0000\u0000\u12b5\u12b6\u0001\u0000\u0000"+
		"\u0000\u12b6\u12b7\u0005\u0197\u0000\u0000\u12b7\u12b8\u0005M\u0000\u0000"+
		"\u12b8\u018b\u0001\u0000\u0000\u0000\u12b9\u12ba\u0005Y\u0000\u0000\u12ba"+
		"\u12bb\u0003\u0248\u0124\u0000\u12bb\u018d\u0001\u0000\u0000\u0000\u12bc"+
		"\u12bd\u0005`\u0000\u0000\u12bd\u12be\u0003\u0248\u0124\u0000\u12be\u018f"+
		"\u0001\u0000\u0000\u0000\u12bf\u12c0\u0003\u0248\u0124\u0000\u12c0\u12c1"+
		"\u0005\u0478\u0000\u0000\u12c1\u12c3\u0001\u0000\u0000\u0000\u12c2\u12bf"+
		"\u0001\u0000\u0000\u0000\u12c2\u12c3\u0001\u0000\u0000\u0000\u12c3\u12c4"+
		"\u0001\u0000\u0000\u0000\u12c4\u12c6\u0005i\u0000\u0000\u12c5\u12c7\u0003"+
		"\u01a4\u00d2\u0000\u12c6\u12c5\u0001\u0000\u0000\u0000\u12c7\u12c8\u0001"+
		"\u0000\u0000\u0000\u12c8\u12c6\u0001\u0000\u0000\u0000\u12c8\u12c9\u0001"+
		"\u0000\u0000\u0000\u12c9\u12ca\u0001\u0000\u0000\u0000\u12ca\u12cb\u0005"+
		"\u0197\u0000\u0000\u12cb\u12cd\u0005i\u0000\u0000\u12cc\u12ce\u0003\u0248"+
		"\u0124\u0000\u12cd\u12cc\u0001\u0000\u0000\u0000\u12cd\u12ce\u0001\u0000"+
		"\u0000\u0000\u12ce\u0191\u0001\u0000\u0000\u0000\u12cf\u12d0\u0003\u0248"+
		"\u0124\u0000\u12d0\u12d1\u0005\u0478\u0000\u0000\u12d1\u12d3\u0001\u0000"+
		"\u0000\u0000\u12d2\u12cf\u0001\u0000\u0000\u0000\u12d2\u12d3\u0001\u0000"+
		"\u0000\u0000\u12d3\u12d4\u0001\u0000\u0000\u0000\u12d4\u12d6\u0005\u008c"+
		"\u0000\u0000\u12d5\u12d7\u0003\u01a4\u00d2\u0000\u12d6\u12d5\u0001\u0000"+
		"\u0000\u0000\u12d7\u12d8\u0001\u0000\u0000\u0000\u12d8\u12d6\u0001\u0000"+
		"\u0000\u0000\u12d8\u12d9\u0001\u0000\u0000\u0000\u12d9\u12da\u0001\u0000"+
		"\u0000\u0000\u12da\u12db\u0005\u0297\u0000\u0000\u12db\u12dc\u0003\u02b0"+
		"\u0158\u0000\u12dc\u12dd\u0005\u0197\u0000\u0000\u12dd\u12df\u0005\u008c"+
		"\u0000\u0000\u12de\u12e0\u0003\u0248\u0124\u0000\u12df\u12de\u0001\u0000"+
		"\u0000\u0000\u12df\u12e0\u0001\u0000\u0000\u0000\u12e0\u0193\u0001\u0000"+
		"\u0000\u0000\u12e1\u12e2\u0005\u0092\u0000\u0000\u12e2\u12e3\u0003\u02b0"+
		"\u0158\u0000\u12e3\u0195\u0001\u0000\u0000\u0000\u12e4\u12e5\u0003\u0248"+
		"\u0124\u0000\u12e5\u12e6\u0005\u0478\u0000\u0000\u12e6\u12e8\u0001\u0000"+
		"\u0000\u0000\u12e7\u12e4\u0001\u0000\u0000\u0000\u12e7\u12e8\u0001\u0000"+
		"\u0000\u0000\u12e8\u12e9\u0001\u0000\u0000\u0000\u12e9\u12ea\u0005\u00bf"+
		"\u0000\u0000\u12ea\u12eb\u0003\u02b0\u0158\u0000\u12eb\u12ed\u0005\u018f"+
		"\u0000\u0000\u12ec\u12ee\u0003\u01a4\u00d2\u0000\u12ed\u12ec\u0001\u0000"+
		"\u0000\u0000\u12ee\u12ef\u0001\u0000\u0000\u0000\u12ef\u12ed\u0001\u0000"+
		"\u0000\u0000\u12ef\u12f0\u0001\u0000\u0000\u0000\u12f0\u12f1\u0001\u0000"+
		"\u0000\u0000\u12f1\u12f2\u0005\u0197\u0000\u0000\u12f2\u12f4\u0005\u00bf"+
		"\u0000\u0000\u12f3\u12f5\u0003\u0248\u0124\u0000\u12f4\u12f3\u0001\u0000"+
		"\u0000\u0000\u12f4\u12f5\u0001\u0000\u0000\u0000\u12f5\u0197\u0001\u0000"+
		"\u0000\u0000\u12f6\u12f7\u0005\u0169\u0000\u0000\u12f7\u1306\u0003\u0248"+
		"\u0124\u0000\u12f8\u12fd\u0005@\u0000\u0000\u12f9\u12fb\u0005\u0208\u0000"+
		"\u0000\u12fa\u12f9\u0001\u0000\u0000\u0000\u12fa\u12fb\u0001\u0000\u0000"+
		"\u0000\u12fb\u12fc\u0001\u0000\u0000\u0000\u12fc\u12fe\u0005D\u0000\u0000"+
		"\u12fd\u12fa\u0001\u0000\u0000\u0000\u12fd\u12fe\u0001\u0000\u0000\u0000"+
		"\u12fe\u12ff\u0001\u0000\u0000\u0000\u12ff\u1300\u0003\u0248\u0124\u0000"+
		"\u1300\u1301\u0005W\u0000\u0000\u1301\u1302\u0003\u0268\u0134\u0000\u1302"+
		"\u1306\u0001\u0000\u0000\u0000\u1303\u1304\u0005\u021b\u0000\u0000\u1304"+
		"\u1306\u0003\u0248\u0124\u0000\u1305\u12f6\u0001\u0000\u0000\u0000\u1305"+
		"\u12f8\u0001\u0000\u0000\u0000\u1305\u1303\u0001\u0000\u0000\u0000\u1306"+
		"\u0199\u0001\u0000\u0000\u0000\u1307\u1308\u0005)\u0000\u0000\u1308\u1309"+
		"\u0003\u0268\u0134\u0000\u1309\u130c\u0003\u025c\u012e\u0000\u130a\u130b"+
		"\u0005*\u0000\u0000\u130b\u130d\u0003\u02b0\u0158\u0000\u130c\u130a\u0001"+
		"\u0000\u0000\u0000\u130c\u130d\u0001\u0000\u0000\u0000\u130d\u019b\u0001"+
		"\u0000\u0000\u0000\u130e\u130f\u0005)\u0000\u0000\u130f\u1310\u0003\u0248"+
		"\u0124\u0000\u1310\u1311\u0005\u001d\u0000\u0000\u1311\u1318\u0005A\u0000"+
		"\u0000\u1312\u1319\u0003\u024e\u0127\u0000\u1313\u1315\u0005\u00a2\u0000"+
		"\u0000\u1314\u1316\u0005\u029d\u0000\u0000\u1315\u1314\u0001\u0000\u0000"+
		"\u0000\u1315\u1316\u0001\u0000\u0000\u0000\u1316\u1317\u0001\u0000\u0000"+
		"\u0000\u1317\u1319\u0005\u047c\u0000\u0000\u1318\u1312\u0001\u0000\u0000"+
		"\u0000\u1318\u1313\u0001\u0000\u0000\u0000\u1319\u019d\u0001\u0000\u0000"+
		"\u0000\u131a\u131b\u0005)\u0000\u0000\u131b\u131c\u0003\u0248\u0124\u0000"+
		"\u131c\u131d\u0005&\u0000\u0000\u131d\u131e\u0005A\u0000\u0000\u131e\u131f"+
		"\u0003\u00c8d\u0000\u131f\u019f\u0001\u0000\u0000\u0000\u1320\u1321\u0005"+
		")\u0000\u0000\u1321\u1322\u0007A\u0000\u0000\u1322\u1323\u0005\u01ba\u0000"+
		"\u0000\u1323\u1324\u0005A\u0000\u0000\u1324\u1329\u0003\u01a2\u00d1\u0000"+
		"\u1325\u1326\u0005\u046f\u0000\u0000\u1326\u1328\u0003\u01a2\u00d1\u0000"+
		"\u1327\u1325\u0001\u0000\u0000\u0000\u1328\u132b\u0001\u0000\u0000\u0000"+
		"\u1329\u1327\u0001\u0000\u0000\u0000\u1329\u132a\u0001\u0000\u0000\u0000"+
		"\u132a\u132c\u0001\u0000\u0000\u0000\u132b\u1329\u0001\u0000\u0000\u0000"+
		"\u132c\u132d\u0003\u0184\u00c2\u0000\u132d\u01a1\u0001\u0000\u0000\u0000"+
		"\u132e\u133a\u0003\u024e\u0127\u0000\u132f\u1331\u0005\u00a2\u0000\u0000"+
		"\u1330\u1332\u0005\u029d\u0000\u0000\u1331\u1330\u0001\u0000\u0000\u0000"+
		"\u1331\u1332\u0001\u0000\u0000\u0000\u1332\u1333\u0001\u0000\u0000\u0000"+
		"\u1333\u133a\u0005\u047c\u0000\u0000\u1334\u133a\u0003\u0248\u0124\u0000"+
		"\u1335\u133a\u0005\u00a3\u0000\u0000\u1336\u1337\u0005r\u0000\u0000\u1337"+
		"\u133a\u0005\u01b3\u0000\u0000\u1338\u133a\u0005\u00a1\u0000\u0000\u1339"+
		"\u132e\u0001\u0000\u0000\u0000\u1339\u132f\u0001\u0000\u0000\u0000\u1339"+
		"\u1334\u0001\u0000\u0000\u0000\u1339\u1335\u0001\u0000\u0000\u0000\u1339"+
		"\u1336\u0001\u0000\u0000\u0000\u1339\u1338\u0001\u0000\u0000\u0000\u133a"+
		"\u01a3\u0001\u0000\u0000\u0000\u133b\u133e\u0003\u0012\t\u0000\u133c\u133e"+
		"\u0003\u0004\u0002\u0000\u133d\u133b\u0001\u0000\u0000\u0000\u133d\u133c"+
		"\u0001\u0000\u0000\u0000\u133e\u133f\u0001\u0000\u0000\u0000\u133f\u1340"+
		"\u0005\u0470\u0000\u0000\u1340\u01a5\u0001\u0000\u0000\u0000\u1341\u1344"+
		"\u0005\u00bd\u0000\u0000\u1342\u1345\u0003\u025a\u012d\u0000\u1343\u1345"+
		"\u0003\u02b0\u0158\u0000\u1344\u1342\u0001\u0000\u0000\u0000\u1344\u1343"+
		"\u0001\u0000\u0000\u0000\u1345\u1346\u0001\u0000\u0000\u0000\u1346\u1348"+
		"\u0005\u00ae\u0000\u0000\u1347\u1349\u0003\u01a4\u00d2\u0000\u1348\u1347"+
		"\u0001\u0000\u0000\u0000\u1349\u134a\u0001\u0000\u0000\u0000\u134a\u1348"+
		"\u0001\u0000\u0000\u0000\u134a\u134b\u0001\u0000\u0000\u0000\u134b\u01a7"+
		"\u0001\u0000\u0000\u0000\u134c\u134d\u00056\u0000\u0000\u134d\u134e\u0003"+
		"\u02b0\u0158\u0000\u134e\u1350\u0005\u00ae\u0000\u0000\u134f\u1351\u0003"+
		"\u01a4\u00d2\u0000\u1350\u134f\u0001\u0000\u0000\u0000\u1351\u1352\u0001"+
		"\u0000\u0000\u0000\u1352\u1350\u0001\u0000\u0000\u0000\u1352\u1353\u0001"+
		"\u0000\u0000\u0000\u1353\u01a9\u0001\u0000\u0000\u0000\u1354\u1355\u0005"+
		"\u0007\u0000\u0000\u1355\u1356\u0005\u0299\u0000\u0000\u1356\u135b\u0003"+
		"\u01be\u00df\u0000\u1357\u1358\u0005\u046f\u0000\u0000\u1358\u135a\u0003"+
		"\u01be\u00df\u0000\u1359\u1357\u0001\u0000\u0000\u0000\u135a\u135d\u0001"+
		"\u0000\u0000\u0000\u135b\u1359\u0001\u0000\u0000\u0000\u135b\u135c\u0001"+
		"\u0000\u0000\u0000\u135c\u139e\u0001\u0000\u0000\u0000\u135d\u135b\u0001"+
		"\u0000\u0000\u0000\u135e\u135f\u0005\u0007\u0000\u0000\u135f\u1361\u0005"+
		"\u0299\u0000\u0000\u1360\u1362\u0003\u0280\u0140\u0000\u1361\u1360\u0001"+
		"\u0000\u0000\u0000\u1361\u1362\u0001\u0000\u0000\u0000\u1362\u1363\u0001"+
		"\u0000\u0000\u0000\u1363\u1368\u0003\u01c0\u00e0\u0000\u1364\u1365\u0005"+
		"\u046f\u0000\u0000\u1365\u1367\u0003\u01c0\u00e0\u0000\u1366\u1364\u0001"+
		"\u0000\u0000\u0000\u1367\u136a\u0001\u0000\u0000\u0000\u1368\u1366\u0001"+
		"\u0000\u0000\u0000\u1368\u1369\u0001\u0000\u0000\u0000\u1369\u1379\u0001"+
		"\u0000\u0000\u0000\u136a\u1368\u0001\u0000\u0000\u0000\u136b\u1377\u0005"+
		"\u008e\u0000\u0000\u136c\u1378\u0005\u0211\u0000\u0000\u136d\u1374\u0003"+
		"\u01c6\u00e3\u0000\u136e\u1370\u0005\n\u0000\u0000\u136f\u136e\u0001\u0000"+
		"\u0000\u0000\u136f\u1370\u0001\u0000\u0000\u0000\u1370\u1371\u0001\u0000"+
		"\u0000\u0000\u1371\u1373\u0003\u01c6\u00e3\u0000\u1372\u136f\u0001\u0000"+
		"\u0000\u0000\u1373\u1376\u0001\u0000\u0000\u0000\u1374\u1372\u0001\u0000"+
		"\u0000\u0000\u1374\u1375\u0001\u0000\u0000\u0000\u1375\u1378\u0001\u0000"+
		"\u0000\u0000\u1376\u1374\u0001\u0000\u0000\u0000\u1377\u136c\u0001\u0000"+
		"\u0000\u0000\u1377\u136d\u0001\u0000\u0000\u0000\u1378\u137a\u0001\u0000"+
		"\u0000\u0000\u1379\u136b\u0001\u0000\u0000\u0000\u1379\u137a\u0001\u0000"+
		"\u0000\u0000\u137a\u1381\u0001\u0000\u0000\u0000\u137b\u137d\u0005\u00c0"+
		"\u0000\u0000\u137c\u137e\u0003\u01c8\u00e4\u0000\u137d\u137c\u0001\u0000"+
		"\u0000\u0000\u137e\u137f\u0001\u0000\u0000\u0000\u137f\u137d\u0001\u0000"+
		"\u0000\u0000\u137f\u1380\u0001\u0000\u0000\u0000\u1380\u1382\u0001\u0000"+
		"\u0000\u0000\u1381\u137b\u0001\u0000\u0000\u0000\u1381\u1382\u0001\u0000"+
		"\u0000\u0000\u1382\u1387\u0001\u0000\u0000\u0000\u1383\u1386\u0003\u01ca"+
		"\u00e5\u0000\u1384\u1386\u0003\u01cc\u00e6\u0000\u1385\u1383\u0001\u0000"+
		"\u0000\u0000\u1385\u1384\u0001\u0000\u0000\u0000\u1386\u1389\u0001\u0000"+
		"\u0000\u0000\u1387\u1385\u0001\u0000\u0000\u0000\u1387\u1388\u0001\u0000"+
		"\u0000\u0000\u1388\u138e\u0001\u0000\u0000\u0000\u1389\u1387\u0001\u0000"+
		"\u0000\u0000\u138a\u138b\u0005\u0170\u0000\u0000\u138b\u138f\u0005\u047c"+
		"\u0000\u0000\u138c\u138d\u0005\u000e\u0000\u0000\u138d\u138f\u0005\u047c"+
		"\u0000\u0000\u138e\u138a\u0001\u0000\u0000\u0000\u138e\u138c\u0001\u0000"+
		"\u0000\u0000\u138e\u138f\u0001\u0000\u0000\u0000\u138f\u139e\u0001\u0000"+
		"\u0000\u0000\u1390\u1391\u0005\u0007\u0000\u0000\u1391\u1393\u0005\u0299"+
		"\u0000\u0000\u1392\u1394\u0003\u0280\u0140\u0000\u1393\u1392\u0001\u0000"+
		"\u0000\u0000\u1393\u1394\u0001\u0000\u0000\u0000\u1394\u1397\u0001\u0000"+
		"\u0000\u0000\u1395\u1398\u0003\u0234\u011a\u0000\u1396\u1398\u0003\u0248"+
		"\u0124\u0000\u1397\u1395\u0001\u0000\u0000\u0000\u1397\u1396\u0001\u0000"+
		"\u0000\u0000\u1398\u1399\u0001\u0000\u0000\u0000\u1399\u139a\u0005*\u0000"+
		"\u0000\u139a\u139b\u0005\u0254\u0000\u0000\u139b\u139c\u0003\u01b2\u00d9"+
		"\u0000\u139c\u139e\u0001\u0000\u0000\u0000\u139d\u1354\u0001\u0000\u0000"+
		"\u0000\u139d\u135e\u0001\u0000\u0000\u0000\u139d\u1390\u0001\u0000\u0000"+
		"\u0000\u139e\u01ab\u0001\u0000\u0000\u0000\u139f\u13a0\u0005!\u0000\u0000"+
		"\u13a0\u13a1\u0005\u0299\u0000\u0000\u13a1\u13a6\u0003\u01c0\u00e0\u0000"+
		"\u13a2\u13a3\u0005\u046f\u0000\u0000\u13a3\u13a5\u0003\u01c0\u00e0\u0000"+
		"\u13a4\u13a2\u0001\u0000\u0000\u0000\u13a5\u13a8\u0001\u0000\u0000\u0000"+
		"\u13a6\u13a4\u0001\u0000\u0000\u0000\u13a6\u13a7\u0001\u0000\u0000\u0000"+
		"\u13a7\u13e1\u0001\u0000\u0000\u0000\u13a8\u13a6\u0001\u0000\u0000\u0000"+
		"\u13a9\u13aa\u0005!\u0000\u0000\u13aa\u13ac\u0005\u0299\u0000\u0000\u13ab"+
		"\u13ad\u0003\u0282\u0141\u0000\u13ac\u13ab\u0001\u0000\u0000\u0000\u13ac"+
		"\u13ad\u0001\u0000\u0000\u0000\u13ad\u13ae\u0001\u0000\u0000\u0000\u13ae"+
		"\u13b3\u0003\u01c0\u00e0\u0000\u13af\u13b0\u0005\u046f\u0000\u0000\u13b0"+
		"\u13b2\u0003\u01c0\u00e0\u0000\u13b1\u13af\u0001\u0000\u0000\u0000\u13b2"+
		"\u13b5\u0001\u0000\u0000\u0000\u13b3\u13b1\u0001\u0000\u0000\u0000\u13b3"+
		"\u13b4\u0001\u0000\u0000\u0000\u13b4\u13b9\u0001\u0000\u0000\u0000\u13b5"+
		"\u13b3\u0001\u0000\u0000\u0000\u13b6\u13b7\u0005*\u0000\u0000\u13b7\u13b8"+
		"\u0005\u0254\u0000\u0000\u13b8\u13ba\u0003\u01b2\u00d9\u0000\u13b9\u13b6"+
		"\u0001\u0000\u0000\u0000\u13b9\u13ba\u0001\u0000\u0000\u0000\u13ba\u13c9"+
		"\u0001\u0000\u0000\u0000\u13bb\u13c7\u0005\u008e\u0000\u0000\u13bc\u13c8"+
		"\u0005\u0211\u0000\u0000\u13bd\u13c4\u0003\u01c6\u00e3\u0000\u13be\u13c0"+
		"\u0005\n\u0000\u0000\u13bf\u13be\u0001\u0000\u0000\u0000\u13bf\u13c0\u0001"+
		"\u0000\u0000\u0000\u13c0\u13c1\u0001\u0000\u0000\u0000\u13c1\u13c3\u0003"+
		"\u01c6\u00e3\u0000\u13c2\u13bf\u0001\u0000\u0000\u0000\u13c3\u13c6\u0001"+
		"\u0000\u0000\u0000\u13c4\u13c2\u0001\u0000\u0000\u0000\u13c4\u13c5\u0001"+
		"\u0000\u0000\u0000\u13c5\u13c8\u0001\u0000\u0000\u0000\u13c6\u13c4\u0001"+
		"\u0000\u0000\u0000\u13c7\u13bc\u0001\u0000\u0000\u0000\u13c7\u13bd\u0001"+
		"\u0000\u0000\u0000\u13c8\u13ca\u0001\u0000\u0000\u0000\u13c9\u13bb\u0001"+
		"\u0000\u0000\u0000\u13c9\u13ca\u0001\u0000\u0000\u0000\u13ca\u13d1\u0001"+
		"\u0000\u0000\u0000\u13cb\u13cd\u0005\u00c0\u0000\u0000\u13cc\u13ce\u0003"+
		"\u01c8\u00e4\u0000\u13cd\u13cc\u0001\u0000\u0000\u0000\u13ce\u13cf\u0001"+
		"\u0000\u0000\u0000\u13cf\u13cd\u0001\u0000\u0000\u0000\u13cf\u13d0\u0001"+
		"\u0000\u0000\u0000\u13d0\u13d2\u0001\u0000\u0000\u0000\u13d1\u13cb\u0001"+
		"\u0000\u0000\u0000\u13d1\u13d2\u0001\u0000\u0000\u0000\u13d2\u13d7\u0001"+
		"\u0000\u0000\u0000\u13d3\u13d6\u0003\u01ca\u00e5\u0000\u13d4\u13d6\u0003"+
		"\u01cc\u00e6\u0000\u13d5\u13d3\u0001\u0000\u0000\u0000\u13d5\u13d4\u0001"+
		"\u0000\u0000\u0000\u13d6\u13d9\u0001\u0000\u0000\u0000\u13d7\u13d5\u0001"+
		"\u0000\u0000\u0000\u13d7\u13d8\u0001\u0000\u0000\u0000\u13d8\u13de\u0001"+
		"\u0000\u0000\u0000\u13d9\u13d7\u0001\u0000\u0000\u0000\u13da\u13db\u0005"+
		"\u0170\u0000\u0000\u13db\u13df\u0005\u047c\u0000\u0000\u13dc\u13dd\u0005"+
		"\u000e\u0000\u0000\u13dd\u13df\u0005\u047c\u0000\u0000\u13de\u13da\u0001"+
		"\u0000\u0000\u0000\u13de\u13dc\u0001\u0000\u0000\u0000\u13de\u13df\u0001"+
		"\u0000\u0000\u0000\u13df\u13e1\u0001\u0000\u0000\u0000\u13e0\u139f\u0001"+
		"\u0000\u0000\u0000\u13e0\u13a9\u0001\u0000\u0000\u0000\u13e1\u01ad\u0001"+
		"\u0000\u0000\u0000\u13e2\u13e3\u00053\u0000\u0000\u13e3\u13e5\u0005\u0299"+
		"\u0000\u0000\u13e4\u13e6\u0003\u0280\u0140\u0000\u13e5\u13e4\u0001\u0000"+
		"\u0000\u0000\u13e5\u13e6\u0001\u0000\u0000\u0000\u13e6\u13e7\u0001\u0000"+
		"\u0000\u0000\u13e7\u13ec\u0003\u0234\u011a\u0000\u13e8\u13e9\u0005\u046f"+
		"\u0000\u0000\u13e9\u13eb\u0003\u0234\u011a\u0000\u13ea\u13e8\u0001\u0000"+
		"\u0000\u0000\u13eb\u13ee\u0001\u0000\u0000\u0000\u13ec\u13ea\u0001\u0000"+
		"\u0000\u0000\u13ec\u13ed\u0001\u0000\u0000\u0000\u13ed\u01af\u0001\u0000"+
		"\u0000\u0000\u13ee\u13ec\u0001\u0000\u0000\u0000\u13ef\u13f0\u0005H\u0000"+
		"\u0000\u13f0\u13f5\u0003\u01ce\u00e7\u0000\u13f1\u13f2\u0005\u046f\u0000"+
		"\u0000\u13f2\u13f4\u0003\u01ce\u00e7\u0000\u13f3\u13f1\u0001\u0000\u0000"+
		"\u0000\u13f4\u13f7\u0001\u0000\u0000\u0000\u13f5\u13f3\u0001\u0000\u0000"+
		"\u0000\u13f5\u13f6\u0001\u0000\u0000\u0000\u13f6\u13f8\u0001\u0000\u0000"+
		"\u0000\u13f7\u13f5\u0001\u0000\u0000\u0000\u13f8\u13fa\u0005v\u0000\u0000"+
		"\u13f9\u13fb\u0007B\u0000\u0000\u13fa\u13f9\u0001\u0000\u0000\u0000\u13fa"+
		"\u13fb\u0001\u0000\u0000\u0000\u13fb\u13fc\u0001\u0000\u0000\u0000\u13fc"+
		"\u13fd\u0003\u01d2\u00e9\u0000\u13fd\u13fe\u0005\u00af\u0000\u0000\u13fe"+
		"\u1403\u0003\u01c0\u00e0\u0000\u13ff\u1400\u0005\u046f\u0000\u0000\u1400"+
		"\u1402\u0003\u01c0\u00e0\u0000\u1401\u13ff\u0001\u0000\u0000\u0000\u1402"+
		"\u1405\u0001\u0000\u0000\u0000\u1403\u1401\u0001\u0000\u0000\u0000\u1403"+
		"\u1404\u0001\u0000\u0000\u0000\u1404\u1414\u0001\u0000\u0000\u0000\u1405"+
		"\u1403\u0001\u0000\u0000\u0000\u1406\u1412\u0005\u008e\u0000\u0000\u1407"+
		"\u1413\u0005\u0211\u0000\u0000\u1408\u140f\u0003\u01c6\u00e3\u0000\u1409"+
		"\u140b\u0005\n\u0000\u0000\u140a\u1409\u0001\u0000\u0000\u0000\u140a\u140b"+
		"\u0001\u0000\u0000\u0000\u140b\u140c\u0001\u0000\u0000\u0000\u140c\u140e"+
		"\u0003\u01c6\u00e3\u0000\u140d\u140a\u0001\u0000\u0000\u0000\u140e\u1411"+
		"\u0001\u0000\u0000\u0000\u140f\u140d\u0001\u0000\u0000\u0000\u140f\u1410"+
		"\u0001\u0000\u0000\u0000\u1410\u1413\u0001\u0000\u0000\u0000\u1411\u140f"+
		"\u0001\u0000\u0000\u0000\u1412\u1407\u0001\u0000\u0000\u0000\u1412\u1408"+
		"\u0001\u0000\u0000\u0000\u1413\u1415\u0001\u0000\u0000\u0000\u1414\u1406"+
		"\u0001\u0000\u0000\u0000\u1414\u1415\u0001\u0000\u0000\u0000\u1415\u141f"+
		"\u0001\u0000\u0000\u0000\u1416\u141c\u0005\u00c0\u0000\u0000\u1417\u1418"+
		"\u0005H\u0000\u0000\u1418\u141b\u0005x\u0000\u0000\u1419\u141b\u0003\u01c8"+
		"\u00e4\u0000\u141a\u1417\u0001\u0000\u0000\u0000\u141a\u1419\u0001\u0000"+
		"\u0000\u0000\u141b\u141e\u0001\u0000\u0000\u0000\u141c\u141a\u0001\u0000"+
		"\u0000\u0000\u141c\u141d\u0001\u0000\u0000\u0000\u141d\u1420\u0001\u0000"+
		"\u0000\u0000\u141e\u141c\u0001\u0000\u0000\u0000\u141f\u1416\u0001\u0000"+
		"\u0000\u0000\u141f\u1420\u0001\u0000\u0000\u0000\u1420\u1427\u0001\u0000"+
		"\u0000\u0000\u1421\u1422\u0005\f\u0000\u0000\u1422\u1423\u0003\u0234\u011a"+
		"\u0000\u1423\u1424\u0005\u00c0\u0000\u0000\u1424\u1425\u0005\u0254\u0000"+
		"\u0000\u1425\u1426\u0003\u01b2\u00d9\u0000\u1426\u1428\u0001\u0000\u0000"+
		"\u0000\u1427\u1421\u0001\u0000\u0000\u0000\u1427\u1428\u0001\u0000\u0000"+
		"\u0000\u1428\u144d\u0001\u0000\u0000\u0000\u1429\u142c\u0005H\u0000\u0000"+
		"\u142a\u142d\u0003\u0234\u011a\u0000\u142b\u142d\u0003\u0248\u0124\u0000"+
		"\u142c\u142a\u0001\u0000\u0000\u0000\u142c\u142b\u0001\u0000\u0000\u0000"+
		"\u142d\u1435\u0001\u0000\u0000\u0000\u142e\u1431\u0005\u046f\u0000\u0000"+
		"\u142f\u1432\u0003\u0234\u011a\u0000\u1430\u1432\u0003\u0248\u0124\u0000"+
		"\u1431\u142f\u0001\u0000\u0000\u0000\u1431\u1430\u0001\u0000\u0000\u0000"+
		"\u1432\u1434\u0001\u0000\u0000\u0000\u1433\u142e\u0001\u0000\u0000\u0000"+
		"\u1434\u1437\u0001\u0000\u0000\u0000\u1435\u1433\u0001\u0000\u0000\u0000"+
		"\u1435\u1436\u0001\u0000\u0000\u0000\u1436\u1438\u0001\u0000\u0000\u0000"+
		"\u1437\u1435\u0001\u0000\u0000\u0000\u1438\u143b\u0005\u00af\u0000\u0000"+
		"\u1439\u143c\u0003\u0234\u011a\u0000\u143a\u143c\u0003\u0248\u0124\u0000"+
		"\u143b\u1439\u0001\u0000\u0000\u0000\u143b\u143a\u0001\u0000\u0000\u0000"+
		"\u143c\u1444\u0001\u0000\u0000\u0000\u143d\u1440\u0005\u046f\u0000\u0000"+
		"\u143e\u1441\u0003\u0234\u011a\u0000\u143f\u1441\u0003\u0248\u0124\u0000"+
		"\u1440\u143e\u0001\u0000\u0000\u0000\u1440\u143f\u0001\u0000\u0000\u0000"+
		"\u1441\u1443\u0001\u0000\u0000\u0000\u1442\u143d\u0001\u0000\u0000\u0000"+
		"\u1443\u1446\u0001\u0000\u0000\u0000\u1444\u1442\u0001\u0000\u0000\u0000"+
		"\u1444\u1445\u0001\u0000\u0000\u0000\u1445\u144a\u0001\u0000\u0000\u0000"+
		"\u1446\u1444\u0001\u0000\u0000\u0000\u1447\u1448\u0005\u00c0\u0000\u0000"+
		"\u1448\u1449\u0005\u02b9\u0000\u0000\u1449\u144b\u0005x\u0000\u0000\u144a"+
		"\u1447\u0001\u0000\u0000\u0000\u144a\u144b\u0001\u0000\u0000\u0000\u144b"+
		"\u144d\u0001\u0000\u0000\u0000\u144c\u13ef\u0001\u0000\u0000\u0000\u144c"+
		"\u1429\u0001\u0000\u0000\u0000\u144d\u01b1\u0001\u0000\u0000\u0000\u144e"+
		"\u1465\u0005*\u0000\u0000\u144f\u1465\u0005\u0211\u0000\u0000\u1450\u145a"+
		"\u0005\u0006\u0000\u0000\u1451\u1452\u0005;\u0000\u0000\u1452\u1457\u0003"+
		"\u0234\u011a\u0000\u1453\u1454\u0005\u046f\u0000\u0000\u1454\u1456\u0003"+
		"\u0234\u011a\u0000\u1455\u1453\u0001\u0000\u0000\u0000\u1456\u1459\u0001"+
		"\u0000\u0000\u0000\u1457\u1455\u0001\u0000\u0000\u0000\u1457\u1458\u0001"+
		"\u0000\u0000\u0000\u1458\u145b\u0001\u0000\u0000\u0000\u1459\u1457\u0001"+
		"\u0000\u0000\u0000\u145a\u1451\u0001\u0000\u0000\u0000\u145a\u145b\u0001"+
		"\u0000\u0000\u0000\u145b\u1465\u0001\u0000\u0000\u0000\u145c\u1461\u0003"+
		"\u0234\u011a\u0000\u145d\u145e\u0005\u046f\u0000\u0000\u145e\u1460\u0003"+
		"\u0234\u011a\u0000\u145f\u145d\u0001\u0000\u0000\u0000\u1460\u1463\u0001"+
		"\u0000\u0000\u0000\u1461\u145f\u0001\u0000\u0000\u0000\u1461\u1462\u0001"+
		"\u0000\u0000\u0000\u1462\u1465\u0001\u0000\u0000\u0000\u1463\u1461\u0001"+
		"\u0000\u0000\u0000\u1464\u144e\u0001\u0000\u0000\u0000\u1464\u144f\u0001"+
		"\u0000\u0000\u0000\u1464\u1450\u0001\u0000\u0000\u0000\u1464\u145c\u0001"+
		"\u0000\u0000\u0000\u1465\u01b3\u0001\u0000\u0000\u0000\u1466\u1467\u0005"+
		"H\u0000\u0000\u1467\u1468\u0005\u0236\u0000\u0000\u1468\u1469\u0005v\u0000"+
		"\u0000\u1469\u146a\u0003\u0234\u011a\u0000\u146a\u146b\u0005\u00af\u0000"+
		"\u0000\u146b\u1470\u0003\u0234\u011a\u0000\u146c\u146d\u0005\u046f\u0000"+
		"\u0000\u146d\u146f\u0003\u0234\u011a\u0000\u146e\u146c\u0001\u0000\u0000"+
		"\u0000\u146f\u1472\u0001\u0000\u0000\u0000\u1470\u146e\u0001\u0000\u0000"+
		"\u0000\u1470\u1471\u0001\u0000\u0000\u0000\u1471\u1476\u0001\u0000\u0000"+
		"\u0000\u1472\u1470\u0001\u0000\u0000\u0000\u1473\u1474\u0005\u00c0\u0000"+
		"\u0000\u1474\u1475\u0005H\u0000\u0000\u1475\u1477\u0005x\u0000\u0000\u1476"+
		"\u1473\u0001\u0000\u0000\u0000\u1476\u1477\u0001\u0000\u0000\u0000\u1477"+
		"\u01b5\u0001\u0000\u0000\u0000\u1478\u1479\u0005\u008b\u0000\u0000\u1479"+
		"\u147a\u0005\u0299\u0000\u0000\u147a\u147f\u0003\u01d4\u00ea\u0000\u147b"+
		"\u147c\u0005\u046f\u0000\u0000\u147c\u147e\u0003\u01d4\u00ea\u0000\u147d"+
		"\u147b\u0001\u0000\u0000\u0000\u147e\u1481\u0001\u0000\u0000\u0000\u147f"+
		"\u147d\u0001\u0000\u0000\u0000\u147f\u1480\u0001\u0000\u0000\u0000\u1480"+
		"\u01b7\u0001\u0000\u0000\u0000\u1481\u147f\u0001\u0000\u0000\u0000\u1482"+
		"\u1483\u0005\u0093\u0000\u0000\u1483\u1488\u0003\u01ce\u00e7\u0000\u1484"+
		"\u1485\u0005\u046f\u0000\u0000\u1485\u1487\u0003\u01ce\u00e7\u0000\u1486"+
		"\u1484\u0001\u0000\u0000\u0000\u1487\u148a\u0001\u0000\u0000\u0000\u1488"+
		"\u1486\u0001\u0000\u0000\u0000\u1488\u1489\u0001\u0000\u0000\u0000\u1489"+
		"\u148b\u0001\u0000\u0000\u0000\u148a\u1488\u0001\u0000\u0000\u0000\u148b"+
		"\u148d\u0005v\u0000\u0000\u148c\u148e\u0007B\u0000\u0000\u148d\u148c\u0001"+
		"\u0000\u0000\u0000\u148d\u148e\u0001\u0000\u0000\u0000\u148e\u148f\u0001"+
		"\u0000\u0000\u0000\u148f\u1490\u0003\u01d2\u00e9\u0000\u1490\u1491\u0005"+
		"D\u0000\u0000\u1491\u1496\u0003\u0234\u011a\u0000\u1492\u1493\u0005\u046f"+
		"\u0000\u0000\u1493\u1495\u0003\u0234\u011a\u0000\u1494\u1492\u0001\u0000"+
		"\u0000\u0000\u1495\u1498\u0001\u0000\u0000\u0000\u1496\u1494\u0001\u0000"+
		"\u0000\u0000\u1496\u1497\u0001\u0000\u0000\u0000\u1497\u14c9\u0001\u0000"+
		"\u0000\u0000\u1498\u1496\u0001\u0000\u0000\u0000\u1499\u149a\u0005\u0093"+
		"\u0000\u0000\u149a\u149c\u0005\u0006\u0000\u0000\u149b\u149d\u0005\u02d5"+
		"\u0000\u0000\u149c\u149b\u0001\u0000\u0000\u0000\u149c\u149d\u0001\u0000"+
		"\u0000\u0000\u149d\u149e\u0001\u0000\u0000\u0000\u149e\u149f\u0005\u046f"+
		"\u0000\u0000\u149f\u14a0\u0005H\u0000\u0000\u14a0\u14a1\u0005x\u0000\u0000"+
		"\u14a1\u14a2\u0005D\u0000\u0000\u14a2\u14a7\u0003\u0234\u011a\u0000\u14a3"+
		"\u14a4\u0005\u046f\u0000\u0000\u14a4\u14a6\u0003\u0234\u011a\u0000\u14a5"+
		"\u14a3\u0001\u0000\u0000\u0000\u14a6\u14a9\u0001\u0000\u0000\u0000\u14a7"+
		"\u14a5\u0001\u0000\u0000\u0000\u14a7\u14a8\u0001\u0000\u0000\u0000\u14a8"+
		"\u14c9\u0001\u0000\u0000\u0000\u14a9\u14a7\u0001\u0000\u0000\u0000\u14aa"+
		"\u14ad\u0005\u0093\u0000\u0000\u14ab\u14ae\u0003\u0234\u011a\u0000\u14ac"+
		"\u14ae\u0003\u0248\u0124\u0000\u14ad\u14ab\u0001\u0000\u0000\u0000\u14ad"+
		"\u14ac\u0001\u0000\u0000\u0000\u14ae\u14b6\u0001\u0000\u0000\u0000\u14af"+
		"\u14b2\u0005\u046f\u0000\u0000\u14b0\u14b3\u0003\u0234\u011a\u0000\u14b1"+
		"\u14b3\u0003\u0248\u0124\u0000\u14b2\u14b0\u0001\u0000\u0000\u0000\u14b2"+
		"\u14b1\u0001\u0000\u0000\u0000\u14b3\u14b5\u0001\u0000\u0000\u0000\u14b4"+
		"\u14af\u0001\u0000\u0000\u0000\u14b5\u14b8\u0001\u0000\u0000\u0000\u14b6"+
		"\u14b4\u0001\u0000\u0000\u0000\u14b6\u14b7\u0001\u0000\u0000\u0000\u14b7"+
		"\u14b9\u0001\u0000\u0000\u0000\u14b8\u14b6\u0001\u0000\u0000\u0000\u14b9"+
		"\u14bc\u0005D\u0000\u0000\u14ba\u14bd\u0003\u0234\u011a\u0000\u14bb\u14bd"+
		"\u0003\u0248\u0124\u0000\u14bc\u14ba\u0001\u0000\u0000\u0000\u14bc\u14bb"+
		"\u0001\u0000\u0000\u0000\u14bd\u14c5\u0001\u0000\u0000\u0000\u14be\u14c1"+
		"\u0005\u046f\u0000\u0000\u14bf\u14c2\u0003\u0234\u011a\u0000\u14c0\u14c2"+
		"\u0003\u0248\u0124\u0000\u14c1\u14bf\u0001\u0000\u0000\u0000\u14c1\u14c0"+
		"\u0001\u0000\u0000\u0000\u14c2\u14c4\u0001\u0000\u0000\u0000\u14c3\u14be"+
		"\u0001\u0000\u0000\u0000\u14c4\u14c7\u0001\u0000\u0000\u0000\u14c5\u14c3"+
		"\u0001\u0000\u0000\u0000\u14c5\u14c6\u0001\u0000\u0000\u0000\u14c6\u14c9"+
		"\u0001\u0000\u0000\u0000\u14c7\u14c5\u0001\u0000\u0000\u0000\u14c8\u1482"+
		"\u0001\u0000\u0000\u0000\u14c8\u1499\u0001\u0000\u0000\u0000\u14c8\u14aa"+
		"\u0001\u0000\u0000\u0000\u14c9\u01b9\u0001\u0000\u0000\u0000\u14ca\u14cb"+
		"\u0005\u0093\u0000\u0000\u14cb\u14cc\u0005\u0236\u0000\u0000\u14cc\u14cd"+
		"\u0005v\u0000\u0000\u14cd\u14ce\u0003\u0234\u011a\u0000\u14ce\u14cf\u0005"+
		"D\u0000\u0000\u14cf\u14d4\u0003\u0234\u011a\u0000\u14d0\u14d1\u0005\u046f"+
		"\u0000\u0000\u14d1\u14d3\u0003\u0234\u011a\u0000\u14d2\u14d0\u0001\u0000"+
		"\u0000\u0000\u14d3\u14d6\u0001\u0000\u0000\u0000\u14d4\u14d2\u0001\u0000"+
		"\u0000\u0000\u14d4\u14d5\u0001\u0000\u0000\u0000\u14d5\u01bb\u0001\u0000"+
		"\u0000\u0000\u14d6\u14d4\u0001\u0000\u0000\u0000\u14d7\u14d8\u0005\u0099"+
		"\u0000\u0000\u14d8\u14db\u0005\u0227\u0000\u0000\u14d9\u14da\u0005A\u0000"+
		"\u0000\u14da\u14dc\u0003\u0234\u011a\u0000\u14db\u14d9\u0001\u0000\u0000"+
		"\u0000\u14db\u14dc\u0001\u0000\u0000\u0000\u14dc\u14dd\u0001\u0000\u0000"+
		"\u0000\u14dd\u14e0\u0005\u0464\u0000\u0000\u14de\u14e1\u0003\u02aa\u0155"+
		"\u0000\u14df\u14e1\u0005\u047c\u0000\u0000\u14e0\u14de\u0001\u0000\u0000"+
		"\u0000\u14e0\u14df\u0001\u0000\u0000\u0000\u14e1\u01bd\u0001\u0000\u0000"+
		"\u0000\u14e2\u14e3\u0003\u0234\u011a\u0000\u14e3\u14e4\u0003\u01ca\u00e5"+
		"\u0000\u14e4\u01bf\u0001\u0000\u0000\u0000\u14e5\u14e6\u0003\u0234\u011a"+
		"\u0000\u14e6\u14e7\u0005\u01c0\u0000\u0000\u14e7\u14e8\u0005\u0013\u0000"+
		"\u0000\u14e8\u14e9\u0005\u0227\u0000\u0000\u14e9\u14ea\u0005\u047c\u0000"+
		"\u0000\u14ea\u14ff\u0001\u0000\u0000\u0000\u14eb\u14ec\u0003\u0234\u011a"+
		"\u0000\u14ec\u14ed\u0005\u01c0\u0000\u0000\u14ed\u14ee\u0005\u0013\u0000"+
		"\u0000\u14ee\u14ef\u0005\u03df\u0000\u0000\u14ef\u14f0\u0005\u0227\u0000"+
		"\u0000\u14f0\u14f1\u0003\u01c2\u00e1\u0000\u14f1\u14ff\u0001\u0000\u0000"+
		"\u0000\u14f2\u14f3\u0003\u0234\u011a\u0000\u14f3\u14f4\u0005\u01c0\u0000"+
		"\u0000\u14f4\u14f5\u0005\u0013\u0000\u0000\u14f5\u14f6\u0005\u047c\u0000"+
		"\u0000\u14f6\u14f7\u0003\u01c2\u00e1\u0000\u14f7\u14ff\u0001\u0000\u0000"+
		"\u0000\u14f8\u14f9\u0003\u0234\u011a\u0000\u14f9\u14fa\u0005\u01c0\u0000"+
		"\u0000\u14fa\u14fb\u0005\u00c0\u0000\u0000\u14fb\u14fc\u0003\u01c4\u00e2"+
		"\u0000\u14fc\u14ff\u0001\u0000\u0000\u0000\u14fd\u14ff\u0003\u0234\u011a"+
		"\u0000\u14fe\u14e5\u0001\u0000\u0000\u0000\u14fe\u14eb\u0001\u0000\u0000"+
		"\u0000\u14fe\u14f2\u0001\u0000\u0000\u0000\u14fe\u14f8\u0001\u0000\u0000"+
		"\u0000\u14fe\u14fd\u0001\u0000\u0000\u0000\u14ff\u01c1\u0001\u0000\u0000"+
		"\u0000\u1500\u1501\u0005\u008d\u0000\u0000\u1501\u1503\u0005\u047c\u0000"+
		"\u0000\u1502\u1500\u0001\u0000\u0000\u0000\u1502\u1503\u0001\u0000\u0000"+
		"\u0000\u1503\u1507\u0001\u0000\u0000\u0000\u1504\u1505\u0005\u0091\u0000"+
		"\u0000\u1505\u1506\u0005#\u0000\u0000\u1506\u1508\u0005\u0227\u0000\u0000"+
		"\u1507\u1504\u0001\u0000\u0000\u0000\u1507\u1508\u0001\u0000\u0000\u0000"+
		"\u1508\u01c3\u0001\u0000\u0000\u0000\u1509\u1511\u0003\u0246\u0123\u0000"+
		"\u150a\u150e\u0007C\u0000\u0000\u150b\u150f\u0005\u047c\u0000\u0000\u150c"+
		"\u150d\u0005\u03df\u0000\u0000\u150d\u150f\u0005\u0227\u0000\u0000\u150e"+
		"\u150b\u0001\u0000\u0000\u0000\u150e\u150c\u0001\u0000\u0000\u0000\u150f"+
		"\u1510\u0001\u0000\u0000\u0000\u1510\u1512\u0003\u01c2\u00e1\u0000\u1511"+
		"\u150a\u0001\u0000\u0000\u0000\u1511\u1512\u0001\u0000\u0000\u0000\u1512"+
		"\u1518\u0001\u0000\u0000\u0000\u1513\u1514\u0003\u0246\u0123\u0000\u1514"+
		"\u1515\u0005\u00bb\u0000\u0000\u1515\u1516\u0003\u02aa\u0155\u0000\u1516"+
		"\u1518\u0001\u0000\u0000\u0000\u1517\u1509\u0001\u0000\u0000\u0000\u1517"+
		"\u1513\u0001\u0000\u0000\u0000\u1518\u01c5\u0001\u0000\u0000\u0000\u1519"+
		"\u1522\u0005\u00a7\u0000\u0000\u151a\u1522\u0005\u02a8\u0000\u0000\u151b"+
		"\u151c\u0005\u0166\u0000\u0000\u151c\u1522\u0005\u047c\u0000\u0000\u151d"+
		"\u151e\u0005\u01d1\u0000\u0000\u151e\u1522\u0005\u047c\u0000\u0000\u151f"+
		"\u1520\u0005\u0280\u0000\u0000\u1520\u1522\u0005\u047c\u0000\u0000\u1521"+
		"\u1519\u0001\u0000\u0000\u0000\u1521\u151a\u0001\u0000\u0000\u0000\u1521"+
		"\u151b\u0001\u0000\u0000\u0000\u1521\u151d\u0001\u0000\u0000\u0000\u1521"+
		"\u151f\u0001\u0000\u0000\u0000\u1522\u01c7\u0001\u0000\u0000\u0000\u1523"+
		"\u1524\u0005\u01f3\u0000\u0000\u1524\u152c\u0003\u024e\u0127\u0000\u1525"+
		"\u1526\u0005\u01f6\u0000\u0000\u1526\u152c\u0003\u024e\u0127\u0000\u1527"+
		"\u1528\u0005\u01f2\u0000\u0000\u1528\u152c\u0003\u024e\u0127\u0000\u1529"+
		"\u152a\u0005\u01f7\u0000\u0000\u152a\u152c\u0003\u024e\u0127\u0000\u152b"+
		"\u1523\u0001\u0000\u0000\u0000\u152b\u1525\u0001\u0000\u0000\u0000\u152b"+
		"\u1527\u0001\u0000\u0000\u0000\u152b\u1529\u0001\u0000\u0000\u0000\u152c"+
		"\u01c9\u0001\u0000\u0000\u0000\u152d\u152e\u0005\u0227\u0000\u0000\u152e"+
		"\u1535\u0005\u01a4\u0000\u0000\u152f\u1536\u0005*\u0000\u0000\u1530\u1536"+
		"\u0005\u0207\u0000\u0000\u1531\u1532\u0005V\u0000\u0000\u1532\u1533\u0003"+
		"\u024e\u0127\u0000\u1533\u1534\u0005\u02b3\u0000\u0000\u1534\u1536\u0001"+
		"\u0000\u0000\u0000\u1535\u152f\u0001\u0000\u0000\u0000\u1535\u1530\u0001"+
		"\u0000\u0000\u0000\u1535\u1531\u0001\u0000\u0000\u0000\u1535\u1536\u0001"+
		"\u0000\u0000\u0000\u1536\u1554\u0001\u0000\u0000\u0000\u1537\u1538\u0005"+
		"\u0227\u0000\u0000\u1538\u153b\u0005\u01bd\u0000\u0000\u1539\u153c\u0005"+
		"*\u0000\u0000\u153a\u153c\u0003\u024e\u0127\u0000\u153b\u1539\u0001\u0000"+
		"\u0000\u0000\u153b\u153a\u0001\u0000\u0000\u0000\u153c\u1554\u0001\u0000"+
		"\u0000\u0000\u153d\u153e\u0005\u0227\u0000\u0000\u153e\u153f\u0005\u0253"+
		"\u0000\u0000\u153f\u1544\u0005V\u0000\u0000\u1540\u1545\u0005*\u0000\u0000"+
		"\u1541\u1542\u0003\u024e\u0127\u0000\u1542\u1543\u0005\u02b3\u0000\u0000"+
		"\u1543\u1545\u0001\u0000\u0000\u0000\u1544\u1540\u0001\u0000\u0000\u0000"+
		"\u1544\u1541\u0001\u0000\u0000\u0000\u1545\u1554\u0001\u0000\u0000\u0000"+
		"\u1546\u1547\u0005\u0227\u0000\u0000\u1547\u1548\u0005\u008e\u0000\u0000"+
		"\u1548\u154a\u0005#\u0000\u0000\u1549\u154b\u0007D\u0000\u0000\u154a\u1549"+
		"\u0001\u0000\u0000\u0000\u154a\u154b\u0001\u0000\u0000\u0000\u154b\u1554"+
		"\u0001\u0000\u0000\u0000\u154c\u154d\u0005\u01a8\u0000\u0000\u154d\u1554"+
		"\u0003\u024e\u0127\u0000\u154e\u1551\u0005\u0228\u0000\u0000\u154f\u1552"+
		"\u0003\u024e\u0127\u0000\u1550\u1552\u0005\u0291\u0000\u0000\u1551\u154f"+
		"\u0001\u0000\u0000\u0000\u1551\u1550\u0001\u0000\u0000\u0000\u1552\u1554"+
		"\u0001\u0000\u0000\u0000\u1553\u152d\u0001\u0000\u0000\u0000\u1553\u1537"+
		"\u0001\u0000\u0000\u0000\u1553\u153d\u0001\u0000\u0000\u0000\u1553\u1546"+
		"\u0001\u0000\u0000\u0000\u1553\u154c\u0001\u0000\u0000\u0000\u1553\u154e"+
		"\u0001\u0000\u0000\u0000\u1554\u01cb\u0001\u0000\u0000\u0000\u1555\u1556"+
		"\u0005\u014c\u0000\u0000\u1556\u1557\u0007E\u0000\u0000\u1557\u01cd\u0001"+
		"\u0000\u0000\u0000\u1558\u155d\u0003\u01d0\u00e8\u0000\u1559\u155a\u0005"+
		"\u046d\u0000\u0000\u155a\u155b\u0003\u0268\u0134\u0000\u155b\u155c\u0005"+
		"\u046e\u0000\u0000\u155c\u155e\u0001\u0000\u0000\u0000\u155d\u1559\u0001"+
		"\u0000\u0000\u0000\u155d\u155e\u0001\u0000\u0000\u0000\u155e\u01cf\u0001"+
		"\u0000\u0000\u0000\u155f\u1561\u0005\u0006\u0000\u0000\u1560\u1562\u0005"+
		"\u02d5\u0000\u0000\u1561\u1560\u0001\u0000\u0000\u0000\u1561\u1562\u0001"+
		"\u0000\u0000\u0000\u1562\u15bd\u0001\u0000\u0000\u0000\u1563\u1565\u0005"+
		"\u0007\u0000\u0000\u1564\u1566\u0005\u02dd\u0000\u0000\u1565\u1564\u0001"+
		"\u0000\u0000\u0000\u1565\u1566\u0001\u0000\u0000\u0000\u1566\u15bd\u0001"+
		"\u0000\u0000\u0000\u1567\u156f\u0005!\u0000\u0000\u1568\u1569\u0005\u0289"+
		"\u0000\u0000\u1569\u1570\u0005\u02e6\u0000\u0000\u156a\u1570\u0005\u02dd"+
		"\u0000\u0000\u156b\u1570\u0005\u029f\u0000\u0000\u156c\u1570\u0005\u0299"+
		"\u0000\u0000\u156d\u1570\u0005\u0287\u0000\u0000\u156e\u1570\u0005\u0254"+
		"\u0000\u0000\u156f\u1568\u0001\u0000\u0000\u0000\u156f\u156a\u0001\u0000"+
		"\u0000\u0000\u156f\u156b\u0001\u0000\u0000\u0000\u156f\u156c\u0001\u0000"+
		"\u0000\u0000\u156f\u156d\u0001\u0000\u0000\u0000\u156f\u156e\u0001\u0000"+
		"\u0000\u0000\u156f\u1570\u0001\u0000\u0000\u0000\u1570\u15bd\u0001\u0000"+
		"\u0000\u0000\u1571\u15bd\u0005,\u0000\u0000\u1572\u1574\u00053\u0000\u0000"+
		"\u1573\u1575\u0005\u0254\u0000\u0000\u1574\u1573\u0001\u0000\u0000\u0000"+
		"\u1574\u1575\u0001\u0000\u0000\u0000\u1575\u15bd\u0001\u0000\u0000\u0000"+
		"\u1576\u15bd\u0005\u019f\u0000\u0000\u1577\u15bd\u0005\u02c4\u0000\u0000"+
		"\u1578\u15bd\u0005\u02c5\u0000\u0000\u1579\u157a\u0005H\u0000\u0000\u157a"+
		"\u15bd\u0005x\u0000\u0000\u157b\u15bd\u0005Q\u0000\u0000\u157c\u15bd\u0005"+
		"U\u0000\u0000\u157d\u157e\u0005g\u0000\u0000\u157e\u15bd\u0005\u02e6\u0000"+
		"\u0000\u157f\u15bd\u0005\u02d6\u0000\u0000\u1580\u15bd\u0005\u0236\u0000"+
		"\u0000\u1581\u15bd\u0005\u0088\u0000\u0000\u1582\u15bd\u0005\u02d7\u0000"+
		"\u0000\u1583\u1584\u0005\u024c\u0000\u0000\u1584\u15bd\u0007F\u0000\u0000"+
		"\u1585\u15bd\u0005\u0098\u0000\u0000\u1586\u1587\u0005\u009b\u0000\u0000"+
		"\u1587\u15bd\u0007G\u0000\u0000\u1588\u15bd\u0005\u02e3\u0000\u0000\u1589"+
		"\u15bd\u0005\u02e4\u0000\u0000\u158a\u15bd\u0005\u00b1\u0000\u0000\u158b"+
		"\u15bd\u0005\u00b8\u0000\u0000\u158c\u15bd\u0005\u00b9\u0000\u0000\u158d"+
		"\u15bd\u0005\u02ba\u0000\u0000\u158e\u15bd\u0005\u02bb\u0000\u0000\u158f"+
		"\u15bd\u0005\u02bc\u0000\u0000\u1590\u15bd\u0005\u02bd\u0000\u0000\u1591"+
		"\u15bd\u0005\u02be\u0000\u0000\u1592\u15bd\u0005\u02bf\u0000\u0000\u1593"+
		"\u15bd\u0005\u02c0\u0000\u0000\u1594\u15bd\u0005\u02c1\u0000\u0000\u1595"+
		"\u15bd\u0005\u02c2\u0000\u0000\u1596\u15bd\u0005\u02c3\u0000\u0000\u1597"+
		"\u15bd\u0005\u02c6\u0000\u0000\u1598\u15bd\u0005\u02c7\u0000\u0000\u1599"+
		"\u15bd\u0005\u02c8\u0000\u0000\u159a\u15bd\u0005\u02c9\u0000\u0000\u159b"+
		"\u15bd\u0005\u02ca\u0000\u0000\u159c\u15bd\u0005\u02cb\u0000\u0000\u159d"+
		"\u15bd\u0005\u02cc\u0000\u0000\u159e\u15bd\u0005\u02cd\u0000\u0000\u159f"+
		"\u15bd\u0005\u02ce\u0000\u0000\u15a0\u15bd\u0005\u02cf\u0000\u0000\u15a1"+
		"\u15bd\u0005\u02d2\u0000\u0000\u15a2\u15bd\u0005\u02d3\u0000\u0000\u15a3"+
		"\u15bd\u0005\u02d4\u0000\u0000\u15a4\u15bd\u0005\u02d8\u0000\u0000\u15a5"+
		"\u15bd\u0005\u02d9\u0000\u0000\u15a6\u15bd\u0005\u02da\u0000\u0000\u15a7"+
		"\u15bd\u0005\u02db\u0000\u0000\u15a8\u15bd\u0005\u02dc\u0000\u0000\u15a9"+
		"\u15bd\u0005\u02df\u0000\u0000\u15aa\u15bd\u0005\u02e0\u0000\u0000\u15ab"+
		"\u15bd\u0005\u02e1\u0000\u0000\u15ac\u15bd\u0005\u009e\u0000\u0000\u15ad"+
		"\u15bd\u0005\u02e2\u0000\u0000\u15ae\u15bd\u0005\u0435\u0000\u0000\u15af"+
		"\u15bd\u0005\u02e5\u0000\u0000\u15b0\u15bd\u0005\u02e7\u0000\u0000\u15b1"+
		"\u15bd\u0005\u0440\u0000\u0000\u15b2\u15bd\u0005\u02e8\u0000\u0000\u15b3"+
		"\u15bd\u0005\u02e9\u0000\u0000\u15b4\u15b5\u0005f\u0000\u0000\u15b5\u15b6"+
		"\u0005D\u0000\u0000\u15b6\u15bd\u0005\u02de\u0000\u0000\u15b7\u15b8\u0005"+
		"\u0098\u0000\u0000\u15b8\u15b9\u0005W\u0000\u0000\u15b9\u15bd\u0005\u02de"+
		"\u0000\u0000\u15ba\u15bb\u0005\u02d0\u0000\u0000\u15bb\u15bd\u0005\u02d1"+
		"\u0000\u0000\u15bc\u155f\u0001\u0000\u0000\u0000\u15bc\u1563\u0001\u0000"+
		"\u0000\u0000\u15bc\u1567\u0001\u0000\u0000\u0000\u15bc\u1571\u0001\u0000"+
		"\u0000\u0000\u15bc\u1572\u0001\u0000\u0000\u0000\u15bc\u1576\u0001\u0000"+
		"\u0000\u0000\u15bc\u1577\u0001\u0000\u0000\u0000\u15bc\u1578\u0001\u0000"+
		"\u0000\u0000\u15bc\u1579\u0001\u0000\u0000\u0000\u15bc\u157b\u0001\u0000"+
		"\u0000\u0000\u15bc\u157c\u0001\u0000\u0000\u0000\u15bc\u157d\u0001\u0000"+
		"\u0000\u0000\u15bc\u157f\u0001\u0000\u0000\u0000\u15bc\u1580\u0001\u0000"+
		"\u0000\u0000\u15bc\u1581\u0001\u0000\u0000\u0000\u15bc\u1582\u0001\u0000"+
		"\u0000\u0000\u15bc\u1583\u0001\u0000\u0000\u0000\u15bc\u1585\u0001\u0000"+
		"\u0000\u0000\u15bc\u1586\u0001\u0000\u0000\u0000\u15bc\u1588\u0001\u0000"+
		"\u0000\u0000\u15bc\u1589\u0001\u0000\u0000\u0000\u15bc\u158a\u0001\u0000"+
		"\u0000\u0000\u15bc\u158b\u0001\u0000\u0000\u0000\u15bc\u158c\u0001\u0000"+
		"\u0000\u0000\u15bc\u158d\u0001\u0000\u0000\u0000\u15bc\u158e\u0001\u0000"+
		"\u0000\u0000\u15bc\u158f\u0001\u0000\u0000\u0000\u15bc\u1590\u0001\u0000"+
		"\u0000\u0000\u15bc\u1591\u0001\u0000\u0000\u0000\u15bc\u1592\u0001\u0000"+
		"\u0000\u0000\u15bc\u1593\u0001\u0000\u0000\u0000\u15bc\u1594\u0001\u0000"+
		"\u0000\u0000\u15bc\u1595\u0001\u0000\u0000\u0000\u15bc\u1596\u0001\u0000"+
		"\u0000\u0000\u15bc\u1597\u0001\u0000\u0000\u0000\u15bc\u1598\u0001\u0000"+
		"\u0000\u0000\u15bc\u1599\u0001\u0000\u0000\u0000\u15bc\u159a\u0001\u0000"+
		"\u0000\u0000\u15bc\u159b\u0001\u0000\u0000\u0000\u15bc\u159c\u0001\u0000"+
		"\u0000\u0000\u15bc\u159d\u0001\u0000\u0000\u0000\u15bc\u159e\u0001\u0000"+
		"\u0000\u0000\u15bc\u159f\u0001\u0000\u0000\u0000\u15bc\u15a0\u0001\u0000"+
		"\u0000\u0000\u15bc\u15a1\u0001\u0000\u0000\u0000\u15bc\u15a2\u0001\u0000"+
		"\u0000\u0000\u15bc\u15a3\u0001\u0000\u0000\u0000\u15bc\u15a4\u0001\u0000"+
		"\u0000\u0000\u15bc\u15a5\u0001\u0000\u0000\u0000\u15bc\u15a6\u0001\u0000"+
		"\u0000\u0000\u15bc\u15a7\u0001\u0000\u0000\u0000\u15bc\u15a8\u0001\u0000"+
		"\u0000\u0000\u15bc\u15a9\u0001\u0000\u0000\u0000\u15bc\u15aa\u0001\u0000"+
		"\u0000\u0000\u15bc\u15ab\u0001\u0000\u0000\u0000\u15bc\u15ac\u0001\u0000"+
		"\u0000\u0000\u15bc\u15ad\u0001\u0000\u0000\u0000\u15bc\u15ae\u0001\u0000"+
		"\u0000\u0000\u15bc\u15af\u0001\u0000\u0000\u0000\u15bc\u15b0\u0001\u0000"+
		"\u0000\u0000\u15bc\u15b1\u0001\u0000\u0000\u0000\u15bc\u15b2\u0001\u0000"+
		"\u0000\u0000\u15bc\u15b3\u0001\u0000\u0000\u0000\u15bc\u15b4\u0001\u0000"+
		"\u0000\u0000\u15bc\u15b7\u0001\u0000\u0000\u0000\u15bc\u15ba\u0001\u0000"+
		"\u0000\u0000\u15bd\u01d1\u0001\u0000\u0000\u0000\u15be\u15cf\u0005\u045d"+
		"\u0000\u0000\u15bf\u15c0\u0005\u045d\u0000\u0000\u15c0\u15c1\u0005\u046c"+
		"\u0000\u0000\u15c1\u15cf\u0005\u045d\u0000\u0000\u15c2\u15c3\u0003\u0248"+
		"\u0124\u0000\u15c3\u15c4\u0005\u046c\u0000\u0000\u15c4\u15c5\u0005\u045d"+
		"\u0000\u0000\u15c5\u15cf\u0001\u0000\u0000\u0000\u15c6\u15c7\u0003\u0248"+
		"\u0124\u0000\u15c7\u15c8\u0005\u046c\u0000\u0000\u15c8\u15c9\u0003\u0248"+
		"\u0124\u0000\u15c9\u15cf\u0001\u0000\u0000\u0000\u15ca\u15cb\u0003\u0248"+
		"\u0124\u0000\u15cb\u15cc\u0003\u024c\u0126\u0000\u15cc\u15cf\u0001\u0000"+
		"\u0000\u0000\u15cd\u15cf\u0003\u0248\u0124\u0000\u15ce\u15be\u0001\u0000"+
		"\u0000\u0000\u15ce\u15bf\u0001\u0000\u0000\u0000\u15ce\u15c2\u0001\u0000"+
		"\u0000\u0000\u15ce\u15c6\u0001\u0000\u0000\u0000\u15ce\u15ca\u0001\u0000"+
		"\u0000\u0000\u15ce\u15cd\u0001\u0000\u0000\u0000\u15cf\u01d3\u0001\u0000"+
		"\u0000\u0000\u15d0\u15d1\u0003\u0234\u011a\u0000\u15d1\u15d2\u0005\u00af"+
		"\u0000\u0000\u15d2\u15d3\u0003\u0234\u011a\u0000\u15d3\u01d5\u0001\u0000"+
		"\u0000\u0000\u15d4\u15d6\u0005\t\u0000\u0000\u15d5\u15d7\u0007H\u0000"+
		"\u0000\u15d6\u15d5\u0001\u0000\u0000\u0000\u15d6\u15d7\u0001\u0000\u0000"+
		"\u0000\u15d7\u15d8\u0001\u0000\u0000\u0000\u15d8\u15d9\u00076\u0000\u0000"+
		"\u15d9\u15eb\u0003\u026c\u0136\u0000\u15da\u15db\u0005\u00b8\u0000\u0000"+
		"\u15db\u15dc\u0005L\u0000\u0000\u15dc\u15dd\u0005v\u0000\u0000\u15dd\u15e2"+
		"\u0003\u022c\u0116\u0000\u15de\u15df\u0005\u046f\u0000\u0000\u15df\u15e1"+
		"\u0003\u022c\u0116\u0000\u15e0\u15de\u0001\u0000\u0000\u0000\u15e1\u15e4"+
		"\u0001\u0000\u0000\u0000\u15e2\u15e0\u0001\u0000\u0000\u0000\u15e2\u15e3"+
		"\u0001\u0000\u0000\u0000\u15e3\u15e9\u0001\u0000\u0000\u0000\u15e4\u15e2"+
		"\u0001\u0000\u0000\u0000\u15e5\u15e6\u0005\u00c0\u0000\u0000\u15e6\u15e7"+
		"\u0003\u024e\u0127\u0000\u15e7\u15e8\u0005\u0012\u0000\u0000\u15e8\u15ea"+
		"\u0001\u0000\u0000\u0000\u15e9\u15e5\u0001\u0000\u0000\u0000\u15e9\u15ea"+
		"\u0001\u0000\u0000\u0000\u15ea\u15ec\u0001\u0000\u0000\u0000\u15eb\u15da"+
		"\u0001\u0000\u0000\u0000\u15eb\u15ec\u0001\u0000\u0000\u0000\u15ec\u15f8"+
		"\u0001\u0000\u0000\u0000\u15ed\u15ee\u00053\u0000\u0000\u15ee\u15ef\u0005"+
		"L\u0000\u0000\u15ef\u15f0\u0005v\u0000\u0000\u15f0\u15f5\u0003\u022c\u0116"+
		"\u0000\u15f1\u15f2\u0005\u046f\u0000\u0000\u15f2\u15f4\u0003\u022c\u0116"+
		"\u0000\u15f3\u15f1\u0001\u0000\u0000\u0000\u15f4\u15f7\u0001\u0000\u0000"+
		"\u0000\u15f5\u15f3\u0001\u0000\u0000\u0000\u15f5\u15f6\u0001\u0000\u0000"+
		"\u0000\u15f6\u15f9\u0001\u0000\u0000\u0000\u15f7\u15f5\u0001\u0000\u0000"+
		"\u0000\u15f8\u15ed\u0001\u0000\u0000\u0000\u15f8\u15f9\u0001\u0000\u0000"+
		"\u0000\u15f9\u01d7\u0001\u0000\u0000\u0000\u15fa\u15fb\u0005\u001a\u0000"+
		"\u0000\u15fb\u15fc\u0005\u00ac\u0000\u0000\u15fc\u1600\u0003\u026c\u0136"+
		"\u0000\u15fd\u15ff\u0003\u01e0\u00f0\u0000\u15fe\u15fd\u0001\u0000\u0000"+
		"\u0000\u15ff\u1602\u0001\u0000\u0000\u0000\u1600\u15fe\u0001\u0000\u0000"+
		"\u0000\u1600\u1601\u0001\u0000\u0000\u0000\u1601\u01d9\u0001\u0000\u0000"+
		"\u0000\u1602\u1600\u0001\u0000\u0000\u0000\u1603\u1604\u0005\u0164\u0000"+
		"\u0000\u1604\u1605\u0005\u00ac\u0000\u0000\u1605\u1607\u0003\u026c\u0136"+
		"\u0000\u1606\u1608\u0007I\u0000\u0000\u1607\u1606\u0001\u0000\u0000\u0000"+
		"\u1607\u1608\u0001\u0000\u0000\u0000\u1608\u01db\u0001\u0000\u0000\u0000"+
		"\u1609\u160b\u0005w\u0000\u0000\u160a\u160c\u0007H\u0000\u0000\u160b\u160a"+
		"\u0001\u0000\u0000\u0000\u160b\u160c\u0001\u0000\u0000\u0000\u160c\u160d"+
		"\u0001\u0000\u0000\u0000\u160d\u160e\u00076\u0000\u0000\u160e\u160f\u0003"+
		"\u026c\u0136\u0000\u160f\u01dd\u0001\u0000\u0000\u0000\u1610\u1612\u0005"+
		"\u0244\u0000\u0000\u1611\u1613\u0007H\u0000\u0000\u1612\u1611\u0001\u0000"+
		"\u0000\u0000\u1612\u1613\u0001\u0000\u0000\u0000\u1613\u1614\u0001\u0000"+
		"\u0000\u0000\u1614\u1615\u0005\u00ac\u0000\u0000\u1615\u1617\u0003\u026c"+
		"\u0136\u0000\u1616\u1618\u0005\u0238\u0000\u0000\u1617\u1616\u0001\u0000"+
		"\u0000\u0000\u1617\u1618\u0001\u0000\u0000\u0000\u1618\u161a\u0001\u0000"+
		"\u0000\u0000\u1619\u161b\u0005\u01a6\u0000\u0000\u161a\u1619\u0001\u0000"+
		"\u0000\u0000\u161a\u161b\u0001\u0000\u0000\u0000\u161b\u161d\u0001\u0000"+
		"\u0000\u0000\u161c\u161e\u0005\u029a\u0000\u0000\u161d\u161c\u0001\u0000"+
		"\u0000\u0000\u161d\u161e\u0001\u0000\u0000\u0000\u161e\u01df\u0001\u0000"+
		"\u0000\u0000\u161f\u1620\u0005A\u0000\u0000\u1620\u1627\u0005\u0298\u0000"+
		"\u0000\u1621\u1627\u0005\u0238\u0000\u0000\u1622\u1627\u0005\u01a9\u0000"+
		"\u0000\u1623\u1627\u0005\u01f8\u0000\u0000\u1624\u1627\u0005\u01a6\u0000"+
		"\u0000\u1625\u1627\u0005\u0162\u0000\u0000\u1626\u161f\u0001\u0000\u0000"+
		"\u0000\u1626\u1621\u0001\u0000\u0000\u0000\u1626\u1622\u0001\u0000\u0000"+
		"\u0000\u1626\u1623\u0001\u0000\u0000\u0000\u1626\u1624\u0001\u0000\u0000"+
		"\u0000\u1626\u1625\u0001\u0000\u0000\u0000\u1627\u01e1\u0001\u0000\u0000"+
		"\u0000\u1628\u162a\u0005!\u0000\u0000\u1629\u162b\u0005\u014f\u0000\u0000"+
		"\u162a\u1629\u0001\u0000\u0000\u0000\u162a\u162b\u0001\u0000\u0000\u0000"+
		"\u162b\u162c\u0001\u0000\u0000\u0000\u162c\u162e\u0005\u01b5\u0000\u0000"+
		"\u162d\u162f\u0003\u0282\u0141\u0000\u162e\u162d\u0001\u0000\u0000\u0000"+
		"\u162e\u162f\u0001\u0000\u0000\u0000\u162f\u1630\u0001\u0000\u0000\u0000"+
		"\u1630\u1631\u0003\u0248\u0124\u0000\u1631\u1632\u0005\u0252\u0000\u0000"+
		"\u1632\u1633\u0007J\u0000\u0000\u1633\u1634\u0005\u026b\u0000\u0000\u1634"+
		"\u1635\u0005\u047c\u0000\u0000\u1635\u01e3\u0001\u0000\u0000\u0000\u1636"+
		"\u1637\u0005\u01c8\u0000\u0000\u1637\u1638\u0005\u022a\u0000\u0000\u1638"+
		"\u1639\u0003\u0248\u0124\u0000\u1639\u163a\u0005\u026b\u0000\u0000\u163a"+
		"\u163b\u0005\u047c\u0000\u0000\u163b\u01e5\u0001\u0000\u0000\u0000\u163c"+
		"\u163d\u0005\u0295\u0000\u0000\u163d\u163e\u0005\u022a\u0000\u0000\u163e"+
		"\u163f\u0003\u0248\u0124\u0000\u163f\u01e7\u0001\u0000\u0000\u0000\u1640"+
		"\u1641\u0005\u0099\u0000\u0000\u1641\u1642\u0003\u01ec\u00f6\u0000\u1642"+
		"\u1645\u0007K\u0000\u0000\u1643\u1646\u0003\u02b0\u0158\u0000\u1644\u1646"+
		"\u0005v\u0000\u0000\u1645\u1643\u0001\u0000\u0000\u0000\u1645\u1644\u0001"+
		"\u0000\u0000\u0000\u1646\u1650\u0001\u0000\u0000\u0000\u1647\u1648\u0005"+
		"\u046f\u0000\u0000\u1648\u1649\u0003\u01ec\u00f6\u0000\u1649\u164c\u0007"+
		"K\u0000\u0000\u164a\u164d\u0003\u02b0\u0158\u0000\u164b\u164d\u0005v\u0000"+
		"\u0000\u164c\u164a\u0001\u0000\u0000\u0000\u164c\u164b\u0001\u0000\u0000"+
		"\u0000\u164d\u164f\u0001\u0000\u0000\u0000\u164e\u1647\u0001\u0000\u0000"+
		"\u0000\u164f\u1652\u0001\u0000\u0000\u0000\u1650\u164e\u0001\u0000\u0000"+
		"\u0000\u1650\u1651\u0001\u0000\u0000\u0000\u1651\u1675\u0001\u0000\u0000"+
		"\u0000\u1652\u1650\u0001\u0000\u0000\u0000\u1653\u1654\u0005\u0099\u0000"+
		"\u0000\u1654\u1657\u0003<\u001e\u0000\u1655\u1658\u0003\u0238\u011c\u0000"+
		"\u1656\u1658\u0005*\u0000\u0000\u1657\u1655\u0001\u0000\u0000\u0000\u1657"+
		"\u1656\u0001\u0000\u0000\u0000\u1658\u1675\u0001\u0000\u0000\u0000\u1659"+
		"\u165a\u0005\u0099\u0000\u0000\u165a\u1661\u0005\u0205\u0000\u0000\u165b"+
		"\u165e\u0003\u0238\u011c\u0000\u165c\u165d\u0005\u001b\u0000\u0000\u165d"+
		"\u165f\u0003\u023a\u011d\u0000\u165e\u165c\u0001\u0000\u0000\u0000\u165e"+
		"\u165f\u0001\u0000\u0000\u0000\u165f\u1662\u0001\u0000\u0000\u0000\u1660"+
		"\u1662\u0005*\u0000\u0000\u1661\u165b\u0001\u0000\u0000\u0000\u1661\u1660"+
		"\u0001\u0000\u0000\u0000\u1662\u1675\u0001\u0000\u0000\u0000\u1663\u1675"+
		"\u0003\u01bc\u00de\u0000\u1664\u1675\u0003\u013e\u009f\u0000\u1665\u1675"+
		"\u0003\u013c\u009e\u0000\u1666\u1667\u0005\u0099\u0000\u0000\u1667\u1668"+
		"\u0003\u0226\u0113\u0000\u1668\u1669\u0007K\u0000\u0000\u1669\u1671\u0003"+
		"\u02b0\u0158\u0000\u166a\u166b\u0005\u046f\u0000\u0000\u166b\u166c\u0003"+
		"\u0226\u0113\u0000\u166c\u166d\u0007K\u0000\u0000\u166d\u166e\u0003\u02b0"+
		"\u0158\u0000\u166e\u1670\u0001\u0000\u0000\u0000\u166f\u166a\u0001\u0000"+
		"\u0000\u0000\u1670\u1673\u0001\u0000\u0000\u0000\u1671\u166f\u0001\u0000"+
		"\u0000\u0000\u1671\u1672\u0001\u0000\u0000\u0000\u1672\u1675\u0001\u0000"+
		"\u0000\u0000\u1673\u1671\u0001\u0000\u0000\u0000\u1674\u1640\u0001\u0000"+
		"\u0000\u0000\u1674\u1653\u0001\u0000\u0000\u0000\u1674\u1659\u0001\u0000"+
		"\u0000\u0000\u1674\u1663\u0001\u0000\u0000\u0000\u1674\u1664\u0001\u0000"+
		"\u0000\u0000\u1674\u1665\u0001\u0000\u0000\u0000\u1674\u1666\u0001\u0000"+
		"\u0000\u0000\u1675\u01e9\u0001\u0000\u0000\u0000\u1676\u1677\u0005\u009b"+
		"\u0000\u0000\u1677\u1678\u00078\u0000\u0000\u1678\u1710\u0005\u01dc\u0000"+
		"\u0000\u1679\u167a\u0005\u009b\u0000\u0000\u167a\u167b\u0007L\u0000\u0000"+
		"\u167b\u167e\u0005\u01a0\u0000\u0000\u167c\u167d\u0005P\u0000\u0000\u167d"+
		"\u167f\u0005\u047c\u0000\u0000\u167e\u167c\u0001\u0000\u0000\u0000\u167e"+
		"\u167f\u0001\u0000\u0000\u0000\u167f\u1682\u0001\u0000\u0000\u0000\u1680"+
		"\u1681\u0005D\u0000\u0000\u1681\u1683\u0003\u024e\u0127\u0000\u1682\u1680"+
		"\u0001\u0000\u0000\u0000\u1682\u1683\u0001\u0000\u0000\u0000\u1683\u168b"+
		"\u0001\u0000\u0000\u0000\u1684\u1688\u0005c\u0000\u0000\u1685\u1686\u0003"+
		"\u024e\u0127\u0000\u1686\u1687\u0005\u046f\u0000\u0000\u1687\u1689\u0001"+
		"\u0000\u0000\u0000\u1688\u1685\u0001\u0000\u0000\u0000\u1688\u1689\u0001"+
		"\u0000\u0000\u0000\u1689\u168a\u0001\u0000\u0000\u0000\u168a\u168c\u0003"+
		"\u024e\u0127\u0000\u168b\u1684\u0001\u0000\u0000\u0000\u168b\u168c\u0001"+
		"\u0000\u0000\u0000\u168c\u1710\u0001\u0000\u0000\u0000\u168d\u168e\u0005"+
		"\u009b\u0000\u0000\u168e\u1690\u0003\u01ee\u00f7\u0000\u168f\u1691\u0003"+
		"\u01f0\u00f8\u0000\u1690\u168f\u0001\u0000\u0000\u0000\u1690\u1691\u0001"+
		"\u0000\u0000\u0000\u1691\u1710\u0001\u0000\u0000\u0000\u1692\u1694\u0005"+
		"\u009b\u0000\u0000\u1693\u1695\u0005\u01b4\u0000\u0000\u1694\u1693\u0001"+
		"\u0000\u0000\u0000\u1694\u1695\u0001\u0000\u0000\u0000\u1695\u1696\u0001"+
		"\u0000\u0000\u0000\u1696\u1697\u0007)\u0000\u0000\u1697\u1698\u0007M\u0000"+
		"\u0000\u1698\u169b\u0003\u0228\u0114\u0000\u1699\u169a\u0007M\u0000\u0000"+
		"\u169a\u169c\u0003\u0248\u0124\u0000\u169b\u1699\u0001\u0000\u0000\u0000"+
		"\u169b\u169c\u0001\u0000\u0000\u0000\u169c\u169e\u0001\u0000\u0000\u0000"+
		"\u169d\u169f\u0003\u01f0\u00f8\u0000\u169e\u169d\u0001\u0000\u0000\u0000"+
		"\u169e\u169f\u0001\u0000\u0000\u0000\u169f\u1710\u0001\u0000\u0000\u0000"+
		"\u16a0\u16a1\u0005\u009b\u0000\u0000\u16a1\u16a2\u0005!\u0000\u0000\u16a2"+
		"\u16a4\u0007\u0000\u0000\u0000\u16a3\u16a5\u0003\u0282\u0141\u0000\u16a4"+
		"\u16a3\u0001\u0000\u0000\u0000\u16a4\u16a5\u0001\u0000\u0000\u0000\u16a5"+
		"\u16a6\u0001\u0000\u0000\u0000\u16a6\u1710\u0003\u0248\u0124\u0000\u16a7"+
		"\u16a8\u0005\u009b\u0000\u0000\u16a8\u16a9\u0005!\u0000\u0000\u16a9\u16aa"+
		"\u0007N\u0000\u0000\u16aa\u1710\u0003\u0226\u0113\u0000\u16ab\u16ac\u0005"+
		"\u009b\u0000\u0000\u16ac\u16ad\u0005!\u0000\u0000\u16ad\u16ae\u0005\u0299"+
		"\u0000\u0000\u16ae\u1710\u0003\u0234\u011a\u0000\u16af\u16b0\u0005\u009b"+
		"\u0000\u0000\u16b0\u16b1\u0005\u0199\u0000\u0000\u16b1\u16b2\u0003\u023c"+
		"\u011e\u0000\u16b2\u16b3\u0007O\u0000\u0000\u16b3\u1710\u0001\u0000\u0000"+
		"\u0000\u16b4\u16b5\u0005\u009b\u0000\u0000\u16b5\u1710\u0003\u01f2\u00f9"+
		"\u0000\u16b6\u16b7\u0005\u009b\u0000\u0000\u16b7\u16bf\u0007P\u0000\u0000"+
		"\u16b8\u16bc\u0005c\u0000\u0000\u16b9\u16ba\u0003\u024e\u0127\u0000\u16ba"+
		"\u16bb\u0005\u046f\u0000\u0000\u16bb\u16bd\u0001\u0000\u0000\u0000\u16bc"+
		"\u16b9\u0001\u0000\u0000\u0000\u16bc\u16bd\u0001\u0000\u0000\u0000\u16bd"+
		"\u16be\u0001\u0000\u0000\u0000\u16be\u16c0\u0003\u024e\u0127\u0000\u16bf"+
		"\u16b8\u0001\u0000\u0000\u0000\u16bf\u16c0\u0001\u0000\u0000\u0000\u16c0"+
		"\u1710\u0001\u0000\u0000\u0000\u16c1\u16c2\u0005\u009b\u0000\u0000\u16c2"+
		"\u16c3\u0005\u0122\u0000\u0000\u16c3\u16c4\u0005\u046d\u0000\u0000\u16c4"+
		"\u16c5\u0005\u045d\u0000\u0000\u16c5\u16c6\u0005\u046e\u0000\u0000\u16c6"+
		"\u1710\u0007P\u0000\u0000\u16c7\u16c8\u0005\u009b\u0000\u0000\u16c8\u16cb"+
		"\u0003\u01f4\u00fa\u0000\u16c9\u16ca\u0007M\u0000\u0000\u16ca\u16cc\u0003"+
		"\u0248\u0124\u0000\u16cb\u16c9\u0001\u0000\u0000\u0000\u16cb\u16cc\u0001"+
		"\u0000\u0000\u0000\u16cc\u16ce\u0001\u0000\u0000\u0000\u16cd\u16cf\u0003"+
		"\u01f0\u00f8\u0000\u16ce\u16cd\u0001\u0000\u0000\u0000\u16ce\u16cf\u0001"+
		"\u0000\u0000\u0000\u16cf\u1710\u0001\u0000\u0000\u0000\u16d0\u16d1\u0005"+
		"\u009b\u0000\u0000\u16d1\u16d2\u0007Q\u0000\u0000\u16d2\u16d3\u0005\u016c"+
		"\u0000\u0000\u16d3\u1710\u0003\u0226\u0113\u0000\u16d4\u16d5\u0005\u009b"+
		"\u0000\u0000\u16d5\u16d8\u0005\u01b8\u0000\u0000\u16d6\u16d7\u0005A\u0000"+
		"\u0000\u16d7\u16d9\u0003\u0234\u011a\u0000\u16d8\u16d6\u0001\u0000\u0000"+
		"\u0000\u16d8\u16d9\u0001\u0000\u0000\u0000\u16d9\u1710\u0001\u0000\u0000"+
		"\u0000\u16da\u16db\u0005\u009b\u0000\u0000\u16db\u16dc\u0007R\u0000\u0000"+
		"\u16dc\u16dd\u0007M\u0000\u0000\u16dd\u16e0\u0003\u0228\u0114\u0000\u16de"+
		"\u16df\u0007M\u0000\u0000\u16df\u16e1\u0003\u0248\u0124\u0000\u16e0\u16de"+
		"\u0001\u0000\u0000\u0000\u16e0\u16e1\u0001\u0000\u0000\u0000\u16e1\u16e4"+
		"\u0001\u0000\u0000\u0000\u16e2\u16e3\u0005\u00be\u0000\u0000\u16e3\u16e5"+
		"\u0003\u02b0\u0158\u0000\u16e4\u16e2\u0001\u0000\u0000\u0000\u16e4\u16e5"+
		"\u0001\u0000\u0000\u0000\u16e5\u1710\u0001\u0000\u0000\u0000\u16e6\u16e7"+
		"\u0005\u009b\u0000\u0000\u16e7\u16e8\u0005\u021b\u0000\u0000\u16e8\u16eb"+
		"\u0005\u02e6\u0000\u0000\u16e9\u16ea\u0007M\u0000\u0000\u16ea\u16ec\u0003"+
		"\u0248\u0124\u0000\u16eb\u16e9\u0001\u0000\u0000\u0000\u16eb\u16ec\u0001"+
		"\u0000\u0000\u0000\u16ec\u16ee\u0001\u0000\u0000\u0000\u16ed\u16ef\u0003"+
		"\u01f0\u00f8\u0000\u16ee\u16ed\u0001\u0000\u0000\u0000\u16ee\u16ef\u0001"+
		"\u0000\u0000\u0000\u16ef\u1710\u0001\u0000\u0000\u0000\u16f0\u16f1\u0005"+
		"\u009b\u0000\u0000\u16f1\u16f2\u0005\u0234\u0000\u0000\u16f2\u16f7\u0003"+
		"\u01f6\u00fb\u0000\u16f3\u16f4\u0005\u046f\u0000\u0000\u16f4\u16f6\u0003"+
		"\u01f6\u00fb\u0000\u16f5\u16f3\u0001\u0000\u0000\u0000\u16f6\u16f9\u0001"+
		"\u0000\u0000\u0000\u16f7\u16f5\u0001\u0000\u0000\u0000\u16f7\u16f8\u0001"+
		"\u0000\u0000\u0000\u16f8\u16fd\u0001\u0000\u0000\u0000\u16f9\u16f7\u0001"+
		"\u0000\u0000\u0000\u16fa\u16fb\u0005A\u0000\u0000\u16fb\u16fc\u0005\u0237"+
		"\u0000\u0000\u16fc\u16fe\u0003\u024e\u0127\u0000\u16fd\u16fa\u0001\u0000"+
		"\u0000\u0000\u16fd\u16fe\u0001\u0000\u0000\u0000\u16fe\u16ff\u0001\u0000"+
		"\u0000\u0000\u16ff\u1703\u0005c\u0000\u0000\u1700\u1701\u0003\u024e\u0127"+
		"\u0000\u1701\u1702\u0005\u046f\u0000\u0000\u1702\u1704\u0001\u0000\u0000"+
		"\u0000\u1703\u1700\u0001\u0000\u0000\u0000\u1703\u1704\u0001\u0000\u0000"+
		"\u0000\u1704\u1705\u0001\u0000\u0000\u0000\u1705\u1706\u0003\u024e\u0127"+
		"\u0000\u1706\u1710\u0001\u0000\u0000\u0000\u1707\u1708\u0005\u009b\u0000"+
		"\u0000\u1708\u1709\u0005\u0266\u0000\u0000\u1709\u170d\u0005\u027a\u0000"+
		"\u0000\u170a\u170b\u0005A\u0000\u0000\u170b\u170c\u0005\u0163\u0000\u0000"+
		"\u170c\u170e\u0005\u047c\u0000\u0000\u170d\u170a\u0001\u0000\u0000\u0000"+
		"\u170d\u170e\u0001\u0000\u0000\u0000\u170e\u1710\u0001\u0000\u0000\u0000"+
		"\u170f\u1676\u0001\u0000\u0000\u0000\u170f\u1679\u0001\u0000\u0000\u0000"+
		"\u170f\u168d\u0001\u0000\u0000\u0000\u170f\u1692\u0001\u0000\u0000\u0000"+
		"\u170f\u16a0\u0001\u0000\u0000\u0000\u170f\u16a7\u0001\u0000\u0000\u0000"+
		"\u170f\u16ab\u0001\u0000\u0000\u0000\u170f\u16af\u0001\u0000\u0000\u0000"+
		"\u170f\u16b4\u0001\u0000\u0000\u0000\u170f\u16b6\u0001\u0000\u0000\u0000"+
		"\u170f\u16c1\u0001\u0000\u0000\u0000\u170f\u16c7\u0001\u0000\u0000\u0000"+
		"\u170f\u16d0\u0001\u0000\u0000\u0000\u170f\u16d4\u0001\u0000\u0000\u0000"+
		"\u170f\u16da\u0001\u0000\u0000\u0000\u170f\u16e6\u0001\u0000\u0000\u0000"+
		"\u170f\u16f0\u0001\u0000\u0000\u0000\u170f\u1707\u0001\u0000\u0000\u0000"+
		"\u1710\u01eb\u0001\u0000\u0000\u0000\u1711\u171c\u0005\u0487\u0000\u0000"+
		"\u1712\u171c\u0005\u0488\u0000\u0000\u1713\u1714\u0005\u0471\u0000\u0000"+
		"\u1714\u1716\u0005\u0471\u0000\u0000\u1715\u1713\u0001\u0000\u0000\u0000"+
		"\u1715\u1716\u0001\u0000\u0000\u0000\u1716\u1717\u0001\u0000\u0000\u0000"+
		"\u1717\u1719\u0007S\u0000\u0000\u1718\u1715\u0001\u0000\u0000\u0000\u1718"+
		"\u1719\u0001\u0000\u0000\u0000\u1719\u171a\u0001\u0000\u0000\u0000\u171a"+
		"\u171c\u0003\u0248\u0124\u0000\u171b\u1711\u0001\u0000\u0000\u0000\u171b"+
		"\u1712\u0001\u0000\u0000\u0000\u171b\u1718\u0001\u0000\u0000\u0000\u171c"+
		"\u01ed\u0001\u0000\u0000\u0000\u171d\u171e\u0005\u0019\u0000\u0000\u171e"+
		"\u172b\u0005\u0099\u0000\u0000\u171f\u172b\u0005\u034c\u0000\u0000\u1720"+
		"\u172b\u0005(\u0000\u0000\u1721\u172b\u0005\u0097\u0000\u0000\u1722\u1723"+
		"\u0005\u01b5\u0000\u0000\u1723\u172b\u0005\u027a\u0000\u0000\u1724\u1725"+
		"\u0005\u0083\u0000\u0000\u1725\u172b\u0005\u027a\u0000\u0000\u1726\u1728"+
		"\u00077\u0000\u0000\u1727\u1726\u0001\u0000\u0000\u0000\u1727\u1728\u0001"+
		"\u0000\u0000\u0000\u1728\u1729\u0001\u0000\u0000\u0000\u1729\u172b\u0007"+
		"T\u0000\u0000\u172a\u171d\u0001\u0000\u0000\u0000\u172a\u171f\u0001\u0000"+
		"\u0000\u0000\u172a\u1720\u0001\u0000\u0000\u0000\u172a\u1721\u0001\u0000"+
		"\u0000\u0000\u172a\u1722\u0001\u0000\u0000\u0000\u172a\u1724\u0001\u0000"+
		"\u0000\u0000\u172a\u1727\u0001\u0000\u0000\u0000\u172b\u01ef\u0001\u0000"+
		"\u0000\u0000\u172c\u172d\u0005b\u0000\u0000\u172d\u1731\u0005\u047c\u0000"+
		"\u0000\u172e\u172f\u0005\u00be\u0000\u0000\u172f\u1731\u0003\u02b0\u0158"+
		"\u0000\u1730\u172c\u0001\u0000\u0000\u0000\u1730\u172e\u0001\u0000\u0000"+
		"\u0000\u1731\u01f1\u0001\u0000\u0000\u0000\u1732\u1734\u0005\u027c\u0000"+
		"\u0000\u1733\u1732\u0001\u0000\u0000\u0000\u1733\u1734\u0001\u0000\u0000"+
		"\u0000\u1734\u1735\u0001\u0000\u0000\u0000\u1735\u1744\u0005\u019a\u0000"+
		"\u0000\u1736\u1737\u0005\u01dd\u0000\u0000\u1737\u1744\u0005\u027a\u0000"+
		"\u0000\u1738\u1744\u0005\u022c\u0000\u0000\u1739\u1744\u0005\u02d5\u0000"+
		"\u0000\u173a\u173c\u0005\u01b4\u0000\u0000\u173b\u173a\u0001\u0000\u0000"+
		"\u0000\u173b\u173c\u0001\u0000\u0000\u0000\u173c\u173d\u0001\u0000\u0000"+
		"\u0000\u173d\u1744\u0005\u0233\u0000\u0000\u173e\u1744\u0005\u0235\u0000"+
		"\u0000\u173f\u1740\u0005\u0266\u0000\u0000\u1740\u1744\u0005\u01bf\u0000"+
		"\u0000\u1741\u1744\u0005\u0153\u0000\u0000\u1742\u1744\u0005\u017f\u0000"+
		"\u0000\u1743\u1733\u0001\u0000\u0000\u0000\u1743\u1736\u0001\u0000\u0000"+
		"\u0000\u1743\u1738\u0001\u0000\u0000\u0000\u1743\u1739\u0001\u0000\u0000"+
		"\u0000\u1743\u173b\u0001\u0000\u0000\u0000\u1743\u173e\u0001\u0000\u0000"+
		"\u0000\u1743\u173f\u0001\u0000\u0000\u0000\u1743\u1741\u0001\u0000\u0000"+
		"\u0000\u1743\u1742\u0001\u0000\u0000\u0000\u1744\u01f3\u0001\u0000\u0000"+
		"\u0000\u1745\u174e\u0005\u01a0\u0000\u0000\u1746\u1747\u0005\u00ac\u0000"+
		"\u0000\u1747\u174e\u0005\u027a\u0000\u0000\u1748\u174a\u0005\u01b4\u0000"+
		"\u0000\u1749\u1748\u0001\u0000\u0000\u0000\u1749\u174a\u0001\u0000\u0000"+
		"\u0000\u174a\u174b\u0001\u0000\u0000\u0000\u174b\u174e\u0005\u02e6\u0000"+
		"\u0000\u174c\u174e\u0005\u028f\u0000\u0000\u174d\u1745\u0001\u0000\u0000"+
		"\u0000\u174d\u1746\u0001\u0000\u0000\u0000\u174d\u1749\u0001\u0000\u0000"+
		"\u0000\u174d\u174c\u0001\u0000\u0000\u0000\u174e\u01f5\u0001\u0000\u0000"+
		"\u0000\u174f\u175c\u0005\u0006\u0000\u0000\u1750\u1751\u0005\u015b\u0000"+
		"\u0000\u1751\u175c\u0005\u01cd\u0000\u0000\u1752\u1753\u0005\u017e\u0000"+
		"\u0000\u1753\u175c\u0005\u0285\u0000\u0000\u1754\u175c\u0005\u0181\u0000"+
		"\u0000\u1755\u175c\u0005\u01cf\u0000\u0000\u1756\u175c\u0005\u0318\u0000"+
		"\u0000\u1757\u1758\u0005\u0220\u0000\u0000\u1758\u175c\u0005\u01aa\u0000"+
		"\u0000\u1759\u175c\u0005\u026d\u0000\u0000\u175a\u175c\u0005\u0284\u0000"+
		"\u0000\u175b\u174f\u0001\u0000\u0000\u0000\u175b\u1750\u0001\u0000\u0000"+
		"\u0000\u175b\u1752\u0001\u0000\u0000\u0000\u175b\u1754\u0001\u0000\u0000"+
		"\u0000\u175b\u1755\u0001\u0000\u0000\u0000\u175b\u1756\u0001\u0000\u0000"+
		"\u0000\u175b\u1757\u0001\u0000\u0000\u0000\u175b\u1759\u0001\u0000\u0000"+
		"\u0000\u175b\u175a\u0001\u0000\u0000\u0000\u175c\u01f7\u0001\u0000\u0000"+
		"\u0000\u175d\u175e\u0005\u0159\u0000\u0000\u175e\u175f\u0005\u047c\u0000"+
		"\u0000\u175f\u01f9\u0001\u0000\u0000\u0000\u1760\u1761\u0005\u015f\u0000"+
		"\u0000\u1761\u1762\u0005Q\u0000\u0000\u1762\u1767\u0003\u0206\u0103\u0000"+
		"\u1763\u1764\u0005\u046f\u0000\u0000\u1764\u1766\u0003\u0206\u0103\u0000"+
		"\u1765\u1763\u0001\u0000\u0000\u0000\u1766\u1769\u0001\u0000\u0000\u0000"+
		"\u1767\u1765\u0001\u0000\u0000\u0000\u1767\u1768\u0001\u0000\u0000\u0000"+
		"\u1768\u1771\u0001\u0000\u0000\u0000\u1769\u1767\u0001\u0000\u0000\u0000"+
		"\u176a\u176b\u0005\u0081\u0000\u0000\u176b\u176e\u0005\u046d\u0000\u0000"+
		"\u176c\u176f\u0003\u0268\u0134\u0000\u176d\u176f\u0005\u0006\u0000\u0000"+
		"\u176e\u176c\u0001\u0000\u0000\u0000\u176e\u176d\u0001\u0000\u0000\u0000"+
		"\u176f\u1770\u0001\u0000\u0000\u0000\u1770\u1772\u0005\u046e\u0000\u0000"+
		"\u1771\u176a\u0001\u0000\u0000\u0000\u1771\u1772\u0001\u0000\u0000\u0000"+
		"\u1772\u1773\u0001\u0000\u0000\u0000\u1773\u1774\u0005P\u0000\u0000\u1774"+
		"\u1775\u0003\u0248\u0124\u0000\u1775\u01fb\u0001\u0000\u0000\u0000\u1776"+
		"\u1778\u0005\u01b0\u0000\u0000\u1777\u1779\u0007H\u0000\u0000\u1778\u1777"+
		"\u0001\u0000\u0000\u0000\u1778\u1779\u0001\u0000\u0000\u0000\u1779\u177a"+
		"\u0001\u0000\u0000\u0000\u177a\u177f\u0003\u0208\u0104\u0000\u177b\u177c"+
		"\u0005\u046f\u0000\u0000\u177c\u177e\u0003\u0208\u0104\u0000\u177d\u177b"+
		"\u0001\u0000\u0000\u0000\u177e\u1781\u0001\u0000\u0000\u0000\u177f\u177d"+
		"\u0001\u0000\u0000\u0000\u177f\u1780\u0001\u0000\u0000\u0000\u1780\u01fd"+
		"\u0001\u0000\u0000\u0000\u1781\u177f\u0001\u0000\u0000\u0000\u1782\u1784"+
		"\u0005]\u0000\u0000\u1783\u1785\u0007U\u0000\u0000\u1784\u1783\u0001\u0000"+
		"\u0000\u0000\u1784\u1785\u0001\u0000\u0000\u0000\u1785\u1786\u0001\u0000"+
		"\u0000\u0000\u1786\u1787\u0003\u02b0\u0158\u0000\u1787\u01ff\u0001\u0000"+
		"\u0000\u0000\u1788\u1789\u0005f\u0000\u0000\u1789\u178a\u0005Q\u0000\u0000"+
		"\u178a\u178b\u0005W\u0000\u0000\u178b\u178c\u0005\u015f\u0000\u0000\u178c"+
		"\u1791\u0003\u020c\u0106\u0000\u178d\u178e\u0005\u046f\u0000\u0000\u178e"+
		"\u1790\u0003\u020c\u0106\u0000\u178f\u178d\u0001\u0000\u0000\u0000\u1790"+
		"\u1793\u0001\u0000\u0000\u0000\u1791\u178f\u0001\u0000\u0000\u0000\u1791"+
		"\u1792\u0001\u0000\u0000\u0000\u1792\u0201\u0001\u0000\u0000\u0000\u1793"+
		"\u1791\u0001\u0000\u0000\u0000\u1794\u1795\u0005\u024d\u0000\u0000\u1795"+
		"\u1796\u0005\u0237\u0000\u0000\u1796\u1797\u0005\u015f\u0000\u0000\u1797"+
		"\u0203\u0001\u0000\u0000\u0000\u1798\u1799\u0005\u02e3\u0000\u0000\u1799"+
		"\u0205\u0001\u0000\u0000\u0000\u179a\u17a2\u0003\u0228\u0114\u0000\u179b"+
		"\u179d\u0007\u0014\u0000\u0000\u179c\u179b\u0001\u0000\u0000\u0000\u179c"+
		"\u179d\u0001\u0000\u0000\u0000\u179d\u179e\u0001\u0000\u0000\u0000\u179e"+
		"\u179f\u0005\u046d\u0000\u0000\u179f\u17a0\u0003\u0268\u0134\u0000\u17a0"+
		"\u17a1\u0005\u046e\u0000\u0000\u17a1\u17a3\u0001\u0000\u0000\u0000\u17a2"+
		"\u179c\u0001\u0000\u0000\u0000\u17a2\u17a3\u0001\u0000\u0000\u0000\u17a3"+
		"\u0207\u0001\u0000\u0000\u0000\u17a4\u17b7\u0005\u018a\u0000\u0000\u17a5"+
		"\u17b7\u0005\u01bf\u0000\u0000\u17a6\u17a8\u0007V\u0000\u0000\u17a7\u17a6"+
		"\u0001\u0000\u0000\u0000\u17a7\u17a8\u0001\u0000\u0000\u0000\u17a8\u17a9"+
		"\u0001\u0000\u0000\u0000\u17a9\u17b7\u0005\u01dc\u0000\u0000\u17aa\u17b7"+
		"\u0005\u021c\u0000\u0000\u17ab\u17b7\u0005\u02d5\u0000\u0000\u17ac\u17ad"+
		"\u0005\u0237\u0000\u0000\u17ad\u17b7\u0005\u015f\u0000\u0000\u17ae\u17b7"+
		"\u0005\u027a\u0000\u0000\u17af\u17b7\u0005\u029b\u0000\u0000\u17b0\u17b4"+
		"\u0005\u02e6\u0000\u0000\u17b1\u17b2\u0005\u00c0\u0000\u0000\u17b2\u17b3"+
		"\u0005\u0086\u0000\u0000\u17b3\u17b5\u0005g\u0000\u0000\u17b4\u17b1\u0001"+
		"\u0000\u0000\u0000\u17b4\u17b5\u0001\u0000\u0000\u0000\u17b5\u17b7\u0001"+
		"\u0000\u0000\u0000\u17b6\u17a4\u0001\u0000\u0000\u0000\u17b6\u17a5\u0001"+
		"\u0000\u0000\u0000\u17b6\u17a7\u0001\u0000\u0000\u0000\u17b6\u17aa\u0001"+
		"\u0000\u0000\u0000\u17b6\u17ab\u0001\u0000\u0000\u0000\u17b6\u17ac\u0001"+
		"\u0000\u0000\u0000\u17b6\u17ae\u0001\u0000\u0000\u0000\u17b6\u17af\u0001"+
		"\u0000\u0000\u0000\u17b6\u17b0\u0001\u0000\u0000\u0000\u17b7\u17c5\u0001"+
		"\u0000\u0000\u0000\u17b8\u17b9\u0005\u023e\u0000\u0000\u17b9\u17bb\u0005"+
		"\u01dc\u0000\u0000\u17ba\u17bc\u0003\u0164\u00b2\u0000\u17bb\u17ba\u0001"+
		"\u0000\u0000\u0000\u17bb\u17bc\u0001\u0000\u0000\u0000\u17bc\u17c5\u0001"+
		"\u0000\u0000\u0000\u17bd\u17bf\u00076\u0000\u0000\u17be\u17c0\u0003\u026c"+
		"\u0136\u0000\u17bf\u17be\u0001\u0000\u0000\u0000\u17bf\u17c0\u0001\u0000"+
		"\u0000\u0000\u17c0\u17c2\u0001\u0000\u0000\u0000\u17c1\u17c3\u0003\u020a"+
		"\u0105\u0000\u17c2\u17c1\u0001\u0000\u0000\u0000\u17c2\u17c3\u0001\u0000"+
		"\u0000\u0000\u17c3\u17c5\u0001\u0000\u0000\u0000\u17c4\u17b6\u0001\u0000"+
		"\u0000\u0000\u17c4\u17b8\u0001\u0000\u0000\u0000\u17c4\u17bd\u0001\u0000"+
		"\u0000\u0000\u17c5\u0209\u0001\u0000\u0000\u0000\u17c6\u17c7\u0005\u00c0"+
		"\u0000\u0000\u17c7\u17c8\u0005\u0086\u0000\u0000\u17c8\u17cc\u0005g\u0000"+
		"\u0000\u17c9\u17ca\u0005A\u0000\u0000\u17ca\u17cc\u0005\u01a5\u0000\u0000"+
		"\u17cb\u17c6\u0001\u0000\u0000\u0000\u17cb\u17c9\u0001\u0000\u0000\u0000"+
		"\u17cc\u020b\u0001\u0000\u0000\u0000\u17cd\u17d5\u0003\u0228\u0114\u0000"+
		"\u17ce\u17cf\u0005\u0081\u0000\u0000\u17cf\u17d2\u0005\u046d\u0000\u0000"+
		"\u17d0\u17d3\u0003\u0268\u0134\u0000\u17d1\u17d3\u0005\u0006\u0000\u0000"+
		"\u17d2\u17d0\u0001\u0000\u0000\u0000\u17d2\u17d1\u0001\u0000\u0000\u0000"+
		"\u17d3\u17d4\u0001\u0000\u0000\u0000\u17d4\u17d6\u0005\u046e\u0000\u0000"+
		"\u17d5\u17ce\u0001\u0000\u0000\u0000\u17d5\u17d6\u0001\u0000\u0000\u0000"+
		"\u17d6\u17de\u0001\u0000\u0000\u0000\u17d7\u17d9\u0007\u0014\u0000\u0000"+
		"\u17d8\u17d7\u0001\u0000\u0000\u0000\u17d8\u17d9\u0001\u0000\u0000\u0000"+
		"\u17d9\u17da\u0001\u0000\u0000\u0000\u17da\u17db\u0005\u046d\u0000\u0000"+
		"\u17db\u17dc\u0003\u0268\u0134\u0000\u17dc\u17dd\u0005\u046e\u0000\u0000"+
		"\u17dd\u17df\u0001\u0000\u0000\u0000\u17de\u17d8\u0001\u0000\u0000\u0000"+
		"\u17de\u17df\u0001\u0000\u0000\u0000\u17df\u17e2\u0001\u0000\u0000\u0000"+
		"\u17e0\u17e1\u0005N\u0000\u0000\u17e1\u17e3\u0005\u01d6\u0000\u0000\u17e2"+
		"\u17e0\u0001\u0000\u0000\u0000\u17e2\u17e3\u0001\u0000\u0000\u0000\u17e3"+
		"\u020d\u0001\u0000\u0000\u0000\u17e4\u17e5\u0007W\u0000\u0000\u17e5\u17e8"+
		"\u0003\u0228\u0114\u0000\u17e6\u17e9\u0003\u0248\u0124\u0000\u17e7\u17e9"+
		"\u0005\u047c\u0000\u0000\u17e8\u17e6\u0001\u0000\u0000\u0000\u17e8\u17e7"+
		"\u0001\u0000\u0000\u0000\u17e8\u17e9\u0001\u0000\u0000\u0000\u17e9\u020f"+
		"\u0001\u0000\u0000\u0000\u17ea\u17ee\u0007W\u0000\u0000\u17eb\u17ec\u0007"+
		"X\u0000\u0000\u17ec\u17ed\u0005\u0464\u0000\u0000\u17ed\u17ef\u0007Y\u0000"+
		"\u0000\u17ee\u17eb\u0001\u0000\u0000\u0000\u17ee\u17ef\u0001\u0000\u0000"+
		"\u0000\u17ef\u17f0\u0001\u0000\u0000\u0000\u17f0\u17f1\u0003\u0224\u0112"+
		"\u0000\u17f1\u0211\u0001\u0000\u0000\u0000\u17f2\u17f3\u0005\u01bc\u0000"+
		"\u0000\u17f3\u17f4\u0005\u047c\u0000\u0000\u17f4\u0213\u0001\u0000\u0000"+
		"\u0000\u17f5\u17f6\u0005\u00ba\u0000\u0000\u17f6\u17f7\u0003\u0248\u0124"+
		"\u0000\u17f7\u0215\u0001\u0000\u0000\u0000\u17f8\u1800\u0005\u009c\u0000"+
		"\u0000\u17f9\u17fb\u0005\u00a2\u0000\u0000\u17fa\u17fc\u0005\u029d\u0000"+
		"\u0000\u17fb\u17fa\u0001\u0000\u0000\u0000\u17fb\u17fc\u0001\u0000\u0000"+
		"\u0000\u17fc\u17fd\u0001\u0000\u0000\u0000\u17fd\u1801\u0003\u0252\u0129"+
		"\u0000\u17fe\u1801\u0005\u0484\u0000\u0000\u17ff\u1801\u0005\u0485\u0000"+
		"\u0000\u1800\u17f9\u0001\u0000\u0000\u0000\u1800\u17fe\u0001\u0000\u0000"+
		"\u0000\u1800\u17ff\u0001\u0000\u0000\u0000\u1801\u180b\u0001\u0000\u0000"+
		"\u0000\u1802\u1803\u0005\u0099\u0000\u0000\u1803\u1808\u0003\u021a\u010d"+
		"\u0000\u1804\u1805\u0005\u046f\u0000\u0000\u1805\u1807\u0003\u021a\u010d"+
		"\u0000\u1806\u1804\u0001\u0000\u0000\u0000\u1807\u180a\u0001\u0000\u0000"+
		"\u0000\u1808\u1806\u0001\u0000\u0000\u0000\u1808\u1809\u0001\u0000\u0000"+
		"\u0000\u1809\u180c\u0001\u0000\u0000\u0000\u180a\u1808\u0001\u0000\u0000"+
		"\u0000\u180b\u1802\u0001\u0000\u0000\u0000\u180b\u180c\u0001\u0000\u0000"+
		"\u0000\u180c\u0217\u0001\u0000\u0000\u0000\u180d\u1815\u0005\u008f\u0000"+
		"\u0000\u180e\u1810\u0005\u00a2\u0000\u0000\u180f\u1811\u0005\u029d\u0000"+
		"\u0000\u1810\u180f\u0001\u0000\u0000\u0000\u1810\u1811\u0001\u0000\u0000"+
		"\u0000\u1811\u1812\u0001\u0000\u0000\u0000\u1812\u1816\u0003\u0252\u0129"+
		"\u0000\u1813\u1816\u0005\u0484\u0000\u0000\u1814\u1816\u0005\u0485\u0000"+
		"\u0000\u1815\u180e\u0001\u0000\u0000\u0000\u1815\u1813\u0001\u0000\u0000"+
		"\u0000\u1815\u1814\u0001\u0000\u0000\u0000\u1815\u1816\u0001\u0000\u0000"+
		"\u0000\u1816\u1820\u0001\u0000\u0000\u0000\u1817\u1818\u0005\u0099\u0000"+
		"\u0000\u1818\u181d\u0003\u021a\u010d\u0000\u1819\u181a\u0005\u046f\u0000"+
		"\u0000\u181a\u181c\u0003\u021a\u010d\u0000\u181b\u1819\u0001\u0000\u0000"+
		"\u0000\u181c\u181f\u0001\u0000\u0000\u0000\u181d\u181b\u0001\u0000\u0000"+
		"\u0000\u181d\u181e\u0001\u0000\u0000\u0000\u181e\u1821\u0001\u0000\u0000"+
		"\u0000\u181f\u181d\u0001\u0000\u0000\u0000\u1820\u1817\u0001\u0000\u0000"+
		"\u0000\u1820\u1821\u0001\u0000\u0000\u0000\u1821\u0219\u0001\u0000\u0000"+
		"\u0000\u1822\u1823\u0007Z\u0000\u0000\u1823\u1828\u0005\u0464\u0000\u0000"+
		"\u1824\u1829\u0003\u0252\u0129\u0000\u1825\u1829\u0005\u047d\u0000\u0000"+
		"\u1826\u1829\u0003\u0236\u011b\u0000\u1827\u1829\u0003\u024a\u0125\u0000"+
		"\u1828\u1824\u0001\u0000\u0000\u0000\u1828\u1825\u0001\u0000\u0000\u0000"+
		"\u1828\u1826\u0001\u0000\u0000\u0000\u1828\u1827\u0001\u0000\u0000\u0000"+
		"\u1829\u021b\u0001\u0000\u0000\u0000\u182a\u182c\u0005\u00c0\u0000\u0000"+
		"\u182b\u182d\u0005\u023b\u0000\u0000\u182c\u182b\u0001\u0000\u0000\u0000"+
		"\u182c\u182d\u0001\u0000\u0000\u0000\u182d\u182e\u0001\u0000\u0000\u0000"+
		"\u182e\u1833\u00032\u0019\u0000\u182f\u1830\u0005\u046f\u0000\u0000\u1830"+
		"\u1832\u00032\u0019\u0000\u1831\u182f\u0001\u0000\u0000\u0000\u1832\u1835"+
		"\u0001\u0000\u0000\u0000\u1833\u1831\u0001\u0000\u0000\u0000\u1833\u1834"+
		"\u0001\u0000\u0000\u0000\u1834\u021d\u0001\u0000\u0000\u0000\u1835\u1833"+
		"\u0001\u0000\u0000\u0000\u1836\u1837\u0005\u00ac\u0000\u0000\u1837\u1839"+
		"\u0003\u0228\u0114\u0000\u1838\u183a\u0003\u00e6s\u0000\u1839\u1838\u0001"+
		"\u0000\u0000\u0000\u1839\u183a\u0001\u0000\u0000\u0000\u183a\u183c\u0001"+
		"\u0000\u0000\u0000\u183b\u183d\u0003\u0126\u0093\u0000\u183c\u183b\u0001"+
		"\u0000\u0000\u0000\u183c\u183d\u0001\u0000\u0000\u0000\u183d\u021f\u0001"+
		"\u0000\u0000\u0000\u183e\u1840\u0005G\u0000\u0000\u183f\u1841\u0007[\u0000"+
		"\u0000\u1840\u183f\u0001\u0000\u0000\u0000\u1840\u1841\u0001\u0000\u0000"+
		"\u0000\u1841\u1842\u0001\u0000\u0000\u0000\u1842\u1862\u00050\u0000\u0000"+
		"\u1843\u1844\u0003\u01ec\u00f6\u0000\u1844\u1845\u0005\u0464\u0000\u0000"+
		"\u1845\u184d\u0007\\\u0000\u0000\u1846\u1847\u0005\u046f\u0000\u0000\u1847"+
		"\u1848\u0003\u01ec\u00f6\u0000\u1848\u1849\u0005\u0464\u0000\u0000\u1849"+
		"\u184a\u0007\\\u0000\u0000\u184a\u184c\u0001\u0000\u0000\u0000\u184b\u1846"+
		"\u0001\u0000\u0000\u0000\u184c\u184f\u0001\u0000\u0000\u0000\u184d\u184b"+
		"\u0001\u0000\u0000\u0000\u184d\u184e\u0001\u0000\u0000\u0000\u184e\u1863"+
		"\u0001\u0000\u0000\u0000\u184f\u184d\u0001\u0000\u0000\u0000\u1850\u1853"+
		"\u0005\u001d\u0000\u0000\u1851\u1854\u0003\u024e\u0127\u0000\u1852\u1854"+
		"\u0003\u01ec\u00f6\u0000\u1853\u1851\u0001\u0000\u0000\u0000\u1853\u1852"+
		"\u0001\u0000\u0000\u0000\u1854\u1855\u0001\u0000\u0000\u0000\u1855\u1856"+
		"\u0003\u01ec\u00f6\u0000\u1856\u1857\u0005\u0464\u0000\u0000\u1857\u185f"+
		"\u0003\u0222\u0111\u0000\u1858\u1859\u0005\u046f\u0000\u0000\u1859\u185a"+
		"\u0003\u01ec\u00f6\u0000\u185a\u185b\u0005\u0464\u0000\u0000\u185b\u185c"+
		"\u0003\u0222\u0111\u0000\u185c\u185e\u0001\u0000\u0000\u0000\u185d\u1858"+
		"\u0001\u0000\u0000\u0000\u185e\u1861\u0001\u0000\u0000\u0000\u185f\u185d"+
		"\u0001\u0000\u0000\u0000\u185f\u1860\u0001\u0000\u0000\u0000\u1860\u1863"+
		"\u0001\u0000\u0000\u0000\u1861\u185f\u0001\u0000\u0000\u0000\u1862\u1843"+
		"\u0001\u0000\u0000\u0000\u1862\u1850\u0001\u0000\u0000\u0000\u1863\u0221"+
		"\u0001\u0000\u0000\u0000\u1864\u1865\u0007]\u0000\u0000\u1865\u0223\u0001"+
		"\u0000\u0000\u0000\u1866\u186c\u0003\u00c8d\u0000\u1867\u186c\u0003\u00ba"+
		"]\u0000\u1868\u186c\u0003\u00c0`\u0000\u1869\u186c\u0003\u00c6c\u0000"+
		"\u186a\u186c\u0003\u00cae\u0000\u186b\u1866\u0001\u0000\u0000\u0000\u186b"+
		"\u1867\u0001\u0000\u0000\u0000\u186b\u1868\u0001\u0000\u0000\u0000\u186b"+
		"\u1869\u0001\u0000\u0000\u0000\u186b\u186a\u0001\u0000\u0000\u0000\u186c"+
		"\u1871\u0001\u0000\u0000\u0000\u186d\u186e\u0005A\u0000\u0000\u186e\u186f"+
		"\u0005\u0178\u0000\u0000\u186f\u1871\u0003\u0248\u0124\u0000\u1870\u186b"+
		"\u0001\u0000\u0000\u0000\u1870\u186d\u0001\u0000\u0000\u0000\u1871\u0225"+
		"\u0001\u0000\u0000\u0000\u1872\u1876\u0003\u0248\u0124\u0000\u1873\u1877"+
		"\u0005\u0483\u0000\u0000\u1874\u1875\u0005\u046c\u0000\u0000\u1875\u1877"+
		"\u0003\u0248\u0124\u0000\u1876\u1873\u0001\u0000\u0000\u0000\u1876\u1874"+
		"\u0001\u0000\u0000\u0000\u1876\u1877\u0001\u0000\u0000\u0000\u1877\u0227"+
		"\u0001\u0000\u0000\u0000\u1878\u1879\u0003\u0226\u0113\u0000\u1879\u0229"+
		"\u0001\u0000\u0000\u0000\u187a\u187d\u0003\u0234\u011a\u0000\u187b\u187d"+
		"\u0003\u0248\u0124\u0000\u187c\u187a\u0001\u0000\u0000\u0000\u187c\u187b"+
		"\u0001\u0000\u0000\u0000\u187d\u022b\u0001\u0000\u0000\u0000\u187e\u1883"+
		"\u0003\u0248\u0124\u0000\u187f\u1881\u0003\u024c\u0126\u0000\u1880\u1882"+
		"\u0003\u024c\u0126\u0000\u1881\u1880\u0001\u0000\u0000\u0000\u1881\u1882"+
		"\u0001\u0000\u0000\u0000\u1882\u1884\u0001\u0000\u0000\u0000\u1883\u187f"+
		"\u0001\u0000\u0000\u0000\u1883\u1884\u0001\u0000\u0000\u0000\u1884\u188d"+
		"\u0001\u0000\u0000\u0000\u1885\u1887\t\u0000\u0000\u0000\u1886\u1885\u0001"+
		"\u0000\u0000\u0000\u1886\u1887\u0001\u0000\u0000\u0000\u1887\u1888\u0001"+
		"\u0000\u0000\u0000\u1888\u188a\u0003\u024c\u0126\u0000\u1889\u188b\u0003"+
		"\u024c\u0126\u0000\u188a\u1889\u0001\u0000\u0000\u0000\u188a\u188b\u0001"+
		"\u0000\u0000\u0000\u188b\u188d\u0001\u0000\u0000\u0000\u188c\u187e\u0001"+
		"\u0000\u0000\u0000\u188c\u1886\u0001\u0000\u0000\u0000\u188d\u022d\u0001"+
		"\u0000\u0000\u0000\u188e\u1891\u0003\u0248\u0124\u0000\u188f\u1891\u0005"+
		"\u047c\u0000\u0000\u1890\u188e\u0001\u0000\u0000\u0000\u1890\u188f\u0001"+
		"\u0000\u0000\u0000\u1891\u1896\u0001\u0000\u0000\u0000\u1892\u1893\u0005"+
		"\u046d\u0000\u0000\u1893\u1894\u0003\u024e\u0127\u0000\u1894\u1895\u0005"+
		"\u046e\u0000\u0000\u1895\u1897\u0001\u0000\u0000\u0000\u1896\u1892\u0001"+
		"\u0000\u0000\u0000\u1896\u1897\u0001\u0000\u0000\u0000\u1897\u189a\u0001"+
		"\u0000\u0000\u0000\u1898\u189a\u0003\u02b0\u0158\u0000\u1899\u1890\u0001"+
		"\u0000\u0000\u0000\u1899\u1898\u0001\u0000\u0000\u0000\u189a\u189c\u0001"+
		"\u0000\u0000\u0000\u189b\u189d\u00070\u0000\u0000\u189c\u189b\u0001\u0000"+
		"\u0000\u0000\u189c\u189d\u0001\u0000\u0000\u0000\u189d\u022f\u0001\u0000"+
		"\u0000\u0000\u189e\u18a3\u0005\u047c\u0000\u0000\u189f\u18a3\u0005\u0484"+
		"\u0000\u0000\u18a0\u18a3\u0005\u02b9\u0000\u0000\u18a1\u18a3\u0003\u02ce"+
		"\u0167\u0000\u18a2\u189e\u0001\u0000\u0000\u0000\u18a2\u189f\u0001\u0000"+
		"\u0000\u0000\u18a2\u18a0\u0001\u0000\u0000\u0000\u18a2\u18a1\u0001\u0000"+
		"\u0000\u0000\u18a3\u0231\u0001\u0000\u0000\u0000\u18a4\u18a5\u0007^\u0000"+
		"\u0000\u18a5\u0233\u0001\u0000\u0000\u0000\u18a6\u18ac\u0003\u0230\u0118"+
		"\u0000\u18a7\u18a8\u0003\u0230\u0118\u0000\u18a8\u18a9\u0003\u0232\u0119"+
		"\u0000\u18a9\u18ac\u0001\u0000\u0000\u0000\u18aa\u18ac\u0003>\u001f\u0000"+
		"\u18ab\u18a6\u0001\u0000\u0000\u0000\u18ab\u18a7\u0001\u0000\u0000\u0000"+
		"\u18ab\u18aa\u0001\u0000\u0000\u0000\u18ac\u0235\u0001\u0000\u0000\u0000"+
		"\u18ad\u18ae\u0007_\u0000\u0000\u18ae\u0237\u0001\u0000\u0000\u0000\u18af"+
		"\u18b4\u0005\u00e2\u0000\u0000\u18b0\u18b4\u0003\u02c4\u0162\u0000\u18b1"+
		"\u18b4\u0005\u047c\u0000\u0000\u18b2\u18b4\u0005\u0479\u0000\u0000\u18b3"+
		"\u18af\u0001\u0000\u0000\u0000\u18b3\u18b0\u0001\u0000\u0000\u0000\u18b3"+
		"\u18b1\u0001\u0000\u0000\u0000\u18b3\u18b2\u0001\u0000\u0000\u0000\u18b4"+
		"\u0239\u0001\u0000\u0000\u0000\u18b5\u18b8\u0003\u0248\u0124\u0000\u18b6"+
		"\u18b8\u0005\u047c\u0000\u0000\u18b7\u18b5\u0001\u0000\u0000\u0000\u18b7"+
		"\u18b6\u0001\u0000\u0000\u0000\u18b8\u023b\u0001\u0000\u0000\u0000\u18b9"+
		"\u18bd\u0003\u023e\u011f\u0000\u18ba\u18bd\u0005\u0484\u0000\u0000\u18bb"+
		"\u18bd\u0005\u047c\u0000\u0000\u18bc\u18b9\u0001\u0000\u0000\u0000\u18bc"+
		"\u18ba\u0001\u0000\u0000\u0000\u18bc\u18bb\u0001\u0000\u0000\u0000\u18bd"+
		"\u023d\u0001\u0000\u0000\u0000\u18be\u18bf\u0007`\u0000\u0000\u18bf\u023f"+
		"\u0001\u0000\u0000\u0000\u18c0\u18c1\u0003\u024e\u0127\u0000\u18c1\u18c2"+
		"\u0005\u0461\u0000\u0000\u18c2\u18c3\u0003\u024e\u0127\u0000\u18c3\u18c4"+
		"\u0005\u0461\u0000\u0000\u18c4\u18c5\u0003\u024e\u0127\u0000\u18c5\u18c6"+
		"\u0005\u0461\u0000\u0000\u18c6\u18c7\u0003\u024e\u0127\u0000\u18c7\u18c8"+
		"\u0005\u0461\u0000\u0000\u18c8\u18ce\u0003\u024e\u0127\u0000\u18c9\u18ca"+
		"\u0005\u0478\u0000\u0000\u18ca\u18cb\u0003\u024e\u0127\u0000\u18cb\u18cc"+
		"\u0005\u0461\u0000\u0000\u18cc\u18cd\u0003\u024e\u0127\u0000\u18cd\u18cf"+
		"\u0001\u0000\u0000\u0000\u18ce\u18c9\u0001\u0000\u0000\u0000\u18cf\u18d0"+
		"\u0001\u0000\u0000\u0000\u18d0\u18ce\u0001\u0000\u0000\u0000\u18d0\u18d1"+
		"\u0001\u0000\u0000\u0000\u18d1\u0241\u0001\u0000\u0000\u0000\u18d2\u18d9"+
		"\u0003\u0244\u0122\u0000\u18d3\u18d4\u0005\u046f\u0000\u0000\u18d4\u18d7"+
		"\u0003\u0244\u0122\u0000\u18d5\u18d6\u0005\u046f\u0000\u0000\u18d6\u18d8"+
		"\u0003\u024e\u0127\u0000\u18d7\u18d5\u0001\u0000\u0000\u0000\u18d7\u18d8"+
		"\u0001\u0000\u0000\u0000\u18d8\u18da\u0001\u0000\u0000\u0000\u18d9\u18d3"+
		"\u0001\u0000\u0000\u0000\u18d9\u18da\u0001\u0000\u0000\u0000\u18da\u0243"+
		"\u0001\u0000\u0000\u0000\u18db\u18e3\u0005\u047c\u0000\u0000\u18dc\u18e3"+
		"\u0005\u0481\u0000\u0000\u18dd\u18df\u0005\u047e\u0000\u0000\u18de\u18dd"+
		"\u0001\u0000\u0000\u0000\u18df\u18e0\u0001\u0000\u0000\u0000\u18e0\u18de"+
		"\u0001\u0000\u0000\u0000\u18e0\u18e1\u0001\u0000\u0000\u0000\u18e1\u18e3"+
		"\u0001\u0000\u0000\u0000\u18e2\u18db\u0001\u0000\u0000\u0000\u18e2\u18dc"+
		"\u0001\u0000\u0000\u0000\u18e2\u18de\u0001\u0000\u0000\u0000\u18e3\u0245"+
		"\u0001\u0000\u0000\u0000\u18e4\u18e7\u0003\u0248\u0124\u0000\u18e5\u18e7"+
		"\u0005\u047c\u0000\u0000\u18e6\u18e4\u0001\u0000\u0000\u0000\u18e6\u18e5"+
		"\u0001\u0000\u0000\u0000\u18e7\u0247\u0001\u0000\u0000\u0000\u18e8\u18ec"+
		"\u0003\u024a\u0125\u0000\u18e9\u18ec\u0005\u0479\u0000\u0000\u18ea\u18ec"+
		"\u0005\u047c\u0000\u0000\u18eb\u18e8\u0001\u0000\u0000\u0000\u18eb\u18e9"+
		"\u0001\u0000\u0000\u0000\u18eb\u18ea\u0001\u0000\u0000\u0000\u18ec\u0249"+
		"\u0001\u0000\u0000\u0000\u18ed\u18f7\u0005\u0484\u0000\u0000\u18ee\u18f7"+
		"\u0003\u02c4\u0162\u0000\u18ef\u18f7\u0003\u02c6\u0163\u0000\u18f0\u18f7"+
		"\u0003\u023e\u011f\u0000\u18f1\u18f7\u0003\u02c8\u0164\u0000\u18f2\u18f7"+
		"\u0003\u02ca\u0165\u0000\u18f3\u18f7\u0003\u02cc\u0166\u0000\u18f4\u18f7"+
		"\u0003\u02ce\u0167\u0000\u18f5\u18f7\u0003\u02a8\u0154\u0000\u18f6\u18ed"+
		"\u0001\u0000\u0000\u0000\u18f6\u18ee\u0001\u0000\u0000\u0000\u18f6\u18ef"+
		"\u0001\u0000\u0000\u0000\u18f6\u18f0\u0001\u0000\u0000\u0000\u18f6\u18f1"+
		"\u0001\u0000\u0000\u0000\u18f6\u18f2\u0001\u0000\u0000\u0000\u18f6\u18f3"+
		"\u0001\u0000\u0000\u0000\u18f6\u18f4\u0001\u0000\u0000\u0000\u18f6\u18f5"+
		"\u0001\u0000\u0000\u0000\u18f7\u024b\u0001\u0000\u0000\u0000\u18f8\u18fc"+
		"\u0005\u0483\u0000\u0000\u18f9\u18fa\u0005\u046c\u0000\u0000\u18fa\u18fc"+
		"\u0003\u0248\u0124\u0000\u18fb\u18f8\u0001\u0000\u0000\u0000\u18fb\u18f9"+
		"\u0001\u0000\u0000\u0000\u18fc\u024d\u0001\u0000\u0000\u0000\u18fd\u18fe"+
		"\u0007a\u0000\u0000\u18fe\u024f\u0001\u0000\u0000\u0000\u18ff\u1902\u0005"+
		"\u047a\u0000\u0000\u1900\u1902\u0003\u024e\u0127\u0000\u1901\u18ff\u0001"+
		"\u0000\u0000\u0000\u1901\u1900\u0001\u0000\u0000\u0000\u1902\u0251\u0001"+
		"\u0000\u0000\u0000\u1903\u1905\u0005\u0482\u0000\u0000\u1904\u1903\u0001"+
		"\u0000\u0000\u0000\u1904\u1905\u0001\u0000\u0000\u0000\u1905\u1906\u0001"+
		"\u0000\u0000\u0000\u1906\u1909\u0005\u047c\u0000\u0000\u1907\u1909\u0005"+
		"\u047b\u0000\u0000\u1908\u1904\u0001\u0000\u0000\u0000\u1908\u1907\u0001"+
		"\u0000\u0000\u0000\u1909\u190b\u0001\u0000\u0000\u0000\u190a\u190c\u0005"+
		"\u047c\u0000\u0000\u190b\u190a\u0001\u0000\u0000\u0000\u190c\u190d\u0001"+
		"\u0000\u0000\u0000\u190d\u190b\u0001\u0000\u0000\u0000\u190d\u190e\u0001"+
		"\u0000\u0000\u0000\u190e\u191b\u0001\u0000\u0000\u0000\u190f\u1911\u0005"+
		"\u0482\u0000\u0000\u1910\u190f\u0001\u0000\u0000\u0000\u1910\u1911\u0001"+
		"\u0000\u0000\u0000\u1911\u1912\u0001\u0000\u0000\u0000\u1912\u1915\u0005"+
		"\u047c\u0000\u0000\u1913\u1915\u0005\u047b\u0000\u0000\u1914\u1910\u0001"+
		"\u0000\u0000\u0000\u1914\u1913\u0001\u0000\u0000\u0000\u1915\u1918\u0001"+
		"\u0000\u0000\u0000\u1916\u1917\u0005\u001b\u0000\u0000\u1917\u1919\u0003"+
		"\u023a\u011d\u0000\u1918\u1916\u0001\u0000\u0000\u0000\u1918\u1919\u0001"+
		"\u0000\u0000\u0000\u1919\u191b\u0001\u0000\u0000\u0000\u191a\u1908\u0001"+
		"\u0000\u0000\u0000\u191a\u1914\u0001\u0000\u0000\u0000\u191b\u0253\u0001"+
		"\u0000\u0000\u0000\u191c\u191d\u0007b\u0000\u0000\u191d\u0255\u0001\u0000"+
		"\u0000\u0000\u191e\u1920\u0005\u0482\u0000\u0000\u191f\u191e\u0001\u0000"+
		"\u0000\u0000\u191f\u1920\u0001\u0000\u0000\u0000\u1920\u1921\u0001\u0000"+
		"\u0000\u0000\u1921\u1922\u0005\u047e\u0000\u0000\u1922\u0257\u0001\u0000"+
		"\u0000\u0000\u1923\u1925\u0005r\u0000\u0000\u1924\u1923\u0001\u0000\u0000"+
		"\u0000\u1924\u1925\u0001\u0000\u0000\u0000\u1925\u1926\u0001\u0000\u0000"+
		"\u0000\u1926\u1927\u0007c\u0000\u0000\u1927\u0259\u0001\u0000\u0000\u0000"+
		"\u1928\u1935\u0003\u0252\u0129\u0000\u1929\u1935\u0003\u024e\u0127\u0000"+
		"\u192a\u192b\u0005\u0461\u0000\u0000\u192b\u1935\u0003\u024e\u0127\u0000"+
		"\u192c\u1935\u0003\u0256\u012b\u0000\u192d\u1935\u0003\u0254\u012a\u0000"+
		"\u192e\u1935\u0005\u047f\u0000\u0000\u192f\u1935\u0005\u0481\u0000\u0000"+
		"\u1930\u1932\u0005r\u0000\u0000\u1931\u1930\u0001\u0000\u0000\u0000\u1931"+
		"\u1932\u0001\u0000\u0000\u0000\u1932\u1933\u0001\u0000\u0000\u0000\u1933"+
		"\u1935\u0007c\u0000\u0000\u1934\u1928\u0001\u0000\u0000\u0000\u1934\u1929"+
		"\u0001\u0000\u0000\u0000\u1934\u192a\u0001\u0000\u0000\u0000\u1934\u192c"+
		"\u0001\u0000\u0000\u0000\u1934\u192d\u0001\u0000\u0000\u0000\u1934\u192e"+
		"\u0001\u0000\u0000\u0000\u1934\u192f\u0001\u0000\u0000\u0000\u1934\u1931"+
		"\u0001\u0000\u0000\u0000\u1935\u025b\u0001\u0000\u0000\u0000\u1936\u1938"+
		"\u0007d\u0000\u0000\u1937\u1939\u0005\u00ee\u0000\u0000\u1938\u1937\u0001"+
		"\u0000\u0000\u0000\u1938\u1939\u0001\u0000\u0000\u0000\u1939\u193b\u0001"+
		"\u0000\u0000\u0000\u193a\u193c\u0003\u0262\u0131\u0000\u193b\u193a\u0001"+
		"\u0000\u0000\u0000\u193b\u193c\u0001\u0000\u0000\u0000\u193c\u193e\u0001"+
		"\u0000\u0000\u0000\u193d\u193f\u0005\u00e2\u0000\u0000\u193e\u193d\u0001"+
		"\u0000\u0000\u0000\u193e\u193f\u0001\u0000\u0000\u0000\u193f\u1943\u0001"+
		"\u0000\u0000\u0000\u1940\u1941\u0003<\u001e\u0000\u1941\u1942\u0003\u0238"+
		"\u011c\u0000\u1942\u1944\u0001\u0000\u0000\u0000\u1943\u1940\u0001\u0000"+
		"\u0000\u0000\u1943\u1944\u0001\u0000\u0000\u0000\u1944\u1948\u0001\u0000"+
		"\u0000\u0000\u1945\u1946\u0005\u001b\u0000\u0000\u1946\u1949\u0003\u023a"+
		"\u011d\u0000\u1947\u1949\u0005\u00e2\u0000\u0000\u1948\u1945\u0001\u0000"+
		"\u0000\u0000\u1948\u1947\u0001\u0000\u0000\u0000\u1948\u1949\u0001\u0000"+
		"\u0000\u0000\u1949\u19b5\u0001\u0000\u0000\u0000\u194a\u194b\u0005\u00e1"+
		"\u0000\u0000\u194b\u194c\u0007e\u0000\u0000\u194c\u194e\u0005\u00ee\u0000"+
		"\u0000\u194d\u194f\u0003\u0262\u0131\u0000\u194e\u194d\u0001\u0000\u0000"+
		"\u0000\u194e\u194f\u0001\u0000\u0000\u0000\u194f\u1951\u0001\u0000\u0000"+
		"\u0000\u1950\u1952\u0005\u00e2\u0000\u0000\u1951\u1950\u0001\u0000\u0000"+
		"\u0000\u1951\u1952\u0001\u0000\u0000\u0000\u1952\u19b5\u0001\u0000\u0000"+
		"\u0000\u1953\u1954\u0005\u00e1\u0000\u0000\u1954\u1956\u0007f\u0000\u0000"+
		"\u1955\u1957\u0003\u0262\u0131\u0000\u1956\u1955\u0001\u0000\u0000\u0000"+
		"\u1956\u1957\u0001\u0000\u0000\u0000\u1957\u1959\u0001\u0000\u0000\u0000"+
		"\u1958\u195a\u0005\u00e2\u0000\u0000\u1959\u1958\u0001\u0000\u0000\u0000"+
		"\u1959\u195a\u0001\u0000\u0000\u0000\u195a\u19b5\u0001\u0000\u0000\u0000"+
		"\u195b\u195c\u0005\u0206\u0000\u0000\u195c\u195e\u0005\u00df\u0000\u0000"+
		"\u195d\u195f\u0003\u0262\u0131\u0000\u195e\u195d\u0001\u0000\u0000\u0000"+
		"\u195e\u195f\u0001\u0000\u0000\u0000\u195f\u1961\u0001\u0000\u0000\u0000"+
		"\u1960\u1962\u0005\u00e2\u0000\u0000\u1961\u1960\u0001\u0000\u0000\u0000"+
		"\u1961\u1962\u0001\u0000\u0000\u0000\u1962\u19b5\u0001\u0000\u0000\u0000"+
		"\u1963\u1965\u0007g\u0000\u0000\u1964\u1966\u0003\u0262\u0131\u0000\u1965"+
		"\u1964\u0001\u0000\u0000\u0000\u1965\u1966\u0001\u0000\u0000\u0000\u1966"+
		"\u196a\u0001\u0000\u0000\u0000\u1967\u1969\u0007h\u0000\u0000\u1968\u1967"+
		"\u0001\u0000\u0000\u0000\u1969\u196c\u0001\u0000\u0000\u0000\u196a\u1968"+
		"\u0001\u0000\u0000\u0000\u196a\u196b\u0001\u0000\u0000\u0000\u196b\u19b5"+
		"\u0001\u0000\u0000\u0000\u196c\u196a\u0001\u0000\u0000\u0000\u196d\u196f"+
		"\u0005\u00d0\u0000\u0000\u196e\u1970\u0003\u0264\u0132\u0000\u196f\u196e"+
		"\u0001\u0000\u0000\u0000\u196f\u1970\u0001\u0000\u0000\u0000\u1970\u1974"+
		"\u0001\u0000\u0000\u0000\u1971\u1973\u0007h\u0000\u0000\u1972\u1971\u0001"+
		"\u0000\u0000\u0000\u1973\u1976\u0001\u0000\u0000\u0000\u1974\u1972\u0001"+
		"\u0000\u0000\u0000\u1974\u1975\u0001\u0000\u0000\u0000\u1975\u19b5\u0001"+
		"\u0000\u0000\u0000\u1976\u1974\u0001\u0000\u0000\u0000\u1977\u1979\u0005"+
		"\u00d1\u0000\u0000\u1978\u197a\u0005\u00d2\u0000\u0000\u1979\u1978\u0001"+
		"\u0000\u0000\u0000\u1979\u197a\u0001\u0000\u0000\u0000\u197a\u197c\u0001"+
		"\u0000\u0000\u0000\u197b\u197d\u0003\u0264\u0132\u0000\u197c\u197b\u0001"+
		"\u0000\u0000\u0000\u197c\u197d\u0001\u0000\u0000\u0000\u197d\u1981\u0001"+
		"\u0000\u0000\u0000\u197e\u1980\u0007h\u0000\u0000\u197f\u197e\u0001\u0000"+
		"\u0000\u0000\u1980\u1983\u0001\u0000\u0000\u0000\u1981\u197f\u0001\u0000"+
		"\u0000\u0000\u1981\u1982\u0001\u0000\u0000\u0000\u1982\u19b5\u0001\u0000"+
		"\u0000\u0000\u1983\u1981\u0001\u0000\u0000\u0000\u1984\u1986\u0007i\u0000"+
		"\u0000\u1985\u1987\u0003\u0266\u0133\u0000\u1986\u1985\u0001\u0000\u0000"+
		"\u0000\u1986\u1987\u0001\u0000\u0000\u0000\u1987\u198b\u0001\u0000\u0000"+
		"\u0000\u1988\u198a\u0007h\u0000\u0000\u1989\u1988\u0001\u0000\u0000\u0000"+
		"\u198a\u198d\u0001\u0000\u0000\u0000\u198b\u1989\u0001\u0000\u0000\u0000"+
		"\u198b\u198c\u0001\u0000\u0000\u0000\u198c\u19b5\u0001\u0000\u0000\u0000"+
		"\u198d\u198b\u0001\u0000\u0000\u0000\u198e\u19b5\u0007j\u0000\u0000\u198f"+
		"\u1991\u0007k\u0000\u0000\u1990\u1992\u0003\u0262\u0131\u0000\u1991\u1990"+
		"\u0001\u0000\u0000\u0000\u1991\u1992\u0001\u0000\u0000\u0000\u1992\u19b5"+
		"\u0001\u0000\u0000\u0000\u1993\u1994\u0007l\u0000\u0000\u1994\u1996\u0003"+
		"\u025e\u012f\u0000\u1995\u1997\u0005\u00e2\u0000\u0000\u1996\u1995\u0001"+
		"\u0000\u0000\u0000\u1996\u1997\u0001\u0000\u0000\u0000\u1997\u199b\u0001"+
		"\u0000\u0000\u0000\u1998\u1999\u0003<\u001e\u0000\u1999\u199a\u0003\u0238"+
		"\u011c\u0000\u199a\u199c\u0001\u0000\u0000\u0000\u199b\u1998\u0001\u0000"+
		"\u0000\u0000\u199b\u199c\u0001\u0000\u0000\u0000\u199c\u19b5\u0001\u0000"+
		"\u0000\u0000\u199d\u19a0\u0007m\u0000\u0000\u199e\u199f\u0005\u03f4\u0000"+
		"\u0000\u199f\u19a1\u0003\u024e\u0127\u0000\u19a0\u199e\u0001\u0000\u0000"+
		"\u0000\u19a0\u19a1\u0001\u0000\u0000\u0000\u19a1\u19b5\u0001\u0000\u0000"+
		"\u0000\u19a2\u19a4\u0005\u00e7\u0000\u0000\u19a3\u19a5\u0005\u00df\u0000"+
		"\u0000\u19a4\u19a3\u0001\u0000\u0000\u0000\u19a4\u19a5\u0001\u0000\u0000"+
		"\u0000\u19a5\u19a7\u0001\u0000\u0000\u0000\u19a6\u19a8\u0005\u00e2\u0000"+
		"\u0000\u19a7\u19a6\u0001\u0000\u0000\u0000\u19a7\u19a8\u0001\u0000\u0000"+
		"\u0000\u19a8\u19ac\u0001\u0000\u0000\u0000\u19a9\u19aa\u0003<\u001e\u0000"+
		"\u19aa\u19ab\u0003\u0238\u011c\u0000\u19ab\u19ad\u0001\u0000\u0000\u0000"+
		"\u19ac\u19a9\u0001\u0000\u0000\u0000\u19ac\u19ad\u0001\u0000\u0000\u0000"+
		"\u19ad\u19b0\u0001\u0000\u0000\u0000\u19ae\u19af\u0005\u001b\u0000\u0000"+
		"\u19af\u19b1\u0003\u023a\u011d\u0000\u19b0\u19ae\u0001\u0000\u0000\u0000"+
		"\u19b0\u19b1\u0001\u0000\u0000\u0000\u19b1\u19b5\u0001\u0000\u0000\u0000"+
		"\u19b2\u19b3\u0005\u00e7\u0000\u0000\u19b3\u19b5\u0005\u00e3\u0000\u0000"+
		"\u19b4\u1936\u0001\u0000\u0000\u0000\u19b4\u194a\u0001\u0000\u0000\u0000"+
		"\u19b4\u1953\u0001\u0000\u0000\u0000\u19b4\u195b\u0001\u0000\u0000\u0000"+
		"\u19b4\u1963\u0001\u0000\u0000\u0000\u19b4\u196d\u0001\u0000\u0000\u0000"+
		"\u19b4\u1977\u0001\u0000\u0000\u0000\u19b4\u1984\u0001\u0000\u0000\u0000"+
		"\u19b4\u198e\u0001\u0000\u0000\u0000\u19b4\u198f\u0001\u0000\u0000\u0000"+
		"\u19b4\u1993\u0001\u0000\u0000\u0000\u19b4\u199d\u0001\u0000\u0000\u0000"+
		"\u19b4\u19a2\u0001\u0000\u0000\u0000\u19b4\u19b2\u0001\u0000\u0000\u0000"+
		"\u19b5\u025d\u0001\u0000\u0000\u0000\u19b6\u19b7\u0005\u046d\u0000\u0000"+
		"\u19b7\u19bc\u0005\u047c\u0000\u0000\u19b8\u19b9\u0005\u046f\u0000\u0000"+
		"\u19b9\u19bb\u0005\u047c\u0000\u0000\u19ba\u19b8\u0001\u0000\u0000\u0000"+
		"\u19bb\u19be\u0001\u0000\u0000\u0000\u19bc\u19ba\u0001\u0000\u0000\u0000"+
		"\u19bc\u19bd\u0001\u0000\u0000\u0000\u19bd\u19bf\u0001\u0000\u0000\u0000"+
		"\u19be\u19bc\u0001\u0000\u0000\u0000\u19bf\u19c0\u0005\u046e\u0000\u0000"+
		"\u19c0\u025f\u0001\u0000\u0000\u0000\u19c1\u19c3\u0007n\u0000\u0000\u19c2"+
		"\u19c4\u0003\u0262\u0131\u0000\u19c3\u19c2\u0001\u0000\u0000\u0000\u19c3"+
		"\u19c4\u0001\u0000\u0000\u0000\u19c4\u19d8\u0001\u0000\u0000\u0000\u19c5"+
		"\u19c7\u0005\u00de\u0000\u0000\u19c6\u19c8\u0003\u0262\u0131\u0000\u19c7"+
		"\u19c6\u0001\u0000\u0000\u0000\u19c7\u19c8\u0001\u0000\u0000\u0000\u19c8"+
		"\u19cc\u0001\u0000\u0000\u0000\u19c9\u19ca\u0003<\u001e\u0000\u19ca\u19cb"+
		"\u0003\u0238\u011c\u0000\u19cb\u19cd\u0001\u0000\u0000\u0000\u19cc\u19c9"+
		"\u0001\u0000\u0000\u0000\u19cc\u19cd\u0001\u0000\u0000\u0000\u19cd\u19d8"+
		"\u0001\u0000\u0000\u0000\u19ce\u19d8\u0007o\u0000\u0000\u19cf\u19d1\u0007"+
		"p\u0000\u0000\u19d0\u19d2\u0003\u0266\u0133\u0000\u19d1\u19d0\u0001\u0000"+
		"\u0000\u0000\u19d1\u19d2\u0001\u0000\u0000\u0000\u19d2\u19d8\u0001\u0000"+
		"\u0000\u0000\u19d3\u19d5\u0007q\u0000\u0000\u19d4\u19d6\u0007r\u0000\u0000"+
		"\u19d5\u19d4\u0001\u0000\u0000\u0000\u19d5\u19d6\u0001\u0000\u0000\u0000"+
		"\u19d6\u19d8\u0001\u0000\u0000\u0000\u19d7\u19c1\u0001\u0000\u0000\u0000"+
		"\u19d7\u19c5\u0001\u0000\u0000\u0000\u19d7\u19ce\u0001\u0000\u0000\u0000"+
		"\u19d7\u19cf\u0001\u0000\u0000\u0000\u19d7\u19d3\u0001\u0000\u0000\u0000"+
		"\u19d8\u19da\u0001\u0000\u0000\u0000\u19d9\u19db\u0005\u000b\u0000\u0000"+
		"\u19da\u19d9\u0001\u0000\u0000\u0000\u19da\u19db\u0001\u0000\u0000\u0000"+
		"\u19db\u0261\u0001\u0000\u0000\u0000\u19dc\u19dd\u0005\u046d\u0000\u0000"+
		"\u19dd\u19de\u0003\u024e\u0127\u0000\u19de\u19df\u0005\u046e\u0000\u0000"+
		"\u19df\u0263\u0001\u0000\u0000\u0000\u19e0\u19e1\u0005\u046d\u0000\u0000"+
		"\u19e1\u19e2\u0003\u024e\u0127\u0000\u19e2\u19e3\u0005\u046f\u0000\u0000"+
		"\u19e3\u19e4\u0003\u024e\u0127\u0000\u19e4\u19e5\u0005\u046e\u0000\u0000"+
		"\u19e5\u0265\u0001\u0000\u0000\u0000\u19e6\u19e7\u0005\u046d\u0000\u0000"+
		"\u19e7\u19ea\u0003\u024e\u0127\u0000\u19e8\u19e9\u0005\u046f\u0000\u0000"+
		"\u19e9\u19eb\u0003\u024e\u0127\u0000\u19ea\u19e8\u0001\u0000\u0000\u0000"+
		"\u19ea\u19eb\u0001\u0000\u0000\u0000\u19eb\u19ec\u0001\u0000\u0000\u0000"+
		"\u19ec\u19ed\u0005\u046e\u0000\u0000\u19ed\u0267\u0001\u0000\u0000\u0000"+
		"\u19ee\u19f3\u0003\u0248\u0124\u0000\u19ef\u19f0\u0005\u046f\u0000\u0000"+
		"\u19f0\u19f2\u0003\u0248\u0124\u0000\u19f1\u19ef\u0001\u0000\u0000\u0000"+
		"\u19f2\u19f5\u0001\u0000\u0000\u0000\u19f3\u19f1\u0001\u0000\u0000\u0000"+
		"\u19f3\u19f4\u0001\u0000\u0000\u0000\u19f4\u0269\u0001\u0000\u0000\u0000"+
		"\u19f5\u19f3\u0001\u0000\u0000\u0000\u19f6\u19fb\u0003\u022c\u0116\u0000"+
		"\u19f7\u19f8\u0005\u046f\u0000\u0000\u19f8\u19fa\u0003\u022c\u0116\u0000"+
		"\u19f9\u19f7\u0001\u0000\u0000\u0000\u19fa\u19fd\u0001\u0000\u0000\u0000"+
		"\u19fb\u19f9\u0001\u0000\u0000\u0000\u19fb\u19fc\u0001\u0000\u0000\u0000"+
		"\u19fc\u026b\u0001\u0000\u0000\u0000\u19fd\u19fb\u0001\u0000\u0000\u0000"+
		"\u19fe\u1a03\u0003\u0228\u0114\u0000\u19ff\u1a00\u0005\u046f\u0000\u0000"+
		"\u1a00\u1a02\u0003\u0228\u0114\u0000\u1a01\u19ff\u0001\u0000\u0000\u0000"+
		"\u1a02\u1a05\u0001\u0000\u0000\u0000\u1a03\u1a01\u0001\u0000\u0000\u0000"+
		"\u1a03\u1a04\u0001\u0000\u0000\u0000\u1a04\u026d\u0001\u0000\u0000\u0000"+
		"\u1a05\u1a03\u0001\u0000\u0000\u0000\u1a06\u1a07\u0005\u046d\u0000\u0000"+
		"\u1a07\u1a0c\u0003\u022e\u0117\u0000\u1a08\u1a09\u0005\u046f\u0000\u0000"+
		"\u1a09\u1a0b\u0003\u022e\u0117\u0000\u1a0a\u1a08\u0001\u0000\u0000\u0000"+
		"\u1a0b\u1a0e\u0001\u0000\u0000\u0000\u1a0c\u1a0a\u0001\u0000\u0000\u0000"+
		"\u1a0c\u1a0d\u0001\u0000\u0000\u0000\u1a0d\u1a0f\u0001\u0000\u0000\u0000"+
		"\u1a0e\u1a0c\u0001\u0000\u0000\u0000\u1a0f\u1a10\u0005\u046e\u0000\u0000"+
		"\u1a10\u026f\u0001\u0000\u0000\u0000\u1a11\u1a16\u0003\u02b0\u0158\u0000"+
		"\u1a12\u1a13\u0005\u046f\u0000\u0000\u1a13\u1a15\u0003\u02b0\u0158\u0000"+
		"\u1a14\u1a12\u0001\u0000\u0000\u0000\u1a15\u1a18\u0001\u0000\u0000\u0000"+
		"\u1a16\u1a14\u0001\u0000\u0000\u0000\u1a16\u1a17\u0001\u0000\u0000\u0000"+
		"\u1a17\u0271\u0001\u0000\u0000\u0000\u1a18\u1a16\u0001\u0000\u0000\u0000"+
		"\u1a19\u1a1e\u0003\u027e\u013f\u0000\u1a1a\u1a1b\u0005\u046f\u0000\u0000"+
		"\u1a1b\u1a1d\u0003\u027e\u013f\u0000\u1a1c\u1a1a\u0001\u0000\u0000\u0000"+
		"\u1a1d\u1a20\u0001\u0000\u0000\u0000\u1a1e\u1a1c\u0001\u0000\u0000\u0000"+
		"\u1a1e\u1a1f\u0001\u0000\u0000\u0000\u1a1f\u0273\u0001\u0000\u0000\u0000"+
		"\u1a20\u1a1e\u0001\u0000\u0000\u0000\u1a21\u1a26\u0003\u025a\u012d\u0000"+
		"\u1a22\u1a23\u0005\u046f\u0000\u0000\u1a23\u1a25\u0003\u025a\u012d\u0000"+
		"\u1a24\u1a22\u0001\u0000\u0000\u0000\u1a25\u1a28\u0001\u0000\u0000\u0000"+
		"\u1a26\u1a24\u0001\u0000\u0000\u0000\u1a26\u1a27\u0001\u0000\u0000\u0000"+
		"\u1a27\u0275\u0001\u0000\u0000\u0000\u1a28\u1a26\u0001\u0000\u0000\u0000"+
		"\u1a29\u1a2e\u0005\u047c\u0000\u0000\u1a2a\u1a2b\u0005\u046f\u0000\u0000"+
		"\u1a2b\u1a2d\u0005\u047c\u0000\u0000\u1a2c\u1a2a\u0001\u0000\u0000\u0000"+
		"\u1a2d\u1a30\u0001\u0000\u0000\u0000\u1a2e\u1a2c\u0001\u0000\u0000\u0000"+
		"\u1a2e\u1a2f\u0001\u0000\u0000\u0000\u1a2f\u0277\u0001\u0000\u0000\u0000"+
		"\u1a30\u1a2e\u0001\u0000\u0000\u0000\u1a31\u1a36\u0005\u0487\u0000\u0000"+
		"\u1a32\u1a33\u0005\u046f\u0000\u0000\u1a33\u1a35\u0005\u0487\u0000\u0000"+
		"\u1a34\u1a32\u0001\u0000\u0000\u0000\u1a35\u1a38\u0001\u0000\u0000\u0000"+
		"\u1a36\u1a34\u0001\u0000\u0000\u0000\u1a36\u1a37\u0001\u0000\u0000\u0000"+
		"\u1a37\u0279\u0001\u0000\u0000\u0000\u1a38\u1a36\u0001\u0000\u0000\u0000"+
		"\u1a39\u1a54\u0005t\u0000\u0000\u1a3a\u1a3b\u0005\u0017\u0000\u0000\u1a3b"+
		"\u1a3c\u0005\u046d\u0000\u0000\u1a3c\u1a3d\u0003\u02b0\u0158\u0000\u1a3d"+
		"\u1a3e\u0005\f\u0000\u0000\u1a3e\u1a3f\u0003\u0260\u0130\u0000\u1a3f\u1a40"+
		"\u0005\u046e\u0000\u0000\u1a40\u1a54\u0001\u0000\u0000\u0000\u1a41\u1a43"+
		"\u0003\u02b6\u015b\u0000\u1a42\u1a41\u0001\u0000\u0000\u0000\u1a42\u1a43"+
		"\u0001\u0000\u0000\u0000\u1a43\u1a44\u0001\u0000\u0000\u0000\u1a44\u1a54"+
		"\u0003\u025a\u012d\u0000\u1a45\u1a49\u0003\u027c\u013e\u0000\u1a46\u1a47"+
		"\u0005v\u0000\u0000\u1a47\u1a48\u0005\u00b8\u0000\u0000\u1a48\u1a4a\u0003"+
		"\u027c\u013e\u0000\u1a49\u1a46\u0001\u0000\u0000\u0000\u1a49\u1a4a\u0001"+
		"\u0000\u0000\u0000\u1a4a\u1a54\u0001\u0000\u0000\u0000\u1a4b\u1a4c\u0005"+
		"\u046d\u0000\u0000\u1a4c\u1a4d\u0003\u02b0\u0158\u0000\u1a4d\u1a4e\u0005"+
		"\u046e\u0000\u0000\u1a4e\u1a54\u0001\u0000\u0000\u0000\u1a4f\u1a50\u0005"+
		"\u046d\u0000\u0000\u1a50\u1a51\u0003\u0226\u0113\u0000\u1a51\u1a52\u0005"+
		"\u046e\u0000\u0000\u1a52\u1a54\u0001\u0000\u0000\u0000\u1a53\u1a39\u0001"+
		"\u0000\u0000\u0000\u1a53\u1a3a\u0001\u0000\u0000\u0000\u1a53\u1a42\u0001"+
		"\u0000\u0000\u0000\u1a53\u1a45\u0001\u0000\u0000\u0000\u1a53\u1a4b\u0001"+
		"\u0000\u0000\u0000\u1a53\u1a4f\u0001\u0000\u0000\u0000\u1a54\u027b\u0001"+
		"\u0000\u0000\u0000\u1a55\u1a5b\u0007s\u0000\u0000\u1a56\u1a58\u0005\u046d"+
		"\u0000\u0000\u1a57\u1a59\u0003\u024e\u0127\u0000\u1a58\u1a57\u0001\u0000"+
		"\u0000\u0000\u1a58\u1a59\u0001\u0000\u0000\u0000\u1a59\u1a5a\u0001\u0000"+
		"\u0000\u0000\u1a5a\u1a5c\u0005\u046e\u0000\u0000\u1a5b\u1a56\u0001\u0000"+
		"\u0000\u0000\u1a5b\u1a5c\u0001\u0000\u0000\u0000\u1a5c\u1a64\u0001\u0000"+
		"\u0000\u0000\u1a5d\u1a5e\u0005\u0143\u0000\u0000\u1a5e\u1a60\u0005\u046d"+
		"\u0000\u0000\u1a5f\u1a61\u0003\u024e\u0127\u0000\u1a60\u1a5f\u0001\u0000"+
		"\u0000\u0000\u1a60\u1a61\u0001\u0000\u0000\u0000\u1a61\u1a62\u0001\u0000"+
		"\u0000\u0000\u1a62\u1a64\u0005\u046e\u0000\u0000\u1a63\u1a55\u0001\u0000"+
		"\u0000\u0000\u1a63\u1a5d\u0001\u0000\u0000\u0000\u1a64\u027d\u0001\u0000"+
		"\u0000\u0000\u1a65\u1a68\u0003\u02b0\u0158\u0000\u1a66\u1a68\u0005*\u0000"+
		"\u0000\u1a67\u1a65\u0001\u0000\u0000\u0000\u1a67\u1a66\u0001\u0000\u0000"+
		"\u0000\u1a68\u027f\u0001\u0000\u0000\u0000\u1a69\u1a6a\u0005M\u0000\u0000"+
		"\u1a6a\u1a6b\u0005<\u0000\u0000\u1a6b\u0281\u0001\u0000\u0000\u0000\u1a6c"+
		"\u1a6d\u0005M\u0000\u0000\u1a6d\u1a6e\u0005r\u0000\u0000\u1a6e\u1a6f\u0005"+
		"<\u0000\u0000\u1a6f\u0283\u0001\u0000\u0000\u0000\u1a70\u1a71\u0005{\u0000"+
		"\u0000\u1a71\u1a72\u0005\u008d\u0000\u0000\u1a72\u0285\u0001\u0000\u0000"+
		"\u0000\u1a73\u1a74\u0005\u02a2\u0000\u0000\u1a74\u1a77\u0003\u024e\u0127"+
		"\u0000\u1a75\u1a77\u0005\u020f\u0000\u0000\u1a76\u1a73\u0001\u0000\u0000"+
		"\u0000\u1a76\u1a75\u0001\u0000\u0000\u0000\u1a77\u0287\u0001\u0000\u0000"+
		"\u0000\u1a78\u1a8b\u0003\u028a\u0145\u0000\u1a79\u1a8b\u0003\u0292\u0149"+
		"\u0000\u1a7a\u1a8b\u0003\u0294\u014a\u0000\u1a7b\u1a7c\u0003\u02a8\u0154"+
		"\u0000\u1a7c\u1a7e\u0005\u046d\u0000\u0000\u1a7d\u1a7f\u0003\u02ac\u0156"+
		"\u0000\u1a7e\u1a7d\u0001\u0000\u0000\u0000\u1a7e\u1a7f\u0001\u0000\u0000"+
		"\u0000\u1a7f\u1a80\u0001\u0000\u0000\u0000\u1a80\u1a81\u0005\u046e\u0000"+
		"\u0000\u1a81\u1a8b\u0001\u0000\u0000\u0000\u1a82\u1a83\u0003\u0226\u0113"+
		"\u0000\u1a83\u1a85\u0005\u046d\u0000\u0000\u1a84\u1a86\u0003\u02ac\u0156"+
		"\u0000\u1a85\u1a84\u0001\u0000\u0000\u0000\u1a85\u1a86\u0001\u0000\u0000"+
		"\u0000\u1a86\u1a87\u0001\u0000\u0000\u0000\u1a87\u1a88\u0005\u046e\u0000"+
		"\u0000\u1a88\u1a8b\u0001\u0000\u0000\u0000\u1a89\u1a8b\u0003\u02aa\u0155"+
		"\u0000\u1a8a\u1a78\u0001\u0000\u0000\u0000\u1a8a\u1a79\u0001\u0000\u0000"+
		"\u0000\u1a8a\u1a7a\u0001\u0000\u0000\u0000\u1a8a\u1a7b\u0001\u0000\u0000"+
		"\u0000\u1a8a\u1a82\u0001\u0000\u0000\u0000\u1a8a\u1a89\u0001\u0000\u0000"+
		"\u0000\u1a8b\u0289\u0001\u0000\u0000\u0000\u1a8c\u1a8f\u0007t\u0000\u0000"+
		"\u1a8d\u1a8e\u0005\u046d\u0000\u0000\u1a8e\u1a90\u0005\u046e\u0000\u0000"+
		"\u1a8f\u1a8d\u0001\u0000\u0000\u0000\u1a8f\u1a90\u0001\u0000\u0000\u0000"+
		"\u1a90\u1b40\u0001\u0000\u0000\u0000\u1a91\u1b40\u0003>\u001f\u0000\u1a92"+
		"\u1a93\u0005 \u0000\u0000\u1a93\u1a94\u0005\u046d\u0000\u0000\u1a94\u1a95"+
		"\u0003\u02b0\u0158\u0000\u1a95\u1a96\u0005\u046f\u0000\u0000\u1a96\u1a97"+
		"\u0003\u0260\u0130\u0000\u1a97\u1a98\u0005\u046e\u0000\u0000\u1a98\u1b40"+
		"\u0001\u0000\u0000\u0000\u1a99\u1a9a\u0005 \u0000\u0000\u1a9a\u1a9b\u0005"+
		"\u046d\u0000\u0000\u1a9b\u1a9c\u0003\u02b0";
	private static final String _serializedATNSegment3 =
		"\u0158\u0000\u1a9c\u1a9d\u0005\u00bb\u0000\u0000\u1a9d\u1a9e\u0003\u0238"+
		"\u011c\u0000\u1a9e\u1a9f\u0005\u046e\u0000\u0000\u1a9f\u1b40\u0001\u0000"+
		"\u0000\u0000\u1aa0\u1aa1\u0005\u0017\u0000\u0000\u1aa1\u1aa2\u0005\u046d"+
		"\u0000\u0000\u1aa2\u1aa3\u0003\u02b0\u0158\u0000\u1aa3\u1aa4\u0005\f\u0000"+
		"\u0000\u1aa4\u1aa5\u0003\u0260\u0130\u0000\u1aa5\u1aa6\u0005\u046e\u0000"+
		"\u0000\u1aa6\u1b40\u0001\u0000\u0000\u0000\u1aa7\u1aa8\u0005\u00bc\u0000"+
		"\u0000\u1aa8\u1aa9\u0005\u046d\u0000\u0000\u1aa9\u1aaa\u0003\u022c\u0116"+
		"\u0000\u1aaa\u1aab\u0005\u046e\u0000\u0000\u1aab\u1b40\u0001\u0000\u0000"+
		"\u0000\u1aac\u1aad\u0005\u0016\u0000\u0000\u1aad\u1aaf\u0003\u02b0\u0158"+
		"\u0000\u1aae\u1ab0\u0003\u028c\u0146\u0000\u1aaf\u1aae\u0001\u0000\u0000"+
		"\u0000\u1ab0\u1ab1\u0001\u0000\u0000\u0000\u1ab1\u1aaf\u0001\u0000\u0000"+
		"\u0000\u1ab1\u1ab2\u0001\u0000\u0000\u0000\u1ab2\u1ab5\u0001\u0000\u0000"+
		"\u0000\u1ab3\u1ab4\u00055\u0000\u0000\u1ab4\u1ab6\u0003\u02ae\u0157\u0000"+
		"\u1ab5\u1ab3\u0001\u0000\u0000\u0000\u1ab5\u1ab6\u0001\u0000\u0000\u0000"+
		"\u1ab6\u1ab7\u0001\u0000\u0000\u0000\u1ab7\u1ab8\u0005\u0197\u0000\u0000"+
		"\u1ab8\u1b40\u0001\u0000\u0000\u0000\u1ab9\u1abb\u0005\u0016\u0000\u0000"+
		"\u1aba\u1abc\u0003\u028c\u0146\u0000\u1abb\u1aba\u0001\u0000\u0000\u0000"+
		"\u1abc\u1abd\u0001\u0000\u0000\u0000\u1abd\u1abb\u0001\u0000\u0000\u0000"+
		"\u1abd\u1abe\u0001\u0000\u0000\u0000\u1abe\u1ac1\u0001\u0000\u0000\u0000"+
		"\u1abf\u1ac0\u00055\u0000\u0000\u1ac0\u1ac2\u0003\u02ae\u0157\u0000\u1ac1"+
		"\u1abf\u0001\u0000\u0000\u0000\u1ac1\u1ac2\u0001\u0000\u0000\u0000\u1ac2"+
		"\u1ac3\u0001\u0000\u0000\u0000\u1ac3\u1ac4\u0005\u0197\u0000\u0000\u1ac4"+
		"\u1b40\u0001\u0000\u0000\u0000\u1ac5\u1ac6\u0005\u00de\u0000\u0000\u1ac6"+
		"\u1ac7\u0005\u046d\u0000\u0000\u1ac7\u1aca\u0003\u02ac\u0156\u0000\u1ac8"+
		"\u1ac9\u0005\u00bb\u0000\u0000\u1ac9\u1acb\u0003\u0238\u011c\u0000\u1aca"+
		"\u1ac8\u0001\u0000\u0000\u0000\u1aca\u1acb\u0001\u0000\u0000\u0000\u1acb"+
		"\u1acc\u0001\u0000\u0000\u0000\u1acc\u1acd\u0005\u046e\u0000\u0000\u1acd"+
		"\u1b40\u0001\u0000\u0000\u0000\u1ace\u1acf\u0005\u0144\u0000\u0000\u1acf"+
		"\u1ad2\u0005\u046d\u0000\u0000\u1ad0\u1ad3\u0003\u0252\u0129\u0000\u1ad1"+
		"\u1ad3\u0003\u02b0\u0158\u0000\u1ad2\u1ad0\u0001\u0000\u0000\u0000\u1ad2"+
		"\u1ad1\u0001\u0000\u0000\u0000\u1ad3\u1ad4\u0001\u0000\u0000\u0000\u1ad4"+
		"\u1ad7\u0005P\u0000\u0000\u1ad5\u1ad8\u0003\u0252\u0129\u0000\u1ad6\u1ad8"+
		"\u0003\u02b0\u0158\u0000\u1ad7\u1ad5\u0001\u0000\u0000\u0000\u1ad7\u1ad6"+
		"\u0001\u0000\u0000\u0000\u1ad8\u1ad9\u0001\u0000\u0000\u0000\u1ad9\u1ada"+
		"\u0005\u046e\u0000\u0000\u1ada\u1b40\u0001\u0000\u0000\u0000\u1adb\u1adc"+
		"\u0007u\u0000\u0000\u1adc\u1adf\u0005\u046d\u0000\u0000\u1add\u1ae0\u0003"+
		"\u0252\u0129\u0000\u1ade\u1ae0\u0003\u02b0\u0158\u0000\u1adf\u1add\u0001"+
		"\u0000\u0000\u0000\u1adf\u1ade\u0001\u0000\u0000\u0000\u1ae0\u1ae1\u0001"+
		"\u0000\u0000\u0000\u1ae1\u1ae4\u0005D\u0000\u0000\u1ae2\u1ae5\u0003\u024e"+
		"\u0127\u0000\u1ae3\u1ae5\u0003\u02b0\u0158\u0000\u1ae4\u1ae2\u0001\u0000"+
		"\u0000\u0000\u1ae4\u1ae3\u0001\u0000\u0000\u0000\u1ae5\u1aeb\u0001\u0000"+
		"\u0000\u0000\u1ae6\u1ae9\u0005A\u0000\u0000\u1ae7\u1aea\u0003\u024e\u0127"+
		"\u0000\u1ae8\u1aea\u0003\u02b0\u0158\u0000\u1ae9\u1ae7\u0001\u0000\u0000"+
		"\u0000\u1ae9\u1ae8\u0001\u0000\u0000\u0000\u1aea\u1aec\u0001\u0000\u0000"+
		"\u0000\u1aeb\u1ae6\u0001\u0000\u0000\u0000\u1aeb\u1aec\u0001\u0000\u0000"+
		"\u0000\u1aec\u1aed\u0001\u0000\u0000\u0000\u1aed\u1aee\u0005\u046e\u0000"+
		"\u0000\u1aee\u1b40\u0001\u0000\u0000\u0000\u1aef\u1af0\u0005\u0148\u0000"+
		"\u0000\u1af0\u1af1\u0005\u046d\u0000\u0000\u1af1\u1af4\u0007v\u0000\u0000"+
		"\u1af2\u1af5\u0003\u0252\u0129\u0000\u1af3\u1af5\u0003\u02b0\u0158\u0000"+
		"\u1af4\u1af2\u0001\u0000\u0000\u0000\u1af4\u1af3\u0001\u0000\u0000\u0000"+
		"\u1af4\u1af5\u0001\u0000\u0000\u0000\u1af5\u1af6\u0001\u0000\u0000\u0000"+
		"\u1af6\u1af9\u0005D\u0000\u0000\u1af7\u1afa\u0003\u0252\u0129\u0000\u1af8"+
		"\u1afa\u0003\u02b0\u0158\u0000\u1af9\u1af7\u0001\u0000\u0000\u0000\u1af9"+
		"\u1af8\u0001\u0000\u0000\u0000\u1afa\u1afb\u0001\u0000\u0000\u0000\u1afb"+
		"\u1afc\u0005\u046e\u0000\u0000\u1afc\u1b40\u0001\u0000\u0000\u0000\u1afd"+
		"\u1afe\u0005\u0148\u0000\u0000\u1afe\u1b01\u0005\u046d\u0000\u0000\u1aff"+
		"\u1b02\u0003\u0252\u0129\u0000\u1b00\u1b02\u0003\u02b0\u0158\u0000\u1b01"+
		"\u1aff\u0001\u0000\u0000\u0000\u1b01\u1b00\u0001\u0000\u0000\u0000\u1b02"+
		"\u1b03\u0001\u0000\u0000\u0000\u1b03\u1b06\u0005D\u0000\u0000\u1b04\u1b07"+
		"\u0003\u0252\u0129\u0000\u1b05\u1b07\u0003\u02b0\u0158\u0000\u1b06\u1b04"+
		"\u0001\u0000\u0000\u0000\u1b06\u1b05\u0001\u0000\u0000\u0000\u1b07\u1b08"+
		"\u0001\u0000\u0000\u0000\u1b08\u1b09\u0005\u046e\u0000\u0000\u1b09\u1b40"+
		"\u0001\u0000\u0000\u0000\u1b0a\u1b0b\u0005\u044f\u0000\u0000\u1b0b\u1b0e"+
		"\u0005\u046d\u0000\u0000\u1b0c\u1b0f\u0003\u0252\u0129\u0000\u1b0d\u1b0f"+
		"\u0003\u02b0\u0158\u0000\u1b0e\u1b0c\u0001\u0000\u0000\u0000\u1b0e\u1b0d"+
		"\u0001\u0000\u0000\u0000\u1b0f\u1b16\u0001\u0000\u0000\u0000\u1b10\u1b11"+
		"\u0005\f\u0000\u0000\u1b11\u1b12\u0007w\u0000\u0000\u1b12\u1b13\u0005"+
		"\u046d\u0000\u0000\u1b13\u1b14\u0003\u024e\u0127\u0000\u1b14\u1b15\u0005"+
		"\u046e\u0000\u0000\u1b15\u1b17\u0001\u0000\u0000\u0000\u1b16\u1b10\u0001"+
		"\u0000\u0000\u0000\u1b16\u1b17\u0001\u0000\u0000\u0000\u1b17\u1b19\u0001"+
		"\u0000\u0000\u0000\u1b18\u1b1a\u0003\u028e\u0147\u0000\u1b19\u1b18\u0001"+
		"\u0000\u0000\u0000\u1b19\u1b1a\u0001\u0000\u0000\u0000\u1b1a\u1b1b\u0001"+
		"\u0000\u0000\u0000\u1b1b\u1b1c\u0005\u046e\u0000\u0000\u1b1c\u1b40\u0001"+
		"\u0000\u0000\u0000\u1b1d\u1b1e\u0005\u0141\u0000\u0000\u1b1e\u1b1f\u0005"+
		"\u046d\u0000\u0000\u1b1f\u1b20\u0003H$\u0000\u1b20\u1b23\u0005D\u0000"+
		"\u0000\u1b21\u1b24\u0003\u0252\u0129\u0000\u1b22\u1b24\u0003\u02b0\u0158"+
		"\u0000\u1b23\u1b21\u0001\u0000\u0000\u0000\u1b23\u1b22\u0001\u0000\u0000"+
		"\u0000\u1b24\u1b25\u0001\u0000\u0000\u0000\u1b25\u1b26\u0005\u046e\u0000"+
		"\u0000\u1b26\u1b40\u0001\u0000\u0000\u0000\u1b27\u1b28\u0005\u0384\u0000"+
		"\u0000\u1b28\u1b29\u0005\u046d\u0000\u0000\u1b29\u1b2a\u0007x\u0000\u0000"+
		"\u1b2a\u1b2b\u0005\u046f\u0000\u0000\u1b2b\u1b2c\u0003\u0252\u0129\u0000"+
		"\u1b2c\u1b2d\u0005\u046e\u0000\u0000\u1b2d\u1b40\u0001\u0000\u0000\u0000"+
		"\u1b2e\u1b2f\u0005\u011a\u0000\u0000\u1b2f\u1b30\u0005\u046d\u0000\u0000"+
		"\u1b30\u1b31\u0003\u02b0\u0158\u0000\u1b31\u1b32\u0005\u046f\u0000\u0000"+
		"\u1b32\u1b35\u0003\u02b0\u0158\u0000\u1b33\u1b34\u0005\u0251\u0000\u0000"+
		"\u1b34\u1b36\u0003\u0260\u0130\u0000\u1b35\u1b33\u0001\u0000\u0000\u0000"+
		"\u1b35\u1b36\u0001\u0000\u0000\u0000\u1b36\u1b38\u0001\u0000\u0000\u0000"+
		"\u1b37\u1b39\u0003\u010c\u0086\u0000\u1b38\u1b37\u0001\u0000\u0000\u0000"+
		"\u1b38\u1b39\u0001\u0000\u0000\u0000\u1b39\u1b3b\u0001\u0000\u0000\u0000"+
		"\u1b3a\u1b3c\u0003\u010e\u0087\u0000\u1b3b\u1b3a\u0001\u0000\u0000\u0000"+
		"\u1b3b\u1b3c\u0001\u0000\u0000\u0000\u1b3c\u1b3d\u0001\u0000\u0000\u0000"+
		"\u1b3d\u1b3e\u0005\u046e\u0000\u0000\u1b3e\u1b40\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1a8c\u0001\u0000\u0000\u0000\u1b3f\u1a91\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1a92\u0001\u0000\u0000\u0000\u1b3f\u1a99\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1aa0\u0001\u0000\u0000\u0000\u1b3f\u1aa7\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1aac\u0001\u0000\u0000\u0000\u1b3f\u1ab9\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1ac5\u0001\u0000\u0000\u0000\u1b3f\u1ace\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1adb\u0001\u0000\u0000\u0000\u1b3f\u1aef\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1afd\u0001\u0000\u0000\u0000\u1b3f\u1b0a\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1b1d\u0001\u0000\u0000\u0000\u1b3f\u1b27\u0001\u0000\u0000\u0000"+
		"\u1b3f\u1b2e\u0001\u0000\u0000\u0000\u1b40\u028b\u0001\u0000\u0000\u0000"+
		"\u1b41\u1b42\u0005\u00bd\u0000\u0000\u1b42\u1b43\u0003\u02ae\u0157\u0000"+
		"\u1b43\u1b44\u0005\u00ae\u0000\u0000\u1b44\u1b45\u0003\u02ae\u0157\u0000"+
		"\u1b45\u028d\u0001\u0000\u0000\u0000\u1b46\u1b47\u0005\u01d8\u0000\u0000"+
		"\u1b47\u1b4c\u0003\u0290\u0148\u0000\u1b48\u1b49\u0005\u046f\u0000\u0000"+
		"\u1b49\u1b4b\u0003\u0290\u0148\u0000\u1b4a\u1b48\u0001\u0000\u0000\u0000"+
		"\u1b4b\u1b4e\u0001\u0000\u0000\u0000\u1b4c\u1b4a\u0001\u0000\u0000\u0000"+
		"\u1b4c\u1b4d\u0001\u0000\u0000\u0000\u1b4d\u1b55\u0001\u0000\u0000\u0000"+
		"\u1b4e\u1b4c\u0001\u0000\u0000\u0000\u1b4f\u1b50\u0005\u01d8\u0000\u0000"+
		"\u1b50\u1b51\u0003\u024e\u0127\u0000\u1b51\u1b52\u0005\u0461\u0000\u0000"+
		"\u1b52\u1b53\u0003\u024e\u0127\u0000\u1b53\u1b55\u0001\u0000\u0000\u0000"+
		"\u1b54\u1b46\u0001\u0000\u0000\u0000\u1b54\u1b4f\u0001\u0000\u0000\u0000"+
		"\u1b55\u028f\u0001\u0000\u0000\u0000\u1b56\u1b58\u0003\u024e\u0127\u0000"+
		"\u1b57\u1b59\u0007y\u0000\u0000\u1b58\u1b57\u0001\u0000\u0000\u0000\u1b58"+
		"\u1b59\u0001\u0000\u0000\u0000\u1b59\u0291\u0001\u0000\u0000\u0000\u1b5a"+
		"\u1b5b\u0007z\u0000\u0000\u1b5b\u1b5d\u0005\u046d\u0000\u0000\u1b5c\u1b5e"+
		"\u0007,\u0000\u0000\u1b5d\u1b5c\u0001\u0000\u0000\u0000\u1b5d\u1b5e\u0001"+
		"\u0000\u0000\u0000\u1b5e\u1b5f\u0001\u0000\u0000\u0000\u1b5f\u1b60\u0003"+
		"\u02ae\u0157\u0000\u1b60\u1b62\u0005\u046e\u0000\u0000\u1b61\u1b63\u0003"+
		"\u0296\u014b\u0000\u1b62\u1b61\u0001\u0000\u0000\u0000\u1b62\u1b63\u0001"+
		"\u0000\u0000\u0000\u1b63\u1b96\u0001\u0000\u0000\u0000\u1b64\u1b65\u0005"+
		"\u0122\u0000\u0000\u1b65\u1b6d\u0005\u046d\u0000\u0000\u1b66\u1b6e\u0005"+
		"\u045d\u0000\u0000\u1b67\u1b69\u0005\u0006\u0000\u0000\u1b68\u1b67\u0001"+
		"\u0000\u0000\u0000\u1b68\u1b69\u0001\u0000\u0000\u0000\u1b69\u1b6a\u0001"+
		"\u0000\u0000\u0000\u1b6a\u1b6e\u0003\u02ae\u0157\u0000\u1b6b\u1b6c\u0005"+
		"1\u0000\u0000\u1b6c\u1b6e\u0003\u02ac\u0156\u0000\u1b6d\u1b66\u0001\u0000"+
		"\u0000\u0000\u1b6d\u1b68\u0001\u0000\u0000\u0000\u1b6d\u1b6b\u0001\u0000"+
		"\u0000\u0000\u1b6e\u1b6f\u0001\u0000\u0000\u0000\u1b6f\u1b71\u0005\u046e"+
		"\u0000\u0000\u1b70\u1b72\u0003\u0296\u014b\u0000\u1b71\u1b70\u0001\u0000"+
		"\u0000\u0000\u1b71\u1b72\u0001\u0000\u0000\u0000\u1b72\u1b96\u0001\u0000"+
		"\u0000\u0000\u1b73\u1b74\u0007{\u0000\u0000\u1b74\u1b76\u0005\u046d\u0000"+
		"\u0000\u1b75\u1b77\u0005\u0006\u0000\u0000\u1b76\u1b75\u0001\u0000\u0000"+
		"\u0000\u1b76\u1b77\u0001\u0000\u0000\u0000\u1b77\u1b78\u0001\u0000\u0000"+
		"\u0000\u1b78\u1b79\u0003\u02ae\u0157\u0000\u1b79\u1b7b\u0005\u046e\u0000"+
		"\u0000\u1b7a\u1b7c\u0003\u0296\u014b\u0000\u1b7b\u1b7a\u0001\u0000\u0000"+
		"\u0000\u1b7b\u1b7c\u0001\u0000\u0000\u0000\u1b7c\u1b96\u0001\u0000\u0000"+
		"\u0000\u1b7d\u1b7e\u0005\u0126\u0000\u0000\u1b7e\u1b80\u0005\u046d\u0000"+
		"\u0000\u1b7f\u1b81\u00051\u0000\u0000\u1b80\u1b7f\u0001\u0000\u0000\u0000"+
		"\u1b80\u1b81\u0001\u0000\u0000\u0000\u1b81\u1b82\u0001\u0000\u0000\u0000"+
		"\u1b82\u1b8d\u0003\u02ac\u0156\u0000\u1b83\u1b84\u0005|\u0000\u0000\u1b84"+
		"\u1b85\u0005\u0013\u0000\u0000\u1b85\u1b8a\u0003\u00e8t\u0000\u1b86\u1b87"+
		"\u0005\u046f\u0000\u0000\u1b87\u1b89\u0003\u00e8t\u0000\u1b88\u1b86\u0001"+
		"\u0000\u0000\u0000\u1b89\u1b8c\u0001\u0000\u0000\u0000\u1b8a\u1b88\u0001"+
		"\u0000\u0000\u0000\u1b8a\u1b8b\u0001\u0000\u0000\u0000\u1b8b\u1b8e\u0001"+
		"\u0000\u0000\u0000\u1b8c\u1b8a\u0001\u0000\u0000\u0000\u1b8d\u1b83\u0001"+
		"\u0000\u0000\u0000\u1b8d\u1b8e\u0001\u0000\u0000\u0000\u1b8e\u1b91\u0001"+
		"\u0000\u0000\u0000\u1b8f\u1b90\u0005\u009a\u0000\u0000\u1b90\u1b92\u0005"+
		"\u047c\u0000\u0000\u1b91\u1b8f\u0001\u0000\u0000\u0000\u1b91\u1b92\u0001"+
		"\u0000\u0000\u0000\u1b92\u1b93\u0001\u0000\u0000\u0000\u1b93\u1b94\u0005"+
		"\u046e\u0000\u0000\u1b94\u1b96\u0001\u0000\u0000\u0000\u1b95\u1b5a\u0001"+
		"\u0000\u0000\u0000\u1b95\u1b64\u0001\u0000\u0000\u0000\u1b95\u1b73\u0001"+
		"\u0000\u0000\u0000\u1b95\u1b7d\u0001\u0000\u0000\u0000\u1b96\u0293\u0001"+
		"\u0000\u0000\u0000\u1b97\u1b98\u0007|\u0000\u0000\u1b98\u1b99\u0005\u046d"+
		"\u0000\u0000\u1b99\u1b9c\u0003\u02b0\u0158\u0000\u1b9a\u1b9b\u0005\u046f"+
		"\u0000\u0000\u1b9b\u1b9d\u0003\u024e\u0127\u0000\u1b9c\u1b9a\u0001\u0000"+
		"\u0000\u0000\u1b9c\u1b9d\u0001\u0000\u0000\u0000\u1b9d\u1ba0\u0001\u0000"+
		"\u0000\u0000\u1b9e\u1b9f\u0005\u046f\u0000\u0000\u1b9f\u1ba1\u0003\u024e"+
		"\u0127\u0000\u1ba0\u1b9e\u0001\u0000\u0000\u0000\u1ba0\u1ba1\u0001\u0000"+
		"\u0000\u0000\u1ba1\u1ba2\u0001\u0000\u0000\u0000\u1ba2\u1ba3\u0005\u046e"+
		"\u0000\u0000\u1ba3\u1ba4\u0003\u0296\u014b\u0000\u1ba4\u1bbe\u0001\u0000"+
		"\u0000\u0000\u1ba5\u1ba6\u0007}\u0000\u0000\u1ba6\u1ba7\u0005\u046d\u0000"+
		"\u0000\u1ba7\u1ba8\u0003\u02b0\u0158\u0000\u1ba8\u1ba9\u0005\u046e\u0000"+
		"\u0000\u1ba9\u1baa\u0003\u0296\u014b\u0000\u1baa\u1bbe\u0001\u0000\u0000"+
		"\u0000\u1bab\u1bac\u0007~\u0000\u0000\u1bac\u1bad\u0005\u046d\u0000\u0000"+
		"\u1bad\u1bae\u0005\u046e\u0000\u0000\u1bae\u1bbe\u0003\u0296\u014b\u0000"+
		"\u1baf\u1bb0\u0005\u012d\u0000\u0000\u1bb0\u1bb1\u0005\u046d\u0000\u0000"+
		"\u1bb1\u1bb2\u0003\u02b0\u0158\u0000\u1bb2\u1bb3\u0005\u046f\u0000\u0000"+
		"\u1bb3\u1bb4\u0003\u024e\u0127\u0000\u1bb4\u1bb5\u0005\u046e\u0000\u0000"+
		"\u1bb5\u1bb6\u0003\u0296\u014b\u0000\u1bb6\u1bbe\u0001\u0000\u0000\u0000"+
		"\u1bb7\u1bb8\u0005\u012c\u0000\u0000\u1bb8\u1bb9\u0005\u046d\u0000\u0000"+
		"\u1bb9\u1bba\u0003\u024e\u0127\u0000\u1bba\u1bbb\u0005\u046e\u0000\u0000"+
		"\u1bbb\u1bbc\u0003\u0296\u014b\u0000\u1bbc\u1bbe\u0001\u0000\u0000\u0000"+
		"\u1bbd\u1b97\u0001\u0000\u0000\u0000\u1bbd\u1ba5\u0001\u0000\u0000\u0000"+
		"\u1bbd\u1bab\u0001\u0000\u0000\u0000\u1bbd\u1baf\u0001\u0000\u0000\u0000"+
		"\u1bbd\u1bb7\u0001\u0000\u0000\u0000\u1bbe\u0295\u0001\u0000\u0000\u0000"+
		"\u1bbf\u1bc5\u0005\u0080\u0000\u0000\u1bc0\u1bc1\u0005\u046d\u0000\u0000"+
		"\u1bc1\u1bc2\u0003\u0298\u014c\u0000\u1bc2\u1bc3\u0005\u046e\u0000\u0000"+
		"\u1bc3\u1bc6\u0001\u0000\u0000\u0000\u1bc4\u1bc6\u0003\u029a\u014d\u0000"+
		"\u1bc5\u1bc0\u0001\u0000\u0000\u0000\u1bc5\u1bc4\u0001\u0000\u0000\u0000"+
		"\u1bc6\u0297\u0001\u0000\u0000\u0000\u1bc7\u1bc9\u0003\u029a\u014d\u0000"+
		"\u1bc8\u1bc7\u0001\u0000\u0000\u0000\u1bc8\u1bc9\u0001\u0000\u0000\u0000"+
		"\u1bc9\u1bcb\u0001\u0000\u0000\u0000\u1bca\u1bcc\u0003\u02a6\u0153\u0000"+
		"\u1bcb\u1bca\u0001\u0000\u0000\u0000\u1bcb\u1bcc\u0001\u0000\u0000\u0000"+
		"\u1bcc\u1bce\u0001\u0000\u0000\u0000\u1bcd\u1bcf\u0003\u00e6s\u0000\u1bce"+
		"\u1bcd\u0001\u0000\u0000\u0000\u1bce\u1bcf\u0001\u0000\u0000\u0000\u1bcf"+
		"\u1bd1\u0001\u0000\u0000\u0000\u1bd0\u1bd2\u0003\u029c\u014e\u0000\u1bd1"+
		"\u1bd0\u0001\u0000\u0000\u0000\u1bd1\u1bd2\u0001\u0000\u0000\u0000\u1bd2"+
		"\u0299\u0001\u0000\u0000\u0000\u1bd3\u1bd4\u0003\u0248\u0124\u0000\u1bd4"+
		"\u029b\u0001\u0000\u0000\u0000\u1bd5\u1bd6\u0003\u029e\u014f\u0000\u1bd6"+
		"\u1bd7\u0003\u02a0\u0150\u0000\u1bd7\u029d\u0001\u0000\u0000\u0000\u1bd8"+
		"\u1bd9\u0007\u007f\u0000\u0000\u1bd9\u029f\u0001\u0000\u0000\u0000\u1bda"+
		"\u1bdd\u0003\u02a4\u0152\u0000\u1bdb\u1bdd\u0003\u02a2\u0151\u0000\u1bdc"+
		"\u1bda\u0001\u0000\u0000\u0000\u1bdc\u1bdb\u0001\u0000\u0000\u0000\u1bdd"+
		"\u02a1\u0001\u0000\u0000\u0000\u1bde\u1bdf\u0005\u0010\u0000\u0000\u1bdf"+
		"\u1be0\u0003\u02a4\u0152\u0000\u1be0\u1be1\u0005\n\u0000\u0000\u1be1\u1be2"+
		"\u0003\u02a4\u0152\u0000\u1be2\u02a3\u0001\u0000\u0000\u0000\u1be3\u1be4"+
		"\u0005#\u0000\u0000\u1be4\u1beb\u0005\u0258\u0000\u0000\u1be5\u1be6\u0005"+
		"\u0291\u0000\u0000\u1be6\u1beb\u0007\u0080\u0000\u0000\u1be7\u1be8\u0003"+
		"\u02b0\u0158\u0000\u1be8\u1be9\u0007\u0080\u0000\u0000\u1be9\u1beb\u0001"+
		"\u0000\u0000\u0000\u1bea\u1be3\u0001\u0000\u0000\u0000\u1bea\u1be5\u0001"+
		"\u0000\u0000\u0000\u1bea\u1be7\u0001\u0000\u0000\u0000\u1beb\u02a5\u0001"+
		"\u0000\u0000\u0000\u1bec\u1bed\u0005\u0081\u0000\u0000\u1bed\u1bee\u0005"+
		"\u0013\u0000\u0000\u1bee\u1bf3\u0003\u02b0\u0158\u0000\u1bef\u1bf0\u0005"+
		"\u046f\u0000\u0000\u1bf0\u1bf2\u0003\u02b0\u0158\u0000\u1bf1\u1bef\u0001"+
		"\u0000\u0000\u0000\u1bf2\u1bf5\u0001\u0000\u0000\u0000\u1bf3\u1bf1\u0001"+
		"\u0000\u0000\u0000\u1bf3\u1bf4\u0001\u0000\u0000\u0000\u1bf4\u02a7\u0001"+
		"\u0000\u0000\u0000\u1bf5\u1bf3\u0001\u0000\u0000\u0000\u1bf6\u1c0f\u0003"+
		"\u02d0\u0168\u0000\u1bf7\u1c0f\u0005\u02eb\u0000\u0000\u1bf8\u1c0f\u0005"+
		"\u013d\u0000\u0000\u1bf9\u1c0f\u0005\u0139\u0000\u0000\u1bfa\u1c0f\u0005"+
		"\u013a\u0000\u0000\u1bfb\u1c0f\u0005\u013b\u0000\u0000\u1bfc\u1c0f\u0005"+
		"\u013e\u0000\u0000\u1bfd\u1c0f\u0005\u013f\u0000\u0000\u1bfe\u1c0f\u0005"+
		"\u0140\u0000\u0000\u1bff\u1c0f\u0005M\u0000\u0000\u1c00\u1c0f\u0005U\u0000"+
		"\u0000\u1c01\u1c0f\u0005\u013c\u0000\u0000\u1c02\u1c0f\u0005\u0142\u0000"+
		"\u0000\u1c03\u1c0f\u0005\u01fc\u0000\u0000\u1c04\u1c0f\u0005\u0143\u0000"+
		"\u0000\u1c05\u1c0f\u0005\u008c\u0000\u0000\u1c06\u1c0f\u0005\u008d\u0000"+
		"\u0000\u1c07\u1c0f\u0005\u0145\u0000\u0000\u1c08\u1c0f\u0005\u0146\u0000"+
		"\u0000\u1c09\u1c0f\u0005\u0147\u0000\u0000\u1c0a\u1c0f\u0005\u0148\u0000"+
		"\u0000\u1c0b\u1c0f\u0005\u0149\u0000\u0000\u1c0c\u1c0f\u0005\u014a\u0000"+
		"\u0000\u1c0d\u1c0f\u0005\u014b\u0000\u0000\u1c0e\u1bf6\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1bf7\u0001\u0000\u0000\u0000\u1c0e\u1bf8\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1bf9\u0001\u0000\u0000\u0000\u1c0e\u1bfa\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1bfb\u0001\u0000\u0000\u0000\u1c0e\u1bfc\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1bfd\u0001\u0000\u0000\u0000\u1c0e\u1bfe\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1bff\u0001\u0000\u0000\u0000\u1c0e\u1c00\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c01\u0001\u0000\u0000\u0000\u1c0e\u1c02\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c03\u0001\u0000\u0000\u0000\u1c0e\u1c04\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c05\u0001\u0000\u0000\u0000\u1c0e\u1c06\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c07\u0001\u0000\u0000\u0000\u1c0e\u1c08\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c09\u0001\u0000\u0000\u0000\u1c0e\u1c0a\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c0b\u0001\u0000\u0000\u0000\u1c0e\u1c0c\u0001\u0000\u0000"+
		"\u0000\u1c0e\u1c0d\u0001\u0000\u0000\u0000\u1c0f\u02a9\u0001\u0000\u0000"+
		"\u0000\u1c10\u1c11\u0007\u0081\u0000\u0000\u1c11\u1c12\u0005\u046d\u0000"+
		"\u0000\u1c12\u1c13\u0003\u02ae\u0157\u0000\u1c13\u1c14\u0005\u046e\u0000"+
		"\u0000\u1c14\u02ab\u0001\u0000\u0000\u0000\u1c15\u1c1a\u0003\u025a\u012d"+
		"\u0000\u1c16\u1c1a\u0003\u022c\u0116\u0000\u1c17\u1c1a\u0003\u0288\u0144"+
		"\u0000\u1c18\u1c1a\u0003\u02b0\u0158\u0000\u1c19\u1c15\u0001\u0000\u0000"+
		"\u0000\u1c19\u1c16\u0001\u0000\u0000\u0000\u1c19\u1c17\u0001\u0000\u0000"+
		"\u0000\u1c19\u1c18\u0001\u0000\u0000\u0000\u1c1a\u1c24\u0001\u0000\u0000"+
		"\u0000\u1c1b\u1c20\u0005\u046f\u0000\u0000\u1c1c\u1c21\u0003\u025a\u012d"+
		"\u0000\u1c1d\u1c21\u0003\u022c\u0116\u0000\u1c1e\u1c21\u0003\u0288\u0144"+
		"\u0000\u1c1f\u1c21\u0003\u02b0\u0158\u0000\u1c20\u1c1c\u0001\u0000\u0000"+
		"\u0000\u1c20\u1c1d\u0001\u0000\u0000\u0000\u1c20\u1c1e\u0001\u0000\u0000"+
		"\u0000\u1c20\u1c1f\u0001\u0000\u0000\u0000\u1c21\u1c23\u0001\u0000\u0000"+
		"\u0000\u1c22\u1c1b\u0001\u0000\u0000\u0000\u1c23\u1c26\u0001\u0000\u0000"+
		"\u0000\u1c24\u1c22\u0001\u0000\u0000\u0000\u1c24\u1c25\u0001\u0000\u0000"+
		"\u0000\u1c25\u02ad\u0001\u0000\u0000\u0000\u1c26\u1c24\u0001\u0000\u0000"+
		"\u0000\u1c27\u1c2c\u0003\u025a\u012d\u0000\u1c28\u1c2c\u0003\u022c\u0116"+
		"\u0000\u1c29\u1c2c\u0003\u0288\u0144\u0000\u1c2a\u1c2c\u0003\u02b0\u0158"+
		"\u0000\u1c2b\u1c27\u0001\u0000\u0000\u0000\u1c2b\u1c28\u0001\u0000\u0000"+
		"\u0000\u1c2b\u1c29\u0001\u0000\u0000\u0000\u1c2b\u1c2a\u0001\u0000\u0000"+
		"\u0000\u1c2c\u02af\u0001\u0000\u0000\u0000\u1c2d\u1c2e\u0006\u0158\uffff"+
		"\uffff\u0000\u1c2e\u1c2f\u0007\u0082\u0000\u0000\u1c2f\u1c39\u0003\u02b0"+
		"\u0158\u0004\u1c30\u1c31\u0003\u02b2\u0159\u0000\u1c31\u1c33\u0005X\u0000"+
		"\u0000\u1c32\u1c34\u0005r\u0000\u0000\u1c33\u1c32\u0001\u0000\u0000\u0000"+
		"\u1c33\u1c34\u0001\u0000\u0000\u0000\u1c34\u1c35\u0001\u0000\u0000\u0000"+
		"\u1c35\u1c36\u0007\u0083\u0000\u0000\u1c36\u1c39\u0001\u0000\u0000\u0000"+
		"\u1c37\u1c39\u0003\u02b2\u0159\u0000\u1c38\u1c2d\u0001\u0000\u0000\u0000"+
		"\u1c38\u1c30\u0001\u0000\u0000\u0000\u1c38\u1c37\u0001\u0000\u0000\u0000"+
		"\u1c39\u1c40\u0001\u0000\u0000\u0000\u1c3a\u1c3b\n\u0003\u0000\u0000\u1c3b"+
		"\u1c3c\u0003\u02ba\u015d\u0000\u1c3c\u1c3d\u0003\u02b0\u0158\u0004\u1c3d"+
		"\u1c3f\u0001\u0000\u0000\u0000\u1c3e\u1c3a\u0001\u0000\u0000\u0000\u1c3f"+
		"\u1c42\u0001\u0000\u0000\u0000\u1c40\u1c3e\u0001\u0000\u0000\u0000\u1c40"+
		"\u1c41\u0001\u0000\u0000\u0000\u1c41\u02b1\u0001\u0000\u0000\u0000\u1c42"+
		"\u1c40\u0001\u0000\u0000\u0000\u1c43\u1c44\u0006\u0159\uffff\uffff\u0000"+
		"\u1c44\u1c45\u0003\u02b4\u015a\u0000\u1c45\u1c86\u0001\u0000\u0000\u0000"+
		"\u1c46\u1c47\n\b\u0000\u0000\u1c47\u1c48\u0003\u02b8\u015c\u0000\u1c48"+
		"\u1c49\u0003\u02b2\u0159\t\u1c49\u1c85\u0001\u0000\u0000\u0000\u1c4a\u1c4c"+
		"\n\u0006\u0000\u0000\u1c4b\u1c4d\u0005r\u0000\u0000\u1c4c\u1c4b\u0001"+
		"\u0000\u0000\u0000\u1c4c\u1c4d\u0001\u0000\u0000\u0000\u1c4d\u1c4e\u0001"+
		"\u0000\u0000\u0000\u1c4e\u1c4f\u0005\u0010\u0000\u0000\u1c4f\u1c50\u0003"+
		"\u02b2\u0159\u0000\u1c50\u1c51\u0005\n\u0000\u0000\u1c51\u1c52\u0003\u02b2"+
		"\u0159\u0007\u1c52\u1c85\u0001\u0000\u0000\u0000\u1c53\u1c54\n\u0005\u0000"+
		"\u0000\u1c54\u1c55\u0005\u026c\u0000\u0000\u1c55\u1c56\u0005b\u0000\u0000"+
		"\u1c56\u1c85\u0003\u02b2\u0159\u0006\u1c57\u1c59\n\u0003\u0000\u0000\u1c58"+
		"\u1c5a\u0005r\u0000\u0000\u1c59\u1c58\u0001\u0000\u0000\u0000\u1c59\u1c5a"+
		"\u0001\u0000\u0000\u0000\u1c5a\u1c5b\u0001\u0000\u0000\u0000\u1c5b\u1c5c"+
		"\u0007\u0084\u0000\u0000\u1c5c\u1c85\u0003\u02b2\u0159\u0004\u1c5d\u1c5f"+
		"\n\n\u0000\u0000\u1c5e\u1c60\u0005r\u0000\u0000\u1c5f\u1c5e\u0001\u0000"+
		"\u0000\u0000\u1c5f\u1c60\u0001\u0000\u0000\u0000\u1c60\u1c61\u0001\u0000"+
		"\u0000\u0000\u1c61\u1c62\u0005P\u0000\u0000\u1c62\u1c65\u0005\u046d\u0000"+
		"\u0000\u1c63\u1c66\u0003\u00c8d\u0000\u1c64\u1c66\u0003\u0270\u0138\u0000"+
		"\u1c65\u1c63\u0001\u0000\u0000\u0000\u1c65\u1c64\u0001\u0000\u0000\u0000"+
		"\u1c66\u1c67\u0001\u0000\u0000\u0000\u1c67\u1c68\u0005\u046e\u0000\u0000"+
		"\u1c68\u1c85\u0001\u0000\u0000\u0000\u1c69\u1c6a\n\t\u0000\u0000\u1c6a"+
		"\u1c6b\u0005X\u0000\u0000\u1c6b\u1c85\u0003\u0258\u012c\u0000\u1c6c\u1c6d"+
		"\n\u0007\u0000\u0000\u1c6d\u1c6e\u0003\u02b8\u015c\u0000\u1c6e\u1c6f\u0007"+
		"\u0085\u0000\u0000\u1c6f\u1c70\u0005\u046d\u0000\u0000\u1c70\u1c71\u0003"+
		"\u00c8d\u0000\u1c71\u1c72\u0005\u046e\u0000\u0000\u1c72\u1c85\u0001\u0000"+
		"\u0000\u0000\u1c73\u1c75\n\u0004\u0000\u0000\u1c74\u1c76\u0005r\u0000"+
		"\u0000\u1c75\u1c74\u0001\u0000\u0000\u0000\u1c75\u1c76\u0001\u0000\u0000"+
		"\u0000\u1c76\u1c77\u0001\u0000\u0000\u0000\u1c77\u1c78\u0005b\u0000\u0000"+
		"\u1c78\u1c7b\u0003\u02b2\u0159\u0000\u1c79\u1c7a\u0005\u019d\u0000\u0000"+
		"\u1c7a\u1c7c\u0005\u047c\u0000\u0000\u1c7b\u1c79\u0001\u0000\u0000\u0000"+
		"\u1c7b\u1c7c\u0001\u0000\u0000\u0000\u1c7c\u1c85\u0001\u0000\u0000\u0000"+
		"\u1c7d\u1c7e\n\u0002\u0000\u0000\u1c7e\u1c7f\u0005\u01f9\u0000\u0000\u1c7f"+
		"\u1c80\u0005\u0215\u0000\u0000\u1c80\u1c81\u0005\u046d\u0000\u0000\u1c81"+
		"\u1c82\u0003\u02b2\u0159\u0000\u1c82\u1c83\u0005\u046e\u0000\u0000\u1c83"+
		"\u1c85\u0001\u0000\u0000\u0000\u1c84\u1c46\u0001\u0000\u0000\u0000\u1c84"+
		"\u1c4a\u0001\u0000\u0000\u0000\u1c84\u1c53\u0001\u0000\u0000\u0000\u1c84"+
		"\u1c57\u0001\u0000\u0000\u0000\u1c84\u1c5d\u0001\u0000\u0000\u0000\u1c84"+
		"\u1c69\u0001\u0000\u0000\u0000\u1c84\u1c6c\u0001\u0000\u0000\u0000\u1c84"+
		"\u1c73\u0001\u0000\u0000\u0000\u1c84\u1c7d\u0001\u0000\u0000\u0000\u1c85"+
		"\u1c88\u0001\u0000\u0000\u0000\u1c86\u1c84\u0001\u0000\u0000\u0000\u1c86"+
		"\u1c87\u0001\u0000\u0000\u0000\u1c87\u02b3\u0001\u0000\u0000\u0000\u1c88"+
		"\u1c86\u0001\u0000\u0000\u0000\u1c89\u1c8a\u0006\u015a\uffff\uffff\u0000"+
		"\u1c8a\u1cba\u0003\u025a\u012d\u0000\u1c8b\u1cba\u0003\u022c\u0116\u0000"+
		"\u1c8c\u1cba\u0003\u0288\u0144\u0000\u1c8d\u1cba\u0003\u0236\u011b\u0000"+
		"\u1c8e\u1c8f\u0003\u02b6\u015b\u0000\u1c8f\u1c90\u0003\u02b4\u015a\f\u1c90"+
		"\u1cba\u0001\u0000\u0000\u0000\u1c91\u1c92\u0005\u00e2\u0000\u0000\u1c92"+
		"\u1cba\u0003\u02b4\u015a\u000b\u1c93\u1c94\u0005\u0487\u0000\u0000\u1c94"+
		"\u1c95\u0005\u0454\u0000\u0000\u1c95\u1cba\u0003\u02b4\u015a\n\u1c96\u1c97"+
		"\u0005\u046d\u0000\u0000\u1c97\u1c9c\u0003\u02b0\u0158\u0000\u1c98\u1c99"+
		"\u0005\u046f\u0000\u0000\u1c99\u1c9b\u0003\u02b0\u0158\u0000\u1c9a\u1c98"+
		"\u0001\u0000\u0000\u0000\u1c9b\u1c9e\u0001\u0000\u0000\u0000\u1c9c\u1c9a"+
		"\u0001\u0000\u0000\u0000\u1c9c\u1c9d\u0001\u0000\u0000\u0000\u1c9d\u1c9f"+
		"\u0001\u0000\u0000\u0000\u1c9e\u1c9c\u0001\u0000\u0000\u0000\u1c9f\u1ca0"+
		"\u0005\u046e\u0000\u0000\u1ca0\u1cba\u0001\u0000\u0000\u0000\u1ca1\u1ca2"+
		"\u0005\u0258\u0000\u0000\u1ca2\u1ca3\u0005\u046d\u0000\u0000\u1ca3\u1ca6"+
		"\u0003\u02b0\u0158\u0000\u1ca4\u1ca5\u0005\u046f\u0000\u0000\u1ca5\u1ca7"+
		"\u0003\u02b0\u0158\u0000\u1ca6\u1ca4\u0001\u0000\u0000\u0000\u1ca7\u1ca8"+
		"\u0001\u0000\u0000\u0000\u1ca8\u1ca6\u0001\u0000\u0000\u0000\u1ca8\u1ca9"+
		"\u0001\u0000\u0000\u0000\u1ca9\u1caa\u0001\u0000\u0000\u0000\u1caa\u1cab"+
		"\u0005\u046e\u0000\u0000\u1cab\u1cba\u0001\u0000\u0000\u0000\u1cac\u1cad"+
		"\u0005<\u0000\u0000\u1cad\u1cae\u0005\u046d\u0000\u0000\u1cae\u1caf\u0003"+
		"\u00c8d\u0000\u1caf\u1cb0\u0005\u046e\u0000\u0000\u1cb0\u1cba\u0001\u0000"+
		"\u0000\u0000\u1cb1\u1cb2\u0005\u046d\u0000\u0000\u1cb2\u1cb3\u0003\u00c8"+
		"d\u0000\u1cb3\u1cb4\u0005\u046e\u0000\u0000\u1cb4\u1cba\u0001\u0000\u0000"+
		"\u0000\u1cb5\u1cb6\u0005V\u0000\u0000\u1cb6\u1cb7\u0003\u02b0\u0158\u0000"+
		"\u1cb7\u1cb8\u0003H$\u0000\u1cb8\u1cba\u0001\u0000\u0000\u0000\u1cb9\u1c89"+
		"\u0001\u0000\u0000\u0000\u1cb9\u1c8b\u0001\u0000\u0000\u0000\u1cb9\u1c8c"+
		"\u0001\u0000\u0000\u0000\u1cb9\u1c8d\u0001\u0000\u0000\u0000\u1cb9\u1c8e"+
		"\u0001\u0000\u0000\u0000\u1cb9\u1c91\u0001\u0000\u0000\u0000\u1cb9\u1c93"+
		"\u0001\u0000\u0000\u0000\u1cb9\u1c96\u0001\u0000\u0000\u0000\u1cb9\u1ca1"+
		"\u0001\u0000\u0000\u0000\u1cb9\u1cac\u0001\u0000\u0000\u0000\u1cb9\u1cb1"+
		"\u0001\u0000\u0000\u0000\u1cb9\u1cb5\u0001\u0000\u0000\u0000\u1cba\u1cd0"+
		"\u0001\u0000\u0000\u0000\u1cbb\u1cbc\n\u0004\u0000\u0000\u1cbc\u1cbd\u0003"+
		"\u02bc\u015e\u0000\u1cbd\u1cbe\u0003\u02b4\u015a\u0005\u1cbe\u1ccf\u0001"+
		"\u0000\u0000\u0000\u1cbf\u1cc0\n\u0003\u0000\u0000\u1cc0\u1cc1\u0003\u02be"+
		"\u015f\u0000\u1cc1\u1cc2\u0003\u02b4\u015a\u0004\u1cc2\u1ccf\u0001\u0000"+
		"\u0000\u0000\u1cc3\u1cc4\n\u0002\u0000\u0000\u1cc4\u1cc5\u0003\u02c0\u0160"+
		"\u0000\u1cc5\u1cc6\u0003\u02b4\u015a\u0003\u1cc6\u1ccf\u0001\u0000\u0000"+
		"\u0000\u1cc7\u1cc8\n\u0001\u0000\u0000\u1cc8\u1cc9\u0003\u02c2\u0161\u0000"+
		"\u1cc9\u1cca\u0003\u02b4\u015a\u0002\u1cca\u1ccf\u0001\u0000\u0000\u0000"+
		"\u1ccb\u1ccc\n\u000e\u0000\u0000\u1ccc\u1ccd\u0005\u001b\u0000\u0000\u1ccd"+
		"\u1ccf\u0003\u023a\u011d\u0000\u1cce\u1cbb\u0001\u0000\u0000\u0000\u1cce"+
		"\u1cbf\u0001\u0000\u0000\u0000\u1cce\u1cc3\u0001\u0000\u0000\u0000\u1cce"+
		"\u1cc7\u0001\u0000\u0000\u0000\u1cce\u1ccb\u0001\u0000\u0000\u0000\u1ccf"+
		"\u1cd2\u0001\u0000\u0000\u0000\u1cd0\u1cce\u0001\u0000\u0000\u0000\u1cd0"+
		"\u1cd1\u0001\u0000\u0000\u0000\u1cd1\u02b5\u0001\u0000\u0000\u0000\u1cd2"+
		"\u1cd0\u0001\u0000\u0000\u0000\u1cd3\u1cd4\u0007\u0086\u0000\u0000\u1cd4"+
		"\u02b7\u0001\u0000\u0000\u0000\u1cd5\u1ce4\u0005\u0464\u0000\u0000\u1cd6"+
		"\u1ce4\u0005\u0465\u0000\u0000\u1cd7\u1ce4\u0005\u0466\u0000\u0000\u1cd8"+
		"\u1cd9\u0005\u0466\u0000\u0000\u1cd9\u1ce4\u0005\u0464\u0000\u0000\u1cda"+
		"\u1cdb\u0005\u0465\u0000\u0000\u1cdb\u1ce4\u0005\u0464\u0000\u0000\u1cdc"+
		"\u1cdd\u0005\u0466\u0000\u0000\u1cdd\u1ce4\u0005\u0465\u0000\u0000\u1cde"+
		"\u1cdf\u0005\u0467\u0000\u0000\u1cdf\u1ce4\u0005\u0464\u0000\u0000\u1ce0"+
		"\u1ce1\u0005\u0466\u0000\u0000\u1ce1\u1ce2\u0005\u0464\u0000\u0000\u1ce2"+
		"\u1ce4\u0005\u0465\u0000\u0000\u1ce3\u1cd5\u0001\u0000\u0000\u0000\u1ce3"+
		"\u1cd6\u0001\u0000\u0000\u0000\u1ce3\u1cd7\u0001\u0000\u0000\u0000\u1ce3"+
		"\u1cd8\u0001\u0000\u0000\u0000\u1ce3\u1cda\u0001\u0000\u0000\u0000\u1ce3"+
		"\u1cdc\u0001\u0000\u0000\u0000\u1ce3\u1cde\u0001\u0000\u0000\u0000\u1ce3"+
		"\u1ce0\u0001\u0000\u0000\u0000\u1ce4\u02b9\u0001\u0000\u0000\u0000\u1ce5"+
		"\u1ced\u0005\n\u0000\u0000\u1ce6\u1ce7\u0005\u046a\u0000\u0000\u1ce7\u1ced"+
		"\u0005\u046a\u0000\u0000\u1ce8\u1ced\u0005\u00c2\u0000\u0000\u1ce9\u1ced"+
		"\u0005{\u0000\u0000\u1cea\u1ceb\u0005\u0469\u0000\u0000\u1ceb\u1ced\u0005"+
		"\u0469\u0000\u0000\u1cec\u1ce5\u0001\u0000\u0000\u0000\u1cec\u1ce6\u0001"+
		"\u0000\u0000\u0000\u1cec\u1ce8\u0001\u0000\u0000\u0000\u1cec\u1ce9\u0001"+
		"\u0000\u0000\u0000\u1cec\u1cea\u0001\u0000\u0000\u0000\u1ced\u02bb\u0001"+
		"\u0000\u0000\u0000\u1cee\u1cef\u0005\u0466\u0000\u0000\u1cef\u1cf6\u0005"+
		"\u0466\u0000\u0000\u1cf0\u1cf1\u0005\u0465\u0000\u0000\u1cf1\u1cf6\u0005"+
		"\u0465\u0000\u0000\u1cf2\u1cf6\u0005\u046a\u0000\u0000\u1cf3\u1cf6\u0005"+
		"\u046b\u0000\u0000\u1cf4\u1cf6\u0005\u0469\u0000\u0000\u1cf5\u1cee\u0001"+
		"\u0000\u0000\u0000\u1cf5\u1cf0\u0001\u0000\u0000\u0000\u1cf5\u1cf2\u0001"+
		"\u0000\u0000\u0000\u1cf5\u1cf3\u0001\u0000\u0000\u0000\u1cf5\u1cf4\u0001"+
		"\u0000\u0000\u0000\u1cf6\u02bd\u0001\u0000\u0000\u0000\u1cf7\u1cf8\u0007"+
		"\u0087\u0000\u0000\u1cf8\u02bf\u0001\u0000\u0000\u0000\u1cf9\u1cfa\u0007"+
		"\u0088\u0000\u0000\u1cfa\u02c1\u0001\u0000\u0000\u0000\u1cfb\u1cfc\u0005"+
		"\u0461\u0000\u0000\u1cfc\u1d01\u0005\u0465\u0000\u0000\u1cfd\u1cfe\u0005"+
		"\u0461\u0000\u0000\u1cfe\u1cff\u0005\u0465\u0000\u0000\u1cff\u1d01\u0005"+
		"\u0465\u0000\u0000\u1d00\u1cfb\u0001\u0000\u0000\u0000\u1d00\u1cfd\u0001"+
		"\u0000\u0000\u0000\u1d01\u02c3\u0001\u0000\u0000\u0000\u1d02\u1d03\u0007"+
		"\u0089\u0000\u0000\u1d03\u02c5\u0001\u0000\u0000\u0000\u1d04\u1d05\u0007"+
		"\u008a\u0000\u0000\u1d05\u02c7\u0001\u0000\u0000\u0000\u1d06\u1d07\u0007"+
		"\u008b\u0000\u0000\u1d07\u02c9\u0001\u0000\u0000\u0000\u1d08\u1d09\u0007"+
		"\u008c\u0000\u0000\u1d09\u02cb\u0001\u0000\u0000\u0000\u1d0a\u1d0b\u0007"+
		"\u008d\u0000\u0000\u1d0b\u02cd\u0001\u0000\u0000\u0000\u1d0c\u1d0d\u0007"+
		"\u008e\u0000\u0000\u1d0d\u02cf\u0001\u0000\u0000\u0000\u1d0e\u1d0f\u0007"+
		"\u008f\u0000\u0000\u1d0f\u02d1\u0001\u0000\u0000\u0000\u043d\u02d3\u02d7"+
		"\u02de\u02e1\u02e4\u02e6\u02ec\u02ef\u02f2\u02fb\u0325\u0334\u033f\u0350"+
		"\u0355\u0361\u037c\u0385\u038a\u0390\u0395\u0399\u03a2\u03a5\u03a8\u03ac"+
		"\u03b3\u03b6\u03bb\u03c3\u03c8\u03cd\u03d0\u03d2\u03de\u03e1\u03e5\u03e8"+
		"\u03ec\u03ef\u03f3\u03f6\u03f9\u03fd\u0400\u0404\u040a\u0410\u0416\u041d"+
		"\u0424\u0427\u042b\u0430\u0436\u043f\u0444\u0449\u0450\u0461\u0468\u046c"+
		"\u0476\u047a\u047e\u0482\u0486\u048b\u048e\u0491\u0494\u0497\u049d\u04a1"+
		"\u04a7\u04ac\u04af\u04b2\u04b4\u04bf\u04c3\u04c6\u04d4\u04d7\u04db\u04de"+
		"\u04e2\u04e5\u04e9\u04ec\u04f0\u04f3\u04f6\u04fa\u04fd\u0501\u0507\u0514"+
		"\u051a\u0525\u052a\u0532\u053a\u053f\u0542\u0547\u054f\u0554\u055a\u055f"+
		"\u0563\u0565\u0568\u056c\u0570\u0573\u0577\u057b\u057f\u0585\u0588\u058f"+
		"\u0594\u059a\u05a1\u05a7\u05af\u05b2\u05b9\u05bc\u05be\u05c4\u05ca\u05db"+
		"\u05e2\u05e9\u05f5\u05fa\u05fd\u0600\u060d\u061a\u061f\u062f\u0637\u0641"+
		"\u0644\u0647\u064d\u0651\u0654\u065f\u0662\u0667\u0674\u067b\u0682\u0684"+
		"\u068b\u068f\u0691\u0696\u0699\u069f\u06a4\u06a6\u06aa\u06ad\u06b0\u06b6"+
		"\u06bb\u06bd\u06c2\u06c9\u06cb\u06d2\u06d7\u06db\u06de\u06e6\u06ee\u06f0"+
		"\u06fa\u06fe\u0701\u0707\u070c\u070f\u0715\u0718\u071c\u071f\u0723\u0728"+
		"\u072d\u0732\u0736\u073a\u073e\u0742\u0746\u074a\u074f\u0754\u0759\u075f"+
		"\u0764\u0769\u076e\u0773\u0778\u077e\u0783\u0788\u078d\u0792\u0797\u079c"+
		"\u07a1\u07a8\u07ad\u07b2\u07b7\u07bb\u07c0\u07c8\u07cd\u07d3\u07df\u07e6"+
		"\u07e8\u07f0\u07f5\u07f8\u0800\u0806\u080a\u0817\u0823\u0825\u0828\u0830"+
		"\u0836\u083c\u0849\u0850\u0859\u085e\u0869\u0872\u0877\u0883\u088a\u0893"+
		"\u0898\u08a4\u08ab\u08b4\u08b9\u08c0\u08c9\u08ce\u08d0\u08d5\u08dd\u08e6"+
		"\u08ea\u08ed\u08f1\u08f6\u08fc\u0902\u0907\u090c\u0911\u0916\u0919\u091e"+
		"\u0923\u092d\u0931\u0938\u093d\u0940\u0945\u0948\u094c\u0950\u0958\u096b"+
		"\u096e\u0971\u0975\u097f\u098c\u0993\u0996\u099b\u09a2\u09a5\u09a8\u09b3"+
		"\u09b6\u09ba\u09c2\u09c5\u09ca\u09d2\u09d8\u09dc\u09e0\u09e5\u09ea\u09f1"+
		"\u09f5\u0a00\u0a08\u0a0b\u0a11\u0a17\u0a19\u0a1e\u0a21\u0a27\u0a2d\u0a2f"+
		"\u0a33\u0a36\u0a39\u0a3f\u0a45\u0a48\u0a4e\u0a54\u0a56\u0a5b\u0a63\u0a65"+
		"\u0a6e\u0a71\u0a74\u0a79\u0a7b\u0a84\u0a87\u0a8a\u0a8f\u0a91\u0a9a\u0a9f"+
		"\u0aa7\u0aab\u0ab3\u0abd\u0ac2\u0ac9\u0acd\u0ad1\u0ae4\u0aee\u0af4\u0b05"+
		"\u0b09\u0b13\u0b18\u0b1b\u0b24\u0b2f\u0b37\u0b3d\u0b47\u0b53\u0b5a\u0b61"+
		"\u0b70\u0b7d\u0b83\u0b89\u0b8f\u0b95\u0b9b\u0ba1\u0ba6\u0bad\u0bb4\u0bbb"+
		"\u0bc0\u0bc3\u0bc5\u0bd3\u0bda\u0be1\u0be7\u0beb\u0bef\u0bf6\u0bf9\u0bfe"+
		"\u0c05\u0c0c\u0c10\u0c15\u0c1c\u0c29\u0c2c\u0c31\u0c36\u0c3a\u0c40\u0c49"+
		"\u0c52\u0c5b\u0c5e\u0c62\u0c6b\u0c6f\u0c72\u0c75\u0c7b\u0c7e\u0c82\u0c85"+
		"\u0c89\u0c8c\u0c94\u0c97\u0ca2\u0ca5\u0caa\u0cad\u0cb2\u0cbc\u0cc1\u0cc7"+
		"\u0cc9\u0ccf\u0cd1\u0cd7\u0cdf\u0ce4\u0cec\u0cef\u0cf4\u0cf7\u0cfc\u0d04"+
		"\u0d0c\u0d12\u0d1a\u0d1f\u0d27\u0d2a\u0d2e\u0d31\u0d39\u0d3f\u0d48\u0d4b"+
		"\u0d4f\u0d53\u0d57\u0d5c\u0d60\u0d64\u0d66\u0d69\u0d6c\u0d6f\u0d75\u0d79"+
		"\u0d7c\u0d7f\u0d82\u0d85\u0d8c\u0d8e\u0d92\u0d97\u0d9d\u0da2\u0da9\u0daf"+
		"\u0db4\u0db7\u0dbd\u0dc1\u0dc9\u0dcd\u0dd0\u0dd3\u0dd8\u0ddb\u0de2\u0de6"+
		"\u0de9\u0ded\u0df1\u0df4\u0df7\u0dfc\u0e02\u0e06\u0e10\u0e16\u0e1a\u0e20"+
		"\u0e24\u0e2a\u0e2d\u0e39\u0e3d\u0e41\u0e49\u0e4d\u0e55\u0e58\u0e5c\u0e5f"+
		"\u0e67\u0e6c\u0e6f\u0e72\u0e76\u0e79\u0e82\u0e87\u0e90\u0e95\u0e9c\u0ea3"+
		"\u0eab\u0eb1\u0eb9\u0ebc\u0ebf\u0ec6\u0ec9\u0ed0\u0ed3\u0edb\u0ee1\u0eec"+
		"\u0eef\u0ef3\u0ef9\u0f02\u0f07\u0f0b\u0f11\u0f17\u0f19\u0f1d\u0f26\u0f30"+
		"\u0f3a\u0f40\u0f45\u0f49\u0f4c\u0f4f\u0f52\u0f55\u0f5b\u0f61\u0f64\u0f67"+
		"\u0f6a\u0f6d\u0f70\u0f72\u0f78\u0f7e\u0f81\u0f84\u0f87\u0f8a\u0f8e\u0f94"+
		"\u0f98\u0fa0\u0fa4\u0fa7\u0fa9\u0fb6\u0fb9\u0fc0\u0fca\u0fcd\u0fd2\u0fd4"+
		"\u0fd8\u0fe0\u0fe6\u0fef\u0ffc\u1000\u1006\u100f\u1012\u1016\u1019\u101d"+
		"\u1021\u1024\u1026\u102e\u103a\u1040\u1042\u1048\u104a\u104c\u1052\u105a"+
		"\u1062\u1066\u106a\u1073\u1078\u108c\u1091\u1097\u109e\u10a3\u10ac\u10af"+
		"\u10b3\u10b7\u10bb\u10be\u10c1\u10c4\u10c8\u10cc\u10cf\u10d2\u10d5\u10dc"+
		"\u10e0\u10ef\u10f3\u10ff\u1107\u1111\u1115\u1118\u111e\u1121\u1124\u112d"+
		"\u1136\u1140\u1144\u114e\u1158\u1160\u1163\u116c\u116f\u1173\u1178\u117c"+
		"\u1185\u1188\u11a7\u11aa\u11ad\u11e5\u11ea\u1206\u1214\u121b\u121f\u1225"+
		"\u122d\u122f\u123a\u1244\u124b\u1251\u1259\u125e\u1266\u126e\u1276\u127e"+
		"\u1284\u1289\u128e\u1293\u1299\u129b\u12a6\u12ab\u12b2\u12b4\u12c2\u12c8"+
		"\u12cd\u12d2\u12d8\u12df\u12e7\u12ef\u12f4\u12fa\u12fd\u1305\u130c\u1315"+
		"\u1318\u1329\u1331\u1339\u133d\u1344\u134a\u1352\u135b\u1361\u1368\u136f"+
		"\u1374\u1377\u1379\u137f\u1381\u1385\u1387\u138e\u1393\u1397\u139d\u13a6"+
		"\u13ac\u13b3\u13b9\u13bf\u13c4\u13c7\u13c9\u13cf\u13d1\u13d5\u13d7\u13de"+
		"\u13e0\u13e5\u13ec\u13f5\u13fa\u1403\u140a\u140f\u1412\u1414\u141a\u141c"+
		"\u141f\u1427\u142c\u1431\u1435\u143b\u1440\u1444\u144a\u144c\u1457\u145a"+
		"\u1461\u1464\u1470\u1476\u147f\u1488\u148d\u1496\u149c\u14a7\u14ad\u14b2"+
		"\u14b6\u14bc\u14c1\u14c5\u14c8\u14d4\u14db\u14e0\u14fe\u1502\u1507\u150e"+
		"\u1511\u1517\u1521\u152b\u1535\u153b\u1544\u154a\u1551\u1553\u155d\u1561"+
		"\u1565\u156f\u1574\u15bc\u15ce\u15d6\u15e2\u15e9\u15eb\u15f5\u15f8\u1600"+
		"\u1607\u160b\u1612\u1617\u161a\u161d\u1626\u162a\u162e\u1645\u164c\u1650"+
		"\u1657\u165e\u1661\u1671\u1674\u167e\u1682\u1688\u168b\u1690\u1694\u169b"+
		"\u169e\u16a4\u16bc\u16bf\u16cb\u16ce\u16d8\u16e0\u16e4\u16eb\u16ee\u16f7"+
		"\u16fd\u1703\u170d\u170f\u1715\u1718\u171b\u1727\u172a\u1730\u1733\u173b"+
		"\u1743\u1749\u174d\u175b\u1767\u176e\u1771\u1778\u177f\u1784\u1791\u179c"+
		"\u17a2\u17a7\u17b4\u17b6\u17bb\u17bf\u17c2\u17c4\u17cb\u17d2\u17d5\u17d8"+
		"\u17de\u17e2\u17e8\u17ee\u17fb\u1800\u1808\u180b\u1810\u1815\u181d\u1820"+
		"\u1828\u182c\u1833\u1839\u183c\u1840\u184d\u1853\u185f\u1862\u186b\u1870"+
		"\u1876\u187c\u1881\u1883\u1886\u188a\u188c\u1890\u1896\u1899\u189c\u18a2"+
		"\u18ab\u18b3\u18b7\u18bc\u18d0\u18d7\u18d9\u18e0\u18e2\u18e6\u18eb\u18f6"+
		"\u18fb\u1901\u1904\u1908\u190d\u1910\u1914\u1918\u191a\u191f\u1924\u1931"+
		"\u1934\u1938\u193b\u193e\u1943\u1948\u194e\u1951\u1956\u1959\u195e\u1961"+
		"\u1965\u196a\u196f\u1974\u1979\u197c\u1981\u1986\u198b\u1991\u1996\u199b"+
		"\u19a0\u19a4\u19a7\u19ac\u19b0\u19b4\u19bc\u19c3\u19c7\u19cc\u19d1\u19d5"+
		"\u19d7\u19da\u19ea\u19f3\u19fb\u1a03\u1a0c\u1a16\u1a1e\u1a26\u1a2e\u1a36"+
		"\u1a42\u1a49\u1a53\u1a58\u1a5b\u1a60\u1a63\u1a67\u1a76\u1a7e\u1a85\u1a8a"+
		"\u1a8f\u1ab1\u1ab5\u1abd\u1ac1\u1aca\u1ad2\u1ad7\u1adf\u1ae4\u1ae9\u1aeb"+
		"\u1af4\u1af9\u1b01\u1b06\u1b0e\u1b16\u1b19\u1b23\u1b35\u1b38\u1b3b\u1b3f"+
		"\u1b4c\u1b54\u1b58\u1b5d\u1b62\u1b68\u1b6d\u1b71\u1b76\u1b7b\u1b80\u1b8a"+
		"\u1b8d\u1b91\u1b95\u1b9c\u1ba0\u1bbd\u1bc5\u1bc8\u1bcb\u1bce\u1bd1\u1bdc"+
		"\u1bea\u1bf3\u1c0e\u1c19\u1c20\u1c24\u1c2b\u1c33\u1c38\u1c40\u1c4c\u1c59"+
		"\u1c5f\u1c65\u1c75\u1c7b\u1c84\u1c86\u1c9c\u1ca8\u1cb9\u1cce\u1cd0\u1ce3"+
		"\u1cec\u1cf5\u1d00";
	public static final String _serializedATN = Utils.join(
		new String[] {
			_serializedATNSegment0,
			_serializedATNSegment1,
			_serializedATNSegment2,
			_serializedATNSegment3
		},
		""
	);
	public static final ATN _ATN =
		new ATNDeserializer().deserialize(_serializedATN.toCharArray());
	static {
		_decisionToDFA = new DFA[_ATN.getNumberOfDecisions()];
		for (int i = 0; i < _ATN.getNumberOfDecisions(); i++) {
			_decisionToDFA[i] = new DFA(_ATN.getDecisionState(i), i);
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy